diff --git a/.vscode/launch.json b/.vscode/launch.json index eb8e414cf..ffba4697a 100644 --- a/.vscode/launch.json +++ b/.vscode/launch.json @@ -3,7 +3,7 @@ // Hover to view descriptions of existing attributes. // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 "version": "0.2.0", - "configurations": [ + "configurations": [ { "type": "node", "request": "launch", @@ -11,6 +11,14 @@ "program": "${workspaceFolder}/packages/less/test/index.js", "cwd": "${workspaceFolder}/packages/less", "console": "integratedTerminal" + }, + { + "type": "node", + "request": "launch", + "name": "Benchmark test", + "program": "${workspaceFolder}/packages/less/benchmark/index.js", + "cwd": "${workspaceFolder}/packages/less", + "console": "integratedTerminal" } ] } \ No newline at end of file diff --git a/dist/less.js b/dist/less.js index a881ab4b9..e71e5fc5b 100644 --- a/dist/less.js +++ b/dist/less.js @@ -1,5 +1,5 @@ /** - * Less - Leaner CSS v3.13.1 + * Less - Leaner CSS v4.0.0 * http://lesscss.org * * Copyright (c) 2009-2020, Alexis Sellier @@ -9,11267 +9,11264 @@ */ (function (global, factory) { - typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : - typeof define === 'function' && define.amd ? define(factory) : - (global = global || self, global.less = factory()); + typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : + typeof define === 'function' && define.amd ? define(factory) : + (global = global || self, global.less = factory()); }(this, (function () { 'use strict'; - // Export a new default each time - var defaultOptions = (function () { return ({ - /* Inline Javascript - @plugin still allowed */ - javascriptEnabled: false, - /* Outputs a makefile import dependency list to stdout. */ - depends: false, - /* (DEPRECATED) Compress using less built-in compression. - * This does an okay job but does not utilise all the tricks of - * dedicated css compression. */ - compress: false, - /* Runs the less parser and just reports errors without any output. */ - lint: false, - /* Sets available include paths. - * If the file in an @import rule does not exist at that exact location, - * less will look for it at the location(s) passed to this option. - * You might use this for instance to specify a path to a library which - * you want to be referenced simply and relatively in the less files. */ - paths: [], - /* color output in the terminal */ - color: true, - /* The strictImports controls whether the compiler will allow an @import inside of either - * @media blocks or (a later addition) other selector blocks. - * See: https://github.com/less/less.js/issues/656 */ - strictImports: false, - /* Allow Imports from Insecure HTTPS Hosts */ - insecure: false, - /* Allows you to add a path to every generated import and url in your css. - * This does not affect less import statements that are processed, just ones - * that are left in the output css. */ - rootpath: '', - /* By default URLs are kept as-is, so if you import a file in a sub-directory - * that references an image, exactly the same URL will be output in the css. - * This option allows you to re-write URL's in imported files so that the - * URL is always relative to the base imported file */ - rewriteUrls: false, - /* How to process math - * 0 always - eagerly try to solve all operations - * 1 parens-division - require parens for division "/" - * 2 parens | strict - require parens for all operations - * 3 strict-legacy - legacy strict behavior (super-strict) - */ - math: 0, - /* Without this option, less attempts to guess at the output unit when it does maths. */ - strictUnits: false, - /* Effectively the declaration is put at the top of your base Less file, - * meaning it can be used but it also can be overridden if this variable - * is defined in the file. */ - globalVars: null, - /* As opposed to the global variable option, this puts the declaration at the - * end of your base file, meaning it will override anything defined in your Less file. */ - modifyVars: null, - /* This option allows you to specify a argument to go on to every URL. */ - urlArgs: '' - }); }); + // Export a new default each time + function defaultOptions () { + return { + /* Inline Javascript - @plugin still allowed */ + javascriptEnabled: false, + /* Outputs a makefile import dependency list to stdout. */ + depends: false, + /* (DEPRECATED) Compress using less built-in compression. + * This does an okay job but does not utilise all the tricks of + * dedicated css compression. */ + compress: false, + /* Runs the less parser and just reports errors without any output. */ + lint: false, + /* Sets available include paths. + * If the file in an @import rule does not exist at that exact location, + * less will look for it at the location(s) passed to this option. + * You might use this for instance to specify a path to a library which + * you want to be referenced simply and relatively in the less files. */ + paths: [], + /* color output in the terminal */ + color: true, + /* The strictImports controls whether the compiler will allow an @import inside of either + * @media blocks or (a later addition) other selector blocks. + * See: https://github.com/less/less.js/issues/656 */ + strictImports: false, + /* Allow Imports from Insecure HTTPS Hosts */ + insecure: false, + /* Allows you to add a path to every generated import and url in your css. + * This does not affect less import statements that are processed, just ones + * that are left in the output css. */ + rootpath: '', + /* By default URLs are kept as-is, so if you import a file in a sub-directory + * that references an image, exactly the same URL will be output in the css. + * This option allows you to re-write URL's in imported files so that the + * URL is always relative to the base imported file */ + rewriteUrls: false, + /* How to process math + * 0 always - eagerly try to solve all operations + * 1 parens-division - require parens for division "/" + * 2 parens | strict - require parens for all operations + * 3 strict-legacy - legacy strict behavior (super-strict) + */ + math: 1, + /* Without this option, less attempts to guess at the output unit when it does maths. */ + strictUnits: false, + /* Effectively the declaration is put at the top of your base Less file, + * meaning it can be used but it also can be overridden if this variable + * is defined in the file. */ + globalVars: null, + /* As opposed to the global variable option, this puts the declaration at the + * end of your base file, meaning it will override anything defined in your Less file. */ + modifyVars: null, + /* This option allows you to specify a argument to go on to every URL. */ + urlArgs: '' + }; + } - function extractId(href) { - return href.replace(/^[a-z-]+:\/+?[^\/]+/, '') // Remove protocol & domain - .replace(/[\?\&]livereload=\w+/, '') // Remove LiveReload cachebuster - .replace(/^\//, '') // Remove root / - .replace(/\.[a-zA-Z]+$/, '') // Remove simple extension - .replace(/[^\.\w-]+/g, '-') // Replace illegal characters - .replace(/\./g, ':'); // Replace dots with colons(for valid id) - } - function addDataAttr(options, tag) { - for (var opt in tag.dataset) { - if (tag.dataset.hasOwnProperty(opt)) { - if (opt === 'env' || opt === 'dumpLineNumbers' || opt === 'rootpath' || opt === 'errorReporting') { - options[opt] = tag.dataset[opt]; - } - else { - try { - options[opt] = JSON.parse(tag.dataset[opt]); - } - catch (_) { } - } - } - } - } + function extractId(href) { + return href.replace(/^[a-z-]+:\/+?[^\/]+/, '') // Remove protocol & domain + .replace(/[\?\&]livereload=\w+/, '') // Remove LiveReload cachebuster + .replace(/^\//, '') // Remove root / + .replace(/\.[a-zA-Z]+$/, '') // Remove simple extension + .replace(/[^\.\w-]+/g, '-') // Replace illegal characters + .replace(/\./g, ':'); // Replace dots with colons(for valid id) + } + function addDataAttr(options, tag) { + for (var opt in tag.dataset) { + if (tag.dataset.hasOwnProperty(opt)) { + if (opt === 'env' || opt === 'dumpLineNumbers' || opt === 'rootpath' || opt === 'errorReporting') { + options[opt] = tag.dataset[opt]; + } + else { + try { + options[opt] = JSON.parse(tag.dataset[opt]); + } + catch (_) { } + } + } + } + } - var browser = { - createCSS: function (document, styles, sheet) { - // Strip the query-string - var href = sheet.href || ''; - // If there is no title set, use the filename, minus the extension - var id = "less:" + (sheet.title || extractId(href)); - // If this has already been inserted into the DOM, we may need to replace it - var oldStyleNode = document.getElementById(id); - var keepOldStyleNode = false; - // Create a new stylesheet node for insertion or (if necessary) replacement - var styleNode = document.createElement('style'); - styleNode.setAttribute('type', 'text/css'); - if (sheet.media) { - styleNode.setAttribute('media', sheet.media); - } - styleNode.id = id; - if (!styleNode.styleSheet) { - styleNode.appendChild(document.createTextNode(styles)); - // If new contents match contents of oldStyleNode, don't replace oldStyleNode - keepOldStyleNode = (oldStyleNode !== null && oldStyleNode.childNodes.length > 0 && styleNode.childNodes.length > 0 && - oldStyleNode.firstChild.nodeValue === styleNode.firstChild.nodeValue); - } - var head = document.getElementsByTagName('head')[0]; - // If there is no oldStyleNode, just append; otherwise, only append if we need - // to replace oldStyleNode with an updated stylesheet - if (oldStyleNode === null || keepOldStyleNode === false) { - var nextEl = sheet && sheet.nextSibling || null; - if (nextEl) { - nextEl.parentNode.insertBefore(styleNode, nextEl); - } - else { - head.appendChild(styleNode); - } - } - if (oldStyleNode && keepOldStyleNode === false) { - oldStyleNode.parentNode.removeChild(oldStyleNode); - } - // For IE. - // This needs to happen *after* the style element is added to the DOM, otherwise IE 7 and 8 may crash. - // See http://social.msdn.microsoft.com/Forums/en-US/7e081b65-878a-4c22-8e68-c10d39c2ed32/internet-explorer-crashes-appending-style-element-to-head - if (styleNode.styleSheet) { - try { - styleNode.styleSheet.cssText = styles; - } - catch (e) { - throw new Error('Couldn\'t reassign styleSheet.cssText.'); - } - } - }, - currentScript: function (window) { - var document = window.document; - return document.currentScript || (function () { - var scripts = document.getElementsByTagName('script'); - return scripts[scripts.length - 1]; - })(); - } - }; + var browser = { + createCSS: function (document, styles, sheet) { + // Strip the query-string + var href = sheet.href || ''; + // If there is no title set, use the filename, minus the extension + var id = "less:" + (sheet.title || extractId(href)); + // If this has already been inserted into the DOM, we may need to replace it + var oldStyleNode = document.getElementById(id); + var keepOldStyleNode = false; + // Create a new stylesheet node for insertion or (if necessary) replacement + var styleNode = document.createElement('style'); + styleNode.setAttribute('type', 'text/css'); + if (sheet.media) { + styleNode.setAttribute('media', sheet.media); + } + styleNode.id = id; + if (!styleNode.styleSheet) { + styleNode.appendChild(document.createTextNode(styles)); + // If new contents match contents of oldStyleNode, don't replace oldStyleNode + keepOldStyleNode = (oldStyleNode !== null && oldStyleNode.childNodes.length > 0 && styleNode.childNodes.length > 0 && + oldStyleNode.firstChild.nodeValue === styleNode.firstChild.nodeValue); + } + var head = document.getElementsByTagName('head')[0]; + // If there is no oldStyleNode, just append; otherwise, only append if we need + // to replace oldStyleNode with an updated stylesheet + if (oldStyleNode === null || keepOldStyleNode === false) { + var nextEl = sheet && sheet.nextSibling || null; + if (nextEl) { + nextEl.parentNode.insertBefore(styleNode, nextEl); + } + else { + head.appendChild(styleNode); + } + } + if (oldStyleNode && keepOldStyleNode === false) { + oldStyleNode.parentNode.removeChild(oldStyleNode); + } + // For IE. + // This needs to happen *after* the style element is added to the DOM, otherwise IE 7 and 8 may crash. + // See http://social.msdn.microsoft.com/Forums/en-US/7e081b65-878a-4c22-8e68-c10d39c2ed32/internet-explorer-crashes-appending-style-element-to-head + if (styleNode.styleSheet) { + try { + styleNode.styleSheet.cssText = styles; + } + catch (e) { + throw new Error('Couldn\'t reassign styleSheet.cssText.'); + } + } + }, + currentScript: function (window) { + var document = window.document; + return document.currentScript || (function () { + var scripts = document.getElementsByTagName('script'); + return scripts[scripts.length - 1]; + })(); + } + }; - var addDefaultOptions = (function (window, options) { - // use options from the current script tag data attribues - addDataAttr(options, browser.currentScript(window)); - if (options.isFileProtocol === undefined) { - options.isFileProtocol = /^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(window.location.protocol); - } - // Load styles asynchronously (default: false) - // - // This is set to `false` by default, so that the body - // doesn't start loading before the stylesheets are parsed. - // Setting this to `true` can result in flickering. - // - options.async = options.async || false; - options.fileAsync = options.fileAsync || false; - // Interval between watch polls - options.poll = options.poll || (options.isFileProtocol ? 1000 : 1500); - options.env = options.env || (window.location.hostname == '127.0.0.1' || - window.location.hostname == '0.0.0.0' || - window.location.hostname == 'localhost' || - (window.location.port && - window.location.port.length > 0) || - options.isFileProtocol ? 'development' - : 'production'); - var dumpLineNumbers = /!dumpLineNumbers:(comments|mediaquery|all)/.exec(window.location.hash); - if (dumpLineNumbers) { - options.dumpLineNumbers = dumpLineNumbers[1]; - } - if (options.useFileCache === undefined) { - options.useFileCache = true; - } - if (options.onReady === undefined) { - options.onReady = true; - } - if (options.relativeUrls) { - options.rewriteUrls = 'all'; - } - }); + var addDefaultOptions = (function (window, options) { + // use options from the current script tag data attribues + addDataAttr(options, browser.currentScript(window)); + if (options.isFileProtocol === undefined) { + options.isFileProtocol = /^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(window.location.protocol); + } + // Load styles asynchronously (default: false) + // + // This is set to `false` by default, so that the body + // doesn't start loading before the stylesheets are parsed. + // Setting this to `true` can result in flickering. + // + options.async = options.async || false; + options.fileAsync = options.fileAsync || false; + // Interval between watch polls + options.poll = options.poll || (options.isFileProtocol ? 1000 : 1500); + options.env = options.env || (window.location.hostname == '127.0.0.1' || + window.location.hostname == '0.0.0.0' || + window.location.hostname == 'localhost' || + (window.location.port && + window.location.port.length > 0) || + options.isFileProtocol ? 'development' + : 'production'); + var dumpLineNumbers = /!dumpLineNumbers:(comments|mediaquery|all)/.exec(window.location.hash); + if (dumpLineNumbers) { + options.dumpLineNumbers = dumpLineNumbers[1]; + } + if (options.useFileCache === undefined) { + options.useFileCache = true; + } + if (options.onReady === undefined) { + options.onReady = true; + } + if (options.relativeUrls) { + options.rewriteUrls = 'all'; + } + }); - /*! ***************************************************************************** - Copyright (c) Microsoft Corporation. + var logger = { + error: function (msg) { + this._fireEvent('error', msg); + }, + warn: function (msg) { + this._fireEvent('warn', msg); + }, + info: function (msg) { + this._fireEvent('info', msg); + }, + debug: function (msg) { + this._fireEvent('debug', msg); + }, + addListener: function (listener) { + this._listeners.push(listener); + }, + removeListener: function (listener) { + for (var i = 0; i < this._listeners.length; i++) { + if (this._listeners[i] === listener) { + this._listeners.splice(i, 1); + return; + } + } + }, + _fireEvent: function (type, msg) { + for (var i = 0; i < this._listeners.length; i++) { + var logFunction = this._listeners[i][type]; + if (logFunction) { + logFunction(msg); + } + } + }, + _listeners: [] + }; - Permission to use, copy, modify, and/or distribute this software for any - purpose with or without fee is hereby granted. + /** + * @todo Document why this abstraction exists, and the relationship between + * environment, file managers, and plugin manager + */ + var Environment = /** @class */ (function () { + function Environment(externalEnvironment, fileManagers) { + this.fileManagers = fileManagers || []; + externalEnvironment = externalEnvironment || {}; + var optionalFunctions = ['encodeBase64', 'mimeLookup', 'charsetLookup', 'getSourceMapGenerator']; + var requiredFunctions = []; + var functions = requiredFunctions.concat(optionalFunctions); + for (var i = 0; i < functions.length; i++) { + var propName = functions[i]; + var environmentFunc = externalEnvironment[propName]; + if (environmentFunc) { + this[propName] = environmentFunc.bind(externalEnvironment); + } + else if (i < requiredFunctions.length) { + this.warn("missing required function in environment - " + propName); + } + } + } + Environment.prototype.getFileManager = function (filename, currentDirectory, options, environment, isSync) { + if (!filename) { + logger.warn('getFileManager called with no filename.. Please report this issue. continuing.'); + } + if (currentDirectory == null) { + logger.warn('getFileManager called with null directory.. Please report this issue. continuing.'); + } + var fileManagers = this.fileManagers; + if (options.pluginManager) { + fileManagers = [].concat(fileManagers).concat(options.pluginManager.getFileManagers()); + } + for (var i = fileManagers.length - 1; i >= 0; i--) { + var fileManager = fileManagers[i]; + if (fileManager[isSync ? 'supportsSync' : 'supports'](filename, currentDirectory, options, environment)) { + return fileManager; + } + } + return null; + }; + Environment.prototype.addFileManager = function (fileManager) { + this.fileManagers.push(fileManager); + }; + Environment.prototype.clearFileManagers = function () { + this.fileManagers = []; + }; + return Environment; + }()); - THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH - REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY - AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, - INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM - LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR - OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR - PERFORMANCE OF THIS SOFTWARE. - ***************************************************************************** */ - /* global Reflect, Promise */ - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) - if (b.hasOwnProperty(p)) - d[p] = b[p]; }; - return extendStatics(d, b); - }; - function __extends(d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - } - function __spreadArrays() { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) - s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; - } + var colors = { + 'aliceblue': '#f0f8ff', + 'antiquewhite': '#faebd7', + 'aqua': '#00ffff', + 'aquamarine': '#7fffd4', + 'azure': '#f0ffff', + 'beige': '#f5f5dc', + 'bisque': '#ffe4c4', + 'black': '#000000', + 'blanchedalmond': '#ffebcd', + 'blue': '#0000ff', + 'blueviolet': '#8a2be2', + 'brown': '#a52a2a', + 'burlywood': '#deb887', + 'cadetblue': '#5f9ea0', + 'chartreuse': '#7fff00', + 'chocolate': '#d2691e', + 'coral': '#ff7f50', + 'cornflowerblue': '#6495ed', + 'cornsilk': '#fff8dc', + 'crimson': '#dc143c', + 'cyan': '#00ffff', + 'darkblue': '#00008b', + 'darkcyan': '#008b8b', + 'darkgoldenrod': '#b8860b', + 'darkgray': '#a9a9a9', + 'darkgrey': '#a9a9a9', + 'darkgreen': '#006400', + 'darkkhaki': '#bdb76b', + 'darkmagenta': '#8b008b', + 'darkolivegreen': '#556b2f', + 'darkorange': '#ff8c00', + 'darkorchid': '#9932cc', + 'darkred': '#8b0000', + 'darksalmon': '#e9967a', + 'darkseagreen': '#8fbc8f', + 'darkslateblue': '#483d8b', + 'darkslategray': '#2f4f4f', + 'darkslategrey': '#2f4f4f', + 'darkturquoise': '#00ced1', + 'darkviolet': '#9400d3', + 'deeppink': '#ff1493', + 'deepskyblue': '#00bfff', + 'dimgray': '#696969', + 'dimgrey': '#696969', + 'dodgerblue': '#1e90ff', + 'firebrick': '#b22222', + 'floralwhite': '#fffaf0', + 'forestgreen': '#228b22', + 'fuchsia': '#ff00ff', + 'gainsboro': '#dcdcdc', + 'ghostwhite': '#f8f8ff', + 'gold': '#ffd700', + 'goldenrod': '#daa520', + 'gray': '#808080', + 'grey': '#808080', + 'green': '#008000', + 'greenyellow': '#adff2f', + 'honeydew': '#f0fff0', + 'hotpink': '#ff69b4', + 'indianred': '#cd5c5c', + 'indigo': '#4b0082', + 'ivory': '#fffff0', + 'khaki': '#f0e68c', + 'lavender': '#e6e6fa', + 'lavenderblush': '#fff0f5', + 'lawngreen': '#7cfc00', + 'lemonchiffon': '#fffacd', + 'lightblue': '#add8e6', + 'lightcoral': '#f08080', + 'lightcyan': '#e0ffff', + 'lightgoldenrodyellow': '#fafad2', + 'lightgray': '#d3d3d3', + 'lightgrey': '#d3d3d3', + 'lightgreen': '#90ee90', + 'lightpink': '#ffb6c1', + 'lightsalmon': '#ffa07a', + 'lightseagreen': '#20b2aa', + 'lightskyblue': '#87cefa', + 'lightslategray': '#778899', + 'lightslategrey': '#778899', + 'lightsteelblue': '#b0c4de', + 'lightyellow': '#ffffe0', + 'lime': '#00ff00', + 'limegreen': '#32cd32', + 'linen': '#faf0e6', + 'magenta': '#ff00ff', + 'maroon': '#800000', + 'mediumaquamarine': '#66cdaa', + 'mediumblue': '#0000cd', + 'mediumorchid': '#ba55d3', + 'mediumpurple': '#9370d8', + 'mediumseagreen': '#3cb371', + 'mediumslateblue': '#7b68ee', + 'mediumspringgreen': '#00fa9a', + 'mediumturquoise': '#48d1cc', + 'mediumvioletred': '#c71585', + 'midnightblue': '#191970', + 'mintcream': '#f5fffa', + 'mistyrose': '#ffe4e1', + 'moccasin': '#ffe4b5', + 'navajowhite': '#ffdead', + 'navy': '#000080', + 'oldlace': '#fdf5e6', + 'olive': '#808000', + 'olivedrab': '#6b8e23', + 'orange': '#ffa500', + 'orangered': '#ff4500', + 'orchid': '#da70d6', + 'palegoldenrod': '#eee8aa', + 'palegreen': '#98fb98', + 'paleturquoise': '#afeeee', + 'palevioletred': '#d87093', + 'papayawhip': '#ffefd5', + 'peachpuff': '#ffdab9', + 'peru': '#cd853f', + 'pink': '#ffc0cb', + 'plum': '#dda0dd', + 'powderblue': '#b0e0e6', + 'purple': '#800080', + 'rebeccapurple': '#663399', + 'red': '#ff0000', + 'rosybrown': '#bc8f8f', + 'royalblue': '#4169e1', + 'saddlebrown': '#8b4513', + 'salmon': '#fa8072', + 'sandybrown': '#f4a460', + 'seagreen': '#2e8b57', + 'seashell': '#fff5ee', + 'sienna': '#a0522d', + 'silver': '#c0c0c0', + 'skyblue': '#87ceeb', + 'slateblue': '#6a5acd', + 'slategray': '#708090', + 'slategrey': '#708090', + 'snow': '#fffafa', + 'springgreen': '#00ff7f', + 'steelblue': '#4682b4', + 'tan': '#d2b48c', + 'teal': '#008080', + 'thistle': '#d8bfd8', + 'tomato': '#ff6347', + 'turquoise': '#40e0d0', + 'violet': '#ee82ee', + 'wheat': '#f5deb3', + 'white': '#ffffff', + 'whitesmoke': '#f5f5f5', + 'yellow': '#ffff00', + 'yellowgreen': '#9acd32' + }; - var colors = { - 'aliceblue': '#f0f8ff', - 'antiquewhite': '#faebd7', - 'aqua': '#00ffff', - 'aquamarine': '#7fffd4', - 'azure': '#f0ffff', - 'beige': '#f5f5dc', - 'bisque': '#ffe4c4', - 'black': '#000000', - 'blanchedalmond': '#ffebcd', - 'blue': '#0000ff', - 'blueviolet': '#8a2be2', - 'brown': '#a52a2a', - 'burlywood': '#deb887', - 'cadetblue': '#5f9ea0', - 'chartreuse': '#7fff00', - 'chocolate': '#d2691e', - 'coral': '#ff7f50', - 'cornflowerblue': '#6495ed', - 'cornsilk': '#fff8dc', - 'crimson': '#dc143c', - 'cyan': '#00ffff', - 'darkblue': '#00008b', - 'darkcyan': '#008b8b', - 'darkgoldenrod': '#b8860b', - 'darkgray': '#a9a9a9', - 'darkgrey': '#a9a9a9', - 'darkgreen': '#006400', - 'darkkhaki': '#bdb76b', - 'darkmagenta': '#8b008b', - 'darkolivegreen': '#556b2f', - 'darkorange': '#ff8c00', - 'darkorchid': '#9932cc', - 'darkred': '#8b0000', - 'darksalmon': '#e9967a', - 'darkseagreen': '#8fbc8f', - 'darkslateblue': '#483d8b', - 'darkslategray': '#2f4f4f', - 'darkslategrey': '#2f4f4f', - 'darkturquoise': '#00ced1', - 'darkviolet': '#9400d3', - 'deeppink': '#ff1493', - 'deepskyblue': '#00bfff', - 'dimgray': '#696969', - 'dimgrey': '#696969', - 'dodgerblue': '#1e90ff', - 'firebrick': '#b22222', - 'floralwhite': '#fffaf0', - 'forestgreen': '#228b22', - 'fuchsia': '#ff00ff', - 'gainsboro': '#dcdcdc', - 'ghostwhite': '#f8f8ff', - 'gold': '#ffd700', - 'goldenrod': '#daa520', - 'gray': '#808080', - 'grey': '#808080', - 'green': '#008000', - 'greenyellow': '#adff2f', - 'honeydew': '#f0fff0', - 'hotpink': '#ff69b4', - 'indianred': '#cd5c5c', - 'indigo': '#4b0082', - 'ivory': '#fffff0', - 'khaki': '#f0e68c', - 'lavender': '#e6e6fa', - 'lavenderblush': '#fff0f5', - 'lawngreen': '#7cfc00', - 'lemonchiffon': '#fffacd', - 'lightblue': '#add8e6', - 'lightcoral': '#f08080', - 'lightcyan': '#e0ffff', - 'lightgoldenrodyellow': '#fafad2', - 'lightgray': '#d3d3d3', - 'lightgrey': '#d3d3d3', - 'lightgreen': '#90ee90', - 'lightpink': '#ffb6c1', - 'lightsalmon': '#ffa07a', - 'lightseagreen': '#20b2aa', - 'lightskyblue': '#87cefa', - 'lightslategray': '#778899', - 'lightslategrey': '#778899', - 'lightsteelblue': '#b0c4de', - 'lightyellow': '#ffffe0', - 'lime': '#00ff00', - 'limegreen': '#32cd32', - 'linen': '#faf0e6', - 'magenta': '#ff00ff', - 'maroon': '#800000', - 'mediumaquamarine': '#66cdaa', - 'mediumblue': '#0000cd', - 'mediumorchid': '#ba55d3', - 'mediumpurple': '#9370d8', - 'mediumseagreen': '#3cb371', - 'mediumslateblue': '#7b68ee', - 'mediumspringgreen': '#00fa9a', - 'mediumturquoise': '#48d1cc', - 'mediumvioletred': '#c71585', - 'midnightblue': '#191970', - 'mintcream': '#f5fffa', - 'mistyrose': '#ffe4e1', - 'moccasin': '#ffe4b5', - 'navajowhite': '#ffdead', - 'navy': '#000080', - 'oldlace': '#fdf5e6', - 'olive': '#808000', - 'olivedrab': '#6b8e23', - 'orange': '#ffa500', - 'orangered': '#ff4500', - 'orchid': '#da70d6', - 'palegoldenrod': '#eee8aa', - 'palegreen': '#98fb98', - 'paleturquoise': '#afeeee', - 'palevioletred': '#d87093', - 'papayawhip': '#ffefd5', - 'peachpuff': '#ffdab9', - 'peru': '#cd853f', - 'pink': '#ffc0cb', - 'plum': '#dda0dd', - 'powderblue': '#b0e0e6', - 'purple': '#800080', - 'rebeccapurple': '#663399', - 'red': '#ff0000', - 'rosybrown': '#bc8f8f', - 'royalblue': '#4169e1', - 'saddlebrown': '#8b4513', - 'salmon': '#fa8072', - 'sandybrown': '#f4a460', - 'seagreen': '#2e8b57', - 'seashell': '#fff5ee', - 'sienna': '#a0522d', - 'silver': '#c0c0c0', - 'skyblue': '#87ceeb', - 'slateblue': '#6a5acd', - 'slategray': '#708090', - 'slategrey': '#708090', - 'snow': '#fffafa', - 'springgreen': '#00ff7f', - 'steelblue': '#4682b4', - 'tan': '#d2b48c', - 'teal': '#008080', - 'thistle': '#d8bfd8', - 'tomato': '#ff6347', - 'turquoise': '#40e0d0', - 'violet': '#ee82ee', - 'wheat': '#f5deb3', - 'white': '#ffffff', - 'whitesmoke': '#f5f5f5', - 'yellow': '#ffff00', - 'yellowgreen': '#9acd32' - }; + var unitConversions = { + length: { + 'm': 1, + 'cm': 0.01, + 'mm': 0.001, + 'in': 0.0254, + 'px': 0.0254 / 96, + 'pt': 0.0254 / 72, + 'pc': 0.0254 / 72 * 12 + }, + duration: { + 's': 1, + 'ms': 0.001 + }, + angle: { + 'rad': 1 / (2 * Math.PI), + 'deg': 1 / 360, + 'grad': 1 / 400, + 'turn': 1 + } + }; - var unitConversions = { - length: { - 'm': 1, - 'cm': 0.01, - 'mm': 0.001, - 'in': 0.0254, - 'px': 0.0254 / 96, - 'pt': 0.0254 / 72, - 'pc': 0.0254 / 72 * 12 - }, - duration: { - 's': 1, - 'ms': 0.001 - }, - angle: { - 'rad': 1 / (2 * Math.PI), - 'deg': 1 / 360, - 'grad': 1 / 400, - 'turn': 1 - } - }; + var data = { colors: colors, unitConversions: unitConversions }; - var data = { colors: colors, unitConversions: unitConversions }; + /** + * The reason why Node is a class and other nodes simply do not extend + * from Node (since we're transpiling) is due to this issue: + * + * https://github.com/less/less.js/issues/3434 + */ + var Node = /** @class */ (function () { + function Node() { + this.parent = null; + this.visibilityBlocks = undefined; + this.nodeVisible = undefined; + this.rootNode = null; + this.parsed = null; + var self = this; + Object.defineProperty(this, 'currentFileInfo', { + get: function () { return self.fileInfo(); } + }); + Object.defineProperty(this, 'index', { + get: function () { return self.getIndex(); } + }); + } + Node.prototype.setParent = function (nodes, parent) { + function set(node) { + if (node && node instanceof Node) { + node.parent = parent; + } + } + if (Array.isArray(nodes)) { + nodes.forEach(set); + } + else { + set(nodes); + } + }; + Node.prototype.getIndex = function () { + return this._index || (this.parent && this.parent.getIndex()) || 0; + }; + Node.prototype.fileInfo = function () { + return this._fileInfo || (this.parent && this.parent.fileInfo()) || {}; + }; + Node.prototype.isRulesetLike = function () { return false; }; + Node.prototype.toCSS = function (context) { + var strs = []; + this.genCSS(context, { + add: function (chunk, fileInfo, index) { + strs.push(chunk); + }, + isEmpty: function () { + return strs.length === 0; + } + }); + return strs.join(''); + }; + Node.prototype.genCSS = function (context, output) { + output.add(this.value); + }; + Node.prototype.accept = function (visitor) { + this.value = visitor.visit(this.value); + }; + Node.prototype.eval = function () { return this; }; + Node.prototype._operate = function (context, op, a, b) { + switch (op) { + case '+': return a + b; + case '-': return a - b; + case '*': return a * b; + case '/': return a / b; + } + }; + Node.prototype.fround = function (context, value) { + var precision = context && context.numPrecision; + // add "epsilon" to ensure numbers like 1.000000005 (represented as 1.000000004999...) are properly rounded: + return (precision) ? Number((value + 2e-16).toFixed(precision)) : value; + }; + Node.compare = function (a, b) { + /* returns: + -1: a < b + 0: a = b + 1: a > b + and *any* other value for a != b (e.g. undefined, NaN, -2 etc.) */ + if ((a.compare) && + // for "symmetric results" force toCSS-based comparison + // of Quoted or Anonymous if either value is one of those + !(b.type === 'Quoted' || b.type === 'Anonymous')) { + return a.compare(b); + } + else if (b.compare) { + return -b.compare(a); + } + else if (a.type !== b.type) { + return undefined; + } + a = a.value; + b = b.value; + if (!Array.isArray(a)) { + return a === b ? 0 : undefined; + } + if (a.length !== b.length) { + return undefined; + } + for (var i = 0; i < a.length; i++) { + if (Node.compare(a[i], b[i]) !== 0) { + return undefined; + } + } + return 0; + }; + Node.numericCompare = function (a, b) { + return a < b ? -1 + : a === b ? 0 + : a > b ? 1 : undefined; + }; + // Returns true if this node represents root of ast imported by reference + Node.prototype.blocksVisibility = function () { + if (this.visibilityBlocks == null) { + this.visibilityBlocks = 0; + } + return this.visibilityBlocks !== 0; + }; + Node.prototype.addVisibilityBlock = function () { + if (this.visibilityBlocks == null) { + this.visibilityBlocks = 0; + } + this.visibilityBlocks = this.visibilityBlocks + 1; + }; + Node.prototype.removeVisibilityBlock = function () { + if (this.visibilityBlocks == null) { + this.visibilityBlocks = 0; + } + this.visibilityBlocks = this.visibilityBlocks - 1; + }; + // Turns on node visibility - if called node will be shown in output regardless + // of whether it comes from import by reference or not + Node.prototype.ensureVisibility = function () { + this.nodeVisible = true; + }; + // Turns off node visibility - if called node will NOT be shown in output regardless + // of whether it comes from import by reference or not + Node.prototype.ensureInvisibility = function () { + this.nodeVisible = false; + }; + // return values: + // false - the node must not be visible + // true - the node must be visible + // undefined or null - the node has the same visibility as its parent + Node.prototype.isVisible = function () { + return this.nodeVisible; + }; + Node.prototype.visibilityInfo = function () { + return { + visibilityBlocks: this.visibilityBlocks, + nodeVisible: this.nodeVisible + }; + }; + Node.prototype.copyVisibilityInfo = function (info) { + if (!info) { + return; + } + this.visibilityBlocks = info.visibilityBlocks; + this.nodeVisible = info.nodeVisible; + }; + return Node; + }()); - /** - * The reason why Node is a class and other nodes simply do not extend - * from Node (since we're transpiling) is due to this issue: - * - * https://github.com/less/less.js/issues/3434 - */ - var Node = /** @class */ (function () { - function Node() { - this.parent = null; - this.visibilityBlocks = undefined; - this.nodeVisible = undefined; - this.rootNode = null; - this.parsed = null; - var self = this; - Object.defineProperty(this, 'currentFileInfo', { - get: function () { return self.fileInfo(); } - }); - Object.defineProperty(this, 'index', { - get: function () { return self.getIndex(); } - }); - } - Node.prototype.setParent = function (nodes, parent) { - function set(node) { - if (node && node instanceof Node) { - node.parent = parent; - } - } - if (Array.isArray(nodes)) { - nodes.forEach(set); - } - else { - set(nodes); - } - }; - Node.prototype.getIndex = function () { - return this._index || (this.parent && this.parent.getIndex()) || 0; - }; - Node.prototype.fileInfo = function () { - return this._fileInfo || (this.parent && this.parent.fileInfo()) || {}; - }; - Node.prototype.isRulesetLike = function () { - return false; - }; - Node.prototype.toCSS = function (context) { - var strs = []; - this.genCSS(context, { - add: function (chunk, fileInfo, index) { - strs.push(chunk); - }, - isEmpty: function () { - return strs.length === 0; - } - }); - return strs.join(''); - }; - Node.prototype.genCSS = function (context, output) { - output.add(this.value); - }; - Node.prototype.accept = function (visitor) { - this.value = visitor.visit(this.value); - }; - Node.prototype.eval = function () { return this; }; - Node.prototype._operate = function (context, op, a, b) { - switch (op) { - case '+': return a + b; - case '-': return a - b; - case '*': return a * b; - case '/': return a / b; - } - }; - Node.prototype.fround = function (context, value) { - var precision = context && context.numPrecision; - // add "epsilon" to ensure numbers like 1.000000005 (represented as 1.000000004999...) are properly rounded: - return (precision) ? Number((value + 2e-16).toFixed(precision)) : value; - }; - // Returns true if this node represents root of ast imported by reference - Node.prototype.blocksVisibility = function () { - if (this.visibilityBlocks == null) { - this.visibilityBlocks = 0; - } - return this.visibilityBlocks !== 0; - }; - Node.prototype.addVisibilityBlock = function () { - if (this.visibilityBlocks == null) { - this.visibilityBlocks = 0; - } - this.visibilityBlocks = this.visibilityBlocks + 1; - }; - Node.prototype.removeVisibilityBlock = function () { - if (this.visibilityBlocks == null) { - this.visibilityBlocks = 0; - } - this.visibilityBlocks = this.visibilityBlocks - 1; - }; - // Turns on node visibility - if called node will be shown in output regardless - // of whether it comes from import by reference or not - Node.prototype.ensureVisibility = function () { - this.nodeVisible = true; - }; - // Turns off node visibility - if called node will NOT be shown in output regardless - // of whether it comes from import by reference or not - Node.prototype.ensureInvisibility = function () { - this.nodeVisible = false; - }; - // return values: - // false - the node must not be visible - // true - the node must be visible - // undefined or null - the node has the same visibility as its parent - Node.prototype.isVisible = function () { - return this.nodeVisible; - }; - Node.prototype.visibilityInfo = function () { - return { - visibilityBlocks: this.visibilityBlocks, - nodeVisible: this.nodeVisible - }; - }; - Node.prototype.copyVisibilityInfo = function (info) { - if (!info) { - return; - } - this.visibilityBlocks = info.visibilityBlocks; - this.nodeVisible = info.nodeVisible; - }; - return Node; - }()); - Node.compare = function (a, b) { - /* returns: - -1: a < b - 0: a = b - 1: a > b - and *any* other value for a != b (e.g. undefined, NaN, -2 etc.) */ - if ((a.compare) && - // for "symmetric results" force toCSS-based comparison - // of Quoted or Anonymous if either value is one of those - !(b.type === 'Quoted' || b.type === 'Anonymous')) { - return a.compare(b); - } - else if (b.compare) { - return -b.compare(a); - } - else if (a.type !== b.type) { - return undefined; - } - a = a.value; - b = b.value; - if (!Array.isArray(a)) { - return a === b ? 0 : undefined; - } - if (a.length !== b.length) { - return undefined; - } - for (var i = 0; i < a.length; i++) { - if (Node.compare(a[i], b[i]) !== 0) { - return undefined; - } - } - return 0; - }; - Node.numericCompare = function (a, b) { return a < b ? -1 - : a === b ? 0 - : a > b ? 1 : undefined; }; + // + // RGB Colors - #ff0014, #eee + // + var Color = function (rgb, a, originalForm) { + var self = this; + // + // The end goal here, is to parse the arguments + // into an integer triplet, such as `128, 255, 0` + // + // This facilitates operations and conversions. + // + if (Array.isArray(rgb)) { + this.rgb = rgb; + } + else if (rgb.length >= 6) { + this.rgb = []; + rgb.match(/.{2}/g).map(function (c, i) { + if (i < 3) { + self.rgb.push(parseInt(c, 16)); + } + else { + self.alpha = (parseInt(c, 16)) / 255; + } + }); + } + else { + this.rgb = []; + rgb.split('').map(function (c, i) { + if (i < 3) { + self.rgb.push(parseInt(c + c, 16)); + } + else { + self.alpha = (parseInt(c + c, 16)) / 255; + } + }); + } + this.alpha = this.alpha || (typeof a === 'number' ? a : 1); + if (typeof originalForm !== 'undefined') { + this.value = originalForm; + } + }; + Color.prototype = Object.assign(new Node(), { + type: 'Color', + luma: function () { + var r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255; + r = (r <= 0.03928) ? r / 12.92 : Math.pow(((r + 0.055) / 1.055), 2.4); + g = (g <= 0.03928) ? g / 12.92 : Math.pow(((g + 0.055) / 1.055), 2.4); + b = (b <= 0.03928) ? b / 12.92 : Math.pow(((b + 0.055) / 1.055), 2.4); + return 0.2126 * r + 0.7152 * g + 0.0722 * b; + }, + genCSS: function (context, output) { + output.add(this.toCSS(context)); + }, + toCSS: function (context, doNotCompress) { + var compress = context && context.compress && !doNotCompress; + var color; + var alpha; + var colorFunction; + var args = []; + // `value` is set if this color was originally + // converted from a named color string so we need + // to respect this and try to output named color too. + alpha = this.fround(context, this.alpha); + if (this.value) { + if (this.value.indexOf('rgb') === 0) { + if (alpha < 1) { + colorFunction = 'rgba'; + } + } + else if (this.value.indexOf('hsl') === 0) { + if (alpha < 1) { + colorFunction = 'hsla'; + } + else { + colorFunction = 'hsl'; + } + } + else { + return this.value; + } + } + else { + if (alpha < 1) { + colorFunction = 'rgba'; + } + } + switch (colorFunction) { + case 'rgba': + args = this.rgb.map(function (c) { + return clamp(Math.round(c), 255); + }).concat(clamp(alpha, 1)); + break; + case 'hsla': + args.push(clamp(alpha, 1)); + case 'hsl': + color = this.toHSL(); + args = [ + this.fround(context, color.h), + this.fround(context, color.s * 100) + "%", + this.fround(context, color.l * 100) + "%" + ].concat(args); + } + if (colorFunction) { + // Values are capped between `0` and `255`, rounded and zero-padded. + return colorFunction + "(" + args.join("," + (compress ? '' : ' ')) + ")"; + } + color = this.toRGB(); + if (compress) { + var splitcolor = color.split(''); + // Convert color to short format + if (splitcolor[1] === splitcolor[2] && splitcolor[3] === splitcolor[4] && splitcolor[5] === splitcolor[6]) { + color = "#" + splitcolor[1] + splitcolor[3] + splitcolor[5]; + } + } + return color; + }, + // + // Operations have to be done per-channel, if not, + // channels will spill onto each other. Once we have + // our result, in the form of an integer triplet, + // we create a new Color node to hold the result. + // + operate: function (context, op, other) { + var rgb = new Array(3); + var alpha = this.alpha * (1 - other.alpha) + other.alpha; + for (var c = 0; c < 3; c++) { + rgb[c] = this._operate(context, op, this.rgb[c], other.rgb[c]); + } + return new Color(rgb, alpha); + }, + toRGB: function () { + return toHex(this.rgb); + }, + toHSL: function () { + var r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255, a = this.alpha; + var max = Math.max(r, g, b), min = Math.min(r, g, b); + var h; + var s; + var l = (max + min) / 2; + var d = max - min; + if (max === min) { + h = s = 0; + } + else { + s = l > 0.5 ? d / (2 - max - min) : d / (max + min); + switch (max) { + case r: + h = (g - b) / d + (g < b ? 6 : 0); + break; + case g: + h = (b - r) / d + 2; + break; + case b: + h = (r - g) / d + 4; + break; + } + h /= 6; + } + return { h: h * 360, s: s, l: l, a: a }; + }, + // Adapted from http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript + toHSV: function () { + var r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255, a = this.alpha; + var max = Math.max(r, g, b), min = Math.min(r, g, b); + var h; + var s; + var v = max; + var d = max - min; + if (max === 0) { + s = 0; + } + else { + s = d / max; + } + if (max === min) { + h = 0; + } + else { + switch (max) { + case r: + h = (g - b) / d + (g < b ? 6 : 0); + break; + case g: + h = (b - r) / d + 2; + break; + case b: + h = (r - g) / d + 4; + break; + } + h /= 6; + } + return { h: h * 360, s: s, v: v, a: a }; + }, + toARGB: function () { + return toHex([this.alpha * 255].concat(this.rgb)); + }, + compare: function (x) { + return (x.rgb && + x.rgb[0] === this.rgb[0] && + x.rgb[1] === this.rgb[1] && + x.rgb[2] === this.rgb[2] && + x.alpha === this.alpha) ? 0 : undefined; + } + }); + Color.fromKeyword = function (keyword) { + var c; + var key = keyword.toLowerCase(); + if (colors.hasOwnProperty(key)) { + c = new Color(colors[key].slice(1)); + } + else if (key === 'transparent') { + c = new Color([0, 0, 0], 0); + } + if (c) { + c.value = keyword; + return c; + } + }; + function clamp(v, max) { + return Math.min(Math.max(v, 0), max); + } + function toHex(v) { + return "#" + v.map(function (c) { + c = clamp(Math.round(c), 255); + return (c < 16 ? '0' : '') + c.toString(16); + }).join(''); + } - // - // RGB Colors - #ff0014, #eee - // - var Color = function (rgb, a, originalForm) { - var self = this; - // - // The end goal here, is to parse the arguments - // into an integer triplet, such as `128, 255, 0` - // - // This facilitates operations and conversions. - // - if (Array.isArray(rgb)) { - this.rgb = rgb; - } - else if (rgb.length >= 6) { - this.rgb = []; - rgb.match(/.{2}/g).map(function (c, i) { - if (i < 3) { - self.rgb.push(parseInt(c, 16)); - } - else { - self.alpha = (parseInt(c, 16)) / 255; - } - }); - } - else { - this.rgb = []; - rgb.split('').map(function (c, i) { - if (i < 3) { - self.rgb.push(parseInt(c + c, 16)); - } - else { - self.alpha = (parseInt(c + c, 16)) / 255; - } - }); - } - this.alpha = this.alpha || (typeof a === 'number' ? a : 1); - if (typeof originalForm !== 'undefined') { - this.value = originalForm; - } - }; - Color.prototype = new Node(); - Color.prototype.luma = function () { - var r = this.rgb[0] / 255; - var g = this.rgb[1] / 255; - var b = this.rgb[2] / 255; - r = (r <= 0.03928) ? r / 12.92 : Math.pow(((r + 0.055) / 1.055), 2.4); - g = (g <= 0.03928) ? g / 12.92 : Math.pow(((g + 0.055) / 1.055), 2.4); - b = (b <= 0.03928) ? b / 12.92 : Math.pow(((b + 0.055) / 1.055), 2.4); - return 0.2126 * r + 0.7152 * g + 0.0722 * b; - }; - Color.prototype.genCSS = function (context, output) { - output.add(this.toCSS(context)); - }; - Color.prototype.toCSS = function (context, doNotCompress) { - var compress = context && context.compress && !doNotCompress; - var color; - var alpha; - var colorFunction; - var args = []; - // `value` is set if this color was originally - // converted from a named color string so we need - // to respect this and try to output named color too. - alpha = this.fround(context, this.alpha); - if (this.value) { - if (this.value.indexOf('rgb') === 0) { - if (alpha < 1) { - colorFunction = 'rgba'; - } - } - else if (this.value.indexOf('hsl') === 0) { - if (alpha < 1) { - colorFunction = 'hsla'; - } - else { - colorFunction = 'hsl'; - } - } - else { - return this.value; - } - } - else { - if (alpha < 1) { - colorFunction = 'rgba'; - } - } - switch (colorFunction) { - case 'rgba': - args = this.rgb.map(function (c) { return clamp(Math.round(c), 255); }).concat(clamp(alpha, 1)); - break; - case 'hsla': - args.push(clamp(alpha, 1)); - case 'hsl': - color = this.toHSL(); - args = [ - this.fround(context, color.h), - this.fround(context, color.s * 100) + "%", - this.fround(context, color.l * 100) + "%" - ].concat(args); - } - if (colorFunction) { - // Values are capped between `0` and `255`, rounded and zero-padded. - return colorFunction + "(" + args.join("," + (compress ? '' : ' ')) + ")"; - } - color = this.toRGB(); - if (compress) { - var splitcolor = color.split(''); - // Convert color to short format - if (splitcolor[1] === splitcolor[2] && splitcolor[3] === splitcolor[4] && splitcolor[5] === splitcolor[6]) { - color = "#" + splitcolor[1] + splitcolor[3] + splitcolor[5]; - } - } - return color; - }; - // - // Operations have to be done per-channel, if not, - // channels will spill onto each other. Once we have - // our result, in the form of an integer triplet, - // we create a new Color node to hold the result. - // - Color.prototype.operate = function (context, op, other) { - var rgb = new Array(3); - var alpha = this.alpha * (1 - other.alpha) + other.alpha; - for (var c = 0; c < 3; c++) { - rgb[c] = this._operate(context, op, this.rgb[c], other.rgb[c]); - } - return new Color(rgb, alpha); - }; - Color.prototype.toRGB = function () { - return toHex(this.rgb); - }; - Color.prototype.toHSL = function () { - var r = this.rgb[0] / 255; - var g = this.rgb[1] / 255; - var b = this.rgb[2] / 255; - var a = this.alpha; - var max = Math.max(r, g, b); - var min = Math.min(r, g, b); - var h; - var s; - var l = (max + min) / 2; - var d = max - min; - if (max === min) { - h = s = 0; - } - else { - s = l > 0.5 ? d / (2 - max - min) : d / (max + min); - switch (max) { - case r: - h = (g - b) / d + (g < b ? 6 : 0); - break; - case g: - h = (b - r) / d + 2; - break; - case b: - h = (r - g) / d + 4; - break; - } - h /= 6; - } - return { h: h * 360, s: s, l: l, a: a }; - }; - // Adapted from http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript - Color.prototype.toHSV = function () { - var r = this.rgb[0] / 255; - var g = this.rgb[1] / 255; - var b = this.rgb[2] / 255; - var a = this.alpha; - var max = Math.max(r, g, b); - var min = Math.min(r, g, b); - var h; - var s; - var v = max; - var d = max - min; - if (max === 0) { - s = 0; - } - else { - s = d / max; - } - if (max === min) { - h = 0; - } - else { - switch (max) { - case r: - h = (g - b) / d + (g < b ? 6 : 0); - break; - case g: - h = (b - r) / d + 2; - break; - case b: - h = (r - g) / d + 4; - break; - } - h /= 6; - } - return { h: h * 360, s: s, v: v, a: a }; - }; - Color.prototype.toARGB = function () { - return toHex([this.alpha * 255].concat(this.rgb)); - }; - Color.prototype.compare = function (x) { - return (x.rgb && - x.rgb[0] === this.rgb[0] && - x.rgb[1] === this.rgb[1] && - x.rgb[2] === this.rgb[2] && - x.alpha === this.alpha) ? 0 : undefined; - }; - Color.prototype.type = 'Color'; - function clamp(v, max) { - return Math.min(Math.max(v, 0), max); - } - function toHex(v) { - return "#" + v.map(function (c) { - c = clamp(Math.round(c), 255); - return (c < 16 ? '0' : '') + c.toString(16); - }).join(''); - } - Color.fromKeyword = function (keyword) { - var c; - var key = keyword.toLowerCase(); - if (colors.hasOwnProperty(key)) { - c = new Color(colors[key].slice(1)); - } - else if (key === 'transparent') { - c = new Color([0, 0, 0], 0); - } - if (c) { - c.value = keyword; - return c; - } - }; + var Paren = function (node) { + this.value = node; + }; + Paren.prototype = Object.assign(new Node(), { + type: 'Paren', + genCSS: function (context, output) { + output.add('('); + this.value.genCSS(context, output); + output.add(')'); + }, + eval: function (context) { + return new Paren(this.value.eval(context)); + } + }); - var Paren = function (node) { - this.value = node; - }; - Paren.prototype = new Node(); - Paren.prototype.genCSS = function (context, output) { - output.add('('); - this.value.genCSS(context, output); - output.add(')'); - }; - Paren.prototype.eval = function (context) { - return new Paren(this.value.eval(context)); - }; - Paren.prototype.type = 'Paren'; + var _noSpaceCombinators = { + '': true, + ' ': true, + '|': true + }; + var Combinator = function (value) { + if (value === ' ') { + this.value = ' '; + this.emptyOrWhitespace = true; + } + else { + this.value = value ? value.trim() : ''; + this.emptyOrWhitespace = this.value === ''; + } + }; + Combinator.prototype = Object.assign(new Node(), { + type: 'Combinator', + genCSS: function (context, output) { + var spaceOrEmpty = (context.compress || _noSpaceCombinators[this.value]) ? '' : ' '; + output.add(spaceOrEmpty + this.value + spaceOrEmpty); + } + }); - var _noSpaceCombinators = { - '': true, - ' ': true, - '|': true - }; - var Combinator = function (value) { - if (value === ' ') { - this.value = ' '; - this.emptyOrWhitespace = true; - } - else { - this.value = value ? value.trim() : ''; - this.emptyOrWhitespace = this.value === ''; - } - }; - Combinator.prototype = new Node(); - Combinator.prototype.genCSS = function (context, output) { - var spaceOrEmpty = (context.compress || _noSpaceCombinators[this.value]) ? '' : ' '; - output.add(spaceOrEmpty + this.value + spaceOrEmpty); - }; - Combinator.prototype.type = 'Combinator'; + var Element = function (combinator, value, isVariable, index, currentFileInfo, visibilityInfo) { + this.combinator = combinator instanceof Combinator ? + combinator : new Combinator(combinator); + if (typeof value === 'string') { + this.value = value.trim(); + } + else if (value) { + this.value = value; + } + else { + this.value = ''; + } + this.isVariable = isVariable; + this._index = index; + this._fileInfo = currentFileInfo; + this.copyVisibilityInfo(visibilityInfo); + this.setParent(this.combinator, this); + }; + Element.prototype = Object.assign(new Node(), { + type: 'Element', + accept: function (visitor) { + var value = this.value; + this.combinator = visitor.visit(this.combinator); + if (typeof value === 'object') { + this.value = visitor.visit(value); + } + }, + eval: function (context) { + return new Element(this.combinator, this.value.eval ? this.value.eval(context) : this.value, this.isVariable, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + }, + clone: function () { + return new Element(this.combinator, this.value, this.isVariable, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + }, + genCSS: function (context, output) { + output.add(this.toCSS(context), this.fileInfo(), this.getIndex()); + }, + toCSS: function (context) { + context = context || {}; + var value = this.value; + var firstSelector = context.firstSelector; + if (value instanceof Paren) { + // selector in parens should not be affected by outer selector + // flags (breaks only interpolated selectors - see #1973) + context.firstSelector = true; + } + value = value.toCSS ? value.toCSS(context) : value; + context.firstSelector = firstSelector; + if (value === '' && this.combinator.value.charAt(0) === '&') { + return ''; + } + else { + return this.combinator.toCSS(context) + value; + } + } + }); - var Element = function (combinator, value, isVariable, index, currentFileInfo, visibilityInfo) { - this.combinator = combinator instanceof Combinator ? - combinator : new Combinator(combinator); - if (typeof value === 'string') { - this.value = value.trim(); - } - else if (value) { - this.value = value; - } - else { - this.value = ''; - } - this.isVariable = isVariable; - this._index = index; - this._fileInfo = currentFileInfo; - this.copyVisibilityInfo(visibilityInfo); - this.setParent(this.combinator, this); - }; - Element.prototype = new Node(); - Element.prototype.accept = function (visitor) { - var value = this.value; - this.combinator = visitor.visit(this.combinator); - if (typeof value === 'object') { - this.value = visitor.visit(value); - } - }; - Element.prototype.eval = function (context) { - return new Element(this.combinator, this.value.eval ? this.value.eval(context) : this.value, this.isVariable, this.getIndex(), this.fileInfo(), this.visibilityInfo()); - }; - Element.prototype.clone = function () { - return new Element(this.combinator, this.value, this.isVariable, this.getIndex(), this.fileInfo(), this.visibilityInfo()); - }; - Element.prototype.genCSS = function (context, output) { - output.add(this.toCSS(context), this.fileInfo(), this.getIndex()); - }; - Element.prototype.toCSS = function (context) { - if (context === void 0) { context = {}; } - var value = this.value; - var firstSelector = context.firstSelector; - if (value instanceof Paren) { - // selector in parens should not be affected by outer selector - // flags (breaks only interpolated selectors - see #1973) - context.firstSelector = true; - } - value = value.toCSS ? value.toCSS(context) : value; - context.firstSelector = firstSelector; - if (value === '' && this.combinator.value.charAt(0) === '&') { - return ''; - } - else { - return this.combinator.toCSS(context) + value; - } - }; - Element.prototype.type = 'Element'; + var Math$1 = { + ALWAYS: 0, + PARENS_DIVISION: 1, + PARENS: 2 + // removed - STRICT_LEGACY: 3 + }; + var RewriteUrls = { + OFF: 0, + LOCAL: 1, + ALL: 2 + }; - var Math$1 = { - ALWAYS: 0, - PARENS_DIVISION: 1, - PARENS: 2, - STRICT_LEGACY: 3 - }; - var RewriteUrls = { - OFF: 0, - LOCAL: 1, - ALL: 2 - }; + /** + * Returns the object type of the given payload + * + * @param {*} payload + * @returns {string} + */ + function getType(payload) { + return Object.prototype.toString.call(payload).slice(8, -1); + } + /** + * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes) + * + * @param {*} payload + * @returns {payload is Record} + */ + function isPlainObject(payload) { + if (getType(payload) !== 'Object') + return false; + return payload.constructor === Object && Object.getPrototypeOf(payload) === Object.prototype; + } + /** + * Returns whether the payload is an array + * + * @param {any} payload + * @returns {payload is any[]} + */ + function isArray(payload) { + return getType(payload) === 'Array'; + } - /** - * Returns the object type of the given payload - * - * @param {*} payload - * @returns {string} - */ - function getType(payload) { - return Object.prototype.toString.call(payload).slice(8, -1); - } - /** - * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes) - * - * @param {*} payload - * @returns {payload is Record} - */ - function isPlainObject(payload) { - if (getType(payload) !== 'Object') - return false; - return payload.constructor === Object && Object.getPrototypeOf(payload) === Object.prototype; - } - /** - * Returns whether the payload is an array - * - * @param {any} payload - * @returns {payload is any[]} - */ - function isArray(payload) { - return getType(payload) === 'Array'; - } + /*! ***************************************************************************** + Copyright (c) Microsoft Corporation. All rights reserved. + Licensed under the Apache License, Version 2.0 (the "License"); you may not use + this file except in compliance with the License. You may obtain a copy of the + License at http://www.apache.org/licenses/LICENSE-2.0 - /*! ***************************************************************************** - Copyright (c) Microsoft Corporation. All rights reserved. - Licensed under the Apache License, Version 2.0 (the "License"); you may not use - this file except in compliance with the License. You may obtain a copy of the - License at http://www.apache.org/licenses/LICENSE-2.0 + THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED + WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, + MERCHANTABLITY OR NON-INFRINGEMENT. - THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY - KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED - WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, - MERCHANTABLITY OR NON-INFRINGEMENT. + See the Apache Version 2.0 License for specific language governing permissions + and limitations under the License. + ***************************************************************************** */ + function __spreadArrays() { + for (var s = 0, i = 0, il = arguments.length; i < il; i++) + s += arguments[i].length; + for (var r = Array(s), k = 0, i = 0; i < il; i++) + for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) + r[k] = a[j]; + return r; + } + function assignProp(carry, key, newVal, originalObject, includeNonenumerable) { + var propType = {}.propertyIsEnumerable.call(originalObject, key) + ? 'enumerable' + : 'nonenumerable'; + if (propType === 'enumerable') + carry[key] = newVal; + if (includeNonenumerable && propType === 'nonenumerable') { + Object.defineProperty(carry, key, { + value: newVal, + enumerable: false, + writable: true, + configurable: true, + }); + } + } + /** + * Copy (clone) an object and all its props recursively to get rid of any prop referenced of the original object. Arrays are also cloned, however objects inside arrays are still linked. + * + * @export + * @template T + * @param {T} target Target can be anything + * @param {Options} [options={}] Options can be `props` or `nonenumerable` + * @returns {T} the target with replaced values + * @export + */ + function copy(target, options) { + if (options === void 0) { + options = {}; + } + if (isArray(target)) + return target.map(function (i) { return copy(i, options); }); + if (!isPlainObject(target)) + return target; + var props = Object.getOwnPropertyNames(target); + var symbols = Object.getOwnPropertySymbols(target); + return __spreadArrays(props, symbols).reduce(function (carry, key) { + if (isArray(options.props) && !options.props.includes(key)) { + return carry; + } + var val = target[key]; + var newVal = copy(val, options); + assignProp(carry, key, newVal, target, options.nonenumerable); + return carry; + }, {}); + } - See the Apache Version 2.0 License for specific language governing permissions - and limitations under the License. - ***************************************************************************** */ - function __spreadArrays$1() { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) - s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; - } - function assignProp(carry, key, newVal, originalObject, includeNonenumerable) { - var propType = {}.propertyIsEnumerable.call(originalObject, key) - ? 'enumerable' - : 'nonenumerable'; - if (propType === 'enumerable') - carry[key] = newVal; - if (includeNonenumerable && propType === 'nonenumerable') { - Object.defineProperty(carry, key, { - value: newVal, - enumerable: false, - writable: true, - configurable: true, - }); - } - } - /** - * Copy (clone) an object and all its props recursively to get rid of any prop referenced of the original object. Arrays are also cloned, however objects inside arrays are still linked. - * - * @export - * @template T - * @param {T} target Target can be anything - * @param {Options} [options={}] Options can be `props` or `nonenumerable` - * @returns {T} the target with replaced values - * @export - */ - function copy(target, options) { - if (options === void 0) { - options = {}; - } - if (isArray(target)) - return target.map(function (i) { return copy(i, options); }); - if (!isPlainObject(target)) - return target; - var props = Object.getOwnPropertyNames(target); - var symbols = Object.getOwnPropertySymbols(target); - return __spreadArrays$1(props, symbols).reduce(function (carry, key) { - if (isArray(options.props) && !options.props.includes(key)) { - return carry; - } - var val = target[key]; - var newVal = copy(val, options); - assignProp(carry, key, newVal, target, options.nonenumerable); - return carry; - }, {}); - } + /* jshint proto: true */ + function getLocation(index, inputStream) { + var n = index + 1; + var line = null; + var column = -1; + while (--n >= 0 && inputStream.charAt(n) !== '\n') { + column++; + } + if (typeof index === 'number') { + line = (inputStream.slice(0, index).match(/\n/g) || '').length; + } + return { + line: line, + column: column + }; + } + function copyArray(arr) { + var i; + var length = arr.length; + var copy = new Array(length); + for (i = 0; i < length; i++) { + copy[i] = arr[i]; + } + return copy; + } + function clone(obj) { + var cloned = {}; + for (var prop in obj) { + if (obj.hasOwnProperty(prop)) { + cloned[prop] = obj[prop]; + } + } + return cloned; + } + function defaults(obj1, obj2) { + var newObj = obj2 || {}; + if (!obj2._defaults) { + newObj = {}; + var defaults_1 = copy(obj1); + newObj._defaults = defaults_1; + var cloned = obj2 ? copy(obj2) : {}; + Object.assign(newObj, defaults_1, cloned); + } + return newObj; + } + function copyOptions(obj1, obj2) { + if (obj2 && obj2._defaults) { + return obj2; + } + var opts = defaults(obj1, obj2); + if (opts.strictMath) { + opts.math = Math$1.PARENS; + } + // Back compat with changed relativeUrls option + if (opts.relativeUrls) { + opts.rewriteUrls = RewriteUrls.ALL; + } + if (typeof opts.math === 'string') { + switch (opts.math.toLowerCase()) { + case 'always': + opts.math = Math$1.ALWAYS; + break; + case 'parens-division': + opts.math = Math$1.PARENS_DIVISION; + break; + case 'strict': + case 'parens': + opts.math = Math$1.PARENS; + break; + default: + opts.math = Math$1.PARENS; + } + } + if (typeof opts.rewriteUrls === 'string') { + switch (opts.rewriteUrls.toLowerCase()) { + case 'off': + opts.rewriteUrls = RewriteUrls.OFF; + break; + case 'local': + opts.rewriteUrls = RewriteUrls.LOCAL; + break; + case 'all': + opts.rewriteUrls = RewriteUrls.ALL; + break; + } + } + return opts; + } + function merge(obj1, obj2) { + for (var prop in obj2) { + if (obj2.hasOwnProperty(prop)) { + obj1[prop] = obj2[prop]; + } + } + return obj1; + } + function flattenArray(arr, result) { + if (result === void 0) { result = []; } + for (var i = 0, length_1 = arr.length; i < length_1; i++) { + var value = arr[i]; + if (Array.isArray(value)) { + flattenArray(value, result); + } + else { + if (value !== undefined) { + result.push(value); + } + } + } + return result; + } - /* jshint proto: true */ - function getLocation(index, inputStream) { - var n = index + 1; - var line = null; - var column = -1; - while (--n >= 0 && inputStream.charAt(n) !== '\n') { - column++; - } - if (typeof index === 'number') { - line = (inputStream.slice(0, index).match(/\n/g) || '').length; - } - return { - line: line, - column: column - }; - } - function copyArray(arr) { - var i; - var length = arr.length; - var copy = new Array(length); - for (i = 0; i < length; i++) { - copy[i] = arr[i]; - } - return copy; - } - function clone(obj) { - var cloned = {}; - for (var prop in obj) { - if (obj.hasOwnProperty(prop)) { - cloned[prop] = obj[prop]; - } - } - return cloned; - } - function defaults(obj1, obj2) { - var newObj = obj2 || {}; - if (!obj2._defaults) { - newObj = {}; - var defaults_1 = copy(obj1); - newObj._defaults = defaults_1; - var cloned = obj2 ? copy(obj2) : {}; - Object.assign(newObj, defaults_1, cloned); - } - return newObj; - } - function copyOptions(obj1, obj2) { - if (obj2 && obj2._defaults) { - return obj2; - } - var opts = defaults(obj1, obj2); - if (opts.strictMath) { - opts.math = Math$1.STRICT_LEGACY; - } - // Back compat with changed relativeUrls option - if (opts.relativeUrls) { - opts.rewriteUrls = RewriteUrls.ALL; - } - if (typeof opts.math === 'string') { - switch (opts.math.toLowerCase()) { - case 'always': - opts.math = Math$1.ALWAYS; - break; - case 'parens-division': - opts.math = Math$1.PARENS_DIVISION; - break; - case 'strict': - case 'parens': - opts.math = Math$1.PARENS; - break; - case 'strict-legacy': - opts.math = Math$1.STRICT_LEGACY; - } - } - if (typeof opts.rewriteUrls === 'string') { - switch (opts.rewriteUrls.toLowerCase()) { - case 'off': - opts.rewriteUrls = RewriteUrls.OFF; - break; - case 'local': - opts.rewriteUrls = RewriteUrls.LOCAL; - break; - case 'all': - opts.rewriteUrls = RewriteUrls.ALL; - break; - } - } - return opts; - } - function merge(obj1, obj2) { - for (var prop in obj2) { - if (obj2.hasOwnProperty(prop)) { - obj1[prop] = obj2[prop]; - } - } - return obj1; - } - function flattenArray(arr, result) { - if (result === void 0) { result = []; } - for (var i = 0, length_1 = arr.length; i < length_1; i++) { - var value = arr[i]; - if (Array.isArray(value)) { - flattenArray(value, result); - } - else { - if (value !== undefined) { - result.push(value); - } - } - } - return result; - } + var utils = /*#__PURE__*/Object.freeze({ + __proto__: null, + getLocation: getLocation, + copyArray: copyArray, + clone: clone, + defaults: defaults, + copyOptions: copyOptions, + merge: merge, + flattenArray: flattenArray + }); - var utils = /*#__PURE__*/Object.freeze({ - __proto__: null, - getLocation: getLocation, - copyArray: copyArray, - clone: clone, - defaults: defaults, - copyOptions: copyOptions, - merge: merge, - flattenArray: flattenArray - }); + var anonymousFunc = /(|Function):(\d+):(\d+)/; + /** + * This is a centralized class of any error that could be thrown internally (mostly by the parser). + * Besides standard .message it keeps some additional data like a path to the file where the error + * occurred along with line and column numbers. + * + * @class + * @extends Error + * @type {module.LessError} + * + * @prop {string} type + * @prop {string} filename + * @prop {number} index + * @prop {number} line + * @prop {number} column + * @prop {number} callLine + * @prop {number} callExtract + * @prop {string[]} extract + * + * @param {Object} e - An error object to wrap around or just a descriptive object + * @param {Object} fileContentMap - An object with file contents in 'contents' property (like importManager) @todo - move to fileManager? + * @param {string} [currentFilename] + */ + var LessError = function (e, fileContentMap, currentFilename) { + Error.call(this); + var filename = e.filename || currentFilename; + this.message = e.message; + this.stack = e.stack; + if (fileContentMap && filename) { + var input = fileContentMap.contents[filename]; + var loc = getLocation(e.index, input); + var line = loc.line; + var col = loc.column; + var callLine = e.call && getLocation(e.call, input).line; + var lines = input ? input.split('\n') : ''; + this.type = e.type || 'Syntax'; + this.filename = filename; + this.index = e.index; + this.line = typeof line === 'number' ? line + 1 : null; + this.column = col; + if (!this.line && this.stack) { + var found = this.stack.match(anonymousFunc); + /** + * We have to figure out how this environment stringifies anonymous functions + * so we can correctly map plugin errors. + * + * Note, in Node 8, the output of anonymous funcs varied based on parameters + * being present or not, so we inject dummy params. + */ + var func = new Function('a', 'throw new Error()'); + var lineAdjust = 0; + try { + func(); + } + catch (e) { + var match = e.stack.match(anonymousFunc); + var line = parseInt(match[2]); + lineAdjust = 1 - line; + } + if (found) { + if (found[2]) { + this.line = parseInt(found[2]) + lineAdjust; + } + if (found[3]) { + this.column = parseInt(found[3]); + } + } + } + this.callLine = callLine + 1; + this.callExtract = lines[callLine]; + this.extract = [ + lines[this.line - 2], + lines[this.line - 1], + lines[this.line] + ]; + } + }; + if (typeof Object.create === 'undefined') { + var F = function () { }; + F.prototype = Error.prototype; + LessError.prototype = new F(); + } + else { + LessError.prototype = Object.create(Error.prototype); + } + LessError.prototype.constructor = LessError; + /** + * An overridden version of the default Object.prototype.toString + * which uses additional information to create a helpful message. + * + * @param {Object} options + * @returns {string} + */ + LessError.prototype.toString = function (options) { + options = options || {}; + var message = ''; + var extract = this.extract || []; + var error = []; + var stylize = function (str) { return str; }; + if (options.stylize) { + var type = typeof options.stylize; + if (type !== 'function') { + throw Error("options.stylize should be a function, got a " + type + "!"); + } + stylize = options.stylize; + } + if (this.line !== null) { + if (typeof extract[0] === 'string') { + error.push(stylize(this.line - 1 + " " + extract[0], 'grey')); + } + if (typeof extract[1] === 'string') { + var errorTxt = this.line + " "; + if (extract[1]) { + errorTxt += extract[1].slice(0, this.column) + + stylize(stylize(stylize(extract[1].substr(this.column, 1), 'bold') + + extract[1].slice(this.column + 1), 'red'), 'inverse'); + } + error.push(errorTxt); + } + if (typeof extract[2] === 'string') { + error.push(stylize(this.line + 1 + " " + extract[2], 'grey')); + } + error = error.join('\n') + stylize('', 'reset') + "\n"; + } + message += stylize(this.type + "Error: " + this.message, 'red'); + if (this.filename) { + message += stylize(' in ', 'red') + this.filename; + } + if (this.line) { + message += stylize(" on line " + this.line + ", column " + (this.column + 1) + ":", 'grey'); + } + message += "\n" + error; + if (this.callLine) { + message += stylize('from ', 'red') + (this.filename || '') + "/n"; + message += stylize(this.callLine, 'grey') + " " + this.callExtract + "/n"; + } + return message; + }; - var anonymousFunc = /(|Function):(\d+):(\d+)/; - /** - * This is a centralized class of any error that could be thrown internally (mostly by the parser). - * Besides standard .message it keeps some additional data like a path to the file where the error - * occurred along with line and column numbers. - * - * @class - * @extends Error - * @type {module.LessError} - * - * @prop {string} type - * @prop {string} filename - * @prop {number} index - * @prop {number} line - * @prop {number} column - * @prop {number} callLine - * @prop {number} callExtract - * @prop {string[]} extract - * - * @param {Object} e - An error object to wrap around or just a descriptive object - * @param {Object} fileContentMap - An object with file contents in 'contents' property (like importManager) @todo - move to fileManager? - * @param {string} [currentFilename] - */ - var LessError = function LessError(e, fileContentMap, currentFilename) { - Error.call(this); - var filename = e.filename || currentFilename; - this.message = e.message; - this.stack = e.stack; - if (fileContentMap && filename) { - var input = fileContentMap.contents[filename]; - var loc = getLocation(e.index, input); - var line = loc.line; - var col = loc.column; - var callLine = e.call && getLocation(e.call, input).line; - var lines = input ? input.split('\n') : ''; - this.type = e.type || 'Syntax'; - this.filename = filename; - this.index = e.index; - this.line = typeof line === 'number' ? line + 1 : null; - this.column = col; - if (!this.line && this.stack) { - var found = this.stack.match(anonymousFunc); - /** - * We have to figure out how this environment stringifies anonymous functions - * so we can correctly map plugin errors. - * - * Note, in Node 8, the output of anonymous funcs varied based on parameters - * being present or not, so we inject dummy params. - */ - var func = new Function('a', 'throw new Error()'); - var lineAdjust = 0; - try { - func(); - } - catch (e) { - var match = e.stack.match(anonymousFunc); - var line_1 = parseInt(match[2]); - lineAdjust = 1 - line_1; - } - if (found) { - if (found[2]) { - this.line = parseInt(found[2]) + lineAdjust; - } - if (found[3]) { - this.column = parseInt(found[3]); - } - } - } - this.callLine = callLine + 1; - this.callExtract = lines[callLine]; - this.extract = [ - lines[this.line - 2], - lines[this.line - 1], - lines[this.line] - ]; - } - }; - if (typeof Object.create === 'undefined') { - var F = function () { }; - F.prototype = Error.prototype; - LessError.prototype = new F(); - } - else { - LessError.prototype = Object.create(Error.prototype); - } - LessError.prototype.constructor = LessError; - /** - * An overridden version of the default Object.prototype.toString - * which uses additional information to create a helpful message. - * - * @param {Object} options - * @returns {string} - */ - LessError.prototype.toString = function (options) { - if (options === void 0) { options = {}; } - var message = ''; - var extract = this.extract || []; - var error = []; - var stylize = function (str) { return str; }; - if (options.stylize) { - var type = typeof options.stylize; - if (type !== 'function') { - throw Error("options.stylize should be a function, got a " + type + "!"); - } - stylize = options.stylize; - } - if (this.line !== null) { - if (typeof extract[0] === 'string') { - error.push(stylize(this.line - 1 + " " + extract[0], 'grey')); - } - if (typeof extract[1] === 'string') { - var errorTxt = this.line + " "; - if (extract[1]) { - errorTxt += extract[1].slice(0, this.column) + - stylize(stylize(stylize(extract[1].substr(this.column, 1), 'bold') + - extract[1].slice(this.column + 1), 'red'), 'inverse'); - } - error.push(errorTxt); - } - if (typeof extract[2] === 'string') { - error.push(stylize(this.line + 1 + " " + extract[2], 'grey')); - } - error = error.join('\n') + stylize('', 'reset') + "\n"; - } - message += stylize(this.type + "Error: " + this.message, 'red'); - if (this.filename) { - message += stylize(' in ', 'red') + this.filename; - } - if (this.line) { - message += stylize(" on line " + this.line + ", column " + (this.column + 1) + ":", 'grey'); - } - message += "\n" + error; - if (this.callLine) { - message += stylize('from ', 'red') + (this.filename || '') + "/n"; - message += stylize(this.callLine, 'grey') + " " + this.callExtract + "/n"; - } - return message; - }; + var Selector = function (elements, extendList, condition, index, currentFileInfo, visibilityInfo) { + this.extendList = extendList; + this.condition = condition; + this.evaldCondition = !condition; + this._index = index; + this._fileInfo = currentFileInfo; + this.elements = this.getElements(elements); + this.mixinElements_ = undefined; + this.copyVisibilityInfo(visibilityInfo); + this.setParent(this.elements, this); + }; + Selector.prototype = Object.assign(new Node(), { + type: 'Selector', + accept: function (visitor) { + if (this.elements) { + this.elements = visitor.visitArray(this.elements); + } + if (this.extendList) { + this.extendList = visitor.visitArray(this.extendList); + } + if (this.condition) { + this.condition = visitor.visit(this.condition); + } + }, + createDerived: function (elements, extendList, evaldCondition) { + elements = this.getElements(elements); + var newSelector = new Selector(elements, extendList || this.extendList, null, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + newSelector.evaldCondition = (evaldCondition != null) ? evaldCondition : this.evaldCondition; + newSelector.mediaEmpty = this.mediaEmpty; + return newSelector; + }, + getElements: function (els) { + if (!els) { + return [new Element('', '&', false, this._index, this._fileInfo)]; + } + if (typeof els === 'string') { + this.parse.parseNode(els, ['selector'], this._index, this._fileInfo, function (err, result) { + if (err) { + throw new LessError({ + index: err.index, + message: err.message + }, this.parse.imports, this._fileInfo.filename); + } + els = result[0].elements; + }); + } + return els; + }, + createEmptySelectors: function () { + var el = new Element('', '&', false, this._index, this._fileInfo), sels = [new Selector([el], null, null, this._index, this._fileInfo)]; + sels[0].mediaEmpty = true; + return sels; + }, + match: function (other) { + var elements = this.elements; + var len = elements.length; + var olen; + var i; + other = other.mixinElements(); + olen = other.length; + if (olen === 0 || len < olen) { + return 0; + } + else { + for (i = 0; i < olen; i++) { + if (elements[i].value !== other[i]) { + return 0; + } + } + } + return olen; // return number of matched elements + }, + mixinElements: function () { + if (this.mixinElements_) { + return this.mixinElements_; + } + var elements = this.elements.map(function (v) { + return v.combinator.value + (v.value.value || v.value); + }).join('').match(/[,&#\*\.\w-]([\w-]|(\\.))*/g); + if (elements) { + if (elements[0] === '&') { + elements.shift(); + } + } + else { + elements = []; + } + return (this.mixinElements_ = elements); + }, + isJustParentSelector: function () { + return !this.mediaEmpty && + this.elements.length === 1 && + this.elements[0].value === '&' && + (this.elements[0].combinator.value === ' ' || this.elements[0].combinator.value === ''); + }, + eval: function (context) { + var evaldCondition = this.condition && this.condition.eval(context); + var elements = this.elements; + var extendList = this.extendList; + elements = elements && elements.map(function (e) { return e.eval(context); }); + extendList = extendList && extendList.map(function (extend) { return extend.eval(context); }); + return this.createDerived(elements, extendList, evaldCondition); + }, + genCSS: function (context, output) { + var i, element; + if ((!context || !context.firstSelector) && this.elements[0].combinator.value === '') { + output.add(' ', this.fileInfo(), this.getIndex()); + } + for (i = 0; i < this.elements.length; i++) { + element = this.elements[i]; + element.genCSS(context, output); + } + }, + getIsOutput: function () { + return this.evaldCondition; + } + }); - var Selector = function (elements, extendList, condition, index, currentFileInfo, visibilityInfo) { - this.extendList = extendList; - this.condition = condition; - this.evaldCondition = !condition; - this._index = index; - this._fileInfo = currentFileInfo; - this.elements = this.getElements(elements); - this.mixinElements_ = undefined; - this.copyVisibilityInfo(visibilityInfo); - this.setParent(this.elements, this); - }; - Selector.prototype = new Node(); - Selector.prototype.accept = function (visitor) { - if (this.elements) { - this.elements = visitor.visitArray(this.elements); - } - if (this.extendList) { - this.extendList = visitor.visitArray(this.extendList); - } - if (this.condition) { - this.condition = visitor.visit(this.condition); - } - }; - Selector.prototype.createDerived = function (elements, extendList, evaldCondition) { - elements = this.getElements(elements); - var newSelector = new Selector(elements, extendList || this.extendList, null, this.getIndex(), this.fileInfo(), this.visibilityInfo()); - newSelector.evaldCondition = (evaldCondition != null) ? evaldCondition : this.evaldCondition; - newSelector.mediaEmpty = this.mediaEmpty; - return newSelector; - }; - Selector.prototype.getElements = function (els) { - if (!els) { - return [new Element('', '&', false, this._index, this._fileInfo)]; - } - if (typeof els === 'string') { - this.parse.parseNode(els, ['selector'], this._index, this._fileInfo, function (err, result) { - if (err) { - throw new LessError({ - index: err.index, - message: err.message - }, this.parse.imports, this._fileInfo.filename); - } - els = result[0].elements; - }); - } - return els; - }; - Selector.prototype.createEmptySelectors = function () { - var el = new Element('', '&', false, this._index, this._fileInfo); - var sels = [new Selector([el], null, null, this._index, this._fileInfo)]; - sels[0].mediaEmpty = true; - return sels; - }; - Selector.prototype.match = function (other) { - var elements = this.elements; - var len = elements.length; - var olen; - var i; - other = other.mixinElements(); - olen = other.length; - if (olen === 0 || len < olen) { - return 0; - } - else { - for (i = 0; i < olen; i++) { - if (elements[i].value !== other[i]) { - return 0; - } - } - } - return olen; // return number of matched elements - }; - Selector.prototype.mixinElements = function () { - if (this.mixinElements_) { - return this.mixinElements_; - } - var elements = this.elements.map(function (v) { return v.combinator.value + (v.value.value || v.value); }).join('').match(/[,&#\*\.\w-]([\w-]|(\\.))*/g); - if (elements) { - if (elements[0] === '&') { - elements.shift(); - } - } - else { - elements = []; - } - return (this.mixinElements_ = elements); - }; - Selector.prototype.isJustParentSelector = function () { - return !this.mediaEmpty && - this.elements.length === 1 && - this.elements[0].value === '&' && - (this.elements[0].combinator.value === ' ' || this.elements[0].combinator.value === ''); - }; - Selector.prototype.eval = function (context) { - var evaldCondition = this.condition && this.condition.eval(context); - var elements = this.elements; - var extendList = this.extendList; - elements = elements && elements.map(function (e) { return e.eval(context); }); - extendList = extendList && extendList.map(function (extend) { return extend.eval(context); }); - return this.createDerived(elements, extendList, evaldCondition); - }; - Selector.prototype.genCSS = function (context, output) { - var i; - var element; - if ((!context || !context.firstSelector) && this.elements[0].combinator.value === '') { - output.add(' ', this.fileInfo(), this.getIndex()); - } - for (i = 0; i < this.elements.length; i++) { - element = this.elements[i]; - element.genCSS(context, output); - } - }; - Selector.prototype.getIsOutput = function () { - return this.evaldCondition; - }; - Selector.prototype.type = 'Selector'; + var Value = function (value) { + if (!value) { + throw new Error('Value requires an array argument'); + } + if (!Array.isArray(value)) { + this.value = [value]; + } + else { + this.value = value; + } + }; + Value.prototype = Object.assign(new Node(), { + type: 'Value', + accept: function (visitor) { + if (this.value) { + this.value = visitor.visitArray(this.value); + } + }, + eval: function (context) { + if (this.value.length === 1) { + return this.value[0].eval(context); + } + else { + return new Value(this.value.map(function (v) { + return v.eval(context); + })); + } + }, + genCSS: function (context, output) { + var i; + for (i = 0; i < this.value.length; i++) { + this.value[i].genCSS(context, output); + if (i + 1 < this.value.length) { + output.add((context && context.compress) ? ',' : ', '); + } + } + } + }); - var Value = function (value) { - if (!value) { - throw new Error('Value requires an array argument'); - } - if (!Array.isArray(value)) { - this.value = [value]; - } - else { - this.value = value; - } - }; - Value.prototype = new Node(); - Value.prototype.accept = function (visitor) { - if (this.value) { - this.value = visitor.visitArray(this.value); - } - }; - Value.prototype.eval = function (context) { - if (this.value.length === 1) { - return this.value[0].eval(context); - } - else { - return new Value(this.value.map(function (v) { return v.eval(context); })); - } - }; - Value.prototype.genCSS = function (context, output) { - var i; - for (i = 0; i < this.value.length; i++) { - this.value[i].genCSS(context, output); - if (i + 1 < this.value.length) { - output.add((context && context.compress) ? ',' : ', '); - } - } - }; - Value.prototype.type = 'Value'; + var Keyword = function (value) { + this.value = value; + }; + Keyword.prototype = Object.assign(new Node(), { + type: 'Keyword', + genCSS: function (context, output) { + if (this.value === '%') { + throw { type: 'Syntax', message: 'Invalid % without number' }; + } + output.add(this.value); + } + }); + Keyword.True = new Keyword('true'); + Keyword.False = new Keyword('false'); - var Keyword = function (value) { - this.value = value; - }; - Keyword.prototype = new Node(); - Keyword.prototype.genCSS = function (context, output) { - if (this.value === '%') { - throw { type: 'Syntax', message: 'Invalid % without number' }; - } - output.add(this.value); - }; - Keyword.prototype.type = 'Keyword'; - Keyword.True = new Keyword('true'); - Keyword.False = new Keyword('false'); + var Anonymous = function (value, index, currentFileInfo, mapLines, rulesetLike, visibilityInfo) { + this.value = value; + this._index = index; + this._fileInfo = currentFileInfo; + this.mapLines = mapLines; + this.rulesetLike = (typeof rulesetLike === 'undefined') ? false : rulesetLike; + this.allowRoot = true; + this.copyVisibilityInfo(visibilityInfo); + }; + Anonymous.prototype = Object.assign(new Node(), { + type: 'Anonymous', + eval: function () { + return new Anonymous(this.value, this._index, this._fileInfo, this.mapLines, this.rulesetLike, this.visibilityInfo()); + }, + compare: function (other) { + return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; + }, + isRulesetLike: function () { + return this.rulesetLike; + }, + genCSS: function (context, output) { + this.nodeVisible = Boolean(this.value); + if (this.nodeVisible) { + output.add(this.value, this._fileInfo, this._index, this.mapLines); + } + } + }); - var Anonymous = function (value, index, currentFileInfo, mapLines, rulesetLike, visibilityInfo) { - this.value = value; - this._index = index; - this._fileInfo = currentFileInfo; - this.mapLines = mapLines; - this.rulesetLike = (typeof rulesetLike === 'undefined') ? false : rulesetLike; - this.allowRoot = true; - this.copyVisibilityInfo(visibilityInfo); - }; - Anonymous.prototype = new Node(); - Anonymous.prototype.eval = function () { - return new Anonymous(this.value, this._index, this._fileInfo, this.mapLines, this.rulesetLike, this.visibilityInfo()); - }; - Anonymous.prototype.compare = function (other) { - return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; - }; - Anonymous.prototype.isRulesetLike = function () { - return this.rulesetLike; - }; - Anonymous.prototype.genCSS = function (context, output) { - this.nodeVisible = Boolean(this.value); - if (this.nodeVisible) { - output.add(this.value, this._fileInfo, this._index, this.mapLines); - } - }; - Anonymous.prototype.type = 'Anonymous'; + var MATH = Math$1; + function evalName(context, name) { + var value = ''; + var i; + var n = name.length; + var output = { add: function (s) { value += s; } }; + for (i = 0; i < n; i++) { + name[i].eval(context).genCSS(context, output); + } + return value; + } + var Declaration = function (name, value, important, merge, index, currentFileInfo, inline, variable) { + this.name = name; + this.value = (value instanceof Node) ? value : new Value([value ? new Anonymous(value) : null]); + this.important = important ? " " + important.trim() : ''; + this.merge = merge; + this._index = index; + this._fileInfo = currentFileInfo; + this.inline = inline || false; + this.variable = (variable !== undefined) ? variable + : (name.charAt && (name.charAt(0) === '@')); + this.allowRoot = true; + this.setParent(this.value, this); + }; + Declaration.prototype = Object.assign(new Node(), { + type: 'Declaration', + genCSS: function (context, output) { + output.add(this.name + (context.compress ? ':' : ': '), this.fileInfo(), this.getIndex()); + try { + this.value.genCSS(context, output); + } + catch (e) { + e.index = this._index; + e.filename = this._fileInfo.filename; + throw e; + } + output.add(this.important + ((this.inline || (context.lastRule && context.compress)) ? '' : ';'), this._fileInfo, this._index); + }, + eval: function (context) { + var mathBypass = false, prevMath, name = this.name, evaldValue, variable = this.variable; + if (typeof name !== 'string') { + // expand 'primitive' name directly to get + // things faster (~10% for benchmark.less): + name = (name.length === 1) && (name[0] instanceof Keyword) ? + name[0].value : evalName(context, name); + variable = false; // never treat expanded interpolation as new variable name + } + // @todo remove when parens-division is default + if (name === 'font' && context.math === MATH.ALWAYS) { + mathBypass = true; + prevMath = context.math; + context.math = MATH.PARENS_DIVISION; + } + try { + context.importantScope.push({}); + evaldValue = this.value.eval(context); + if (!this.variable && evaldValue.type === 'DetachedRuleset') { + throw { message: 'Rulesets cannot be evaluated on a property.', + index: this.getIndex(), filename: this.fileInfo().filename }; + } + var important = this.important; + var importantResult = context.importantScope.pop(); + if (!important && importantResult.important) { + important = importantResult.important; + } + return new Declaration(name, evaldValue, important, this.merge, this.getIndex(), this.fileInfo(), this.inline, variable); + } + catch (e) { + if (typeof e.index !== 'number') { + e.index = this.getIndex(); + e.filename = this.fileInfo().filename; + } + throw e; + } + finally { + if (mathBypass) { + context.math = prevMath; + } + } + }, + makeImportant: function () { + return new Declaration(this.name, this.value, '!important', this.merge, this.getIndex(), this.fileInfo(), this.inline); + } + }); - var MATH = Math$1; - var Declaration = function (name, value, important, merge, index, currentFileInfo, inline, variable) { - this.name = name; - this.value = (value instanceof Node) ? value : new Value([value ? new Anonymous(value) : null]); - this.important = important ? " " + important.trim() : ''; - this.merge = merge; - this._index = index; - this._fileInfo = currentFileInfo; - this.inline = inline || false; - this.variable = (variable !== undefined) ? variable - : (name.charAt && (name.charAt(0) === '@')); - this.allowRoot = true; - this.setParent(this.value, this); - }; - Declaration.prototype = new Node(); - Declaration.prototype.genCSS = function (context, output) { - output.add(this.name + (context.compress ? ':' : ': '), this.fileInfo(), this.getIndex()); - try { - this.value.genCSS(context, output); - } - catch (e) { - e.index = this._index; - e.filename = this._fileInfo.filename; - throw e; - } - output.add(this.important + ((this.inline || (context.lastRule && context.compress)) ? '' : ';'), this._fileInfo, this._index); - }; - Declaration.prototype.eval = function (context) { - var mathBypass = false; - var prevMath; - var name = this.name; - var evaldValue; - var variable = this.variable; - if (typeof name !== 'string') { - // expand 'primitive' name directly to get - // things faster (~10% for benchmark.less): - name = (name.length === 1) && (name[0] instanceof Keyword) ? - name[0].value : evalName(context, name); - variable = false; // never treat expanded interpolation as new variable name - } - // @todo remove when parens-division is default - if (name === 'font' && context.math === MATH.ALWAYS) { - mathBypass = true; - prevMath = context.math; - context.math = MATH.PARENS_DIVISION; - } - try { - context.importantScope.push({}); - evaldValue = this.value.eval(context); - if (!this.variable && evaldValue.type === 'DetachedRuleset') { - throw { message: 'Rulesets cannot be evaluated on a property.', - index: this.getIndex(), filename: this.fileInfo().filename }; - } - var important = this.important; - var importantResult = context.importantScope.pop(); - if (!important && importantResult.important) { - important = importantResult.important; - } - return new Declaration(name, evaldValue, important, this.merge, this.getIndex(), this.fileInfo(), this.inline, variable); - } - catch (e) { - if (typeof e.index !== 'number') { - e.index = this.getIndex(); - e.filename = this.fileInfo().filename; - } - throw e; - } - finally { - if (mathBypass) { - context.math = prevMath; - } - } - }; - Declaration.prototype.makeImportant = function () { - return new Declaration(this.name, this.value, '!important', this.merge, this.getIndex(), this.fileInfo(), this.inline); - }; - function evalName(context, name) { - var value = ''; - var i; - var n = name.length; - var output = { add: function (s) { value += s; } }; - for (i = 0; i < n; i++) { - name[i].eval(context).genCSS(context, output); - } - return value; - } - Declaration.prototype.type = 'Declaration'; + var debugInfo = /** @class */ (function () { + function debugInfo(context, ctx, lineSeparator) { + var result = ''; + if (context.dumpLineNumbers && !context.compress) { + switch (context.dumpLineNumbers) { + case 'comments': + result = debugInfo.asComment(ctx); + break; + case 'mediaquery': + result = debugInfo.asMediaQuery(ctx); + break; + case 'all': + result = debugInfo.asComment(ctx) + (lineSeparator || '') + debugInfo.asMediaQuery(ctx); + break; + } + } + return result; + } + debugInfo.asComment = function (ctx) { + return "/* line " + ctx.debugInfo.lineNumber + ", " + ctx.debugInfo.fileName + " */\n"; + }; + debugInfo.asMediaQuery = function (ctx) { + var filenameWithProtocol = ctx.debugInfo.fileName; + if (!/^[a-z]+:\/\//i.test(filenameWithProtocol)) { + filenameWithProtocol = "file://" + filenameWithProtocol; + } + return "@media -sass-debug-info{filename{font-family:" + filenameWithProtocol.replace(/([.:\/\\])/g, function (a) { + if (a == '\\') { + a = '\/'; + } + return "\\" + a; + }) + "}line{font-family:\\00003" + ctx.debugInfo.lineNumber + "}}\n"; + }; + return debugInfo; + }()); - var debugInfo = function (context, ctx, lineSeparator) { - var result = ''; - if (context.dumpLineNumbers && !context.compress) { - switch (context.dumpLineNumbers) { - case 'comments': - result = debugInfo.asComment(ctx); - break; - case 'mediaquery': - result = debugInfo.asMediaQuery(ctx); - break; - case 'all': - result = debugInfo.asComment(ctx) + (lineSeparator || '') + debugInfo.asMediaQuery(ctx); - break; - } - } - return result; - }; - debugInfo.asComment = function (ctx) { return ctx.debugInfo ? "/* line " + ctx.debugInfo.lineNumber + ", " + ctx.debugInfo.fileName + " */\n" : ''; }; - debugInfo.asMediaQuery = function (ctx) { - if (!ctx.debugInfo) { - return ''; - } - var filenameWithProtocol = ctx.debugInfo.fileName; - if (!/^[a-z]+:\/\//i.test(filenameWithProtocol)) { - filenameWithProtocol = "file://" + filenameWithProtocol; - } - return "@media -sass-debug-info{filename{font-family:" + filenameWithProtocol.replace(/([.:\/\\])/g, function (a) { - if (a == '\\') { - a = '\/'; - } - return "\\" + a; - }) + "}line{font-family:\\00003" + ctx.debugInfo.lineNumber + "}}\n"; - }; + var Comment = function (value, isLineComment, index, currentFileInfo) { + this.value = value; + this.isLineComment = isLineComment; + this._index = index; + this._fileInfo = currentFileInfo; + this.allowRoot = true; + }; + Comment.prototype = Object.assign(new Node(), { + type: 'Comment', + genCSS: function (context, output) { + if (this.debugInfo) { + output.add(debugInfo(context, this), this.fileInfo(), this.getIndex()); + } + output.add(this.value); + }, + isSilent: function (context) { + var isCompressed = context.compress && this.value[2] !== '!'; + return this.isLineComment || isCompressed; + } + }); - var Comment = function (value, isLineComment, index, currentFileInfo) { - this.value = value; - this.isLineComment = isLineComment; - this._index = index; - this._fileInfo = currentFileInfo; - this.allowRoot = true; - }; - Comment.prototype = new Node(); - Comment.prototype.genCSS = function (context, output) { - if (this.debugInfo) { - output.add(debugInfo(context, this), this.fileInfo(), this.getIndex()); - } - output.add(this.value); - }; - Comment.prototype.isSilent = function (context) { - var isCompressed = context.compress && this.value[2] !== '!'; - return this.isLineComment || isCompressed; - }; - Comment.prototype.type = 'Comment'; + var contexts = {}; + var copyFromOriginal = function copyFromOriginal(original, destination, propertiesToCopy) { + if (!original) { + return; + } + for (var i = 0; i < propertiesToCopy.length; i++) { + if (original.hasOwnProperty(propertiesToCopy[i])) { + destination[propertiesToCopy[i]] = original[propertiesToCopy[i]]; + } + } + }; + /* + parse is used whilst parsing + */ + var parseCopyProperties = [ + // options + 'paths', + 'rewriteUrls', + 'rootpath', + 'strictImports', + 'insecure', + 'dumpLineNumbers', + 'compress', + 'syncImport', + 'chunkInput', + 'mime', + 'useFileCache', + // context + 'processImports', + // Used by the import manager to stop multiple import visitors being created. + 'pluginManager' // Used as the plugin manager for the session + ]; + contexts.Parse = function (options) { + copyFromOriginal(options, this, parseCopyProperties); + if (typeof this.paths === 'string') { + this.paths = [this.paths]; + } + }; + var evalCopyProperties = [ + 'paths', + 'compress', + 'math', + 'strictUnits', + 'sourceMap', + 'importMultiple', + 'urlArgs', + 'javascriptEnabled', + 'pluginManager', + 'importantScope', + 'rewriteUrls' // option - whether to adjust URL's to be relative + ]; + contexts.Eval = function (options, frames) { + copyFromOriginal(options, this, evalCopyProperties); + if (typeof this.paths === 'string') { + this.paths = [this.paths]; + } + this.frames = frames || []; + this.importantScope = this.importantScope || []; + }; + contexts.Eval.prototype.enterCalc = function () { + if (!this.calcStack) { + this.calcStack = []; + } + this.calcStack.push(true); + this.inCalc = true; + }; + contexts.Eval.prototype.exitCalc = function () { + this.calcStack.pop(); + if (!this.calcStack.length) { + this.inCalc = false; + } + }; + contexts.Eval.prototype.inParenthesis = function () { + if (!this.parensStack) { + this.parensStack = []; + } + this.parensStack.push(true); + }; + contexts.Eval.prototype.outOfParenthesis = function () { + this.parensStack.pop(); + }; + contexts.Eval.prototype.inCalc = false; + contexts.Eval.prototype.mathOn = true; + contexts.Eval.prototype.isMathOn = function (op) { + if (!this.mathOn) { + return false; + } + if (op === '/' && this.math !== Math$1.ALWAYS && (!this.parensStack || !this.parensStack.length)) { + return false; + } + if (this.math > Math$1.PARENS_DIVISION) { + return this.parensStack && this.parensStack.length; + } + return true; + }; + contexts.Eval.prototype.pathRequiresRewrite = function (path) { + var isRelative = this.rewriteUrls === RewriteUrls.LOCAL ? isPathLocalRelative : isPathRelative; + return isRelative(path); + }; + contexts.Eval.prototype.rewritePath = function (path, rootpath) { + var newPath; + rootpath = rootpath || ''; + newPath = this.normalizePath(rootpath + path); + // If a path was explicit relative and the rootpath was not an absolute path + // we must ensure that the new path is also explicit relative. + if (isPathLocalRelative(path) && + isPathRelative(rootpath) && + isPathLocalRelative(newPath) === false) { + newPath = "./" + newPath; + } + return newPath; + }; + contexts.Eval.prototype.normalizePath = function (path) { + var segments = path.split('/').reverse(); + var segment; + path = []; + while (segments.length !== 0) { + segment = segments.pop(); + switch (segment) { + case '.': + break; + case '..': + if ((path.length === 0) || (path[path.length - 1] === '..')) { + path.push(segment); + } + else { + path.pop(); + } + break; + default: + path.push(segment); + break; + } + } + return path.join('/'); + }; + function isPathRelative(path) { + return !/^(?:[a-z-]+:|\/|#)/i.test(path); + } + function isPathLocalRelative(path) { + return path.charAt(0) === '.'; + } + // todo - do the same for the toCSS ? - var contexts = {}; - var copyFromOriginal = function copyFromOriginal(original, destination, propertiesToCopy) { - if (!original) { - return; - } - for (var i = 0; i < propertiesToCopy.length; i++) { - if (original.hasOwnProperty(propertiesToCopy[i])) { - destination[propertiesToCopy[i]] = original[propertiesToCopy[i]]; - } - } - }; - /* - parse is used whilst parsing - */ - var parseCopyProperties = [ - // options - 'paths', - 'rewriteUrls', - 'rootpath', - 'strictImports', - 'insecure', - 'dumpLineNumbers', - 'compress', - 'syncImport', - 'chunkInput', - 'mime', - 'useFileCache', - // context - 'processImports', - // Used by the import manager to stop multiple import visitors being created. - 'pluginManager' // Used as the plugin manager for the session - ]; - contexts.Parse = function (options) { - copyFromOriginal(options, this, parseCopyProperties); - if (typeof this.paths === 'string') { - this.paths = [this.paths]; - } - }; - var evalCopyProperties = [ - 'paths', - 'compress', - 'math', - 'strictUnits', - 'sourceMap', - 'importMultiple', - 'urlArgs', - 'javascriptEnabled', - 'pluginManager', - 'importantScope', - 'rewriteUrls' // option - whether to adjust URL's to be relative - ]; - function isPathRelative(path) { - return !/^(?:[a-z-]+:|\/|#)/i.test(path); - } - function isPathLocalRelative(path) { - return path.charAt(0) === '.'; - } - contexts.Eval = /** @class */ (function () { - function Eval(options, frames) { - copyFromOriginal(options, this, evalCopyProperties); - if (typeof this.paths === 'string') { - this.paths = [this.paths]; - } - this.frames = frames || []; - this.importantScope = this.importantScope || []; - this.inCalc = false; - this.mathOn = true; - } - Eval.prototype.enterCalc = function () { - if (!this.calcStack) { - this.calcStack = []; - } - this.calcStack.push(true); - this.inCalc = true; - }; - Eval.prototype.exitCalc = function () { - this.calcStack.pop(); - if (!this.calcStack.length) { - this.inCalc = false; - } - }; - Eval.prototype.inParenthesis = function () { - if (!this.parensStack) { - this.parensStack = []; - } - this.parensStack.push(true); - }; - Eval.prototype.outOfParenthesis = function () { - this.parensStack.pop(); - }; - Eval.prototype.isMathOn = function (op) { - if (!this.mathOn) { - return false; - } - if (op === '/' && this.math !== Math$1.ALWAYS && (!this.parensStack || !this.parensStack.length)) { - return false; - } - if (this.math > Math$1.PARENS_DIVISION) { - return this.parensStack && this.parensStack.length; - } - return true; - }; - Eval.prototype.pathRequiresRewrite = function (path) { - var isRelative = this.rewriteUrls === RewriteUrls.LOCAL ? isPathLocalRelative : isPathRelative; - return isRelative(path); - }; - Eval.prototype.rewritePath = function (path, rootpath) { - var newPath; - rootpath = rootpath || ''; - newPath = this.normalizePath(rootpath + path); - // If a path was explicit relative and the rootpath was not an absolute path - // we must ensure that the new path is also explicit relative. - if (isPathLocalRelative(path) && - isPathRelative(rootpath) && - isPathLocalRelative(newPath) === false) { - newPath = "./" + newPath; - } - return newPath; - }; - Eval.prototype.normalizePath = function (path) { - var segments = path.split('/').reverse(); - var segment; - path = []; - while (segments.length !== 0) { - segment = segments.pop(); - switch (segment) { - case '.': - break; - case '..': - if ((path.length === 0) || (path[path.length - 1] === '..')) { - path.push(segment); - } - else { - path.pop(); - } - break; - default: - path.push(segment); - break; - } - } - return path.join('/'); - }; - return Eval; - }()); + function makeRegistry(base) { + return { + _data: {}, + add: function (name, func) { + // precautionary case conversion, as later querying of + // the registry by function-caller uses lower case as well. + name = name.toLowerCase(); + if (this._data.hasOwnProperty(name)) ; + this._data[name] = func; + }, + addMultiple: function (functions) { + var _this = this; + Object.keys(functions).forEach(function (name) { + _this.add(name, functions[name]); + }); + }, + get: function (name) { + return this._data[name] || (base && base.get(name)); + }, + getLocalFunctions: function () { + return this._data; + }, + inherit: function () { + return makeRegistry(this); + }, + create: function (base) { + return makeRegistry(base); + } + }; + } + var functionRegistry = makeRegistry(null); - function makeRegistry(base) { - return { - _data: {}, - add: function (name, func) { - // precautionary case conversion, as later querying of - // the registry by function-caller uses lower case as well. - name = name.toLowerCase(); - if (this._data.hasOwnProperty(name)) ; - this._data[name] = func; - }, - addMultiple: function (functions) { - var _this = this; - Object.keys(functions).forEach(function (name) { - _this.add(name, functions[name]); - }); - }, - get: function (name) { - return this._data[name] || (base && base.get(name)); - }, - getLocalFunctions: function () { - return this._data; - }, - inherit: function () { - return makeRegistry(this); - }, - create: function (base) { - return makeRegistry(base); - } - }; - } - var functionRegistry = makeRegistry(null); + var defaultFunc = { + eval: function () { + var v = this.value_; + var e = this.error_; + if (e) { + throw e; + } + if (v != null) { + return v ? Keyword.True : Keyword.False; + } + }, + value: function (v) { + this.value_ = v; + }, + error: function (e) { + this.error_ = e; + }, + reset: function () { + this.value_ = this.error_ = null; + } + }; - var defaultFunc = { - eval: function () { - var v = this.value_; - var e = this.error_; - if (e) { - throw e; - } - if (v != null) { - return v ? Keyword.True : Keyword.False; - } - }, - value: function (v) { - this.value_ = v; - }, - error: function (e) { - this.error_ = e; - }, - reset: function () { - this.value_ = this.error_ = null; - } - }; + var Ruleset = function (selectors, rules, strictImports, visibilityInfo) { + this.selectors = selectors; + this.rules = rules; + this._lookups = {}; + this._variables = null; + this._properties = null; + this.strictImports = strictImports; + this.copyVisibilityInfo(visibilityInfo); + this.allowRoot = true; + this.setParent(this.selectors, this); + this.setParent(this.rules, this); + }; + Ruleset.prototype = Object.assign(new Node(), { + type: 'Ruleset', + isRuleset: true, + isRulesetLike: function () { return true; }, + accept: function (visitor) { + if (this.paths) { + this.paths = visitor.visitArray(this.paths, true); + } + else if (this.selectors) { + this.selectors = visitor.visitArray(this.selectors); + } + if (this.rules && this.rules.length) { + this.rules = visitor.visitArray(this.rules); + } + }, + eval: function (context) { + var selectors; + var selCnt; + var selector; + var i; + var hasVariable; + var hasOnePassingSelector = false; + if (this.selectors && (selCnt = this.selectors.length)) { + selectors = new Array(selCnt); + defaultFunc.error({ + type: 'Syntax', + message: 'it is currently only allowed in parametric mixin guards,' + }); + for (i = 0; i < selCnt; i++) { + selector = this.selectors[i].eval(context); + for (var j = 0; j < selector.elements.length; j++) { + if (selector.elements[j].isVariable) { + hasVariable = true; + break; + } + } + selectors[i] = selector; + if (selector.evaldCondition) { + hasOnePassingSelector = true; + } + } + if (hasVariable) { + var toParseSelectors = new Array(selCnt); + for (i = 0; i < selCnt; i++) { + selector = selectors[i]; + toParseSelectors[i] = selector.toCSS(context); + } + this.parse.parseNode(toParseSelectors.join(','), ["selectors"], selectors[0].getIndex(), selectors[0].fileInfo(), function (err, result) { + if (result) { + selectors = flattenArray(result); + } + }); + } + defaultFunc.reset(); + } + else { + hasOnePassingSelector = true; + } + var rules = this.rules ? copyArray(this.rules) : null; + var ruleset = new Ruleset(selectors, rules, this.strictImports, this.visibilityInfo()); + var rule; + var subRule; + ruleset.originalRuleset = this; + ruleset.root = this.root; + ruleset.firstRoot = this.firstRoot; + ruleset.allowImports = this.allowImports; + if (this.debugInfo) { + ruleset.debugInfo = this.debugInfo; + } + if (!hasOnePassingSelector) { + rules.length = 0; + } + // inherit a function registry from the frames stack when possible; + // otherwise from the global registry + ruleset.functionRegistry = (function (frames) { + var i = 0; + var n = frames.length; + var found; + for (; i !== n; ++i) { + found = frames[i].functionRegistry; + if (found) { + return found; + } + } + return functionRegistry; + }(context.frames)).inherit(); + // push the current ruleset to the frames stack + var ctxFrames = context.frames; + ctxFrames.unshift(ruleset); + // currrent selectors + var ctxSelectors = context.selectors; + if (!ctxSelectors) { + context.selectors = ctxSelectors = []; + } + ctxSelectors.unshift(this.selectors); + // Evaluate imports + if (ruleset.root || ruleset.allowImports || !ruleset.strictImports) { + ruleset.evalImports(context); + } + // Store the frames around mixin definitions, + // so they can be evaluated like closures when the time comes. + var rsRules = ruleset.rules; + for (i = 0; (rule = rsRules[i]); i++) { + if (rule.evalFirst) { + rsRules[i] = rule.eval(context); + } + } + var mediaBlockCount = (context.mediaBlocks && context.mediaBlocks.length) || 0; + // Evaluate mixin calls. + for (i = 0; (rule = rsRules[i]); i++) { + if (rule.type === 'MixinCall') { + /* jshint loopfunc:true */ + rules = rule.eval(context).filter(function (r) { + if ((r instanceof Declaration) && r.variable) { + // do not pollute the scope if the variable is + // already there. consider returning false here + // but we need a way to "return" variable from mixins + return !(ruleset.variable(r.name)); + } + return true; + }); + rsRules.splice.apply(rsRules, [i, 1].concat(rules)); + i += rules.length - 1; + ruleset.resetCache(); + } + else if (rule.type === 'VariableCall') { + /* jshint loopfunc:true */ + rules = rule.eval(context).rules.filter(function (r) { + if ((r instanceof Declaration) && r.variable) { + // do not pollute the scope at all + return false; + } + return true; + }); + rsRules.splice.apply(rsRules, [i, 1].concat(rules)); + i += rules.length - 1; + ruleset.resetCache(); + } + } + // Evaluate everything else + for (i = 0; (rule = rsRules[i]); i++) { + if (!rule.evalFirst) { + rsRules[i] = rule = rule.eval ? rule.eval(context) : rule; + } + } + // Evaluate everything else + for (i = 0; (rule = rsRules[i]); i++) { + // for rulesets, check if it is a css guard and can be removed + if (rule instanceof Ruleset && rule.selectors && rule.selectors.length === 1) { + // check if it can be folded in (e.g. & where) + if (rule.selectors[0] && rule.selectors[0].isJustParentSelector()) { + rsRules.splice(i--, 1); + for (var j = 0; (subRule = rule.rules[j]); j++) { + if (subRule instanceof Node) { + subRule.copyVisibilityInfo(rule.visibilityInfo()); + if (!(subRule instanceof Declaration) || !subRule.variable) { + rsRules.splice(++i, 0, subRule); + } + } + } + } + } + } + // Pop the stack + ctxFrames.shift(); + ctxSelectors.shift(); + if (context.mediaBlocks) { + for (i = mediaBlockCount; i < context.mediaBlocks.length; i++) { + context.mediaBlocks[i].bubbleSelectors(selectors); + } + } + return ruleset; + }, + evalImports: function (context) { + var rules = this.rules; + var i; + var importRules; + if (!rules) { + return; + } + for (i = 0; i < rules.length; i++) { + if (rules[i].type === 'Import') { + importRules = rules[i].eval(context); + if (importRules && (importRules.length || importRules.length === 0)) { + rules.splice.apply(rules, [i, 1].concat(importRules)); + i += importRules.length - 1; + } + else { + rules.splice(i, 1, importRules); + } + this.resetCache(); + } + } + }, + makeImportant: function () { + var result = new Ruleset(this.selectors, this.rules.map(function (r) { + if (r.makeImportant) { + return r.makeImportant(); + } + else { + return r; + } + }), this.strictImports, this.visibilityInfo()); + return result; + }, + matchArgs: function (args) { + return !args || args.length === 0; + }, + // lets you call a css selector with a guard + matchCondition: function (args, context) { + var lastSelector = this.selectors[this.selectors.length - 1]; + if (!lastSelector.evaldCondition) { + return false; + } + if (lastSelector.condition && + !lastSelector.condition.eval(new contexts.Eval(context, context.frames))) { + return false; + } + return true; + }, + resetCache: function () { + this._rulesets = null; + this._variables = null; + this._properties = null; + this._lookups = {}; + }, + variables: function () { + if (!this._variables) { + this._variables = !this.rules ? {} : this.rules.reduce(function (hash, r) { + if (r instanceof Declaration && r.variable === true) { + hash[r.name] = r; + } + // when evaluating variables in an import statement, imports have not been eval'd + // so we need to go inside import statements. + // guard against root being a string (in the case of inlined less) + if (r.type === 'Import' && r.root && r.root.variables) { + var vars = r.root.variables(); + for (var name_1 in vars) { + if (vars.hasOwnProperty(name_1)) { + hash[name_1] = r.root.variable(name_1); + } + } + } + return hash; + }, {}); + } + return this._variables; + }, + properties: function () { + if (!this._properties) { + this._properties = !this.rules ? {} : this.rules.reduce(function (hash, r) { + if (r instanceof Declaration && r.variable !== true) { + var name_2 = (r.name.length === 1) && (r.name[0] instanceof Keyword) ? + r.name[0].value : r.name; + // Properties don't overwrite as they can merge + if (!hash["$" + name_2]) { + hash["$" + name_2] = [r]; + } + else { + hash["$" + name_2].push(r); + } + } + return hash; + }, {}); + } + return this._properties; + }, + variable: function (name) { + var decl = this.variables()[name]; + if (decl) { + return this.parseValue(decl); + } + }, + property: function (name) { + var decl = this.properties()[name]; + if (decl) { + return this.parseValue(decl); + } + }, + lastDeclaration: function () { + for (var i = this.rules.length; i > 0; i--) { + var decl = this.rules[i - 1]; + if (decl instanceof Declaration) { + return this.parseValue(decl); + } + } + }, + parseValue: function (toParse) { + var self = this; + function transformDeclaration(decl) { + if (decl.value instanceof Anonymous && !decl.parsed) { + if (typeof decl.value.value === 'string') { + this.parse.parseNode(decl.value.value, ['value', 'important'], decl.value.getIndex(), decl.fileInfo(), function (err, result) { + if (err) { + decl.parsed = true; + } + if (result) { + decl.value = result[0]; + decl.important = result[1] || ''; + decl.parsed = true; + } + }); + } + else { + decl.parsed = true; + } + return decl; + } + else { + return decl; + } + } + if (!Array.isArray(toParse)) { + return transformDeclaration.call(self, toParse); + } + else { + var nodes_1 = []; + toParse.forEach(function (n) { + nodes_1.push(transformDeclaration.call(self, n)); + }); + return nodes_1; + } + }, + rulesets: function () { + if (!this.rules) { + return []; + } + var filtRules = []; + var rules = this.rules; + var i; + var rule; + for (i = 0; (rule = rules[i]); i++) { + if (rule.isRuleset) { + filtRules.push(rule); + } + } + return filtRules; + }, + prependRule: function (rule) { + var rules = this.rules; + if (rules) { + rules.unshift(rule); + } + else { + this.rules = [rule]; + } + this.setParent(rule, this); + }, + find: function (selector, self, filter) { + self = self || this; + var rules = []; + var match; + var foundMixins; + var key = selector.toCSS(); + if (key in this._lookups) { + return this._lookups[key]; + } + this.rulesets().forEach(function (rule) { + if (rule !== self) { + for (var j = 0; j < rule.selectors.length; j++) { + match = selector.match(rule.selectors[j]); + if (match) { + if (selector.elements.length > match) { + if (!filter || filter(rule)) { + foundMixins = rule.find(new Selector(selector.elements.slice(match)), self, filter); + for (var i = 0; i < foundMixins.length; ++i) { + foundMixins[i].path.push(rule); + } + Array.prototype.push.apply(rules, foundMixins); + } + } + else { + rules.push({ rule: rule, path: [] }); + } + break; + } + } + } + }); + this._lookups[key] = rules; + return rules; + }, + genCSS: function (context, output) { + var i; + var j; + var charsetRuleNodes = []; + var ruleNodes = []; + var // Line number debugging + debugInfo$1; + var rule; + var path; + context.tabLevel = (context.tabLevel || 0); + if (!this.root) { + context.tabLevel++; + } + var tabRuleStr = context.compress ? '' : Array(context.tabLevel + 1).join(' '); + var tabSetStr = context.compress ? '' : Array(context.tabLevel).join(' '); + var sep; + var charsetNodeIndex = 0; + var importNodeIndex = 0; + for (i = 0; (rule = this.rules[i]); i++) { + if (rule instanceof Comment) { + if (importNodeIndex === i) { + importNodeIndex++; + } + ruleNodes.push(rule); + } + else if (rule.isCharset && rule.isCharset()) { + ruleNodes.splice(charsetNodeIndex, 0, rule); + charsetNodeIndex++; + importNodeIndex++; + } + else if (rule.type === 'Import') { + ruleNodes.splice(importNodeIndex, 0, rule); + importNodeIndex++; + } + else { + ruleNodes.push(rule); + } + } + ruleNodes = charsetRuleNodes.concat(ruleNodes); + // If this is the root node, we don't render + // a selector, or {}. + if (!this.root) { + debugInfo$1 = debugInfo(context, this, tabSetStr); + if (debugInfo$1) { + output.add(debugInfo$1); + output.add(tabSetStr); + } + var paths = this.paths; + var pathCnt = paths.length; + var pathSubCnt = void 0; + sep = context.compress ? ',' : (",\n" + tabSetStr); + for (i = 0; i < pathCnt; i++) { + path = paths[i]; + if (!(pathSubCnt = path.length)) { + continue; + } + if (i > 0) { + output.add(sep); + } + context.firstSelector = true; + path[0].genCSS(context, output); + context.firstSelector = false; + for (j = 1; j < pathSubCnt; j++) { + path[j].genCSS(context, output); + } + } + output.add((context.compress ? '{' : ' {\n') + tabRuleStr); + } + // Compile rules and rulesets + for (i = 0; (rule = ruleNodes[i]); i++) { + if (i + 1 === ruleNodes.length) { + context.lastRule = true; + } + var currentLastRule = context.lastRule; + if (rule.isRulesetLike(rule)) { + context.lastRule = false; + } + if (rule.genCSS) { + rule.genCSS(context, output); + } + else if (rule.value) { + output.add(rule.value.toString()); + } + context.lastRule = currentLastRule; + if (!context.lastRule && rule.isVisible()) { + output.add(context.compress ? '' : ("\n" + tabRuleStr)); + } + else { + context.lastRule = false; + } + } + if (!this.root) { + output.add((context.compress ? '}' : "\n" + tabSetStr + "}")); + context.tabLevel--; + } + if (!output.isEmpty() && !context.compress && this.firstRoot) { + output.add('\n'); + } + }, + joinSelectors: function (paths, context, selectors) { + for (var s = 0; s < selectors.length; s++) { + this.joinSelector(paths, context, selectors[s]); + } + }, + joinSelector: function (paths, context, selector) { + function createParenthesis(elementsToPak, originalElement) { + var replacementParen, j; + if (elementsToPak.length === 0) { + replacementParen = new Paren(elementsToPak[0]); + } + else { + var insideParent = new Array(elementsToPak.length); + for (j = 0; j < elementsToPak.length; j++) { + insideParent[j] = new Element(null, elementsToPak[j], originalElement.isVariable, originalElement._index, originalElement._fileInfo); + } + replacementParen = new Paren(new Selector(insideParent)); + } + return replacementParen; + } + function createSelector(containedElement, originalElement) { + var element, selector; + element = new Element(null, containedElement, originalElement.isVariable, originalElement._index, originalElement._fileInfo); + selector = new Selector([element]); + return selector; + } + // joins selector path from `beginningPath` with selector path in `addPath` + // `replacedElement` contains element that is being replaced by `addPath` + // returns concatenated path + function addReplacementIntoPath(beginningPath, addPath, replacedElement, originalSelector) { + var newSelectorPath, lastSelector, newJoinedSelector; + // our new selector path + newSelectorPath = []; + // construct the joined selector - if & is the first thing this will be empty, + // if not newJoinedSelector will be the last set of elements in the selector + if (beginningPath.length > 0) { + newSelectorPath = copyArray(beginningPath); + lastSelector = newSelectorPath.pop(); + newJoinedSelector = originalSelector.createDerived(copyArray(lastSelector.elements)); + } + else { + newJoinedSelector = originalSelector.createDerived([]); + } + if (addPath.length > 0) { + // /deep/ is a CSS4 selector - (removed, so should deprecate) + // that is valid without anything in front of it + // so if the & does not have a combinator that is "" or " " then + // and there is a combinator on the parent, then grab that. + // this also allows + a { & .b { .a & { ... though not sure why you would want to do that + var combinator = replacedElement.combinator; + var parentEl = addPath[0].elements[0]; + if (combinator.emptyOrWhitespace && !parentEl.combinator.emptyOrWhitespace) { + combinator = parentEl.combinator; + } + // join the elements so far with the first part of the parent + newJoinedSelector.elements.push(new Element(combinator, parentEl.value, replacedElement.isVariable, replacedElement._index, replacedElement._fileInfo)); + newJoinedSelector.elements = newJoinedSelector.elements.concat(addPath[0].elements.slice(1)); + } + // now add the joined selector - but only if it is not empty + if (newJoinedSelector.elements.length !== 0) { + newSelectorPath.push(newJoinedSelector); + } + // put together the parent selectors after the join (e.g. the rest of the parent) + if (addPath.length > 1) { + var restOfPath = addPath.slice(1); + restOfPath = restOfPath.map(function (selector) { + return selector.createDerived(selector.elements, []); + }); + newSelectorPath = newSelectorPath.concat(restOfPath); + } + return newSelectorPath; + } + // joins selector path from `beginningPath` with every selector path in `addPaths` array + // `replacedElement` contains element that is being replaced by `addPath` + // returns array with all concatenated paths + function addAllReplacementsIntoPath(beginningPath, addPaths, replacedElement, originalSelector, result) { + var j; + for (j = 0; j < beginningPath.length; j++) { + var newSelectorPath = addReplacementIntoPath(beginningPath[j], addPaths, replacedElement, originalSelector); + result.push(newSelectorPath); + } + return result; + } + function mergeElementsOnToSelectors(elements, selectors) { + var i, sel; + if (elements.length === 0) { + return; + } + if (selectors.length === 0) { + selectors.push([new Selector(elements)]); + return; + } + for (i = 0; (sel = selectors[i]); i++) { + // if the previous thing in sel is a parent this needs to join on to it + if (sel.length > 0) { + sel[sel.length - 1] = sel[sel.length - 1].createDerived(sel[sel.length - 1].elements.concat(elements)); + } + else { + sel.push(new Selector(elements)); + } + } + } + // replace all parent selectors inside `inSelector` by content of `context` array + // resulting selectors are returned inside `paths` array + // returns true if `inSelector` contained at least one parent selector + function replaceParentSelector(paths, context, inSelector) { + // The paths are [[Selector]] + // The first list is a list of comma separated selectors + // The inner list is a list of inheritance separated selectors + // e.g. + // .a, .b { + // .c { + // } + // } + // == [[.a] [.c]] [[.b] [.c]] + // + var i, j, k, currentElements, newSelectors, selectorsMultiplied, sel, el, hadParentSelector = false, length, lastSelector; + function findNestedSelector(element) { + var maybeSelector; + if (!(element.value instanceof Paren)) { + return null; + } + maybeSelector = element.value.value; + if (!(maybeSelector instanceof Selector)) { + return null; + } + return maybeSelector; + } + // the elements from the current selector so far + currentElements = []; + // the current list of new selectors to add to the path. + // We will build it up. We initiate it with one empty selector as we "multiply" the new selectors + // by the parents + newSelectors = [ + [] + ]; + for (i = 0; (el = inSelector.elements[i]); i++) { + // non parent reference elements just get added + if (el.value !== '&') { + var nestedSelector = findNestedSelector(el); + if (nestedSelector != null) { + // merge the current list of non parent selector elements + // on to the current list of selectors to add + mergeElementsOnToSelectors(currentElements, newSelectors); + var nestedPaths = []; + var replaced = void 0; + var replacedNewSelectors = []; + replaced = replaceParentSelector(nestedPaths, context, nestedSelector); + hadParentSelector = hadParentSelector || replaced; + // the nestedPaths array should have only one member - replaceParentSelector does not multiply selectors + for (k = 0; k < nestedPaths.length; k++) { + var replacementSelector = createSelector(createParenthesis(nestedPaths[k], el), el); + addAllReplacementsIntoPath(newSelectors, [replacementSelector], el, inSelector, replacedNewSelectors); + } + newSelectors = replacedNewSelectors; + currentElements = []; + } + else { + currentElements.push(el); + } + } + else { + hadParentSelector = true; + // the new list of selectors to add + selectorsMultiplied = []; + // merge the current list of non parent selector elements + // on to the current list of selectors to add + mergeElementsOnToSelectors(currentElements, newSelectors); + // loop through our current selectors + for (j = 0; j < newSelectors.length; j++) { + sel = newSelectors[j]; + // if we don't have any parent paths, the & might be in a mixin so that it can be used + // whether there are parents or not + if (context.length === 0) { + // the combinator used on el should now be applied to the next element instead so that + // it is not lost + if (sel.length > 0) { + sel[0].elements.push(new Element(el.combinator, '', el.isVariable, el._index, el._fileInfo)); + } + selectorsMultiplied.push(sel); + } + else { + // and the parent selectors + for (k = 0; k < context.length; k++) { + // We need to put the current selectors + // then join the last selector's elements on to the parents selectors + var newSelectorPath = addReplacementIntoPath(sel, context[k], el, inSelector); + // add that to our new set of selectors + selectorsMultiplied.push(newSelectorPath); + } + } + } + // our new selectors has been multiplied, so reset the state + newSelectors = selectorsMultiplied; + currentElements = []; + } + } + // if we have any elements left over (e.g. .a& .b == .b) + // add them on to all the current selectors + mergeElementsOnToSelectors(currentElements, newSelectors); + for (i = 0; i < newSelectors.length; i++) { + length = newSelectors[i].length; + if (length > 0) { + paths.push(newSelectors[i]); + lastSelector = newSelectors[i][length - 1]; + newSelectors[i][length - 1] = lastSelector.createDerived(lastSelector.elements, inSelector.extendList); + } + } + return hadParentSelector; + } + function deriveSelector(visibilityInfo, deriveFrom) { + var newSelector = deriveFrom.createDerived(deriveFrom.elements, deriveFrom.extendList, deriveFrom.evaldCondition); + newSelector.copyVisibilityInfo(visibilityInfo); + return newSelector; + } + // joinSelector code follows + var i, newPaths, hadParentSelector; + newPaths = []; + hadParentSelector = replaceParentSelector(newPaths, context, selector); + if (!hadParentSelector) { + if (context.length > 0) { + newPaths = []; + for (i = 0; i < context.length; i++) { + var concatenated = context[i].map(deriveSelector.bind(this, selector.visibilityInfo())); + concatenated.push(selector); + newPaths.push(concatenated); + } + } + else { + newPaths = [[selector]]; + } + } + for (i = 0; i < newPaths.length; i++) { + paths.push(newPaths[i]); + } + } + }); - var Ruleset = function (selectors, rules, strictImports, visibilityInfo) { - this.selectors = selectors; - this.rules = rules; - this._lookups = {}; - this._variables = null; - this._properties = null; - this.strictImports = strictImports; - this.copyVisibilityInfo(visibilityInfo); - this.allowRoot = true; - this.setParent(this.selectors, this); - this.setParent(this.rules, this); - }; - Ruleset.prototype = new Node(); - Ruleset.prototype.isRulesetLike = function () { - return true; - }; - Ruleset.prototype.accept = function (visitor) { - if (this.paths) { - this.paths = visitor.visitArray(this.paths, true); - } - else if (this.selectors) { - this.selectors = visitor.visitArray(this.selectors); - } - if (this.rules && this.rules.length) { - this.rules = visitor.visitArray(this.rules); - } - }; - Ruleset.prototype.eval = function (context) { - var selectors; - var selCnt; - var selector; - var i; - var hasVariable; - var hasOnePassingSelector = false; - if (this.selectors && (selCnt = this.selectors.length)) { - selectors = new Array(selCnt); - defaultFunc.error({ - type: 'Syntax', - message: 'it is currently only allowed in parametric mixin guards,' - }); - for (i = 0; i < selCnt; i++) { - selector = this.selectors[i].eval(context); - for (var j = 0; j < selector.elements.length; j++) { - if (selector.elements[j].isVariable) { - hasVariable = true; - break; - } - } - selectors[i] = selector; - if (selector.evaldCondition) { - hasOnePassingSelector = true; - } - } - if (hasVariable) { - var toParseSelectors = new Array(selCnt); - for (i = 0; i < selCnt; i++) { - selector = selectors[i]; - toParseSelectors[i] = selector.toCSS(context); - } - this.parse.parseNode(toParseSelectors.join(','), ["selectors"], selectors[0].getIndex(), selectors[0].fileInfo(), function (err, result) { - if (result) { - selectors = flattenArray(result); - } - }); - } - defaultFunc.reset(); - } - else { - hasOnePassingSelector = true; - } - var rules = this.rules ? copyArray(this.rules) : null; - var ruleset = new Ruleset(selectors, rules, this.strictImports, this.visibilityInfo()); - var rule; - var subRule; - ruleset.originalRuleset = this; - ruleset.root = this.root; - ruleset.firstRoot = this.firstRoot; - ruleset.allowImports = this.allowImports; - if (this.debugInfo) { - ruleset.debugInfo = this.debugInfo; - } - if (!hasOnePassingSelector) { - rules.length = 0; - } - // inherit a function registry from the frames stack when possible; - // otherwise from the global registry - ruleset.functionRegistry = (function (frames) { - var i = 0; - var n = frames.length; - var found; - for (; i !== n; ++i) { - found = frames[i].functionRegistry; - if (found) { - return found; - } - } - return functionRegistry; - })(context.frames).inherit(); - // push the current ruleset to the frames stack - var ctxFrames = context.frames; - ctxFrames.unshift(ruleset); - // currrent selectors - var ctxSelectors = context.selectors; - if (!ctxSelectors) { - context.selectors = ctxSelectors = []; - } - ctxSelectors.unshift(this.selectors); - // Evaluate imports - if (ruleset.root || ruleset.allowImports || !ruleset.strictImports) { - ruleset.evalImports(context); - } - // Store the frames around mixin definitions, - // so they can be evaluated like closures when the time comes. - var rsRules = ruleset.rules; - for (i = 0; (rule = rsRules[i]); i++) { - if (rule.evalFirst) { - rsRules[i] = rule.eval(context); - } - } - var mediaBlockCount = (context.mediaBlocks && context.mediaBlocks.length) || 0; - // Evaluate mixin calls. - for (i = 0; (rule = rsRules[i]); i++) { - if (rule.type === 'MixinCall') { - /* jshint loopfunc:true */ - rules = rule.eval(context).filter(function (r) { - if ((r instanceof Declaration) && r.variable) { - // do not pollute the scope if the variable is - // already there. consider returning false here - // but we need a way to "return" variable from mixins - return !(ruleset.variable(r.name)); - } - return true; - }); - rsRules.splice.apply(rsRules, [i, 1].concat(rules)); - i += rules.length - 1; - ruleset.resetCache(); - } - else if (rule.type === 'VariableCall') { - /* jshint loopfunc:true */ - rules = rule.eval(context).rules.filter(function (r) { - if ((r instanceof Declaration) && r.variable) { - // do not pollute the scope at all - return false; - } - return true; - }); - rsRules.splice.apply(rsRules, [i, 1].concat(rules)); - i += rules.length - 1; - ruleset.resetCache(); - } - } - // Evaluate everything else - for (i = 0; (rule = rsRules[i]); i++) { - if (!rule.evalFirst) { - rsRules[i] = rule = rule.eval ? rule.eval(context) : rule; - } - } - // Evaluate everything else - for (i = 0; (rule = rsRules[i]); i++) { - // for rulesets, check if it is a css guard and can be removed - if (rule instanceof Ruleset && rule.selectors && rule.selectors.length === 1) { - // check if it can be folded in (e.g. & where) - if (rule.selectors[0] && rule.selectors[0].isJustParentSelector()) { - rsRules.splice(i--, 1); - for (var j = 0; (subRule = rule.rules[j]); j++) { - if (subRule instanceof Node) { - subRule.copyVisibilityInfo(rule.visibilityInfo()); - if (!(subRule instanceof Declaration) || !subRule.variable) { - rsRules.splice(++i, 0, subRule); - } - } - } - } - } - } - // Pop the stack - ctxFrames.shift(); - ctxSelectors.shift(); - if (context.mediaBlocks) { - for (i = mediaBlockCount; i < context.mediaBlocks.length; i++) { - context.mediaBlocks[i].bubbleSelectors(selectors); - } - } - return ruleset; - }; - Ruleset.prototype.evalImports = function (context) { - var rules = this.rules; - var i; - var importRules; - if (!rules) { - return; - } - for (i = 0; i < rules.length; i++) { - if (rules[i].type === 'Import') { - importRules = rules[i].eval(context); - if (importRules && (importRules.length || importRules.length === 0)) { - rules.splice.apply(rules, [i, 1].concat(importRules)); - i += importRules.length - 1; - } - else { - rules.splice(i, 1, importRules); - } - this.resetCache(); - } - } - }; - Ruleset.prototype.makeImportant = function () { - var result = new Ruleset(this.selectors, this.rules.map(function (r) { - if (r.makeImportant) { - return r.makeImportant(); - } - else { - return r; - } - }), this.strictImports, this.visibilityInfo()); - return result; - }; - Ruleset.prototype.matchArgs = function (args) { - return !args || args.length === 0; - }; - // lets you call a css selector with a guard - Ruleset.prototype.matchCondition = function (args, context) { - var lastSelector = this.selectors[this.selectors.length - 1]; - if (!lastSelector.evaldCondition) { - return false; - } - if (lastSelector.condition && - !lastSelector.condition.eval(new contexts.Eval(context, context.frames))) { - return false; - } - return true; - }; - Ruleset.prototype.resetCache = function () { - this._rulesets = null; - this._variables = null; - this._properties = null; - this._lookups = {}; - }; - Ruleset.prototype.variables = function () { - if (!this._variables) { - this._variables = !this.rules ? {} : this.rules.reduce(function (hash, r) { - if (r instanceof Declaration && r.variable === true) { - hash[r.name] = r; - } - // when evaluating variables in an import statement, imports have not been eval'd - // so we need to go inside import statements. - // guard against root being a string (in the case of inlined less) - if (r.type === 'Import' && r.root && r.root.variables) { - var vars = r.root.variables(); - for (var name_1 in vars) { - if (vars.hasOwnProperty(name_1)) { - hash[name_1] = r.root.variable(name_1); - } - } - } - return hash; - }, {}); - } - return this._variables; - }; - Ruleset.prototype.properties = function () { - if (!this._properties) { - this._properties = !this.rules ? {} : this.rules.reduce(function (hash, r) { - if (r instanceof Declaration && r.variable !== true) { - var name_2 = (r.name.length === 1) && (r.name[0] instanceof Keyword) ? - r.name[0].value : r.name; - // Properties don't overwrite as they can merge - if (!hash["$" + name_2]) { - hash["$" + name_2] = [r]; - } - else { - hash["$" + name_2].push(r); - } - } - return hash; - }, {}); - } - return this._properties; - }; - Ruleset.prototype.variable = function (name) { - var decl = this.variables()[name]; - if (decl) { - return this.parseValue(decl); - } - }; - Ruleset.prototype.property = function (name) { - var decl = this.properties()[name]; - if (decl) { - return this.parseValue(decl); - } - }; - Ruleset.prototype.lastDeclaration = function () { - for (var i = this.rules.length; i > 0; i--) { - var decl = this.rules[i - 1]; - if (decl instanceof Declaration) { - return this.parseValue(decl); - } - } - }; - Ruleset.prototype.parseValue = function (toParse) { - var self = this; - function transformDeclaration(decl) { - if (decl.value instanceof Anonymous && !decl.parsed) { - if (typeof decl.value.value === 'string') { - this.parse.parseNode(decl.value.value, ['value', 'important'], decl.value.getIndex(), decl.fileInfo(), function (err, result) { - if (err) { - decl.parsed = true; - } - if (result) { - decl.value = result[0]; - decl.important = result[1] || ''; - decl.parsed = true; - } - }); - } - else { - decl.parsed = true; - } - return decl; - } - else { - return decl; - } - } - if (!Array.isArray(toParse)) { - return transformDeclaration.call(self, toParse); - } - else { - var nodes_1 = []; - toParse.forEach(function (n) { - nodes_1.push(transformDeclaration.call(self, n)); - }); - return nodes_1; - } - }; - Ruleset.prototype.rulesets = function () { - if (!this.rules) { - return []; - } - var filtRules = []; - var rules = this.rules; - var i; - var rule; - for (i = 0; (rule = rules[i]); i++) { - if (rule.isRuleset) { - filtRules.push(rule); - } - } - return filtRules; - }; - Ruleset.prototype.prependRule = function (rule) { - var rules = this.rules; - if (rules) { - rules.unshift(rule); - } - else { - this.rules = [rule]; - } - this.setParent(rule, this); - }; - Ruleset.prototype.find = function (selector, self, filter) { - if (self === void 0) { self = this; } - var rules = []; - var match; - var foundMixins; - var key = selector.toCSS(); - if (key in this._lookups) { - return this._lookups[key]; - } - this.rulesets().forEach(function (rule) { - if (rule !== self) { - for (var j = 0; j < rule.selectors.length; j++) { - match = selector.match(rule.selectors[j]); - if (match) { - if (selector.elements.length > match) { - if (!filter || filter(rule)) { - foundMixins = rule.find(new Selector(selector.elements.slice(match)), self, filter); - for (var i = 0; i < foundMixins.length; ++i) { - foundMixins[i].path.push(rule); - } - Array.prototype.push.apply(rules, foundMixins); - } - } - else { - rules.push({ rule: rule, path: [] }); - } - break; - } - } - } - }); - this._lookups[key] = rules; - return rules; - }; - Ruleset.prototype.genCSS = function (context, output) { - var i; - var j; - var charsetRuleNodes = []; - var ruleNodes = []; - var // Line number debugging - debugInfo$1; - var rule; - var path; - context.tabLevel = (context.tabLevel || 0); - if (!this.root) { - context.tabLevel++; - } - var tabRuleStr = context.compress ? '' : Array(context.tabLevel + 1).join(' '); - var tabSetStr = context.compress ? '' : Array(context.tabLevel).join(' '); - var sep; - var charsetNodeIndex = 0; - var importNodeIndex = 0; - for (i = 0; (rule = this.rules[i]); i++) { - if (rule instanceof Comment) { - if (importNodeIndex === i) { - importNodeIndex++; - } - ruleNodes.push(rule); - } - else if (rule.isCharset && rule.isCharset()) { - ruleNodes.splice(charsetNodeIndex, 0, rule); - charsetNodeIndex++; - importNodeIndex++; - } - else if (rule.type === 'Import') { - ruleNodes.splice(importNodeIndex, 0, rule); - importNodeIndex++; - } - else { - ruleNodes.push(rule); - } - } - ruleNodes = charsetRuleNodes.concat(ruleNodes); - // If this is the root node, we don't render - // a selector, or {}. - if (!this.root) { - debugInfo$1 = debugInfo(context, this, tabSetStr); - if (debugInfo$1) { - output.add(debugInfo$1); - output.add(tabSetStr); - } - var paths = this.paths; - var pathCnt = paths.length; - var pathSubCnt = void 0; - sep = context.compress ? ',' : (",\n" + tabSetStr); - for (i = 0; i < pathCnt; i++) { - path = paths[i]; - if (!(pathSubCnt = path.length)) { - continue; - } - if (i > 0) { - output.add(sep); - } - context.firstSelector = true; - path[0].genCSS(context, output); - context.firstSelector = false; - for (j = 1; j < pathSubCnt; j++) { - path[j].genCSS(context, output); - } - } - output.add((context.compress ? '{' : ' {\n') + tabRuleStr); - } - // Compile rules and rulesets - for (i = 0; (rule = ruleNodes[i]); i++) { - if (i + 1 === ruleNodes.length) { - context.lastRule = true; - } - var currentLastRule = context.lastRule; - if (rule.isRulesetLike(rule)) { - context.lastRule = false; - } - if (rule.genCSS) { - rule.genCSS(context, output); - } - else if (rule.value) { - output.add(rule.value.toString()); - } - context.lastRule = currentLastRule; - if (!context.lastRule && rule.isVisible()) { - output.add(context.compress ? '' : ("\n" + tabRuleStr)); - } - else { - context.lastRule = false; - } - } - if (!this.root) { - output.add((context.compress ? '}' : "\n" + tabSetStr + "}")); - context.tabLevel--; - } - if (!output.isEmpty() && !context.compress && this.firstRoot) { - output.add('\n'); - } - }; - Ruleset.prototype.joinSelectors = function (paths, context, selectors) { - for (var s = 0; s < selectors.length; s++) { - this.joinSelector(paths, context, selectors[s]); - } - }; - Ruleset.prototype.joinSelector = function (paths, context, selector) { - function createParenthesis(elementsToPak, originalElement) { - var replacementParen; - var j; - if (elementsToPak.length === 0) { - replacementParen = new Paren(elementsToPak[0]); - } - else { - var insideParent = new Array(elementsToPak.length); - for (j = 0; j < elementsToPak.length; j++) { - insideParent[j] = new Element(null, elementsToPak[j], originalElement.isVariable, originalElement._index, originalElement._fileInfo); - } - replacementParen = new Paren(new Selector(insideParent)); - } - return replacementParen; - } - function createSelector(containedElement, originalElement) { - var element; - var selector; - element = new Element(null, containedElement, originalElement.isVariable, originalElement._index, originalElement._fileInfo); - selector = new Selector([element]); - return selector; - } - // joins selector path from `beginningPath` with selector path in `addPath` - // `replacedElement` contains element that is being replaced by `addPath` - // returns concatenated path - function addReplacementIntoPath(beginningPath, addPath, replacedElement, originalSelector) { - var newSelectorPath; - var lastSelector; - var newJoinedSelector; - // our new selector path - newSelectorPath = []; - // construct the joined selector - if & is the first thing this will be empty, - // if not newJoinedSelector will be the last set of elements in the selector - if (beginningPath.length > 0) { - newSelectorPath = copyArray(beginningPath); - lastSelector = newSelectorPath.pop(); - newJoinedSelector = originalSelector.createDerived(copyArray(lastSelector.elements)); - } - else { - newJoinedSelector = originalSelector.createDerived([]); - } - if (addPath.length > 0) { - // /deep/ is a CSS4 selector - (removed, so should deprecate) - // that is valid without anything in front of it - // so if the & does not have a combinator that is "" or " " then - // and there is a combinator on the parent, then grab that. - // this also allows + a { & .b { .a & { ... though not sure why you would want to do that - var combinator = replacedElement.combinator; - var parentEl = addPath[0].elements[0]; - if (combinator.emptyOrWhitespace && !parentEl.combinator.emptyOrWhitespace) { - combinator = parentEl.combinator; - } - // join the elements so far with the first part of the parent - newJoinedSelector.elements.push(new Element(combinator, parentEl.value, replacedElement.isVariable, replacedElement._index, replacedElement._fileInfo)); - newJoinedSelector.elements = newJoinedSelector.elements.concat(addPath[0].elements.slice(1)); - } - // now add the joined selector - but only if it is not empty - if (newJoinedSelector.elements.length !== 0) { - newSelectorPath.push(newJoinedSelector); - } - // put together the parent selectors after the join (e.g. the rest of the parent) - if (addPath.length > 1) { - var restOfPath = addPath.slice(1); - restOfPath = restOfPath.map(function (selector) { return selector.createDerived(selector.elements, []); }); - newSelectorPath = newSelectorPath.concat(restOfPath); - } - return newSelectorPath; - } - // joins selector path from `beginningPath` with every selector path in `addPaths` array - // `replacedElement` contains element that is being replaced by `addPath` - // returns array with all concatenated paths - function addAllReplacementsIntoPath(beginningPath, addPaths, replacedElement, originalSelector, result) { - var j; - for (j = 0; j < beginningPath.length; j++) { - var newSelectorPath = addReplacementIntoPath(beginningPath[j], addPaths, replacedElement, originalSelector); - result.push(newSelectorPath); - } - return result; - } - function mergeElementsOnToSelectors(elements, selectors) { - var i; - var sel; - if (elements.length === 0) { - return; - } - if (selectors.length === 0) { - selectors.push([new Selector(elements)]); - return; - } - for (i = 0; (sel = selectors[i]); i++) { - // if the previous thing in sel is a parent this needs to join on to it - if (sel.length > 0) { - sel[sel.length - 1] = sel[sel.length - 1].createDerived(sel[sel.length - 1].elements.concat(elements)); - } - else { - sel.push(new Selector(elements)); - } - } - } - // replace all parent selectors inside `inSelector` by content of `context` array - // resulting selectors are returned inside `paths` array - // returns true if `inSelector` contained at least one parent selector - function replaceParentSelector(paths, context, inSelector) { - // The paths are [[Selector]] - // The first list is a list of comma separated selectors - // The inner list is a list of inheritance separated selectors - // e.g. - // .a, .b { - // .c { - // } - // } - // == [[.a] [.c]] [[.b] [.c]] - // - var i; - var j; - var k; - var currentElements; - var newSelectors; - var selectorsMultiplied; - var sel; - var el; - var hadParentSelector = false; - var length; - var lastSelector; - function findNestedSelector(element) { - var maybeSelector; - if (!(element.value instanceof Paren)) { - return null; - } - maybeSelector = element.value.value; - if (!(maybeSelector instanceof Selector)) { - return null; - } - return maybeSelector; - } - // the elements from the current selector so far - currentElements = []; - // the current list of new selectors to add to the path. - // We will build it up. We initiate it with one empty selector as we "multiply" the new selectors - // by the parents - newSelectors = [ - [] - ]; - for (i = 0; (el = inSelector.elements[i]); i++) { - // non parent reference elements just get added - if (el.value !== '&') { - var nestedSelector = findNestedSelector(el); - if (nestedSelector != null) { - // merge the current list of non parent selector elements - // on to the current list of selectors to add - mergeElementsOnToSelectors(currentElements, newSelectors); - var nestedPaths = []; - var replaced = void 0; - var replacedNewSelectors = []; - replaced = replaceParentSelector(nestedPaths, context, nestedSelector); - hadParentSelector = hadParentSelector || replaced; - // the nestedPaths array should have only one member - replaceParentSelector does not multiply selectors - for (k = 0; k < nestedPaths.length; k++) { - var replacementSelector = createSelector(createParenthesis(nestedPaths[k], el), el); - addAllReplacementsIntoPath(newSelectors, [replacementSelector], el, inSelector, replacedNewSelectors); - } - newSelectors = replacedNewSelectors; - currentElements = []; - } - else { - currentElements.push(el); - } - } - else { - hadParentSelector = true; - // the new list of selectors to add - selectorsMultiplied = []; - // merge the current list of non parent selector elements - // on to the current list of selectors to add - mergeElementsOnToSelectors(currentElements, newSelectors); - // loop through our current selectors - for (j = 0; j < newSelectors.length; j++) { - sel = newSelectors[j]; - // if we don't have any parent paths, the & might be in a mixin so that it can be used - // whether there are parents or not - if (context.length === 0) { - // the combinator used on el should now be applied to the next element instead so that - // it is not lost - if (sel.length > 0) { - sel[0].elements.push(new Element(el.combinator, '', el.isVariable, el._index, el._fileInfo)); - } - selectorsMultiplied.push(sel); - } - else { - // and the parent selectors - for (k = 0; k < context.length; k++) { - // We need to put the current selectors - // then join the last selector's elements on to the parents selectors - var newSelectorPath = addReplacementIntoPath(sel, context[k], el, inSelector); - // add that to our new set of selectors - selectorsMultiplied.push(newSelectorPath); - } - } - } - // our new selectors has been multiplied, so reset the state - newSelectors = selectorsMultiplied; - currentElements = []; - } - } - // if we have any elements left over (e.g. .a& .b == .b) - // add them on to all the current selectors - mergeElementsOnToSelectors(currentElements, newSelectors); - for (i = 0; i < newSelectors.length; i++) { - length = newSelectors[i].length; - if (length > 0) { - paths.push(newSelectors[i]); - lastSelector = newSelectors[i][length - 1]; - newSelectors[i][length - 1] = lastSelector.createDerived(lastSelector.elements, inSelector.extendList); - } - } - return hadParentSelector; - } - function deriveSelector(visibilityInfo, deriveFrom) { - var newSelector = deriveFrom.createDerived(deriveFrom.elements, deriveFrom.extendList, deriveFrom.evaldCondition); - newSelector.copyVisibilityInfo(visibilityInfo); - return newSelector; - } - // joinSelector code follows - var i; - var newPaths; - var hadParentSelector; - newPaths = []; - hadParentSelector = replaceParentSelector(newPaths, context, selector); - if (!hadParentSelector) { - if (context.length > 0) { - newPaths = []; - for (i = 0; i < context.length; i++) { - var concatenated = context[i].map(deriveSelector.bind(this, selector.visibilityInfo())); - concatenated.push(selector); - newPaths.push(concatenated); - } - } - else { - newPaths = [[selector]]; - } - } - for (i = 0; i < newPaths.length; i++) { - paths.push(newPaths[i]); - } - }; - Ruleset.prototype.type = 'Ruleset'; - Ruleset.prototype.isRuleset = true; + var AtRule = function (name, value, rules, index, currentFileInfo, debugInfo, isRooted, visibilityInfo) { + var i; + this.name = name; + this.value = (value instanceof Node) ? value : (value ? new Anonymous(value) : value); + if (rules) { + if (Array.isArray(rules)) { + this.rules = rules; + } + else { + this.rules = [rules]; + this.rules[0].selectors = (new Selector([], null, null, index, currentFileInfo)).createEmptySelectors(); + } + for (i = 0; i < this.rules.length; i++) { + this.rules[i].allowImports = true; + } + this.setParent(this.rules, this); + } + this._index = index; + this._fileInfo = currentFileInfo; + this.debugInfo = debugInfo; + this.isRooted = isRooted || false; + this.copyVisibilityInfo(visibilityInfo); + this.allowRoot = true; + }; + AtRule.prototype = Object.assign(new Node(), { + type: 'AtRule', + accept: function (visitor) { + var value = this.value, rules = this.rules; + if (rules) { + this.rules = visitor.visitArray(rules); + } + if (value) { + this.value = visitor.visit(value); + } + }, + isRulesetLike: function () { + return this.rules || !this.isCharset(); + }, + isCharset: function () { + return '@charset' === this.name; + }, + genCSS: function (context, output) { + var value = this.value, rules = this.rules; + output.add(this.name, this.fileInfo(), this.getIndex()); + if (value) { + output.add(' '); + value.genCSS(context, output); + } + if (rules) { + this.outputRuleset(context, output, rules); + } + else { + output.add(';'); + } + }, + eval: function (context) { + var mediaPathBackup, mediaBlocksBackup, value = this.value, rules = this.rules; + // media stored inside other atrule should not bubble over it + // backpup media bubbling information + mediaPathBackup = context.mediaPath; + mediaBlocksBackup = context.mediaBlocks; + // deleted media bubbling information + context.mediaPath = []; + context.mediaBlocks = []; + if (value) { + value = value.eval(context); + } + if (rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + rules = [rules[0].eval(context)]; + rules[0].root = true; + } + // restore media bubbling information + context.mediaPath = mediaPathBackup; + context.mediaBlocks = mediaBlocksBackup; + return new AtRule(this.name, value, rules, this.getIndex(), this.fileInfo(), this.debugInfo, this.isRooted, this.visibilityInfo()); + }, + variable: function (name) { + if (this.rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + return Ruleset.prototype.variable.call(this.rules[0], name); + } + }, + find: function () { + if (this.rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + return Ruleset.prototype.find.apply(this.rules[0], arguments); + } + }, + rulesets: function () { + if (this.rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + return Ruleset.prototype.rulesets.apply(this.rules[0]); + } + }, + outputRuleset: function (context, output, rules) { + var ruleCnt = rules.length; + var i; + context.tabLevel = (context.tabLevel | 0) + 1; + // Compressed + if (context.compress) { + output.add('{'); + for (i = 0; i < ruleCnt; i++) { + rules[i].genCSS(context, output); + } + output.add('}'); + context.tabLevel--; + return; + } + // Non-compressed + var tabSetStr = "\n" + Array(context.tabLevel).join(' '), tabRuleStr = tabSetStr + " "; + if (!ruleCnt) { + output.add(" {" + tabSetStr + "}"); + } + else { + output.add(" {" + tabRuleStr); + rules[0].genCSS(context, output); + for (i = 1; i < ruleCnt; i++) { + output.add(tabRuleStr); + rules[i].genCSS(context, output); + } + output.add(tabSetStr + "}"); + } + context.tabLevel--; + } + }); - var AtRule = function (name, value, rules, index, currentFileInfo, debugInfo, isRooted, visibilityInfo) { - var i; - this.name = name; - this.value = (value instanceof Node) ? value : (value ? new Anonymous(value) : value); - if (rules) { - if (Array.isArray(rules)) { - this.rules = rules; - } - else { - this.rules = [rules]; - this.rules[0].selectors = (new Selector([], null, null, index, currentFileInfo)).createEmptySelectors(); - } - for (i = 0; i < this.rules.length; i++) { - this.rules[i].allowImports = true; - } - this.setParent(this.rules, this); - } - this._index = index; - this._fileInfo = currentFileInfo; - this.debugInfo = debugInfo; - this.isRooted = isRooted || false; - this.copyVisibilityInfo(visibilityInfo); - this.allowRoot = true; - }; - AtRule.prototype = new Node(); - AtRule.prototype.accept = function (visitor) { - var value = this.value; - var rules = this.rules; - if (rules) { - this.rules = visitor.visitArray(rules); - } - if (value) { - this.value = visitor.visit(value); - } - }; - AtRule.prototype.isRulesetLike = function () { - return this.rules || !this.isCharset(); - }; - AtRule.prototype.isCharset = function () { - return '@charset' === this.name; - }; - AtRule.prototype.genCSS = function (context, output) { - var value = this.value; - var rules = this.rules; - output.add(this.name, this.fileInfo(), this.getIndex()); - if (value) { - output.add(' '); - value.genCSS(context, output); - } - if (rules) { - this.outputRuleset(context, output, rules); - } - else { - output.add(';'); - } - }; - AtRule.prototype.eval = function (context) { - var mediaPathBackup; - var mediaBlocksBackup; - var value = this.value; - var rules = this.rules; - // media stored inside other atrule should not bubble over it - // backpup media bubbling information - mediaPathBackup = context.mediaPath; - mediaBlocksBackup = context.mediaBlocks; - // deleted media bubbling information - context.mediaPath = []; - context.mediaBlocks = []; - if (value) { - value = value.eval(context); - } - if (rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - rules = [rules[0].eval(context)]; - rules[0].root = true; - } - // restore media bubbling information - context.mediaPath = mediaPathBackup; - context.mediaBlocks = mediaBlocksBackup; - return new AtRule(this.name, value, rules, this.getIndex(), this.fileInfo(), this.debugInfo, this.isRooted, this.visibilityInfo()); - }; - AtRule.prototype.variable = function (name) { - if (this.rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - return Ruleset.prototype.variable.call(this.rules[0], name); - } - }; - AtRule.prototype.find = function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - if (this.rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - return Ruleset.prototype.find.apply(this.rules[0], args); - } - }; - AtRule.prototype.rulesets = function () { - if (this.rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - return Ruleset.prototype.rulesets.apply(this.rules[0]); - } - }; - AtRule.prototype.outputRuleset = function (context, output, rules) { - var ruleCnt = rules.length; - var i; - context.tabLevel = (context.tabLevel | 0) + 1; - // Compressed - if (context.compress) { - output.add('{'); - for (i = 0; i < ruleCnt; i++) { - rules[i].genCSS(context, output); - } - output.add('}'); - context.tabLevel--; - return; - } - // Non-compressed - var tabSetStr = "\n" + Array(context.tabLevel).join(' '); - var tabRuleStr = tabSetStr + " "; - if (!ruleCnt) { - output.add(" {" + tabSetStr + "}"); - } - else { - output.add(" {" + tabRuleStr); - rules[0].genCSS(context, output); - for (i = 1; i < ruleCnt; i++) { - output.add(tabRuleStr); - rules[i].genCSS(context, output); - } - output.add(tabSetStr + "}"); - } - context.tabLevel--; - }; - AtRule.prototype.type = 'AtRule'; + var DetachedRuleset = function (ruleset, frames) { + this.ruleset = ruleset; + this.frames = frames; + this.setParent(this.ruleset, this); + }; + DetachedRuleset.prototype = Object.assign(new Node(), { + type: 'DetachedRuleset', + evalFirst: true, + accept: function (visitor) { + this.ruleset = visitor.visit(this.ruleset); + }, + eval: function (context) { + var frames = this.frames || copyArray(context.frames); + return new DetachedRuleset(this.ruleset, frames); + }, + callEval: function (context) { + return this.ruleset.eval(this.frames ? new contexts.Eval(context, this.frames.concat(context.frames)) : context); + } + }); - var DetachedRuleset = function (ruleset, frames) { - this.ruleset = ruleset; - this.frames = frames; - this.setParent(this.ruleset, this); - }; - DetachedRuleset.prototype = new Node(); - DetachedRuleset.prototype.accept = function (visitor) { - this.ruleset = visitor.visit(this.ruleset); - }; - DetachedRuleset.prototype.eval = function (context) { - var frames = this.frames || copyArray(context.frames); - return new DetachedRuleset(this.ruleset, frames); - }; - DetachedRuleset.prototype.callEval = function (context) { - return this.ruleset.eval(this.frames ? new contexts.Eval(context, this.frames.concat(context.frames)) : context); - }; - DetachedRuleset.prototype.type = 'DetachedRuleset'; - DetachedRuleset.prototype.evalFirst = true; + var Unit = function (numerator, denominator, backupUnit) { + this.numerator = numerator ? copyArray(numerator).sort() : []; + this.denominator = denominator ? copyArray(denominator).sort() : []; + if (backupUnit) { + this.backupUnit = backupUnit; + } + else if (numerator && numerator.length) { + this.backupUnit = numerator[0]; + } + }; + Unit.prototype = Object.assign(new Node(), { + type: 'Unit', + clone: function () { + return new Unit(copyArray(this.numerator), copyArray(this.denominator), this.backupUnit); + }, + genCSS: function (context, output) { + // Dimension checks the unit is singular and throws an error if in strict math mode. + var strictUnits = context && context.strictUnits; + if (this.numerator.length === 1) { + output.add(this.numerator[0]); // the ideal situation + } + else if (!strictUnits && this.backupUnit) { + output.add(this.backupUnit); + } + else if (!strictUnits && this.denominator.length) { + output.add(this.denominator[0]); + } + }, + toString: function () { + var i, returnStr = this.numerator.join('*'); + for (i = 0; i < this.denominator.length; i++) { + returnStr += "/" + this.denominator[i]; + } + return returnStr; + }, + compare: function (other) { + return this.is(other.toString()) ? 0 : undefined; + }, + is: function (unitString) { + return this.toString().toUpperCase() === unitString.toUpperCase(); + }, + isLength: function () { + return RegExp('^(px|em|ex|ch|rem|in|cm|mm|pc|pt|ex|vw|vh|vmin|vmax)$', 'gi').test(this.toCSS()); + }, + isEmpty: function () { + return this.numerator.length === 0 && this.denominator.length === 0; + }, + isSingular: function () { + return this.numerator.length <= 1 && this.denominator.length === 0; + }, + map: function (callback) { + var i; + for (i = 0; i < this.numerator.length; i++) { + this.numerator[i] = callback(this.numerator[i], false); + } + for (i = 0; i < this.denominator.length; i++) { + this.denominator[i] = callback(this.denominator[i], true); + } + }, + usedUnits: function () { + var group; + var result = {}; + var mapUnit; + var groupName; + mapUnit = function (atomicUnit) { + /* jshint loopfunc:true */ + if (group.hasOwnProperty(atomicUnit) && !result[groupName]) { + result[groupName] = atomicUnit; + } + return atomicUnit; + }; + for (groupName in unitConversions) { + if (unitConversions.hasOwnProperty(groupName)) { + group = unitConversions[groupName]; + this.map(mapUnit); + } + } + return result; + }, + cancel: function () { + var counter = {}; + var atomicUnit; + var i; + for (i = 0; i < this.numerator.length; i++) { + atomicUnit = this.numerator[i]; + counter[atomicUnit] = (counter[atomicUnit] || 0) + 1; + } + for (i = 0; i < this.denominator.length; i++) { + atomicUnit = this.denominator[i]; + counter[atomicUnit] = (counter[atomicUnit] || 0) - 1; + } + this.numerator = []; + this.denominator = []; + for (atomicUnit in counter) { + if (counter.hasOwnProperty(atomicUnit)) { + var count = counter[atomicUnit]; + if (count > 0) { + for (i = 0; i < count; i++) { + this.numerator.push(atomicUnit); + } + } + else if (count < 0) { + for (i = 0; i < -count; i++) { + this.denominator.push(atomicUnit); + } + } + } + } + this.numerator.sort(); + this.denominator.sort(); + } + }); - var Unit = function (numerator, denominator, backupUnit) { - this.numerator = numerator ? copyArray(numerator).sort() : []; - this.denominator = denominator ? copyArray(denominator).sort() : []; - if (backupUnit) { - this.backupUnit = backupUnit; - } - else if (numerator && numerator.length) { - this.backupUnit = numerator[0]; - } - }; - Unit.prototype = new Node(); - Unit.prototype.clone = function () { - return new Unit(copyArray(this.numerator), copyArray(this.denominator), this.backupUnit); - }; - Unit.prototype.genCSS = function (context, output) { - // Dimension checks the unit is singular and throws an error if in strict math mode. - var strictUnits = context && context.strictUnits; - if (this.numerator.length === 1) { - output.add(this.numerator[0]); // the ideal situation - } - else if (!strictUnits && this.backupUnit) { - output.add(this.backupUnit); - } - else if (!strictUnits && this.denominator.length) { - output.add(this.denominator[0]); - } - }; - Unit.prototype.toString = function () { - var i; - var returnStr = this.numerator.join('*'); - for (i = 0; i < this.denominator.length; i++) { - returnStr += "/" + this.denominator[i]; - } - return returnStr; - }; - Unit.prototype.compare = function (other) { - return this.is(other.toString()) ? 0 : undefined; - }; - Unit.prototype.is = function (unitString) { - return this.toString().toUpperCase() === unitString.toUpperCase(); - }; - Unit.prototype.isLength = function () { - return RegExp('^(px|em|ex|ch|rem|in|cm|mm|pc|pt|ex|vw|vh|vmin|vmax)$', 'gi').test(this.toCSS()); - }; - Unit.prototype.isEmpty = function () { - return this.numerator.length === 0 && this.denominator.length === 0; - }; - Unit.prototype.isSingular = function () { - return this.numerator.length <= 1 && this.denominator.length === 0; - }; - Unit.prototype.map = function (callback) { - var i; - for (i = 0; i < this.numerator.length; i++) { - this.numerator[i] = callback(this.numerator[i], false); - } - for (i = 0; i < this.denominator.length; i++) { - this.denominator[i] = callback(this.denominator[i], true); - } - }; - Unit.prototype.usedUnits = function () { - var group; - var result = {}; - var mapUnit; - var groupName; - mapUnit = function (atomicUnit) { - /* jshint loopfunc:true */ - if (group.hasOwnProperty(atomicUnit) && !result[groupName]) { - result[groupName] = atomicUnit; - } - return atomicUnit; - }; - for (groupName in unitConversions) { - if (unitConversions.hasOwnProperty(groupName)) { - group = unitConversions[groupName]; - this.map(mapUnit); - } - } - return result; - }; - Unit.prototype.cancel = function () { - var counter = {}; - var atomicUnit; - var i; - for (i = 0; i < this.numerator.length; i++) { - atomicUnit = this.numerator[i]; - counter[atomicUnit] = (counter[atomicUnit] || 0) + 1; - } - for (i = 0; i < this.denominator.length; i++) { - atomicUnit = this.denominator[i]; - counter[atomicUnit] = (counter[atomicUnit] || 0) - 1; - } - this.numerator = []; - this.denominator = []; - for (atomicUnit in counter) { - if (counter.hasOwnProperty(atomicUnit)) { - var count = counter[atomicUnit]; - if (count > 0) { - for (i = 0; i < count; i++) { - this.numerator.push(atomicUnit); - } - } - else if (count < 0) { - for (i = 0; i < -count; i++) { - this.denominator.push(atomicUnit); - } - } - } - } - this.numerator.sort(); - this.denominator.sort(); - }; - Unit.prototype.type = 'Unit'; + // + // A number with a unit + // + var Dimension = function (value, unit) { + this.value = parseFloat(value); + if (isNaN(this.value)) { + throw new Error('Dimension is not a number.'); + } + this.unit = (unit && unit instanceof Unit) ? unit : + new Unit(unit ? [unit] : undefined); + this.setParent(this.unit, this); + }; + Dimension.prototype = Object.assign(new Node(), { + type: 'Dimension', + accept: function (visitor) { + this.unit = visitor.visit(this.unit); + }, + eval: function (context) { + return this; + }, + toColor: function () { + return new Color([this.value, this.value, this.value]); + }, + genCSS: function (context, output) { + if ((context && context.strictUnits) && !this.unit.isSingular()) { + throw new Error("Multiple units in dimension. Correct the units or use the unit function. Bad unit: " + this.unit.toString()); + } + var value = this.fround(context, this.value); + var strValue = String(value); + if (value !== 0 && value < 0.000001 && value > -0.000001) { + // would be output 1e-6 etc. + strValue = value.toFixed(20).replace(/0+$/, ''); + } + if (context && context.compress) { + // Zero values doesn't need a unit + if (value === 0 && this.unit.isLength()) { + output.add(strValue); + return; + } + // Float values doesn't need a leading zero + if (value > 0 && value < 1) { + strValue = (strValue).substr(1); + } + } + output.add(strValue); + this.unit.genCSS(context, output); + }, + // In an operation between two Dimensions, + // we default to the first Dimension's unit, + // so `1px + 2` will yield `3px`. + operate: function (context, op, other) { + /* jshint noempty:false */ + var value = this._operate(context, op, this.value, other.value), unit = this.unit.clone(); + if (op === '+' || op === '-') { + if (unit.numerator.length === 0 && unit.denominator.length === 0) { + unit = other.unit.clone(); + if (this.unit.backupUnit) { + unit.backupUnit = this.unit.backupUnit; + } + } + else if (other.unit.numerator.length === 0 && unit.denominator.length === 0) ; + else { + other = other.convertTo(this.unit.usedUnits()); + if (context.strictUnits && other.unit.toString() !== unit.toString()) { + throw new Error("Incompatible units. Change the units or use the unit function. " + + ("Bad units: '" + unit.toString() + "' and '" + other.unit.toString() + "'.")); + } + value = this._operate(context, op, this.value, other.value); + } + } + else if (op === '*') { + unit.numerator = unit.numerator.concat(other.unit.numerator).sort(); + unit.denominator = unit.denominator.concat(other.unit.denominator).sort(); + unit.cancel(); + } + else if (op === '/') { + unit.numerator = unit.numerator.concat(other.unit.denominator).sort(); + unit.denominator = unit.denominator.concat(other.unit.numerator).sort(); + unit.cancel(); + } + return new Dimension(value, unit); + }, + compare: function (other) { + var a, b; + if (!(other instanceof Dimension)) { + return undefined; + } + if (this.unit.isEmpty() || other.unit.isEmpty()) { + a = this; + b = other; + } + else { + a = this.unify(); + b = other.unify(); + if (a.unit.compare(b.unit) !== 0) { + return undefined; + } + } + return Node.numericCompare(a.value, b.value); + }, + unify: function () { + return this.convertTo({ length: 'px', duration: 's', angle: 'rad' }); + }, + convertTo: function (conversions) { + var value = this.value; + var unit = this.unit.clone(); + var i; + var groupName; + var group; + var targetUnit; + var derivedConversions = {}; + var applyUnit; + if (typeof conversions === 'string') { + for (i in unitConversions) { + if (unitConversions[i].hasOwnProperty(conversions)) { + derivedConversions = {}; + derivedConversions[i] = conversions; + } + } + conversions = derivedConversions; + } + applyUnit = function (atomicUnit, denominator) { + /* jshint loopfunc:true */ + if (group.hasOwnProperty(atomicUnit)) { + if (denominator) { + value = value / (group[atomicUnit] / group[targetUnit]); + } + else { + value = value * (group[atomicUnit] / group[targetUnit]); + } + return targetUnit; + } + return atomicUnit; + }; + for (groupName in conversions) { + if (conversions.hasOwnProperty(groupName)) { + targetUnit = conversions[groupName]; + group = unitConversions[groupName]; + unit.map(applyUnit); + } + } + unit.cancel(); + return new Dimension(value, unit); + } + }); - // - // A number with a unit - // - var Dimension = function (value, unit) { - this.value = parseFloat(value); - if (isNaN(this.value)) { - throw new Error('Dimension is not a number.'); - } - this.unit = (unit && unit instanceof Unit) ? unit : - new Unit(unit ? [unit] : undefined); - this.setParent(this.unit, this); - }; - Dimension.prototype = new Node(); - Dimension.prototype.accept = function (visitor) { - this.unit = visitor.visit(this.unit); - }; - Dimension.prototype.eval = function (context) { - return this; - }; - Dimension.prototype.toColor = function () { - return new Color([this.value, this.value, this.value]); - }; - Dimension.prototype.genCSS = function (context, output) { - if ((context && context.strictUnits) && !this.unit.isSingular()) { - throw new Error("Multiple units in dimension. Correct the units or use the unit function. Bad unit: " + this.unit.toString()); - } - var value = this.fround(context, this.value); - var strValue = String(value); - if (value !== 0 && value < 0.000001 && value > -0.000001) { - // would be output 1e-6 etc. - strValue = value.toFixed(20).replace(/0+$/, ''); - } - if (context && context.compress) { - // Zero values doesn't need a unit - if (value === 0 && this.unit.isLength()) { - output.add(strValue); - return; - } - // Float values doesn't need a leading zero - if (value > 0 && value < 1) { - strValue = (strValue).substr(1); - } - } - output.add(strValue); - this.unit.genCSS(context, output); - }; - // In an operation between two Dimensions, - // we default to the first Dimension's unit, - // so `1px + 2` will yield `3px`. - Dimension.prototype.operate = function (context, op, other) { - /* jshint noempty:false */ - var value = this._operate(context, op, this.value, other.value); - var unit = this.unit.clone(); - if (op === '+' || op === '-') { - if (unit.numerator.length === 0 && unit.denominator.length === 0) { - unit = other.unit.clone(); - if (this.unit.backupUnit) { - unit.backupUnit = this.unit.backupUnit; - } - } - else if (other.unit.numerator.length === 0 && unit.denominator.length === 0) ; - else { - other = other.convertTo(this.unit.usedUnits()); - if (context.strictUnits && other.unit.toString() !== unit.toString()) { - throw new Error("Incompatible units. Change the units or use the unit function. " + - ("Bad units: '" + unit.toString() + "' and '" + other.unit.toString() + "'.")); - } - value = this._operate(context, op, this.value, other.value); - } - } - else if (op === '*') { - unit.numerator = unit.numerator.concat(other.unit.numerator).sort(); - unit.denominator = unit.denominator.concat(other.unit.denominator).sort(); - unit.cancel(); - } - else if (op === '/') { - unit.numerator = unit.numerator.concat(other.unit.denominator).sort(); - unit.denominator = unit.denominator.concat(other.unit.numerator).sort(); - unit.cancel(); - } - return new Dimension(value, unit); - }; - Dimension.prototype.compare = function (other) { - var a; - var b; - if (!(other instanceof Dimension)) { - return undefined; - } - if (this.unit.isEmpty() || other.unit.isEmpty()) { - a = this; - b = other; - } - else { - a = this.unify(); - b = other.unify(); - if (a.unit.compare(b.unit) !== 0) { - return undefined; - } - } - return Node.numericCompare(a.value, b.value); - }; - Dimension.prototype.unify = function () { - return this.convertTo({ length: 'px', duration: 's', angle: 'rad' }); - }; - Dimension.prototype.convertTo = function (conversions) { - var value = this.value; - var unit = this.unit.clone(); - var i; - var groupName; - var group; - var targetUnit; - var derivedConversions = {}; - var applyUnit; - if (typeof conversions === 'string') { - for (i in unitConversions) { - if (unitConversions[i].hasOwnProperty(conversions)) { - derivedConversions = {}; - derivedConversions[i] = conversions; - } - } - conversions = derivedConversions; - } - applyUnit = function (atomicUnit, denominator) { - /* jshint loopfunc:true */ - if (group.hasOwnProperty(atomicUnit)) { - if (denominator) { - value = value / (group[atomicUnit] / group[targetUnit]); - } - else { - value = value * (group[atomicUnit] / group[targetUnit]); - } - return targetUnit; - } - return atomicUnit; - }; - for (groupName in conversions) { - if (conversions.hasOwnProperty(groupName)) { - targetUnit = conversions[groupName]; - group = unitConversions[groupName]; - unit.map(applyUnit); - } - } - unit.cancel(); - return new Dimension(value, unit); - }; - Dimension.prototype.type = 'Dimension'; + var MATH$1 = Math$1; + var Operation = function (op, operands, isSpaced) { + this.op = op.trim(); + this.operands = operands; + this.isSpaced = isSpaced; + }; + Operation.prototype = Object.assign(new Node(), { + type: 'Operation', + accept: function (visitor) { + this.operands = visitor.visitArray(this.operands); + }, + eval: function (context) { + var a = this.operands[0].eval(context), b = this.operands[1].eval(context), op; + if (context.isMathOn(this.op)) { + op = this.op === './' ? '/' : this.op; + if (a instanceof Dimension && b instanceof Color) { + a = a.toColor(); + } + if (b instanceof Dimension && a instanceof Color) { + b = b.toColor(); + } + if (!a.operate) { + if (a instanceof Operation && a.op === '/' && context.math === MATH$1.PARENS_DIVISION) { + return new Operation(this.op, [a, b], this.isSpaced); + } + throw { type: 'Operation', + message: 'Operation on an invalid type' }; + } + return a.operate(context, op, b); + } + else { + return new Operation(this.op, [a, b], this.isSpaced); + } + }, + genCSS: function (context, output) { + this.operands[0].genCSS(context, output); + if (this.isSpaced) { + output.add(' '); + } + output.add(this.op); + if (this.isSpaced) { + output.add(' '); + } + this.operands[1].genCSS(context, output); + } + }); - var MATH$1 = Math$1; - var Operation = function (op, operands, isSpaced) { - this.op = op.trim(); - this.operands = operands; - this.isSpaced = isSpaced; - }; - Operation.prototype = new Node(); - Operation.prototype.accept = function (visitor) { - this.operands = visitor.visitArray(this.operands); - }; - Operation.prototype.eval = function (context) { - var a = this.operands[0].eval(context); - var b = this.operands[1].eval(context); - var op; - if (context.isMathOn(this.op)) { - op = this.op === './' ? '/' : this.op; - if (a instanceof Dimension && b instanceof Color) { - a = a.toColor(); - } - if (b instanceof Dimension && a instanceof Color) { - b = b.toColor(); - } - if (!a.operate) { - if (a instanceof Operation && a.op === '/' && context.math === MATH$1.PARENS_DIVISION) { - return new Operation(this.op, [a, b], this.isSpaced); - } - throw { type: 'Operation', - message: 'Operation on an invalid type' }; - } - return a.operate(context, op, b); - } - else { - return new Operation(this.op, [a, b], this.isSpaced); - } - }; - Operation.prototype.genCSS = function (context, output) { - this.operands[0].genCSS(context, output); - if (this.isSpaced) { - output.add(' '); - } - output.add(this.op); - if (this.isSpaced) { - output.add(' '); - } - this.operands[1].genCSS(context, output); - }; - Operation.prototype.type = 'Operation'; + /*! ***************************************************************************** + Copyright (c) Microsoft Corporation. - var MATH$2 = Math$1; - var Expression = function (value, noSpacing) { - this.value = value; - this.noSpacing = noSpacing; - if (!value) { - throw new Error('Expression requires an array parameter'); - } - }; - Expression.prototype = new Node(); - Expression.prototype.accept = function (visitor) { - this.value = visitor.visitArray(this.value); - }; - Expression.prototype.eval = function (context) { - var returnValue; - var mathOn = context.isMathOn(); - var inParenthesis = this.parens && - (context.math !== MATH$2.STRICT_LEGACY || !this.parensInOp); - var doubleParen = false; - if (inParenthesis) { - context.inParenthesis(); - } - if (this.value.length > 1) { - returnValue = new Expression(this.value.map(function (e) { - if (!e.eval) { - return e; - } - return e.eval(context); - }), this.noSpacing); - } - else if (this.value.length === 1) { - if (this.value[0].parens && !this.value[0].parensInOp && !context.inCalc) { - doubleParen = true; - } - returnValue = this.value[0].eval(context); - } - else { - returnValue = this; - } - if (inParenthesis) { - context.outOfParenthesis(); - } - if (this.parens && this.parensInOp && !mathOn && !doubleParen - && (!(returnValue instanceof Dimension))) { - returnValue = new Paren(returnValue); - } - return returnValue; - }; - Expression.prototype.genCSS = function (context, output) { - for (var i = 0; i < this.value.length; i++) { - this.value[i].genCSS(context, output); - if (!this.noSpacing && i + 1 < this.value.length) { - output.add(' '); - } - } - }; - Expression.prototype.throwAwayComments = function () { - this.value = this.value.filter(function (v) { return !(v instanceof Comment); }); - }; - Expression.prototype.type = 'Expression'; + Permission to use, copy, modify, and/or distribute this software for any + purpose with or without fee is hereby granted. - var functionCaller = /** @class */ (function () { - function functionCaller(name, context, index, currentFileInfo) { - this.name = name.toLowerCase(); - this.index = index; - this.context = context; - this.currentFileInfo = currentFileInfo; - this.func = context.frames[0].functionRegistry.get(this.name); - } - functionCaller.prototype.isValid = function () { - return Boolean(this.func); - }; - functionCaller.prototype.call = function (args) { - var _this = this; - var evalArgs = this.func.evalArgs; - if (evalArgs !== false) { - args = args.map(function (a) { return a.eval(_this.context); }); - } - // This code is terrible and should be replaced as per this issue... - // https://github.com/less/less.js/issues/2477 - if (Array.isArray(args)) { - args = args.filter(function (item) { - if (item.type === 'Comment') { - return false; - } - return true; - }) - .map(function (item) { - if (item.type === 'Expression') { - var subNodes = item.value.filter(function (item) { - if (item.type === 'Comment') { - return false; - } - return true; - }); - if (subNodes.length === 1) { - return subNodes[0]; - } - else { - return new Expression(subNodes); - } - } - return item; - }); - } - if (evalArgs === false) { - return this.func.apply(this, __spreadArrays([this.context], args)); - } - return this.func.apply(this, args); - }; - return functionCaller; - }()); + THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH + REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY + AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, + INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM + LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR + OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR + PERFORMANCE OF THIS SOFTWARE. + ***************************************************************************** */ + function __spreadArrays$1() { + for (var s = 0, i = 0, il = arguments.length; i < il; i++) + s += arguments[i].length; + for (var r = Array(s), k = 0, i = 0; i < il; i++) + for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) + r[k] = a[j]; + return r; + } - // - // A function call node. - // - var Call = function (name, args, index, currentFileInfo) { - this.name = name; - this.args = args; - this.calc = name === 'calc'; - this._index = index; - this._fileInfo = currentFileInfo; - }; - Call.prototype = new Node(); - Call.prototype.accept = function (visitor) { - if (this.args) { - this.args = visitor.visitArray(this.args); - } - }; - // - // When evaluating a function call, - // we either find the function in the functionRegistry, - // in which case we call it, passing the evaluated arguments, - // if this returns null or we cannot find the function, we - // simply print it out as it appeared originally [2]. - // - // The reason why we evaluate the arguments, is in the case where - // we try to pass a variable to a function, like: `saturate(@color)`. - // The function should receive the value, not the variable. - // - Call.prototype.eval = function (context) { - var _this = this; - /** - * Turn off math for calc(), and switch back on for evaluating nested functions - */ - var currentMathContext = context.mathOn; - context.mathOn = !this.calc; - if (this.calc || context.inCalc) { - context.enterCalc(); - } - var exitCalc = function () { - if (_this.calc || context.inCalc) { - context.exitCalc(); - } - context.mathOn = currentMathContext; - }; - var result; - var funcCaller = new functionCaller(this.name, context, this.getIndex(), this.fileInfo()); - if (funcCaller.isValid()) { - try { - result = funcCaller.call(this.args); - exitCalc(); - } - catch (e) { - if (e.hasOwnProperty('line') && e.hasOwnProperty('column')) { - throw e; - } - throw { - type: e.type || 'Runtime', - message: "error evaluating function `" + this.name + "`" + (e.message ? ": " + e.message : ''), - index: this.getIndex(), - filename: this.fileInfo().filename, - line: e.lineNumber, - column: e.columnNumber - }; - } - if (result !== null && result !== undefined) { - // Results that that are not nodes are cast as Anonymous nodes - // Falsy values or booleans are returned as empty nodes - if (!(result instanceof Node)) { - if (!result || result === true) { - result = new Anonymous(null); - } - else { - result = new Anonymous(result.toString()); - } - } - result._index = this._index; - result._fileInfo = this._fileInfo; - return result; - } - } - var args = this.args.map(function (a) { return a.eval(context); }); - exitCalc(); - return new Call(this.name, args, this.getIndex(), this.fileInfo()); - }; - Call.prototype.genCSS = function (context, output) { - output.add(this.name + "(", this.fileInfo(), this.getIndex()); - for (var i = 0; i < this.args.length; i++) { - this.args[i].genCSS(context, output); - if (i + 1 < this.args.length) { - output.add(', '); - } - } - output.add(')'); - }; - Call.prototype.type = 'Call'; + var Expression = function (value, noSpacing) { + this.value = value; + this.noSpacing = noSpacing; + if (!value) { + throw new Error('Expression requires an array parameter'); + } + }; + Expression.prototype = Object.assign(new Node(), { + type: 'Expression', + accept: function (visitor) { + this.value = visitor.visitArray(this.value); + }, + eval: function (context) { + var returnValue; + var mathOn = context.isMathOn(); + var inParenthesis = this.parens; + var doubleParen = false; + if (inParenthesis) { + context.inParenthesis(); + } + if (this.value.length > 1) { + returnValue = new Expression(this.value.map(function (e) { + if (!e.eval) { + return e; + } + return e.eval(context); + }), this.noSpacing); + } + else if (this.value.length === 1) { + if (this.value[0].parens && !this.value[0].parensInOp && !context.inCalc) { + doubleParen = true; + } + returnValue = this.value[0].eval(context); + } + else { + returnValue = this; + } + if (inParenthesis) { + context.outOfParenthesis(); + } + if (this.parens && this.parensInOp && !mathOn && !doubleParen + && (!(returnValue instanceof Dimension))) { + returnValue = new Paren(returnValue); + } + return returnValue; + }, + genCSS: function (context, output) { + for (var i = 0; i < this.value.length; i++) { + this.value[i].genCSS(context, output); + if (!this.noSpacing && i + 1 < this.value.length) { + output.add(' '); + } + } + }, + throwAwayComments: function () { + this.value = this.value.filter(function (v) { + return !(v instanceof Comment); + }); + } + }); - var Variable = function (name, index, currentFileInfo) { - this.name = name; - this._index = index; - this._fileInfo = currentFileInfo; - }; - Variable.prototype = new Node(); - Variable.prototype.eval = function (context) { - var variable; - var name = this.name; - if (name.indexOf('@@') === 0) { - name = "@" + new Variable(name.slice(1), this.getIndex(), this.fileInfo()).eval(context).value; - } - if (this.evaluating) { - throw { type: 'Name', message: "Recursive variable definition for " + name, filename: this.fileInfo().filename, - index: this.getIndex() }; - } - this.evaluating = true; - variable = this.find(context.frames, function (frame) { - var v = frame.variable(name); - if (v) { - if (v.important) { - var importantScope = context.importantScope[context.importantScope.length - 1]; - importantScope.important = v.important; - } - // If in calc, wrap vars in a function call to cascade evaluate args first - if (context.inCalc) { - return (new Call('_SELF', [v.value])).eval(context); - } - else { - return v.value.eval(context); - } - } - }); - if (variable) { - this.evaluating = false; - return variable; - } - else { - throw { type: 'Name', message: "variable " + name + " is undefined", filename: this.fileInfo().filename, - index: this.getIndex() }; - } - }; - Variable.prototype.find = function (obj, fun) { - for (var i = 0, r = void 0; i < obj.length; i++) { - r = fun.call(obj, obj[i]); - if (r) { - return r; - } - } - return null; - }; - Variable.prototype.type = 'Variable'; + var functionCaller = /** @class */ (function () { + function functionCaller(name, context, index, currentFileInfo) { + this.name = name.toLowerCase(); + this.index = index; + this.context = context; + this.currentFileInfo = currentFileInfo; + this.func = context.frames[0].functionRegistry.get(this.name); + } + functionCaller.prototype.isValid = function () { + return Boolean(this.func); + }; + functionCaller.prototype.call = function (args) { + var _this = this; + if (!(Array.isArray(args))) { + args = [args]; + } + var evalArgs = this.func.evalArgs; + if (evalArgs !== false) { + args = args.map(function (a) { return a.eval(_this.context); }); + } + var commentFilter = function (item) { return !(item.type === 'Comment'); }; + // This code is terrible and should be replaced as per this issue... + // https://github.com/less/less.js/issues/2477 + args = args + .filter(commentFilter) + .map(function (item) { + if (item.type === 'Expression') { + var subNodes = item.value.filter(commentFilter); + if (subNodes.length === 1) { + return subNodes[0]; + } + else { + return new Expression(subNodes); + } + } + return item; + }); + if (evalArgs === false) { + return this.func.apply(this, __spreadArrays$1([this.context], args)); + } + return this.func.apply(this, args); + }; + return functionCaller; + }()); - var Property = function (name, index, currentFileInfo) { - this.name = name; - this._index = index; - this._fileInfo = currentFileInfo; - }; - Property.prototype = new Node(); - Property.prototype.eval = function (context) { - var property; - var name = this.name; - // TODO: shorten this reference - var mergeRules = context.pluginManager.less.visitors.ToCSSVisitor.prototype._mergeRules; - if (this.evaluating) { - throw { type: 'Name', message: "Recursive property reference for " + name, filename: this.fileInfo().filename, - index: this.getIndex() }; - } - this.evaluating = true; - property = this.find(context.frames, function (frame) { - var v; - var vArr = frame.property(name); - if (vArr) { - for (var i = 0; i < vArr.length; i++) { - v = vArr[i]; - vArr[i] = new Declaration(v.name, v.value, v.important, v.merge, v.index, v.currentFileInfo, v.inline, v.variable); - } - mergeRules(vArr); - v = vArr[vArr.length - 1]; - if (v.important) { - var importantScope = context.importantScope[context.importantScope.length - 1]; - importantScope.important = v.important; - } - v = v.value.eval(context); - return v; - } - }); - if (property) { - this.evaluating = false; - return property; - } - else { - throw { type: 'Name', message: "Property '" + name + "' is undefined", filename: this.currentFileInfo.filename, - index: this.index }; - } - }; - Property.prototype.find = function (obj, fun) { - for (var i = 0, r = void 0; i < obj.length; i++) { - r = fun.call(obj, obj[i]); - if (r) { - return r; - } - } - return null; - }; - Property.prototype.type = 'Property'; + // + // A function call node. + // + var Call = function (name, args, index, currentFileInfo) { + this.name = name; + this.args = args; + this.calc = name === 'calc'; + this._index = index; + this._fileInfo = currentFileInfo; + }; + Call.prototype = Object.assign(new Node(), { + type: 'Call', + accept: function (visitor) { + if (this.args) { + this.args = visitor.visitArray(this.args); + } + }, + // + // When evaluating a function call, + // we either find the function in the functionRegistry, + // in which case we call it, passing the evaluated arguments, + // if this returns null or we cannot find the function, we + // simply print it out as it appeared originally [2]. + // + // The reason why we evaluate the arguments, is in the case where + // we try to pass a variable to a function, like: `saturate(@color)`. + // The function should receive the value, not the variable. + // + eval: function (context) { + var _this = this; + /** + * Turn off math for calc(), and switch back on for evaluating nested functions + */ + var currentMathContext = context.mathOn; + context.mathOn = !this.calc; + if (this.calc || context.inCalc) { + context.enterCalc(); + } + var exitCalc = function () { + if (_this.calc || context.inCalc) { + context.exitCalc(); + } + context.mathOn = currentMathContext; + }; + var result; + var funcCaller = new functionCaller(this.name, context, this.getIndex(), this.fileInfo()); + if (funcCaller.isValid()) { + try { + result = funcCaller.call(this.args); + exitCalc(); + } + catch (e) { + if (e.hasOwnProperty('line') && e.hasOwnProperty('column')) { + throw e; + } + throw { + type: e.type || 'Runtime', + message: "Error evaluating function `" + this.name + "`" + (e.message ? ": " + e.message : ''), + index: this.getIndex(), + filename: this.fileInfo().filename, + line: e.lineNumber, + column: e.columnNumber + }; + } + } + if (result !== null && result !== undefined) { + // Results that that are not nodes are cast as Anonymous nodes + // Falsy values or booleans are returned as empty nodes + if (!(result instanceof Node)) { + if (!result || result === true) { + result = new Anonymous(null); + } + else { + result = new Anonymous(result.toString()); + } + } + result._index = this._index; + result._fileInfo = this._fileInfo; + return result; + } + var args = this.args.map(function (a) { return a.eval(context); }); + exitCalc(); + return new Call(this.name, args, this.getIndex(), this.fileInfo()); + }, + genCSS: function (context, output) { + output.add(this.name + "(", this.fileInfo(), this.getIndex()); + for (var i = 0; i < this.args.length; i++) { + this.args[i].genCSS(context, output); + if (i + 1 < this.args.length) { + output.add(', '); + } + } + output.add(')'); + } + }); - var Attribute = function (key, op, value) { - this.key = key; - this.op = op; - this.value = value; - }; - Attribute.prototype = new Node(); - Attribute.prototype.eval = function (context) { - return new Attribute(this.key.eval ? this.key.eval(context) : this.key, this.op, (this.value && this.value.eval) ? this.value.eval(context) : this.value); - }; - Attribute.prototype.genCSS = function (context, output) { - output.add(this.toCSS(context)); - }; - Attribute.prototype.toCSS = function (context) { - var value = this.key.toCSS ? this.key.toCSS(context) : this.key; - if (this.op) { - value += this.op; - value += (this.value.toCSS ? this.value.toCSS(context) : this.value); - } - return "[" + value + "]"; - }; - Attribute.prototype.type = 'Attribute'; + var Variable = function (name, index, currentFileInfo) { + this.name = name; + this._index = index; + this._fileInfo = currentFileInfo; + }; + Variable.prototype = Object.assign(new Node(), { + type: 'Variable', + eval: function (context) { + var variable, name = this.name; + if (name.indexOf('@@') === 0) { + name = "@" + new Variable(name.slice(1), this.getIndex(), this.fileInfo()).eval(context).value; + } + if (this.evaluating) { + throw { type: 'Name', message: "Recursive variable definition for " + name, filename: this.fileInfo().filename, + index: this.getIndex() }; + } + this.evaluating = true; + variable = this.find(context.frames, function (frame) { + var v = frame.variable(name); + if (v) { + if (v.important) { + var importantScope = context.importantScope[context.importantScope.length - 1]; + importantScope.important = v.important; + } + // If in calc, wrap vars in a function call to cascade evaluate args first + if (context.inCalc) { + return (new Call('_SELF', [v.value])).eval(context); + } + else { + return v.value.eval(context); + } + } + }); + if (variable) { + this.evaluating = false; + return variable; + } + else { + throw { type: 'Name', message: "variable " + name + " is undefined", filename: this.fileInfo().filename, + index: this.getIndex() }; + } + }, + find: function (obj, fun) { + for (var i = 0, r = void 0; i < obj.length; i++) { + r = fun.call(obj, obj[i]); + if (r) { + return r; + } + } + return null; + } + }); - var Quoted = function (str, content, escaped, index, currentFileInfo) { - this.escaped = (escaped == null) ? true : escaped; - this.value = content || ''; - this.quote = str.charAt(0); - this._index = index; - this._fileInfo = currentFileInfo; - this.variableRegex = /@\{([\w-]+)\}/g; - this.propRegex = /\$\{([\w-]+)\}/g; - this.allowRoot = escaped; - }; - Quoted.prototype = new Node(); - Quoted.prototype.genCSS = function (context, output) { - if (!this.escaped) { - output.add(this.quote, this.fileInfo(), this.getIndex()); - } - output.add(this.value); - if (!this.escaped) { - output.add(this.quote); - } - }; - Quoted.prototype.containsVariables = function () { - return this.value.match(this.variableRegex); - }; - Quoted.prototype.eval = function (context) { - var that = this; - var value = this.value; - var variableReplacement = function (_, name) { - var v = new Variable("@" + name, that.getIndex(), that.fileInfo()).eval(context, true); - return (v instanceof Quoted) ? v.value : v.toCSS(); - }; - var propertyReplacement = function (_, name) { - var v = new Property("$" + name, that.getIndex(), that.fileInfo()).eval(context, true); - return (v instanceof Quoted) ? v.value : v.toCSS(); - }; - function iterativeReplace(value, regexp, replacementFnc) { - var evaluatedValue = value; - do { - value = evaluatedValue.toString(); - evaluatedValue = value.replace(regexp, replacementFnc); - } while (value !== evaluatedValue); - return evaluatedValue; - } - value = iterativeReplace(value, this.variableRegex, variableReplacement); - value = iterativeReplace(value, this.propRegex, propertyReplacement); - return new Quoted(this.quote + value + this.quote, value, this.escaped, this.getIndex(), this.fileInfo()); - }; - Quoted.prototype.compare = function (other) { - // when comparing quoted strings allow the quote to differ - if (other.type === 'Quoted' && !this.escaped && !other.escaped) { - return Node.numericCompare(this.value, other.value); - } - else { - return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; - } - }; - Quoted.prototype.type = 'Quoted'; + var Property = function (name, index, currentFileInfo) { + this.name = name; + this._index = index; + this._fileInfo = currentFileInfo; + }; + Property.prototype = Object.assign(new Node(), { + type: 'Property', + eval: function (context) { + var property; + var name = this.name; + // TODO: shorten this reference + var mergeRules = context.pluginManager.less.visitors.ToCSSVisitor.prototype._mergeRules; + if (this.evaluating) { + throw { type: 'Name', message: "Recursive property reference for " + name, filename: this.fileInfo().filename, + index: this.getIndex() }; + } + this.evaluating = true; + property = this.find(context.frames, function (frame) { + var v; + var vArr = frame.property(name); + if (vArr) { + for (var i = 0; i < vArr.length; i++) { + v = vArr[i]; + vArr[i] = new Declaration(v.name, v.value, v.important, v.merge, v.index, v.currentFileInfo, v.inline, v.variable); + } + mergeRules(vArr); + v = vArr[vArr.length - 1]; + if (v.important) { + var importantScope = context.importantScope[context.importantScope.length - 1]; + importantScope.important = v.important; + } + v = v.value.eval(context); + return v; + } + }); + if (property) { + this.evaluating = false; + return property; + } + else { + throw { type: 'Name', message: "Property '" + name + "' is undefined", filename: this.currentFileInfo.filename, + index: this.index }; + } + }, + find: function (obj, fun) { + for (var i = 0, r = void 0; i < obj.length; i++) { + r = fun.call(obj, obj[i]); + if (r) { + return r; + } + } + return null; + } + }); - var URL = function (val, index, currentFileInfo, isEvald) { - this.value = val; - this._index = index; - this._fileInfo = currentFileInfo; - this.isEvald = isEvald; - }; - URL.prototype = new Node(); - URL.prototype.accept = function (visitor) { - this.value = visitor.visit(this.value); - }; - URL.prototype.genCSS = function (context, output) { - output.add('url('); - this.value.genCSS(context, output); - output.add(')'); - }; - URL.prototype.eval = function (context) { - var val = this.value.eval(context); - var rootpath; - if (!this.isEvald) { - // Add the rootpath if the URL requires a rewrite - rootpath = this.fileInfo() && this.fileInfo().rootpath; - if (typeof rootpath === 'string' && - typeof val.value === 'string' && - context.pathRequiresRewrite(val.value)) { - if (!val.quote) { - rootpath = escapePath(rootpath); - } - val.value = context.rewritePath(val.value, rootpath); - } - else { - val.value = context.normalizePath(val.value); - } - // Add url args if enabled - if (context.urlArgs) { - if (!val.value.match(/^\s*data:/)) { - var delimiter = val.value.indexOf('?') === -1 ? '?' : '&'; - var urlArgs = delimiter + context.urlArgs; - if (val.value.indexOf('#') !== -1) { - val.value = val.value.replace('#', urlArgs + "#"); - } - else { - val.value += urlArgs; - } - } - } - } - return new URL(val, this.getIndex(), this.fileInfo(), true); - }; - URL.prototype.type = 'Url'; - function escapePath(path) { - return path.replace(/[\(\)'"\s]/g, function (match) { return "\\" + match; }); - } + var Attribute = function (key, op, value) { + this.key = key; + this.op = op; + this.value = value; + }; + Attribute.prototype = Object.assign(new Node(), { + type: 'Attribute', + eval: function (context) { + return new Attribute(this.key.eval ? this.key.eval(context) : this.key, this.op, (this.value && this.value.eval) ? this.value.eval(context) : this.value); + }, + genCSS: function (context, output) { + output.add(this.toCSS(context)); + }, + toCSS: function (context) { + var value = this.key.toCSS ? this.key.toCSS(context) : this.key; + if (this.op) { + value += this.op; + value += (this.value.toCSS ? this.value.toCSS(context) : this.value); + } + return "[" + value + "]"; + } + }); - var Media = function (value, features, index, currentFileInfo, visibilityInfo) { - this._index = index; - this._fileInfo = currentFileInfo; - var selectors = (new Selector([], null, null, this._index, this._fileInfo)).createEmptySelectors(); - this.features = new Value(features); - this.rules = [new Ruleset(selectors, value)]; - this.rules[0].allowImports = true; - this.copyVisibilityInfo(visibilityInfo); - this.allowRoot = true; - this.setParent(selectors, this); - this.setParent(this.features, this); - this.setParent(this.rules, this); - }; - Media.prototype = new AtRule(); - Media.prototype.isRulesetLike = function () { - return true; - }; - Media.prototype.accept = function (visitor) { - if (this.features) { - this.features = visitor.visit(this.features); - } - if (this.rules) { - this.rules = visitor.visitArray(this.rules); - } - }; - Media.prototype.genCSS = function (context, output) { - output.add('@media ', this._fileInfo, this._index); - this.features.genCSS(context, output); - this.outputRuleset(context, output, this.rules); - }; - Media.prototype.eval = function (context) { - if (!context.mediaBlocks) { - context.mediaBlocks = []; - context.mediaPath = []; - } - var media = new Media(null, [], this._index, this._fileInfo, this.visibilityInfo()); - if (this.debugInfo) { - this.rules[0].debugInfo = this.debugInfo; - media.debugInfo = this.debugInfo; - } - media.features = this.features.eval(context); - context.mediaPath.push(media); - context.mediaBlocks.push(media); - this.rules[0].functionRegistry = context.frames[0].functionRegistry.inherit(); - context.frames.unshift(this.rules[0]); - media.rules = [this.rules[0].eval(context)]; - context.frames.shift(); - context.mediaPath.pop(); - return context.mediaPath.length === 0 ? media.evalTop(context) : - media.evalNested(context); - }; - Media.prototype.evalTop = function (context) { - var result = this; - // Render all dependent Media blocks. - if (context.mediaBlocks.length > 1) { - var selectors = (new Selector([], null, null, this.getIndex(), this.fileInfo())).createEmptySelectors(); - result = new Ruleset(selectors, context.mediaBlocks); - result.multiMedia = true; - result.copyVisibilityInfo(this.visibilityInfo()); - this.setParent(result, this); - } - delete context.mediaBlocks; - delete context.mediaPath; - return result; - }; - Media.prototype.evalNested = function (context) { - var i; - var value; - var path = context.mediaPath.concat([this]); - // Extract the media-query conditions separated with `,` (OR). - for (i = 0; i < path.length; i++) { - value = path[i].features instanceof Value ? - path[i].features.value : path[i].features; - path[i] = Array.isArray(value) ? value : [value]; - } - // Trace all permutations to generate the resulting media-query. - // - // (a, b and c) with nested (d, e) -> - // a and d - // a and e - // b and c and d - // b and c and e - this.features = new Value(this.permute(path).map(function (path) { - path = path.map(function (fragment) { return fragment.toCSS ? fragment : new Anonymous(fragment); }); - for (i = path.length - 1; i > 0; i--) { - path.splice(i, 0, new Anonymous('and')); - } - return new Expression(path); - })); - this.setParent(this.features, this); - // Fake a tree-node that doesn't output anything. - return new Ruleset([], []); - }; - Media.prototype.permute = function (arr) { - if (arr.length === 0) { - return []; - } - else if (arr.length === 1) { - return arr[0]; - } - else { - var result = []; - var rest = this.permute(arr.slice(1)); - for (var i = 0; i < rest.length; i++) { - for (var j = 0; j < arr[0].length; j++) { - result.push([arr[0][j]].concat(rest[i])); - } - } - return result; - } - }; - Media.prototype.bubbleSelectors = function (selectors) { - if (!selectors) { - return; - } - this.rules = [new Ruleset(copyArray(selectors), [this.rules[0]])]; - this.setParent(this.rules, this); - }; - Media.prototype.type = 'Media'; + var Quoted = function (str, content, escaped, index, currentFileInfo) { + this.escaped = (escaped == null) ? true : escaped; + this.value = content || ''; + this.quote = str.charAt(0); + this._index = index; + this._fileInfo = currentFileInfo; + this.variableRegex = /@\{([\w-]+)\}/g; + this.propRegex = /\$\{([\w-]+)\}/g; + this.allowRoot = escaped; + }; + Quoted.prototype = Object.assign(new Node(), { + type: 'Quoted', + genCSS: function (context, output) { + if (!this.escaped) { + output.add(this.quote, this.fileInfo(), this.getIndex()); + } + output.add(this.value); + if (!this.escaped) { + output.add(this.quote); + } + }, + containsVariables: function () { + return this.value.match(this.variableRegex); + }, + eval: function (context) { + var that = this; + var value = this.value; + var variableReplacement = function (_, name) { + var v = new Variable("@" + name, that.getIndex(), that.fileInfo()).eval(context, true); + return (v instanceof Quoted) ? v.value : v.toCSS(); + }; + var propertyReplacement = function (_, name) { + var v = new Property("$" + name, that.getIndex(), that.fileInfo()).eval(context, true); + return (v instanceof Quoted) ? v.value : v.toCSS(); + }; + function iterativeReplace(value, regexp, replacementFnc) { + var evaluatedValue = value; + do { + value = evaluatedValue.toString(); + evaluatedValue = value.replace(regexp, replacementFnc); + } while (value !== evaluatedValue); + return evaluatedValue; + } + value = iterativeReplace(value, this.variableRegex, variableReplacement); + value = iterativeReplace(value, this.propRegex, propertyReplacement); + return new Quoted(this.quote + value + this.quote, value, this.escaped, this.getIndex(), this.fileInfo()); + }, + compare: function (other) { + // when comparing quoted strings allow the quote to differ + if (other.type === 'Quoted' && !this.escaped && !other.escaped) { + return Node.numericCompare(this.value, other.value); + } + else { + return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; + } + } + }); - // - // CSS @import node - // - // The general strategy here is that we don't want to wait - // for the parsing to be completed, before we start importing - // the file. That's because in the context of a browser, - // most of the time will be spent waiting for the server to respond. - // - // On creation, we push the import path to our import queue, though - // `import,push`, we also pass it a callback, which it'll call once - // the file has been fetched, and parsed. - // - var Import = function (path, features, options, index, currentFileInfo, visibilityInfo) { - this.options = options; - this._index = index; - this._fileInfo = currentFileInfo; - this.path = path; - this.features = features; - this.allowRoot = true; - if (this.options.less !== undefined || this.options.inline) { - this.css = !this.options.less || this.options.inline; - } - else { - var pathValue = this.getPath(); - if (pathValue && /[#\.\&\?]css([\?;].*)?$/.test(pathValue)) { - this.css = true; - } - } - this.copyVisibilityInfo(visibilityInfo); - this.setParent(this.features, this); - this.setParent(this.path, this); - }; - Import.prototype = new Node(); - Import.prototype.accept = function (visitor) { - if (this.features) { - this.features = visitor.visit(this.features); - } - this.path = visitor.visit(this.path); - if (!this.options.isPlugin && !this.options.inline && this.root) { - this.root = visitor.visit(this.root); - } - }; - Import.prototype.genCSS = function (context, output) { - if (this.css && this.path._fileInfo.reference === undefined) { - output.add('@import ', this._fileInfo, this._index); - this.path.genCSS(context, output); - if (this.features) { - output.add(' '); - this.features.genCSS(context, output); - } - output.add(';'); - } - }; - Import.prototype.getPath = function () { - return (this.path instanceof URL) ? - this.path.value.value : this.path.value; - }; - Import.prototype.isVariableImport = function () { - var path = this.path; - if (path instanceof URL) { - path = path.value; - } - if (path instanceof Quoted) { - return path.containsVariables(); - } - return true; - }; - Import.prototype.evalForImport = function (context) { - var path = this.path; - if (path instanceof URL) { - path = path.value; - } - return new Import(path.eval(context), this.features, this.options, this._index, this._fileInfo, this.visibilityInfo()); - }; - Import.prototype.evalPath = function (context) { - var path = this.path.eval(context); - var fileInfo = this._fileInfo; - if (!(path instanceof URL)) { - // Add the rootpath if the URL requires a rewrite - var pathValue = path.value; - if (fileInfo && - pathValue && - context.pathRequiresRewrite(pathValue)) { - path.value = context.rewritePath(pathValue, fileInfo.rootpath); - } - else { - path.value = context.normalizePath(path.value); - } - } - return path; - }; - Import.prototype.eval = function (context) { - var result = this.doEval(context); - if (this.options.reference || this.blocksVisibility()) { - if (result.length || result.length === 0) { - result.forEach(function (node) { - node.addVisibilityBlock(); - }); - } - else { - result.addVisibilityBlock(); - } - } - return result; - }; - Import.prototype.doEval = function (context) { - var ruleset; - var registry; - var features = this.features && this.features.eval(context); - if (this.options.isPlugin) { - if (this.root && this.root.eval) { - try { - this.root.eval(context); - } - catch (e) { - e.message = 'Plugin error during evaluation'; - throw new LessError(e, this.root.imports, this.root.filename); - } - } - registry = context.frames[0] && context.frames[0].functionRegistry; - if (registry && this.root && this.root.functions) { - registry.addMultiple(this.root.functions); - } - return []; - } - if (this.skip) { - if (typeof this.skip === 'function') { - this.skip = this.skip(); - } - if (this.skip) { - return []; - } - } - if (this.options.inline) { - var contents = new Anonymous(this.root, 0, { - filename: this.importedFilename, - reference: this.path._fileInfo && this.path._fileInfo.reference - }, true, true); - return this.features ? new Media([contents], this.features.value) : [contents]; - } - else if (this.css) { - var newImport = new Import(this.evalPath(context), features, this.options, this._index); - if (!newImport.css && this.error) { - throw this.error; - } - return newImport; - } - else if (this.root) { - ruleset = new Ruleset(null, copyArray(this.root.rules)); - ruleset.evalImports(context); - return this.features ? new Media(ruleset.rules, this.features.value) : ruleset.rules; - } - else { - return []; - } - }; - Import.prototype.type = 'Import'; + function escapePath(path) { + return path.replace(/[\(\)'"\s]/g, function (match) { return "\\" + match; }); + } + var URL = function (val, index, currentFileInfo, isEvald) { + this.value = val; + this._index = index; + this._fileInfo = currentFileInfo; + this.isEvald = isEvald; + }; + URL.prototype = Object.assign(new Node(), { + type: 'Url', + accept: function (visitor) { + this.value = visitor.visit(this.value); + }, + genCSS: function (context, output) { + output.add('url('); + this.value.genCSS(context, output); + output.add(')'); + }, + eval: function (context) { + var val = this.value.eval(context); + var rootpath; + if (!this.isEvald) { + // Add the rootpath if the URL requires a rewrite + rootpath = this.fileInfo() && this.fileInfo().rootpath; + if (typeof rootpath === 'string' && + typeof val.value === 'string' && + context.pathRequiresRewrite(val.value)) { + if (!val.quote) { + rootpath = escapePath(rootpath); + } + val.value = context.rewritePath(val.value, rootpath); + } + else { + val.value = context.normalizePath(val.value); + } + // Add url args if enabled + if (context.urlArgs) { + if (!val.value.match(/^\s*data:/)) { + var delimiter = val.value.indexOf('?') === -1 ? '?' : '&'; + var urlArgs = delimiter + context.urlArgs; + if (val.value.indexOf('#') !== -1) { + val.value = val.value.replace('#', urlArgs + "#"); + } + else { + val.value += urlArgs; + } + } + } + } + return new URL(val, this.getIndex(), this.fileInfo(), true); + } + }); - var JsEvalNode = function () { }; - JsEvalNode.prototype = new Node(); - JsEvalNode.prototype.evaluateJavaScript = function (expression, context) { - var result; - var that = this; - var evalContext = {}; - if (!context.javascriptEnabled) { - throw { message: 'Inline JavaScript is not enabled. Is it set in your options?', - filename: this.fileInfo().filename, - index: this.getIndex() }; - } - expression = expression.replace(/@\{([\w-]+)\}/g, function (_, name) { return that.jsify(new Variable("@" + name, that.getIndex(), that.fileInfo()).eval(context)); }); - try { - expression = new Function("return (" + expression + ")"); - } - catch (e) { - throw { message: "JavaScript evaluation error: " + e.message + " from `" + expression + "`", filename: this.fileInfo().filename, - index: this.getIndex() }; - } - var variables = context.frames[0].variables(); - for (var k in variables) { - if (variables.hasOwnProperty(k)) { - /* jshint loopfunc:true */ - evalContext[k.slice(1)] = { - value: variables[k].value, - toJS: function () { - return this.value.eval(context).toCSS(); - } - }; - } - } - try { - result = expression.call(evalContext); - } - catch (e) { - throw { message: "JavaScript evaluation error: '" + e.name + ": " + e.message.replace(/["]/g, '\'') + "'", filename: this.fileInfo().filename, - index: this.getIndex() }; - } - return result; - }; - JsEvalNode.prototype.jsify = function (obj) { - if (Array.isArray(obj.value) && (obj.value.length > 1)) { - return "[" + obj.value.map(function (v) { return v.toCSS(); }).join(', ') + "]"; - } - else { - return obj.toCSS(); - } - }; + var Media = function (value, features, index, currentFileInfo, visibilityInfo) { + this._index = index; + this._fileInfo = currentFileInfo; + var selectors = (new Selector([], null, null, this._index, this._fileInfo)).createEmptySelectors(); + this.features = new Value(features); + this.rules = [new Ruleset(selectors, value)]; + this.rules[0].allowImports = true; + this.copyVisibilityInfo(visibilityInfo); + this.allowRoot = true; + this.setParent(selectors, this); + this.setParent(this.features, this); + this.setParent(this.rules, this); + }; + Media.prototype = Object.assign(new AtRule(), { + type: 'Media', + isRulesetLike: function () { + return true; + }, + accept: function (visitor) { + if (this.features) { + this.features = visitor.visit(this.features); + } + if (this.rules) { + this.rules = visitor.visitArray(this.rules); + } + }, + genCSS: function (context, output) { + output.add('@media ', this._fileInfo, this._index); + this.features.genCSS(context, output); + this.outputRuleset(context, output, this.rules); + }, + eval: function (context) { + if (!context.mediaBlocks) { + context.mediaBlocks = []; + context.mediaPath = []; + } + var media = new Media(null, [], this._index, this._fileInfo, this.visibilityInfo()); + if (this.debugInfo) { + this.rules[0].debugInfo = this.debugInfo; + media.debugInfo = this.debugInfo; + } + media.features = this.features.eval(context); + context.mediaPath.push(media); + context.mediaBlocks.push(media); + this.rules[0].functionRegistry = context.frames[0].functionRegistry.inherit(); + context.frames.unshift(this.rules[0]); + media.rules = [this.rules[0].eval(context)]; + context.frames.shift(); + context.mediaPath.pop(); + return context.mediaPath.length === 0 ? media.evalTop(context) : + media.evalNested(context); + }, + evalTop: function (context) { + var result = this; + // Render all dependent Media blocks. + if (context.mediaBlocks.length > 1) { + var selectors = (new Selector([], null, null, this.getIndex(), this.fileInfo())).createEmptySelectors(); + result = new Ruleset(selectors, context.mediaBlocks); + result.multiMedia = true; + result.copyVisibilityInfo(this.visibilityInfo()); + this.setParent(result, this); + } + delete context.mediaBlocks; + delete context.mediaPath; + return result; + }, + evalNested: function (context) { + var i; + var value; + var path = context.mediaPath.concat([this]); + // Extract the media-query conditions separated with `,` (OR). + for (i = 0; i < path.length; i++) { + value = path[i].features instanceof Value ? + path[i].features.value : path[i].features; + path[i] = Array.isArray(value) ? value : [value]; + } + // Trace all permutations to generate the resulting media-query. + // + // (a, b and c) with nested (d, e) -> + // a and d + // a and e + // b and c and d + // b and c and e + this.features = new Value(this.permute(path).map(function (path) { + path = path.map(function (fragment) { return fragment.toCSS ? fragment : new Anonymous(fragment); }); + for (i = path.length - 1; i > 0; i--) { + path.splice(i, 0, new Anonymous('and')); + } + return new Expression(path); + })); + this.setParent(this.features, this); + // Fake a tree-node that doesn't output anything. + return new Ruleset([], []); + }, + permute: function (arr) { + if (arr.length === 0) { + return []; + } + else if (arr.length === 1) { + return arr[0]; + } + else { + var result = []; + var rest = this.permute(arr.slice(1)); + for (var i = 0; i < rest.length; i++) { + for (var j = 0; j < arr[0].length; j++) { + result.push([arr[0][j]].concat(rest[i])); + } + } + return result; + } + }, + bubbleSelectors: function (selectors) { + if (!selectors) { + return; + } + this.rules = [new Ruleset(copyArray(selectors), [this.rules[0]])]; + this.setParent(this.rules, this); + } + }); - var JavaScript = function (string, escaped, index, currentFileInfo) { - this.escaped = escaped; - this.expression = string; - this._index = index; - this._fileInfo = currentFileInfo; - }; - JavaScript.prototype = new JsEvalNode(); - JavaScript.prototype.eval = function (context) { - var result = this.evaluateJavaScript(this.expression, context); - var type = typeof result; - if (type === 'number' && !isNaN(result)) { - return new Dimension(result); - } - else if (type === 'string') { - return new Quoted("\"" + result + "\"", result, this.escaped, this._index); - } - else if (Array.isArray(result)) { - return new Anonymous(result.join(', ')); - } - else { - return new Anonymous(result); - } - }; - JavaScript.prototype.type = 'JavaScript'; + // + // CSS @import node + // + // The general strategy here is that we don't want to wait + // for the parsing to be completed, before we start importing + // the file. That's because in the context of a browser, + // most of the time will be spent waiting for the server to respond. + // + // On creation, we push the import path to our import queue, though + // `import,push`, we also pass it a callback, which it'll call once + // the file has been fetched, and parsed. + // + var Import = function (path, features, options, index, currentFileInfo, visibilityInfo) { + this.options = options; + this._index = index; + this._fileInfo = currentFileInfo; + this.path = path; + this.features = features; + this.allowRoot = true; + if (this.options.less !== undefined || this.options.inline) { + this.css = !this.options.less || this.options.inline; + } + else { + var pathValue = this.getPath(); + if (pathValue && /[#\.\&\?]css([\?;].*)?$/.test(pathValue)) { + this.css = true; + } + } + this.copyVisibilityInfo(visibilityInfo); + this.setParent(this.features, this); + this.setParent(this.path, this); + }; + Import.prototype = Object.assign(new Node(), { + type: 'Import', + accept: function (visitor) { + if (this.features) { + this.features = visitor.visit(this.features); + } + this.path = visitor.visit(this.path); + if (!this.options.isPlugin && !this.options.inline && this.root) { + this.root = visitor.visit(this.root); + } + }, + genCSS: function (context, output) { + if (this.css && this.path._fileInfo.reference === undefined) { + output.add('@import ', this._fileInfo, this._index); + this.path.genCSS(context, output); + if (this.features) { + output.add(' '); + this.features.genCSS(context, output); + } + output.add(';'); + } + }, + getPath: function () { + return (this.path instanceof URL) ? + this.path.value.value : this.path.value; + }, + isVariableImport: function () { + var path = this.path; + if (path instanceof URL) { + path = path.value; + } + if (path instanceof Quoted) { + return path.containsVariables(); + } + return true; + }, + evalForImport: function (context) { + var path = this.path; + if (path instanceof URL) { + path = path.value; + } + return new Import(path.eval(context), this.features, this.options, this._index, this._fileInfo, this.visibilityInfo()); + }, + evalPath: function (context) { + var path = this.path.eval(context); + var fileInfo = this._fileInfo; + if (!(path instanceof URL)) { + // Add the rootpath if the URL requires a rewrite + var pathValue = path.value; + if (fileInfo && + pathValue && + context.pathRequiresRewrite(pathValue)) { + path.value = context.rewritePath(pathValue, fileInfo.rootpath); + } + else { + path.value = context.normalizePath(path.value); + } + } + return path; + }, + eval: function (context) { + var result = this.doEval(context); + if (this.options.reference || this.blocksVisibility()) { + if (result.length || result.length === 0) { + result.forEach(function (node) { + node.addVisibilityBlock(); + }); + } + else { + result.addVisibilityBlock(); + } + } + return result; + }, + doEval: function (context) { + var ruleset; + var registry; + var features = this.features && this.features.eval(context); + if (this.options.isPlugin) { + if (this.root && this.root.eval) { + try { + this.root.eval(context); + } + catch (e) { + e.message = 'Plugin error during evaluation'; + throw new LessError(e, this.root.imports, this.root.filename); + } + } + registry = context.frames[0] && context.frames[0].functionRegistry; + if (registry && this.root && this.root.functions) { + registry.addMultiple(this.root.functions); + } + return []; + } + if (this.skip) { + if (typeof this.skip === 'function') { + this.skip = this.skip(); + } + if (this.skip) { + return []; + } + } + if (this.options.inline) { + var contents = new Anonymous(this.root, 0, { + filename: this.importedFilename, + reference: this.path._fileInfo && this.path._fileInfo.reference + }, true, true); + return this.features ? new Media([contents], this.features.value) : [contents]; + } + else if (this.css) { + var newImport = new Import(this.evalPath(context), features, this.options, this._index); + if (!newImport.css && this.error) { + throw this.error; + } + return newImport; + } + else if (this.root) { + ruleset = new Ruleset(null, copyArray(this.root.rules)); + ruleset.evalImports(context); + return this.features ? new Media(ruleset.rules, this.features.value) : ruleset.rules; + } + else { + return []; + } + } + }); - var Assignment = function (key, val) { - this.key = key; - this.value = val; - }; - Assignment.prototype = new Node(); - Assignment.prototype.accept = function (visitor) { - this.value = visitor.visit(this.value); - }; - Assignment.prototype.eval = function (context) { - if (this.value.eval) { - return new Assignment(this.key, this.value.eval(context)); - } - return this; - }; - Assignment.prototype.genCSS = function (context, output) { - output.add(this.key + "="); - if (this.value.genCSS) { - this.value.genCSS(context, output); - } - else { - output.add(this.value); - } - }; - Assignment.prototype.type = 'Assignment'; + var JsEvalNode = function () { }; + JsEvalNode.prototype = Object.assign(new Node(), { + evaluateJavaScript: function (expression, context) { + var result; + var that = this; + var evalContext = {}; + if (!context.javascriptEnabled) { + throw { message: 'Inline JavaScript is not enabled. Is it set in your options?', + filename: this.fileInfo().filename, + index: this.getIndex() }; + } + expression = expression.replace(/@\{([\w-]+)\}/g, function (_, name) { + return that.jsify(new Variable("@" + name, that.getIndex(), that.fileInfo()).eval(context)); + }); + try { + expression = new Function("return (" + expression + ")"); + } + catch (e) { + throw { message: "JavaScript evaluation error: " + e.message + " from `" + expression + "`", filename: this.fileInfo().filename, + index: this.getIndex() }; + } + var variables = context.frames[0].variables(); + for (var k in variables) { + if (variables.hasOwnProperty(k)) { + /* jshint loopfunc:true */ + evalContext[k.slice(1)] = { + value: variables[k].value, + toJS: function () { + return this.value.eval(context).toCSS(); + } + }; + } + } + try { + result = expression.call(evalContext); + } + catch (e) { + throw { message: "JavaScript evaluation error: '" + e.name + ": " + e.message.replace(/["]/g, '\'') + "'", filename: this.fileInfo().filename, + index: this.getIndex() }; + } + return result; + }, + jsify: function (obj) { + if (Array.isArray(obj.value) && (obj.value.length > 1)) { + return "[" + obj.value.map(function (v) { return v.toCSS(); }).join(', ') + "]"; + } + else { + return obj.toCSS(); + } + } + }); - var Condition = function (op, l, r, i, negate) { - this.op = op.trim(); - this.lvalue = l; - this.rvalue = r; - this._index = i; - this.negate = negate; - }; - Condition.prototype = new Node(); - Condition.prototype.accept = function (visitor) { - this.lvalue = visitor.visit(this.lvalue); - this.rvalue = visitor.visit(this.rvalue); - }; - Condition.prototype.eval = function (context) { - var result = (function (op, a, b) { - switch (op) { - case 'and': return a && b; - case 'or': return a || b; - default: - switch (Node.compare(a, b)) { - case -1: - return op === '<' || op === '=<' || op === '<='; - case 0: - return op === '=' || op === '>=' || op === '=<' || op === '<='; - case 1: - return op === '>' || op === '>='; - default: - return false; - } - } - })(this.op, this.lvalue.eval(context), this.rvalue.eval(context)); - return this.negate ? !result : result; - }; - Condition.prototype.type = 'Condition'; + var JavaScript = function (string, escaped, index, currentFileInfo) { + this.escaped = escaped; + this.expression = string; + this._index = index; + this._fileInfo = currentFileInfo; + }; + JavaScript.prototype = Object.assign(new JsEvalNode(), { + type: 'JavaScript', + eval: function (context) { + var result = this.evaluateJavaScript(this.expression, context); + var type = typeof result; + if (type === 'number' && !isNaN(result)) { + return new Dimension(result); + } + else if (type === 'string') { + return new Quoted("\"" + result + "\"", result, this.escaped, this._index); + } + else if (Array.isArray(result)) { + return new Anonymous(result.join(', ')); + } + else { + return new Anonymous(result); + } + } + }); - var UnicodeDescriptor = function (value) { - this.value = value; - }; - UnicodeDescriptor.prototype = new Node(); - UnicodeDescriptor.prototype.type = 'UnicodeDescriptor'; + var Assignment = function (key, val) { + this.key = key; + this.value = val; + }; + Assignment.prototype = Object.assign(new Node(), { + type: 'Assignment', + accept: function (visitor) { + this.value = visitor.visit(this.value); + }, + eval: function (context) { + if (this.value.eval) { + return new Assignment(this.key, this.value.eval(context)); + } + return this; + }, + genCSS: function (context, output) { + output.add(this.key + "="); + if (this.value.genCSS) { + this.value.genCSS(context, output); + } + else { + output.add(this.value); + } + } + }); - var Negative = function (node) { - this.value = node; - }; - Negative.prototype = new Node(); - Negative.prototype.genCSS = function (context, output) { - output.add('-'); - this.value.genCSS(context, output); - }; - Negative.prototype.eval = function (context) { - if (context.isMathOn()) { - return (new Operation('*', [new Dimension(-1), this.value])).eval(context); - } - return new Negative(this.value.eval(context)); - }; - Negative.prototype.type = 'Negative'; + var Condition = function (op, l, r, i, negate) { + this.op = op.trim(); + this.lvalue = l; + this.rvalue = r; + this._index = i; + this.negate = negate; + }; + Condition.prototype = Object.assign(new Node(), { + type: 'Condition', + accept: function (visitor) { + this.lvalue = visitor.visit(this.lvalue); + this.rvalue = visitor.visit(this.rvalue); + }, + eval: function (context) { + var result = (function (op, a, b) { + switch (op) { + case 'and': return a && b; + case 'or': return a || b; + default: + switch (Node.compare(a, b)) { + case -1: + return op === '<' || op === '=<' || op === '<='; + case 0: + return op === '=' || op === '>=' || op === '=<' || op === '<='; + case 1: + return op === '>' || op === '>='; + default: + return false; + } + } + })(this.op, this.lvalue.eval(context), this.rvalue.eval(context)); + return this.negate ? !result : result; + } + }); - var Extend = function (selector, option, index, currentFileInfo, visibilityInfo) { - this.selector = selector; - this.option = option; - this.object_id = Extend.next_id++; - this.parent_ids = [this.object_id]; - this._index = index; - this._fileInfo = currentFileInfo; - this.copyVisibilityInfo(visibilityInfo); - this.allowRoot = true; - switch (option) { - case 'all': - this.allowBefore = true; - this.allowAfter = true; - break; - default: - this.allowBefore = false; - this.allowAfter = false; - break; - } - this.setParent(this.selector, this); - }; - Extend.prototype = new Node(); - Extend.prototype.accept = function (visitor) { - this.selector = visitor.visit(this.selector); - }; - Extend.prototype.eval = function (context) { - return new Extend(this.selector.eval(context), this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); - }; - Extend.prototype.clone = function (context) { - return new Extend(this.selector, this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); - }; - // it concatenates (joins) all selectors in selector array - Extend.prototype.findSelfSelectors = function (selectors) { - var selfElements = []; - var i; - var selectorElements; - for (i = 0; i < selectors.length; i++) { - selectorElements = selectors[i].elements; - // duplicate the logic in genCSS function inside the selector node. - // future TODO - move both logics into the selector joiner visitor - if (i > 0 && selectorElements.length && selectorElements[0].combinator.value === '') { - selectorElements[0].combinator.value = ' '; - } - selfElements = selfElements.concat(selectors[i].elements); - } - this.selfSelectors = [new Selector(selfElements)]; - this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo()); - }; - /** - * Used with the extend visitor - */ - Extend.next_id = 0; - Extend.prototype.type = 'Extend'; + var UnicodeDescriptor = function (value) { + this.value = value; + }; + UnicodeDescriptor.prototype = Object.assign(new Node(), { + type: 'UnicodeDescriptor' + }); - var VariableCall = function (variable, index, currentFileInfo) { - this.variable = variable; - this._index = index; - this._fileInfo = currentFileInfo; - this.allowRoot = true; - }; - VariableCall.prototype = new Node(); - VariableCall.prototype.eval = function (context) { - var rules; - var detachedRuleset = new Variable(this.variable, this.getIndex(), this.fileInfo()).eval(context); - var error = new LessError({ message: "Could not evaluate variable call " + this.variable }); - if (!detachedRuleset.ruleset) { - if (detachedRuleset.rules) { - rules = detachedRuleset; - } - else if (Array.isArray(detachedRuleset)) { - rules = new Ruleset('', detachedRuleset); - } - else if (Array.isArray(detachedRuleset.value)) { - rules = new Ruleset('', detachedRuleset.value); - } - else { - throw error; - } - detachedRuleset = new DetachedRuleset(rules); - } - if (detachedRuleset.ruleset) { - return detachedRuleset.callEval(context); - } - throw error; - }; - VariableCall.prototype.type = 'VariableCall'; + var Negative = function (node) { + this.value = node; + }; + Negative.prototype = Object.assign(new Node(), { + type: 'Negative', + genCSS: function (context, output) { + output.add('-'); + this.value.genCSS(context, output); + }, + eval: function (context) { + if (context.isMathOn()) { + return (new Operation('*', [new Dimension(-1), this.value])).eval(context); + } + return new Negative(this.value.eval(context)); + } + }); - var NamespaceValue = function (ruleCall, lookups, index, fileInfo) { - this.value = ruleCall; - this.lookups = lookups; - this._index = index; - this._fileInfo = fileInfo; - }; - NamespaceValue.prototype = new Node(); - NamespaceValue.prototype.eval = function (context) { - var i; - var name; - var rules = this.value.eval(context); - for (i = 0; i < this.lookups.length; i++) { - name = this.lookups[i]; - /** - * Eval'd DRs return rulesets. - * Eval'd mixins return rules, so let's make a ruleset if we need it. - * We need to do this because of late parsing of values - */ - if (Array.isArray(rules)) { - rules = new Ruleset([new Selector()], rules); - } - if (name === '') { - rules = rules.lastDeclaration(); - } - else if (name.charAt(0) === '@') { - if (name.charAt(1) === '@') { - name = "@" + new Variable(name.substr(1)).eval(context).value; - } - if (rules.variables) { - rules = rules.variable(name); - } - if (!rules) { - throw { type: 'Name', message: "variable " + name + " not found", filename: this.fileInfo().filename, - index: this.getIndex() }; - } - } - else { - if (name.substring(0, 2) === '$@') { - name = "$" + new Variable(name.substr(1)).eval(context).value; - } - else { - name = name.charAt(0) === '$' ? name : "$" + name; - } - if (rules.properties) { - rules = rules.property(name); - } - if (!rules) { - throw { type: 'Name', message: "property \"" + name.substr(1) + "\" not found", filename: this.fileInfo().filename, - index: this.getIndex() }; - } - // Properties are an array of values, since a ruleset can have multiple props. - // We pick the last one (the "cascaded" value) - rules = rules[rules.length - 1]; - } - if (rules.value) { - rules = rules.eval(context).value; - } - if (rules.ruleset) { - rules = rules.ruleset.eval(context); - } - } - return rules; - }; - NamespaceValue.prototype.type = 'NamespaceValue'; + var Extend = function (selector, option, index, currentFileInfo, visibilityInfo) { + this.selector = selector; + this.option = option; + this.object_id = Extend.next_id++; + this.parent_ids = [this.object_id]; + this._index = index; + this._fileInfo = currentFileInfo; + this.copyVisibilityInfo(visibilityInfo); + this.allowRoot = true; + switch (option) { + case 'all': + this.allowBefore = true; + this.allowAfter = true; + break; + default: + this.allowBefore = false; + this.allowAfter = false; + break; + } + this.setParent(this.selector, this); + }; + Extend.prototype = Object.assign(new Node(), { + type: 'Extend', + accept: function (visitor) { + this.selector = visitor.visit(this.selector); + }, + eval: function (context) { + return new Extend(this.selector.eval(context), this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + }, + clone: function (context) { + return new Extend(this.selector, this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + }, + // it concatenates (joins) all selectors in selector array + findSelfSelectors: function (selectors) { + var selfElements = [], i, selectorElements; + for (i = 0; i < selectors.length; i++) { + selectorElements = selectors[i].elements; + // duplicate the logic in genCSS function inside the selector node. + // future TODO - move both logics into the selector joiner visitor + if (i > 0 && selectorElements.length && selectorElements[0].combinator.value === '') { + selectorElements[0].combinator.value = ' '; + } + selfElements = selfElements.concat(selectors[i].elements); + } + this.selfSelectors = [new Selector(selfElements)]; + this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo()); + } + }); + Extend.next_id = 0; - var Definition = function (name, params, rules, condition, variadic, frames, visibilityInfo) { - this.name = name || 'anonymous mixin'; - this.selectors = [new Selector([new Element(null, name, false, this._index, this._fileInfo)])]; - this.params = params; - this.condition = condition; - this.variadic = variadic; - this.arity = params.length; - this.rules = rules; - this._lookups = {}; - var optionalParameters = []; - this.required = params.reduce(function (count, p) { - if (!p.name || (p.name && !p.value)) { - return count + 1; - } - else { - optionalParameters.push(p.name); - return count; - } - }, 0); - this.optionalParameters = optionalParameters; - this.frames = frames; - this.copyVisibilityInfo(visibilityInfo); - this.allowRoot = true; - }; - Definition.prototype = new Ruleset(); - Definition.prototype.accept = function (visitor) { - if (this.params && this.params.length) { - this.params = visitor.visitArray(this.params); - } - this.rules = visitor.visitArray(this.rules); - if (this.condition) { - this.condition = visitor.visit(this.condition); - } - }; - Definition.prototype.evalParams = function (context, mixinEnv, args, evaldArguments) { - /* jshint boss:true */ - var frame = new Ruleset(null, null); - var varargs; - var arg; - var params = copyArray(this.params); - var i; - var j; - var val; - var name; - var isNamedFound; - var argIndex; - var argsLength = 0; - if (mixinEnv.frames && mixinEnv.frames[0] && mixinEnv.frames[0].functionRegistry) { - frame.functionRegistry = mixinEnv.frames[0].functionRegistry.inherit(); - } - mixinEnv = new contexts.Eval(mixinEnv, [frame].concat(mixinEnv.frames)); - if (args) { - args = copyArray(args); - argsLength = args.length; - for (i = 0; i < argsLength; i++) { - arg = args[i]; - if (name = (arg && arg.name)) { - isNamedFound = false; - for (j = 0; j < params.length; j++) { - if (!evaldArguments[j] && name === params[j].name) { - evaldArguments[j] = arg.value.eval(context); - frame.prependRule(new Declaration(name, arg.value.eval(context))); - isNamedFound = true; - break; - } - } - if (isNamedFound) { - args.splice(i, 1); - i--; - continue; - } - else { - throw { type: 'Runtime', message: "Named argument for " + this.name + " " + args[i].name + " not found" }; - } - } - } - } - argIndex = 0; - for (i = 0; i < params.length; i++) { - if (evaldArguments[i]) { - continue; - } - arg = args && args[argIndex]; - if (name = params[i].name) { - if (params[i].variadic) { - varargs = []; - for (j = argIndex; j < argsLength; j++) { - varargs.push(args[j].value.eval(context)); - } - frame.prependRule(new Declaration(name, new Expression(varargs).eval(context))); - } - else { - val = arg && arg.value; - if (val) { - // This was a mixin call, pass in a detached ruleset of it's eval'd rules - if (Array.isArray(val)) { - val = new DetachedRuleset(new Ruleset('', val)); - } - else { - val = val.eval(context); - } - } - else if (params[i].value) { - val = params[i].value.eval(mixinEnv); - frame.resetCache(); - } - else { - throw { type: 'Runtime', message: "wrong number of arguments for " + this.name + " (" + argsLength + " for " + this.arity + ")" }; - } - frame.prependRule(new Declaration(name, val)); - evaldArguments[i] = val; - } - } - if (params[i].variadic && args) { - for (j = argIndex; j < argsLength; j++) { - evaldArguments[j] = args[j].value.eval(context); - } - } - argIndex++; - } - return frame; - }; - Definition.prototype.makeImportant = function () { - var rules = !this.rules ? this.rules : this.rules.map(function (r) { - if (r.makeImportant) { - return r.makeImportant(true); - } - else { - return r; - } - }); - var result = new Definition(this.name, this.params, rules, this.condition, this.variadic, this.frames); - return result; - }; - Definition.prototype.eval = function (context) { - return new Definition(this.name, this.params, this.rules, this.condition, this.variadic, this.frames || copyArray(context.frames)); - }; - Definition.prototype.evalCall = function (context, args, important) { - var _arguments = []; - var mixinFrames = this.frames ? this.frames.concat(context.frames) : context.frames; - var frame = this.evalParams(context, new contexts.Eval(context, mixinFrames), args, _arguments); - var rules; - var ruleset; - frame.prependRule(new Declaration('@arguments', new Expression(_arguments).eval(context))); - rules = copyArray(this.rules); - ruleset = new Ruleset(null, rules); - ruleset.originalRuleset = this; - ruleset = ruleset.eval(new contexts.Eval(context, [this, frame].concat(mixinFrames))); - if (important) { - ruleset = ruleset.makeImportant(); - } - return ruleset; - }; - Definition.prototype.matchCondition = function (args, context) { - if (this.condition && !this.condition.eval(new contexts.Eval(context, [this.evalParams(context, /* the parameter variables */ new contexts.Eval(context, this.frames ? this.frames.concat(context.frames) : context.frames), args, [])] - .concat(this.frames || []) // the parent namespace/mixin frames - .concat(context.frames)))) { // the current environment frames - return false; - } - return true; - }; - Definition.prototype.matchArgs = function (args, context) { - var allArgsCnt = (args && args.length) || 0; - var len; - var optionalParameters = this.optionalParameters; - var requiredArgsCnt = !args ? 0 : args.reduce(function (count, p) { - if (optionalParameters.indexOf(p.name) < 0) { - return count + 1; - } - else { - return count; - } - }, 0); - if (!this.variadic) { - if (requiredArgsCnt < this.required) { - return false; - } - if (allArgsCnt > this.params.length) { - return false; - } - } - else { - if (requiredArgsCnt < (this.required - 1)) { - return false; - } - } - // check patterns - len = Math.min(requiredArgsCnt, this.arity); - for (var i = 0; i < len; i++) { - if (!this.params[i].name && !this.params[i].variadic) { - if (args[i].value.eval(context).toCSS() != this.params[i].value.eval(context).toCSS()) { - return false; - } - } - } - return true; - }; - Definition.prototype.type = 'MixinDefinition'; - Definition.prototype.evalFirst = true; + var VariableCall = function (variable, index, currentFileInfo) { + this.variable = variable; + this._index = index; + this._fileInfo = currentFileInfo; + this.allowRoot = true; + }; + VariableCall.prototype = Object.assign(new Node(), { + type: 'VariableCall', + eval: function (context) { + var rules; + var detachedRuleset = new Variable(this.variable, this.getIndex(), this.fileInfo()).eval(context); + var error = new LessError({ message: "Could not evaluate variable call " + this.variable }); + if (!detachedRuleset.ruleset) { + if (detachedRuleset.rules) { + rules = detachedRuleset; + } + else if (Array.isArray(detachedRuleset)) { + rules = new Ruleset('', detachedRuleset); + } + else if (Array.isArray(detachedRuleset.value)) { + rules = new Ruleset('', detachedRuleset.value); + } + else { + throw error; + } + detachedRuleset = new DetachedRuleset(rules); + } + if (detachedRuleset.ruleset) { + return detachedRuleset.callEval(context); + } + throw error; + } + }); - var MixinCall = function (elements, args, index, currentFileInfo, important) { - this.selector = new Selector(elements); - this.arguments = args || []; - this._index = index; - this._fileInfo = currentFileInfo; - this.important = important; - this.allowRoot = true; - this.setParent(this.selector, this); - }; - MixinCall.prototype = new Node(); - MixinCall.prototype.accept = function (visitor) { - if (this.selector) { - this.selector = visitor.visit(this.selector); - } - if (this.arguments.length) { - this.arguments = visitor.visitArray(this.arguments); - } - }; - MixinCall.prototype.eval = function (context) { - var mixins; - var mixin; - var mixinPath; - var args = []; - var arg; - var argValue; - var rules = []; - var match = false; - var i; - var m; - var f; - var isRecursive; - var isOneFound; - var candidates = []; - var candidate; - var conditionResult = []; - var defaultResult; - var defFalseEitherCase = -1; - var defNone = 0; - var defTrue = 1; - var defFalse = 2; - var count; - var originalRuleset; - var noArgumentsFilter; - this.selector = this.selector.eval(context); - function calcDefGroup(mixin, mixinPath) { - var f; - var p; - var namespace; - for (f = 0; f < 2; f++) { - conditionResult[f] = true; - defaultFunc.value(f); - for (p = 0; p < mixinPath.length && conditionResult[f]; p++) { - namespace = mixinPath[p]; - if (namespace.matchCondition) { - conditionResult[f] = conditionResult[f] && namespace.matchCondition(null, context); - } - } - if (mixin.matchCondition) { - conditionResult[f] = conditionResult[f] && mixin.matchCondition(args, context); - } - } - if (conditionResult[0] || conditionResult[1]) { - if (conditionResult[0] != conditionResult[1]) { - return conditionResult[1] ? - defTrue : defFalse; - } - return defNone; - } - return defFalseEitherCase; - } - for (i = 0; i < this.arguments.length; i++) { - arg = this.arguments[i]; - argValue = arg.value.eval(context); - if (arg.expand && Array.isArray(argValue.value)) { - argValue = argValue.value; - for (m = 0; m < argValue.length; m++) { - args.push({ value: argValue[m] }); - } - } - else { - args.push({ name: arg.name, value: argValue }); - } - } - noArgumentsFilter = function (rule) { return rule.matchArgs(null, context); }; - for (i = 0; i < context.frames.length; i++) { - if ((mixins = context.frames[i].find(this.selector, null, noArgumentsFilter)).length > 0) { - isOneFound = true; - // To make `default()` function independent of definition order we have two "subpasses" here. - // At first we evaluate each guard *twice* (with `default() == true` and `default() == false`), - // and build candidate list with corresponding flags. Then, when we know all possible matches, - // we make a final decision. - for (m = 0; m < mixins.length; m++) { - mixin = mixins[m].rule; - mixinPath = mixins[m].path; - isRecursive = false; - for (f = 0; f < context.frames.length; f++) { - if ((!(mixin instanceof Definition)) && mixin === (context.frames[f].originalRuleset || context.frames[f])) { - isRecursive = true; - break; - } - } - if (isRecursive) { - continue; - } - if (mixin.matchArgs(args, context)) { - candidate = { mixin: mixin, group: calcDefGroup(mixin, mixinPath) }; - if (candidate.group !== defFalseEitherCase) { - candidates.push(candidate); - } - match = true; - } - } - defaultFunc.reset(); - count = [0, 0, 0]; - for (m = 0; m < candidates.length; m++) { - count[candidates[m].group]++; - } - if (count[defNone] > 0) { - defaultResult = defFalse; - } - else { - defaultResult = defTrue; - if ((count[defTrue] + count[defFalse]) > 1) { - throw { type: 'Runtime', message: "Ambiguous use of `default()` found when matching for `" + this.format(args) + "`", index: this.getIndex(), filename: this.fileInfo().filename }; - } - } - for (m = 0; m < candidates.length; m++) { - candidate = candidates[m].group; - if ((candidate === defNone) || (candidate === defaultResult)) { - try { - mixin = candidates[m].mixin; - if (!(mixin instanceof Definition)) { - originalRuleset = mixin.originalRuleset || mixin; - mixin = new Definition('', [], mixin.rules, null, false, null, originalRuleset.visibilityInfo()); - mixin.originalRuleset = originalRuleset; - } - var newRules = mixin.evalCall(context, args, this.important).rules; - this._setVisibilityToReplacement(newRules); - Array.prototype.push.apply(rules, newRules); - } - catch (e) { - throw { message: e.message, index: this.getIndex(), filename: this.fileInfo().filename, stack: e.stack }; - } - } - } - if (match) { - return rules; - } - } - } - if (isOneFound) { - throw { type: 'Runtime', message: "No matching definition was found for `" + this.format(args) + "`", index: this.getIndex(), filename: this.fileInfo().filename }; - } - else { - throw { type: 'Name', message: this.selector.toCSS().trim() + " is undefined", index: this.getIndex(), filename: this.fileInfo().filename }; - } - }; - MixinCall.prototype._setVisibilityToReplacement = function (replacement) { - var i; - var rule; - if (this.blocksVisibility()) { - for (i = 0; i < replacement.length; i++) { - rule = replacement[i]; - rule.addVisibilityBlock(); - } - } - }; - MixinCall.prototype.format = function (args) { - return this.selector.toCSS().trim() + "(" + (args ? args.map(function (a) { - var argValue = ''; - if (a.name) { - argValue += a.name + ":"; - } - if (a.value.toCSS) { - argValue += a.value.toCSS(); - } - else { - argValue += '???'; - } - return argValue; - }).join(', ') : '') + ")"; - }; - MixinCall.prototype.type = 'MixinCall'; + var NamespaceValue = function (ruleCall, lookups, index, fileInfo) { + this.value = ruleCall; + this.lookups = lookups; + this._index = index; + this._fileInfo = fileInfo; + }; + NamespaceValue.prototype = Object.assign(new Node(), { + type: 'NamespaceValue', + eval: function (context) { + var i, name, rules = this.value.eval(context); + for (i = 0; i < this.lookups.length; i++) { + name = this.lookups[i]; + /** + * Eval'd DRs return rulesets. + * Eval'd mixins return rules, so let's make a ruleset if we need it. + * We need to do this because of late parsing of values + */ + if (Array.isArray(rules)) { + rules = new Ruleset([new Selector()], rules); + } + if (name === '') { + rules = rules.lastDeclaration(); + } + else if (name.charAt(0) === '@') { + if (name.charAt(1) === '@') { + name = "@" + new Variable(name.substr(1)).eval(context).value; + } + if (rules.variables) { + rules = rules.variable(name); + } + if (!rules) { + throw { type: 'Name', message: "variable " + name + " not found", filename: this.fileInfo().filename, + index: this.getIndex() }; + } + } + else { + if (name.substring(0, 2) === '$@') { + name = "$" + new Variable(name.substr(1)).eval(context).value; + } + else { + name = name.charAt(0) === '$' ? name : "$" + name; + } + if (rules.properties) { + rules = rules.property(name); + } + if (!rules) { + throw { type: 'Name', message: "property \"" + name.substr(1) + "\" not found", filename: this.fileInfo().filename, + index: this.getIndex() }; + } + // Properties are an array of values, since a ruleset can have multiple props. + // We pick the last one (the "cascaded" value) + rules = rules[rules.length - 1]; + } + if (rules.value) { + rules = rules.eval(context).value; + } + if (rules.ruleset) { + rules = rules.ruleset.eval(context); + } + } + return rules; + } + }); - var tree = { - Node: Node, Color: Color, AtRule: AtRule, DetachedRuleset: DetachedRuleset, Operation: Operation, - Dimension: Dimension, Unit: Unit, Keyword: Keyword, Variable: Variable, Property: Property, - Ruleset: Ruleset, Element: Element, Attribute: Attribute, Combinator: Combinator, Selector: Selector, - Quoted: Quoted, Expression: Expression, Declaration: Declaration, Call: Call, URL: URL, Import: Import, - Comment: Comment, Anonymous: Anonymous, Value: Value, JavaScript: JavaScript, Assignment: Assignment, - Condition: Condition, Paren: Paren, Media: Media, UnicodeDescriptor: UnicodeDescriptor, Negative: Negative, - Extend: Extend, VariableCall: VariableCall, NamespaceValue: NamespaceValue, - mixin: { - Call: MixinCall, - Definition: Definition - } - }; + var Definition = function (name, params, rules, condition, variadic, frames, visibilityInfo) { + this.name = name || 'anonymous mixin'; + this.selectors = [new Selector([new Element(null, name, false, this._index, this._fileInfo)])]; + this.params = params; + this.condition = condition; + this.variadic = variadic; + this.arity = params.length; + this.rules = rules; + this._lookups = {}; + var optionalParameters = []; + this.required = params.reduce(function (count, p) { + if (!p.name || (p.name && !p.value)) { + return count + 1; + } + else { + optionalParameters.push(p.name); + return count; + } + }, 0); + this.optionalParameters = optionalParameters; + this.frames = frames; + this.copyVisibilityInfo(visibilityInfo); + this.allowRoot = true; + }; + Definition.prototype = Object.assign(new Ruleset(), { + type: 'MixinDefinition', + evalFirst: true, + accept: function (visitor) { + if (this.params && this.params.length) { + this.params = visitor.visitArray(this.params); + } + this.rules = visitor.visitArray(this.rules); + if (this.condition) { + this.condition = visitor.visit(this.condition); + } + }, + evalParams: function (context, mixinEnv, args, evaldArguments) { + /* jshint boss:true */ + var frame = new Ruleset(null, null); + var varargs; + var arg; + var params = copyArray(this.params); + var i; + var j; + var val; + var name; + var isNamedFound; + var argIndex; + var argsLength = 0; + if (mixinEnv.frames && mixinEnv.frames[0] && mixinEnv.frames[0].functionRegistry) { + frame.functionRegistry = mixinEnv.frames[0].functionRegistry.inherit(); + } + mixinEnv = new contexts.Eval(mixinEnv, [frame].concat(mixinEnv.frames)); + if (args) { + args = copyArray(args); + argsLength = args.length; + for (i = 0; i < argsLength; i++) { + arg = args[i]; + if (name = (arg && arg.name)) { + isNamedFound = false; + for (j = 0; j < params.length; j++) { + if (!evaldArguments[j] && name === params[j].name) { + evaldArguments[j] = arg.value.eval(context); + frame.prependRule(new Declaration(name, arg.value.eval(context))); + isNamedFound = true; + break; + } + } + if (isNamedFound) { + args.splice(i, 1); + i--; + continue; + } + else { + throw { type: 'Runtime', message: "Named argument for " + this.name + " " + args[i].name + " not found" }; + } + } + } + } + argIndex = 0; + for (i = 0; i < params.length; i++) { + if (evaldArguments[i]) { + continue; + } + arg = args && args[argIndex]; + if (name = params[i].name) { + if (params[i].variadic) { + varargs = []; + for (j = argIndex; j < argsLength; j++) { + varargs.push(args[j].value.eval(context)); + } + frame.prependRule(new Declaration(name, new Expression(varargs).eval(context))); + } + else { + val = arg && arg.value; + if (val) { + // This was a mixin call, pass in a detached ruleset of it's eval'd rules + if (Array.isArray(val)) { + val = new DetachedRuleset(new Ruleset('', val)); + } + else { + val = val.eval(context); + } + } + else if (params[i].value) { + val = params[i].value.eval(mixinEnv); + frame.resetCache(); + } + else { + throw { type: 'Runtime', message: "wrong number of arguments for " + this.name + " (" + argsLength + " for " + this.arity + ")" }; + } + frame.prependRule(new Declaration(name, val)); + evaldArguments[i] = val; + } + } + if (params[i].variadic && args) { + for (j = argIndex; j < argsLength; j++) { + evaldArguments[j] = args[j].value.eval(context); + } + } + argIndex++; + } + return frame; + }, + makeImportant: function () { + var rules = !this.rules ? this.rules : this.rules.map(function (r) { + if (r.makeImportant) { + return r.makeImportant(true); + } + else { + return r; + } + }); + var result = new Definition(this.name, this.params, rules, this.condition, this.variadic, this.frames); + return result; + }, + eval: function (context) { + return new Definition(this.name, this.params, this.rules, this.condition, this.variadic, this.frames || copyArray(context.frames)); + }, + evalCall: function (context, args, important) { + var _arguments = []; + var mixinFrames = this.frames ? this.frames.concat(context.frames) : context.frames; + var frame = this.evalParams(context, new contexts.Eval(context, mixinFrames), args, _arguments); + var rules; + var ruleset; + frame.prependRule(new Declaration('@arguments', new Expression(_arguments).eval(context))); + rules = copyArray(this.rules); + ruleset = new Ruleset(null, rules); + ruleset.originalRuleset = this; + ruleset = ruleset.eval(new contexts.Eval(context, [this, frame].concat(mixinFrames))); + if (important) { + ruleset = ruleset.makeImportant(); + } + return ruleset; + }, + matchCondition: function (args, context) { + if (this.condition && !this.condition.eval(new contexts.Eval(context, [this.evalParams(context, /* the parameter variables */ new contexts.Eval(context, this.frames ? this.frames.concat(context.frames) : context.frames), args, [])] + .concat(this.frames || []) // the parent namespace/mixin frames + .concat(context.frames)))) { // the current environment frames + return false; + } + return true; + }, + matchArgs: function (args, context) { + var allArgsCnt = (args && args.length) || 0; + var len; + var optionalParameters = this.optionalParameters; + var requiredArgsCnt = !args ? 0 : args.reduce(function (count, p) { + if (optionalParameters.indexOf(p.name) < 0) { + return count + 1; + } + else { + return count; + } + }, 0); + if (!this.variadic) { + if (requiredArgsCnt < this.required) { + return false; + } + if (allArgsCnt > this.params.length) { + return false; + } + } + else { + if (requiredArgsCnt < (this.required - 1)) { + return false; + } + } + // check patterns + len = Math.min(requiredArgsCnt, this.arity); + for (var i = 0; i < len; i++) { + if (!this.params[i].name && !this.params[i].variadic) { + if (args[i].value.eval(context).toCSS() != this.params[i].value.eval(context).toCSS()) { + return false; + } + } + } + return true; + } + }); - var logger = { - error: function (msg) { - this._fireEvent('error', msg); - }, - warn: function (msg) { - this._fireEvent('warn', msg); - }, - info: function (msg) { - this._fireEvent('info', msg); - }, - debug: function (msg) { - this._fireEvent('debug', msg); - }, - addListener: function (listener) { - this._listeners.push(listener); - }, - removeListener: function (listener) { - for (var i = 0; i < this._listeners.length; i++) { - if (this._listeners[i] === listener) { - this._listeners.splice(i, 1); - return; - } - } - }, - _fireEvent: function (type, msg) { - for (var i = 0; i < this._listeners.length; i++) { - var logFunction = this._listeners[i][type]; - if (logFunction) { - logFunction(msg); - } - } - }, - _listeners: [] - }; + var MixinCall = function (elements, args, index, currentFileInfo, important) { + this.selector = new Selector(elements); + this.arguments = args || []; + this._index = index; + this._fileInfo = currentFileInfo; + this.important = important; + this.allowRoot = true; + this.setParent(this.selector, this); + }; + MixinCall.prototype = Object.assign(new Node(), { + type: 'MixinCall', + accept: function (visitor) { + if (this.selector) { + this.selector = visitor.visit(this.selector); + } + if (this.arguments.length) { + this.arguments = visitor.visitArray(this.arguments); + } + }, + eval: function (context) { + var mixins; + var mixin; + var mixinPath; + var args = []; + var arg; + var argValue; + var rules = []; + var match = false; + var i; + var m; + var f; + var isRecursive; + var isOneFound; + var candidates = []; + var candidate; + var conditionResult = []; + var defaultResult; + var defFalseEitherCase = -1; + var defNone = 0; + var defTrue = 1; + var defFalse = 2; + var count; + var originalRuleset; + var noArgumentsFilter; + this.selector = this.selector.eval(context); + function calcDefGroup(mixin, mixinPath) { + var f, p, namespace; + for (f = 0; f < 2; f++) { + conditionResult[f] = true; + defaultFunc.value(f); + for (p = 0; p < mixinPath.length && conditionResult[f]; p++) { + namespace = mixinPath[p]; + if (namespace.matchCondition) { + conditionResult[f] = conditionResult[f] && namespace.matchCondition(null, context); + } + } + if (mixin.matchCondition) { + conditionResult[f] = conditionResult[f] && mixin.matchCondition(args, context); + } + } + if (conditionResult[0] || conditionResult[1]) { + if (conditionResult[0] != conditionResult[1]) { + return conditionResult[1] ? + defTrue : defFalse; + } + return defNone; + } + return defFalseEitherCase; + } + for (i = 0; i < this.arguments.length; i++) { + arg = this.arguments[i]; + argValue = arg.value.eval(context); + if (arg.expand && Array.isArray(argValue.value)) { + argValue = argValue.value; + for (m = 0; m < argValue.length; m++) { + args.push({ value: argValue[m] }); + } + } + else { + args.push({ name: arg.name, value: argValue }); + } + } + noArgumentsFilter = function (rule) { return rule.matchArgs(null, context); }; + for (i = 0; i < context.frames.length; i++) { + if ((mixins = context.frames[i].find(this.selector, null, noArgumentsFilter)).length > 0) { + isOneFound = true; + // To make `default()` function independent of definition order we have two "subpasses" here. + // At first we evaluate each guard *twice* (with `default() == true` and `default() == false`), + // and build candidate list with corresponding flags. Then, when we know all possible matches, + // we make a final decision. + for (m = 0; m < mixins.length; m++) { + mixin = mixins[m].rule; + mixinPath = mixins[m].path; + isRecursive = false; + for (f = 0; f < context.frames.length; f++) { + if ((!(mixin instanceof Definition)) && mixin === (context.frames[f].originalRuleset || context.frames[f])) { + isRecursive = true; + break; + } + } + if (isRecursive) { + continue; + } + if (mixin.matchArgs(args, context)) { + candidate = { mixin: mixin, group: calcDefGroup(mixin, mixinPath) }; + if (candidate.group !== defFalseEitherCase) { + candidates.push(candidate); + } + match = true; + } + } + defaultFunc.reset(); + count = [0, 0, 0]; + for (m = 0; m < candidates.length; m++) { + count[candidates[m].group]++; + } + if (count[defNone] > 0) { + defaultResult = defFalse; + } + else { + defaultResult = defTrue; + if ((count[defTrue] + count[defFalse]) > 1) { + throw { type: 'Runtime', message: "Ambiguous use of `default()` found when matching for `" + this.format(args) + "`", index: this.getIndex(), filename: this.fileInfo().filename }; + } + } + for (m = 0; m < candidates.length; m++) { + candidate = candidates[m].group; + if ((candidate === defNone) || (candidate === defaultResult)) { + try { + mixin = candidates[m].mixin; + if (!(mixin instanceof Definition)) { + originalRuleset = mixin.originalRuleset || mixin; + mixin = new Definition('', [], mixin.rules, null, false, null, originalRuleset.visibilityInfo()); + mixin.originalRuleset = originalRuleset; + } + var newRules = mixin.evalCall(context, args, this.important).rules; + this._setVisibilityToReplacement(newRules); + Array.prototype.push.apply(rules, newRules); + } + catch (e) { + throw { message: e.message, index: this.getIndex(), filename: this.fileInfo().filename, stack: e.stack }; + } + } + } + if (match) { + return rules; + } + } + } + if (isOneFound) { + throw { type: 'Runtime', message: "No matching definition was found for `" + this.format(args) + "`", index: this.getIndex(), filename: this.fileInfo().filename }; + } + else { + throw { type: 'Name', message: this.selector.toCSS().trim() + " is undefined", index: this.getIndex(), filename: this.fileInfo().filename }; + } + }, + _setVisibilityToReplacement: function (replacement) { + var i, rule; + if (this.blocksVisibility()) { + for (i = 0; i < replacement.length; i++) { + rule = replacement[i]; + rule.addVisibilityBlock(); + } + } + }, + format: function (args) { + return this.selector.toCSS().trim() + "(" + (args ? args.map(function (a) { + var argValue = ''; + if (a.name) { + argValue += a.name + ":"; + } + if (a.value.toCSS) { + argValue += a.value.toCSS(); + } + else { + argValue += '???'; + } + return argValue; + }).join(', ') : '') + ")"; + } + }); - /** - * @todo Document why this abstraction exists, and the relationship between - * environment, file managers, and plugin manager - */ - var environment = /** @class */ (function () { - function environment(externalEnvironment, fileManagers) { - this.fileManagers = fileManagers || []; - externalEnvironment = externalEnvironment || {}; - var optionalFunctions = ['encodeBase64', 'mimeLookup', 'charsetLookup', 'getSourceMapGenerator']; - var requiredFunctions = []; - var functions = requiredFunctions.concat(optionalFunctions); - for (var i = 0; i < functions.length; i++) { - var propName = functions[i]; - var environmentFunc = externalEnvironment[propName]; - if (environmentFunc) { - this[propName] = environmentFunc.bind(externalEnvironment); - } - else if (i < requiredFunctions.length) { - this.warn("missing required function in environment - " + propName); - } - } - } - environment.prototype.getFileManager = function (filename, currentDirectory, options, environment, isSync) { - if (!filename) { - logger.warn('getFileManager called with no filename.. Please report this issue. continuing.'); - } - if (currentDirectory == null) { - logger.warn('getFileManager called with null directory.. Please report this issue. continuing.'); - } - var fileManagers = this.fileManagers; - if (options.pluginManager) { - fileManagers = [].concat(fileManagers).concat(options.pluginManager.getFileManagers()); - } - for (var i = fileManagers.length - 1; i >= 0; i--) { - var fileManager = fileManagers[i]; - if (fileManager[isSync ? 'supportsSync' : 'supports'](filename, currentDirectory, options, environment)) { - return fileManager; - } - } - return null; - }; - environment.prototype.addFileManager = function (fileManager) { - this.fileManagers.push(fileManager); - }; - environment.prototype.clearFileManagers = function () { - this.fileManagers = []; - }; - return environment; - }()); + var tree = { + Node: Node, Color: Color, AtRule: AtRule, DetachedRuleset: DetachedRuleset, Operation: Operation, + Dimension: Dimension, Unit: Unit, Keyword: Keyword, Variable: Variable, Property: Property, + Ruleset: Ruleset, Element: Element, Attribute: Attribute, Combinator: Combinator, Selector: Selector, + Quoted: Quoted, Expression: Expression, Declaration: Declaration, Call: Call, URL: URL, Import: Import, + Comment: Comment, Anonymous: Anonymous, Value: Value, JavaScript: JavaScript, Assignment: Assignment, + Condition: Condition, Paren: Paren, Media: Media, UnicodeDescriptor: UnicodeDescriptor, Negative: Negative, + Extend: Extend, VariableCall: VariableCall, NamespaceValue: NamespaceValue, + mixin: { + Call: MixinCall, + Definition: Definition + } + }; - var AbstractFileManager = /** @class */ (function () { - function AbstractFileManager() { - } - AbstractFileManager.prototype.getPath = function (filename) { - var j = filename.lastIndexOf('?'); - if (j > 0) { - filename = filename.slice(0, j); - } - j = filename.lastIndexOf('/'); - if (j < 0) { - j = filename.lastIndexOf('\\'); - } - if (j < 0) { - return ''; - } - return filename.slice(0, j + 1); - }; - AbstractFileManager.prototype.tryAppendExtension = function (path, ext) { - return /(\.[a-z]*$)|([\?;].*)$/.test(path) ? path : path + ext; - }; - AbstractFileManager.prototype.tryAppendLessExtension = function (path) { - return this.tryAppendExtension(path, '.less'); - }; - AbstractFileManager.prototype.supportsSync = function () { return false; }; - AbstractFileManager.prototype.alwaysMakePathsAbsolute = function () { return false; }; - AbstractFileManager.prototype.isPathAbsolute = function (filename) { - return (/^(?:[a-z-]+:|\/|\\|#)/i).test(filename); - }; - // TODO: pull out / replace? - AbstractFileManager.prototype.join = function (basePath, laterPath) { - if (!basePath) { - return laterPath; - } - return basePath + laterPath; - }; - AbstractFileManager.prototype.pathDiff = function (url, baseUrl) { - // diff between two paths to create a relative path - var urlParts = this.extractUrlParts(url); - var baseUrlParts = this.extractUrlParts(baseUrl); - var i; - var max; - var urlDirectories; - var baseUrlDirectories; - var diff = ''; - if (urlParts.hostPart !== baseUrlParts.hostPart) { - return ''; - } - max = Math.max(baseUrlParts.directories.length, urlParts.directories.length); - for (i = 0; i < max; i++) { - if (baseUrlParts.directories[i] !== urlParts.directories[i]) { - break; - } - } - baseUrlDirectories = baseUrlParts.directories.slice(i); - urlDirectories = urlParts.directories.slice(i); - for (i = 0; i < baseUrlDirectories.length - 1; i++) { - diff += '../'; - } - for (i = 0; i < urlDirectories.length - 1; i++) { - diff += urlDirectories[i] + "/"; - } - return diff; - }; - // helper function, not part of API - AbstractFileManager.prototype.extractUrlParts = function (url, baseUrl) { - // urlParts[1] = protocol://hostname/ OR / - // urlParts[2] = / if path relative to host base - // urlParts[3] = directories - // urlParts[4] = filename - // urlParts[5] = parameters - var urlPartsRegex = /^((?:[a-z-]+:)?\/{2}(?:[^\/\?#]*\/)|([\/\\]))?((?:[^\/\\\?#]*[\/\\])*)([^\/\\\?#]*)([#\?].*)?$/i; - var urlParts = url.match(urlPartsRegex); - var returner = {}; - var rawDirectories = []; - var directories = []; - var i; - var baseUrlParts; - if (!urlParts) { - throw new Error("Could not parse sheet href - '" + url + "'"); - } - // Stylesheets in IE don't always return the full path - if (baseUrl && (!urlParts[1] || urlParts[2])) { - baseUrlParts = baseUrl.match(urlPartsRegex); - if (!baseUrlParts) { - throw new Error("Could not parse page url - '" + baseUrl + "'"); - } - urlParts[1] = urlParts[1] || baseUrlParts[1] || ''; - if (!urlParts[2]) { - urlParts[3] = baseUrlParts[3] + urlParts[3]; - } - } - if (urlParts[3]) { - rawDirectories = urlParts[3].replace(/\\/g, '/').split('/'); - // collapse '..' and skip '.' - for (i = 0; i < rawDirectories.length; i++) { - if (rawDirectories[i] === '..') { - directories.pop(); - } - else if (rawDirectories[i] !== '.') { - directories.push(rawDirectories[i]); - } - } - } - returner.hostPart = urlParts[1]; - returner.directories = directories; - returner.rawPath = (urlParts[1] || '') + rawDirectories.join('/'); - returner.path = (urlParts[1] || '') + directories.join('/'); - returner.filename = urlParts[4]; - returner.fileUrl = returner.path + (urlParts[4] || ''); - returner.url = returner.fileUrl + (urlParts[5] || ''); - return returner; - }; - return AbstractFileManager; - }()); + var AbstractFileManager = /** @class */ (function () { + function AbstractFileManager() { + } + AbstractFileManager.prototype.getPath = function (filename) { + var j = filename.lastIndexOf('?'); + if (j > 0) { + filename = filename.slice(0, j); + } + j = filename.lastIndexOf('/'); + if (j < 0) { + j = filename.lastIndexOf('\\'); + } + if (j < 0) { + return ''; + } + return filename.slice(0, j + 1); + }; + AbstractFileManager.prototype.tryAppendExtension = function (path, ext) { + return /(\.[a-z]*$)|([\?;].*)$/.test(path) ? path : path + ext; + }; + AbstractFileManager.prototype.tryAppendLessExtension = function (path) { + return this.tryAppendExtension(path, '.less'); + }; + AbstractFileManager.prototype.supportsSync = function () { + return false; + }; + AbstractFileManager.prototype.alwaysMakePathsAbsolute = function () { + return false; + }; + AbstractFileManager.prototype.isPathAbsolute = function (filename) { + return (/^(?:[a-z-]+:|\/|\\|#)/i).test(filename); + }; + // TODO: pull out / replace? + AbstractFileManager.prototype.join = function (basePath, laterPath) { + if (!basePath) { + return laterPath; + } + return basePath + laterPath; + }; + AbstractFileManager.prototype.pathDiff = function (url, baseUrl) { + // diff between two paths to create a relative path + var urlParts = this.extractUrlParts(url); + var baseUrlParts = this.extractUrlParts(baseUrl); + var i; + var max; + var urlDirectories; + var baseUrlDirectories; + var diff = ''; + if (urlParts.hostPart !== baseUrlParts.hostPart) { + return ''; + } + max = Math.max(baseUrlParts.directories.length, urlParts.directories.length); + for (i = 0; i < max; i++) { + if (baseUrlParts.directories[i] !== urlParts.directories[i]) { + break; + } + } + baseUrlDirectories = baseUrlParts.directories.slice(i); + urlDirectories = urlParts.directories.slice(i); + for (i = 0; i < baseUrlDirectories.length - 1; i++) { + diff += '../'; + } + for (i = 0; i < urlDirectories.length - 1; i++) { + diff += urlDirectories[i] + "/"; + } + return diff; + }; + // helper function, not part of API + AbstractFileManager.prototype.extractUrlParts = function (url, baseUrl) { + // urlParts[1] = protocol://hostname/ OR / + // urlParts[2] = / if path relative to host base + // urlParts[3] = directories + // urlParts[4] = filename + // urlParts[5] = parameters + var urlPartsRegex = /^((?:[a-z-]+:)?\/{2}(?:[^\/\?#]*\/)|([\/\\]))?((?:[^\/\\\?#]*[\/\\])*)([^\/\\\?#]*)([#\?].*)?$/i; + var urlParts = url.match(urlPartsRegex); + var returner = {}; + var rawDirectories = []; + var directories = []; + var i; + var baseUrlParts; + if (!urlParts) { + throw new Error("Could not parse sheet href - '" + url + "'"); + } + // Stylesheets in IE don't always return the full path + if (baseUrl && (!urlParts[1] || urlParts[2])) { + baseUrlParts = baseUrl.match(urlPartsRegex); + if (!baseUrlParts) { + throw new Error("Could not parse page url - '" + baseUrl + "'"); + } + urlParts[1] = urlParts[1] || baseUrlParts[1] || ''; + if (!urlParts[2]) { + urlParts[3] = baseUrlParts[3] + urlParts[3]; + } + } + if (urlParts[3]) { + rawDirectories = urlParts[3].replace(/\\/g, '/').split('/'); + // collapse '..' and skip '.' + for (i = 0; i < rawDirectories.length; i++) { + if (rawDirectories[i] === '..') { + directories.pop(); + } + else if (rawDirectories[i] !== '.') { + directories.push(rawDirectories[i]); + } + } + } + returner.hostPart = urlParts[1]; + returner.directories = directories; + returner.rawPath = (urlParts[1] || '') + rawDirectories.join('/'); + returner.path = (urlParts[1] || '') + directories.join('/'); + returner.filename = urlParts[4]; + returner.fileUrl = returner.path + (urlParts[4] || ''); + returner.url = returner.fileUrl + (urlParts[5] || ''); + return returner; + }; + return AbstractFileManager; + }()); - var AbstractPluginLoader = /** @class */ (function () { - function AbstractPluginLoader() { - // Implemented by Node.js plugin loader - this.require = function () { return null; }; - } - AbstractPluginLoader.prototype.evalPlugin = function (contents, context, imports, pluginOptions, fileInfo) { - var loader; - var registry; - var pluginObj; - var localModule; - var pluginManager; - var filename; - var result; - pluginManager = context.pluginManager; - if (fileInfo) { - if (typeof fileInfo === 'string') { - filename = fileInfo; - } - else { - filename = fileInfo.filename; - } - } - var shortname = (new this.less.FileManager()).extractUrlParts(filename).filename; - if (filename) { - pluginObj = pluginManager.get(filename); - if (pluginObj) { - result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); - if (result) { - return result; - } - try { - if (pluginObj.use) { - pluginObj.use.call(this.context, pluginObj); - } - } - catch (e) { - e.message = e.message || 'Error during @plugin call'; - return new LessError(e, imports, filename); - } - return pluginObj; - } - } - localModule = { - exports: {}, - pluginManager: pluginManager, - fileInfo: fileInfo - }; - registry = functionRegistry.create(); - var registerPlugin = function (obj) { - pluginObj = obj; - }; - try { - loader = new Function('module', 'require', 'registerPlugin', 'functions', 'tree', 'less', 'fileInfo', contents); - loader(localModule, this.require(filename), registerPlugin, registry, this.less.tree, this.less, fileInfo); - } - catch (e) { - return new LessError(e, imports, filename); - } - if (!pluginObj) { - pluginObj = localModule.exports; - } - pluginObj = this.validatePlugin(pluginObj, filename, shortname); - if (pluginObj instanceof LessError) { - return pluginObj; - } - if (pluginObj) { - pluginObj.imports = imports; - pluginObj.filename = filename; - // For < 3.x (or unspecified minVersion) - setOptions() before install() - if (!pluginObj.minVersion || this.compareVersion('3.0.0', pluginObj.minVersion) < 0) { - result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); - if (result) { - return result; - } - } - // Run on first load - pluginManager.addPlugin(pluginObj, fileInfo.filename, registry); - pluginObj.functions = registry.getLocalFunctions(); - // Need to call setOptions again because the pluginObj might have functions - result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); - if (result) { - return result; - } - // Run every @plugin call - try { - if (pluginObj.use) { - pluginObj.use.call(this.context, pluginObj); - } - } - catch (e) { - e.message = e.message || 'Error during @plugin call'; - return new LessError(e, imports, filename); - } - } - else { - return new LessError({ message: 'Not a valid plugin' }, imports, filename); - } - return pluginObj; - }; - AbstractPluginLoader.prototype.trySetOptions = function (plugin, filename, name, options) { - if (options && !plugin.setOptions) { - return new LessError({ - message: "Options have been provided but the plugin " + name + " does not support any options." - }); - } - try { - plugin.setOptions && plugin.setOptions(options); - } - catch (e) { - return new LessError(e); - } - }; - AbstractPluginLoader.prototype.validatePlugin = function (plugin, filename, name) { - if (plugin) { - // support plugins being a function - // so that the plugin can be more usable programmatically - if (typeof plugin === 'function') { - plugin = new plugin(); - } - if (plugin.minVersion) { - if (this.compareVersion(plugin.minVersion, this.less.version) < 0) { - return new LessError({ - message: "Plugin " + name + " requires version " + this.versionToString(plugin.minVersion) - }); - } - } - return plugin; - } - return null; - }; - AbstractPluginLoader.prototype.compareVersion = function (aVersion, bVersion) { - if (typeof aVersion === 'string') { - aVersion = aVersion.match(/^(\d+)\.?(\d+)?\.?(\d+)?/); - aVersion.shift(); - } - for (var i = 0; i < aVersion.length; i++) { - if (aVersion[i] !== bVersion[i]) { - return parseInt(aVersion[i]) > parseInt(bVersion[i]) ? -1 : 1; - } - } - return 0; - }; - AbstractPluginLoader.prototype.versionToString = function (version) { - var versionString = ''; - for (var i = 0; i < version.length; i++) { - versionString += (versionString ? '.' : '') + version[i]; - } - return versionString; - }; - AbstractPluginLoader.prototype.printUsage = function (plugins) { - for (var i = 0; i < plugins.length; i++) { - var plugin = plugins[i]; - if (plugin.printUsage) { - plugin.printUsage(); - } - } - }; - return AbstractPluginLoader; - }()); + var AbstractPluginLoader = /** @class */ (function () { + function AbstractPluginLoader() { + // Implemented by Node.js plugin loader + this.require = function () { + return null; + }; + } + AbstractPluginLoader.prototype.evalPlugin = function (contents, context, imports, pluginOptions, fileInfo) { + var loader, registry, pluginObj, localModule, pluginManager, filename, result; + pluginManager = context.pluginManager; + if (fileInfo) { + if (typeof fileInfo === 'string') { + filename = fileInfo; + } + else { + filename = fileInfo.filename; + } + } + var shortname = (new this.less.FileManager()).extractUrlParts(filename).filename; + if (filename) { + pluginObj = pluginManager.get(filename); + if (pluginObj) { + result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); + if (result) { + return result; + } + try { + if (pluginObj.use) { + pluginObj.use.call(this.context, pluginObj); + } + } + catch (e) { + e.message = e.message || 'Error during @plugin call'; + return new LessError(e, imports, filename); + } + return pluginObj; + } + } + localModule = { + exports: {}, + pluginManager: pluginManager, + fileInfo: fileInfo + }; + registry = functionRegistry.create(); + var registerPlugin = function (obj) { + pluginObj = obj; + }; + try { + loader = new Function('module', 'require', 'registerPlugin', 'functions', 'tree', 'less', 'fileInfo', contents); + loader(localModule, this.require(filename), registerPlugin, registry, this.less.tree, this.less, fileInfo); + } + catch (e) { + return new LessError(e, imports, filename); + } + if (!pluginObj) { + pluginObj = localModule.exports; + } + pluginObj = this.validatePlugin(pluginObj, filename, shortname); + if (pluginObj instanceof LessError) { + return pluginObj; + } + if (pluginObj) { + pluginObj.imports = imports; + pluginObj.filename = filename; + // For < 3.x (or unspecified minVersion) - setOptions() before install() + if (!pluginObj.minVersion || this.compareVersion('3.0.0', pluginObj.minVersion) < 0) { + result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); + if (result) { + return result; + } + } + // Run on first load + pluginManager.addPlugin(pluginObj, fileInfo.filename, registry); + pluginObj.functions = registry.getLocalFunctions(); + // Need to call setOptions again because the pluginObj might have functions + result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); + if (result) { + return result; + } + // Run every @plugin call + try { + if (pluginObj.use) { + pluginObj.use.call(this.context, pluginObj); + } + } + catch (e) { + e.message = e.message || 'Error during @plugin call'; + return new LessError(e, imports, filename); + } + } + else { + return new LessError({ message: 'Not a valid plugin' }, imports, filename); + } + return pluginObj; + }; + AbstractPluginLoader.prototype.trySetOptions = function (plugin, filename, name, options) { + if (options && !plugin.setOptions) { + return new LessError({ + message: "Options have been provided but the plugin " + name + " does not support any options." + }); + } + try { + plugin.setOptions && plugin.setOptions(options); + } + catch (e) { + return new LessError(e); + } + }; + AbstractPluginLoader.prototype.validatePlugin = function (plugin, filename, name) { + if (plugin) { + // support plugins being a function + // so that the plugin can be more usable programmatically + if (typeof plugin === 'function') { + plugin = new plugin(); + } + if (plugin.minVersion) { + if (this.compareVersion(plugin.minVersion, this.less.version) < 0) { + return new LessError({ + message: "Plugin " + name + " requires version " + this.versionToString(plugin.minVersion) + }); + } + } + return plugin; + } + return null; + }; + AbstractPluginLoader.prototype.compareVersion = function (aVersion, bVersion) { + if (typeof aVersion === 'string') { + aVersion = aVersion.match(/^(\d+)\.?(\d+)?\.?(\d+)?/); + aVersion.shift(); + } + for (var i = 0; i < aVersion.length; i++) { + if (aVersion[i] !== bVersion[i]) { + return parseInt(aVersion[i]) > parseInt(bVersion[i]) ? -1 : 1; + } + } + return 0; + }; + AbstractPluginLoader.prototype.versionToString = function (version) { + var versionString = ''; + for (var i = 0; i < version.length; i++) { + versionString += (versionString ? '.' : '') + version[i]; + } + return versionString; + }; + AbstractPluginLoader.prototype.printUsage = function (plugins) { + for (var i = 0; i < plugins.length; i++) { + var plugin = plugins[i]; + if (plugin.printUsage) { + plugin.printUsage(); + } + } + }; + return AbstractPluginLoader; + }()); - var _visitArgs = { visitDeeper: true }; - var _hasIndexed = false; - function _noop(node) { - return node; - } - function indexNodeTypes(parent, ticker) { - // add .typeIndex to tree node types for lookup table - var key; - var child; - for (key in parent) { - /* eslint guard-for-in: 0 */ - child = parent[key]; - switch (typeof child) { - case 'function': - // ignore bound functions directly on tree which do not have a prototype - // or aren't nodes - if (child.prototype && child.prototype.type) { - child.prototype.typeIndex = ticker++; - } - break; - case 'object': - ticker = indexNodeTypes(child, ticker); - break; - } - } - return ticker; - } - var Visitor = /** @class */ (function () { - function Visitor(implementation) { - this._implementation = implementation; - this._visitInCache = {}; - this._visitOutCache = {}; - if (!_hasIndexed) { - indexNodeTypes(tree, 1); - _hasIndexed = true; - } - } - Visitor.prototype.visit = function (node) { - if (!node) { - return node; - } - var nodeTypeIndex = node.typeIndex; - if (!nodeTypeIndex) { - // MixinCall args aren't a node type? - if (node.value && node.value.typeIndex) { - this.visit(node.value); - } - return node; - } - var impl = this._implementation; - var func = this._visitInCache[nodeTypeIndex]; - var funcOut = this._visitOutCache[nodeTypeIndex]; - var visitArgs = _visitArgs; - var fnName; - visitArgs.visitDeeper = true; - if (!func) { - fnName = "visit" + node.type; - func = impl[fnName] || _noop; - funcOut = impl[fnName + "Out"] || _noop; - this._visitInCache[nodeTypeIndex] = func; - this._visitOutCache[nodeTypeIndex] = funcOut; - } - if (func !== _noop) { - var newNode = func.call(impl, node, visitArgs); - if (node && impl.isReplacing) { - node = newNode; - } - } - if (visitArgs.visitDeeper && node) { - if (node.length) { - for (var i = 0, cnt = node.length; i < cnt; i++) { - if (node[i].accept) { - node[i].accept(this); - } - } - } - else if (node.accept) { - node.accept(this); - } - } - if (funcOut != _noop) { - funcOut.call(impl, node); - } - return node; - }; - Visitor.prototype.visitArray = function (nodes, nonReplacing) { - if (!nodes) { - return nodes; - } - var cnt = nodes.length; - var i; - // Non-replacing - if (nonReplacing || !this._implementation.isReplacing) { - for (i = 0; i < cnt; i++) { - this.visit(nodes[i]); - } - return nodes; - } - // Replacing - var out = []; - for (i = 0; i < cnt; i++) { - var evald = this.visit(nodes[i]); - if (evald === undefined) { - continue; - } - if (!evald.splice) { - out.push(evald); - } - else if (evald.length) { - this.flatten(evald, out); - } - } - return out; - }; - Visitor.prototype.flatten = function (arr, out) { - if (!out) { - out = []; - } - var cnt; - var i; - var item; - var nestedCnt; - var j; - var nestedItem; - for (i = 0, cnt = arr.length; i < cnt; i++) { - item = arr[i]; - if (item === undefined) { - continue; - } - if (!item.splice) { - out.push(item); - continue; - } - for (j = 0, nestedCnt = item.length; j < nestedCnt; j++) { - nestedItem = item[j]; - if (nestedItem === undefined) { - continue; - } - if (!nestedItem.splice) { - out.push(nestedItem); - } - else if (nestedItem.length) { - this.flatten(nestedItem, out); - } - } - } - return out; - }; - return Visitor; - }()); + var _visitArgs = { visitDeeper: true }; + var _hasIndexed = false; + function _noop(node) { + return node; + } + function indexNodeTypes(parent, ticker) { + // add .typeIndex to tree node types for lookup table + var key, child; + for (key in parent) { + /* eslint guard-for-in: 0 */ + child = parent[key]; + switch (typeof child) { + case 'function': + // ignore bound functions directly on tree which do not have a prototype + // or aren't nodes + if (child.prototype && child.prototype.type) { + child.prototype.typeIndex = ticker++; + } + break; + case 'object': + ticker = indexNodeTypes(child, ticker); + break; + } + } + return ticker; + } + var Visitor = /** @class */ (function () { + function Visitor(implementation) { + this._implementation = implementation; + this._visitInCache = {}; + this._visitOutCache = {}; + if (!_hasIndexed) { + indexNodeTypes(tree, 1); + _hasIndexed = true; + } + } + Visitor.prototype.visit = function (node) { + if (!node) { + return node; + } + var nodeTypeIndex = node.typeIndex; + if (!nodeTypeIndex) { + // MixinCall args aren't a node type? + if (node.value && node.value.typeIndex) { + this.visit(node.value); + } + return node; + } + var impl = this._implementation; + var func = this._visitInCache[nodeTypeIndex]; + var funcOut = this._visitOutCache[nodeTypeIndex]; + var visitArgs = _visitArgs; + var fnName; + visitArgs.visitDeeper = true; + if (!func) { + fnName = "visit" + node.type; + func = impl[fnName] || _noop; + funcOut = impl[fnName + "Out"] || _noop; + this._visitInCache[nodeTypeIndex] = func; + this._visitOutCache[nodeTypeIndex] = funcOut; + } + if (func !== _noop) { + var newNode = func.call(impl, node, visitArgs); + if (node && impl.isReplacing) { + node = newNode; + } + } + if (visitArgs.visitDeeper && node) { + if (node.length) { + for (var i = 0, cnt = node.length; i < cnt; i++) { + if (node[i].accept) { + node[i].accept(this); + } + } + } + else if (node.accept) { + node.accept(this); + } + } + if (funcOut != _noop) { + funcOut.call(impl, node); + } + return node; + }; + Visitor.prototype.visitArray = function (nodes, nonReplacing) { + if (!nodes) { + return nodes; + } + var cnt = nodes.length; + var i; + // Non-replacing + if (nonReplacing || !this._implementation.isReplacing) { + for (i = 0; i < cnt; i++) { + this.visit(nodes[i]); + } + return nodes; + } + // Replacing + var out = []; + for (i = 0; i < cnt; i++) { + var evald = this.visit(nodes[i]); + if (evald === undefined) { + continue; + } + if (!evald.splice) { + out.push(evald); + } + else if (evald.length) { + this.flatten(evald, out); + } + } + return out; + }; + Visitor.prototype.flatten = function (arr, out) { + if (!out) { + out = []; + } + var cnt, i, item, nestedCnt, j, nestedItem; + for (i = 0, cnt = arr.length; i < cnt; i++) { + item = arr[i]; + if (item === undefined) { + continue; + } + if (!item.splice) { + out.push(item); + continue; + } + for (j = 0, nestedCnt = item.length; j < nestedCnt; j++) { + nestedItem = item[j]; + if (nestedItem === undefined) { + continue; + } + if (!nestedItem.splice) { + out.push(nestedItem); + } + else if (nestedItem.length) { + this.flatten(nestedItem, out); + } + } + } + return out; + }; + return Visitor; + }()); - var ImportSequencer = /** @class */ (function () { - function ImportSequencer(onSequencerEmpty) { - this.imports = []; - this.variableImports = []; - this._onSequencerEmpty = onSequencerEmpty; - this._currentDepth = 0; - } - ImportSequencer.prototype.addImport = function (callback) { - var importSequencer = this; - var importItem = { - callback: callback, - args: null, - isReady: false - }; - this.imports.push(importItem); - return function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - importItem.args = Array.prototype.slice.call(args, 0); - importItem.isReady = true; - importSequencer.tryRun(); - }; - }; - ImportSequencer.prototype.addVariableImport = function (callback) { - this.variableImports.push(callback); - }; - ImportSequencer.prototype.tryRun = function () { - this._currentDepth++; - try { - while (true) { - while (this.imports.length > 0) { - var importItem = this.imports[0]; - if (!importItem.isReady) { - return; - } - this.imports = this.imports.slice(1); - importItem.callback.apply(null, importItem.args); - } - if (this.variableImports.length === 0) { - break; - } - var variableImport = this.variableImports[0]; - this.variableImports = this.variableImports.slice(1); - variableImport(); - } - } - finally { - this._currentDepth--; - } - if (this._currentDepth === 0 && this._onSequencerEmpty) { - this._onSequencerEmpty(); - } - }; - return ImportSequencer; - }()); + var ImportSequencer = /** @class */ (function () { + function ImportSequencer(onSequencerEmpty) { + this.imports = []; + this.variableImports = []; + this._onSequencerEmpty = onSequencerEmpty; + this._currentDepth = 0; + } + ImportSequencer.prototype.addImport = function (callback) { + var importSequencer = this, importItem = { + callback: callback, + args: null, + isReady: false + }; + this.imports.push(importItem); + return function () { + importItem.args = Array.prototype.slice.call(arguments, 0); + importItem.isReady = true; + importSequencer.tryRun(); + }; + }; + ImportSequencer.prototype.addVariableImport = function (callback) { + this.variableImports.push(callback); + }; + ImportSequencer.prototype.tryRun = function () { + this._currentDepth++; + try { + while (true) { + while (this.imports.length > 0) { + var importItem = this.imports[0]; + if (!importItem.isReady) { + return; + } + this.imports = this.imports.slice(1); + importItem.callback.apply(null, importItem.args); + } + if (this.variableImports.length === 0) { + break; + } + var variableImport = this.variableImports[0]; + this.variableImports = this.variableImports.slice(1); + variableImport(); + } + } + finally { + this._currentDepth--; + } + if (this._currentDepth === 0 && this._onSequencerEmpty) { + this._onSequencerEmpty(); + } + }; + return ImportSequencer; + }()); - var ImportVisitor = function (importer, finish) { - this._visitor = new Visitor(this); - this._importer = importer; - this._finish = finish; - this.context = new contexts.Eval(); - this.importCount = 0; - this.onceFileDetectionMap = {}; - this.recursionDetector = {}; - this._sequencer = new ImportSequencer(this._onSequencerEmpty.bind(this)); - }; - ImportVisitor.prototype = { - isReplacing: false, - run: function (root) { - try { - // process the contents - this._visitor.visit(root); - } - catch (e) { - this.error = e; - } - this.isFinished = true; - this._sequencer.tryRun(); - }, - _onSequencerEmpty: function () { - if (!this.isFinished) { - return; - } - this._finish(this.error); - }, - visitImport: function (importNode, visitArgs) { - var inlineCSS = importNode.options.inline; - if (!importNode.css || inlineCSS) { - var context = new contexts.Eval(this.context, copyArray(this.context.frames)); - var importParent = context.frames[0]; - this.importCount++; - if (importNode.isVariableImport()) { - this._sequencer.addVariableImport(this.processImportNode.bind(this, importNode, context, importParent)); - } - else { - this.processImportNode(importNode, context, importParent); - } - } - visitArgs.visitDeeper = false; - }, - processImportNode: function (importNode, context, importParent) { - var evaldImportNode; - var inlineCSS = importNode.options.inline; - try { - evaldImportNode = importNode.evalForImport(context); - } - catch (e) { - if (!e.filename) { - e.index = importNode.getIndex(); - e.filename = importNode.fileInfo().filename; - } - // attempt to eval properly and treat as css - importNode.css = true; - // if that fails, this error will be thrown - importNode.error = e; - } - if (evaldImportNode && (!evaldImportNode.css || inlineCSS)) { - if (evaldImportNode.options.multiple) { - context.importMultiple = true; - } - // try appending if we haven't determined if it is css or not - var tryAppendLessExtension = evaldImportNode.css === undefined; - for (var i = 0; i < importParent.rules.length; i++) { - if (importParent.rules[i] === importNode) { - importParent.rules[i] = evaldImportNode; - break; - } - } - var onImported = this.onImported.bind(this, evaldImportNode, context); - var sequencedOnImported = this._sequencer.addImport(onImported); - this._importer.push(evaldImportNode.getPath(), tryAppendLessExtension, evaldImportNode.fileInfo(), evaldImportNode.options, sequencedOnImported); - } - else { - this.importCount--; - if (this.isFinished) { - this._sequencer.tryRun(); - } - } - }, - onImported: function (importNode, context, e, root, importedAtRoot, fullPath) { - if (e) { - if (!e.filename) { - e.index = importNode.getIndex(); - e.filename = importNode.fileInfo().filename; - } - this.error = e; - } - var importVisitor = this; - var inlineCSS = importNode.options.inline; - var isPlugin = importNode.options.isPlugin; - var isOptional = importNode.options.optional; - var duplicateImport = importedAtRoot || fullPath in importVisitor.recursionDetector; - if (!context.importMultiple) { - if (duplicateImport) { - importNode.skip = true; - } - else { - importNode.skip = function () { - if (fullPath in importVisitor.onceFileDetectionMap) { - return true; - } - importVisitor.onceFileDetectionMap[fullPath] = true; - return false; - }; - } - } - if (!fullPath && isOptional) { - importNode.skip = true; - } - if (root) { - importNode.root = root; - importNode.importedFilename = fullPath; - if (!inlineCSS && !isPlugin && (context.importMultiple || !duplicateImport)) { - importVisitor.recursionDetector[fullPath] = true; - var oldContext = this.context; - this.context = context; - try { - this._visitor.visit(root); - } - catch (e) { - this.error = e; - } - this.context = oldContext; - } - } - importVisitor.importCount--; - if (importVisitor.isFinished) { - importVisitor._sequencer.tryRun(); - } - }, - visitDeclaration: function (declNode, visitArgs) { - if (declNode.value.type === 'DetachedRuleset') { - this.context.frames.unshift(declNode); - } - else { - visitArgs.visitDeeper = false; - } - }, - visitDeclarationOut: function (declNode) { - if (declNode.value.type === 'DetachedRuleset') { - this.context.frames.shift(); - } - }, - visitAtRule: function (atRuleNode, visitArgs) { - this.context.frames.unshift(atRuleNode); - }, - visitAtRuleOut: function (atRuleNode) { - this.context.frames.shift(); - }, - visitMixinDefinition: function (mixinDefinitionNode, visitArgs) { - this.context.frames.unshift(mixinDefinitionNode); - }, - visitMixinDefinitionOut: function (mixinDefinitionNode) { - this.context.frames.shift(); - }, - visitRuleset: function (rulesetNode, visitArgs) { - this.context.frames.unshift(rulesetNode); - }, - visitRulesetOut: function (rulesetNode) { - this.context.frames.shift(); - }, - visitMedia: function (mediaNode, visitArgs) { - this.context.frames.unshift(mediaNode.rules[0]); - }, - visitMediaOut: function (mediaNode) { - this.context.frames.shift(); - } - }; + var ImportVisitor = function (importer, finish) { + this._visitor = new Visitor(this); + this._importer = importer; + this._finish = finish; + this.context = new contexts.Eval(); + this.importCount = 0; + this.onceFileDetectionMap = {}; + this.recursionDetector = {}; + this._sequencer = new ImportSequencer(this._onSequencerEmpty.bind(this)); + }; + ImportVisitor.prototype = { + isReplacing: false, + run: function (root) { + try { + // process the contents + this._visitor.visit(root); + } + catch (e) { + this.error = e; + } + this.isFinished = true; + this._sequencer.tryRun(); + }, + _onSequencerEmpty: function () { + if (!this.isFinished) { + return; + } + this._finish(this.error); + }, + visitImport: function (importNode, visitArgs) { + var inlineCSS = importNode.options.inline; + if (!importNode.css || inlineCSS) { + var context = new contexts.Eval(this.context, copyArray(this.context.frames)); + var importParent = context.frames[0]; + this.importCount++; + if (importNode.isVariableImport()) { + this._sequencer.addVariableImport(this.processImportNode.bind(this, importNode, context, importParent)); + } + else { + this.processImportNode(importNode, context, importParent); + } + } + visitArgs.visitDeeper = false; + }, + processImportNode: function (importNode, context, importParent) { + var evaldImportNode; + var inlineCSS = importNode.options.inline; + try { + evaldImportNode = importNode.evalForImport(context); + } + catch (e) { + if (!e.filename) { + e.index = importNode.getIndex(); + e.filename = importNode.fileInfo().filename; + } + // attempt to eval properly and treat as css + importNode.css = true; + // if that fails, this error will be thrown + importNode.error = e; + } + if (evaldImportNode && (!evaldImportNode.css || inlineCSS)) { + if (evaldImportNode.options.multiple) { + context.importMultiple = true; + } + // try appending if we haven't determined if it is css or not + var tryAppendLessExtension = evaldImportNode.css === undefined; + for (var i = 0; i < importParent.rules.length; i++) { + if (importParent.rules[i] === importNode) { + importParent.rules[i] = evaldImportNode; + break; + } + } + var onImported = this.onImported.bind(this, evaldImportNode, context), sequencedOnImported = this._sequencer.addImport(onImported); + this._importer.push(evaldImportNode.getPath(), tryAppendLessExtension, evaldImportNode.fileInfo(), evaldImportNode.options, sequencedOnImported); + } + else { + this.importCount--; + if (this.isFinished) { + this._sequencer.tryRun(); + } + } + }, + onImported: function (importNode, context, e, root, importedAtRoot, fullPath) { + if (e) { + if (!e.filename) { + e.index = importNode.getIndex(); + e.filename = importNode.fileInfo().filename; + } + this.error = e; + } + var importVisitor = this, inlineCSS = importNode.options.inline, isPlugin = importNode.options.isPlugin, isOptional = importNode.options.optional, duplicateImport = importedAtRoot || fullPath in importVisitor.recursionDetector; + if (!context.importMultiple) { + if (duplicateImport) { + importNode.skip = true; + } + else { + importNode.skip = function () { + if (fullPath in importVisitor.onceFileDetectionMap) { + return true; + } + importVisitor.onceFileDetectionMap[fullPath] = true; + return false; + }; + } + } + if (!fullPath && isOptional) { + importNode.skip = true; + } + if (root) { + importNode.root = root; + importNode.importedFilename = fullPath; + if (!inlineCSS && !isPlugin && (context.importMultiple || !duplicateImport)) { + importVisitor.recursionDetector[fullPath] = true; + var oldContext = this.context; + this.context = context; + try { + this._visitor.visit(root); + } + catch (e) { + this.error = e; + } + this.context = oldContext; + } + } + importVisitor.importCount--; + if (importVisitor.isFinished) { + importVisitor._sequencer.tryRun(); + } + }, + visitDeclaration: function (declNode, visitArgs) { + if (declNode.value.type === 'DetachedRuleset') { + this.context.frames.unshift(declNode); + } + else { + visitArgs.visitDeeper = false; + } + }, + visitDeclarationOut: function (declNode) { + if (declNode.value.type === 'DetachedRuleset') { + this.context.frames.shift(); + } + }, + visitAtRule: function (atRuleNode, visitArgs) { + this.context.frames.unshift(atRuleNode); + }, + visitAtRuleOut: function (atRuleNode) { + this.context.frames.shift(); + }, + visitMixinDefinition: function (mixinDefinitionNode, visitArgs) { + this.context.frames.unshift(mixinDefinitionNode); + }, + visitMixinDefinitionOut: function (mixinDefinitionNode) { + this.context.frames.shift(); + }, + visitRuleset: function (rulesetNode, visitArgs) { + this.context.frames.unshift(rulesetNode); + }, + visitRulesetOut: function (rulesetNode) { + this.context.frames.shift(); + }, + visitMedia: function (mediaNode, visitArgs) { + this.context.frames.unshift(mediaNode.rules[0]); + }, + visitMediaOut: function (mediaNode) { + this.context.frames.shift(); + } + }; - var SetTreeVisibilityVisitor = /** @class */ (function () { - function SetTreeVisibilityVisitor(visible) { - this.visible = visible; - } - SetTreeVisibilityVisitor.prototype.run = function (root) { - this.visit(root); - }; - SetTreeVisibilityVisitor.prototype.visitArray = function (nodes) { - if (!nodes) { - return nodes; - } - var cnt = nodes.length; - var i; - for (i = 0; i < cnt; i++) { - this.visit(nodes[i]); - } - return nodes; - }; - SetTreeVisibilityVisitor.prototype.visit = function (node) { - if (!node) { - return node; - } - if (node.constructor === Array) { - return this.visitArray(node); - } - if (!node.blocksVisibility || node.blocksVisibility()) { - return node; - } - if (this.visible) { - node.ensureVisibility(); - } - else { - node.ensureInvisibility(); - } - node.accept(this); - return node; - }; - return SetTreeVisibilityVisitor; - }()); + var SetTreeVisibilityVisitor = /** @class */ (function () { + function SetTreeVisibilityVisitor(visible) { + this.visible = visible; + } + SetTreeVisibilityVisitor.prototype.run = function (root) { + this.visit(root); + }; + SetTreeVisibilityVisitor.prototype.visitArray = function (nodes) { + if (!nodes) { + return nodes; + } + var cnt = nodes.length; + var i; + for (i = 0; i < cnt; i++) { + this.visit(nodes[i]); + } + return nodes; + }; + SetTreeVisibilityVisitor.prototype.visit = function (node) { + if (!node) { + return node; + } + if (node.constructor === Array) { + return this.visitArray(node); + } + if (!node.blocksVisibility || node.blocksVisibility()) { + return node; + } + if (this.visible) { + node.ensureVisibility(); + } + else { + node.ensureInvisibility(); + } + node.accept(this); + return node; + }; + return SetTreeVisibilityVisitor; + }()); - /* jshint loopfunc:true */ - var ExtendFinderVisitor = /** @class */ (function () { - function ExtendFinderVisitor() { - this._visitor = new Visitor(this); - this.contexts = []; - this.allExtendsStack = [[]]; - } - ExtendFinderVisitor.prototype.run = function (root) { - root = this._visitor.visit(root); - root.allExtends = this.allExtendsStack[0]; - return root; - }; - ExtendFinderVisitor.prototype.visitDeclaration = function (declNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - ExtendFinderVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - ExtendFinderVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { - if (rulesetNode.root) { - return; - } - var i; - var j; - var extend; - var allSelectorsExtendList = []; - var extendList; - // get &:extend(.a); rules which apply to all selectors in this ruleset - var rules = rulesetNode.rules; - var ruleCnt = rules ? rules.length : 0; - for (i = 0; i < ruleCnt; i++) { - if (rulesetNode.rules[i] instanceof tree.Extend) { - allSelectorsExtendList.push(rules[i]); - rulesetNode.extendOnEveryPath = true; - } - } - // now find every selector and apply the extends that apply to all extends - // and the ones which apply to an individual extend - var paths = rulesetNode.paths; - for (i = 0; i < paths.length; i++) { - var selectorPath = paths[i]; - var selector = selectorPath[selectorPath.length - 1]; - var selExtendList = selector.extendList; - extendList = selExtendList ? copyArray(selExtendList).concat(allSelectorsExtendList) - : allSelectorsExtendList; - if (extendList) { - extendList = extendList.map(function (allSelectorsExtend) { return allSelectorsExtend.clone(); }); - } - for (j = 0; j < extendList.length; j++) { - this.foundExtends = true; - extend = extendList[j]; - extend.findSelfSelectors(selectorPath); - extend.ruleset = rulesetNode; - if (j === 0) { - extend.firstExtendOnThisSelectorPath = true; - } - this.allExtendsStack[this.allExtendsStack.length - 1].push(extend); - } - } - this.contexts.push(rulesetNode.selectors); - }; - ExtendFinderVisitor.prototype.visitRulesetOut = function (rulesetNode) { - if (!rulesetNode.root) { - this.contexts.length = this.contexts.length - 1; - } - }; - ExtendFinderVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { - mediaNode.allExtends = []; - this.allExtendsStack.push(mediaNode.allExtends); - }; - ExtendFinderVisitor.prototype.visitMediaOut = function (mediaNode) { - this.allExtendsStack.length = this.allExtendsStack.length - 1; - }; - ExtendFinderVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { - atRuleNode.allExtends = []; - this.allExtendsStack.push(atRuleNode.allExtends); - }; - ExtendFinderVisitor.prototype.visitAtRuleOut = function (atRuleNode) { - this.allExtendsStack.length = this.allExtendsStack.length - 1; - }; - return ExtendFinderVisitor; - }()); - var ProcessExtendsVisitor = /** @class */ (function () { - function ProcessExtendsVisitor() { - this._visitor = new Visitor(this); - } - ProcessExtendsVisitor.prototype.run = function (root) { - var extendFinder = new ExtendFinderVisitor(); - this.extendIndices = {}; - extendFinder.run(root); - if (!extendFinder.foundExtends) { - return root; - } - root.allExtends = root.allExtends.concat(this.doExtendChaining(root.allExtends, root.allExtends)); - this.allExtendsStack = [root.allExtends]; - var newRoot = this._visitor.visit(root); - this.checkExtendsForNonMatched(root.allExtends); - return newRoot; - }; - ProcessExtendsVisitor.prototype.checkExtendsForNonMatched = function (extendList) { - var indices = this.extendIndices; - extendList.filter(function (extend) { return !extend.hasFoundMatches && extend.parent_ids.length == 1; }).forEach(function (extend) { - var selector = '_unknown_'; - try { - selector = extend.selector.toCSS({}); - } - catch (_) { } - if (!indices[extend.index + " " + selector]) { - indices[extend.index + " " + selector] = true; - logger.warn("extend '" + selector + "' has no matches"); - } - }); - }; - ProcessExtendsVisitor.prototype.doExtendChaining = function (extendsList, extendsListTarget, iterationCount) { - // - // chaining is different from normal extension.. if we extend an extend then we are not just copying, altering - // and pasting the selector we would do normally, but we are also adding an extend with the same target selector - // this means this new extend can then go and alter other extends - // - // this method deals with all the chaining work - without it, extend is flat and doesn't work on other extend selectors - // this is also the most expensive.. and a match on one selector can cause an extension of a selector we had already - // processed if we look at each selector at a time, as is done in visitRuleset - var extendIndex; - var targetExtendIndex; - var matches; - var extendsToAdd = []; - var newSelector; - var extendVisitor = this; - var selectorPath; - var extend; - var targetExtend; - var newExtend; - iterationCount = iterationCount || 0; - // loop through comparing every extend with every target extend. - // a target extend is the one on the ruleset we are looking at copy/edit/pasting in place - // e.g. .a:extend(.b) {} and .b:extend(.c) {} then the first extend extends the second one - // and the second is the target. - // the separation into two lists allows us to process a subset of chains with a bigger set, as is the - // case when processing media queries - for (extendIndex = 0; extendIndex < extendsList.length; extendIndex++) { - for (targetExtendIndex = 0; targetExtendIndex < extendsListTarget.length; targetExtendIndex++) { - extend = extendsList[extendIndex]; - targetExtend = extendsListTarget[targetExtendIndex]; - // look for circular references - if (extend.parent_ids.indexOf(targetExtend.object_id) >= 0) { - continue; - } - // find a match in the target extends self selector (the bit before :extend) - selectorPath = [targetExtend.selfSelectors[0]]; - matches = extendVisitor.findMatch(extend, selectorPath); - if (matches.length) { - extend.hasFoundMatches = true; - // we found a match, so for each self selector.. - extend.selfSelectors.forEach(function (selfSelector) { - var info = targetExtend.visibilityInfo(); - // process the extend as usual - newSelector = extendVisitor.extendSelector(matches, selectorPath, selfSelector, extend.isVisible()); - // but now we create a new extend from it - newExtend = new (tree.Extend)(targetExtend.selector, targetExtend.option, 0, targetExtend.fileInfo(), info); - newExtend.selfSelectors = newSelector; - // add the extend onto the list of extends for that selector - newSelector[newSelector.length - 1].extendList = [newExtend]; - // record that we need to add it. - extendsToAdd.push(newExtend); - newExtend.ruleset = targetExtend.ruleset; - // remember its parents for circular references - newExtend.parent_ids = newExtend.parent_ids.concat(targetExtend.parent_ids, extend.parent_ids); - // only process the selector once.. if we have :extend(.a,.b) then multiple - // extends will look at the same selector path, so when extending - // we know that any others will be duplicates in terms of what is added to the css - if (targetExtend.firstExtendOnThisSelectorPath) { - newExtend.firstExtendOnThisSelectorPath = true; - targetExtend.ruleset.paths.push(newSelector); - } - }); - } - } - } - if (extendsToAdd.length) { - // try to detect circular references to stop a stack overflow. - // may no longer be needed. - this.extendChainCount++; - if (iterationCount > 100) { - var selectorOne = '{unable to calculate}'; - var selectorTwo = '{unable to calculate}'; - try { - selectorOne = extendsToAdd[0].selfSelectors[0].toCSS(); - selectorTwo = extendsToAdd[0].selector.toCSS(); - } - catch (e) { } - throw { message: "extend circular reference detected. One of the circular extends is currently:" + selectorOne + ":extend(" + selectorTwo + ")" }; - } - // now process the new extends on the existing rules so that we can handle a extending b extending c extending - // d extending e... - return extendsToAdd.concat(extendVisitor.doExtendChaining(extendsToAdd, extendsListTarget, iterationCount + 1)); - } - else { - return extendsToAdd; - } - }; - ProcessExtendsVisitor.prototype.visitDeclaration = function (ruleNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - ProcessExtendsVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - ProcessExtendsVisitor.prototype.visitSelector = function (selectorNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - ProcessExtendsVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { - if (rulesetNode.root) { - return; - } - var matches; - var pathIndex; - var extendIndex; - var allExtends = this.allExtendsStack[this.allExtendsStack.length - 1]; - var selectorsToAdd = []; - var extendVisitor = this; - var selectorPath; - // look at each selector path in the ruleset, find any extend matches and then copy, find and replace - for (extendIndex = 0; extendIndex < allExtends.length; extendIndex++) { - for (pathIndex = 0; pathIndex < rulesetNode.paths.length; pathIndex++) { - selectorPath = rulesetNode.paths[pathIndex]; - // extending extends happens initially, before the main pass - if (rulesetNode.extendOnEveryPath) { - continue; - } - var extendList = selectorPath[selectorPath.length - 1].extendList; - if (extendList && extendList.length) { - continue; - } - matches = this.findMatch(allExtends[extendIndex], selectorPath); - if (matches.length) { - allExtends[extendIndex].hasFoundMatches = true; - allExtends[extendIndex].selfSelectors.forEach(function (selfSelector) { - var extendedSelectors; - extendedSelectors = extendVisitor.extendSelector(matches, selectorPath, selfSelector, allExtends[extendIndex].isVisible()); - selectorsToAdd.push(extendedSelectors); - }); - } - } - } - rulesetNode.paths = rulesetNode.paths.concat(selectorsToAdd); - }; - ProcessExtendsVisitor.prototype.findMatch = function (extend, haystackSelectorPath) { - // - // look through the haystack selector path to try and find the needle - extend.selector - // returns an array of selector matches that can then be replaced - // - var haystackSelectorIndex; - var hackstackSelector; - var hackstackElementIndex; - var haystackElement; - var targetCombinator; - var i; - var extendVisitor = this; - var needleElements = extend.selector.elements; - var potentialMatches = []; - var potentialMatch; - var matches = []; - // loop through the haystack elements - for (haystackSelectorIndex = 0; haystackSelectorIndex < haystackSelectorPath.length; haystackSelectorIndex++) { - hackstackSelector = haystackSelectorPath[haystackSelectorIndex]; - for (hackstackElementIndex = 0; hackstackElementIndex < hackstackSelector.elements.length; hackstackElementIndex++) { - haystackElement = hackstackSelector.elements[hackstackElementIndex]; - // if we allow elements before our match we can add a potential match every time. otherwise only at the first element. - if (extend.allowBefore || (haystackSelectorIndex === 0 && hackstackElementIndex === 0)) { - potentialMatches.push({ pathIndex: haystackSelectorIndex, index: hackstackElementIndex, matched: 0, - initialCombinator: haystackElement.combinator }); - } - for (i = 0; i < potentialMatches.length; i++) { - potentialMatch = potentialMatches[i]; - // selectors add " " onto the first element. When we use & it joins the selectors together, but if we don't - // then each selector in haystackSelectorPath has a space before it added in the toCSS phase. so we need to - // work out what the resulting combinator will be - targetCombinator = haystackElement.combinator.value; - if (targetCombinator === '' && hackstackElementIndex === 0) { - targetCombinator = ' '; - } - // if we don't match, null our match to indicate failure - if (!extendVisitor.isElementValuesEqual(needleElements[potentialMatch.matched].value, haystackElement.value) || - (potentialMatch.matched > 0 && needleElements[potentialMatch.matched].combinator.value !== targetCombinator)) { - potentialMatch = null; - } - else { - potentialMatch.matched++; - } - // if we are still valid and have finished, test whether we have elements after and whether these are allowed - if (potentialMatch) { - potentialMatch.finished = potentialMatch.matched === needleElements.length; - if (potentialMatch.finished && - (!extend.allowAfter && - (hackstackElementIndex + 1 < hackstackSelector.elements.length || haystackSelectorIndex + 1 < haystackSelectorPath.length))) { - potentialMatch = null; - } - } - // if null we remove, if not, we are still valid, so either push as a valid match or continue - if (potentialMatch) { - if (potentialMatch.finished) { - potentialMatch.length = needleElements.length; - potentialMatch.endPathIndex = haystackSelectorIndex; - potentialMatch.endPathElementIndex = hackstackElementIndex + 1; // index after end of match - potentialMatches.length = 0; // we don't allow matches to overlap, so start matching again - matches.push(potentialMatch); - } - } - else { - potentialMatches.splice(i, 1); - i--; - } - } - } - } - return matches; - }; - ProcessExtendsVisitor.prototype.isElementValuesEqual = function (elementValue1, elementValue2) { - if (typeof elementValue1 === 'string' || typeof elementValue2 === 'string') { - return elementValue1 === elementValue2; - } - if (elementValue1 instanceof tree.Attribute) { - if (elementValue1.op !== elementValue2.op || elementValue1.key !== elementValue2.key) { - return false; - } - if (!elementValue1.value || !elementValue2.value) { - if (elementValue1.value || elementValue2.value) { - return false; - } - return true; - } - elementValue1 = elementValue1.value.value || elementValue1.value; - elementValue2 = elementValue2.value.value || elementValue2.value; - return elementValue1 === elementValue2; - } - elementValue1 = elementValue1.value; - elementValue2 = elementValue2.value; - if (elementValue1 instanceof tree.Selector) { - if (!(elementValue2 instanceof tree.Selector) || elementValue1.elements.length !== elementValue2.elements.length) { - return false; - } - for (var i = 0; i < elementValue1.elements.length; i++) { - if (elementValue1.elements[i].combinator.value !== elementValue2.elements[i].combinator.value) { - if (i !== 0 || (elementValue1.elements[i].combinator.value || ' ') !== (elementValue2.elements[i].combinator.value || ' ')) { - return false; - } - } - if (!this.isElementValuesEqual(elementValue1.elements[i].value, elementValue2.elements[i].value)) { - return false; - } - } - return true; - } - return false; - }; - ProcessExtendsVisitor.prototype.extendSelector = function (matches, selectorPath, replacementSelector, isVisible) { - // for a set of matches, replace each match with the replacement selector - var currentSelectorPathIndex = 0; - var currentSelectorPathElementIndex = 0; - var path = []; - var matchIndex; - var selector; - var firstElement; - var match; - var newElements; - for (matchIndex = 0; matchIndex < matches.length; matchIndex++) { - match = matches[matchIndex]; - selector = selectorPath[match.pathIndex]; - firstElement = new tree.Element(match.initialCombinator, replacementSelector.elements[0].value, replacementSelector.elements[0].isVariable, replacementSelector.elements[0].getIndex(), replacementSelector.elements[0].fileInfo()); - if (match.pathIndex > currentSelectorPathIndex && currentSelectorPathElementIndex > 0) { - path[path.length - 1].elements = path[path.length - 1] - .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex)); - currentSelectorPathElementIndex = 0; - currentSelectorPathIndex++; - } - newElements = selector.elements - .slice(currentSelectorPathElementIndex, match.index) - .concat([firstElement]) - .concat(replacementSelector.elements.slice(1)); - if (currentSelectorPathIndex === match.pathIndex && matchIndex > 0) { - path[path.length - 1].elements = - path[path.length - 1].elements.concat(newElements); - } - else { - path = path.concat(selectorPath.slice(currentSelectorPathIndex, match.pathIndex)); - path.push(new tree.Selector(newElements)); - } - currentSelectorPathIndex = match.endPathIndex; - currentSelectorPathElementIndex = match.endPathElementIndex; - if (currentSelectorPathElementIndex >= selectorPath[currentSelectorPathIndex].elements.length) { - currentSelectorPathElementIndex = 0; - currentSelectorPathIndex++; - } - } - if (currentSelectorPathIndex < selectorPath.length && currentSelectorPathElementIndex > 0) { - path[path.length - 1].elements = path[path.length - 1] - .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex)); - currentSelectorPathIndex++; - } - path = path.concat(selectorPath.slice(currentSelectorPathIndex, selectorPath.length)); - path = path.map(function (currentValue) { - // we can re-use elements here, because the visibility property matters only for selectors - var derived = currentValue.createDerived(currentValue.elements); - if (isVisible) { - derived.ensureVisibility(); - } - else { - derived.ensureInvisibility(); - } - return derived; - }); - return path; - }; - ProcessExtendsVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { - var newAllExtends = mediaNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]); - newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, mediaNode.allExtends)); - this.allExtendsStack.push(newAllExtends); - }; - ProcessExtendsVisitor.prototype.visitMediaOut = function (mediaNode) { - var lastIndex = this.allExtendsStack.length - 1; - this.allExtendsStack.length = lastIndex; - }; - ProcessExtendsVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { - var newAllExtends = atRuleNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]); - newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, atRuleNode.allExtends)); - this.allExtendsStack.push(newAllExtends); - }; - ProcessExtendsVisitor.prototype.visitAtRuleOut = function (atRuleNode) { - var lastIndex = this.allExtendsStack.length - 1; - this.allExtendsStack.length = lastIndex; - }; - return ProcessExtendsVisitor; - }()); + /* jshint loopfunc:true */ + var ExtendFinderVisitor = /** @class */ (function () { + function ExtendFinderVisitor() { + this._visitor = new Visitor(this); + this.contexts = []; + this.allExtendsStack = [[]]; + } + ExtendFinderVisitor.prototype.run = function (root) { + root = this._visitor.visit(root); + root.allExtends = this.allExtendsStack[0]; + return root; + }; + ExtendFinderVisitor.prototype.visitDeclaration = function (declNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + ExtendFinderVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + ExtendFinderVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { + if (rulesetNode.root) { + return; + } + var i; + var j; + var extend; + var allSelectorsExtendList = []; + var extendList; + // get &:extend(.a); rules which apply to all selectors in this ruleset + var rules = rulesetNode.rules, ruleCnt = rules ? rules.length : 0; + for (i = 0; i < ruleCnt; i++) { + if (rulesetNode.rules[i] instanceof tree.Extend) { + allSelectorsExtendList.push(rules[i]); + rulesetNode.extendOnEveryPath = true; + } + } + // now find every selector and apply the extends that apply to all extends + // and the ones which apply to an individual extend + var paths = rulesetNode.paths; + for (i = 0; i < paths.length; i++) { + var selectorPath = paths[i], selector = selectorPath[selectorPath.length - 1], selExtendList = selector.extendList; + extendList = selExtendList ? copyArray(selExtendList).concat(allSelectorsExtendList) + : allSelectorsExtendList; + if (extendList) { + extendList = extendList.map(function (allSelectorsExtend) { + return allSelectorsExtend.clone(); + }); + } + for (j = 0; j < extendList.length; j++) { + this.foundExtends = true; + extend = extendList[j]; + extend.findSelfSelectors(selectorPath); + extend.ruleset = rulesetNode; + if (j === 0) { + extend.firstExtendOnThisSelectorPath = true; + } + this.allExtendsStack[this.allExtendsStack.length - 1].push(extend); + } + } + this.contexts.push(rulesetNode.selectors); + }; + ExtendFinderVisitor.prototype.visitRulesetOut = function (rulesetNode) { + if (!rulesetNode.root) { + this.contexts.length = this.contexts.length - 1; + } + }; + ExtendFinderVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { + mediaNode.allExtends = []; + this.allExtendsStack.push(mediaNode.allExtends); + }; + ExtendFinderVisitor.prototype.visitMediaOut = function (mediaNode) { + this.allExtendsStack.length = this.allExtendsStack.length - 1; + }; + ExtendFinderVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { + atRuleNode.allExtends = []; + this.allExtendsStack.push(atRuleNode.allExtends); + }; + ExtendFinderVisitor.prototype.visitAtRuleOut = function (atRuleNode) { + this.allExtendsStack.length = this.allExtendsStack.length - 1; + }; + return ExtendFinderVisitor; + }()); + var ProcessExtendsVisitor = /** @class */ (function () { + function ProcessExtendsVisitor() { + this._visitor = new Visitor(this); + } + ProcessExtendsVisitor.prototype.run = function (root) { + var extendFinder = new ExtendFinderVisitor(); + this.extendIndices = {}; + extendFinder.run(root); + if (!extendFinder.foundExtends) { + return root; + } + root.allExtends = root.allExtends.concat(this.doExtendChaining(root.allExtends, root.allExtends)); + this.allExtendsStack = [root.allExtends]; + var newRoot = this._visitor.visit(root); + this.checkExtendsForNonMatched(root.allExtends); + return newRoot; + }; + ProcessExtendsVisitor.prototype.checkExtendsForNonMatched = function (extendList) { + var indices = this.extendIndices; + extendList.filter(function (extend) { + return !extend.hasFoundMatches && extend.parent_ids.length == 1; + }).forEach(function (extend) { + var selector = '_unknown_'; + try { + selector = extend.selector.toCSS({}); + } + catch (_) { } + if (!indices[extend.index + " " + selector]) { + indices[extend.index + " " + selector] = true; + logger.warn("extend '" + selector + "' has no matches"); + } + }); + }; + ProcessExtendsVisitor.prototype.doExtendChaining = function (extendsList, extendsListTarget, iterationCount) { + // + // chaining is different from normal extension.. if we extend an extend then we are not just copying, altering + // and pasting the selector we would do normally, but we are also adding an extend with the same target selector + // this means this new extend can then go and alter other extends + // + // this method deals with all the chaining work - without it, extend is flat and doesn't work on other extend selectors + // this is also the most expensive.. and a match on one selector can cause an extension of a selector we had already + // processed if we look at each selector at a time, as is done in visitRuleset + var extendIndex; + var targetExtendIndex; + var matches; + var extendsToAdd = []; + var newSelector; + var extendVisitor = this; + var selectorPath; + var extend; + var targetExtend; + var newExtend; + iterationCount = iterationCount || 0; + // loop through comparing every extend with every target extend. + // a target extend is the one on the ruleset we are looking at copy/edit/pasting in place + // e.g. .a:extend(.b) {} and .b:extend(.c) {} then the first extend extends the second one + // and the second is the target. + // the separation into two lists allows us to process a subset of chains with a bigger set, as is the + // case when processing media queries + for (extendIndex = 0; extendIndex < extendsList.length; extendIndex++) { + for (targetExtendIndex = 0; targetExtendIndex < extendsListTarget.length; targetExtendIndex++) { + extend = extendsList[extendIndex]; + targetExtend = extendsListTarget[targetExtendIndex]; + // look for circular references + if (extend.parent_ids.indexOf(targetExtend.object_id) >= 0) { + continue; + } + // find a match in the target extends self selector (the bit before :extend) + selectorPath = [targetExtend.selfSelectors[0]]; + matches = extendVisitor.findMatch(extend, selectorPath); + if (matches.length) { + extend.hasFoundMatches = true; + // we found a match, so for each self selector.. + extend.selfSelectors.forEach(function (selfSelector) { + var info = targetExtend.visibilityInfo(); + // process the extend as usual + newSelector = extendVisitor.extendSelector(matches, selectorPath, selfSelector, extend.isVisible()); + // but now we create a new extend from it + newExtend = new (tree.Extend)(targetExtend.selector, targetExtend.option, 0, targetExtend.fileInfo(), info); + newExtend.selfSelectors = newSelector; + // add the extend onto the list of extends for that selector + newSelector[newSelector.length - 1].extendList = [newExtend]; + // record that we need to add it. + extendsToAdd.push(newExtend); + newExtend.ruleset = targetExtend.ruleset; + // remember its parents for circular references + newExtend.parent_ids = newExtend.parent_ids.concat(targetExtend.parent_ids, extend.parent_ids); + // only process the selector once.. if we have :extend(.a,.b) then multiple + // extends will look at the same selector path, so when extending + // we know that any others will be duplicates in terms of what is added to the css + if (targetExtend.firstExtendOnThisSelectorPath) { + newExtend.firstExtendOnThisSelectorPath = true; + targetExtend.ruleset.paths.push(newSelector); + } + }); + } + } + } + if (extendsToAdd.length) { + // try to detect circular references to stop a stack overflow. + // may no longer be needed. + this.extendChainCount++; + if (iterationCount > 100) { + var selectorOne = '{unable to calculate}'; + var selectorTwo = '{unable to calculate}'; + try { + selectorOne = extendsToAdd[0].selfSelectors[0].toCSS(); + selectorTwo = extendsToAdd[0].selector.toCSS(); + } + catch (e) { } + throw { message: "extend circular reference detected. One of the circular extends is currently:" + selectorOne + ":extend(" + selectorTwo + ")" }; + } + // now process the new extends on the existing rules so that we can handle a extending b extending c extending + // d extending e... + return extendsToAdd.concat(extendVisitor.doExtendChaining(extendsToAdd, extendsListTarget, iterationCount + 1)); + } + else { + return extendsToAdd; + } + }; + ProcessExtendsVisitor.prototype.visitDeclaration = function (ruleNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + ProcessExtendsVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + ProcessExtendsVisitor.prototype.visitSelector = function (selectorNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + ProcessExtendsVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { + if (rulesetNode.root) { + return; + } + var matches; + var pathIndex; + var extendIndex; + var allExtends = this.allExtendsStack[this.allExtendsStack.length - 1]; + var selectorsToAdd = []; + var extendVisitor = this; + var selectorPath; + // look at each selector path in the ruleset, find any extend matches and then copy, find and replace + for (extendIndex = 0; extendIndex < allExtends.length; extendIndex++) { + for (pathIndex = 0; pathIndex < rulesetNode.paths.length; pathIndex++) { + selectorPath = rulesetNode.paths[pathIndex]; + // extending extends happens initially, before the main pass + if (rulesetNode.extendOnEveryPath) { + continue; + } + var extendList = selectorPath[selectorPath.length - 1].extendList; + if (extendList && extendList.length) { + continue; + } + matches = this.findMatch(allExtends[extendIndex], selectorPath); + if (matches.length) { + allExtends[extendIndex].hasFoundMatches = true; + allExtends[extendIndex].selfSelectors.forEach(function (selfSelector) { + var extendedSelectors; + extendedSelectors = extendVisitor.extendSelector(matches, selectorPath, selfSelector, allExtends[extendIndex].isVisible()); + selectorsToAdd.push(extendedSelectors); + }); + } + } + } + rulesetNode.paths = rulesetNode.paths.concat(selectorsToAdd); + }; + ProcessExtendsVisitor.prototype.findMatch = function (extend, haystackSelectorPath) { + // + // look through the haystack selector path to try and find the needle - extend.selector + // returns an array of selector matches that can then be replaced + // + var haystackSelectorIndex; + var hackstackSelector; + var hackstackElementIndex; + var haystackElement; + var targetCombinator; + var i; + var extendVisitor = this; + var needleElements = extend.selector.elements; + var potentialMatches = []; + var potentialMatch; + var matches = []; + // loop through the haystack elements + for (haystackSelectorIndex = 0; haystackSelectorIndex < haystackSelectorPath.length; haystackSelectorIndex++) { + hackstackSelector = haystackSelectorPath[haystackSelectorIndex]; + for (hackstackElementIndex = 0; hackstackElementIndex < hackstackSelector.elements.length; hackstackElementIndex++) { + haystackElement = hackstackSelector.elements[hackstackElementIndex]; + // if we allow elements before our match we can add a potential match every time. otherwise only at the first element. + if (extend.allowBefore || (haystackSelectorIndex === 0 && hackstackElementIndex === 0)) { + potentialMatches.push({ pathIndex: haystackSelectorIndex, index: hackstackElementIndex, matched: 0, + initialCombinator: haystackElement.combinator }); + } + for (i = 0; i < potentialMatches.length; i++) { + potentialMatch = potentialMatches[i]; + // selectors add " " onto the first element. When we use & it joins the selectors together, but if we don't + // then each selector in haystackSelectorPath has a space before it added in the toCSS phase. so we need to + // work out what the resulting combinator will be + targetCombinator = haystackElement.combinator.value; + if (targetCombinator === '' && hackstackElementIndex === 0) { + targetCombinator = ' '; + } + // if we don't match, null our match to indicate failure + if (!extendVisitor.isElementValuesEqual(needleElements[potentialMatch.matched].value, haystackElement.value) || + (potentialMatch.matched > 0 && needleElements[potentialMatch.matched].combinator.value !== targetCombinator)) { + potentialMatch = null; + } + else { + potentialMatch.matched++; + } + // if we are still valid and have finished, test whether we have elements after and whether these are allowed + if (potentialMatch) { + potentialMatch.finished = potentialMatch.matched === needleElements.length; + if (potentialMatch.finished && + (!extend.allowAfter && + (hackstackElementIndex + 1 < hackstackSelector.elements.length || haystackSelectorIndex + 1 < haystackSelectorPath.length))) { + potentialMatch = null; + } + } + // if null we remove, if not, we are still valid, so either push as a valid match or continue + if (potentialMatch) { + if (potentialMatch.finished) { + potentialMatch.length = needleElements.length; + potentialMatch.endPathIndex = haystackSelectorIndex; + potentialMatch.endPathElementIndex = hackstackElementIndex + 1; // index after end of match + potentialMatches.length = 0; // we don't allow matches to overlap, so start matching again + matches.push(potentialMatch); + } + } + else { + potentialMatches.splice(i, 1); + i--; + } + } + } + } + return matches; + }; + ProcessExtendsVisitor.prototype.isElementValuesEqual = function (elementValue1, elementValue2) { + if (typeof elementValue1 === 'string' || typeof elementValue2 === 'string') { + return elementValue1 === elementValue2; + } + if (elementValue1 instanceof tree.Attribute) { + if (elementValue1.op !== elementValue2.op || elementValue1.key !== elementValue2.key) { + return false; + } + if (!elementValue1.value || !elementValue2.value) { + if (elementValue1.value || elementValue2.value) { + return false; + } + return true; + } + elementValue1 = elementValue1.value.value || elementValue1.value; + elementValue2 = elementValue2.value.value || elementValue2.value; + return elementValue1 === elementValue2; + } + elementValue1 = elementValue1.value; + elementValue2 = elementValue2.value; + if (elementValue1 instanceof tree.Selector) { + if (!(elementValue2 instanceof tree.Selector) || elementValue1.elements.length !== elementValue2.elements.length) { + return false; + } + for (var i = 0; i < elementValue1.elements.length; i++) { + if (elementValue1.elements[i].combinator.value !== elementValue2.elements[i].combinator.value) { + if (i !== 0 || (elementValue1.elements[i].combinator.value || ' ') !== (elementValue2.elements[i].combinator.value || ' ')) { + return false; + } + } + if (!this.isElementValuesEqual(elementValue1.elements[i].value, elementValue2.elements[i].value)) { + return false; + } + } + return true; + } + return false; + }; + ProcessExtendsVisitor.prototype.extendSelector = function (matches, selectorPath, replacementSelector, isVisible) { + // for a set of matches, replace each match with the replacement selector + var currentSelectorPathIndex = 0, currentSelectorPathElementIndex = 0, path = [], matchIndex, selector, firstElement, match, newElements; + for (matchIndex = 0; matchIndex < matches.length; matchIndex++) { + match = matches[matchIndex]; + selector = selectorPath[match.pathIndex]; + firstElement = new tree.Element(match.initialCombinator, replacementSelector.elements[0].value, replacementSelector.elements[0].isVariable, replacementSelector.elements[0].getIndex(), replacementSelector.elements[0].fileInfo()); + if (match.pathIndex > currentSelectorPathIndex && currentSelectorPathElementIndex > 0) { + path[path.length - 1].elements = path[path.length - 1] + .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex)); + currentSelectorPathElementIndex = 0; + currentSelectorPathIndex++; + } + newElements = selector.elements + .slice(currentSelectorPathElementIndex, match.index) + .concat([firstElement]) + .concat(replacementSelector.elements.slice(1)); + if (currentSelectorPathIndex === match.pathIndex && matchIndex > 0) { + path[path.length - 1].elements = + path[path.length - 1].elements.concat(newElements); + } + else { + path = path.concat(selectorPath.slice(currentSelectorPathIndex, match.pathIndex)); + path.push(new tree.Selector(newElements)); + } + currentSelectorPathIndex = match.endPathIndex; + currentSelectorPathElementIndex = match.endPathElementIndex; + if (currentSelectorPathElementIndex >= selectorPath[currentSelectorPathIndex].elements.length) { + currentSelectorPathElementIndex = 0; + currentSelectorPathIndex++; + } + } + if (currentSelectorPathIndex < selectorPath.length && currentSelectorPathElementIndex > 0) { + path[path.length - 1].elements = path[path.length - 1] + .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex)); + currentSelectorPathIndex++; + } + path = path.concat(selectorPath.slice(currentSelectorPathIndex, selectorPath.length)); + path = path.map(function (currentValue) { + // we can re-use elements here, because the visibility property matters only for selectors + var derived = currentValue.createDerived(currentValue.elements); + if (isVisible) { + derived.ensureVisibility(); + } + else { + derived.ensureInvisibility(); + } + return derived; + }); + return path; + }; + ProcessExtendsVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { + var newAllExtends = mediaNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]); + newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, mediaNode.allExtends)); + this.allExtendsStack.push(newAllExtends); + }; + ProcessExtendsVisitor.prototype.visitMediaOut = function (mediaNode) { + var lastIndex = this.allExtendsStack.length - 1; + this.allExtendsStack.length = lastIndex; + }; + ProcessExtendsVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { + var newAllExtends = atRuleNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]); + newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, atRuleNode.allExtends)); + this.allExtendsStack.push(newAllExtends); + }; + ProcessExtendsVisitor.prototype.visitAtRuleOut = function (atRuleNode) { + var lastIndex = this.allExtendsStack.length - 1; + this.allExtendsStack.length = lastIndex; + }; + return ProcessExtendsVisitor; + }()); - var JoinSelectorVisitor = /** @class */ (function () { - function JoinSelectorVisitor() { - this.contexts = [[]]; - this._visitor = new Visitor(this); - } - JoinSelectorVisitor.prototype.run = function (root) { - return this._visitor.visit(root); - }; - JoinSelectorVisitor.prototype.visitDeclaration = function (declNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - JoinSelectorVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - JoinSelectorVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { - var context = this.contexts[this.contexts.length - 1]; - var paths = []; - var selectors; - this.contexts.push(paths); - if (!rulesetNode.root) { - selectors = rulesetNode.selectors; - if (selectors) { - selectors = selectors.filter(function (selector) { return selector.getIsOutput(); }); - rulesetNode.selectors = selectors.length ? selectors : (selectors = null); - if (selectors) { - rulesetNode.joinSelectors(paths, context, selectors); - } - } - if (!selectors) { - rulesetNode.rules = null; - } - rulesetNode.paths = paths; - } - }; - JoinSelectorVisitor.prototype.visitRulesetOut = function (rulesetNode) { - this.contexts.length = this.contexts.length - 1; - }; - JoinSelectorVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { - var context = this.contexts[this.contexts.length - 1]; - mediaNode.rules[0].root = (context.length === 0 || context[0].multiMedia); - }; - JoinSelectorVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { - var context = this.contexts[this.contexts.length - 1]; - if (atRuleNode.rules && atRuleNode.rules.length) { - atRuleNode.rules[0].root = (atRuleNode.isRooted || context.length === 0 || null); - } - }; - return JoinSelectorVisitor; - }()); + var JoinSelectorVisitor = /** @class */ (function () { + function JoinSelectorVisitor() { + this.contexts = [[]]; + this._visitor = new Visitor(this); + } + JoinSelectorVisitor.prototype.run = function (root) { + return this._visitor.visit(root); + }; + JoinSelectorVisitor.prototype.visitDeclaration = function (declNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + JoinSelectorVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + JoinSelectorVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { + var context = this.contexts[this.contexts.length - 1]; + var paths = []; + var selectors; + this.contexts.push(paths); + if (!rulesetNode.root) { + selectors = rulesetNode.selectors; + if (selectors) { + selectors = selectors.filter(function (selector) { return selector.getIsOutput(); }); + rulesetNode.selectors = selectors.length ? selectors : (selectors = null); + if (selectors) { + rulesetNode.joinSelectors(paths, context, selectors); + } + } + if (!selectors) { + rulesetNode.rules = null; + } + rulesetNode.paths = paths; + } + }; + JoinSelectorVisitor.prototype.visitRulesetOut = function (rulesetNode) { + this.contexts.length = this.contexts.length - 1; + }; + JoinSelectorVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { + var context = this.contexts[this.contexts.length - 1]; + mediaNode.rules[0].root = (context.length === 0 || context[0].multiMedia); + }; + JoinSelectorVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { + var context = this.contexts[this.contexts.length - 1]; + if (atRuleNode.rules && atRuleNode.rules.length) { + atRuleNode.rules[0].root = (atRuleNode.isRooted || context.length === 0 || null); + } + }; + return JoinSelectorVisitor; + }()); - var CSSVisitorUtils = /** @class */ (function () { - function CSSVisitorUtils(context) { - this._visitor = new Visitor(this); - this._context = context; - } - CSSVisitorUtils.prototype.containsSilentNonBlockedChild = function (bodyRules) { - var rule; - if (!bodyRules) { - return false; - } - for (var r = 0; r < bodyRules.length; r++) { - rule = bodyRules[r]; - if (rule.isSilent && rule.isSilent(this._context) && !rule.blocksVisibility()) { - // the atrule contains something that was referenced (likely by extend) - // therefore it needs to be shown in output too - return true; - } - } - return false; - }; - CSSVisitorUtils.prototype.keepOnlyVisibleChilds = function (owner) { - if (owner && owner.rules) { - owner.rules = owner.rules.filter(function (thing) { return thing.isVisible(); }); - } - }; - CSSVisitorUtils.prototype.isEmpty = function (owner) { - return (owner && owner.rules) - ? (owner.rules.length === 0) : true; - }; - CSSVisitorUtils.prototype.hasVisibleSelector = function (rulesetNode) { - return (rulesetNode && rulesetNode.paths) - ? (rulesetNode.paths.length > 0) : false; - }; - CSSVisitorUtils.prototype.resolveVisibility = function (node, originalRules) { - if (!node.blocksVisibility()) { - if (this.isEmpty(node) && !this.containsSilentNonBlockedChild(originalRules)) { - return; - } - return node; - } - var compiledRulesBody = node.rules[0]; - this.keepOnlyVisibleChilds(compiledRulesBody); - if (this.isEmpty(compiledRulesBody)) { - return; - } - node.ensureVisibility(); - node.removeVisibilityBlock(); - return node; - }; - CSSVisitorUtils.prototype.isVisibleRuleset = function (rulesetNode) { - if (rulesetNode.firstRoot) { - return true; - } - if (this.isEmpty(rulesetNode)) { - return false; - } - if (!rulesetNode.root && !this.hasVisibleSelector(rulesetNode)) { - return false; - } - return true; - }; - return CSSVisitorUtils; - }()); - var ToCSSVisitor = function (context) { - this._visitor = new Visitor(this); - this._context = context; - this.utils = new CSSVisitorUtils(context); - }; - ToCSSVisitor.prototype = { - isReplacing: true, - run: function (root) { - return this._visitor.visit(root); - }, - visitDeclaration: function (declNode, visitArgs) { - if (declNode.blocksVisibility() || declNode.variable) { - return; - } - return declNode; - }, - visitMixinDefinition: function (mixinNode, visitArgs) { - // mixin definitions do not get eval'd - this means they keep state - // so we have to clear that state here so it isn't used if toCSS is called twice - mixinNode.frames = []; - }, - visitExtend: function (extendNode, visitArgs) { - }, - visitComment: function (commentNode, visitArgs) { - if (commentNode.blocksVisibility() || commentNode.isSilent(this._context)) { - return; - } - return commentNode; - }, - visitMedia: function (mediaNode, visitArgs) { - var originalRules = mediaNode.rules[0].rules; - mediaNode.accept(this._visitor); - visitArgs.visitDeeper = false; - return this.utils.resolveVisibility(mediaNode, originalRules); - }, - visitImport: function (importNode, visitArgs) { - if (importNode.blocksVisibility()) { - return; - } - return importNode; - }, - visitAtRule: function (atRuleNode, visitArgs) { - if (atRuleNode.rules && atRuleNode.rules.length) { - return this.visitAtRuleWithBody(atRuleNode, visitArgs); - } - else { - return this.visitAtRuleWithoutBody(atRuleNode, visitArgs); - } - }, - visitAnonymous: function (anonymousNode, visitArgs) { - if (!anonymousNode.blocksVisibility()) { - anonymousNode.accept(this._visitor); - return anonymousNode; - } - }, - visitAtRuleWithBody: function (atRuleNode, visitArgs) { - // if there is only one nested ruleset and that one has no path, then it is - // just fake ruleset - function hasFakeRuleset(atRuleNode) { - var bodyRules = atRuleNode.rules; - return bodyRules.length === 1 && (!bodyRules[0].paths || bodyRules[0].paths.length === 0); - } - function getBodyRules(atRuleNode) { - var nodeRules = atRuleNode.rules; - if (hasFakeRuleset(atRuleNode)) { - return nodeRules[0].rules; - } - return nodeRules; - } - // it is still true that it is only one ruleset in array - // this is last such moment - // process childs - var originalRules = getBodyRules(atRuleNode); - atRuleNode.accept(this._visitor); - visitArgs.visitDeeper = false; - if (!this.utils.isEmpty(atRuleNode)) { - this._mergeRules(atRuleNode.rules[0].rules); - } - return this.utils.resolveVisibility(atRuleNode, originalRules); - }, - visitAtRuleWithoutBody: function (atRuleNode, visitArgs) { - if (atRuleNode.blocksVisibility()) { - return; - } - if (atRuleNode.name === '@charset') { - // Only output the debug info together with subsequent @charset definitions - // a comment (or @media statement) before the actual @charset atrule would - // be considered illegal css as it has to be on the first line - if (this.charset) { - if (atRuleNode.debugInfo) { - var comment = new tree.Comment("/* " + atRuleNode.toCSS(this._context).replace(/\n/g, '') + " */\n"); - comment.debugInfo = atRuleNode.debugInfo; - return this._visitor.visit(comment); - } - return; - } - this.charset = true; - } - return atRuleNode; - }, - checkValidNodes: function (rules, isRoot) { - if (!rules) { - return; - } - for (var i = 0; i < rules.length; i++) { - var ruleNode = rules[i]; - if (isRoot && ruleNode instanceof tree.Declaration && !ruleNode.variable) { - throw { message: 'Properties must be inside selector blocks. They cannot be in the root', - index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; - } - if (ruleNode instanceof tree.Call) { - throw { message: "Function '" + ruleNode.name + "' is undefined", index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; - } - if (ruleNode.type && !ruleNode.allowRoot) { - throw { message: ruleNode.type + " node returned by a function is not valid here", index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; - } - } - }, - visitRuleset: function (rulesetNode, visitArgs) { - // at this point rulesets are nested into each other - var rule; - var rulesets = []; - this.checkValidNodes(rulesetNode.rules, rulesetNode.firstRoot); - if (!rulesetNode.root) { - // remove invisible paths - this._compileRulesetPaths(rulesetNode); - // remove rulesets from this ruleset body and compile them separately - var nodeRules = rulesetNode.rules; - var nodeRuleCnt = nodeRules ? nodeRules.length : 0; - for (var i = 0; i < nodeRuleCnt;) { - rule = nodeRules[i]; - if (rule && rule.rules) { - // visit because we are moving them out from being a child - rulesets.push(this._visitor.visit(rule)); - nodeRules.splice(i, 1); - nodeRuleCnt--; - continue; - } - i++; - } - // accept the visitor to remove rules and refactor itself - // then we can decide nogw whether we want it or not - // compile body - if (nodeRuleCnt > 0) { - rulesetNode.accept(this._visitor); - } - else { - rulesetNode.rules = null; - } - visitArgs.visitDeeper = false; - } - else { // if (! rulesetNode.root) { - rulesetNode.accept(this._visitor); - visitArgs.visitDeeper = false; - } - if (rulesetNode.rules) { - this._mergeRules(rulesetNode.rules); - this._removeDuplicateRules(rulesetNode.rules); - } - // now decide whether we keep the ruleset - if (this.utils.isVisibleRuleset(rulesetNode)) { - rulesetNode.ensureVisibility(); - rulesets.splice(0, 0, rulesetNode); - } - if (rulesets.length === 1) { - return rulesets[0]; - } - return rulesets; - }, - _compileRulesetPaths: function (rulesetNode) { - if (rulesetNode.paths) { - rulesetNode.paths = rulesetNode.paths - .filter(function (p) { - var i; - if (p[0].elements[0].combinator.value === ' ') { - p[0].elements[0].combinator = new (tree.Combinator)(''); - } - for (i = 0; i < p.length; i++) { - if (p[i].isVisible() && p[i].getIsOutput()) { - return true; - } - } - return false; - }); - } - }, - _removeDuplicateRules: function (rules) { - if (!rules) { - return; - } - // remove duplicates - var ruleCache = {}; - var ruleList; - var rule; - var i; - for (i = rules.length - 1; i >= 0; i--) { - rule = rules[i]; - if (rule instanceof tree.Declaration) { - if (!ruleCache[rule.name]) { - ruleCache[rule.name] = rule; - } - else { - ruleList = ruleCache[rule.name]; - if (ruleList instanceof tree.Declaration) { - ruleList = ruleCache[rule.name] = [ruleCache[rule.name].toCSS(this._context)]; - } - var ruleCSS = rule.toCSS(this._context); - if (ruleList.indexOf(ruleCSS) !== -1) { - rules.splice(i, 1); - } - else { - ruleList.push(ruleCSS); - } - } - } - } - }, - _mergeRules: function (rules) { - if (!rules) { - return; - } - var groups = {}; - var groupsArr = []; - for (var i = 0; i < rules.length; i++) { - var rule = rules[i]; - if (rule.merge) { - var key = rule.name; - groups[key] ? rules.splice(i--, 1) : - groupsArr.push(groups[key] = []); - groups[key].push(rule); - } - } - groupsArr.forEach(function (group) { - if (group.length > 0) { - var result_1 = group[0]; - var space_1 = []; - var comma_1 = [new tree.Expression(space_1)]; - group.forEach(function (rule) { - if ((rule.merge === '+') && (space_1.length > 0)) { - comma_1.push(new tree.Expression(space_1 = [])); - } - space_1.push(rule.value); - result_1.important = result_1.important || rule.important; - }); - result_1.value = new tree.Value(comma_1); - } - }); - } - }; + var CSSVisitorUtils = /** @class */ (function () { + function CSSVisitorUtils(context) { + this._visitor = new Visitor(this); + this._context = context; + } + CSSVisitorUtils.prototype.containsSilentNonBlockedChild = function (bodyRules) { + var rule; + if (!bodyRules) { + return false; + } + for (var r = 0; r < bodyRules.length; r++) { + rule = bodyRules[r]; + if (rule.isSilent && rule.isSilent(this._context) && !rule.blocksVisibility()) { + // the atrule contains something that was referenced (likely by extend) + // therefore it needs to be shown in output too + return true; + } + } + return false; + }; + CSSVisitorUtils.prototype.keepOnlyVisibleChilds = function (owner) { + if (owner && owner.rules) { + owner.rules = owner.rules.filter(function (thing) { return thing.isVisible(); }); + } + }; + CSSVisitorUtils.prototype.isEmpty = function (owner) { + return (owner && owner.rules) + ? (owner.rules.length === 0) : true; + }; + CSSVisitorUtils.prototype.hasVisibleSelector = function (rulesetNode) { + return (rulesetNode && rulesetNode.paths) + ? (rulesetNode.paths.length > 0) : false; + }; + CSSVisitorUtils.prototype.resolveVisibility = function (node, originalRules) { + if (!node.blocksVisibility()) { + if (this.isEmpty(node) && !this.containsSilentNonBlockedChild(originalRules)) { + return; + } + return node; + } + var compiledRulesBody = node.rules[0]; + this.keepOnlyVisibleChilds(compiledRulesBody); + if (this.isEmpty(compiledRulesBody)) { + return; + } + node.ensureVisibility(); + node.removeVisibilityBlock(); + return node; + }; + CSSVisitorUtils.prototype.isVisibleRuleset = function (rulesetNode) { + if (rulesetNode.firstRoot) { + return true; + } + if (this.isEmpty(rulesetNode)) { + return false; + } + if (!rulesetNode.root && !this.hasVisibleSelector(rulesetNode)) { + return false; + } + return true; + }; + return CSSVisitorUtils; + }()); + var ToCSSVisitor = function (context) { + this._visitor = new Visitor(this); + this._context = context; + this.utils = new CSSVisitorUtils(context); + }; + ToCSSVisitor.prototype = { + isReplacing: true, + run: function (root) { + return this._visitor.visit(root); + }, + visitDeclaration: function (declNode, visitArgs) { + if (declNode.blocksVisibility() || declNode.variable) { + return; + } + return declNode; + }, + visitMixinDefinition: function (mixinNode, visitArgs) { + // mixin definitions do not get eval'd - this means they keep state + // so we have to clear that state here so it isn't used if toCSS is called twice + mixinNode.frames = []; + }, + visitExtend: function (extendNode, visitArgs) { + }, + visitComment: function (commentNode, visitArgs) { + if (commentNode.blocksVisibility() || commentNode.isSilent(this._context)) { + return; + } + return commentNode; + }, + visitMedia: function (mediaNode, visitArgs) { + var originalRules = mediaNode.rules[0].rules; + mediaNode.accept(this._visitor); + visitArgs.visitDeeper = false; + return this.utils.resolveVisibility(mediaNode, originalRules); + }, + visitImport: function (importNode, visitArgs) { + if (importNode.blocksVisibility()) { + return; + } + return importNode; + }, + visitAtRule: function (atRuleNode, visitArgs) { + if (atRuleNode.rules && atRuleNode.rules.length) { + return this.visitAtRuleWithBody(atRuleNode, visitArgs); + } + else { + return this.visitAtRuleWithoutBody(atRuleNode, visitArgs); + } + }, + visitAnonymous: function (anonymousNode, visitArgs) { + if (!anonymousNode.blocksVisibility()) { + anonymousNode.accept(this._visitor); + return anonymousNode; + } + }, + visitAtRuleWithBody: function (atRuleNode, visitArgs) { + // if there is only one nested ruleset and that one has no path, then it is + // just fake ruleset + function hasFakeRuleset(atRuleNode) { + var bodyRules = atRuleNode.rules; + return bodyRules.length === 1 && (!bodyRules[0].paths || bodyRules[0].paths.length === 0); + } + function getBodyRules(atRuleNode) { + var nodeRules = atRuleNode.rules; + if (hasFakeRuleset(atRuleNode)) { + return nodeRules[0].rules; + } + return nodeRules; + } + // it is still true that it is only one ruleset in array + // this is last such moment + // process childs + var originalRules = getBodyRules(atRuleNode); + atRuleNode.accept(this._visitor); + visitArgs.visitDeeper = false; + if (!this.utils.isEmpty(atRuleNode)) { + this._mergeRules(atRuleNode.rules[0].rules); + } + return this.utils.resolveVisibility(atRuleNode, originalRules); + }, + visitAtRuleWithoutBody: function (atRuleNode, visitArgs) { + if (atRuleNode.blocksVisibility()) { + return; + } + if (atRuleNode.name === '@charset') { + // Only output the debug info together with subsequent @charset definitions + // a comment (or @media statement) before the actual @charset atrule would + // be considered illegal css as it has to be on the first line + if (this.charset) { + if (atRuleNode.debugInfo) { + var comment = new tree.Comment("/* " + atRuleNode.toCSS(this._context).replace(/\n/g, '') + " */\n"); + comment.debugInfo = atRuleNode.debugInfo; + return this._visitor.visit(comment); + } + return; + } + this.charset = true; + } + return atRuleNode; + }, + checkValidNodes: function (rules, isRoot) { + if (!rules) { + return; + } + for (var i = 0; i < rules.length; i++) { + var ruleNode = rules[i]; + if (isRoot && ruleNode instanceof tree.Declaration && !ruleNode.variable) { + throw { message: 'Properties must be inside selector blocks. They cannot be in the root', + index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; + } + if (ruleNode instanceof tree.Call) { + throw { message: "Function '" + ruleNode.name + "' did not return a root node", index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; + } + if (ruleNode.type && !ruleNode.allowRoot) { + throw { message: ruleNode.type + " node returned by a function is not valid here", index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; + } + } + }, + visitRuleset: function (rulesetNode, visitArgs) { + // at this point rulesets are nested into each other + var rule; + var rulesets = []; + this.checkValidNodes(rulesetNode.rules, rulesetNode.firstRoot); + if (!rulesetNode.root) { + // remove invisible paths + this._compileRulesetPaths(rulesetNode); + // remove rulesets from this ruleset body and compile them separately + var nodeRules = rulesetNode.rules; + var nodeRuleCnt = nodeRules ? nodeRules.length : 0; + for (var i = 0; i < nodeRuleCnt;) { + rule = nodeRules[i]; + if (rule && rule.rules) { + // visit because we are moving them out from being a child + rulesets.push(this._visitor.visit(rule)); + nodeRules.splice(i, 1); + nodeRuleCnt--; + continue; + } + i++; + } + // accept the visitor to remove rules and refactor itself + // then we can decide nogw whether we want it or not + // compile body + if (nodeRuleCnt > 0) { + rulesetNode.accept(this._visitor); + } + else { + rulesetNode.rules = null; + } + visitArgs.visitDeeper = false; + } + else { // if (! rulesetNode.root) { + rulesetNode.accept(this._visitor); + visitArgs.visitDeeper = false; + } + if (rulesetNode.rules) { + this._mergeRules(rulesetNode.rules); + this._removeDuplicateRules(rulesetNode.rules); + } + // now decide whether we keep the ruleset + if (this.utils.isVisibleRuleset(rulesetNode)) { + rulesetNode.ensureVisibility(); + rulesets.splice(0, 0, rulesetNode); + } + if (rulesets.length === 1) { + return rulesets[0]; + } + return rulesets; + }, + _compileRulesetPaths: function (rulesetNode) { + if (rulesetNode.paths) { + rulesetNode.paths = rulesetNode.paths + .filter(function (p) { + var i; + if (p[0].elements[0].combinator.value === ' ') { + p[0].elements[0].combinator = new (tree.Combinator)(''); + } + for (i = 0; i < p.length; i++) { + if (p[i].isVisible() && p[i].getIsOutput()) { + return true; + } + } + return false; + }); + } + }, + _removeDuplicateRules: function (rules) { + if (!rules) { + return; + } + // remove duplicates + var ruleCache = {}; + var ruleList; + var rule; + var i; + for (i = rules.length - 1; i >= 0; i--) { + rule = rules[i]; + if (rule instanceof tree.Declaration) { + if (!ruleCache[rule.name]) { + ruleCache[rule.name] = rule; + } + else { + ruleList = ruleCache[rule.name]; + if (ruleList instanceof tree.Declaration) { + ruleList = ruleCache[rule.name] = [ruleCache[rule.name].toCSS(this._context)]; + } + var ruleCSS = rule.toCSS(this._context); + if (ruleList.indexOf(ruleCSS) !== -1) { + rules.splice(i, 1); + } + else { + ruleList.push(ruleCSS); + } + } + } + } + }, + _mergeRules: function (rules) { + if (!rules) { + return; + } + var groups = {}; + var groupsArr = []; + for (var i = 0; i < rules.length; i++) { + var rule = rules[i]; + if (rule.merge) { + var key = rule.name; + groups[key] ? rules.splice(i--, 1) : + groupsArr.push(groups[key] = []); + groups[key].push(rule); + } + } + groupsArr.forEach(function (group) { + if (group.length > 0) { + var result_1 = group[0]; + var space_1 = []; + var comma_1 = [new tree.Expression(space_1)]; + group.forEach(function (rule) { + if ((rule.merge === '+') && (space_1.length > 0)) { + comma_1.push(new tree.Expression(space_1 = [])); + } + space_1.push(rule.value); + result_1.important = result_1.important || rule.important; + }); + result_1.value = new tree.Value(comma_1); + } + }); + } + }; - var visitors = { - Visitor: Visitor, - ImportVisitor: ImportVisitor, - MarkVisibleSelectorsVisitor: SetTreeVisibilityVisitor, - ExtendVisitor: ProcessExtendsVisitor, - JoinSelectorVisitor: JoinSelectorVisitor, - ToCSSVisitor: ToCSSVisitor - }; + var visitors = { + Visitor: Visitor, + ImportVisitor: ImportVisitor, + MarkVisibleSelectorsVisitor: SetTreeVisibilityVisitor, + ExtendVisitor: ProcessExtendsVisitor, + JoinSelectorVisitor: JoinSelectorVisitor, + ToCSSVisitor: ToCSSVisitor + }; - // Split the input into chunks. - var chunker = (function (input, fail) { - var len = input.length; - var level = 0; - var parenLevel = 0; - var lastOpening; - var lastOpeningParen; - var lastMultiComment; - var lastMultiCommentEndBrace; - var chunks = []; - var emitFrom = 0; - var chunkerCurrentIndex; - var currentChunkStartIndex; - var cc; - var cc2; - var matched; - function emitChunk(force) { - var len = chunkerCurrentIndex - emitFrom; - if (((len < 512) && !force) || !len) { - return; - } - chunks.push(input.slice(emitFrom, chunkerCurrentIndex + 1)); - emitFrom = chunkerCurrentIndex + 1; - } - for (chunkerCurrentIndex = 0; chunkerCurrentIndex < len; chunkerCurrentIndex++) { - cc = input.charCodeAt(chunkerCurrentIndex); - if (((cc >= 97) && (cc <= 122)) || (cc < 34)) { - // a-z or whitespace - continue; - } - switch (cc) { - case 40: // ( - parenLevel++; - lastOpeningParen = chunkerCurrentIndex; - continue; - case 41: // ) - if (--parenLevel < 0) { - return fail('missing opening `(`', chunkerCurrentIndex); - } - continue; - case 59: // ; - if (!parenLevel) { - emitChunk(); - } - continue; - case 123: // { - level++; - lastOpening = chunkerCurrentIndex; - continue; - case 125: // } - if (--level < 0) { - return fail('missing opening `{`', chunkerCurrentIndex); - } - if (!level && !parenLevel) { - emitChunk(); - } - continue; - case 92: // \ - if (chunkerCurrentIndex < len - 1) { - chunkerCurrentIndex++; - continue; - } - return fail('unescaped `\\`', chunkerCurrentIndex); - case 34: - case 39: - case 96: // ", ' and ` - matched = 0; - currentChunkStartIndex = chunkerCurrentIndex; - for (chunkerCurrentIndex = chunkerCurrentIndex + 1; chunkerCurrentIndex < len; chunkerCurrentIndex++) { - cc2 = input.charCodeAt(chunkerCurrentIndex); - if (cc2 > 96) { - continue; - } - if (cc2 == cc) { - matched = 1; - break; - } - if (cc2 == 92) { // \ - if (chunkerCurrentIndex == len - 1) { - return fail('unescaped `\\`', chunkerCurrentIndex); - } - chunkerCurrentIndex++; - } - } - if (matched) { - continue; - } - return fail("unmatched `" + String.fromCharCode(cc) + "`", currentChunkStartIndex); - case 47: // /, check for comment - if (parenLevel || (chunkerCurrentIndex == len - 1)) { - continue; - } - cc2 = input.charCodeAt(chunkerCurrentIndex + 1); - if (cc2 == 47) { - // //, find lnfeed - for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len; chunkerCurrentIndex++) { - cc2 = input.charCodeAt(chunkerCurrentIndex); - if ((cc2 <= 13) && ((cc2 == 10) || (cc2 == 13))) { - break; - } - } - } - else if (cc2 == 42) { - // /*, find */ - lastMultiComment = currentChunkStartIndex = chunkerCurrentIndex; - for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len - 1; chunkerCurrentIndex++) { - cc2 = input.charCodeAt(chunkerCurrentIndex); - if (cc2 == 125) { - lastMultiCommentEndBrace = chunkerCurrentIndex; - } - if (cc2 != 42) { - continue; - } - if (input.charCodeAt(chunkerCurrentIndex + 1) == 47) { - break; - } - } - if (chunkerCurrentIndex == len - 1) { - return fail('missing closing `*/`', currentChunkStartIndex); - } - chunkerCurrentIndex++; - } - continue; - case 42: // *, check for unmatched */ - if ((chunkerCurrentIndex < len - 1) && (input.charCodeAt(chunkerCurrentIndex + 1) == 47)) { - return fail('unmatched `/*`', chunkerCurrentIndex); - } - continue; - } - } - if (level !== 0) { - if ((lastMultiComment > lastOpening) && (lastMultiCommentEndBrace > lastMultiComment)) { - return fail('missing closing `}` or `*/`', lastOpening); - } - else { - return fail('missing closing `}`', lastOpening); - } - } - else if (parenLevel !== 0) { - return fail('missing closing `)`', lastOpeningParen); - } - emitChunk(true); - return chunks; - }); + // Split the input into chunks. + function chunker (input, fail) { + var len = input.length; + var level = 0; + var parenLevel = 0; + var lastOpening; + var lastOpeningParen; + var lastMultiComment; + var lastMultiCommentEndBrace; + var chunks = []; + var emitFrom = 0; + var chunkerCurrentIndex; + var currentChunkStartIndex; + var cc; + var cc2; + var matched; + function emitChunk(force) { + var len = chunkerCurrentIndex - emitFrom; + if (((len < 512) && !force) || !len) { + return; + } + chunks.push(input.slice(emitFrom, chunkerCurrentIndex + 1)); + emitFrom = chunkerCurrentIndex + 1; + } + for (chunkerCurrentIndex = 0; chunkerCurrentIndex < len; chunkerCurrentIndex++) { + cc = input.charCodeAt(chunkerCurrentIndex); + if (((cc >= 97) && (cc <= 122)) || (cc < 34)) { + // a-z or whitespace + continue; + } + switch (cc) { + case 40: // ( + parenLevel++; + lastOpeningParen = chunkerCurrentIndex; + continue; + case 41: // ) + if (--parenLevel < 0) { + return fail('missing opening `(`', chunkerCurrentIndex); + } + continue; + case 59: // ; + if (!parenLevel) { + emitChunk(); + } + continue; + case 123: // { + level++; + lastOpening = chunkerCurrentIndex; + continue; + case 125: // } + if (--level < 0) { + return fail('missing opening `{`', chunkerCurrentIndex); + } + if (!level && !parenLevel) { + emitChunk(); + } + continue; + case 92: // \ + if (chunkerCurrentIndex < len - 1) { + chunkerCurrentIndex++; + continue; + } + return fail('unescaped `\\`', chunkerCurrentIndex); + case 34: + case 39: + case 96: // ", ' and ` + matched = 0; + currentChunkStartIndex = chunkerCurrentIndex; + for (chunkerCurrentIndex = chunkerCurrentIndex + 1; chunkerCurrentIndex < len; chunkerCurrentIndex++) { + cc2 = input.charCodeAt(chunkerCurrentIndex); + if (cc2 > 96) { + continue; + } + if (cc2 == cc) { + matched = 1; + break; + } + if (cc2 == 92) { // \ + if (chunkerCurrentIndex == len - 1) { + return fail('unescaped `\\`', chunkerCurrentIndex); + } + chunkerCurrentIndex++; + } + } + if (matched) { + continue; + } + return fail("unmatched `" + String.fromCharCode(cc) + "`", currentChunkStartIndex); + case 47: // /, check for comment + if (parenLevel || (chunkerCurrentIndex == len - 1)) { + continue; + } + cc2 = input.charCodeAt(chunkerCurrentIndex + 1); + if (cc2 == 47) { + // //, find lnfeed + for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len; chunkerCurrentIndex++) { + cc2 = input.charCodeAt(chunkerCurrentIndex); + if ((cc2 <= 13) && ((cc2 == 10) || (cc2 == 13))) { + break; + } + } + } + else if (cc2 == 42) { + // /*, find */ + lastMultiComment = currentChunkStartIndex = chunkerCurrentIndex; + for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len - 1; chunkerCurrentIndex++) { + cc2 = input.charCodeAt(chunkerCurrentIndex); + if (cc2 == 125) { + lastMultiCommentEndBrace = chunkerCurrentIndex; + } + if (cc2 != 42) { + continue; + } + if (input.charCodeAt(chunkerCurrentIndex + 1) == 47) { + break; + } + } + if (chunkerCurrentIndex == len - 1) { + return fail('missing closing `*/`', currentChunkStartIndex); + } + chunkerCurrentIndex++; + } + continue; + case 42: // *, check for unmatched */ + if ((chunkerCurrentIndex < len - 1) && (input.charCodeAt(chunkerCurrentIndex + 1) == 47)) { + return fail('unmatched `/*`', chunkerCurrentIndex); + } + continue; + } + } + if (level !== 0) { + if ((lastMultiComment > lastOpening) && (lastMultiCommentEndBrace > lastMultiComment)) { + return fail('missing closing `}` or `*/`', lastOpening); + } + else { + return fail('missing closing `}`', lastOpening); + } + } + else if (parenLevel !== 0) { + return fail('missing closing `)`', lastOpeningParen); + } + emitChunk(true); + return chunks; + } - var getParserInput = (function () { - var // Less input string - input; - var // current chunk - j; - var // holds state for backtracking - saveStack = []; - var // furthest index the parser has gone to - furthest; - var // if this is furthest we got to, this is the probably cause - furthestPossibleErrorMessage; - var // chunkified input - chunks; - var // current chunk - current; - var // index of current chunk, in `input` - currentPos; - var parserInput = {}; - var CHARCODE_SPACE = 32; - var CHARCODE_TAB = 9; - var CHARCODE_LF = 10; - var CHARCODE_CR = 13; - var CHARCODE_PLUS = 43; - var CHARCODE_COMMA = 44; - var CHARCODE_FORWARD_SLASH = 47; - var CHARCODE_9 = 57; - function skipWhitespace(length) { - var oldi = parserInput.i; - var oldj = j; - var curr = parserInput.i - currentPos; - var endIndex = parserInput.i + current.length - curr; - var mem = (parserInput.i += length); - var inp = input; - var c; - var nextChar; - var comment; - for (; parserInput.i < endIndex; parserInput.i++) { - c = inp.charCodeAt(parserInput.i); - if (parserInput.autoCommentAbsorb && c === CHARCODE_FORWARD_SLASH) { - nextChar = inp.charAt(parserInput.i + 1); - if (nextChar === '/') { - comment = { index: parserInput.i, isLineComment: true }; - var nextNewLine = inp.indexOf('\n', parserInput.i + 2); - if (nextNewLine < 0) { - nextNewLine = endIndex; - } - parserInput.i = nextNewLine; - comment.text = inp.substr(comment.index, parserInput.i - comment.index); - parserInput.commentStore.push(comment); - continue; - } - else if (nextChar === '*') { - var nextStarSlash = inp.indexOf('*/', parserInput.i + 2); - if (nextStarSlash >= 0) { - comment = { - index: parserInput.i, - text: inp.substr(parserInput.i, nextStarSlash + 2 - parserInput.i), - isLineComment: false - }; - parserInput.i += comment.text.length - 1; - parserInput.commentStore.push(comment); - continue; - } - } - break; - } - if ((c !== CHARCODE_SPACE) && (c !== CHARCODE_LF) && (c !== CHARCODE_TAB) && (c !== CHARCODE_CR)) { - break; - } - } - current = current.slice(length + parserInput.i - mem + curr); - currentPos = parserInput.i; - if (!current.length) { - if (j < chunks.length - 1) { - current = chunks[++j]; - skipWhitespace(0); // skip space at the beginning of a chunk - return true; // things changed - } - parserInput.finished = true; - } - return oldi !== parserInput.i || oldj !== j; - } - parserInput.save = function () { - currentPos = parserInput.i; - saveStack.push({ current: current, i: parserInput.i, j: j }); - }; - parserInput.restore = function (possibleErrorMessage) { - if (parserInput.i > furthest || (parserInput.i === furthest && possibleErrorMessage && !furthestPossibleErrorMessage)) { - furthest = parserInput.i; - furthestPossibleErrorMessage = possibleErrorMessage; - } - var state = saveStack.pop(); - current = state.current; - currentPos = parserInput.i = state.i; - j = state.j; - }; - parserInput.forget = function () { - saveStack.pop(); - }; - parserInput.isWhitespace = function (offset) { - var pos = parserInput.i + (offset || 0); - var code = input.charCodeAt(pos); - return (code === CHARCODE_SPACE || code === CHARCODE_CR || code === CHARCODE_TAB || code === CHARCODE_LF); - }; - // Specialization of $(tok) - parserInput.$re = function (tok) { - if (parserInput.i > currentPos) { - current = current.slice(parserInput.i - currentPos); - currentPos = parserInput.i; - } - var m = tok.exec(current); - if (!m) { - return null; - } - skipWhitespace(m[0].length); - if (typeof m === 'string') { - return m; - } - return m.length === 1 ? m[0] : m; - }; - parserInput.$char = function (tok) { - if (input.charAt(parserInput.i) !== tok) { - return null; - } - skipWhitespace(1); - return tok; - }; - parserInput.$str = function (tok) { - var tokLength = tok.length; - // https://jsperf.com/string-startswith/21 - for (var i = 0; i < tokLength; i++) { - if (input.charAt(parserInput.i + i) !== tok.charAt(i)) { - return null; - } - } - skipWhitespace(tokLength); - return tok; - }; - parserInput.$quoted = function (loc) { - var pos = loc || parserInput.i; - var startChar = input.charAt(pos); - if (startChar !== '\'' && startChar !== '"') { - return; - } - var length = input.length; - var currentPosition = pos; - for (var i = 1; i + currentPosition < length; i++) { - var nextChar = input.charAt(i + currentPosition); - switch (nextChar) { - case '\\': - i++; - continue; - case '\r': - case '\n': - break; - case startChar: - var str = input.substr(currentPosition, i + 1); - if (!loc && loc !== 0) { - skipWhitespace(i + 1); - return str; - } - return [startChar, str]; - } - } - return null; - }; - /** - * Permissive parsing. Ignores everything except matching {} [] () and quotes - * until matching token (outside of blocks) - */ - parserInput.$parseUntil = function (tok) { - var quote = ''; - var returnVal = null; - var inComment = false; - var blockDepth = 0; - var blockStack = []; - var parseGroups = []; - var length = input.length; - var startPos = parserInput.i; - var lastPos = parserInput.i; - var i = parserInput.i; - var loop = true; - var testChar; - if (typeof tok === 'string') { - testChar = function (char) { return char === tok; }; - } - else { - testChar = function (char) { return tok.test(char); }; - } - do { - var nextChar = input.charAt(i); - if (blockDepth === 0 && testChar(nextChar)) { - returnVal = input.substr(lastPos, i - lastPos); - if (returnVal) { - parseGroups.push(returnVal); - } - else { - parseGroups.push(' '); - } - returnVal = parseGroups; - skipWhitespace(i - startPos); - loop = false; - } - else { - if (inComment) { - if (nextChar === '*' && - input.charAt(i + 1) === '/') { - i++; - blockDepth--; - inComment = false; - } - i++; - continue; - } - switch (nextChar) { - case '\\': - i++; - nextChar = input.charAt(i); - parseGroups.push(input.substr(lastPos, i - lastPos + 1)); - lastPos = i + 1; - break; - case '/': - if (input.charAt(i + 1) === '*') { - i++; - inComment = true; - blockDepth++; - } - break; - case '\'': - case '"': - quote = parserInput.$quoted(i); - if (quote) { - parseGroups.push(input.substr(lastPos, i - lastPos), quote); - i += quote[1].length - 1; - lastPos = i + 1; - } - else { - skipWhitespace(i - startPos); - returnVal = nextChar; - loop = false; - } - break; - case '{': - blockStack.push('}'); - blockDepth++; - break; - case '(': - blockStack.push(')'); - blockDepth++; - break; - case '[': - blockStack.push(']'); - blockDepth++; - break; - case '}': - case ')': - case ']': - var expected = blockStack.pop(); - if (nextChar === expected) { - blockDepth--; - } - else { - // move the parser to the error and return expected - skipWhitespace(i - startPos); - returnVal = expected; - loop = false; - } - } - i++; - if (i > length) { - loop = false; - } - } - } while (loop); - return returnVal ? returnVal : null; - }; - parserInput.autoCommentAbsorb = true; - parserInput.commentStore = []; - parserInput.finished = false; - // Same as $(), but don't change the state of the parser, - // just return the match. - parserInput.peek = function (tok) { - if (typeof tok === 'string') { - // https://jsperf.com/string-startswith/21 - for (var i = 0; i < tok.length; i++) { - if (input.charAt(parserInput.i + i) !== tok.charAt(i)) { - return false; - } - } - return true; - } - else { - return tok.test(current); - } - }; - // Specialization of peek() - // TODO remove or change some currentChar calls to peekChar - parserInput.peekChar = function (tok) { return input.charAt(parserInput.i) === tok; }; - parserInput.currentChar = function () { return input.charAt(parserInput.i); }; - parserInput.prevChar = function () { return input.charAt(parserInput.i - 1); }; - parserInput.getInput = function () { return input; }; - parserInput.peekNotNumeric = function () { - var c = input.charCodeAt(parserInput.i); - // Is the first char of the dimension 0-9, '.', '+' or '-' - return (c > CHARCODE_9 || c < CHARCODE_PLUS) || c === CHARCODE_FORWARD_SLASH || c === CHARCODE_COMMA; - }; - parserInput.start = function (str, chunkInput, failFunction) { - input = str; - parserInput.i = j = currentPos = furthest = 0; - // chunking apparently makes things quicker (but my tests indicate - // it might actually make things slower in node at least) - // and it is a non-perfect parse - it can't recognise - // unquoted urls, meaning it can't distinguish comments - // meaning comments with quotes or {}() in them get 'counted' - // and then lead to parse errors. - // In addition if the chunking chunks in the wrong place we might - // not be able to parse a parser statement in one go - // this is officially deprecated but can be switched on via an option - // in the case it causes too much performance issues. - if (chunkInput) { - chunks = chunker(str, failFunction); - } - else { - chunks = [str]; - } - current = chunks[0]; - skipWhitespace(0); - }; - parserInput.end = function () { - var message; - var isFinished = parserInput.i >= input.length; - if (parserInput.i < furthest) { - message = furthestPossibleErrorMessage; - parserInput.i = furthest; - } - return { - isFinished: isFinished, - furthest: parserInput.i, - furthestPossibleErrorMessage: message, - furthestReachedEnd: parserInput.i >= input.length - 1, - furthestChar: input[parserInput.i] - }; - }; - return parserInput; - }); + var getParserInput = (function () { + var // Less input string + input; + var // current chunk + j; + var // holds state for backtracking + saveStack = []; + var // furthest index the parser has gone to + furthest; + var // if this is furthest we got to, this is the probably cause + furthestPossibleErrorMessage; + var // chunkified input + chunks; + var // current chunk + current; + var // index of current chunk, in `input` + currentPos; + var parserInput = {}; + var CHARCODE_SPACE = 32; + var CHARCODE_TAB = 9; + var CHARCODE_LF = 10; + var CHARCODE_CR = 13; + var CHARCODE_PLUS = 43; + var CHARCODE_COMMA = 44; + var CHARCODE_FORWARD_SLASH = 47; + var CHARCODE_9 = 57; + function skipWhitespace(length) { + var oldi = parserInput.i; + var oldj = j; + var curr = parserInput.i - currentPos; + var endIndex = parserInput.i + current.length - curr; + var mem = (parserInput.i += length); + var inp = input; + var c; + var nextChar; + var comment; + for (; parserInput.i < endIndex; parserInput.i++) { + c = inp.charCodeAt(parserInput.i); + if (parserInput.autoCommentAbsorb && c === CHARCODE_FORWARD_SLASH) { + nextChar = inp.charAt(parserInput.i + 1); + if (nextChar === '/') { + comment = { index: parserInput.i, isLineComment: true }; + var nextNewLine = inp.indexOf('\n', parserInput.i + 2); + if (nextNewLine < 0) { + nextNewLine = endIndex; + } + parserInput.i = nextNewLine; + comment.text = inp.substr(comment.index, parserInput.i - comment.index); + parserInput.commentStore.push(comment); + continue; + } + else if (nextChar === '*') { + var nextStarSlash = inp.indexOf('*/', parserInput.i + 2); + if (nextStarSlash >= 0) { + comment = { + index: parserInput.i, + text: inp.substr(parserInput.i, nextStarSlash + 2 - parserInput.i), + isLineComment: false + }; + parserInput.i += comment.text.length - 1; + parserInput.commentStore.push(comment); + continue; + } + } + break; + } + if ((c !== CHARCODE_SPACE) && (c !== CHARCODE_LF) && (c !== CHARCODE_TAB) && (c !== CHARCODE_CR)) { + break; + } + } + current = current.slice(length + parserInput.i - mem + curr); + currentPos = parserInput.i; + if (!current.length) { + if (j < chunks.length - 1) { + current = chunks[++j]; + skipWhitespace(0); // skip space at the beginning of a chunk + return true; // things changed + } + parserInput.finished = true; + } + return oldi !== parserInput.i || oldj !== j; + } + parserInput.save = function () { + currentPos = parserInput.i; + saveStack.push({ current: current, i: parserInput.i, j: j }); + }; + parserInput.restore = function (possibleErrorMessage) { + if (parserInput.i > furthest || (parserInput.i === furthest && possibleErrorMessage && !furthestPossibleErrorMessage)) { + furthest = parserInput.i; + furthestPossibleErrorMessage = possibleErrorMessage; + } + var state = saveStack.pop(); + current = state.current; + currentPos = parserInput.i = state.i; + j = state.j; + }; + parserInput.forget = function () { + saveStack.pop(); + }; + parserInput.isWhitespace = function (offset) { + var pos = parserInput.i + (offset || 0); + var code = input.charCodeAt(pos); + return (code === CHARCODE_SPACE || code === CHARCODE_CR || code === CHARCODE_TAB || code === CHARCODE_LF); + }; + // Specialization of $(tok) + parserInput.$re = function (tok) { + if (parserInput.i > currentPos) { + current = current.slice(parserInput.i - currentPos); + currentPos = parserInput.i; + } + var m = tok.exec(current); + if (!m) { + return null; + } + skipWhitespace(m[0].length); + if (typeof m === 'string') { + return m; + } + return m.length === 1 ? m[0] : m; + }; + parserInput.$char = function (tok) { + if (input.charAt(parserInput.i) !== tok) { + return null; + } + skipWhitespace(1); + return tok; + }; + parserInput.$str = function (tok) { + var tokLength = tok.length; + // https://jsperf.com/string-startswith/21 + for (var i = 0; i < tokLength; i++) { + if (input.charAt(parserInput.i + i) !== tok.charAt(i)) { + return null; + } + } + skipWhitespace(tokLength); + return tok; + }; + parserInput.$quoted = function (loc) { + var pos = loc || parserInput.i; + var startChar = input.charAt(pos); + if (startChar !== '\'' && startChar !== '"') { + return; + } + var length = input.length; + var currentPosition = pos; + for (var i = 1; i + currentPosition < length; i++) { + var nextChar = input.charAt(i + currentPosition); + switch (nextChar) { + case '\\': + i++; + continue; + case '\r': + case '\n': + break; + case startChar: + var str = input.substr(currentPosition, i + 1); + if (!loc && loc !== 0) { + skipWhitespace(i + 1); + return str; + } + return [startChar, str]; + } + } + return null; + }; + /** + * Permissive parsing. Ignores everything except matching {} [] () and quotes + * until matching token (outside of blocks) + */ + parserInput.$parseUntil = function (tok) { + var quote = ''; + var returnVal = null; + var inComment = false; + var blockDepth = 0; + var blockStack = []; + var parseGroups = []; + var length = input.length; + var startPos = parserInput.i; + var lastPos = parserInput.i; + var i = parserInput.i; + var loop = true; + var testChar; + if (typeof tok === 'string') { + testChar = function (char) { return char === tok; }; + } + else { + testChar = function (char) { return tok.test(char); }; + } + do { + var nextChar = input.charAt(i); + if (blockDepth === 0 && testChar(nextChar)) { + returnVal = input.substr(lastPos, i - lastPos); + if (returnVal) { + parseGroups.push(returnVal); + } + else { + parseGroups.push(' '); + } + returnVal = parseGroups; + skipWhitespace(i - startPos); + loop = false; + } + else { + if (inComment) { + if (nextChar === '*' && + input.charAt(i + 1) === '/') { + i++; + blockDepth--; + inComment = false; + } + i++; + continue; + } + switch (nextChar) { + case '\\': + i++; + nextChar = input.charAt(i); + parseGroups.push(input.substr(lastPos, i - lastPos + 1)); + lastPos = i + 1; + break; + case '/': + if (input.charAt(i + 1) === '*') { + i++; + inComment = true; + blockDepth++; + } + break; + case '\'': + case '"': + quote = parserInput.$quoted(i); + if (quote) { + parseGroups.push(input.substr(lastPos, i - lastPos), quote); + i += quote[1].length - 1; + lastPos = i + 1; + } + else { + skipWhitespace(i - startPos); + returnVal = nextChar; + loop = false; + } + break; + case '{': + blockStack.push('}'); + blockDepth++; + break; + case '(': + blockStack.push(')'); + blockDepth++; + break; + case '[': + blockStack.push(']'); + blockDepth++; + break; + case '}': + case ')': + case ']': + var expected = blockStack.pop(); + if (nextChar === expected) { + blockDepth--; + } + else { + // move the parser to the error and return expected + skipWhitespace(i - startPos); + returnVal = expected; + loop = false; + } + } + i++; + if (i > length) { + loop = false; + } + } + } while (loop); + return returnVal ? returnVal : null; + }; + parserInput.autoCommentAbsorb = true; + parserInput.commentStore = []; + parserInput.finished = false; + // Same as $(), but don't change the state of the parser, + // just return the match. + parserInput.peek = function (tok) { + if (typeof tok === 'string') { + // https://jsperf.com/string-startswith/21 + for (var i = 0; i < tok.length; i++) { + if (input.charAt(parserInput.i + i) !== tok.charAt(i)) { + return false; + } + } + return true; + } + else { + return tok.test(current); + } + }; + // Specialization of peek() + // TODO remove or change some currentChar calls to peekChar + parserInput.peekChar = function (tok) { return input.charAt(parserInput.i) === tok; }; + parserInput.currentChar = function () { return input.charAt(parserInput.i); }; + parserInput.prevChar = function () { return input.charAt(parserInput.i - 1); }; + parserInput.getInput = function () { return input; }; + parserInput.peekNotNumeric = function () { + var c = input.charCodeAt(parserInput.i); + // Is the first char of the dimension 0-9, '.', '+' or '-' + return (c > CHARCODE_9 || c < CHARCODE_PLUS) || c === CHARCODE_FORWARD_SLASH || c === CHARCODE_COMMA; + }; + parserInput.start = function (str, chunkInput, failFunction) { + input = str; + parserInput.i = j = currentPos = furthest = 0; + // chunking apparently makes things quicker (but my tests indicate + // it might actually make things slower in node at least) + // and it is a non-perfect parse - it can't recognise + // unquoted urls, meaning it can't distinguish comments + // meaning comments with quotes or {}() in them get 'counted' + // and then lead to parse errors. + // In addition if the chunking chunks in the wrong place we might + // not be able to parse a parser statement in one go + // this is officially deprecated but can be switched on via an option + // in the case it causes too much performance issues. + if (chunkInput) { + chunks = chunker(str, failFunction); + } + else { + chunks = [str]; + } + current = chunks[0]; + skipWhitespace(0); + }; + parserInput.end = function () { + var message; + var isFinished = parserInput.i >= input.length; + if (parserInput.i < furthest) { + message = furthestPossibleErrorMessage; + parserInput.i = furthest; + } + return { + isFinished: isFinished, + furthest: parserInput.i, + furthestPossibleErrorMessage: message, + furthestReachedEnd: parserInput.i >= input.length - 1, + furthestChar: input[parserInput.i] + }; + }; + return parserInput; + }); - // - // less.js - parser - // - // A relatively straight-forward predictive parser. - // There is no tokenization/lexing stage, the input is parsed - // in one sweep. - // - // To make the parser fast enough to run in the browser, several - // optimization had to be made: - // - // - Matching and slicing on a huge input is often cause of slowdowns. - // The solution is to chunkify the input into smaller strings. - // The chunks are stored in the `chunks` var, - // `j` holds the current chunk index, and `currentPos` holds - // the index of the current chunk in relation to `input`. - // This gives us an almost 4x speed-up. - // - // - In many cases, we don't need to match individual tokens; - // for example, if a value doesn't hold any variables, operations - // or dynamic references, the parser can effectively 'skip' it, - // treating it as a literal. - // An example would be '1px solid #000' - which evaluates to itself, - // we don't need to know what the individual components are. - // The drawback, of course is that you don't get the benefits of - // syntax-checking on the CSS. This gives us a 50% speed-up in the parser, - // and a smaller speed-up in the code-gen. - // - // - // Token matching is done with the `$` function, which either takes - // a terminal string or regexp, or a non-terminal function to call. - // It also takes care of moving all the indices forwards. - // - var Parser = function Parser(context, imports, fileInfo) { - var parsers; - var parserInput = getParserInput(); - function error(msg, type) { - throw new LessError({ - index: parserInput.i, - filename: fileInfo.filename, - type: type || 'Syntax', - message: msg - }, imports); - } - function expect(arg, msg) { - // some older browsers return typeof 'function' for RegExp - var result = (arg instanceof Function) ? arg.call(parsers) : parserInput.$re(arg); - if (result) { - return result; - } - error(msg || (typeof arg === 'string' - ? "expected '" + arg + "' got '" + parserInput.currentChar() + "'" - : 'unexpected token')); - } - // Specialization of expect() - function expectChar(arg, msg) { - if (parserInput.$char(arg)) { - return arg; - } - error(msg || "expected '" + arg + "' got '" + parserInput.currentChar() + "'"); - } - function getDebugInfo(index) { - var filename = fileInfo.filename; - return { - lineNumber: getLocation(index, parserInput.getInput()).line + 1, - fileName: filename - }; - } - /** - * Used after initial parsing to create nodes on the fly - * - * @param {String} str - string to parse - * @param {Array} parseList - array of parsers to run input through e.g. ["value", "important"] - * @param {Number} currentIndex - start number to begin indexing - * @param {Object} fileInfo - fileInfo to attach to created nodes - */ - function parseNode(str, parseList, currentIndex, fileInfo, callback) { - var result; - var returnNodes = []; - var parser = parserInput; - try { - parser.start(str, false, function fail(msg, index) { - callback({ - message: msg, - index: index + currentIndex - }); - }); - for (var x = 0, p = void 0, i = void 0; (p = parseList[x]); x++) { - i = parser.i; - result = parsers[p](); - if (result) { - try { - result._index = i + currentIndex; - result._fileInfo = fileInfo; - } - catch (e) { } - returnNodes.push(result); - } - else { - returnNodes.push(null); - } - } - var endInfo = parser.end(); - if (endInfo.isFinished) { - callback(null, returnNodes); - } - else { - callback(true, null); - } - } - catch (e) { - throw new LessError({ - index: e.index + currentIndex, - message: e.message - }, imports, fileInfo.filename); - } - } - // - // The Parser - // - return { - parserInput: parserInput, - imports: imports, - fileInfo: fileInfo, - parseNode: parseNode, - // - // Parse an input string into an abstract syntax tree, - // @param str A string containing 'less' markup - // @param callback call `callback` when done. - // @param [additionalData] An optional map which can contains vars - a map (key, value) of variables to apply - // - parse: function (str, callback, additionalData) { - var root; - var error = null; - var globalVars; - var modifyVars; - var ignored; - var preText = ''; - globalVars = (additionalData && additionalData.globalVars) ? Parser.serializeVars(additionalData.globalVars) + "\n" : ''; - modifyVars = (additionalData && additionalData.modifyVars) ? "\n" + Parser.serializeVars(additionalData.modifyVars) : ''; - if (context.pluginManager) { - var preProcessors = context.pluginManager.getPreProcessors(); - for (var i = 0; i < preProcessors.length; i++) { - str = preProcessors[i].process(str, { context: context, imports: imports, fileInfo: fileInfo }); - } - } - if (globalVars || (additionalData && additionalData.banner)) { - preText = ((additionalData && additionalData.banner) ? additionalData.banner : '') + globalVars; - ignored = imports.contentsIgnoredChars; - ignored[fileInfo.filename] = ignored[fileInfo.filename] || 0; - ignored[fileInfo.filename] += preText.length; - } - str = str.replace(/\r\n?/g, '\n'); - // Remove potential UTF Byte Order Mark - str = preText + str.replace(/^\uFEFF/, '') + modifyVars; - imports.contents[fileInfo.filename] = str; - // Start with the primary rule. - // The whole syntax tree is held under a Ruleset node, - // with the `root` property set to true, so no `{}` are - // output. The callback is called when the input is parsed. - try { - parserInput.start(str, context.chunkInput, function fail(msg, index) { - throw new LessError({ - index: index, - type: 'Parse', - message: msg, - filename: fileInfo.filename - }, imports); - }); - tree.Node.prototype.parse = this; - root = new tree.Ruleset(null, this.parsers.primary()); - tree.Node.prototype.rootNode = root; - root.root = true; - root.firstRoot = true; - root.functionRegistry = functionRegistry.inherit(); - } - catch (e) { - return callback(new LessError(e, imports, fileInfo.filename)); - } - // If `i` is smaller than the `input.length - 1`, - // it means the parser wasn't able to parse the whole - // string, so we've got a parsing error. - // - // We try to extract a \n delimited string, - // showing the line where the parse error occurred. - // We split it up into two parts (the part which parsed, - // and the part which didn't), so we can color them differently. - var endInfo = parserInput.end(); - if (!endInfo.isFinished) { - var message = endInfo.furthestPossibleErrorMessage; - if (!message) { - message = 'Unrecognised input'; - if (endInfo.furthestChar === '}') { - message += '. Possibly missing opening \'{\''; - } - else if (endInfo.furthestChar === ')') { - message += '. Possibly missing opening \'(\''; - } - else if (endInfo.furthestReachedEnd) { - message += '. Possibly missing something'; - } - } - error = new LessError({ - type: 'Parse', - message: message, - index: endInfo.furthest, - filename: fileInfo.filename - }, imports); - } - var finish = function (e) { - e = error || e || imports.error; - if (e) { - if (!(e instanceof LessError)) { - e = new LessError(e, imports, fileInfo.filename); - } - return callback(e); - } - else { - return callback(null, root); - } - }; - if (context.processImports !== false) { - new visitors.ImportVisitor(imports, finish) - .run(root); - } - else { - return finish(); - } - }, - // - // Here in, the parsing rules/functions - // - // The basic structure of the syntax tree generated is as follows: - // - // Ruleset -> Declaration -> Value -> Expression -> Entity - // - // Here's some Less code: - // - // .class { - // color: #fff; - // border: 1px solid #000; - // width: @w + 4px; - // > .child {...} - // } - // - // And here's what the parse tree might look like: - // - // Ruleset (Selector '.class', [ - // Declaration ("color", Value ([Expression [Color #fff]])) - // Declaration ("border", Value ([Expression [Dimension 1px][Keyword "solid"][Color #000]])) - // Declaration ("width", Value ([Expression [Operation " + " [Variable "@w"][Dimension 4px]]])) - // Ruleset (Selector [Element '>', '.child'], [...]) - // ]) - // - // In general, most rules will try to parse a token with the `$re()` function, and if the return - // value is truly, will return a new node, of the relevant type. Sometimes, we need to check - // first, before parsing, that's when we use `peek()`. - // - parsers: parsers = { - // - // The `primary` rule is the *entry* and *exit* point of the parser. - // The rules here can appear at any level of the parse tree. - // - // The recursive nature of the grammar is an interplay between the `block` - // rule, which represents `{ ... }`, the `ruleset` rule, and this `primary` rule, - // as represented by this simplified grammar: - // - // primary → (ruleset | declaration)+ - // ruleset → selector+ block - // block → '{' primary '}' - // - // Only at one point is the primary rule not called from the - // block rule: at the root level. - // - primary: function () { - var mixin = this.mixin; - var root = []; - var node; - while (true) { - while (true) { - node = this.comment(); - if (!node) { - break; - } - root.push(node); - } - // always process comments before deciding if finished - if (parserInput.finished) { - break; - } - if (parserInput.peek('}')) { - break; - } - node = this.extendRule(); - if (node) { - root = root.concat(node); - continue; - } - node = mixin.definition() || this.declaration() || mixin.call(false, false) || - this.ruleset() || this.variableCall() || this.entities.call() || this.atrule(); - if (node) { - root.push(node); - } - else { - var foundSemiColon = false; - while (parserInput.$char(';')) { - foundSemiColon = true; - } - if (!foundSemiColon) { - break; - } - } - } - return root; - }, - // comments are collected by the main parsing mechanism and then assigned to nodes - // where the current structure allows it - comment: function () { - if (parserInput.commentStore.length) { - var comment = parserInput.commentStore.shift(); - return new (tree.Comment)(comment.text, comment.isLineComment, comment.index, fileInfo); - } - }, - // - // Entities are tokens which can be found inside an Expression - // - entities: { - mixinLookup: function () { - return parsers.mixin.call(true, true); - }, - // - // A string, which supports escaping " and ' - // - // "milky way" 'he\'s the one!' - // - quoted: function (forceEscaped) { - var str; - var index = parserInput.i; - var isEscaped = false; - parserInput.save(); - if (parserInput.$char('~')) { - isEscaped = true; - } - else if (forceEscaped) { - parserInput.restore(); - return; - } - str = parserInput.$quoted(); - if (!str) { - parserInput.restore(); - return; - } - parserInput.forget(); - return new (tree.Quoted)(str.charAt(0), str.substr(1, str.length - 2), isEscaped, index, fileInfo); - }, - // - // A catch-all word, such as: - // - // black border-collapse - // - keyword: function () { - var k = parserInput.$char('%') || parserInput.$re(/^\[?(?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+\]?/); - if (k) { - return tree.Color.fromKeyword(k) || new (tree.Keyword)(k); - } - }, - // - // A function call - // - // rgb(255, 0, 255) - // - // The arguments are parsed with the `entities.arguments` parser. - // - call: function () { - var name; - var args; - var func; - var index = parserInput.i; - // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18 - if (parserInput.peek(/^url\(/i)) { - return; - } - parserInput.save(); - name = parserInput.$re(/^([\w-]+|%|progid:[\w\.]+)\(/); - if (!name) { - parserInput.forget(); - return; - } - name = name[1]; - func = this.customFuncCall(name); - if (func) { - args = func.parse(); - if (args && func.stop) { - parserInput.forget(); - return args; - } - } - args = this.arguments(args); - if (!parserInput.$char(')')) { - parserInput.restore('Could not parse call arguments or missing \')\''); - return; - } - parserInput.forget(); - return new (tree.Call)(name, args, index, fileInfo); - }, - // - // Parsing rules for functions with non-standard args, e.g.: - // - // boolean(not(2 > 1)) - // - // This is a quick prototype, to be modified/improved when - // more custom-parsed funcs come (e.g. `selector(...)`) - // - customFuncCall: function (name) { - /* Ideally the table is to be moved out of here for faster perf., - but it's quite tricky since it relies on all these `parsers` - and `expect` available only here */ - return { - alpha: f(parsers.ieAlpha, true), - boolean: f(condition), - 'if': f(condition) - }[name.toLowerCase()]; - function f(parse, stop) { - return { - parse: parse, - stop: stop // when true - stop after parse() and return its result, - // otherwise continue for plain args - }; - } - function condition() { - return [expect(parsers.condition, 'expected condition')]; - } - }, - arguments: function (prevArgs) { - var argsComma = prevArgs || []; - var argsSemiColon = []; - var isSemiColonSeparated; - var value; - parserInput.save(); - while (true) { - if (prevArgs) { - prevArgs = false; - } - else { - value = parsers.detachedRuleset() || this.assignment() || parsers.expression(); - if (!value) { - break; - } - if (value.value && value.value.length == 1) { - value = value.value[0]; - } - argsComma.push(value); - } - if (parserInput.$char(',')) { - continue; - } - if (parserInput.$char(';') || isSemiColonSeparated) { - isSemiColonSeparated = true; - value = (argsComma.length < 1) ? argsComma[0] - : new tree.Value(argsComma); - argsSemiColon.push(value); - argsComma = []; - } - } - parserInput.forget(); - return isSemiColonSeparated ? argsSemiColon : argsComma; - }, - literal: function () { - return this.dimension() || - this.color() || - this.quoted() || - this.unicodeDescriptor(); - }, - // Assignments are argument entities for calls. - // They are present in ie filter properties as shown below. - // - // filter: progid:DXImageTransform.Microsoft.Alpha( *opacity=50* ) - // - assignment: function () { - var key; - var value; - parserInput.save(); - key = parserInput.$re(/^\w+(?=\s?=)/i); - if (!key) { - parserInput.restore(); - return; - } - if (!parserInput.$char('=')) { - parserInput.restore(); - return; - } - value = parsers.entity(); - if (value) { - parserInput.forget(); - return new (tree.Assignment)(key, value); - } - else { - parserInput.restore(); - } - }, - // - // Parse url() tokens - // - // We use a specific rule for urls, because they don't really behave like - // standard function calls. The difference is that the argument doesn't have - // to be enclosed within a string, so it can't be parsed as an Expression. - // - url: function () { - var value; - var index = parserInput.i; - parserInput.autoCommentAbsorb = false; - if (!parserInput.$str('url(')) { - parserInput.autoCommentAbsorb = true; - return; - } - value = this.quoted() || this.variable() || this.property() || - parserInput.$re(/^(?:(?:\\[\(\)'"])|[^\(\)'"])+/) || ''; - parserInput.autoCommentAbsorb = true; - expectChar(')'); - return new (tree.URL)((value.value != null || - value instanceof tree.Variable || - value instanceof tree.Property) ? - value : new (tree.Anonymous)(value, index), index, fileInfo); - }, - // - // A Variable entity, such as `@fink`, in - // - // width: @fink + 2px - // - // We use a different parser for variable definitions, - // see `parsers.variable`. - // - variable: function () { - var ch; - var name; - var index = parserInput.i; - parserInput.save(); - if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^@@?[\w-]+/))) { - ch = parserInput.currentChar(); - if (ch === '(' || ch === '[' && !parserInput.prevChar().match(/^\s/)) { - // this may be a VariableCall lookup - var result = parsers.variableCall(name); - if (result) { - parserInput.forget(); - return result; - } - } - parserInput.forget(); - return new (tree.Variable)(name, index, fileInfo); - } - parserInput.restore(); - }, - // A variable entity using the protective {} e.g. @{var} - variableCurly: function () { - var curly; - var index = parserInput.i; - if (parserInput.currentChar() === '@' && (curly = parserInput.$re(/^@\{([\w-]+)\}/))) { - return new (tree.Variable)("@" + curly[1], index, fileInfo); - } - }, - // - // A Property accessor, such as `$color`, in - // - // background-color: $color - // - property: function () { - var name; - var index = parserInput.i; - if (parserInput.currentChar() === '$' && (name = parserInput.$re(/^\$[\w-]+/))) { - return new (tree.Property)(name, index, fileInfo); - } - }, - // A property entity useing the protective {} e.g. ${prop} - propertyCurly: function () { - var curly; - var index = parserInput.i; - if (parserInput.currentChar() === '$' && (curly = parserInput.$re(/^\$\{([\w-]+)\}/))) { - return new (tree.Property)("$" + curly[1], index, fileInfo); - } - }, - // - // A Hexadecimal color - // - // #4F3C2F - // - // `rgb` and `hsl` colors are parsed through the `entities.call` parser. - // - color: function () { - var rgb; - parserInput.save(); - if (parserInput.currentChar() === '#' && (rgb = parserInput.$re(/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})([\w.#\[])?/))) { - if (!rgb[2]) { - parserInput.forget(); - return new (tree.Color)(rgb[1], undefined, rgb[0]); - } - } - parserInput.restore(); - }, - colorKeyword: function () { - parserInput.save(); - var autoCommentAbsorb = parserInput.autoCommentAbsorb; - parserInput.autoCommentAbsorb = false; - var k = parserInput.$re(/^[_A-Za-z-][_A-Za-z0-9-]+/); - parserInput.autoCommentAbsorb = autoCommentAbsorb; - if (!k) { - parserInput.forget(); - return; - } - parserInput.restore(); - var color = tree.Color.fromKeyword(k); - if (color) { - parserInput.$str(k); - return color; - } - }, - // - // A Dimension, that is, a number and a unit - // - // 0.5em 95% - // - dimension: function () { - if (parserInput.peekNotNumeric()) { - return; - } - var value = parserInput.$re(/^([+-]?\d*\.?\d+)(%|[a-z_]+)?/i); - if (value) { - return new (tree.Dimension)(value[1], value[2]); - } - }, - // - // A unicode descriptor, as is used in unicode-range - // - // U+0?? or U+00A1-00A9 - // - unicodeDescriptor: function () { - var ud; - ud = parserInput.$re(/^U\+[0-9a-fA-F?]+(\-[0-9a-fA-F?]+)?/); - if (ud) { - return new (tree.UnicodeDescriptor)(ud[0]); - } - }, - // - // JavaScript code to be evaluated - // - // `window.location.href` - // - javascript: function () { - var js; - var index = parserInput.i; - parserInput.save(); - var escape = parserInput.$char('~'); - var jsQuote = parserInput.$char('`'); - if (!jsQuote) { - parserInput.restore(); - return; - } - js = parserInput.$re(/^[^`]*`/); - if (js) { - parserInput.forget(); - return new (tree.JavaScript)(js.substr(0, js.length - 1), Boolean(escape), index, fileInfo); - } - parserInput.restore('invalid javascript definition'); - } - }, - // - // The variable part of a variable definition. Used in the `rule` parser - // - // @fink: - // - variable: function () { - var name; - if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^(@[\w-]+)\s*:/))) { - return name[1]; - } - }, - // - // Call a variable value to retrieve a detached ruleset - // or a value from a detached ruleset's rules. - // - // @fink(); - // @fink; - // color: @fink[@color]; - // - variableCall: function (parsedName) { - var lookups; - var i = parserInput.i; - var inValue = !!parsedName; - var name = parsedName; - parserInput.save(); - if (name || (parserInput.currentChar() === '@' - && (name = parserInput.$re(/^(@[\w-]+)(\(\s*\))?/)))) { - lookups = this.mixin.ruleLookups(); - if (!lookups && ((inValue && parserInput.$str('()') !== '()') || (name[2] !== '()'))) { - parserInput.restore('Missing \'[...]\' lookup in variable call'); - return; - } - if (!inValue) { - name = name[1]; - } - var call = new tree.VariableCall(name, i, fileInfo); - if (!inValue && parsers.end()) { - parserInput.forget(); - return call; - } - else { - parserInput.forget(); - return new tree.NamespaceValue(call, lookups, i, fileInfo); - } - } - parserInput.restore(); - }, - // - // extend syntax - used to extend selectors - // - extend: function (isRule) { - var elements; - var e; - var index = parserInput.i; - var option; - var extendList; - var extend; - if (!parserInput.$str(isRule ? '&:extend(' : ':extend(')) { - return; - } - do { - option = null; - elements = null; - while (!(option = parserInput.$re(/^(all)(?=\s*(\)|,))/))) { - e = this.element(); - if (!e) { - break; - } - if (elements) { - elements.push(e); - } - else { - elements = [e]; - } - } - option = option && option[1]; - if (!elements) { - error('Missing target selector for :extend().'); - } - extend = new (tree.Extend)(new (tree.Selector)(elements), option, index, fileInfo); - if (extendList) { - extendList.push(extend); - } - else { - extendList = [extend]; - } - } while (parserInput.$char(',')); - expect(/^\)/); - if (isRule) { - expect(/^;/); - } - return extendList; - }, - // - // extendRule - used in a rule to extend all the parent selectors - // - extendRule: function () { - return this.extend(true); - }, - // - // Mixins - // - mixin: { - // - // A Mixin call, with an optional argument list - // - // #mixins > .square(#fff); - // #mixins.square(#fff); - // .rounded(4px, black); - // .button; - // - // We can lookup / return a value using the lookup syntax: - // - // color: #mixin.square(#fff)[@color]; - // - // The `while` loop is there because mixins can be - // namespaced, but we only support the child and descendant - // selector for now. - // - call: function (inValue, getLookup) { - var s = parserInput.currentChar(); - var important = false; - var lookups; - var index = parserInput.i; - var elements; - var args; - var hasParens; - if (s !== '.' && s !== '#') { - return; - } - parserInput.save(); // stop us absorbing part of an invalid selector - elements = this.elements(); - if (elements) { - if (parserInput.$char('(')) { - args = this.args(true).args; - expectChar(')'); - hasParens = true; - } - if (getLookup !== false) { - lookups = this.ruleLookups(); - } - if (getLookup === true && !lookups) { - parserInput.restore(); - return; - } - if (inValue && !lookups && !hasParens) { - // This isn't a valid in-value mixin call - parserInput.restore(); - return; - } - if (!inValue && parsers.important()) { - important = true; - } - if (inValue || parsers.end()) { - parserInput.forget(); - var mixin = new (tree.mixin.Call)(elements, args, index, fileInfo, !lookups && important); - if (lookups) { - return new tree.NamespaceValue(mixin, lookups); - } - else { - return mixin; - } - } - } - parserInput.restore(); - }, - /** - * Matching elements for mixins - * (Start with . or # and can have > ) - */ - elements: function () { - var elements; - var e; - var c; - var elem; - var elemIndex; - var re = /^[#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/; - while (true) { - elemIndex = parserInput.i; - e = parserInput.$re(re); - if (!e) { - break; - } - elem = new (tree.Element)(c, e, false, elemIndex, fileInfo); - if (elements) { - elements.push(elem); - } - else { - elements = [elem]; - } - c = parserInput.$char('>'); - } - return elements; - }, - args: function (isCall) { - var entities = parsers.entities; - var returner = { args: null, variadic: false }; - var expressions = []; - var argsSemiColon = []; - var argsComma = []; - var isSemiColonSeparated; - var expressionContainsNamed; - var name; - var nameLoop; - var value; - var arg; - var expand; - var hasSep = true; - parserInput.save(); - while (true) { - if (isCall) { - arg = parsers.detachedRuleset() || parsers.expression(); - } - else { - parserInput.commentStore.length = 0; - if (parserInput.$str('...')) { - returner.variadic = true; - if (parserInput.$char(';') && !isSemiColonSeparated) { - isSemiColonSeparated = true; - } - (isSemiColonSeparated ? argsSemiColon : argsComma) - .push({ variadic: true }); - break; - } - arg = entities.variable() || entities.property() || entities.literal() || entities.keyword() || this.call(true); - } - if (!arg || !hasSep) { - break; - } - nameLoop = null; - if (arg.throwAwayComments) { - arg.throwAwayComments(); - } - value = arg; - var val = null; - if (isCall) { - // Variable - if (arg.value && arg.value.length == 1) { - val = arg.value[0]; - } - } - else { - val = arg; - } - if (val && (val instanceof tree.Variable || val instanceof tree.Property)) { - if (parserInput.$char(':')) { - if (expressions.length > 0) { - if (isSemiColonSeparated) { - error('Cannot mix ; and , as delimiter types'); - } - expressionContainsNamed = true; - } - value = parsers.detachedRuleset() || parsers.expression(); - if (!value) { - if (isCall) { - error('could not understand value for named argument'); - } - else { - parserInput.restore(); - returner.args = []; - return returner; - } - } - nameLoop = (name = val.name); - } - else if (parserInput.$str('...')) { - if (!isCall) { - returner.variadic = true; - if (parserInput.$char(';') && !isSemiColonSeparated) { - isSemiColonSeparated = true; - } - (isSemiColonSeparated ? argsSemiColon : argsComma) - .push({ name: arg.name, variadic: true }); - break; - } - else { - expand = true; - } - } - else if (!isCall) { - name = nameLoop = val.name; - value = null; - } - } - if (value) { - expressions.push(value); - } - argsComma.push({ name: nameLoop, value: value, expand: expand }); - if (parserInput.$char(',')) { - hasSep = true; - continue; - } - hasSep = parserInput.$char(';') === ';'; - if (hasSep || isSemiColonSeparated) { - if (expressionContainsNamed) { - error('Cannot mix ; and , as delimiter types'); - } - isSemiColonSeparated = true; - if (expressions.length > 1) { - value = new (tree.Value)(expressions); - } - argsSemiColon.push({ name: name, value: value, expand: expand }); - name = null; - expressions = []; - expressionContainsNamed = false; - } - } - parserInput.forget(); - returner.args = isSemiColonSeparated ? argsSemiColon : argsComma; - return returner; - }, - // - // A Mixin definition, with a list of parameters - // - // .rounded (@radius: 2px, @color) { - // ... - // } - // - // Until we have a finer grained state-machine, we have to - // do a look-ahead, to make sure we don't have a mixin call. - // See the `rule` function for more information. - // - // We start by matching `.rounded (`, and then proceed on to - // the argument list, which has optional default values. - // We store the parameters in `params`, with a `value` key, - // if there is a value, such as in the case of `@radius`. - // - // Once we've got our params list, and a closing `)`, we parse - // the `{...}` block. - // - definition: function () { - var name; - var params = []; - var match; - var ruleset; - var cond; - var variadic = false; - if ((parserInput.currentChar() !== '.' && parserInput.currentChar() !== '#') || - parserInput.peek(/^[^{]*\}/)) { - return; - } - parserInput.save(); - match = parserInput.$re(/^([#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\s*\(/); - if (match) { - name = match[1]; - var argInfo = this.args(false); - params = argInfo.args; - variadic = argInfo.variadic; - // .mixincall("@{a}"); - // looks a bit like a mixin definition.. - // also - // .mixincall(@a: {rule: set;}); - // so we have to be nice and restore - if (!parserInput.$char(')')) { - parserInput.restore('Missing closing \')\''); - return; - } - parserInput.commentStore.length = 0; - if (parserInput.$str('when')) { // Guard - cond = expect(parsers.conditions, 'expected condition'); - } - ruleset = parsers.block(); - if (ruleset) { - parserInput.forget(); - return new (tree.mixin.Definition)(name, params, ruleset, cond, variadic); - } - else { - parserInput.restore(); - } - } - else { - parserInput.restore(); - } - }, - ruleLookups: function () { - var rule; - var lookups = []; - if (parserInput.currentChar() !== '[') { - return; - } - while (true) { - parserInput.save(); - rule = this.lookupValue(); - if (!rule && rule !== '') { - parserInput.restore(); - break; - } - lookups.push(rule); - parserInput.forget(); - } - if (lookups.length > 0) { - return lookups; - } - }, - lookupValue: function () { - parserInput.save(); - if (!parserInput.$char('[')) { - parserInput.restore(); - return; - } - var name = parserInput.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/); - if (!parserInput.$char(']')) { - parserInput.restore(); - return; - } - if (name || name === '') { - parserInput.forget(); - return name; - } - parserInput.restore(); - } - }, - // - // Entities are the smallest recognized token, - // and can be found inside a rule's value. - // - entity: function () { - var entities = this.entities; - return this.comment() || entities.literal() || entities.variable() || entities.url() || - entities.property() || entities.call() || entities.keyword() || this.mixin.call(true) || - entities.javascript(); - }, - // - // A Declaration terminator. Note that we use `peek()` to check for '}', - // because the `block` rule will be expecting it, but we still need to make sure - // it's there, if ';' was omitted. - // - end: function () { - return parserInput.$char(';') || parserInput.peek('}'); - }, - // - // IE's alpha function - // - // alpha(opacity=88) - // - ieAlpha: function () { - var value; - // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18 - if (!parserInput.$re(/^opacity=/i)) { - return; - } - value = parserInput.$re(/^\d+/); - if (!value) { - value = expect(parsers.entities.variable, 'Could not parse alpha'); - value = "@{" + value.name.slice(1) + "}"; - } - expectChar(')'); - return new tree.Quoted('', "alpha(opacity=" + value + ")"); - }, - // - // A Selector Element - // - // div - // + h1 - // #socks - // input[type="text"] - // - // Elements are the building blocks for Selectors, - // they are made out of a `Combinator` (see combinator rule), - // and an element name, such as a tag a class, or `*`. - // - element: function () { - var e; - var c; - var v; - var index = parserInput.i; - c = this.combinator(); - e = parserInput.$re(/^(?:\d+\.\d+|\d+)%/) || - parserInput.$re(/^(?:[.#]?|:*)(?:[\w-]|[^\x00-\x9f]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/) || - parserInput.$char('*') || parserInput.$char('&') || this.attribute() || - parserInput.$re(/^\([^&()@]+\)/) || parserInput.$re(/^[\.#:](?=@)/) || - this.entities.variableCurly(); - if (!e) { - parserInput.save(); - if (parserInput.$char('(')) { - if ((v = this.selector(false)) && parserInput.$char(')')) { - e = new (tree.Paren)(v); - parserInput.forget(); - } - else { - parserInput.restore('Missing closing \')\''); - } - } - else { - parserInput.forget(); - } - } - if (e) { - return new (tree.Element)(c, e, e instanceof tree.Variable, index, fileInfo); - } - }, - // - // Combinators combine elements together, in a Selector. - // - // Because our parser isn't white-space sensitive, special care - // has to be taken, when parsing the descendant combinator, ` `, - // as it's an empty space. We have to check the previous character - // in the input, to see if it's a ` ` character. More info on how - // we deal with this in *combinator.js*. - // - combinator: function () { - var c = parserInput.currentChar(); - if (c === '/') { - parserInput.save(); - var slashedCombinator = parserInput.$re(/^\/[a-z]+\//i); - if (slashedCombinator) { - parserInput.forget(); - return new (tree.Combinator)(slashedCombinator); - } - parserInput.restore(); - } - if (c === '>' || c === '+' || c === '~' || c === '|' || c === '^') { - parserInput.i++; - if (c === '^' && parserInput.currentChar() === '^') { - c = '^^'; - parserInput.i++; - } - while (parserInput.isWhitespace()) { - parserInput.i++; - } - return new (tree.Combinator)(c); - } - else if (parserInput.isWhitespace(-1)) { - return new (tree.Combinator)(' '); - } - else { - return new (tree.Combinator)(null); - } - }, - // - // A CSS Selector - // with less extensions e.g. the ability to extend and guard - // - // .class > div + h1 - // li a:hover - // - // Selectors are made out of one or more Elements, see above. - // - selector: function (isLess) { - var index = parserInput.i; - var elements; - var extendList; - var c; - var e; - var allExtends; - var when; - var condition; - isLess = isLess !== false; - while ((isLess && (extendList = this.extend())) || (isLess && (when = parserInput.$str('when'))) || (e = this.element())) { - if (when) { - condition = expect(this.conditions, 'expected condition'); - } - else if (condition) { - error('CSS guard can only be used at the end of selector'); - } - else if (extendList) { - if (allExtends) { - allExtends = allExtends.concat(extendList); - } - else { - allExtends = extendList; - } - } - else { - if (allExtends) { - error('Extend can only be used at the end of selector'); - } - c = parserInput.currentChar(); - if (elements) { - elements.push(e); - } - else { - elements = [e]; - } - e = null; - } - if (c === '{' || c === '}' || c === ';' || c === ',' || c === ')') { - break; - } - } - if (elements) { - return new (tree.Selector)(elements, allExtends, condition, index, fileInfo); - } - if (allExtends) { - error('Extend must be used to extend a selector, it cannot be used on its own'); - } - }, - selectors: function () { - var s; - var selectors; - while (true) { - s = this.selector(); - if (!s) { - break; - } - if (selectors) { - selectors.push(s); - } - else { - selectors = [s]; - } - parserInput.commentStore.length = 0; - if (s.condition && selectors.length > 1) { - error("Guards are only currently allowed on a single selector."); - } - if (!parserInput.$char(',')) { - break; - } - if (s.condition) { - error("Guards are only currently allowed on a single selector."); - } - parserInput.commentStore.length = 0; - } - return selectors; - }, - attribute: function () { - if (!parserInput.$char('[')) { - return; - } - var entities = this.entities; - var key; - var val; - var op; - if (!(key = entities.variableCurly())) { - key = expect(/^(?:[_A-Za-z0-9-\*]*\|)?(?:[_A-Za-z0-9-]|\\.)+/); - } - op = parserInput.$re(/^[|~*$^]?=/); - if (op) { - val = entities.quoted() || parserInput.$re(/^[0-9]+%/) || parserInput.$re(/^[\w-]+/) || entities.variableCurly(); - } - expectChar(']'); - return new (tree.Attribute)(key, op, val); - }, - // - // The `block` rule is used by `ruleset` and `mixin.definition`. - // It's a wrapper around the `primary` rule, with added `{}`. - // - block: function () { - var content; - if (parserInput.$char('{') && (content = this.primary()) && parserInput.$char('}')) { - return content; - } - }, - blockRuleset: function () { - var block = this.block(); - if (block) { - block = new tree.Ruleset(null, block); - } - return block; - }, - detachedRuleset: function () { - var argInfo; - var params; - var variadic; - parserInput.save(); - if (parserInput.$re(/^[.#]\(/)) { - /** - * DR args currently only implemented for each() function, and not - * yet settable as `@dr: #(@arg) {}` - * This should be done when DRs are merged with mixins. - * See: https://github.com/less/less-meta/issues/16 - */ - argInfo = this.mixin.args(false); - params = argInfo.args; - variadic = argInfo.variadic; - if (!parserInput.$char(')')) { - parserInput.restore(); - return; - } - } - var blockRuleset = this.blockRuleset(); - if (blockRuleset) { - parserInput.forget(); - if (params) { - return new tree.mixin.Definition(null, params, blockRuleset, null, variadic); - } - return new tree.DetachedRuleset(blockRuleset); - } - parserInput.restore(); - }, - // - // div, .class, body > p {...} - // - ruleset: function () { - var selectors; - var rules; - var debugInfo; - parserInput.save(); - if (context.dumpLineNumbers) { - debugInfo = getDebugInfo(parserInput.i); - } - selectors = this.selectors(); - if (selectors && (rules = this.block())) { - parserInput.forget(); - var ruleset = new (tree.Ruleset)(selectors, rules, context.strictImports); - if (context.dumpLineNumbers) { - ruleset.debugInfo = debugInfo; - } - return ruleset; - } - else { - parserInput.restore(); - } - }, - declaration: function () { - var name; - var value; - var index = parserInput.i; - var hasDR; - var c = parserInput.currentChar(); - var important; - var merge; - var isVariable; - if (c === '.' || c === '#' || c === '&' || c === ':') { - return; - } - parserInput.save(); - name = this.variable() || this.ruleProperty(); - if (name) { - isVariable = typeof name === 'string'; - if (isVariable) { - value = this.detachedRuleset(); - if (value) { - hasDR = true; - } - } - parserInput.commentStore.length = 0; - if (!value) { - // a name returned by this.ruleProperty() is always an array of the form: - // [string-1, ..., string-n, ""] or [string-1, ..., string-n, "+"] - // where each item is a tree.Keyword or tree.Variable - merge = !isVariable && name.length > 1 && name.pop().value; - // Custom property values get permissive parsing - if (name[0].value && name[0].value.slice(0, 2) === '--') { - value = this.permissiveValue(); - } - // Try to store values as anonymous - // If we need the value later we'll re-parse it in ruleset.parseValue - else { - value = this.anonymousValue(); - } - if (value) { - parserInput.forget(); - // anonymous values absorb the end ';' which is required for them to work - return new (tree.Declaration)(name, value, false, merge, index, fileInfo); - } - if (!value) { - value = this.value(); - } - if (value) { - important = this.important(); - } - else if (isVariable) { - // As a last resort, try permissiveValue - value = this.permissiveValue(); - } - } - if (value && (this.end() || hasDR)) { - parserInput.forget(); - return new (tree.Declaration)(name, value, important, merge, index, fileInfo); - } - else { - parserInput.restore(); - } - } - else { - parserInput.restore(); - } - }, - anonymousValue: function () { - var index = parserInput.i; - var match = parserInput.$re(/^([^.#@\$+\/'"*`(;{}-]*);/); - if (match) { - return new (tree.Anonymous)(match[1], index); - } - }, - /** - * Used for custom properties, at-rules, and variables (as fallback) - * Parses almost anything inside of {} [] () "" blocks - * until it reaches outer-most tokens. - * - * First, it will try to parse comments and entities to reach - * the end. This is mostly like the Expression parser except no - * math is allowed. - */ - permissiveValue: function (untilTokens) { - var i; - var e; - var done; - var value; - var tok = untilTokens || ';'; - var index = parserInput.i; - var result = []; - function testCurrentChar() { - var char = parserInput.currentChar(); - if (typeof tok === 'string') { - return char === tok; - } - else { - return tok.test(char); - } - } - if (testCurrentChar()) { - return; - } - value = []; - do { - e = this.comment(); - if (e) { - value.push(e); - continue; - } - e = this.entity(); - if (e) { - value.push(e); - } - } while (e); - done = testCurrentChar(); - if (value.length > 0) { - value = new (tree.Expression)(value); - if (done) { - return value; - } - else { - result.push(value); - } - // Preserve space before $parseUntil as it will not - if (parserInput.prevChar() === ' ') { - result.push(new tree.Anonymous(' ', index)); - } - } - parserInput.save(); - value = parserInput.$parseUntil(tok); - if (value) { - if (typeof value === 'string') { - error("Expected '" + value + "'", 'Parse'); - } - if (value.length === 1 && value[0] === ' ') { - parserInput.forget(); - return new tree.Anonymous('', index); - } - var item = void 0; - for (i = 0; i < value.length; i++) { - item = value[i]; - if (Array.isArray(item)) { - // Treat actual quotes as normal quoted values - result.push(new tree.Quoted(item[0], item[1], true, index, fileInfo)); - } - else { - if (i === value.length - 1) { - item = item.trim(); - } - // Treat like quoted values, but replace vars like unquoted expressions - var quote = new tree.Quoted('\'', item, true, index, fileInfo); - quote.variableRegex = /@([\w-]+)/g; - quote.propRegex = /\$([\w-]+)/g; - result.push(quote); - } - } - parserInput.forget(); - return new tree.Expression(result, true); - } - parserInput.restore(); - }, - // - // An @import atrule - // - // @import "lib"; - // - // Depending on our environment, importing is done differently: - // In the browser, it's an XHR request, in Node, it would be a - // file-system operation. The function used for importing is - // stored in `import`, which we pass to the Import constructor. - // - 'import': function () { - var path; - var features; - var index = parserInput.i; - var dir = parserInput.$re(/^@import?\s+/); - if (dir) { - var options = (dir ? this.importOptions() : null) || {}; - if ((path = this.entities.quoted() || this.entities.url())) { - features = this.mediaFeatures(); - if (!parserInput.$char(';')) { - parserInput.i = index; - error('missing semi-colon or unrecognised media features on import'); - } - features = features && new (tree.Value)(features); - return new (tree.Import)(path, features, options, index, fileInfo); - } - else { - parserInput.i = index; - error('malformed import statement'); - } - } - }, - importOptions: function () { - var o; - var options = {}; - var optionName; - var value; - // list of options, surrounded by parens - if (!parserInput.$char('(')) { - return null; - } - do { - o = this.importOption(); - if (o) { - optionName = o; - value = true; - switch (optionName) { - case 'css': - optionName = 'less'; - value = false; - break; - case 'once': - optionName = 'multiple'; - value = false; - break; - } - options[optionName] = value; - if (!parserInput.$char(',')) { - break; - } - } - } while (o); - expectChar(')'); - return options; - }, - importOption: function () { - var opt = parserInput.$re(/^(less|css|multiple|once|inline|reference|optional)/); - if (opt) { - return opt[1]; - } - }, - mediaFeature: function () { - var entities = this.entities; - var nodes = []; - var e; - var p; - parserInput.save(); - do { - e = entities.keyword() || entities.variable() || entities.mixinLookup(); - if (e) { - nodes.push(e); - } - else if (parserInput.$char('(')) { - p = this.property(); - e = this.value(); - if (parserInput.$char(')')) { - if (p && e) { - nodes.push(new (tree.Paren)(new (tree.Declaration)(p, e, null, null, parserInput.i, fileInfo, true))); - } - else if (e) { - nodes.push(new (tree.Paren)(e)); - } - else { - error('badly formed media feature definition'); - } - } - else { - error('Missing closing \')\'', 'Parse'); - } - } - } while (e); - parserInput.forget(); - if (nodes.length > 0) { - return new (tree.Expression)(nodes); - } - }, - mediaFeatures: function () { - var entities = this.entities; - var features = []; - var e; - do { - e = this.mediaFeature(); - if (e) { - features.push(e); - if (!parserInput.$char(',')) { - break; - } - } - else { - e = entities.variable() || entities.mixinLookup(); - if (e) { - features.push(e); - if (!parserInput.$char(',')) { - break; - } - } - } - } while (e); - return features.length > 0 ? features : null; - }, - media: function () { - var features; - var rules; - var media; - var debugInfo; - var index = parserInput.i; - if (context.dumpLineNumbers) { - debugInfo = getDebugInfo(index); - } - parserInput.save(); - if (parserInput.$str('@media')) { - features = this.mediaFeatures(); - rules = this.block(); - if (!rules) { - error('media definitions require block statements after any features'); - } - parserInput.forget(); - media = new (tree.Media)(rules, features, index, fileInfo); - if (context.dumpLineNumbers) { - media.debugInfo = debugInfo; - } - return media; - } - parserInput.restore(); - }, - // - // A @plugin directive, used to import plugins dynamically. - // - // @plugin (args) "lib"; - // - plugin: function () { - var path; - var args; - var options; - var index = parserInput.i; - var dir = parserInput.$re(/^@plugin?\s+/); - if (dir) { - args = this.pluginArgs(); - if (args) { - options = { - pluginArgs: args, - isPlugin: true - }; - } - else { - options = { isPlugin: true }; - } - if ((path = this.entities.quoted() || this.entities.url())) { - if (!parserInput.$char(';')) { - parserInput.i = index; - error('missing semi-colon on @plugin'); - } - return new (tree.Import)(path, null, options, index, fileInfo); - } - else { - parserInput.i = index; - error('malformed @plugin statement'); - } - } - }, - pluginArgs: function () { - // list of options, surrounded by parens - parserInput.save(); - if (!parserInput.$char('(')) { - parserInput.restore(); - return null; - } - var args = parserInput.$re(/^\s*([^\);]+)\)\s*/); - if (args[1]) { - parserInput.forget(); - return args[1].trim(); - } - else { - parserInput.restore(); - return null; - } - }, - // - // A CSS AtRule - // - // @charset "utf-8"; - // - atrule: function () { - var index = parserInput.i; - var name; - var value; - var rules; - var nonVendorSpecificName; - var hasIdentifier; - var hasExpression; - var hasUnknown; - var hasBlock = true; - var isRooted = true; - if (parserInput.currentChar() !== '@') { - return; - } - value = this['import']() || this.plugin() || this.media(); - if (value) { - return value; - } - parserInput.save(); - name = parserInput.$re(/^@[a-z-]+/); - if (!name) { - return; - } - nonVendorSpecificName = name; - if (name.charAt(1) == '-' && name.indexOf('-', 2) > 0) { - nonVendorSpecificName = "@" + name.slice(name.indexOf('-', 2) + 1); - } - switch (nonVendorSpecificName) { - case '@charset': - hasIdentifier = true; - hasBlock = false; - break; - case '@namespace': - hasExpression = true; - hasBlock = false; - break; - case '@keyframes': - case '@counter-style': - hasIdentifier = true; - break; - case '@document': - case '@supports': - hasUnknown = true; - isRooted = false; - break; - default: - hasUnknown = true; - break; - } - parserInput.commentStore.length = 0; - if (hasIdentifier) { - value = this.entity(); - if (!value) { - error("expected " + name + " identifier"); - } - } - else if (hasExpression) { - value = this.expression(); - if (!value) { - error("expected " + name + " expression"); - } - } - else if (hasUnknown) { - value = this.permissiveValue(/^[{;]/); - hasBlock = (parserInput.currentChar() === '{'); - if (!value) { - if (!hasBlock && parserInput.currentChar() !== ';') { - error(name + " rule is missing block or ending semi-colon"); - } - } - else if (!value.value) { - value = null; - } - } - if (hasBlock) { - rules = this.blockRuleset(); - } - if (rules || (!hasBlock && value && parserInput.$char(';'))) { - parserInput.forget(); - return new (tree.AtRule)(name, value, rules, index, fileInfo, context.dumpLineNumbers ? getDebugInfo(index) : null, isRooted); - } - parserInput.restore('at-rule options not recognised'); - }, - // - // A Value is a comma-delimited list of Expressions - // - // font-family: Baskerville, Georgia, serif; - // - // In a Rule, a Value represents everything after the `:`, - // and before the `;`. - // - value: function () { - var e; - var expressions = []; - var index = parserInput.i; - do { - e = this.expression(); - if (e) { - expressions.push(e); - if (!parserInput.$char(',')) { - break; - } - } - } while (e); - if (expressions.length > 0) { - return new (tree.Value)(expressions, index); - } - }, - important: function () { - if (parserInput.currentChar() === '!') { - return parserInput.$re(/^! *important/); - } - }, - sub: function () { - var a; - var e; - parserInput.save(); - if (parserInput.$char('(')) { - a = this.addition(); - if (a && parserInput.$char(')')) { - parserInput.forget(); - e = new (tree.Expression)([a]); - e.parens = true; - return e; - } - parserInput.restore('Expected \')\''); - return; - } - parserInput.restore(); - }, - multiplication: function () { - var m; - var a; - var op; - var operation; - var isSpaced; - m = this.operand(); - if (m) { - isSpaced = parserInput.isWhitespace(-1); - while (true) { - if (parserInput.peek(/^\/[*\/]/)) { - break; - } - parserInput.save(); - op = parserInput.$char('/') || parserInput.$char('*') || parserInput.$str('./'); - if (!op) { - parserInput.forget(); - break; - } - a = this.operand(); - if (!a) { - parserInput.restore(); - break; - } - parserInput.forget(); - m.parensInOp = true; - a.parensInOp = true; - operation = new (tree.Operation)(op, [operation || m, a], isSpaced); - isSpaced = parserInput.isWhitespace(-1); - } - return operation || m; - } - }, - addition: function () { - var m; - var a; - var op; - var operation; - var isSpaced; - m = this.multiplication(); - if (m) { - isSpaced = parserInput.isWhitespace(-1); - while (true) { - op = parserInput.$re(/^[-+]\s+/) || (!isSpaced && (parserInput.$char('+') || parserInput.$char('-'))); - if (!op) { - break; - } - a = this.multiplication(); - if (!a) { - break; - } - m.parensInOp = true; - a.parensInOp = true; - operation = new (tree.Operation)(op, [operation || m, a], isSpaced); - isSpaced = parserInput.isWhitespace(-1); - } - return operation || m; - } - }, - conditions: function () { - var a; - var b; - var index = parserInput.i; - var condition; - a = this.condition(true); - if (a) { - while (true) { - if (!parserInput.peek(/^,\s*(not\s*)?\(/) || !parserInput.$char(',')) { - break; - } - b = this.condition(true); - if (!b) { - break; - } - condition = new (tree.Condition)('or', condition || a, b, index); - } - return condition || a; - } - }, - condition: function (needsParens) { - var result; - var logical; - var next; - function or() { - return parserInput.$str('or'); - } - result = this.conditionAnd(needsParens); - if (!result) { - return; - } - logical = or(); - if (logical) { - next = this.condition(needsParens); - if (next) { - result = new (tree.Condition)(logical, result, next); - } - else { - return; - } - } - return result; - }, - conditionAnd: function (needsParens) { - var result; - var logical; - var next; - var self = this; - function insideCondition() { - var cond = self.negatedCondition(needsParens) || self.parenthesisCondition(needsParens); - if (!cond && !needsParens) { - return self.atomicCondition(needsParens); - } - return cond; - } - function and() { - return parserInput.$str('and'); - } - result = insideCondition(); - if (!result) { - return; - } - logical = and(); - if (logical) { - next = this.conditionAnd(needsParens); - if (next) { - result = new (tree.Condition)(logical, result, next); - } - else { - return; - } - } - return result; - }, - negatedCondition: function (needsParens) { - if (parserInput.$str('not')) { - var result = this.parenthesisCondition(needsParens); - if (result) { - result.negate = !result.negate; - } - return result; - } - }, - parenthesisCondition: function (needsParens) { - function tryConditionFollowedByParenthesis(me) { - var body; - parserInput.save(); - body = me.condition(needsParens); - if (!body) { - parserInput.restore(); - return; - } - if (!parserInput.$char(')')) { - parserInput.restore(); - return; - } - parserInput.forget(); - return body; - } - var body; - parserInput.save(); - if (!parserInput.$str('(')) { - parserInput.restore(); - return; - } - body = tryConditionFollowedByParenthesis(this); - if (body) { - parserInput.forget(); - return body; - } - body = this.atomicCondition(needsParens); - if (!body) { - parserInput.restore(); - return; - } - if (!parserInput.$char(')')) { - parserInput.restore("expected ')' got '" + parserInput.currentChar() + "'"); - return; - } - parserInput.forget(); - return body; - }, - atomicCondition: function (needsParens) { - var entities = this.entities; - var index = parserInput.i; - var a; - var b; - var c; - var op; - function cond() { - return this.addition() || entities.keyword() || entities.quoted() || entities.mixinLookup(); - } - cond = cond.bind(this); - a = cond(); - if (a) { - if (parserInput.$char('>')) { - if (parserInput.$char('=')) { - op = '>='; - } - else { - op = '>'; - } - } - else if (parserInput.$char('<')) { - if (parserInput.$char('=')) { - op = '<='; - } - else { - op = '<'; - } - } - else if (parserInput.$char('=')) { - if (parserInput.$char('>')) { - op = '=>'; - } - else if (parserInput.$char('<')) { - op = '=<'; - } - else { - op = '='; - } - } - if (op) { - b = cond(); - if (b) { - c = new (tree.Condition)(op, a, b, index, false); - } - else { - error('expected expression'); - } - } - else { - c = new (tree.Condition)('=', a, new (tree.Keyword)('true'), index, false); - } - return c; - } - }, - // - // An operand is anything that can be part of an operation, - // such as a Color, or a Variable - // - operand: function () { - var entities = this.entities; - var negate; - if (parserInput.peek(/^-[@\$\(]/)) { - negate = parserInput.$char('-'); - } - var o = this.sub() || entities.dimension() || - entities.color() || entities.variable() || - entities.property() || entities.call() || - entities.quoted(true) || entities.colorKeyword() || - entities.mixinLookup(); - if (negate) { - o.parensInOp = true; - o = new (tree.Negative)(o); - } - return o; - }, - // - // Expressions either represent mathematical operations, - // or white-space delimited Entities. - // - // 1px solid black - // @var * 2 - // - expression: function () { - var entities = []; - var e; - var delim; - var index = parserInput.i; - do { - e = this.comment(); - if (e) { - entities.push(e); - continue; - } - e = this.addition() || this.entity(); - if (e instanceof tree.Comment) { - e = null; - } - if (e) { - entities.push(e); - // operations do not allow keyword "/" dimension (e.g. small/20px) so we support that here - if (!parserInput.peek(/^\/[\/*]/)) { - delim = parserInput.$char('/'); - if (delim) { - entities.push(new (tree.Anonymous)(delim, index)); - } - } - } - } while (e); - if (entities.length > 0) { - return new (tree.Expression)(entities); - } - }, - property: function () { - var name = parserInput.$re(/^(\*?-?[_a-zA-Z0-9-]+)\s*:/); - if (name) { - return name[1]; - } - }, - ruleProperty: function () { - var name = []; - var index = []; - var s; - var k; - parserInput.save(); - var simpleProperty = parserInput.$re(/^([_a-zA-Z0-9-]+)\s*:/); - if (simpleProperty) { - name = [new (tree.Keyword)(simpleProperty[1])]; - parserInput.forget(); - return name; - } - function match(re) { - var i = parserInput.i; - var chunk = parserInput.$re(re); - if (chunk) { - index.push(i); - return name.push(chunk[1]); - } - } - match(/^(\*?)/); - while (true) { - if (!match(/^((?:[\w-]+)|(?:[@\$]\{[\w-]+\}))/)) { - break; - } - } - if ((name.length > 1) && match(/^((?:\+_|\+)?)\s*:/)) { - parserInput.forget(); - // at last, we have the complete match now. move forward, - // convert name particles to tree objects and return: - if (name[0] === '') { - name.shift(); - index.shift(); - } - for (k = 0; k < name.length; k++) { - s = name[k]; - name[k] = (s.charAt(0) !== '@' && s.charAt(0) !== '$') ? - new (tree.Keyword)(s) : - (s.charAt(0) === '@' ? - new (tree.Variable)("@" + s.slice(2, -1), index[k], fileInfo) : - new (tree.Property)("$" + s.slice(2, -1), index[k], fileInfo)); - } - return name; - } - parserInput.restore(); - } - } - }; - }; - Parser.serializeVars = function (vars) { - var s = ''; - for (var name_1 in vars) { - if (Object.hasOwnProperty.call(vars, name_1)) { - var value = vars[name_1]; - s += ((name_1[0] === '@') ? '' : '@') + name_1 + ": " + value + ((String(value).slice(-1) === ';') ? '' : ';'); - } - } - return s; - }; + // + // less.js - parser + // + // A relatively straight-forward predictive parser. + // There is no tokenization/lexing stage, the input is parsed + // in one sweep. + // + // To make the parser fast enough to run in the browser, several + // optimization had to be made: + // + // - Matching and slicing on a huge input is often cause of slowdowns. + // The solution is to chunkify the input into smaller strings. + // The chunks are stored in the `chunks` var, + // `j` holds the current chunk index, and `currentPos` holds + // the index of the current chunk in relation to `input`. + // This gives us an almost 4x speed-up. + // + // - In many cases, we don't need to match individual tokens; + // for example, if a value doesn't hold any variables, operations + // or dynamic references, the parser can effectively 'skip' it, + // treating it as a literal. + // An example would be '1px solid #000' - which evaluates to itself, + // we don't need to know what the individual components are. + // The drawback, of course is that you don't get the benefits of + // syntax-checking on the CSS. This gives us a 50% speed-up in the parser, + // and a smaller speed-up in the code-gen. + // + // + // Token matching is done with the `$` function, which either takes + // a terminal string or regexp, or a non-terminal function to call. + // It also takes care of moving all the indices forwards. + // + var Parser = function Parser(context, imports, fileInfo) { + var parsers; + var parserInput = getParserInput(); + function error(msg, type) { + throw new LessError({ + index: parserInput.i, + filename: fileInfo.filename, + type: type || 'Syntax', + message: msg + }, imports); + } + function expect(arg, msg) { + // some older browsers return typeof 'function' for RegExp + var result = (arg instanceof Function) ? arg.call(parsers) : parserInput.$re(arg); + if (result) { + return result; + } + error(msg || (typeof arg === 'string' + ? "expected '" + arg + "' got '" + parserInput.currentChar() + "'" + : 'unexpected token')); + } + // Specialization of expect() + function expectChar(arg, msg) { + if (parserInput.$char(arg)) { + return arg; + } + error(msg || "expected '" + arg + "' got '" + parserInput.currentChar() + "'"); + } + function getDebugInfo(index) { + var filename = fileInfo.filename; + return { + lineNumber: getLocation(index, parserInput.getInput()).line + 1, + fileName: filename + }; + } + /** + * Used after initial parsing to create nodes on the fly + * + * @param {String} str - string to parse + * @param {Array} parseList - array of parsers to run input through e.g. ["value", "important"] + * @param {Number} currentIndex - start number to begin indexing + * @param {Object} fileInfo - fileInfo to attach to created nodes + */ + function parseNode(str, parseList, currentIndex, fileInfo, callback) { + var result; + var returnNodes = []; + var parser = parserInput; + try { + parser.start(str, false, function fail(msg, index) { + callback({ + message: msg, + index: index + currentIndex + }); + }); + for (var x = 0, p = void 0, i = void 0; (p = parseList[x]); x++) { + i = parser.i; + result = parsers[p](); + if (result) { + try { + result._index = i + currentIndex; + result._fileInfo = fileInfo; + } + catch (e) { } + returnNodes.push(result); + } + else { + returnNodes.push(null); + } + } + var endInfo = parser.end(); + if (endInfo.isFinished) { + callback(null, returnNodes); + } + else { + callback(true, null); + } + } + catch (e) { + throw new LessError({ + index: e.index + currentIndex, + message: e.message + }, imports, fileInfo.filename); + } + } + // + // The Parser + // + return { + parserInput: parserInput, + imports: imports, + fileInfo: fileInfo, + parseNode: parseNode, + // + // Parse an input string into an abstract syntax tree, + // @param str A string containing 'less' markup + // @param callback call `callback` when done. + // @param [additionalData] An optional map which can contains vars - a map (key, value) of variables to apply + // + parse: function (str, callback, additionalData) { + var root; + var error = null; + var globalVars; + var modifyVars; + var ignored; + var preText = ''; + globalVars = (additionalData && additionalData.globalVars) ? Parser.serializeVars(additionalData.globalVars) + "\n" : ''; + modifyVars = (additionalData && additionalData.modifyVars) ? "\n" + Parser.serializeVars(additionalData.modifyVars) : ''; + if (context.pluginManager) { + var preProcessors = context.pluginManager.getPreProcessors(); + for (var i = 0; i < preProcessors.length; i++) { + str = preProcessors[i].process(str, { context: context, imports: imports, fileInfo: fileInfo }); + } + } + if (globalVars || (additionalData && additionalData.banner)) { + preText = ((additionalData && additionalData.banner) ? additionalData.banner : '') + globalVars; + ignored = imports.contentsIgnoredChars; + ignored[fileInfo.filename] = ignored[fileInfo.filename] || 0; + ignored[fileInfo.filename] += preText.length; + } + str = str.replace(/\r\n?/g, '\n'); + // Remove potential UTF Byte Order Mark + str = preText + str.replace(/^\uFEFF/, '') + modifyVars; + imports.contents[fileInfo.filename] = str; + // Start with the primary rule. + // The whole syntax tree is held under a Ruleset node, + // with the `root` property set to true, so no `{}` are + // output. The callback is called when the input is parsed. + try { + parserInput.start(str, context.chunkInput, function fail(msg, index) { + throw new LessError({ + index: index, + type: 'Parse', + message: msg, + filename: fileInfo.filename + }, imports); + }); + tree.Node.prototype.parse = this; + root = new tree.Ruleset(null, this.parsers.primary()); + tree.Node.prototype.rootNode = root; + root.root = true; + root.firstRoot = true; + root.functionRegistry = functionRegistry.inherit(); + } + catch (e) { + return callback(new LessError(e, imports, fileInfo.filename)); + } + // If `i` is smaller than the `input.length - 1`, + // it means the parser wasn't able to parse the whole + // string, so we've got a parsing error. + // + // We try to extract a \n delimited string, + // showing the line where the parse error occurred. + // We split it up into two parts (the part which parsed, + // and the part which didn't), so we can color them differently. + var endInfo = parserInput.end(); + if (!endInfo.isFinished) { + var message = endInfo.furthestPossibleErrorMessage; + if (!message) { + message = 'Unrecognised input'; + if (endInfo.furthestChar === '}') { + message += '. Possibly missing opening \'{\''; + } + else if (endInfo.furthestChar === ')') { + message += '. Possibly missing opening \'(\''; + } + else if (endInfo.furthestReachedEnd) { + message += '. Possibly missing something'; + } + } + error = new LessError({ + type: 'Parse', + message: message, + index: endInfo.furthest, + filename: fileInfo.filename + }, imports); + } + var finish = function (e) { + e = error || e || imports.error; + if (e) { + if (!(e instanceof LessError)) { + e = new LessError(e, imports, fileInfo.filename); + } + return callback(e); + } + else { + return callback(null, root); + } + }; + if (context.processImports !== false) { + new visitors.ImportVisitor(imports, finish) + .run(root); + } + else { + return finish(); + } + }, + // + // Here in, the parsing rules/functions + // + // The basic structure of the syntax tree generated is as follows: + // + // Ruleset -> Declaration -> Value -> Expression -> Entity + // + // Here's some Less code: + // + // .class { + // color: #fff; + // border: 1px solid #000; + // width: @w + 4px; + // > .child {...} + // } + // + // And here's what the parse tree might look like: + // + // Ruleset (Selector '.class', [ + // Declaration ("color", Value ([Expression [Color #fff]])) + // Declaration ("border", Value ([Expression [Dimension 1px][Keyword "solid"][Color #000]])) + // Declaration ("width", Value ([Expression [Operation " + " [Variable "@w"][Dimension 4px]]])) + // Ruleset (Selector [Element '>', '.child'], [...]) + // ]) + // + // In general, most rules will try to parse a token with the `$re()` function, and if the return + // value is truly, will return a new node, of the relevant type. Sometimes, we need to check + // first, before parsing, that's when we use `peek()`. + // + parsers: parsers = { + // + // The `primary` rule is the *entry* and *exit* point of the parser. + // The rules here can appear at any level of the parse tree. + // + // The recursive nature of the grammar is an interplay between the `block` + // rule, which represents `{ ... }`, the `ruleset` rule, and this `primary` rule, + // as represented by this simplified grammar: + // + // primary → (ruleset | declaration)+ + // ruleset → selector+ block + // block → '{' primary '}' + // + // Only at one point is the primary rule not called from the + // block rule: at the root level. + // + primary: function () { + var mixin = this.mixin; + var root = []; + var node; + while (true) { + while (true) { + node = this.comment(); + if (!node) { + break; + } + root.push(node); + } + // always process comments before deciding if finished + if (parserInput.finished) { + break; + } + if (parserInput.peek('}')) { + break; + } + node = this.extendRule(); + if (node) { + root = root.concat(node); + continue; + } + node = mixin.definition() || this.declaration() || mixin.call(false, false) || + this.ruleset() || this.variableCall() || this.entities.call() || this.atrule(); + if (node) { + root.push(node); + } + else { + var foundSemiColon = false; + while (parserInput.$char(';')) { + foundSemiColon = true; + } + if (!foundSemiColon) { + break; + } + } + } + return root; + }, + // comments are collected by the main parsing mechanism and then assigned to nodes + // where the current structure allows it + comment: function () { + if (parserInput.commentStore.length) { + var comment = parserInput.commentStore.shift(); + return new (tree.Comment)(comment.text, comment.isLineComment, comment.index, fileInfo); + } + }, + // + // Entities are tokens which can be found inside an Expression + // + entities: { + mixinLookup: function () { + return parsers.mixin.call(true, true); + }, + // + // A string, which supports escaping " and ' + // + // "milky way" 'he\'s the one!' + // + quoted: function (forceEscaped) { + var str; + var index = parserInput.i; + var isEscaped = false; + parserInput.save(); + if (parserInput.$char('~')) { + isEscaped = true; + } + else if (forceEscaped) { + parserInput.restore(); + return; + } + str = parserInput.$quoted(); + if (!str) { + parserInput.restore(); + return; + } + parserInput.forget(); + return new (tree.Quoted)(str.charAt(0), str.substr(1, str.length - 2), isEscaped, index, fileInfo); + }, + // + // A catch-all word, such as: + // + // black border-collapse + // + keyword: function () { + var k = parserInput.$char('%') || parserInput.$re(/^\[?(?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+\]?/); + if (k) { + return tree.Color.fromKeyword(k) || new (tree.Keyword)(k); + } + }, + // + // A function call + // + // rgb(255, 0, 255) + // + // The arguments are parsed with the `entities.arguments` parser. + // + call: function () { + var name; + var args; + var func; + var index = parserInput.i; + // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18 + if (parserInput.peek(/^url\(/i)) { + return; + } + parserInput.save(); + name = parserInput.$re(/^([\w-]+|%|~|progid:[\w\.]+)\(/); + if (!name) { + parserInput.forget(); + return; + } + name = name[1]; + func = this.customFuncCall(name); + if (func) { + args = func.parse(); + if (args && func.stop) { + parserInput.forget(); + return args; + } + } + args = this.arguments(args); + if (!parserInput.$char(')')) { + parserInput.restore('Could not parse call arguments or missing \')\''); + return; + } + parserInput.forget(); + return new (tree.Call)(name, args, index, fileInfo); + }, + // + // Parsing rules for functions with non-standard args, e.g.: + // + // boolean(not(2 > 1)) + // + // This is a quick prototype, to be modified/improved when + // more custom-parsed funcs come (e.g. `selector(...)`) + // + customFuncCall: function (name) { + /* Ideally the table is to be moved out of here for faster perf., + but it's quite tricky since it relies on all these `parsers` + and `expect` available only here */ + return { + alpha: f(parsers.ieAlpha, true), + boolean: f(condition), + 'if': f(condition) + }[name.toLowerCase()]; + function f(parse, stop) { + return { + parse: parse, + stop: stop // when true - stop after parse() and return its result, + // otherwise continue for plain args + }; + } + function condition() { + return [expect(parsers.condition, 'expected condition')]; + } + }, + arguments: function (prevArgs) { + var argsComma = prevArgs || []; + var argsSemiColon = []; + var isSemiColonSeparated; + var value; + parserInput.save(); + while (true) { + if (prevArgs) { + prevArgs = false; + } + else { + value = parsers.detachedRuleset() || this.assignment() || parsers.expression(); + if (!value) { + break; + } + if (value.value && value.value.length == 1) { + value = value.value[0]; + } + argsComma.push(value); + } + if (parserInput.$char(',')) { + continue; + } + if (parserInput.$char(';') || isSemiColonSeparated) { + isSemiColonSeparated = true; + value = (argsComma.length < 1) ? argsComma[0] + : new tree.Value(argsComma); + argsSemiColon.push(value); + argsComma = []; + } + } + parserInput.forget(); + return isSemiColonSeparated ? argsSemiColon : argsComma; + }, + literal: function () { + return this.dimension() || + this.color() || + this.quoted() || + this.unicodeDescriptor(); + }, + // Assignments are argument entities for calls. + // They are present in ie filter properties as shown below. + // + // filter: progid:DXImageTransform.Microsoft.Alpha( *opacity=50* ) + // + assignment: function () { + var key; + var value; + parserInput.save(); + key = parserInput.$re(/^\w+(?=\s?=)/i); + if (!key) { + parserInput.restore(); + return; + } + if (!parserInput.$char('=')) { + parserInput.restore(); + return; + } + value = parsers.entity(); + if (value) { + parserInput.forget(); + return new (tree.Assignment)(key, value); + } + else { + parserInput.restore(); + } + }, + // + // Parse url() tokens + // + // We use a specific rule for urls, because they don't really behave like + // standard function calls. The difference is that the argument doesn't have + // to be enclosed within a string, so it can't be parsed as an Expression. + // + url: function () { + var value; + var index = parserInput.i; + parserInput.autoCommentAbsorb = false; + if (!parserInput.$str('url(')) { + parserInput.autoCommentAbsorb = true; + return; + } + value = this.quoted() || this.variable() || this.property() || + parserInput.$re(/^(?:(?:\\[\(\)'"])|[^\(\)'"])+/) || ''; + parserInput.autoCommentAbsorb = true; + expectChar(')'); + return new (tree.URL)((value.value != null || + value instanceof tree.Variable || + value instanceof tree.Property) ? + value : new (tree.Anonymous)(value, index), index, fileInfo); + }, + // + // A Variable entity, such as `@fink`, in + // + // width: @fink + 2px + // + // We use a different parser for variable definitions, + // see `parsers.variable`. + // + variable: function () { + var ch; + var name; + var index = parserInput.i; + parserInput.save(); + if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^@@?[\w-]+/))) { + ch = parserInput.currentChar(); + if (ch === '(' || ch === '[' && !parserInput.prevChar().match(/^\s/)) { + // this may be a VariableCall lookup + var result = parsers.variableCall(name); + if (result) { + parserInput.forget(); + return result; + } + } + parserInput.forget(); + return new (tree.Variable)(name, index, fileInfo); + } + parserInput.restore(); + }, + // A variable entity using the protective {} e.g. @{var} + variableCurly: function () { + var curly; + var index = parserInput.i; + if (parserInput.currentChar() === '@' && (curly = parserInput.$re(/^@\{([\w-]+)\}/))) { + return new (tree.Variable)("@" + curly[1], index, fileInfo); + } + }, + // + // A Property accessor, such as `$color`, in + // + // background-color: $color + // + property: function () { + var name; + var index = parserInput.i; + if (parserInput.currentChar() === '$' && (name = parserInput.$re(/^\$[\w-]+/))) { + return new (tree.Property)(name, index, fileInfo); + } + }, + // A property entity useing the protective {} e.g. ${prop} + propertyCurly: function () { + var curly; + var index = parserInput.i; + if (parserInput.currentChar() === '$' && (curly = parserInput.$re(/^\$\{([\w-]+)\}/))) { + return new (tree.Property)("$" + curly[1], index, fileInfo); + } + }, + // + // A Hexadecimal color + // + // #4F3C2F + // + // `rgb` and `hsl` colors are parsed through the `entities.call` parser. + // + color: function () { + var rgb; + parserInput.save(); + if (parserInput.currentChar() === '#' && (rgb = parserInput.$re(/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})([\w.#\[])?/))) { + if (!rgb[2]) { + parserInput.forget(); + return new (tree.Color)(rgb[1], undefined, rgb[0]); + } + } + parserInput.restore(); + }, + colorKeyword: function () { + parserInput.save(); + var autoCommentAbsorb = parserInput.autoCommentAbsorb; + parserInput.autoCommentAbsorb = false; + var k = parserInput.$re(/^[_A-Za-z-][_A-Za-z0-9-]+/); + parserInput.autoCommentAbsorb = autoCommentAbsorb; + if (!k) { + parserInput.forget(); + return; + } + parserInput.restore(); + var color = tree.Color.fromKeyword(k); + if (color) { + parserInput.$str(k); + return color; + } + }, + // + // A Dimension, that is, a number and a unit + // + // 0.5em 95% + // + dimension: function () { + if (parserInput.peekNotNumeric()) { + return; + } + var value = parserInput.$re(/^([+-]?\d*\.?\d+)(%|[a-z_]+)?/i); + if (value) { + return new (tree.Dimension)(value[1], value[2]); + } + }, + // + // A unicode descriptor, as is used in unicode-range + // + // U+0?? or U+00A1-00A9 + // + unicodeDescriptor: function () { + var ud; + ud = parserInput.$re(/^U\+[0-9a-fA-F?]+(\-[0-9a-fA-F?]+)?/); + if (ud) { + return new (tree.UnicodeDescriptor)(ud[0]); + } + }, + // + // JavaScript code to be evaluated + // + // `window.location.href` + // + javascript: function () { + var js; + var index = parserInput.i; + parserInput.save(); + var escape = parserInput.$char('~'); + var jsQuote = parserInput.$char('`'); + if (!jsQuote) { + parserInput.restore(); + return; + } + js = parserInput.$re(/^[^`]*`/); + if (js) { + parserInput.forget(); + return new (tree.JavaScript)(js.substr(0, js.length - 1), Boolean(escape), index, fileInfo); + } + parserInput.restore('invalid javascript definition'); + } + }, + // + // The variable part of a variable definition. Used in the `rule` parser + // + // @fink: + // + variable: function () { + var name; + if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^(@[\w-]+)\s*:/))) { + return name[1]; + } + }, + // + // Call a variable value to retrieve a detached ruleset + // or a value from a detached ruleset's rules. + // + // @fink(); + // @fink; + // color: @fink[@color]; + // + variableCall: function (parsedName) { + var lookups; + var i = parserInput.i; + var inValue = !!parsedName; + var name = parsedName; + parserInput.save(); + if (name || (parserInput.currentChar() === '@' + && (name = parserInput.$re(/^(@[\w-]+)(\(\s*\))?/)))) { + lookups = this.mixin.ruleLookups(); + if (!lookups && ((inValue && parserInput.$str('()') !== '()') || (name[2] !== '()'))) { + parserInput.restore('Missing \'[...]\' lookup in variable call'); + return; + } + if (!inValue) { + name = name[1]; + } + var call = new tree.VariableCall(name, i, fileInfo); + if (!inValue && parsers.end()) { + parserInput.forget(); + return call; + } + else { + parserInput.forget(); + return new tree.NamespaceValue(call, lookups, i, fileInfo); + } + } + parserInput.restore(); + }, + // + // extend syntax - used to extend selectors + // + extend: function (isRule) { + var elements; + var e; + var index = parserInput.i; + var option; + var extendList; + var extend; + if (!parserInput.$str(isRule ? '&:extend(' : ':extend(')) { + return; + } + do { + option = null; + elements = null; + while (!(option = parserInput.$re(/^(all)(?=\s*(\)|,))/))) { + e = this.element(); + if (!e) { + break; + } + if (elements) { + elements.push(e); + } + else { + elements = [e]; + } + } + option = option && option[1]; + if (!elements) { + error('Missing target selector for :extend().'); + } + extend = new (tree.Extend)(new (tree.Selector)(elements), option, index, fileInfo); + if (extendList) { + extendList.push(extend); + } + else { + extendList = [extend]; + } + } while (parserInput.$char(',')); + expect(/^\)/); + if (isRule) { + expect(/^;/); + } + return extendList; + }, + // + // extendRule - used in a rule to extend all the parent selectors + // + extendRule: function () { + return this.extend(true); + }, + // + // Mixins + // + mixin: { + // + // A Mixin call, with an optional argument list + // + // #mixins > .square(#fff); + // #mixins.square(#fff); + // .rounded(4px, black); + // .button; + // + // We can lookup / return a value using the lookup syntax: + // + // color: #mixin.square(#fff)[@color]; + // + // The `while` loop is there because mixins can be + // namespaced, but we only support the child and descendant + // selector for now. + // + call: function (inValue, getLookup) { + var s = parserInput.currentChar(); + var important = false; + var lookups; + var index = parserInput.i; + var elements; + var args; + var hasParens; + if (s !== '.' && s !== '#') { + return; + } + parserInput.save(); // stop us absorbing part of an invalid selector + elements = this.elements(); + if (elements) { + if (parserInput.$char('(')) { + args = this.args(true).args; + expectChar(')'); + hasParens = true; + } + if (getLookup !== false) { + lookups = this.ruleLookups(); + } + if (getLookup === true && !lookups) { + parserInput.restore(); + return; + } + if (!lookups && !hasParens) { + // This isn't a valid mixin call + parserInput.restore('Unrecognized input. Possibly missing \'(\' in mixin call.'); + return; + } + if (!inValue && parsers.important()) { + important = true; + } + if (inValue || parsers.end()) { + parserInput.forget(); + var mixin = new (tree.mixin.Call)(elements, args, index, fileInfo, !lookups && important); + if (lookups) { + return new tree.NamespaceValue(mixin, lookups); + } + else { + return mixin; + } + } + } + parserInput.restore(); + }, + /** + * Matching elements for mixins + * (Start with . or # and can have > ) + */ + elements: function () { + var elements; + var e; + var c; + var elem; + var elemIndex; + var re = /^[#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/; + while (true) { + elemIndex = parserInput.i; + e = parserInput.$re(re); + if (!e) { + break; + } + elem = new (tree.Element)(c, e, false, elemIndex, fileInfo); + if (elements) { + elements.push(elem); + } + else { + elements = [elem]; + } + c = parserInput.$char('>'); + } + return elements; + }, + args: function (isCall) { + var entities = parsers.entities; + var returner = { args: null, variadic: false }; + var expressions = []; + var argsSemiColon = []; + var argsComma = []; + var isSemiColonSeparated; + var expressionContainsNamed; + var name; + var nameLoop; + var value; + var arg; + var expand; + var hasSep = true; + parserInput.save(); + while (true) { + if (isCall) { + arg = parsers.detachedRuleset() || parsers.expression(); + } + else { + parserInput.commentStore.length = 0; + if (parserInput.$str('...')) { + returner.variadic = true; + if (parserInput.$char(';') && !isSemiColonSeparated) { + isSemiColonSeparated = true; + } + (isSemiColonSeparated ? argsSemiColon : argsComma) + .push({ variadic: true }); + break; + } + arg = entities.variable() || entities.property() || entities.literal() || entities.keyword() || this.call(true); + } + if (!arg || !hasSep) { + break; + } + nameLoop = null; + if (arg.throwAwayComments) { + arg.throwAwayComments(); + } + value = arg; + var val = null; + if (isCall) { + // Variable + if (arg.value && arg.value.length == 1) { + val = arg.value[0]; + } + } + else { + val = arg; + } + if (val && (val instanceof tree.Variable || val instanceof tree.Property)) { + if (parserInput.$char(':')) { + if (expressions.length > 0) { + if (isSemiColonSeparated) { + error('Cannot mix ; and , as delimiter types'); + } + expressionContainsNamed = true; + } + value = parsers.detachedRuleset() || parsers.expression(); + if (!value) { + if (isCall) { + error('could not understand value for named argument'); + } + else { + parserInput.restore(); + returner.args = []; + return returner; + } + } + nameLoop = (name = val.name); + } + else if (parserInput.$str('...')) { + if (!isCall) { + returner.variadic = true; + if (parserInput.$char(';') && !isSemiColonSeparated) { + isSemiColonSeparated = true; + } + (isSemiColonSeparated ? argsSemiColon : argsComma) + .push({ name: arg.name, variadic: true }); + break; + } + else { + expand = true; + } + } + else if (!isCall) { + name = nameLoop = val.name; + value = null; + } + } + if (value) { + expressions.push(value); + } + argsComma.push({ name: nameLoop, value: value, expand: expand }); + if (parserInput.$char(',')) { + hasSep = true; + continue; + } + hasSep = parserInput.$char(';') === ';'; + if (hasSep || isSemiColonSeparated) { + if (expressionContainsNamed) { + error('Cannot mix ; and , as delimiter types'); + } + isSemiColonSeparated = true; + if (expressions.length > 1) { + value = new (tree.Value)(expressions); + } + argsSemiColon.push({ name: name, value: value, expand: expand }); + name = null; + expressions = []; + expressionContainsNamed = false; + } + } + parserInput.forget(); + returner.args = isSemiColonSeparated ? argsSemiColon : argsComma; + return returner; + }, + // + // A Mixin definition, with a list of parameters + // + // .rounded (@radius: 2px, @color) { + // ... + // } + // + // Until we have a finer grained state-machine, we have to + // do a look-ahead, to make sure we don't have a mixin call. + // See the `rule` function for more information. + // + // We start by matching `.rounded (`, and then proceed on to + // the argument list, which has optional default values. + // We store the parameters in `params`, with a `value` key, + // if there is a value, such as in the case of `@radius`. + // + // Once we've got our params list, and a closing `)`, we parse + // the `{...}` block. + // + definition: function () { + var name; + var params = []; + var match; + var ruleset; + var cond; + var variadic = false; + if ((parserInput.currentChar() !== '.' && parserInput.currentChar() !== '#') || + parserInput.peek(/^[^{]*\}/)) { + return; + } + parserInput.save(); + match = parserInput.$re(/^([#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\s*\(/); + if (match) { + name = match[1]; + var argInfo = this.args(false); + params = argInfo.args; + variadic = argInfo.variadic; + // .mixincall("@{a}"); + // looks a bit like a mixin definition.. + // also + // .mixincall(@a: {rule: set;}); + // so we have to be nice and restore + if (!parserInput.$char(')')) { + parserInput.restore('Missing closing \')\''); + return; + } + parserInput.commentStore.length = 0; + if (parserInput.$str('when')) { // Guard + cond = expect(parsers.conditions, 'expected condition'); + } + ruleset = parsers.block(); + if (ruleset) { + parserInput.forget(); + return new (tree.mixin.Definition)(name, params, ruleset, cond, variadic); + } + else { + parserInput.restore(); + } + } + else { + parserInput.restore(); + } + }, + ruleLookups: function () { + var rule; + var lookups = []; + if (parserInput.currentChar() !== '[') { + return; + } + while (true) { + parserInput.save(); + rule = this.lookupValue(); + if (!rule && rule !== '') { + parserInput.restore(); + break; + } + lookups.push(rule); + parserInput.forget(); + } + if (lookups.length > 0) { + return lookups; + } + }, + lookupValue: function () { + parserInput.save(); + if (!parserInput.$char('[')) { + parserInput.restore(); + return; + } + var name = parserInput.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/); + if (!parserInput.$char(']')) { + parserInput.restore(); + return; + } + if (name || name === '') { + parserInput.forget(); + return name; + } + parserInput.restore(); + } + }, + // + // Entities are the smallest recognized token, + // and can be found inside a rule's value. + // + entity: function () { + var entities = this.entities; + return this.comment() || entities.literal() || entities.variable() || entities.url() || + entities.property() || entities.call() || entities.keyword() || this.mixin.call(true) || + entities.javascript(); + }, + // + // A Declaration terminator. Note that we use `peek()` to check for '}', + // because the `block` rule will be expecting it, but we still need to make sure + // it's there, if ';' was omitted. + // + end: function () { + return parserInput.$char(';') || parserInput.peek('}'); + }, + // + // IE's alpha function + // + // alpha(opacity=88) + // + ieAlpha: function () { + var value; + // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18 + if (!parserInput.$re(/^opacity=/i)) { + return; + } + value = parserInput.$re(/^\d+/); + if (!value) { + value = expect(parsers.entities.variable, 'Could not parse alpha'); + value = "@{" + value.name.slice(1) + "}"; + } + expectChar(')'); + return new tree.Quoted('', "alpha(opacity=" + value + ")"); + }, + // + // A Selector Element + // + // div + // + h1 + // #socks + // input[type="text"] + // + // Elements are the building blocks for Selectors, + // they are made out of a `Combinator` (see combinator rule), + // and an element name, such as a tag a class, or `*`. + // + element: function () { + var e; + var c; + var v; + var index = parserInput.i; + c = this.combinator(); + e = parserInput.$re(/^(?:\d+\.\d+|\d+)%/) || + parserInput.$re(/^(?:[.#]?|:*)(?:[\w-]|[^\x00-\x9f]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/) || + parserInput.$char('*') || parserInput.$char('&') || this.attribute() || + parserInput.$re(/^\([^&()@]+\)/) || parserInput.$re(/^[\.#:](?=@)/) || + this.entities.variableCurly(); + if (!e) { + parserInput.save(); + if (parserInput.$char('(')) { + if ((v = this.selector(false)) && parserInput.$char(')')) { + e = new (tree.Paren)(v); + parserInput.forget(); + } + else { + parserInput.restore('Missing closing \')\''); + } + } + else { + parserInput.forget(); + } + } + if (e) { + return new (tree.Element)(c, e, e instanceof tree.Variable, index, fileInfo); + } + }, + // + // Combinators combine elements together, in a Selector. + // + // Because our parser isn't white-space sensitive, special care + // has to be taken, when parsing the descendant combinator, ` `, + // as it's an empty space. We have to check the previous character + // in the input, to see if it's a ` ` character. More info on how + // we deal with this in *combinator.js*. + // + combinator: function () { + var c = parserInput.currentChar(); + if (c === '/') { + parserInput.save(); + var slashedCombinator = parserInput.$re(/^\/[a-z]+\//i); + if (slashedCombinator) { + parserInput.forget(); + return new (tree.Combinator)(slashedCombinator); + } + parserInput.restore(); + } + if (c === '>' || c === '+' || c === '~' || c === '|' || c === '^') { + parserInput.i++; + if (c === '^' && parserInput.currentChar() === '^') { + c = '^^'; + parserInput.i++; + } + while (parserInput.isWhitespace()) { + parserInput.i++; + } + return new (tree.Combinator)(c); + } + else if (parserInput.isWhitespace(-1)) { + return new (tree.Combinator)(' '); + } + else { + return new (tree.Combinator)(null); + } + }, + // + // A CSS Selector + // with less extensions e.g. the ability to extend and guard + // + // .class > div + h1 + // li a:hover + // + // Selectors are made out of one or more Elements, see above. + // + selector: function (isLess) { + var index = parserInput.i; + var elements; + var extendList; + var c; + var e; + var allExtends; + var when; + var condition; + isLess = isLess !== false; + while ((isLess && (extendList = this.extend())) || (isLess && (when = parserInput.$str('when'))) || (e = this.element())) { + if (when) { + condition = expect(this.conditions, 'expected condition'); + } + else if (condition) { + error('CSS guard can only be used at the end of selector'); + } + else if (extendList) { + if (allExtends) { + allExtends = allExtends.concat(extendList); + } + else { + allExtends = extendList; + } + } + else { + if (allExtends) { + error('Extend can only be used at the end of selector'); + } + c = parserInput.currentChar(); + if (elements) { + elements.push(e); + } + else { + elements = [e]; + } + e = null; + } + if (c === '{' || c === '}' || c === ';' || c === ',' || c === ')') { + break; + } + } + if (elements) { + return new (tree.Selector)(elements, allExtends, condition, index, fileInfo); + } + if (allExtends) { + error('Extend must be used to extend a selector, it cannot be used on its own'); + } + }, + selectors: function () { + var s; + var selectors; + while (true) { + s = this.selector(); + if (!s) { + break; + } + if (selectors) { + selectors.push(s); + } + else { + selectors = [s]; + } + parserInput.commentStore.length = 0; + if (s.condition && selectors.length > 1) { + error("Guards are only currently allowed on a single selector."); + } + if (!parserInput.$char(',')) { + break; + } + if (s.condition) { + error("Guards are only currently allowed on a single selector."); + } + parserInput.commentStore.length = 0; + } + return selectors; + }, + attribute: function () { + if (!parserInput.$char('[')) { + return; + } + var entities = this.entities; + var key; + var val; + var op; + if (!(key = entities.variableCurly())) { + key = expect(/^(?:[_A-Za-z0-9-\*]*\|)?(?:[_A-Za-z0-9-]|\\.)+/); + } + op = parserInput.$re(/^[|~*$^]?=/); + if (op) { + val = entities.quoted() || parserInput.$re(/^[0-9]+%/) || parserInput.$re(/^[\w-]+/) || entities.variableCurly(); + } + expectChar(']'); + return new (tree.Attribute)(key, op, val); + }, + // + // The `block` rule is used by `ruleset` and `mixin.definition`. + // It's a wrapper around the `primary` rule, with added `{}`. + // + block: function () { + var content; + if (parserInput.$char('{') && (content = this.primary()) && parserInput.$char('}')) { + return content; + } + }, + blockRuleset: function () { + var block = this.block(); + if (block) { + block = new tree.Ruleset(null, block); + } + return block; + }, + detachedRuleset: function () { + var argInfo; + var params; + var variadic; + parserInput.save(); + if (parserInput.$re(/^[.#]\(/)) { + /** + * DR args currently only implemented for each() function, and not + * yet settable as `@dr: #(@arg) {}` + * This should be done when DRs are merged with mixins. + * See: https://github.com/less/less-meta/issues/16 + */ + argInfo = this.mixin.args(false); + params = argInfo.args; + variadic = argInfo.variadic; + if (!parserInput.$char(')')) { + parserInput.restore(); + return; + } + } + var blockRuleset = this.blockRuleset(); + if (blockRuleset) { + parserInput.forget(); + if (params) { + return new tree.mixin.Definition(null, params, blockRuleset, null, variadic); + } + return new tree.DetachedRuleset(blockRuleset); + } + parserInput.restore(); + }, + // + // div, .class, body > p {...} + // + ruleset: function () { + var selectors; + var rules; + var debugInfo; + parserInput.save(); + if (context.dumpLineNumbers) { + debugInfo = getDebugInfo(parserInput.i); + } + selectors = this.selectors(); + if (selectors && (rules = this.block())) { + parserInput.forget(); + var ruleset = new (tree.Ruleset)(selectors, rules, context.strictImports); + if (context.dumpLineNumbers) { + ruleset.debugInfo = debugInfo; + } + return ruleset; + } + else { + parserInput.restore(); + } + }, + declaration: function () { + var name; + var value; + var index = parserInput.i; + var hasDR; + var c = parserInput.currentChar(); + var important; + var merge; + var isVariable; + if (c === '.' || c === '#' || c === '&' || c === ':') { + return; + } + parserInput.save(); + name = this.variable() || this.ruleProperty(); + if (name) { + isVariable = typeof name === 'string'; + if (isVariable) { + value = this.detachedRuleset(); + if (value) { + hasDR = true; + } + } + parserInput.commentStore.length = 0; + if (!value) { + // a name returned by this.ruleProperty() is always an array of the form: + // [string-1, ..., string-n, ""] or [string-1, ..., string-n, "+"] + // where each item is a tree.Keyword or tree.Variable + merge = !isVariable && name.length > 1 && name.pop().value; + // Custom property values get permissive parsing + if (name[0].value && name[0].value.slice(0, 2) === '--') { + value = this.permissiveValue(); + } + // Try to store values as anonymous + // If we need the value later we'll re-parse it in ruleset.parseValue + else { + value = this.anonymousValue(); + } + if (value) { + parserInput.forget(); + // anonymous values absorb the end ';' which is required for them to work + return new (tree.Declaration)(name, value, false, merge, index, fileInfo); + } + if (!value) { + value = this.value(); + } + if (value) { + important = this.important(); + } + else if (isVariable) { + // As a last resort, try permissiveValue + value = this.permissiveValue(); + } + } + if (value && (this.end() || hasDR)) { + parserInput.forget(); + return new (tree.Declaration)(name, value, important, merge, index, fileInfo); + } + else { + parserInput.restore(); + } + } + else { + parserInput.restore(); + } + }, + anonymousValue: function () { + var index = parserInput.i; + var match = parserInput.$re(/^([^.#@\$+\/'"*`(;{}-]*);/); + if (match) { + return new (tree.Anonymous)(match[1], index); + } + }, + /** + * Used for custom properties, at-rules, and variables (as fallback) + * Parses almost anything inside of {} [] () "" blocks + * until it reaches outer-most tokens. + * + * First, it will try to parse comments and entities to reach + * the end. This is mostly like the Expression parser except no + * math is allowed. + */ + permissiveValue: function (untilTokens) { + var i; + var e; + var done; + var value; + var tok = untilTokens || ';'; + var index = parserInput.i; + var result = []; + function testCurrentChar() { + var char = parserInput.currentChar(); + if (typeof tok === 'string') { + return char === tok; + } + else { + return tok.test(char); + } + } + if (testCurrentChar()) { + return; + } + value = []; + do { + e = this.comment(); + if (e) { + value.push(e); + continue; + } + e = this.entity(); + if (e) { + value.push(e); + } + } while (e); + done = testCurrentChar(); + if (value.length > 0) { + value = new (tree.Expression)(value); + if (done) { + return value; + } + else { + result.push(value); + } + // Preserve space before $parseUntil as it will not + if (parserInput.prevChar() === ' ') { + result.push(new tree.Anonymous(' ', index)); + } + } + parserInput.save(); + value = parserInput.$parseUntil(tok); + if (value) { + if (typeof value === 'string') { + error("Expected '" + value + "'", 'Parse'); + } + if (value.length === 1 && value[0] === ' ') { + parserInput.forget(); + return new tree.Anonymous('', index); + } + var item = void 0; + for (i = 0; i < value.length; i++) { + item = value[i]; + if (Array.isArray(item)) { + // Treat actual quotes as normal quoted values + result.push(new tree.Quoted(item[0], item[1], true, index, fileInfo)); + } + else { + if (i === value.length - 1) { + item = item.trim(); + } + // Treat like quoted values, but replace vars like unquoted expressions + var quote = new tree.Quoted('\'', item, true, index, fileInfo); + quote.variableRegex = /@([\w-]+)/g; + quote.propRegex = /\$([\w-]+)/g; + result.push(quote); + } + } + parserInput.forget(); + return new tree.Expression(result, true); + } + parserInput.restore(); + }, + // + // An @import atrule + // + // @import "lib"; + // + // Depending on our environment, importing is done differently: + // In the browser, it's an XHR request, in Node, it would be a + // file-system operation. The function used for importing is + // stored in `import`, which we pass to the Import constructor. + // + 'import': function () { + var path; + var features; + var index = parserInput.i; + var dir = parserInput.$re(/^@import?\s+/); + if (dir) { + var options = (dir ? this.importOptions() : null) || {}; + if ((path = this.entities.quoted() || this.entities.url())) { + features = this.mediaFeatures(); + if (!parserInput.$char(';')) { + parserInput.i = index; + error('missing semi-colon or unrecognised media features on import'); + } + features = features && new (tree.Value)(features); + return new (tree.Import)(path, features, options, index, fileInfo); + } + else { + parserInput.i = index; + error('malformed import statement'); + } + } + }, + importOptions: function () { + var o; + var options = {}; + var optionName; + var value; + // list of options, surrounded by parens + if (!parserInput.$char('(')) { + return null; + } + do { + o = this.importOption(); + if (o) { + optionName = o; + value = true; + switch (optionName) { + case 'css': + optionName = 'less'; + value = false; + break; + case 'once': + optionName = 'multiple'; + value = false; + break; + } + options[optionName] = value; + if (!parserInput.$char(',')) { + break; + } + } + } while (o); + expectChar(')'); + return options; + }, + importOption: function () { + var opt = parserInput.$re(/^(less|css|multiple|once|inline|reference|optional)/); + if (opt) { + return opt[1]; + } + }, + mediaFeature: function () { + var entities = this.entities; + var nodes = []; + var e; + var p; + parserInput.save(); + do { + e = entities.keyword() || entities.variable() || entities.mixinLookup(); + if (e) { + nodes.push(e); + } + else if (parserInput.$char('(')) { + p = this.property(); + e = this.value(); + if (parserInput.$char(')')) { + if (p && e) { + nodes.push(new (tree.Paren)(new (tree.Declaration)(p, e, null, null, parserInput.i, fileInfo, true))); + } + else if (e) { + nodes.push(new (tree.Paren)(e)); + } + else { + error('badly formed media feature definition'); + } + } + else { + error('Missing closing \')\'', 'Parse'); + } + } + } while (e); + parserInput.forget(); + if (nodes.length > 0) { + return new (tree.Expression)(nodes); + } + }, + mediaFeatures: function () { + var entities = this.entities; + var features = []; + var e; + do { + e = this.mediaFeature(); + if (e) { + features.push(e); + if (!parserInput.$char(',')) { + break; + } + } + else { + e = entities.variable() || entities.mixinLookup(); + if (e) { + features.push(e); + if (!parserInput.$char(',')) { + break; + } + } + } + } while (e); + return features.length > 0 ? features : null; + }, + media: function () { + var features; + var rules; + var media; + var debugInfo; + var index = parserInput.i; + if (context.dumpLineNumbers) { + debugInfo = getDebugInfo(index); + } + parserInput.save(); + if (parserInput.$str('@media')) { + features = this.mediaFeatures(); + rules = this.block(); + if (!rules) { + error('media definitions require block statements after any features'); + } + parserInput.forget(); + media = new (tree.Media)(rules, features, index, fileInfo); + if (context.dumpLineNumbers) { + media.debugInfo = debugInfo; + } + return media; + } + parserInput.restore(); + }, + // + // A @plugin directive, used to import plugins dynamically. + // + // @plugin (args) "lib"; + // + plugin: function () { + var path; + var args; + var options; + var index = parserInput.i; + var dir = parserInput.$re(/^@plugin?\s+/); + if (dir) { + args = this.pluginArgs(); + if (args) { + options = { + pluginArgs: args, + isPlugin: true + }; + } + else { + options = { isPlugin: true }; + } + if ((path = this.entities.quoted() || this.entities.url())) { + if (!parserInput.$char(';')) { + parserInput.i = index; + error('missing semi-colon on @plugin'); + } + return new (tree.Import)(path, null, options, index, fileInfo); + } + else { + parserInput.i = index; + error('malformed @plugin statement'); + } + } + }, + pluginArgs: function () { + // list of options, surrounded by parens + parserInput.save(); + if (!parserInput.$char('(')) { + parserInput.restore(); + return null; + } + var args = parserInput.$re(/^\s*([^\);]+)\)\s*/); + if (args[1]) { + parserInput.forget(); + return args[1].trim(); + } + else { + parserInput.restore(); + return null; + } + }, + // + // A CSS AtRule + // + // @charset "utf-8"; + // + atrule: function () { + var index = parserInput.i; + var name; + var value; + var rules; + var nonVendorSpecificName; + var hasIdentifier; + var hasExpression; + var hasUnknown; + var hasBlock = true; + var isRooted = true; + if (parserInput.currentChar() !== '@') { + return; + } + value = this['import']() || this.plugin() || this.media(); + if (value) { + return value; + } + parserInput.save(); + name = parserInput.$re(/^@[a-z-]+/); + if (!name) { + return; + } + nonVendorSpecificName = name; + if (name.charAt(1) == '-' && name.indexOf('-', 2) > 0) { + nonVendorSpecificName = "@" + name.slice(name.indexOf('-', 2) + 1); + } + switch (nonVendorSpecificName) { + case '@charset': + hasIdentifier = true; + hasBlock = false; + break; + case '@namespace': + hasExpression = true; + hasBlock = false; + break; + case '@keyframes': + case '@counter-style': + hasIdentifier = true; + break; + case '@document': + case '@supports': + hasUnknown = true; + isRooted = false; + break; + default: + hasUnknown = true; + break; + } + parserInput.commentStore.length = 0; + if (hasIdentifier) { + value = this.entity(); + if (!value) { + error("expected " + name + " identifier"); + } + } + else if (hasExpression) { + value = this.expression(); + if (!value) { + error("expected " + name + " expression"); + } + } + else if (hasUnknown) { + value = this.permissiveValue(/^[{;]/); + hasBlock = (parserInput.currentChar() === '{'); + if (!value) { + if (!hasBlock && parserInput.currentChar() !== ';') { + error(name + " rule is missing block or ending semi-colon"); + } + } + else if (!value.value) { + value = null; + } + } + if (hasBlock) { + rules = this.blockRuleset(); + } + if (rules || (!hasBlock && value && parserInput.$char(';'))) { + parserInput.forget(); + return new (tree.AtRule)(name, value, rules, index, fileInfo, context.dumpLineNumbers ? getDebugInfo(index) : null, isRooted); + } + parserInput.restore('at-rule options not recognised'); + }, + // + // A Value is a comma-delimited list of Expressions + // + // font-family: Baskerville, Georgia, serif; + // + // In a Rule, a Value represents everything after the `:`, + // and before the `;`. + // + value: function () { + var e; + var expressions = []; + var index = parserInput.i; + do { + e = this.expression(); + if (e) { + expressions.push(e); + if (!parserInput.$char(',')) { + break; + } + } + } while (e); + if (expressions.length > 0) { + return new (tree.Value)(expressions, index); + } + }, + important: function () { + if (parserInput.currentChar() === '!') { + return parserInput.$re(/^! *important/); + } + }, + sub: function () { + var a; + var e; + parserInput.save(); + if (parserInput.$char('(')) { + a = this.addition(); + if (a && parserInput.$char(')')) { + parserInput.forget(); + e = new (tree.Expression)([a]); + e.parens = true; + return e; + } + parserInput.restore('Expected \')\''); + return; + } + parserInput.restore(); + }, + multiplication: function () { + var m; + var a; + var op; + var operation; + var isSpaced; + m = this.operand(); + if (m) { + isSpaced = parserInput.isWhitespace(-1); + while (true) { + if (parserInput.peek(/^\/[*\/]/)) { + break; + } + parserInput.save(); + op = parserInput.$char('/') || parserInput.$char('*') || parserInput.$str('./'); + if (!op) { + parserInput.forget(); + break; + } + a = this.operand(); + if (!a) { + parserInput.restore(); + break; + } + parserInput.forget(); + m.parensInOp = true; + a.parensInOp = true; + operation = new (tree.Operation)(op, [operation || m, a], isSpaced); + isSpaced = parserInput.isWhitespace(-1); + } + return operation || m; + } + }, + addition: function () { + var m; + var a; + var op; + var operation; + var isSpaced; + m = this.multiplication(); + if (m) { + isSpaced = parserInput.isWhitespace(-1); + while (true) { + op = parserInput.$re(/^[-+]\s+/) || (!isSpaced && (parserInput.$char('+') || parserInput.$char('-'))); + if (!op) { + break; + } + a = this.multiplication(); + if (!a) { + break; + } + m.parensInOp = true; + a.parensInOp = true; + operation = new (tree.Operation)(op, [operation || m, a], isSpaced); + isSpaced = parserInput.isWhitespace(-1); + } + return operation || m; + } + }, + conditions: function () { + var a; + var b; + var index = parserInput.i; + var condition; + a = this.condition(true); + if (a) { + while (true) { + if (!parserInput.peek(/^,\s*(not\s*)?\(/) || !parserInput.$char(',')) { + break; + } + b = this.condition(true); + if (!b) { + break; + } + condition = new (tree.Condition)('or', condition || a, b, index); + } + return condition || a; + } + }, + condition: function (needsParens) { + var result; + var logical; + var next; + function or() { + return parserInput.$str('or'); + } + result = this.conditionAnd(needsParens); + if (!result) { + return; + } + logical = or(); + if (logical) { + next = this.condition(needsParens); + if (next) { + result = new (tree.Condition)(logical, result, next); + } + else { + return; + } + } + return result; + }, + conditionAnd: function (needsParens) { + var result; + var logical; + var next; + var self = this; + function insideCondition() { + var cond = self.negatedCondition(needsParens) || self.parenthesisCondition(needsParens); + if (!cond && !needsParens) { + return self.atomicCondition(needsParens); + } + return cond; + } + function and() { + return parserInput.$str('and'); + } + result = insideCondition(); + if (!result) { + return; + } + logical = and(); + if (logical) { + next = this.conditionAnd(needsParens); + if (next) { + result = new (tree.Condition)(logical, result, next); + } + else { + return; + } + } + return result; + }, + negatedCondition: function (needsParens) { + if (parserInput.$str('not')) { + var result = this.parenthesisCondition(needsParens); + if (result) { + result.negate = !result.negate; + } + return result; + } + }, + parenthesisCondition: function (needsParens) { + function tryConditionFollowedByParenthesis(me) { + var body; + parserInput.save(); + body = me.condition(needsParens); + if (!body) { + parserInput.restore(); + return; + } + if (!parserInput.$char(')')) { + parserInput.restore(); + return; + } + parserInput.forget(); + return body; + } + var body; + parserInput.save(); + if (!parserInput.$str('(')) { + parserInput.restore(); + return; + } + body = tryConditionFollowedByParenthesis(this); + if (body) { + parserInput.forget(); + return body; + } + body = this.atomicCondition(needsParens); + if (!body) { + parserInput.restore(); + return; + } + if (!parserInput.$char(')')) { + parserInput.restore("expected ')' got '" + parserInput.currentChar() + "'"); + return; + } + parserInput.forget(); + return body; + }, + atomicCondition: function (needsParens) { + var entities = this.entities; + var index = parserInput.i; + var a; + var b; + var c; + var op; + function cond() { + return this.addition() || entities.keyword() || entities.quoted() || entities.mixinLookup(); + } + cond = cond.bind(this); + a = cond(); + if (a) { + if (parserInput.$char('>')) { + if (parserInput.$char('=')) { + op = '>='; + } + else { + op = '>'; + } + } + else if (parserInput.$char('<')) { + if (parserInput.$char('=')) { + op = '<='; + } + else { + op = '<'; + } + } + else if (parserInput.$char('=')) { + if (parserInput.$char('>')) { + op = '=>'; + } + else if (parserInput.$char('<')) { + op = '=<'; + } + else { + op = '='; + } + } + if (op) { + b = cond(); + if (b) { + c = new (tree.Condition)(op, a, b, index, false); + } + else { + error('expected expression'); + } + } + else { + c = new (tree.Condition)('=', a, new (tree.Keyword)('true'), index, false); + } + return c; + } + }, + // + // An operand is anything that can be part of an operation, + // such as a Color, or a Variable + // + operand: function () { + var entities = this.entities; + var negate; + if (parserInput.peek(/^-[@\$\(]/)) { + negate = parserInput.$char('-'); + } + var o = this.sub() || entities.dimension() || + entities.color() || entities.variable() || + entities.property() || entities.call() || + entities.quoted(true) || entities.colorKeyword() || + entities.mixinLookup(); + if (negate) { + o.parensInOp = true; + o = new (tree.Negative)(o); + } + return o; + }, + // + // Expressions either represent mathematical operations, + // or white-space delimited Entities. + // + // 1px solid black + // @var * 2 + // + expression: function () { + var entities = []; + var e; + var delim; + var index = parserInput.i; + do { + e = this.comment(); + if (e) { + entities.push(e); + continue; + } + e = this.addition() || this.entity(); + if (e instanceof tree.Comment) { + e = null; + } + if (e) { + entities.push(e); + // operations do not allow keyword "/" dimension (e.g. small/20px) so we support that here + if (!parserInput.peek(/^\/[\/*]/)) { + delim = parserInput.$char('/'); + if (delim) { + entities.push(new (tree.Anonymous)(delim, index)); + } + } + } + } while (e); + if (entities.length > 0) { + return new (tree.Expression)(entities); + } + }, + property: function () { + var name = parserInput.$re(/^(\*?-?[_a-zA-Z0-9-]+)\s*:/); + if (name) { + return name[1]; + } + }, + ruleProperty: function () { + var name = []; + var index = []; + var s; + var k; + parserInput.save(); + var simpleProperty = parserInput.$re(/^([_a-zA-Z0-9-]+)\s*:/); + if (simpleProperty) { + name = [new (tree.Keyword)(simpleProperty[1])]; + parserInput.forget(); + return name; + } + function match(re) { + var i = parserInput.i; + var chunk = parserInput.$re(re); + if (chunk) { + index.push(i); + return name.push(chunk[1]); + } + } + match(/^(\*?)/); + while (true) { + if (!match(/^((?:[\w-]+)|(?:[@\$]\{[\w-]+\}))/)) { + break; + } + } + if ((name.length > 1) && match(/^((?:\+_|\+)?)\s*:/)) { + parserInput.forget(); + // at last, we have the complete match now. move forward, + // convert name particles to tree objects and return: + if (name[0] === '') { + name.shift(); + index.shift(); + } + for (k = 0; k < name.length; k++) { + s = name[k]; + name[k] = (s.charAt(0) !== '@' && s.charAt(0) !== '$') ? + new (tree.Keyword)(s) : + (s.charAt(0) === '@' ? + new (tree.Variable)("@" + s.slice(2, -1), index[k], fileInfo) : + new (tree.Property)("$" + s.slice(2, -1), index[k], fileInfo)); + } + return name; + } + parserInput.restore(); + } + } + }; + }; + Parser.serializeVars = function (vars) { + var s = ''; + for (var name_1 in vars) { + if (Object.hasOwnProperty.call(vars, name_1)) { + var value = vars[name_1]; + s += ((name_1[0] === '@') ? '' : '@') + name_1 + ": " + value + ((String(value).slice(-1) === ';') ? '' : ';'); + } + } + return s; + }; - function boolean(condition) { - return condition ? Keyword.True : Keyword.False; - } - /** - * Functions with evalArgs set to false are sent context - * as the first argument. - */ - function If(context, condition, trueValue, falseValue) { - return condition.eval(context) ? trueValue.eval(context) - : (falseValue ? falseValue.eval(context) : new Anonymous); - } - If.evalArgs = false; - var boolean$1 = { boolean: boolean, 'if': If }; + function boolean(condition) { + return condition ? Keyword.True : Keyword.False; + } + /** + * Functions with evalArgs set to false are sent context + * as the first argument. + */ + function If(context, condition, trueValue, falseValue) { + return condition.eval(context) ? trueValue.eval(context) + : (falseValue ? falseValue.eval(context) : new Anonymous); + } + If.evalArgs = false; + function isdefined(context, variable) { + try { + variable.eval(context); + return Keyword.True; + } + catch (e) { + return Keyword.False; + } + } + isdefined.evalArgs = false; + var boolean$1 = { isdefined: isdefined, boolean: boolean, 'if': If }; - var colorFunctions; - function clamp$1(val) { - return Math.min(1, Math.max(0, val)); - } - function hsla(origColor, hsl) { - var color = colorFunctions.hsla(hsl.h, hsl.s, hsl.l, hsl.a); - if (color) { - if (origColor.value && - /^(rgb|hsl)/.test(origColor.value)) { - color.value = origColor.value; - } - else { - color.value = 'rgb'; - } - return color; - } - } - function toHSL(color) { - if (color.toHSL) { - return color.toHSL(); - } - else { - throw new Error('Argument cannot be evaluated to a color'); - } - } - function toHSV(color) { - if (color.toHSV) { - return color.toHSV(); - } - else { - throw new Error('Argument cannot be evaluated to a color'); - } - } - function number(n) { - if (n instanceof Dimension) { - return parseFloat(n.unit.is('%') ? n.value / 100 : n.value); - } - else if (typeof n === 'number') { - return n; - } - else { - throw { - type: 'Argument', - message: 'color functions take numbers as parameters' - }; - } - } - function scaled(n, size) { - if (n instanceof Dimension && n.unit.is('%')) { - return parseFloat(n.value * size / 100); - } - else { - return number(n); - } - } - colorFunctions = { - rgb: function (r, g, b) { - var color = colorFunctions.rgba(r, g, b, 1.0); - if (color) { - color.value = 'rgb'; - return color; - } - }, - rgba: function (r, g, b, a) { - try { - if (r instanceof Color) { - if (g) { - a = number(g); - } - else { - a = r.alpha; - } - return new Color(r.rgb, a, 'rgba'); - } - var rgb = [r, g, b].map(function (c) { return scaled(c, 255); }); - a = number(a); - return new Color(rgb, a, 'rgba'); - } - catch (e) { } - }, - hsl: function (h, s, l) { - var color = colorFunctions.hsla(h, s, l, 1.0); - if (color) { - color.value = 'hsl'; - return color; - } - }, - hsla: function (h, s, l, a) { - try { - if (h instanceof Color) { - if (s) { - a = number(s); - } - else { - a = h.alpha; - } - return new Color(h.rgb, a, 'hsla'); - } - var m1_1; - var m2_1; - function hue(h) { - h = h < 0 ? h + 1 : (h > 1 ? h - 1 : h); - if (h * 6 < 1) { - return m1_1 + (m2_1 - m1_1) * h * 6; - } - else if (h * 2 < 1) { - return m2_1; - } - else if (h * 3 < 2) { - return m1_1 + (m2_1 - m1_1) * (2 / 3 - h) * 6; - } - else { - return m1_1; - } - } - h = (number(h) % 360) / 360; - s = clamp$1(number(s)); - l = clamp$1(number(l)); - a = clamp$1(number(a)); - m2_1 = l <= 0.5 ? l * (s + 1) : l + s - l * s; - m1_1 = l * 2 - m2_1; - var rgb = [ - hue(h + 1 / 3) * 255, - hue(h) * 255, - hue(h - 1 / 3) * 255 - ]; - a = number(a); - return new Color(rgb, a, 'hsla'); - } - catch (e) { } - }, - hsv: function (h, s, v) { - return colorFunctions.hsva(h, s, v, 1.0); - }, - hsva: function (h, s, v, a) { - h = ((number(h) % 360) / 360) * 360; - s = number(s); - v = number(v); - a = number(a); - var i; - var f; - i = Math.floor((h / 60) % 6); - f = (h / 60) - i; - var vs = [v, - v * (1 - s), - v * (1 - f * s), - v * (1 - (1 - f) * s)]; - var perm = [[0, 3, 1], - [2, 0, 1], - [1, 0, 3], - [1, 2, 0], - [3, 1, 0], - [0, 1, 2]]; - return colorFunctions.rgba(vs[perm[i][0]] * 255, vs[perm[i][1]] * 255, vs[perm[i][2]] * 255, a); - }, - hue: function (color) { - return new Dimension(toHSL(color).h); - }, - saturation: function (color) { - return new Dimension(toHSL(color).s * 100, '%'); - }, - lightness: function (color) { - return new Dimension(toHSL(color).l * 100, '%'); - }, - hsvhue: function (color) { - return new Dimension(toHSV(color).h); - }, - hsvsaturation: function (color) { - return new Dimension(toHSV(color).s * 100, '%'); - }, - hsvvalue: function (color) { - return new Dimension(toHSV(color).v * 100, '%'); - }, - red: function (color) { - return new Dimension(color.rgb[0]); - }, - green: function (color) { - return new Dimension(color.rgb[1]); - }, - blue: function (color) { - return new Dimension(color.rgb[2]); - }, - alpha: function (color) { - return new Dimension(toHSL(color).a); - }, - luma: function (color) { - return new Dimension(color.luma() * color.alpha * 100, '%'); - }, - luminance: function (color) { - var luminance = (0.2126 * color.rgb[0] / 255) + - (0.7152 * color.rgb[1] / 255) + - (0.0722 * color.rgb[2] / 255); - return new Dimension(luminance * color.alpha * 100, '%'); - }, - saturate: function (color, amount, method) { - // filter: saturate(3.2); - // should be kept as is, so check for color - if (!color.rgb) { - return null; - } - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.s += hsl.s * amount.value / 100; - } - else { - hsl.s += amount.value / 100; - } - hsl.s = clamp$1(hsl.s); - return hsla(color, hsl); - }, - desaturate: function (color, amount, method) { - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.s -= hsl.s * amount.value / 100; - } - else { - hsl.s -= amount.value / 100; - } - hsl.s = clamp$1(hsl.s); - return hsla(color, hsl); - }, - lighten: function (color, amount, method) { - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.l += hsl.l * amount.value / 100; - } - else { - hsl.l += amount.value / 100; - } - hsl.l = clamp$1(hsl.l); - return hsla(color, hsl); - }, - darken: function (color, amount, method) { - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.l -= hsl.l * amount.value / 100; - } - else { - hsl.l -= amount.value / 100; - } - hsl.l = clamp$1(hsl.l); - return hsla(color, hsl); - }, - fadein: function (color, amount, method) { - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.a += hsl.a * amount.value / 100; - } - else { - hsl.a += amount.value / 100; - } - hsl.a = clamp$1(hsl.a); - return hsla(color, hsl); - }, - fadeout: function (color, amount, method) { - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.a -= hsl.a * amount.value / 100; - } - else { - hsl.a -= amount.value / 100; - } - hsl.a = clamp$1(hsl.a); - return hsla(color, hsl); - }, - fade: function (color, amount) { - var hsl = toHSL(color); - hsl.a = amount.value / 100; - hsl.a = clamp$1(hsl.a); - return hsla(color, hsl); - }, - spin: function (color, amount) { - var hsl = toHSL(color); - var hue = (hsl.h + amount.value) % 360; - hsl.h = hue < 0 ? 360 + hue : hue; - return hsla(color, hsl); - }, - // - // Copyright (c) 2006-2009 Hampton Catlin, Natalie Weizenbaum, and Chris Eppstein - // http://sass-lang.com - // - mix: function (color1, color2, weight) { - if (!weight) { - weight = new Dimension(50); - } - var p = weight.value / 100.0; - var w = p * 2 - 1; - var a = toHSL(color1).a - toHSL(color2).a; - var w1 = (((w * a == -1) ? w : (w + a) / (1 + w * a)) + 1) / 2.0; - var w2 = 1 - w1; - var rgb = [color1.rgb[0] * w1 + color2.rgb[0] * w2, - color1.rgb[1] * w1 + color2.rgb[1] * w2, - color1.rgb[2] * w1 + color2.rgb[2] * w2]; - var alpha = color1.alpha * p + color2.alpha * (1 - p); - return new Color(rgb, alpha); - }, - greyscale: function (color) { - return colorFunctions.desaturate(color, new Dimension(100)); - }, - contrast: function (color, dark, light, threshold) { - // filter: contrast(3.2); - // should be kept as is, so check for color - if (!color.rgb) { - return null; - } - if (typeof light === 'undefined') { - light = colorFunctions.rgba(255, 255, 255, 1.0); - } - if (typeof dark === 'undefined') { - dark = colorFunctions.rgba(0, 0, 0, 1.0); - } - // Figure out which is actually light and dark: - if (dark.luma() > light.luma()) { - var t = light; - light = dark; - dark = t; - } - if (typeof threshold === 'undefined') { - threshold = 0.43; - } - else { - threshold = number(threshold); - } - if (color.luma() < threshold) { - return light; - } - else { - return dark; - } - }, - // Changes made in 2.7.0 - Reverted in 3.0.0 - // contrast: function (color, color1, color2, threshold) { - // // Return which of `color1` and `color2` has the greatest contrast with `color` - // // according to the standard WCAG contrast ratio calculation. - // // http://www.w3.org/TR/WCAG20/#contrast-ratiodef - // // The threshold param is no longer used, in line with SASS. - // // filter: contrast(3.2); - // // should be kept as is, so check for color - // if (!color.rgb) { - // return null; - // } - // if (typeof color1 === 'undefined') { - // color1 = colorFunctions.rgba(0, 0, 0, 1.0); - // } - // if (typeof color2 === 'undefined') { - // color2 = colorFunctions.rgba(255, 255, 255, 1.0); - // } - // var contrast1, contrast2; - // var luma = color.luma(); - // var luma1 = color1.luma(); - // var luma2 = color2.luma(); - // // Calculate contrast ratios for each color - // if (luma > luma1) { - // contrast1 = (luma + 0.05) / (luma1 + 0.05); - // } else { - // contrast1 = (luma1 + 0.05) / (luma + 0.05); - // } - // if (luma > luma2) { - // contrast2 = (luma + 0.05) / (luma2 + 0.05); - // } else { - // contrast2 = (luma2 + 0.05) / (luma + 0.05); - // } - // if (contrast1 > contrast2) { - // return color1; - // } else { - // return color2; - // } - // }, - argb: function (color) { - return new Anonymous(color.toARGB()); - }, - color: function (c) { - if ((c instanceof Quoted) && - (/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})$/i.test(c.value))) { - var val = c.value.slice(1); - return new Color(val, undefined, "#" + val); - } - if ((c instanceof Color) || (c = Color.fromKeyword(c.value))) { - c.value = undefined; - return c; - } - throw { - type: 'Argument', - message: 'argument must be a color keyword or 3|4|6|8 digit hex e.g. #FFF' - }; - }, - tint: function (color, amount) { - return colorFunctions.mix(colorFunctions.rgb(255, 255, 255), color, amount); - }, - shade: function (color, amount) { - return colorFunctions.mix(colorFunctions.rgb(0, 0, 0), color, amount); - } - }; - var color = colorFunctions; + var colorFunctions; + function clamp$1(val) { + return Math.min(1, Math.max(0, val)); + } + function hsla(origColor, hsl) { + var color = colorFunctions.hsla(hsl.h, hsl.s, hsl.l, hsl.a); + if (color) { + if (origColor.value && + /^(rgb|hsl)/.test(origColor.value)) { + color.value = origColor.value; + } + else { + color.value = 'rgb'; + } + return color; + } + } + function toHSL(color) { + if (color.toHSL) { + return color.toHSL(); + } + else { + throw new Error('Argument cannot be evaluated to a color'); + } + } + function toHSV(color) { + if (color.toHSV) { + return color.toHSV(); + } + else { + throw new Error('Argument cannot be evaluated to a color'); + } + } + function number(n) { + if (n instanceof Dimension) { + return parseFloat(n.unit.is('%') ? n.value / 100 : n.value); + } + else if (typeof n === 'number') { + return n; + } + else { + throw { + type: 'Argument', + message: 'color functions take numbers as parameters' + }; + } + } + function scaled(n, size) { + if (n instanceof Dimension && n.unit.is('%')) { + return parseFloat(n.value * size / 100); + } + else { + return number(n); + } + } + colorFunctions = { + rgb: function (r, g, b) { + var a = 1; + /** + * Comma-less syntax + * e.g. rgb(0 128 255 / 50%) + */ + if (r instanceof Expression) { + var val = r.value; + r = val[0]; + g = val[1]; + b = val[2]; + /** + * @todo - should this be normalized in + * function caller? Or parsed differently? + */ + if (b instanceof Operation) { + var op = b; + b = op.operands[0]; + a = op.operands[1]; + } + } + var color = colorFunctions.rgba(r, g, b, a); + if (color) { + color.value = 'rgb'; + return color; + } + }, + rgba: function (r, g, b, a) { + try { + if (r instanceof Color) { + if (g) { + a = number(g); + } + else { + a = r.alpha; + } + return new Color(r.rgb, a, 'rgba'); + } + var rgb = [r, g, b].map(function (c) { return scaled(c, 255); }); + a = number(a); + return new Color(rgb, a, 'rgba'); + } + catch (e) { } + }, + hsl: function (h, s, l) { + var a = 1; + if (h instanceof Expression) { + var val = h.value; + h = val[0]; + s = val[1]; + l = val[2]; + if (l instanceof Operation) { + var op = l; + l = op.operands[0]; + a = op.operands[1]; + } + } + var color = colorFunctions.hsla(h, s, l, a); + if (color) { + color.value = 'hsl'; + return color; + } + }, + hsla: function (h, s, l, a) { + try { + if (h instanceof Color) { + if (s) { + a = number(s); + } + else { + a = h.alpha; + } + return new Color(h.rgb, a, 'hsla'); + } + var m1_1; + var m2_1; + function hue(h) { + h = h < 0 ? h + 1 : (h > 1 ? h - 1 : h); + if (h * 6 < 1) { + return m1_1 + (m2_1 - m1_1) * h * 6; + } + else if (h * 2 < 1) { + return m2_1; + } + else if (h * 3 < 2) { + return m1_1 + (m2_1 - m1_1) * (2 / 3 - h) * 6; + } + else { + return m1_1; + } + } + h = (number(h) % 360) / 360; + s = clamp$1(number(s)); + l = clamp$1(number(l)); + a = clamp$1(number(a)); + m2_1 = l <= 0.5 ? l * (s + 1) : l + s - l * s; + m1_1 = l * 2 - m2_1; + var rgb = [ + hue(h + 1 / 3) * 255, + hue(h) * 255, + hue(h - 1 / 3) * 255 + ]; + a = number(a); + return new Color(rgb, a, 'hsla'); + } + catch (e) { } + }, + hsv: function (h, s, v) { + return colorFunctions.hsva(h, s, v, 1.0); + }, + hsva: function (h, s, v, a) { + h = ((number(h) % 360) / 360) * 360; + s = number(s); + v = number(v); + a = number(a); + var i; + var f; + i = Math.floor((h / 60) % 6); + f = (h / 60) - i; + var vs = [v, + v * (1 - s), + v * (1 - f * s), + v * (1 - (1 - f) * s)]; + var perm = [[0, 3, 1], + [2, 0, 1], + [1, 0, 3], + [1, 2, 0], + [3, 1, 0], + [0, 1, 2]]; + return colorFunctions.rgba(vs[perm[i][0]] * 255, vs[perm[i][1]] * 255, vs[perm[i][2]] * 255, a); + }, + hue: function (color) { + return new Dimension(toHSL(color).h); + }, + saturation: function (color) { + return new Dimension(toHSL(color).s * 100, '%'); + }, + lightness: function (color) { + return new Dimension(toHSL(color).l * 100, '%'); + }, + hsvhue: function (color) { + return new Dimension(toHSV(color).h); + }, + hsvsaturation: function (color) { + return new Dimension(toHSV(color).s * 100, '%'); + }, + hsvvalue: function (color) { + return new Dimension(toHSV(color).v * 100, '%'); + }, + red: function (color) { + return new Dimension(color.rgb[0]); + }, + green: function (color) { + return new Dimension(color.rgb[1]); + }, + blue: function (color) { + return new Dimension(color.rgb[2]); + }, + alpha: function (color) { + return new Dimension(toHSL(color).a); + }, + luma: function (color) { + return new Dimension(color.luma() * color.alpha * 100, '%'); + }, + luminance: function (color) { + var luminance = (0.2126 * color.rgb[0] / 255) + + (0.7152 * color.rgb[1] / 255) + + (0.0722 * color.rgb[2] / 255); + return new Dimension(luminance * color.alpha * 100, '%'); + }, + saturate: function (color, amount, method) { + // filter: saturate(3.2); + // should be kept as is, so check for color + if (!color.rgb) { + return null; + } + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.s += hsl.s * amount.value / 100; + } + else { + hsl.s += amount.value / 100; + } + hsl.s = clamp$1(hsl.s); + return hsla(color, hsl); + }, + desaturate: function (color, amount, method) { + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.s -= hsl.s * amount.value / 100; + } + else { + hsl.s -= amount.value / 100; + } + hsl.s = clamp$1(hsl.s); + return hsla(color, hsl); + }, + lighten: function (color, amount, method) { + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.l += hsl.l * amount.value / 100; + } + else { + hsl.l += amount.value / 100; + } + hsl.l = clamp$1(hsl.l); + return hsla(color, hsl); + }, + darken: function (color, amount, method) { + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.l -= hsl.l * amount.value / 100; + } + else { + hsl.l -= amount.value / 100; + } + hsl.l = clamp$1(hsl.l); + return hsla(color, hsl); + }, + fadein: function (color, amount, method) { + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.a += hsl.a * amount.value / 100; + } + else { + hsl.a += amount.value / 100; + } + hsl.a = clamp$1(hsl.a); + return hsla(color, hsl); + }, + fadeout: function (color, amount, method) { + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.a -= hsl.a * amount.value / 100; + } + else { + hsl.a -= amount.value / 100; + } + hsl.a = clamp$1(hsl.a); + return hsla(color, hsl); + }, + fade: function (color, amount) { + var hsl = toHSL(color); + hsl.a = amount.value / 100; + hsl.a = clamp$1(hsl.a); + return hsla(color, hsl); + }, + spin: function (color, amount) { + var hsl = toHSL(color); + var hue = (hsl.h + amount.value) % 360; + hsl.h = hue < 0 ? 360 + hue : hue; + return hsla(color, hsl); + }, + // + // Copyright (c) 2006-2009 Hampton Catlin, Natalie Weizenbaum, and Chris Eppstein + // http://sass-lang.com + // + mix: function (color1, color2, weight) { + if (!weight) { + weight = new Dimension(50); + } + var p = weight.value / 100.0; + var w = p * 2 - 1; + var a = toHSL(color1).a - toHSL(color2).a; + var w1 = (((w * a == -1) ? w : (w + a) / (1 + w * a)) + 1) / 2.0; + var w2 = 1 - w1; + var rgb = [color1.rgb[0] * w1 + color2.rgb[0] * w2, + color1.rgb[1] * w1 + color2.rgb[1] * w2, + color1.rgb[2] * w1 + color2.rgb[2] * w2]; + var alpha = color1.alpha * p + color2.alpha * (1 - p); + return new Color(rgb, alpha); + }, + greyscale: function (color) { + return colorFunctions.desaturate(color, new Dimension(100)); + }, + contrast: function (color, dark, light, threshold) { + // filter: contrast(3.2); + // should be kept as is, so check for color + if (!color.rgb) { + return null; + } + if (typeof light === 'undefined') { + light = colorFunctions.rgba(255, 255, 255, 1.0); + } + if (typeof dark === 'undefined') { + dark = colorFunctions.rgba(0, 0, 0, 1.0); + } + // Figure out which is actually light and dark: + if (dark.luma() > light.luma()) { + var t = light; + light = dark; + dark = t; + } + if (typeof threshold === 'undefined') { + threshold = 0.43; + } + else { + threshold = number(threshold); + } + if (color.luma() < threshold) { + return light; + } + else { + return dark; + } + }, + // Changes made in 2.7.0 - Reverted in 3.0.0 + // contrast: function (color, color1, color2, threshold) { + // // Return which of `color1` and `color2` has the greatest contrast with `color` + // // according to the standard WCAG contrast ratio calculation. + // // http://www.w3.org/TR/WCAG20/#contrast-ratiodef + // // The threshold param is no longer used, in line with SASS. + // // filter: contrast(3.2); + // // should be kept as is, so check for color + // if (!color.rgb) { + // return null; + // } + // if (typeof color1 === 'undefined') { + // color1 = colorFunctions.rgba(0, 0, 0, 1.0); + // } + // if (typeof color2 === 'undefined') { + // color2 = colorFunctions.rgba(255, 255, 255, 1.0); + // } + // var contrast1, contrast2; + // var luma = color.luma(); + // var luma1 = color1.luma(); + // var luma2 = color2.luma(); + // // Calculate contrast ratios for each color + // if (luma > luma1) { + // contrast1 = (luma + 0.05) / (luma1 + 0.05); + // } else { + // contrast1 = (luma1 + 0.05) / (luma + 0.05); + // } + // if (luma > luma2) { + // contrast2 = (luma + 0.05) / (luma2 + 0.05); + // } else { + // contrast2 = (luma2 + 0.05) / (luma + 0.05); + // } + // if (contrast1 > contrast2) { + // return color1; + // } else { + // return color2; + // } + // }, + argb: function (color) { + return new Anonymous(color.toARGB()); + }, + color: function (c) { + if ((c instanceof Quoted) && + (/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})$/i.test(c.value))) { + var val = c.value.slice(1); + return new Color(val, undefined, "#" + val); + } + if ((c instanceof Color) || (c = Color.fromKeyword(c.value))) { + c.value = undefined; + return c; + } + throw { + type: 'Argument', + message: 'argument must be a color keyword or 3|4|6|8 digit hex e.g. #FFF' + }; + }, + tint: function (color, amount) { + return colorFunctions.mix(colorFunctions.rgb(255, 255, 255), color, amount); + }, + shade: function (color, amount) { + return colorFunctions.mix(colorFunctions.rgb(0, 0, 0), color, amount); + } + }; + var color = colorFunctions; - // Color Blending - // ref: http://www.w3.org/TR/compositing-1 - function colorBlend(mode, color1, color2) { - var ab = color1.alpha; // result - var // backdrop - cb; - var as = color2.alpha; - var // source - cs; - var ar; - var cr; - var r = []; - ar = as + ab * (1 - as); - for (var i = 0; i < 3; i++) { - cb = color1.rgb[i] / 255; - cs = color2.rgb[i] / 255; - cr = mode(cb, cs); - if (ar) { - cr = (as * cs + ab * (cb - - as * (cb + cs - cr))) / ar; - } - r[i] = cr * 255; - } - return new Color(r, ar); - } - var colorBlendModeFunctions = { - multiply: function (cb, cs) { - return cb * cs; - }, - screen: function (cb, cs) { - return cb + cs - cb * cs; - }, - overlay: function (cb, cs) { - cb *= 2; - return (cb <= 1) ? - colorBlendModeFunctions.multiply(cb, cs) : - colorBlendModeFunctions.screen(cb - 1, cs); - }, - softlight: function (cb, cs) { - var d = 1; - var e = cb; - if (cs > 0.5) { - e = 1; - d = (cb > 0.25) ? Math.sqrt(cb) - : ((16 * cb - 12) * cb + 4) * cb; - } - return cb - (1 - 2 * cs) * e * (d - cb); - }, - hardlight: function (cb, cs) { - return colorBlendModeFunctions.overlay(cs, cb); - }, - difference: function (cb, cs) { - return Math.abs(cb - cs); - }, - exclusion: function (cb, cs) { - return cb + cs - 2 * cb * cs; - }, - // non-w3c functions: - average: function (cb, cs) { - return (cb + cs) / 2; - }, - negation: function (cb, cs) { - return 1 - Math.abs(cb + cs - 1); - } - }; - for (var f in colorBlendModeFunctions) { - if (colorBlendModeFunctions.hasOwnProperty(f)) { - colorBlend[f] = colorBlend.bind(null, colorBlendModeFunctions[f]); - } - } + // Color Blending + // ref: http://www.w3.org/TR/compositing-1 + function colorBlend(mode, color1, color2) { + var ab = color1.alpha; // result + var // backdrop + cb; + var as = color2.alpha; + var // source + cs; + var ar; + var cr; + var r = []; + ar = as + ab * (1 - as); + for (var i = 0; i < 3; i++) { + cb = color1.rgb[i] / 255; + cs = color2.rgb[i] / 255; + cr = mode(cb, cs); + if (ar) { + cr = (as * cs + ab * (cb - + as * (cb + cs - cr))) / ar; + } + r[i] = cr * 255; + } + return new Color(r, ar); + } + var colorBlendModeFunctions = { + multiply: function (cb, cs) { + return cb * cs; + }, + screen: function (cb, cs) { + return cb + cs - cb * cs; + }, + overlay: function (cb, cs) { + cb *= 2; + return (cb <= 1) ? + colorBlendModeFunctions.multiply(cb, cs) : + colorBlendModeFunctions.screen(cb - 1, cs); + }, + softlight: function (cb, cs) { + var d = 1; + var e = cb; + if (cs > 0.5) { + e = 1; + d = (cb > 0.25) ? Math.sqrt(cb) + : ((16 * cb - 12) * cb + 4) * cb; + } + return cb - (1 - 2 * cs) * e * (d - cb); + }, + hardlight: function (cb, cs) { + return colorBlendModeFunctions.overlay(cs, cb); + }, + difference: function (cb, cs) { + return Math.abs(cb - cs); + }, + exclusion: function (cb, cs) { + return cb + cs - 2 * cb * cs; + }, + // non-w3c functions: + average: function (cb, cs) { + return (cb + cs) / 2; + }, + negation: function (cb, cs) { + return 1 - Math.abs(cb + cs - 1); + } + }; + for (var f in colorBlendModeFunctions) { + if (colorBlendModeFunctions.hasOwnProperty(f)) { + colorBlend[f] = colorBlend.bind(null, colorBlendModeFunctions[f]); + } + } - var dataUri = (function (environment) { - var fallback = function (functionThis, node) { return new URL(node, functionThis.index, functionThis.currentFileInfo).eval(functionThis.context); }; - return { 'data-uri': function (mimetypeNode, filePathNode) { - if (!filePathNode) { - filePathNode = mimetypeNode; - mimetypeNode = null; - } - var mimetype = mimetypeNode && mimetypeNode.value; - var filePath = filePathNode.value; - var currentFileInfo = this.currentFileInfo; - var currentDirectory = currentFileInfo.rewriteUrls ? - currentFileInfo.currentDirectory : currentFileInfo.entryPath; - var fragmentStart = filePath.indexOf('#'); - var fragment = ''; - if (fragmentStart !== -1) { - fragment = filePath.slice(fragmentStart); - filePath = filePath.slice(0, fragmentStart); - } - var context = clone(this.context); - context.rawBuffer = true; - var fileManager = environment.getFileManager(filePath, currentDirectory, context, environment, true); - if (!fileManager) { - return fallback(this, filePathNode); - } - var useBase64 = false; - // detect the mimetype if not given - if (!mimetypeNode) { - mimetype = environment.mimeLookup(filePath); - if (mimetype === 'image/svg+xml') { - useBase64 = false; - } - else { - // use base 64 unless it's an ASCII or UTF-8 format - var charset = environment.charsetLookup(mimetype); - useBase64 = ['US-ASCII', 'UTF-8'].indexOf(charset) < 0; - } - if (useBase64) { - mimetype += ';base64'; - } - } - else { - useBase64 = /;base64$/.test(mimetype); - } - var fileSync = fileManager.loadFileSync(filePath, currentDirectory, context, environment); - if (!fileSync.contents) { - logger.warn("Skipped data-uri embedding of " + filePath + " because file not found"); - return fallback(this, filePathNode || mimetypeNode); - } - var buf = fileSync.contents; - if (useBase64 && !environment.encodeBase64) { - return fallback(this, filePathNode); - } - buf = useBase64 ? environment.encodeBase64(buf) : encodeURIComponent(buf); - var uri = "data:" + mimetype + "," + buf + fragment; - return new URL(new Quoted("\"" + uri + "\"", uri, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo); - } }; - }); + var dataUri = (function (environment) { + var fallback = function (functionThis, node) { return new URL(node, functionThis.index, functionThis.currentFileInfo).eval(functionThis.context); }; + return { 'data-uri': function (mimetypeNode, filePathNode) { + if (!filePathNode) { + filePathNode = mimetypeNode; + mimetypeNode = null; + } + var mimetype = mimetypeNode && mimetypeNode.value; + var filePath = filePathNode.value; + var currentFileInfo = this.currentFileInfo; + var currentDirectory = currentFileInfo.rewriteUrls ? + currentFileInfo.currentDirectory : currentFileInfo.entryPath; + var fragmentStart = filePath.indexOf('#'); + var fragment = ''; + if (fragmentStart !== -1) { + fragment = filePath.slice(fragmentStart); + filePath = filePath.slice(0, fragmentStart); + } + var context = clone(this.context); + context.rawBuffer = true; + var fileManager = environment.getFileManager(filePath, currentDirectory, context, environment, true); + if (!fileManager) { + return fallback(this, filePathNode); + } + var useBase64 = false; + // detect the mimetype if not given + if (!mimetypeNode) { + mimetype = environment.mimeLookup(filePath); + if (mimetype === 'image/svg+xml') { + useBase64 = false; + } + else { + // use base 64 unless it's an ASCII or UTF-8 format + var charset = environment.charsetLookup(mimetype); + useBase64 = ['US-ASCII', 'UTF-8'].indexOf(charset) < 0; + } + if (useBase64) { + mimetype += ';base64'; + } + } + else { + useBase64 = /;base64$/.test(mimetype); + } + var fileSync = fileManager.loadFileSync(filePath, currentDirectory, context, environment); + if (!fileSync.contents) { + logger.warn("Skipped data-uri embedding of " + filePath + " because file not found"); + return fallback(this, filePathNode || mimetypeNode); + } + var buf = fileSync.contents; + if (useBase64 && !environment.encodeBase64) { + return fallback(this, filePathNode); + } + buf = useBase64 ? environment.encodeBase64(buf) : encodeURIComponent(buf); + var uri = "data:" + mimetype + "," + buf + fragment; + return new URL(new Quoted("\"" + uri + "\"", uri, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo); + } }; + }); - var getItemsFromNode = function (node) { - // handle non-array values as an array of length 1 - // return 'undefined' if index is invalid - var items = Array.isArray(node.value) ? - node.value : Array(node); - return items; - }; - var list = { - _SELF: function (n) { - return n; - }, - extract: function (values, index) { - // (1-based index) - index = index.value - 1; - return getItemsFromNode(values)[index]; - }, - length: function (values) { - return new Dimension(getItemsFromNode(values).length); - }, - /** - * Creates a Less list of incremental values. - * Modeled after Lodash's range function, also exists natively in PHP - * - * @param {Dimension} [start=1] - * @param {Dimension} end - e.g. 10 or 10px - unit is added to output - * @param {Dimension} [step=1] - */ - range: function (start, end, step) { - var from; - var to; - var stepValue = 1; - var list = []; - if (end) { - to = end; - from = start.value; - if (step) { - stepValue = step.value; - } - } - else { - from = 1; - to = start; - } - for (var i = from; i <= to.value; i += stepValue) { - list.push(new Dimension(i, to.unit)); - } - return new Expression(list); - }, - each: function (list, rs) { - var _this = this; - var rules = []; - var newRules; - var iterator; - var tryEval = function (val) { - if (val instanceof Node) { - return val.eval(_this.context); - } - return val; - }; - if (list.value && !(list instanceof Quoted)) { - if (Array.isArray(list.value)) { - iterator = list.value.map(tryEval); - } - else { - iterator = [tryEval(list.value)]; - } - } - else if (list.ruleset) { - iterator = tryEval(list.ruleset).rules; - } - else if (list.rules) { - iterator = list.rules.map(tryEval); - } - else if (Array.isArray(list)) { - iterator = list.map(tryEval); - } - else { - iterator = [tryEval(list)]; - } - var valueName = '@value'; - var keyName = '@key'; - var indexName = '@index'; - if (rs.params) { - valueName = rs.params[0] && rs.params[0].name; - keyName = rs.params[1] && rs.params[1].name; - indexName = rs.params[2] && rs.params[2].name; - rs = rs.rules; - } - else { - rs = rs.ruleset; - } - for (var i = 0; i < iterator.length; i++) { - var key = void 0; - var value = void 0; - var item = iterator[i]; - if (item instanceof Declaration) { - key = typeof item.name === 'string' ? item.name : item.name[0].value; - value = item.value; - } - else { - key = new Dimension(i + 1); - value = item; - } - if (item instanceof Comment) { - continue; - } - newRules = rs.rules.slice(0); - if (valueName) { - newRules.push(new Declaration(valueName, value, false, false, this.index, this.currentFileInfo)); - } - if (indexName) { - newRules.push(new Declaration(indexName, new Dimension(i + 1), false, false, this.index, this.currentFileInfo)); - } - if (keyName) { - newRules.push(new Declaration(keyName, key, false, false, this.index, this.currentFileInfo)); - } - rules.push(new Ruleset([new (Selector)([new Element("", '&')])], newRules, rs.strictImports, rs.visibilityInfo())); - } - return new Ruleset([new (Selector)([new Element("", '&')])], rules, rs.strictImports, rs.visibilityInfo()).eval(this.context); - } - }; + var getItemsFromNode = function (node) { + // handle non-array values as an array of length 1 + // return 'undefined' if index is invalid + var items = Array.isArray(node.value) ? + node.value : Array(node); + return items; + }; + var list = { + _SELF: function (n) { + return n; + }, + '~': function () { + var expr = []; + for (var _i = 0; _i < arguments.length; _i++) { + expr[_i] = arguments[_i]; + } + if (expr.length === 1) { + return expr[0]; + } + return new Value(expr); + }, + extract: function (values, index) { + // (1-based index) + index = index.value - 1; + return getItemsFromNode(values)[index]; + }, + length: function (values) { + return new Dimension(getItemsFromNode(values).length); + }, + /** + * Creates a Less list of incremental values. + * Modeled after Lodash's range function, also exists natively in PHP + * + * @param {Dimension} [start=1] + * @param {Dimension} end - e.g. 10 or 10px - unit is added to output + * @param {Dimension} [step=1] + */ + range: function (start, end, step) { + var from; + var to; + var stepValue = 1; + var list = []; + if (end) { + to = end; + from = start.value; + if (step) { + stepValue = step.value; + } + } + else { + from = 1; + to = start; + } + for (var i = from; i <= to.value; i += stepValue) { + list.push(new Dimension(i, to.unit)); + } + return new Expression(list); + }, + each: function (list, rs) { + var _this = this; + var rules = []; + var newRules; + var iterator; + var tryEval = function (val) { + if (val instanceof Node) { + return val.eval(_this.context); + } + return val; + }; + if (list.value && !(list instanceof Quoted)) { + if (Array.isArray(list.value)) { + iterator = list.value.map(tryEval); + } + else { + iterator = [tryEval(list.value)]; + } + } + else if (list.ruleset) { + iterator = tryEval(list.ruleset).rules; + } + else if (list.rules) { + iterator = list.rules.map(tryEval); + } + else if (Array.isArray(list)) { + iterator = list.map(tryEval); + } + else { + iterator = [tryEval(list)]; + } + var valueName = '@value'; + var keyName = '@key'; + var indexName = '@index'; + if (rs.params) { + valueName = rs.params[0] && rs.params[0].name; + keyName = rs.params[1] && rs.params[1].name; + indexName = rs.params[2] && rs.params[2].name; + rs = rs.rules; + } + else { + rs = rs.ruleset; + } + for (var i = 0; i < iterator.length; i++) { + var key = void 0; + var value = void 0; + var item = iterator[i]; + if (item instanceof Declaration) { + key = typeof item.name === 'string' ? item.name : item.name[0].value; + value = item.value; + } + else { + key = new Dimension(i + 1); + value = item; + } + if (item instanceof Comment) { + continue; + } + newRules = rs.rules.slice(0); + if (valueName) { + newRules.push(new Declaration(valueName, value, false, false, this.index, this.currentFileInfo)); + } + if (indexName) { + newRules.push(new Declaration(indexName, new Dimension(i + 1), false, false, this.index, this.currentFileInfo)); + } + if (keyName) { + newRules.push(new Declaration(keyName, key, false, false, this.index, this.currentFileInfo)); + } + rules.push(new Ruleset([new (Selector)([new Element("", '&')])], newRules, rs.strictImports, rs.visibilityInfo())); + } + return new Ruleset([new (Selector)([new Element("", '&')])], rules, rs.strictImports, rs.visibilityInfo()).eval(this.context); + } + }; - var MathHelper = function (fn, unit, n) { - if (!(n instanceof Dimension)) { - throw { type: 'Argument', message: 'argument must be a number' }; - } - if (unit == null) { - unit = n.unit; - } - else { - n = n.unify(); - } - return new Dimension(fn(parseFloat(n.value)), unit); - }; + var MathHelper = function (fn, unit, n) { + if (!(n instanceof Dimension)) { + throw { type: 'Argument', message: 'argument must be a number' }; + } + if (unit == null) { + unit = n.unit; + } + else { + n = n.unify(); + } + return new Dimension(fn(parseFloat(n.value)), unit); + }; - var mathFunctions = { - // name, unit - ceil: null, - floor: null, - sqrt: null, - abs: null, - tan: '', - sin: '', - cos: '', - atan: 'rad', - asin: 'rad', - acos: 'rad' - }; - for (var f$1 in mathFunctions) { - if (mathFunctions.hasOwnProperty(f$1)) { - mathFunctions[f$1] = MathHelper.bind(null, Math[f$1], mathFunctions[f$1]); - } - } - mathFunctions.round = function (n, f) { - var fraction = typeof f === 'undefined' ? 0 : f.value; - return MathHelper(function (num) { return num.toFixed(fraction); }, null, n); - }; + var mathFunctions = { + // name, unit + ceil: null, + floor: null, + sqrt: null, + abs: null, + tan: '', + sin: '', + cos: '', + atan: 'rad', + asin: 'rad', + acos: 'rad' + }; + for (var f$1 in mathFunctions) { + if (mathFunctions.hasOwnProperty(f$1)) { + mathFunctions[f$1] = MathHelper.bind(null, Math[f$1], mathFunctions[f$1]); + } + } + mathFunctions.round = function (n, f) { + var fraction = typeof f === 'undefined' ? 0 : f.value; + return MathHelper(function (num) { return num.toFixed(fraction); }, null, n); + }; - var minMax = function (isMin, args) { - args = Array.prototype.slice.call(args); - switch (args.length) { - case 0: throw { type: 'Argument', message: 'one or more arguments required' }; - } - var i; // key is the unit.toString() for unified Dimension values, - var j; - var current; - var currentUnified; - var referenceUnified; - var unit; - var unitStatic; - var unitClone; - var // elems only contains original argument values. - order = []; - var values = {}; - // value is the index into the order array. - for (i = 0; i < args.length; i++) { - current = args[i]; - if (!(current instanceof Dimension)) { - if (Array.isArray(args[i].value)) { - Array.prototype.push.apply(args, Array.prototype.slice.call(args[i].value)); - } - continue; - } - currentUnified = current.unit.toString() === '' && unitClone !== undefined ? new Dimension(current.value, unitClone).unify() : current.unify(); - unit = currentUnified.unit.toString() === '' && unitStatic !== undefined ? unitStatic : currentUnified.unit.toString(); - unitStatic = unit !== '' && unitStatic === undefined || unit !== '' && order[0].unify().unit.toString() === '' ? unit : unitStatic; - unitClone = unit !== '' && unitClone === undefined ? current.unit.toString() : unitClone; - j = values[''] !== undefined && unit !== '' && unit === unitStatic ? values[''] : values[unit]; - if (j === undefined) { - if (unitStatic !== undefined && unit !== unitStatic) { - throw { type: 'Argument', message: 'incompatible types' }; - } - values[unit] = order.length; - order.push(current); - continue; - } - referenceUnified = order[j].unit.toString() === '' && unitClone !== undefined ? new Dimension(order[j].value, unitClone).unify() : order[j].unify(); - if (isMin && currentUnified.value < referenceUnified.value || - !isMin && currentUnified.value > referenceUnified.value) { - order[j] = current; - } - } - if (order.length == 1) { - return order[0]; - } - args = order.map(function (a) { return a.toCSS(this.context); }).join(this.context.compress ? ',' : ', '); - return new Anonymous((isMin ? 'min' : 'max') + "(" + args + ")"); - }; - var number$1 = { - min: function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - return minMax(true, args); - }, - max: function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - return minMax(false, args); - }, - convert: function (val, unit) { - return val.convertTo(unit.value); - }, - pi: function () { - return new Dimension(Math.PI); - }, - mod: function (a, b) { - return new Dimension(a.value % b.value, a.unit); - }, - pow: function (x, y) { - if (typeof x === 'number' && typeof y === 'number') { - x = new Dimension(x); - y = new Dimension(y); - } - else if (!(x instanceof Dimension) || !(y instanceof Dimension)) { - throw { type: 'Argument', message: 'arguments must be numbers' }; - } - return new Dimension(Math.pow(x.value, y.value), x.unit); - }, - percentage: function (n) { - var result = MathHelper(function (num) { return num * 100; }, '%', n); - return result; - } - }; + var minMax = function (isMin, args) { + args = Array.prototype.slice.call(args); + switch (args.length) { + case 0: throw { type: 'Argument', message: 'one or more arguments required' }; + } + var i; // key is the unit.toString() for unified Dimension values, + var j; + var current; + var currentUnified; + var referenceUnified; + var unit; + var unitStatic; + var unitClone; + var // elems only contains original argument values. + order = []; + var values = {}; + // value is the index into the order array. + for (i = 0; i < args.length; i++) { + current = args[i]; + if (!(current instanceof Dimension)) { + if (Array.isArray(args[i].value)) { + Array.prototype.push.apply(args, Array.prototype.slice.call(args[i].value)); + } + continue; + } + currentUnified = current.unit.toString() === '' && unitClone !== undefined ? new Dimension(current.value, unitClone).unify() : current.unify(); + unit = currentUnified.unit.toString() === '' && unitStatic !== undefined ? unitStatic : currentUnified.unit.toString(); + unitStatic = unit !== '' && unitStatic === undefined || unit !== '' && order[0].unify().unit.toString() === '' ? unit : unitStatic; + unitClone = unit !== '' && unitClone === undefined ? current.unit.toString() : unitClone; + j = values[''] !== undefined && unit !== '' && unit === unitStatic ? values[''] : values[unit]; + if (j === undefined) { + if (unitStatic !== undefined && unit !== unitStatic) { + throw { type: 'Argument', message: 'incompatible types' }; + } + values[unit] = order.length; + order.push(current); + continue; + } + referenceUnified = order[j].unit.toString() === '' && unitClone !== undefined ? new Dimension(order[j].value, unitClone).unify() : order[j].unify(); + if (isMin && currentUnified.value < referenceUnified.value || + !isMin && currentUnified.value > referenceUnified.value) { + order[j] = current; + } + } + if (order.length == 1) { + return order[0]; + } + args = order.map(function (a) { return a.toCSS(this.context); }).join(this.context.compress ? ',' : ', '); + return new Anonymous((isMin ? 'min' : 'max') + "(" + args + ")"); + }; + var number$1 = { + min: function () { + var args = []; + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + try { + return minMax(true, args); + } + catch (e) { } + }, + max: function () { + var args = []; + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + try { + return minMax(false, args); + } + catch (e) { } + }, + convert: function (val, unit) { + return val.convertTo(unit.value); + }, + pi: function () { + return new Dimension(Math.PI); + }, + mod: function (a, b) { + return new Dimension(a.value % b.value, a.unit); + }, + pow: function (x, y) { + if (typeof x === 'number' && typeof y === 'number') { + x = new Dimension(x); + y = new Dimension(y); + } + else if (!(x instanceof Dimension) || !(y instanceof Dimension)) { + throw { type: 'Argument', message: 'arguments must be numbers' }; + } + return new Dimension(Math.pow(x.value, y.value), x.unit); + }, + percentage: function (n) { + var result = MathHelper(function (num) { return num * 100; }, '%', n); + return result; + } + }; - var string = { - e: function (str) { - return new Quoted('"', str instanceof JavaScript ? str.evaluated : str.value, true); - }, - escape: function (str) { - return new Anonymous(encodeURI(str.value).replace(/=/g, '%3D').replace(/:/g, '%3A').replace(/#/g, '%23').replace(/;/g, '%3B') - .replace(/\(/g, '%28').replace(/\)/g, '%29')); - }, - replace: function (string, pattern, replacement, flags) { - var result = string.value; - replacement = (replacement.type === 'Quoted') ? - replacement.value : replacement.toCSS(); - result = result.replace(new RegExp(pattern.value, flags ? flags.value : ''), replacement); - return new Quoted(string.quote || '', result, string.escaped); - }, - '%': function (string /* arg, arg, ... */) { - var args = Array.prototype.slice.call(arguments, 1); - var result = string.value; - var _loop_1 = function (i) { - /* jshint loopfunc:true */ - result = result.replace(/%[sda]/i, function (token) { - var value = ((args[i].type === 'Quoted') && - token.match(/s/i)) ? args[i].value : args[i].toCSS(); - return token.match(/[A-Z]$/) ? encodeURIComponent(value) : value; - }); - }; - for (var i = 0; i < args.length; i++) { - _loop_1(i); - } - result = result.replace(/%%/g, '%'); - return new Quoted(string.quote || '', result, string.escaped); - } - }; + var string = { + e: function (str) { + return new Quoted('"', str instanceof JavaScript ? str.evaluated : str.value, true); + }, + escape: function (str) { + return new Anonymous(encodeURI(str.value).replace(/=/g, '%3D').replace(/:/g, '%3A').replace(/#/g, '%23').replace(/;/g, '%3B') + .replace(/\(/g, '%28').replace(/\)/g, '%29')); + }, + replace: function (string, pattern, replacement, flags) { + var result = string.value; + replacement = (replacement.type === 'Quoted') ? + replacement.value : replacement.toCSS(); + result = result.replace(new RegExp(pattern.value, flags ? flags.value : ''), replacement); + return new Quoted(string.quote || '', result, string.escaped); + }, + '%': function (string /* arg, arg, ... */) { + var args = Array.prototype.slice.call(arguments, 1); + var result = string.value; + var _loop_1 = function (i) { + /* jshint loopfunc:true */ + result = result.replace(/%[sda]/i, function (token) { + var value = ((args[i].type === 'Quoted') && + token.match(/s/i)) ? args[i].value : args[i].toCSS(); + return token.match(/[A-Z]$/) ? encodeURIComponent(value) : value; + }); + }; + for (var i = 0; i < args.length; i++) { + _loop_1(i); + } + result = result.replace(/%%/g, '%'); + return new Quoted(string.quote || '', result, string.escaped); + } + }; - var svg = (function (environment) { - return { 'svg-gradient': function (direction) { - var stops; - var gradientDirectionSvg; - var gradientType = 'linear'; - var rectangleDimension = 'x="0" y="0" width="1" height="1"'; - var renderEnv = { compress: false }; - var returner; - var directionValue = direction.toCSS(renderEnv); - var i; - var color; - var position; - var positionValue; - var alpha; - function throwArgumentDescriptor() { - throw { type: 'Argument', - message: 'svg-gradient expects direction, start_color [start_position], [color position,]...,' + - ' end_color [end_position] or direction, color list' }; - } - if (arguments.length == 2) { - if (arguments[1].value.length < 2) { - throwArgumentDescriptor(); - } - stops = arguments[1].value; - } - else if (arguments.length < 3) { - throwArgumentDescriptor(); - } - else { - stops = Array.prototype.slice.call(arguments, 1); - } - switch (directionValue) { - case 'to bottom': - gradientDirectionSvg = 'x1="0%" y1="0%" x2="0%" y2="100%"'; - break; - case 'to right': - gradientDirectionSvg = 'x1="0%" y1="0%" x2="100%" y2="0%"'; - break; - case 'to bottom right': - gradientDirectionSvg = 'x1="0%" y1="0%" x2="100%" y2="100%"'; - break; - case 'to top right': - gradientDirectionSvg = 'x1="0%" y1="100%" x2="100%" y2="0%"'; - break; - case 'ellipse': - case 'ellipse at center': - gradientType = 'radial'; - gradientDirectionSvg = 'cx="50%" cy="50%" r="75%"'; - rectangleDimension = 'x="-50" y="-50" width="101" height="101"'; - break; - default: - throw { type: 'Argument', message: 'svg-gradient direction must be \'to bottom\', \'to right\',' + - ' \'to bottom right\', \'to top right\' or \'ellipse at center\'' }; - } - returner = "<" + gradientType + "Gradient id=\"g\" " + gradientDirectionSvg + ">"; - for (i = 0; i < stops.length; i += 1) { - if (stops[i] instanceof Expression) { - color = stops[i].value[0]; - position = stops[i].value[1]; - } - else { - color = stops[i]; - position = undefined; - } - if (!(color instanceof Color) || (!((i === 0 || i + 1 === stops.length) && position === undefined) && !(position instanceof Dimension))) { - throwArgumentDescriptor(); - } - positionValue = position ? position.toCSS(renderEnv) : i === 0 ? '0%' : '100%'; - alpha = color.alpha; - returner += ""; - } - returner += ""; - returner = encodeURIComponent(returner); - returner = "data:image/svg+xml," + returner; - return new URL(new Quoted("'" + returner + "'", returner, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo); - } }; - }); + var svg = (function (environment) { + return { 'svg-gradient': function (direction) { + var stops; + var gradientDirectionSvg; + var gradientType = 'linear'; + var rectangleDimension = 'x="0" y="0" width="1" height="1"'; + var renderEnv = { compress: false }; + var returner; + var directionValue = direction.toCSS(renderEnv); + var i; + var color; + var position; + var positionValue; + var alpha; + function throwArgumentDescriptor() { + throw { type: 'Argument', + message: 'svg-gradient expects direction, start_color [start_position], [color position,]...,' + + ' end_color [end_position] or direction, color list' }; + } + if (arguments.length == 2) { + if (arguments[1].value.length < 2) { + throwArgumentDescriptor(); + } + stops = arguments[1].value; + } + else if (arguments.length < 3) { + throwArgumentDescriptor(); + } + else { + stops = Array.prototype.slice.call(arguments, 1); + } + switch (directionValue) { + case 'to bottom': + gradientDirectionSvg = 'x1="0%" y1="0%" x2="0%" y2="100%"'; + break; + case 'to right': + gradientDirectionSvg = 'x1="0%" y1="0%" x2="100%" y2="0%"'; + break; + case 'to bottom right': + gradientDirectionSvg = 'x1="0%" y1="0%" x2="100%" y2="100%"'; + break; + case 'to top right': + gradientDirectionSvg = 'x1="0%" y1="100%" x2="100%" y2="0%"'; + break; + case 'ellipse': + case 'ellipse at center': + gradientType = 'radial'; + gradientDirectionSvg = 'cx="50%" cy="50%" r="75%"'; + rectangleDimension = 'x="-50" y="-50" width="101" height="101"'; + break; + default: + throw { type: 'Argument', message: 'svg-gradient direction must be \'to bottom\', \'to right\',' + + ' \'to bottom right\', \'to top right\' or \'ellipse at center\'' }; + } + returner = "<" + gradientType + "Gradient id=\"g\" " + gradientDirectionSvg + ">"; + for (i = 0; i < stops.length; i += 1) { + if (stops[i] instanceof Expression) { + color = stops[i].value[0]; + position = stops[i].value[1]; + } + else { + color = stops[i]; + position = undefined; + } + if (!(color instanceof Color) || (!((i === 0 || i + 1 === stops.length) && position === undefined) && !(position instanceof Dimension))) { + throwArgumentDescriptor(); + } + positionValue = position ? position.toCSS(renderEnv) : i === 0 ? '0%' : '100%'; + alpha = color.alpha; + returner += ""; + } + returner += ""; + returner = encodeURIComponent(returner); + returner = "data:image/svg+xml," + returner; + return new URL(new Quoted("'" + returner + "'", returner, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo); + } }; + }); - var isa = function (n, Type) { return (n instanceof Type) ? Keyword.True : Keyword.False; }; - var isunit = function (n, unit) { - if (unit === undefined) { - throw { type: 'Argument', message: 'missing the required second argument to isunit.' }; - } - unit = typeof unit.value === 'string' ? unit.value : unit; - if (typeof unit !== 'string') { - throw { type: 'Argument', message: 'Second argument to isunit should be a unit or a string.' }; - } - return (n instanceof Dimension) && n.unit.is(unit) ? Keyword.True : Keyword.False; - }; - var types = { - isruleset: function (n) { - return isa(n, DetachedRuleset); - }, - iscolor: function (n) { - return isa(n, Color); - }, - isnumber: function (n) { - return isa(n, Dimension); - }, - isstring: function (n) { - return isa(n, Quoted); - }, - iskeyword: function (n) { - return isa(n, Keyword); - }, - isurl: function (n) { - return isa(n, URL); - }, - ispixel: function (n) { - return isunit(n, 'px'); - }, - ispercentage: function (n) { - return isunit(n, '%'); - }, - isem: function (n) { - return isunit(n, 'em'); - }, - isunit: isunit, - unit: function (val, unit) { - if (!(val instanceof Dimension)) { - throw { type: 'Argument', message: "the first argument to unit must be a number" + (val instanceof Operation ? '. Have you forgotten parenthesis?' : '') }; - } - if (unit) { - if (unit instanceof Keyword) { - unit = unit.value; - } - else { - unit = unit.toCSS(); - } - } - else { - unit = ''; - } - return new Dimension(val.value, unit); - }, - 'get-unit': function (n) { - return new Anonymous(n.unit); - } - }; + var isa = function (n, Type) { return (n instanceof Type) ? Keyword.True : Keyword.False; }; + var isunit = function (n, unit) { + if (unit === undefined) { + throw { type: 'Argument', message: 'missing the required second argument to isunit.' }; + } + unit = typeof unit.value === 'string' ? unit.value : unit; + if (typeof unit !== 'string') { + throw { type: 'Argument', message: 'Second argument to isunit should be a unit or a string.' }; + } + return (n instanceof Dimension) && n.unit.is(unit) ? Keyword.True : Keyword.False; + }; + var types = { + isruleset: function (n) { + return isa(n, DetachedRuleset); + }, + iscolor: function (n) { + return isa(n, Color); + }, + isnumber: function (n) { + return isa(n, Dimension); + }, + isstring: function (n) { + return isa(n, Quoted); + }, + iskeyword: function (n) { + return isa(n, Keyword); + }, + isurl: function (n) { + return isa(n, URL); + }, + ispixel: function (n) { + return isunit(n, 'px'); + }, + ispercentage: function (n) { + return isunit(n, '%'); + }, + isem: function (n) { + return isunit(n, 'em'); + }, + isunit: isunit, + unit: function (val, unit) { + if (!(val instanceof Dimension)) { + throw { type: 'Argument', message: "the first argument to unit must be a number" + (val instanceof Operation ? '. Have you forgotten parenthesis?' : '') }; + } + if (unit) { + if (unit instanceof Keyword) { + unit = unit.value; + } + else { + unit = unit.toCSS(); + } + } + else { + unit = ''; + } + return new Dimension(val.value, unit); + }, + 'get-unit': function (n) { + return new Anonymous(n.unit); + } + }; - var Functions = (function (environment) { - var functions = { functionRegistry: functionRegistry, functionCaller: functionCaller }; - // register functions - functionRegistry.addMultiple(boolean$1); - functionRegistry.add('default', defaultFunc.eval.bind(defaultFunc)); - functionRegistry.addMultiple(color); - functionRegistry.addMultiple(colorBlend); - functionRegistry.addMultiple(dataUri(environment)); - functionRegistry.addMultiple(list); - functionRegistry.addMultiple(mathFunctions); - functionRegistry.addMultiple(number$1); - functionRegistry.addMultiple(string); - functionRegistry.addMultiple(svg()); - functionRegistry.addMultiple(types); - return functions; - }); + var functions = (function (environment) { + var functions = { functionRegistry: functionRegistry, functionCaller: functionCaller }; + // register functions + functionRegistry.addMultiple(boolean$1); + functionRegistry.add('default', defaultFunc.eval.bind(defaultFunc)); + functionRegistry.addMultiple(color); + functionRegistry.addMultiple(colorBlend); + functionRegistry.addMultiple(dataUri(environment)); + functionRegistry.addMultiple(list); + functionRegistry.addMultiple(mathFunctions); + functionRegistry.addMultiple(number$1); + functionRegistry.addMultiple(string); + functionRegistry.addMultiple(svg()); + functionRegistry.addMultiple(types); + return functions; + }); - var sourceMapOutput = (function (environment) { - var SourceMapOutput = /** @class */ (function () { - function SourceMapOutput(options) { - this._css = []; - this._rootNode = options.rootNode; - this._contentsMap = options.contentsMap; - this._contentsIgnoredCharsMap = options.contentsIgnoredCharsMap; - if (options.sourceMapFilename) { - this._sourceMapFilename = options.sourceMapFilename.replace(/\\/g, '/'); - } - this._outputFilename = options.outputFilename; - this.sourceMapURL = options.sourceMapURL; - if (options.sourceMapBasepath) { - this._sourceMapBasepath = options.sourceMapBasepath.replace(/\\/g, '/'); - } - if (options.sourceMapRootpath) { - this._sourceMapRootpath = options.sourceMapRootpath.replace(/\\/g, '/'); - if (this._sourceMapRootpath.charAt(this._sourceMapRootpath.length - 1) !== '/') { - this._sourceMapRootpath += '/'; - } - } - else { - this._sourceMapRootpath = ''; - } - this._outputSourceFiles = options.outputSourceFiles; - this._sourceMapGeneratorConstructor = environment.getSourceMapGenerator(); - this._lineNumber = 0; - this._column = 0; - } - SourceMapOutput.prototype.removeBasepath = function (path) { - if (this._sourceMapBasepath && path.indexOf(this._sourceMapBasepath) === 0) { - path = path.substring(this._sourceMapBasepath.length); - if (path.charAt(0) === '\\' || path.charAt(0) === '/') { - path = path.substring(1); - } - } - return path; - }; - SourceMapOutput.prototype.normalizeFilename = function (filename) { - filename = filename.replace(/\\/g, '/'); - filename = this.removeBasepath(filename); - return (this._sourceMapRootpath || '') + filename; - }; - SourceMapOutput.prototype.add = function (chunk, fileInfo, index, mapLines) { - // ignore adding empty strings - if (!chunk) { - return; - } - var lines; - var sourceLines; - var columns; - var sourceColumns; - var i; - if (fileInfo && fileInfo.filename) { - var inputSource = this._contentsMap[fileInfo.filename]; - // remove vars/banner added to the top of the file - if (this._contentsIgnoredCharsMap[fileInfo.filename]) { - // adjust the index - index -= this._contentsIgnoredCharsMap[fileInfo.filename]; - if (index < 0) { - index = 0; - } - // adjust the source - inputSource = inputSource.slice(this._contentsIgnoredCharsMap[fileInfo.filename]); - } - /** - * ignore empty content, or failsafe - * if contents map is incorrect - */ - if (inputSource === undefined) { - this._css.push(chunk); - return; - } - inputSource = inputSource.substring(0, index); - sourceLines = inputSource.split('\n'); - sourceColumns = sourceLines[sourceLines.length - 1]; - } - lines = chunk.split('\n'); - columns = lines[lines.length - 1]; - if (fileInfo && fileInfo.filename) { - if (!mapLines) { - this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + 1, column: this._column }, - original: { line: sourceLines.length, column: sourceColumns.length }, - source: this.normalizeFilename(fileInfo.filename) }); - } - else { - for (i = 0; i < lines.length; i++) { - this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + i + 1, column: i === 0 ? this._column : 0 }, - original: { line: sourceLines.length + i, column: i === 0 ? sourceColumns.length : 0 }, - source: this.normalizeFilename(fileInfo.filename) }); - } - } - } - if (lines.length === 1) { - this._column += columns.length; - } - else { - this._lineNumber += lines.length - 1; - this._column = columns.length; - } - this._css.push(chunk); - }; - SourceMapOutput.prototype.isEmpty = function () { - return this._css.length === 0; - }; - SourceMapOutput.prototype.toCSS = function (context) { - this._sourceMapGenerator = new this._sourceMapGeneratorConstructor({ file: this._outputFilename, sourceRoot: null }); - if (this._outputSourceFiles) { - for (var filename in this._contentsMap) { - if (this._contentsMap.hasOwnProperty(filename)) { - var source = this._contentsMap[filename]; - if (this._contentsIgnoredCharsMap[filename]) { - source = source.slice(this._contentsIgnoredCharsMap[filename]); - } - this._sourceMapGenerator.setSourceContent(this.normalizeFilename(filename), source); - } - } - } - this._rootNode.genCSS(context, this); - if (this._css.length > 0) { - var sourceMapURL = void 0; - var sourceMapContent = JSON.stringify(this._sourceMapGenerator.toJSON()); - if (this.sourceMapURL) { - sourceMapURL = this.sourceMapURL; - } - else if (this._sourceMapFilename) { - sourceMapURL = this._sourceMapFilename; - } - this.sourceMapURL = sourceMapURL; - this.sourceMap = sourceMapContent; - } - return this._css.join(''); - }; - return SourceMapOutput; - }()); - return SourceMapOutput; - }); + function transformTree (root, options) { + options = options || {}; + var evaldRoot; + var variables = options.variables; + var evalEnv = new contexts.Eval(options); + // + // Allows setting variables with a hash, so: + // + // `{ color: new tree.Color('#f01') }` will become: + // + // new tree.Declaration('@color', + // new tree.Value([ + // new tree.Expression([ + // new tree.Color('#f01') + // ]) + // ]) + // ) + // + if (typeof variables === 'object' && !Array.isArray(variables)) { + variables = Object.keys(variables).map(function (k) { + var value = variables[k]; + if (!(value instanceof tree.Value)) { + if (!(value instanceof tree.Expression)) { + value = new tree.Expression([value]); + } + value = new tree.Value([value]); + } + return new tree.Declaration("@" + k, value, false, null, 0); + }); + evalEnv.frames = [new tree.Ruleset(null, variables)]; + } + var visitors$1 = [ + new visitors.JoinSelectorVisitor(), + new visitors.MarkVisibleSelectorsVisitor(true), + new visitors.ExtendVisitor(), + new visitors.ToCSSVisitor({ compress: Boolean(options.compress) }) + ]; + var preEvalVisitors = []; + var v; + var visitorIterator; + /** + * first() / get() allows visitors to be added while visiting + * + * @todo Add scoping for visitors just like functions for @plugin; right now they're global + */ + if (options.pluginManager) { + visitorIterator = options.pluginManager.visitor(); + for (var i = 0; i < 2; i++) { + visitorIterator.first(); + while ((v = visitorIterator.get())) { + if (v.isPreEvalVisitor) { + if (i === 0 || preEvalVisitors.indexOf(v) === -1) { + preEvalVisitors.push(v); + v.run(root); + } + } + else { + if (i === 0 || visitors$1.indexOf(v) === -1) { + if (v.isPreVisitor) { + visitors$1.unshift(v); + } + else { + visitors$1.push(v); + } + } + } + } + } + } + evaldRoot = root.eval(evalEnv); + for (var i = 0; i < visitors$1.length; i++) { + visitors$1[i].run(evaldRoot); + } + // Run any remaining visitors added after eval pass + if (options.pluginManager) { + visitorIterator.first(); + while ((v = visitorIterator.get())) { + if (visitors$1.indexOf(v) === -1 && preEvalVisitors.indexOf(v) === -1) { + v.run(evaldRoot); + } + } + } + return evaldRoot; + } - var sourceMapBuilder = (function (SourceMapOutput, environment) { - var SourceMapBuilder = /** @class */ (function () { - function SourceMapBuilder(options) { - this.options = options; - } - SourceMapBuilder.prototype.toCSS = function (rootNode, options, imports) { - var sourceMapOutput = new SourceMapOutput({ - contentsIgnoredCharsMap: imports.contentsIgnoredChars, - rootNode: rootNode, - contentsMap: imports.contents, - sourceMapFilename: this.options.sourceMapFilename, - sourceMapURL: this.options.sourceMapURL, - outputFilename: this.options.sourceMapOutputFilename, - sourceMapBasepath: this.options.sourceMapBasepath, - sourceMapRootpath: this.options.sourceMapRootpath, - outputSourceFiles: this.options.outputSourceFiles, - sourceMapGenerator: this.options.sourceMapGenerator, - sourceMapFileInline: this.options.sourceMapFileInline, - disableSourcemapAnnotation: this.options.disableSourcemapAnnotation - }); - var css = sourceMapOutput.toCSS(options); - this.sourceMap = sourceMapOutput.sourceMap; - this.sourceMapURL = sourceMapOutput.sourceMapURL; - if (this.options.sourceMapInputFilename) { - this.sourceMapInputFilename = sourceMapOutput.normalizeFilename(this.options.sourceMapInputFilename); - } - if (this.options.sourceMapBasepath !== undefined && this.sourceMapURL !== undefined) { - this.sourceMapURL = sourceMapOutput.removeBasepath(this.sourceMapURL); - } - return css + this.getCSSAppendage(); - }; - SourceMapBuilder.prototype.getCSSAppendage = function () { - var sourceMapURL = this.sourceMapURL; - if (this.options.sourceMapFileInline) { - if (this.sourceMap === undefined) { - return ''; - } - sourceMapURL = "data:application/json;base64," + environment.encodeBase64(this.sourceMap); - } - if (this.options.disableSourcemapAnnotation) { - return ''; - } - if (sourceMapURL) { - return "/*# sourceMappingURL=" + sourceMapURL + " */"; - } - return ''; - }; - SourceMapBuilder.prototype.getExternalSourceMap = function () { - return this.sourceMap; - }; - SourceMapBuilder.prototype.setExternalSourceMap = function (sourceMap) { - this.sourceMap = sourceMap; - }; - SourceMapBuilder.prototype.isInline = function () { - return this.options.sourceMapFileInline; - }; - SourceMapBuilder.prototype.getSourceMapURL = function () { - return this.sourceMapURL; - }; - SourceMapBuilder.prototype.getOutputFilename = function () { - return this.options.sourceMapOutputFilename; - }; - SourceMapBuilder.prototype.getInputFilename = function () { - return this.sourceMapInputFilename; - }; - return SourceMapBuilder; - }()); - return SourceMapBuilder; - }); + /** + * Plugin Manager + */ + var PluginManager = /** @class */ (function () { + function PluginManager(less) { + this.less = less; + this.visitors = []; + this.preProcessors = []; + this.postProcessors = []; + this.installedPlugins = []; + this.fileManagers = []; + this.iterator = -1; + this.pluginCache = {}; + this.Loader = new less.PluginLoader(less); + } + /** + * Adds all the plugins in the array + * @param {Array} plugins + */ + PluginManager.prototype.addPlugins = function (plugins) { + if (plugins) { + for (var i = 0; i < plugins.length; i++) { + this.addPlugin(plugins[i]); + } + } + }; + /** + * + * @param plugin + * @param {String} filename + */ + PluginManager.prototype.addPlugin = function (plugin, filename, functionRegistry) { + this.installedPlugins.push(plugin); + if (filename) { + this.pluginCache[filename] = plugin; + } + if (plugin.install) { + plugin.install(this.less, this, functionRegistry || this.less.functions.functionRegistry); + } + }; + /** + * + * @param filename + */ + PluginManager.prototype.get = function (filename) { + return this.pluginCache[filename]; + }; + /** + * Adds a visitor. The visitor object has options on itself to determine + * when it should run. + * @param visitor + */ + PluginManager.prototype.addVisitor = function (visitor) { + this.visitors.push(visitor); + }; + /** + * Adds a pre processor object + * @param {object} preProcessor + * @param {number} priority - guidelines 1 = before import, 1000 = import, 2000 = after import + */ + PluginManager.prototype.addPreProcessor = function (preProcessor, priority) { + var indexToInsertAt; + for (indexToInsertAt = 0; indexToInsertAt < this.preProcessors.length; indexToInsertAt++) { + if (this.preProcessors[indexToInsertAt].priority >= priority) { + break; + } + } + this.preProcessors.splice(indexToInsertAt, 0, { preProcessor: preProcessor, priority: priority }); + }; + /** + * Adds a post processor object + * @param {object} postProcessor + * @param {number} priority - guidelines 1 = before compression, 1000 = compression, 2000 = after compression + */ + PluginManager.prototype.addPostProcessor = function (postProcessor, priority) { + var indexToInsertAt; + for (indexToInsertAt = 0; indexToInsertAt < this.postProcessors.length; indexToInsertAt++) { + if (this.postProcessors[indexToInsertAt].priority >= priority) { + break; + } + } + this.postProcessors.splice(indexToInsertAt, 0, { postProcessor: postProcessor, priority: priority }); + }; + /** + * + * @param manager + */ + PluginManager.prototype.addFileManager = function (manager) { + this.fileManagers.push(manager); + }; + /** + * + * @returns {Array} + * @private + */ + PluginManager.prototype.getPreProcessors = function () { + var preProcessors = []; + for (var i = 0; i < this.preProcessors.length; i++) { + preProcessors.push(this.preProcessors[i].preProcessor); + } + return preProcessors; + }; + /** + * + * @returns {Array} + * @private + */ + PluginManager.prototype.getPostProcessors = function () { + var postProcessors = []; + for (var i = 0; i < this.postProcessors.length; i++) { + postProcessors.push(this.postProcessors[i].postProcessor); + } + return postProcessors; + }; + /** + * + * @returns {Array} + * @private + */ + PluginManager.prototype.getVisitors = function () { + return this.visitors; + }; + PluginManager.prototype.visitor = function () { + var self = this; + return { + first: function () { + self.iterator = -1; + return self.visitors[self.iterator]; + }, + get: function () { + self.iterator += 1; + return self.visitors[self.iterator]; + } + }; + }; + /** + * + * @returns {Array} + * @private + */ + PluginManager.prototype.getFileManagers = function () { + return this.fileManagers; + }; + return PluginManager; + }()); + var pm; + var PluginManagerFactory = function (less, newFactory) { + if (newFactory || !pm) { + pm = new PluginManager(less); + } + return pm; + }; - var transformTree = (function (root, options) { - if (options === void 0) { options = {}; } - var evaldRoot; - var variables = options.variables; - var evalEnv = new contexts.Eval(options); - // - // Allows setting variables with a hash, so: - // - // `{ color: new tree.Color('#f01') }` will become: - // - // new tree.Declaration('@color', - // new tree.Value([ - // new tree.Expression([ - // new tree.Color('#f01') - // ]) - // ]) - // ) - // - if (typeof variables === 'object' && !Array.isArray(variables)) { - variables = Object.keys(variables).map(function (k) { - var value = variables[k]; - if (!(value instanceof tree.Value)) { - if (!(value instanceof tree.Expression)) { - value = new tree.Expression([value]); - } - value = new tree.Value([value]); - } - return new tree.Declaration("@" + k, value, false, null, 0); - }); - evalEnv.frames = [new tree.Ruleset(null, variables)]; - } - var visitors$1 = [ - new visitors.JoinSelectorVisitor(), - new visitors.MarkVisibleSelectorsVisitor(true), - new visitors.ExtendVisitor(), - new visitors.ToCSSVisitor({ compress: Boolean(options.compress) }) - ]; - var preEvalVisitors = []; - var v; - var visitorIterator; - /** - * first() / get() allows visitors to be added while visiting - * - * @todo Add scoping for visitors just like functions for @plugin; right now they're global - */ - if (options.pluginManager) { - visitorIterator = options.pluginManager.visitor(); - for (var i = 0; i < 2; i++) { - visitorIterator.first(); - while ((v = visitorIterator.get())) { - if (v.isPreEvalVisitor) { - if (i === 0 || preEvalVisitors.indexOf(v) === -1) { - preEvalVisitors.push(v); - v.run(root); - } - } - else { - if (i === 0 || visitors$1.indexOf(v) === -1) { - if (v.isPreVisitor) { - visitors$1.unshift(v); - } - else { - visitors$1.push(v); - } - } - } - } - } - } - evaldRoot = root.eval(evalEnv); - for (var i = 0; i < visitors$1.length; i++) { - visitors$1[i].run(evaldRoot); - } - // Run any remaining visitors added after eval pass - if (options.pluginManager) { - visitorIterator.first(); - while ((v = visitorIterator.get())) { - if (visitors$1.indexOf(v) === -1 && preEvalVisitors.indexOf(v) === -1) { - v.run(evaldRoot); - } - } - } - return evaldRoot; - }); + function SourceMapOutput (environment) { + var SourceMapOutput = /** @class */ (function () { + function SourceMapOutput(options) { + this._css = []; + this._rootNode = options.rootNode; + this._contentsMap = options.contentsMap; + this._contentsIgnoredCharsMap = options.contentsIgnoredCharsMap; + if (options.sourceMapFilename) { + this._sourceMapFilename = options.sourceMapFilename.replace(/\\/g, '/'); + } + this._outputFilename = options.outputFilename; + this.sourceMapURL = options.sourceMapURL; + if (options.sourceMapBasepath) { + this._sourceMapBasepath = options.sourceMapBasepath.replace(/\\/g, '/'); + } + if (options.sourceMapRootpath) { + this._sourceMapRootpath = options.sourceMapRootpath.replace(/\\/g, '/'); + if (this._sourceMapRootpath.charAt(this._sourceMapRootpath.length - 1) !== '/') { + this._sourceMapRootpath += '/'; + } + } + else { + this._sourceMapRootpath = ''; + } + this._outputSourceFiles = options.outputSourceFiles; + this._sourceMapGeneratorConstructor = environment.getSourceMapGenerator(); + this._lineNumber = 0; + this._column = 0; + } + SourceMapOutput.prototype.removeBasepath = function (path) { + if (this._sourceMapBasepath && path.indexOf(this._sourceMapBasepath) === 0) { + path = path.substring(this._sourceMapBasepath.length); + if (path.charAt(0) === '\\' || path.charAt(0) === '/') { + path = path.substring(1); + } + } + return path; + }; + SourceMapOutput.prototype.normalizeFilename = function (filename) { + filename = filename.replace(/\\/g, '/'); + filename = this.removeBasepath(filename); + return (this._sourceMapRootpath || '') + filename; + }; + SourceMapOutput.prototype.add = function (chunk, fileInfo, index, mapLines) { + // ignore adding empty strings + if (!chunk) { + return; + } + var lines, sourceLines, columns, sourceColumns, i; + if (fileInfo && fileInfo.filename) { + var inputSource = this._contentsMap[fileInfo.filename]; + // remove vars/banner added to the top of the file + if (this._contentsIgnoredCharsMap[fileInfo.filename]) { + // adjust the index + index -= this._contentsIgnoredCharsMap[fileInfo.filename]; + if (index < 0) { + index = 0; + } + // adjust the source + inputSource = inputSource.slice(this._contentsIgnoredCharsMap[fileInfo.filename]); + } + /** + * ignore empty content, or failsafe + * if contents map is incorrect + */ + if (inputSource === undefined) { + this._css.push(chunk); + return; + } + inputSource = inputSource.substring(0, index); + sourceLines = inputSource.split('\n'); + sourceColumns = sourceLines[sourceLines.length - 1]; + } + lines = chunk.split('\n'); + columns = lines[lines.length - 1]; + if (fileInfo && fileInfo.filename) { + if (!mapLines) { + this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + 1, column: this._column }, + original: { line: sourceLines.length, column: sourceColumns.length }, + source: this.normalizeFilename(fileInfo.filename) }); + } + else { + for (i = 0; i < lines.length; i++) { + this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + i + 1, column: i === 0 ? this._column : 0 }, + original: { line: sourceLines.length + i, column: i === 0 ? sourceColumns.length : 0 }, + source: this.normalizeFilename(fileInfo.filename) }); + } + } + } + if (lines.length === 1) { + this._column += columns.length; + } + else { + this._lineNumber += lines.length - 1; + this._column = columns.length; + } + this._css.push(chunk); + }; + SourceMapOutput.prototype.isEmpty = function () { + return this._css.length === 0; + }; + SourceMapOutput.prototype.toCSS = function (context) { + this._sourceMapGenerator = new this._sourceMapGeneratorConstructor({ file: this._outputFilename, sourceRoot: null }); + if (this._outputSourceFiles) { + for (var filename in this._contentsMap) { + if (this._contentsMap.hasOwnProperty(filename)) { + var source = this._contentsMap[filename]; + if (this._contentsIgnoredCharsMap[filename]) { + source = source.slice(this._contentsIgnoredCharsMap[filename]); + } + this._sourceMapGenerator.setSourceContent(this.normalizeFilename(filename), source); + } + } + } + this._rootNode.genCSS(context, this); + if (this._css.length > 0) { + var sourceMapURL = void 0; + var sourceMapContent = JSON.stringify(this._sourceMapGenerator.toJSON()); + if (this.sourceMapURL) { + sourceMapURL = this.sourceMapURL; + } + else if (this._sourceMapFilename) { + sourceMapURL = this._sourceMapFilename; + } + this.sourceMapURL = sourceMapURL; + this.sourceMap = sourceMapContent; + } + return this._css.join(''); + }; + return SourceMapOutput; + }()); + return SourceMapOutput; + } - var parseTree = (function (SourceMapBuilder) { - var ParseTree = /** @class */ (function () { - function ParseTree(root, imports) { - this.root = root; - this.imports = imports; - } - ParseTree.prototype.toCSS = function (options) { - var evaldRoot; - var result = {}; - var sourceMapBuilder; - try { - evaldRoot = transformTree(this.root, options); - } - catch (e) { - throw new LessError(e, this.imports); - } - try { - var compress = Boolean(options.compress); - if (compress) { - logger.warn('The compress option has been deprecated. ' + - 'We recommend you use a dedicated css minifier, for instance see less-plugin-clean-css.'); - } - var toCSSOptions = { - compress: compress, - dumpLineNumbers: options.dumpLineNumbers, - strictUnits: Boolean(options.strictUnits), - numPrecision: 8 - }; - if (options.sourceMap) { - sourceMapBuilder = new SourceMapBuilder(options.sourceMap); - result.css = sourceMapBuilder.toCSS(evaldRoot, toCSSOptions, this.imports); - } - else { - result.css = evaldRoot.toCSS(toCSSOptions); - } - } - catch (e) { - throw new LessError(e, this.imports); - } - if (options.pluginManager) { - var postProcessors = options.pluginManager.getPostProcessors(); - for (var i = 0; i < postProcessors.length; i++) { - result.css = postProcessors[i].process(result.css, { sourceMap: sourceMapBuilder, options: options, imports: this.imports }); - } - } - if (options.sourceMap) { - result.map = sourceMapBuilder.getExternalSourceMap(); - } - result.imports = []; - for (var file in this.imports.files) { - if (this.imports.files.hasOwnProperty(file) && file !== this.imports.rootFilename) { - result.imports.push(file); - } - } - return result; - }; - return ParseTree; - }()); - return ParseTree; - }); + function SourceMapBuilder (SourceMapOutput, environment) { + var SourceMapBuilder = /** @class */ (function () { + function SourceMapBuilder(options) { + this.options = options; + } + SourceMapBuilder.prototype.toCSS = function (rootNode, options, imports) { + var sourceMapOutput = new SourceMapOutput({ + contentsIgnoredCharsMap: imports.contentsIgnoredChars, + rootNode: rootNode, + contentsMap: imports.contents, + sourceMapFilename: this.options.sourceMapFilename, + sourceMapURL: this.options.sourceMapURL, + outputFilename: this.options.sourceMapOutputFilename, + sourceMapBasepath: this.options.sourceMapBasepath, + sourceMapRootpath: this.options.sourceMapRootpath, + outputSourceFiles: this.options.outputSourceFiles, + sourceMapGenerator: this.options.sourceMapGenerator, + sourceMapFileInline: this.options.sourceMapFileInline, + disableSourcemapAnnotation: this.options.disableSourcemapAnnotation + }); + var css = sourceMapOutput.toCSS(options); + this.sourceMap = sourceMapOutput.sourceMap; + this.sourceMapURL = sourceMapOutput.sourceMapURL; + if (this.options.sourceMapInputFilename) { + this.sourceMapInputFilename = sourceMapOutput.normalizeFilename(this.options.sourceMapInputFilename); + } + if (this.options.sourceMapBasepath !== undefined && this.sourceMapURL !== undefined) { + this.sourceMapURL = sourceMapOutput.removeBasepath(this.sourceMapURL); + } + return css + this.getCSSAppendage(); + }; + SourceMapBuilder.prototype.getCSSAppendage = function () { + var sourceMapURL = this.sourceMapURL; + if (this.options.sourceMapFileInline) { + if (this.sourceMap === undefined) { + return ''; + } + sourceMapURL = "data:application/json;base64," + environment.encodeBase64(this.sourceMap); + } + if (this.options.disableSourcemapAnnotation) { + return ''; + } + if (sourceMapURL) { + return "/*# sourceMappingURL=" + sourceMapURL + " */"; + } + return ''; + }; + SourceMapBuilder.prototype.getExternalSourceMap = function () { + return this.sourceMap; + }; + SourceMapBuilder.prototype.setExternalSourceMap = function (sourceMap) { + this.sourceMap = sourceMap; + }; + SourceMapBuilder.prototype.isInline = function () { + return this.options.sourceMapFileInline; + }; + SourceMapBuilder.prototype.getSourceMapURL = function () { + return this.sourceMapURL; + }; + SourceMapBuilder.prototype.getOutputFilename = function () { + return this.options.sourceMapOutputFilename; + }; + SourceMapBuilder.prototype.getInputFilename = function () { + return this.sourceMapInputFilename; + }; + return SourceMapBuilder; + }()); + return SourceMapBuilder; + } - function importManager (environment) { - // FileInfo = { - // 'rewriteUrls' - option - whether to adjust URL's to be relative - // 'filename' - full resolved filename of current file - // 'rootpath' - path to append to normal URLs for this node - // 'currentDirectory' - path to the current file, absolute - // 'rootFilename' - filename of the base file - // 'entryPath' - absolute path to the entry file - // 'reference' - whether the file should not be output and only output parts that are referenced - var ImportManager = /** @class */ (function () { - function ImportManager(less, context, rootFileInfo) { - this.less = less; - this.rootFilename = rootFileInfo.filename; - this.paths = context.paths || []; // Search paths, when importing - this.contents = {}; // map - filename to contents of all the files - this.contentsIgnoredChars = {}; // map - filename to lines at the beginning of each file to ignore - this.mime = context.mime; - this.error = null; - this.context = context; - // Deprecated? Unused outside of here, could be useful. - this.queue = []; // Files which haven't been imported yet - this.files = {}; // Holds the imported parse trees. - } - /** - * Add an import to be imported - * @param path - the raw path - * @param tryAppendExtension - whether to try appending a file extension (.less or .js if the path has no extension) - * @param currentFileInfo - the current file info (used for instance to work out relative paths) - * @param importOptions - import options - * @param callback - callback for when it is imported - */ - ImportManager.prototype.push = function (path, tryAppendExtension, currentFileInfo, importOptions, callback) { - var importManager = this, pluginLoader = this.context.pluginManager.Loader; - this.queue.push(path); - var fileParsedFunc = function (e, root, fullPath) { - importManager.queue.splice(importManager.queue.indexOf(path), 1); // Remove the path from the queue - var importedEqualsRoot = fullPath === importManager.rootFilename; - if (importOptions.optional && e) { - callback(null, { rules: [] }, false, null); - logger.info("The file " + fullPath + " was skipped because it was not found and the import was marked optional."); - } - else { - // Inline imports aren't cached here. - // If we start to cache them, please make sure they won't conflict with non-inline imports of the - // same name as they used to do before this comment and the condition below have been added. - if (!importManager.files[fullPath] && !importOptions.inline) { - importManager.files[fullPath] = { root: root, options: importOptions }; - } - if (e && !importManager.error) { - importManager.error = e; - } - callback(e, root, importedEqualsRoot, fullPath); - } - }; - var newFileInfo = { - rewriteUrls: this.context.rewriteUrls, - entryPath: currentFileInfo.entryPath, - rootpath: currentFileInfo.rootpath, - rootFilename: currentFileInfo.rootFilename - }; - var fileManager = environment.getFileManager(path, currentFileInfo.currentDirectory, this.context, environment); - if (!fileManager) { - fileParsedFunc({ message: "Could not find a file-manager for " + path }); - return; - } - var loadFileCallback = function (loadedFile) { - var plugin; - var resolvedFilename = loadedFile.filename; - var contents = loadedFile.contents.replace(/^\uFEFF/, ''); - // Pass on an updated rootpath if path of imported file is relative and file - // is in a (sub|sup) directory - // - // Examples: - // - If path of imported file is 'module/nav/nav.less' and rootpath is 'less/', - // then rootpath should become 'less/module/nav/' - // - If path of imported file is '../mixins.less' and rootpath is 'less/', - // then rootpath should become 'less/../' - newFileInfo.currentDirectory = fileManager.getPath(resolvedFilename); - if (newFileInfo.rewriteUrls) { - newFileInfo.rootpath = fileManager.join((importManager.context.rootpath || ''), fileManager.pathDiff(newFileInfo.currentDirectory, newFileInfo.entryPath)); - if (!fileManager.isPathAbsolute(newFileInfo.rootpath) && fileManager.alwaysMakePathsAbsolute()) { - newFileInfo.rootpath = fileManager.join(newFileInfo.entryPath, newFileInfo.rootpath); - } - } - newFileInfo.filename = resolvedFilename; - var newEnv = new contexts.Parse(importManager.context); - newEnv.processImports = false; - importManager.contents[resolvedFilename] = contents; - if (currentFileInfo.reference || importOptions.reference) { - newFileInfo.reference = true; - } - if (importOptions.isPlugin) { - plugin = pluginLoader.evalPlugin(contents, newEnv, importManager, importOptions.pluginArgs, newFileInfo); - if (plugin instanceof LessError) { - fileParsedFunc(plugin, null, resolvedFilename); - } - else { - fileParsedFunc(null, plugin, resolvedFilename); - } - } - else if (importOptions.inline) { - fileParsedFunc(null, contents, resolvedFilename); - } - else { - // import (multiple) parse trees apparently get altered and can't be cached. - // TODO: investigate why this is - if (importManager.files[resolvedFilename] - && !importManager.files[resolvedFilename].options.multiple - && !importOptions.multiple) { - fileParsedFunc(null, importManager.files[resolvedFilename].root, resolvedFilename); - } - else { - new Parser(newEnv, importManager, newFileInfo).parse(contents, function (e, root) { - fileParsedFunc(e, root, resolvedFilename); - }); - } - } - }; - var loadedFile; - var promise; - var context = clone(this.context); - if (tryAppendExtension) { - context.ext = importOptions.isPlugin ? '.js' : '.less'; - } - if (importOptions.isPlugin) { - context.mime = 'application/javascript'; - if (context.syncImport) { - loadedFile = pluginLoader.loadPluginSync(path, currentFileInfo.currentDirectory, context, environment, fileManager); - } - else { - promise = pluginLoader.loadPlugin(path, currentFileInfo.currentDirectory, context, environment, fileManager); - } - } - else { - if (context.syncImport) { - loadedFile = fileManager.loadFileSync(path, currentFileInfo.currentDirectory, context, environment); - } - else { - promise = fileManager.loadFile(path, currentFileInfo.currentDirectory, context, environment, function (err, loadedFile) { - if (err) { - fileParsedFunc(err); - } - else { - loadFileCallback(loadedFile); - } - }); - } - } - if (loadedFile) { - if (!loadedFile.filename) { - fileParsedFunc(loadedFile); - } - else { - loadFileCallback(loadedFile); - } - } - else if (promise) { - promise.then(loadFileCallback, fileParsedFunc); - } - }; - return ImportManager; - }()); - return ImportManager; - } + function ParseTree (SourceMapBuilder) { + var ParseTree = /** @class */ (function () { + function ParseTree(root, imports) { + this.root = root; + this.imports = imports; + } + ParseTree.prototype.toCSS = function (options) { + var evaldRoot; + var result = {}; + var sourceMapBuilder; + try { + evaldRoot = transformTree(this.root, options); + } + catch (e) { + throw new LessError(e, this.imports); + } + try { + var compress = Boolean(options.compress); + if (compress) { + logger.warn('The compress option has been deprecated. ' + + 'We recommend you use a dedicated css minifier, for instance see less-plugin-clean-css.'); + } + var toCSSOptions = { + compress: compress, + dumpLineNumbers: options.dumpLineNumbers, + strictUnits: Boolean(options.strictUnits), + numPrecision: 8 + }; + if (options.sourceMap) { + sourceMapBuilder = new SourceMapBuilder(options.sourceMap); + result.css = sourceMapBuilder.toCSS(evaldRoot, toCSSOptions, this.imports); + } + else { + result.css = evaldRoot.toCSS(toCSSOptions); + } + } + catch (e) { + throw new LessError(e, this.imports); + } + if (options.pluginManager) { + var postProcessors = options.pluginManager.getPostProcessors(); + for (var i = 0; i < postProcessors.length; i++) { + result.css = postProcessors[i].process(result.css, { sourceMap: sourceMapBuilder, options: options, imports: this.imports }); + } + } + if (options.sourceMap) { + result.map = sourceMapBuilder.getExternalSourceMap(); + } + result.imports = []; + for (var file in this.imports.files) { + if (this.imports.files.hasOwnProperty(file) && file !== this.imports.rootFilename) { + result.imports.push(file); + } + } + return result; + }; + return ParseTree; + }()); + return ParseTree; + } - var Render = (function (environment, ParseTree, ImportManager) { - var render = function (input, options, callback) { - if (typeof options === 'function') { - callback = options; - options = copyOptions(this.options, {}); - } - else { - options = copyOptions(this.options, options || {}); - } - if (!callback) { - var self_1 = this; - return new Promise(function (resolve, reject) { - render.call(self_1, input, options, function (err, output) { - if (err) { - reject(err); - } - else { - resolve(output); - } - }); - }); - } - else { - this.parse(input, options, function (err, root, imports, options) { - if (err) { - return callback(err); - } - var result; - try { - var parseTree = new ParseTree(root, imports); - result = parseTree.toCSS(options); - } - catch (err) { - return callback(err); - } - callback(null, result); - }); - } - }; - return render; - }); + function ImportManager (environment) { + // FileInfo = { + // 'rewriteUrls' - option - whether to adjust URL's to be relative + // 'filename' - full resolved filename of current file + // 'rootpath' - path to append to normal URLs for this node + // 'currentDirectory' - path to the current file, absolute + // 'rootFilename' - filename of the base file + // 'entryPath' - absolute path to the entry file + // 'reference' - whether the file should not be output and only output parts that are referenced + var ImportManager = /** @class */ (function () { + function ImportManager(less, context, rootFileInfo) { + this.less = less; + this.rootFilename = rootFileInfo.filename; + this.paths = context.paths || []; // Search paths, when importing + this.contents = {}; // map - filename to contents of all the files + this.contentsIgnoredChars = {}; // map - filename to lines at the beginning of each file to ignore + this.mime = context.mime; + this.error = null; + this.context = context; + // Deprecated? Unused outside of here, could be useful. + this.queue = []; // Files which haven't been imported yet + this.files = {}; // Holds the imported parse trees. + } + /** + * Add an import to be imported + * @param path - the raw path + * @param tryAppendExtension - whether to try appending a file extension (.less or .js if the path has no extension) + * @param currentFileInfo - the current file info (used for instance to work out relative paths) + * @param importOptions - import options + * @param callback - callback for when it is imported + */ + ImportManager.prototype.push = function (path, tryAppendExtension, currentFileInfo, importOptions, callback) { + var importManager = this, pluginLoader = this.context.pluginManager.Loader; + this.queue.push(path); + var fileParsedFunc = function (e, root, fullPath) { + importManager.queue.splice(importManager.queue.indexOf(path), 1); // Remove the path from the queue + var importedEqualsRoot = fullPath === importManager.rootFilename; + if (importOptions.optional && e) { + callback(null, { rules: [] }, false, null); + logger.info("The file " + fullPath + " was skipped because it was not found and the import was marked optional."); + } + else { + // Inline imports aren't cached here. + // If we start to cache them, please make sure they won't conflict with non-inline imports of the + // same name as they used to do before this comment and the condition below have been added. + if (!importManager.files[fullPath] && !importOptions.inline) { + importManager.files[fullPath] = { root: root, options: importOptions }; + } + if (e && !importManager.error) { + importManager.error = e; + } + callback(e, root, importedEqualsRoot, fullPath); + } + }; + var newFileInfo = { + rewriteUrls: this.context.rewriteUrls, + entryPath: currentFileInfo.entryPath, + rootpath: currentFileInfo.rootpath, + rootFilename: currentFileInfo.rootFilename + }; + var fileManager = environment.getFileManager(path, currentFileInfo.currentDirectory, this.context, environment); + if (!fileManager) { + fileParsedFunc({ message: "Could not find a file-manager for " + path }); + return; + } + var loadFileCallback = function (loadedFile) { + var plugin; + var resolvedFilename = loadedFile.filename; + var contents = loadedFile.contents.replace(/^\uFEFF/, ''); + // Pass on an updated rootpath if path of imported file is relative and file + // is in a (sub|sup) directory + // + // Examples: + // - If path of imported file is 'module/nav/nav.less' and rootpath is 'less/', + // then rootpath should become 'less/module/nav/' + // - If path of imported file is '../mixins.less' and rootpath is 'less/', + // then rootpath should become 'less/../' + newFileInfo.currentDirectory = fileManager.getPath(resolvedFilename); + if (newFileInfo.rewriteUrls) { + newFileInfo.rootpath = fileManager.join((importManager.context.rootpath || ''), fileManager.pathDiff(newFileInfo.currentDirectory, newFileInfo.entryPath)); + if (!fileManager.isPathAbsolute(newFileInfo.rootpath) && fileManager.alwaysMakePathsAbsolute()) { + newFileInfo.rootpath = fileManager.join(newFileInfo.entryPath, newFileInfo.rootpath); + } + } + newFileInfo.filename = resolvedFilename; + var newEnv = new contexts.Parse(importManager.context); + newEnv.processImports = false; + importManager.contents[resolvedFilename] = contents; + if (currentFileInfo.reference || importOptions.reference) { + newFileInfo.reference = true; + } + if (importOptions.isPlugin) { + plugin = pluginLoader.evalPlugin(contents, newEnv, importManager, importOptions.pluginArgs, newFileInfo); + if (plugin instanceof LessError) { + fileParsedFunc(plugin, null, resolvedFilename); + } + else { + fileParsedFunc(null, plugin, resolvedFilename); + } + } + else if (importOptions.inline) { + fileParsedFunc(null, contents, resolvedFilename); + } + else { + // import (multiple) parse trees apparently get altered and can't be cached. + // TODO: investigate why this is + if (importManager.files[resolvedFilename] + && !importManager.files[resolvedFilename].options.multiple + && !importOptions.multiple) { + fileParsedFunc(null, importManager.files[resolvedFilename].root, resolvedFilename); + } + else { + new Parser(newEnv, importManager, newFileInfo).parse(contents, function (e, root) { + fileParsedFunc(e, root, resolvedFilename); + }); + } + } + }; + var loadedFile; + var promise; + var context = clone(this.context); + if (tryAppendExtension) { + context.ext = importOptions.isPlugin ? '.js' : '.less'; + } + if (importOptions.isPlugin) { + context.mime = 'application/javascript'; + if (context.syncImport) { + loadedFile = pluginLoader.loadPluginSync(path, currentFileInfo.currentDirectory, context, environment, fileManager); + } + else { + promise = pluginLoader.loadPlugin(path, currentFileInfo.currentDirectory, context, environment, fileManager); + } + } + else { + if (context.syncImport) { + loadedFile = fileManager.loadFileSync(path, currentFileInfo.currentDirectory, context, environment); + } + else { + promise = fileManager.loadFile(path, currentFileInfo.currentDirectory, context, environment, function (err, loadedFile) { + if (err) { + fileParsedFunc(err); + } + else { + loadFileCallback(loadedFile); + } + }); + } + } + if (loadedFile) { + if (!loadedFile.filename) { + fileParsedFunc(loadedFile); + } + else { + loadFileCallback(loadedFile); + } + } + else if (promise) { + promise.then(loadFileCallback, fileParsedFunc); + } + }; + return ImportManager; + }()); + return ImportManager; + } - /** - * Plugin Manager - */ - var PluginManager = /** @class */ (function () { - function PluginManager(less) { - this.less = less; - this.visitors = []; - this.preProcessors = []; - this.postProcessors = []; - this.installedPlugins = []; - this.fileManagers = []; - this.iterator = -1; - this.pluginCache = {}; - this.Loader = new less.PluginLoader(less); - } - /** - * Adds all the plugins in the array - * @param {Array} plugins - */ - PluginManager.prototype.addPlugins = function (plugins) { - if (plugins) { - for (var i = 0; i < plugins.length; i++) { - this.addPlugin(plugins[i]); - } - } - }; - /** - * - * @param plugin - * @param {String} filename - */ - PluginManager.prototype.addPlugin = function (plugin, filename, functionRegistry) { - this.installedPlugins.push(plugin); - if (filename) { - this.pluginCache[filename] = plugin; - } - if (plugin.install) { - plugin.install(this.less, this, functionRegistry || this.less.functions.functionRegistry); - } - }; - /** - * - * @param filename - */ - PluginManager.prototype.get = function (filename) { - return this.pluginCache[filename]; - }; - /** - * Adds a visitor. The visitor object has options on itself to determine - * when it should run. - * @param visitor - */ - PluginManager.prototype.addVisitor = function (visitor) { - this.visitors.push(visitor); - }; - /** - * Adds a pre processor object - * @param {object} preProcessor - * @param {number} priority - guidelines 1 = before import, 1000 = import, 2000 = after import - */ - PluginManager.prototype.addPreProcessor = function (preProcessor, priority) { - var indexToInsertAt; - for (indexToInsertAt = 0; indexToInsertAt < this.preProcessors.length; indexToInsertAt++) { - if (this.preProcessors[indexToInsertAt].priority >= priority) { - break; - } - } - this.preProcessors.splice(indexToInsertAt, 0, { preProcessor: preProcessor, priority: priority }); - }; - /** - * Adds a post processor object - * @param {object} postProcessor - * @param {number} priority - guidelines 1 = before compression, 1000 = compression, 2000 = after compression - */ - PluginManager.prototype.addPostProcessor = function (postProcessor, priority) { - var indexToInsertAt; - for (indexToInsertAt = 0; indexToInsertAt < this.postProcessors.length; indexToInsertAt++) { - if (this.postProcessors[indexToInsertAt].priority >= priority) { - break; - } - } - this.postProcessors.splice(indexToInsertAt, 0, { postProcessor: postProcessor, priority: priority }); - }; - /** - * - * @param manager - */ - PluginManager.prototype.addFileManager = function (manager) { - this.fileManagers.push(manager); - }; - /** - * - * @returns {Array} - * @private - */ - PluginManager.prototype.getPreProcessors = function () { - var preProcessors = []; - for (var i = 0; i < this.preProcessors.length; i++) { - preProcessors.push(this.preProcessors[i].preProcessor); - } - return preProcessors; - }; - /** - * - * @returns {Array} - * @private - */ - PluginManager.prototype.getPostProcessors = function () { - var postProcessors = []; - for (var i = 0; i < this.postProcessors.length; i++) { - postProcessors.push(this.postProcessors[i].postProcessor); - } - return postProcessors; - }; - /** - * - * @returns {Array} - * @private - */ - PluginManager.prototype.getVisitors = function () { - return this.visitors; - }; - PluginManager.prototype.visitor = function () { - var self = this; - return { - first: function () { - self.iterator = -1; - return self.visitors[self.iterator]; - }, - get: function () { - self.iterator += 1; - return self.visitors[self.iterator]; - } - }; - }; - /** - * - * @returns {Array} - * @private - */ - PluginManager.prototype.getFileManagers = function () { - return this.fileManagers; - }; - return PluginManager; - }()); - var pm; - function PluginManagerFactory(less, newFactory) { - if (newFactory || !pm) { - pm = new PluginManager(less); - } - return pm; - } + function Parse (environment, ParseTree, ImportManager) { + var parse = function (input, options, callback) { + if (typeof options === 'function') { + callback = options; + options = copyOptions(this.options, {}); + } + else { + options = copyOptions(this.options, options || {}); + } + if (!callback) { + var self_1 = this; + return new Promise(function (resolve, reject) { + parse.call(self_1, input, options, function (err, output) { + if (err) { + reject(err); + } + else { + resolve(output); + } + }); + }); + } + else { + var context_1; + var rootFileInfo = void 0; + var pluginManager_1 = new PluginManagerFactory(this, !options.reUsePluginManager); + options.pluginManager = pluginManager_1; + context_1 = new contexts.Parse(options); + if (options.rootFileInfo) { + rootFileInfo = options.rootFileInfo; + } + else { + var filename = options.filename || 'input'; + var entryPath = filename.replace(/[^\/\\]*$/, ''); + rootFileInfo = { + filename: filename, + rewriteUrls: context_1.rewriteUrls, + rootpath: context_1.rootpath || '', + currentDirectory: entryPath, + entryPath: entryPath, + rootFilename: filename + }; + // add in a missing trailing slash + if (rootFileInfo.rootpath && rootFileInfo.rootpath.slice(-1) !== '/') { + rootFileInfo.rootpath += '/'; + } + } + var imports_1 = new ImportManager(this, context_1, rootFileInfo); + this.importManager = imports_1; + // TODO: allow the plugins to be just a list of paths or names + // Do an async plugin queue like lessc + if (options.plugins) { + options.plugins.forEach(function (plugin) { + var evalResult, contents; + if (plugin.fileContent) { + contents = plugin.fileContent.replace(/^\uFEFF/, ''); + evalResult = pluginManager_1.Loader.evalPlugin(contents, context_1, imports_1, plugin.options, plugin.filename); + if (evalResult instanceof LessError) { + return callback(evalResult); + } + } + else { + pluginManager_1.addPlugin(plugin); + } + }); + } + new Parser(context_1, imports_1, rootFileInfo) + .parse(input, function (e, root) { + if (e) { + return callback(e); + } + callback(null, root, imports_1, options); + }, options); + } + }; + return parse; + } - var Parse = (function (environment, ParseTree, ImportManager) { - var parse = function (input, options, callback) { - if (typeof options === 'function') { - callback = options; - options = copyOptions(this.options, {}); - } - else { - options = copyOptions(this.options, options || {}); - } - if (!callback) { - var self_1 = this; - return new Promise(function (resolve, reject) { - parse.call(self_1, input, options, function (err, output) { - if (err) { - reject(err); - } - else { - resolve(output); - } - }); - }); - } - else { - var context_1; - var rootFileInfo = void 0; - var pluginManager_1 = new PluginManagerFactory(this, !options.reUsePluginManager); - options.pluginManager = pluginManager_1; - context_1 = new contexts.Parse(options); - if (options.rootFileInfo) { - rootFileInfo = options.rootFileInfo; - } - else { - var filename = options.filename || 'input'; - var entryPath = filename.replace(/[^\/\\]*$/, ''); - rootFileInfo = { - filename: filename, - rewriteUrls: context_1.rewriteUrls, - rootpath: context_1.rootpath || '', - currentDirectory: entryPath, - entryPath: entryPath, - rootFilename: filename - }; - // add in a missing trailing slash - if (rootFileInfo.rootpath && rootFileInfo.rootpath.slice(-1) !== '/') { - rootFileInfo.rootpath += '/'; - } - } - var imports_1 = new ImportManager(this, context_1, rootFileInfo); - this.importManager = imports_1; - // TODO: allow the plugins to be just a list of paths or names - // Do an async plugin queue like lessc - if (options.plugins) { - options.plugins.forEach(function (plugin) { - var evalResult; - var contents; - if (plugin.fileContent) { - contents = plugin.fileContent.replace(/^\uFEFF/, ''); - evalResult = pluginManager_1.Loader.evalPlugin(contents, context_1, imports_1, plugin.options, plugin.filename); - if (evalResult instanceof LessError) { - return callback(evalResult); - } - } - else { - pluginManager_1.addPlugin(plugin); - } - }); - } - new Parser(context_1, imports_1, rootFileInfo) - .parse(input, function (e, root) { - if (e) { - return callback(e); - } - callback(null, root, imports_1, options); - }, options); - } - }; - return parse; - }); + function Render (environment, ParseTree, ImportManager) { + var render = function (input, options, callback) { + if (typeof options === 'function') { + callback = options; + options = copyOptions(this.options, {}); + } + else { + options = copyOptions(this.options, options || {}); + } + if (!callback) { + var self_1 = this; + return new Promise(function (resolve, reject) { + render.call(self_1, input, options, function (err, output) { + if (err) { + reject(err); + } + else { + resolve(output); + } + }); + }); + } + else { + this.parse(input, options, function (err, root, imports, options) { + if (err) { + return callback(err); + } + var result; + try { + var parseTree = new ParseTree(root, imports); + result = parseTree.toCSS(options); + } + catch (err) { + return callback(err); + } + callback(null, result); + }); + } + }; + return render; + } - var lessRoot = (function (environment$1, fileManagers) { - /** - * @todo - * This original code could be improved quite a bit. - * Many classes / modules currently add side-effects / mutations to passed in objects, - * which makes it hard to refactor and reason about. - */ - environment$1 = new environment(environment$1, fileManagers); - var SourceMapOutput = sourceMapOutput(environment$1); - var SourceMapBuilder = sourceMapBuilder(SourceMapOutput, environment$1); - var ParseTree = parseTree(SourceMapBuilder); - var ImportManager = importManager(environment$1); - var render = Render(environment$1, ParseTree); - var parse = Parse(environment$1, ParseTree, ImportManager); - var functions = Functions(environment$1); - /** - * @todo - * This root properties / methods need to be organized. - * It's not clear what should / must be public and why. - */ - var initial = { - version: [3, 13, 1], - data: data, - tree: tree, - Environment: environment, - AbstractFileManager: AbstractFileManager, - AbstractPluginLoader: AbstractPluginLoader, - environment: environment$1, - visitors: visitors, - Parser: Parser, - functions: functions, - contexts: contexts, - SourceMapOutput: SourceMapOutput, - SourceMapBuilder: SourceMapBuilder, - ParseTree: ParseTree, - ImportManager: ImportManager, - render: render, - parse: parse, - LessError: LessError, - transformTree: transformTree, - utils: utils, - PluginManager: PluginManagerFactory, - logger: logger - }; - // Create a public API - var ctor = function (t) { return function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - return new (t.bind.apply(t, __spreadArrays([void 0], args)))(); - }; }; - var t; - var api = Object.create(initial); - for (var n in initial.tree) { - /* eslint guard-for-in: 0 */ - t = initial.tree[n]; - if (typeof t === 'function') { - api[n.toLowerCase()] = ctor(t); - } - else { - api[n] = Object.create(null); - for (var o in t) { - /* eslint guard-for-in: 0 */ - api[n][o.toLowerCase()] = ctor(t[o]); - } - } - } - /** - * Some of the functions assume a `this` context of the API object, - * which causes it to fail when wrapped for ES6 imports. - * - * An assumed `this` should be removed in the future. - */ - initial.parse = initial.parse.bind(api); - initial.render = initial.render.bind(api); - return api; - }); + var version = "4.0.0"; - /* global window, XMLHttpRequest */ - var options; - var logger$1; - var fileCache = {}; - // TODOS - move log somewhere. pathDiff and doing something similar in node. use pathDiff in the other browser file for the initial load - var FileManager = /** @class */ (function (_super) { - __extends(FileManager, _super); - function FileManager() { - return _super !== null && _super.apply(this, arguments) || this; - } - FileManager.prototype.alwaysMakePathsAbsolute = function () { - return true; - }; - FileManager.prototype.join = function (basePath, laterPath) { - if (!basePath) { - return laterPath; - } - return this.extractUrlParts(laterPath, basePath).path; - }; - FileManager.prototype.doXHR = function (url, type, callback, errback) { - var xhr = new XMLHttpRequest(); - var async = options.isFileProtocol ? options.fileAsync : true; - if (typeof xhr.overrideMimeType === 'function') { - xhr.overrideMimeType('text/css'); - } - logger$1.debug("XHR: Getting '" + url + "'"); - xhr.open('GET', url, async); - xhr.setRequestHeader('Accept', type || 'text/x-less, text/css; q=0.9, */*; q=0.5'); - xhr.send(null); - function handleResponse(xhr, callback, errback) { - if (xhr.status >= 200 && xhr.status < 300) { - callback(xhr.responseText, xhr.getResponseHeader('Last-Modified')); - } - else if (typeof errback === 'function') { - errback(xhr.status, url); - } - } - if (options.isFileProtocol && !options.fileAsync) { - if (xhr.status === 0 || (xhr.status >= 200 && xhr.status < 300)) { - callback(xhr.responseText); - } - else { - errback(xhr.status, url); - } - } - else if (async) { - xhr.onreadystatechange = function () { - if (xhr.readyState == 4) { - handleResponse(xhr, callback, errback); - } - }; - } - else { - handleResponse(xhr, callback, errback); - } - }; - FileManager.prototype.supports = function () { - return true; - }; - FileManager.prototype.clearFileCache = function () { - fileCache = {}; - }; - FileManager.prototype.loadFile = function (filename, currentDirectory, options, environment) { - // TODO: Add prefix support like less-node? - // What about multiple paths? - if (currentDirectory && !this.isPathAbsolute(filename)) { - filename = currentDirectory + filename; - } - filename = options.ext ? this.tryAppendExtension(filename, options.ext) : filename; - options = options || {}; - // sheet may be set to the stylesheet for the initial load or a collection of properties including - // some context variables for imports - var hrefParts = this.extractUrlParts(filename, window.location.href); - var href = hrefParts.url; - var self = this; - return new Promise(function (resolve, reject) { - if (options.useFileCache && fileCache[href]) { - try { - var lessText = fileCache[href]; - return resolve({ contents: lessText, filename: href, webInfo: { lastModified: new Date() } }); - } - catch (e) { - return reject({ filename: href, message: "Error loading file " + href + " error was " + e.message }); - } - } - self.doXHR(href, options.mime, function doXHRCallback(data, lastModified) { - // per file cache - fileCache[href] = data; - // Use remote copy (re-parse) - resolve({ contents: data, filename: href, webInfo: { lastModified: lastModified } }); - }, function doXHRError(status, url) { - reject({ type: 'File', message: "'" + url + "' wasn't found (" + status + ")", href: href }); - }); - }); - }; - return FileManager; - }(AbstractFileManager)); - var FM = (function (opts, log) { - options = opts; - logger$1 = log; - return FileManager; - }); + function parseNodeVersion(version) { + var match = version.match(/^v(\d{1,2})\.(\d{1,2})\.(\d{1,2})(?:-([0-9A-Za-z-.]+))?(?:\+([0-9A-Za-z-.]+))?$/); // eslint-disable-line max-len + if (!match) { + throw new Error('Unable to parse: ' + version); + } + var res = { + major: parseInt(match[1], 10), + minor: parseInt(match[2], 10), + patch: parseInt(match[3], 10), + pre: match[4] || '', + build: match[5] || '', + }; + return res; + } + var parseNodeVersion_1 = parseNodeVersion; - // TODO: Add tests for browser @plugin - /** - * Browser Plugin Loader - */ - var PluginLoader = /** @class */ (function (_super) { - __extends(PluginLoader, _super); - function PluginLoader(less) { - var _this = _super.call(this) || this; - _this.less = less; - return _this; - // Should we shim this.require for browser? Probably not? - } - PluginLoader.prototype.loadPlugin = function (filename, basePath, context, environment, fileManager) { - return new Promise(function (fulfill, reject) { - fileManager.loadFile(filename, basePath, context, environment) - .then(fulfill).catch(reject); - }); - }; - return PluginLoader; - }(AbstractPluginLoader)); + function lessRoot (environment, fileManagers) { + var sourceMapOutput, sourceMapBuilder, parseTree, importManager; + environment = new Environment(environment, fileManagers); + sourceMapOutput = SourceMapOutput(environment); + sourceMapBuilder = SourceMapBuilder(sourceMapOutput, environment); + parseTree = ParseTree(sourceMapBuilder); + importManager = ImportManager(environment); + var render = Render(environment, parseTree); + var parse = Parse(environment, parseTree, importManager); + var v = parseNodeVersion_1(version); + var initial = { + version: [v.major, v.minor, v.patch], + data: data, + tree: tree, + Environment: Environment, + AbstractFileManager: AbstractFileManager, + AbstractPluginLoader: AbstractPluginLoader, + environment: environment, + visitors: visitors, + Parser: Parser, + functions: functions(environment), + contexts: contexts, + SourceMapOutput: sourceMapOutput, + SourceMapBuilder: sourceMapBuilder, + ParseTree: parseTree, + ImportManager: importManager, + render: render, + parse: parse, + LessError: LessError, + transformTree: transformTree, + utils: utils, + PluginManager: PluginManagerFactory, + logger: logger + }; + // Create a public API + var ctor = function (t) { + return function () { + var obj = Object.create(t.prototype); + t.apply(obj, Array.prototype.slice.call(arguments, 0)); + return obj; + }; + }; + var t; + var api = Object.create(initial); + for (var n in initial.tree) { + /* eslint guard-for-in: 0 */ + t = initial.tree[n]; + if (typeof t === 'function') { + api[n.toLowerCase()] = ctor(t); + } + else { + api[n] = Object.create(null); + for (var o in t) { + /* eslint guard-for-in: 0 */ + api[n][o.toLowerCase()] = ctor(t[o]); + } + } + } + /** + * Some of the functions assume a `this` context of the API object, + * which causes it to fail when wrapped for ES6 imports. + * + * An assumed `this` should be removed in the future. + */ + initial.parse = initial.parse.bind(api); + initial.render = initial.render.bind(api); + return api; + } - var LogListener = (function (less, options) { - var logLevel_debug = 4; - var logLevel_info = 3; - var logLevel_warn = 2; - var logLevel_error = 1; - // The amount of logging in the javascript console. - // 3 - Debug, information and errors - // 2 - Information and errors - // 1 - Errors - // 0 - None - // Defaults to 2 - options.logLevel = typeof options.logLevel !== 'undefined' ? options.logLevel : (options.env === 'development' ? logLevel_info : logLevel_error); - if (!options.loggers) { - options.loggers = [{ - debug: function (msg) { - if (options.logLevel >= logLevel_debug) { - console.log(msg); - } - }, - info: function (msg) { - if (options.logLevel >= logLevel_info) { - console.log(msg); - } - }, - warn: function (msg) { - if (options.logLevel >= logLevel_warn) { - console.warn(msg); - } - }, - error: function (msg) { - if (options.logLevel >= logLevel_error) { - console.error(msg); - } - } - }]; - } - for (var i = 0; i < options.loggers.length; i++) { - less.logger.addListener(options.loggers[i]); - } - }); + /* global window, XMLHttpRequest */ + var options; + var logger$1; + var fileCache = {}; + // TODOS - move log somewhere. pathDiff and doing something similar in node. use pathDiff in the other browser file for the initial load + var FileManager = function () { }; + FileManager.prototype = Object.assign(new AbstractFileManager(), { + alwaysMakePathsAbsolute: function () { + return true; + }, + join: function (basePath, laterPath) { + if (!basePath) { + return laterPath; + } + return this.extractUrlParts(laterPath, basePath).path; + }, + doXHR: function (url, type, callback, errback) { + var xhr = new XMLHttpRequest(); + var async = options.isFileProtocol ? options.fileAsync : true; + if (typeof xhr.overrideMimeType === 'function') { + xhr.overrideMimeType('text/css'); + } + logger$1.debug("XHR: Getting '" + url + "'"); + xhr.open('GET', url, async); + xhr.setRequestHeader('Accept', type || 'text/x-less, text/css; q=0.9, */*; q=0.5'); + xhr.send(null); + function handleResponse(xhr, callback, errback) { + if (xhr.status >= 200 && xhr.status < 300) { + callback(xhr.responseText, xhr.getResponseHeader('Last-Modified')); + } + else if (typeof errback === 'function') { + errback(xhr.status, url); + } + } + if (options.isFileProtocol && !options.fileAsync) { + if (xhr.status === 0 || (xhr.status >= 200 && xhr.status < 300)) { + callback(xhr.responseText); + } + else { + errback(xhr.status, url); + } + } + else if (async) { + xhr.onreadystatechange = function () { + if (xhr.readyState == 4) { + handleResponse(xhr, callback, errback); + } + }; + } + else { + handleResponse(xhr, callback, errback); + } + }, + supports: function () { + return true; + }, + clearFileCache: function () { + fileCache = {}; + }, + loadFile: function (filename, currentDirectory, options, environment) { + // TODO: Add prefix support like less-node? + // What about multiple paths? + if (currentDirectory && !this.isPathAbsolute(filename)) { + filename = currentDirectory + filename; + } + filename = options.ext ? this.tryAppendExtension(filename, options.ext) : filename; + options = options || {}; + // sheet may be set to the stylesheet for the initial load or a collection of properties including + // some context variables for imports + var hrefParts = this.extractUrlParts(filename, window.location.href); + var href = hrefParts.url; + var self = this; + return new Promise(function (resolve, reject) { + if (options.useFileCache && fileCache[href]) { + try { + var lessText = fileCache[href]; + return resolve({ contents: lessText, filename: href, webInfo: { lastModified: new Date() } }); + } + catch (e) { + return reject({ filename: href, message: "Error loading file " + href + " error was " + e.message }); + } + } + self.doXHR(href, options.mime, function doXHRCallback(data, lastModified) { + // per file cache + fileCache[href] = data; + // Use remote copy (re-parse) + resolve({ contents: data, filename: href, webInfo: { lastModified: lastModified } }); + }, function doXHRError(status, url) { + reject({ type: 'File', message: "'" + url + "' wasn't found (" + status + ")", href: href }); + }); + }); + } + }); + var FM = (function (opts, log) { + options = opts; + logger$1 = log; + return FileManager; + }); - var ErrorReporting = (function (window, less, options) { - function errorHTML(e, rootHref) { - var id = "less-error-message:" + extractId(rootHref || ''); - var template = '
  • {content}
  • '; - var elem = window.document.createElement('div'); - var timer; - var content; - var errors = []; - var filename = e.filename || rootHref; - var filenameNoPath = filename.match(/([^\/]+(\?.*)?)$/)[1]; - elem.id = id; - elem.className = 'less-error-message'; - content = "

    " + (e.type || 'Syntax') + "Error: " + (e.message || 'There is an error in your .less file') + - ("

    in " + filenameNoPath + " "); - var errorline = function (e, i, classname) { - if (e.extract[i] !== undefined) { - errors.push(template.replace(/\{line\}/, (parseInt(e.line, 10) || 0) + (i - 1)) - .replace(/\{class\}/, classname) - .replace(/\{content\}/, e.extract[i])); - } - }; - if (e.line) { - errorline(e, 0, ''); - errorline(e, 1, 'line'); - errorline(e, 2, ''); - content += "on line " + e.line + ", column " + (e.column + 1) + ":

      " + errors.join('') + "
    "; - } - if (e.stack && (e.extract || options.logLevel >= 4)) { - content += "
    Stack Trace
    " + e.stack.split('\n').slice(1).join('
    '); - } - elem.innerHTML = content; - // CSS for error messages - browser.createCSS(window.document, [ - '.less-error-message ul, .less-error-message li {', - 'list-style-type: none;', - 'margin-right: 15px;', - 'padding: 4px 0;', - 'margin: 0;', - '}', - '.less-error-message label {', - 'font-size: 12px;', - 'margin-right: 15px;', - 'padding: 4px 0;', - 'color: #cc7777;', - '}', - '.less-error-message pre {', - 'color: #dd6666;', - 'padding: 4px 0;', - 'margin: 0;', - 'display: inline-block;', - '}', - '.less-error-message pre.line {', - 'color: #ff0000;', - '}', - '.less-error-message h3 {', - 'font-size: 20px;', - 'font-weight: bold;', - 'padding: 15px 0 5px 0;', - 'margin: 0;', - '}', - '.less-error-message a {', - 'color: #10a', - '}', - '.less-error-message .error {', - 'color: red;', - 'font-weight: bold;', - 'padding-bottom: 2px;', - 'border-bottom: 1px dashed red;', - '}' - ].join('\n'), { title: 'error-message' }); - elem.style.cssText = [ - 'font-family: Arial, sans-serif', - 'border: 1px solid #e00', - 'background-color: #eee', - 'border-radius: 5px', - '-webkit-border-radius: 5px', - '-moz-border-radius: 5px', - 'color: #e00', - 'padding: 15px', - 'margin-bottom: 15px' - ].join(';'); - if (options.env === 'development') { - timer = setInterval(function () { - var document = window.document; - var body = document.body; - if (body) { - if (document.getElementById(id)) { - body.replaceChild(elem, document.getElementById(id)); - } - else { - body.insertBefore(elem, body.firstChild); - } - clearInterval(timer); - } - }, 10); - } - } - function removeErrorHTML(path) { - var node = window.document.getElementById("less-error-message:" + extractId(path)); - if (node) { - node.parentNode.removeChild(node); - } - } - function removeError(path) { - if (!options.errorReporting || options.errorReporting === 'html') { - removeErrorHTML(path); - } - else if (options.errorReporting === 'console') ; - else if (typeof options.errorReporting === 'function') { - options.errorReporting('remove', path); - } - } - function errorConsole(e, rootHref) { - var template = '{line} {content}'; - var filename = e.filename || rootHref; - var errors = []; - var content = (e.type || 'Syntax') + "Error: " + (e.message || 'There is an error in your .less file') + " in " + filename; - var errorline = function (e, i, classname) { - if (e.extract[i] !== undefined) { - errors.push(template.replace(/\{line\}/, (parseInt(e.line, 10) || 0) + (i - 1)) - .replace(/\{class\}/, classname) - .replace(/\{content\}/, e.extract[i])); - } - }; - if (e.line) { - errorline(e, 0, ''); - errorline(e, 1, 'line'); - errorline(e, 2, ''); - content += " on line " + e.line + ", column " + (e.column + 1) + ":\n" + errors.join('\n'); - } - if (e.stack && (e.extract || options.logLevel >= 4)) { - content += "\nStack Trace\n" + e.stack; - } - less.logger.error(content); - } - function error(e, rootHref) { - if (!options.errorReporting || options.errorReporting === 'html') { - errorHTML(e, rootHref); - } - else if (options.errorReporting === 'console') { - errorConsole(e, rootHref); - } - else if (typeof options.errorReporting === 'function') { - options.errorReporting('add', e, rootHref); - } - } - return { - add: error, - remove: removeError - }; - }); + // TODO: Add tests for browser @plugin + /** + * Browser Plugin Loader + */ + var PluginLoader = function (less) { + this.less = less; + // Should we shim this.require for browser? Probably not? + }; + PluginLoader.prototype = Object.assign(new AbstractPluginLoader(), { + loadPlugin: function (filename, basePath, context, environment, fileManager) { + return new Promise(function (fulfill, reject) { + fileManager.loadFile(filename, basePath, context, environment) + .then(fulfill).catch(reject); + }); + } + }); - // Cache system is a bit outdated and could do with work - var Cache = (function (window, options, logger) { - var cache = null; - if (options.env !== 'development') { - try { - cache = (typeof window.localStorage === 'undefined') ? null : window.localStorage; - } - catch (_) { } - } - return { - setCSS: function (path, lastModified, modifyVars, styles) { - if (cache) { - logger.info("saving " + path + " to cache."); - try { - cache.setItem(path, styles); - cache.setItem(path + ":timestamp", lastModified); - if (modifyVars) { - cache.setItem(path + ":vars", JSON.stringify(modifyVars)); - } - } - catch (e) { - // TODO - could do with adding more robust error handling - logger.error("failed to save \"" + path + "\" to local storage for caching."); - } - } - }, - getCSS: function (path, webInfo, modifyVars) { - var css = cache && cache.getItem(path); - var timestamp = cache && cache.getItem(path + ":timestamp"); - var vars = cache && cache.getItem(path + ":vars"); - modifyVars = modifyVars || {}; - vars = vars || "{}"; // if not set, treat as the JSON representation of an empty object - if (timestamp && webInfo.lastModified && - (new Date(webInfo.lastModified).valueOf() === - new Date(timestamp).valueOf()) && - JSON.stringify(modifyVars) === vars) { - // Use local copy - return css; - } - } - }; - }); + var LogListener = (function (less, options) { + var logLevel_debug = 4; + var logLevel_info = 3; + var logLevel_warn = 2; + var logLevel_error = 1; + // The amount of logging in the javascript console. + // 3 - Debug, information and errors + // 2 - Information and errors + // 1 - Errors + // 0 - None + // Defaults to 2 + options.logLevel = typeof options.logLevel !== 'undefined' ? options.logLevel : (options.env === 'development' ? logLevel_info : logLevel_error); + if (!options.loggers) { + options.loggers = [{ + debug: function (msg) { + if (options.logLevel >= logLevel_debug) { + console.log(msg); + } + }, + info: function (msg) { + if (options.logLevel >= logLevel_info) { + console.log(msg); + } + }, + warn: function (msg) { + if (options.logLevel >= logLevel_warn) { + console.warn(msg); + } + }, + error: function (msg) { + if (options.logLevel >= logLevel_error) { + console.error(msg); + } + } + }]; + } + for (var i = 0; i < options.loggers.length; i++) { + less.logger.addListener(options.loggers[i]); + } + }); - var ImageSize = (function () { - function imageSize() { - throw { - type: 'Runtime', - message: 'Image size functions are not supported in browser version of less' - }; - } - var imageFunctions = { - 'image-size': function (filePathNode) { - imageSize(); - return -1; - }, - 'image-width': function (filePathNode) { - imageSize(); - return -1; - }, - 'image-height': function (filePathNode) { - imageSize(); - return -1; - } - }; - functionRegistry.addMultiple(imageFunctions); - }); + var ErrorReporting = (function (window, less, options) { + function errorHTML(e, rootHref) { + var id = "less-error-message:" + extractId(rootHref || ''); + var template = '
  • {content}
  • '; + var elem = window.document.createElement('div'); + var timer; + var content; + var errors = []; + var filename = e.filename || rootHref; + var filenameNoPath = filename.match(/([^\/]+(\?.*)?)$/)[1]; + elem.id = id; + elem.className = 'less-error-message'; + content = "

    " + (e.type || 'Syntax') + "Error: " + (e.message || 'There is an error in your .less file') + + ("

    in " + filenameNoPath + " "); + var errorline = function (e, i, classname) { + if (e.extract[i] !== undefined) { + errors.push(template.replace(/\{line\}/, (parseInt(e.line, 10) || 0) + (i - 1)) + .replace(/\{class\}/, classname) + .replace(/\{content\}/, e.extract[i])); + } + }; + if (e.line) { + errorline(e, 0, ''); + errorline(e, 1, 'line'); + errorline(e, 2, ''); + content += "on line " + e.line + ", column " + (e.column + 1) + ":

      " + errors.join('') + "
    "; + } + if (e.stack && (e.extract || options.logLevel >= 4)) { + content += "
    Stack Trace
    " + e.stack.split('\n').slice(1).join('
    '); + } + elem.innerHTML = content; + // CSS for error messages + browser.createCSS(window.document, [ + '.less-error-message ul, .less-error-message li {', + 'list-style-type: none;', + 'margin-right: 15px;', + 'padding: 4px 0;', + 'margin: 0;', + '}', + '.less-error-message label {', + 'font-size: 12px;', + 'margin-right: 15px;', + 'padding: 4px 0;', + 'color: #cc7777;', + '}', + '.less-error-message pre {', + 'color: #dd6666;', + 'padding: 4px 0;', + 'margin: 0;', + 'display: inline-block;', + '}', + '.less-error-message pre.line {', + 'color: #ff0000;', + '}', + '.less-error-message h3 {', + 'font-size: 20px;', + 'font-weight: bold;', + 'padding: 15px 0 5px 0;', + 'margin: 0;', + '}', + '.less-error-message a {', + 'color: #10a', + '}', + '.less-error-message .error {', + 'color: red;', + 'font-weight: bold;', + 'padding-bottom: 2px;', + 'border-bottom: 1px dashed red;', + '}' + ].join('\n'), { title: 'error-message' }); + elem.style.cssText = [ + 'font-family: Arial, sans-serif', + 'border: 1px solid #e00', + 'background-color: #eee', + 'border-radius: 5px', + '-webkit-border-radius: 5px', + '-moz-border-radius: 5px', + 'color: #e00', + 'padding: 15px', + 'margin-bottom: 15px' + ].join(';'); + if (options.env === 'development') { + timer = setInterval(function () { + var document = window.document; + var body = document.body; + if (body) { + if (document.getElementById(id)) { + body.replaceChild(elem, document.getElementById(id)); + } + else { + body.insertBefore(elem, body.firstChild); + } + clearInterval(timer); + } + }, 10); + } + } + function removeErrorHTML(path) { + var node = window.document.getElementById("less-error-message:" + extractId(path)); + if (node) { + node.parentNode.removeChild(node); + } + } + function removeError(path) { + if (!options.errorReporting || options.errorReporting === 'html') { + removeErrorHTML(path); + } + else if (options.errorReporting === 'console') ; + else if (typeof options.errorReporting === 'function') { + options.errorReporting('remove', path); + } + } + function errorConsole(e, rootHref) { + var template = '{line} {content}'; + var filename = e.filename || rootHref; + var errors = []; + var content = (e.type || 'Syntax') + "Error: " + (e.message || 'There is an error in your .less file') + " in " + filename; + var errorline = function (e, i, classname) { + if (e.extract[i] !== undefined) { + errors.push(template.replace(/\{line\}/, (parseInt(e.line, 10) || 0) + (i - 1)) + .replace(/\{class\}/, classname) + .replace(/\{content\}/, e.extract[i])); + } + }; + if (e.line) { + errorline(e, 0, ''); + errorline(e, 1, 'line'); + errorline(e, 2, ''); + content += " on line " + e.line + ", column " + (e.column + 1) + ":\n" + errors.join('\n'); + } + if (e.stack && (e.extract || options.logLevel >= 4)) { + content += "\nStack Trace\n" + e.stack; + } + less.logger.error(content); + } + function error(e, rootHref) { + if (!options.errorReporting || options.errorReporting === 'html') { + errorHTML(e, rootHref); + } + else if (options.errorReporting === 'console') { + errorConsole(e, rootHref); + } + else if (typeof options.errorReporting === 'function') { + options.errorReporting('add', e, rootHref); + } + } + return { + add: error, + remove: removeError + }; + }); - // - var root = (function (window, options) { - var document = window.document; - var less = lessRoot(); - less.options = options; - var environment = less.environment; - var FileManager = FM(options, less.logger); - var fileManager = new FileManager(); - environment.addFileManager(fileManager); - less.FileManager = FileManager; - less.PluginLoader = PluginLoader; - LogListener(less, options); - var errors = ErrorReporting(window, less, options); - var cache = less.cache = options.cache || Cache(window, options, less.logger); - ImageSize(less.environment); - // Setup user functions - Deprecate? - if (options.functions) { - less.functions.functionRegistry.addMultiple(options.functions); - } - var typePattern = /^text\/(x-)?less$/; - function clone(obj) { - var cloned = {}; - for (var prop in obj) { - if (obj.hasOwnProperty(prop)) { - cloned[prop] = obj[prop]; - } - } - return cloned; - } - // only really needed for phantom - function bind(func, thisArg) { - var curryArgs = Array.prototype.slice.call(arguments, 2); - return function () { - var args = curryArgs.concat(Array.prototype.slice.call(arguments, 0)); - return func.apply(thisArg, args); - }; - } - function loadStyles(modifyVars) { - var styles = document.getElementsByTagName('style'); - var style; - for (var i = 0; i < styles.length; i++) { - style = styles[i]; - if (style.type.match(typePattern)) { - var instanceOptions = clone(options); - instanceOptions.modifyVars = modifyVars; - var lessText = style.innerHTML || ''; - instanceOptions.filename = document.location.href.replace(/#.*$/, ''); - /* jshint loopfunc:true */ - // use closure to store current style - less.render(lessText, instanceOptions, bind(function (style, e, result) { - if (e) { - errors.add(e, 'inline'); - } - else { - style.type = 'text/css'; - if (style.styleSheet) { - style.styleSheet.cssText = result.css; - } - else { - style.innerHTML = result.css; - } - } - }, null, style)); - } - } - } - function loadStyleSheet(sheet, callback, reload, remaining, modifyVars) { - var instanceOptions = clone(options); - addDataAttr(instanceOptions, sheet); - instanceOptions.mime = sheet.type; - if (modifyVars) { - instanceOptions.modifyVars = modifyVars; - } - function loadInitialFileCallback(loadedFile) { - var data = loadedFile.contents; - var path = loadedFile.filename; - var webInfo = loadedFile.webInfo; - var newFileInfo = { - currentDirectory: fileManager.getPath(path), - filename: path, - rootFilename: path, - rewriteUrls: instanceOptions.rewriteUrls - }; - newFileInfo.entryPath = newFileInfo.currentDirectory; - newFileInfo.rootpath = instanceOptions.rootpath || newFileInfo.currentDirectory; - if (webInfo) { - webInfo.remaining = remaining; - var css = cache.getCSS(path, webInfo, instanceOptions.modifyVars); - if (!reload && css) { - webInfo.local = true; - callback(null, css, data, sheet, webInfo, path); - return; - } - } - // TODO add tests around how this behaves when reloading - errors.remove(path); - instanceOptions.rootFileInfo = newFileInfo; - less.render(data, instanceOptions, function (e, result) { - if (e) { - e.href = path; - callback(e); - } - else { - cache.setCSS(sheet.href, webInfo.lastModified, instanceOptions.modifyVars, result.css); - callback(null, result.css, data, sheet, webInfo, path); - } - }); - } - fileManager.loadFile(sheet.href, null, instanceOptions, environment) - .then(function (loadedFile) { - loadInitialFileCallback(loadedFile); - }).catch(function (err) { - console.log(err); - callback(err); - }); - } - function loadStyleSheets(callback, reload, modifyVars) { - for (var i = 0; i < less.sheets.length; i++) { - loadStyleSheet(less.sheets[i], callback, reload, less.sheets.length - (i + 1), modifyVars); - } - } - function initRunningMode() { - if (less.env === 'development') { - less.watchTimer = setInterval(function () { - if (less.watchMode) { - fileManager.clearFileCache(); - loadStyleSheets(function (e, css, _, sheet, webInfo) { - if (e) { - errors.add(e, e.href || sheet.href); - } - else if (css) { - browser.createCSS(window.document, css, sheet); - } - }); - } - }, options.poll); - } - } - // - // Watch mode - // - less.watch = function () { - if (!less.watchMode) { - less.env = 'development'; - initRunningMode(); - } - this.watchMode = true; - return true; - }; - less.unwatch = function () { clearInterval(less.watchTimer); this.watchMode = false; return false; }; - // - // Synchronously get all tags with the 'rel' attribute set to - // "stylesheet/less". - // - less.registerStylesheetsImmediately = function () { - var links = document.getElementsByTagName('link'); - less.sheets = []; - for (var i = 0; i < links.length; i++) { - if (links[i].rel === 'stylesheet/less' || (links[i].rel.match(/stylesheet/) && - (links[i].type.match(typePattern)))) { - less.sheets.push(links[i]); - } - } - }; - // - // Asynchronously get all tags with the 'rel' attribute set to - // "stylesheet/less", returning a Promise. - // - less.registerStylesheets = function () { return new Promise(function (resolve, reject) { - less.registerStylesheetsImmediately(); - resolve(); - }); }; - // - // With this function, it's possible to alter variables and re-render - // CSS without reloading less-files - // - less.modifyVars = function (record) { return less.refresh(true, record, false); }; - less.refresh = function (reload, modifyVars, clearFileCache) { - if ((reload || clearFileCache) && clearFileCache !== false) { - fileManager.clearFileCache(); - } - return new Promise(function (resolve, reject) { - var startTime; - var endTime; - var totalMilliseconds; - var remainingSheets; - startTime = endTime = new Date(); - // Set counter for remaining unprocessed sheets - remainingSheets = less.sheets.length; - if (remainingSheets === 0) { - endTime = new Date(); - totalMilliseconds = endTime - startTime; - less.logger.info('Less has finished and no sheets were loaded.'); - resolve({ - startTime: startTime, - endTime: endTime, - totalMilliseconds: totalMilliseconds, - sheets: less.sheets.length - }); - } - else { - // Relies on less.sheets array, callback seems to be guaranteed to be called for every element of the array - loadStyleSheets(function (e, css, _, sheet, webInfo) { - if (e) { - errors.add(e, e.href || sheet.href); - reject(e); - return; - } - if (webInfo.local) { - less.logger.info("Loading " + sheet.href + " from cache."); - } - else { - less.logger.info("Rendered " + sheet.href + " successfully."); - } - browser.createCSS(window.document, css, sheet); - less.logger.info("CSS for " + sheet.href + " generated in " + (new Date() - endTime) + "ms"); - // Count completed sheet - remainingSheets--; - // Check if the last remaining sheet was processed and then call the promise - if (remainingSheets === 0) { - totalMilliseconds = new Date() - startTime; - less.logger.info("Less has finished. CSS generated in " + totalMilliseconds + "ms"); - resolve({ - startTime: startTime, - endTime: endTime, - totalMilliseconds: totalMilliseconds, - sheets: less.sheets.length - }); - } - endTime = new Date(); - }, reload, modifyVars); - } - loadStyles(modifyVars); - }); - }; - less.refreshStyles = loadStyles; - return less; - }); + // Cache system is a bit outdated and could do with work + var Cache = (function (window, options, logger) { + var cache = null; + if (options.env !== 'development') { + try { + cache = (typeof window.localStorage === 'undefined') ? null : window.localStorage; + } + catch (_) { } + } + return { + setCSS: function (path, lastModified, modifyVars, styles) { + if (cache) { + logger.info("saving " + path + " to cache."); + try { + cache.setItem(path, styles); + cache.setItem(path + ":timestamp", lastModified); + if (modifyVars) { + cache.setItem(path + ":vars", JSON.stringify(modifyVars)); + } + } + catch (e) { + // TODO - could do with adding more robust error handling + logger.error("failed to save \"" + path + "\" to local storage for caching."); + } + } + }, + getCSS: function (path, webInfo, modifyVars) { + var css = cache && cache.getItem(path); + var timestamp = cache && cache.getItem(path + ":timestamp"); + var vars = cache && cache.getItem(path + ":vars"); + modifyVars = modifyVars || {}; + vars = vars || "{}"; // if not set, treat as the JSON representation of an empty object + if (timestamp && webInfo.lastModified && + (new Date(webInfo.lastModified).valueOf() === + new Date(timestamp).valueOf()) && + JSON.stringify(modifyVars) === vars) { + // Use local copy + return css; + } + } + }; + }); - /** - * Kicks off less and compiles any stylesheets - * used in the browser distributed version of less - * to kick-start less using the browser api - */ - var options$1 = defaultOptions(); - if (window.less) { - for (var key in window.less) { - if (window.less.hasOwnProperty(key)) { - options$1[key] = window.less[key]; - } - } - } - addDefaultOptions(window, options$1); - options$1.plugins = options$1.plugins || []; - if (window.LESS_PLUGINS) { - options$1.plugins = options$1.plugins.concat(window.LESS_PLUGINS); - } - var less = root(window, options$1); - window.less = less; - var css; - var head; - var style; - // Always restore page visibility - function resolveOrReject(data) { - if (data.filename) { - console.warn(data); - } - if (!options$1.async) { - head.removeChild(style); - } - } - if (options$1.onReady) { - if (/!watch/.test(window.location.hash)) { - less.watch(); - } - // Simulate synchronous stylesheet loading by hiding page rendering - if (!options$1.async) { - css = 'body { display: none !important }'; - head = document.head || document.getElementsByTagName('head')[0]; - style = document.createElement('style'); - style.type = 'text/css'; - if (style.styleSheet) { - style.styleSheet.cssText = css; - } - else { - style.appendChild(document.createTextNode(css)); - } - head.appendChild(style); - } - less.registerStylesheetsImmediately(); - less.pageLoadFinished = less.refresh(less.env === 'development').then(resolveOrReject, resolveOrReject); - } + var ImageSize = (function () { + function imageSize() { + throw { + type: 'Runtime', + message: 'Image size functions are not supported in browser version of less' + }; + } + var imageFunctions = { + 'image-size': function (filePathNode) { + imageSize(); + return -1; + }, + 'image-width': function (filePathNode) { + imageSize(); + return -1; + }, + 'image-height': function (filePathNode) { + imageSize(); + return -1; + } + }; + functionRegistry.addMultiple(imageFunctions); + }); - return less; + // + var root = (function (window, options) { + var document = window.document; + var less = lessRoot(); + less.options = options; + var environment = less.environment; + var FileManager = FM(options, less.logger); + var fileManager = new FileManager(); + environment.addFileManager(fileManager); + less.FileManager = FileManager; + less.PluginLoader = PluginLoader; + LogListener(less, options); + var errors = ErrorReporting(window, less, options); + var cache = less.cache = options.cache || Cache(window, options, less.logger); + ImageSize(less.environment); + // Setup user functions - Deprecate? + if (options.functions) { + less.functions.functionRegistry.addMultiple(options.functions); + } + var typePattern = /^text\/(x-)?less$/; + function clone(obj) { + var cloned = {}; + for (var prop in obj) { + if (obj.hasOwnProperty(prop)) { + cloned[prop] = obj[prop]; + } + } + return cloned; + } + // only really needed for phantom + function bind(func, thisArg) { + var curryArgs = Array.prototype.slice.call(arguments, 2); + return function () { + var args = curryArgs.concat(Array.prototype.slice.call(arguments, 0)); + return func.apply(thisArg, args); + }; + } + function loadStyles(modifyVars) { + var styles = document.getElementsByTagName('style'); + var style; + for (var i = 0; i < styles.length; i++) { + style = styles[i]; + if (style.type.match(typePattern)) { + var instanceOptions = clone(options); + instanceOptions.modifyVars = modifyVars; + var lessText = style.innerHTML || ''; + instanceOptions.filename = document.location.href.replace(/#.*$/, ''); + /* jshint loopfunc:true */ + // use closure to store current style + less.render(lessText, instanceOptions, bind(function (style, e, result) { + if (e) { + errors.add(e, 'inline'); + } + else { + style.type = 'text/css'; + if (style.styleSheet) { + style.styleSheet.cssText = result.css; + } + else { + style.innerHTML = result.css; + } + } + }, null, style)); + } + } + } + function loadStyleSheet(sheet, callback, reload, remaining, modifyVars) { + var instanceOptions = clone(options); + addDataAttr(instanceOptions, sheet); + instanceOptions.mime = sheet.type; + if (modifyVars) { + instanceOptions.modifyVars = modifyVars; + } + function loadInitialFileCallback(loadedFile) { + var data = loadedFile.contents; + var path = loadedFile.filename; + var webInfo = loadedFile.webInfo; + var newFileInfo = { + currentDirectory: fileManager.getPath(path), + filename: path, + rootFilename: path, + rewriteUrls: instanceOptions.rewriteUrls + }; + newFileInfo.entryPath = newFileInfo.currentDirectory; + newFileInfo.rootpath = instanceOptions.rootpath || newFileInfo.currentDirectory; + if (webInfo) { + webInfo.remaining = remaining; + var css = cache.getCSS(path, webInfo, instanceOptions.modifyVars); + if (!reload && css) { + webInfo.local = true; + callback(null, css, data, sheet, webInfo, path); + return; + } + } + // TODO add tests around how this behaves when reloading + errors.remove(path); + instanceOptions.rootFileInfo = newFileInfo; + less.render(data, instanceOptions, function (e, result) { + if (e) { + e.href = path; + callback(e); + } + else { + cache.setCSS(sheet.href, webInfo.lastModified, instanceOptions.modifyVars, result.css); + callback(null, result.css, data, sheet, webInfo, path); + } + }); + } + fileManager.loadFile(sheet.href, null, instanceOptions, environment) + .then(function (loadedFile) { + loadInitialFileCallback(loadedFile); + }).catch(function (err) { + console.log(err); + callback(err); + }); + } + function loadStyleSheets(callback, reload, modifyVars) { + for (var i = 0; i < less.sheets.length; i++) { + loadStyleSheet(less.sheets[i], callback, reload, less.sheets.length - (i + 1), modifyVars); + } + } + function initRunningMode() { + if (less.env === 'development') { + less.watchTimer = setInterval(function () { + if (less.watchMode) { + fileManager.clearFileCache(); + loadStyleSheets(function (e, css, _, sheet, webInfo) { + if (e) { + errors.add(e, e.href || sheet.href); + } + else if (css) { + browser.createCSS(window.document, css, sheet); + } + }); + } + }, options.poll); + } + } + // + // Watch mode + // + less.watch = function () { + if (!less.watchMode) { + less.env = 'development'; + initRunningMode(); + } + this.watchMode = true; + return true; + }; + less.unwatch = function () { clearInterval(less.watchTimer); this.watchMode = false; return false; }; + // + // Synchronously get all tags with the 'rel' attribute set to + // "stylesheet/less". + // + less.registerStylesheetsImmediately = function () { + var links = document.getElementsByTagName('link'); + less.sheets = []; + for (var i = 0; i < links.length; i++) { + if (links[i].rel === 'stylesheet/less' || (links[i].rel.match(/stylesheet/) && + (links[i].type.match(typePattern)))) { + less.sheets.push(links[i]); + } + } + }; + // + // Asynchronously get all tags with the 'rel' attribute set to + // "stylesheet/less", returning a Promise. + // + less.registerStylesheets = function () { return new Promise(function (resolve, reject) { + less.registerStylesheetsImmediately(); + resolve(); + }); }; + // + // With this function, it's possible to alter variables and re-render + // CSS without reloading less-files + // + less.modifyVars = function (record) { return less.refresh(true, record, false); }; + less.refresh = function (reload, modifyVars, clearFileCache) { + if ((reload || clearFileCache) && clearFileCache !== false) { + fileManager.clearFileCache(); + } + return new Promise(function (resolve, reject) { + var startTime; + var endTime; + var totalMilliseconds; + var remainingSheets; + startTime = endTime = new Date(); + // Set counter for remaining unprocessed sheets + remainingSheets = less.sheets.length; + if (remainingSheets === 0) { + endTime = new Date(); + totalMilliseconds = endTime - startTime; + less.logger.info('Less has finished and no sheets were loaded.'); + resolve({ + startTime: startTime, + endTime: endTime, + totalMilliseconds: totalMilliseconds, + sheets: less.sheets.length + }); + } + else { + // Relies on less.sheets array, callback seems to be guaranteed to be called for every element of the array + loadStyleSheets(function (e, css, _, sheet, webInfo) { + if (e) { + errors.add(e, e.href || sheet.href); + reject(e); + return; + } + if (webInfo.local) { + less.logger.info("Loading " + sheet.href + " from cache."); + } + else { + less.logger.info("Rendered " + sheet.href + " successfully."); + } + browser.createCSS(window.document, css, sheet); + less.logger.info("CSS for " + sheet.href + " generated in " + (new Date() - endTime) + "ms"); + // Count completed sheet + remainingSheets--; + // Check if the last remaining sheet was processed and then call the promise + if (remainingSheets === 0) { + totalMilliseconds = new Date() - startTime; + less.logger.info("Less has finished. CSS generated in " + totalMilliseconds + "ms"); + resolve({ + startTime: startTime, + endTime: endTime, + totalMilliseconds: totalMilliseconds, + sheets: less.sheets.length + }); + } + endTime = new Date(); + }, reload, modifyVars); + } + loadStyles(modifyVars); + }); + }; + less.refreshStyles = loadStyles; + return less; + }); + + /** + * Kicks off less and compiles any stylesheets + * used in the browser distributed version of less + * to kick-start less using the browser api + */ + var options$1 = defaultOptions(); + if (window.less) { + for (var key in window.less) { + if (window.less.hasOwnProperty(key)) { + options$1[key] = window.less[key]; + } + } + } + addDefaultOptions(window, options$1); + options$1.plugins = options$1.plugins || []; + if (window.LESS_PLUGINS) { + options$1.plugins = options$1.plugins.concat(window.LESS_PLUGINS); + } + var less = root(window, options$1); + window.less = less; + var css; + var head; + var style; + // Always restore page visibility + function resolveOrReject(data) { + if (data.filename) { + console.warn(data); + } + if (!options$1.async) { + head.removeChild(style); + } + } + if (options$1.onReady) { + if (/!watch/.test(window.location.hash)) { + less.watch(); + } + // Simulate synchronous stylesheet loading by hiding page rendering + if (!options$1.async) { + css = 'body { display: none !important }'; + head = document.head || document.getElementsByTagName('head')[0]; + style = document.createElement('style'); + style.type = 'text/css'; + if (style.styleSheet) { + style.styleSheet.cssText = css; + } + else { + style.appendChild(document.createTextNode(css)); + } + head.appendChild(style); + } + less.registerStylesheetsImmediately(); + less.pageLoadFinished = less.refresh(less.env === 'development').then(resolveOrReject, resolveOrReject); + } + + return less; }))); diff --git a/dist/less.min.js b/dist/less.min.js index 88206ab4b..050af49bb 100644 --- a/dist/less.min.js +++ b/dist/less.min.js @@ -1,5 +1,5 @@ /** - * Less - Leaner CSS v3.13.1 + * Less - Leaner CSS v4.0.0 * http://lesscss.org * * Copyright (c) 2009-2020, Alexis Sellier @@ -7,5 +7,5 @@ * * @license Apache-2.0 */ -!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(e=e||self).less=t()}(this,(function(){"use strict";function e(e){return e.replace(/^[a-z-]+:\/+?[^\/]+/,"").replace(/[\?\&]livereload=\w+/,"").replace(/^\//,"").replace(/\.[a-zA-Z]+$/,"").replace(/[^\.\w-]+/g,"-").replace(/\./g,":")}function t(e,t){for(var i in t.dataset)if(t.dataset.hasOwnProperty(i))if("env"===i||"dumpLineNumbers"===i||"rootpath"===i||"errorReporting"===i)e[i]=t.dataset[i];else try{e[i]=JSON.parse(t.dataset[i])}catch(e){}}var i=function(t,i,n){var r=n.href||"",s="less:"+(n.title||e(r)),o=t.getElementById(s),a=!1,l=t.createElement("style");l.setAttribute("type","text/css"),n.media&&l.setAttribute("media",n.media),l.id=s,l.styleSheet||(l.appendChild(t.createTextNode(i)),a=null!==o&&o.childNodes.length>0&&l.childNodes.length>0&&o.firstChild.nodeValue===l.firstChild.nodeValue);var u=t.getElementsByTagName("head")[0];if(null===o||!1===a){var h=n&&n.nextSibling||null;h?h.parentNode.insertBefore(l,h):u.appendChild(l)}if(o&&!1===a&&o.parentNode.removeChild(o),l.styleSheet)try{l.styleSheet.cssText=i}catch(e){throw new Error("Couldn't reassign styleSheet.cssText.")}},n=function(e){var t,i=e.document;return i.currentScript||(t=i.getElementsByTagName("script"))[t.length-1]},r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var i in t)t.hasOwnProperty(i)&&(e[i]=t[i])})(e,t)};function s(e,t){function i(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(i.prototype=t.prototype,new i)}function o(){for(var e=0,t=0,i=arguments.length;tt?1:void 0};var c=function(e,t,i){var n=this;Array.isArray(e)?this.rgb=e:e.length>=6?(this.rgb=[],e.match(/.{2}/g).map((function(e,t){t<3?n.rgb.push(parseInt(e,16)):n.alpha=parseInt(e,16)/255}))):(this.rgb=[],e.split("").map((function(e,t){t<3?n.rgb.push(parseInt(e+e,16)):n.alpha=parseInt(e+e,16)/255}))),this.alpha=this.alpha||("number"==typeof t?t:1),void 0!==i&&(this.value=i)};function f(e,t){return Math.min(Math.max(e,0),t)}function p(e){return"#"+e.map((function(e){return((e=f(Math.round(e),255))<16?"0":"")+e.toString(16)})).join("")}(c.prototype=new h).luma=function(){var e=this.rgb[0]/255,t=this.rgb[1]/255,i=this.rgb[2]/255;return.2126*(e=e<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4))+.7152*(t=t<=.03928?t/12.92:Math.pow((t+.055)/1.055,2.4))+.0722*(i=i<=.03928?i/12.92:Math.pow((i+.055)/1.055,2.4))},c.prototype.genCSS=function(e,t){t.add(this.toCSS(e))},c.prototype.toCSS=function(e,t){var i,n,r,s=e&&e.compress&&!t,o=[];if(n=this.fround(e,this.alpha),this.value)if(0===this.value.indexOf("rgb"))n<1&&(r="rgba");else{if(0!==this.value.indexOf("hsl"))return this.value;r=n<1?"hsla":"hsl"}else n<1&&(r="rgba");switch(r){case"rgba":o=this.rgb.map((function(e){return f(Math.round(e),255)})).concat(f(n,1));break;case"hsla":o.push(f(n,1));case"hsl":i=this.toHSL(),o=[this.fround(e,i.h),this.fround(e,100*i.s)+"%",this.fround(e,100*i.l)+"%"].concat(o)}if(r)return r+"("+o.join(","+(s?"":" "))+")";if(i=this.toRGB(),s){var a=i.split("");a[1]===a[2]&&a[3]===a[4]&&a[5]===a[6]&&(i="#"+a[1]+a[3]+a[5])}return i},c.prototype.operate=function(e,t,i){for(var n=new Array(3),r=this.alpha*(1-i.alpha)+i.alpha,s=0;s<3;s++)n[s]=this._operate(e,t,this.rgb[s],i.rgb[s]);return new c(n,r)},c.prototype.toRGB=function(){return p(this.rgb)},c.prototype.toHSL=function(){var e,t,i=this.rgb[0]/255,n=this.rgb[1]/255,r=this.rgb[2]/255,s=this.alpha,o=Math.max(i,n,r),a=Math.min(i,n,r),l=(o+a)/2,u=o-a;if(o===a)e=t=0;else{switch(t=l>.5?u/(2-o-a):u/(o+a),o){case i:e=(n-r)/u+(n=0&&"\n"!==t.charAt(i);)r++;return"number"==typeof e&&(n=(t.slice(0,e).match(/\n/g)||"").length),{line:n,column:r}}function _(e){var t,i=e.length,n=new Array(i);for(t=0;t|Function):(\d+):(\d+)/,F=function(e,t,i){Error.call(this);var n=e.filename||i;if(this.message=e.message,this.stack=e.stack,t&&n){var r=t.contents[n],s=k(e.index,r),o=s.line,a=s.column,l=e.call&&k(e.call,r).line,u=r?r.split("\n"):"";if(this.type=e.type||"Syntax",this.filename=n,this.index=e.index,this.line="number"==typeof o?o+1:null,this.column=a,!this.line&&this.stack){var h=this.stack.match(V),c=new Function("a","throw new Error()"),f=0;try{c()}catch(e){var p=e.stack.match(V);f=1-parseInt(p[2])}h&&(h[2]&&(this.line=parseInt(h[2])+f),h[3]&&(this.column=parseInt(h[3])))}this.callLine=l+1,this.callExtract=u[l],this.extract=[u[this.line-2],u[this.line-1],u[this.line]]}};if(void 0===Object.create){var $=function(){};$.prototype=Error.prototype,F.prototype=new $}else F.prototype=Object.create(Error.prototype);F.prototype.constructor=F,F.prototype.toString=function(e){void 0===e&&(e={});var t="",i=this.extract||[],n=[],r=function(e){return e};if(e.stylize){var s=typeof e.stylize;if("function"!==s)throw Error("options.stylize should be a function, got a "+s+"!");r=e.stylize}if(null!==this.line){if("string"==typeof i[0]&&n.push(r(this.line-1+" "+i[0],"grey")),"string"==typeof i[1]){var o=this.line+" ";i[1]&&(o+=i[1].slice(0,this.column)+r(r(r(i[1].substr(this.column,1),"bold")+i[1].slice(this.column+1),"red"),"inverse")),n.push(o)}"string"==typeof i[2]&&n.push(r(this.line+1+" "+i[2],"grey")),n=n.join("\n")+r("","reset")+"\n"}return t+=r(this.type+"Error: "+this.message,"red"),this.filename&&(t+=r(" in ","red")+this.filename),this.line&&(t+=r(" on line "+this.line+", column "+(this.column+1)+":","grey")),t+="\n"+n,this.callLine&&(t+=r("from ","red")+(this.filename||"")+"/n",t+=r(this.callLine,"grey")+" "+this.callExtract+"/n"),t};var O=function(e,t,i,n,r,s){this.extendList=t,this.condition=i,this.evaldCondition=!i,this._index=n,this._fileInfo=r,this.elements=this.getElements(e),this.mixinElements_=void 0,this.copyVisibilityInfo(s),this.setParent(this.elements,this)};(O.prototype=new h).accept=function(e){this.elements&&(this.elements=e.visitArray(this.elements)),this.extendList&&(this.extendList=e.visitArray(this.extendList)),this.condition&&(this.condition=e.visit(this.condition))},O.prototype.createDerived=function(e,t,i){e=this.getElements(e);var n=new O(e,t||this.extendList,null,this.getIndex(),this.fileInfo(),this.visibilityInfo());return n.evaldCondition=null!=i?i:this.evaldCondition,n.mediaEmpty=this.mediaEmpty,n},O.prototype.getElements=function(e){return e?("string"==typeof e&&this.parse.parseNode(e,["selector"],this._index,this._fileInfo,(function(t,i){if(t)throw new F({index:t.index,message:t.message},this.parse.imports,this._fileInfo.filename);e=i[0].elements})),e):[new g("","&",!1,this._index,this._fileInfo)]},O.prototype.createEmptySelectors=function(){var e=new g("","&",!1,this._index,this._fileInfo),t=[new O([e],null,null,this._index,this._fileInfo)];return t[0].mediaEmpty=!0,t},O.prototype.match=function(e){var t,i,n=this.elements,r=n.length;if(0===(t=(e=e.mixinElements()).length)||ry.PARENS_DIVISION)||this.parensStack&&this.parensStack.length))},e.prototype.pathRequiresRewrite=function(e){return(this.rewriteUrls===w?H:J)(e)},e.prototype.rewritePath=function(e,t){var i;return t=t||"",i=this.normalizePath(t+e),H(e)&&J(t)&&!1===H(i)&&(i="./"+i),i},e.prototype.normalizePath=function(e){var t,i=e.split("/").reverse();for(e=[];0!==i.length;)switch(t=i.pop()){case".":break;case"..":0===e.length||".."===e[e.length-1]?e.push(t):e.pop();break;default:e.push(t)}return e.join("/")},e}();var Q=function e(t){return{_data:{},add:function(e,t){e=e.toLowerCase(),this._data.hasOwnProperty(e),this._data[e]=t},addMultiple:function(e){var t=this;Object.keys(e).forEach((function(i){t.add(i,e[i])}))},get:function(e){return this._data[e]||t&&t.get(e)},getLocalFunctions:function(){return this._data},inherit:function(){return e(this)},create:function(t){return e(t)}}}(null),K={eval:function(){var e=this.value_,t=this.error_;if(t)throw t;if(null!=e)return e?N.True:N.False},value:function(e){this.value_=e},error:function(e){this.error_=e},reset:function(){this.value_=this.error_=null}},Z=function(e,t,i,n){this.selectors=e,this.rules=t,this._lookups={},this._variables=null,this._properties=null,this.strictImports=i,this.copyVisibilityInfo(n),this.allowRoot=!0,this.setParent(this.selectors,this),this.setParent(this.rules,this)};(Z.prototype=new h).isRulesetLike=function(){return!0},Z.prototype.accept=function(e){this.paths?this.paths=e.visitArray(this.paths,!0):this.selectors&&(this.selectors=e.visitArray(this.selectors)),this.rules&&this.rules.length&&(this.rules=e.visitArray(this.rules))},Z.prototype.eval=function(e){var t,i,n,r,s,o=!1;if(this.selectors&&(i=this.selectors.length)){for(t=new Array(i),K.error({type:"Syntax",message:"it is currently only allowed in parametric mixin guards,"}),r=0;r0;e--){var t=this.rules[e-1];if(t instanceof U)return this.parseValue(t)}},Z.prototype.parseValue=function(e){var t=this;function i(e){return e.value instanceof D&&!e.parsed?("string"==typeof e.value.value?this.parse.parseNode(e.value.value,["value","important"],e.value.getIndex(),e.fileInfo(),(function(t,i){t&&(e.parsed=!0),i&&(e.value=i[0],e.important=i[1]||"",e.parsed=!0)})):e.parsed=!0,e):e}if(Array.isArray(e)){var n=[];return e.forEach((function(e){n.push(i.call(t,e))})),n}return i.call(t,e)},Z.prototype.rulesets=function(){if(!this.rules)return[];var e,t,i=[],n=this.rules;for(e=0;t=n[e];e++)t.isRuleset&&i.push(t);return i},Z.prototype.prependRule=function(e){var t=this.rules;t?t.unshift(e):this.rules=[e],this.setParent(e,this)},Z.prototype.find=function(e,t,i){void 0===t&&(t=this);var n,r,s=[],o=e.toCSS();return o in this._lookups?this._lookups[o]:(this.rulesets().forEach((function(o){if(o!==t)for(var a=0;an){if(!i||i(o)){r=o.find(new O(e.elements.slice(n)),t,i);for(var l=0;l0&&t.add(l),e.firstSelector=!0,o[0].genCSS(e,t),e.firstSelector=!1,n=1;n0?(s=(r=_(e)).pop(),o=n.createDerived(_(s.elements))):o=n.createDerived([]),t.length>0){var a=i.combinator,l=t[0].elements[0];a.emptyOrWhitespace&&!l.combinator.emptyOrWhitespace&&(a=l.combinator),o.elements.push(new g(a,l.value,i.isVariable,i._index,i._fileInfo)),o.elements=o.elements.concat(t[0].elements.slice(1))}if(0!==o.elements.length&&r.push(o),t.length>1){var u=t.slice(1);u=u.map((function(e){return e.createDerived(e.elements,[])})),r=r.concat(u)}return r}function o(e,t,i,n,r){var o;for(o=0;o0?n[n.length-1]=n[n.length-1].createDerived(n[n.length-1].elements.concat(e)):n.push(new O(e));else t.push([new O(e)])}function l(e,t){var i=t.createDerived(t.elements,t.extendList,t.evaldCondition);return i.copyVisibilityInfo(e),i}var u,h;if(!function e(t,i,l){var u,h,c,f,p,v,m,y,b,w,x,S,I=!1;for(f=[],p=[[]],u=0;y=l.elements[u];u++)if("&"!==y.value){var C=(S=void 0,(x=y).value instanceof d&&(S=x.value.value)instanceof O?S:null);if(null!=C){a(f,p);var k,_=[],A=[];for(k=e(_,i,C),I=I||k,c=0;c<_.length;c++){o(p,[r(n(_[c],y),y)],y,l,A)}p=A,f=[]}else f.push(y)}else{for(I=!0,v=[],a(f,p),h=0;h0&&m[0].elements.push(new g(y.combinator,"",y.isVariable,y._index,y._fileInfo)),v.push(m);else for(c=0;c0&&(t.push(p[u]),w=p[u][b-1],p[u][b-1]=w.createDerived(w.elements,l.extendList));return I}(h=[],t,i))if(t.length>0)for(h=[],u=0;u0)for(t=0;t-1e-6&&(n=i.toFixed(20).replace(/0+$/,"")),e&&e.compress){if(0===i&&this.unit.isLength())return void t.add(n);i>0&&i<1&&(n=n.substr(1))}t.add(n),this.unit.genCSS(e,t)},te.prototype.operate=function(e,t,i){var n=this._operate(e,t,this.value,i.value),r=this.unit.clone();if("+"===t||"-"===t)if(0===r.numerator.length&&0===r.denominator.length)r=i.unit.clone(),this.unit.backupUnit&&(r.backupUnit=this.unit.backupUnit);else if(0===i.unit.numerator.length&&0===r.denominator.length);else{if(i=i.convertTo(this.unit.usedUnits()),e.strictUnits&&i.unit.toString()!==r.toString())throw new Error("Incompatible units. Change the units or use the unit function. Bad units: '"+r.toString()+"' and '"+i.unit.toString()+"'.");n=this._operate(e,t,this.value,i.value)}else"*"===t?(r.numerator=r.numerator.concat(i.unit.numerator).sort(),r.denominator=r.denominator.concat(i.unit.denominator).sort(),r.cancel()):"/"===t&&(r.numerator=r.numerator.concat(i.unit.denominator).sort(),r.denominator=r.denominator.concat(i.unit.numerator).sort(),r.cancel());return new te(n,r)},te.prototype.compare=function(e){var t,i;if(e instanceof te){if(this.unit.isEmpty()||e.unit.isEmpty())t=this,i=e;else if(t=this.unify(),i=e.unify(),0!==t.unit.compare(i.unit))return;return h.numericCompare(t.value,i.value)}},te.prototype.unify=function(){return this.convertTo({length:"px",duration:"s",angle:"rad"})},te.prototype.convertTo=function(e){var t,i,n,r,s,o=this.value,a=this.unit.clone(),u={};if("string"==typeof e){for(t in l)l[t].hasOwnProperty(e)&&((u={})[t]=e);e=u}for(i in s=function(e,t){return n.hasOwnProperty(e)?(t?o/=n[e]/n[r]:o*=n[e]/n[r],r):e},e)e.hasOwnProperty(i)&&(r=e[i],n=l[i],a.map(s));return a.cancel(),new te(o,a)},te.prototype.type="Dimension";var ie=y,ne=function(e,t,i){this.op=e.trim(),this.operands=t,this.isSpaced=i};(ne.prototype=new h).accept=function(e){this.operands=e.visitArray(this.operands)},ne.prototype.eval=function(e){var t,i=this.operands[0].eval(e),n=this.operands[1].eval(e);if(e.isMathOn(this.op)){if(t="./"===this.op?"/":this.op,i instanceof te&&n instanceof c&&(i=i.toColor()),n instanceof te&&i instanceof c&&(n=n.toColor()),!i.operate){if(i instanceof ne&&"/"===i.op&&e.math===ie.PARENS_DIVISION)return new ne(this.op,[i,n],this.isSpaced);throw{type:"Operation",message:"Operation on an invalid type"}}return i.operate(e,t,n)}return new ne(this.op,[i,n],this.isSpaced)},ne.prototype.genCSS=function(e,t){this.operands[0].genCSS(e,t),this.isSpaced&&t.add(" "),t.add(this.op),this.isSpaced&&t.add(" "),this.operands[1].genCSS(e,t)},ne.prototype.type="Operation";var re=y,se=function(e,t){if(this.value=e,this.noSpacing=t,!e)throw new Error("Expression requires an array parameter")};(se.prototype=new h).accept=function(e){this.value=e.visitArray(this.value)},se.prototype.eval=function(e){var t,i=e.isMathOn(),n=this.parens&&(e.math!==re.STRICT_LEGACY||!this.parensInOp),r=!1;return n&&e.inParenthesis(),this.value.length>1?t=new se(this.value.map((function(t){return t.eval?t.eval(e):t})),this.noSpacing):1===this.value.length?(!this.value[0].parens||this.value[0].parensInOp||e.inCalc||(r=!0),t=this.value[0].eval(e)):t=this,n&&e.outOfParenthesis(),!this.parens||!this.parensInOp||i||r||t instanceof te||(t=new d(t)),t},se.prototype.genCSS=function(e,t){for(var i=0;i1){var i=new O([],null,null,this.getIndex(),this.fileInfo()).createEmptySelectors();(t=new Z(i,e.mediaBlocks)).multiMedia=!0,t.copyVisibilityInfo(this.visibilityInfo()),this.setParent(t,this)}return delete e.mediaBlocks,delete e.mediaPath,t},pe.prototype.evalNested=function(e){var t,i,n=e.mediaPath.concat([this]);for(t=0;t0;t--)e.splice(t,0,new D("and"));return new se(e)}))),this.setParent(this.features,this),new Z([],[])},pe.prototype.permute=function(e){if(0===e.length)return[];if(1===e.length)return e[0];for(var t=[],i=this.permute(e.slice(1)),n=0;n1?"["+e.value.map((function(e){return e.toCSS()})).join(", ")+"]":e.toCSS()};var me=function(e,t,i,n){this.escaped=t,this.expression=e,this._index=i,this._fileInfo=n};(me.prototype=new ve).eval=function(e){var t=this.evaluateJavaScript(this.expression,e),i=typeof t;return"number"!==i||isNaN(t)?"string"===i?new ce('"'+t+'"',t,this.escaped,this._index):Array.isArray(t)?new D(t.join(", ")):new D(t):new te(t)},me.prototype.type="JavaScript";var ge=function(e,t){this.key=e,this.value=t};(ge.prototype=new h).accept=function(e){this.value=e.visit(this.value)},ge.prototype.eval=function(e){return this.value.eval?new ge(this.key,this.value.eval(e)):this},ge.prototype.genCSS=function(e,t){t.add(this.key+"="),this.value.genCSS?this.value.genCSS(e,t):t.add(this.value)},ge.prototype.type="Assignment";var ye=function(e,t,i,n,r){this.op=e.trim(),this.lvalue=t,this.rvalue=i,this._index=n,this.negate=r};(ye.prototype=new h).accept=function(e){this.lvalue=e.visit(this.lvalue),this.rvalue=e.visit(this.rvalue)},ye.prototype.eval=function(e){var t=function(e,t,i){switch(e){case"and":return t&&i;case"or":return t||i;default:switch(h.compare(t,i)){case-1:return"<"===e||"=<"===e||"<="===e;case 0:return"="===e||">="===e||"=<"===e||"<="===e;case 1:return">"===e||">="===e;default:return!1}}}(this.op,this.lvalue.eval(e),this.rvalue.eval(e));return this.negate?!t:t},ye.prototype.type="Condition";var be=function(e){this.value=e};(be.prototype=new h).type="UnicodeDescriptor";var we=function(e){this.value=e};(we.prototype=new h).genCSS=function(e,t){t.add("-"),this.value.genCSS(e,t)},we.prototype.eval=function(e){return e.isMathOn()?new ne("*",[new te(-1),this.value]).eval(e):new we(this.value.eval(e))},we.prototype.type="Negative";var xe=function(e,t,i,n,r){switch(this.selector=e,this.option=t,this.object_id=xe.next_id++,this.parent_ids=[this.object_id],this._index=i,this._fileInfo=n,this.copyVisibilityInfo(r),this.allowRoot=!0,t){case"all":this.allowBefore=!0,this.allowAfter=!0;break;default:this.allowBefore=!1,this.allowAfter=!1}this.setParent(this.selector,this)};xe.prototype=new h,xe.prototype.accept=function(e){this.selector=e.visit(this.selector)},xe.prototype.eval=function(e){return new xe(this.selector.eval(e),this.option,this.getIndex(),this.fileInfo(),this.visibilityInfo())},xe.prototype.clone=function(e){return new xe(this.selector,this.option,this.getIndex(),this.fileInfo(),this.visibilityInfo())},xe.prototype.findSelfSelectors=function(e){var t,i,n=[];for(t=0;t0&&i.length&&""===i[0].combinator.value&&(i[0].combinator.value=" "),n=n.concat(e[t].elements);this.selfSelectors=[new O(n)],this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo())},xe.next_id=0,xe.prototype.type="Extend";var Se=function(e,t,i){this.variable=e,this._index=t,this._fileInfo=i,this.allowRoot=!0};(Se.prototype=new h).eval=function(e){var t,i=new le(this.variable,this.getIndex(),this.fileInfo()).eval(e),n=new F({message:"Could not evaluate variable call "+this.variable});if(!i.ruleset){if(i.rules)t=i;else if(Array.isArray(i))t=new Z("",i);else{if(!Array.isArray(i.value))throw n;t=new Z("",i.value)}i=new X(t)}if(i.ruleset)return i.callEval(e);throw n},Se.prototype.type="VariableCall";var Ie=function(e,t,i,n){this.value=e,this.lookups=t,this._index=i,this._fileInfo=n};(Ie.prototype=new h).eval=function(e){var t,i,n=this.value.eval(e);for(t=0;tthis.params.length)return!1}i=Math.min(s,this.arity);for(var o=0;o0){for(h=!0,a=0;a0)f=2;else if(f=1,p[1]+p[2]>1)throw{type:"Runtime",message:"Ambiguous use of `default()` found when matching for `"+this.format(m)+"`",index:this.getIndex(),filename:this.fileInfo().filename};for(a=0;a=0;o--){var a=s[o];if(a[r?"supportsSync":"supports"](e,t,i,n))return a}return null},e.prototype.addFileManager=function(e){this.fileManagers.push(e)},e.prototype.clearFileManagers=function(){this.fileManagers=[]},e}(),Pe=function(){function e(){}return e.prototype.getPath=function(e){var t=e.lastIndexOf("?");return t>0&&(e=e.slice(0,t)),(t=e.lastIndexOf("/"))<0&&(t=e.lastIndexOf("\\")),t<0?"":e.slice(0,t+1)},e.prototype.tryAppendExtension=function(e,t){return/(\.[a-z]*$)|([\?;].*)$/.test(e)?e:e+t},e.prototype.tryAppendLessExtension=function(e){return this.tryAppendExtension(e,".less")},e.prototype.supportsSync=function(){return!1},e.prototype.alwaysMakePathsAbsolute=function(){return!1},e.prototype.isPathAbsolute=function(e){return/^(?:[a-z-]+:|\/|\\|#)/i.test(e)},e.prototype.join=function(e,t){return e?e+t:t},e.prototype.pathDiff=function(e,t){var i,n,r,s,o=this.extractUrlParts(e),a=this.extractUrlParts(t),l="";if(o.hostPart!==a.hostPart)return"";for(n=Math.max(a.directories.length,o.directories.length),i=0;iparseInt(t[i])?-1:1;return 0},e.prototype.versionToString=function(e){for(var t="",i=0;i0;){var e=this.imports[0];if(!e.isReady)return;this.imports=this.imports.slice(1),e.callback.apply(null,e.args)}if(0===this.variableImports.length)break;var t=this.variableImports[0];this.variableImports=this.variableImports.slice(1),t()}}finally{this._currentDepth--}0===this._currentDepth&&this._onSequencerEmpty&&this._onSequencerEmpty()},e}(),Le=function(e,t){this._visitor=new $e(this),this._importer=e,this._finish=t,this.context=new T.Eval,this.importCount=0,this.onceFileDetectionMap={},this.recursionDetector={},this._sequencer=new Oe(this._onSequencerEmpty.bind(this))};Le.prototype={isReplacing:!1,run:function(e){try{this._visitor.visit(e)}catch(e){this.error=e}this.isFinished=!0,this._sequencer.tryRun()},_onSequencerEmpty:function(){this.isFinished&&this._finish(this.error)},visitImport:function(e,t){var i=e.options.inline;if(!e.css||i){var n=new T.Eval(this.context,_(this.context.frames)),r=n.frames[0];this.importCount++,e.isVariableImport()?this._sequencer.addVariableImport(this.processImportNode.bind(this,e,n,r)):this.processImportNode(e,n,r)}t.visitDeeper=!1},processImportNode:function(e,t,i){var n,r=e.options.inline;try{n=e.evalForImport(t)}catch(t){t.filename||(t.index=e.getIndex(),t.filename=e.fileInfo().filename),e.css=!0,e.error=t}if(!n||n.css&&!r)this.importCount--,this.isFinished&&this._sequencer.tryRun();else{n.options.multiple&&(t.importMultiple=!0);for(var s=void 0===n.css,o=0;o=0||(a=[u.selfSelectors[0]],(s=f.findMatch(l,a)).length&&(l.hasFoundMatches=!0,l.selfSelectors.forEach((function(e){var t=u.visibilityInfo();o=f.extendSelector(s,a,e,l.isVisible()),(h=new _e.Extend(u.selector,u.option,0,u.fileInfo(),t)).selfSelectors=o,o[o.length-1].extendList=[h],c.push(h),h.ruleset=u.ruleset,h.parent_ids=h.parent_ids.concat(u.parent_ids,l.parent_ids),u.firstExtendOnThisSelectorPath&&(h.firstExtendOnThisSelectorPath=!0,u.ruleset.paths.push(o))}))));if(c.length){if(this.extendChainCount++,i>100){var p="{unable to calculate}",d="{unable to calculate}";try{p=c[0].selfSelectors[0].toCSS(),d=c[0].selector.toCSS()}catch(e){}throw{message:"extend circular reference detected. One of the circular extends is currently:"+p+":extend("+d+")"}}return c.concat(f.doExtendChaining(c,t,i+1))}return c},e.prototype.visitDeclaration=function(e,t){t.visitDeeper=!1},e.prototype.visitMixinDefinition=function(e,t){t.visitDeeper=!1},e.prototype.visitSelector=function(e,t){t.visitDeeper=!1},e.prototype.visitRuleset=function(e,t){if(!e.root){var i,n,r,s,o=this.allExtendsStack[this.allExtendsStack.length-1],a=[],l=this;for(r=0;r0&&u[l.matched].combinator.value!==o?l=null:l.matched++,l&&(l.finished=l.matched===u.length,l.finished&&!e.allowAfter&&(r+1u&&h>0&&(c[c.length-1].elements=c[c.length-1].elements.concat(t[u].elements.slice(h)),h=0,u++),l=s.elements.slice(h,a.index).concat([o]).concat(i.elements.slice(1)),u===a.pathIndex&&r>0?c[c.length-1].elements=c[c.length-1].elements.concat(l):(c=c.concat(t.slice(u,a.pathIndex))).push(new _e.Selector(l)),u=a.endPathIndex,(h=a.endPathElementIndex)>=t[u].elements.length&&(h=0,u++);return u0&&(c[c.length-1].elements=c[c.length-1].elements.concat(t[u].elements.slice(h)),u++),c=(c=c.concat(t.slice(u,t.length))).map((function(e){var t=e.createDerived(e.elements);return n?t.ensureVisibility():t.ensureInvisibility(),t}))},e.prototype.visitMedia=function(e,t){var i=e.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length-1]);i=i.concat(this.doExtendChaining(i,e.allExtends)),this.allExtendsStack.push(i)},e.prototype.visitMediaOut=function(e){var t=this.allExtendsStack.length-1;this.allExtendsStack.length=t},e.prototype.visitAtRule=function(e,t){var i=e.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length-1]);i=i.concat(this.doExtendChaining(i,e.allExtends)),this.allExtendsStack.push(i)},e.prototype.visitAtRuleOut=function(e){var t=this.allExtendsStack.length-1;this.allExtendsStack.length=t},e}(),Ue=function(){function e(){this.contexts=[[]],this._visitor=new $e(this)}return e.prototype.run=function(e){return this._visitor.visit(e)},e.prototype.visitDeclaration=function(e,t){t.visitDeeper=!1},e.prototype.visitMixinDefinition=function(e,t){t.visitDeeper=!1},e.prototype.visitRuleset=function(e,t){var i,n=this.contexts[this.contexts.length-1],r=[];this.contexts.push(r),e.root||((i=e.selectors)&&(i=i.filter((function(e){return e.getIsOutput()})),e.selectors=i.length?i:i=null,i&&e.joinSelectors(r,n,i)),i||(e.rules=null),e.paths=r)},e.prototype.visitRulesetOut=function(e){this.contexts.length=this.contexts.length-1},e.prototype.visitMedia=function(e,t){var i=this.contexts[this.contexts.length-1];e.rules[0].root=0===i.length||i[0].multiMedia},e.prototype.visitAtRule=function(e,t){var i=this.contexts[this.contexts.length-1];e.rules&&e.rules.length&&(e.rules[0].root=e.isRooted||0===i.length||null)},e}(),je=function(){function e(e){this._visitor=new $e(this),this._context=e}return e.prototype.containsSilentNonBlockedChild=function(e){var t;if(!e)return!1;for(var i=0;i0},e.prototype.resolveVisibility=function(e,t){if(!e.blocksVisibility()){if(this.isEmpty(e)&&!this.containsSilentNonBlockedChild(t))return;return e}var i=e.rules[0];if(this.keepOnlyVisibleChilds(i),!this.isEmpty(i))return e.ensureVisibility(),e.removeVisibilityBlock(),e},e.prototype.isVisibleRuleset=function(e){return!!e.firstRoot||!this.isEmpty(e)&&!(!e.root&&!this.hasVisibleSelector(e))},e}(),qe=function(e){this._visitor=new $e(this),this._context=e,this.utils=new je(e)};qe.prototype={isReplacing:!0,run:function(e){return this._visitor.visit(e)},visitDeclaration:function(e,t){if(!e.blocksVisibility()&&!e.variable)return e},visitMixinDefinition:function(e,t){e.frames=[]},visitExtend:function(e,t){},visitComment:function(e,t){if(!e.blocksVisibility()&&!e.isSilent(this._context))return e},visitMedia:function(e,t){var i=e.rules[0].rules;return e.accept(this._visitor),t.visitDeeper=!1,this.utils.resolveVisibility(e,i)},visitImport:function(e,t){if(!e.blocksVisibility())return e},visitAtRule:function(e,t){return e.rules&&e.rules.length?this.visitAtRuleWithBody(e,t):this.visitAtRuleWithoutBody(e,t)},visitAnonymous:function(e,t){if(!e.blocksVisibility())return e.accept(this._visitor),e},visitAtRuleWithBody:function(e,t){var i=function(e){var t=e.rules;return function(e){var t=e.rules;return 1===t.length&&(!t[0].paths||0===t[0].paths.length)}(e)?t[0].rules:t}(e);return e.accept(this._visitor),t.visitDeeper=!1,this.utils.isEmpty(e)||this._mergeRules(e.rules[0].rules),this.utils.resolveVisibility(e,i)},visitAtRuleWithoutBody:function(e,t){if(!e.blocksVisibility()){if("@charset"===e.name){if(this.charset){if(e.debugInfo){var i=new _e.Comment("/* "+e.toCSS(this._context).replace(/\n/g,"")+" */\n");return i.debugInfo=e.debugInfo,this._visitor.visit(i)}return}this.charset=!0}return e}},checkValidNodes:function(e,t){if(e)for(var i=0;i0?e.accept(this._visitor):e.rules=null,t.visitDeeper=!1}return e.rules&&(this._mergeRules(e.rules),this._removeDuplicateRules(e.rules)),this.utils.isVisibleRuleset(e)&&(e.ensureVisibility(),n.splice(0,0,e)),1===n.length?n[0]:n},_compileRulesetPaths:function(e){e.paths&&(e.paths=e.paths.filter((function(e){var t;for(" "===e[0].elements[0].combinator.value&&(e[0].elements[0].combinator=new _e.Combinator("")),t=0;t=0;n--)if((i=e[n])instanceof _e.Declaration)if(r[i.name]){(t=r[i.name])instanceof _e.Declaration&&(t=r[i.name]=[r[i.name].toCSS(this._context)]);var s=i.toCSS(this._context);-1!==t.indexOf(s)?e.splice(n,1):t.push(s)}else r[i.name]=i}},_mergeRules:function(e){if(e){for(var t={},i=[],n=0;n0){var t=e[0],i=[],n=[new _e.Expression(i)];e.forEach((function(e){"+"===e.merge&&i.length>0&&n.push(new _e.Expression(i=[])),i.push(e.value),t.important=t.important||e.important})),t.value=new _e.Value(n)}}))}}};var Te={Visitor:$e,ImportVisitor:Le,MarkVisibleSelectorsVisitor:Ne,ExtendVisitor:Be,JoinSelectorVisitor:Ue,ToCSSVisitor:qe},ze=function(){var e,t,i,n,r,s,o,a=[],l={};function u(i){for(var n,a,h,c=l.i,f=t,p=l.i-o,d=l.i+s.length-p,v=l.i+=i,m=e;l.i=0){h={index:l.i,text:m.substr(l.i,y+2-l.i),isLineComment:!1},l.i+=h.text.length-1,l.commentStore.push(h);continue}}break}if(32!==n&&10!==n&&9!==n&&13!==n)break}if(s=s.slice(i+l.i-v+p),o=l.i,!s.length){if(ti||l.i===i&&e&&!n)&&(i=l.i,n=e);var r=a.pop();s=r.current,o=l.i=r.i,t=r.j},l.forget=function(){a.pop()},l.isWhitespace=function(t){var i=l.i+(t||0),n=e.charCodeAt(i);return 32===n||13===n||9===n||10===n},l.$re=function(e){l.i>o&&(s=s.slice(l.i-o),o=l.i);var t=e.exec(s);return t?(u(t[0].length),"string"==typeof t?t:1===t.length?t[0]:t):null},l.$char=function(t){return e.charAt(l.i)!==t?null:(u(1),t)},l.$str=function(t){for(var i=t.length,n=0;nc&&(v=!1)}}while(v);return r||null},l.autoCommentAbsorb=!0,l.commentStore=[],l.finished=!1,l.peek=function(t){if("string"==typeof t){for(var i=0;i57||t<43||47===t||44===t},l.start=function(n,a,h){e=n,l.i=t=o=i=0,r=a?function(e,t){var i,n,r,s,o,a,l,u,h,c=e.length,f=0,p=0,d=[],v=0;function m(t){var i=o-v;i<512&&!t||!i||(d.push(e.slice(v,o+1)),v=o+1)}for(o=0;o=97&&l<=122||l<34))switch(l){case 40:p++,n=o;continue;case 41:if(--p<0)return t("missing opening `(`",o);continue;case 59:p||m();continue;case 123:f++,i=o;continue;case 125:if(--f<0)return t("missing opening `{`",o);f||p||m();continue;case 92:if(o96)){if(u==l){h=1;break}if(92==u){if(o==c-1)return t("unescaped `\\`",o);o++}}if(h)continue;return t("unmatched `"+String.fromCharCode(l)+"`",a);case 47:if(p||o==c-1)continue;if(47==(u=e.charCodeAt(o+1)))for(o+=2;oi&&s>r?"missing closing `}` or `*/`":"missing closing `}`",i):0!==p?t("missing closing `)`",n):(m(!0),d)}(n,h):[n],s=r[0],u(0)},l.end=function(){var t,r=l.i>=e.length;return l.i=e.length-1,furthestChar:e[l.i]}},l},Ge=function e(t,i,n){var r,s=ze();function o(e,t){throw new F({index:s.i,filename:n.filename,type:t||"Syntax",message:e},i)}function a(e,t){var i=e instanceof Function?e.call(r):s.$re(e);if(i)return i;o(t||("string"==typeof e?"expected '"+e+"' got '"+s.currentChar()+"'":"unexpected token"))}function l(e,t){if(s.$char(e))return e;o(t||"expected '"+e+"' got '"+s.currentChar()+"'")}function u(e){var t=n.filename;return{lineNumber:k(e,s.getInput()).line+1,fileName:t}}return{parserInput:s,imports:i,fileInfo:n,parseNode:function(e,t,n,o,a){var l,u=[],h=s;try{h.start(e,!1,(function(e,t){a({message:e,index:t+n})}));for(var c=0,f=void 0,p=void 0;f=t[c];c++)if(p=h.i,l=r[f]()){try{l._index=p+n,l._fileInfo=o}catch(e){}u.push(l)}else u.push(null);h.end().isFinished?a(null,u):a(!0,null)}catch(e){throw new F({index:e.index+n,message:e.message},i,o.filename)}},parse:function(r,o,a){var l,u,h,c,f=null,p="";if(u=a&&a.globalVars?e.serializeVars(a.globalVars)+"\n":"",h=a&&a.modifyVars?"\n"+e.serializeVars(a.modifyVars):"",t.pluginManager)for(var d=t.pluginManager.getPreProcessors(),v=0;v");return e},args:function(e){var t,i,n,a,l,u,h,c=r.entities,f={args:null,variadic:!1},p=[],d=[],v=[],m=!0;for(s.save();;){if(e)u=r.detachedRuleset()||r.expression();else{if(s.commentStore.length=0,s.$str("...")){f.variadic=!0,s.$char(";")&&!t&&(t=!0),(t?d:v).push({variadic:!0});break}u=c.variable()||c.property()||c.literal()||c.keyword()||this.call(!0)}if(!u||!m)break;a=null,u.throwAwayComments&&u.throwAwayComments(),l=u;var g=null;if(e?u.value&&1==u.value.length&&(g=u.value[0]):g=u,g&&(g instanceof _e.Variable||g instanceof _e.Property))if(s.$char(":")){if(p.length>0&&(t&&o("Cannot mix ; and , as delimiter types"),i=!0),!(l=r.detachedRuleset()||r.expression())){if(!e)return s.restore(),f.args=[],f;o("could not understand value for named argument")}a=n=g.name}else if(s.$str("...")){if(!e){f.variadic=!0,s.$char(";")&&!t&&(t=!0),(t?d:v).push({name:u.name,variadic:!0});break}h=!0}else e||(n=a=g.name,l=null);l&&p.push(l),v.push({name:a,value:l,expand:h}),s.$char(",")?m=!0:((m=";"===s.$char(";"))||t)&&(i&&o("Cannot mix ; and , as delimiter types"),t=!0,p.length>1&&(l=new _e.Value(p)),d.push({name:n,value:l,expand:h}),n=null,p=[],i=!1)}return s.forget(),f.args=t?d:v,f},definition:function(){var e,t,i,n,o=[],l=!1;if(!("."!==s.currentChar()&&"#"!==s.currentChar()||s.peek(/^[^{]*\}/)))if(s.save(),t=s.$re(/^([#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\s*\(/)){e=t[1];var u=this.args(!1);if(o=u.args,l=u.variadic,!s.$char(")"))return void s.restore("Missing closing ')'");if(s.commentStore.length=0,s.$str("when")&&(n=a(r.conditions,"expected condition")),i=r.block())return s.forget(),new _e.mixin.Definition(e,o,i,n,l);s.restore()}else s.restore()},ruleLookups:function(){var e,t=[];if("["===s.currentChar()){for(;;){if(s.save(),!(e=this.lookupValue())&&""!==e){s.restore();break}t.push(e),s.forget()}return t.length>0?t:void 0}},lookupValue:function(){if(s.save(),s.$char("[")){var e=s.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/);if(s.$char("]"))return e||""===e?(s.forget(),e):void s.restore();s.restore()}else s.restore()}},entity:function(){var e=this.entities;return this.comment()||e.literal()||e.variable()||e.url()||e.property()||e.call()||e.keyword()||this.mixin.call(!0)||e.javascript()},end:function(){return s.$char(";")||s.peek("}")},ieAlpha:function(){var e;if(s.$re(/^opacity=/i))return(e=s.$re(/^\d+/))||(e="@{"+(e=a(r.entities.variable,"Could not parse alpha")).name.slice(1)+"}"),l(")"),new _e.Quoted("","alpha(opacity="+e+")")},element:function(){var e,t,i,r=s.i;if(t=this.combinator(),(e=s.$re(/^(?:\d+\.\d+|\d+)%/)||s.$re(/^(?:[.#]?|:*)(?:[\w-]|[^\x00-\x9f]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/)||s.$char("*")||s.$char("&")||this.attribute()||s.$re(/^\([^&()@]+\)/)||s.$re(/^[\.#:](?=@)/)||this.entities.variableCurly())||(s.save(),s.$char("(")?(i=this.selector(!1))&&s.$char(")")?(e=new _e.Paren(i),s.forget()):s.restore("Missing closing ')'"):s.forget()),e)return new _e.Element(t,e,e instanceof _e.Variable,r,n)},combinator:function(){var e=s.currentChar();if("/"===e){s.save();var t=s.$re(/^\/[a-z]+\//i);if(t)return s.forget(),new _e.Combinator(t);s.restore()}if(">"===e||"+"===e||"~"===e||"|"===e||"^"===e){for(s.i++,"^"===e&&"^"===s.currentChar()&&(e="^^",s.i++);s.isWhitespace();)s.i++;return new _e.Combinator(e)}return s.isWhitespace(-1)?new _e.Combinator(" "):new _e.Combinator(null)},selector:function(e){var t,i,r,l,u,h,c,f=s.i;for(e=!1!==e;(e&&(i=this.extend())||e&&(h=s.$str("when"))||(l=this.element()))&&(h?c=a(this.conditions,"expected condition"):c?o("CSS guard can only be used at the end of selector"):i?u=u?u.concat(i):i:(u&&o("Extend can only be used at the end of selector"),r=s.currentChar(),t?t.push(l):t=[l],l=null),"{"!==r&&"}"!==r&&";"!==r&&","!==r&&")"!==r););if(t)return new _e.Selector(t,u,c,f,n);u&&o("Extend must be used to extend a selector, it cannot be used on its own")},selectors:function(){for(var e,t;(e=this.selector())&&(t?t.push(e):t=[e],s.commentStore.length=0,e.condition&&t.length>1&&o("Guards are only currently allowed on a single selector."),s.$char(","));)e.condition&&o("Guards are only currently allowed on a single selector."),s.commentStore.length=0;return t},attribute:function(){if(s.$char("[")){var e,t,i,n=this.entities;return(e=n.variableCurly())||(e=a(/^(?:[_A-Za-z0-9-\*]*\|)?(?:[_A-Za-z0-9-]|\\.)+/)),(i=s.$re(/^[|~*$^]?=/))&&(t=n.quoted()||s.$re(/^[0-9]+%/)||s.$re(/^[\w-]+/)||n.variableCurly()),l("]"),new _e.Attribute(e,i,t)}},block:function(){var e;if(s.$char("{")&&(e=this.primary())&&s.$char("}"))return e},blockRuleset:function(){var e=this.block();return e&&(e=new _e.Ruleset(null,e)),e},detachedRuleset:function(){var e,t,i;if(s.save(),!s.$re(/^[.#]\(/)||(t=(e=this.mixin.args(!1)).args,i=e.variadic,s.$char(")"))){var n=this.blockRuleset();if(n)return s.forget(),t?new _e.mixin.Definition(null,t,n,null,i):new _e.DetachedRuleset(n);s.restore()}else s.restore()},ruleset:function(){var e,i,n;if(s.save(),t.dumpLineNumbers&&(n=u(s.i)),(e=this.selectors())&&(i=this.block())){s.forget();var r=new _e.Ruleset(e,i,t.strictImports);return t.dumpLineNumbers&&(r.debugInfo=n),r}s.restore()},declaration:function(){var e,t,i,r,o,a,l=s.i,u=s.currentChar();if("."!==u&&"#"!==u&&"&"!==u&&":"!==u)if(s.save(),e=this.variable()||this.ruleProperty()){if((a="string"==typeof e)&&(t=this.detachedRuleset())&&(i=!0),s.commentStore.length=0,!t){if(o=!a&&e.length>1&&e.pop().value,t=e[0].value&&"--"===e[0].value.slice(0,2)?this.permissiveValue():this.anonymousValue())return s.forget(),new _e.Declaration(e,t,!1,o,l,n);t||(t=this.value()),t?r=this.important():a&&(t=this.permissiveValue())}if(t&&(this.end()||i))return s.forget(),new _e.Declaration(e,t,r,o,l,n);s.restore()}else s.restore()},anonymousValue:function(){var e=s.i,t=s.$re(/^([^.#@\$+\/'"*`(;{}-]*);/);if(t)return new _e.Anonymous(t[1],e)},permissiveValue:function(e){var t,i,r,a,l=e||";",u=s.i,h=[];function c(){var e=s.currentChar();return"string"==typeof l?e===l:l.test(e)}if(!c()){a=[];do{((i=this.comment())||(i=this.entity()))&&a.push(i)}while(i);if(r=c(),a.length>0){if(a=new _e.Expression(a),r)return a;h.push(a)," "===s.prevChar()&&h.push(new _e.Anonymous(" ",u))}if(s.save(),a=s.$parseUntil(l)){if("string"==typeof a&&o("Expected '"+a+"'","Parse"),1===a.length&&" "===a[0])return s.forget(),new _e.Anonymous("",u);var f=void 0;for(t=0;t0)return new _e.Expression(r)},mediaFeatures:function(){var e,t=this.entities,i=[];do{if(e=this.mediaFeature()){if(i.push(e),!s.$char(","))break}else if((e=t.variable()||t.mixinLookup())&&(i.push(e),!s.$char(",")))break}while(e);return i.length>0?i:null},media:function(){var e,i,r,a,l=s.i;if(t.dumpLineNumbers&&(a=u(l)),s.save(),s.$str("@media"))return e=this.mediaFeatures(),(i=this.block())||o("media definitions require block statements after any features"),s.forget(),r=new _e.Media(i,e,l,n),t.dumpLineNumbers&&(r.debugInfo=a),r;s.restore()},plugin:function(){var e,t,i,r=s.i;if(s.$re(/^@plugin?\s+/)){if(i=(t=this.pluginArgs())?{pluginArgs:t,isPlugin:!0}:{isPlugin:!0},e=this.entities.quoted()||this.entities.url())return s.$char(";")||(s.i=r,o("missing semi-colon on @plugin")),new _e.Import(e,null,i,r,n);s.i=r,o("malformed @plugin statement")}},pluginArgs:function(){if(s.save(),!s.$char("("))return s.restore(),null;var e=s.$re(/^\s*([^\);]+)\)\s*/);return e[1]?(s.forget(),e[1].trim()):(s.restore(),null)},atrule:function(){var e,i,r,a,l,h,c,f=s.i,p=!0,d=!0;if("@"===s.currentChar()){if(i=this.import()||this.plugin()||this.media())return i;if(s.save(),e=s.$re(/^@[a-z-]+/)){switch(a=e,"-"==e.charAt(1)&&e.indexOf("-",2)>0&&(a="@"+e.slice(e.indexOf("-",2)+1)),a){case"@charset":l=!0,p=!1;break;case"@namespace":h=!0,p=!1;break;case"@keyframes":case"@counter-style":l=!0;break;case"@document":case"@supports":c=!0,d=!1;break;default:c=!0}if(s.commentStore.length=0,l?(i=this.entity())||o("expected "+e+" identifier"):h?(i=this.expression())||o("expected "+e+" expression"):c&&(i=this.permissiveValue(/^[{;]/),p="{"===s.currentChar(),i?i.value||(i=null):p||";"===s.currentChar()||o(e+" rule is missing block or ending semi-colon")),p&&(r=this.blockRuleset()),r||!p&&i&&s.$char(";"))return s.forget(),new _e.AtRule(e,i,r,f,n,t.dumpLineNumbers?u(f):null,d);s.restore("at-rule options not recognised")}}},value:function(){var e,t=[],i=s.i;do{if((e=this.expression())&&(t.push(e),!s.$char(",")))break}while(e);if(t.length>0)return new _e.Value(t,i)},important:function(){if("!"===s.currentChar())return s.$re(/^! *important/)},sub:function(){var e,t;if(s.save(),s.$char("("))return(e=this.addition())&&s.$char(")")?(s.forget(),(t=new _e.Expression([e])).parens=!0,t):void s.restore("Expected ')'");s.restore()},multiplication:function(){var e,t,i,n,r;if(e=this.operand()){for(r=s.isWhitespace(-1);!s.peek(/^\/[*\/]/);){if(s.save(),!(i=s.$char("/")||s.$char("*")||s.$str("./"))){s.forget();break}if(!(t=this.operand())){s.restore();break}s.forget(),e.parensInOp=!0,t.parensInOp=!0,n=new _e.Operation(i,[n||e,t],r),r=s.isWhitespace(-1)}return n||e}},addition:function(){var e,t,i,n,r;if(e=this.multiplication()){for(r=s.isWhitespace(-1);(i=s.$re(/^[-+]\s+/)||!r&&(s.$char("+")||s.$char("-")))&&(t=this.multiplication());)e.parensInOp=!0,t.parensInOp=!0,n=new _e.Operation(i,[n||e,t],r),r=s.isWhitespace(-1);return n||e}},conditions:function(){var e,t,i,n=s.i;if(e=this.condition(!0)){for(;s.peek(/^,\s*(not\s*)?\(/)&&s.$char(",")&&(t=this.condition(!0));)i=new _e.Condition("or",i||e,t,n);return i||e}},condition:function(e){var t,i,n;if(t=this.conditionAnd(e)){if(i=s.$str("or")){if(!(n=this.condition(e)))return;t=new _e.Condition(i,t,n)}return t}},conditionAnd:function(e){var t,i,n,r,o=this;if(t=(r=o.negatedCondition(e)||o.parenthesisCondition(e))||e?r:o.atomicCondition(e)){if(i=s.$str("and")){if(!(n=this.conditionAnd(e)))return;t=new _e.Condition(i,t,n)}return t}},negatedCondition:function(e){if(s.$str("not")){var t=this.parenthesisCondition(e);return t&&(t.negate=!t.negate),t}},parenthesisCondition:function(e){var t;if(s.save(),s.$str("(")){if(t=function(t){var i;if(s.save(),i=t.condition(e)){if(s.$char(")"))return s.forget(),i;s.restore()}else s.restore()}(this))return s.forget(),t;if(t=this.atomicCondition(e)){if(s.$char(")"))return s.forget(),t;s.restore("expected ')' got '"+s.currentChar()+"'")}else s.restore()}else s.restore()},atomicCondition:function(e){var t,i,n,r,a=this.entities,l=s.i;function u(){return this.addition()||a.keyword()||a.quoted()||a.mixinLookup()}if(t=(u=u.bind(this))())return s.$char(">")?r=s.$char("=")?">=":">":s.$char("<")?r=s.$char("=")?"<=":"<":s.$char("=")&&(r=s.$char(">")?"=>":s.$char("<")?"=<":"="),r?(i=u())?n=new _e.Condition(r,t,i,l,!1):o("expected expression"):n=new _e.Condition("=",t,new _e.Keyword("true"),l,!1),n},operand:function(){var e,t=this.entities;s.peek(/^-[@\$\(]/)&&(e=s.$char("-"));var i=this.sub()||t.dimension()||t.color()||t.variable()||t.property()||t.call()||t.quoted(!0)||t.colorKeyword()||t.mixinLookup();return e&&(i.parensInOp=!0,i=new _e.Negative(i)),i},expression:function(){var e,t,i=[],n=s.i;do{(e=this.comment())?i.push(e):((e=this.addition()||this.entity())instanceof _e.Comment&&(e=null),e&&(i.push(e),s.peek(/^\/[\/*]/)||(t=s.$char("/"))&&i.push(new _e.Anonymous(t,n))))}while(e);if(i.length>0)return new _e.Expression(i)},property:function(){var e=s.$re(/^(\*?-?[_a-zA-Z0-9-]+)\s*:/);if(e)return e[1]},ruleProperty:function(){var e,t,i=[],r=[];s.save();var o=s.$re(/^([_a-zA-Z0-9-]+)\s*:/);if(o)return i=[new _e.Keyword(o[1])],s.forget(),i;function a(e){var t=s.i,n=s.$re(e);if(n)return r.push(t),i.push(n[1])}for(a(/^(\*?)/);a(/^((?:[\w-]+)|(?:[@\$]\{[\w-]+\}))/););if(i.length>1&&a(/^((?:\+_|\+)?)\s*:/)){for(s.forget(),""===i[0]&&(i.shift(),r.shift()),t=0;t1?e-1:e)<1?r+(s-r)*e*6:2*e<1?s:3*e<2?r+(s-r)*(2/3-e)*6:r}e=Xe(e)%360/360,t=Qe(Xe(t)),i=Qe(Xe(i)),n=Qe(Xe(n)),r=2*i-(s=i<=.5?i*(t+1):i+t-i*t);var a=[255*o(e+1/3),255*o(e),255*o(e-1/3)];return n=Xe(n),new c(a,n,"hsla")}catch(e){}},hsv:function(e,t,i){return Je.hsva(e,t,i,1)},hsva:function(e,t,i,n){var r,s;e=Xe(e)%360/360*360,t=Xe(t),i=Xe(i),n=Xe(n);var o=[i,i*(1-t),i*(1-(s=e/60-(r=Math.floor(e/60%6)))*t),i*(1-(1-s)*t)],a=[[0,3,1],[2,0,1],[1,0,3],[1,2,0],[3,1,0],[0,1,2]];return Je.rgba(255*o[a[r][0]],255*o[a[r][1]],255*o[a[r][2]],n)},hue:function(e){return new te(Ze(e).h)},saturation:function(e){return new te(100*Ze(e).s,"%")},lightness:function(e){return new te(100*Ze(e).l,"%")},hsvhue:function(e){return new te(Ye(e).h)},hsvsaturation:function(e){return new te(100*Ye(e).s,"%")},hsvvalue:function(e){return new te(100*Ye(e).v,"%")},red:function(e){return new te(e.rgb[0])},green:function(e){return new te(e.rgb[1])},blue:function(e){return new te(e.rgb[2])},alpha:function(e){return new te(Ze(e).a)},luma:function(e){return new te(e.luma()*e.alpha*100,"%")},luminance:function(e){var t=.2126*e.rgb[0]/255+.7152*e.rgb[1]/255+.0722*e.rgb[2]/255;return new te(t*e.alpha*100,"%")},saturate:function(e,t,i){if(!e.rgb)return null;var n=Ze(e);return void 0!==i&&"relative"===i.value?n.s+=n.s*t.value/100:n.s+=t.value/100,n.s=Qe(n.s),Ke(e,n)},desaturate:function(e,t,i){var n=Ze(e);return void 0!==i&&"relative"===i.value?n.s-=n.s*t.value/100:n.s-=t.value/100,n.s=Qe(n.s),Ke(e,n)},lighten:function(e,t,i){var n=Ze(e);return void 0!==i&&"relative"===i.value?n.l+=n.l*t.value/100:n.l+=t.value/100,n.l=Qe(n.l),Ke(e,n)},darken:function(e,t,i){var n=Ze(e);return void 0!==i&&"relative"===i.value?n.l-=n.l*t.value/100:n.l-=t.value/100,n.l=Qe(n.l),Ke(e,n)},fadein:function(e,t,i){var n=Ze(e);return void 0!==i&&"relative"===i.value?n.a+=n.a*t.value/100:n.a+=t.value/100,n.a=Qe(n.a),Ke(e,n)},fadeout:function(e,t,i){var n=Ze(e);return void 0!==i&&"relative"===i.value?n.a-=n.a*t.value/100:n.a-=t.value/100,n.a=Qe(n.a),Ke(e,n)},fade:function(e,t){var i=Ze(e);return i.a=t.value/100,i.a=Qe(i.a),Ke(e,i)},spin:function(e,t){var i=Ze(e),n=(i.h+t.value)%360;return i.h=n<0?360+n:n,Ke(e,i)},mix:function(e,t,i){i||(i=new te(50));var n=i.value/100,r=2*n-1,s=Ze(e).a-Ze(t).a,o=((r*s==-1?r:(r+s)/(1+r*s))+1)/2,a=1-o,l=[e.rgb[0]*o+t.rgb[0]*a,e.rgb[1]*o+t.rgb[1]*a,e.rgb[2]*o+t.rgb[2]*a],u=e.alpha*n+t.alpha*(1-n);return new c(l,u)},greyscale:function(e){return Je.desaturate(e,new te(100))},contrast:function(e,t,i,n){if(!e.rgb)return null;if(void 0===i&&(i=Je.rgba(255,255,255,1)),void 0===t&&(t=Je.rgba(0,0,0,1)),t.luma()>i.luma()){var r=i;i=t,t=r}return n=void 0===n?.43:Xe(n),e.luma().5&&(n=1,i=e>.25?Math.sqrt(e):((16*e-12)*e+4)*e),e-(1-2*t)*n*(i-e)},hardlight:function(e,t){return it.overlay(t,e)},difference:function(e,t){return Math.abs(e-t)},exclusion:function(e,t){return e+t-2*e*t},average:function(e,t){return(e+t)/2},negation:function(e,t){return 1-Math.abs(e+t-1)}};for(var nt in it)it.hasOwnProperty(nt)&&(tt[nt]=tt.bind(null,it[nt]));var rt=function(e){return Array.isArray(e.value)?e.value:Array(e)},st={_SELF:function(e){return e},extract:function(e,t){return t=t.value-1,rt(e)[t]},length:function(e){return new te(rt(e).length)},range:function(e,t,i){var n,r,s=1,o=[];t?(r=t,n=e.value,i&&(s=i.value)):(n=1,r=e);for(var a=n;a<=r.value;a+=s)o.push(new te(a,r.unit));return new se(o)},each:function(e,t){var i,n,r=this,s=[],o=function(e){return e instanceof h?e.eval(r.context):e};n=!e.value||e instanceof ce?e.ruleset?o(e.ruleset).rules:e.rules?e.rules.map(o):Array.isArray(e)?e.map(o):[o(e)]:Array.isArray(e.value)?e.value.map(o):[o(e.value)];var a="@value",l="@key",u="@index";t.params?(a=t.params[0]&&t.params[0].name,l=t.params[1]&&t.params[1].name,u=t.params[2]&&t.params[2].name,t=t.rules):t=t.ruleset;for(var c=0;co.value)&&(h[n]=r);else{if(void 0!==l&&a!==l)throw{type:"Argument",message:"incompatible types"};c[a]=h.length,h.push(r)}else Array.isArray(t[i].value)&&Array.prototype.push.apply(t,Array.prototype.slice.call(t[i].value));return 1==h.length?h[0]:(t=h.map((function(e){return e.toCSS(this.context)})).join(this.context.compress?",":", "),new D((e?"min":"max")+"("+t+")"))},ht={min:function(){for(var e=[],t=0;t",r=0;r";return n+="',n=encodeURIComponent(n),new fe(new ce("'"+(n="data:image/svg+xml,"+n)+"'",n,!1,this.index,this.currentFileInfo),this.index,this.currentFileInfo)}}),Q.addMultiple(dt),t},mt=function(e,t){var i;void 0===t&&(t={});var n=t.variables,r=new T.Eval(t);"object"!=typeof n||Array.isArray(n)||(n=Object.keys(n).map((function(e){var t=n[e];return t instanceof _e.Value||(t instanceof _e.Expression||(t=new _e.Expression([t])),t=new _e.Value([t])),new _e.Declaration("@"+e,t,!1,null,0)})),r.frames=[new _e.Ruleset(null,n)]);var s,o,a=[new Te.JoinSelectorVisitor,new Te.MarkVisibleSelectorsVisitor(!0),new Te.ExtendVisitor,new Te.ToCSSVisitor({compress:Boolean(t.compress)})],l=[];if(t.pluginManager){o=t.pluginManager.visitor();for(var u=0;u<2;u++)for(o.first();s=o.get();)s.isPreEvalVisitor?0!==u&&-1!==l.indexOf(s)||(l.push(s),s.run(e)):0!==u&&-1!==a.indexOf(s)||(s.isPreVisitor?a.unshift(s):a.push(s))}i=e.eval(r);for(u=0;u=t);i++);this.preProcessors.splice(i,0,{preProcessor:e,priority:t})},e.prototype.addPostProcessor=function(e,t){var i;for(i=0;i=t);i++);this.postProcessors.splice(i,0,{postProcessor:e,priority:t})},e.prototype.addFileManager=function(e){this.fileManagers.push(e)},e.prototype.getPreProcessors=function(){for(var e=[],t=0;t0){var n=void 0,r=JSON.stringify(this._sourceMapGenerator.toJSON());this.sourceMapURL?n=this.sourceMapURL:this._sourceMapFilename&&(n=this._sourceMapFilename),this.sourceMapURL=n,this.sourceMap=r}return this._css.join("")},t}()}(e=new Me(e,t)),r=function(e,t){return function(){function i(e){this.options=e}return i.prototype.toCSS=function(t,i,n){var r=new e({contentsIgnoredCharsMap:n.contentsIgnoredChars,rootNode:t,contentsMap:n.contents,sourceMapFilename:this.options.sourceMapFilename,sourceMapURL:this.options.sourceMapURL,outputFilename:this.options.sourceMapOutputFilename,sourceMapBasepath:this.options.sourceMapBasepath,sourceMapRootpath:this.options.sourceMapRootpath,outputSourceFiles:this.options.outputSourceFiles,sourceMapGenerator:this.options.sourceMapGenerator,sourceMapFileInline:this.options.sourceMapFileInline,disableSourcemapAnnotation:this.options.disableSourcemapAnnotation}),s=r.toCSS(i);return this.sourceMap=r.sourceMap,this.sourceMapURL=r.sourceMapURL,this.options.sourceMapInputFilename&&(this.sourceMapInputFilename=r.normalizeFilename(this.options.sourceMapInputFilename)),void 0!==this.options.sourceMapBasepath&&void 0!==this.sourceMapURL&&(this.sourceMapURL=r.removeBasepath(this.sourceMapURL)),s+this.getCSSAppendage()},i.prototype.getCSSAppendage=function(){var e=this.sourceMapURL;if(this.options.sourceMapFileInline){if(void 0===this.sourceMap)return"";e="data:application/json;base64,"+t.encodeBase64(this.sourceMap)}return this.options.disableSourcemapAnnotation?"":e?"/*# sourceMappingURL="+e+" */":""},i.prototype.getExternalSourceMap=function(){return this.sourceMap},i.prototype.setExternalSourceMap=function(e){this.sourceMap=e},i.prototype.isInline=function(){return this.options.sourceMapFileInline},i.prototype.getSourceMapURL=function(){return this.sourceMapURL},i.prototype.getOutputFilename=function(){return this.options.sourceMapOutputFilename},i.prototype.getInputFilename=function(){return this.sourceMapInputFilename},i}()}(n,e),s=function(e){return function(){function t(e,t){this.root=e,this.imports=t}return t.prototype.toCSS=function(t){var i,n,r={};try{i=mt(this.root,t)}catch(e){throw new F(e,this.imports)}try{var s=Boolean(t.compress);s&&Ae.warn("The compress option has been deprecated. We recommend you use a dedicated css minifier, for instance see less-plugin-clean-css.");var o={compress:s,dumpLineNumbers:t.dumpLineNumbers,strictUnits:Boolean(t.strictUnits),numPrecision:8};t.sourceMap?(n=new e(t.sourceMap),r.css=n.toCSS(i,o,this.imports)):r.css=i.toCSS(o)}catch(e){throw new F(e,this.imports)}if(t.pluginManager)for(var a=t.pluginManager.getPostProcessors(),l=0;l=200&&t.status<300?i(t.responseText,t.getResponseHeader("Last-Modified")):"function"==typeof n&&n(t.status,e)}"function"==typeof r.overrideMimeType&&r.overrideMimeType("text/css"),xt.debug("XHR: Getting '"+e+"'"),r.open("GET",e,s),r.setRequestHeader("Accept",t||"text/x-less, text/css; q=0.9, */*; q=0.5"),r.send(null),wt.isFileProtocol&&!wt.fileAsync?0===r.status||r.status>=200&&r.status<300?i(r.responseText):n(r.status,e):s?r.onreadystatechange=function(){4==r.readyState&&o(r,i,n)}:o(r,i,n)},t.prototype.supports=function(){return!0},t.prototype.clearFileCache=function(){It={}},t.prototype.loadFile=function(e,t,i,n){t&&!this.isPathAbsolute(e)&&(e=t+e),e=i.ext?this.tryAppendExtension(e,i.ext):e,i=i||{};var r=this.extractUrlParts(e,window.location.href).url,s=this;return new Promise((function(e,t){if(i.useFileCache&&It[r])try{var n=It[r];return e({contents:n,filename:r,webInfo:{lastModified:new Date}})}catch(e){return t({filename:r,message:"Error loading file "+r+" error was "+e.message})}s.doXHR(r,i.mime,(function(t,i){It[r]=t,e({contents:t,filename:r,webInfo:{lastModified:i}})}),(function(e,i){t({type:"File",message:"'"+i+"' wasn't found ("+e+")",href:r})}))}))},t}(Pe),kt=function(e,t){return wt=e,xt=t,Ct},_t=function(e){function t(t){var i=e.call(this)||this;return i.less=t,i}return s(t,e),t.prototype.loadPlugin=function(e,t,i,n,r){return new Promise((function(s,o){r.loadFile(e,t,i,n).then(s).catch(o)}))},t}(Ee),At=function(t,n,r){return{add:function(s,o){r.errorReporting&&"html"!==r.errorReporting?"console"===r.errorReporting?function(e,t){var i=e.filename||t,s=[],o=(e.type||"Syntax")+"Error: "+(e.message||"There is an error in your .less file")+" in "+i,a=function(e,t,i){void 0!==e.extract[t]&&s.push("{line} {content}".replace(/\{line\}/,(parseInt(e.line,10)||0)+(t-1)).replace(/\{class\}/,i).replace(/\{content\}/,e.extract[t]))};e.line&&(a(e,0,""),a(e,1,"line"),a(e,2,""),o+=" on line "+e.line+", column "+(e.column+1)+":\n"+s.join("\n")),e.stack&&(e.extract||r.logLevel>=4)&&(o+="\nStack Trace\n"+e.stack),n.logger.error(o)}(s,o):"function"==typeof r.errorReporting&&r.errorReporting("add",s,o):function(n,s){var o,a,l="less-error-message:"+e(s||""),u=t.document.createElement("div"),h=[],c=n.filename||s,f=c.match(/([^\/]+(\?.*)?)$/)[1];u.id=l,u.className="less-error-message",a="

    "+(n.type||"Syntax")+"Error: "+(n.message||"There is an error in your .less file")+'

    in '+f+" ";var p=function(e,t,i){void 0!==e.extract[t]&&h.push('

  • {content}
  • '.replace(/\{line\}/,(parseInt(e.line,10)||0)+(t-1)).replace(/\{class\}/,i).replace(/\{content\}/,e.extract[t]))};n.line&&(p(n,0,""),p(n,1,"line"),p(n,2,""),a+="on line "+n.line+", column "+(n.column+1)+":

      "+h.join("")+"
    "),n.stack&&(n.extract||r.logLevel>=4)&&(a+="
    Stack Trace
    "+n.stack.split("\n").slice(1).join("
    ")),u.innerHTML=a,i(t.document,[".less-error-message ul, .less-error-message li {","list-style-type: none;","margin-right: 15px;","padding: 4px 0;","margin: 0;","}",".less-error-message label {","font-size: 12px;","margin-right: 15px;","padding: 4px 0;","color: #cc7777;","}",".less-error-message pre {","color: #dd6666;","padding: 4px 0;","margin: 0;","display: inline-block;","}",".less-error-message pre.line {","color: #ff0000;","}",".less-error-message h3 {","font-size: 20px;","font-weight: bold;","padding: 15px 0 5px 0;","margin: 0;","}",".less-error-message a {","color: #10a","}",".less-error-message .error {","color: red;","font-weight: bold;","padding-bottom: 2px;","border-bottom: 1px dashed red;","}"].join("\n"),{title:"error-message"}),u.style.cssText=["font-family: Arial, sans-serif","border: 1px solid #e00","background-color: #eee","border-radius: 5px","-webkit-border-radius: 5px","-moz-border-radius: 5px","color: #e00","padding: 15px","margin-bottom: 15px"].join(";"),"development"===r.env&&(o=setInterval((function(){var e=t.document,i=e.body;i&&(e.getElementById(l)?i.replaceChild(u,e.getElementById(l)):i.insertBefore(u,i.firstChild),clearInterval(o))}),10))}(s,o)},remove:function(i){r.errorReporting&&"html"!==r.errorReporting?"console"===r.errorReporting||"function"==typeof r.errorReporting&&r.errorReporting("remove",i):function(i){var n=t.document.getElementById("less-error-message:"+e(i));n&&n.parentNode.removeChild(n)}(i)}}},Mt={javascriptEnabled:!1,depends:!1,compress:!1,lint:!1,paths:[],color:!0,strictImports:!1,insecure:!1,rootpath:"",rewriteUrls:!1,math:0,strictUnits:!1,globalVars:null,modifyVars:null,urlArgs:""};if(window.less)for(var Pt in window.less)window.less.hasOwnProperty(Pt)&&(Mt[Pt]=window.less[Pt]);!function(e,i){t(i,n(e)),void 0===i.isFileProtocol&&(i.isFileProtocol=/^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(e.location.protocol)),i.async=i.async||!1,i.fileAsync=i.fileAsync||!1,i.poll=i.poll||(i.isFileProtocol?1e3:1500),i.env=i.env||("127.0.0.1"==e.location.hostname||"0.0.0.0"==e.location.hostname||"localhost"==e.location.hostname||e.location.port&&e.location.port.length>0||i.isFileProtocol?"development":"production");var r=/!dumpLineNumbers:(comments|mediaquery|all)/.exec(e.location.hash);r&&(i.dumpLineNumbers=r[1]),void 0===i.useFileCache&&(i.useFileCache=!0),void 0===i.onReady&&(i.onReady=!0),i.relativeUrls&&(i.rewriteUrls="all")}(window,Mt),Mt.plugins=Mt.plugins||[],window.LESS_PLUGINS&&(Mt.plugins=Mt.plugins.concat(window.LESS_PLUGINS));var Et,Rt,Vt,Ft=function(e,n){var r=e.document,s=St();s.options=n;var o=s.environment,a=kt(n,s.logger),l=new a;o.addFileManager(l),s.FileManager=a,s.PluginLoader=_t,function(e,t){t.logLevel=void 0!==t.logLevel?t.logLevel:"development"===t.env?3:1,t.loggers||(t.loggers=[{debug:function(e){t.logLevel>=4&&console.log(e)},info:function(e){t.logLevel>=3&&console.log(e)},warn:function(e){t.logLevel>=2&&console.warn(e)},error:function(e){t.logLevel>=1&&console.error(e)}}]);for(var i=0;i0&&l.childNodes.length>0&&o.firstChild.nodeValue===l.firstChild.nodeValue);var u=t.getElementsByTagName("head")[0];if(null===o||!1===a){var c=n&&n.nextSibling||null;c?c.parentNode.insertBefore(l,c):u.appendChild(l)}if(o&&!1===a&&o.parentNode.removeChild(o),l.styleSheet)try{l.styleSheet.cssText=i}catch(e){throw new Error("Couldn't reassign styleSheet.cssText.")}},n=function(e){var t,i=e.document;return i.currentScript||(t=i.getElementsByTagName("script"))[t.length-1]},r={error:function(e){this._fireEvent("error",e)},warn:function(e){this._fireEvent("warn",e)},info:function(e){this._fireEvent("info",e)},debug:function(e){this._fireEvent("debug",e)},addListener:function(e){this._listeners.push(e)},removeListener:function(e){for(var t=0;t=0;a--){var l=o[a];if(l[s?"supportsSync":"supports"](e,t,i,n))return l}return null},e.prototype.addFileManager=function(e){this.fileManagers.push(e)},e.prototype.clearFileManagers=function(){this.fileManagers=[]},e}(),o={aliceblue:"#f0f8ff",antiquewhite:"#faebd7",aqua:"#00ffff",aquamarine:"#7fffd4",azure:"#f0ffff",beige:"#f5f5dc",bisque:"#ffe4c4",black:"#000000",blanchedalmond:"#ffebcd",blue:"#0000ff",blueviolet:"#8a2be2",brown:"#a52a2a",burlywood:"#deb887",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",cornflowerblue:"#6495ed",cornsilk:"#fff8dc",crimson:"#dc143c",cyan:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkgray:"#a9a9a9",darkgrey:"#a9a9a9",darkgreen:"#006400",darkkhaki:"#bdb76b",darkmagenta:"#8b008b",darkolivegreen:"#556b2f",darkorange:"#ff8c00",darkorchid:"#9932cc",darkred:"#8b0000",darksalmon:"#e9967a",darkseagreen:"#8fbc8f",darkslateblue:"#483d8b",darkslategray:"#2f4f4f",darkslategrey:"#2f4f4f",darkturquoise:"#00ced1",darkviolet:"#9400d3",deeppink:"#ff1493",deepskyblue:"#00bfff",dimgray:"#696969",dimgrey:"#696969",dodgerblue:"#1e90ff",firebrick:"#b22222",floralwhite:"#fffaf0",forestgreen:"#228b22",fuchsia:"#ff00ff",gainsboro:"#dcdcdc",ghostwhite:"#f8f8ff",gold:"#ffd700",goldenrod:"#daa520",gray:"#808080",grey:"#808080",green:"#008000",greenyellow:"#adff2f",honeydew:"#f0fff0",hotpink:"#ff69b4",indianred:"#cd5c5c",indigo:"#4b0082",ivory:"#fffff0",khaki:"#f0e68c",lavender:"#e6e6fa",lavenderblush:"#fff0f5",lawngreen:"#7cfc00",lemonchiffon:"#fffacd",lightblue:"#add8e6",lightcoral:"#f08080",lightcyan:"#e0ffff",lightgoldenrodyellow:"#fafad2",lightgray:"#d3d3d3",lightgrey:"#d3d3d3",lightgreen:"#90ee90",lightpink:"#ffb6c1",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",lightskyblue:"#87cefa",lightslategray:"#778899",lightslategrey:"#778899",lightsteelblue:"#b0c4de",lightyellow:"#ffffe0",lime:"#00ff00",limegreen:"#32cd32",linen:"#faf0e6",magenta:"#ff00ff",maroon:"#800000",mediumaquamarine:"#66cdaa",mediumblue:"#0000cd",mediumorchid:"#ba55d3",mediumpurple:"#9370d8",mediumseagreen:"#3cb371",mediumslateblue:"#7b68ee",mediumspringgreen:"#00fa9a",mediumturquoise:"#48d1cc",mediumvioletred:"#c71585",midnightblue:"#191970",mintcream:"#f5fffa",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",navajowhite:"#ffdead",navy:"#000080",oldlace:"#fdf5e6",olive:"#808000",olivedrab:"#6b8e23",orange:"#ffa500",orangered:"#ff4500",orchid:"#da70d6",palegoldenrod:"#eee8aa",palegreen:"#98fb98",paleturquoise:"#afeeee",palevioletred:"#d87093",papayawhip:"#ffefd5",peachpuff:"#ffdab9",peru:"#cd853f",pink:"#ffc0cb",plum:"#dda0dd",powderblue:"#b0e0e6",purple:"#800080",rebeccapurple:"#663399",red:"#ff0000",rosybrown:"#bc8f8f",royalblue:"#4169e1",saddlebrown:"#8b4513",salmon:"#fa8072",sandybrown:"#f4a460",seagreen:"#2e8b57",seashell:"#fff5ee",sienna:"#a0522d",silver:"#c0c0c0",skyblue:"#87ceeb",slateblue:"#6a5acd",slategray:"#708090",slategrey:"#708090",snow:"#fffafa",springgreen:"#00ff7f",steelblue:"#4682b4",tan:"#d2b48c",teal:"#008080",thistle:"#d8bfd8",tomato:"#ff6347",turquoise:"#40e0d0",violet:"#ee82ee",wheat:"#f5deb3",white:"#ffffff",whitesmoke:"#f5f5f5",yellow:"#ffff00",yellowgreen:"#9acd32"},a={length:{m:1,cm:.01,mm:.001,in:.0254,px:.0254/96,pt:.0254/72,pc:.0254/72*12},duration:{s:1,ms:.001},angle:{rad:1/(2*Math.PI),deg:1/360,grad:1/400,turn:1}},l={colors:o,unitConversions:a},u=function(){function e(){this.parent=null,this.visibilityBlocks=void 0,this.nodeVisible=void 0,this.rootNode=null,this.parsed=null;var e=this;Object.defineProperty(this,"currentFileInfo",{get:function(){return e.fileInfo()}}),Object.defineProperty(this,"index",{get:function(){return e.getIndex()}})}return e.prototype.setParent=function(t,i){function n(t){t&&t instanceof e&&(t.parent=i)}Array.isArray(t)?t.forEach(n):n(t)},e.prototype.getIndex=function(){return this._index||this.parent&&this.parent.getIndex()||0},e.prototype.fileInfo=function(){return this._fileInfo||this.parent&&this.parent.fileInfo()||{}},e.prototype.isRulesetLike=function(){return!1},e.prototype.toCSS=function(e){var t=[];return this.genCSS(e,{add:function(e,i,n){t.push(e)},isEmpty:function(){return 0===t.length}}),t.join("")},e.prototype.genCSS=function(e,t){t.add(this.value)},e.prototype.accept=function(e){this.value=e.visit(this.value)},e.prototype.eval=function(){return this},e.prototype._operate=function(e,t,i,n){switch(t){case"+":return i+n;case"-":return i-n;case"*":return i*n;case"/":return i/n}},e.prototype.fround=function(e,t){var i=e&&e.numPrecision;return i?Number((t+2e-16).toFixed(i)):t},e.compare=function(t,i){if(t.compare&&"Quoted"!==i.type&&"Anonymous"!==i.type)return t.compare(i);if(i.compare)return-i.compare(t);if(t.type===i.type){if(t=t.value,i=i.value,!Array.isArray(t))return t===i?0:void 0;if(t.length===i.length){for(var n=0;nt?1:void 0},e.prototype.blocksVisibility=function(){return null==this.visibilityBlocks&&(this.visibilityBlocks=0),0!==this.visibilityBlocks},e.prototype.addVisibilityBlock=function(){null==this.visibilityBlocks&&(this.visibilityBlocks=0),this.visibilityBlocks=this.visibilityBlocks+1},e.prototype.removeVisibilityBlock=function(){null==this.visibilityBlocks&&(this.visibilityBlocks=0),this.visibilityBlocks=this.visibilityBlocks-1},e.prototype.ensureVisibility=function(){this.nodeVisible=!0},e.prototype.ensureInvisibility=function(){this.nodeVisible=!1},e.prototype.isVisible=function(){return this.nodeVisible},e.prototype.visibilityInfo=function(){return{visibilityBlocks:this.visibilityBlocks,nodeVisible:this.nodeVisible}},e.prototype.copyVisibilityInfo=function(e){e&&(this.visibilityBlocks=e.visibilityBlocks,this.nodeVisible=e.nodeVisible)},e}(),c=function(e,t,i){var n=this;Array.isArray(e)?this.rgb=e:e.length>=6?(this.rgb=[],e.match(/.{2}/g).map((function(e,t){t<3?n.rgb.push(parseInt(e,16)):n.alpha=parseInt(e,16)/255}))):(this.rgb=[],e.split("").map((function(e,t){t<3?n.rgb.push(parseInt(e+e,16)):n.alpha=parseInt(e+e,16)/255}))),this.alpha=this.alpha||("number"==typeof t?t:1),void 0!==i&&(this.value=i)};function h(e,t){return Math.min(Math.max(e,0),t)}function f(e){return"#"+e.map((function(e){return((e=h(Math.round(e),255))<16?"0":"")+e.toString(16)})).join("")}c.prototype=Object.assign(new u,{type:"Color",luma:function(){var e=this.rgb[0]/255,t=this.rgb[1]/255,i=this.rgb[2]/255;return.2126*(e=e<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4))+.7152*(t=t<=.03928?t/12.92:Math.pow((t+.055)/1.055,2.4))+.0722*(i=i<=.03928?i/12.92:Math.pow((i+.055)/1.055,2.4))},genCSS:function(e,t){t.add(this.toCSS(e))},toCSS:function(e,t){var i,n,r,s=e&&e.compress&&!t,o=[];if(n=this.fround(e,this.alpha),this.value)if(0===this.value.indexOf("rgb"))n<1&&(r="rgba");else{if(0!==this.value.indexOf("hsl"))return this.value;r=n<1?"hsla":"hsl"}else n<1&&(r="rgba");switch(r){case"rgba":o=this.rgb.map((function(e){return h(Math.round(e),255)})).concat(h(n,1));break;case"hsla":o.push(h(n,1));case"hsl":i=this.toHSL(),o=[this.fround(e,i.h),this.fround(e,100*i.s)+"%",this.fround(e,100*i.l)+"%"].concat(o)}if(r)return r+"("+o.join(","+(s?"":" "))+")";if(i=this.toRGB(),s){var a=i.split("");a[1]===a[2]&&a[3]===a[4]&&a[5]===a[6]&&(i="#"+a[1]+a[3]+a[5])}return i},operate:function(e,t,i){for(var n=new Array(3),r=this.alpha*(1-i.alpha)+i.alpha,s=0;s<3;s++)n[s]=this._operate(e,t,this.rgb[s],i.rgb[s]);return new c(n,r)},toRGB:function(){return f(this.rgb)},toHSL:function(){var e,t,i=this.rgb[0]/255,n=this.rgb[1]/255,r=this.rgb[2]/255,s=this.alpha,o=Math.max(i,n,r),a=Math.min(i,n,r),l=(o+a)/2,u=o-a;if(o===a)e=t=0;else{switch(t=l>.5?u/(2-o-a):u/(o+a),o){case i:e=(n-r)/u+(n=0&&"\n"!==t.charAt(i);)r++;return"number"==typeof e&&(n=(t.slice(0,e).match(/\n/g)||"").length),{line:n,column:r}}function k(e){var t,i=e.length,n=new Array(i);for(t=0;t|Function):(\d+):(\d+)/,O=function(e,t,i){Error.call(this);var n=e.filename||i;if(this.message=e.message,this.stack=e.stack,t&&n){var r=t.contents[n],s=C(e.index,r),o=s.line,a=s.column,l=e.call&&C(e.call,r).line,u=r?r.split("\n"):"";if(this.type=e.type||"Syntax",this.filename=n,this.index=e.index,this.line="number"==typeof o?o+1:null,this.column=a,!this.line&&this.stack){var c=this.stack.match(R),h=new Function("a","throw new Error()"),f=0;try{h()}catch(e){var p=e.stack.match(R);f=1-(o=parseInt(p[2]))}c&&(c[2]&&(this.line=parseInt(c[2])+f),c[3]&&(this.column=parseInt(c[3])))}this.callLine=l+1,this.callExtract=u[l],this.extract=[u[this.line-2],u[this.line-1],u[this.line]]}};if(void 0===Object.create){var V=function(){};V.prototype=Error.prototype,O.prototype=new V}else O.prototype=Object.create(Error.prototype);O.prototype.constructor=O,O.prototype.toString=function(e){e=e||{};var t="",i=this.extract||[],n=[],r=function(e){return e};if(e.stylize){var s=typeof e.stylize;if("function"!==s)throw Error("options.stylize should be a function, got a "+s+"!");r=e.stylize}if(null!==this.line){if("string"==typeof i[0]&&n.push(r(this.line-1+" "+i[0],"grey")),"string"==typeof i[1]){var o=this.line+" ";i[1]&&(o+=i[1].slice(0,this.column)+r(r(r(i[1].substr(this.column,1),"bold")+i[1].slice(this.column+1),"red"),"inverse")),n.push(o)}"string"==typeof i[2]&&n.push(r(this.line+1+" "+i[2],"grey")),n=n.join("\n")+r("","reset")+"\n"}return t+=r(this.type+"Error: "+this.message,"red"),this.filename&&(t+=r(" in ","red")+this.filename),this.line&&(t+=r(" on line "+this.line+", column "+(this.column+1)+":","grey")),t+="\n"+n,this.callLine&&(t+=r("from ","red")+(this.filename||"")+"/n",t+=r(this.callLine,"grey")+" "+this.callExtract+"/n"),t};var F=function(e,t,i,n,r,s){this.extendList=t,this.condition=i,this.evaldCondition=!i,this._index=n,this._fileInfo=r,this.elements=this.getElements(e),this.mixinElements_=void 0,this.copyVisibilityInfo(s),this.setParent(this.elements,this)};F.prototype=Object.assign(new u,{type:"Selector",accept:function(e){this.elements&&(this.elements=e.visitArray(this.elements)),this.extendList&&(this.extendList=e.visitArray(this.extendList)),this.condition&&(this.condition=e.visit(this.condition))},createDerived:function(e,t,i){e=this.getElements(e);var n=new F(e,t||this.extendList,null,this.getIndex(),this.fileInfo(),this.visibilityInfo());return n.evaldCondition=null!=i?i:this.evaldCondition,n.mediaEmpty=this.mediaEmpty,n},getElements:function(e){return e?("string"==typeof e&&this.parse.parseNode(e,["selector"],this._index,this._fileInfo,(function(t,i){if(t)throw new O({index:t.index,message:t.message},this.parse.imports,this._fileInfo.filename);e=i[0].elements})),e):[new m("","&",!1,this._index,this._fileInfo)]},createEmptySelectors:function(){var e=new m("","&",!1,this._index,this._fileInfo),t=[new F([e],null,null,this._index,this._fileInfo)];return t[0].mediaEmpty=!0,t},match:function(e){var t,i,n=this.elements,r=n.length;if(0===(t=(e=e.mixinElements()).length)||rg.PARENS_DIVISION)||this.parensStack&&this.parensStack.length))},q.Eval.prototype.pathRequiresRewrite=function(e){return(this.rewriteUrls===b?J:W)(e)},q.Eval.prototype.rewritePath=function(e,t){var i;return t=t||"",i=this.normalizePath(t+e),J(e)&&W(t)&&!1===J(i)&&(i="./"+i),i},q.Eval.prototype.normalizePath=function(e){var t,i=e.split("/").reverse();for(e=[];0!==i.length;)switch(t=i.pop()){case".":break;case"..":0===e.length||".."===e[e.length-1]?e.push(t):e.pop();break;default:e.push(t)}return e.join("/")};var H=function e(t){return{_data:{},add:function(e,t){e=e.toLowerCase(),this._data.hasOwnProperty(e),this._data[e]=t},addMultiple:function(e){var t=this;Object.keys(e).forEach((function(i){t.add(i,e[i])}))},get:function(e){return this._data[e]||t&&t.get(e)},getLocalFunctions:function(){return this._data},inherit:function(){return e(this)},create:function(t){return e(t)}}}(null),Q={eval:function(){var e=this.value_,t=this.error_;if(t)throw t;if(null!=e)return e?L.True:L.False},value:function(e){this.value_=e},error:function(e){this.error_=e},reset:function(){this.value_=this.error_=null}},K=function(e,t,i,n){this.selectors=e,this.rules=t,this._lookups={},this._variables=null,this._properties=null,this.strictImports=i,this.copyVisibilityInfo(n),this.allowRoot=!0,this.setParent(this.selectors,this),this.setParent(this.rules,this)};K.prototype=Object.assign(new u,{type:"Ruleset",isRuleset:!0,isRulesetLike:function(){return!0},accept:function(e){this.paths?this.paths=e.visitArray(this.paths,!0):this.selectors&&(this.selectors=e.visitArray(this.selectors)),this.rules&&this.rules.length&&(this.rules=e.visitArray(this.rules))},eval:function(e){var t,i,n,r,s,o=!1;if(this.selectors&&(i=this.selectors.length)){for(t=new Array(i),Q.error({type:"Syntax",message:"it is currently only allowed in parametric mixin guards,"}),r=0;r0;e--){var t=this.rules[e-1];if(t instanceof D)return this.parseValue(t)}},parseValue:function(e){var t=this;function i(e){return e.value instanceof j&&!e.parsed?("string"==typeof e.value.value?this.parse.parseNode(e.value.value,["value","important"],e.value.getIndex(),e.fileInfo(),(function(t,i){t&&(e.parsed=!0),i&&(e.value=i[0],e.important=i[1]||"",e.parsed=!0)})):e.parsed=!0,e):e}if(Array.isArray(e)){var n=[];return e.forEach((function(e){n.push(i.call(t,e))})),n}return i.call(t,e)},rulesets:function(){if(!this.rules)return[];var e,t,i=[],n=this.rules;for(e=0;t=n[e];e++)t.isRuleset&&i.push(t);return i},prependRule:function(e){var t=this.rules;t?t.unshift(e):this.rules=[e],this.setParent(e,this)},find:function(e,t,i){t=t||this;var n,r,s=[],o=e.toCSS();return o in this._lookups?this._lookups[o]:(this.rulesets().forEach((function(o){if(o!==t)for(var a=0;an){if(!i||i(o)){r=o.find(new F(e.elements.slice(n)),t,i);for(var l=0;l0&&t.add(l),e.firstSelector=!0,o[0].genCSS(e,t),e.firstSelector=!1,n=1;n0?(s=(r=k(e)).pop(),o=n.createDerived(k(s.elements))):o=n.createDerived([]),t.length>0){var a=i.combinator,l=t[0].elements[0];a.emptyOrWhitespace&&!l.combinator.emptyOrWhitespace&&(a=l.combinator),o.elements.push(new m(a,l.value,i.isVariable,i._index,i._fileInfo)),o.elements=o.elements.concat(t[0].elements.slice(1))}if(0!==o.elements.length&&r.push(o),t.length>1){var u=t.slice(1);u=u.map((function(e){return e.createDerived(e.elements,[])})),r=r.concat(u)}return r}function o(e,t,i,n,r){var o;for(o=0;o0?n[n.length-1]=n[n.length-1].createDerived(n[n.length-1].elements.concat(e)):n.push(new F(e));else t.push([new F(e)])}function l(e,t){var i=t.createDerived(t.elements,t.extendList,t.evaldCondition);return i.copyVisibilityInfo(e),i}var u,c;if(!function e(t,i,l){var u,c,h,f,v,d,g,y,b,w,x,S,I=!1;for(f=[],v=[[]],u=0;y=l.elements[u];u++)if("&"!==y.value){var C=(S=void 0,(x=y).value instanceof p&&(S=x.value.value)instanceof F?S:null);if(null!=C){a(f,v);var k,_=[],A=[];for(k=e(_,i,C),I=I||k,h=0;h<_.length;h++){o(v,[r(n(_[h],y),y)],y,l,A)}v=A,f=[]}else f.push(y)}else{for(I=!0,d=[],a(f,v),c=0;c0&&g[0].elements.push(new m(y.combinator,"",y.isVariable,y._index,y._fileInfo)),d.push(g);else for(h=0;h0&&(t.push(v[u]),w=v[u][b-1],v[u][b-1]=w.createDerived(w.elements,l.extendList));return I}(c=[],t,i))if(t.length>0)for(c=[],u=0;u0)for(t=0;t-1e-6&&(n=i.toFixed(20).replace(/0+$/,"")),e&&e.compress){if(0===i&&this.unit.isLength())return void t.add(n);i>0&&i<1&&(n=n.substr(1))}t.add(n),this.unit.genCSS(e,t)},operate:function(e,t,i){var n=this._operate(e,t,this.value,i.value),r=this.unit.clone();if("+"===t||"-"===t)if(0===r.numerator.length&&0===r.denominator.length)r=i.unit.clone(),this.unit.backupUnit&&(r.backupUnit=this.unit.backupUnit);else if(0===i.unit.numerator.length&&0===r.denominator.length);else{if(i=i.convertTo(this.unit.usedUnits()),e.strictUnits&&i.unit.toString()!==r.toString())throw new Error("Incompatible units. Change the units or use the unit function. Bad units: '"+r.toString()+"' and '"+i.unit.toString()+"'.");n=this._operate(e,t,this.value,i.value)}else"*"===t?(r.numerator=r.numerator.concat(i.unit.numerator).sort(),r.denominator=r.denominator.concat(i.unit.denominator).sort(),r.cancel()):"/"===t&&(r.numerator=r.numerator.concat(i.unit.denominator).sort(),r.denominator=r.denominator.concat(i.unit.numerator).sort(),r.cancel());return new ee(n,r)},compare:function(e){var t,i;if(e instanceof ee){if(this.unit.isEmpty()||e.unit.isEmpty())t=this,i=e;else if(t=this.unify(),i=e.unify(),0!==t.unit.compare(i.unit))return;return u.numericCompare(t.value,i.value)}},unify:function(){return this.convertTo({length:"px",duration:"s",angle:"rad"})},convertTo:function(e){var t,i,n,r,s,o=this.value,l=this.unit.clone(),u={};if("string"==typeof e){for(t in a)a[t].hasOwnProperty(e)&&((u={})[t]=e);e=u}for(i in s=function(e,t){return n.hasOwnProperty(e)?(t?o/=n[e]/n[r]:o*=n[e]/n[r],r):e},e)e.hasOwnProperty(i)&&(r=e[i],n=a[i],l.map(s));return l.cancel(),new ee(o,l)}});var te=g,ie=function(e,t,i){this.op=e.trim(),this.operands=t,this.isSpaced=i};ie.prototype=Object.assign(new u,{type:"Operation",accept:function(e){this.operands=e.visitArray(this.operands)},eval:function(e){var t,i=this.operands[0].eval(e),n=this.operands[1].eval(e);if(e.isMathOn(this.op)){if(t="./"===this.op?"/":this.op,i instanceof ee&&n instanceof c&&(i=i.toColor()),n instanceof ee&&i instanceof c&&(n=n.toColor()),!i.operate){if(i instanceof ie&&"/"===i.op&&e.math===te.PARENS_DIVISION)return new ie(this.op,[i,n],this.isSpaced);throw{type:"Operation",message:"Operation on an invalid type"}}return i.operate(e,t,n)}return new ie(this.op,[i,n],this.isSpaced)},genCSS:function(e,t){this.operands[0].genCSS(e,t),this.isSpaced&&t.add(" "),t.add(this.op),this.isSpaced&&t.add(" "),this.operands[1].genCSS(e,t)}});var ne=function(e,t){if(this.value=e,this.noSpacing=t,!e)throw new Error("Expression requires an array parameter")};ne.prototype=Object.assign(new u,{type:"Expression",accept:function(e){this.value=e.visitArray(this.value)},eval:function(e){var t,i=e.isMathOn(),n=this.parens,r=!1;return n&&e.inParenthesis(),this.value.length>1?t=new ne(this.value.map((function(t){return t.eval?t.eval(e):t})),this.noSpacing):1===this.value.length?(!this.value[0].parens||this.value[0].parensInOp||e.inCalc||(r=!0),t=this.value[0].eval(e)):t=this,n&&e.outOfParenthesis(),!this.parens||!this.parensInOp||i||r||t instanceof ee||(t=new p(t)),t},genCSS:function(e,t){for(var i=0;i1){var i=new F([],null,null,this.getIndex(),this.fileInfo()).createEmptySelectors();(t=new K(i,e.mediaBlocks)).multiMedia=!0,t.copyVisibilityInfo(this.visibilityInfo()),this.setParent(t,this)}return delete e.mediaBlocks,delete e.mediaPath,t},evalNested:function(e){var t,i,n=e.mediaPath.concat([this]);for(t=0;t0;t--)e.splice(t,0,new j("and"));return new ne(e)}))),this.setParent(this.features,this),new K([],[])},permute:function(e){if(0===e.length)return[];if(1===e.length)return e[0];for(var t=[],i=this.permute(e.slice(1)),n=0;n1?"["+e.value.map((function(e){return e.toCSS()})).join(", ")+"]":e.toCSS()}});var ve=function(e,t,i,n){this.escaped=t,this.expression=e,this._index=i,this._fileInfo=n};ve.prototype=Object.assign(new pe,{type:"JavaScript",eval:function(e){var t=this.evaluateJavaScript(this.expression,e),i=typeof t;return"number"!==i||isNaN(t)?"string"===i?new ue('"'+t+'"',t,this.escaped,this._index):Array.isArray(t)?new j(t.join(", ")):new j(t):new ee(t)}});var de=function(e,t){this.key=e,this.value=t};de.prototype=Object.assign(new u,{type:"Assignment",accept:function(e){this.value=e.visit(this.value)},eval:function(e){return this.value.eval?new de(this.key,this.value.eval(e)):this},genCSS:function(e,t){t.add(this.key+"="),this.value.genCSS?this.value.genCSS(e,t):t.add(this.value)}});var me=function(e,t,i,n,r){this.op=e.trim(),this.lvalue=t,this.rvalue=i,this._index=n,this.negate=r};me.prototype=Object.assign(new u,{type:"Condition",accept:function(e){this.lvalue=e.visit(this.lvalue),this.rvalue=e.visit(this.rvalue)},eval:function(e){var t=function(e,t,i){switch(e){case"and":return t&&i;case"or":return t||i;default:switch(u.compare(t,i)){case-1:return"<"===e||"=<"===e||"<="===e;case 0:return"="===e||">="===e||"=<"===e||"<="===e;case 1:return">"===e||">="===e;default:return!1}}}(this.op,this.lvalue.eval(e),this.rvalue.eval(e));return this.negate?!t:t}});var ge=function(e){this.value=e};ge.prototype=Object.assign(new u,{type:"UnicodeDescriptor"});var ye=function(e){this.value=e};ye.prototype=Object.assign(new u,{type:"Negative",genCSS:function(e,t){t.add("-"),this.value.genCSS(e,t)},eval:function(e){return e.isMathOn()?new ie("*",[new ee(-1),this.value]).eval(e):new ye(this.value.eval(e))}});var be=function(e,t,i,n,r){switch(this.selector=e,this.option=t,this.object_id=be.next_id++,this.parent_ids=[this.object_id],this._index=i,this._fileInfo=n,this.copyVisibilityInfo(r),this.allowRoot=!0,t){case"all":this.allowBefore=!0,this.allowAfter=!0;break;default:this.allowBefore=!1,this.allowAfter=!1}this.setParent(this.selector,this)};be.prototype=Object.assign(new u,{type:"Extend",accept:function(e){this.selector=e.visit(this.selector)},eval:function(e){return new be(this.selector.eval(e),this.option,this.getIndex(),this.fileInfo(),this.visibilityInfo())},clone:function(e){return new be(this.selector,this.option,this.getIndex(),this.fileInfo(),this.visibilityInfo())},findSelfSelectors:function(e){var t,i,n=[];for(t=0;t0&&i.length&&""===i[0].combinator.value&&(i[0].combinator.value=" "),n=n.concat(e[t].elements);this.selfSelectors=[new F(n)],this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo())}}),be.next_id=0;var we=function(e,t,i){this.variable=e,this._index=t,this._fileInfo=i,this.allowRoot=!0};we.prototype=Object.assign(new u,{type:"VariableCall",eval:function(e){var t,i=new oe(this.variable,this.getIndex(),this.fileInfo()).eval(e),n=new O({message:"Could not evaluate variable call "+this.variable});if(!i.ruleset){if(i.rules)t=i;else if(Array.isArray(i))t=new K("",i);else{if(!Array.isArray(i.value))throw n;t=new K("",i.value)}i=new X(t)}if(i.ruleset)return i.callEval(e);throw n}});var xe=function(e,t,i,n){this.value=e,this.lookups=t,this._index=i,this._fileInfo=n};xe.prototype=Object.assign(new u,{type:"NamespaceValue",eval:function(e){var t,i,n=this.value.eval(e);for(t=0;tthis.params.length)return!1}i=Math.min(s,this.arity);for(var o=0;o0){for(c=!0,a=0;a0)f=2;else if(f=1,p[1]+p[2]>1)throw{type:"Runtime",message:"Ambiguous use of `default()` found when matching for `"+this.format(m)+"`",index:this.getIndex(),filename:this.fileInfo().filename};for(a=0;a0&&(e=e.slice(0,t)),(t=e.lastIndexOf("/"))<0&&(t=e.lastIndexOf("\\")),t<0?"":e.slice(0,t+1)},e.prototype.tryAppendExtension=function(e,t){return/(\.[a-z]*$)|([\?;].*)$/.test(e)?e:e+t},e.prototype.tryAppendLessExtension=function(e){return this.tryAppendExtension(e,".less")},e.prototype.supportsSync=function(){return!1},e.prototype.alwaysMakePathsAbsolute=function(){return!1},e.prototype.isPathAbsolute=function(e){return/^(?:[a-z-]+:|\/|\\|#)/i.test(e)},e.prototype.join=function(e,t){return e?e+t:t},e.prototype.pathDiff=function(e,t){var i,n,r,s,o=this.extractUrlParts(e),a=this.extractUrlParts(t),l="";if(o.hostPart!==a.hostPart)return"";for(n=Math.max(a.directories.length,o.directories.length),i=0;iparseInt(t[i])?-1:1;return 0},e.prototype.versionToString=function(e){for(var t="",i=0;i0;){var e=this.imports[0];if(!e.isReady)return;this.imports=this.imports.slice(1),e.callback.apply(null,e.args)}if(0===this.variableImports.length)break;var t=this.variableImports[0];this.variableImports=this.variableImports.slice(1),t()}}finally{this._currentDepth--}0===this._currentDepth&&this._onSequencerEmpty&&this._onSequencerEmpty()},e}(),Oe=function(e,t){this._visitor=new Pe(this),this._importer=e,this._finish=t,this.context=new q.Eval,this.importCount=0,this.onceFileDetectionMap={},this.recursionDetector={},this._sequencer=new Re(this._onSequencerEmpty.bind(this))};Oe.prototype={isReplacing:!1,run:function(e){try{this._visitor.visit(e)}catch(e){this.error=e}this.isFinished=!0,this._sequencer.tryRun()},_onSequencerEmpty:function(){this.isFinished&&this._finish(this.error)},visitImport:function(e,t){var i=e.options.inline;if(!e.css||i){var n=new q.Eval(this.context,k(this.context.frames)),r=n.frames[0];this.importCount++,e.isVariableImport()?this._sequencer.addVariableImport(this.processImportNode.bind(this,e,n,r)):this.processImportNode(e,n,r)}t.visitDeeper=!1},processImportNode:function(e,t,i){var n,r=e.options.inline;try{n=e.evalForImport(t)}catch(t){t.filename||(t.index=e.getIndex(),t.filename=e.fileInfo().filename),e.css=!0,e.error=t}if(!n||n.css&&!r)this.importCount--,this.isFinished&&this._sequencer.tryRun();else{n.options.multiple&&(t.importMultiple=!0);for(var s=void 0===n.css,o=0;o=0||(a=[u.selfSelectors[0]],(s=f.findMatch(l,a)).length&&(l.hasFoundMatches=!0,l.selfSelectors.forEach((function(e){var t=u.visibilityInfo();o=f.extendSelector(s,a,e,l.isVisible()),(c=new Ce.Extend(u.selector,u.option,0,u.fileInfo(),t)).selfSelectors=o,o[o.length-1].extendList=[c],h.push(c),c.ruleset=u.ruleset,c.parent_ids=c.parent_ids.concat(u.parent_ids,l.parent_ids),u.firstExtendOnThisSelectorPath&&(c.firstExtendOnThisSelectorPath=!0,u.ruleset.paths.push(o))}))));if(h.length){if(this.extendChainCount++,i>100){var p="{unable to calculate}",v="{unable to calculate}";try{p=h[0].selfSelectors[0].toCSS(),v=h[0].selector.toCSS()}catch(e){}throw{message:"extend circular reference detected. One of the circular extends is currently:"+p+":extend("+v+")"}}return h.concat(f.doExtendChaining(h,t,i+1))}return h},e.prototype.visitDeclaration=function(e,t){t.visitDeeper=!1},e.prototype.visitMixinDefinition=function(e,t){t.visitDeeper=!1},e.prototype.visitSelector=function(e,t){t.visitDeeper=!1},e.prototype.visitRuleset=function(e,t){if(!e.root){var i,n,r,s,o=this.allExtendsStack[this.allExtendsStack.length-1],a=[],l=this;for(r=0;r0&&u[l.matched].combinator.value!==o?l=null:l.matched++,l&&(l.finished=l.matched===u.length,l.finished&&!e.allowAfter&&(r+1u&&c>0&&(h[h.length-1].elements=h[h.length-1].elements.concat(t[u].elements.slice(c)),c=0,u++),l=s.elements.slice(c,a.index).concat([o]).concat(i.elements.slice(1)),u===a.pathIndex&&r>0?h[h.length-1].elements=h[h.length-1].elements.concat(l):(h=h.concat(t.slice(u,a.pathIndex))).push(new Ce.Selector(l)),u=a.endPathIndex,(c=a.endPathElementIndex)>=t[u].elements.length&&(c=0,u++);return u0&&(h[h.length-1].elements=h[h.length-1].elements.concat(t[u].elements.slice(c)),u++),h=(h=h.concat(t.slice(u,t.length))).map((function(e){var t=e.createDerived(e.elements);return n?t.ensureVisibility():t.ensureInvisibility(),t}))},e.prototype.visitMedia=function(e,t){var i=e.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length-1]);i=i.concat(this.doExtendChaining(i,e.allExtends)),this.allExtendsStack.push(i)},e.prototype.visitMediaOut=function(e){var t=this.allExtendsStack.length-1;this.allExtendsStack.length=t},e.prototype.visitAtRule=function(e,t){var i=e.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length-1]);i=i.concat(this.doExtendChaining(i,e.allExtends)),this.allExtendsStack.push(i)},e.prototype.visitAtRuleOut=function(e){var t=this.allExtendsStack.length-1;this.allExtendsStack.length=t},e}(),Le=function(){function e(){this.contexts=[[]],this._visitor=new Pe(this)}return e.prototype.run=function(e){return this._visitor.visit(e)},e.prototype.visitDeclaration=function(e,t){t.visitDeeper=!1},e.prototype.visitMixinDefinition=function(e,t){t.visitDeeper=!1},e.prototype.visitRuleset=function(e,t){var i,n=this.contexts[this.contexts.length-1],r=[];this.contexts.push(r),e.root||((i=e.selectors)&&(i=i.filter((function(e){return e.getIsOutput()})),e.selectors=i.length?i:i=null,i&&e.joinSelectors(r,n,i)),i||(e.rules=null),e.paths=r)},e.prototype.visitRulesetOut=function(e){this.contexts.length=this.contexts.length-1},e.prototype.visitMedia=function(e,t){var i=this.contexts[this.contexts.length-1];e.rules[0].root=0===i.length||i[0].multiMedia},e.prototype.visitAtRule=function(e,t){var i=this.contexts[this.contexts.length-1];e.rules&&e.rules.length&&(e.rules[0].root=e.isRooted||0===i.length||null)},e}(),je=function(){function e(e){this._visitor=new Pe(this),this._context=e}return e.prototype.containsSilentNonBlockedChild=function(e){var t;if(!e)return!1;for(var i=0;i0},e.prototype.resolveVisibility=function(e,t){if(!e.blocksVisibility()){if(this.isEmpty(e)&&!this.containsSilentNonBlockedChild(t))return;return e}var i=e.rules[0];if(this.keepOnlyVisibleChilds(i),!this.isEmpty(i))return e.ensureVisibility(),e.removeVisibilityBlock(),e},e.prototype.isVisibleRuleset=function(e){return!!e.firstRoot||!this.isEmpty(e)&&!(!e.root&&!this.hasVisibleSelector(e))},e}(),Ne=function(e){this._visitor=new Pe(this),this._context=e,this.utils=new je(e)};Ne.prototype={isReplacing:!0,run:function(e){return this._visitor.visit(e)},visitDeclaration:function(e,t){if(!e.blocksVisibility()&&!e.variable)return e},visitMixinDefinition:function(e,t){e.frames=[]},visitExtend:function(e,t){},visitComment:function(e,t){if(!e.blocksVisibility()&&!e.isSilent(this._context))return e},visitMedia:function(e,t){var i=e.rules[0].rules;return e.accept(this._visitor),t.visitDeeper=!1,this.utils.resolveVisibility(e,i)},visitImport:function(e,t){if(!e.blocksVisibility())return e},visitAtRule:function(e,t){return e.rules&&e.rules.length?this.visitAtRuleWithBody(e,t):this.visitAtRuleWithoutBody(e,t)},visitAnonymous:function(e,t){if(!e.blocksVisibility())return e.accept(this._visitor),e},visitAtRuleWithBody:function(e,t){var i=function(e){var t=e.rules;return function(e){var t=e.rules;return 1===t.length&&(!t[0].paths||0===t[0].paths.length)}(e)?t[0].rules:t}(e);return e.accept(this._visitor),t.visitDeeper=!1,this.utils.isEmpty(e)||this._mergeRules(e.rules[0].rules),this.utils.resolveVisibility(e,i)},visitAtRuleWithoutBody:function(e,t){if(!e.blocksVisibility()){if("@charset"===e.name){if(this.charset){if(e.debugInfo){var i=new Ce.Comment("/* "+e.toCSS(this._context).replace(/\n/g,"")+" */\n");return i.debugInfo=e.debugInfo,this._visitor.visit(i)}return}this.charset=!0}return e}},checkValidNodes:function(e,t){if(e)for(var i=0;i0?e.accept(this._visitor):e.rules=null,t.visitDeeper=!1}return e.rules&&(this._mergeRules(e.rules),this._removeDuplicateRules(e.rules)),this.utils.isVisibleRuleset(e)&&(e.ensureVisibility(),n.splice(0,0,e)),1===n.length?n[0]:n},_compileRulesetPaths:function(e){e.paths&&(e.paths=e.paths.filter((function(e){var t;for(" "===e[0].elements[0].combinator.value&&(e[0].elements[0].combinator=new Ce.Combinator("")),t=0;t=0;n--)if((i=e[n])instanceof Ce.Declaration)if(r[i.name]){(t=r[i.name])instanceof Ce.Declaration&&(t=r[i.name]=[r[i.name].toCSS(this._context)]);var s=i.toCSS(this._context);-1!==t.indexOf(s)?e.splice(n,1):t.push(s)}else r[i.name]=i}},_mergeRules:function(e){if(e){for(var t={},i=[],n=0;n0){var t=e[0],i=[],n=[new Ce.Expression(i)];e.forEach((function(e){"+"===e.merge&&i.length>0&&n.push(new Ce.Expression(i=[])),i.push(e.value),t.important=t.important||e.important})),t.value=new Ce.Value(n)}}))}}};var De={Visitor:Pe,ImportVisitor:Oe,MarkVisibleSelectorsVisitor:Ve,ExtendVisitor:$e,JoinSelectorVisitor:Le,ToCSSVisitor:Ne};var Ue=function(){var e,t,i,n,r,s,o,a=[],l={};function u(i){for(var n,a,c,h=l.i,f=t,p=l.i-o,v=l.i+s.length-p,d=l.i+=i,m=e;l.i=0){c={index:l.i,text:m.substr(l.i,y+2-l.i),isLineComment:!1},l.i+=c.text.length-1,l.commentStore.push(c);continue}}break}if(32!==n&&10!==n&&9!==n&&13!==n)break}if(s=s.slice(i+l.i-d+p),o=l.i,!s.length){if(ti||l.i===i&&e&&!n)&&(i=l.i,n=e);var r=a.pop();s=r.current,o=l.i=r.i,t=r.j},l.forget=function(){a.pop()},l.isWhitespace=function(t){var i=l.i+(t||0),n=e.charCodeAt(i);return 32===n||13===n||9===n||10===n},l.$re=function(e){l.i>o&&(s=s.slice(l.i-o),o=l.i);var t=e.exec(s);return t?(u(t[0].length),"string"==typeof t?t:1===t.length?t[0]:t):null},l.$char=function(t){return e.charAt(l.i)!==t?null:(u(1),t)},l.$str=function(t){for(var i=t.length,n=0;nh&&(d=!1)}}while(d);return r||null},l.autoCommentAbsorb=!0,l.commentStore=[],l.finished=!1,l.peek=function(t){if("string"==typeof t){for(var i=0;i57||t<43||47===t||44===t},l.start=function(n,a,c){e=n,l.i=t=o=i=0,r=a?function(e,t){var i,n,r,s,o,a,l,u,c,h=e.length,f=0,p=0,v=[],d=0;function m(t){var i=o-d;i<512&&!t||!i||(v.push(e.slice(d,o+1)),d=o+1)}for(o=0;o=97&&l<=122||l<34))switch(l){case 40:p++,n=o;continue;case 41:if(--p<0)return t("missing opening `(`",o);continue;case 59:p||m();continue;case 123:f++,i=o;continue;case 125:if(--f<0)return t("missing opening `{`",o);f||p||m();continue;case 92:if(o96)){if(u==l){c=1;break}if(92==u){if(o==h-1)return t("unescaped `\\`",o);o++}}if(c)continue;return t("unmatched `"+String.fromCharCode(l)+"`",a);case 47:if(p||o==h-1)continue;if(47==(u=e.charCodeAt(o+1)))for(o+=2;oi&&s>r?"missing closing `}` or `*/`":"missing closing `}`",i):0!==p?t("missing closing `)`",n):(m(!0),v)}(n,c):[n],s=r[0],u(0)},l.end=function(){var t,r=l.i>=e.length;return l.i=e.length-1,furthestChar:e[l.i]}},l},Be=function e(t,i,n){var r,s=Ue();function o(e,t){throw new O({index:s.i,filename:n.filename,type:t||"Syntax",message:e},i)}function a(e,t){var i=e instanceof Function?e.call(r):s.$re(e);if(i)return i;o(t||("string"==typeof e?"expected '"+e+"' got '"+s.currentChar()+"'":"unexpected token"))}function l(e,t){if(s.$char(e))return e;o(t||"expected '"+e+"' got '"+s.currentChar()+"'")}function u(e){var t=n.filename;return{lineNumber:C(e,s.getInput()).line+1,fileName:t}}return{parserInput:s,imports:i,fileInfo:n,parseNode:function(e,t,n,o,a){var l,u=[],c=s;try{c.start(e,!1,(function(e,t){a({message:e,index:t+n})}));for(var h=0,f=void 0,p=void 0;f=t[h];h++)if(p=c.i,l=r[f]()){try{l._index=p+n,l._fileInfo=o}catch(e){}u.push(l)}else u.push(null);c.end().isFinished?a(null,u):a(!0,null)}catch(e){throw new O({index:e.index+n,message:e.message},i,o.filename)}},parse:function(r,o,a){var l,u,c,h,f=null,p="";if(u=a&&a.globalVars?e.serializeVars(a.globalVars)+"\n":"",c=a&&a.modifyVars?"\n"+e.serializeVars(a.modifyVars):"",t.pluginManager)for(var v=t.pluginManager.getPreProcessors(),d=0;d");return e},args:function(e){var t,i,n,a,l,u,c,h=r.entities,f={args:null,variadic:!1},p=[],v=[],d=[],m=!0;for(s.save();;){if(e)u=r.detachedRuleset()||r.expression();else{if(s.commentStore.length=0,s.$str("...")){f.variadic=!0,s.$char(";")&&!t&&(t=!0),(t?v:d).push({variadic:!0});break}u=h.variable()||h.property()||h.literal()||h.keyword()||this.call(!0)}if(!u||!m)break;a=null,u.throwAwayComments&&u.throwAwayComments(),l=u;var g=null;if(e?u.value&&1==u.value.length&&(g=u.value[0]):g=u,g&&(g instanceof Ce.Variable||g instanceof Ce.Property))if(s.$char(":")){if(p.length>0&&(t&&o("Cannot mix ; and , as delimiter types"),i=!0),!(l=r.detachedRuleset()||r.expression())){if(!e)return s.restore(),f.args=[],f;o("could not understand value for named argument")}a=n=g.name}else if(s.$str("...")){if(!e){f.variadic=!0,s.$char(";")&&!t&&(t=!0),(t?v:d).push({name:u.name,variadic:!0});break}c=!0}else e||(n=a=g.name,l=null);l&&p.push(l),d.push({name:a,value:l,expand:c}),s.$char(",")?m=!0:((m=";"===s.$char(";"))||t)&&(i&&o("Cannot mix ; and , as delimiter types"),t=!0,p.length>1&&(l=new Ce.Value(p)),v.push({name:n,value:l,expand:c}),n=null,p=[],i=!1)}return s.forget(),f.args=t?v:d,f},definition:function(){var e,t,i,n,o=[],l=!1;if(!("."!==s.currentChar()&&"#"!==s.currentChar()||s.peek(/^[^{]*\}/)))if(s.save(),t=s.$re(/^([#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\s*\(/)){e=t[1];var u=this.args(!1);if(o=u.args,l=u.variadic,!s.$char(")"))return void s.restore("Missing closing ')'");if(s.commentStore.length=0,s.$str("when")&&(n=a(r.conditions,"expected condition")),i=r.block())return s.forget(),new Ce.mixin.Definition(e,o,i,n,l);s.restore()}else s.restore()},ruleLookups:function(){var e,t=[];if("["===s.currentChar()){for(;;){if(s.save(),!(e=this.lookupValue())&&""!==e){s.restore();break}t.push(e),s.forget()}return t.length>0?t:void 0}},lookupValue:function(){if(s.save(),s.$char("[")){var e=s.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/);if(s.$char("]"))return e||""===e?(s.forget(),e):void s.restore();s.restore()}else s.restore()}},entity:function(){var e=this.entities;return this.comment()||e.literal()||e.variable()||e.url()||e.property()||e.call()||e.keyword()||this.mixin.call(!0)||e.javascript()},end:function(){return s.$char(";")||s.peek("}")},ieAlpha:function(){var e;if(s.$re(/^opacity=/i))return(e=s.$re(/^\d+/))||(e="@{"+(e=a(r.entities.variable,"Could not parse alpha")).name.slice(1)+"}"),l(")"),new Ce.Quoted("","alpha(opacity="+e+")")},element:function(){var e,t,i,r=s.i;if(t=this.combinator(),(e=s.$re(/^(?:\d+\.\d+|\d+)%/)||s.$re(/^(?:[.#]?|:*)(?:[\w-]|[^\x00-\x9f]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/)||s.$char("*")||s.$char("&")||this.attribute()||s.$re(/^\([^&()@]+\)/)||s.$re(/^[\.#:](?=@)/)||this.entities.variableCurly())||(s.save(),s.$char("(")?(i=this.selector(!1))&&s.$char(")")?(e=new Ce.Paren(i),s.forget()):s.restore("Missing closing ')'"):s.forget()),e)return new Ce.Element(t,e,e instanceof Ce.Variable,r,n)},combinator:function(){var e=s.currentChar();if("/"===e){s.save();var t=s.$re(/^\/[a-z]+\//i);if(t)return s.forget(),new Ce.Combinator(t);s.restore()}if(">"===e||"+"===e||"~"===e||"|"===e||"^"===e){for(s.i++,"^"===e&&"^"===s.currentChar()&&(e="^^",s.i++);s.isWhitespace();)s.i++;return new Ce.Combinator(e)}return s.isWhitespace(-1)?new Ce.Combinator(" "):new Ce.Combinator(null)},selector:function(e){var t,i,r,l,u,c,h,f=s.i;for(e=!1!==e;(e&&(i=this.extend())||e&&(c=s.$str("when"))||(l=this.element()))&&(c?h=a(this.conditions,"expected condition"):h?o("CSS guard can only be used at the end of selector"):i?u=u?u.concat(i):i:(u&&o("Extend can only be used at the end of selector"),r=s.currentChar(),t?t.push(l):t=[l],l=null),"{"!==r&&"}"!==r&&";"!==r&&","!==r&&")"!==r););if(t)return new Ce.Selector(t,u,h,f,n);u&&o("Extend must be used to extend a selector, it cannot be used on its own")},selectors:function(){for(var e,t;(e=this.selector())&&(t?t.push(e):t=[e],s.commentStore.length=0,e.condition&&t.length>1&&o("Guards are only currently allowed on a single selector."),s.$char(","));)e.condition&&o("Guards are only currently allowed on a single selector."),s.commentStore.length=0;return t},attribute:function(){if(s.$char("[")){var e,t,i,n=this.entities;return(e=n.variableCurly())||(e=a(/^(?:[_A-Za-z0-9-\*]*\|)?(?:[_A-Za-z0-9-]|\\.)+/)),(i=s.$re(/^[|~*$^]?=/))&&(t=n.quoted()||s.$re(/^[0-9]+%/)||s.$re(/^[\w-]+/)||n.variableCurly()),l("]"),new Ce.Attribute(e,i,t)}},block:function(){var e;if(s.$char("{")&&(e=this.primary())&&s.$char("}"))return e},blockRuleset:function(){var e=this.block();return e&&(e=new Ce.Ruleset(null,e)),e},detachedRuleset:function(){var e,t,i;if(s.save(),!s.$re(/^[.#]\(/)||(t=(e=this.mixin.args(!1)).args,i=e.variadic,s.$char(")"))){var n=this.blockRuleset();if(n)return s.forget(),t?new Ce.mixin.Definition(null,t,n,null,i):new Ce.DetachedRuleset(n);s.restore()}else s.restore()},ruleset:function(){var e,i,n;if(s.save(),t.dumpLineNumbers&&(n=u(s.i)),(e=this.selectors())&&(i=this.block())){s.forget();var r=new Ce.Ruleset(e,i,t.strictImports);return t.dumpLineNumbers&&(r.debugInfo=n),r}s.restore()},declaration:function(){var e,t,i,r,o,a,l=s.i,u=s.currentChar();if("."!==u&&"#"!==u&&"&"!==u&&":"!==u)if(s.save(),e=this.variable()||this.ruleProperty()){if((a="string"==typeof e)&&(t=this.detachedRuleset())&&(i=!0),s.commentStore.length=0,!t){if(o=!a&&e.length>1&&e.pop().value,t=e[0].value&&"--"===e[0].value.slice(0,2)?this.permissiveValue():this.anonymousValue())return s.forget(),new Ce.Declaration(e,t,!1,o,l,n);t||(t=this.value()),t?r=this.important():a&&(t=this.permissiveValue())}if(t&&(this.end()||i))return s.forget(),new Ce.Declaration(e,t,r,o,l,n);s.restore()}else s.restore()},anonymousValue:function(){var e=s.i,t=s.$re(/^([^.#@\$+\/'"*`(;{}-]*);/);if(t)return new Ce.Anonymous(t[1],e)},permissiveValue:function(e){var t,i,r,a,l=e||";",u=s.i,c=[];function h(){var e=s.currentChar();return"string"==typeof l?e===l:l.test(e)}if(!h()){a=[];do{((i=this.comment())||(i=this.entity()))&&a.push(i)}while(i);if(r=h(),a.length>0){if(a=new Ce.Expression(a),r)return a;c.push(a)," "===s.prevChar()&&c.push(new Ce.Anonymous(" ",u))}if(s.save(),a=s.$parseUntil(l)){if("string"==typeof a&&o("Expected '"+a+"'","Parse"),1===a.length&&" "===a[0])return s.forget(),new Ce.Anonymous("",u);var f=void 0;for(t=0;t0)return new Ce.Expression(r)},mediaFeatures:function(){var e,t=this.entities,i=[];do{if(e=this.mediaFeature()){if(i.push(e),!s.$char(","))break}else if((e=t.variable()||t.mixinLookup())&&(i.push(e),!s.$char(",")))break}while(e);return i.length>0?i:null},media:function(){var e,i,r,a,l=s.i;if(t.dumpLineNumbers&&(a=u(l)),s.save(),s.$str("@media"))return e=this.mediaFeatures(),(i=this.block())||o("media definitions require block statements after any features"),s.forget(),r=new Ce.Media(i,e,l,n),t.dumpLineNumbers&&(r.debugInfo=a),r;s.restore()},plugin:function(){var e,t,i,r=s.i;if(s.$re(/^@plugin?\s+/)){if(i=(t=this.pluginArgs())?{pluginArgs:t,isPlugin:!0}:{isPlugin:!0},e=this.entities.quoted()||this.entities.url())return s.$char(";")||(s.i=r,o("missing semi-colon on @plugin")),new Ce.Import(e,null,i,r,n);s.i=r,o("malformed @plugin statement")}},pluginArgs:function(){if(s.save(),!s.$char("("))return s.restore(),null;var e=s.$re(/^\s*([^\);]+)\)\s*/);return e[1]?(s.forget(),e[1].trim()):(s.restore(),null)},atrule:function(){var e,i,r,a,l,c,h,f=s.i,p=!0,v=!0;if("@"===s.currentChar()){if(i=this.import()||this.plugin()||this.media())return i;if(s.save(),e=s.$re(/^@[a-z-]+/)){switch(a=e,"-"==e.charAt(1)&&e.indexOf("-",2)>0&&(a="@"+e.slice(e.indexOf("-",2)+1)),a){case"@charset":l=!0,p=!1;break;case"@namespace":c=!0,p=!1;break;case"@keyframes":case"@counter-style":l=!0;break;case"@document":case"@supports":h=!0,v=!1;break;default:h=!0}if(s.commentStore.length=0,l?(i=this.entity())||o("expected "+e+" identifier"):c?(i=this.expression())||o("expected "+e+" expression"):h&&(i=this.permissiveValue(/^[{;]/),p="{"===s.currentChar(),i?i.value||(i=null):p||";"===s.currentChar()||o(e+" rule is missing block or ending semi-colon")),p&&(r=this.blockRuleset()),r||!p&&i&&s.$char(";"))return s.forget(),new Ce.AtRule(e,i,r,f,n,t.dumpLineNumbers?u(f):null,v);s.restore("at-rule options not recognised")}}},value:function(){var e,t=[],i=s.i;do{if((e=this.expression())&&(t.push(e),!s.$char(",")))break}while(e);if(t.length>0)return new Ce.Value(t,i)},important:function(){if("!"===s.currentChar())return s.$re(/^! *important/)},sub:function(){var e,t;if(s.save(),s.$char("("))return(e=this.addition())&&s.$char(")")?(s.forget(),(t=new Ce.Expression([e])).parens=!0,t):void s.restore("Expected ')'");s.restore()},multiplication:function(){var e,t,i,n,r;if(e=this.operand()){for(r=s.isWhitespace(-1);!s.peek(/^\/[*\/]/);){if(s.save(),!(i=s.$char("/")||s.$char("*")||s.$str("./"))){s.forget();break}if(!(t=this.operand())){s.restore();break}s.forget(),e.parensInOp=!0,t.parensInOp=!0,n=new Ce.Operation(i,[n||e,t],r),r=s.isWhitespace(-1)}return n||e}},addition:function(){var e,t,i,n,r;if(e=this.multiplication()){for(r=s.isWhitespace(-1);(i=s.$re(/^[-+]\s+/)||!r&&(s.$char("+")||s.$char("-")))&&(t=this.multiplication());)e.parensInOp=!0,t.parensInOp=!0,n=new Ce.Operation(i,[n||e,t],r),r=s.isWhitespace(-1);return n||e}},conditions:function(){var e,t,i,n=s.i;if(e=this.condition(!0)){for(;s.peek(/^,\s*(not\s*)?\(/)&&s.$char(",")&&(t=this.condition(!0));)i=new Ce.Condition("or",i||e,t,n);return i||e}},condition:function(e){var t,i,n;if(t=this.conditionAnd(e)){if(i=s.$str("or")){if(!(n=this.condition(e)))return;t=new Ce.Condition(i,t,n)}return t}},conditionAnd:function(e){var t,i,n,r,o=this;if(t=(r=o.negatedCondition(e)||o.parenthesisCondition(e))||e?r:o.atomicCondition(e)){if(i=s.$str("and")){if(!(n=this.conditionAnd(e)))return;t=new Ce.Condition(i,t,n)}return t}},negatedCondition:function(e){if(s.$str("not")){var t=this.parenthesisCondition(e);return t&&(t.negate=!t.negate),t}},parenthesisCondition:function(e){var t;if(s.save(),s.$str("(")){if(t=function(t){var i;if(s.save(),i=t.condition(e)){if(s.$char(")"))return s.forget(),i;s.restore()}else s.restore()}(this))return s.forget(),t;if(t=this.atomicCondition(e)){if(s.$char(")"))return s.forget(),t;s.restore("expected ')' got '"+s.currentChar()+"'")}else s.restore()}else s.restore()},atomicCondition:function(e){var t,i,n,r,a=this.entities,l=s.i;function u(){return this.addition()||a.keyword()||a.quoted()||a.mixinLookup()}if(t=(u=u.bind(this))())return s.$char(">")?r=s.$char("=")?">=":">":s.$char("<")?r=s.$char("=")?"<=":"<":s.$char("=")&&(r=s.$char(">")?"=>":s.$char("<")?"=<":"="),r?(i=u())?n=new Ce.Condition(r,t,i,l,!1):o("expected expression"):n=new Ce.Condition("=",t,new Ce.Keyword("true"),l,!1),n},operand:function(){var e,t=this.entities;s.peek(/^-[@\$\(]/)&&(e=s.$char("-"));var i=this.sub()||t.dimension()||t.color()||t.variable()||t.property()||t.call()||t.quoted(!0)||t.colorKeyword()||t.mixinLookup();return e&&(i.parensInOp=!0,i=new Ce.Negative(i)),i},expression:function(){var e,t,i=[],n=s.i;do{(e=this.comment())?i.push(e):((e=this.addition()||this.entity())instanceof Ce.Comment&&(e=null),e&&(i.push(e),s.peek(/^\/[\/*]/)||(t=s.$char("/"))&&i.push(new Ce.Anonymous(t,n))))}while(e);if(i.length>0)return new Ce.Expression(i)},property:function(){var e=s.$re(/^(\*?-?[_a-zA-Z0-9-]+)\s*:/);if(e)return e[1]},ruleProperty:function(){var e,t,i=[],r=[];s.save();var o=s.$re(/^([_a-zA-Z0-9-]+)\s*:/);if(o)return i=[new Ce.Keyword(o[1])],s.forget(),i;function a(e){var t=s.i,n=s.$re(e);if(n)return r.push(t),i.push(n[1])}for(a(/^(\*?)/);a(/^((?:[\w-]+)|(?:[@\$]\{[\w-]+\}))/););if(i.length>1&&a(/^((?:\+_|\+)?)\s*:/)){for(s.forget(),""===i[0]&&(i.shift(),r.shift()),t=0;t1?e-1:e)<1?r+(s-r)*e*6:2*e<1?s:3*e<2?r+(s-r)*(2/3-e)*6:r}e=Ke(e)%360/360,t=We(Ke(t)),i=We(Ke(i)),n=We(Ke(n)),r=2*i-(s=i<=.5?i*(t+1):i+t-i*t);var a=[255*o(e+1/3),255*o(e),255*o(e-1/3)];return n=Ke(n),new c(a,n,"hsla")}catch(e){}},hsv:function(e,t,i){return ze.hsva(e,t,i,1)},hsva:function(e,t,i,n){var r,s;e=Ke(e)%360/360*360,t=Ke(t),i=Ke(i),n=Ke(n);var o=[i,i*(1-t),i*(1-(s=e/60-(r=Math.floor(e/60%6)))*t),i*(1-(1-s)*t)],a=[[0,3,1],[2,0,1],[1,0,3],[1,2,0],[3,1,0],[0,1,2]];return ze.rgba(255*o[a[r][0]],255*o[a[r][1]],255*o[a[r][2]],n)},hue:function(e){return new ee(He(e).h)},saturation:function(e){return new ee(100*He(e).s,"%")},lightness:function(e){return new ee(100*He(e).l,"%")},hsvhue:function(e){return new ee(Qe(e).h)},hsvsaturation:function(e){return new ee(100*Qe(e).s,"%")},hsvvalue:function(e){return new ee(100*Qe(e).v,"%")},red:function(e){return new ee(e.rgb[0])},green:function(e){return new ee(e.rgb[1])},blue:function(e){return new ee(e.rgb[2])},alpha:function(e){return new ee(He(e).a)},luma:function(e){return new ee(e.luma()*e.alpha*100,"%")},luminance:function(e){var t=.2126*e.rgb[0]/255+.7152*e.rgb[1]/255+.0722*e.rgb[2]/255;return new ee(t*e.alpha*100,"%")},saturate:function(e,t,i){if(!e.rgb)return null;var n=He(e);return void 0!==i&&"relative"===i.value?n.s+=n.s*t.value/100:n.s+=t.value/100,n.s=We(n.s),Je(e,n)},desaturate:function(e,t,i){var n=He(e);return void 0!==i&&"relative"===i.value?n.s-=n.s*t.value/100:n.s-=t.value/100,n.s=We(n.s),Je(e,n)},lighten:function(e,t,i){var n=He(e);return void 0!==i&&"relative"===i.value?n.l+=n.l*t.value/100:n.l+=t.value/100,n.l=We(n.l),Je(e,n)},darken:function(e,t,i){var n=He(e);return void 0!==i&&"relative"===i.value?n.l-=n.l*t.value/100:n.l-=t.value/100,n.l=We(n.l),Je(e,n)},fadein:function(e,t,i){var n=He(e);return void 0!==i&&"relative"===i.value?n.a+=n.a*t.value/100:n.a+=t.value/100,n.a=We(n.a),Je(e,n)},fadeout:function(e,t,i){var n=He(e);return void 0!==i&&"relative"===i.value?n.a-=n.a*t.value/100:n.a-=t.value/100,n.a=We(n.a),Je(e,n)},fade:function(e,t){var i=He(e);return i.a=t.value/100,i.a=We(i.a),Je(e,i)},spin:function(e,t){var i=He(e),n=(i.h+t.value)%360;return i.h=n<0?360+n:n,Je(e,i)},mix:function(e,t,i){i||(i=new ee(50));var n=i.value/100,r=2*n-1,s=He(e).a-He(t).a,o=((r*s==-1?r:(r+s)/(1+r*s))+1)/2,a=1-o,l=[e.rgb[0]*o+t.rgb[0]*a,e.rgb[1]*o+t.rgb[1]*a,e.rgb[2]*o+t.rgb[2]*a],u=e.alpha*n+t.alpha*(1-n);return new c(l,u)},greyscale:function(e){return ze.desaturate(e,new ee(100))},contrast:function(e,t,i,n){if(!e.rgb)return null;if(void 0===i&&(i=ze.rgba(255,255,255,1)),void 0===t&&(t=ze.rgba(0,0,0,1)),t.luma()>i.luma()){var r=i;i=t,t=r}return n=void 0===n?.43:Ke(n),e.luma().5&&(n=1,i=e>.25?Math.sqrt(e):((16*e-12)*e+4)*e),e-(1-2*t)*n*(i-e)},hardlight:function(e,t){return Ye.overlay(t,e)},difference:function(e,t){return Math.abs(e-t)},exclusion:function(e,t){return e+t-2*e*t},average:function(e,t){return(e+t)/2},negation:function(e,t){return 1-Math.abs(e+t-1)}};for(var et in Ye)Ye.hasOwnProperty(et)&&(Xe[et]=Xe.bind(null,Ye[et]));var tt=function(e){return Array.isArray(e.value)?e.value:Array(e)},it={_SELF:function(e){return e},"~":function(){for(var e=[],t=0;to.value)&&(c[n]=r);else{if(void 0!==l&&a!==l)throw{type:"Argument",message:"incompatible types"};h[a]=c.length,c.push(r)}else Array.isArray(t[i].value)&&Array.prototype.push.apply(t,Array.prototype.slice.call(t[i].value));return 1==c.length?c[0]:(t=c.map((function(e){return e.toCSS(this.context)})).join(this.context.compress?",":", "),new j((e?"min":"max")+"("+t+")"))},at={min:function(){for(var e=[],t=0;t",r=0;r";return n+="',n=encodeURIComponent(n),new ce(new ue("'"+(n="data:image/svg+xml,"+n)+"'",n,!1,this.index,this.currentFileInfo),this.index,this.currentFileInfo)}}),H.addMultiple(ht),t};function pt(e,t){var i,n=(t=t||{}).variables,r=new q.Eval(t);"object"!=typeof n||Array.isArray(n)||(n=Object.keys(n).map((function(e){var t=n[e];return t instanceof Ce.Value||(t instanceof Ce.Expression||(t=new Ce.Expression([t])),t=new Ce.Value([t])),new Ce.Declaration("@"+e,t,!1,null,0)})),r.frames=[new Ce.Ruleset(null,n)]);var s,o,a=[new De.JoinSelectorVisitor,new De.MarkVisibleSelectorsVisitor(!0),new De.ExtendVisitor,new De.ToCSSVisitor({compress:Boolean(t.compress)})],l=[];if(t.pluginManager){o=t.pluginManager.visitor();for(var u=0;u<2;u++)for(o.first();s=o.get();)s.isPreEvalVisitor?0!==u&&-1!==l.indexOf(s)||(l.push(s),s.run(e)):0!==u&&-1!==a.indexOf(s)||(s.isPreVisitor?a.unshift(s):a.push(s))}i=e.eval(r);for(u=0;u=t);i++);this.preProcessors.splice(i,0,{preProcessor:e,priority:t})},e.prototype.addPostProcessor=function(e,t){var i;for(i=0;i=t);i++);this.postProcessors.splice(i,0,{postProcessor:e,priority:t})},e.prototype.addFileManager=function(e){this.fileManagers.push(e)},e.prototype.getPreProcessors=function(){for(var e=[],t=0;t0){var n=void 0,r=JSON.stringify(this._sourceMapGenerator.toJSON());this.sourceMapURL?n=this.sourceMapURL:this._sourceMapFilename&&(n=this._sourceMapFilename),this.sourceMapURL=n,this.sourceMap=r}return this._css.join("")},t}()}(e=new s(e,t)),e)),a=function(e){return function(){function t(e,t,i){this.less=e,this.rootFilename=i.filename,this.paths=t.paths||[],this.contents={},this.contentsIgnoredChars={},this.mime=t.mime,this.error=null,this.context=t,this.queue=[],this.files={}}return t.prototype.push=function(t,i,n,s,o){var a=this,l=this.context.pluginManager.Loader;this.queue.push(t);var u=function(e,i,n){a.queue.splice(a.queue.indexOf(t),1);var l=n===a.rootFilename;s.optional&&e?(o(null,{rules:[]},!1,null),r.info("The file "+n+" was skipped because it was not found and the import was marked optional.")):(a.files[n]||s.inline||(a.files[n]={root:i,options:s}),e&&!a.error&&(a.error=e),o(e,i,l,n))},c={rewriteUrls:this.context.rewriteUrls,entryPath:n.entryPath,rootpath:n.rootpath,rootFilename:n.rootFilename},h=e.getFileManager(t,n.currentDirectory,this.context,e);if(h){var f,p,v=function(e){var t,i=e.filename,r=e.contents.replace(/^\uFEFF/,"");c.currentDirectory=h.getPath(i),c.rewriteUrls&&(c.rootpath=h.join(a.context.rootpath||"",h.pathDiff(c.currentDirectory,c.entryPath)),!h.isPathAbsolute(c.rootpath)&&h.alwaysMakePathsAbsolute()&&(c.rootpath=h.join(c.entryPath,c.rootpath))),c.filename=i;var o=new q.Parse(a.context);o.processImports=!1,a.contents[i]=r,(n.reference||s.reference)&&(c.reference=!0),s.isPlugin?(t=l.evalPlugin(r,o,a,s.pluginArgs,c))instanceof O?u(t,null,i):u(null,t,i):s.inline?u(null,r,i):!a.files[i]||a.files[i].options.multiple||s.multiple?new Be(o,a,c).parse(r,(function(e,t){u(e,t,i)})):u(null,a.files[i].root,i)},d=_(this.context);i&&(d.ext=s.isPlugin?".js":".less"),s.isPlugin?(d.mime="application/javascript",d.syncImport?f=l.loadPluginSync(t,n.currentDirectory,d,e,h):p=l.loadPlugin(t,n.currentDirectory,d,e,h)):d.syncImport?f=h.loadFileSync(t,n.currentDirectory,d,e):p=h.loadFile(t,n.currentDirectory,d,e,(function(e,t){e?u(e):v(t)})),f?f.filename?v(f):u(f):p&&p.then(v,u)}else u({message:"Could not find a file-manager for "+t})},t}()}(e);var u,c=function(e,t,i){var n=function(e,i,r){if("function"==typeof i?(r=i,i=M(this.options,{})):i=M(this.options,i||{}),!r){var s=this;return new Promise((function(t,r){n.call(s,e,i,(function(e,i){e?r(e):t(i)}))}))}this.parse(e,i,(function(e,i,n,s){if(e)return r(e);var o;try{o=new t(i,n).toCSS(s)}catch(e){return r(e)}r(null,o)}))};return n}(0,o),h=function(e,t,i){var n=function(e,t,r){if("function"==typeof t?(r=t,t=M(this.options,{})):t=M(this.options,t||{}),!r){var s=this;return new Promise((function(i,r){n.call(s,e,t,(function(e,t){e?r(e):i(t)}))}))}var o,a=void 0,l=new mt(this,!t.reUsePluginManager);if(t.pluginManager=l,o=new q.Parse(t),t.rootFileInfo)a=t.rootFileInfo;else{var u=t.filename||"input",c=u.replace(/[^\/\\]*$/,"");(a={filename:u,rewriteUrls:o.rewriteUrls,rootpath:o.rootpath||"",currentDirectory:c,entryPath:c,rootFilename:u}).rootpath&&"/"!==a.rootpath.slice(-1)&&(a.rootpath+="/")}var h=new i(this,o,a);this.importManager=h,t.plugins&&t.plugins.forEach((function(e){var t,i;if(e.fileContent){if(i=e.fileContent.replace(/^\uFEFF/,""),(t=l.Loader.evalPlugin(i,o,h,e.options,e.filename))instanceof O)return r(t)}else l.addPlugin(e)})),new Be(o,h,a).parse(e,(function(e,i){if(e)return r(e);r(null,i,h,t)}),t)};return n}(0,0,a),f=bt("4.0.0"),p={version:[f.major,f.minor,f.patch],data:l,tree:Ce,Environment:s,AbstractFileManager:ke,AbstractPluginLoader:_e,environment:e,visitors:De,Parser:Be,functions:ft(e),contexts:q,SourceMapOutput:i,SourceMapBuilder:n,ParseTree:o,ImportManager:a,render:c,parse:h,LessError:O,transformTree:pt,utils:P,PluginManager:mt,logger:r},v=function(e){return function(){var t=Object.create(e.prototype);return e.apply(t,Array.prototype.slice.call(arguments,0)),t}},d=Object.create(p);for(var m in p.tree)if("function"==typeof(u=p.tree[m]))d[m.toLowerCase()]=v(u);else for(var g in d[m]=Object.create(null),u)d[m][g.toLowerCase()]=v(u[g]);return p.parse=p.parse.bind(d),p.render=p.render.bind(d),d}var xt={},St=function(){};St.prototype=Object.assign(new ke,{alwaysMakePathsAbsolute:function(){return!0},join:function(e,t){return e?this.extractUrlParts(t,e).path:t},doXHR:function(e,t,i,n){var r=new XMLHttpRequest,s=!gt.isFileProtocol||gt.fileAsync;function o(t,i,n){t.status>=200&&t.status<300?i(t.responseText,t.getResponseHeader("Last-Modified")):"function"==typeof n&&n(t.status,e)}"function"==typeof r.overrideMimeType&&r.overrideMimeType("text/css"),yt.debug("XHR: Getting '"+e+"'"),r.open("GET",e,s),r.setRequestHeader("Accept",t||"text/x-less, text/css; q=0.9, */*; q=0.5"),r.send(null),gt.isFileProtocol&&!gt.fileAsync?0===r.status||r.status>=200&&r.status<300?i(r.responseText):n(r.status,e):s?r.onreadystatechange=function(){4==r.readyState&&o(r,i,n)}:o(r,i,n)},supports:function(){return!0},clearFileCache:function(){xt={}},loadFile:function(e,t,i,n){t&&!this.isPathAbsolute(e)&&(e=t+e),e=i.ext?this.tryAppendExtension(e,i.ext):e,i=i||{};var r=this.extractUrlParts(e,window.location.href).url,s=this;return new Promise((function(e,t){if(i.useFileCache&&xt[r])try{var n=xt[r];return e({contents:n,filename:r,webInfo:{lastModified:new Date}})}catch(e){return t({filename:r,message:"Error loading file "+r+" error was "+e.message})}s.doXHR(r,i.mime,(function(t,i){xt[r]=t,e({contents:t,filename:r,webInfo:{lastModified:i}})}),(function(e,i){t({type:"File",message:"'"+i+"' wasn't found ("+e+")",href:r})}))}))}});var It=function(e,t){return gt=e,yt=t,St},Ct=function(e){this.less=e};Ct.prototype=Object.assign(new _e,{loadPlugin:function(e,t,i,n,r){return new Promise((function(s,o){r.loadFile(e,t,i,n).then(s).catch(o)}))}});var kt=function(t,n,r){return{add:function(s,o){r.errorReporting&&"html"!==r.errorReporting?"console"===r.errorReporting?function(e,t){var i=e.filename||t,s=[],o=(e.type||"Syntax")+"Error: "+(e.message||"There is an error in your .less file")+" in "+i,a=function(e,t,i){void 0!==e.extract[t]&&s.push("{line} {content}".replace(/\{line\}/,(parseInt(e.line,10)||0)+(t-1)).replace(/\{class\}/,i).replace(/\{content\}/,e.extract[t]))};e.line&&(a(e,0,""),a(e,1,"line"),a(e,2,""),o+=" on line "+e.line+", column "+(e.column+1)+":\n"+s.join("\n")),e.stack&&(e.extract||r.logLevel>=4)&&(o+="\nStack Trace\n"+e.stack),n.logger.error(o)}(s,o):"function"==typeof r.errorReporting&&r.errorReporting("add",s,o):function(n,s){var o,a,l="less-error-message:"+e(s||""),u=t.document.createElement("div"),c=[],h=n.filename||s,f=h.match(/([^\/]+(\?.*)?)$/)[1];u.id=l,u.className="less-error-message",a="

    "+(n.type||"Syntax")+"Error: "+(n.message||"There is an error in your .less file")+'

    in '+f+" ";var p=function(e,t,i){void 0!==e.extract[t]&&c.push('

  • {content}
  • '.replace(/\{line\}/,(parseInt(e.line,10)||0)+(t-1)).replace(/\{class\}/,i).replace(/\{content\}/,e.extract[t]))};n.line&&(p(n,0,""),p(n,1,"line"),p(n,2,""),a+="on line "+n.line+", column "+(n.column+1)+":

      "+c.join("")+"
    "),n.stack&&(n.extract||r.logLevel>=4)&&(a+="
    Stack Trace
    "+n.stack.split("\n").slice(1).join("
    ")),u.innerHTML=a,i(t.document,[".less-error-message ul, .less-error-message li {","list-style-type: none;","margin-right: 15px;","padding: 4px 0;","margin: 0;","}",".less-error-message label {","font-size: 12px;","margin-right: 15px;","padding: 4px 0;","color: #cc7777;","}",".less-error-message pre {","color: #dd6666;","padding: 4px 0;","margin: 0;","display: inline-block;","}",".less-error-message pre.line {","color: #ff0000;","}",".less-error-message h3 {","font-size: 20px;","font-weight: bold;","padding: 15px 0 5px 0;","margin: 0;","}",".less-error-message a {","color: #10a","}",".less-error-message .error {","color: red;","font-weight: bold;","padding-bottom: 2px;","border-bottom: 1px dashed red;","}"].join("\n"),{title:"error-message"}),u.style.cssText=["font-family: Arial, sans-serif","border: 1px solid #e00","background-color: #eee","border-radius: 5px","-webkit-border-radius: 5px","-moz-border-radius: 5px","color: #e00","padding: 15px","margin-bottom: 15px"].join(";"),"development"===r.env&&(o=setInterval((function(){var e=t.document,i=e.body;i&&(e.getElementById(l)?i.replaceChild(u,e.getElementById(l)):i.insertBefore(u,i.firstChild),clearInterval(o))}),10))}(s,o)},remove:function(i){r.errorReporting&&"html"!==r.errorReporting?"console"===r.errorReporting||"function"==typeof r.errorReporting&&r.errorReporting("remove",i):function(i){var n=t.document.getElementById("less-error-message:"+e(i));n&&n.parentNode.removeChild(n)}(i)}}},_t={javascriptEnabled:!1,depends:!1,compress:!1,lint:!1,paths:[],color:!0,strictImports:!1,insecure:!1,rootpath:"",rewriteUrls:!1,math:1,strictUnits:!1,globalVars:null,modifyVars:null,urlArgs:""};if(window.less)for(var At in window.less)window.less.hasOwnProperty(At)&&(_t[At]=window.less[At]);!function(e,i){t(i,n(e)),void 0===i.isFileProtocol&&(i.isFileProtocol=/^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(e.location.protocol)),i.async=i.async||!1,i.fileAsync=i.fileAsync||!1,i.poll=i.poll||(i.isFileProtocol?1e3:1500),i.env=i.env||("127.0.0.1"==e.location.hostname||"0.0.0.0"==e.location.hostname||"localhost"==e.location.hostname||e.location.port&&e.location.port.length>0||i.isFileProtocol?"development":"production");var r=/!dumpLineNumbers:(comments|mediaquery|all)/.exec(e.location.hash);r&&(i.dumpLineNumbers=r[1]),void 0===i.useFileCache&&(i.useFileCache=!0),void 0===i.onReady&&(i.onReady=!0),i.relativeUrls&&(i.rewriteUrls="all")}(window,_t),_t.plugins=_t.plugins||[],window.LESS_PLUGINS&&(_t.plugins=_t.plugins.concat(window.LESS_PLUGINS));var Mt,Et,Pt,Rt=function(e,n){var r=e.document,s=wt();s.options=n;var o=s.environment,a=It(n,s.logger),l=new a;o.addFileManager(l),s.FileManager=a,s.PluginLoader=Ct,function(e,t){t.logLevel=void 0!==t.logLevel?t.logLevel:"development"===t.env?3:1,t.loggers||(t.loggers=[{debug:function(e){t.logLevel>=4&&console.log(e)},info:function(e){t.logLevel>=3&&console.log(e)},warn:function(e){t.logLevel>=2&&console.warn(e)},error:function(e){t.logLevel>=1&&console.error(e)}}]);for(var i=0;i 0 && styleNode.childNodes.length > 0 &&\n oldStyleNode.firstChild.nodeValue === styleNode.firstChild.nodeValue);\n }\n\n const head = document.getElementsByTagName('head')[0];\n\n // If there is no oldStyleNode, just append; otherwise, only append if we need\n // to replace oldStyleNode with an updated stylesheet\n if (oldStyleNode === null || keepOldStyleNode === false) {\n const nextEl = sheet && sheet.nextSibling || null;\n if (nextEl) {\n nextEl.parentNode.insertBefore(styleNode, nextEl);\n } else {\n head.appendChild(styleNode);\n }\n }\n if (oldStyleNode && keepOldStyleNode === false) {\n oldStyleNode.parentNode.removeChild(oldStyleNode);\n }\n\n // For IE.\n // This needs to happen *after* the style element is added to the DOM, otherwise IE 7 and 8 may crash.\n // See http://social.msdn.microsoft.com/Forums/en-US/7e081b65-878a-4c22-8e68-c10d39c2ed32/internet-explorer-crashes-appending-style-element-to-head\n if (styleNode.styleSheet) {\n try {\n styleNode.styleSheet.cssText = styles;\n } catch (e) {\n throw new Error('Couldn\\'t reassign styleSheet.cssText.');\n }\n }\n },\n currentScript: function(window) {\n const document = window.document;\n return document.currentScript || (() => {\n const scripts = document.getElementsByTagName('script');\n return scripts[scripts.length - 1];\n })();\n }\n};\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport function __createBinding(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n result.default = mod;\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to get private field on non-instance\");\r\n }\r\n return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to set private field on non-instance\");\r\n }\r\n privateMap.set(receiver, value);\r\n return value;\r\n}\r\n","export default {\n 'aliceblue':'#f0f8ff',\n 'antiquewhite':'#faebd7',\n 'aqua':'#00ffff',\n 'aquamarine':'#7fffd4',\n 'azure':'#f0ffff',\n 'beige':'#f5f5dc',\n 'bisque':'#ffe4c4',\n 'black':'#000000',\n 'blanchedalmond':'#ffebcd',\n 'blue':'#0000ff',\n 'blueviolet':'#8a2be2',\n 'brown':'#a52a2a',\n 'burlywood':'#deb887',\n 'cadetblue':'#5f9ea0',\n 'chartreuse':'#7fff00',\n 'chocolate':'#d2691e',\n 'coral':'#ff7f50',\n 'cornflowerblue':'#6495ed',\n 'cornsilk':'#fff8dc',\n 'crimson':'#dc143c',\n 'cyan':'#00ffff',\n 'darkblue':'#00008b',\n 'darkcyan':'#008b8b',\n 'darkgoldenrod':'#b8860b',\n 'darkgray':'#a9a9a9',\n 'darkgrey':'#a9a9a9',\n 'darkgreen':'#006400',\n 'darkkhaki':'#bdb76b',\n 'darkmagenta':'#8b008b',\n 'darkolivegreen':'#556b2f',\n 'darkorange':'#ff8c00',\n 'darkorchid':'#9932cc',\n 'darkred':'#8b0000',\n 'darksalmon':'#e9967a',\n 'darkseagreen':'#8fbc8f',\n 'darkslateblue':'#483d8b',\n 'darkslategray':'#2f4f4f',\n 'darkslategrey':'#2f4f4f',\n 'darkturquoise':'#00ced1',\n 'darkviolet':'#9400d3',\n 'deeppink':'#ff1493',\n 'deepskyblue':'#00bfff',\n 'dimgray':'#696969',\n 'dimgrey':'#696969',\n 'dodgerblue':'#1e90ff',\n 'firebrick':'#b22222',\n 'floralwhite':'#fffaf0',\n 'forestgreen':'#228b22',\n 'fuchsia':'#ff00ff',\n 'gainsboro':'#dcdcdc',\n 'ghostwhite':'#f8f8ff',\n 'gold':'#ffd700',\n 'goldenrod':'#daa520',\n 'gray':'#808080',\n 'grey':'#808080',\n 'green':'#008000',\n 'greenyellow':'#adff2f',\n 'honeydew':'#f0fff0',\n 'hotpink':'#ff69b4',\n 'indianred':'#cd5c5c',\n 'indigo':'#4b0082',\n 'ivory':'#fffff0',\n 'khaki':'#f0e68c',\n 'lavender':'#e6e6fa',\n 'lavenderblush':'#fff0f5',\n 'lawngreen':'#7cfc00',\n 'lemonchiffon':'#fffacd',\n 'lightblue':'#add8e6',\n 'lightcoral':'#f08080',\n 'lightcyan':'#e0ffff',\n 'lightgoldenrodyellow':'#fafad2',\n 'lightgray':'#d3d3d3',\n 'lightgrey':'#d3d3d3',\n 'lightgreen':'#90ee90',\n 'lightpink':'#ffb6c1',\n 'lightsalmon':'#ffa07a',\n 'lightseagreen':'#20b2aa',\n 'lightskyblue':'#87cefa',\n 'lightslategray':'#778899',\n 'lightslategrey':'#778899',\n 'lightsteelblue':'#b0c4de',\n 'lightyellow':'#ffffe0',\n 'lime':'#00ff00',\n 'limegreen':'#32cd32',\n 'linen':'#faf0e6',\n 'magenta':'#ff00ff',\n 'maroon':'#800000',\n 'mediumaquamarine':'#66cdaa',\n 'mediumblue':'#0000cd',\n 'mediumorchid':'#ba55d3',\n 'mediumpurple':'#9370d8',\n 'mediumseagreen':'#3cb371',\n 'mediumslateblue':'#7b68ee',\n 'mediumspringgreen':'#00fa9a',\n 'mediumturquoise':'#48d1cc',\n 'mediumvioletred':'#c71585',\n 'midnightblue':'#191970',\n 'mintcream':'#f5fffa',\n 'mistyrose':'#ffe4e1',\n 'moccasin':'#ffe4b5',\n 'navajowhite':'#ffdead',\n 'navy':'#000080',\n 'oldlace':'#fdf5e6',\n 'olive':'#808000',\n 'olivedrab':'#6b8e23',\n 'orange':'#ffa500',\n 'orangered':'#ff4500',\n 'orchid':'#da70d6',\n 'palegoldenrod':'#eee8aa',\n 'palegreen':'#98fb98',\n 'paleturquoise':'#afeeee',\n 'palevioletred':'#d87093',\n 'papayawhip':'#ffefd5',\n 'peachpuff':'#ffdab9',\n 'peru':'#cd853f',\n 'pink':'#ffc0cb',\n 'plum':'#dda0dd',\n 'powderblue':'#b0e0e6',\n 'purple':'#800080',\n 'rebeccapurple':'#663399',\n 'red':'#ff0000',\n 'rosybrown':'#bc8f8f',\n 'royalblue':'#4169e1',\n 'saddlebrown':'#8b4513',\n 'salmon':'#fa8072',\n 'sandybrown':'#f4a460',\n 'seagreen':'#2e8b57',\n 'seashell':'#fff5ee',\n 'sienna':'#a0522d',\n 'silver':'#c0c0c0',\n 'skyblue':'#87ceeb',\n 'slateblue':'#6a5acd',\n 'slategray':'#708090',\n 'slategrey':'#708090',\n 'snow':'#fffafa',\n 'springgreen':'#00ff7f',\n 'steelblue':'#4682b4',\n 'tan':'#d2b48c',\n 'teal':'#008080',\n 'thistle':'#d8bfd8',\n 'tomato':'#ff6347',\n 'turquoise':'#40e0d0',\n 'violet':'#ee82ee',\n 'wheat':'#f5deb3',\n 'white':'#ffffff',\n 'whitesmoke':'#f5f5f5',\n 'yellow':'#ffff00',\n 'yellowgreen':'#9acd32'\n};","export default {\n length: {\n 'm': 1,\n 'cm': 0.01,\n 'mm': 0.001,\n 'in': 0.0254,\n 'px': 0.0254 / 96,\n 'pt': 0.0254 / 72,\n 'pc': 0.0254 / 72 * 12\n },\n duration: {\n 's': 1,\n 'ms': 0.001\n },\n angle: {\n 'rad': 1 / (2 * Math.PI),\n 'deg': 1 / 360,\n 'grad': 1 / 400,\n 'turn': 1\n }\n};","import colors from './colors';\nimport unitConversions from './unit-conversions';\n\nexport default { colors, unitConversions };\n","/**\n * The reason why Node is a class and other nodes simply do not extend\n * from Node (since we're transpiling) is due to this issue:\n * \n * https://github.com/less/less.js/issues/3434\n */\nclass Node {\n constructor() {\n this.parent = null;\n this.visibilityBlocks = undefined;\n this.nodeVisible = undefined;\n this.rootNode = null;\n this.parsed = null;\n\n const self = this;\n Object.defineProperty(this, 'currentFileInfo', {\n get: function() { return self.fileInfo(); }\n });\n Object.defineProperty(this, 'index', {\n get: function() { return self.getIndex(); }\n });\n\n }\n\n setParent(nodes, parent) {\n function set(node) {\n if (node && node instanceof Node) {\n node.parent = parent;\n }\n }\n if (Array.isArray(nodes)) {\n nodes.forEach(set);\n }\n else {\n set(nodes);\n }\n }\n\n getIndex() {\n return this._index || (this.parent && this.parent.getIndex()) || 0;\n }\n\n fileInfo() {\n return this._fileInfo || (this.parent && this.parent.fileInfo()) || {};\n }\n\n isRulesetLike() {\n return false;\n }\n\n toCSS(context) {\n const strs = [];\n this.genCSS(context, {\n add: function(chunk, fileInfo, index) {\n strs.push(chunk);\n },\n isEmpty: function () {\n return strs.length === 0;\n }\n });\n return strs.join('');\n }\n\n genCSS(context, output) {\n output.add(this.value);\n }\n\n accept(visitor) {\n this.value = visitor.visit(this.value);\n }\n\n eval() { return this; }\n\n _operate(context, op, a, b) {\n switch (op) {\n case '+': return a + b;\n case '-': return a - b;\n case '*': return a * b;\n case '/': return a / b;\n }\n }\n\n fround(context, value) {\n const precision = context && context.numPrecision;\n // add \"epsilon\" to ensure numbers like 1.000000005 (represented as 1.000000004999...) are properly rounded:\n return (precision) ? Number((value + 2e-16).toFixed(precision)) : value;\n }\n\n // Returns true if this node represents root of ast imported by reference\n blocksVisibility() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n return this.visibilityBlocks !== 0;\n }\n\n addVisibilityBlock() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n this.visibilityBlocks = this.visibilityBlocks + 1;\n }\n\n removeVisibilityBlock() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n this.visibilityBlocks = this.visibilityBlocks - 1;\n }\n\n // Turns on node visibility - if called node will be shown in output regardless\n // of whether it comes from import by reference or not\n ensureVisibility() {\n this.nodeVisible = true;\n }\n\n // Turns off node visibility - if called node will NOT be shown in output regardless\n // of whether it comes from import by reference or not\n ensureInvisibility() {\n this.nodeVisible = false;\n }\n\n // return values:\n // false - the node must not be visible\n // true - the node must be visible\n // undefined or null - the node has the same visibility as its parent\n isVisible() {\n return this.nodeVisible;\n }\n\n visibilityInfo() {\n return {\n visibilityBlocks: this.visibilityBlocks,\n nodeVisible: this.nodeVisible\n };\n }\n\n copyVisibilityInfo(info) {\n if (!info) {\n return;\n }\n this.visibilityBlocks = info.visibilityBlocks;\n this.nodeVisible = info.nodeVisible;\n }\n}\n\nNode.compare = (a, b) => {\n /* returns:\n -1: a < b\n 0: a = b\n 1: a > b\n and *any* other value for a != b (e.g. undefined, NaN, -2 etc.) */\n\n if ((a.compare) &&\n // for \"symmetric results\" force toCSS-based comparison\n // of Quoted or Anonymous if either value is one of those\n !(b.type === 'Quoted' || b.type === 'Anonymous')) {\n return a.compare(b);\n } else if (b.compare) {\n return -b.compare(a);\n } else if (a.type !== b.type) {\n return undefined;\n }\n\n a = a.value;\n b = b.value;\n if (!Array.isArray(a)) {\n return a === b ? 0 : undefined;\n }\n if (a.length !== b.length) {\n return undefined;\n }\n for (let i = 0; i < a.length; i++) {\n if (Node.compare(a[i], b[i]) !== 0) {\n return undefined;\n }\n }\n return 0;\n};\n\nNode.numericCompare = (a, b) => a < b ? -1\n : a === b ? 0\n : a > b ? 1 : undefined;\nexport default Node;\n","import Node from './node';\nimport colors from '../data/colors';\n\n//\n// RGB Colors - #ff0014, #eee\n//\nconst Color = function(rgb, a, originalForm) {\n const self = this;\n //\n // The end goal here, is to parse the arguments\n // into an integer triplet, such as `128, 255, 0`\n //\n // This facilitates operations and conversions.\n //\n if (Array.isArray(rgb)) {\n this.rgb = rgb;\n } else if (rgb.length >= 6) {\n this.rgb = [];\n rgb.match(/.{2}/g).map((c, i) => {\n if (i < 3) {\n self.rgb.push(parseInt(c, 16));\n } else {\n self.alpha = (parseInt(c, 16)) / 255;\n }\n });\n } else {\n this.rgb = [];\n rgb.split('').map((c, i) => {\n if (i < 3) {\n self.rgb.push(parseInt(c + c, 16));\n } else {\n self.alpha = (parseInt(c + c, 16)) / 255;\n }\n });\n }\n this.alpha = this.alpha || (typeof a === 'number' ? a : 1);\n if (typeof originalForm !== 'undefined') {\n this.value = originalForm;\n }\n};\n\nColor.prototype = new Node();\n\nColor.prototype.luma = function() {\n let r = this.rgb[0] / 255;\n let g = this.rgb[1] / 255;\n let b = this.rgb[2] / 255;\n\n r = (r <= 0.03928) ? r / 12.92 : Math.pow(((r + 0.055) / 1.055), 2.4);\n g = (g <= 0.03928) ? g / 12.92 : Math.pow(((g + 0.055) / 1.055), 2.4);\n b = (b <= 0.03928) ? b / 12.92 : Math.pow(((b + 0.055) / 1.055), 2.4);\n\n return 0.2126 * r + 0.7152 * g + 0.0722 * b;\n};\n\nColor.prototype.genCSS = function(context, output) {\n output.add(this.toCSS(context));\n};\n\nColor.prototype.toCSS = function(context, doNotCompress) {\n const compress = context && context.compress && !doNotCompress;\n let color;\n let alpha;\n let colorFunction;\n let args = [];\n\n // `value` is set if this color was originally\n // converted from a named color string so we need\n // to respect this and try to output named color too.\n alpha = this.fround(context, this.alpha);\n\n if (this.value) {\n if (this.value.indexOf('rgb') === 0) {\n if (alpha < 1) {\n colorFunction = 'rgba';\n }\n } else if (this.value.indexOf('hsl') === 0) {\n if (alpha < 1) {\n colorFunction = 'hsla';\n } else {\n colorFunction = 'hsl';\n }\n } else {\n return this.value;\n }\n } else {\n if (alpha < 1) {\n colorFunction = 'rgba';\n }\n }\n\n switch (colorFunction) {\n case 'rgba':\n args = this.rgb.map(c => clamp(Math.round(c), 255)).concat(clamp(alpha, 1));\n break;\n case 'hsla':\n args.push(clamp(alpha, 1));\n case 'hsl':\n color = this.toHSL();\n args = [\n this.fround(context, color.h),\n `${this.fround(context, color.s * 100)}%`,\n `${this.fround(context, color.l * 100)}%`\n ].concat(args);\n }\n\n if (colorFunction) {\n // Values are capped between `0` and `255`, rounded and zero-padded.\n return `${colorFunction}(${args.join(`,${compress ? '' : ' '}`)})`;\n }\n\n color = this.toRGB();\n\n if (compress) {\n const splitcolor = color.split('');\n\n // Convert color to short format\n if (splitcolor[1] === splitcolor[2] && splitcolor[3] === splitcolor[4] && splitcolor[5] === splitcolor[6]) {\n color = `#${splitcolor[1]}${splitcolor[3]}${splitcolor[5]}`;\n }\n }\n\n return color;\n};\n\n//\n// Operations have to be done per-channel, if not,\n// channels will spill onto each other. Once we have\n// our result, in the form of an integer triplet,\n// we create a new Color node to hold the result.\n//\nColor.prototype.operate = function(context, op, other) {\n const rgb = new Array(3);\n const alpha = this.alpha * (1 - other.alpha) + other.alpha;\n for (let c = 0; c < 3; c++) {\n rgb[c] = this._operate(context, op, this.rgb[c], other.rgb[c]);\n }\n return new Color(rgb, alpha);\n};\n\nColor.prototype.toRGB = function() {\n return toHex(this.rgb);\n};\n\nColor.prototype.toHSL = function() {\n const r = this.rgb[0] / 255;\n const g = this.rgb[1] / 255;\n const b = this.rgb[2] / 255;\n const a = this.alpha;\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n let h;\n let s;\n const l = (max + min) / 2;\n const d = max - min;\n\n if (max === min) {\n h = s = 0;\n } else {\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n\n switch (max) {\n case r: h = (g - b) / d + (g < b ? 6 : 0); break;\n case g: h = (b - r) / d + 2; break;\n case b: h = (r - g) / d + 4; break;\n }\n h /= 6;\n }\n return { h: h * 360, s, l, a };\n};\n\n// Adapted from http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript\nColor.prototype.toHSV = function() {\n const r = this.rgb[0] / 255;\n const g = this.rgb[1] / 255;\n const b = this.rgb[2] / 255;\n const a = this.alpha;\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n let h;\n let s;\n const v = max;\n\n const d = max - min;\n if (max === 0) {\n s = 0;\n } else {\n s = d / max;\n }\n\n if (max === min) {\n h = 0;\n } else {\n switch (max) {\n case r: h = (g - b) / d + (g < b ? 6 : 0); break;\n case g: h = (b - r) / d + 2; break;\n case b: h = (r - g) / d + 4; break;\n }\n h /= 6;\n }\n return { h: h * 360, s, v, a };\n};\n\nColor.prototype.toARGB = function() {\n return toHex([this.alpha * 255].concat(this.rgb));\n};\n\nColor.prototype.compare = function(x) {\n return (x.rgb &&\n x.rgb[0] === this.rgb[0] &&\n x.rgb[1] === this.rgb[1] &&\n x.rgb[2] === this.rgb[2] &&\n x.alpha === this.alpha) ? 0 : undefined;\n};\n\nColor.prototype.type = 'Color';\n\nfunction clamp(v, max) {\n return Math.min(Math.max(v, 0), max);\n}\n\nfunction toHex(v) {\n return `#${v.map(c => {\n c = clamp(Math.round(c), 255);\n return (c < 16 ? '0' : '') + c.toString(16);\n }).join('')}`;\n}\n\nColor.fromKeyword = keyword => {\n let c;\n const key = keyword.toLowerCase();\n if (colors.hasOwnProperty(key)) {\n c = new Color(colors[key].slice(1));\n }\n else if (key === 'transparent') {\n c = new Color([0, 0, 0], 0);\n }\n\n if (c) {\n c.value = keyword;\n return c;\n }\n};\n\nexport default Color;\n","import Node from './node';\n\nconst Paren = function(node) {\n this.value = node;\n};\n\nParen.prototype = new Node();\n\nParen.prototype.genCSS = function(context, output) {\n output.add('(');\n this.value.genCSS(context, output);\n output.add(')');\n}\n\nParen.prototype.eval = function(context) {\n return new Paren(this.value.eval(context));\n};\n\nParen.prototype.type = 'Paren';\nexport default Paren;\n","import Node from './node';\nconst _noSpaceCombinators = {\n '': true,\n ' ': true,\n '|': true\n};\n\nconst Combinator = function(value) {\n if (value === ' ') {\n this.value = ' ';\n this.emptyOrWhitespace = true;\n } else {\n this.value = value ? value.trim() : '';\n this.emptyOrWhitespace = this.value === '';\n }\n};\n\nCombinator.prototype = new Node();\n\nCombinator.prototype.genCSS = function(context, output) {\n const spaceOrEmpty = (context.compress || _noSpaceCombinators[this.value]) ? '' : ' ';\n output.add(spaceOrEmpty + this.value + spaceOrEmpty);\n};\n\nCombinator.prototype.type = 'Combinator';\n\nexport default Combinator;\n","import Node from './node';\nimport Paren from './paren';\nimport Combinator from './combinator';\n\nconst Element = function(combinator, value, isVariable, index, currentFileInfo, visibilityInfo) {\n this.combinator = combinator instanceof Combinator ?\n combinator : new Combinator(combinator);\n\n if (typeof value === 'string') {\n this.value = value.trim();\n } else if (value) {\n this.value = value;\n } else {\n this.value = '';\n }\n this.isVariable = isVariable;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.combinator, this);\n};\n\nElement.prototype = new Node();\n\nElement.prototype.accept = function(visitor) {\n const value = this.value;\n this.combinator = visitor.visit(this.combinator);\n if (typeof value === 'object') {\n this.value = visitor.visit(value);\n }\n};\n\nElement.prototype.eval = function(context) {\n return new Element(this.combinator,\n this.value.eval ? this.value.eval(context) : this.value,\n this.isVariable,\n this.getIndex(),\n this.fileInfo(), this.visibilityInfo());\n};\n\nElement.prototype.clone = function() {\n return new Element(this.combinator,\n this.value,\n this.isVariable,\n this.getIndex(),\n this.fileInfo(), this.visibilityInfo());\n};\n\nElement.prototype.genCSS = function(context, output) {\n output.add(this.toCSS(context), this.fileInfo(), this.getIndex());\n};\n\nElement.prototype.toCSS = function(context = {}) {\n let value = this.value;\n const firstSelector = context.firstSelector;\n if (value instanceof Paren) {\n // selector in parens should not be affected by outer selector\n // flags (breaks only interpolated selectors - see #1973)\n context.firstSelector = true;\n }\n value = value.toCSS ? value.toCSS(context) : value;\n context.firstSelector = firstSelector;\n if (value === '' && this.combinator.value.charAt(0) === '&') {\n return '';\n } else {\n return this.combinator.toCSS(context) + value;\n }\n};\n\nElement.prototype.type = 'Element';\nexport default Element;\n","\nexport const Math = {\n ALWAYS: 0,\n PARENS_DIVISION: 1,\n PARENS: 2,\n STRICT_LEGACY: 3\n};\n\nexport const RewriteUrls = {\n OFF: 0,\n LOCAL: 1,\n ALL: 2\n};","/**\r\n * Returns the object type of the given payload\r\n *\r\n * @param {*} payload\r\n * @returns {string}\r\n */\r\nfunction getType(payload) {\r\n return Object.prototype.toString.call(payload).slice(8, -1);\r\n}\r\n/**\r\n * Returns whether the payload is undefined\r\n *\r\n * @param {*} payload\r\n * @returns {payload is undefined}\r\n */\r\nfunction isUndefined(payload) {\r\n return getType(payload) === 'Undefined';\r\n}\r\n/**\r\n * Returns whether the payload is null\r\n *\r\n * @param {*} payload\r\n * @returns {payload is null}\r\n */\r\nfunction isNull(payload) {\r\n return getType(payload) === 'Null';\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isPlainObject(payload) {\r\n if (getType(payload) !== 'Object')\r\n return false;\r\n return payload.constructor === Object && Object.getPrototypeOf(payload) === Object.prototype;\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isObject(payload) {\r\n return isPlainObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a an empty object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is { [K in any]: never }}\r\n */\r\nfunction isEmptyObject(payload) {\r\n return isPlainObject(payload) && Object.keys(payload).length === 0;\r\n}\r\n/**\r\n * Returns whether the payload is an any kind of object (including special classes or objects with different prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isAnyObject(payload) {\r\n return getType(payload) === 'Object';\r\n}\r\n/**\r\n * Returns whether the payload is an object like a type passed in < >\r\n *\r\n * Usage: isObjectLike<{id: any}>(payload) // will make sure it's an object and has an `id` prop.\r\n *\r\n * @template T this must be passed in < >\r\n * @param {*} payload\r\n * @returns {payload is T}\r\n */\r\nfunction isObjectLike(payload) {\r\n return isAnyObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a function (regular or async)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is AnyFunction}\r\n */\r\nfunction isFunction(payload) {\r\n return typeof payload === \"function\";\r\n}\r\n/**\r\n * Returns whether the payload is an array\r\n *\r\n * @param {any} payload\r\n * @returns {payload is any[]}\r\n */\r\nfunction isArray(payload) {\r\n return getType(payload) === 'Array';\r\n}\r\n/**\r\n * Returns whether the payload is a an array with at least 1 item\r\n *\r\n * @param {*} payload\r\n * @returns {payload is any[]}\r\n */\r\nfunction isFullArray(payload) {\r\n return isArray(payload) && payload.length > 0;\r\n}\r\n/**\r\n * Returns whether the payload is a an empty array\r\n *\r\n * @param {*} payload\r\n * @returns {payload is []}\r\n */\r\nfunction isEmptyArray(payload) {\r\n return isArray(payload) && payload.length === 0;\r\n}\r\n/**\r\n * Returns whether the payload is a string\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isString(payload) {\r\n return getType(payload) === 'String';\r\n}\r\n/**\r\n * Returns whether the payload is a string, BUT returns false for ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isFullString(payload) {\r\n return isString(payload) && payload !== '';\r\n}\r\n/**\r\n * Returns whether the payload is ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isEmptyString(payload) {\r\n return payload === '';\r\n}\r\n/**\r\n * Returns whether the payload is a number (but not NaN)\r\n *\r\n * This will return `false` for `NaN`!!\r\n *\r\n * @param {*} payload\r\n * @returns {payload is number}\r\n */\r\nfunction isNumber(payload) {\r\n return getType(payload) === 'Number' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a boolean\r\n *\r\n * @param {*} payload\r\n * @returns {payload is boolean}\r\n */\r\nfunction isBoolean(payload) {\r\n return getType(payload) === 'Boolean';\r\n}\r\n/**\r\n * Returns whether the payload is a regular expression (RegExp)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is RegExp}\r\n */\r\nfunction isRegExp(payload) {\r\n return getType(payload) === 'RegExp';\r\n}\r\n/**\r\n * Returns whether the payload is a Map\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Map}\r\n */\r\nfunction isMap(payload) {\r\n return getType(payload) === 'Map';\r\n}\r\n/**\r\n * Returns whether the payload is a WeakMap\r\n *\r\n * @param {*} payload\r\n * @returns {payload is WeakMap}\r\n */\r\nfunction isWeakMap(payload) {\r\n return getType(payload) === 'WeakMap';\r\n}\r\n/**\r\n * Returns whether the payload is a Set\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Set}\r\n */\r\nfunction isSet(payload) {\r\n return getType(payload) === 'Set';\r\n}\r\n/**\r\n * Returns whether the payload is a WeakSet\r\n *\r\n * @param {*} payload\r\n * @returns {payload is WeakSet}\r\n */\r\nfunction isWeakSet(payload) {\r\n return getType(payload) === 'WeakSet';\r\n}\r\n/**\r\n * Returns whether the payload is a Symbol\r\n *\r\n * @param {*} payload\r\n * @returns {payload is symbol}\r\n */\r\nfunction isSymbol(payload) {\r\n return getType(payload) === 'Symbol';\r\n}\r\n/**\r\n * Returns whether the payload is a Date, and that the date is valid\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Date}\r\n */\r\nfunction isDate(payload) {\r\n return getType(payload) === 'Date' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a Blob\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Blob}\r\n */\r\nfunction isBlob(payload) {\r\n return getType(payload) === 'Blob';\r\n}\r\n/**\r\n * Returns whether the payload is a File\r\n *\r\n * @param {*} payload\r\n * @returns {payload is File}\r\n */\r\nfunction isFile(payload) {\r\n return getType(payload) === 'File';\r\n}\r\n/**\r\n * Returns whether the payload is a Promise\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Promise}\r\n */\r\nfunction isPromise(payload) {\r\n return getType(payload) === 'Promise';\r\n}\r\n/**\r\n * Returns whether the payload is an Error\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Error}\r\n */\r\nfunction isError(payload) {\r\n return getType(payload) === 'Error';\r\n}\r\n/**\r\n * Returns whether the payload is literally the value `NaN` (it's `NaN` and also a `number`)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is typeof NaN}\r\n */\r\nfunction isNaNValue(payload) {\r\n return getType(payload) === 'Number' && isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a primitive type (eg. Boolean | Null | Undefined | Number | String | Symbol)\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is boolean | null | undefined | number | string | symbol)}\r\n */\r\nfunction isPrimitive(payload) {\r\n return (isBoolean(payload) ||\r\n isNull(payload) ||\r\n isUndefined(payload) ||\r\n isNumber(payload) ||\r\n isString(payload) ||\r\n isSymbol(payload));\r\n}\r\n/**\r\n * Returns true whether the payload is null or undefined\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is null | undefined)}\r\n */\r\nfunction isNullOrUndefined(payload) {\r\n return isNull(payload) || isUndefined(payload);\r\n}\r\n/**\r\n * Does a generic check to check that the given payload is of a given type.\r\n * In cases like Number, it will return true for NaN as NaN is a Number (thanks javascript!);\r\n * It will, however, differentiate between object and null\r\n *\r\n * @template T\r\n * @param {*} payload\r\n * @param {T} type\r\n * @throws {TypeError} Will throw type error if type is an invalid type\r\n * @returns {payload is T}\r\n */\r\nfunction isType(payload, type) {\r\n if (!(type instanceof Function)) {\r\n throw new TypeError('Type must be a function');\r\n }\r\n if (!Object.prototype.hasOwnProperty.call(type, 'prototype')) {\r\n throw new TypeError('Type is not a class');\r\n }\r\n // Classes usually have names (as functions usually have names)\r\n var name = type.name;\r\n return getType(payload) === name || Boolean(payload && payload.constructor === type);\r\n}\n\nexport { getType, isAnyObject, isArray, isBlob, isBoolean, isDate, isEmptyArray, isEmptyObject, isEmptyString, isError, isFile, isFullArray, isFullString, isFunction, isMap, isNaNValue, isNull, isNullOrUndefined, isNumber, isObject, isObjectLike, isPlainObject, isPrimitive, isPromise, isRegExp, isSet, isString, isSymbol, isType, isUndefined, isWeakMap, isWeakSet };\n","import { isArray, isPlainObject } from 'is-what';\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n\r\nfunction __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\n\nfunction assignProp(carry, key, newVal, originalObject, includeNonenumerable) {\r\n var propType = {}.propertyIsEnumerable.call(originalObject, key)\r\n ? 'enumerable'\r\n : 'nonenumerable';\r\n if (propType === 'enumerable')\r\n carry[key] = newVal;\r\n if (includeNonenumerable && propType === 'nonenumerable') {\r\n Object.defineProperty(carry, key, {\r\n value: newVal,\r\n enumerable: false,\r\n writable: true,\r\n configurable: true,\r\n });\r\n }\r\n}\r\n/**\r\n * Copy (clone) an object and all its props recursively to get rid of any prop referenced of the original object. Arrays are also cloned, however objects inside arrays are still linked.\r\n *\r\n * @export\r\n * @template T\r\n * @param {T} target Target can be anything\r\n * @param {Options} [options={}] Options can be `props` or `nonenumerable`\r\n * @returns {T} the target with replaced values\r\n * @export\r\n */\r\nfunction copy(target, options) {\r\n if (options === void 0) { options = {}; }\r\n if (isArray(target))\r\n return target.map(function (i) { return copy(i, options); });\r\n if (!isPlainObject(target))\r\n return target;\r\n var props = Object.getOwnPropertyNames(target);\r\n var symbols = Object.getOwnPropertySymbols(target);\r\n return __spreadArrays(props, symbols).reduce(function (carry, key) {\r\n if (isArray(options.props) && !options.props.includes(key)) {\r\n return carry;\r\n }\r\n var val = target[key];\r\n var newVal = copy(val, options);\r\n assignProp(carry, key, newVal, target, options.nonenumerable);\r\n return carry;\r\n }, {});\r\n}\n\nexport { copy };\n","/* jshint proto: true */\nimport * as Constants from './constants';\nimport { copy } from 'copy-anything';\n\nexport function getLocation(index, inputStream) {\n let n = index + 1;\n let line = null;\n let column = -1;\n\n while (--n >= 0 && inputStream.charAt(n) !== '\\n') {\n column++;\n }\n\n if (typeof index === 'number') {\n line = (inputStream.slice(0, index).match(/\\n/g) || '').length;\n }\n\n return {\n line,\n column\n };\n}\n\nexport function copyArray(arr) {\n let i;\n const length = arr.length;\n const copy = new Array(length);\n\n for (i = 0; i < length; i++) {\n copy[i] = arr[i];\n }\n return copy;\n}\n\nexport function clone(obj) {\n const cloned = {};\n for (const prop in obj) {\n if (obj.hasOwnProperty(prop)) {\n cloned[prop] = obj[prop];\n }\n }\n return cloned;\n}\n\nexport function defaults(obj1, obj2) {\n let newObj = obj2 || {};\n if (!obj2._defaults) {\n newObj = {};\n const defaults = copy(obj1);\n newObj._defaults = defaults;\n const cloned = obj2 ? copy(obj2) : {};\n Object.assign(newObj, defaults, cloned);\n }\n return newObj;\n}\n\nexport function copyOptions(obj1, obj2) {\n if (obj2 && obj2._defaults) {\n return obj2;\n }\n const opts = defaults(obj1, obj2);\n if (opts.strictMath) {\n opts.math = Constants.Math.STRICT_LEGACY;\n }\n // Back compat with changed relativeUrls option\n if (opts.relativeUrls) {\n opts.rewriteUrls = Constants.RewriteUrls.ALL;\n }\n if (typeof opts.math === 'string') {\n switch (opts.math.toLowerCase()) {\n case 'always':\n opts.math = Constants.Math.ALWAYS;\n break;\n case 'parens-division':\n opts.math = Constants.Math.PARENS_DIVISION;\n break;\n case 'strict':\n case 'parens':\n opts.math = Constants.Math.PARENS;\n break;\n case 'strict-legacy':\n opts.math = Constants.Math.STRICT_LEGACY;\n }\n }\n if (typeof opts.rewriteUrls === 'string') {\n switch (opts.rewriteUrls.toLowerCase()) {\n case 'off':\n opts.rewriteUrls = Constants.RewriteUrls.OFF;\n break;\n case 'local':\n opts.rewriteUrls = Constants.RewriteUrls.LOCAL;\n break;\n case 'all':\n opts.rewriteUrls = Constants.RewriteUrls.ALL;\n break;\n }\n }\n return opts;\n}\n\nexport function merge(obj1, obj2) {\n for (const prop in obj2) {\n if (obj2.hasOwnProperty(prop)) {\n obj1[prop] = obj2[prop];\n }\n }\n return obj1;\n}\n\nexport function flattenArray(arr, result = []) {\n for (let i = 0, length = arr.length; i < length; i++) {\n const value = arr[i];\n if (Array.isArray(value)) {\n flattenArray(value, result);\n } else {\n if (value !== undefined) {\n result.push(value);\n }\n }\n }\n return result;\n}","import * as utils from './utils';\n\nconst anonymousFunc = /(|Function):(\\d+):(\\d+)/;\n\n/**\n * This is a centralized class of any error that could be thrown internally (mostly by the parser).\n * Besides standard .message it keeps some additional data like a path to the file where the error\n * occurred along with line and column numbers.\n *\n * @class\n * @extends Error\n * @type {module.LessError}\n *\n * @prop {string} type\n * @prop {string} filename\n * @prop {number} index\n * @prop {number} line\n * @prop {number} column\n * @prop {number} callLine\n * @prop {number} callExtract\n * @prop {string[]} extract\n *\n * @param {Object} e - An error object to wrap around or just a descriptive object\n * @param {Object} fileContentMap - An object with file contents in 'contents' property (like importManager) @todo - move to fileManager?\n * @param {string} [currentFilename]\n */\nconst LessError = function LessError(e, fileContentMap, currentFilename) {\n Error.call(this);\n\n const filename = e.filename || currentFilename;\n\n this.message = e.message;\n this.stack = e.stack;\n\n if (fileContentMap && filename) {\n const input = fileContentMap.contents[filename];\n const loc = utils.getLocation(e.index, input);\n const line = loc.line;\n const col = loc.column;\n const callLine = e.call && utils.getLocation(e.call, input).line;\n const lines = input ? input.split('\\n') : '';\n\n this.type = e.type || 'Syntax';\n this.filename = filename;\n this.index = e.index;\n this.line = typeof line === 'number' ? line + 1 : null;\n this.column = col;\n\n if (!this.line && this.stack) {\n const found = this.stack.match(anonymousFunc);\n\n /**\n * We have to figure out how this environment stringifies anonymous functions\n * so we can correctly map plugin errors.\n * \n * Note, in Node 8, the output of anonymous funcs varied based on parameters\n * being present or not, so we inject dummy params.\n */\n const func = new Function('a', 'throw new Error()');\n let lineAdjust = 0;\n try {\n func();\n } catch (e) {\n const match = e.stack.match(anonymousFunc);\n const line = parseInt(match[2]);\n lineAdjust = 1 - line;\n }\n\n if (found) {\n if (found[2]) {\n this.line = parseInt(found[2]) + lineAdjust;\n }\n if (found[3]) {\n this.column = parseInt(found[3]);\n }\n }\n }\n\n this.callLine = callLine + 1;\n this.callExtract = lines[callLine];\n\n this.extract = [\n lines[this.line - 2],\n lines[this.line - 1],\n lines[this.line]\n ];\n }\n\n};\n\nif (typeof Object.create === 'undefined') {\n const F = () => {};\n F.prototype = Error.prototype;\n LessError.prototype = new F();\n} else {\n LessError.prototype = Object.create(Error.prototype);\n}\n\nLessError.prototype.constructor = LessError;\n\n/**\n * An overridden version of the default Object.prototype.toString\n * which uses additional information to create a helpful message.\n *\n * @param {Object} options\n * @returns {string}\n */\nLessError.prototype.toString = function(options = {}) {\n let message = '';\n const extract = this.extract || [];\n let error = [];\n let stylize = str => str;\n if (options.stylize) {\n const type = typeof options.stylize;\n if (type !== 'function') {\n throw Error(`options.stylize should be a function, got a ${type}!`);\n }\n stylize = options.stylize;\n }\n\n if (this.line !== null) {\n if (typeof extract[0] === 'string') {\n error.push(stylize(`${this.line - 1} ${extract[0]}`, 'grey'));\n }\n\n if (typeof extract[1] === 'string') {\n let errorTxt = `${this.line} `;\n if (extract[1]) {\n errorTxt += extract[1].slice(0, this.column) +\n stylize(stylize(stylize(extract[1].substr(this.column, 1), 'bold') +\n extract[1].slice(this.column + 1), 'red'), 'inverse');\n }\n error.push(errorTxt);\n }\n\n if (typeof extract[2] === 'string') {\n error.push(stylize(`${this.line + 1} ${extract[2]}`, 'grey'));\n }\n error = `${error.join('\\n') + stylize('', 'reset')}\\n`;\n }\n\n message += stylize(`${this.type}Error: ${this.message}`, 'red');\n if (this.filename) {\n message += stylize(' in ', 'red') + this.filename;\n }\n if (this.line) {\n message += stylize(` on line ${this.line}, column ${this.column + 1}:`, 'grey');\n }\n\n message += `\\n${error}`;\n\n if (this.callLine) {\n message += `${stylize('from ', 'red') + (this.filename || '')}/n`;\n message += `${stylize(this.callLine, 'grey')} ${this.callExtract}/n`;\n }\n\n return message;\n};\n\nexport default LessError;","import Node from './node';\nimport Element from './element';\nimport LessError from '../less-error';\n\nconst Selector = function(elements, extendList, condition, index, currentFileInfo, visibilityInfo) {\n this.extendList = extendList;\n this.condition = condition;\n this.evaldCondition = !condition;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.elements = this.getElements(elements);\n this.mixinElements_ = undefined;\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.elements, this);\n}\n\nSelector.prototype = new Node();\n\nSelector.prototype.accept = function(visitor) {\n if (this.elements) {\n this.elements = visitor.visitArray(this.elements);\n }\n if (this.extendList) {\n this.extendList = visitor.visitArray(this.extendList);\n }\n if (this.condition) {\n this.condition = visitor.visit(this.condition);\n }\n};\n\nSelector.prototype.createDerived = function(elements, extendList, evaldCondition) {\n elements = this.getElements(elements);\n const newSelector = new Selector(elements, extendList || this.extendList,\n null, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n newSelector.evaldCondition = (evaldCondition != null) ? evaldCondition : this.evaldCondition;\n newSelector.mediaEmpty = this.mediaEmpty;\n return newSelector;\n};\n\nSelector.prototype.getElements = function(els) {\n if (!els) {\n return [new Element('', '&', false, this._index, this._fileInfo)];\n }\n if (typeof els === 'string') {\n this.parse.parseNode(\n els, \n ['selector'],\n this._index, \n this._fileInfo, \n function(err, result) {\n if (err) {\n throw new LessError({\n index: err.index,\n message: err.message\n }, this.parse.imports, this._fileInfo.filename);\n }\n els = result[0].elements;\n });\n }\n return els;\n};\n\nSelector.prototype.createEmptySelectors = function() {\n const el = new Element('', '&', false, this._index, this._fileInfo);\n const sels = [new Selector([el], null, null, this._index, this._fileInfo)];\n sels[0].mediaEmpty = true;\n return sels;\n};\n\nSelector.prototype.match = function(other) {\n const elements = this.elements;\n const len = elements.length;\n let olen;\n let i;\n\n other = other.mixinElements();\n olen = other.length;\n if (olen === 0 || len < olen) {\n return 0;\n } else {\n for (i = 0; i < olen; i++) {\n if (elements[i].value !== other[i]) {\n return 0;\n }\n }\n }\n\n return olen; // return number of matched elements\n};\n\nSelector.prototype.mixinElements = function() {\n if (this.mixinElements_) {\n return this.mixinElements_;\n }\n\n let elements = this.elements.map( v => v.combinator.value + (v.value.value || v.value)).join('').match(/[,&#\\*\\.\\w-]([\\w-]|(\\\\.))*/g);\n\n if (elements) {\n if (elements[0] === '&') {\n elements.shift();\n }\n } else {\n elements = [];\n }\n\n return (this.mixinElements_ = elements);\n};\n\nSelector.prototype.isJustParentSelector = function() {\n return !this.mediaEmpty &&\n this.elements.length === 1 &&\n this.elements[0].value === '&' &&\n (this.elements[0].combinator.value === ' ' || this.elements[0].combinator.value === '');\n};\n\nSelector.prototype.eval = function(context) {\n const evaldCondition = this.condition && this.condition.eval(context);\n let elements = this.elements;\n let extendList = this.extendList;\n\n elements = elements && elements.map(e => e.eval(context));\n extendList = extendList && extendList.map(extend => extend.eval(context));\n\n return this.createDerived(elements, extendList, evaldCondition);\n};\n\nSelector.prototype.genCSS = function(context, output) {\n let i;\n let element;\n if ((!context || !context.firstSelector) && this.elements[0].combinator.value === '') {\n output.add(' ', this.fileInfo(), this.getIndex());\n }\n for (i = 0; i < this.elements.length; i++) {\n element = this.elements[i];\n element.genCSS(context, output);\n }\n};\n\nSelector.prototype.getIsOutput = function() {\n return this.evaldCondition;\n};\n\nSelector.prototype.type = 'Selector';\nexport default Selector;\n","import Node from './node';\n\nconst Value = function(value) {\n if (!value) {\n throw new Error('Value requires an array argument');\n }\n if (!Array.isArray(value)) {\n this.value = [ value ];\n }\n else {\n this.value = value;\n }\n};\n\nValue.prototype = new Node();\n\nValue.prototype.accept = function(visitor) {\n if (this.value) {\n this.value = visitor.visitArray(this.value);\n }\n};\n\nValue.prototype.eval = function(context) {\n if (this.value.length === 1) {\n return this.value[0].eval(context);\n } else {\n return new Value(this.value.map(v => v.eval(context)));\n }\n};\n\nValue.prototype.genCSS = function(context, output) {\n let i;\n for (i = 0; i < this.value.length; i++) {\n this.value[i].genCSS(context, output);\n if (i + 1 < this.value.length) {\n output.add((context && context.compress) ? ',' : ', ');\n }\n }\n};\n\nValue.prototype.type = 'Value';\nexport default Value;\n","import Node from './node';\n\nconst Keyword = function(value) {\n this.value = value;\n};\n\nKeyword.prototype = new Node();\n\nKeyword.prototype.genCSS = function(context, output) {\n if (this.value === '%') { throw { type: 'Syntax', message: 'Invalid % without number' }; }\n output.add(this.value);\n};\n\nKeyword.prototype.type = 'Keyword';\n\nKeyword.True = new Keyword('true');\nKeyword.False = new Keyword('false');\n\nexport default Keyword;\n","import Node from './node';\nimport { extend } from './util';\n\nconst Anonymous = function(value, index, currentFileInfo, mapLines, rulesetLike, visibilityInfo) {\n this.value = value;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.mapLines = mapLines;\n this.rulesetLike = (typeof rulesetLike === 'undefined') ? false : rulesetLike;\n this.allowRoot = true;\n this.copyVisibilityInfo(visibilityInfo);\n}\n\nAnonymous.prototype = new Node();\n\nAnonymous.prototype.eval = function() {\n return new Anonymous(this.value, this._index, this._fileInfo, this.mapLines, this.rulesetLike, this.visibilityInfo());\n};\n\nAnonymous.prototype.compare = function(other) {\n return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined;\n};\n\nAnonymous.prototype.isRulesetLike = function() {\n return this.rulesetLike;\n};\n\nAnonymous.prototype.genCSS = function(context, output) {\n this.nodeVisible = Boolean(this.value);\n if (this.nodeVisible) {\n output.add(this.value, this._fileInfo, this._index, this.mapLines);\n }\n};\n\nAnonymous.prototype.type = 'Anonymous';\nexport default Anonymous;\n","import Node from './node';\nimport Value from './value';\nimport Keyword from './keyword';\nimport Anonymous from './anonymous';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\n\nconst Declaration = function(name, value, important, merge, index, currentFileInfo, inline, variable) {\n this.name = name;\n this.value = (value instanceof Node) ? value : new Value([value ? new Anonymous(value) : null]);\n this.important = important ? ` ${important.trim()}` : '';\n this.merge = merge;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.inline = inline || false;\n this.variable = (variable !== undefined) ? variable\n : (name.charAt && (name.charAt(0) === '@'));\n this.allowRoot = true;\n this.setParent(this.value, this);\n};\n\nDeclaration.prototype = new Node();\n\nDeclaration.prototype.genCSS = function(context, output) {\n output.add(this.name + (context.compress ? ':' : ': '), this.fileInfo(), this.getIndex());\n try {\n this.value.genCSS(context, output);\n }\n catch (e) {\n e.index = this._index;\n e.filename = this._fileInfo.filename;\n throw e;\n }\n output.add(this.important + ((this.inline || (context.lastRule && context.compress)) ? '' : ';'), this._fileInfo, this._index);\n}\n\nDeclaration.prototype.eval = function(context) {\n let mathBypass = false;\n let prevMath;\n let name = this.name;\n let evaldValue;\n let variable = this.variable;\n if (typeof name !== 'string') {\n // expand 'primitive' name directly to get\n // things faster (~10% for benchmark.less):\n name = (name.length === 1) && (name[0] instanceof Keyword) ?\n name[0].value : evalName(context, name);\n variable = false; // never treat expanded interpolation as new variable name\n }\n\n // @todo remove when parens-division is default\n if (name === 'font' && context.math === MATH.ALWAYS) {\n mathBypass = true;\n prevMath = context.math;\n context.math = MATH.PARENS_DIVISION;\n }\n try {\n context.importantScope.push({});\n evaldValue = this.value.eval(context);\n\n if (!this.variable && evaldValue.type === 'DetachedRuleset') {\n throw { message: 'Rulesets cannot be evaluated on a property.',\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n let important = this.important;\n const importantResult = context.importantScope.pop();\n if (!important && importantResult.important) {\n important = importantResult.important;\n }\n\n return new Declaration(name,\n evaldValue,\n important,\n this.merge,\n this.getIndex(), this.fileInfo(), this.inline,\n variable);\n }\n catch (e) {\n if (typeof e.index !== 'number') {\n e.index = this.getIndex();\n e.filename = this.fileInfo().filename;\n }\n throw e;\n }\n finally {\n if (mathBypass) {\n context.math = prevMath;\n }\n }\n};\n\nDeclaration.prototype.makeImportant = function() {\n return new Declaration(this.name,\n this.value,\n '!important',\n this.merge,\n this.getIndex(), this.fileInfo(), this.inline);\n};\n\nfunction evalName(context, name) {\n let value = '';\n let i;\n const n = name.length;\n const output = {add: function (s) {value += s;}};\n for (i = 0; i < n; i++) {\n name[i].eval(context).genCSS(context, output);\n }\n return value;\n}\n\nDeclaration.prototype.type = 'Declaration';\nexport default Declaration;","const debugInfo = (context, ctx, lineSeparator) => {\n let result = '';\n if (context.dumpLineNumbers && !context.compress) {\n switch (context.dumpLineNumbers) {\n case 'comments':\n result = debugInfo.asComment(ctx);\n break;\n case 'mediaquery':\n result = debugInfo.asMediaQuery(ctx);\n break;\n case 'all':\n result = debugInfo.asComment(ctx) + (lineSeparator || '') + debugInfo.asMediaQuery(ctx);\n break;\n }\n }\n return result;\n};\n\ndebugInfo.asComment = ctx => ctx.debugInfo ? `/* line ${ctx.debugInfo.lineNumber}, ${ctx.debugInfo.fileName} */\\n` : '';\n\ndebugInfo.asMediaQuery = ctx => {\n if (!ctx.debugInfo) { return ''; }\n let filenameWithProtocol = ctx.debugInfo.fileName;\n if (!/^[a-z]+:\\/\\//i.test(filenameWithProtocol)) {\n filenameWithProtocol = `file://${filenameWithProtocol}`;\n }\n return `@media -sass-debug-info{filename{font-family:${filenameWithProtocol.replace(/([.:\\/\\\\])/g, a => {\n if (a == '\\\\') {\n a = '\\/';\n }\n return `\\\\${a}`;\n })}}line{font-family:\\\\00003${ctx.debugInfo.lineNumber}}}\\n`;\n};\n\nexport default debugInfo;\n","import Node from './node';\nimport getDebugInfo from './debug-info';\n\nconst Comment = function(value, isLineComment, index, currentFileInfo) {\n this.value = value;\n this.isLineComment = isLineComment;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.allowRoot = true;\n};\n\nComment.prototype = new Node();\n\nComment.prototype.genCSS = function(context, output) {\n if (this.debugInfo) {\n output.add(getDebugInfo(context, this), this.fileInfo(), this.getIndex());\n }\n output.add(this.value);\n};\n\nComment.prototype.isSilent = function(context) {\n const isCompressed = context.compress && this.value[2] !== '!';\n return this.isLineComment || isCompressed;\n};\n\nComment.prototype.type = 'Comment';\nexport default Comment;\n","const contexts = {};\nexport default contexts;\nimport * as Constants from './constants';\n\nconst copyFromOriginal = function copyFromOriginal(original, destination, propertiesToCopy) {\n if (!original) { return; }\n\n for (let i = 0; i < propertiesToCopy.length; i++) {\n if (original.hasOwnProperty(propertiesToCopy[i])) {\n destination[propertiesToCopy[i]] = original[propertiesToCopy[i]];\n }\n }\n};\n\n/*\n parse is used whilst parsing\n */\nconst parseCopyProperties = [\n // options\n 'paths', // option - unmodified - paths to search for imports on\n 'rewriteUrls', // option - whether to adjust URL's to be relative\n 'rootpath', // option - rootpath to append to URL's\n 'strictImports', // option -\n 'insecure', // option - whether to allow imports from insecure ssl hosts\n 'dumpLineNumbers', // option - whether to dump line numbers\n 'compress', // option - whether to compress\n 'syncImport', // option - whether to import synchronously\n 'chunkInput', // option - whether to chunk input. more performant but causes parse issues.\n 'mime', // browser only - mime type for sheet import\n 'useFileCache', // browser only - whether to use the per file session cache\n // context\n 'processImports', // option & context - whether to process imports. if false then imports will not be imported.\n // Used by the import manager to stop multiple import visitors being created.\n 'pluginManager' // Used as the plugin manager for the session\n];\n\ncontexts.Parse = function(options) {\n copyFromOriginal(options, this, parseCopyProperties);\n\n if (typeof this.paths === 'string') { this.paths = [this.paths]; }\n};\n\nconst evalCopyProperties = [\n 'paths', // additional include paths\n 'compress', // whether to compress\n 'math', // whether math has to be within parenthesis\n 'strictUnits', // whether units need to evaluate correctly\n 'sourceMap', // whether to output a source map\n 'importMultiple', // whether we are currently importing multiple copies\n 'urlArgs', // whether to add args into url tokens\n 'javascriptEnabled', // option - whether Inline JavaScript is enabled. if undefined, defaults to false\n 'pluginManager', // Used as the plugin manager for the session\n 'importantScope', // used to bubble up !important statements\n 'rewriteUrls' // option - whether to adjust URL's to be relative\n];\n\nfunction isPathRelative(path) {\n return !/^(?:[a-z-]+:|\\/|#)/i.test(path);\n}\n\nfunction isPathLocalRelative(path) {\n return path.charAt(0) === '.';\n}\n\ncontexts.Eval = class {\n constructor(options, frames) {\n copyFromOriginal(options, this, evalCopyProperties);\n\n if (typeof this.paths === 'string') { this.paths = [this.paths]; }\n\n this.frames = frames || [];\n this.importantScope = this.importantScope || [];\n this.inCalc = false;\n this.mathOn = true;\n }\n\n enterCalc() {\n if (!this.calcStack) {\n this.calcStack = [];\n }\n this.calcStack.push(true);\n this.inCalc = true;\n }\n\n exitCalc() {\n this.calcStack.pop();\n if (!this.calcStack.length) {\n this.inCalc = false;\n }\n }\n\n inParenthesis() {\n if (!this.parensStack) {\n this.parensStack = [];\n }\n this.parensStack.push(true);\n };\n\n outOfParenthesis() {\n this.parensStack.pop();\n };\n\n isMathOn(op) {\n if (!this.mathOn) {\n return false;\n }\n if (op === '/' && this.math !== Constants.Math.ALWAYS && (!this.parensStack || !this.parensStack.length)) {\n return false;\n }\n if (this.math > Constants.Math.PARENS_DIVISION) {\n return this.parensStack && this.parensStack.length;\n }\n return true;\n }\n\n pathRequiresRewrite(path) {\n const isRelative = this.rewriteUrls === Constants.RewriteUrls.LOCAL ? isPathLocalRelative : isPathRelative;\n\n return isRelative(path);\n }\n\n rewritePath(path, rootpath) {\n let newPath;\n\n rootpath = rootpath || '';\n newPath = this.normalizePath(rootpath + path);\n\n // If a path was explicit relative and the rootpath was not an absolute path\n // we must ensure that the new path is also explicit relative.\n if (isPathLocalRelative(path) &&\n isPathRelative(rootpath) &&\n isPathLocalRelative(newPath) === false) {\n newPath = `./${newPath}`;\n }\n\n return newPath;\n }\n\n normalizePath(path) {\n const segments = path.split('/').reverse();\n let segment;\n\n path = [];\n while (segments.length !== 0) {\n segment = segments.pop();\n switch ( segment ) {\n case '.':\n break;\n case '..':\n if ((path.length === 0) || (path[path.length - 1] === '..')) {\n path.push( segment );\n } else {\n path.pop();\n }\n break;\n default:\n path.push(segment);\n break;\n }\n }\n\n return path.join('/');\n }\n}\n","function makeRegistry( base ) {\n return {\n _data: {},\n add: function(name, func) {\n // precautionary case conversion, as later querying of\n // the registry by function-caller uses lower case as well.\n name = name.toLowerCase();\n\n if (this._data.hasOwnProperty(name)) {\n // TODO warn\n }\n this._data[name] = func;\n },\n addMultiple: function(functions) {\n Object.keys(functions).forEach(\n name => {\n this.add(name, functions[name]);\n });\n },\n get: function(name) {\n return this._data[name] || ( base && base.get( name ));\n },\n getLocalFunctions: function() {\n return this._data;\n },\n inherit: function() {\n return makeRegistry( this );\n },\n create: function(base) {\n return makeRegistry(base);\n }\n };\n}\n\nexport default makeRegistry( null );","import Keyword from '../tree/keyword';\n\nconst defaultFunc = {\n eval: function () {\n const v = this.value_;\n const e = this.error_;\n if (e) {\n throw e;\n }\n if (v != null) {\n return v ? Keyword.True : Keyword.False;\n }\n },\n value: function (v) {\n this.value_ = v;\n },\n error: function (e) {\n this.error_ = e;\n },\n reset: function () {\n this.value_ = this.error_ = null;\n }\n};\n\nexport default defaultFunc;\n","import Node from './node';\nimport Declaration from './declaration';\nimport Keyword from './keyword';\nimport Comment from './comment';\nimport Paren from './paren';\nimport Selector from './selector';\nimport Element from './element';\nimport Anonymous from './anonymous';\nimport contexts from '../contexts';\nimport globalFunctionRegistry from '../functions/function-registry';\nimport defaultFunc from '../functions/default';\nimport getDebugInfo from './debug-info';\nimport * as utils from '../utils';\n\nconst Ruleset = function(selectors, rules, strictImports, visibilityInfo) {\n this.selectors = selectors;\n this.rules = rules;\n this._lookups = {};\n this._variables = null;\n this._properties = null;\n this.strictImports = strictImports;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n\n this.setParent(this.selectors, this);\n this.setParent(this.rules, this);\n}\n\nRuleset.prototype = new Node();\n\nRuleset.prototype.isRulesetLike = function() {\n return true;\n};\n\nRuleset.prototype.accept = function(visitor) {\n if (this.paths) {\n this.paths = visitor.visitArray(this.paths, true);\n } else if (this.selectors) {\n this.selectors = visitor.visitArray(this.selectors);\n }\n if (this.rules && this.rules.length) {\n this.rules = visitor.visitArray(this.rules);\n }\n};\n\nRuleset.prototype.eval = function(context) {\n const that = this;\n let selectors;\n let selCnt;\n let selector;\n let i;\n let hasVariable;\n let hasOnePassingSelector = false;\n\n if (this.selectors && (selCnt = this.selectors.length)) {\n selectors = new Array(selCnt);\n defaultFunc.error({\n type: 'Syntax',\n message: 'it is currently only allowed in parametric mixin guards,'\n });\n\n for (i = 0; i < selCnt; i++) {\n selector = this.selectors[i].eval(context);\n for (var j = 0; j < selector.elements.length; j++) {\n if (selector.elements[j].isVariable) {\n hasVariable = true;\n break;\n }\n }\n selectors[i] = selector;\n if (selector.evaldCondition) {\n hasOnePassingSelector = true;\n }\n }\n\n if (hasVariable) {\n const toParseSelectors = new Array(selCnt);\n for (i = 0; i < selCnt; i++) {\n selector = selectors[i];\n toParseSelectors[i] = selector.toCSS(context);\n }\n this.parse.parseNode(\n toParseSelectors.join(','),\n [\"selectors\"], \n selectors[0].getIndex(), \n selectors[0].fileInfo(), \n (err, result) => {\n if (result) {\n selectors = utils.flattenArray(result);\n }\n });\n }\n\n defaultFunc.reset();\n } else {\n hasOnePassingSelector = true;\n }\n\n let rules = this.rules ? utils.copyArray(this.rules) : null;\n const ruleset = new Ruleset(selectors, rules, this.strictImports, this.visibilityInfo());\n let rule;\n let subRule;\n\n ruleset.originalRuleset = this;\n ruleset.root = this.root;\n ruleset.firstRoot = this.firstRoot;\n ruleset.allowImports = this.allowImports;\n\n if (this.debugInfo) {\n ruleset.debugInfo = this.debugInfo;\n }\n\n if (!hasOnePassingSelector) {\n rules.length = 0;\n }\n\n // inherit a function registry from the frames stack when possible;\n // otherwise from the global registry\n ruleset.functionRegistry = (frames => {\n let i = 0;\n const n = frames.length;\n let found;\n for ( ; i !== n ; ++i ) {\n found = frames[ i ].functionRegistry;\n if ( found ) { return found; }\n }\n return globalFunctionRegistry;\n })(context.frames).inherit();\n\n // push the current ruleset to the frames stack\n const ctxFrames = context.frames;\n ctxFrames.unshift(ruleset);\n\n // currrent selectors\n let ctxSelectors = context.selectors;\n if (!ctxSelectors) {\n context.selectors = ctxSelectors = [];\n }\n ctxSelectors.unshift(this.selectors);\n\n // Evaluate imports\n if (ruleset.root || ruleset.allowImports || !ruleset.strictImports) {\n ruleset.evalImports(context);\n }\n\n // Store the frames around mixin definitions,\n // so they can be evaluated like closures when the time comes.\n const rsRules = ruleset.rules;\n for (i = 0; (rule = rsRules[i]); i++) {\n if (rule.evalFirst) {\n rsRules[i] = rule.eval(context);\n }\n }\n\n const mediaBlockCount = (context.mediaBlocks && context.mediaBlocks.length) || 0;\n\n // Evaluate mixin calls.\n for (i = 0; (rule = rsRules[i]); i++) {\n if (rule.type === 'MixinCall') {\n /* jshint loopfunc:true */\n rules = rule.eval(context).filter(r => {\n if ((r instanceof Declaration) && r.variable) {\n // do not pollute the scope if the variable is\n // already there. consider returning false here\n // but we need a way to \"return\" variable from mixins\n return !(ruleset.variable(r.name));\n }\n return true;\n });\n rsRules.splice(...[i, 1].concat(rules));\n i += rules.length - 1;\n ruleset.resetCache();\n } else if (rule.type === 'VariableCall') {\n /* jshint loopfunc:true */\n rules = rule.eval(context).rules.filter(r => {\n if ((r instanceof Declaration) && r.variable) {\n // do not pollute the scope at all\n return false;\n }\n return true;\n });\n rsRules.splice(...[i, 1].concat(rules));\n i += rules.length - 1;\n ruleset.resetCache();\n }\n }\n\n // Evaluate everything else\n for (i = 0; (rule = rsRules[i]); i++) {\n if (!rule.evalFirst) {\n rsRules[i] = rule = rule.eval ? rule.eval(context) : rule;\n }\n }\n\n // Evaluate everything else\n for (i = 0; (rule = rsRules[i]); i++) {\n // for rulesets, check if it is a css guard and can be removed\n if (rule instanceof Ruleset && rule.selectors && rule.selectors.length === 1) {\n // check if it can be folded in (e.g. & where)\n if (rule.selectors[0] && rule.selectors[0].isJustParentSelector()) {\n rsRules.splice(i--, 1);\n\n for (var j = 0; (subRule = rule.rules[j]); j++) {\n if (subRule instanceof Node) {\n subRule.copyVisibilityInfo(rule.visibilityInfo());\n if (!(subRule instanceof Declaration) || !subRule.variable) {\n rsRules.splice(++i, 0, subRule);\n }\n }\n }\n }\n }\n }\n\n // Pop the stack\n ctxFrames.shift();\n ctxSelectors.shift();\n\n if (context.mediaBlocks) {\n for (i = mediaBlockCount; i < context.mediaBlocks.length; i++) {\n context.mediaBlocks[i].bubbleSelectors(selectors);\n }\n }\n\n return ruleset;\n};\n\nRuleset.prototype.evalImports = function(context) {\n const rules = this.rules;\n let i;\n let importRules;\n if (!rules) { return; }\n\n for (i = 0; i < rules.length; i++) {\n if (rules[i].type === 'Import') {\n importRules = rules[i].eval(context);\n if (importRules && (importRules.length || importRules.length === 0)) {\n rules.splice(...[i, 1].concat(importRules));\n i += importRules.length - 1;\n } else {\n rules.splice(i, 1, importRules);\n }\n this.resetCache();\n }\n }\n};\n\nRuleset.prototype.makeImportant = function() {\n const result = new Ruleset(this.selectors, this.rules.map(r => {\n if (r.makeImportant) {\n return r.makeImportant();\n } else {\n return r;\n }\n }), this.strictImports, this.visibilityInfo());\n\n return result;\n};\n\nRuleset.prototype.matchArgs = function(args) {\n return !args || args.length === 0;\n};\n\n// lets you call a css selector with a guard\nRuleset.prototype.matchCondition = function(args, context) {\n const lastSelector = this.selectors[this.selectors.length - 1];\n if (!lastSelector.evaldCondition) {\n return false;\n }\n if (lastSelector.condition &&\n !lastSelector.condition.eval(\n new contexts.Eval(context,\n context.frames))) {\n return false;\n }\n return true;\n};\n\nRuleset.prototype.resetCache = function() {\n this._rulesets = null;\n this._variables = null;\n this._properties = null;\n this._lookups = {};\n};\n\nRuleset.prototype.variables = function() {\n if (!this._variables) {\n this._variables = !this.rules ? {} : this.rules.reduce((hash, r) => {\n if (r instanceof Declaration && r.variable === true) {\n hash[r.name] = r;\n }\n // when evaluating variables in an import statement, imports have not been eval'd\n // so we need to go inside import statements.\n // guard against root being a string (in the case of inlined less)\n if (r.type === 'Import' && r.root && r.root.variables) {\n const vars = r.root.variables();\n for (const name in vars) {\n if (vars.hasOwnProperty(name)) {\n hash[name] = r.root.variable(name);\n }\n }\n }\n return hash;\n }, {});\n }\n return this._variables;\n};\n\nRuleset.prototype.properties = function() {\n if (!this._properties) {\n this._properties = !this.rules ? {} : this.rules.reduce((hash, r) => {\n if (r instanceof Declaration && r.variable !== true) {\n const name = (r.name.length === 1) && (r.name[0] instanceof Keyword) ?\n r.name[0].value : r.name;\n // Properties don't overwrite as they can merge\n if (!hash[`$${name}`]) {\n hash[`$${name}`] = [ r ];\n }\n else {\n hash[`$${name}`].push(r);\n }\n }\n return hash;\n }, {});\n }\n return this._properties;\n};\n\nRuleset.prototype.variable = function(name) {\n const decl = this.variables()[name];\n if (decl) {\n return this.parseValue(decl);\n }\n};\n\nRuleset.prototype.property = function(name) {\n const decl = this.properties()[name];\n if (decl) {\n return this.parseValue(decl);\n }\n};\n\nRuleset.prototype.lastDeclaration = function() {\n for (let i = this.rules.length; i > 0; i--) {\n const decl = this.rules[i - 1];\n if (decl instanceof Declaration) {\n return this.parseValue(decl);\n }\n }\n};\n\nRuleset.prototype.parseValue = function(toParse) {\n const self = this;\n function transformDeclaration(decl) {\n if (decl.value instanceof Anonymous && !decl.parsed) {\n if (typeof decl.value.value === 'string') {\n this.parse.parseNode(\n decl.value.value,\n ['value', 'important'], \n decl.value.getIndex(), \n decl.fileInfo(), \n (err, result) => {\n if (err) {\n decl.parsed = true;\n }\n if (result) {\n decl.value = result[0];\n decl.important = result[1] || '';\n decl.parsed = true;\n }\n });\n } else {\n decl.parsed = true;\n }\n\n return decl;\n }\n else {\n return decl;\n }\n }\n if (!Array.isArray(toParse)) {\n return transformDeclaration.call(self, toParse);\n }\n else {\n const nodes = [];\n toParse.forEach(n => {\n nodes.push(transformDeclaration.call(self, n));\n });\n return nodes;\n }\n};\n\nRuleset.prototype.rulesets = function() {\n if (!this.rules) { return []; }\n\n const filtRules = [];\n const rules = this.rules;\n let i;\n let rule;\n\n for (i = 0; (rule = rules[i]); i++) {\n if (rule.isRuleset) {\n filtRules.push(rule);\n }\n }\n\n return filtRules;\n};\n\nRuleset.prototype.prependRule = function(rule) {\n const rules = this.rules;\n if (rules) {\n rules.unshift(rule);\n } else {\n this.rules = [ rule ];\n }\n this.setParent(rule, this);\n};\n\nRuleset.prototype.find = function(selector, self = this, filter) {\n const rules = [];\n let match;\n let foundMixins;\n const key = selector.toCSS();\n\n if (key in this._lookups) { return this._lookups[key]; }\n\n this.rulesets().forEach(rule => {\n if (rule !== self) {\n for (let j = 0; j < rule.selectors.length; j++) {\n match = selector.match(rule.selectors[j]);\n if (match) {\n if (selector.elements.length > match) {\n if (!filter || filter(rule)) {\n foundMixins = rule.find(new Selector(selector.elements.slice(match)), self, filter);\n for (let i = 0; i < foundMixins.length; ++i) {\n foundMixins[i].path.push(rule);\n }\n Array.prototype.push.apply(rules, foundMixins);\n }\n } else {\n rules.push({ rule, path: []});\n }\n break;\n }\n }\n }\n });\n this._lookups[key] = rules;\n return rules;\n};\n\nRuleset.prototype.genCSS = function(context, output) {\n let i;\n let j;\n const charsetRuleNodes = [];\n let ruleNodes = [];\n\n let // Line number debugging\n debugInfo;\n\n let rule;\n let path;\n\n context.tabLevel = (context.tabLevel || 0);\n\n if (!this.root) {\n context.tabLevel++;\n }\n\n const tabRuleStr = context.compress ? '' : Array(context.tabLevel + 1).join(' ');\n const tabSetStr = context.compress ? '' : Array(context.tabLevel).join(' ');\n let sep;\n\n let charsetNodeIndex = 0;\n let importNodeIndex = 0;\n for (i = 0; (rule = this.rules[i]); i++) {\n if (rule instanceof Comment) {\n if (importNodeIndex === i) {\n importNodeIndex++;\n }\n ruleNodes.push(rule);\n } else if (rule.isCharset && rule.isCharset()) {\n ruleNodes.splice(charsetNodeIndex, 0, rule);\n charsetNodeIndex++;\n importNodeIndex++;\n } else if (rule.type === 'Import') {\n ruleNodes.splice(importNodeIndex, 0, rule);\n importNodeIndex++;\n } else {\n ruleNodes.push(rule);\n }\n }\n ruleNodes = charsetRuleNodes.concat(ruleNodes);\n\n // If this is the root node, we don't render\n // a selector, or {}.\n if (!this.root) {\n debugInfo = getDebugInfo(context, this, tabSetStr);\n\n if (debugInfo) {\n output.add(debugInfo);\n output.add(tabSetStr);\n }\n\n const paths = this.paths;\n const pathCnt = paths.length;\n let pathSubCnt;\n\n sep = context.compress ? ',' : (`,\\n${tabSetStr}`);\n\n for (i = 0; i < pathCnt; i++) {\n path = paths[i];\n if (!(pathSubCnt = path.length)) { continue; }\n if (i > 0) { output.add(sep); }\n\n context.firstSelector = true;\n path[0].genCSS(context, output);\n\n context.firstSelector = false;\n for (j = 1; j < pathSubCnt; j++) {\n path[j].genCSS(context, output);\n }\n }\n\n output.add((context.compress ? '{' : ' {\\n') + tabRuleStr);\n }\n\n // Compile rules and rulesets\n for (i = 0; (rule = ruleNodes[i]); i++) {\n\n if (i + 1 === ruleNodes.length) {\n context.lastRule = true;\n }\n\n const currentLastRule = context.lastRule;\n if (rule.isRulesetLike(rule)) {\n context.lastRule = false;\n }\n\n if (rule.genCSS) {\n rule.genCSS(context, output);\n } else if (rule.value) {\n output.add(rule.value.toString());\n }\n\n context.lastRule = currentLastRule;\n\n if (!context.lastRule && rule.isVisible()) {\n output.add(context.compress ? '' : (`\\n${tabRuleStr}`));\n } else {\n context.lastRule = false;\n }\n }\n\n if (!this.root) {\n output.add((context.compress ? '}' : `\\n${tabSetStr}}`));\n context.tabLevel--;\n }\n\n if (!output.isEmpty() && !context.compress && this.firstRoot) {\n output.add('\\n');\n }\n};\n\nRuleset.prototype.joinSelectors = function(paths, context, selectors) {\n for (let s = 0; s < selectors.length; s++) {\n this.joinSelector(paths, context, selectors[s]);\n }\n};\n\nRuleset.prototype.joinSelector = function(paths, context, selector) {\n function createParenthesis(elementsToPak, originalElement) {\n let replacementParen;\n let j;\n if (elementsToPak.length === 0) {\n replacementParen = new Paren(elementsToPak[0]);\n } else {\n const insideParent = new Array(elementsToPak.length);\n for (j = 0; j < elementsToPak.length; j++) {\n insideParent[j] = new Element(\n null,\n elementsToPak[j],\n originalElement.isVariable,\n originalElement._index,\n originalElement._fileInfo\n );\n }\n replacementParen = new Paren(new Selector(insideParent));\n }\n return replacementParen;\n }\n\n function createSelector(containedElement, originalElement) {\n let element;\n let selector;\n element = new Element(null, containedElement, originalElement.isVariable, originalElement._index, originalElement._fileInfo);\n selector = new Selector([element]);\n return selector;\n }\n\n // joins selector path from `beginningPath` with selector path in `addPath`\n // `replacedElement` contains element that is being replaced by `addPath`\n // returns concatenated path\n function addReplacementIntoPath(beginningPath, addPath, replacedElement, originalSelector) {\n let newSelectorPath;\n let lastSelector;\n let newJoinedSelector;\n // our new selector path\n newSelectorPath = [];\n\n // construct the joined selector - if & is the first thing this will be empty,\n // if not newJoinedSelector will be the last set of elements in the selector\n if (beginningPath.length > 0) {\n newSelectorPath = utils.copyArray(beginningPath);\n lastSelector = newSelectorPath.pop();\n newJoinedSelector = originalSelector.createDerived(utils.copyArray(lastSelector.elements));\n }\n else {\n newJoinedSelector = originalSelector.createDerived([]);\n }\n\n if (addPath.length > 0) {\n // /deep/ is a CSS4 selector - (removed, so should deprecate)\n // that is valid without anything in front of it\n // so if the & does not have a combinator that is \"\" or \" \" then\n // and there is a combinator on the parent, then grab that.\n // this also allows + a { & .b { .a & { ... though not sure why you would want to do that\n let combinator = replacedElement.combinator;\n\n const parentEl = addPath[0].elements[0];\n if (combinator.emptyOrWhitespace && !parentEl.combinator.emptyOrWhitespace) {\n combinator = parentEl.combinator;\n }\n // join the elements so far with the first part of the parent\n newJoinedSelector.elements.push(new Element(\n combinator,\n parentEl.value,\n replacedElement.isVariable,\n replacedElement._index,\n replacedElement._fileInfo\n ));\n newJoinedSelector.elements = newJoinedSelector.elements.concat(addPath[0].elements.slice(1));\n }\n\n // now add the joined selector - but only if it is not empty\n if (newJoinedSelector.elements.length !== 0) {\n newSelectorPath.push(newJoinedSelector);\n }\n\n // put together the parent selectors after the join (e.g. the rest of the parent)\n if (addPath.length > 1) {\n let restOfPath = addPath.slice(1);\n restOfPath = restOfPath.map(selector => selector.createDerived(selector.elements, []));\n newSelectorPath = newSelectorPath.concat(restOfPath);\n }\n return newSelectorPath;\n }\n\n // joins selector path from `beginningPath` with every selector path in `addPaths` array\n // `replacedElement` contains element that is being replaced by `addPath`\n // returns array with all concatenated paths\n function addAllReplacementsIntoPath( beginningPath, addPaths, replacedElement, originalSelector, result) {\n let j;\n for (j = 0; j < beginningPath.length; j++) {\n const newSelectorPath = addReplacementIntoPath(beginningPath[j], addPaths, replacedElement, originalSelector);\n result.push(newSelectorPath);\n }\n return result;\n }\n\n function mergeElementsOnToSelectors(elements, selectors) {\n let i;\n let sel;\n\n if (elements.length === 0) {\n return ;\n }\n if (selectors.length === 0) {\n selectors.push([ new Selector(elements) ]);\n return;\n }\n\n for (i = 0; (sel = selectors[i]); i++) {\n // if the previous thing in sel is a parent this needs to join on to it\n if (sel.length > 0) {\n sel[sel.length - 1] = sel[sel.length - 1].createDerived(sel[sel.length - 1].elements.concat(elements));\n }\n else {\n sel.push(new Selector(elements));\n }\n }\n }\n\n // replace all parent selectors inside `inSelector` by content of `context` array\n // resulting selectors are returned inside `paths` array\n // returns true if `inSelector` contained at least one parent selector\n function replaceParentSelector(paths, context, inSelector) {\n // The paths are [[Selector]]\n // The first list is a list of comma separated selectors\n // The inner list is a list of inheritance separated selectors\n // e.g.\n // .a, .b {\n // .c {\n // }\n // }\n // == [[.a] [.c]] [[.b] [.c]]\n //\n let i;\n\n let j;\n let k;\n let currentElements;\n let newSelectors;\n let selectorsMultiplied;\n let sel;\n let el;\n let hadParentSelector = false;\n let length;\n let lastSelector;\n function findNestedSelector(element) {\n let maybeSelector;\n if (!(element.value instanceof Paren)) {\n return null;\n }\n\n maybeSelector = element.value.value;\n if (!(maybeSelector instanceof Selector)) {\n return null;\n }\n\n return maybeSelector;\n }\n\n // the elements from the current selector so far\n currentElements = [];\n // the current list of new selectors to add to the path.\n // We will build it up. We initiate it with one empty selector as we \"multiply\" the new selectors\n // by the parents\n newSelectors = [\n []\n ];\n\n for (i = 0; (el = inSelector.elements[i]); i++) {\n // non parent reference elements just get added\n if (el.value !== '&') {\n const nestedSelector = findNestedSelector(el);\n if (nestedSelector != null) {\n // merge the current list of non parent selector elements\n // on to the current list of selectors to add\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n const nestedPaths = [];\n let replaced;\n const replacedNewSelectors = [];\n replaced = replaceParentSelector(nestedPaths, context, nestedSelector);\n hadParentSelector = hadParentSelector || replaced;\n // the nestedPaths array should have only one member - replaceParentSelector does not multiply selectors\n for (k = 0; k < nestedPaths.length; k++) {\n const replacementSelector = createSelector(createParenthesis(nestedPaths[k], el), el);\n addAllReplacementsIntoPath(newSelectors, [replacementSelector], el, inSelector, replacedNewSelectors);\n }\n newSelectors = replacedNewSelectors;\n currentElements = [];\n } else {\n currentElements.push(el);\n }\n\n } else {\n hadParentSelector = true;\n // the new list of selectors to add\n selectorsMultiplied = [];\n\n // merge the current list of non parent selector elements\n // on to the current list of selectors to add\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n // loop through our current selectors\n for (j = 0; j < newSelectors.length; j++) {\n sel = newSelectors[j];\n // if we don't have any parent paths, the & might be in a mixin so that it can be used\n // whether there are parents or not\n if (context.length === 0) {\n // the combinator used on el should now be applied to the next element instead so that\n // it is not lost\n if (sel.length > 0) {\n sel[0].elements.push(new Element(el.combinator, '', el.isVariable, el._index, el._fileInfo));\n }\n selectorsMultiplied.push(sel);\n }\n else {\n // and the parent selectors\n for (k = 0; k < context.length; k++) {\n // We need to put the current selectors\n // then join the last selector's elements on to the parents selectors\n const newSelectorPath = addReplacementIntoPath(sel, context[k], el, inSelector);\n // add that to our new set of selectors\n selectorsMultiplied.push(newSelectorPath);\n }\n }\n }\n\n // our new selectors has been multiplied, so reset the state\n newSelectors = selectorsMultiplied;\n currentElements = [];\n }\n }\n\n // if we have any elements left over (e.g. .a& .b == .b)\n // add them on to all the current selectors\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n for (i = 0; i < newSelectors.length; i++) {\n length = newSelectors[i].length;\n if (length > 0) {\n paths.push(newSelectors[i]);\n lastSelector = newSelectors[i][length - 1];\n newSelectors[i][length - 1] = lastSelector.createDerived(lastSelector.elements, inSelector.extendList);\n }\n }\n\n return hadParentSelector;\n }\n\n function deriveSelector(visibilityInfo, deriveFrom) {\n const newSelector = deriveFrom.createDerived(deriveFrom.elements, deriveFrom.extendList, deriveFrom.evaldCondition);\n newSelector.copyVisibilityInfo(visibilityInfo);\n return newSelector;\n }\n\n // joinSelector code follows\n let i;\n\n let newPaths;\n let hadParentSelector;\n\n newPaths = [];\n hadParentSelector = replaceParentSelector(newPaths, context, selector);\n\n if (!hadParentSelector) {\n if (context.length > 0) {\n newPaths = [];\n for (i = 0; i < context.length; i++) {\n\n const concatenated = context[i].map(deriveSelector.bind(this, selector.visibilityInfo()));\n\n concatenated.push(selector);\n newPaths.push(concatenated);\n }\n }\n else {\n newPaths = [[selector]];\n }\n }\n\n for (i = 0; i < newPaths.length; i++) {\n paths.push(newPaths[i]);\n }\n};\n\nRuleset.prototype.type = 'Ruleset';\nRuleset.prototype.isRuleset = true;\nexport default Ruleset;\n","import Node from './node';\nimport Selector from './selector';\nimport Ruleset from './ruleset';\nimport Anonymous from './anonymous';\n\nconst AtRule = function(\n name,\n value,\n rules,\n index,\n currentFileInfo,\n debugInfo,\n isRooted,\n visibilityInfo\n) {\n let i;\n\n this.name = name;\n this.value = (value instanceof Node) ? value : (value ? new Anonymous(value) : value);\n if (rules) {\n if (Array.isArray(rules)) {\n this.rules = rules;\n } else {\n this.rules = [rules];\n this.rules[0].selectors = (new Selector([], null, null, index, currentFileInfo)).createEmptySelectors();\n }\n for (i = 0; i < this.rules.length; i++) {\n this.rules[i].allowImports = true;\n }\n this.setParent(this.rules, this);\n }\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.debugInfo = debugInfo;\n this.isRooted = isRooted || false;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n};\n\nAtRule.prototype = new Node();\n\nAtRule.prototype.accept = function(visitor) {\n const value = this.value;\n const rules = this.rules;\n if (rules) {\n this.rules = visitor.visitArray(rules);\n }\n if (value) {\n this.value = visitor.visit(value);\n }\n};\n\nAtRule.prototype.isRulesetLike = function() {\n return this.rules || !this.isCharset();\n};\n\nAtRule.prototype.isCharset = function() {\n return '@charset' === this.name;\n};\n\nAtRule.prototype.genCSS = function(context, output) {\n const value = this.value;\n const rules = this.rules;\n output.add(this.name, this.fileInfo(), this.getIndex());\n if (value) {\n output.add(' ');\n value.genCSS(context, output);\n }\n if (rules) {\n this.outputRuleset(context, output, rules);\n } else {\n output.add(';');\n }\n};\n\nAtRule.prototype.eval = function(context) {\n let mediaPathBackup;\n let mediaBlocksBackup;\n let value = this.value;\n let rules = this.rules;\n\n // media stored inside other atrule should not bubble over it\n // backpup media bubbling information\n mediaPathBackup = context.mediaPath;\n mediaBlocksBackup = context.mediaBlocks;\n // deleted media bubbling information\n context.mediaPath = [];\n context.mediaBlocks = [];\n\n if (value) {\n value = value.eval(context);\n }\n if (rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n rules = [rules[0].eval(context)];\n rules[0].root = true;\n }\n // restore media bubbling information\n context.mediaPath = mediaPathBackup;\n context.mediaBlocks = mediaBlocksBackup;\n\n return new AtRule(this.name, value, rules,\n this.getIndex(), this.fileInfo(), this.debugInfo, this.isRooted, this.visibilityInfo());\n};\n\nAtRule.prototype.variable = function(name) {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.variable.call(this.rules[0], name);\n }\n};\n\nAtRule.prototype.find = function(...args) {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.find.apply(this.rules[0], args);\n }\n};\n\nAtRule.prototype.rulesets = function() {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.rulesets.apply(this.rules[0]);\n }\n};\n\nAtRule.prototype.outputRuleset = function(context, output, rules) {\n const ruleCnt = rules.length;\n let i;\n context.tabLevel = (context.tabLevel | 0) + 1;\n\n // Compressed\n if (context.compress) {\n output.add('{');\n for (i = 0; i < ruleCnt; i++) {\n rules[i].genCSS(context, output);\n }\n output.add('}');\n context.tabLevel--;\n return;\n }\n\n // Non-compressed\n const tabSetStr = `\\n${Array(context.tabLevel).join(' ')}`;\n\n const tabRuleStr = `${tabSetStr} `;\n if (!ruleCnt) {\n output.add(` {${tabSetStr}}`);\n } else {\n output.add(` {${tabRuleStr}`);\n rules[0].genCSS(context, output);\n for (i = 1; i < ruleCnt; i++) {\n output.add(tabRuleStr);\n rules[i].genCSS(context, output);\n }\n output.add(`${tabSetStr}}`);\n }\n\n context.tabLevel--;\n};\n\nAtRule.prototype.type = 'AtRule';\nexport default AtRule;\n","import Node from './node';\nimport contexts from '../contexts';\nimport * as utils from '../utils';\n\nconst DetachedRuleset = function(ruleset, frames) {\n this.ruleset = ruleset;\n this.frames = frames;\n this.setParent(this.ruleset, this);\n};\n\nDetachedRuleset.prototype = new Node();\n\nDetachedRuleset.prototype.accept = function(visitor) {\n this.ruleset = visitor.visit(this.ruleset);\n};\n\nDetachedRuleset.prototype.eval = function(context) {\n const frames = this.frames || utils.copyArray(context.frames);\n return new DetachedRuleset(this.ruleset, frames);\n};\n\nDetachedRuleset.prototype.callEval = function(context) {\n return this.ruleset.eval(this.frames ? new contexts.Eval(context, this.frames.concat(context.frames)) : context);\n};\n\nDetachedRuleset.prototype.type = 'DetachedRuleset';\nDetachedRuleset.prototype.evalFirst = true;\nexport default DetachedRuleset;\n","import Node from './node';\nimport unitConversions from '../data/unit-conversions';\nimport * as utils from '../utils';\n\nconst Unit = function(numerator, denominator, backupUnit) {\n this.numerator = numerator ? utils.copyArray(numerator).sort() : [];\n this.denominator = denominator ? utils.copyArray(denominator).sort() : [];\n if (backupUnit) {\n this.backupUnit = backupUnit;\n } else if (numerator && numerator.length) {\n this.backupUnit = numerator[0];\n }\n};\n\nUnit.prototype = new Node();\n\nUnit.prototype.clone = function() {\n return new Unit(utils.copyArray(this.numerator), utils.copyArray(this.denominator), this.backupUnit);\n};\n\nUnit.prototype.genCSS = function(context, output) {\n // Dimension checks the unit is singular and throws an error if in strict math mode.\n const strictUnits = context && context.strictUnits;\n if (this.numerator.length === 1) {\n output.add(this.numerator[0]); // the ideal situation\n } else if (!strictUnits && this.backupUnit) {\n output.add(this.backupUnit);\n } else if (!strictUnits && this.denominator.length) {\n output.add(this.denominator[0]);\n }\n};\n\nUnit.prototype.toString = function() {\n let i;\n let returnStr = this.numerator.join('*');\n for (i = 0; i < this.denominator.length; i++) {\n returnStr += `/${this.denominator[i]}`;\n }\n return returnStr;\n};\n\nUnit.prototype.compare = function(other) {\n return this.is(other.toString()) ? 0 : undefined;\n};\n\nUnit.prototype.is = function(unitString) {\n return this.toString().toUpperCase() === unitString.toUpperCase();\n};\n\nUnit.prototype.isLength = function() {\n return RegExp('^(px|em|ex|ch|rem|in|cm|mm|pc|pt|ex|vw|vh|vmin|vmax)$', 'gi').test(this.toCSS());\n};\n\nUnit.prototype.isEmpty = function() {\n return this.numerator.length === 0 && this.denominator.length === 0;\n};\n\nUnit.prototype.isSingular = function() {\n return this.numerator.length <= 1 && this.denominator.length === 0;\n};\n\nUnit.prototype.map = function(callback) {\n let i;\n\n for (i = 0; i < this.numerator.length; i++) {\n this.numerator[i] = callback(this.numerator[i], false);\n }\n\n for (i = 0; i < this.denominator.length; i++) {\n this.denominator[i] = callback(this.denominator[i], true);\n }\n};\n\nUnit.prototype.usedUnits = function() {\n let group;\n const result = {};\n let mapUnit;\n let groupName;\n\n mapUnit = atomicUnit => {\n /* jshint loopfunc:true */\n if (group.hasOwnProperty(atomicUnit) && !result[groupName]) {\n result[groupName] = atomicUnit;\n }\n\n return atomicUnit;\n };\n\n for (groupName in unitConversions) {\n if (unitConversions.hasOwnProperty(groupName)) {\n group = unitConversions[groupName];\n\n this.map(mapUnit);\n }\n }\n\n return result;\n};\n\nUnit.prototype.cancel = function() {\n const counter = {};\n let atomicUnit;\n let i;\n\n for (i = 0; i < this.numerator.length; i++) {\n atomicUnit = this.numerator[i];\n counter[atomicUnit] = (counter[atomicUnit] || 0) + 1;\n }\n\n for (i = 0; i < this.denominator.length; i++) {\n atomicUnit = this.denominator[i];\n counter[atomicUnit] = (counter[atomicUnit] || 0) - 1;\n }\n\n this.numerator = [];\n this.denominator = [];\n\n for (atomicUnit in counter) {\n if (counter.hasOwnProperty(atomicUnit)) {\n const count = counter[atomicUnit];\n\n if (count > 0) {\n for (i = 0; i < count; i++) {\n this.numerator.push(atomicUnit);\n }\n } else if (count < 0) {\n for (i = 0; i < -count; i++) {\n this.denominator.push(atomicUnit);\n }\n }\n }\n }\n\n this.numerator.sort();\n this.denominator.sort();\n};\n\nUnit.prototype.type = 'Unit';\nexport default Unit;\n","import Node from './node';\nimport unitConversions from '../data/unit-conversions';\nimport Unit from './unit';\nimport Color from './color';\n\n//\n// A number with a unit\n//\nconst Dimension = function(value, unit) {\n this.value = parseFloat(value);\n if (isNaN(this.value)) {\n throw new Error('Dimension is not a number.');\n }\n this.unit = (unit && unit instanceof Unit) ? unit :\n new Unit(unit ? [unit] : undefined);\n this.setParent(this.unit, this);\n};\n\nDimension.prototype = new Node();\n\nDimension.prototype.accept = function(visitor) {\n this.unit = visitor.visit(this.unit);\n};\n\nDimension.prototype.eval = function(context) {\n return this;\n};\n\nDimension.prototype.toColor = function() {\n return new Color([this.value, this.value, this.value]);\n};\n\nDimension.prototype.genCSS = function(context, output) {\n if ((context && context.strictUnits) && !this.unit.isSingular()) {\n throw new Error(`Multiple units in dimension. Correct the units or use the unit function. Bad unit: ${this.unit.toString()}`);\n }\n\n const value = this.fround(context, this.value);\n let strValue = String(value);\n\n if (value !== 0 && value < 0.000001 && value > -0.000001) {\n // would be output 1e-6 etc.\n strValue = value.toFixed(20).replace(/0+$/, '');\n }\n\n if (context && context.compress) {\n // Zero values doesn't need a unit\n if (value === 0 && this.unit.isLength()) {\n output.add(strValue);\n return;\n }\n\n // Float values doesn't need a leading zero\n if (value > 0 && value < 1) {\n strValue = (strValue).substr(1);\n }\n }\n\n output.add(strValue);\n this.unit.genCSS(context, output);\n};\n\n// In an operation between two Dimensions,\n// we default to the first Dimension's unit,\n// so `1px + 2` will yield `3px`.\nDimension.prototype.operate = function(context, op, other) {\n /* jshint noempty:false */\n let value = this._operate(context, op, this.value, other.value);\n\n let unit = this.unit.clone();\n\n if (op === '+' || op === '-') {\n if (unit.numerator.length === 0 && unit.denominator.length === 0) {\n unit = other.unit.clone();\n if (this.unit.backupUnit) {\n unit.backupUnit = this.unit.backupUnit;\n }\n } else if (other.unit.numerator.length === 0 && unit.denominator.length === 0) {\n // do nothing\n } else {\n other = other.convertTo(this.unit.usedUnits());\n\n if (context.strictUnits && other.unit.toString() !== unit.toString()) {\n throw new Error(`Incompatible units. Change the units or use the unit function. ` + \n `Bad units: '${unit.toString()}' and '${other.unit.toString()}'.`);\n }\n\n value = this._operate(context, op, this.value, other.value);\n }\n } else if (op === '*') {\n unit.numerator = unit.numerator.concat(other.unit.numerator).sort();\n unit.denominator = unit.denominator.concat(other.unit.denominator).sort();\n unit.cancel();\n } else if (op === '/') {\n unit.numerator = unit.numerator.concat(other.unit.denominator).sort();\n unit.denominator = unit.denominator.concat(other.unit.numerator).sort();\n unit.cancel();\n }\n return new Dimension(value, unit);\n};\n\nDimension.prototype.compare = function(other) {\n let a;\n let b;\n\n if (!(other instanceof Dimension)) {\n return undefined;\n }\n\n if (this.unit.isEmpty() || other.unit.isEmpty()) {\n a = this;\n b = other;\n } else {\n a = this.unify();\n b = other.unify();\n if (a.unit.compare(b.unit) !== 0) {\n return undefined;\n }\n }\n\n return Node.numericCompare(a.value, b.value);\n};\n\nDimension.prototype.unify = function() {\n return this.convertTo({ length: 'px', duration: 's', angle: 'rad' });\n};\n\nDimension.prototype.convertTo = function(conversions) {\n let value = this.value;\n const unit = this.unit.clone();\n let i;\n let groupName;\n let group;\n let targetUnit;\n let derivedConversions = {};\n let applyUnit;\n\n if (typeof conversions === 'string') {\n for (i in unitConversions) {\n if (unitConversions[i].hasOwnProperty(conversions)) {\n derivedConversions = {};\n derivedConversions[i] = conversions;\n }\n }\n conversions = derivedConversions;\n }\n applyUnit = (atomicUnit, denominator) => {\n /* jshint loopfunc:true */\n if (group.hasOwnProperty(atomicUnit)) {\n if (denominator) {\n value = value / (group[atomicUnit] / group[targetUnit]);\n } else {\n value = value * (group[atomicUnit] / group[targetUnit]);\n }\n\n return targetUnit;\n }\n\n return atomicUnit;\n };\n\n for (groupName in conversions) {\n if (conversions.hasOwnProperty(groupName)) {\n targetUnit = conversions[groupName];\n group = unitConversions[groupName];\n\n unit.map(applyUnit);\n }\n }\n\n unit.cancel();\n\n return new Dimension(value, unit);\n};\n\nDimension.prototype.type = 'Dimension';\nexport default Dimension;\n","import Node from './node';\nimport Color from './color';\nimport Dimension from './dimension';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\nconst Operation = function(op, operands, isSpaced) {\n this.op = op.trim();\n this.operands = operands;\n this.isSpaced = isSpaced;\n};\n\nOperation.prototype = new Node();\n\nOperation.prototype.accept = function(visitor) {\n this.operands = visitor.visitArray(this.operands);\n}\n\nOperation.prototype.eval = function(context) {\n let a = this.operands[0].eval(context);\n let b = this.operands[1].eval(context);\n let op;\n\n if (context.isMathOn(this.op)) {\n op = this.op === './' ? '/' : this.op;\n if (a instanceof Dimension && b instanceof Color) {\n a = a.toColor();\n }\n if (b instanceof Dimension && a instanceof Color) {\n b = b.toColor();\n }\n if (!a.operate) {\n if (a instanceof Operation && a.op === '/' && context.math === MATH.PARENS_DIVISION) {\n return new Operation(this.op, [a, b], this.isSpaced);\n }\n throw { type: 'Operation',\n message: 'Operation on an invalid type' };\n }\n\n return a.operate(context, op, b);\n } else {\n return new Operation(this.op, [a, b], this.isSpaced);\n }\n};\n\nOperation.prototype.genCSS = function(context, output) {\n this.operands[0].genCSS(context, output);\n if (this.isSpaced) {\n output.add(' ');\n }\n output.add(this.op);\n if (this.isSpaced) {\n output.add(' ');\n }\n this.operands[1].genCSS(context, output);\n};\n\nOperation.prototype.type = 'Operation';\nexport default Operation;\n","import Node from './node';\nimport Paren from './paren';\nimport Comment from './comment';\nimport Dimension from './dimension';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\nconst Expression = function(value, noSpacing) {\n this.value = value;\n this.noSpacing = noSpacing;\n if (!value) {\n throw new Error('Expression requires an array parameter');\n }\n};\n\nExpression.prototype = new Node();\n\nExpression.prototype.accept = function(visitor) {\n this.value = visitor.visitArray(this.value);\n};\n\nExpression.prototype.eval = function(context) {\n let returnValue;\n const mathOn = context.isMathOn();\n\n const inParenthesis = this.parens && \n (context.math !== MATH.STRICT_LEGACY || !this.parensInOp);\n\n let doubleParen = false;\n if (inParenthesis) {\n context.inParenthesis();\n }\n if (this.value.length > 1) {\n returnValue = new Expression(this.value.map(e => {\n if (!e.eval) {\n return e;\n }\n return e.eval(context);\n }), this.noSpacing);\n } else if (this.value.length === 1) {\n if (this.value[0].parens && !this.value[0].parensInOp && !context.inCalc) {\n doubleParen = true;\n }\n returnValue = this.value[0].eval(context);\n } else {\n returnValue = this;\n }\n if (inParenthesis) {\n context.outOfParenthesis();\n }\n if (this.parens && this.parensInOp && !mathOn && !doubleParen \n && (!(returnValue instanceof Dimension))) {\n returnValue = new Paren(returnValue);\n }\n return returnValue;\n};\n\nExpression.prototype.genCSS = function(context, output) {\n for (let i = 0; i < this.value.length; i++) {\n this.value[i].genCSS(context, output);\n if (!this.noSpacing && i + 1 < this.value.length) {\n output.add(' ');\n }\n }\n};\n\nExpression.prototype.throwAwayComments = function() {\n this.value = this.value.filter(v => !(v instanceof Comment));\n};\n\nExpression.prototype.type = 'Expression';\nexport default Expression;\n","import Expression from '../tree/expression';\n\nclass functionCaller {\n constructor(name, context, index, currentFileInfo) {\n this.name = name.toLowerCase();\n this.index = index;\n this.context = context;\n this.currentFileInfo = currentFileInfo;\n\n this.func = context.frames[0].functionRegistry.get(this.name);\n }\n\n isValid() {\n return Boolean(this.func);\n }\n\n call(args) {\n const evalArgs = this.func.evalArgs;\n if (evalArgs !== false) {\n args = args.map(a => a.eval(this.context));\n }\n // This code is terrible and should be replaced as per this issue...\n // https://github.com/less/less.js/issues/2477\n if (Array.isArray(args)) {\n args = args.filter(item => {\n if (item.type === 'Comment') {\n return false;\n }\n return true;\n })\n .map(item => {\n if (item.type === 'Expression') {\n const subNodes = item.value.filter(item => {\n if (item.type === 'Comment') {\n return false;\n }\n return true;\n });\n if (subNodes.length === 1) {\n return subNodes[0];\n } else {\n return new Expression(subNodes);\n }\n }\n return item;\n });\n }\n\n if (evalArgs === false) {\n return this.func(this.context, ...args);\n }\n\n return this.func(...args);\n }\n}\n\nexport default functionCaller;\n","import Node from './node';\nimport Anonymous from './anonymous';\nimport FunctionCaller from '../functions/function-caller';\n\n//\n// A function call node.\n//\nconst Call = function(name, args, index, currentFileInfo) {\n this.name = name;\n this.args = args;\n this.calc = name === 'calc';\n this._index = index;\n this._fileInfo = currentFileInfo;\n}\n\nCall.prototype = new Node();\n\nCall.prototype.accept = function(visitor) {\n if (this.args) {\n this.args = visitor.visitArray(this.args);\n }\n};\n\n//\n// When evaluating a function call,\n// we either find the function in the functionRegistry,\n// in which case we call it, passing the evaluated arguments,\n// if this returns null or we cannot find the function, we\n// simply print it out as it appeared originally [2].\n//\n// The reason why we evaluate the arguments, is in the case where\n// we try to pass a variable to a function, like: `saturate(@color)`.\n// The function should receive the value, not the variable.\n//\nCall.prototype.eval = function(context) {\n /**\n * Turn off math for calc(), and switch back on for evaluating nested functions\n */\n const currentMathContext = context.mathOn;\n context.mathOn = !this.calc;\n if (this.calc || context.inCalc) {\n context.enterCalc();\n }\n\n const exitCalc = () => {\n if (this.calc || context.inCalc) {\n context.exitCalc();\n }\n context.mathOn = currentMathContext;\n };\n\n let result;\n const funcCaller = new FunctionCaller(this.name, context, this.getIndex(), this.fileInfo());\n\n if (funcCaller.isValid()) {\n try {\n result = funcCaller.call(this.args);\n exitCalc();\n } catch (e) {\n if (e.hasOwnProperty('line') && e.hasOwnProperty('column')) {\n throw e\n }\n throw { \n type: e.type || 'Runtime',\n message: `error evaluating function \\`${this.name}\\`${e.message ? `: ${e.message}` : ''}`,\n index: this.getIndex(), \n filename: this.fileInfo().filename,\n line: e.lineNumber,\n column: e.columnNumber\n };\n }\n\n if (result !== null && result !== undefined) {\n // Results that that are not nodes are cast as Anonymous nodes\n // Falsy values or booleans are returned as empty nodes\n if (!(result instanceof Node)) {\n if (!result || result === true) {\n result = new Anonymous(null); \n }\n else {\n result = new Anonymous(result.toString()); \n }\n \n }\n result._index = this._index;\n result._fileInfo = this._fileInfo;\n return result;\n }\n }\n\n const args = this.args.map(a => a.eval(context));\n exitCalc();\n\n return new Call(this.name, args, this.getIndex(), this.fileInfo());\n};\n\nCall.prototype.genCSS = function(context, output) {\n output.add(`${this.name}(`, this.fileInfo(), this.getIndex());\n\n for (let i = 0; i < this.args.length; i++) {\n this.args[i].genCSS(context, output);\n if (i + 1 < this.args.length) {\n output.add(', ');\n }\n }\n\n output.add(')');\n};\n\nCall.prototype.type = 'Call';\nexport default Call;\n","import Node from './node';\nimport Call from './call';\n\nconst Variable = function(name, index, currentFileInfo) {\n this.name = name;\n this._index = index;\n this._fileInfo = currentFileInfo;\n};\n\nVariable.prototype = new Node();\n\nVariable.prototype.eval = function(context) {\n let variable;\n let name = this.name;\n\n if (name.indexOf('@@') === 0) {\n name = `@${new Variable(name.slice(1), this.getIndex(), this.fileInfo()).eval(context).value}`;\n }\n\n if (this.evaluating) {\n throw { type: 'Name',\n message: `Recursive variable definition for ${name}`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n this.evaluating = true;\n\n variable = this.find(context.frames, frame => {\n const v = frame.variable(name);\n if (v) {\n if (v.important) {\n const importantScope = context.importantScope[context.importantScope.length - 1];\n importantScope.important = v.important;\n }\n // If in calc, wrap vars in a function call to cascade evaluate args first\n if (context.inCalc) {\n return (new Call('_SELF', [v.value])).eval(context);\n }\n else {\n return v.value.eval(context);\n }\n }\n });\n if (variable) {\n this.evaluating = false;\n return variable;\n } else {\n throw { type: 'Name',\n message: `variable ${name} is undefined`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n};\n\nVariable.prototype.find = function(obj, fun) {\n for (let i = 0, r; i < obj.length; i++) {\n r = fun.call(obj, obj[i]);\n if (r) { return r; }\n }\n return null;\n};\n\nVariable.prototype.type = 'Variable';\nexport default Variable;\n","import Node from './node';\nimport Declaration from './declaration';\n\nconst Property = function(name, index, currentFileInfo) {\n this.name = name;\n this._index = index;\n this._fileInfo = currentFileInfo;\n};\n\nProperty.prototype = new Node();\n\nProperty.prototype.eval = function(context) {\n let property;\n const name = this.name;\n // TODO: shorten this reference\n const mergeRules = context.pluginManager.less.visitors.ToCSSVisitor.prototype._mergeRules;\n\n if (this.evaluating) {\n throw { type: 'Name',\n message: `Recursive property reference for ${name}`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n this.evaluating = true;\n\n property = this.find(context.frames, frame => {\n let v;\n const vArr = frame.property(name);\n if (vArr) {\n for (let i = 0; i < vArr.length; i++) {\n v = vArr[i];\n\n vArr[i] = new Declaration(v.name,\n v.value,\n v.important,\n v.merge,\n v.index,\n v.currentFileInfo,\n v.inline,\n v.variable\n );\n }\n mergeRules(vArr);\n\n v = vArr[vArr.length - 1];\n if (v.important) {\n const importantScope = context.importantScope[context.importantScope.length - 1];\n importantScope.important = v.important;\n }\n v = v.value.eval(context);\n return v;\n }\n });\n if (property) {\n this.evaluating = false;\n return property;\n } else {\n throw { type: 'Name',\n message: `Property '${name}' is undefined`,\n filename: this.currentFileInfo.filename,\n index: this.index };\n }\n};\n\nProperty.prototype.find = function(obj, fun) {\n for (let i = 0, r; i < obj.length; i++) {\n r = fun.call(obj, obj[i]);\n if (r) { return r; }\n }\n return null;\n};\n\nProperty.prototype.type = 'Property';\nexport default Property;\n","import Node from './node';\n\nconst Attribute = function(key, op, value) {\n this.key = key;\n this.op = op;\n this.value = value;\n};\n\nAttribute.prototype = new Node();\n\nAttribute.prototype.eval = function(context) {\n return new Attribute(this.key.eval ? this.key.eval(context) : this.key,\n this.op, (this.value && this.value.eval) ? this.value.eval(context) : this.value);\n};\n\nAttribute.prototype.genCSS = function(context, output) {\n output.add(this.toCSS(context));\n};\n\nAttribute.prototype.toCSS = function(context) {\n let value = this.key.toCSS ? this.key.toCSS(context) : this.key;\n\n if (this.op) {\n value += this.op;\n value += (this.value.toCSS ? this.value.toCSS(context) : this.value);\n }\n\n return `[${value}]`;\n};\n\nAttribute.prototype.type = 'Attribute';\nexport default Attribute;\n","import Node from './node';\nimport Variable from './variable';\nimport Property from './property';\n\nconst Quoted = function(str, content, escaped, index, currentFileInfo) {\n this.escaped = (escaped == null) ? true : escaped;\n this.value = content || '';\n this.quote = str.charAt(0);\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.variableRegex = /@\\{([\\w-]+)\\}/g;\n this.propRegex = /\\$\\{([\\w-]+)\\}/g;\n this.allowRoot = escaped;\n};\n\nQuoted.prototype = new Node();\n\nQuoted.prototype.genCSS = function(context, output) {\n if (!this.escaped) {\n output.add(this.quote, this.fileInfo(), this.getIndex());\n }\n output.add(this.value);\n if (!this.escaped) {\n output.add(this.quote);\n }\n};\n\nQuoted.prototype.containsVariables = function() {\n return this.value.match(this.variableRegex);\n};\n\nQuoted.prototype.eval = function(context) {\n const that = this;\n let value = this.value;\n const variableReplacement = (_, name) => {\n const v = new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context, true);\n return (v instanceof Quoted) ? v.value : v.toCSS();\n };\n const propertyReplacement = (_, name) => {\n const v = new Property(`$${name}`, that.getIndex(), that.fileInfo()).eval(context, true);\n return (v instanceof Quoted) ? v.value : v.toCSS();\n };\n function iterativeReplace(value, regexp, replacementFnc) {\n let evaluatedValue = value;\n do {\n value = evaluatedValue.toString();\n evaluatedValue = value.replace(regexp, replacementFnc);\n } while (value !== evaluatedValue);\n return evaluatedValue;\n }\n value = iterativeReplace(value, this.variableRegex, variableReplacement);\n value = iterativeReplace(value, this.propRegex, propertyReplacement);\n\n return new Quoted(this.quote + value + this.quote, value, this.escaped, this.getIndex(), this.fileInfo());\n};\n\nQuoted.prototype.compare = function(other) {\n // when comparing quoted strings allow the quote to differ\n if (other.type === 'Quoted' && !this.escaped && !other.escaped) {\n return Node.numericCompare(this.value, other.value);\n } else {\n return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined;\n }\n};\n\nQuoted.prototype.type = 'Quoted';\nexport default Quoted;\n","import Node from './node';\n\nconst URL = function(val, index, currentFileInfo, isEvald) {\n this.value = val;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.isEvald = isEvald;\n};\n\nURL.prototype = new Node();\n\nURL.prototype.accept = function(visitor) {\n this.value = visitor.visit(this.value);\n};\n\nURL.prototype.genCSS = function(context, output) {\n output.add('url(');\n this.value.genCSS(context, output);\n output.add(')');\n};\n\nURL.prototype.eval = function(context) {\n const val = this.value.eval(context);\n let rootpath;\n\n if (!this.isEvald) {\n // Add the rootpath if the URL requires a rewrite\n rootpath = this.fileInfo() && this.fileInfo().rootpath;\n if (typeof rootpath === 'string' &&\n typeof val.value === 'string' &&\n context.pathRequiresRewrite(val.value)) {\n if (!val.quote) {\n rootpath = escapePath(rootpath);\n }\n val.value = context.rewritePath(val.value, rootpath);\n } else {\n val.value = context.normalizePath(val.value);\n }\n\n // Add url args if enabled\n if (context.urlArgs) {\n if (!val.value.match(/^\\s*data:/)) {\n const delimiter = val.value.indexOf('?') === -1 ? '?' : '&';\n const urlArgs = delimiter + context.urlArgs;\n if (val.value.indexOf('#') !== -1) {\n val.value = val.value.replace('#', `${urlArgs}#`);\n } else {\n val.value += urlArgs;\n }\n }\n }\n }\n\n return new URL(val, this.getIndex(), this.fileInfo(), true);\n};\n\nURL.prototype.type = 'Url';\n\nfunction escapePath(path) {\n return path.replace(/[\\(\\)'\"\\s]/g, match => `\\\\${match}`);\n}\n\nexport default URL;\n","import Ruleset from './ruleset';\nimport Value from './value';\nimport Selector from './selector';\nimport Anonymous from './anonymous';\nimport Expression from './expression';\nimport AtRule from './atrule';\nimport * as utils from '../utils';\n\nconst Media = function(value, features, index, currentFileInfo, visibilityInfo) {\n this._index = index;\n this._fileInfo = currentFileInfo;\n\n const selectors = (new Selector([], null, null, this._index, this._fileInfo)).createEmptySelectors();\n\n this.features = new Value(features);\n this.rules = [new Ruleset(selectors, value)];\n this.rules[0].allowImports = true;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n this.setParent(selectors, this);\n this.setParent(this.features, this);\n this.setParent(this.rules, this);\n}\n\nMedia.prototype = new AtRule();\n\nMedia.prototype.isRulesetLike = function() {\n return true;\n};\n\nMedia.prototype.accept = function(visitor) {\n if (this.features) {\n this.features = visitor.visit(this.features);\n }\n if (this.rules) {\n this.rules = visitor.visitArray(this.rules);\n }\n};\n\nMedia.prototype.genCSS = function(context, output) {\n output.add('@media ', this._fileInfo, this._index);\n this.features.genCSS(context, output);\n this.outputRuleset(context, output, this.rules);\n};\n\nMedia.prototype.eval = function(context) {\n if (!context.mediaBlocks) {\n context.mediaBlocks = [];\n context.mediaPath = [];\n }\n\n const media = new Media(null, [], this._index, this._fileInfo, this.visibilityInfo());\n if (this.debugInfo) {\n this.rules[0].debugInfo = this.debugInfo;\n media.debugInfo = this.debugInfo;\n }\n \n media.features = this.features.eval(context);\n\n context.mediaPath.push(media);\n context.mediaBlocks.push(media);\n\n this.rules[0].functionRegistry = context.frames[0].functionRegistry.inherit();\n context.frames.unshift(this.rules[0]);\n media.rules = [this.rules[0].eval(context)];\n context.frames.shift();\n\n context.mediaPath.pop();\n\n return context.mediaPath.length === 0 ? media.evalTop(context) :\n media.evalNested(context);\n};\n\nMedia.prototype.evalTop = function(context) {\n let result = this;\n\n // Render all dependent Media blocks.\n if (context.mediaBlocks.length > 1) {\n const selectors = (new Selector([], null, null, this.getIndex(), this.fileInfo())).createEmptySelectors();\n result = new Ruleset(selectors, context.mediaBlocks);\n result.multiMedia = true;\n result.copyVisibilityInfo(this.visibilityInfo());\n this.setParent(result, this);\n }\n\n delete context.mediaBlocks;\n delete context.mediaPath;\n\n return result;\n};\n\nMedia.prototype.evalNested = function(context) {\n let i;\n let value;\n const path = context.mediaPath.concat([this]);\n\n // Extract the media-query conditions separated with `,` (OR).\n for (i = 0; i < path.length; i++) {\n value = path[i].features instanceof Value ?\n path[i].features.value : path[i].features;\n path[i] = Array.isArray(value) ? value : [value];\n }\n\n // Trace all permutations to generate the resulting media-query.\n //\n // (a, b and c) with nested (d, e) ->\n // a and d\n // a and e\n // b and c and d\n // b and c and e\n this.features = new Value(this.permute(path).map(path => {\n path = path.map(fragment => fragment.toCSS ? fragment : new Anonymous(fragment));\n\n for (i = path.length - 1; i > 0; i--) {\n path.splice(i, 0, new Anonymous('and'));\n }\n\n return new Expression(path);\n }));\n this.setParent(this.features, this);\n\n // Fake a tree-node that doesn't output anything.\n return new Ruleset([], []);\n};\n\nMedia.prototype.permute = function(arr) {\n if (arr.length === 0) {\n return [];\n } else if (arr.length === 1) {\n return arr[0];\n } else {\n const result = [];\n const rest = this.permute(arr.slice(1));\n for (let i = 0; i < rest.length; i++) {\n for (let j = 0; j < arr[0].length; j++) {\n result.push([arr[0][j]].concat(rest[i]));\n }\n }\n return result;\n }\n};\n\nMedia.prototype.bubbleSelectors = function(selectors) {\n if (!selectors) {\n return;\n }\n this.rules = [new Ruleset(utils.copyArray(selectors), [this.rules[0]])];\n this.setParent(this.rules, this);\n};\n\nMedia.prototype.type = 'Media';\nexport default Media;\n","import Node from './node';\nimport Media from './media';\nimport URL from './url';\nimport Quoted from './quoted';\nimport Ruleset from './ruleset';\nimport Anonymous from './anonymous';\nimport * as utils from '../utils';\nimport LessError from '../less-error';\n\n//\n// CSS @import node\n//\n// The general strategy here is that we don't want to wait\n// for the parsing to be completed, before we start importing\n// the file. That's because in the context of a browser,\n// most of the time will be spent waiting for the server to respond.\n//\n// On creation, we push the import path to our import queue, though\n// `import,push`, we also pass it a callback, which it'll call once\n// the file has been fetched, and parsed.\n//\nconst Import = function(path, features, options, index, currentFileInfo, visibilityInfo) {\n this.options = options;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.path = path;\n this.features = features;\n this.allowRoot = true;\n\n if (this.options.less !== undefined || this.options.inline) {\n this.css = !this.options.less || this.options.inline;\n } else {\n const pathValue = this.getPath();\n if (pathValue && /[#\\.\\&\\?]css([\\?;].*)?$/.test(pathValue)) {\n this.css = true;\n }\n }\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.features, this);\n this.setParent(this.path, this);\n}\n\nImport.prototype = new Node();\n\nImport.prototype.accept = function(visitor) {\n if (this.features) {\n this.features = visitor.visit(this.features);\n }\n this.path = visitor.visit(this.path);\n if (!this.options.isPlugin && !this.options.inline && this.root) {\n this.root = visitor.visit(this.root);\n }\n};\n\nImport.prototype.genCSS = function(context, output) {\n if (this.css && this.path._fileInfo.reference === undefined) {\n output.add('@import ', this._fileInfo, this._index);\n this.path.genCSS(context, output);\n if (this.features) {\n output.add(' ');\n this.features.genCSS(context, output);\n }\n output.add(';');\n }\n};\n\nImport.prototype.getPath = function() {\n return (this.path instanceof URL) ?\n this.path.value.value : this.path.value;\n};\n\nImport.prototype.isVariableImport = function() {\n let path = this.path;\n if (path instanceof URL) {\n path = path.value;\n }\n if (path instanceof Quoted) {\n return path.containsVariables();\n }\n\n return true;\n};\n\nImport.prototype.evalForImport = function(context) {\n let path = this.path;\n\n if (path instanceof URL) {\n path = path.value;\n }\n\n return new Import(path.eval(context), this.features, this.options, this._index, this._fileInfo, this.visibilityInfo());\n};\n\nImport.prototype.evalPath = function(context) {\n const path = this.path.eval(context);\n const fileInfo = this._fileInfo;\n\n if (!(path instanceof URL)) {\n // Add the rootpath if the URL requires a rewrite\n const pathValue = path.value;\n if (fileInfo &&\n pathValue &&\n context.pathRequiresRewrite(pathValue)) {\n path.value = context.rewritePath(pathValue, fileInfo.rootpath);\n } else {\n path.value = context.normalizePath(path.value);\n }\n }\n\n return path;\n};\n\nImport.prototype.eval = function(context) {\n const result = this.doEval(context);\n if (this.options.reference || this.blocksVisibility()) {\n if (result.length || result.length === 0) {\n result.forEach(node => {\n node.addVisibilityBlock();\n }\n );\n } else {\n result.addVisibilityBlock();\n }\n }\n return result;\n};\n\nImport.prototype.doEval = function(context) {\n let ruleset;\n let registry;\n const features = this.features && this.features.eval(context);\n\n if (this.options.isPlugin) {\n if (this.root && this.root.eval) {\n try {\n this.root.eval(context);\n }\n catch (e) {\n e.message = 'Plugin error during evaluation';\n throw new LessError(e, this.root.imports, this.root.filename);\n }\n }\n registry = context.frames[0] && context.frames[0].functionRegistry;\n if ( registry && this.root && this.root.functions ) {\n registry.addMultiple( this.root.functions );\n }\n\n return [];\n }\n\n if (this.skip) {\n if (typeof this.skip === 'function') {\n this.skip = this.skip();\n }\n if (this.skip) {\n return [];\n }\n }\n if (this.options.inline) {\n const contents = new Anonymous(this.root, 0,\n {\n filename: this.importedFilename,\n reference: this.path._fileInfo && this.path._fileInfo.reference\n }, true, true);\n\n return this.features ? new Media([contents], this.features.value) : [contents];\n } else if (this.css) {\n const newImport = new Import(this.evalPath(context), features, this.options, this._index);\n if (!newImport.css && this.error) {\n throw this.error;\n }\n return newImport;\n } else if (this.root) {\n ruleset = new Ruleset(null, utils.copyArray(this.root.rules));\n ruleset.evalImports(context);\n\n return this.features ? new Media(ruleset.rules, this.features.value) : ruleset.rules;\n } else {\n return [];\n }\n};\n\nImport.prototype.type = 'Import';\nexport default Import;\n","import Node from './node';\nimport Variable from './variable';\n\nconst JsEvalNode = function() {};\n\nJsEvalNode.prototype = new Node();\n\nJsEvalNode.prototype.evaluateJavaScript = function(expression, context) {\n let result;\n const that = this;\n const evalContext = {};\n\n if (!context.javascriptEnabled) {\n throw { message: 'Inline JavaScript is not enabled. Is it set in your options?',\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n expression = expression.replace(/@\\{([\\w-]+)\\}/g, (_, name) => that.jsify(new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context)));\n\n try {\n expression = new Function(`return (${expression})`);\n } catch (e) {\n throw { message: `JavaScript evaluation error: ${e.message} from \\`${expression}\\`` ,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n const variables = context.frames[0].variables();\n for (const k in variables) {\n if (variables.hasOwnProperty(k)) {\n /* jshint loopfunc:true */\n evalContext[k.slice(1)] = {\n value: variables[k].value,\n toJS: function () {\n return this.value.eval(context).toCSS();\n }\n };\n }\n }\n\n try {\n result = expression.call(evalContext);\n } catch (e) {\n throw { message: `JavaScript evaluation error: '${e.name}: ${e.message.replace(/[\"]/g, '\\'')}'` ,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n return result;\n};\n\nJsEvalNode.prototype.jsify = function(obj) {\n if (Array.isArray(obj.value) && (obj.value.length > 1)) {\n return `[${obj.value.map(v => v.toCSS()).join(', ')}]`;\n } else {\n return obj.toCSS();\n }\n};\n\nexport default JsEvalNode;\n","import JsEvalNode from './js-eval-node';\nimport Dimension from './dimension';\nimport Quoted from './quoted';\nimport Anonymous from './anonymous';\n\nconst JavaScript = function(string, escaped, index, currentFileInfo) {\n this.escaped = escaped;\n this.expression = string;\n this._index = index;\n this._fileInfo = currentFileInfo;\n};\n\nJavaScript.prototype = new JsEvalNode();\n\nJavaScript.prototype.eval = function(context) {\n const result = this.evaluateJavaScript(this.expression, context);\n const type = typeof result;\n\n if (type === 'number' && !isNaN(result)) {\n return new Dimension(result);\n } else if (type === 'string') {\n return new Quoted(`\"${result}\"`, result, this.escaped, this._index);\n } else if (Array.isArray(result)) {\n return new Anonymous(result.join(', '));\n } else {\n return new Anonymous(result);\n }\n};\n\nJavaScript.prototype.type = 'JavaScript';\nexport default JavaScript;\n","import Node from './node';\n\nconst Assignment = function(key, val) {\n this.key = key;\n this.value = val;\n};\n\nAssignment.prototype = new Node();\n\nAssignment.prototype.accept = function(visitor) {\n this.value = visitor.visit(this.value);\n};\n\nAssignment.prototype.eval = function(context) {\n if (this.value.eval) {\n return new Assignment(this.key, this.value.eval(context));\n }\n return this;\n};\n\nAssignment.prototype.genCSS = function(context, output) {\n output.add(`${this.key}=`);\n if (this.value.genCSS) {\n this.value.genCSS(context, output);\n } else {\n output.add(this.value);\n }\n};\n\nAssignment.prototype.type = 'Assignment';\nexport default Assignment;\n","import Node from './node';\n\nconst Condition = function(op, l, r, i, negate) {\n this.op = op.trim();\n this.lvalue = l;\n this.rvalue = r;\n this._index = i;\n this.negate = negate;\n};\n\nCondition.prototype = new Node();\n\nCondition.prototype.accept = function(visitor) {\n this.lvalue = visitor.visit(this.lvalue);\n this.rvalue = visitor.visit(this.rvalue);\n}\n\nCondition.prototype.eval = function(context) {\n const result = ((op, a, b) => {\n switch (op) {\n case 'and': return a && b;\n case 'or': return a || b;\n default:\n switch (Node.compare(a, b)) {\n case -1:\n return op === '<' || op === '=<' || op === '<=';\n case 0:\n return op === '=' || op === '>=' || op === '=<' || op === '<=';\n case 1:\n return op === '>' || op === '>=';\n default:\n return false;\n }\n }\n })(this.op, this.lvalue.eval(context), this.rvalue.eval(context));\n\n return this.negate ? !result : result;\n};\n\nCondition.prototype.type = 'Condition';\nexport default Condition;\n","import Node from './node';\n\nconst UnicodeDescriptor = function(value) {\n this.value = value;\n}\n\nUnicodeDescriptor.prototype = new Node();\nUnicodeDescriptor.prototype.type = 'UnicodeDescriptor';\n\nexport default UnicodeDescriptor;\n","import Node from './node';\nimport Operation from './operation';\nimport Dimension from './dimension';\n\nconst Negative = function(node) {\n this.value = node;\n}\n\nNegative.prototype = new Node();\n\nNegative.prototype.genCSS = function(context, output) {\n output.add('-');\n this.value.genCSS(context, output);\n};\n\nNegative.prototype.eval = function(context) {\n if (context.isMathOn()) {\n return (new Operation('*', [new Dimension(-1), this.value])).eval(context);\n }\n return new Negative(this.value.eval(context));\n};\n\nNegative.prototype.type = 'Negative';\nexport default Negative;\n","import Node from './node';\nimport Selector from './selector';\n\nconst Extend = function(selector, option, index, currentFileInfo, visibilityInfo) {\n this.selector = selector;\n this.option = option;\n this.object_id = Extend.next_id++;\n this.parent_ids = [this.object_id];\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n\n switch (option) {\n case 'all':\n this.allowBefore = true;\n this.allowAfter = true;\n break;\n default:\n this.allowBefore = false;\n this.allowAfter = false;\n break;\n }\n this.setParent(this.selector, this);\n};\n\nExtend.prototype = new Node();\n\nExtend.prototype.accept = function(visitor) {\n this.selector = visitor.visit(this.selector);\n};\n\nExtend.prototype.eval = function(context) {\n return new Extend(this.selector.eval(context), this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n};\n\nExtend.prototype.clone = function(context) {\n return new Extend(this.selector, this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n};\n\n// it concatenates (joins) all selectors in selector array\nExtend.prototype.findSelfSelectors = function(selectors) {\n let selfElements = [];\n let i;\n let selectorElements;\n\n for (i = 0; i < selectors.length; i++) {\n selectorElements = selectors[i].elements;\n // duplicate the logic in genCSS function inside the selector node.\n // future TODO - move both logics into the selector joiner visitor\n if (i > 0 && selectorElements.length && selectorElements[0].combinator.value === '') {\n selectorElements[0].combinator.value = ' ';\n }\n selfElements = selfElements.concat(selectors[i].elements);\n }\n\n this.selfSelectors = [new Selector(selfElements)];\n this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo());\n};\n\n/**\n * Used with the extend visitor\n */\nExtend.next_id = 0;\nExtend.prototype.type = 'Extend';\nexport default Extend;\n","import Node from './node';\nimport Variable from './variable';\nimport Ruleset from './ruleset';\nimport DetachedRuleset from './detached-ruleset';\nimport LessError from '../less-error';\n\nconst VariableCall = function(variable, index, currentFileInfo) {\n this.variable = variable;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.allowRoot = true;\n};\n\nVariableCall.prototype = new Node();\n\nVariableCall.prototype.eval = function(context) {\n let rules;\n let detachedRuleset = new Variable(this.variable, this.getIndex(), this.fileInfo()).eval(context);\n const error = new LessError({message: `Could not evaluate variable call ${this.variable}`});\n\n if (!detachedRuleset.ruleset) {\n if (detachedRuleset.rules) {\n rules = detachedRuleset;\n }\n else if (Array.isArray(detachedRuleset)) {\n rules = new Ruleset('', detachedRuleset);\n }\n else if (Array.isArray(detachedRuleset.value)) {\n rules = new Ruleset('', detachedRuleset.value);\n }\n else {\n throw error;\n }\n detachedRuleset = new DetachedRuleset(rules);\n }\n\n if (detachedRuleset.ruleset) {\n return detachedRuleset.callEval(context);\n }\n throw error;\n};\n\nVariableCall.prototype.type = 'VariableCall';\nexport default VariableCall;\n","import Node from './node';\nimport Variable from './variable';\nimport Ruleset from './ruleset';\nimport Selector from './selector';\n\nconst NamespaceValue = function(ruleCall, lookups, index, fileInfo) {\n this.value = ruleCall;\n this.lookups = lookups;\n this._index = index;\n this._fileInfo = fileInfo;\n}\n\nNamespaceValue.prototype = new Node();\n\nNamespaceValue.prototype.eval = function(context) {\n let i;\n let j;\n let name;\n let rules = this.value.eval(context);\n\n for (i = 0; i < this.lookups.length; i++) {\n name = this.lookups[i];\n\n /**\n * Eval'd DRs return rulesets.\n * Eval'd mixins return rules, so let's make a ruleset if we need it.\n * We need to do this because of late parsing of values\n */\n if (Array.isArray(rules)) {\n rules = new Ruleset([new Selector()], rules);\n }\n\n if (name === '') {\n rules = rules.lastDeclaration();\n }\n else if (name.charAt(0) === '@') {\n if (name.charAt(1) === '@') {\n name = `@${new Variable(name.substr(1)).eval(context).value}`;\n }\n if (rules.variables) {\n rules = rules.variable(name);\n }\n \n if (!rules) {\n throw { type: 'Name',\n message: `variable ${name} not found`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n }\n else {\n if (name.substring(0, 2) === '$@') {\n name = `$${new Variable(name.substr(1)).eval(context).value}`;\n }\n else {\n name = name.charAt(0) === '$' ? name : `$${name}`;\n }\n if (rules.properties) {\n rules = rules.property(name);\n }\n \n if (!rules) {\n throw { type: 'Name',\n message: `property \"${name.substr(1)}\" not found`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n // Properties are an array of values, since a ruleset can have multiple props.\n // We pick the last one (the \"cascaded\" value)\n rules = rules[rules.length - 1];\n }\n\n if (rules.value) {\n rules = rules.eval(context).value;\n }\n if (rules.ruleset) {\n rules = rules.ruleset.eval(context);\n }\n }\n return rules;\n};\n\nNamespaceValue.prototype.type = 'NamespaceValue';\nexport default NamespaceValue;\n","import Selector from './selector';\nimport Element from './element';\nimport Ruleset from './ruleset';\nimport Declaration from './declaration';\nimport DetachedRuleset from './detached-ruleset';\nimport Expression from './expression';\nimport contexts from '../contexts';\nimport * as utils from '../utils';\n\nconst Definition = function(name, params, rules, condition, variadic, frames, visibilityInfo) {\n this.name = name || 'anonymous mixin';\n this.selectors = [new Selector([new Element(null, name, false, this._index, this._fileInfo)])];\n this.params = params;\n this.condition = condition;\n this.variadic = variadic;\n this.arity = params.length;\n this.rules = rules;\n this._lookups = {};\n const optionalParameters = [];\n this.required = params.reduce((count, p) => {\n if (!p.name || (p.name && !p.value)) {\n return count + 1;\n }\n else {\n optionalParameters.push(p.name);\n return count;\n }\n }, 0);\n this.optionalParameters = optionalParameters;\n this.frames = frames;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n};\n\nDefinition.prototype = new Ruleset();\n\nDefinition.prototype.accept = function(visitor) {\n if (this.params && this.params.length) {\n this.params = visitor.visitArray(this.params);\n }\n this.rules = visitor.visitArray(this.rules);\n if (this.condition) {\n this.condition = visitor.visit(this.condition);\n }\n};\n\nDefinition.prototype.evalParams = function(context, mixinEnv, args, evaldArguments) {\n /* jshint boss:true */\n const frame = new Ruleset(null, null);\n\n let varargs;\n let arg;\n const params = utils.copyArray(this.params);\n let i;\n let j;\n let val;\n let name;\n let isNamedFound;\n let argIndex;\n let argsLength = 0;\n\n if (mixinEnv.frames && mixinEnv.frames[0] && mixinEnv.frames[0].functionRegistry) {\n frame.functionRegistry = mixinEnv.frames[0].functionRegistry.inherit();\n }\n mixinEnv = new contexts.Eval(mixinEnv, [frame].concat(mixinEnv.frames));\n\n if (args) {\n args = utils.copyArray(args);\n argsLength = args.length;\n\n for (i = 0; i < argsLength; i++) {\n arg = args[i];\n if (name = (arg && arg.name)) {\n isNamedFound = false;\n for (j = 0; j < params.length; j++) {\n if (!evaldArguments[j] && name === params[j].name) {\n evaldArguments[j] = arg.value.eval(context);\n frame.prependRule(new Declaration(name, arg.value.eval(context)));\n isNamedFound = true;\n break;\n }\n }\n if (isNamedFound) {\n args.splice(i, 1);\n i--;\n continue;\n } else {\n throw { type: 'Runtime', message: `Named argument for ${this.name} ${args[i].name} not found` };\n }\n }\n }\n }\n argIndex = 0;\n for (i = 0; i < params.length; i++) {\n if (evaldArguments[i]) { continue; }\n\n arg = args && args[argIndex];\n\n if (name = params[i].name) {\n if (params[i].variadic) {\n varargs = [];\n for (j = argIndex; j < argsLength; j++) {\n varargs.push(args[j].value.eval(context));\n }\n frame.prependRule(new Declaration(name, new Expression(varargs).eval(context)));\n } else {\n val = arg && arg.value;\n if (val) {\n // This was a mixin call, pass in a detached ruleset of it's eval'd rules\n if (Array.isArray(val)) {\n val = new DetachedRuleset(new Ruleset('', val));\n }\n else {\n val = val.eval(context);\n }\n } else if (params[i].value) {\n val = params[i].value.eval(mixinEnv);\n frame.resetCache();\n } else {\n throw { type: 'Runtime', message: `wrong number of arguments for ${this.name} (${argsLength} for ${this.arity})` };\n }\n\n frame.prependRule(new Declaration(name, val));\n evaldArguments[i] = val;\n }\n }\n\n if (params[i].variadic && args) {\n for (j = argIndex; j < argsLength; j++) {\n evaldArguments[j] = args[j].value.eval(context);\n }\n }\n argIndex++;\n }\n\n return frame;\n};\n\nDefinition.prototype.makeImportant = function() {\n const rules = !this.rules ? this.rules : this.rules.map(r => {\n if (r.makeImportant) {\n return r.makeImportant(true);\n } else {\n return r;\n }\n });\n const result = new Definition(this.name, this.params, rules, this.condition, this.variadic, this.frames);\n return result;\n};\n\nDefinition.prototype.eval = function(context) {\n return new Definition(this.name, this.params, this.rules, this.condition, this.variadic, this.frames || utils.copyArray(context.frames));\n};\n\nDefinition.prototype.evalCall = function(context, args, important) {\n const _arguments = [];\n const mixinFrames = this.frames ? this.frames.concat(context.frames) : context.frames;\n const frame = this.evalParams(context, new contexts.Eval(context, mixinFrames), args, _arguments);\n let rules;\n let ruleset;\n\n frame.prependRule(new Declaration('@arguments', new Expression(_arguments).eval(context)));\n\n rules = utils.copyArray(this.rules);\n\n ruleset = new Ruleset(null, rules);\n ruleset.originalRuleset = this;\n ruleset = ruleset.eval(new contexts.Eval(context, [this, frame].concat(mixinFrames)));\n if (important) {\n ruleset = ruleset.makeImportant();\n }\n return ruleset;\n};\n\nDefinition.prototype.matchCondition = function(args, context) {\n if (this.condition && !this.condition.eval(\n new contexts.Eval(context,\n [this.evalParams(context, /* the parameter variables */\n new contexts.Eval(context, this.frames ? this.frames.concat(context.frames) : context.frames), args, [])]\n .concat(this.frames || []) // the parent namespace/mixin frames\n .concat(context.frames)))) { // the current environment frames\n return false;\n }\n return true;\n};\n\nDefinition.prototype.matchArgs = function(args, context) {\n const allArgsCnt = (args && args.length) || 0;\n let len;\n const optionalParameters = this.optionalParameters;\n const requiredArgsCnt = !args ? 0 : args.reduce((count, p) => {\n if (optionalParameters.indexOf(p.name) < 0) {\n return count + 1;\n } else {\n return count;\n }\n }, 0);\n\n if (!this.variadic) {\n if (requiredArgsCnt < this.required) {\n return false;\n }\n if (allArgsCnt > this.params.length) {\n return false;\n }\n } else {\n if (requiredArgsCnt < (this.required - 1)) {\n return false;\n }\n }\n\n // check patterns\n len = Math.min(requiredArgsCnt, this.arity);\n\n for (let i = 0; i < len; i++) {\n if (!this.params[i].name && !this.params[i].variadic) {\n if (args[i].value.eval(context).toCSS() != this.params[i].value.eval(context).toCSS()) {\n return false;\n }\n }\n }\n return true;\n};\n\nDefinition.prototype.type = 'MixinDefinition';\nDefinition.prototype.evalFirst = true;\nexport default Definition;\n","import Node from './node';\nimport Selector from './selector';\nimport MixinDefinition from './mixin-definition';\nimport defaultFunc from '../functions/default';\n\nconst MixinCall = function(elements, args, index, currentFileInfo, important) {\n this.selector = new Selector(elements);\n this.arguments = args || [];\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.important = important;\n this.allowRoot = true;\n this.setParent(this.selector, this);\n};\n\nMixinCall.prototype = new Node();\n\nMixinCall.prototype.accept = function(visitor) {\n if (this.selector) {\n this.selector = visitor.visit(this.selector);\n }\n if (this.arguments.length) {\n this.arguments = visitor.visitArray(this.arguments);\n }\n};\n\nMixinCall.prototype.eval = function(context) {\n let mixins;\n let mixin;\n let mixinPath;\n const args = [];\n let arg;\n let argValue;\n const rules = [];\n let match = false;\n let i;\n let m;\n let f;\n let isRecursive;\n let isOneFound;\n const candidates = [];\n let candidate;\n const conditionResult = [];\n let defaultResult;\n const defFalseEitherCase = -1;\n const defNone = 0;\n const defTrue = 1;\n const defFalse = 2;\n let count;\n let originalRuleset;\n let noArgumentsFilter;\n\n this.selector = this.selector.eval(context);\n\n function calcDefGroup(mixin, mixinPath) {\n let f;\n let p;\n let namespace;\n\n for (f = 0; f < 2; f++) {\n conditionResult[f] = true;\n defaultFunc.value(f);\n for (p = 0; p < mixinPath.length && conditionResult[f]; p++) {\n namespace = mixinPath[p];\n if (namespace.matchCondition) {\n conditionResult[f] = conditionResult[f] && namespace.matchCondition(null, context);\n }\n }\n if (mixin.matchCondition) {\n conditionResult[f] = conditionResult[f] && mixin.matchCondition(args, context);\n }\n }\n if (conditionResult[0] || conditionResult[1]) {\n if (conditionResult[0] != conditionResult[1]) {\n return conditionResult[1] ?\n defTrue : defFalse;\n }\n\n return defNone;\n }\n return defFalseEitherCase;\n }\n\n for (i = 0; i < this.arguments.length; i++) {\n arg = this.arguments[i];\n argValue = arg.value.eval(context);\n if (arg.expand && Array.isArray(argValue.value)) {\n argValue = argValue.value;\n for (m = 0; m < argValue.length; m++) {\n args.push({value: argValue[m]});\n }\n } else {\n args.push({name: arg.name, value: argValue});\n }\n }\n\n noArgumentsFilter = rule => rule.matchArgs(null, context);\n\n for (i = 0; i < context.frames.length; i++) {\n if ((mixins = context.frames[i].find(this.selector, null, noArgumentsFilter)).length > 0) {\n isOneFound = true;\n\n // To make `default()` function independent of definition order we have two \"subpasses\" here.\n // At first we evaluate each guard *twice* (with `default() == true` and `default() == false`),\n // and build candidate list with corresponding flags. Then, when we know all possible matches,\n // we make a final decision.\n\n for (m = 0; m < mixins.length; m++) {\n mixin = mixins[m].rule;\n mixinPath = mixins[m].path;\n isRecursive = false;\n for (f = 0; f < context.frames.length; f++) {\n if ((!(mixin instanceof MixinDefinition)) && mixin === (context.frames[f].originalRuleset || context.frames[f])) {\n isRecursive = true;\n break;\n }\n }\n if (isRecursive) {\n continue;\n }\n\n if (mixin.matchArgs(args, context)) {\n candidate = {mixin, group: calcDefGroup(mixin, mixinPath)};\n\n if (candidate.group !== defFalseEitherCase) {\n candidates.push(candidate);\n }\n\n match = true;\n }\n }\n\n defaultFunc.reset();\n\n count = [0, 0, 0];\n for (m = 0; m < candidates.length; m++) {\n count[candidates[m].group]++;\n }\n\n if (count[defNone] > 0) {\n defaultResult = defFalse;\n } else {\n defaultResult = defTrue;\n if ((count[defTrue] + count[defFalse]) > 1) {\n throw { type: 'Runtime',\n message: `Ambiguous use of \\`default()\\` found when matching for \\`${this.format(args)}\\``,\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n }\n\n for (m = 0; m < candidates.length; m++) {\n candidate = candidates[m].group;\n if ((candidate === defNone) || (candidate === defaultResult)) {\n try {\n mixin = candidates[m].mixin;\n if (!(mixin instanceof MixinDefinition)) {\n originalRuleset = mixin.originalRuleset || mixin;\n mixin = new MixinDefinition('', [], mixin.rules, null, false, null, originalRuleset.visibilityInfo());\n mixin.originalRuleset = originalRuleset;\n }\n const newRules = mixin.evalCall(context, args, this.important).rules;\n this._setVisibilityToReplacement(newRules);\n Array.prototype.push.apply(rules, newRules);\n } catch (e) {\n throw { message: e.message, index: this.getIndex(), filename: this.fileInfo().filename, stack: e.stack };\n }\n }\n }\n\n if (match) {\n return rules;\n }\n }\n }\n if (isOneFound) {\n throw { type: 'Runtime',\n message: `No matching definition was found for \\`${this.format(args)}\\``,\n index: this.getIndex(), filename: this.fileInfo().filename };\n } else {\n throw { type: 'Name',\n message: `${this.selector.toCSS().trim()} is undefined`,\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n};\n\nMixinCall.prototype._setVisibilityToReplacement = function(replacement) {\n let i;\n let rule;\n if (this.blocksVisibility()) {\n for (i = 0; i < replacement.length; i++) {\n rule = replacement[i];\n rule.addVisibilityBlock();\n }\n }\n};\n\nMixinCall.prototype.format = function(args) {\n return `${this.selector.toCSS().trim()}(${args ? args.map(a => {\n let argValue = '';\n if (a.name) {\n argValue += `${a.name}:`;\n }\n if (a.value.toCSS) {\n argValue += a.value.toCSS();\n } else {\n argValue += '???';\n }\n return argValue;\n }).join(', ') : ''})`;\n};\n\nMixinCall.prototype.type = 'MixinCall';\nexport default MixinCall;\n","import Node from './node';\nimport Color from './color';\nimport AtRule from './atrule';\nimport DetachedRuleset from './detached-ruleset';\nimport Operation from './operation';\nimport Dimension from './dimension';\nimport Unit from './unit';\nimport Keyword from './keyword';\nimport Variable from './variable';\nimport Property from './property';\nimport Ruleset from './ruleset';\nimport Element from './element';\nimport Attribute from './attribute';\nimport Combinator from './combinator';\nimport Selector from './selector';\nimport Quoted from './quoted';\nimport Expression from './expression';\nimport Declaration from './declaration';\nimport Call from './call';\nimport URL from './url';\nimport Import from './import';\nimport Comment from './comment';\nimport Anonymous from './anonymous';\nimport Value from './value';\nimport JavaScript from './javascript';\nimport Assignment from './assignment';\nimport Condition from './condition';\nimport Paren from './paren';\nimport Media from './media';\nimport UnicodeDescriptor from './unicode-descriptor';\nimport Negative from './negative';\nimport Extend from './extend';\nimport VariableCall from './variable-call';\nimport NamespaceValue from './namespace-value';\n\n// mixins\nimport MixinCall from './mixin-call';\nimport MixinDefinition from './mixin-definition';\n\nexport default {\n Node, Color, AtRule, DetachedRuleset, Operation,\n Dimension, Unit, Keyword, Variable, Property,\n Ruleset, Element, Attribute, Combinator, Selector,\n Quoted, Expression, Declaration, Call, URL, Import,\n Comment, Anonymous, Value, JavaScript, Assignment,\n Condition, Paren, Media, UnicodeDescriptor, Negative,\n Extend, VariableCall, NamespaceValue,\n mixin: {\n Call: MixinCall,\n Definition: MixinDefinition\n }\n};","export default {\n error: function(msg) {\n this._fireEvent('error', msg);\n },\n warn: function(msg) {\n this._fireEvent('warn', msg);\n },\n info: function(msg) {\n this._fireEvent('info', msg);\n },\n debug: function(msg) {\n this._fireEvent('debug', msg);\n },\n addListener: function(listener) {\n this._listeners.push(listener);\n },\n removeListener: function(listener) {\n for (let i = 0; i < this._listeners.length; i++) {\n if (this._listeners[i] === listener) {\n this._listeners.splice(i, 1);\n return;\n }\n }\n },\n _fireEvent: function(type, msg) {\n for (let i = 0; i < this._listeners.length; i++) {\n const logFunction = this._listeners[i][type];\n if (logFunction) {\n logFunction(msg);\n }\n }\n },\n _listeners: []\n};\n","/**\n * @todo Document why this abstraction exists, and the relationship between\n * environment, file managers, and plugin manager\n */\n\nimport logger from '../logger';\n\nclass environment {\n constructor(externalEnvironment, fileManagers) {\n this.fileManagers = fileManagers || [];\n externalEnvironment = externalEnvironment || {};\n\n const optionalFunctions = ['encodeBase64', 'mimeLookup', 'charsetLookup', 'getSourceMapGenerator'];\n const requiredFunctions = [];\n const functions = requiredFunctions.concat(optionalFunctions);\n\n for (let i = 0; i < functions.length; i++) {\n const propName = functions[i];\n const environmentFunc = externalEnvironment[propName];\n if (environmentFunc) {\n this[propName] = environmentFunc.bind(externalEnvironment);\n } else if (i < requiredFunctions.length) {\n this.warn(`missing required function in environment - ${propName}`);\n }\n }\n }\n\n getFileManager(filename, currentDirectory, options, environment, isSync) {\n\n if (!filename) {\n logger.warn('getFileManager called with no filename.. Please report this issue. continuing.');\n }\n if (currentDirectory == null) {\n logger.warn('getFileManager called with null directory.. Please report this issue. continuing.');\n }\n\n let fileManagers = this.fileManagers;\n if (options.pluginManager) {\n fileManagers = [].concat(fileManagers).concat(options.pluginManager.getFileManagers());\n }\n for (let i = fileManagers.length - 1; i >= 0 ; i--) {\n const fileManager = fileManagers[i];\n if (fileManager[isSync ? 'supportsSync' : 'supports'](filename, currentDirectory, options, environment)) {\n return fileManager;\n }\n }\n return null;\n }\n\n addFileManager(fileManager) {\n this.fileManagers.push(fileManager);\n }\n\n clearFileManagers() {\n this.fileManagers = [];\n }\n}\n\nexport default environment;\n","class AbstractFileManager {\n getPath(filename) {\n let j = filename.lastIndexOf('?');\n if (j > 0) {\n filename = filename.slice(0, j);\n }\n j = filename.lastIndexOf('/');\n if (j < 0) {\n j = filename.lastIndexOf('\\\\');\n }\n if (j < 0) {\n return '';\n }\n return filename.slice(0, j + 1);\n }\n\n tryAppendExtension(path, ext) {\n return /(\\.[a-z]*$)|([\\?;].*)$/.test(path) ? path : path + ext;\n }\n\n tryAppendLessExtension(path) {\n return this.tryAppendExtension(path, '.less');\n };\n\n supportsSync() { return false; }\n\n alwaysMakePathsAbsolute() { return false; }\n\n isPathAbsolute(filename) {\n return (/^(?:[a-z-]+:|\\/|\\\\|#)/i).test(filename);\n }\n // TODO: pull out / replace?\n join(basePath, laterPath) {\n if (!basePath) {\n return laterPath;\n }\n return basePath + laterPath;\n };\n\n pathDiff(url, baseUrl) {\n // diff between two paths to create a relative path\n const urlParts = this.extractUrlParts(url);\n const baseUrlParts = this.extractUrlParts(baseUrl);\n\n let i;\n let max;\n let urlDirectories;\n let baseUrlDirectories;\n let diff = '';\n if (urlParts.hostPart !== baseUrlParts.hostPart) {\n return '';\n }\n max = Math.max(baseUrlParts.directories.length, urlParts.directories.length);\n for (i = 0; i < max; i++) {\n if (baseUrlParts.directories[i] !== urlParts.directories[i]) { break; }\n }\n baseUrlDirectories = baseUrlParts.directories.slice(i);\n urlDirectories = urlParts.directories.slice(i);\n for (i = 0; i < baseUrlDirectories.length - 1; i++) {\n diff += '../';\n }\n for (i = 0; i < urlDirectories.length - 1; i++) {\n diff += `${urlDirectories[i]}/`;\n }\n return diff;\n };\n // helper function, not part of API\n extractUrlParts(url, baseUrl) {\n // urlParts[1] = protocol://hostname/ OR /\n // urlParts[2] = / if path relative to host base\n // urlParts[3] = directories\n // urlParts[4] = filename\n // urlParts[5] = parameters\n\n const urlPartsRegex = /^((?:[a-z-]+:)?\\/{2}(?:[^\\/\\?#]*\\/)|([\\/\\\\]))?((?:[^\\/\\\\\\?#]*[\\/\\\\])*)([^\\/\\\\\\?#]*)([#\\?].*)?$/i;\n\n const urlParts = url.match(urlPartsRegex);\n const returner = {};\n let rawDirectories = [];\n const directories = [];\n let i;\n let baseUrlParts;\n\n if (!urlParts) {\n throw new Error(`Could not parse sheet href - '${url}'`);\n }\n\n // Stylesheets in IE don't always return the full path\n if (baseUrl && (!urlParts[1] || urlParts[2])) {\n baseUrlParts = baseUrl.match(urlPartsRegex);\n if (!baseUrlParts) {\n throw new Error(`Could not parse page url - '${baseUrl}'`);\n }\n urlParts[1] = urlParts[1] || baseUrlParts[1] || '';\n if (!urlParts[2]) {\n urlParts[3] = baseUrlParts[3] + urlParts[3];\n }\n }\n\n if (urlParts[3]) {\n rawDirectories = urlParts[3].replace(/\\\\/g, '/').split('/');\n\n // collapse '..' and skip '.'\n for (i = 0; i < rawDirectories.length; i++) {\n\n if (rawDirectories[i] === '..') {\n directories.pop();\n }\n else if (rawDirectories[i] !== '.') {\n directories.push(rawDirectories[i]);\n }\n \n }\n }\n\n returner.hostPart = urlParts[1];\n returner.directories = directories;\n returner.rawPath = (urlParts[1] || '') + rawDirectories.join('/');\n returner.path = (urlParts[1] || '') + directories.join('/');\n returner.filename = urlParts[4];\n returner.fileUrl = returner.path + (urlParts[4] || '');\n returner.url = returner.fileUrl + (urlParts[5] || '');\n return returner;\n };\n}\n\nexport default AbstractFileManager;","import functionRegistry from '../functions/function-registry';\nimport LessError from '../less-error';\n\nclass AbstractPluginLoader {\n constructor() {\n // Implemented by Node.js plugin loader\n this.require = () => null\n }\n\n evalPlugin(contents, context, imports, pluginOptions, fileInfo) {\n let loader;\n let registry;\n let pluginObj;\n let localModule;\n let pluginManager;\n let filename;\n let result;\n\n pluginManager = context.pluginManager;\n\n if (fileInfo) {\n if (typeof fileInfo === 'string') {\n filename = fileInfo;\n }\n else {\n filename = fileInfo.filename;\n }\n }\n const shortname = (new this.less.FileManager()).extractUrlParts(filename).filename;\n\n if (filename) {\n pluginObj = pluginManager.get(filename);\n\n if (pluginObj) {\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n if (result) {\n return result;\n }\n try {\n if (pluginObj.use) {\n pluginObj.use.call(this.context, pluginObj);\n }\n }\n catch (e) {\n e.message = e.message || 'Error during @plugin call';\n return new LessError(e, imports, filename);\n }\n return pluginObj;\n }\n }\n localModule = {\n exports: {},\n pluginManager,\n fileInfo\n };\n registry = functionRegistry.create();\n\n const registerPlugin = obj => {\n pluginObj = obj;\n };\n\n try {\n loader = new Function('module', 'require', 'registerPlugin', 'functions', 'tree', 'less', 'fileInfo', contents);\n loader(localModule, this.require(filename), registerPlugin, registry, this.less.tree, this.less, fileInfo);\n }\n catch (e) {\n return new LessError(e, imports, filename);\n }\n\n if (!pluginObj) {\n pluginObj = localModule.exports;\n }\n pluginObj = this.validatePlugin(pluginObj, filename, shortname);\n\n if (pluginObj instanceof LessError) {\n return pluginObj;\n }\n\n if (pluginObj) {\n pluginObj.imports = imports;\n pluginObj.filename = filename;\n\n // For < 3.x (or unspecified minVersion) - setOptions() before install()\n if (!pluginObj.minVersion || this.compareVersion('3.0.0', pluginObj.minVersion) < 0) {\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n\n if (result) {\n return result;\n }\n }\n\n // Run on first load\n pluginManager.addPlugin(pluginObj, fileInfo.filename, registry);\n pluginObj.functions = registry.getLocalFunctions();\n\n // Need to call setOptions again because the pluginObj might have functions\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n if (result) {\n return result;\n }\n\n // Run every @plugin call\n try {\n if (pluginObj.use) {\n pluginObj.use.call(this.context, pluginObj);\n }\n }\n catch (e) {\n e.message = e.message || 'Error during @plugin call';\n return new LessError(e, imports, filename);\n }\n\n }\n else {\n return new LessError({ message: 'Not a valid plugin' }, imports, filename);\n }\n\n return pluginObj;\n }\n\n trySetOptions(plugin, filename, name, options) {\n if (options && !plugin.setOptions) {\n return new LessError({\n message: `Options have been provided but the plugin ${name} does not support any options.`\n });\n }\n try {\n plugin.setOptions && plugin.setOptions(options);\n }\n catch (e) {\n return new LessError(e);\n }\n }\n\n validatePlugin(plugin, filename, name) {\n if (plugin) {\n // support plugins being a function\n // so that the plugin can be more usable programmatically\n if (typeof plugin === 'function') {\n plugin = new plugin();\n }\n\n if (plugin.minVersion) {\n if (this.compareVersion(plugin.minVersion, this.less.version) < 0) {\n return new LessError({\n message: `Plugin ${name} requires version ${this.versionToString(plugin.minVersion)}`\n });\n }\n }\n return plugin;\n }\n return null;\n }\n\n compareVersion(aVersion, bVersion) {\n if (typeof aVersion === 'string') {\n aVersion = aVersion.match(/^(\\d+)\\.?(\\d+)?\\.?(\\d+)?/);\n aVersion.shift();\n }\n for (let i = 0; i < aVersion.length; i++) {\n if (aVersion[i] !== bVersion[i]) {\n return parseInt(aVersion[i]) > parseInt(bVersion[i]) ? -1 : 1;\n }\n }\n return 0;\n }\n\n versionToString(version) {\n let versionString = '';\n for (let i = 0; i < version.length; i++) {\n versionString += (versionString ? '.' : '') + version[i];\n }\n return versionString;\n }\n\n printUsage(plugins) {\n for (let i = 0; i < plugins.length; i++) {\n const plugin = plugins[i];\n if (plugin.printUsage) {\n plugin.printUsage();\n }\n }\n }\n}\n\nexport default AbstractPluginLoader;\n\n","import tree from '../tree';\nconst _visitArgs = { visitDeeper: true };\nlet _hasIndexed = false;\n\nfunction _noop(node) {\n return node;\n}\n\nfunction indexNodeTypes(parent, ticker) {\n // add .typeIndex to tree node types for lookup table\n let key;\n\n let child;\n for (key in parent) { \n /* eslint guard-for-in: 0 */\n child = parent[key];\n switch (typeof child) {\n case 'function':\n // ignore bound functions directly on tree which do not have a prototype\n // or aren't nodes\n if (child.prototype && child.prototype.type) {\n child.prototype.typeIndex = ticker++;\n }\n break;\n case 'object':\n ticker = indexNodeTypes(child, ticker);\n break;\n \n }\n }\n return ticker;\n}\n\nclass Visitor {\n constructor(implementation) {\n this._implementation = implementation;\n this._visitInCache = {};\n this._visitOutCache = {};\n\n if (!_hasIndexed) {\n indexNodeTypes(tree, 1);\n _hasIndexed = true;\n }\n }\n\n visit(node) {\n if (!node) {\n return node;\n }\n\n const nodeTypeIndex = node.typeIndex;\n if (!nodeTypeIndex) {\n // MixinCall args aren't a node type?\n if (node.value && node.value.typeIndex) {\n this.visit(node.value);\n }\n return node;\n }\n\n const impl = this._implementation;\n let func = this._visitInCache[nodeTypeIndex];\n let funcOut = this._visitOutCache[nodeTypeIndex];\n const visitArgs = _visitArgs;\n let fnName;\n\n visitArgs.visitDeeper = true;\n\n if (!func) {\n fnName = `visit${node.type}`;\n func = impl[fnName] || _noop;\n funcOut = impl[`${fnName}Out`] || _noop;\n this._visitInCache[nodeTypeIndex] = func;\n this._visitOutCache[nodeTypeIndex] = funcOut;\n }\n\n if (func !== _noop) {\n const newNode = func.call(impl, node, visitArgs);\n if (node && impl.isReplacing) {\n node = newNode;\n }\n }\n\n if (visitArgs.visitDeeper && node) {\n if (node.length) {\n for (var i = 0, cnt = node.length; i < cnt; i++) {\n if (node[i].accept) {\n node[i].accept(this);\n }\n }\n } else if (node.accept) {\n node.accept(this);\n }\n }\n\n if (funcOut != _noop) {\n funcOut.call(impl, node);\n }\n\n return node;\n }\n\n visitArray(nodes, nonReplacing) {\n if (!nodes) {\n return nodes;\n }\n\n const cnt = nodes.length;\n let i;\n\n // Non-replacing\n if (nonReplacing || !this._implementation.isReplacing) {\n for (i = 0; i < cnt; i++) {\n this.visit(nodes[i]);\n }\n return nodes;\n }\n\n // Replacing\n const out = [];\n for (i = 0; i < cnt; i++) {\n const evald = this.visit(nodes[i]);\n if (evald === undefined) { continue; }\n if (!evald.splice) {\n out.push(evald);\n } else if (evald.length) {\n this.flatten(evald, out);\n }\n }\n return out;\n }\n\n flatten(arr, out) {\n if (!out) {\n out = [];\n }\n\n let cnt;\n let i;\n let item;\n let nestedCnt;\n let j;\n let nestedItem;\n\n for (i = 0, cnt = arr.length; i < cnt; i++) {\n item = arr[i];\n if (item === undefined) {\n continue;\n }\n if (!item.splice) {\n out.push(item);\n continue;\n }\n\n for (j = 0, nestedCnt = item.length; j < nestedCnt; j++) {\n nestedItem = item[j];\n if (nestedItem === undefined) {\n continue;\n }\n if (!nestedItem.splice) {\n out.push(nestedItem);\n } else if (nestedItem.length) {\n this.flatten(nestedItem, out);\n }\n }\n }\n\n return out;\n }\n}\n\nexport default Visitor;\n","class ImportSequencer {\n constructor(onSequencerEmpty) {\n this.imports = [];\n this.variableImports = [];\n this._onSequencerEmpty = onSequencerEmpty;\n this._currentDepth = 0;\n }\n\n addImport(callback) {\n const importSequencer = this;\n\n const importItem = {\n callback,\n args: null,\n isReady: false\n };\n\n this.imports.push(importItem);\n return function(...args) {\n importItem.args = Array.prototype.slice.call(args, 0);\n importItem.isReady = true;\n importSequencer.tryRun();\n };\n }\n\n addVariableImport(callback) {\n this.variableImports.push(callback);\n }\n\n tryRun() {\n this._currentDepth++;\n try {\n while (true) {\n while (this.imports.length > 0) {\n const importItem = this.imports[0];\n if (!importItem.isReady) {\n return;\n }\n this.imports = this.imports.slice(1);\n importItem.callback.apply(null, importItem.args);\n }\n if (this.variableImports.length === 0) {\n break;\n }\n const variableImport = this.variableImports[0];\n this.variableImports = this.variableImports.slice(1);\n variableImport();\n }\n } finally {\n this._currentDepth--;\n }\n if (this._currentDepth === 0 && this._onSequencerEmpty) {\n this._onSequencerEmpty();\n }\n }\n}\n\nexport default ImportSequencer;\n","import contexts from '../contexts';\nimport Visitor from './visitor';\nimport ImportSequencer from './import-sequencer';\nimport * as utils from '../utils';\n\nconst ImportVisitor = function(importer, finish) {\n\n this._visitor = new Visitor(this);\n this._importer = importer;\n this._finish = finish;\n this.context = new contexts.Eval();\n this.importCount = 0;\n this.onceFileDetectionMap = {};\n this.recursionDetector = {};\n this._sequencer = new ImportSequencer(this._onSequencerEmpty.bind(this));\n};\n\nImportVisitor.prototype = {\n isReplacing: false,\n run: function (root) {\n try {\n // process the contents\n this._visitor.visit(root);\n }\n catch (e) {\n this.error = e;\n }\n\n this.isFinished = true;\n this._sequencer.tryRun();\n },\n _onSequencerEmpty: function() {\n if (!this.isFinished) {\n return;\n }\n this._finish(this.error);\n },\n visitImport: function (importNode, visitArgs) {\n const inlineCSS = importNode.options.inline;\n\n if (!importNode.css || inlineCSS) {\n\n const context = new contexts.Eval(this.context, utils.copyArray(this.context.frames));\n const importParent = context.frames[0];\n\n this.importCount++;\n if (importNode.isVariableImport()) {\n this._sequencer.addVariableImport(this.processImportNode.bind(this, importNode, context, importParent));\n } else {\n this.processImportNode(importNode, context, importParent);\n }\n }\n visitArgs.visitDeeper = false;\n },\n processImportNode: function(importNode, context, importParent) {\n let evaldImportNode;\n const inlineCSS = importNode.options.inline;\n\n try {\n evaldImportNode = importNode.evalForImport(context);\n } catch (e) {\n if (!e.filename) { e.index = importNode.getIndex(); e.filename = importNode.fileInfo().filename; }\n // attempt to eval properly and treat as css\n importNode.css = true;\n // if that fails, this error will be thrown\n importNode.error = e;\n }\n\n if (evaldImportNode && (!evaldImportNode.css || inlineCSS)) {\n if (evaldImportNode.options.multiple) {\n context.importMultiple = true;\n }\n\n // try appending if we haven't determined if it is css or not\n const tryAppendLessExtension = evaldImportNode.css === undefined;\n\n for (let i = 0; i < importParent.rules.length; i++) {\n if (importParent.rules[i] === importNode) {\n importParent.rules[i] = evaldImportNode;\n break;\n }\n }\n\n const onImported = this.onImported.bind(this, evaldImportNode, context);\n const sequencedOnImported = this._sequencer.addImport(onImported);\n\n this._importer.push(evaldImportNode.getPath(), tryAppendLessExtension, evaldImportNode.fileInfo(),\n evaldImportNode.options, sequencedOnImported);\n } else {\n this.importCount--;\n if (this.isFinished) {\n this._sequencer.tryRun();\n }\n }\n },\n onImported: function (importNode, context, e, root, importedAtRoot, fullPath) {\n if (e) {\n if (!e.filename) {\n e.index = importNode.getIndex(); e.filename = importNode.fileInfo().filename;\n }\n this.error = e;\n }\n\n const importVisitor = this;\n const inlineCSS = importNode.options.inline;\n const isPlugin = importNode.options.isPlugin;\n const isOptional = importNode.options.optional;\n const duplicateImport = importedAtRoot || fullPath in importVisitor.recursionDetector;\n\n if (!context.importMultiple) {\n if (duplicateImport) {\n importNode.skip = true;\n } else {\n importNode.skip = () => {\n if (fullPath in importVisitor.onceFileDetectionMap) {\n return true;\n }\n importVisitor.onceFileDetectionMap[fullPath] = true;\n return false;\n };\n }\n }\n\n if (!fullPath && isOptional) {\n importNode.skip = true;\n }\n\n if (root) {\n importNode.root = root;\n importNode.importedFilename = fullPath;\n\n if (!inlineCSS && !isPlugin && (context.importMultiple || !duplicateImport)) {\n importVisitor.recursionDetector[fullPath] = true;\n\n const oldContext = this.context;\n this.context = context;\n try {\n this._visitor.visit(root);\n } catch (e) {\n this.error = e;\n }\n this.context = oldContext;\n }\n }\n\n importVisitor.importCount--;\n\n if (importVisitor.isFinished) {\n importVisitor._sequencer.tryRun();\n }\n },\n visitDeclaration: function (declNode, visitArgs) {\n if (declNode.value.type === 'DetachedRuleset') {\n this.context.frames.unshift(declNode);\n } else {\n visitArgs.visitDeeper = false;\n }\n },\n visitDeclarationOut: function(declNode) {\n if (declNode.value.type === 'DetachedRuleset') {\n this.context.frames.shift();\n }\n },\n visitAtRule: function (atRuleNode, visitArgs) {\n this.context.frames.unshift(atRuleNode);\n },\n visitAtRuleOut: function (atRuleNode) {\n this.context.frames.shift();\n },\n visitMixinDefinition: function (mixinDefinitionNode, visitArgs) {\n this.context.frames.unshift(mixinDefinitionNode);\n },\n visitMixinDefinitionOut: function (mixinDefinitionNode) {\n this.context.frames.shift();\n },\n visitRuleset: function (rulesetNode, visitArgs) {\n this.context.frames.unshift(rulesetNode);\n },\n visitRulesetOut: function (rulesetNode) {\n this.context.frames.shift();\n },\n visitMedia: function (mediaNode, visitArgs) {\n this.context.frames.unshift(mediaNode.rules[0]);\n },\n visitMediaOut: function (mediaNode) {\n this.context.frames.shift();\n }\n};\nexport default ImportVisitor;\n","class SetTreeVisibilityVisitor {\n constructor(visible) {\n this.visible = visible;\n }\n\n run(root) {\n this.visit(root);\n }\n\n visitArray(nodes) {\n if (!nodes) {\n return nodes;\n }\n\n const cnt = nodes.length;\n let i;\n for (i = 0; i < cnt; i++) {\n this.visit(nodes[i]);\n }\n return nodes;\n }\n\n visit(node) {\n if (!node) {\n return node;\n }\n if (node.constructor === Array) {\n return this.visitArray(node);\n }\n\n if (!node.blocksVisibility || node.blocksVisibility()) {\n return node;\n }\n if (this.visible) {\n node.ensureVisibility();\n } else {\n node.ensureInvisibility();\n }\n\n node.accept(this);\n return node;\n }\n}\n\nexport default SetTreeVisibilityVisitor;","import tree from '../tree';\nimport Visitor from './visitor';\nimport logger from '../logger';\nimport * as utils from '../utils';\n\n/* jshint loopfunc:true */\n\nclass ExtendFinderVisitor {\n constructor() {\n this._visitor = new Visitor(this);\n this.contexts = [];\n this.allExtendsStack = [[]];\n }\n\n run(root) {\n root = this._visitor.visit(root);\n root.allExtends = this.allExtendsStack[0];\n return root;\n }\n\n visitDeclaration(declNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n if (rulesetNode.root) {\n return;\n }\n\n let i;\n let j;\n let extend;\n const allSelectorsExtendList = [];\n let extendList;\n\n // get &:extend(.a); rules which apply to all selectors in this ruleset\n const rules = rulesetNode.rules;\n\n const ruleCnt = rules ? rules.length : 0;\n for (i = 0; i < ruleCnt; i++) {\n if (rulesetNode.rules[i] instanceof tree.Extend) {\n allSelectorsExtendList.push(rules[i]);\n rulesetNode.extendOnEveryPath = true;\n }\n }\n\n // now find every selector and apply the extends that apply to all extends\n // and the ones which apply to an individual extend\n const paths = rulesetNode.paths;\n for (i = 0; i < paths.length; i++) {\n const selectorPath = paths[i];\n const selector = selectorPath[selectorPath.length - 1];\n const selExtendList = selector.extendList;\n\n extendList = selExtendList ? utils.copyArray(selExtendList).concat(allSelectorsExtendList)\n : allSelectorsExtendList;\n\n if (extendList) {\n extendList = extendList.map(allSelectorsExtend => allSelectorsExtend.clone());\n }\n\n for (j = 0; j < extendList.length; j++) {\n this.foundExtends = true;\n extend = extendList[j];\n extend.findSelfSelectors(selectorPath);\n extend.ruleset = rulesetNode;\n if (j === 0) { extend.firstExtendOnThisSelectorPath = true; }\n this.allExtendsStack[this.allExtendsStack.length - 1].push(extend);\n }\n }\n\n this.contexts.push(rulesetNode.selectors);\n }\n\n visitRulesetOut(rulesetNode) {\n if (!rulesetNode.root) {\n this.contexts.length = this.contexts.length - 1;\n }\n }\n\n visitMedia(mediaNode, visitArgs) {\n mediaNode.allExtends = [];\n this.allExtendsStack.push(mediaNode.allExtends);\n }\n\n visitMediaOut(mediaNode) {\n this.allExtendsStack.length = this.allExtendsStack.length - 1;\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n atRuleNode.allExtends = [];\n this.allExtendsStack.push(atRuleNode.allExtends);\n }\n\n visitAtRuleOut(atRuleNode) {\n this.allExtendsStack.length = this.allExtendsStack.length - 1;\n }\n}\n\nclass ProcessExtendsVisitor {\n constructor() {\n this._visitor = new Visitor(this);\n }\n\n run(root) {\n const extendFinder = new ExtendFinderVisitor();\n this.extendIndices = {};\n extendFinder.run(root);\n if (!extendFinder.foundExtends) { return root; }\n root.allExtends = root.allExtends.concat(this.doExtendChaining(root.allExtends, root.allExtends));\n this.allExtendsStack = [root.allExtends];\n const newRoot = this._visitor.visit(root);\n this.checkExtendsForNonMatched(root.allExtends);\n return newRoot;\n }\n\n checkExtendsForNonMatched(extendList) {\n const indices = this.extendIndices;\n extendList.filter(extend => !extend.hasFoundMatches && extend.parent_ids.length == 1).forEach(extend => {\n let selector = '_unknown_';\n try {\n selector = extend.selector.toCSS({});\n }\n catch (_) {}\n\n if (!indices[`${extend.index} ${selector}`]) {\n indices[`${extend.index} ${selector}`] = true;\n logger.warn(`extend '${selector}' has no matches`);\n }\n });\n }\n\n doExtendChaining(extendsList, extendsListTarget, iterationCount) {\n //\n // chaining is different from normal extension.. if we extend an extend then we are not just copying, altering\n // and pasting the selector we would do normally, but we are also adding an extend with the same target selector\n // this means this new extend can then go and alter other extends\n //\n // this method deals with all the chaining work - without it, extend is flat and doesn't work on other extend selectors\n // this is also the most expensive.. and a match on one selector can cause an extension of a selector we had already\n // processed if we look at each selector at a time, as is done in visitRuleset\n\n let extendIndex;\n\n let targetExtendIndex;\n let matches;\n const extendsToAdd = [];\n let newSelector;\n const extendVisitor = this;\n let selectorPath;\n let extend;\n let targetExtend;\n let newExtend;\n\n iterationCount = iterationCount || 0;\n\n // loop through comparing every extend with every target extend.\n // a target extend is the one on the ruleset we are looking at copy/edit/pasting in place\n // e.g. .a:extend(.b) {} and .b:extend(.c) {} then the first extend extends the second one\n // and the second is the target.\n // the separation into two lists allows us to process a subset of chains with a bigger set, as is the\n // case when processing media queries\n for (extendIndex = 0; extendIndex < extendsList.length; extendIndex++) {\n for (targetExtendIndex = 0; targetExtendIndex < extendsListTarget.length; targetExtendIndex++) {\n\n extend = extendsList[extendIndex];\n targetExtend = extendsListTarget[targetExtendIndex];\n\n // look for circular references\n if ( extend.parent_ids.indexOf( targetExtend.object_id ) >= 0 ) { continue; }\n\n // find a match in the target extends self selector (the bit before :extend)\n selectorPath = [targetExtend.selfSelectors[0]];\n matches = extendVisitor.findMatch(extend, selectorPath);\n\n if (matches.length) {\n extend.hasFoundMatches = true;\n\n // we found a match, so for each self selector..\n extend.selfSelectors.forEach(selfSelector => {\n const info = targetExtend.visibilityInfo();\n\n // process the extend as usual\n newSelector = extendVisitor.extendSelector(matches, selectorPath, selfSelector, extend.isVisible());\n\n // but now we create a new extend from it\n newExtend = new(tree.Extend)(targetExtend.selector, targetExtend.option, 0, targetExtend.fileInfo(), info);\n newExtend.selfSelectors = newSelector;\n\n // add the extend onto the list of extends for that selector\n newSelector[newSelector.length - 1].extendList = [newExtend];\n\n // record that we need to add it.\n extendsToAdd.push(newExtend);\n newExtend.ruleset = targetExtend.ruleset;\n\n // remember its parents for circular references\n newExtend.parent_ids = newExtend.parent_ids.concat(targetExtend.parent_ids, extend.parent_ids);\n\n // only process the selector once.. if we have :extend(.a,.b) then multiple\n // extends will look at the same selector path, so when extending\n // we know that any others will be duplicates in terms of what is added to the css\n if (targetExtend.firstExtendOnThisSelectorPath) {\n newExtend.firstExtendOnThisSelectorPath = true;\n targetExtend.ruleset.paths.push(newSelector);\n }\n });\n }\n }\n }\n\n if (extendsToAdd.length) {\n // try to detect circular references to stop a stack overflow.\n // may no longer be needed.\n this.extendChainCount++;\n if (iterationCount > 100) {\n let selectorOne = '{unable to calculate}';\n let selectorTwo = '{unable to calculate}';\n try {\n selectorOne = extendsToAdd[0].selfSelectors[0].toCSS();\n selectorTwo = extendsToAdd[0].selector.toCSS();\n }\n catch (e) {}\n throw { message: `extend circular reference detected. One of the circular extends is currently:${selectorOne}:extend(${selectorTwo})`};\n }\n\n // now process the new extends on the existing rules so that we can handle a extending b extending c extending\n // d extending e...\n return extendsToAdd.concat(extendVisitor.doExtendChaining(extendsToAdd, extendsListTarget, iterationCount + 1));\n } else {\n return extendsToAdd;\n }\n }\n\n visitDeclaration(ruleNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitSelector(selectorNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n if (rulesetNode.root) {\n return;\n }\n let matches;\n let pathIndex;\n let extendIndex;\n const allExtends = this.allExtendsStack[this.allExtendsStack.length - 1];\n const selectorsToAdd = [];\n const extendVisitor = this;\n let selectorPath;\n\n // look at each selector path in the ruleset, find any extend matches and then copy, find and replace\n\n for (extendIndex = 0; extendIndex < allExtends.length; extendIndex++) {\n for (pathIndex = 0; pathIndex < rulesetNode.paths.length; pathIndex++) {\n selectorPath = rulesetNode.paths[pathIndex];\n\n // extending extends happens initially, before the main pass\n if (rulesetNode.extendOnEveryPath) { continue; }\n const extendList = selectorPath[selectorPath.length - 1].extendList;\n if (extendList && extendList.length) { continue; }\n\n matches = this.findMatch(allExtends[extendIndex], selectorPath);\n\n if (matches.length) {\n allExtends[extendIndex].hasFoundMatches = true;\n\n allExtends[extendIndex].selfSelectors.forEach(selfSelector => {\n let extendedSelectors;\n extendedSelectors = extendVisitor.extendSelector(matches, selectorPath, selfSelector, allExtends[extendIndex].isVisible());\n selectorsToAdd.push(extendedSelectors);\n });\n }\n }\n }\n rulesetNode.paths = rulesetNode.paths.concat(selectorsToAdd);\n }\n\n findMatch(extend, haystackSelectorPath) {\n //\n // look through the haystack selector path to try and find the needle - extend.selector\n // returns an array of selector matches that can then be replaced\n //\n let haystackSelectorIndex;\n\n let hackstackSelector;\n let hackstackElementIndex;\n let haystackElement;\n let targetCombinator;\n let i;\n const extendVisitor = this;\n const needleElements = extend.selector.elements;\n const potentialMatches = [];\n let potentialMatch;\n const matches = [];\n\n // loop through the haystack elements\n for (haystackSelectorIndex = 0; haystackSelectorIndex < haystackSelectorPath.length; haystackSelectorIndex++) {\n hackstackSelector = haystackSelectorPath[haystackSelectorIndex];\n\n for (hackstackElementIndex = 0; hackstackElementIndex < hackstackSelector.elements.length; hackstackElementIndex++) {\n\n haystackElement = hackstackSelector.elements[hackstackElementIndex];\n\n // if we allow elements before our match we can add a potential match every time. otherwise only at the first element.\n if (extend.allowBefore || (haystackSelectorIndex === 0 && hackstackElementIndex === 0)) {\n potentialMatches.push({pathIndex: haystackSelectorIndex, index: hackstackElementIndex, matched: 0,\n initialCombinator: haystackElement.combinator});\n }\n\n for (i = 0; i < potentialMatches.length; i++) {\n potentialMatch = potentialMatches[i];\n\n // selectors add \" \" onto the first element. When we use & it joins the selectors together, but if we don't\n // then each selector in haystackSelectorPath has a space before it added in the toCSS phase. so we need to\n // work out what the resulting combinator will be\n targetCombinator = haystackElement.combinator.value;\n if (targetCombinator === '' && hackstackElementIndex === 0) {\n targetCombinator = ' ';\n }\n\n // if we don't match, null our match to indicate failure\n if (!extendVisitor.isElementValuesEqual(needleElements[potentialMatch.matched].value, haystackElement.value) ||\n (potentialMatch.matched > 0 && needleElements[potentialMatch.matched].combinator.value !== targetCombinator)) {\n potentialMatch = null;\n } else {\n potentialMatch.matched++;\n }\n\n // if we are still valid and have finished, test whether we have elements after and whether these are allowed\n if (potentialMatch) {\n potentialMatch.finished = potentialMatch.matched === needleElements.length;\n if (potentialMatch.finished &&\n (!extend.allowAfter &&\n (hackstackElementIndex + 1 < hackstackSelector.elements.length || haystackSelectorIndex + 1 < haystackSelectorPath.length))) {\n potentialMatch = null;\n }\n }\n // if null we remove, if not, we are still valid, so either push as a valid match or continue\n if (potentialMatch) {\n if (potentialMatch.finished) {\n potentialMatch.length = needleElements.length;\n potentialMatch.endPathIndex = haystackSelectorIndex;\n potentialMatch.endPathElementIndex = hackstackElementIndex + 1; // index after end of match\n potentialMatches.length = 0; // we don't allow matches to overlap, so start matching again\n matches.push(potentialMatch);\n }\n } else {\n potentialMatches.splice(i, 1);\n i--;\n }\n }\n }\n }\n return matches;\n }\n\n isElementValuesEqual(elementValue1, elementValue2) {\n if (typeof elementValue1 === 'string' || typeof elementValue2 === 'string') {\n return elementValue1 === elementValue2;\n }\n if (elementValue1 instanceof tree.Attribute) {\n if (elementValue1.op !== elementValue2.op || elementValue1.key !== elementValue2.key) {\n return false;\n }\n if (!elementValue1.value || !elementValue2.value) {\n if (elementValue1.value || elementValue2.value) {\n return false;\n }\n return true;\n }\n elementValue1 = elementValue1.value.value || elementValue1.value;\n elementValue2 = elementValue2.value.value || elementValue2.value;\n return elementValue1 === elementValue2;\n }\n elementValue1 = elementValue1.value;\n elementValue2 = elementValue2.value;\n if (elementValue1 instanceof tree.Selector) {\n if (!(elementValue2 instanceof tree.Selector) || elementValue1.elements.length !== elementValue2.elements.length) {\n return false;\n }\n for (let i = 0; i < elementValue1.elements.length; i++) {\n if (elementValue1.elements[i].combinator.value !== elementValue2.elements[i].combinator.value) {\n if (i !== 0 || (elementValue1.elements[i].combinator.value || ' ') !== (elementValue2.elements[i].combinator.value || ' ')) {\n return false;\n }\n }\n if (!this.isElementValuesEqual(elementValue1.elements[i].value, elementValue2.elements[i].value)) {\n return false;\n }\n }\n return true;\n }\n return false;\n }\n\n extendSelector(matches, selectorPath, replacementSelector, isVisible) {\n // for a set of matches, replace each match with the replacement selector\n\n let currentSelectorPathIndex = 0;\n\n let currentSelectorPathElementIndex = 0;\n let path = [];\n let matchIndex;\n let selector;\n let firstElement;\n let match;\n let newElements;\n\n for (matchIndex = 0; matchIndex < matches.length; matchIndex++) {\n match = matches[matchIndex];\n selector = selectorPath[match.pathIndex];\n firstElement = new tree.Element(\n match.initialCombinator,\n replacementSelector.elements[0].value,\n replacementSelector.elements[0].isVariable,\n replacementSelector.elements[0].getIndex(),\n replacementSelector.elements[0].fileInfo()\n );\n\n if (match.pathIndex > currentSelectorPathIndex && currentSelectorPathElementIndex > 0) {\n path[path.length - 1].elements = path[path.length - 1]\n .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex));\n currentSelectorPathElementIndex = 0;\n currentSelectorPathIndex++;\n }\n\n newElements = selector.elements\n .slice(currentSelectorPathElementIndex, match.index)\n .concat([firstElement])\n .concat(replacementSelector.elements.slice(1));\n\n if (currentSelectorPathIndex === match.pathIndex && matchIndex > 0) {\n path[path.length - 1].elements =\n path[path.length - 1].elements.concat(newElements);\n } else {\n path = path.concat(selectorPath.slice(currentSelectorPathIndex, match.pathIndex));\n\n path.push(new tree.Selector(\n newElements\n ));\n }\n currentSelectorPathIndex = match.endPathIndex;\n currentSelectorPathElementIndex = match.endPathElementIndex;\n if (currentSelectorPathElementIndex >= selectorPath[currentSelectorPathIndex].elements.length) {\n currentSelectorPathElementIndex = 0;\n currentSelectorPathIndex++;\n }\n }\n\n if (currentSelectorPathIndex < selectorPath.length && currentSelectorPathElementIndex > 0) {\n path[path.length - 1].elements = path[path.length - 1]\n .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex));\n currentSelectorPathIndex++;\n }\n\n path = path.concat(selectorPath.slice(currentSelectorPathIndex, selectorPath.length));\n path = path.map(currentValue => {\n // we can re-use elements here, because the visibility property matters only for selectors\n const derived = currentValue.createDerived(currentValue.elements);\n if (isVisible) {\n derived.ensureVisibility();\n } else {\n derived.ensureInvisibility();\n }\n return derived;\n });\n return path;\n }\n\n visitMedia(mediaNode, visitArgs) {\n let newAllExtends = mediaNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]);\n newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, mediaNode.allExtends));\n this.allExtendsStack.push(newAllExtends);\n }\n\n visitMediaOut(mediaNode) {\n const lastIndex = this.allExtendsStack.length - 1;\n this.allExtendsStack.length = lastIndex;\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n let newAllExtends = atRuleNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]);\n newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, atRuleNode.allExtends));\n this.allExtendsStack.push(newAllExtends);\n }\n\n visitAtRuleOut(atRuleNode) {\n const lastIndex = this.allExtendsStack.length - 1;\n this.allExtendsStack.length = lastIndex;\n }\n}\n\nexport default ProcessExtendsVisitor;\n","import Visitor from './visitor';\n\nclass JoinSelectorVisitor {\n constructor() {\n this.contexts = [[]];\n this._visitor = new Visitor(this);\n }\n\n run(root) {\n return this._visitor.visit(root);\n }\n\n visitDeclaration(declNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n const paths = [];\n let selectors;\n\n this.contexts.push(paths);\n\n if (!rulesetNode.root) {\n selectors = rulesetNode.selectors;\n if (selectors) {\n selectors = selectors.filter(selector => selector.getIsOutput());\n rulesetNode.selectors = selectors.length ? selectors : (selectors = null);\n if (selectors) { rulesetNode.joinSelectors(paths, context, selectors); }\n }\n if (!selectors) { rulesetNode.rules = null; }\n rulesetNode.paths = paths;\n }\n }\n\n visitRulesetOut(rulesetNode) {\n this.contexts.length = this.contexts.length - 1;\n }\n\n visitMedia(mediaNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n mediaNode.rules[0].root = (context.length === 0 || context[0].multiMedia);\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n if (atRuleNode.rules && atRuleNode.rules.length) {\n atRuleNode.rules[0].root = (atRuleNode.isRooted || context.length === 0 || null);\n }\n }\n}\n\nexport default JoinSelectorVisitor;\n","import tree from '../tree';\nimport Visitor from './visitor';\n\nclass CSSVisitorUtils {\n constructor(context) {\n this._visitor = new Visitor(this);\n this._context = context;\n }\n\n containsSilentNonBlockedChild(bodyRules) {\n let rule;\n if (!bodyRules) {\n return false;\n }\n for (let r = 0; r < bodyRules.length; r++) {\n rule = bodyRules[r];\n if (rule.isSilent && rule.isSilent(this._context) && !rule.blocksVisibility()) {\n // the atrule contains something that was referenced (likely by extend)\n // therefore it needs to be shown in output too\n return true;\n }\n }\n return false;\n }\n\n keepOnlyVisibleChilds(owner) {\n if (owner && owner.rules) {\n owner.rules = owner.rules.filter(thing => thing.isVisible());\n }\n }\n\n isEmpty(owner) {\n return (owner && owner.rules) \n ? (owner.rules.length === 0) : true;\n }\n\n hasVisibleSelector(rulesetNode) {\n return (rulesetNode && rulesetNode.paths)\n ? (rulesetNode.paths.length > 0) : false;\n }\n\n resolveVisibility(node, originalRules) {\n if (!node.blocksVisibility()) {\n if (this.isEmpty(node) && !this.containsSilentNonBlockedChild(originalRules)) {\n return ;\n }\n\n return node;\n }\n\n const compiledRulesBody = node.rules[0];\n this.keepOnlyVisibleChilds(compiledRulesBody);\n\n if (this.isEmpty(compiledRulesBody)) {\n return ;\n }\n\n node.ensureVisibility();\n node.removeVisibilityBlock();\n\n return node;\n }\n\n isVisibleRuleset(rulesetNode) {\n if (rulesetNode.firstRoot) {\n return true;\n }\n\n if (this.isEmpty(rulesetNode)) {\n return false;\n }\n\n if (!rulesetNode.root && !this.hasVisibleSelector(rulesetNode)) {\n return false;\n }\n\n return true;\n }\n}\n\nconst ToCSSVisitor = function(context) {\n this._visitor = new Visitor(this);\n this._context = context;\n this.utils = new CSSVisitorUtils(context);\n};\n\nToCSSVisitor.prototype = {\n isReplacing: true,\n run: function (root) {\n return this._visitor.visit(root);\n },\n\n visitDeclaration: function (declNode, visitArgs) {\n if (declNode.blocksVisibility() || declNode.variable) {\n return;\n }\n return declNode;\n },\n\n visitMixinDefinition: function (mixinNode, visitArgs) {\n // mixin definitions do not get eval'd - this means they keep state\n // so we have to clear that state here so it isn't used if toCSS is called twice\n mixinNode.frames = [];\n },\n\n visitExtend: function (extendNode, visitArgs) {\n },\n\n visitComment: function (commentNode, visitArgs) {\n if (commentNode.blocksVisibility() || commentNode.isSilent(this._context)) {\n return;\n }\n return commentNode;\n },\n\n visitMedia: function(mediaNode, visitArgs) {\n const originalRules = mediaNode.rules[0].rules;\n mediaNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n\n return this.utils.resolveVisibility(mediaNode, originalRules);\n },\n\n visitImport: function (importNode, visitArgs) {\n if (importNode.blocksVisibility()) {\n return ;\n }\n return importNode;\n },\n\n visitAtRule: function(atRuleNode, visitArgs) {\n if (atRuleNode.rules && atRuleNode.rules.length) {\n return this.visitAtRuleWithBody(atRuleNode, visitArgs);\n } else {\n return this.visitAtRuleWithoutBody(atRuleNode, visitArgs);\n }\n },\n\n visitAnonymous: function(anonymousNode, visitArgs) {\n if (!anonymousNode.blocksVisibility()) {\n anonymousNode.accept(this._visitor);\n return anonymousNode;\n }\n },\n\n visitAtRuleWithBody: function(atRuleNode, visitArgs) {\n // if there is only one nested ruleset and that one has no path, then it is\n // just fake ruleset\n function hasFakeRuleset(atRuleNode) {\n const bodyRules = atRuleNode.rules;\n return bodyRules.length === 1 && (!bodyRules[0].paths || bodyRules[0].paths.length === 0);\n }\n function getBodyRules(atRuleNode) {\n const nodeRules = atRuleNode.rules;\n if (hasFakeRuleset(atRuleNode)) {\n return nodeRules[0].rules;\n }\n\n return nodeRules;\n }\n // it is still true that it is only one ruleset in array\n // this is last such moment\n // process childs\n const originalRules = getBodyRules(atRuleNode);\n atRuleNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n\n if (!this.utils.isEmpty(atRuleNode)) {\n this._mergeRules(atRuleNode.rules[0].rules);\n }\n\n return this.utils.resolveVisibility(atRuleNode, originalRules);\n },\n\n visitAtRuleWithoutBody: function(atRuleNode, visitArgs) {\n if (atRuleNode.blocksVisibility()) {\n return;\n }\n\n if (atRuleNode.name === '@charset') {\n // Only output the debug info together with subsequent @charset definitions\n // a comment (or @media statement) before the actual @charset atrule would\n // be considered illegal css as it has to be on the first line\n if (this.charset) {\n if (atRuleNode.debugInfo) {\n const comment = new tree.Comment(`/* ${atRuleNode.toCSS(this._context).replace(/\\n/g, '')} */\\n`);\n comment.debugInfo = atRuleNode.debugInfo;\n return this._visitor.visit(comment);\n }\n return;\n }\n this.charset = true;\n }\n\n return atRuleNode;\n },\n\n checkValidNodes: function(rules, isRoot) {\n if (!rules) {\n return;\n }\n\n for (let i = 0; i < rules.length; i++) {\n const ruleNode = rules[i];\n if (isRoot && ruleNode instanceof tree.Declaration && !ruleNode.variable) {\n throw { message: 'Properties must be inside selector blocks. They cannot be in the root',\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n if (ruleNode instanceof tree.Call) {\n throw { message: `Function '${ruleNode.name}' is undefined`,\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n if (ruleNode.type && !ruleNode.allowRoot) {\n throw { message: `${ruleNode.type} node returned by a function is not valid here`,\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n }\n },\n\n visitRuleset: function (rulesetNode, visitArgs) {\n // at this point rulesets are nested into each other\n let rule;\n\n const rulesets = [];\n\n this.checkValidNodes(rulesetNode.rules, rulesetNode.firstRoot);\n\n if (!rulesetNode.root) {\n // remove invisible paths\n this._compileRulesetPaths(rulesetNode);\n\n // remove rulesets from this ruleset body and compile them separately\n const nodeRules = rulesetNode.rules;\n\n let nodeRuleCnt = nodeRules ? nodeRules.length : 0;\n for (let i = 0; i < nodeRuleCnt; ) {\n rule = nodeRules[i];\n if (rule && rule.rules) {\n // visit because we are moving them out from being a child\n rulesets.push(this._visitor.visit(rule));\n nodeRules.splice(i, 1);\n nodeRuleCnt--;\n continue;\n }\n i++;\n }\n // accept the visitor to remove rules and refactor itself\n // then we can decide nogw whether we want it or not\n // compile body\n if (nodeRuleCnt > 0) {\n rulesetNode.accept(this._visitor);\n } else {\n rulesetNode.rules = null;\n }\n visitArgs.visitDeeper = false;\n } else { // if (! rulesetNode.root) {\n rulesetNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n }\n\n if (rulesetNode.rules) {\n this._mergeRules(rulesetNode.rules);\n this._removeDuplicateRules(rulesetNode.rules);\n }\n\n // now decide whether we keep the ruleset\n if (this.utils.isVisibleRuleset(rulesetNode)) {\n rulesetNode.ensureVisibility();\n rulesets.splice(0, 0, rulesetNode);\n }\n\n if (rulesets.length === 1) {\n return rulesets[0];\n }\n return rulesets;\n },\n\n _compileRulesetPaths: function(rulesetNode) {\n if (rulesetNode.paths) {\n rulesetNode.paths = rulesetNode.paths\n .filter(p => {\n let i;\n if (p[0].elements[0].combinator.value === ' ') {\n p[0].elements[0].combinator = new(tree.Combinator)('');\n }\n for (i = 0; i < p.length; i++) {\n if (p[i].isVisible() && p[i].getIsOutput()) {\n return true;\n }\n }\n return false;\n });\n }\n },\n\n _removeDuplicateRules: function(rules) {\n if (!rules) { return; }\n\n // remove duplicates\n const ruleCache = {};\n\n let ruleList;\n let rule;\n let i;\n\n for (i = rules.length - 1; i >= 0 ; i--) {\n rule = rules[i];\n if (rule instanceof tree.Declaration) {\n if (!ruleCache[rule.name]) {\n ruleCache[rule.name] = rule;\n } else {\n ruleList = ruleCache[rule.name];\n if (ruleList instanceof tree.Declaration) {\n ruleList = ruleCache[rule.name] = [ruleCache[rule.name].toCSS(this._context)];\n }\n const ruleCSS = rule.toCSS(this._context);\n if (ruleList.indexOf(ruleCSS) !== -1) {\n rules.splice(i, 1);\n } else {\n ruleList.push(ruleCSS);\n }\n }\n }\n }\n },\n\n _mergeRules: function(rules) {\n if (!rules) {\n return; \n }\n\n const groups = {};\n const groupsArr = [];\n\n for (let i = 0; i < rules.length; i++) {\n const rule = rules[i];\n if (rule.merge) {\n const key = rule.name;\n groups[key] ? rules.splice(i--, 1) : \n groupsArr.push(groups[key] = []);\n groups[key].push(rule);\n }\n }\n\n groupsArr.forEach(group => {\n if (group.length > 0) {\n const result = group[0];\n let space = [];\n const comma = [new tree.Expression(space)];\n group.forEach(rule => {\n if ((rule.merge === '+') && (space.length > 0)) {\n comma.push(new tree.Expression(space = []));\n }\n space.push(rule.value);\n result.important = result.important || rule.important;\n });\n result.value = new tree.Value(comma);\n }\n });\n }\n};\n\nexport default ToCSSVisitor;\n","import Visitor from './visitor';\nimport ImportVisitor from './import-visitor';\nimport MarkVisibleSelectorsVisitor from './set-tree-visibility-visitor';\nimport ExtendVisitor from './extend-visitor';\nimport JoinSelectorVisitor from './join-selector-visitor';\nimport ToCSSVisitor from './to-css-visitor';\n\nexport default {\n Visitor,\n ImportVisitor,\n MarkVisibleSelectorsVisitor,\n ExtendVisitor,\n JoinSelectorVisitor,\n ToCSSVisitor\n};\n","import chunker from './chunker';\n\nexport default () => {\n let // Less input string\n input;\n\n let // current chunk\n j;\n\n const // holds state for backtracking\n saveStack = [];\n\n let // furthest index the parser has gone to\n furthest;\n\n let // if this is furthest we got to, this is the probably cause\n furthestPossibleErrorMessage;\n\n let // chunkified input\n chunks;\n\n let // current chunk\n current;\n\n let // index of current chunk, in `input`\n currentPos;\n\n const parserInput = {};\n const CHARCODE_SPACE = 32;\n const CHARCODE_TAB = 9;\n const CHARCODE_LF = 10;\n const CHARCODE_CR = 13;\n const CHARCODE_PLUS = 43;\n const CHARCODE_COMMA = 44;\n const CHARCODE_FORWARD_SLASH = 47;\n const CHARCODE_9 = 57;\n\n function skipWhitespace(length) {\n const oldi = parserInput.i;\n const oldj = j;\n const curr = parserInput.i - currentPos;\n const endIndex = parserInput.i + current.length - curr;\n const mem = (parserInput.i += length);\n const inp = input;\n let c;\n let nextChar;\n let comment;\n\n for (; parserInput.i < endIndex; parserInput.i++) {\n c = inp.charCodeAt(parserInput.i);\n\n if (parserInput.autoCommentAbsorb && c === CHARCODE_FORWARD_SLASH) {\n nextChar = inp.charAt(parserInput.i + 1);\n if (nextChar === '/') {\n comment = {index: parserInput.i, isLineComment: true};\n let nextNewLine = inp.indexOf('\\n', parserInput.i + 2);\n if (nextNewLine < 0) {\n nextNewLine = endIndex;\n }\n parserInput.i = nextNewLine;\n comment.text = inp.substr(comment.index, parserInput.i - comment.index);\n parserInput.commentStore.push(comment);\n continue;\n } else if (nextChar === '*') {\n const nextStarSlash = inp.indexOf('*/', parserInput.i + 2);\n if (nextStarSlash >= 0) {\n comment = {\n index: parserInput.i,\n text: inp.substr(parserInput.i, nextStarSlash + 2 - parserInput.i),\n isLineComment: false\n };\n parserInput.i += comment.text.length - 1;\n parserInput.commentStore.push(comment);\n continue;\n }\n }\n break;\n }\n\n if ((c !== CHARCODE_SPACE) && (c !== CHARCODE_LF) && (c !== CHARCODE_TAB) && (c !== CHARCODE_CR)) {\n break;\n }\n }\n\n current = current.slice(length + parserInput.i - mem + curr);\n currentPos = parserInput.i;\n\n if (!current.length) {\n if (j < chunks.length - 1) {\n current = chunks[++j];\n skipWhitespace(0); // skip space at the beginning of a chunk\n return true; // things changed\n }\n parserInput.finished = true;\n }\n\n return oldi !== parserInput.i || oldj !== j;\n }\n\n parserInput.save = () => {\n currentPos = parserInput.i;\n saveStack.push( { current, i: parserInput.i, j });\n };\n parserInput.restore = possibleErrorMessage => {\n\n if (parserInput.i > furthest || (parserInput.i === furthest && possibleErrorMessage && !furthestPossibleErrorMessage)) {\n furthest = parserInput.i;\n furthestPossibleErrorMessage = possibleErrorMessage;\n }\n const state = saveStack.pop();\n current = state.current;\n currentPos = parserInput.i = state.i;\n j = state.j;\n };\n parserInput.forget = () => {\n saveStack.pop();\n };\n parserInput.isWhitespace = offset => {\n const pos = parserInput.i + (offset || 0);\n const code = input.charCodeAt(pos);\n return (code === CHARCODE_SPACE || code === CHARCODE_CR || code === CHARCODE_TAB || code === CHARCODE_LF);\n };\n\n // Specialization of $(tok)\n parserInput.$re = tok => {\n if (parserInput.i > currentPos) {\n current = current.slice(parserInput.i - currentPos);\n currentPos = parserInput.i;\n }\n\n const m = tok.exec(current);\n if (!m) {\n return null;\n }\n\n skipWhitespace(m[0].length);\n if (typeof m === 'string') {\n return m;\n }\n\n return m.length === 1 ? m[0] : m;\n };\n\n parserInput.$char = tok => {\n if (input.charAt(parserInput.i) !== tok) {\n return null;\n }\n skipWhitespace(1);\n return tok;\n };\n\n parserInput.$str = tok => {\n const tokLength = tok.length;\n\n // https://jsperf.com/string-startswith/21\n for (let i = 0; i < tokLength; i++) {\n if (input.charAt(parserInput.i + i) !== tok.charAt(i)) {\n return null;\n }\n }\n\n skipWhitespace(tokLength);\n return tok;\n };\n\n parserInput.$quoted = loc => {\n const pos = loc || parserInput.i;\n const startChar = input.charAt(pos);\n\n if (startChar !== '\\'' && startChar !== '\"') {\n return;\n }\n const length = input.length;\n const currentPosition = pos;\n\n for (let i = 1; i + currentPosition < length; i++) {\n const nextChar = input.charAt(i + currentPosition);\n switch (nextChar) {\n case '\\\\':\n i++;\n continue;\n case '\\r':\n case '\\n':\n break;\n case startChar:\n const str = input.substr(currentPosition, i + 1);\n if (!loc && loc !== 0) {\n skipWhitespace(i + 1);\n return str\n }\n return [startChar, str];\n default:\n }\n }\n return null;\n };\n\n /**\n * Permissive parsing. Ignores everything except matching {} [] () and quotes\n * until matching token (outside of blocks)\n */\n parserInput.$parseUntil = tok => {\n let quote = '';\n let returnVal = null;\n let inComment = false;\n let blockDepth = 0;\n const blockStack = [];\n const parseGroups = [];\n const length = input.length;\n const startPos = parserInput.i;\n let lastPos = parserInput.i;\n let i = parserInput.i;\n let loop = true;\n let testChar;\n\n if (typeof tok === 'string') {\n testChar = char => char === tok\n } else {\n testChar = char => tok.test(char)\n }\n\n do {\n let prevChar;\n let nextChar = input.charAt(i);\n if (blockDepth === 0 && testChar(nextChar)) {\n returnVal = input.substr(lastPos, i - lastPos);\n if (returnVal) {\n parseGroups.push(returnVal);\n }\n else {\n parseGroups.push(' ');\n }\n returnVal = parseGroups;\n skipWhitespace(i - startPos);\n loop = false\n } else {\n if (inComment) {\n if (nextChar === '*' && \n input.charAt(i + 1) === '/') {\n i++;\n blockDepth--;\n inComment = false;\n }\n i++;\n continue;\n }\n switch (nextChar) {\n case '\\\\':\n i++;\n nextChar = input.charAt(i);\n parseGroups.push(input.substr(lastPos, i - lastPos + 1));\n lastPos = i + 1;\n break;\n case '/':\n if (input.charAt(i + 1) === '*') {\n i++;\n inComment = true;\n blockDepth++;\n }\n break;\n case '\\'':\n case '\"':\n quote = parserInput.$quoted(i);\n if (quote) {\n parseGroups.push(input.substr(lastPos, i - lastPos), quote);\n i += quote[1].length - 1;\n lastPos = i + 1;\n }\n else {\n skipWhitespace(i - startPos);\n returnVal = nextChar;\n loop = false;\n }\n break;\n case '{':\n blockStack.push('}');\n blockDepth++;\n break;\n case '(':\n blockStack.push(')');\n blockDepth++;\n break;\n case '[':\n blockStack.push(']');\n blockDepth++;\n break;\n case '}':\n case ')':\n case ']':\n const expected = blockStack.pop();\n if (nextChar === expected) {\n blockDepth--;\n } else {\n // move the parser to the error and return expected\n skipWhitespace(i - startPos);\n returnVal = expected;\n loop = false;\n }\n }\n i++;\n if (i > length) {\n loop = false;\n }\n }\n prevChar = nextChar;\n } while (loop);\n\n return returnVal ? returnVal : null;\n }\n\n parserInput.autoCommentAbsorb = true;\n parserInput.commentStore = [];\n parserInput.finished = false;\n\n // Same as $(), but don't change the state of the parser,\n // just return the match.\n parserInput.peek = tok => {\n if (typeof tok === 'string') {\n // https://jsperf.com/string-startswith/21\n for (let i = 0; i < tok.length; i++) {\n if (input.charAt(parserInput.i + i) !== tok.charAt(i)) {\n return false;\n }\n }\n return true;\n } else {\n return tok.test(current);\n }\n };\n\n // Specialization of peek()\n // TODO remove or change some currentChar calls to peekChar\n parserInput.peekChar = tok => input.charAt(parserInput.i) === tok;\n\n parserInput.currentChar = () => input.charAt(parserInput.i);\n\n parserInput.prevChar = () => input.charAt(parserInput.i - 1);\n\n parserInput.getInput = () => input;\n\n parserInput.peekNotNumeric = () => {\n const c = input.charCodeAt(parserInput.i);\n // Is the first char of the dimension 0-9, '.', '+' or '-'\n return (c > CHARCODE_9 || c < CHARCODE_PLUS) || c === CHARCODE_FORWARD_SLASH || c === CHARCODE_COMMA;\n };\n\n parserInput.start = (str, chunkInput, failFunction) => {\n input = str;\n parserInput.i = j = currentPos = furthest = 0;\n\n // chunking apparently makes things quicker (but my tests indicate\n // it might actually make things slower in node at least)\n // and it is a non-perfect parse - it can't recognise\n // unquoted urls, meaning it can't distinguish comments\n // meaning comments with quotes or {}() in them get 'counted'\n // and then lead to parse errors.\n // In addition if the chunking chunks in the wrong place we might\n // not be able to parse a parser statement in one go\n // this is officially deprecated but can be switched on via an option\n // in the case it causes too much performance issues.\n if (chunkInput) {\n chunks = chunker(str, failFunction);\n } else {\n chunks = [str];\n }\n\n current = chunks[0];\n\n skipWhitespace(0);\n };\n\n parserInput.end = () => {\n let message;\n const isFinished = parserInput.i >= input.length;\n\n if (parserInput.i < furthest) {\n message = furthestPossibleErrorMessage;\n parserInput.i = furthest;\n }\n return {\n isFinished,\n furthest: parserInput.i,\n furthestPossibleErrorMessage: message,\n furthestReachedEnd: parserInput.i >= input.length - 1,\n furthestChar: input[parserInput.i]\n };\n };\n\n return parserInput;\n};\n","// Split the input into chunks.\nexport default (input, fail) => {\n const len = input.length;\n let level = 0;\n let parenLevel = 0;\n let lastOpening;\n let lastOpeningParen;\n let lastMultiComment;\n let lastMultiCommentEndBrace;\n const chunks = [];\n let emitFrom = 0;\n let chunkerCurrentIndex;\n let currentChunkStartIndex;\n let cc;\n let cc2;\n let matched;\n\n function emitChunk(force) {\n const len = chunkerCurrentIndex - emitFrom;\n if (((len < 512) && !force) || !len) {\n return;\n }\n chunks.push(input.slice(emitFrom, chunkerCurrentIndex + 1));\n emitFrom = chunkerCurrentIndex + 1;\n }\n\n for (chunkerCurrentIndex = 0; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc = input.charCodeAt(chunkerCurrentIndex);\n if (((cc >= 97) && (cc <= 122)) || (cc < 34)) {\n // a-z or whitespace\n continue;\n }\n\n switch (cc) {\n case 40: // (\n parenLevel++;\n lastOpeningParen = chunkerCurrentIndex;\n continue;\n case 41: // )\n if (--parenLevel < 0) {\n return fail('missing opening `(`', chunkerCurrentIndex);\n }\n continue;\n case 59: // ;\n if (!parenLevel) { emitChunk(); }\n continue;\n case 123: // {\n level++;\n lastOpening = chunkerCurrentIndex;\n continue;\n case 125: // }\n if (--level < 0) {\n return fail('missing opening `{`', chunkerCurrentIndex);\n }\n if (!level && !parenLevel) { emitChunk(); }\n continue;\n case 92: // \\\n if (chunkerCurrentIndex < len - 1) { chunkerCurrentIndex++; continue; }\n return fail('unescaped `\\\\`', chunkerCurrentIndex);\n case 34:\n case 39:\n case 96: // \", ' and `\n matched = 0;\n currentChunkStartIndex = chunkerCurrentIndex;\n for (chunkerCurrentIndex = chunkerCurrentIndex + 1; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if (cc2 > 96) { continue; }\n if (cc2 == cc) { matched = 1; break; }\n if (cc2 == 92) { // \\\n if (chunkerCurrentIndex == len - 1) {\n return fail('unescaped `\\\\`', chunkerCurrentIndex);\n }\n chunkerCurrentIndex++;\n }\n }\n if (matched) { continue; }\n return fail(`unmatched \\`${String.fromCharCode(cc)}\\``, currentChunkStartIndex);\n case 47: // /, check for comment\n if (parenLevel || (chunkerCurrentIndex == len - 1)) { continue; }\n cc2 = input.charCodeAt(chunkerCurrentIndex + 1);\n if (cc2 == 47) {\n // //, find lnfeed\n for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if ((cc2 <= 13) && ((cc2 == 10) || (cc2 == 13))) { break; }\n }\n } else if (cc2 == 42) {\n // /*, find */\n lastMultiComment = currentChunkStartIndex = chunkerCurrentIndex;\n for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len - 1; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if (cc2 == 125) { lastMultiCommentEndBrace = chunkerCurrentIndex; }\n if (cc2 != 42) { continue; }\n if (input.charCodeAt(chunkerCurrentIndex + 1) == 47) { break; }\n }\n if (chunkerCurrentIndex == len - 1) {\n return fail('missing closing `*/`', currentChunkStartIndex);\n }\n chunkerCurrentIndex++;\n }\n continue;\n case 42: // *, check for unmatched */\n if ((chunkerCurrentIndex < len - 1) && (input.charCodeAt(chunkerCurrentIndex + 1) == 47)) {\n return fail('unmatched `/*`', chunkerCurrentIndex);\n }\n continue;\n }\n }\n\n if (level !== 0) {\n if ((lastMultiComment > lastOpening) && (lastMultiCommentEndBrace > lastMultiComment)) {\n return fail('missing closing `}` or `*/`', lastOpening);\n } else {\n return fail('missing closing `}`', lastOpening);\n }\n } else if (parenLevel !== 0) {\n return fail('missing closing `)`', lastOpeningParen);\n }\n\n emitChunk(true);\n return chunks;\n};\n","import LessError from '../less-error';\nimport tree from '../tree';\nimport visitors from '../visitors';\nimport getParserInput from './parser-input';\nimport * as utils from '../utils';\nimport functionRegistry from '../functions/function-registry';\n\n//\n// less.js - parser\n//\n// A relatively straight-forward predictive parser.\n// There is no tokenization/lexing stage, the input is parsed\n// in one sweep.\n//\n// To make the parser fast enough to run in the browser, several\n// optimization had to be made:\n//\n// - Matching and slicing on a huge input is often cause of slowdowns.\n// The solution is to chunkify the input into smaller strings.\n// The chunks are stored in the `chunks` var,\n// `j` holds the current chunk index, and `currentPos` holds\n// the index of the current chunk in relation to `input`.\n// This gives us an almost 4x speed-up.\n//\n// - In many cases, we don't need to match individual tokens;\n// for example, if a value doesn't hold any variables, operations\n// or dynamic references, the parser can effectively 'skip' it,\n// treating it as a literal.\n// An example would be '1px solid #000' - which evaluates to itself,\n// we don't need to know what the individual components are.\n// The drawback, of course is that you don't get the benefits of\n// syntax-checking on the CSS. This gives us a 50% speed-up in the parser,\n// and a smaller speed-up in the code-gen.\n//\n//\n// Token matching is done with the `$` function, which either takes\n// a terminal string or regexp, or a non-terminal function to call.\n// It also takes care of moving all the indices forwards.\n//\n\nconst Parser = function Parser(context, imports, fileInfo) {\n let parsers;\n const parserInput = getParserInput();\n\n function error(msg, type) {\n throw new LessError(\n {\n index: parserInput.i,\n filename: fileInfo.filename,\n type: type || 'Syntax',\n message: msg\n },\n imports\n );\n }\n\n function expect(arg, msg) {\n // some older browsers return typeof 'function' for RegExp\n const result = (arg instanceof Function) ? arg.call(parsers) : parserInput.$re(arg);\n if (result) {\n return result;\n }\n \n error(msg || (typeof arg === 'string'\n ? `expected '${arg}' got '${parserInput.currentChar()}'`\n : 'unexpected token'));\n }\n\n // Specialization of expect()\n function expectChar(arg, msg) {\n if (parserInput.$char(arg)) {\n return arg;\n }\n error(msg || `expected '${arg}' got '${parserInput.currentChar()}'`);\n }\n\n function getDebugInfo(index) {\n const filename = fileInfo.filename;\n\n return {\n lineNumber: utils.getLocation(index, parserInput.getInput()).line + 1,\n fileName: filename\n };\n }\n\n /**\n * Used after initial parsing to create nodes on the fly\n * \n * @param {String} str - string to parse \n * @param {Array} parseList - array of parsers to run input through e.g. [\"value\", \"important\"]\n * @param {Number} currentIndex - start number to begin indexing\n * @param {Object} fileInfo - fileInfo to attach to created nodes\n */\n function parseNode(str, parseList, currentIndex, fileInfo, callback) {\n let result;\n const returnNodes = [];\n const parser = parserInput;\n\n try {\n parser.start(str, false, function fail(msg, index) {\n callback({\n message: msg,\n index: index + currentIndex\n });\n });\n for (let x = 0, p, i; (p = parseList[x]); x++) {\n i = parser.i;\n result = parsers[p]();\n if (result) {\n try {\n result._index = i + currentIndex;\n result._fileInfo = fileInfo;\n } catch (e) {}\n returnNodes.push(result);\n }\n else {\n returnNodes.push(null);\n }\n }\n\n const endInfo = parser.end();\n if (endInfo.isFinished) {\n callback(null, returnNodes);\n }\n else {\n callback(true, null);\n }\n } catch (e) {\n throw new LessError({\n index: e.index + currentIndex,\n message: e.message\n }, imports, fileInfo.filename);\n }\n }\n\n //\n // The Parser\n //\n return {\n parserInput,\n imports,\n fileInfo,\n parseNode,\n //\n // Parse an input string into an abstract syntax tree,\n // @param str A string containing 'less' markup\n // @param callback call `callback` when done.\n // @param [additionalData] An optional map which can contains vars - a map (key, value) of variables to apply\n //\n parse: function (str, callback, additionalData) {\n let root;\n let error = null;\n let globalVars;\n let modifyVars;\n let ignored;\n let preText = '';\n\n globalVars = (additionalData && additionalData.globalVars) ? `${Parser.serializeVars(additionalData.globalVars)}\\n` : '';\n modifyVars = (additionalData && additionalData.modifyVars) ? `\\n${Parser.serializeVars(additionalData.modifyVars)}` : '';\n\n if (context.pluginManager) {\n const preProcessors = context.pluginManager.getPreProcessors();\n for (let i = 0; i < preProcessors.length; i++) {\n str = preProcessors[i].process(str, { context, imports, fileInfo });\n }\n }\n\n if (globalVars || (additionalData && additionalData.banner)) {\n preText = ((additionalData && additionalData.banner) ? additionalData.banner : '') + globalVars;\n ignored = imports.contentsIgnoredChars;\n ignored[fileInfo.filename] = ignored[fileInfo.filename] || 0;\n ignored[fileInfo.filename] += preText.length;\n }\n\n str = str.replace(/\\r\\n?/g, '\\n');\n // Remove potential UTF Byte Order Mark\n str = preText + str.replace(/^\\uFEFF/, '') + modifyVars;\n imports.contents[fileInfo.filename] = str;\n\n // Start with the primary rule.\n // The whole syntax tree is held under a Ruleset node,\n // with the `root` property set to true, so no `{}` are\n // output. The callback is called when the input is parsed.\n try {\n parserInput.start(str, context.chunkInput, function fail(msg, index) {\n throw new LessError({\n index,\n type: 'Parse',\n message: msg,\n filename: fileInfo.filename\n }, imports);\n });\n\n tree.Node.prototype.parse = this;\n root = new tree.Ruleset(null, this.parsers.primary());\n tree.Node.prototype.rootNode = root;\n root.root = true;\n root.firstRoot = true;\n root.functionRegistry = functionRegistry.inherit();\n \n } catch (e) {\n return callback(new LessError(e, imports, fileInfo.filename));\n }\n\n // If `i` is smaller than the `input.length - 1`,\n // it means the parser wasn't able to parse the whole\n // string, so we've got a parsing error.\n //\n // We try to extract a \\n delimited string,\n // showing the line where the parse error occurred.\n // We split it up into two parts (the part which parsed,\n // and the part which didn't), so we can color them differently.\n const endInfo = parserInput.end();\n if (!endInfo.isFinished) {\n\n let message = endInfo.furthestPossibleErrorMessage;\n\n if (!message) {\n message = 'Unrecognised input';\n if (endInfo.furthestChar === '}') {\n message += '. Possibly missing opening \\'{\\'';\n } else if (endInfo.furthestChar === ')') {\n message += '. Possibly missing opening \\'(\\'';\n } else if (endInfo.furthestReachedEnd) {\n message += '. Possibly missing something';\n }\n }\n\n error = new LessError({\n type: 'Parse',\n message,\n index: endInfo.furthest,\n filename: fileInfo.filename\n }, imports);\n }\n\n const finish = e => {\n e = error || e || imports.error;\n\n if (e) {\n if (!(e instanceof LessError)) {\n e = new LessError(e, imports, fileInfo.filename);\n }\n\n return callback(e);\n }\n else {\n return callback(null, root);\n }\n };\n\n if (context.processImports !== false) {\n new visitors.ImportVisitor(imports, finish)\n .run(root);\n } else {\n return finish();\n }\n },\n\n //\n // Here in, the parsing rules/functions\n //\n // The basic structure of the syntax tree generated is as follows:\n //\n // Ruleset -> Declaration -> Value -> Expression -> Entity\n //\n // Here's some Less code:\n //\n // .class {\n // color: #fff;\n // border: 1px solid #000;\n // width: @w + 4px;\n // > .child {...}\n // }\n //\n // And here's what the parse tree might look like:\n //\n // Ruleset (Selector '.class', [\n // Declaration (\"color\", Value ([Expression [Color #fff]]))\n // Declaration (\"border\", Value ([Expression [Dimension 1px][Keyword \"solid\"][Color #000]]))\n // Declaration (\"width\", Value ([Expression [Operation \" + \" [Variable \"@w\"][Dimension 4px]]]))\n // Ruleset (Selector [Element '>', '.child'], [...])\n // ])\n //\n // In general, most rules will try to parse a token with the `$re()` function, and if the return\n // value is truly, will return a new node, of the relevant type. Sometimes, we need to check\n // first, before parsing, that's when we use `peek()`.\n //\n parsers: parsers = {\n //\n // The `primary` rule is the *entry* and *exit* point of the parser.\n // The rules here can appear at any level of the parse tree.\n //\n // The recursive nature of the grammar is an interplay between the `block`\n // rule, which represents `{ ... }`, the `ruleset` rule, and this `primary` rule,\n // as represented by this simplified grammar:\n //\n // primary → (ruleset | declaration)+\n // ruleset → selector+ block\n // block → '{' primary '}'\n //\n // Only at one point is the primary rule not called from the\n // block rule: at the root level.\n //\n primary: function () {\n const mixin = this.mixin;\n let root = [];\n let node;\n\n while (true) {\n while (true) {\n node = this.comment();\n if (!node) { break; }\n root.push(node);\n }\n // always process comments before deciding if finished\n if (parserInput.finished) {\n break;\n }\n if (parserInput.peek('}')) {\n break;\n }\n\n node = this.extendRule();\n if (node) {\n root = root.concat(node);\n continue;\n }\n\n node = mixin.definition() || this.declaration() || mixin.call(false, false) || \n this.ruleset() || this.variableCall() || this.entities.call() || this.atrule();\n if (node) {\n root.push(node);\n } else {\n let foundSemiColon = false;\n while (parserInput.$char(';')) {\n foundSemiColon = true;\n }\n if (!foundSemiColon) {\n break;\n }\n }\n }\n\n return root;\n },\n\n // comments are collected by the main parsing mechanism and then assigned to nodes\n // where the current structure allows it\n comment: function () {\n if (parserInput.commentStore.length) {\n const comment = parserInput.commentStore.shift();\n return new(tree.Comment)(comment.text, comment.isLineComment, comment.index, fileInfo);\n }\n },\n\n //\n // Entities are tokens which can be found inside an Expression\n //\n entities: {\n mixinLookup: function() {\n return parsers.mixin.call(true, true);\n },\n //\n // A string, which supports escaping \" and '\n //\n // \"milky way\" 'he\\'s the one!'\n //\n quoted: function (forceEscaped) {\n let str;\n const index = parserInput.i;\n let isEscaped = false;\n\n parserInput.save();\n if (parserInput.$char('~')) {\n isEscaped = true;\n } else if (forceEscaped) {\n parserInput.restore();\n return;\n }\n\n str = parserInput.$quoted();\n if (!str) {\n parserInput.restore();\n return;\n }\n parserInput.forget();\n\n return new(tree.Quoted)(str.charAt(0), str.substr(1, str.length - 2), isEscaped, index, fileInfo);\n },\n\n //\n // A catch-all word, such as:\n //\n // black border-collapse\n //\n keyword: function () {\n const k = parserInput.$char('%') || parserInput.$re(/^\\[?(?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+\\]?/);\n if (k) {\n return tree.Color.fromKeyword(k) || new(tree.Keyword)(k);\n }\n },\n\n //\n // A function call\n //\n // rgb(255, 0, 255)\n //\n // The arguments are parsed with the `entities.arguments` parser.\n //\n call: function () {\n let name;\n let args;\n let func;\n const index = parserInput.i;\n\n // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18\n if (parserInput.peek(/^url\\(/i)) {\n return;\n }\n\n parserInput.save();\n\n name = parserInput.$re(/^([\\w-]+|%|progid:[\\w\\.]+)\\(/);\n if (!name) {\n parserInput.forget(); \n return;\n }\n\n name = name[1];\n func = this.customFuncCall(name);\n if (func) {\n args = func.parse();\n if (args && func.stop) {\n parserInput.forget();\n return args;\n }\n }\n\n args = this.arguments(args);\n\n if (!parserInput.$char(')')) {\n parserInput.restore('Could not parse call arguments or missing \\')\\'');\n return;\n }\n\n parserInput.forget();\n\n return new(tree.Call)(name, args, index, fileInfo);\n },\n \n //\n // Parsing rules for functions with non-standard args, e.g.:\n //\n // boolean(not(2 > 1))\n //\n // This is a quick prototype, to be modified/improved when\n // more custom-parsed funcs come (e.g. `selector(...)`)\n //\n\n customFuncCall: function (name) {\n /* Ideally the table is to be moved out of here for faster perf.,\n but it's quite tricky since it relies on all these `parsers`\n and `expect` available only here */\n return {\n alpha: f(parsers.ieAlpha, true),\n boolean: f(condition),\n 'if': f(condition)\n }[name.toLowerCase()];\n\n function f(parse, stop) {\n return {\n parse, // parsing function\n stop // when true - stop after parse() and return its result, \n // otherwise continue for plain args\n };\n }\n \n function condition() {\n return [expect(parsers.condition, 'expected condition')];\n }\n },\n\n arguments: function (prevArgs) {\n let argsComma = prevArgs || [];\n const argsSemiColon = [];\n let isSemiColonSeparated;\n let value;\n\n parserInput.save();\n\n while (true) {\n if (prevArgs) {\n prevArgs = false;\n } else {\n value = parsers.detachedRuleset() || this.assignment() || parsers.expression();\n if (!value) {\n break;\n }\n\n if (value.value && value.value.length == 1) {\n value = value.value[0];\n }\n\n argsComma.push(value);\n }\n\n if (parserInput.$char(',')) {\n continue;\n }\n\n if (parserInput.$char(';') || isSemiColonSeparated) {\n isSemiColonSeparated = true;\n value = (argsComma.length < 1) ? argsComma[0]\n : new tree.Value(argsComma);\n argsSemiColon.push(value);\n argsComma = [];\n }\n }\n\n parserInput.forget();\n return isSemiColonSeparated ? argsSemiColon : argsComma;\n },\n literal: function () {\n return this.dimension() ||\n this.color() ||\n this.quoted() ||\n this.unicodeDescriptor();\n },\n\n // Assignments are argument entities for calls.\n // They are present in ie filter properties as shown below.\n //\n // filter: progid:DXImageTransform.Microsoft.Alpha( *opacity=50* )\n //\n\n assignment: function () {\n let key;\n let value;\n parserInput.save();\n key = parserInput.$re(/^\\w+(?=\\s?=)/i);\n if (!key) {\n parserInput.restore();\n return;\n }\n if (!parserInput.$char('=')) {\n parserInput.restore();\n return;\n }\n value = parsers.entity();\n if (value) {\n parserInput.forget();\n return new(tree.Assignment)(key, value);\n } else {\n parserInput.restore();\n }\n },\n\n //\n // Parse url() tokens\n //\n // We use a specific rule for urls, because they don't really behave like\n // standard function calls. The difference is that the argument doesn't have\n // to be enclosed within a string, so it can't be parsed as an Expression.\n //\n url: function () {\n let value;\n const index = parserInput.i;\n\n parserInput.autoCommentAbsorb = false;\n\n if (!parserInput.$str('url(')) {\n parserInput.autoCommentAbsorb = true;\n return;\n }\n\n value = this.quoted() || this.variable() || this.property() ||\n parserInput.$re(/^(?:(?:\\\\[\\(\\)'\"])|[^\\(\\)'\"])+/) || '';\n\n parserInput.autoCommentAbsorb = true;\n\n expectChar(')');\n\n return new(tree.URL)((value.value != null || \n value instanceof tree.Variable || \n value instanceof tree.Property) ?\n value : new(tree.Anonymous)(value, index), index, fileInfo);\n },\n\n //\n // A Variable entity, such as `@fink`, in\n //\n // width: @fink + 2px\n //\n // We use a different parser for variable definitions,\n // see `parsers.variable`.\n //\n variable: function () {\n let ch;\n let name;\n const index = parserInput.i;\n\n parserInput.save();\n if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^@@?[\\w-]+/))) {\n ch = parserInput.currentChar();\n if (ch === '(' || ch === '[' && !parserInput.prevChar().match(/^\\s/)) {\n // this may be a VariableCall lookup\n const result = parsers.variableCall(name);\n if (result) {\n parserInput.forget();\n return result;\n }\n }\n parserInput.forget();\n return new(tree.Variable)(name, index, fileInfo);\n }\n parserInput.restore();\n },\n\n // A variable entity using the protective {} e.g. @{var}\n variableCurly: function () {\n let curly;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '@' && (curly = parserInput.$re(/^@\\{([\\w-]+)\\}/))) {\n return new(tree.Variable)(`@${curly[1]}`, index, fileInfo);\n }\n },\n //\n // A Property accessor, such as `$color`, in\n //\n // background-color: $color\n //\n property: function () {\n let name;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '$' && (name = parserInput.$re(/^\\$[\\w-]+/))) {\n return new(tree.Property)(name, index, fileInfo);\n }\n },\n\n // A property entity useing the protective {} e.g. ${prop}\n propertyCurly: function () {\n let curly;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '$' && (curly = parserInput.$re(/^\\$\\{([\\w-]+)\\}/))) {\n return new(tree.Property)(`$${curly[1]}`, index, fileInfo);\n }\n },\n //\n // A Hexadecimal color\n //\n // #4F3C2F\n //\n // `rgb` and `hsl` colors are parsed through the `entities.call` parser.\n //\n color: function () {\n let rgb;\n parserInput.save();\n\n if (parserInput.currentChar() === '#' && (rgb = parserInput.$re(/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})([\\w.#\\[])?/))) {\n if (!rgb[2]) {\n parserInput.forget();\n return new(tree.Color)(rgb[1], undefined, rgb[0]);\n } \n }\n parserInput.restore();\n },\n\n colorKeyword: function () {\n parserInput.save();\n const autoCommentAbsorb = parserInput.autoCommentAbsorb;\n parserInput.autoCommentAbsorb = false;\n const k = parserInput.$re(/^[_A-Za-z-][_A-Za-z0-9-]+/);\n parserInput.autoCommentAbsorb = autoCommentAbsorb;\n if (!k) {\n parserInput.forget();\n return;\n }\n parserInput.restore();\n const color = tree.Color.fromKeyword(k);\n if (color) {\n parserInput.$str(k);\n return color;\n }\n },\n\n //\n // A Dimension, that is, a number and a unit\n //\n // 0.5em 95%\n //\n dimension: function () {\n if (parserInput.peekNotNumeric()) {\n return;\n }\n\n const value = parserInput.$re(/^([+-]?\\d*\\.?\\d+)(%|[a-z_]+)?/i);\n if (value) {\n return new(tree.Dimension)(value[1], value[2]);\n }\n },\n\n //\n // A unicode descriptor, as is used in unicode-range\n //\n // U+0?? or U+00A1-00A9\n //\n unicodeDescriptor: function () {\n let ud;\n\n ud = parserInput.$re(/^U\\+[0-9a-fA-F?]+(\\-[0-9a-fA-F?]+)?/);\n if (ud) {\n return new(tree.UnicodeDescriptor)(ud[0]);\n }\n },\n\n //\n // JavaScript code to be evaluated\n //\n // `window.location.href`\n //\n javascript: function () {\n let js;\n const index = parserInput.i;\n\n parserInput.save();\n\n const escape = parserInput.$char('~');\n const jsQuote = parserInput.$char('`');\n\n if (!jsQuote) {\n parserInput.restore();\n return;\n }\n\n js = parserInput.$re(/^[^`]*`/);\n if (js) {\n parserInput.forget();\n return new(tree.JavaScript)(js.substr(0, js.length - 1), Boolean(escape), index, fileInfo);\n }\n parserInput.restore('invalid javascript definition');\n }\n },\n\n //\n // The variable part of a variable definition. Used in the `rule` parser\n //\n // @fink:\n //\n variable: function () {\n let name;\n\n if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^(@[\\w-]+)\\s*:/))) { return name[1]; }\n },\n\n //\n // Call a variable value to retrieve a detached ruleset\n // or a value from a detached ruleset's rules.\n //\n // @fink();\n // @fink;\n // color: @fink[@color];\n //\n variableCall: function (parsedName) {\n let lookups;\n const i = parserInput.i;\n const inValue = !!parsedName;\n let name = parsedName;\n\n parserInput.save();\n\n if (name || (parserInput.currentChar() === '@'\n && (name = parserInput.$re(/^(@[\\w-]+)(\\(\\s*\\))?/)))) {\n\n lookups = this.mixin.ruleLookups();\n\n if (!lookups && ((inValue && parserInput.$str('()') !== '()') || (name[2] !== '()'))) {\n parserInput.restore('Missing \\'[...]\\' lookup in variable call');\n return;\n }\n\n if (!inValue) {\n name = name[1];\n }\n\n const call = new tree.VariableCall(name, i, fileInfo);\n if (!inValue && parsers.end()) {\n parserInput.forget();\n return call;\n }\n else {\n parserInput.forget();\n return new tree.NamespaceValue(call, lookups, i, fileInfo);\n }\n }\n\n parserInput.restore();\n },\n\n //\n // extend syntax - used to extend selectors\n //\n extend: function(isRule) {\n let elements;\n let e;\n const index = parserInput.i;\n let option;\n let extendList;\n let extend;\n\n if (!parserInput.$str(isRule ? '&:extend(' : ':extend(')) {\n return;\n }\n\n do {\n option = null;\n elements = null;\n while (!(option = parserInput.$re(/^(all)(?=\\s*(\\)|,))/))) {\n e = this.element();\n if (!e) {\n break;\n }\n if (elements) {\n elements.push(e);\n } else {\n elements = [ e ];\n }\n }\n\n option = option && option[1];\n if (!elements) {\n error('Missing target selector for :extend().');\n }\n extend = new(tree.Extend)(new(tree.Selector)(elements), option, index, fileInfo);\n if (extendList) {\n extendList.push(extend);\n } else {\n extendList = [ extend ];\n }\n } while (parserInput.$char(','));\n\n expect(/^\\)/);\n\n if (isRule) {\n expect(/^;/);\n }\n\n return extendList;\n },\n\n //\n // extendRule - used in a rule to extend all the parent selectors\n //\n extendRule: function() {\n return this.extend(true);\n },\n\n //\n // Mixins\n //\n mixin: {\n //\n // A Mixin call, with an optional argument list\n //\n // #mixins > .square(#fff);\n // #mixins.square(#fff);\n // .rounded(4px, black);\n // .button;\n //\n // We can lookup / return a value using the lookup syntax:\n //\n // color: #mixin.square(#fff)[@color];\n //\n // The `while` loop is there because mixins can be\n // namespaced, but we only support the child and descendant\n // selector for now.\n //\n call: function (inValue, getLookup) {\n const s = parserInput.currentChar();\n let important = false;\n let lookups;\n const index = parserInput.i;\n let elements;\n let args;\n let hasParens;\n\n if (s !== '.' && s !== '#') { return; }\n\n parserInput.save(); // stop us absorbing part of an invalid selector\n\n elements = this.elements();\n\n if (elements) {\n if (parserInput.$char('(')) {\n args = this.args(true).args;\n expectChar(')');\n hasParens = true;\n }\n\n if (getLookup !== false) {\n lookups = this.ruleLookups();\n }\n if (getLookup === true && !lookups) {\n parserInput.restore();\n return;\n }\n\n if (inValue && !lookups && !hasParens) {\n // This isn't a valid in-value mixin call\n parserInput.restore();\n return;\n }\n\n if (!inValue && parsers.important()) {\n important = true;\n }\n\n if (inValue || parsers.end()) {\n parserInput.forget();\n const mixin = new(tree.mixin.Call)(elements, args, index, fileInfo, !lookups && important);\n if (lookups) {\n return new tree.NamespaceValue(mixin, lookups);\n }\n else {\n return mixin;\n }\n }\n }\n\n parserInput.restore();\n },\n /**\n * Matching elements for mixins\n * (Start with . or # and can have > )\n */\n elements: function() {\n let elements;\n let e;\n let c;\n let elem;\n let elemIndex;\n const re = /^[#.](?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/;\n while (true) {\n elemIndex = parserInput.i;\n e = parserInput.$re(re);\n \n if (!e) {\n break;\n }\n elem = new(tree.Element)(c, e, false, elemIndex, fileInfo);\n if (elements) {\n elements.push(elem);\n } else {\n elements = [ elem ];\n }\n c = parserInput.$char('>');\n }\n return elements;\n },\n args: function (isCall) {\n const entities = parsers.entities;\n const returner = { args:null, variadic: false };\n let expressions = [];\n const argsSemiColon = [];\n const argsComma = [];\n let isSemiColonSeparated;\n let expressionContainsNamed;\n let name;\n let nameLoop;\n let value;\n let arg;\n let expand;\n let hasSep = true;\n\n parserInput.save();\n\n while (true) {\n if (isCall) {\n arg = parsers.detachedRuleset() || parsers.expression();\n } else {\n parserInput.commentStore.length = 0;\n if (parserInput.$str('...')) {\n returner.variadic = true;\n if (parserInput.$char(';') && !isSemiColonSeparated) {\n isSemiColonSeparated = true;\n }\n (isSemiColonSeparated ? argsSemiColon : argsComma)\n .push({ variadic: true });\n break;\n }\n arg = entities.variable() || entities.property() || entities.literal() || entities.keyword() || this.call(true);\n }\n\n if (!arg || !hasSep) {\n break;\n }\n\n nameLoop = null;\n if (arg.throwAwayComments) {\n arg.throwAwayComments();\n }\n value = arg;\n let val = null;\n\n if (isCall) {\n // Variable\n if (arg.value && arg.value.length == 1) {\n val = arg.value[0];\n }\n } else {\n val = arg;\n }\n\n if (val && (val instanceof tree.Variable || val instanceof tree.Property)) {\n if (parserInput.$char(':')) {\n if (expressions.length > 0) {\n if (isSemiColonSeparated) {\n error('Cannot mix ; and , as delimiter types');\n }\n expressionContainsNamed = true;\n }\n\n value = parsers.detachedRuleset() || parsers.expression();\n\n if (!value) {\n if (isCall) {\n error('could not understand value for named argument');\n } else {\n parserInput.restore();\n returner.args = [];\n return returner;\n }\n }\n nameLoop = (name = val.name);\n } else if (parserInput.$str('...')) {\n if (!isCall) {\n returner.variadic = true;\n if (parserInput.$char(';') && !isSemiColonSeparated) {\n isSemiColonSeparated = true;\n }\n (isSemiColonSeparated ? argsSemiColon : argsComma)\n .push({ name: arg.name, variadic: true });\n break;\n } else {\n expand = true;\n }\n } else if (!isCall) {\n name = nameLoop = val.name;\n value = null;\n }\n }\n\n if (value) {\n expressions.push(value);\n }\n\n argsComma.push({ name:nameLoop, value, expand });\n\n if (parserInput.$char(',')) {\n hasSep = true;\n continue;\n }\n hasSep = parserInput.$char(';') === ';';\n\n if (hasSep || isSemiColonSeparated) {\n\n if (expressionContainsNamed) {\n error('Cannot mix ; and , as delimiter types');\n }\n\n isSemiColonSeparated = true;\n\n if (expressions.length > 1) {\n value = new(tree.Value)(expressions);\n }\n argsSemiColon.push({ name, value, expand });\n\n name = null;\n expressions = [];\n expressionContainsNamed = false;\n }\n }\n\n parserInput.forget();\n returner.args = isSemiColonSeparated ? argsSemiColon : argsComma;\n return returner;\n },\n //\n // A Mixin definition, with a list of parameters\n //\n // .rounded (@radius: 2px, @color) {\n // ...\n // }\n //\n // Until we have a finer grained state-machine, we have to\n // do a look-ahead, to make sure we don't have a mixin call.\n // See the `rule` function for more information.\n //\n // We start by matching `.rounded (`, and then proceed on to\n // the argument list, which has optional default values.\n // We store the parameters in `params`, with a `value` key,\n // if there is a value, such as in the case of `@radius`.\n //\n // Once we've got our params list, and a closing `)`, we parse\n // the `{...}` block.\n //\n definition: function () {\n let name;\n let params = [];\n let match;\n let ruleset;\n let cond;\n let variadic = false;\n if ((parserInput.currentChar() !== '.' && parserInput.currentChar() !== '#') ||\n parserInput.peek(/^[^{]*\\}/)) {\n return;\n }\n\n parserInput.save();\n\n match = parserInput.$re(/^([#.](?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\\s*\\(/);\n if (match) {\n name = match[1];\n\n const argInfo = this.args(false);\n params = argInfo.args;\n variadic = argInfo.variadic;\n\n // .mixincall(\"@{a}\");\n // looks a bit like a mixin definition..\n // also\n // .mixincall(@a: {rule: set;});\n // so we have to be nice and restore\n if (!parserInput.$char(')')) {\n parserInput.restore('Missing closing \\')\\'');\n return;\n }\n\n parserInput.commentStore.length = 0;\n\n if (parserInput.$str('when')) { // Guard\n cond = expect(parsers.conditions, 'expected condition');\n }\n\n ruleset = parsers.block();\n\n if (ruleset) {\n parserInput.forget();\n return new(tree.mixin.Definition)(name, params, ruleset, cond, variadic);\n } else {\n parserInput.restore();\n }\n } else {\n parserInput.restore();\n }\n },\n \n ruleLookups: function() {\n let rule;\n let args;\n const lookups = [];\n\n if (parserInput.currentChar() !== '[') { \n return;\n }\n\n while (true) {\n parserInput.save();\n args = null;\n rule = this.lookupValue();\n if (!rule && rule !== '') {\n parserInput.restore();\n break;\n }\n lookups.push(rule);\n parserInput.forget();\n }\n if (lookups.length > 0) {\n return lookups;\n }\n },\n \n lookupValue: function() {\n parserInput.save();\n \n if (!parserInput.$char('[')) { \n parserInput.restore();\n return;\n }\n \n const name = parserInput.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/);\n \n if (!parserInput.$char(']')) {\n parserInput.restore();\n return;\n } \n\n if (name || name === '') {\n parserInput.forget();\n return name;\n }\n \n parserInput.restore();\n }\n },\n //\n // Entities are the smallest recognized token,\n // and can be found inside a rule's value.\n //\n entity: function () {\n const entities = this.entities;\n\n return this.comment() || entities.literal() || entities.variable() || entities.url() ||\n entities.property() || entities.call() || entities.keyword() || this.mixin.call(true) ||\n entities.javascript();\n },\n\n //\n // A Declaration terminator. Note that we use `peek()` to check for '}',\n // because the `block` rule will be expecting it, but we still need to make sure\n // it's there, if ';' was omitted.\n //\n end: function () {\n return parserInput.$char(';') || parserInput.peek('}');\n },\n\n //\n // IE's alpha function\n //\n // alpha(opacity=88)\n //\n ieAlpha: function () {\n let value;\n\n // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18\n if (!parserInput.$re(/^opacity=/i)) { return; }\n value = parserInput.$re(/^\\d+/);\n if (!value) {\n value = expect(parsers.entities.variable, 'Could not parse alpha');\n value = `@{${value.name.slice(1)}}`;\n }\n expectChar(')');\n return new tree.Quoted('', `alpha(opacity=${value})`);\n },\n\n //\n // A Selector Element\n //\n // div\n // + h1\n // #socks\n // input[type=\"text\"]\n //\n // Elements are the building blocks for Selectors,\n // they are made out of a `Combinator` (see combinator rule),\n // and an element name, such as a tag a class, or `*`.\n //\n element: function () {\n let e;\n let c;\n let v;\n const index = parserInput.i;\n\n c = this.combinator();\n\n e = parserInput.$re(/^(?:\\d+\\.\\d+|\\d+)%/) ||\n parserInput.$re(/^(?:[.#]?|:*)(?:[\\w-]|[^\\x00-\\x9f]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/) ||\n parserInput.$char('*') || parserInput.$char('&') || this.attribute() ||\n parserInput.$re(/^\\([^&()@]+\\)/) || parserInput.$re(/^[\\.#:](?=@)/) ||\n this.entities.variableCurly();\n\n if (!e) {\n parserInput.save();\n if (parserInput.$char('(')) {\n if ((v = this.selector(false)) && parserInput.$char(')')) {\n e = new(tree.Paren)(v);\n parserInput.forget();\n } else {\n parserInput.restore('Missing closing \\')\\'');\n }\n } else {\n parserInput.forget();\n }\n }\n\n if (e) { return new(tree.Element)(c, e, e instanceof tree.Variable, index, fileInfo); }\n },\n\n //\n // Combinators combine elements together, in a Selector.\n //\n // Because our parser isn't white-space sensitive, special care\n // has to be taken, when parsing the descendant combinator, ` `,\n // as it's an empty space. We have to check the previous character\n // in the input, to see if it's a ` ` character. More info on how\n // we deal with this in *combinator.js*.\n //\n combinator: function () {\n let c = parserInput.currentChar();\n\n if (c === '/') {\n parserInput.save();\n const slashedCombinator = parserInput.$re(/^\\/[a-z]+\\//i);\n if (slashedCombinator) {\n parserInput.forget();\n return new(tree.Combinator)(slashedCombinator);\n }\n parserInput.restore();\n }\n\n if (c === '>' || c === '+' || c === '~' || c === '|' || c === '^') {\n parserInput.i++;\n if (c === '^' && parserInput.currentChar() === '^') {\n c = '^^';\n parserInput.i++;\n }\n while (parserInput.isWhitespace()) { parserInput.i++; }\n return new(tree.Combinator)(c);\n } else if (parserInput.isWhitespace(-1)) {\n return new(tree.Combinator)(' ');\n } else {\n return new(tree.Combinator)(null);\n }\n },\n //\n // A CSS Selector\n // with less extensions e.g. the ability to extend and guard\n //\n // .class > div + h1\n // li a:hover\n //\n // Selectors are made out of one or more Elements, see above.\n //\n selector: function (isLess) {\n const index = parserInput.i;\n let elements;\n let extendList;\n let c;\n let e;\n let allExtends;\n let when;\n let condition;\n isLess = isLess !== false;\n while ((isLess && (extendList = this.extend())) || (isLess && (when = parserInput.$str('when'))) || (e = this.element())) {\n if (when) {\n condition = expect(this.conditions, 'expected condition');\n } else if (condition) {\n error('CSS guard can only be used at the end of selector');\n } else if (extendList) {\n if (allExtends) {\n allExtends = allExtends.concat(extendList);\n } else {\n allExtends = extendList;\n }\n } else {\n if (allExtends) { error('Extend can only be used at the end of selector'); }\n c = parserInput.currentChar();\n if (elements) {\n elements.push(e);\n } else {\n elements = [ e ];\n }\n e = null;\n }\n if (c === '{' || c === '}' || c === ';' || c === ',' || c === ')') {\n break;\n }\n }\n\n if (elements) { return new(tree.Selector)(elements, allExtends, condition, index, fileInfo); }\n if (allExtends) { error('Extend must be used to extend a selector, it cannot be used on its own'); }\n },\n selectors: function () {\n let s;\n let selectors;\n while (true) {\n s = this.selector();\n if (!s) {\n break;\n }\n if (selectors) {\n selectors.push(s);\n } else {\n selectors = [ s ];\n }\n parserInput.commentStore.length = 0;\n if (s.condition && selectors.length > 1) {\n error(\"Guards are only currently allowed on a single selector.\");\n }\n if (!parserInput.$char(',')) { break; }\n if (s.condition) {\n error(\"Guards are only currently allowed on a single selector.\");\n }\n parserInput.commentStore.length = 0;\n }\n return selectors;\n },\n attribute: function () {\n if (!parserInput.$char('[')) { return; }\n\n const entities = this.entities;\n let key;\n let val;\n let op;\n\n if (!(key = entities.variableCurly())) {\n key = expect(/^(?:[_A-Za-z0-9-\\*]*\\|)?(?:[_A-Za-z0-9-]|\\\\.)+/);\n }\n\n op = parserInput.$re(/^[|~*$^]?=/);\n if (op) {\n val = entities.quoted() || parserInput.$re(/^[0-9]+%/) || parserInput.$re(/^[\\w-]+/) || entities.variableCurly();\n }\n\n expectChar(']');\n\n return new(tree.Attribute)(key, op, val);\n },\n\n //\n // The `block` rule is used by `ruleset` and `mixin.definition`.\n // It's a wrapper around the `primary` rule, with added `{}`.\n //\n block: function () {\n let content;\n if (parserInput.$char('{') && (content = this.primary()) && parserInput.$char('}')) {\n return content;\n }\n },\n\n blockRuleset: function() {\n let block = this.block();\n\n if (block) {\n block = new tree.Ruleset(null, block);\n }\n return block;\n },\n\n detachedRuleset: function() {\n let argInfo;\n let params;\n let variadic;\n\n parserInput.save();\n if (parserInput.$re(/^[.#]\\(/)) {\n /**\n * DR args currently only implemented for each() function, and not \n * yet settable as `@dr: #(@arg) {}`\n * This should be done when DRs are merged with mixins.\n * See: https://github.com/less/less-meta/issues/16\n */\n argInfo = this.mixin.args(false);\n params = argInfo.args;\n variadic = argInfo.variadic;\n if (!parserInput.$char(')')) {\n parserInput.restore();\n return;\n }\n }\n const blockRuleset = this.blockRuleset();\n if (blockRuleset) {\n parserInput.forget();\n if (params) {\n return new tree.mixin.Definition(null, params, blockRuleset, null, variadic);\n }\n return new tree.DetachedRuleset(blockRuleset);\n }\n parserInput.restore();\n },\n\n //\n // div, .class, body > p {...}\n //\n ruleset: function () {\n let selectors;\n let rules;\n let debugInfo;\n\n parserInput.save();\n\n if (context.dumpLineNumbers) {\n debugInfo = getDebugInfo(parserInput.i);\n }\n\n selectors = this.selectors();\n\n if (selectors && (rules = this.block())) {\n parserInput.forget();\n const ruleset = new(tree.Ruleset)(selectors, rules, context.strictImports);\n if (context.dumpLineNumbers) {\n ruleset.debugInfo = debugInfo;\n }\n return ruleset;\n } else {\n parserInput.restore();\n }\n },\n declaration: function () {\n let name;\n let value;\n const index = parserInput.i;\n let hasDR;\n const c = parserInput.currentChar();\n let important;\n let merge;\n let isVariable;\n\n if (c === '.' || c === '#' || c === '&' || c === ':') { return; }\n\n parserInput.save();\n\n name = this.variable() || this.ruleProperty();\n if (name) {\n isVariable = typeof name === 'string';\n\n if (isVariable) {\n value = this.detachedRuleset();\n if (value) {\n hasDR = true;\n }\n }\n\n parserInput.commentStore.length = 0;\n if (!value) {\n // a name returned by this.ruleProperty() is always an array of the form:\n // [string-1, ..., string-n, \"\"] or [string-1, ..., string-n, \"+\"]\n // where each item is a tree.Keyword or tree.Variable\n merge = !isVariable && name.length > 1 && name.pop().value;\n\n // Custom property values get permissive parsing\n if (name[0].value && name[0].value.slice(0, 2) === '--') {\n value = this.permissiveValue();\n }\n // Try to store values as anonymous\n // If we need the value later we'll re-parse it in ruleset.parseValue\n else {\n value = this.anonymousValue();\n }\n if (value) {\n parserInput.forget();\n // anonymous values absorb the end ';' which is required for them to work\n return new(tree.Declaration)(name, value, false, merge, index, fileInfo);\n }\n\n if (!value) {\n value = this.value();\n }\n\n if (value) {\n important = this.important();\n } else if (isVariable) {\n // As a last resort, try permissiveValue\n value = this.permissiveValue();\n }\n }\n\n if (value && (this.end() || hasDR)) {\n parserInput.forget();\n return new(tree.Declaration)(name, value, important, merge, index, fileInfo);\n }\n else {\n parserInput.restore();\n }\n } else {\n parserInput.restore();\n }\n },\n anonymousValue: function () {\n const index = parserInput.i;\n const match = parserInput.$re(/^([^.#@\\$+\\/'\"*`(;{}-]*);/);\n if (match) {\n return new(tree.Anonymous)(match[1], index);\n }\n },\n /**\n * Used for custom properties, at-rules, and variables (as fallback)\n * Parses almost anything inside of {} [] () \"\" blocks\n * until it reaches outer-most tokens.\n * \n * First, it will try to parse comments and entities to reach\n * the end. This is mostly like the Expression parser except no\n * math is allowed.\n */\n permissiveValue: function (untilTokens) {\n let i;\n let e;\n let done;\n let value;\n const tok = untilTokens || ';';\n const index = parserInput.i;\n const result = [];\n\n function testCurrentChar() {\n const char = parserInput.currentChar();\n if (typeof tok === 'string') {\n return char === tok;\n } else {\n return tok.test(char);\n }\n }\n if (testCurrentChar()) {\n return;\n }\n value = [];\n do {\n e = this.comment();\n if (e) {\n value.push(e);\n continue;\n }\n e = this.entity();\n if (e) {\n value.push(e);\n }\n } while (e);\n\n done = testCurrentChar();\n\n if (value.length > 0) {\n value = new(tree.Expression)(value);\n if (done) {\n return value;\n }\n else {\n result.push(value);\n }\n // Preserve space before $parseUntil as it will not\n if (parserInput.prevChar() === ' ') {\n result.push(new tree.Anonymous(' ', index));\n }\n }\n parserInput.save();\n\n value = parserInput.$parseUntil(tok);\n\n if (value) {\n if (typeof value === 'string') {\n error(`Expected '${value}'`, 'Parse');\n }\n if (value.length === 1 && value[0] === ' ') {\n parserInput.forget();\n return new tree.Anonymous('', index);\n }\n let item;\n for (i = 0; i < value.length; i++) {\n item = value[i];\n if (Array.isArray(item)) {\n // Treat actual quotes as normal quoted values\n result.push(new tree.Quoted(item[0], item[1], true, index, fileInfo));\n }\n else {\n if (i === value.length - 1) {\n item = item.trim();\n }\n // Treat like quoted values, but replace vars like unquoted expressions\n const quote = new tree.Quoted('\\'', item, true, index, fileInfo);\n quote.variableRegex = /@([\\w-]+)/g;\n quote.propRegex = /\\$([\\w-]+)/g;\n result.push(quote);\n }\n }\n parserInput.forget();\n return new tree.Expression(result, true);\n }\n parserInput.restore();\n },\n\n //\n // An @import atrule\n //\n // @import \"lib\";\n //\n // Depending on our environment, importing is done differently:\n // In the browser, it's an XHR request, in Node, it would be a\n // file-system operation. The function used for importing is\n // stored in `import`, which we pass to the Import constructor.\n //\n 'import': function () {\n let path;\n let features;\n const index = parserInput.i;\n\n const dir = parserInput.$re(/^@import?\\s+/);\n\n if (dir) {\n const options = (dir ? this.importOptions() : null) || {};\n\n if ((path = this.entities.quoted() || this.entities.url())) {\n features = this.mediaFeatures();\n\n if (!parserInput.$char(';')) {\n parserInput.i = index;\n error('missing semi-colon or unrecognised media features on import');\n }\n features = features && new(tree.Value)(features);\n return new(tree.Import)(path, features, options, index, fileInfo);\n }\n else {\n parserInput.i = index;\n error('malformed import statement');\n }\n }\n },\n\n importOptions: function() {\n let o;\n const options = {};\n let optionName;\n let value;\n\n // list of options, surrounded by parens\n if (!parserInput.$char('(')) { return null; }\n do {\n o = this.importOption();\n if (o) {\n optionName = o;\n value = true;\n switch (optionName) {\n case 'css':\n optionName = 'less';\n value = false;\n break;\n case 'once':\n optionName = 'multiple';\n value = false;\n break;\n }\n options[optionName] = value;\n if (!parserInput.$char(',')) { break; }\n }\n } while (o);\n expectChar(')');\n return options;\n },\n\n importOption: function() {\n const opt = parserInput.$re(/^(less|css|multiple|once|inline|reference|optional)/);\n if (opt) {\n return opt[1];\n }\n },\n\n mediaFeature: function () {\n const entities = this.entities;\n const nodes = [];\n let e;\n let p;\n parserInput.save();\n do {\n e = entities.keyword() || entities.variable() || entities.mixinLookup();\n if (e) {\n nodes.push(e);\n } else if (parserInput.$char('(')) {\n p = this.property();\n e = this.value();\n if (parserInput.$char(')')) {\n if (p && e) {\n nodes.push(new(tree.Paren)(new(tree.Declaration)(p, e, null, null, parserInput.i, fileInfo, true)));\n } else if (e) {\n nodes.push(new(tree.Paren)(e));\n } else {\n error('badly formed media feature definition');\n }\n } else {\n error('Missing closing \\')\\'', 'Parse');\n }\n }\n } while (e);\n\n parserInput.forget();\n if (nodes.length > 0) {\n return new(tree.Expression)(nodes);\n }\n },\n\n mediaFeatures: function () {\n const entities = this.entities;\n const features = [];\n let e;\n do {\n e = this.mediaFeature();\n if (e) {\n features.push(e);\n if (!parserInput.$char(',')) { break; }\n } else {\n e = entities.variable() || entities.mixinLookup();\n if (e) {\n features.push(e);\n if (!parserInput.$char(',')) { break; }\n }\n }\n } while (e);\n\n return features.length > 0 ? features : null;\n },\n\n media: function () {\n let features;\n let rules;\n let media;\n let debugInfo;\n const index = parserInput.i;\n\n if (context.dumpLineNumbers) {\n debugInfo = getDebugInfo(index);\n }\n\n parserInput.save();\n\n if (parserInput.$str('@media')) {\n features = this.mediaFeatures();\n\n rules = this.block();\n\n if (!rules) {\n error('media definitions require block statements after any features');\n }\n\n parserInput.forget();\n\n media = new(tree.Media)(rules, features, index, fileInfo);\n if (context.dumpLineNumbers) {\n media.debugInfo = debugInfo;\n }\n\n return media;\n }\n\n parserInput.restore();\n },\n\n //\n\n // A @plugin directive, used to import plugins dynamically.\n //\n // @plugin (args) \"lib\";\n //\n plugin: function () {\n let path;\n let args;\n let options;\n const index = parserInput.i;\n const dir = parserInput.$re(/^@plugin?\\s+/);\n\n if (dir) {\n args = this.pluginArgs();\n\n if (args) {\n options = {\n pluginArgs: args,\n isPlugin: true\n };\n }\n else {\n options = { isPlugin: true };\n }\n\n if ((path = this.entities.quoted() || this.entities.url())) {\n\n if (!parserInput.$char(';')) {\n parserInput.i = index;\n error('missing semi-colon on @plugin');\n }\n return new(tree.Import)(path, null, options, index, fileInfo);\n }\n else {\n parserInput.i = index;\n error('malformed @plugin statement');\n }\n }\n },\n\n pluginArgs: function() {\n // list of options, surrounded by parens\n parserInput.save();\n if (!parserInput.$char('(')) {\n parserInput.restore();\n return null;\n }\n const args = parserInput.$re(/^\\s*([^\\);]+)\\)\\s*/);\n if (args[1]) {\n parserInput.forget();\n return args[1].trim();\n }\n else { \n parserInput.restore();\n return null;\n }\n },\n\n //\n // A CSS AtRule\n //\n // @charset \"utf-8\";\n //\n atrule: function () {\n const index = parserInput.i;\n let name;\n let value;\n let rules;\n let nonVendorSpecificName;\n let hasIdentifier;\n let hasExpression;\n let hasUnknown;\n let hasBlock = true;\n let isRooted = true;\n\n if (parserInput.currentChar() !== '@') { return; }\n\n value = this['import']() || this.plugin() || this.media();\n if (value) {\n return value;\n }\n\n parserInput.save();\n\n name = parserInput.$re(/^@[a-z-]+/);\n\n if (!name) { return; }\n\n nonVendorSpecificName = name;\n if (name.charAt(1) == '-' && name.indexOf('-', 2) > 0) {\n nonVendorSpecificName = `@${name.slice(name.indexOf('-', 2) + 1)}`;\n }\n\n switch (nonVendorSpecificName) {\n case '@charset':\n hasIdentifier = true;\n hasBlock = false;\n break;\n case '@namespace':\n hasExpression = true;\n hasBlock = false;\n break;\n case '@keyframes':\n case '@counter-style':\n hasIdentifier = true;\n break;\n case '@document':\n case '@supports':\n hasUnknown = true;\n isRooted = false;\n break;\n default:\n hasUnknown = true;\n break;\n }\n\n parserInput.commentStore.length = 0;\n\n if (hasIdentifier) {\n value = this.entity();\n if (!value) {\n error(`expected ${name} identifier`);\n }\n } else if (hasExpression) {\n value = this.expression();\n if (!value) {\n error(`expected ${name} expression`);\n }\n } else if (hasUnknown) {\n value = this.permissiveValue(/^[{;]/);\n hasBlock = (parserInput.currentChar() === '{');\n if (!value) {\n if (!hasBlock && parserInput.currentChar() !== ';') {\n error(`${name} rule is missing block or ending semi-colon`);\n }\n }\n else if (!value.value) {\n value = null;\n }\n }\n\n if (hasBlock) {\n rules = this.blockRuleset();\n }\n\n if (rules || (!hasBlock && value && parserInput.$char(';'))) {\n parserInput.forget();\n return new(tree.AtRule)(name, value, rules, index, fileInfo,\n context.dumpLineNumbers ? getDebugInfo(index) : null,\n isRooted\n );\n }\n\n parserInput.restore('at-rule options not recognised');\n },\n\n //\n // A Value is a comma-delimited list of Expressions\n //\n // font-family: Baskerville, Georgia, serif;\n //\n // In a Rule, a Value represents everything after the `:`,\n // and before the `;`.\n //\n value: function () {\n let e;\n const expressions = [];\n const index = parserInput.i;\n\n do {\n e = this.expression();\n if (e) {\n expressions.push(e);\n if (!parserInput.$char(',')) { break; }\n }\n } while (e);\n\n if (expressions.length > 0) {\n return new(tree.Value)(expressions, index);\n }\n },\n important: function () {\n if (parserInput.currentChar() === '!') {\n return parserInput.$re(/^! *important/);\n }\n },\n sub: function () {\n let a;\n let e;\n\n parserInput.save();\n if (parserInput.$char('(')) {\n a = this.addition();\n if (a && parserInput.$char(')')) {\n parserInput.forget();\n e = new(tree.Expression)([a]);\n e.parens = true;\n return e;\n }\n parserInput.restore('Expected \\')\\'');\n return;\n }\n parserInput.restore();\n },\n multiplication: function () {\n let m;\n let a;\n let op;\n let operation;\n let isSpaced;\n m = this.operand();\n if (m) {\n isSpaced = parserInput.isWhitespace(-1);\n while (true) {\n if (parserInput.peek(/^\\/[*\\/]/)) {\n break;\n }\n\n parserInput.save();\n\n op = parserInput.$char('/') || parserInput.$char('*') || parserInput.$str('./');\n\n if (!op) { parserInput.forget(); break; }\n\n a = this.operand();\n\n if (!a) { parserInput.restore(); break; }\n parserInput.forget();\n\n m.parensInOp = true;\n a.parensInOp = true;\n operation = new(tree.Operation)(op, [operation || m, a], isSpaced);\n isSpaced = parserInput.isWhitespace(-1);\n }\n return operation || m;\n }\n },\n addition: function () {\n let m;\n let a;\n let op;\n let operation;\n let isSpaced;\n m = this.multiplication();\n if (m) {\n isSpaced = parserInput.isWhitespace(-1);\n while (true) {\n op = parserInput.$re(/^[-+]\\s+/) || (!isSpaced && (parserInput.$char('+') || parserInput.$char('-')));\n if (!op) {\n break;\n }\n a = this.multiplication();\n if (!a) {\n break;\n }\n\n m.parensInOp = true;\n a.parensInOp = true;\n operation = new(tree.Operation)(op, [operation || m, a], isSpaced);\n isSpaced = parserInput.isWhitespace(-1);\n }\n return operation || m;\n }\n },\n conditions: function () {\n let a;\n let b;\n const index = parserInput.i;\n let condition;\n\n a = this.condition(true);\n if (a) {\n while (true) {\n if (!parserInput.peek(/^,\\s*(not\\s*)?\\(/) || !parserInput.$char(',')) {\n break;\n }\n b = this.condition(true);\n if (!b) {\n break;\n }\n condition = new(tree.Condition)('or', condition || a, b, index);\n }\n return condition || a;\n }\n },\n condition: function (needsParens) {\n let result;\n let logical;\n let next;\n function or() {\n return parserInput.$str('or');\n }\n\n result = this.conditionAnd(needsParens);\n if (!result) {\n return ;\n }\n logical = or();\n if (logical) {\n next = this.condition(needsParens);\n if (next) {\n result = new(tree.Condition)(logical, result, next);\n } else {\n return ;\n }\n }\n return result;\n },\n conditionAnd: function (needsParens) {\n let result;\n let logical;\n let next;\n const self = this;\n function insideCondition() {\n const cond = self.negatedCondition(needsParens) || self.parenthesisCondition(needsParens);\n if (!cond && !needsParens) {\n return self.atomicCondition(needsParens);\n }\n return cond;\n }\n function and() {\n return parserInput.$str('and');\n }\n\n result = insideCondition();\n if (!result) {\n return ;\n }\n logical = and();\n if (logical) {\n next = this.conditionAnd(needsParens);\n if (next) {\n result = new(tree.Condition)(logical, result, next);\n } else {\n return ;\n }\n }\n return result;\n },\n negatedCondition: function (needsParens) {\n if (parserInput.$str('not')) {\n const result = this.parenthesisCondition(needsParens);\n if (result) {\n result.negate = !result.negate;\n }\n return result;\n }\n },\n parenthesisCondition: function (needsParens) {\n function tryConditionFollowedByParenthesis(me) {\n let body;\n parserInput.save();\n body = me.condition(needsParens);\n if (!body) {\n parserInput.restore();\n return ;\n }\n if (!parserInput.$char(')')) {\n parserInput.restore();\n return ;\n }\n parserInput.forget();\n return body;\n }\n\n let body;\n parserInput.save();\n if (!parserInput.$str('(')) {\n parserInput.restore();\n return ;\n }\n body = tryConditionFollowedByParenthesis(this);\n if (body) {\n parserInput.forget();\n return body;\n }\n\n body = this.atomicCondition(needsParens);\n if (!body) {\n parserInput.restore();\n return ;\n }\n if (!parserInput.$char(')')) {\n parserInput.restore(`expected ')' got '${parserInput.currentChar()}'`);\n return ;\n }\n parserInput.forget();\n return body;\n },\n atomicCondition: function (needsParens) {\n const entities = this.entities;\n const index = parserInput.i;\n let a;\n let b;\n let c;\n let op;\n\n function cond() {\n return this.addition() || entities.keyword() || entities.quoted() || entities.mixinLookup();\n }\n cond = cond.bind(this);\n\n a = cond();\n if (a) {\n if (parserInput.$char('>')) {\n if (parserInput.$char('=')) {\n op = '>=';\n } else {\n op = '>';\n }\n } else\n if (parserInput.$char('<')) {\n if (parserInput.$char('=')) {\n op = '<=';\n } else {\n op = '<';\n }\n } else\n if (parserInput.$char('=')) {\n if (parserInput.$char('>')) {\n op = '=>';\n } else if (parserInput.$char('<')) {\n op = '=<';\n } else {\n op = '=';\n }\n }\n if (op) {\n b = cond();\n if (b) {\n c = new(tree.Condition)(op, a, b, index, false);\n } else {\n error('expected expression');\n }\n } else {\n c = new(tree.Condition)('=', a, new(tree.Keyword)('true'), index, false);\n }\n return c;\n }\n },\n\n //\n // An operand is anything that can be part of an operation,\n // such as a Color, or a Variable\n //\n operand: function () {\n const entities = this.entities;\n let negate;\n\n if (parserInput.peek(/^-[@\\$\\(]/)) {\n negate = parserInput.$char('-');\n }\n\n let o = this.sub() || entities.dimension() ||\n entities.color() || entities.variable() ||\n entities.property() || entities.call() ||\n entities.quoted(true) || entities.colorKeyword() ||\n entities.mixinLookup();\n\n if (negate) {\n o.parensInOp = true;\n o = new(tree.Negative)(o);\n }\n\n return o;\n },\n\n //\n // Expressions either represent mathematical operations,\n // or white-space delimited Entities.\n //\n // 1px solid black\n // @var * 2\n //\n expression: function () {\n const entities = [];\n let e;\n let delim;\n const index = parserInput.i;\n\n do {\n e = this.comment();\n if (e) {\n entities.push(e);\n continue;\n }\n e = this.addition() || this.entity();\n\n if (e instanceof tree.Comment) {\n e = null;\n }\n\n if (e) {\n entities.push(e);\n // operations do not allow keyword \"/\" dimension (e.g. small/20px) so we support that here\n if (!parserInput.peek(/^\\/[\\/*]/)) {\n delim = parserInput.$char('/');\n if (delim) {\n entities.push(new(tree.Anonymous)(delim, index));\n }\n }\n }\n } while (e);\n if (entities.length > 0) {\n return new(tree.Expression)(entities);\n }\n },\n property: function () {\n const name = parserInput.$re(/^(\\*?-?[_a-zA-Z0-9-]+)\\s*:/);\n if (name) {\n return name[1];\n }\n },\n ruleProperty: function () {\n let name = [];\n const index = [];\n let s;\n let k;\n\n parserInput.save();\n\n const simpleProperty = parserInput.$re(/^([_a-zA-Z0-9-]+)\\s*:/);\n if (simpleProperty) {\n name = [new(tree.Keyword)(simpleProperty[1])];\n parserInput.forget();\n return name;\n }\n\n function match(re) {\n const i = parserInput.i;\n const chunk = parserInput.$re(re);\n if (chunk) {\n index.push(i);\n return name.push(chunk[1]);\n }\n }\n\n match(/^(\\*?)/);\n while (true) {\n if (!match(/^((?:[\\w-]+)|(?:[@\\$]\\{[\\w-]+\\}))/)) {\n break;\n }\n }\n\n if ((name.length > 1) && match(/^((?:\\+_|\\+)?)\\s*:/)) {\n parserInput.forget();\n\n // at last, we have the complete match now. move forward,\n // convert name particles to tree objects and return:\n if (name[0] === '') {\n name.shift();\n index.shift();\n }\n for (k = 0; k < name.length; k++) {\n s = name[k];\n name[k] = (s.charAt(0) !== '@' && s.charAt(0) !== '$') ?\n new(tree.Keyword)(s) :\n (s.charAt(0) === '@' ?\n new(tree.Variable)(`@${s.slice(2, -1)}`, index[k], fileInfo) :\n new(tree.Property)(`$${s.slice(2, -1)}`, index[k], fileInfo));\n }\n return name;\n }\n parserInput.restore();\n }\n }\n };\n};\nParser.serializeVars = vars => {\n let s = '';\n\n for (const name in vars) {\n if (Object.hasOwnProperty.call(vars, name)) {\n const value = vars[name];\n s += `${((name[0] === '@') ? '' : '@') + name}: ${value}${(String(value).slice(-1) === ';') ? '' : ';'}`;\n }\n }\n\n return s;\n};\n\nexport default Parser;\n","import Anonymous from '../tree/anonymous';\nimport Keyword from '../tree/keyword';\n\nfunction boolean(condition) {\n return condition ? Keyword.True : Keyword.False;\n}\n\n/**\n * Functions with evalArgs set to false are sent context\n * as the first argument.\n */\nfunction If(context, condition, trueValue, falseValue) {\n return condition.eval(context) ? trueValue.eval(context)\n : (falseValue ? falseValue.eval(context) : new Anonymous);\n}\nIf.evalArgs = false\n\nexport default { boolean, 'if': If };\n","import Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nlet colorFunctions;\n\nfunction clamp(val) {\n return Math.min(1, Math.max(0, val));\n}\nfunction hsla(origColor, hsl) {\n const color = colorFunctions.hsla(hsl.h, hsl.s, hsl.l, hsl.a);\n if (color) {\n if (origColor.value && \n /^(rgb|hsl)/.test(origColor.value)) {\n color.value = origColor.value;\n } else {\n color.value = 'rgb';\n }\n return color;\n }\n}\nfunction toHSL(color) {\n if (color.toHSL) {\n return color.toHSL();\n } else {\n throw new Error('Argument cannot be evaluated to a color');\n }\n}\n\nfunction toHSV(color) {\n if (color.toHSV) {\n return color.toHSV();\n } else {\n throw new Error('Argument cannot be evaluated to a color');\n }\n}\n\nfunction number(n) {\n if (n instanceof Dimension) {\n return parseFloat(n.unit.is('%') ? n.value / 100 : n.value);\n } else if (typeof n === 'number') {\n return n;\n } else {\n throw {\n type: 'Argument',\n message: 'color functions take numbers as parameters'\n };\n }\n}\nfunction scaled(n, size) {\n if (n instanceof Dimension && n.unit.is('%')) {\n return parseFloat(n.value * size / 100);\n } else {\n return number(n);\n }\n}\ncolorFunctions = {\n rgb: function (r, g, b) {\n const color = colorFunctions.rgba(r, g, b, 1.0);\n if (color) {\n color.value = 'rgb';\n return color;\n }\n },\n rgba: function (r, g, b, a) {\n try {\n if (r instanceof Color) {\n if (g) {\n a = number(g);\n } else {\n a = r.alpha;\n }\n return new Color(r.rgb, a, 'rgba');\n }\n const rgb = [r, g, b].map(c => scaled(c, 255));\n a = number(a);\n return new Color(rgb, a, 'rgba');\n }\n catch (e) {}\n },\n hsl: function (h, s, l) {\n const color = colorFunctions.hsla(h, s, l, 1.0);\n if (color) {\n color.value = 'hsl';\n return color;\n }\n },\n hsla: function (h, s, l, a) {\n try {\n if (h instanceof Color) {\n if (s) {\n a = number(s);\n } else {\n a = h.alpha;\n }\n return new Color(h.rgb, a, 'hsla');\n }\n\n let m1;\n let m2;\n\n function hue(h) {\n h = h < 0 ? h + 1 : (h > 1 ? h - 1 : h);\n if (h * 6 < 1) {\n return m1 + (m2 - m1) * h * 6;\n }\n else if (h * 2 < 1) {\n return m2;\n }\n else if (h * 3 < 2) {\n return m1 + (m2 - m1) * (2 / 3 - h) * 6;\n }\n else {\n return m1;\n }\n }\n\n h = (number(h) % 360) / 360;\n s = clamp(number(s));l = clamp(number(l));a = clamp(number(a));\n\n m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n m1 = l * 2 - m2;\n\n const rgb = [\n hue(h + 1 / 3) * 255,\n hue(h) * 255,\n hue(h - 1 / 3) * 255\n ];\n a = number(a);\n return new Color(rgb, a, 'hsla');\n }\n catch (e) {}\n },\n\n hsv: function(h, s, v) {\n return colorFunctions.hsva(h, s, v, 1.0);\n },\n\n hsva: function(h, s, v, a) {\n h = ((number(h) % 360) / 360) * 360;\n s = number(s);v = number(v);a = number(a);\n\n let i;\n let f;\n i = Math.floor((h / 60) % 6);\n f = (h / 60) - i;\n\n const vs = [v,\n v * (1 - s),\n v * (1 - f * s),\n v * (1 - (1 - f) * s)];\n const perm = [[0, 3, 1],\n [2, 0, 1],\n [1, 0, 3],\n [1, 2, 0],\n [3, 1, 0],\n [0, 1, 2]];\n\n return colorFunctions.rgba(vs[perm[i][0]] * 255,\n vs[perm[i][1]] * 255,\n vs[perm[i][2]] * 255,\n a);\n },\n\n hue: function (color) {\n return new Dimension(toHSL(color).h);\n },\n saturation: function (color) {\n return new Dimension(toHSL(color).s * 100, '%');\n },\n lightness: function (color) {\n return new Dimension(toHSL(color).l * 100, '%');\n },\n hsvhue: function(color) {\n return new Dimension(toHSV(color).h);\n },\n hsvsaturation: function (color) {\n return new Dimension(toHSV(color).s * 100, '%');\n },\n hsvvalue: function (color) {\n return new Dimension(toHSV(color).v * 100, '%');\n },\n red: function (color) {\n return new Dimension(color.rgb[0]);\n },\n green: function (color) {\n return new Dimension(color.rgb[1]);\n },\n blue: function (color) {\n return new Dimension(color.rgb[2]);\n },\n alpha: function (color) {\n return new Dimension(toHSL(color).a);\n },\n luma: function (color) {\n return new Dimension(color.luma() * color.alpha * 100, '%');\n },\n luminance: function (color) {\n const luminance =\n (0.2126 * color.rgb[0] / 255) +\n (0.7152 * color.rgb[1] / 255) +\n (0.0722 * color.rgb[2] / 255);\n\n return new Dimension(luminance * color.alpha * 100, '%');\n },\n saturate: function (color, amount, method) {\n // filter: saturate(3.2);\n // should be kept as is, so check for color\n if (!color.rgb) {\n return null;\n }\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.s += hsl.s * amount.value / 100;\n }\n else {\n hsl.s += amount.value / 100;\n }\n hsl.s = clamp(hsl.s);\n return hsla(color, hsl);\n },\n desaturate: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.s -= hsl.s * amount.value / 100;\n }\n else {\n hsl.s -= amount.value / 100;\n }\n hsl.s = clamp(hsl.s);\n return hsla(color, hsl);\n },\n lighten: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.l += hsl.l * amount.value / 100;\n }\n else {\n hsl.l += amount.value / 100;\n }\n hsl.l = clamp(hsl.l);\n return hsla(color, hsl);\n },\n darken: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.l -= hsl.l * amount.value / 100;\n }\n else {\n hsl.l -= amount.value / 100;\n }\n hsl.l = clamp(hsl.l);\n return hsla(color, hsl);\n },\n fadein: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.a += hsl.a * amount.value / 100;\n }\n else {\n hsl.a += amount.value / 100;\n }\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n fadeout: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.a -= hsl.a * amount.value / 100;\n }\n else {\n hsl.a -= amount.value / 100;\n }\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n fade: function (color, amount) {\n const hsl = toHSL(color);\n\n hsl.a = amount.value / 100;\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n spin: function (color, amount) {\n const hsl = toHSL(color);\n const hue = (hsl.h + amount.value) % 360;\n\n hsl.h = hue < 0 ? 360 + hue : hue;\n\n return hsla(color, hsl);\n },\n //\n // Copyright (c) 2006-2009 Hampton Catlin, Natalie Weizenbaum, and Chris Eppstein\n // http://sass-lang.com\n //\n mix: function (color1, color2, weight) {\n if (!weight) {\n weight = new Dimension(50);\n }\n const p = weight.value / 100.0;\n const w = p * 2 - 1;\n const a = toHSL(color1).a - toHSL(color2).a;\n\n const w1 = (((w * a == -1) ? w : (w + a) / (1 + w * a)) + 1) / 2.0;\n const w2 = 1 - w1;\n\n const rgb = [color1.rgb[0] * w1 + color2.rgb[0] * w2,\n color1.rgb[1] * w1 + color2.rgb[1] * w2,\n color1.rgb[2] * w1 + color2.rgb[2] * w2];\n\n const alpha = color1.alpha * p + color2.alpha * (1 - p);\n\n return new Color(rgb, alpha);\n },\n greyscale: function (color) {\n return colorFunctions.desaturate(color, new Dimension(100));\n },\n contrast: function (color, dark, light, threshold) {\n // filter: contrast(3.2);\n // should be kept as is, so check for color\n if (!color.rgb) {\n return null;\n }\n if (typeof light === 'undefined') {\n light = colorFunctions.rgba(255, 255, 255, 1.0);\n }\n if (typeof dark === 'undefined') {\n dark = colorFunctions.rgba(0, 0, 0, 1.0);\n }\n // Figure out which is actually light and dark:\n if (dark.luma() > light.luma()) {\n const t = light;\n light = dark;\n dark = t;\n }\n if (typeof threshold === 'undefined') {\n threshold = 0.43;\n } else {\n threshold = number(threshold);\n }\n if (color.luma() < threshold) {\n return light;\n } else {\n return dark;\n }\n },\n // Changes made in 2.7.0 - Reverted in 3.0.0\n // contrast: function (color, color1, color2, threshold) {\n // // Return which of `color1` and `color2` has the greatest contrast with `color`\n // // according to the standard WCAG contrast ratio calculation.\n // // http://www.w3.org/TR/WCAG20/#contrast-ratiodef\n // // The threshold param is no longer used, in line with SASS.\n // // filter: contrast(3.2);\n // // should be kept as is, so check for color\n // if (!color.rgb) {\n // return null;\n // }\n // if (typeof color1 === 'undefined') {\n // color1 = colorFunctions.rgba(0, 0, 0, 1.0);\n // }\n // if (typeof color2 === 'undefined') {\n // color2 = colorFunctions.rgba(255, 255, 255, 1.0);\n // }\n // var contrast1, contrast2;\n // var luma = color.luma();\n // var luma1 = color1.luma();\n // var luma2 = color2.luma();\n // // Calculate contrast ratios for each color\n // if (luma > luma1) {\n // contrast1 = (luma + 0.05) / (luma1 + 0.05);\n // } else {\n // contrast1 = (luma1 + 0.05) / (luma + 0.05);\n // }\n // if (luma > luma2) {\n // contrast2 = (luma + 0.05) / (luma2 + 0.05);\n // } else {\n // contrast2 = (luma2 + 0.05) / (luma + 0.05);\n // }\n // if (contrast1 > contrast2) {\n // return color1;\n // } else {\n // return color2;\n // }\n // },\n argb: function (color) {\n return new Anonymous(color.toARGB());\n },\n color: function(c) {\n if ((c instanceof Quoted) &&\n (/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})$/i.test(c.value))) {\n const val = c.value.slice(1);\n return new Color(val, undefined, `#${val}`);\n }\n if ((c instanceof Color) || (c = Color.fromKeyword(c.value))) {\n c.value = undefined;\n return c;\n }\n throw {\n type: 'Argument',\n message: 'argument must be a color keyword or 3|4|6|8 digit hex e.g. #FFF'\n };\n },\n tint: function(color, amount) {\n return colorFunctions.mix(colorFunctions.rgb(255, 255, 255), color, amount);\n },\n shade: function(color, amount) {\n return colorFunctions.mix(colorFunctions.rgb(0, 0, 0), color, amount);\n }\n};\n\nexport default colorFunctions;\n","import Color from '../tree/color';\n\n// Color Blending\n// ref: http://www.w3.org/TR/compositing-1\n\nfunction colorBlend(mode, color1, color2) {\n const ab = color1.alpha; // result\n\n let // backdrop\n cb;\n\n const as = color2.alpha;\n\n let // source\n cs;\n\n let ar;\n let cr;\n const r = [];\n\n ar = as + ab * (1 - as);\n for (let i = 0; i < 3; i++) {\n cb = color1.rgb[i] / 255;\n cs = color2.rgb[i] / 255;\n cr = mode(cb, cs);\n if (ar) {\n cr = (as * cs + ab * (cb -\n as * (cb + cs - cr))) / ar;\n }\n r[i] = cr * 255;\n }\n\n return new Color(r, ar);\n}\n\nconst colorBlendModeFunctions = {\n multiply: function(cb, cs) {\n return cb * cs;\n },\n screen: function(cb, cs) {\n return cb + cs - cb * cs;\n },\n overlay: function(cb, cs) {\n cb *= 2;\n return (cb <= 1) ?\n colorBlendModeFunctions.multiply(cb, cs) :\n colorBlendModeFunctions.screen(cb - 1, cs);\n },\n softlight: function(cb, cs) {\n let d = 1;\n let e = cb;\n if (cs > 0.5) {\n e = 1;\n d = (cb > 0.25) ? Math.sqrt(cb)\n : ((16 * cb - 12) * cb + 4) * cb;\n }\n return cb - (1 - 2 * cs) * e * (d - cb);\n },\n hardlight: function(cb, cs) {\n return colorBlendModeFunctions.overlay(cs, cb);\n },\n difference: function(cb, cs) {\n return Math.abs(cb - cs);\n },\n exclusion: function(cb, cs) {\n return cb + cs - 2 * cb * cs;\n },\n\n // non-w3c functions:\n average: function(cb, cs) {\n return (cb + cs) / 2;\n },\n negation: function(cb, cs) {\n return 1 - Math.abs(cb + cs - 1);\n }\n};\n\nfor (const f in colorBlendModeFunctions) {\n if (colorBlendModeFunctions.hasOwnProperty(f)) {\n colorBlend[f] = colorBlend.bind(null, colorBlendModeFunctions[f]);\n }\n}\n\nexport default colorBlend;\n","import Comment from '../tree/comment';\nimport Node from '../tree/node';\nimport Dimension from '../tree/dimension';\nimport Declaration from '../tree/declaration';\nimport Expression from '../tree/expression';\nimport Ruleset from '../tree/ruleset';\nimport Selector from '../tree/selector';\nimport Element from '../tree/element';\nimport Quote from '../tree/quoted';\n\nconst getItemsFromNode = node => {\n // handle non-array values as an array of length 1\n // return 'undefined' if index is invalid\n const items = Array.isArray(node.value) ?\n node.value : Array(node);\n\n return items;\n};\n\nexport default {\n _SELF: function(n) {\n return n;\n },\n extract: function(values, index) {\n // (1-based index)\n index = index.value - 1;\n\n return getItemsFromNode(values)[index];\n },\n length: function(values) {\n return new Dimension(getItemsFromNode(values).length);\n },\n /**\n * Creates a Less list of incremental values.\n * Modeled after Lodash's range function, also exists natively in PHP\n * \n * @param {Dimension} [start=1]\n * @param {Dimension} end - e.g. 10 or 10px - unit is added to output\n * @param {Dimension} [step=1] \n */\n range: function(start, end, step) {\n let from;\n let to;\n let stepValue = 1;\n const list = [];\n if (end) {\n to = end;\n from = start.value;\n if (step) {\n stepValue = step.value;\n }\n }\n else {\n from = 1;\n to = start;\n }\n\n for (let i = from; i <= to.value; i += stepValue) {\n list.push(new Dimension(i, to.unit));\n }\n\n return new Expression(list);\n },\n each: function(list, rs) {\n const rules = [];\n let newRules;\n let iterator;\n\n const tryEval = val => {\n if (val instanceof Node) {\n return val.eval(this.context);\n }\n return val;\n };\n\n if (list.value && !(list instanceof Quote)) {\n if (Array.isArray(list.value)) {\n iterator = list.value.map(tryEval);\n } else {\n iterator = [tryEval(list.value)];\n }\n } else if (list.ruleset) {\n iterator = tryEval(list.ruleset).rules;\n } else if (list.rules) {\n iterator = list.rules.map(tryEval);\n } else if (Array.isArray(list)) {\n iterator = list.map(tryEval);\n } else {\n iterator = [tryEval(list)];\n }\n\n let valueName = '@value';\n let keyName = '@key';\n let indexName = '@index';\n\n if (rs.params) {\n valueName = rs.params[0] && rs.params[0].name;\n keyName = rs.params[1] && rs.params[1].name;\n indexName = rs.params[2] && rs.params[2].name;\n rs = rs.rules;\n } else {\n rs = rs.ruleset;\n }\n\n for (let i = 0; i < iterator.length; i++) {\n let key;\n let value;\n const item = iterator[i];\n if (item instanceof Declaration) {\n key = typeof item.name === 'string' ? item.name : item.name[0].value;\n value = item.value;\n } else {\n key = new Dimension(i + 1);\n value = item;\n }\n\n if (item instanceof Comment) {\n continue;\n }\n\n newRules = rs.rules.slice(0);\n if (valueName) {\n newRules.push(new Declaration(valueName,\n value,\n false, false, this.index, this.currentFileInfo));\n }\n if (indexName) {\n newRules.push(new Declaration(indexName,\n new Dimension(i + 1),\n false, false, this.index, this.currentFileInfo));\n }\n if (keyName) {\n newRules.push(new Declaration(keyName,\n key,\n false, false, this.index, this.currentFileInfo));\n }\n\n rules.push(new Ruleset([ new(Selector)([ new Element(\"\", '&') ]) ],\n newRules,\n rs.strictImports,\n rs.visibilityInfo()\n ));\n }\n\n return new Ruleset([ new(Selector)([ new Element(\"\", '&') ]) ],\n rules,\n rs.strictImports,\n rs.visibilityInfo()\n ).eval(this.context);\n }\n};\n","import Dimension from '../tree/dimension';\n\nconst MathHelper = (fn, unit, n) => {\n if (!(n instanceof Dimension)) {\n throw { type: 'Argument', message: 'argument must be a number' };\n }\n if (unit == null) {\n unit = n.unit;\n } else {\n n = n.unify();\n }\n return new Dimension(fn(parseFloat(n.value)), unit);\n};\n\nexport default MathHelper;","import mathHelper from './math-helper.js';\n\nconst mathFunctions = {\n // name, unit\n ceil: null,\n floor: null,\n sqrt: null,\n abs: null,\n tan: '',\n sin: '',\n cos: '',\n atan: 'rad',\n asin: 'rad',\n acos: 'rad'\n};\n\nfor (const f in mathFunctions) {\n if (mathFunctions.hasOwnProperty(f)) {\n mathFunctions[f] = mathHelper.bind(null, Math[f], mathFunctions[f]);\n }\n}\n\nmathFunctions.round = (n, f) => {\n const fraction = typeof f === 'undefined' ? 0 : f.value;\n return mathHelper(num => num.toFixed(fraction), null, n);\n};\n\nexport default mathFunctions;\n","import Dimension from '../tree/dimension';\nimport Anonymous from '../tree/anonymous';\nimport mathHelper from './math-helper.js';\n\nconst minMax = function (isMin, args) {\n args = Array.prototype.slice.call(args);\n switch (args.length) {\n case 0: throw { type: 'Argument', message: 'one or more arguments required' };\n }\n let i; // key is the unit.toString() for unified Dimension values,\n let j;\n let current;\n let currentUnified;\n let referenceUnified;\n let unit;\n let unitStatic;\n let unitClone;\n\n const // elems only contains original argument values.\n order = [];\n\n const values = {};\n // value is the index into the order array.\n for (i = 0; i < args.length; i++) {\n current = args[i];\n if (!(current instanceof Dimension)) {\n if (Array.isArray(args[i].value)) {\n Array.prototype.push.apply(args, Array.prototype.slice.call(args[i].value));\n }\n continue;\n }\n currentUnified = current.unit.toString() === '' && unitClone !== undefined ? new Dimension(current.value, unitClone).unify() : current.unify();\n unit = currentUnified.unit.toString() === '' && unitStatic !== undefined ? unitStatic : currentUnified.unit.toString();\n unitStatic = unit !== '' && unitStatic === undefined || unit !== '' && order[0].unify().unit.toString() === '' ? unit : unitStatic;\n unitClone = unit !== '' && unitClone === undefined ? current.unit.toString() : unitClone;\n j = values[''] !== undefined && unit !== '' && unit === unitStatic ? values[''] : values[unit];\n if (j === undefined) {\n if (unitStatic !== undefined && unit !== unitStatic) {\n throw { type: 'Argument', message: 'incompatible types' };\n }\n values[unit] = order.length;\n order.push(current);\n continue;\n }\n referenceUnified = order[j].unit.toString() === '' && unitClone !== undefined ? new Dimension(order[j].value, unitClone).unify() : order[j].unify();\n if ( isMin && currentUnified.value < referenceUnified.value ||\n !isMin && currentUnified.value > referenceUnified.value) {\n order[j] = current;\n }\n }\n if (order.length == 1) {\n return order[0];\n }\n args = order.map(function (a) { return a.toCSS(this.context); }).join(this.context.compress ? ',' : ', ');\n return new Anonymous(`${isMin ? 'min' : 'max'}(${args})`);\n};\n\nexport default {\n min: function(...args) {\n return minMax(true, args);\n },\n max: function(...args) {\n return minMax(false, args);\n },\n convert: function (val, unit) {\n return val.convertTo(unit.value);\n },\n pi: function () {\n return new Dimension(Math.PI);\n },\n mod: function(a, b) {\n return new Dimension(a.value % b.value, a.unit);\n },\n pow: function(x, y) {\n if (typeof x === 'number' && typeof y === 'number') {\n x = new Dimension(x);\n y = new Dimension(y);\n } else if (!(x instanceof Dimension) || !(y instanceof Dimension)) {\n throw { type: 'Argument', message: 'arguments must be numbers' };\n }\n\n return new Dimension(Math.pow(x.value, y.value), x.unit);\n },\n percentage: function (n) {\n const result = mathHelper(num => num * 100, '%', n);\n\n return result;\n }\n};\n","import Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nimport JavaScript from '../tree/javascript';\n\nexport default {\n e: function (str) {\n return new Quoted('\"', str instanceof JavaScript ? str.evaluated : str.value, true);\n },\n escape: function (str) {\n return new Anonymous(\n encodeURI(str.value).replace(/=/g, '%3D').replace(/:/g, '%3A').replace(/#/g, '%23').replace(/;/g, '%3B')\n .replace(/\\(/g, '%28').replace(/\\)/g, '%29'));\n },\n replace: function (string, pattern, replacement, flags) {\n let result = string.value;\n replacement = (replacement.type === 'Quoted') ?\n replacement.value : replacement.toCSS();\n result = result.replace(new RegExp(pattern.value, flags ? flags.value : ''), replacement);\n return new Quoted(string.quote || '', result, string.escaped);\n },\n '%': function (string /* arg, arg, ... */) {\n const args = Array.prototype.slice.call(arguments, 1);\n let result = string.value;\n\n for (let i = 0; i < args.length; i++) {\n /* jshint loopfunc:true */\n result = result.replace(/%[sda]/i, token => {\n const value = ((args[i].type === 'Quoted') &&\n token.match(/s/i)) ? args[i].value : args[i].toCSS();\n return token.match(/[A-Z]$/) ? encodeURIComponent(value) : value;\n });\n }\n result = result.replace(/%%/g, '%');\n return new Quoted(string.quote || '', result, string.escaped);\n }\n};\n","import Keyword from '../tree/keyword';\nimport DetachedRuleset from '../tree/detached-ruleset';\nimport Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nimport URL from '../tree/url';\nimport Operation from '../tree/operation';\n\nconst isa = (n, Type) => (n instanceof Type) ? Keyword.True : Keyword.False;\nconst isunit = (n, unit) => {\n if (unit === undefined) {\n throw { type: 'Argument', message: 'missing the required second argument to isunit.' };\n }\n unit = typeof unit.value === 'string' ? unit.value : unit;\n if (typeof unit !== 'string') {\n throw { type: 'Argument', message: 'Second argument to isunit should be a unit or a string.' };\n }\n return (n instanceof Dimension) && n.unit.is(unit) ? Keyword.True : Keyword.False;\n};\n\nexport default {\n isruleset: function (n) {\n return isa(n, DetachedRuleset);\n },\n iscolor: function (n) {\n return isa(n, Color);\n },\n isnumber: function (n) {\n return isa(n, Dimension);\n },\n isstring: function (n) {\n return isa(n, Quoted);\n },\n iskeyword: function (n) {\n return isa(n, Keyword);\n },\n isurl: function (n) {\n return isa(n, URL);\n },\n ispixel: function (n) {\n return isunit(n, 'px');\n },\n ispercentage: function (n) {\n return isunit(n, '%');\n },\n isem: function (n) {\n return isunit(n, 'em');\n },\n isunit,\n unit: function (val, unit) {\n if (!(val instanceof Dimension)) {\n throw { type: 'Argument',\n message: `the first argument to unit must be a number${val instanceof Operation ? '. Have you forgotten parenthesis?' : ''}` };\n }\n if (unit) {\n if (unit instanceof Keyword) {\n unit = unit.value;\n } else {\n unit = unit.toCSS();\n }\n } else {\n unit = '';\n }\n return new Dimension(val.value, unit);\n },\n 'get-unit': function (n) {\n return new Anonymous(n.unit);\n }\n};\n","import functionRegistry from './function-registry';\nimport functionCaller from './function-caller';\n\nimport boolean from './boolean';\nimport defaultFunc from './default';\nimport color from './color';\nimport colorBlending from './color-blending';\nimport dataUri from './data-uri';\nimport list from './list';\nimport math from './math';\nimport number from './number';\nimport string from './string';\nimport svg from './svg';\nimport types from './types';\n\nexport default environment => {\n const functions = { functionRegistry, functionCaller };\n\n // register functions\n functionRegistry.addMultiple(boolean);\n functionRegistry.add('default', defaultFunc.eval.bind(defaultFunc));\n functionRegistry.addMultiple(color);\n functionRegistry.addMultiple(colorBlending);\n functionRegistry.addMultiple(dataUri(environment));\n functionRegistry.addMultiple(list);\n functionRegistry.addMultiple(math);\n functionRegistry.addMultiple(number);\n functionRegistry.addMultiple(string);\n functionRegistry.addMultiple(svg(environment));\n functionRegistry.addMultiple(types);\n\n return functions;\n};\n","import Quoted from '../tree/quoted';\nimport URL from '../tree/url';\nimport * as utils from '../utils';\nimport logger from '../logger';\n\nexport default environment => {\n \n const fallback = (functionThis, node) => new URL(node, functionThis.index, functionThis.currentFileInfo).eval(functionThis.context); \n\n return { 'data-uri': function(mimetypeNode, filePathNode) {\n\n if (!filePathNode) {\n filePathNode = mimetypeNode;\n mimetypeNode = null;\n }\n\n let mimetype = mimetypeNode && mimetypeNode.value;\n let filePath = filePathNode.value;\n const currentFileInfo = this.currentFileInfo;\n const currentDirectory = currentFileInfo.rewriteUrls ?\n currentFileInfo.currentDirectory : currentFileInfo.entryPath;\n\n const fragmentStart = filePath.indexOf('#');\n let fragment = '';\n if (fragmentStart !== -1) {\n fragment = filePath.slice(fragmentStart);\n filePath = filePath.slice(0, fragmentStart);\n }\n const context = utils.clone(this.context);\n context.rawBuffer = true;\n\n const fileManager = environment.getFileManager(filePath, currentDirectory, context, environment, true);\n\n if (!fileManager) {\n return fallback(this, filePathNode);\n }\n\n let useBase64 = false;\n\n // detect the mimetype if not given\n if (!mimetypeNode) {\n\n mimetype = environment.mimeLookup(filePath);\n\n if (mimetype === 'image/svg+xml') {\n useBase64 = false;\n } else {\n // use base 64 unless it's an ASCII or UTF-8 format\n const charset = environment.charsetLookup(mimetype);\n useBase64 = ['US-ASCII', 'UTF-8'].indexOf(charset) < 0;\n }\n if (useBase64) { mimetype += ';base64'; }\n }\n else {\n useBase64 = /;base64$/.test(mimetype);\n }\n\n const fileSync = fileManager.loadFileSync(filePath, currentDirectory, context, environment);\n if (!fileSync.contents) {\n logger.warn(`Skipped data-uri embedding of ${filePath} because file not found`);\n return fallback(this, filePathNode || mimetypeNode);\n }\n let buf = fileSync.contents;\n if (useBase64 && !environment.encodeBase64) {\n return fallback(this, filePathNode);\n }\n\n buf = useBase64 ? environment.encodeBase64(buf) : encodeURIComponent(buf);\n\n const uri = `data:${mimetype},${buf}${fragment}`;\n\n return new URL(new Quoted(`\"${uri}\"`, uri, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo);\n }};\n};\n","import Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Expression from '../tree/expression';\nimport Quoted from '../tree/quoted';\nimport URL from '../tree/url';\n\nexport default environment => {\n return { 'svg-gradient': function(direction) {\n let stops;\n let gradientDirectionSvg;\n let gradientType = 'linear';\n let rectangleDimension = 'x=\"0\" y=\"0\" width=\"1\" height=\"1\"';\n const renderEnv = {compress: false};\n let returner;\n const directionValue = direction.toCSS(renderEnv);\n let i;\n let color;\n let position;\n let positionValue;\n let alpha;\n\n function throwArgumentDescriptor() {\n throw { type: 'Argument',\n message: 'svg-gradient expects direction, start_color [start_position], [color position,]...,' +\n ' end_color [end_position] or direction, color list' };\n }\n\n if (arguments.length == 2) {\n if (arguments[1].value.length < 2) {\n throwArgumentDescriptor();\n }\n stops = arguments[1].value;\n } else if (arguments.length < 3) {\n throwArgumentDescriptor();\n } else {\n stops = Array.prototype.slice.call(arguments, 1);\n }\n\n switch (directionValue) {\n case 'to bottom':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"0%\" y2=\"100%\"';\n break;\n case 'to right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"100%\" y2=\"0%\"';\n break;\n case 'to bottom right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"100%\" y2=\"100%\"';\n break;\n case 'to top right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"100%\" x2=\"100%\" y2=\"0%\"';\n break;\n case 'ellipse':\n case 'ellipse at center':\n gradientType = 'radial';\n gradientDirectionSvg = 'cx=\"50%\" cy=\"50%\" r=\"75%\"';\n rectangleDimension = 'x=\"-50\" y=\"-50\" width=\"101\" height=\"101\"';\n break;\n default:\n throw { type: 'Argument', message: 'svg-gradient direction must be \\'to bottom\\', \\'to right\\',' +\n ' \\'to bottom right\\', \\'to top right\\' or \\'ellipse at center\\'' };\n }\n returner = `<${gradientType}Gradient id=\"g\" ${gradientDirectionSvg}>`;\n\n for (i = 0; i < stops.length; i += 1) {\n if (stops[i] instanceof Expression) {\n color = stops[i].value[0];\n position = stops[i].value[1];\n } else {\n color = stops[i];\n position = undefined;\n }\n\n if (!(color instanceof Color) || (!((i === 0 || i + 1 === stops.length) && position === undefined) && !(position instanceof Dimension))) {\n throwArgumentDescriptor();\n }\n positionValue = position ? position.toCSS(renderEnv) : i === 0 ? '0%' : '100%';\n alpha = color.alpha;\n returner += ``;\n }\n returner += ``;\n\n returner = encodeURIComponent(returner);\n\n returner = `data:image/svg+xml,${returner}`;\n return new URL(new Quoted(`'${returner}'`, returner, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo);\n }};\n};\n","import contexts from './contexts';\nimport visitor from './visitors';\nimport tree from './tree';\n\nexport default (root, options = {}) => {\n let evaldRoot;\n let variables = options.variables;\n const evalEnv = new contexts.Eval(options);\n\n //\n // Allows setting variables with a hash, so:\n //\n // `{ color: new tree.Color('#f01') }` will become:\n //\n // new tree.Declaration('@color',\n // new tree.Value([\n // new tree.Expression([\n // new tree.Color('#f01')\n // ])\n // ])\n // )\n //\n if (typeof variables === 'object' && !Array.isArray(variables)) {\n variables = Object.keys(variables).map(k => {\n let value = variables[k];\n\n if (!(value instanceof tree.Value)) {\n if (!(value instanceof tree.Expression)) {\n value = new tree.Expression([value]);\n }\n value = new tree.Value([value]);\n }\n return new tree.Declaration(`@${k}`, value, false, null, 0);\n });\n evalEnv.frames = [new tree.Ruleset(null, variables)];\n }\n\n const visitors = [\n new visitor.JoinSelectorVisitor(),\n new visitor.MarkVisibleSelectorsVisitor(true),\n new visitor.ExtendVisitor(),\n new visitor.ToCSSVisitor({compress: Boolean(options.compress)})\n ];\n\n const preEvalVisitors = [];\n let v;\n let visitorIterator;\n\n /**\n * first() / get() allows visitors to be added while visiting\n * \n * @todo Add scoping for visitors just like functions for @plugin; right now they're global\n */\n if (options.pluginManager) {\n visitorIterator = options.pluginManager.visitor();\n for (var i = 0; i < 2; i++) {\n visitorIterator.first();\n while ((v = visitorIterator.get())) {\n if (v.isPreEvalVisitor) {\n if (i === 0 || preEvalVisitors.indexOf(v) === -1) {\n preEvalVisitors.push(v);\n v.run(root);\n }\n }\n else {\n if (i === 0 || visitors.indexOf(v) === -1) {\n if (v.isPreVisitor) {\n visitors.unshift(v);\n }\n else {\n visitors.push(v);\n }\n }\n }\n }\n }\n }\n\n evaldRoot = root.eval(evalEnv);\n\n for (var i = 0; i < visitors.length; i++) {\n visitors[i].run(evaldRoot);\n }\n\n // Run any remaining visitors added after eval pass\n if (options.pluginManager) {\n visitorIterator.first();\n while ((v = visitorIterator.get())) {\n if (visitors.indexOf(v) === -1 && preEvalVisitors.indexOf(v) === -1) {\n v.run(evaldRoot);\n }\n }\n }\n\n return evaldRoot;\n};\n","/**\n * Plugin Manager\n */\nclass PluginManager {\n constructor(less) {\n this.less = less;\n this.visitors = [];\n this.preProcessors = [];\n this.postProcessors = [];\n this.installedPlugins = [];\n this.fileManagers = [];\n this.iterator = -1;\n this.pluginCache = {};\n this.Loader = new less.PluginLoader(less);\n }\n\n /**\n * Adds all the plugins in the array\n * @param {Array} plugins\n */\n addPlugins(plugins) {\n if (plugins) {\n for (let i = 0; i < plugins.length; i++) {\n this.addPlugin(plugins[i]);\n }\n }\n }\n\n /**\n *\n * @param plugin\n * @param {String} filename\n */\n addPlugin(plugin, filename, functionRegistry) {\n this.installedPlugins.push(plugin);\n if (filename) {\n this.pluginCache[filename] = plugin;\n }\n if (plugin.install) {\n plugin.install(this.less, this, functionRegistry || this.less.functions.functionRegistry);\n }\n }\n\n /**\n *\n * @param filename\n */\n get(filename) {\n return this.pluginCache[filename];\n }\n\n /**\n * Adds a visitor. The visitor object has options on itself to determine\n * when it should run.\n * @param visitor\n */\n addVisitor(visitor) {\n this.visitors.push(visitor);\n }\n\n /**\n * Adds a pre processor object\n * @param {object} preProcessor\n * @param {number} priority - guidelines 1 = before import, 1000 = import, 2000 = after import\n */\n addPreProcessor(preProcessor, priority) {\n let indexToInsertAt;\n for (indexToInsertAt = 0; indexToInsertAt < this.preProcessors.length; indexToInsertAt++) {\n if (this.preProcessors[indexToInsertAt].priority >= priority) {\n break;\n }\n }\n this.preProcessors.splice(indexToInsertAt, 0, {preProcessor, priority});\n }\n\n /**\n * Adds a post processor object\n * @param {object} postProcessor\n * @param {number} priority - guidelines 1 = before compression, 1000 = compression, 2000 = after compression\n */\n addPostProcessor(postProcessor, priority) {\n let indexToInsertAt;\n for (indexToInsertAt = 0; indexToInsertAt < this.postProcessors.length; indexToInsertAt++) {\n if (this.postProcessors[indexToInsertAt].priority >= priority) {\n break;\n }\n }\n this.postProcessors.splice(indexToInsertAt, 0, {postProcessor, priority});\n }\n\n /**\n *\n * @param manager\n */\n addFileManager(manager) {\n this.fileManagers.push(manager);\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getPreProcessors() {\n const preProcessors = [];\n for (let i = 0; i < this.preProcessors.length; i++) {\n preProcessors.push(this.preProcessors[i].preProcessor);\n }\n return preProcessors;\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getPostProcessors() {\n const postProcessors = [];\n for (let i = 0; i < this.postProcessors.length; i++) {\n postProcessors.push(this.postProcessors[i].postProcessor);\n }\n return postProcessors;\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getVisitors() {\n return this.visitors;\n }\n\n visitor() {\n const self = this;\n return {\n first: function() {\n self.iterator = -1;\n return self.visitors[self.iterator];\n },\n get: function() {\n self.iterator += 1;\n return self.visitors[self.iterator];\n }\n };\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getFileManagers() {\n return this.fileManagers;\n }\n}\n\nlet pm;\n\nfunction PluginManagerFactory(less, newFactory) {\n if (newFactory || !pm) {\n pm = new PluginManager(less);\n }\n return pm;\n};\n\n//\nexport default PluginManagerFactory;\n","/* global window, XMLHttpRequest */\n\nimport AbstractFileManager from '../less/environment/abstract-file-manager.js';\n\nlet options;\nlet logger;\nlet fileCache = {};\n\n// TODOS - move log somewhere. pathDiff and doing something similar in node. use pathDiff in the other browser file for the initial load\nclass FileManager extends AbstractFileManager {\n alwaysMakePathsAbsolute() {\n return true;\n }\n\n join(basePath, laterPath) {\n if (!basePath) {\n return laterPath;\n }\n return this.extractUrlParts(laterPath, basePath).path;\n }\n\n doXHR(url, type, callback, errback) {\n const xhr = new XMLHttpRequest();\n const async = options.isFileProtocol ? options.fileAsync : true;\n\n if (typeof xhr.overrideMimeType === 'function') {\n xhr.overrideMimeType('text/css');\n }\n logger.debug(`XHR: Getting '${url}'`);\n xhr.open('GET', url, async);\n xhr.setRequestHeader('Accept', type || 'text/x-less, text/css; q=0.9, */*; q=0.5');\n xhr.send(null);\n\n function handleResponse(xhr, callback, errback) {\n if (xhr.status >= 200 && xhr.status < 300) {\n callback(xhr.responseText,\n xhr.getResponseHeader('Last-Modified'));\n } else if (typeof errback === 'function') {\n errback(xhr.status, url);\n }\n }\n\n if (options.isFileProtocol && !options.fileAsync) {\n if (xhr.status === 0 || (xhr.status >= 200 && xhr.status < 300)) {\n callback(xhr.responseText);\n } else {\n errback(xhr.status, url);\n }\n } else if (async) {\n xhr.onreadystatechange = () => {\n if (xhr.readyState == 4) {\n handleResponse(xhr, callback, errback);\n }\n };\n } else {\n handleResponse(xhr, callback, errback);\n }\n }\n\n supports() {\n return true;\n }\n\n clearFileCache() {\n fileCache = {};\n }\n\n loadFile(filename, currentDirectory, options, environment) {\n // TODO: Add prefix support like less-node?\n // What about multiple paths?\n\n if (currentDirectory && !this.isPathAbsolute(filename)) {\n filename = currentDirectory + filename;\n }\n\n filename = options.ext ? this.tryAppendExtension(filename, options.ext) : filename;\n\n options = options || {};\n\n // sheet may be set to the stylesheet for the initial load or a collection of properties including\n // some context variables for imports\n const hrefParts = this.extractUrlParts(filename, window.location.href);\n const href = hrefParts.url;\n const self = this;\n \n return new Promise((resolve, reject) => {\n if (options.useFileCache && fileCache[href]) {\n try {\n const lessText = fileCache[href];\n return resolve({ contents: lessText, filename: href, webInfo: { lastModified: new Date() }});\n } catch (e) {\n return reject({ filename: href, message: `Error loading file ${href} error was ${e.message}` });\n }\n }\n\n self.doXHR(href, options.mime, function doXHRCallback(data, lastModified) {\n // per file cache\n fileCache[href] = data;\n\n // Use remote copy (re-parse)\n resolve({ contents: data, filename: href, webInfo: { lastModified }});\n }, function doXHRError(status, url) {\n reject({ type: 'File', message: `'${url}' wasn't found (${status})`, href });\n });\n });\n }\n}\n\nexport default (opts, log) => {\n options = opts;\n logger = log;\n return FileManager;\n}\n","import data from './data';\nimport tree from './tree';\nimport Environment from './environment/environment';\nimport AbstractFileManager from './environment/abstract-file-manager';\nimport AbstractPluginLoader from './environment/abstract-plugin-loader';\nimport visitors from './visitors';\nimport Parser from './parser/parser';\nimport Functions from './functions';\nimport contexts from './contexts';\nimport sourceMapOutput from './source-map-output';\nimport sourceMapBuilder from './source-map-builder';\nimport parseTree from './parse-tree';\nimport importManager from './import-manager';\nimport Render from './render';\nimport Parse from './parse';\nimport LessError from './less-error';\nimport transformTree from './transform-tree';\nimport * as utils from './utils';\nimport PluginManager from './plugin-manager';\nimport logger from './logger';\n\nexport default (environment, fileManagers) => {\n /**\n * @todo\n * This original code could be improved quite a bit.\n * Many classes / modules currently add side-effects / mutations to passed in objects,\n * which makes it hard to refactor and reason about. \n */\n environment = new Environment(environment, fileManagers);\n\n const SourceMapOutput = sourceMapOutput(environment);\n const SourceMapBuilder = sourceMapBuilder(SourceMapOutput, environment);\n const ParseTree = parseTree(SourceMapBuilder);\n const ImportManager = importManager(environment);\n const render = Render(environment, ParseTree, ImportManager);\n const parse = Parse(environment, ParseTree, ImportManager);\n const functions = Functions(environment);\n\n /**\n * @todo\n * This root properties / methods need to be organized.\n * It's not clear what should / must be public and why.\n */\n const initial = {\n version: [3, 13, 1],\n data,\n tree,\n Environment,\n AbstractFileManager,\n AbstractPluginLoader,\n environment,\n visitors,\n Parser,\n functions,\n contexts,\n SourceMapOutput,\n SourceMapBuilder,\n ParseTree,\n ImportManager,\n render,\n parse,\n LessError,\n transformTree,\n utils,\n PluginManager,\n logger\n };\n\n // Create a public API\n const ctor = t => function (...args) {\n return new t(...args);\n };\n\n let t;\n const api = Object.create(initial);\n for (const n in initial.tree) {\n /* eslint guard-for-in: 0 */\n t = initial.tree[n];\n if (typeof t === 'function') {\n api[n.toLowerCase()] = ctor(t);\n }\n else {\n api[n] = Object.create(null);\n for (const o in t) {\n /* eslint guard-for-in: 0 */\n api[n][o.toLowerCase()] = ctor(t[o]);\n }\n }\n }\n\n /**\n * Some of the functions assume a `this` context of the API object,\n * which causes it to fail when wrapped for ES6 imports.\n * \n * An assumed `this` should be removed in the future.\n */\n initial.parse = initial.parse.bind(api);\n initial.render = initial.render.bind(api);\n\n return api;\n};\n","export default environment => {\n class SourceMapOutput {\n constructor(options) {\n this._css = [];\n this._rootNode = options.rootNode;\n this._contentsMap = options.contentsMap;\n this._contentsIgnoredCharsMap = options.contentsIgnoredCharsMap;\n if (options.sourceMapFilename) {\n this._sourceMapFilename = options.sourceMapFilename.replace(/\\\\/g, '/');\n }\n this._outputFilename = options.outputFilename;\n this.sourceMapURL = options.sourceMapURL;\n if (options.sourceMapBasepath) {\n this._sourceMapBasepath = options.sourceMapBasepath.replace(/\\\\/g, '/');\n }\n if (options.sourceMapRootpath) {\n this._sourceMapRootpath = options.sourceMapRootpath.replace(/\\\\/g, '/');\n if (this._sourceMapRootpath.charAt(this._sourceMapRootpath.length - 1) !== '/') {\n this._sourceMapRootpath += '/';\n }\n } else {\n this._sourceMapRootpath = '';\n }\n this._outputSourceFiles = options.outputSourceFiles;\n this._sourceMapGeneratorConstructor = environment.getSourceMapGenerator();\n\n this._lineNumber = 0;\n this._column = 0;\n }\n\n removeBasepath(path) {\n if (this._sourceMapBasepath && path.indexOf(this._sourceMapBasepath) === 0) {\n path = path.substring(this._sourceMapBasepath.length);\n if (path.charAt(0) === '\\\\' || path.charAt(0) === '/') {\n path = path.substring(1);\n }\n }\n\n return path;\n }\n\n normalizeFilename(filename) {\n filename = filename.replace(/\\\\/g, '/');\n filename = this.removeBasepath(filename);\n return (this._sourceMapRootpath || '') + filename;\n }\n\n add(chunk, fileInfo, index, mapLines) {\n // ignore adding empty strings\n if (!chunk) {\n return;\n }\n\n let lines;\n let sourceLines;\n let columns;\n let sourceColumns;\n let i;\n\n if (fileInfo && fileInfo.filename) {\n let inputSource = this._contentsMap[fileInfo.filename];\n\n // remove vars/banner added to the top of the file\n if (this._contentsIgnoredCharsMap[fileInfo.filename]) {\n // adjust the index\n index -= this._contentsIgnoredCharsMap[fileInfo.filename];\n if (index < 0) { index = 0; }\n // adjust the source\n inputSource = inputSource.slice(this._contentsIgnoredCharsMap[fileInfo.filename]);\n }\n\n /** \n * ignore empty content, or failsafe\n * if contents map is incorrect\n */\n if (inputSource === undefined) {\n this._css.push(chunk);\n return;\n }\n\n inputSource = inputSource.substring(0, index);\n sourceLines = inputSource.split('\\n');\n sourceColumns = sourceLines[sourceLines.length - 1];\n }\n\n lines = chunk.split('\\n');\n columns = lines[lines.length - 1];\n\n if (fileInfo && fileInfo.filename) {\n if (!mapLines) {\n this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + 1, column: this._column},\n original: { line: sourceLines.length, column: sourceColumns.length},\n source: this.normalizeFilename(fileInfo.filename)});\n } else {\n for (i = 0; i < lines.length; i++) {\n this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + i + 1, column: i === 0 ? this._column : 0},\n original: { line: sourceLines.length + i, column: i === 0 ? sourceColumns.length : 0},\n source: this.normalizeFilename(fileInfo.filename)});\n }\n }\n }\n\n if (lines.length === 1) {\n this._column += columns.length;\n } else {\n this._lineNumber += lines.length - 1;\n this._column = columns.length;\n }\n\n this._css.push(chunk);\n }\n\n isEmpty() {\n return this._css.length === 0;\n }\n\n toCSS(context) {\n this._sourceMapGenerator = new this._sourceMapGeneratorConstructor({ file: this._outputFilename, sourceRoot: null });\n\n if (this._outputSourceFiles) {\n for (const filename in this._contentsMap) {\n if (this._contentsMap.hasOwnProperty(filename)) {\n let source = this._contentsMap[filename];\n if (this._contentsIgnoredCharsMap[filename]) {\n source = source.slice(this._contentsIgnoredCharsMap[filename]);\n }\n this._sourceMapGenerator.setSourceContent(this.normalizeFilename(filename), source);\n }\n }\n }\n\n this._rootNode.genCSS(context, this);\n\n if (this._css.length > 0) {\n let sourceMapURL;\n const sourceMapContent = JSON.stringify(this._sourceMapGenerator.toJSON());\n\n if (this.sourceMapURL) {\n sourceMapURL = this.sourceMapURL;\n } else if (this._sourceMapFilename) {\n sourceMapURL = this._sourceMapFilename;\n }\n this.sourceMapURL = sourceMapURL;\n\n this.sourceMap = sourceMapContent;\n }\n\n return this._css.join('');\n }\n }\n\n return SourceMapOutput;\n};\n","export default (SourceMapOutput, environment) => {\n class SourceMapBuilder {\n constructor(options) {\n this.options = options;\n }\n\n toCSS(rootNode, options, imports) {\n const sourceMapOutput = new SourceMapOutput(\n {\n contentsIgnoredCharsMap: imports.contentsIgnoredChars,\n rootNode,\n contentsMap: imports.contents,\n sourceMapFilename: this.options.sourceMapFilename,\n sourceMapURL: this.options.sourceMapURL,\n outputFilename: this.options.sourceMapOutputFilename,\n sourceMapBasepath: this.options.sourceMapBasepath,\n sourceMapRootpath: this.options.sourceMapRootpath,\n outputSourceFiles: this.options.outputSourceFiles,\n sourceMapGenerator: this.options.sourceMapGenerator,\n sourceMapFileInline: this.options.sourceMapFileInline, \n disableSourcemapAnnotation: this.options.disableSourcemapAnnotation\n });\n\n const css = sourceMapOutput.toCSS(options);\n this.sourceMap = sourceMapOutput.sourceMap;\n this.sourceMapURL = sourceMapOutput.sourceMapURL;\n if (this.options.sourceMapInputFilename) {\n this.sourceMapInputFilename = sourceMapOutput.normalizeFilename(this.options.sourceMapInputFilename);\n }\n if (this.options.sourceMapBasepath !== undefined && this.sourceMapURL !== undefined) {\n this.sourceMapURL = sourceMapOutput.removeBasepath(this.sourceMapURL);\n }\n return css + this.getCSSAppendage();\n }\n\n getCSSAppendage() {\n\n let sourceMapURL = this.sourceMapURL;\n if (this.options.sourceMapFileInline) {\n if (this.sourceMap === undefined) {\n return '';\n }\n sourceMapURL = `data:application/json;base64,${environment.encodeBase64(this.sourceMap)}`;\n }\n\n if (this.options.disableSourcemapAnnotation) {\n return '';\n }\n\n if (sourceMapURL) {\n return `/*# sourceMappingURL=${sourceMapURL} */`;\n }\n return '';\n }\n\n getExternalSourceMap() {\n return this.sourceMap;\n }\n\n setExternalSourceMap(sourceMap) {\n this.sourceMap = sourceMap;\n }\n\n isInline() {\n return this.options.sourceMapFileInline;\n }\n\n getSourceMapURL() {\n return this.sourceMapURL;\n }\n\n getOutputFilename() {\n return this.options.sourceMapOutputFilename;\n }\n\n getInputFilename() {\n return this.sourceMapInputFilename;\n }\n }\n\n return SourceMapBuilder;\n};\n","import LessError from './less-error';\nimport transformTree from './transform-tree';\nimport logger from './logger';\n\nexport default SourceMapBuilder => {\n class ParseTree {\n constructor(root, imports) {\n this.root = root;\n this.imports = imports;\n }\n\n toCSS(options) {\n let evaldRoot;\n const result = {};\n let sourceMapBuilder;\n try {\n evaldRoot = transformTree(this.root, options);\n } catch (e) {\n throw new LessError(e, this.imports);\n }\n\n try {\n const compress = Boolean(options.compress);\n if (compress) {\n logger.warn('The compress option has been deprecated. ' + \n 'We recommend you use a dedicated css minifier, for instance see less-plugin-clean-css.');\n }\n\n const toCSSOptions = {\n compress,\n dumpLineNumbers: options.dumpLineNumbers,\n strictUnits: Boolean(options.strictUnits),\n numPrecision: 8};\n\n if (options.sourceMap) {\n sourceMapBuilder = new SourceMapBuilder(options.sourceMap);\n result.css = sourceMapBuilder.toCSS(evaldRoot, toCSSOptions, this.imports);\n } else {\n result.css = evaldRoot.toCSS(toCSSOptions);\n }\n } catch (e) {\n throw new LessError(e, this.imports);\n }\n\n if (options.pluginManager) {\n const postProcessors = options.pluginManager.getPostProcessors();\n for (let i = 0; i < postProcessors.length; i++) {\n result.css = postProcessors[i].process(result.css, { sourceMap: sourceMapBuilder, options, imports: this.imports });\n }\n }\n if (options.sourceMap) {\n result.map = sourceMapBuilder.getExternalSourceMap();\n }\n\n result.imports = [];\n for (const file in this.imports.files) {\n if (this.imports.files.hasOwnProperty(file) && file !== this.imports.rootFilename) {\n result.imports.push(file);\n }\n }\n return result;\n }\n }\n\n return ParseTree;\n};\n","import contexts from './contexts';\nimport Parser from './parser/parser';\nimport LessError from './less-error';\nimport * as utils from './utils';\nimport logger from './logger';\n\nexport default function(environment) {\n // FileInfo = {\n // 'rewriteUrls' - option - whether to adjust URL's to be relative\n // 'filename' - full resolved filename of current file\n // 'rootpath' - path to append to normal URLs for this node\n // 'currentDirectory' - path to the current file, absolute\n // 'rootFilename' - filename of the base file\n // 'entryPath' - absolute path to the entry file\n // 'reference' - whether the file should not be output and only output parts that are referenced\n\n class ImportManager {\n constructor(less, context, rootFileInfo) {\n this.less = less;\n this.rootFilename = rootFileInfo.filename;\n this.paths = context.paths || []; // Search paths, when importing\n this.contents = {}; // map - filename to contents of all the files\n this.contentsIgnoredChars = {}; // map - filename to lines at the beginning of each file to ignore\n this.mime = context.mime;\n this.error = null;\n this.context = context;\n // Deprecated? Unused outside of here, could be useful.\n this.queue = []; // Files which haven't been imported yet\n this.files = {}; // Holds the imported parse trees.\n }\n\n /**\n * Add an import to be imported\n * @param path - the raw path\n * @param tryAppendExtension - whether to try appending a file extension (.less or .js if the path has no extension)\n * @param currentFileInfo - the current file info (used for instance to work out relative paths)\n * @param importOptions - import options\n * @param callback - callback for when it is imported\n */\n push(path, tryAppendExtension, currentFileInfo, importOptions, callback) {\n const importManager = this, pluginLoader = this.context.pluginManager.Loader;\n\n this.queue.push(path);\n\n const fileParsedFunc = function (e, root, fullPath) {\n importManager.queue.splice(importManager.queue.indexOf(path), 1); // Remove the path from the queue\n\n const importedEqualsRoot = fullPath === importManager.rootFilename;\n if (importOptions.optional && e) {\n callback(null, {rules:[]}, false, null);\n logger.info(`The file ${fullPath} was skipped because it was not found and the import was marked optional.`);\n }\n else {\n // Inline imports aren't cached here.\n // If we start to cache them, please make sure they won't conflict with non-inline imports of the\n // same name as they used to do before this comment and the condition below have been added.\n if (!importManager.files[fullPath] && !importOptions.inline) {\n importManager.files[fullPath] = { root, options: importOptions };\n }\n if (e && !importManager.error) { importManager.error = e; }\n callback(e, root, importedEqualsRoot, fullPath);\n }\n };\n\n const newFileInfo = {\n rewriteUrls: this.context.rewriteUrls,\n entryPath: currentFileInfo.entryPath,\n rootpath: currentFileInfo.rootpath,\n rootFilename: currentFileInfo.rootFilename\n };\n\n const fileManager = environment.getFileManager(path, currentFileInfo.currentDirectory, this.context, environment);\n\n if (!fileManager) {\n fileParsedFunc({ message: `Could not find a file-manager for ${path}` });\n return;\n }\n\n const loadFileCallback = function(loadedFile) {\n let plugin;\n const resolvedFilename = loadedFile.filename;\n const contents = loadedFile.contents.replace(/^\\uFEFF/, '');\n\n // Pass on an updated rootpath if path of imported file is relative and file\n // is in a (sub|sup) directory\n //\n // Examples:\n // - If path of imported file is 'module/nav/nav.less' and rootpath is 'less/',\n // then rootpath should become 'less/module/nav/'\n // - If path of imported file is '../mixins.less' and rootpath is 'less/',\n // then rootpath should become 'less/../'\n newFileInfo.currentDirectory = fileManager.getPath(resolvedFilename);\n if (newFileInfo.rewriteUrls) {\n newFileInfo.rootpath = fileManager.join(\n (importManager.context.rootpath || ''),\n fileManager.pathDiff(newFileInfo.currentDirectory, newFileInfo.entryPath));\n\n if (!fileManager.isPathAbsolute(newFileInfo.rootpath) && fileManager.alwaysMakePathsAbsolute()) {\n newFileInfo.rootpath = fileManager.join(newFileInfo.entryPath, newFileInfo.rootpath);\n }\n }\n newFileInfo.filename = resolvedFilename;\n\n const newEnv = new contexts.Parse(importManager.context);\n\n newEnv.processImports = false;\n importManager.contents[resolvedFilename] = contents;\n\n if (currentFileInfo.reference || importOptions.reference) {\n newFileInfo.reference = true;\n }\n\n if (importOptions.isPlugin) {\n plugin = pluginLoader.evalPlugin(contents, newEnv, importManager, importOptions.pluginArgs, newFileInfo);\n if (plugin instanceof LessError) {\n fileParsedFunc(plugin, null, resolvedFilename);\n }\n else {\n fileParsedFunc(null, plugin, resolvedFilename);\n }\n } else if (importOptions.inline) {\n fileParsedFunc(null, contents, resolvedFilename);\n } else {\n // import (multiple) parse trees apparently get altered and can't be cached.\n // TODO: investigate why this is\n if (importManager.files[resolvedFilename]\n && !importManager.files[resolvedFilename].options.multiple\n && !importOptions.multiple) {\n\n fileParsedFunc(null, importManager.files[resolvedFilename].root, resolvedFilename);\n }\n else {\n new Parser(newEnv, importManager, newFileInfo).parse(contents, function (e, root) {\n fileParsedFunc(e, root, resolvedFilename);\n });\n }\n }\n };\n let loadedFile;\n let promise;\n const context = utils.clone(this.context);\n\n if (tryAppendExtension) {\n context.ext = importOptions.isPlugin ? '.js' : '.less';\n }\n\n if (importOptions.isPlugin) {\n context.mime = 'application/javascript';\n\n if (context.syncImport) {\n loadedFile = pluginLoader.loadPluginSync(path, currentFileInfo.currentDirectory, context, environment, fileManager);\n } else {\n promise = pluginLoader.loadPlugin(path, currentFileInfo.currentDirectory, context, environment, fileManager);\n }\n }\n else {\n if (context.syncImport) {\n loadedFile = fileManager.loadFileSync(path, currentFileInfo.currentDirectory, context, environment);\n } else {\n promise = fileManager.loadFile(path, currentFileInfo.currentDirectory, context, environment,\n (err, loadedFile) => {\n if (err) {\n fileParsedFunc(err);\n } else {\n loadFileCallback(loadedFile);\n }\n });\n }\n }\n if (loadedFile) {\n if (!loadedFile.filename) {\n fileParsedFunc(loadedFile);\n } else {\n loadFileCallback(loadedFile);\n }\n } else if (promise) {\n promise.then(loadFileCallback, fileParsedFunc);\n }\n }\n }\n\n return ImportManager;\n};\n","import * as utils from './utils';\n\nexport default (environment, ParseTree, ImportManager) => {\n const render = function (input, options, callback) {\n if (typeof options === 'function') {\n callback = options;\n options = utils.copyOptions(this.options, {});\n }\n else {\n options = utils.copyOptions(this.options, options || {});\n }\n\n if (!callback) {\n const self = this;\n return new Promise((resolve, reject) => {\n render.call(self, input, options, (err, output) => {\n if (err) {\n reject(err);\n } else {\n resolve(output);\n }\n });\n });\n } else {\n this.parse(input, options, (err, root, imports, options) => {\n if (err) { return callback(err); }\n\n let result;\n try {\n const parseTree = new ParseTree(root, imports);\n result = parseTree.toCSS(options);\n }\n catch (err) { return callback(err); }\n\n callback(null, result);\n });\n }\n };\n\n return render;\n};\n","import contexts from './contexts';\nimport Parser from './parser/parser';\nimport PluginManager from './plugin-manager';\nimport LessError from './less-error';\nimport * as utils from './utils';\n\nexport default (environment, ParseTree, ImportManager) => {\n const parse = function (input, options, callback) {\n\n if (typeof options === 'function') {\n callback = options;\n options = utils.copyOptions(this.options, {});\n }\n else {\n options = utils.copyOptions(this.options, options || {});\n }\n\n if (!callback) {\n const self = this;\n return new Promise((resolve, reject) => {\n parse.call(self, input, options, (err, output) => {\n if (err) {\n reject(err);\n } else {\n resolve(output);\n }\n });\n });\n } else {\n let context;\n let rootFileInfo;\n const pluginManager = new PluginManager(this, !options.reUsePluginManager);\n\n options.pluginManager = pluginManager;\n\n context = new contexts.Parse(options);\n\n if (options.rootFileInfo) {\n rootFileInfo = options.rootFileInfo;\n } else {\n const filename = options.filename || 'input';\n const entryPath = filename.replace(/[^\\/\\\\]*$/, '');\n rootFileInfo = {\n filename,\n rewriteUrls: context.rewriteUrls,\n rootpath: context.rootpath || '',\n currentDirectory: entryPath,\n entryPath,\n rootFilename: filename\n };\n // add in a missing trailing slash\n if (rootFileInfo.rootpath && rootFileInfo.rootpath.slice(-1) !== '/') {\n rootFileInfo.rootpath += '/';\n }\n }\n\n const imports = new ImportManager(this, context, rootFileInfo);\n this.importManager = imports;\n\n // TODO: allow the plugins to be just a list of paths or names\n // Do an async plugin queue like lessc\n\n if (options.plugins) {\n options.plugins.forEach(plugin => {\n let evalResult;\n let contents;\n if (plugin.fileContent) {\n contents = plugin.fileContent.replace(/^\\uFEFF/, '');\n evalResult = pluginManager.Loader.evalPlugin(contents, context, imports, plugin.options, plugin.filename);\n if (evalResult instanceof LessError) {\n return callback(evalResult);\n }\n }\n else {\n pluginManager.addPlugin(plugin);\n }\n });\n }\n\n new Parser(context, imports, rootFileInfo)\n .parse(input, (e, root) => {\n if (e) { return callback(e); }\n callback(null, root, imports, options);\n }, options);\n }\n };\n return parse;\n};\n","// TODO: Add tests for browser @plugin\n/* global window */\n\nimport AbstractPluginLoader from '../less/environment/abstract-plugin-loader.js';\n\n/**\n * Browser Plugin Loader\n */\nclass PluginLoader extends AbstractPluginLoader {\n constructor(less) {\n super();\n\n this.less = less;\n // Should we shim this.require for browser? Probably not?\n }\n\n loadPlugin(filename, basePath, context, environment, fileManager) {\n return new Promise((fulfill, reject) => {\n fileManager.loadFile(filename, basePath, context, environment)\n .then(fulfill).catch(reject);\n });\n }\n}\n\nexport default PluginLoader;\n\n","import * as utils from './utils';\nimport browser from './browser';\n\nexport default (window, less, options) => {\n\n function errorHTML(e, rootHref) {\n const id = `less-error-message:${utils.extractId(rootHref || '')}`;\n const template = '
  • {content}
  • ';\n const elem = window.document.createElement('div');\n let timer;\n let content;\n const errors = [];\n const filename = e.filename || rootHref;\n const filenameNoPath = filename.match(/([^\\/]+(\\?.*)?)$/)[1];\n\n elem.id = id;\n elem.className = 'less-error-message';\n\n content = `

    ${e.type || 'Syntax'}Error: ${e.message || 'There is an error in your .less file'}` + \n `

    in ${filenameNoPath} `;\n\n const errorline = (e, i, classname) => {\n if (e.extract[i] !== undefined) {\n errors.push(template.replace(/\\{line\\}/, (parseInt(e.line, 10) || 0) + (i - 1))\n .replace(/\\{class\\}/, classname)\n .replace(/\\{content\\}/, e.extract[i]));\n }\n };\n\n if (e.line) {\n errorline(e, 0, '');\n errorline(e, 1, 'line');\n errorline(e, 2, '');\n content += `on line ${e.line}, column ${e.column + 1}:

      ${errors.join('')}
    `;\n }\n if (e.stack && (e.extract || options.logLevel >= 4)) {\n content += `
    Stack Trace
    ${e.stack.split('\\n').slice(1).join('
    ')}`;\n }\n elem.innerHTML = content;\n\n // CSS for error messages\n browser.createCSS(window.document, [\n '.less-error-message ul, .less-error-message li {',\n 'list-style-type: none;',\n 'margin-right: 15px;',\n 'padding: 4px 0;',\n 'margin: 0;',\n '}',\n '.less-error-message label {',\n 'font-size: 12px;',\n 'margin-right: 15px;',\n 'padding: 4px 0;',\n 'color: #cc7777;',\n '}',\n '.less-error-message pre {',\n 'color: #dd6666;',\n 'padding: 4px 0;',\n 'margin: 0;',\n 'display: inline-block;',\n '}',\n '.less-error-message pre.line {',\n 'color: #ff0000;',\n '}',\n '.less-error-message h3 {',\n 'font-size: 20px;',\n 'font-weight: bold;',\n 'padding: 15px 0 5px 0;',\n 'margin: 0;',\n '}',\n '.less-error-message a {',\n 'color: #10a',\n '}',\n '.less-error-message .error {',\n 'color: red;',\n 'font-weight: bold;',\n 'padding-bottom: 2px;',\n 'border-bottom: 1px dashed red;',\n '}'\n ].join('\\n'), { title: 'error-message' });\n\n elem.style.cssText = [\n 'font-family: Arial, sans-serif',\n 'border: 1px solid #e00',\n 'background-color: #eee',\n 'border-radius: 5px',\n '-webkit-border-radius: 5px',\n '-moz-border-radius: 5px',\n 'color: #e00',\n 'padding: 15px',\n 'margin-bottom: 15px'\n ].join(';');\n\n if (options.env === 'development') {\n timer = setInterval(() => {\n const document = window.document;\n const body = document.body;\n if (body) {\n if (document.getElementById(id)) {\n body.replaceChild(elem, document.getElementById(id));\n } else {\n body.insertBefore(elem, body.firstChild);\n }\n clearInterval(timer);\n }\n }, 10);\n }\n }\n\n function removeErrorHTML(path) {\n const node = window.document.getElementById(`less-error-message:${utils.extractId(path)}`);\n if (node) {\n node.parentNode.removeChild(node);\n }\n }\n\n function removeErrorConsole(path) {\n // no action\n }\n\n function removeError(path) {\n if (!options.errorReporting || options.errorReporting === 'html') {\n removeErrorHTML(path);\n } else if (options.errorReporting === 'console') {\n removeErrorConsole(path);\n } else if (typeof options.errorReporting === 'function') {\n options.errorReporting('remove', path);\n }\n }\n\n function errorConsole(e, rootHref) {\n const template = '{line} {content}';\n const filename = e.filename || rootHref;\n const errors = [];\n let content = `${e.type || 'Syntax'}Error: ${e.message || 'There is an error in your .less file'} in ${filename}`;\n\n const errorline = (e, i, classname) => {\n if (e.extract[i] !== undefined) {\n errors.push(template.replace(/\\{line\\}/, (parseInt(e.line, 10) || 0) + (i - 1))\n .replace(/\\{class\\}/, classname)\n .replace(/\\{content\\}/, e.extract[i]));\n }\n };\n\n if (e.line) {\n errorline(e, 0, '');\n errorline(e, 1, 'line');\n errorline(e, 2, '');\n content += ` on line ${e.line}, column ${e.column + 1}:\\n${errors.join('\\n')}`;\n }\n if (e.stack && (e.extract || options.logLevel >= 4)) {\n content += `\\nStack Trace\\n${e.stack}`;\n }\n less.logger.error(content);\n }\n\n function error(e, rootHref) {\n if (!options.errorReporting || options.errorReporting === 'html') {\n errorHTML(e, rootHref);\n } else if (options.errorReporting === 'console') {\n errorConsole(e, rootHref);\n } else if (typeof options.errorReporting === 'function') {\n options.errorReporting('add', e, rootHref);\n }\n }\n\n return {\n add: error,\n remove: removeError\n };\n};\n","/**\n * Kicks off less and compiles any stylesheets\n * used in the browser distributed version of less\n * to kick-start less using the browser api\n */\n/* global window, document */\n\nimport defaultOptions from '../less/default-options';\nimport addDefaultOptions from './add-default-options';\nimport root from './index';\n\nconst options = defaultOptions();\n\nif (window.less) {\n for (const key in window.less) {\n if (window.less.hasOwnProperty(key)) {\n options[key] = window.less[key];\n }\n }\n}\naddDefaultOptions(window, options);\n\noptions.plugins = options.plugins || [];\n\nif (window.LESS_PLUGINS) {\n options.plugins = options.plugins.concat(window.LESS_PLUGINS);\n}\n\nconst less = root(window, options);\nexport default less;\n\nwindow.less = less;\n\nlet css;\nlet head;\nlet style;\n\n// Always restore page visibility\nfunction resolveOrReject(data) {\n if (data.filename) {\n console.warn(data);\n }\n if (!options.async) {\n head.removeChild(style);\n }\n}\n\nif (options.onReady) {\n if (/!watch/.test(window.location.hash)) {\n less.watch();\n }\n // Simulate synchronous stylesheet loading by hiding page rendering\n if (!options.async) {\n css = 'body { display: none !important }';\n head = document.head || document.getElementsByTagName('head')[0];\n style = document.createElement('style');\n\n style.type = 'text/css';\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n\n head.appendChild(style);\n }\n less.registerStylesheetsImmediately();\n less.pageLoadFinished = less.refresh(less.env === 'development').then(resolveOrReject, resolveOrReject);\n}\n","// Export a new default each time\nexport default () => ({\n /* Inline Javascript - @plugin still allowed */\n javascriptEnabled: false,\n\n /* Outputs a makefile import dependency list to stdout. */\n depends: false,\n\n /* (DEPRECATED) Compress using less built-in compression. \n * This does an okay job but does not utilise all the tricks of \n * dedicated css compression. */\n compress: false,\n\n /* Runs the less parser and just reports errors without any output. */\n lint: false,\n\n /* Sets available include paths.\n * If the file in an @import rule does not exist at that exact location, \n * less will look for it at the location(s) passed to this option. \n * You might use this for instance to specify a path to a library which \n * you want to be referenced simply and relatively in the less files. */\n paths: [],\n\n /* color output in the terminal */\n color: true,\n\n /* The strictImports controls whether the compiler will allow an @import inside of either \n * @media blocks or (a later addition) other selector blocks.\n * See: https://github.com/less/less.js/issues/656 */\n strictImports: false,\n\n /* Allow Imports from Insecure HTTPS Hosts */\n insecure: false,\n\n /* Allows you to add a path to every generated import and url in your css. \n * This does not affect less import statements that are processed, just ones \n * that are left in the output css. */\n rootpath: '',\n\n /* By default URLs are kept as-is, so if you import a file in a sub-directory \n * that references an image, exactly the same URL will be output in the css. \n * This option allows you to re-write URL's in imported files so that the \n * URL is always relative to the base imported file */\n rewriteUrls: false,\n\n /* How to process math \n * 0 always - eagerly try to solve all operations\n * 1 parens-division - require parens for division \"/\"\n * 2 parens | strict - require parens for all operations\n * 3 strict-legacy - legacy strict behavior (super-strict)\n */\n math: 0,\n\n /* Without this option, less attempts to guess at the output unit when it does maths. */\n strictUnits: false,\n\n /* Effectively the declaration is put at the top of your base Less file, \n * meaning it can be used but it also can be overridden if this variable \n * is defined in the file. */\n globalVars: null,\n\n /* As opposed to the global variable option, this puts the declaration at the\n * end of your base file, meaning it will override anything defined in your Less file. */\n modifyVars: null,\n\n /* This option allows you to specify a argument to go on to every URL. */\n urlArgs: ''\n});","import {addDataAttr} from './utils';\nimport browser from './browser';\n\nexport default (window, options) => {\n\n // use options from the current script tag data attribues\n addDataAttr(options, browser.currentScript(window));\n\n if (options.isFileProtocol === undefined) {\n options.isFileProtocol = /^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(window.location.protocol);\n }\n\n // Load styles asynchronously (default: false)\n //\n // This is set to `false` by default, so that the body\n // doesn't start loading before the stylesheets are parsed.\n // Setting this to `true` can result in flickering.\n //\n options.async = options.async || false;\n options.fileAsync = options.fileAsync || false;\n\n // Interval between watch polls\n options.poll = options.poll || (options.isFileProtocol ? 1000 : 1500);\n\n options.env = options.env || (window.location.hostname == '127.0.0.1' ||\n window.location.hostname == '0.0.0.0' ||\n window.location.hostname == 'localhost' ||\n (window.location.port &&\n window.location.port.length > 0) ||\n options.isFileProtocol ? 'development'\n : 'production');\n\n const dumpLineNumbers = /!dumpLineNumbers:(comments|mediaquery|all)/.exec(window.location.hash);\n if (dumpLineNumbers) {\n options.dumpLineNumbers = dumpLineNumbers[1];\n }\n\n if (options.useFileCache === undefined) {\n options.useFileCache = true;\n }\n\n if (options.onReady === undefined) {\n options.onReady = true;\n }\n\n if (options.relativeUrls) {\n options.rewriteUrls = 'all';\n }\n};\n","//\n// index.js\n// Should expose the additional browser functions on to the less object\n//\nimport {addDataAttr} from './utils';\nimport lessRoot from '../less';\nimport browser from './browser';\nimport FM from './file-manager';\nimport PluginLoader from './plugin-loader';\nimport LogListener from './log-listener';\nimport ErrorReporting from './error-reporting';\nimport Cache from './cache';\nimport ImageSize from './image-size';\n\nexport default (window, options) => {\n const document = window.document;\n const less = lessRoot();\n\n less.options = options;\n const environment = less.environment;\n const FileManager = FM(options, less.logger);\n const fileManager = new FileManager();\n environment.addFileManager(fileManager);\n less.FileManager = FileManager;\n less.PluginLoader = PluginLoader;\n\n LogListener(less, options);\n const errors = ErrorReporting(window, less, options);\n const cache = less.cache = options.cache || Cache(window, options, less.logger);\n ImageSize(less.environment);\n\n // Setup user functions - Deprecate?\n if (options.functions) {\n less.functions.functionRegistry.addMultiple(options.functions);\n }\n\n const typePattern = /^text\\/(x-)?less$/;\n\n function clone(obj) {\n const cloned = {};\n for (const prop in obj) {\n if (obj.hasOwnProperty(prop)) {\n cloned[prop] = obj[prop];\n }\n }\n return cloned;\n }\n\n // only really needed for phantom\n function bind(func, thisArg) {\n const curryArgs = Array.prototype.slice.call(arguments, 2);\n return function() {\n const args = curryArgs.concat(Array.prototype.slice.call(arguments, 0));\n return func.apply(thisArg, args);\n };\n }\n\n function loadStyles(modifyVars) {\n const styles = document.getElementsByTagName('style');\n let style;\n\n for (let i = 0; i < styles.length; i++) {\n style = styles[i];\n if (style.type.match(typePattern)) {\n const instanceOptions = clone(options);\n instanceOptions.modifyVars = modifyVars;\n const lessText = style.innerHTML || '';\n instanceOptions.filename = document.location.href.replace(/#.*$/, '');\n\n /* jshint loopfunc:true */\n // use closure to store current style\n less.render(lessText, instanceOptions,\n bind((style, e, result) => {\n if (e) {\n errors.add(e, 'inline');\n } else {\n style.type = 'text/css';\n if (style.styleSheet) {\n style.styleSheet.cssText = result.css;\n } else {\n style.innerHTML = result.css;\n }\n }\n }, null, style));\n }\n }\n }\n\n function loadStyleSheet(sheet, callback, reload, remaining, modifyVars) {\n\n const instanceOptions = clone(options);\n addDataAttr(instanceOptions, sheet);\n instanceOptions.mime = sheet.type;\n\n if (modifyVars) {\n instanceOptions.modifyVars = modifyVars;\n }\n\n function loadInitialFileCallback(loadedFile) {\n const data = loadedFile.contents;\n const path = loadedFile.filename;\n const webInfo = loadedFile.webInfo;\n\n const newFileInfo = {\n currentDirectory: fileManager.getPath(path),\n filename: path,\n rootFilename: path,\n rewriteUrls: instanceOptions.rewriteUrls\n };\n\n newFileInfo.entryPath = newFileInfo.currentDirectory;\n newFileInfo.rootpath = instanceOptions.rootpath || newFileInfo.currentDirectory;\n\n if (webInfo) {\n webInfo.remaining = remaining;\n\n const css = cache.getCSS(path, webInfo, instanceOptions.modifyVars);\n if (!reload && css) {\n webInfo.local = true;\n callback(null, css, data, sheet, webInfo, path);\n return;\n }\n\n }\n\n // TODO add tests around how this behaves when reloading\n errors.remove(path);\n\n instanceOptions.rootFileInfo = newFileInfo;\n less.render(data, instanceOptions, (e, result) => {\n if (e) {\n e.href = path;\n callback(e);\n } else {\n cache.setCSS(sheet.href, webInfo.lastModified, instanceOptions.modifyVars, result.css);\n callback(null, result.css, data, sheet, webInfo, path);\n }\n });\n }\n\n fileManager.loadFile(sheet.href, null, instanceOptions, environment)\n .then(loadedFile => {\n loadInitialFileCallback(loadedFile);\n }).catch(err => {\n console.log(err);\n callback(err);\n });\n\n }\n\n function loadStyleSheets(callback, reload, modifyVars) {\n for (let i = 0; i < less.sheets.length; i++) {\n loadStyleSheet(less.sheets[i], callback, reload, less.sheets.length - (i + 1), modifyVars);\n }\n }\n\n function initRunningMode() {\n if (less.env === 'development') {\n less.watchTimer = setInterval(() => {\n if (less.watchMode) {\n fileManager.clearFileCache();\n loadStyleSheets((e, css, _, sheet, webInfo) => {\n if (e) {\n errors.add(e, e.href || sheet.href);\n } else if (css) {\n browser.createCSS(window.document, css, sheet);\n }\n });\n }\n }, options.poll);\n }\n }\n\n //\n // Watch mode\n //\n less.watch = function () {\n if (!less.watchMode ) {\n less.env = 'development';\n initRunningMode();\n }\n this.watchMode = true;\n return true;\n };\n\n less.unwatch = function () {clearInterval(less.watchTimer); this.watchMode = false; return false; };\n\n //\n // Synchronously get all tags with the 'rel' attribute set to\n // \"stylesheet/less\".\n //\n less.registerStylesheetsImmediately = () => {\n const links = document.getElementsByTagName('link');\n less.sheets = [];\n\n for (let i = 0; i < links.length; i++) {\n if (links[i].rel === 'stylesheet/less' || (links[i].rel.match(/stylesheet/) &&\n (links[i].type.match(typePattern)))) {\n less.sheets.push(links[i]);\n }\n }\n };\n\n //\n // Asynchronously get all tags with the 'rel' attribute set to\n // \"stylesheet/less\", returning a Promise.\n //\n less.registerStylesheets = () => new Promise((resolve, reject) => {\n less.registerStylesheetsImmediately();\n resolve();\n });\n\n //\n // With this function, it's possible to alter variables and re-render\n // CSS without reloading less-files\n //\n less.modifyVars = record => less.refresh(true, record, false);\n\n less.refresh = (reload, modifyVars, clearFileCache) => {\n if ((reload || clearFileCache) && clearFileCache !== false) {\n fileManager.clearFileCache();\n }\n return new Promise((resolve, reject) => {\n let startTime;\n let endTime;\n let totalMilliseconds;\n let remainingSheets;\n startTime = endTime = new Date();\n\n // Set counter for remaining unprocessed sheets\n remainingSheets = less.sheets.length;\n\n if (remainingSheets === 0) {\n\n endTime = new Date();\n totalMilliseconds = endTime - startTime;\n less.logger.info('Less has finished and no sheets were loaded.');\n resolve({\n startTime,\n endTime,\n totalMilliseconds,\n sheets: less.sheets.length\n });\n\n } else {\n // Relies on less.sheets array, callback seems to be guaranteed to be called for every element of the array\n loadStyleSheets((e, css, _, sheet, webInfo) => {\n if (e) {\n errors.add(e, e.href || sheet.href);\n reject(e);\n return;\n }\n if (webInfo.local) {\n less.logger.info(`Loading ${sheet.href} from cache.`);\n } else {\n less.logger.info(`Rendered ${sheet.href} successfully.`);\n }\n browser.createCSS(window.document, css, sheet);\n less.logger.info(`CSS for ${sheet.href} generated in ${new Date() - endTime}ms`);\n\n // Count completed sheet\n remainingSheets--;\n\n // Check if the last remaining sheet was processed and then call the promise\n if (remainingSheets === 0) {\n totalMilliseconds = new Date() - startTime;\n less.logger.info(`Less has finished. CSS generated in ${totalMilliseconds}ms`);\n resolve({\n startTime,\n endTime,\n totalMilliseconds,\n sheets: less.sheets.length\n });\n }\n endTime = new Date();\n }, reload, modifyVars);\n }\n\n loadStyles(modifyVars);\n });\n };\n\n less.refreshStyles = loadStyles;\n return less;\n};\n","export default (less, options) => {\n const logLevel_debug = 4;\n const logLevel_info = 3;\n const logLevel_warn = 2;\n const logLevel_error = 1;\n\n // The amount of logging in the javascript console.\n // 3 - Debug, information and errors\n // 2 - Information and errors\n // 1 - Errors\n // 0 - None\n // Defaults to 2\n options.logLevel = typeof options.logLevel !== 'undefined' ? options.logLevel : (options.env === 'development' ? logLevel_info : logLevel_error);\n\n if (!options.loggers) {\n options.loggers = [{\n debug: function(msg) {\n if (options.logLevel >= logLevel_debug) {\n console.log(msg);\n }\n },\n info: function(msg) {\n if (options.logLevel >= logLevel_info) {\n console.log(msg);\n }\n },\n warn: function(msg) {\n if (options.logLevel >= logLevel_warn) {\n console.warn(msg);\n }\n },\n error: function(msg) {\n if (options.logLevel >= logLevel_error) {\n console.error(msg);\n }\n }\n }];\n }\n for (let i = 0; i < options.loggers.length; i++) {\n less.logger.addListener(options.loggers[i]);\n }\n};\n","// Cache system is a bit outdated and could do with work\n\nexport default (window, options, logger) => {\n let cache = null;\n if (options.env !== 'development') {\n try {\n cache = (typeof window.localStorage === 'undefined') ? null : window.localStorage;\n } catch (_) {}\n }\n return {\n setCSS: function(path, lastModified, modifyVars, styles) {\n if (cache) {\n logger.info(`saving ${path} to cache.`);\n try {\n cache.setItem(path, styles);\n cache.setItem(`${path}:timestamp`, lastModified);\n if (modifyVars) {\n cache.setItem(`${path}:vars`, JSON.stringify(modifyVars));\n }\n } catch (e) {\n // TODO - could do with adding more robust error handling\n logger.error(`failed to save \"${path}\" to local storage for caching.`);\n }\n }\n },\n getCSS: function(path, webInfo, modifyVars) {\n const css = cache && cache.getItem(path);\n const timestamp = cache && cache.getItem(`${path}:timestamp`);\n let vars = cache && cache.getItem(`${path}:vars`);\n\n modifyVars = modifyVars || {};\n vars = vars || \"{}\"; // if not set, treat as the JSON representation of an empty object\n\n if (timestamp && webInfo.lastModified &&\n (new Date(webInfo.lastModified).valueOf() ===\n new Date(timestamp).valueOf()) &&\n JSON.stringify(modifyVars) === vars) {\n // Use local copy\n return css;\n }\n }\n };\n};\n","\nimport functionRegistry from './../less/functions/function-registry';\n\nexport default () => {\n function imageSize() {\n throw {\n type: 'Runtime',\n message: 'Image size functions are not supported in browser version of less'\n };\n }\n\n const imageFunctions = {\n 'image-size': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n },\n 'image-width': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n },\n 'image-height': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n }\n };\n\n functionRegistry.addMultiple(imageFunctions);\n};\n"],"names":["extractId","href","replace","addDataAttr","options","tag","opt","dataset","hasOwnProperty","JSON","parse","_","document","styles","sheet","id","title","utils.extractId","oldStyleNode","getElementById","keepOldStyleNode","styleNode","createElement","setAttribute","media","styleSheet","appendChild","createTextNode","childNodes","length","firstChild","nodeValue","head","getElementsByTagName","nextEl","nextSibling","parentNode","insertBefore","removeChild","cssText","e","Error","window","scripts","currentScript","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","__extends","__","this","constructor","prototype","create","__spreadArrays","s","i","il","arguments","r","k","a","j","jl","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgrey","darkgreen","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","grey","green","greenyellow","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgrey","lightgreen","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","m","cm","mm","in","px","pt","pc","duration","ms","angle","rad","Math","PI","deg","grad","turn","colors","unitConversions","parent","visibilityBlocks","undefined","nodeVisible","rootNode","parsed","self","defineProperty","get","fileInfo","getIndex","Node","nodes","set","node","isArray","forEach","_index","_fileInfo","context","strs","genCSS","add","chunk","index","push","isEmpty","join","output","value","visitor","visit","op","precision","numPrecision","Number","toFixed","info","compare","type","numericCompare","Color","rgb","originalForm","match","map","c","parseInt","alpha","split","clamp","v","max","min","toHex","round","toString","luma","g","pow","toCSS","doNotCompress","color","colorFunction","compress","args","fround","indexOf","concat","toHSL","h","l","toRGB","splitcolor","operate","other","_operate","toHSV","toARGB","x","fromKeyword","keyword","key","toLowerCase","slice","Paren","eval","_noSpaceCombinators"," ","|","Combinator","emptyOrWhitespace","trim","spaceOrEmpty","Element","combinator","isVariable","currentFileInfo","visibilityInfo","copyVisibilityInfo","setParent","accept","clone","firstSelector","charAt","ALWAYS","PARENS_DIVISION","PARENS","STRICT_LEGACY","RewriteUrls","getType","payload","call","copy","target","getPrototypeOf","getOwnPropertyNames","getOwnPropertySymbols","reduce","carry","props","includes","newVal","originalObject","includeNonenumerable","propType","propertyIsEnumerable","enumerable","writable","configurable","assignProp","nonenumerable","getLocation","inputStream","n","line","column","copyArray","arr","obj","cloned","prop","defaults","obj1","obj2","newObj","_defaults","defaults_1","assign","copyOptions","opts","strictMath","math","Constants.Math","relativeUrls","rewriteUrls","Constants.RewriteUrls","flattenArray","result","length_1","anonymousFunc","LessError","fileContentMap","currentFilename","filename","message","stack","input","contents","loc","utils.getLocation","col","callLine","lines","found","func","Function","lineAdjust","callExtract","extract","F","error","stylize","str","errorTxt","substr","Selector","elements","extendList","condition","evaldCondition","getElements","mixinElements_","visitArray","createDerived","newSelector","mediaEmpty","els","parseNode","err","imports","createEmptySelectors","el","sels","olen","len","mixinElements","shift","isJustParentSelector","extend","getIsOutput","Value","Keyword","True","False","Anonymous","mapLines","rulesetLike","allowRoot","isRulesetLike","Boolean","MATH","Declaration","name","important","merge","inline","variable","lastRule","prevMath","evaldValue","mathBypass","evalName","importantScope","importantResult","pop","makeImportant","debugInfo","ctx","lineSeparator","dumpLineNumbers","asComment","asMediaQuery","lineNumber","fileName","filenameWithProtocol","test","Comment","isLineComment","getDebugInfo","isSilent","isCompressed","contexts","copyFromOriginal","original","destination","propertiesToCopy","parseCopyProperties","Parse","paths","evalCopyProperties","isPathRelative","path","isPathLocalRelative","Eval","frames","inCalc","mathOn","calcStack","parensStack","rootpath","newPath","normalizePath","segment","segments","reverse","makeRegistry","base","_data","addMultiple","functions","keys","_this","getLocalFunctions","inherit","defaultFunc","value_","error_","reset","Ruleset","selectors","rules","strictImports","_lookups","_variables","_properties","selCnt","selector","hasVariable","hasOnePassingSelector","toParseSelectors","utils.flattenArray","rule","subRule","utils.copyArray","ruleset","originalRuleset","root","firstRoot","allowImports","functionRegistry","globalFunctionRegistry","ctxFrames","unshift","ctxSelectors","evalImports","rsRules","evalFirst","mediaBlockCount","mediaBlocks","filter","splice","resetCache","bubbleSelectors","importRules","matchArgs","matchCondition","lastSelector","_rulesets","variables","hash","vars","name_1","properties","name_2","decl","parseValue","property","lastDeclaration","toParse","transformDeclaration","nodes_1","rulesets","filtRules","isRuleset","prependRule","find","foundMixins","apply","ruleNodes","tabLevel","sep","tabRuleStr","tabSetStr","charsetNodeIndex","importNodeIndex","isCharset","pathCnt","pathSubCnt","currentLastRule","isVisible","joinSelectors","joinSelector","createParenthesis","elementsToPak","originalElement","replacementParen","insideParent","createSelector","containedElement","element","addReplacementIntoPath","beginningPath","addPath","replacedElement","originalSelector","newSelectorPath","newJoinedSelector","parentEl","restOfPath","addAllReplacementsIntoPath","addPaths","mergeElementsOnToSelectors","sel","deriveSelector","deriveFrom","newPaths","replaceParentSelector","inSelector","currentElements","newSelectors","selectorsMultiplied","maybeSelector","hadParentSelector","nestedSelector","replaced","nestedPaths","replacedNewSelectors","concatenated","bind","AtRule","isRooted","outputRuleset","mediaPathBackup","mediaBlocksBackup","mediaPath","_i","ruleCnt","DetachedRuleset","callEval","Unit","numerator","denominator","backupUnit","sort","strictUnits","returnStr","is","unitString","toUpperCase","isLength","RegExp","isSingular","callback","usedUnits","group","mapUnit","groupName","atomicUnit","cancel","counter","count","Dimension","unit","parseFloat","isNaN","toColor","strValue","String","convertTo","unify","conversions","targetUnit","applyUnit","derivedConversions","Operation","operands","isSpaced","isMathOn","Expression","noSpacing","returnValue","inParenthesis","parens","parensInOp","doubleParen","outOfParenthesis","throwAwayComments","functionCaller","evalArgs","item","subNodes","Call","calc","currentMathContext","enterCalc","exitCalc","funcCaller","FunctionCaller","isValid","columnNumber","Variable","evaluating","frame","fun","Property","mergeRules","pluginManager","less","visitors","ToCSSVisitor","_mergeRules","vArr","Attribute","Quoted","content","escaped","quote","variableRegex","propRegex","containsVariables","that","iterativeReplace","regexp","replacementFnc","evaluatedValue","URL","val","isEvald","pathRequiresRewrite","rewritePath","urlArgs","Media","features","evalTop","evalNested","multiMedia","permute","fragment","rest","Import","css","pathValue","getPath","isPlugin","reference","isVariableImport","evalForImport","evalPath","doEval","blocksVisibility","addVisibilityBlock","registry","skip","importedFilename","newImport","JsEvalNode","evaluateJavaScript","expression","evalContext","javascriptEnabled","jsify","toJS","JavaScript","string","Assignment","Condition","negate","lvalue","rvalue","UnicodeDescriptor","Negative","Extend","option","object_id","next_id","parent_ids","allowBefore","allowAfter","findSelfSelectors","selectorElements","selfElements","selfSelectors","VariableCall","detachedRuleset","NamespaceValue","ruleCall","lookups","substring","Definition","params","variadic","arity","optionalParameters","required","evalParams","mixinEnv","evaldArguments","varargs","arg","isNamedFound","argIndex","argsLength","evalCall","_arguments","mixinFrames","allArgsCnt","requiredArgsCnt","MixinCall","mixins","mixin","mixinPath","argValue","f","isRecursive","isOneFound","candidate","defaultResult","noArgumentsFilter","candidates","conditionResult","calcDefGroup","namespace","expand","MixinDefinition","format","newRules","_setVisibilityToReplacement","replacement","msg","_fireEvent","warn","debug","addListener","listener","_listeners","removeListener","logFunction","externalEnvironment","fileManagers","requiredFunctions","propName","environmentFunc","environment","currentDirectory","isSync","logger","getFileManagers","fileManager","AbstractFileManager","lastIndexOf","ext","tryAppendExtension","basePath","laterPath","url","baseUrl","urlDirectories","baseUrlDirectories","urlParts","extractUrlParts","baseUrlParts","diff","hostPart","directories","urlPartsRegex","returner","rawDirectories","rawPath","fileUrl","require","AbstractPluginLoader","pluginOptions","pluginObj","localModule","shortname","FileManager","trySetOptions","use","exports","loader","tree","validatePlugin","minVersion","compareVersion","addPlugin","plugin","setOptions","version","versionToString","aVersion","bVersion","versionString","plugins","printUsage","_visitArgs","visitDeeper","_hasIndexed","_noop","implementation","_implementation","_visitInCache","_visitOutCache","indexNodeTypes","ticker","child","typeIndex","Visitor","nodeTypeIndex","fnName","impl","funcOut","visitArgs","newNode","isReplacing","cnt","nonReplacing","out","evald","flatten","nestedCnt","nestedItem","onSequencerEmpty","variableImports","_onSequencerEmpty","_currentDepth","ImportSequencer","importSequencer","importItem","isReady","tryRun","variableImport","ImportVisitor","importer","finish","_visitor","_importer","_finish","importCount","onceFileDetectionMap","recursionDetector","_sequencer","run","isFinished","visitImport","importNode","inlineCSS","importParent","addVariableImport","processImportNode","evaldImportNode","multiple","importMultiple","tryAppendLessExtension","onImported","sequencedOnImported","addImport","importedAtRoot","fullPath","importVisitor","isOptional","optional","duplicateImport","oldContext","visitDeclaration","declNode","visitDeclarationOut","visitAtRule","atRuleNode","visitAtRuleOut","visitMixinDefinition","mixinDefinitionNode","visitMixinDefinitionOut","visitRuleset","rulesetNode","visitRulesetOut","visitMedia","mediaNode","visitMediaOut","visible","SetTreeVisibilityVisitor","ensureVisibility","ensureInvisibility","allExtendsStack","ExtendFinderVisitor","allExtends","allSelectorsExtendList","extendOnEveryPath","selectorPath","selExtendList","allSelectorsExtend","foundExtends","firstExtendOnThisSelectorPath","ProcessExtendsVisitor","extendFinder","extendIndices","doExtendChaining","newRoot","checkExtendsForNonMatched","indices","hasFoundMatches","extendsList","extendsListTarget","iterationCount","extendIndex","targetExtendIndex","matches","targetExtend","newExtend","extendsToAdd","extendVisitor","findMatch","selfSelector","extendSelector","extendChainCount","selectorOne","selectorTwo","ruleNode","selectorNode","pathIndex","selectorsToAdd","extendedSelectors","haystackSelectorPath","haystackSelectorIndex","hackstackSelector","hackstackElementIndex","haystackElement","targetCombinator","potentialMatch","needleElements","potentialMatches","matched","initialCombinator","isElementValuesEqual","finished","endPathIndex","endPathElementIndex","elementValue1","elementValue2","replacementSelector","matchIndex","firstElement","newElements","currentSelectorPathIndex","currentSelectorPathElementIndex","currentValue","derived","newAllExtends","lastIndex","JoinSelectorVisitor","_context","CSSVisitorUtils","bodyRules","owner","thing","originalRules","containsSilentNonBlockedChild","compiledRulesBody","keepOnlyVisibleChilds","removeVisibilityBlock","hasVisibleSelector","utils","mixinNode","visitExtend","extendNode","visitComment","commentNode","resolveVisibility","visitAtRuleWithBody","visitAtRuleWithoutBody","visitAnonymous","anonymousNode","nodeRules","hasFakeRuleset","getBodyRules","charset","comment","checkValidNodes","isRoot","_compileRulesetPaths","nodeRuleCnt","_removeDuplicateRules","isVisibleRuleset","ruleList","ruleCache","ruleCSS","groups","groupsArr","result_1","space_1","comma_1","MarkVisibleSelectorsVisitor","ExtendVisitor","furthest","furthestPossibleErrorMessage","chunks","current","currentPos","saveStack","parserInput","skipWhitespace","nextChar","oldi","oldj","curr","endIndex","mem","inp","charCodeAt","autoCommentAbsorb","nextNewLine","text","commentStore","nextStarSlash","save","restore","possibleErrorMessage","state","forget","isWhitespace","offset","pos","code","$re","tok","exec","$char","$str","tokLength","$quoted","startChar","currentPosition","$parseUntil","testChar","returnVal","inComment","blockDepth","blockStack","parseGroups","startPos","lastPos","loop","char","expected","peek","peekChar","currentChar","prevChar","getInput","peekNotNumeric","start","chunkInput","failFunction","fail","lastOpening","lastOpeningParen","lastMultiComment","lastMultiCommentEndBrace","chunkerCurrentIndex","currentChunkStartIndex","cc","cc2","level","parenLevel","emitFrom","emitChunk","force","fromCharCode","chunker","end","furthestReachedEnd","furthestChar","Parser","parsers","getParserInput","expect","expectChar","parseList","currentIndex","returnNodes","parser","additionalData","globalVars","modifyVars","ignored","preText","serializeVars","preProcessors","getPreProcessors","process","banner","contentsIgnoredChars","primary","endInfo","processImports","extendRule","definition","declaration","variableCall","entities","atrule","foundSemiColon","mixinLookup","quoted","forceEscaped","isEscaped","customFuncCall","stop","ieAlpha","boolean","if","prevArgs","isSemiColonSeparated","argsComma","argsSemiColon","assignment","literal","dimension","unicodeDescriptor","entity","ch","variableCurly","curly","propertyCurly","colorKeyword","ud","javascript","js","escape","parsedName","inValue","ruleLookups","isRule","getLookup","hasParens","elem","elemIndex","re","isCall","expressionContainsNamed","nameLoop","expressions","hasSep","cond","argInfo","conditions","block","lookupValue","attribute","slashedCombinator","isLess","when","blockRuleset","hasDR","ruleProperty","permissiveValue","anonymousValue","untilTokens","done","testCurrentChar","import","dir","importOptions","mediaFeatures","o","optionName","importOption","mediaFeature","pluginArgs","nonVendorSpecificName","hasIdentifier","hasExpression","hasUnknown","hasBlock","sub","addition","multiplication","operation","operand","needsParens","logical","next","conditionAnd","negatedCondition","parenthesisCondition","atomicCondition","body","me","tryConditionFollowedByParenthesis","delim","simpleProperty","If","trueValue","falseValue","colorFunctions","hsla","origColor","hsl","number","rgba","size","m1_1","m2_1","hue","hsv","hsva","vs","floor","perm","saturation","lightness","hsvhue","hsvsaturation","hsvvalue","luminance","saturate","amount","method","desaturate","lighten","darken","fadein","fadeout","fade","spin","mix","color1","color2","weight","w","w1","w2","greyscale","contrast","dark","light","threshold","t","argb","tint","shade","colorBlend","mode","cb","cs","ar","cr","ab","as","colorBlendModeFunctions","multiply","screen","overlay","softlight","sqrt","hardlight","difference","abs","exclusion","average","negation","getItemsFromNode","_SELF","values","range","step","from","to","stepValue","list","each","rs","iterator","tryEval","Quote","valueName","keyName","indexName","MathHelper","fn","mathFunctions","ceil","sin","cos","atan","asin","acos","mathHelper","fraction","num","minMax","isMin","currentUnified","referenceUnified","unitStatic","unitClone","order","convert","pi","mod","y","percentage","evaluated","encodeURI","pattern","flags","%","token","encodeURIComponent","isa","Type","isunit","isruleset","iscolor","isnumber","isstring","iskeyword","isurl","ispixel","ispercentage","isem","get-unit","colorBlending","fallback","functionThis","data-uri","mimetypeNode","filePathNode","mimetype","filePath","entryPath","fragmentStart","utils.clone","rawBuffer","getFileManager","useBase64","mimeLookup","charsetLookup","fileSync","loadFileSync","buf","encodeBase64","uri","dataUri","svg-gradient","direction","stops","gradientDirectionSvg","position","positionValue","gradientType","rectangleDimension","renderEnv","directionValue","throwArgumentDescriptor","types","evaldRoot","evalEnv","visitorIterator","preEvalVisitors","first","isPreEvalVisitor","isPreVisitor","pm","postProcessors","installedPlugins","pluginCache","Loader","PluginLoader","PluginManager","install","preProcessor","priority","indexToInsertAt","postProcessor","manager","PluginManagerFactory","newFactory","SourceMapOutput","_css","_rootNode","_contentsMap","contentsMap","_contentsIgnoredCharsMap","contentsIgnoredCharsMap","sourceMapFilename","_sourceMapFilename","_outputFilename","outputFilename","sourceMapURL","sourceMapBasepath","_sourceMapBasepath","sourceMapRootpath","_sourceMapRootpath","_outputSourceFiles","outputSourceFiles","_sourceMapGeneratorConstructor","getSourceMapGenerator","_lineNumber","_column","removeBasepath","sourceLines","columns","sourceColumns","inputSource","_sourceMapGenerator","addMapping","generated","source","normalizeFilename","file","sourceRoot","setSourceContent","sourceMapContent","stringify","toJSON","sourceMap","sourceMapOutput","Environment","SourceMapBuilder","sourceMapOutputFilename","sourceMapGenerator","sourceMapFileInline","disableSourcemapAnnotation","sourceMapInputFilename","getCSSAppendage","sourceMapBuilder","ParseTree","transformTree","toCSSOptions","getPostProcessors","getExternalSourceMap","files","rootFilename","parseTree","ImportManager","rootFileInfo","mime","queue","importManager","pluginLoader","fileParsedFunc","importedEqualsRoot","newFileInfo","loadedFile","promise","loadFileCallback","resolvedFilename","pathDiff","isPathAbsolute","alwaysMakePathsAbsolute","newEnv","evalPlugin","syncImport","loadPluginSync","loadPlugin","loadFile","then","render","utils.copyOptions","self_1","Promise","resolve","reject","Render","context_1","pluginManager_1","reUsePluginManager","imports_1","evalResult","fileContent","Functions","initial","data","ctor","api","fileCache","errback","xhr","XMLHttpRequest","async","isFileProtocol","fileAsync","handleResponse","status","responseText","getResponseHeader","overrideMimeType","open","setRequestHeader","send","onreadystatechange","readyState","location","useFileCache","lessText","webInfo","lastModified","Date","doXHR","log","_super","fulfill","catch","rootHref","errorReporting","errors","errorline","classname","logLevel","errorConsole","timer","filenameNoPath","className","innerHTML","browser","style","env","setInterval","replaceChild","clearInterval","errorHTML","remove","removeErrorHTML","depends","lint","insecure","protocol","poll","hostname","port","onReady","addDefaultOptions","LESS_PLUGINS","lessRoot","FM","addFileManager","loggers","console","LogListener","ErrorReporting","cache","localStorage","setCSS","setItem","getCSS","getItem","timestamp","valueOf","Cache","imageSize","imageFunctions","image-size","image-width","image-height","ImageSize","typePattern","thisArg","curryArgs","loadStyles","instanceOptions","loadStyleSheet","reload","remaining","local","loadInitialFileCallback","loadStyleSheets","sheets","watch","watchMode","watchTimer","clearFileCache","unwatch","registerStylesheetsImmediately","links","rel","registerStylesheets","record","refresh","startTime","endTime","totalMilliseconds","remainingSheets","refreshStyles","resolveOrReject","pageLoadFinished"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"less.min.js","sources":["../src/less-browser/utils.js","../src/less-browser/browser.js","../src/less/logger.js","../src/less/environment/environment.js","../src/less/data/colors.js","../src/less/data/unit-conversions.js","../src/less/data/index.js","../src/less/tree/node.js","../src/less/tree/color.js","../src/less/tree/paren.js","../src/less/tree/combinator.js","../src/less/tree/element.js","../src/less/constants.js","../node_modules/is-what/dist/index.esm.js","../node_modules/copy-anything/dist/index.esm.js","../src/less/utils.js","../src/less/less-error.js","../src/less/tree/selector.js","../src/less/tree/value.js","../src/less/tree/keyword.js","../src/less/tree/anonymous.js","../src/less/tree/declaration.js","../src/less/tree/debug-info.js","../src/less/tree/comment.js","../src/less/contexts.js","../src/less/functions/function-registry.js","../src/less/functions/default.js","../src/less/tree/ruleset.js","../src/less/tree/atrule.js","../src/less/tree/detached-ruleset.js","../src/less/tree/unit.js","../src/less/tree/dimension.js","../src/less/tree/operation.js","../src/less/tree/expression.js","../src/less/functions/function-caller.js","../node_modules/tslib/tslib.es6.js","../src/less/tree/call.js","../src/less/tree/variable.js","../src/less/tree/property.js","../src/less/tree/attribute.js","../src/less/tree/quoted.js","../src/less/tree/url.js","../src/less/tree/media.js","../src/less/tree/import.js","../src/less/tree/js-eval-node.js","../src/less/tree/javascript.js","../src/less/tree/assignment.js","../src/less/tree/condition.js","../src/less/tree/unicode-descriptor.js","../src/less/tree/negative.js","../src/less/tree/extend.js","../src/less/tree/variable-call.js","../src/less/tree/namespace-value.js","../src/less/tree/mixin-definition.js","../src/less/tree/mixin-call.js","../src/less/tree/index.js","../src/less/environment/abstract-file-manager.js","../src/less/environment/abstract-plugin-loader.js","../src/less/visitors/visitor.js","../src/less/visitors/import-sequencer.js","../src/less/visitors/import-visitor.js","../src/less/visitors/set-tree-visibility-visitor.js","../src/less/visitors/extend-visitor.js","../src/less/visitors/join-selector-visitor.js","../src/less/visitors/to-css-visitor.js","../src/less/visitors/index.js","../src/less/parser/parser-input.js","../src/less/parser/chunker.js","../src/less/parser/parser.js","../src/less/functions/boolean.js","../src/less/functions/color.js","../src/less/functions/color-blending.js","../src/less/functions/list.js","../src/less/functions/math-helper.js","../src/less/functions/math.js","../src/less/functions/number.js","../src/less/functions/string.js","../src/less/functions/types.js","../src/less/functions/index.js","../src/less/functions/data-uri.js","../src/less/functions/svg.js","../src/less/transform-tree.js","../src/less/plugin-manager.js","../node_modules/parse-node-version/index.js","../src/less-browser/file-manager.js","../src/less/index.js","../src/less/parse-tree.js","../src/less/source-map-builder.js","../src/less/source-map-output.js","../src/less/import-manager.js","../src/less/render.js","../src/less/parse.js","../src/less-browser/plugin-loader.js","../src/less-browser/error-reporting.js","../src/less-browser/bootstrap.js","../src/less/default-options.js","../src/less-browser/add-default-options.js","../src/less-browser/index.js","../src/less-browser/log-listener.js","../src/less-browser/cache.js","../src/less-browser/image-size.js"],"sourcesContent":["\nexport function extractId(href) {\n return href.replace(/^[a-z-]+:\\/+?[^\\/]+/, '') // Remove protocol & domain\n .replace(/[\\?\\&]livereload=\\w+/, '') // Remove LiveReload cachebuster\n .replace(/^\\//, '') // Remove root /\n .replace(/\\.[a-zA-Z]+$/, '') // Remove simple extension\n .replace(/[^\\.\\w-]+/g, '-') // Replace illegal characters\n .replace(/\\./g, ':'); // Replace dots with colons(for valid id)\n}\n\nexport function addDataAttr(options, tag) {\n for (const opt in tag.dataset) {\n if (tag.dataset.hasOwnProperty(opt)) {\n if (opt === 'env' || opt === 'dumpLineNumbers' || opt === 'rootpath' || opt === 'errorReporting') {\n options[opt] = tag.dataset[opt];\n } else {\n try {\n options[opt] = JSON.parse(tag.dataset[opt]);\n }\n catch (_) {}\n }\n }\n }\n}\n","import * as utils from './utils';\n\nexport default {\n createCSS: function (document, styles, sheet) {\n // Strip the query-string\n const href = sheet.href || '';\n\n // If there is no title set, use the filename, minus the extension\n const id = `less:${sheet.title || utils.extractId(href)}`;\n\n // If this has already been inserted into the DOM, we may need to replace it\n const oldStyleNode = document.getElementById(id);\n let keepOldStyleNode = false;\n\n // Create a new stylesheet node for insertion or (if necessary) replacement\n const styleNode = document.createElement('style');\n styleNode.setAttribute('type', 'text/css');\n if (sheet.media) {\n styleNode.setAttribute('media', sheet.media);\n }\n styleNode.id = id;\n\n if (!styleNode.styleSheet) {\n styleNode.appendChild(document.createTextNode(styles));\n\n // If new contents match contents of oldStyleNode, don't replace oldStyleNode\n keepOldStyleNode = (oldStyleNode !== null && oldStyleNode.childNodes.length > 0 && styleNode.childNodes.length > 0 &&\n oldStyleNode.firstChild.nodeValue === styleNode.firstChild.nodeValue);\n }\n\n const head = document.getElementsByTagName('head')[0];\n\n // If there is no oldStyleNode, just append; otherwise, only append if we need\n // to replace oldStyleNode with an updated stylesheet\n if (oldStyleNode === null || keepOldStyleNode === false) {\n const nextEl = sheet && sheet.nextSibling || null;\n if (nextEl) {\n nextEl.parentNode.insertBefore(styleNode, nextEl);\n } else {\n head.appendChild(styleNode);\n }\n }\n if (oldStyleNode && keepOldStyleNode === false) {\n oldStyleNode.parentNode.removeChild(oldStyleNode);\n }\n\n // For IE.\n // This needs to happen *after* the style element is added to the DOM, otherwise IE 7 and 8 may crash.\n // See http://social.msdn.microsoft.com/Forums/en-US/7e081b65-878a-4c22-8e68-c10d39c2ed32/internet-explorer-crashes-appending-style-element-to-head\n if (styleNode.styleSheet) {\n try {\n styleNode.styleSheet.cssText = styles;\n } catch (e) {\n throw new Error('Couldn\\'t reassign styleSheet.cssText.');\n }\n }\n },\n currentScript: function(window) {\n const document = window.document;\n return document.currentScript || (() => {\n const scripts = document.getElementsByTagName('script');\n return scripts[scripts.length - 1];\n })();\n }\n};\n","export default {\n error: function(msg) {\n this._fireEvent('error', msg);\n },\n warn: function(msg) {\n this._fireEvent('warn', msg);\n },\n info: function(msg) {\n this._fireEvent('info', msg);\n },\n debug: function(msg) {\n this._fireEvent('debug', msg);\n },\n addListener: function(listener) {\n this._listeners.push(listener);\n },\n removeListener: function(listener) {\n for (let i = 0; i < this._listeners.length; i++) {\n if (this._listeners[i] === listener) {\n this._listeners.splice(i, 1);\n return;\n }\n }\n },\n _fireEvent: function(type, msg) {\n for (let i = 0; i < this._listeners.length; i++) {\n const logFunction = this._listeners[i][type];\n if (logFunction) {\n logFunction(msg);\n }\n }\n },\n _listeners: []\n};\n","/**\n * @todo Document why this abstraction exists, and the relationship between\n * environment, file managers, and plugin manager\n */\n\nimport logger from '../logger';\n\nclass Environment {\n constructor(externalEnvironment, fileManagers) {\n this.fileManagers = fileManagers || [];\n externalEnvironment = externalEnvironment || {};\n\n const optionalFunctions = ['encodeBase64', 'mimeLookup', 'charsetLookup', 'getSourceMapGenerator'];\n const requiredFunctions = [];\n const functions = requiredFunctions.concat(optionalFunctions);\n\n for (let i = 0; i < functions.length; i++) {\n const propName = functions[i];\n const environmentFunc = externalEnvironment[propName];\n if (environmentFunc) {\n this[propName] = environmentFunc.bind(externalEnvironment);\n } else if (i < requiredFunctions.length) {\n this.warn(`missing required function in environment - ${propName}`);\n }\n }\n }\n\n getFileManager(filename, currentDirectory, options, environment, isSync) {\n\n if (!filename) {\n logger.warn('getFileManager called with no filename.. Please report this issue. continuing.');\n }\n if (currentDirectory == null) {\n logger.warn('getFileManager called with null directory.. Please report this issue. continuing.');\n }\n\n let fileManagers = this.fileManagers;\n if (options.pluginManager) {\n fileManagers = [].concat(fileManagers).concat(options.pluginManager.getFileManagers());\n }\n for (let i = fileManagers.length - 1; i >= 0 ; i--) {\n const fileManager = fileManagers[i];\n if (fileManager[isSync ? 'supportsSync' : 'supports'](filename, currentDirectory, options, environment)) {\n return fileManager;\n }\n }\n return null;\n }\n\n addFileManager(fileManager) {\n this.fileManagers.push(fileManager);\n }\n\n clearFileManagers() {\n this.fileManagers = [];\n }\n}\n\nexport default Environment;\n","export default {\n 'aliceblue':'#f0f8ff',\n 'antiquewhite':'#faebd7',\n 'aqua':'#00ffff',\n 'aquamarine':'#7fffd4',\n 'azure':'#f0ffff',\n 'beige':'#f5f5dc',\n 'bisque':'#ffe4c4',\n 'black':'#000000',\n 'blanchedalmond':'#ffebcd',\n 'blue':'#0000ff',\n 'blueviolet':'#8a2be2',\n 'brown':'#a52a2a',\n 'burlywood':'#deb887',\n 'cadetblue':'#5f9ea0',\n 'chartreuse':'#7fff00',\n 'chocolate':'#d2691e',\n 'coral':'#ff7f50',\n 'cornflowerblue':'#6495ed',\n 'cornsilk':'#fff8dc',\n 'crimson':'#dc143c',\n 'cyan':'#00ffff',\n 'darkblue':'#00008b',\n 'darkcyan':'#008b8b',\n 'darkgoldenrod':'#b8860b',\n 'darkgray':'#a9a9a9',\n 'darkgrey':'#a9a9a9',\n 'darkgreen':'#006400',\n 'darkkhaki':'#bdb76b',\n 'darkmagenta':'#8b008b',\n 'darkolivegreen':'#556b2f',\n 'darkorange':'#ff8c00',\n 'darkorchid':'#9932cc',\n 'darkred':'#8b0000',\n 'darksalmon':'#e9967a',\n 'darkseagreen':'#8fbc8f',\n 'darkslateblue':'#483d8b',\n 'darkslategray':'#2f4f4f',\n 'darkslategrey':'#2f4f4f',\n 'darkturquoise':'#00ced1',\n 'darkviolet':'#9400d3',\n 'deeppink':'#ff1493',\n 'deepskyblue':'#00bfff',\n 'dimgray':'#696969',\n 'dimgrey':'#696969',\n 'dodgerblue':'#1e90ff',\n 'firebrick':'#b22222',\n 'floralwhite':'#fffaf0',\n 'forestgreen':'#228b22',\n 'fuchsia':'#ff00ff',\n 'gainsboro':'#dcdcdc',\n 'ghostwhite':'#f8f8ff',\n 'gold':'#ffd700',\n 'goldenrod':'#daa520',\n 'gray':'#808080',\n 'grey':'#808080',\n 'green':'#008000',\n 'greenyellow':'#adff2f',\n 'honeydew':'#f0fff0',\n 'hotpink':'#ff69b4',\n 'indianred':'#cd5c5c',\n 'indigo':'#4b0082',\n 'ivory':'#fffff0',\n 'khaki':'#f0e68c',\n 'lavender':'#e6e6fa',\n 'lavenderblush':'#fff0f5',\n 'lawngreen':'#7cfc00',\n 'lemonchiffon':'#fffacd',\n 'lightblue':'#add8e6',\n 'lightcoral':'#f08080',\n 'lightcyan':'#e0ffff',\n 'lightgoldenrodyellow':'#fafad2',\n 'lightgray':'#d3d3d3',\n 'lightgrey':'#d3d3d3',\n 'lightgreen':'#90ee90',\n 'lightpink':'#ffb6c1',\n 'lightsalmon':'#ffa07a',\n 'lightseagreen':'#20b2aa',\n 'lightskyblue':'#87cefa',\n 'lightslategray':'#778899',\n 'lightslategrey':'#778899',\n 'lightsteelblue':'#b0c4de',\n 'lightyellow':'#ffffe0',\n 'lime':'#00ff00',\n 'limegreen':'#32cd32',\n 'linen':'#faf0e6',\n 'magenta':'#ff00ff',\n 'maroon':'#800000',\n 'mediumaquamarine':'#66cdaa',\n 'mediumblue':'#0000cd',\n 'mediumorchid':'#ba55d3',\n 'mediumpurple':'#9370d8',\n 'mediumseagreen':'#3cb371',\n 'mediumslateblue':'#7b68ee',\n 'mediumspringgreen':'#00fa9a',\n 'mediumturquoise':'#48d1cc',\n 'mediumvioletred':'#c71585',\n 'midnightblue':'#191970',\n 'mintcream':'#f5fffa',\n 'mistyrose':'#ffe4e1',\n 'moccasin':'#ffe4b5',\n 'navajowhite':'#ffdead',\n 'navy':'#000080',\n 'oldlace':'#fdf5e6',\n 'olive':'#808000',\n 'olivedrab':'#6b8e23',\n 'orange':'#ffa500',\n 'orangered':'#ff4500',\n 'orchid':'#da70d6',\n 'palegoldenrod':'#eee8aa',\n 'palegreen':'#98fb98',\n 'paleturquoise':'#afeeee',\n 'palevioletred':'#d87093',\n 'papayawhip':'#ffefd5',\n 'peachpuff':'#ffdab9',\n 'peru':'#cd853f',\n 'pink':'#ffc0cb',\n 'plum':'#dda0dd',\n 'powderblue':'#b0e0e6',\n 'purple':'#800080',\n 'rebeccapurple':'#663399',\n 'red':'#ff0000',\n 'rosybrown':'#bc8f8f',\n 'royalblue':'#4169e1',\n 'saddlebrown':'#8b4513',\n 'salmon':'#fa8072',\n 'sandybrown':'#f4a460',\n 'seagreen':'#2e8b57',\n 'seashell':'#fff5ee',\n 'sienna':'#a0522d',\n 'silver':'#c0c0c0',\n 'skyblue':'#87ceeb',\n 'slateblue':'#6a5acd',\n 'slategray':'#708090',\n 'slategrey':'#708090',\n 'snow':'#fffafa',\n 'springgreen':'#00ff7f',\n 'steelblue':'#4682b4',\n 'tan':'#d2b48c',\n 'teal':'#008080',\n 'thistle':'#d8bfd8',\n 'tomato':'#ff6347',\n 'turquoise':'#40e0d0',\n 'violet':'#ee82ee',\n 'wheat':'#f5deb3',\n 'white':'#ffffff',\n 'whitesmoke':'#f5f5f5',\n 'yellow':'#ffff00',\n 'yellowgreen':'#9acd32'\n};","export default {\n length: {\n 'm': 1,\n 'cm': 0.01,\n 'mm': 0.001,\n 'in': 0.0254,\n 'px': 0.0254 / 96,\n 'pt': 0.0254 / 72,\n 'pc': 0.0254 / 72 * 12\n },\n duration: {\n 's': 1,\n 'ms': 0.001\n },\n angle: {\n 'rad': 1 / (2 * Math.PI),\n 'deg': 1 / 360,\n 'grad': 1 / 400,\n 'turn': 1\n }\n};","import colors from './colors';\nimport unitConversions from './unit-conversions';\n\nexport default { colors, unitConversions };\n","/**\n * The reason why Node is a class and other nodes simply do not extend\n * from Node (since we're transpiling) is due to this issue:\n * \n * https://github.com/less/less.js/issues/3434\n */\nclass Node {\n constructor() {\n this.parent = null;\n this.visibilityBlocks = undefined;\n this.nodeVisible = undefined;\n this.rootNode = null;\n this.parsed = null;\n\n const self = this;\n Object.defineProperty(this, 'currentFileInfo', {\n get: function() { return self.fileInfo(); }\n });\n Object.defineProperty(this, 'index', {\n get: function() { return self.getIndex(); }\n });\n\n }\n\n setParent(nodes, parent) {\n function set(node) {\n if (node && node instanceof Node) {\n node.parent = parent;\n }\n }\n if (Array.isArray(nodes)) {\n nodes.forEach(set);\n }\n else {\n set(nodes);\n }\n }\n\n getIndex() {\n return this._index || (this.parent && this.parent.getIndex()) || 0;\n }\n\n fileInfo() {\n return this._fileInfo || (this.parent && this.parent.fileInfo()) || {};\n }\n\n isRulesetLike() { return false; }\n\n toCSS(context) {\n const strs = [];\n this.genCSS(context, {\n add: function(chunk, fileInfo, index) {\n strs.push(chunk);\n },\n isEmpty: function () {\n return strs.length === 0;\n }\n });\n return strs.join('');\n }\n\n genCSS(context, output) {\n output.add(this.value);\n }\n\n accept(visitor) {\n this.value = visitor.visit(this.value);\n }\n\n eval() { return this; }\n\n _operate(context, op, a, b) {\n switch (op) {\n case '+': return a + b;\n case '-': return a - b;\n case '*': return a * b;\n case '/': return a / b;\n }\n }\n\n fround(context, value) {\n const precision = context && context.numPrecision;\n // add \"epsilon\" to ensure numbers like 1.000000005 (represented as 1.000000004999...) are properly rounded:\n return (precision) ? Number((value + 2e-16).toFixed(precision)) : value;\n }\n\n static compare(a, b) {\n /* returns:\n -1: a < b\n 0: a = b\n 1: a > b\n and *any* other value for a != b (e.g. undefined, NaN, -2 etc.) */\n\n if ((a.compare) &&\n // for \"symmetric results\" force toCSS-based comparison\n // of Quoted or Anonymous if either value is one of those\n !(b.type === 'Quoted' || b.type === 'Anonymous')) {\n return a.compare(b);\n } else if (b.compare) {\n return -b.compare(a);\n } else if (a.type !== b.type) {\n return undefined;\n }\n\n a = a.value;\n b = b.value;\n if (!Array.isArray(a)) {\n return a === b ? 0 : undefined;\n }\n if (a.length !== b.length) {\n return undefined;\n }\n for (let i = 0; i < a.length; i++) {\n if (Node.compare(a[i], b[i]) !== 0) {\n return undefined;\n }\n }\n return 0;\n }\n\n static numericCompare(a, b) {\n return a < b ? -1\n : a === b ? 0\n : a > b ? 1 : undefined;\n }\n\n // Returns true if this node represents root of ast imported by reference\n blocksVisibility() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n return this.visibilityBlocks !== 0;\n }\n\n addVisibilityBlock() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n this.visibilityBlocks = this.visibilityBlocks + 1;\n }\n\n removeVisibilityBlock() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n this.visibilityBlocks = this.visibilityBlocks - 1;\n }\n\n // Turns on node visibility - if called node will be shown in output regardless\n // of whether it comes from import by reference or not\n ensureVisibility() {\n this.nodeVisible = true;\n }\n\n // Turns off node visibility - if called node will NOT be shown in output regardless\n // of whether it comes from import by reference or not\n ensureInvisibility() {\n this.nodeVisible = false;\n }\n\n // return values:\n // false - the node must not be visible\n // true - the node must be visible\n // undefined or null - the node has the same visibility as its parent\n isVisible() {\n return this.nodeVisible;\n }\n\n visibilityInfo() {\n return {\n visibilityBlocks: this.visibilityBlocks,\n nodeVisible: this.nodeVisible\n };\n }\n\n copyVisibilityInfo(info) {\n if (!info) {\n return;\n }\n this.visibilityBlocks = info.visibilityBlocks;\n this.nodeVisible = info.nodeVisible;\n }\n}\n\nexport default Node;\n","import Node from './node';\nimport colors from '../data/colors';\n\n//\n// RGB Colors - #ff0014, #eee\n//\nconst Color = function(rgb, a, originalForm) {\n const self = this;\n //\n // The end goal here, is to parse the arguments\n // into an integer triplet, such as `128, 255, 0`\n //\n // This facilitates operations and conversions.\n //\n if (Array.isArray(rgb)) {\n this.rgb = rgb;\n } else if (rgb.length >= 6) {\n this.rgb = [];\n rgb.match(/.{2}/g).map(function (c, i) {\n if (i < 3) {\n self.rgb.push(parseInt(c, 16));\n } else {\n self.alpha = (parseInt(c, 16)) / 255;\n }\n });\n } else {\n this.rgb = [];\n rgb.split('').map(function (c, i) {\n if (i < 3) {\n self.rgb.push(parseInt(c + c, 16));\n } else {\n self.alpha = (parseInt(c + c, 16)) / 255;\n }\n });\n }\n this.alpha = this.alpha || (typeof a === 'number' ? a : 1);\n if (typeof originalForm !== 'undefined') {\n this.value = originalForm;\n }\n}\n\nColor.prototype = Object.assign(new Node(), {\n type: 'Color',\n\n luma() {\n let r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255;\n\n r = (r <= 0.03928) ? r / 12.92 : Math.pow(((r + 0.055) / 1.055), 2.4);\n g = (g <= 0.03928) ? g / 12.92 : Math.pow(((g + 0.055) / 1.055), 2.4);\n b = (b <= 0.03928) ? b / 12.92 : Math.pow(((b + 0.055) / 1.055), 2.4);\n\n return 0.2126 * r + 0.7152 * g + 0.0722 * b;\n },\n\n genCSS(context, output) {\n output.add(this.toCSS(context));\n },\n\n toCSS(context, doNotCompress) {\n const compress = context && context.compress && !doNotCompress;\n let color;\n let alpha;\n let colorFunction;\n let args = [];\n\n // `value` is set if this color was originally\n // converted from a named color string so we need\n // to respect this and try to output named color too.\n alpha = this.fround(context, this.alpha);\n\n if (this.value) {\n if (this.value.indexOf('rgb') === 0) {\n if (alpha < 1) {\n colorFunction = 'rgba';\n }\n } else if (this.value.indexOf('hsl') === 0) {\n if (alpha < 1) {\n colorFunction = 'hsla';\n } else {\n colorFunction = 'hsl';\n }\n } else {\n return this.value;\n }\n } else {\n if (alpha < 1) {\n colorFunction = 'rgba';\n }\n }\n\n switch (colorFunction) {\n case 'rgba':\n args = this.rgb.map(function (c) {\n return clamp(Math.round(c), 255);\n }).concat(clamp(alpha, 1));\n break;\n case 'hsla':\n args.push(clamp(alpha, 1));\n case 'hsl':\n color = this.toHSL();\n args = [\n this.fround(context, color.h),\n `${this.fround(context, color.s * 100)}%`,\n `${this.fround(context, color.l * 100)}%`\n ].concat(args);\n }\n\n if (colorFunction) {\n // Values are capped between `0` and `255`, rounded and zero-padded.\n return `${colorFunction}(${args.join(`,${compress ? '' : ' '}`)})`;\n }\n\n color = this.toRGB();\n\n if (compress) {\n const splitcolor = color.split('');\n\n // Convert color to short format\n if (splitcolor[1] === splitcolor[2] && splitcolor[3] === splitcolor[4] && splitcolor[5] === splitcolor[6]) {\n color = `#${splitcolor[1]}${splitcolor[3]}${splitcolor[5]}`;\n }\n }\n\n return color;\n },\n\n //\n // Operations have to be done per-channel, if not,\n // channels will spill onto each other. Once we have\n // our result, in the form of an integer triplet,\n // we create a new Color node to hold the result.\n //\n operate(context, op, other) {\n const rgb = new Array(3);\n const alpha = this.alpha * (1 - other.alpha) + other.alpha;\n for (let c = 0; c < 3; c++) {\n rgb[c] = this._operate(context, op, this.rgb[c], other.rgb[c]);\n }\n return new Color(rgb, alpha);\n },\n\n toRGB() {\n return toHex(this.rgb);\n },\n\n toHSL() {\n const r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255, a = this.alpha;\n\n const max = Math.max(r, g, b), min = Math.min(r, g, b);\n let h;\n let s;\n const l = (max + min) / 2;\n const d = max - min;\n\n if (max === min) {\n h = s = 0;\n } else {\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n\n switch (max) {\n case r: h = (g - b) / d + (g < b ? 6 : 0); break;\n case g: h = (b - r) / d + 2; break;\n case b: h = (r - g) / d + 4; break;\n }\n h /= 6;\n }\n return { h: h * 360, s, l, a };\n },\n\n // Adapted from http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript\n toHSV() {\n const r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255, a = this.alpha;\n\n const max = Math.max(r, g, b), min = Math.min(r, g, b);\n let h;\n let s;\n const v = max;\n\n const d = max - min;\n if (max === 0) {\n s = 0;\n } else {\n s = d / max;\n }\n\n if (max === min) {\n h = 0;\n } else {\n switch (max) {\n case r: h = (g - b) / d + (g < b ? 6 : 0); break;\n case g: h = (b - r) / d + 2; break;\n case b: h = (r - g) / d + 4; break;\n }\n h /= 6;\n }\n return { h: h * 360, s, v, a };\n },\n\n toARGB() {\n return toHex([this.alpha * 255].concat(this.rgb));\n },\n\n compare(x) {\n return (x.rgb &&\n x.rgb[0] === this.rgb[0] &&\n x.rgb[1] === this.rgb[1] &&\n x.rgb[2] === this.rgb[2] &&\n x.alpha === this.alpha) ? 0 : undefined;\n }\n});\n\nColor.fromKeyword = function(keyword) {\n let c;\n const key = keyword.toLowerCase();\n if (colors.hasOwnProperty(key)) {\n c = new Color(colors[key].slice(1));\n }\n else if (key === 'transparent') {\n c = new Color([0, 0, 0], 0);\n }\n\n if (c) {\n c.value = keyword;\n return c;\n }\n};\n\nfunction clamp(v, max) {\n return Math.min(Math.max(v, 0), max);\n}\n\nfunction toHex(v) {\n return `#${v.map(function (c) {\n c = clamp(Math.round(c), 255);\n return (c < 16 ? '0' : '') + c.toString(16);\n }).join('')}`;\n}\n\nexport default Color;\n","import Node from './node';\n\nconst Paren = function(node) {\n this.value = node;\n};\n\nParen.prototype = Object.assign(new Node(), {\n type: 'Paren',\n\n genCSS(context, output) {\n output.add('(');\n this.value.genCSS(context, output);\n output.add(')');\n },\n\n eval(context) {\n return new Paren(this.value.eval(context));\n }\n});\n\nexport default Paren;\n","import Node from './node';\nconst _noSpaceCombinators = {\n '': true,\n ' ': true,\n '|': true\n};\n\nconst Combinator = function(value) {\n if (value === ' ') {\n this.value = ' ';\n this.emptyOrWhitespace = true;\n } else {\n this.value = value ? value.trim() : '';\n this.emptyOrWhitespace = this.value === '';\n }\n}\n\nCombinator.prototype = Object.assign(new Node(), {\n type: 'Combinator',\n\n genCSS(context, output) {\n const spaceOrEmpty = (context.compress || _noSpaceCombinators[this.value]) ? '' : ' ';\n output.add(spaceOrEmpty + this.value + spaceOrEmpty);\n }\n});\n\nexport default Combinator;\n","import Node from './node';\nimport Paren from './paren';\nimport Combinator from './combinator';\n\nconst Element = function(combinator, value, isVariable, index, currentFileInfo, visibilityInfo) {\n this.combinator = combinator instanceof Combinator ?\n combinator : new Combinator(combinator);\n\n if (typeof value === 'string') {\n this.value = value.trim();\n } else if (value) {\n this.value = value;\n } else {\n this.value = '';\n }\n this.isVariable = isVariable;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.combinator, this);\n}\n\nElement.prototype = Object.assign(new Node(), {\n type: 'Element',\n\n accept(visitor) {\n const value = this.value;\n this.combinator = visitor.visit(this.combinator);\n if (typeof value === 'object') {\n this.value = visitor.visit(value);\n }\n },\n\n eval(context) {\n return new Element(this.combinator,\n this.value.eval ? this.value.eval(context) : this.value,\n this.isVariable,\n this.getIndex(),\n this.fileInfo(), this.visibilityInfo());\n },\n\n clone() {\n return new Element(this.combinator,\n this.value,\n this.isVariable,\n this.getIndex(),\n this.fileInfo(), this.visibilityInfo());\n },\n\n genCSS(context, output) {\n output.add(this.toCSS(context), this.fileInfo(), this.getIndex());\n },\n\n toCSS(context) {\n context = context || {};\n let value = this.value;\n const firstSelector = context.firstSelector;\n if (value instanceof Paren) {\n // selector in parens should not be affected by outer selector\n // flags (breaks only interpolated selectors - see #1973)\n context.firstSelector = true;\n }\n value = value.toCSS ? value.toCSS(context) : value;\n context.firstSelector = firstSelector;\n if (value === '' && this.combinator.value.charAt(0) === '&') {\n return '';\n } else {\n return this.combinator.toCSS(context) + value;\n }\n }\n});\n\nexport default Element;\n","\nexport const Math = {\n ALWAYS: 0,\n PARENS_DIVISION: 1,\n PARENS: 2\n // removed - STRICT_LEGACY: 3\n};\n\nexport const RewriteUrls = {\n OFF: 0,\n LOCAL: 1,\n ALL: 2\n};","/**\r\n * Returns the object type of the given payload\r\n *\r\n * @param {*} payload\r\n * @returns {string}\r\n */\r\nfunction getType(payload) {\r\n return Object.prototype.toString.call(payload).slice(8, -1);\r\n}\r\n/**\r\n * Returns whether the payload is undefined\r\n *\r\n * @param {*} payload\r\n * @returns {payload is undefined}\r\n */\r\nfunction isUndefined(payload) {\r\n return getType(payload) === 'Undefined';\r\n}\r\n/**\r\n * Returns whether the payload is null\r\n *\r\n * @param {*} payload\r\n * @returns {payload is null}\r\n */\r\nfunction isNull(payload) {\r\n return getType(payload) === 'Null';\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isPlainObject(payload) {\r\n if (getType(payload) !== 'Object')\r\n return false;\r\n return payload.constructor === Object && Object.getPrototypeOf(payload) === Object.prototype;\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isObject(payload) {\r\n return isPlainObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a an empty object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is { [K in any]: never }}\r\n */\r\nfunction isEmptyObject(payload) {\r\n return isPlainObject(payload) && Object.keys(payload).length === 0;\r\n}\r\n/**\r\n * Returns whether the payload is an any kind of object (including special classes or objects with different prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isAnyObject(payload) {\r\n return getType(payload) === 'Object';\r\n}\r\n/**\r\n * Returns whether the payload is an object like a type passed in < >\r\n *\r\n * Usage: isObjectLike<{id: any}>(payload) // will make sure it's an object and has an `id` prop.\r\n *\r\n * @template T this must be passed in < >\r\n * @param {*} payload\r\n * @returns {payload is T}\r\n */\r\nfunction isObjectLike(payload) {\r\n return isAnyObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a function (regular or async)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is AnyFunction}\r\n */\r\nfunction isFunction(payload) {\r\n return typeof payload === \"function\";\r\n}\r\n/**\r\n * Returns whether the payload is an array\r\n *\r\n * @param {any} payload\r\n * @returns {payload is any[]}\r\n */\r\nfunction isArray(payload) {\r\n return getType(payload) === 'Array';\r\n}\r\n/**\r\n * Returns whether the payload is a an array with at least 1 item\r\n *\r\n * @param {*} payload\r\n * @returns {payload is any[]}\r\n */\r\nfunction isFullArray(payload) {\r\n return isArray(payload) && payload.length > 0;\r\n}\r\n/**\r\n * Returns whether the payload is a an empty array\r\n *\r\n * @param {*} payload\r\n * @returns {payload is []}\r\n */\r\nfunction isEmptyArray(payload) {\r\n return isArray(payload) && payload.length === 0;\r\n}\r\n/**\r\n * Returns whether the payload is a string\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isString(payload) {\r\n return getType(payload) === 'String';\r\n}\r\n/**\r\n * Returns whether the payload is a string, BUT returns false for ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isFullString(payload) {\r\n return isString(payload) && payload !== '';\r\n}\r\n/**\r\n * Returns whether the payload is ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isEmptyString(payload) {\r\n return payload === '';\r\n}\r\n/**\r\n * Returns whether the payload is a number (but not NaN)\r\n *\r\n * This will return `false` for `NaN`!!\r\n *\r\n * @param {*} payload\r\n * @returns {payload is number}\r\n */\r\nfunction isNumber(payload) {\r\n return getType(payload) === 'Number' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a boolean\r\n *\r\n * @param {*} payload\r\n * @returns {payload is boolean}\r\n */\r\nfunction isBoolean(payload) {\r\n return getType(payload) === 'Boolean';\r\n}\r\n/**\r\n * Returns whether the payload is a regular expression (RegExp)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is RegExp}\r\n */\r\nfunction isRegExp(payload) {\r\n return getType(payload) === 'RegExp';\r\n}\r\n/**\r\n * Returns whether the payload is a Map\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Map}\r\n */\r\nfunction isMap(payload) {\r\n return getType(payload) === 'Map';\r\n}\r\n/**\r\n * Returns whether the payload is a WeakMap\r\n *\r\n * @param {*} payload\r\n * @returns {payload is WeakMap}\r\n */\r\nfunction isWeakMap(payload) {\r\n return getType(payload) === 'WeakMap';\r\n}\r\n/**\r\n * Returns whether the payload is a Set\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Set}\r\n */\r\nfunction isSet(payload) {\r\n return getType(payload) === 'Set';\r\n}\r\n/**\r\n * Returns whether the payload is a WeakSet\r\n *\r\n * @param {*} payload\r\n * @returns {payload is WeakSet}\r\n */\r\nfunction isWeakSet(payload) {\r\n return getType(payload) === 'WeakSet';\r\n}\r\n/**\r\n * Returns whether the payload is a Symbol\r\n *\r\n * @param {*} payload\r\n * @returns {payload is symbol}\r\n */\r\nfunction isSymbol(payload) {\r\n return getType(payload) === 'Symbol';\r\n}\r\n/**\r\n * Returns whether the payload is a Date, and that the date is valid\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Date}\r\n */\r\nfunction isDate(payload) {\r\n return getType(payload) === 'Date' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a Blob\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Blob}\r\n */\r\nfunction isBlob(payload) {\r\n return getType(payload) === 'Blob';\r\n}\r\n/**\r\n * Returns whether the payload is a File\r\n *\r\n * @param {*} payload\r\n * @returns {payload is File}\r\n */\r\nfunction isFile(payload) {\r\n return getType(payload) === 'File';\r\n}\r\n/**\r\n * Returns whether the payload is a Promise\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Promise}\r\n */\r\nfunction isPromise(payload) {\r\n return getType(payload) === 'Promise';\r\n}\r\n/**\r\n * Returns whether the payload is an Error\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Error}\r\n */\r\nfunction isError(payload) {\r\n return getType(payload) === 'Error';\r\n}\r\n/**\r\n * Returns whether the payload is literally the value `NaN` (it's `NaN` and also a `number`)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is typeof NaN}\r\n */\r\nfunction isNaNValue(payload) {\r\n return getType(payload) === 'Number' && isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a primitive type (eg. Boolean | Null | Undefined | Number | String | Symbol)\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is boolean | null | undefined | number | string | symbol)}\r\n */\r\nfunction isPrimitive(payload) {\r\n return (isBoolean(payload) ||\r\n isNull(payload) ||\r\n isUndefined(payload) ||\r\n isNumber(payload) ||\r\n isString(payload) ||\r\n isSymbol(payload));\r\n}\r\n/**\r\n * Returns true whether the payload is null or undefined\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is null | undefined)}\r\n */\r\nfunction isNullOrUndefined(payload) {\r\n return isNull(payload) || isUndefined(payload);\r\n}\r\n/**\r\n * Does a generic check to check that the given payload is of a given type.\r\n * In cases like Number, it will return true for NaN as NaN is a Number (thanks javascript!);\r\n * It will, however, differentiate between object and null\r\n *\r\n * @template T\r\n * @param {*} payload\r\n * @param {T} type\r\n * @throws {TypeError} Will throw type error if type is an invalid type\r\n * @returns {payload is T}\r\n */\r\nfunction isType(payload, type) {\r\n if (!(type instanceof Function)) {\r\n throw new TypeError('Type must be a function');\r\n }\r\n if (!Object.prototype.hasOwnProperty.call(type, 'prototype')) {\r\n throw new TypeError('Type is not a class');\r\n }\r\n // Classes usually have names (as functions usually have names)\r\n var name = type.name;\r\n return getType(payload) === name || Boolean(payload && payload.constructor === type);\r\n}\n\nexport { getType, isAnyObject, isArray, isBlob, isBoolean, isDate, isEmptyArray, isEmptyObject, isEmptyString, isError, isFile, isFullArray, isFullString, isFunction, isMap, isNaNValue, isNull, isNullOrUndefined, isNumber, isObject, isObjectLike, isPlainObject, isPrimitive, isPromise, isRegExp, isSet, isString, isSymbol, isType, isUndefined, isWeakMap, isWeakSet };\n","import { isArray, isPlainObject } from 'is-what';\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n\r\nfunction __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\n\nfunction assignProp(carry, key, newVal, originalObject, includeNonenumerable) {\r\n var propType = {}.propertyIsEnumerable.call(originalObject, key)\r\n ? 'enumerable'\r\n : 'nonenumerable';\r\n if (propType === 'enumerable')\r\n carry[key] = newVal;\r\n if (includeNonenumerable && propType === 'nonenumerable') {\r\n Object.defineProperty(carry, key, {\r\n value: newVal,\r\n enumerable: false,\r\n writable: true,\r\n configurable: true,\r\n });\r\n }\r\n}\r\n/**\r\n * Copy (clone) an object and all its props recursively to get rid of any prop referenced of the original object. Arrays are also cloned, however objects inside arrays are still linked.\r\n *\r\n * @export\r\n * @template T\r\n * @param {T} target Target can be anything\r\n * @param {Options} [options={}] Options can be `props` or `nonenumerable`\r\n * @returns {T} the target with replaced values\r\n * @export\r\n */\r\nfunction copy(target, options) {\r\n if (options === void 0) { options = {}; }\r\n if (isArray(target))\r\n return target.map(function (i) { return copy(i, options); });\r\n if (!isPlainObject(target))\r\n return target;\r\n var props = Object.getOwnPropertyNames(target);\r\n var symbols = Object.getOwnPropertySymbols(target);\r\n return __spreadArrays(props, symbols).reduce(function (carry, key) {\r\n if (isArray(options.props) && !options.props.includes(key)) {\r\n return carry;\r\n }\r\n var val = target[key];\r\n var newVal = copy(val, options);\r\n assignProp(carry, key, newVal, target, options.nonenumerable);\r\n return carry;\r\n }, {});\r\n}\n\nexport { copy };\n","/* jshint proto: true */\nimport * as Constants from './constants';\nimport { copy } from 'copy-anything';\n\nexport function getLocation(index, inputStream) {\n let n = index + 1;\n let line = null;\n let column = -1;\n\n while (--n >= 0 && inputStream.charAt(n) !== '\\n') {\n column++;\n }\n\n if (typeof index === 'number') {\n line = (inputStream.slice(0, index).match(/\\n/g) || '').length;\n }\n\n return {\n line,\n column\n };\n}\n\nexport function copyArray(arr) {\n let i;\n const length = arr.length;\n const copy = new Array(length);\n\n for (i = 0; i < length; i++) {\n copy[i] = arr[i];\n }\n return copy;\n}\n\nexport function clone(obj) {\n const cloned = {};\n for (const prop in obj) {\n if (obj.hasOwnProperty(prop)) {\n cloned[prop] = obj[prop];\n }\n }\n return cloned;\n}\n\nexport function defaults(obj1, obj2) {\n let newObj = obj2 || {};\n if (!obj2._defaults) {\n newObj = {};\n const defaults = copy(obj1);\n newObj._defaults = defaults;\n const cloned = obj2 ? copy(obj2) : {};\n Object.assign(newObj, defaults, cloned);\n }\n return newObj;\n}\n\nexport function copyOptions(obj1, obj2) {\n if (obj2 && obj2._defaults) {\n return obj2;\n }\n const opts = defaults(obj1, obj2);\n if (opts.strictMath) {\n opts.math = Constants.Math.PARENS;\n }\n // Back compat with changed relativeUrls option\n if (opts.relativeUrls) {\n opts.rewriteUrls = Constants.RewriteUrls.ALL;\n }\n if (typeof opts.math === 'string') {\n switch (opts.math.toLowerCase()) {\n case 'always':\n opts.math = Constants.Math.ALWAYS;\n break;\n case 'parens-division':\n opts.math = Constants.Math.PARENS_DIVISION;\n break;\n case 'strict':\n case 'parens':\n opts.math = Constants.Math.PARENS;\n break;\n default:\n opts.math = Constants.Math.PARENS;\n }\n }\n if (typeof opts.rewriteUrls === 'string') {\n switch (opts.rewriteUrls.toLowerCase()) {\n case 'off':\n opts.rewriteUrls = Constants.RewriteUrls.OFF;\n break;\n case 'local':\n opts.rewriteUrls = Constants.RewriteUrls.LOCAL;\n break;\n case 'all':\n opts.rewriteUrls = Constants.RewriteUrls.ALL;\n break;\n }\n }\n return opts;\n}\n\nexport function merge(obj1, obj2) {\n for (const prop in obj2) {\n if (obj2.hasOwnProperty(prop)) {\n obj1[prop] = obj2[prop];\n }\n }\n return obj1;\n}\n\nexport function flattenArray(arr, result = []) {\n for (let i = 0, length = arr.length; i < length; i++) {\n const value = arr[i];\n if (Array.isArray(value)) {\n flattenArray(value, result);\n } else {\n if (value !== undefined) {\n result.push(value);\n }\n }\n }\n return result;\n}","import * as utils from './utils';\n\nconst anonymousFunc = /(|Function):(\\d+):(\\d+)/;\n\n/**\n * This is a centralized class of any error that could be thrown internally (mostly by the parser).\n * Besides standard .message it keeps some additional data like a path to the file where the error\n * occurred along with line and column numbers.\n *\n * @class\n * @extends Error\n * @type {module.LessError}\n *\n * @prop {string} type\n * @prop {string} filename\n * @prop {number} index\n * @prop {number} line\n * @prop {number} column\n * @prop {number} callLine\n * @prop {number} callExtract\n * @prop {string[]} extract\n *\n * @param {Object} e - An error object to wrap around or just a descriptive object\n * @param {Object} fileContentMap - An object with file contents in 'contents' property (like importManager) @todo - move to fileManager?\n * @param {string} [currentFilename]\n */\nconst LessError = function(e, fileContentMap, currentFilename) {\n Error.call(this);\n\n const filename = e.filename || currentFilename;\n\n this.message = e.message;\n this.stack = e.stack;\n\n if (fileContentMap && filename) {\n const input = fileContentMap.contents[filename];\n const loc = utils.getLocation(e.index, input);\n var line = loc.line;\n const col = loc.column;\n const callLine = e.call && utils.getLocation(e.call, input).line;\n const lines = input ? input.split('\\n') : '';\n\n this.type = e.type || 'Syntax';\n this.filename = filename;\n this.index = e.index;\n this.line = typeof line === 'number' ? line + 1 : null;\n this.column = col;\n\n if (!this.line && this.stack) {\n const found = this.stack.match(anonymousFunc);\n\n /**\n * We have to figure out how this environment stringifies anonymous functions\n * so we can correctly map plugin errors.\n * \n * Note, in Node 8, the output of anonymous funcs varied based on parameters\n * being present or not, so we inject dummy params.\n */\n const func = new Function('a', 'throw new Error()');\n let lineAdjust = 0;\n try {\n func();\n } catch (e) {\n const match = e.stack.match(anonymousFunc);\n var line = parseInt(match[2]);\n lineAdjust = 1 - line;\n }\n\n if (found) {\n if (found[2]) {\n this.line = parseInt(found[2]) + lineAdjust;\n }\n if (found[3]) {\n this.column = parseInt(found[3]);\n }\n }\n }\n\n this.callLine = callLine + 1;\n this.callExtract = lines[callLine];\n\n this.extract = [\n lines[this.line - 2],\n lines[this.line - 1],\n lines[this.line]\n ];\n }\n\n};\n\nif (typeof Object.create === 'undefined') {\n const F = function () {};\n F.prototype = Error.prototype;\n LessError.prototype = new F();\n} else {\n LessError.prototype = Object.create(Error.prototype);\n}\n\nLessError.prototype.constructor = LessError;\n\n/**\n * An overridden version of the default Object.prototype.toString\n * which uses additional information to create a helpful message.\n *\n * @param {Object} options\n * @returns {string}\n */\nLessError.prototype.toString = function(options) {\n options = options || {};\n\n let message = '';\n const extract = this.extract || [];\n let error = [];\n let stylize = function (str) { return str; };\n if (options.stylize) {\n const type = typeof options.stylize;\n if (type !== 'function') {\n throw Error(`options.stylize should be a function, got a ${type}!`);\n }\n stylize = options.stylize;\n }\n\n if (this.line !== null) {\n if (typeof extract[0] === 'string') {\n error.push(stylize(`${this.line - 1} ${extract[0]}`, 'grey'));\n }\n\n if (typeof extract[1] === 'string') {\n let errorTxt = `${this.line} `;\n if (extract[1]) {\n errorTxt += extract[1].slice(0, this.column) +\n stylize(stylize(stylize(extract[1].substr(this.column, 1), 'bold') +\n extract[1].slice(this.column + 1), 'red'), 'inverse');\n }\n error.push(errorTxt);\n }\n\n if (typeof extract[2] === 'string') {\n error.push(stylize(`${this.line + 1} ${extract[2]}`, 'grey'));\n }\n error = `${error.join('\\n') + stylize('', 'reset')}\\n`;\n }\n\n message += stylize(`${this.type}Error: ${this.message}`, 'red');\n if (this.filename) {\n message += stylize(' in ', 'red') + this.filename;\n }\n if (this.line) {\n message += stylize(` on line ${this.line}, column ${this.column + 1}:`, 'grey');\n }\n\n message += `\\n${error}`;\n\n if (this.callLine) {\n message += `${stylize('from ', 'red') + (this.filename || '')}/n`;\n message += `${stylize(this.callLine, 'grey')} ${this.callExtract}/n`;\n }\n\n return message;\n};\n\nexport default LessError;","import Node from './node';\nimport Element from './element';\nimport LessError from '../less-error';\n\nconst Selector = function(elements, extendList, condition, index, currentFileInfo, visibilityInfo) {\n this.extendList = extendList;\n this.condition = condition;\n this.evaldCondition = !condition;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.elements = this.getElements(elements);\n this.mixinElements_ = undefined;\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.elements, this);\n};\n\nSelector.prototype = Object.assign(new Node(), {\n type: 'Selector',\n\n accept(visitor) {\n if (this.elements) {\n this.elements = visitor.visitArray(this.elements);\n }\n if (this.extendList) {\n this.extendList = visitor.visitArray(this.extendList);\n }\n if (this.condition) {\n this.condition = visitor.visit(this.condition);\n }\n },\n\n createDerived(elements, extendList, evaldCondition) {\n elements = this.getElements(elements);\n const newSelector = new Selector(elements, extendList || this.extendList,\n null, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n newSelector.evaldCondition = (evaldCondition != null) ? evaldCondition : this.evaldCondition;\n newSelector.mediaEmpty = this.mediaEmpty;\n return newSelector;\n },\n\n getElements(els) {\n if (!els) {\n return [new Element('', '&', false, this._index, this._fileInfo)];\n }\n if (typeof els === 'string') {\n this.parse.parseNode(\n els, \n ['selector'],\n this._index, \n this._fileInfo, \n function(err, result) {\n if (err) {\n throw new LessError({\n index: err.index,\n message: err.message\n }, this.parse.imports, this._fileInfo.filename);\n }\n els = result[0].elements;\n });\n }\n return els;\n },\n\n createEmptySelectors() {\n const el = new Element('', '&', false, this._index, this._fileInfo), sels = [new Selector([el], null, null, this._index, this._fileInfo)];\n sels[0].mediaEmpty = true;\n return sels;\n },\n\n match(other) {\n const elements = this.elements;\n const len = elements.length;\n let olen;\n let i;\n\n other = other.mixinElements();\n olen = other.length;\n if (olen === 0 || len < olen) {\n return 0;\n } else {\n for (i = 0; i < olen; i++) {\n if (elements[i].value !== other[i]) {\n return 0;\n }\n }\n }\n\n return olen; // return number of matched elements\n },\n\n mixinElements() {\n if (this.mixinElements_) {\n return this.mixinElements_;\n }\n\n let elements = this.elements.map( function(v) {\n return v.combinator.value + (v.value.value || v.value);\n }).join('').match(/[,&#\\*\\.\\w-]([\\w-]|(\\\\.))*/g);\n\n if (elements) {\n if (elements[0] === '&') {\n elements.shift();\n }\n } else {\n elements = [];\n }\n\n return (this.mixinElements_ = elements);\n },\n\n isJustParentSelector() {\n return !this.mediaEmpty &&\n this.elements.length === 1 &&\n this.elements[0].value === '&' &&\n (this.elements[0].combinator.value === ' ' || this.elements[0].combinator.value === '');\n },\n\n eval(context) {\n const evaldCondition = this.condition && this.condition.eval(context);\n let elements = this.elements;\n let extendList = this.extendList;\n\n elements = elements && elements.map(function (e) { return e.eval(context); });\n extendList = extendList && extendList.map(function(extend) { return extend.eval(context); });\n\n return this.createDerived(elements, extendList, evaldCondition);\n },\n\n genCSS(context, output) {\n let i, element;\n if ((!context || !context.firstSelector) && this.elements[0].combinator.value === '') {\n output.add(' ', this.fileInfo(), this.getIndex());\n }\n for (i = 0; i < this.elements.length; i++) {\n element = this.elements[i];\n element.genCSS(context, output);\n }\n },\n\n getIsOutput() {\n return this.evaldCondition;\n }\n});\n\nexport default Selector;\n","import Node from './node';\n\nconst Value = function(value) {\n if (!value) {\n throw new Error('Value requires an array argument');\n }\n if (!Array.isArray(value)) {\n this.value = [ value ];\n }\n else {\n this.value = value;\n }\n};\n\nValue.prototype = Object.assign(new Node(), {\n type: 'Value',\n\n accept(visitor) {\n if (this.value) {\n this.value = visitor.visitArray(this.value);\n }\n },\n\n eval(context) {\n if (this.value.length === 1) {\n return this.value[0].eval(context);\n } else {\n return new Value(this.value.map(function (v) {\n return v.eval(context);\n }));\n }\n },\n\n genCSS(context, output) {\n let i;\n for (i = 0; i < this.value.length; i++) {\n this.value[i].genCSS(context, output);\n if (i + 1 < this.value.length) {\n output.add((context && context.compress) ? ',' : ', ');\n }\n }\n }\n});\n\nexport default Value;\n","import Node from './node';\n\nconst Keyword = function(value) {\n this.value = value;\n};\n\nKeyword.prototype = Object.assign(new Node(), {\n type: 'Keyword',\n\n genCSS(context, output) {\n if (this.value === '%') { throw { type: 'Syntax', message: 'Invalid % without number' }; }\n output.add(this.value);\n }\n});\n\nKeyword.True = new Keyword('true');\nKeyword.False = new Keyword('false');\n\nexport default Keyword;\n","import Node from './node';\n\nconst Anonymous = function(value, index, currentFileInfo, mapLines, rulesetLike, visibilityInfo) {\n this.value = value;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.mapLines = mapLines;\n this.rulesetLike = (typeof rulesetLike === 'undefined') ? false : rulesetLike;\n this.allowRoot = true;\n this.copyVisibilityInfo(visibilityInfo);\n}\n\nAnonymous.prototype = Object.assign(new Node(), {\n type: 'Anonymous',\n eval() {\n return new Anonymous(this.value, this._index, this._fileInfo, this.mapLines, this.rulesetLike, this.visibilityInfo());\n },\n compare(other) {\n return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined;\n },\n isRulesetLike() {\n return this.rulesetLike;\n },\n genCSS(context, output) {\n this.nodeVisible = Boolean(this.value);\n if (this.nodeVisible) {\n output.add(this.value, this._fileInfo, this._index, this.mapLines);\n }\n }\n})\n\nexport default Anonymous;\n","import Node from './node';\nimport Value from './value';\nimport Keyword from './keyword';\nimport Anonymous from './anonymous';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\nfunction evalName(context, name) {\n let value = '';\n let i;\n const n = name.length;\n const output = {add: function (s) {value += s;}};\n for (i = 0; i < n; i++) {\n name[i].eval(context).genCSS(context, output);\n }\n return value;\n}\n\nconst Declaration = function(name, value, important, merge, index, currentFileInfo, inline, variable) {\n this.name = name;\n this.value = (value instanceof Node) ? value : new Value([value ? new Anonymous(value) : null]);\n this.important = important ? ` ${important.trim()}` : '';\n this.merge = merge;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.inline = inline || false;\n this.variable = (variable !== undefined) ? variable\n : (name.charAt && (name.charAt(0) === '@'));\n this.allowRoot = true;\n this.setParent(this.value, this);\n};\n\nDeclaration.prototype = Object.assign(new Node(), {\n type: 'Declaration',\n\n genCSS(context, output) {\n output.add(this.name + (context.compress ? ':' : ': '), this.fileInfo(), this.getIndex());\n try {\n this.value.genCSS(context, output);\n }\n catch (e) {\n e.index = this._index;\n e.filename = this._fileInfo.filename;\n throw e;\n }\n output.add(this.important + ((this.inline || (context.lastRule && context.compress)) ? '' : ';'), this._fileInfo, this._index);\n },\n\n eval(context) {\n let mathBypass = false, prevMath, name = this.name, evaldValue, variable = this.variable;\n if (typeof name !== 'string') {\n // expand 'primitive' name directly to get\n // things faster (~10% for benchmark.less):\n name = (name.length === 1) && (name[0] instanceof Keyword) ?\n name[0].value : evalName(context, name);\n variable = false; // never treat expanded interpolation as new variable name\n }\n\n // @todo remove when parens-division is default\n if (name === 'font' && context.math === MATH.ALWAYS) {\n mathBypass = true;\n prevMath = context.math;\n context.math = MATH.PARENS_DIVISION;\n }\n try {\n context.importantScope.push({});\n evaldValue = this.value.eval(context);\n\n if (!this.variable && evaldValue.type === 'DetachedRuleset') {\n throw { message: 'Rulesets cannot be evaluated on a property.',\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n let important = this.important;\n const importantResult = context.importantScope.pop();\n if (!important && importantResult.important) {\n important = importantResult.important;\n }\n\n return new Declaration(name,\n evaldValue,\n important,\n this.merge,\n this.getIndex(), this.fileInfo(), this.inline,\n variable);\n }\n catch (e) {\n if (typeof e.index !== 'number') {\n e.index = this.getIndex();\n e.filename = this.fileInfo().filename;\n }\n throw e;\n }\n finally {\n if (mathBypass) {\n context.math = prevMath;\n }\n }\n },\n\n makeImportant() {\n return new Declaration(this.name,\n this.value,\n '!important',\n this.merge,\n this.getIndex(), this.fileInfo(), this.inline);\n }\n});\n\nexport default Declaration;","class debugInfo {\n constructor(context, ctx, lineSeparator) {\n let result = '';\n if (context.dumpLineNumbers && !context.compress) {\n switch (context.dumpLineNumbers) {\n case 'comments':\n result = debugInfo.asComment(ctx);\n break;\n case 'mediaquery':\n result = debugInfo.asMediaQuery(ctx);\n break;\n case 'all':\n result = debugInfo.asComment(ctx) + (lineSeparator || '') + debugInfo.asMediaQuery(ctx);\n break;\n }\n }\n return result;\n }\n\n static asComment(ctx) {\n return `/* line ${ctx.debugInfo.lineNumber}, ${ctx.debugInfo.fileName} */\\n`;\n }\n\n static asMediaQuery(ctx) {\n let filenameWithProtocol = ctx.debugInfo.fileName;\n if (!/^[a-z]+:\\/\\//i.test(filenameWithProtocol)) {\n filenameWithProtocol = `file://${filenameWithProtocol}`;\n }\n return `@media -sass-debug-info{filename{font-family:${filenameWithProtocol.replace(/([.:\\/\\\\])/g, function (a) {\n if (a == '\\\\') {\n a = '\\/';\n }\n return `\\\\${a}`;\n })}}line{font-family:\\\\00003${ctx.debugInfo.lineNumber}}}\\n`;\n }\n}\n\nexport default debugInfo;\n","import Node from './node';\nimport getDebugInfo from './debug-info';\n\nconst Comment = function(value, isLineComment, index, currentFileInfo) {\n this.value = value;\n this.isLineComment = isLineComment;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.allowRoot = true;\n}\n\nComment.prototype = Object.assign(new Node(), {\n type: 'Comment',\n\n genCSS(context, output) {\n if (this.debugInfo) {\n output.add(getDebugInfo(context, this), this.fileInfo(), this.getIndex());\n }\n output.add(this.value);\n },\n\n isSilent(context) {\n const isCompressed = context.compress && this.value[2] !== '!';\n return this.isLineComment || isCompressed;\n }\n});\n\nexport default Comment;\n","const contexts = {};\nexport default contexts;\nimport * as Constants from './constants';\n\nconst copyFromOriginal = function copyFromOriginal(original, destination, propertiesToCopy) {\n if (!original) { return; }\n\n for (let i = 0; i < propertiesToCopy.length; i++) {\n if (original.hasOwnProperty(propertiesToCopy[i])) {\n destination[propertiesToCopy[i]] = original[propertiesToCopy[i]];\n }\n }\n};\n\n/*\n parse is used whilst parsing\n */\nconst parseCopyProperties = [\n // options\n 'paths', // option - unmodified - paths to search for imports on\n 'rewriteUrls', // option - whether to adjust URL's to be relative\n 'rootpath', // option - rootpath to append to URL's\n 'strictImports', // option -\n 'insecure', // option - whether to allow imports from insecure ssl hosts\n 'dumpLineNumbers', // option - whether to dump line numbers\n 'compress', // option - whether to compress\n 'syncImport', // option - whether to import synchronously\n 'chunkInput', // option - whether to chunk input. more performant but causes parse issues.\n 'mime', // browser only - mime type for sheet import\n 'useFileCache', // browser only - whether to use the per file session cache\n // context\n 'processImports', // option & context - whether to process imports. if false then imports will not be imported.\n // Used by the import manager to stop multiple import visitors being created.\n 'pluginManager' // Used as the plugin manager for the session\n];\n\ncontexts.Parse = function(options) {\n copyFromOriginal(options, this, parseCopyProperties);\n\n if (typeof this.paths === 'string') { this.paths = [this.paths]; }\n};\n\nconst evalCopyProperties = [\n 'paths', // additional include paths\n 'compress', // whether to compress\n 'math', // whether math has to be within parenthesis\n 'strictUnits', // whether units need to evaluate correctly\n 'sourceMap', // whether to output a source map\n 'importMultiple', // whether we are currently importing multiple copies\n 'urlArgs', // whether to add args into url tokens\n 'javascriptEnabled', // option - whether Inline JavaScript is enabled. if undefined, defaults to false\n 'pluginManager', // Used as the plugin manager for the session\n 'importantScope', // used to bubble up !important statements\n 'rewriteUrls' // option - whether to adjust URL's to be relative\n];\n\ncontexts.Eval = function(options, frames) {\n copyFromOriginal(options, this, evalCopyProperties);\n\n if (typeof this.paths === 'string') { this.paths = [this.paths]; }\n\n this.frames = frames || [];\n this.importantScope = this.importantScope || [];\n};\n\ncontexts.Eval.prototype.enterCalc = function () {\n if (!this.calcStack) {\n this.calcStack = [];\n }\n this.calcStack.push(true);\n this.inCalc = true;\n};\n\ncontexts.Eval.prototype.exitCalc = function () {\n this.calcStack.pop();\n if (!this.calcStack.length) {\n this.inCalc = false;\n }\n};\n\ncontexts.Eval.prototype.inParenthesis = function () {\n if (!this.parensStack) {\n this.parensStack = [];\n }\n this.parensStack.push(true);\n};\n\ncontexts.Eval.prototype.outOfParenthesis = function () {\n this.parensStack.pop();\n};\n\ncontexts.Eval.prototype.inCalc = false;\ncontexts.Eval.prototype.mathOn = true;\ncontexts.Eval.prototype.isMathOn = function (op) {\n if (!this.mathOn) {\n return false;\n }\n if (op === '/' && this.math !== Constants.Math.ALWAYS && (!this.parensStack || !this.parensStack.length)) {\n return false;\n }\n if (this.math > Constants.Math.PARENS_DIVISION) {\n return this.parensStack && this.parensStack.length;\n }\n return true;\n};\n\ncontexts.Eval.prototype.pathRequiresRewrite = function (path) {\n const isRelative = this.rewriteUrls === Constants.RewriteUrls.LOCAL ? isPathLocalRelative : isPathRelative;\n\n return isRelative(path);\n};\n\ncontexts.Eval.prototype.rewritePath = function (path, rootpath) {\n let newPath;\n\n rootpath = rootpath || '';\n newPath = this.normalizePath(rootpath + path);\n\n // If a path was explicit relative and the rootpath was not an absolute path\n // we must ensure that the new path is also explicit relative.\n if (isPathLocalRelative(path) &&\n isPathRelative(rootpath) &&\n isPathLocalRelative(newPath) === false) {\n newPath = `./${newPath}`;\n }\n\n return newPath;\n};\n\ncontexts.Eval.prototype.normalizePath = function (path) {\n const segments = path.split('/').reverse();\n let segment;\n\n path = [];\n while (segments.length !== 0) {\n segment = segments.pop();\n switch ( segment ) {\n case '.':\n break;\n case '..':\n if ((path.length === 0) || (path[path.length - 1] === '..')) {\n path.push( segment );\n } else {\n path.pop();\n }\n break;\n default:\n path.push(segment);\n break;\n }\n }\n\n return path.join('/');\n};\n\nfunction isPathRelative(path) {\n return !/^(?:[a-z-]+:|\\/|#)/i.test(path);\n}\n\nfunction isPathLocalRelative(path) {\n return path.charAt(0) === '.';\n}\n\n// todo - do the same for the toCSS ?\n","function makeRegistry( base ) {\n return {\n _data: {},\n add: function(name, func) {\n // precautionary case conversion, as later querying of\n // the registry by function-caller uses lower case as well.\n name = name.toLowerCase();\n\n if (this._data.hasOwnProperty(name)) {\n // TODO warn\n }\n this._data[name] = func;\n },\n addMultiple: function(functions) {\n Object.keys(functions).forEach(\n name => {\n this.add(name, functions[name]);\n });\n },\n get: function(name) {\n return this._data[name] || ( base && base.get( name ));\n },\n getLocalFunctions: function() {\n return this._data;\n },\n inherit: function() {\n return makeRegistry( this );\n },\n create: function(base) {\n return makeRegistry(base);\n }\n };\n}\n\nexport default makeRegistry( null );","import Keyword from '../tree/keyword';\n\nconst defaultFunc = {\n eval: function () {\n const v = this.value_;\n const e = this.error_;\n if (e) {\n throw e;\n }\n if (v != null) {\n return v ? Keyword.True : Keyword.False;\n }\n },\n value: function (v) {\n this.value_ = v;\n },\n error: function (e) {\n this.error_ = e;\n },\n reset: function () {\n this.value_ = this.error_ = null;\n }\n};\n\nexport default defaultFunc;\n","import Node from './node';\nimport Declaration from './declaration';\nimport Keyword from './keyword';\nimport Comment from './comment';\nimport Paren from './paren';\nimport Selector from './selector';\nimport Element from './element';\nimport Anonymous from './anonymous';\nimport contexts from '../contexts';\nimport globalFunctionRegistry from '../functions/function-registry';\nimport defaultFunc from '../functions/default';\nimport getDebugInfo from './debug-info';\nimport * as utils from '../utils';\n\nconst Ruleset = function(selectors, rules, strictImports, visibilityInfo) {\n this.selectors = selectors;\n this.rules = rules;\n this._lookups = {};\n this._variables = null;\n this._properties = null;\n this.strictImports = strictImports;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n\n this.setParent(this.selectors, this);\n this.setParent(this.rules, this);\n}\n\nRuleset.prototype = Object.assign(new Node(), {\n type: 'Ruleset',\n isRuleset: true,\n\n isRulesetLike() { return true; },\n\n accept(visitor) {\n if (this.paths) {\n this.paths = visitor.visitArray(this.paths, true);\n } else if (this.selectors) {\n this.selectors = visitor.visitArray(this.selectors);\n }\n if (this.rules && this.rules.length) {\n this.rules = visitor.visitArray(this.rules);\n }\n },\n\n eval(context) {\n const that = this;\n let selectors;\n let selCnt;\n let selector;\n let i;\n let hasVariable;\n let hasOnePassingSelector = false;\n\n if (this.selectors && (selCnt = this.selectors.length)) {\n selectors = new Array(selCnt);\n defaultFunc.error({\n type: 'Syntax',\n message: 'it is currently only allowed in parametric mixin guards,'\n });\n\n for (i = 0; i < selCnt; i++) {\n selector = this.selectors[i].eval(context);\n for (var j = 0; j < selector.elements.length; j++) {\n if (selector.elements[j].isVariable) {\n hasVariable = true;\n break;\n }\n }\n selectors[i] = selector;\n if (selector.evaldCondition) {\n hasOnePassingSelector = true;\n }\n }\n\n if (hasVariable) {\n const toParseSelectors = new Array(selCnt);\n for (i = 0; i < selCnt; i++) {\n selector = selectors[i];\n toParseSelectors[i] = selector.toCSS(context);\n }\n this.parse.parseNode(\n toParseSelectors.join(','),\n [\"selectors\"], \n selectors[0].getIndex(), \n selectors[0].fileInfo(), \n function(err, result) {\n if (result) {\n selectors = utils.flattenArray(result);\n }\n });\n }\n\n defaultFunc.reset();\n } else {\n hasOnePassingSelector = true;\n }\n\n let rules = this.rules ? utils.copyArray(this.rules) : null;\n const ruleset = new Ruleset(selectors, rules, this.strictImports, this.visibilityInfo());\n let rule;\n let subRule;\n\n ruleset.originalRuleset = this;\n ruleset.root = this.root;\n ruleset.firstRoot = this.firstRoot;\n ruleset.allowImports = this.allowImports;\n\n if (this.debugInfo) {\n ruleset.debugInfo = this.debugInfo;\n }\n\n if (!hasOnePassingSelector) {\n rules.length = 0;\n }\n\n // inherit a function registry from the frames stack when possible;\n // otherwise from the global registry\n ruleset.functionRegistry = (function (frames) {\n let i = 0;\n const n = frames.length;\n let found;\n for ( ; i !== n ; ++i ) {\n found = frames[ i ].functionRegistry;\n if ( found ) { return found; }\n }\n return globalFunctionRegistry;\n }(context.frames)).inherit();\n\n // push the current ruleset to the frames stack\n const ctxFrames = context.frames;\n ctxFrames.unshift(ruleset);\n\n // currrent selectors\n let ctxSelectors = context.selectors;\n if (!ctxSelectors) {\n context.selectors = ctxSelectors = [];\n }\n ctxSelectors.unshift(this.selectors);\n\n // Evaluate imports\n if (ruleset.root || ruleset.allowImports || !ruleset.strictImports) {\n ruleset.evalImports(context);\n }\n\n // Store the frames around mixin definitions,\n // so they can be evaluated like closures when the time comes.\n const rsRules = ruleset.rules;\n for (i = 0; (rule = rsRules[i]); i++) {\n if (rule.evalFirst) {\n rsRules[i] = rule.eval(context);\n }\n }\n\n const mediaBlockCount = (context.mediaBlocks && context.mediaBlocks.length) || 0;\n\n // Evaluate mixin calls.\n for (i = 0; (rule = rsRules[i]); i++) {\n if (rule.type === 'MixinCall') {\n /* jshint loopfunc:true */\n rules = rule.eval(context).filter(function(r) {\n if ((r instanceof Declaration) && r.variable) {\n // do not pollute the scope if the variable is\n // already there. consider returning false here\n // but we need a way to \"return\" variable from mixins\n return !(ruleset.variable(r.name));\n }\n return true;\n });\n rsRules.splice.apply(rsRules, [i, 1].concat(rules));\n i += rules.length - 1;\n ruleset.resetCache();\n } else if (rule.type === 'VariableCall') {\n /* jshint loopfunc:true */\n rules = rule.eval(context).rules.filter(function(r) {\n if ((r instanceof Declaration) && r.variable) {\n // do not pollute the scope at all\n return false;\n }\n return true;\n });\n rsRules.splice.apply(rsRules, [i, 1].concat(rules));\n i += rules.length - 1;\n ruleset.resetCache();\n }\n }\n\n // Evaluate everything else\n for (i = 0; (rule = rsRules[i]); i++) {\n if (!rule.evalFirst) {\n rsRules[i] = rule = rule.eval ? rule.eval(context) : rule;\n }\n }\n\n // Evaluate everything else\n for (i = 0; (rule = rsRules[i]); i++) {\n // for rulesets, check if it is a css guard and can be removed\n if (rule instanceof Ruleset && rule.selectors && rule.selectors.length === 1) {\n // check if it can be folded in (e.g. & where)\n if (rule.selectors[0] && rule.selectors[0].isJustParentSelector()) {\n rsRules.splice(i--, 1);\n\n for (var j = 0; (subRule = rule.rules[j]); j++) {\n if (subRule instanceof Node) {\n subRule.copyVisibilityInfo(rule.visibilityInfo());\n if (!(subRule instanceof Declaration) || !subRule.variable) {\n rsRules.splice(++i, 0, subRule);\n }\n }\n }\n }\n }\n }\n\n // Pop the stack\n ctxFrames.shift();\n ctxSelectors.shift();\n\n if (context.mediaBlocks) {\n for (i = mediaBlockCount; i < context.mediaBlocks.length; i++) {\n context.mediaBlocks[i].bubbleSelectors(selectors);\n }\n }\n\n return ruleset;\n },\n\n evalImports(context) {\n const rules = this.rules;\n let i;\n let importRules;\n if (!rules) { return; }\n\n for (i = 0; i < rules.length; i++) {\n if (rules[i].type === 'Import') {\n importRules = rules[i].eval(context);\n if (importRules && (importRules.length || importRules.length === 0)) {\n rules.splice.apply(rules, [i, 1].concat(importRules));\n i += importRules.length - 1;\n } else {\n rules.splice(i, 1, importRules);\n }\n this.resetCache();\n }\n }\n },\n\n makeImportant() {\n const result = new Ruleset(this.selectors, this.rules.map(function (r) {\n if (r.makeImportant) {\n return r.makeImportant();\n } else {\n return r;\n }\n }), this.strictImports, this.visibilityInfo());\n\n return result;\n },\n\n matchArgs(args) {\n return !args || args.length === 0;\n },\n\n // lets you call a css selector with a guard\n matchCondition(args, context) {\n const lastSelector = this.selectors[this.selectors.length - 1];\n if (!lastSelector.evaldCondition) {\n return false;\n }\n if (lastSelector.condition &&\n !lastSelector.condition.eval(\n new contexts.Eval(context,\n context.frames))) {\n return false;\n }\n return true;\n },\n\n resetCache() {\n this._rulesets = null;\n this._variables = null;\n this._properties = null;\n this._lookups = {};\n },\n\n variables() {\n if (!this._variables) {\n this._variables = !this.rules ? {} : this.rules.reduce(function (hash, r) {\n if (r instanceof Declaration && r.variable === true) {\n hash[r.name] = r;\n }\n // when evaluating variables in an import statement, imports have not been eval'd\n // so we need to go inside import statements.\n // guard against root being a string (in the case of inlined less)\n if (r.type === 'Import' && r.root && r.root.variables) {\n const vars = r.root.variables();\n for (const name in vars) {\n if (vars.hasOwnProperty(name)) {\n hash[name] = r.root.variable(name);\n }\n }\n }\n return hash;\n }, {});\n }\n return this._variables;\n },\n\n properties() {\n if (!this._properties) {\n this._properties = !this.rules ? {} : this.rules.reduce(function (hash, r) {\n if (r instanceof Declaration && r.variable !== true) {\n const name = (r.name.length === 1) && (r.name[0] instanceof Keyword) ?\n r.name[0].value : r.name;\n // Properties don't overwrite as they can merge\n if (!hash[`$${name}`]) {\n hash[`$${name}`] = [ r ];\n }\n else {\n hash[`$${name}`].push(r);\n }\n }\n return hash;\n }, {});\n }\n return this._properties;\n },\n\n variable(name) {\n const decl = this.variables()[name];\n if (decl) {\n return this.parseValue(decl);\n }\n },\n\n property(name) {\n const decl = this.properties()[name];\n if (decl) {\n return this.parseValue(decl);\n }\n },\n\n lastDeclaration() {\n for (let i = this.rules.length; i > 0; i--) {\n const decl = this.rules[i - 1];\n if (decl instanceof Declaration) {\n return this.parseValue(decl);\n }\n }\n },\n\n parseValue(toParse) {\n const self = this;\n function transformDeclaration(decl) {\n if (decl.value instanceof Anonymous && !decl.parsed) {\n if (typeof decl.value.value === 'string') {\n this.parse.parseNode(\n decl.value.value,\n ['value', 'important'], \n decl.value.getIndex(), \n decl.fileInfo(), \n function(err, result) {\n if (err) {\n decl.parsed = true;\n }\n if (result) {\n decl.value = result[0];\n decl.important = result[1] || '';\n decl.parsed = true;\n }\n });\n } else {\n decl.parsed = true;\n }\n\n return decl;\n }\n else {\n return decl;\n }\n }\n if (!Array.isArray(toParse)) {\n return transformDeclaration.call(self, toParse);\n }\n else {\n const nodes = [];\n toParse.forEach(function(n) {\n nodes.push(transformDeclaration.call(self, n));\n });\n return nodes;\n }\n },\n\n rulesets() {\n if (!this.rules) { return []; }\n\n const filtRules = [];\n const rules = this.rules;\n let i;\n let rule;\n\n for (i = 0; (rule = rules[i]); i++) {\n if (rule.isRuleset) {\n filtRules.push(rule);\n }\n }\n\n return filtRules;\n },\n\n prependRule(rule) {\n const rules = this.rules;\n if (rules) {\n rules.unshift(rule);\n } else {\n this.rules = [ rule ];\n }\n this.setParent(rule, this);\n },\n\n find(selector, self, filter) {\n self = self || this;\n const rules = [];\n let match;\n let foundMixins;\n const key = selector.toCSS();\n\n if (key in this._lookups) { return this._lookups[key]; }\n\n this.rulesets().forEach(function (rule) {\n if (rule !== self) {\n for (let j = 0; j < rule.selectors.length; j++) {\n match = selector.match(rule.selectors[j]);\n if (match) {\n if (selector.elements.length > match) {\n if (!filter || filter(rule)) {\n foundMixins = rule.find(new Selector(selector.elements.slice(match)), self, filter);\n for (let i = 0; i < foundMixins.length; ++i) {\n foundMixins[i].path.push(rule);\n }\n Array.prototype.push.apply(rules, foundMixins);\n }\n } else {\n rules.push({ rule, path: []});\n }\n break;\n }\n }\n }\n });\n this._lookups[key] = rules;\n return rules;\n },\n\n genCSS(context, output) {\n let i;\n let j;\n const charsetRuleNodes = [];\n let ruleNodes = [];\n\n let // Line number debugging\n debugInfo;\n\n let rule;\n let path;\n\n context.tabLevel = (context.tabLevel || 0);\n\n if (!this.root) {\n context.tabLevel++;\n }\n\n const tabRuleStr = context.compress ? '' : Array(context.tabLevel + 1).join(' ');\n const tabSetStr = context.compress ? '' : Array(context.tabLevel).join(' ');\n let sep;\n\n let charsetNodeIndex = 0;\n let importNodeIndex = 0;\n for (i = 0; (rule = this.rules[i]); i++) {\n if (rule instanceof Comment) {\n if (importNodeIndex === i) {\n importNodeIndex++;\n }\n ruleNodes.push(rule);\n } else if (rule.isCharset && rule.isCharset()) {\n ruleNodes.splice(charsetNodeIndex, 0, rule);\n charsetNodeIndex++;\n importNodeIndex++;\n } else if (rule.type === 'Import') {\n ruleNodes.splice(importNodeIndex, 0, rule);\n importNodeIndex++;\n } else {\n ruleNodes.push(rule);\n }\n }\n ruleNodes = charsetRuleNodes.concat(ruleNodes);\n\n // If this is the root node, we don't render\n // a selector, or {}.\n if (!this.root) {\n debugInfo = getDebugInfo(context, this, tabSetStr);\n\n if (debugInfo) {\n output.add(debugInfo);\n output.add(tabSetStr);\n }\n\n const paths = this.paths;\n const pathCnt = paths.length;\n let pathSubCnt;\n\n sep = context.compress ? ',' : (`,\\n${tabSetStr}`);\n\n for (i = 0; i < pathCnt; i++) {\n path = paths[i];\n if (!(pathSubCnt = path.length)) { continue; }\n if (i > 0) { output.add(sep); }\n\n context.firstSelector = true;\n path[0].genCSS(context, output);\n\n context.firstSelector = false;\n for (j = 1; j < pathSubCnt; j++) {\n path[j].genCSS(context, output);\n }\n }\n\n output.add((context.compress ? '{' : ' {\\n') + tabRuleStr);\n }\n\n // Compile rules and rulesets\n for (i = 0; (rule = ruleNodes[i]); i++) {\n\n if (i + 1 === ruleNodes.length) {\n context.lastRule = true;\n }\n\n const currentLastRule = context.lastRule;\n if (rule.isRulesetLike(rule)) {\n context.lastRule = false;\n }\n\n if (rule.genCSS) {\n rule.genCSS(context, output);\n } else if (rule.value) {\n output.add(rule.value.toString());\n }\n\n context.lastRule = currentLastRule;\n\n if (!context.lastRule && rule.isVisible()) {\n output.add(context.compress ? '' : (`\\n${tabRuleStr}`));\n } else {\n context.lastRule = false;\n }\n }\n\n if (!this.root) {\n output.add((context.compress ? '}' : `\\n${tabSetStr}}`));\n context.tabLevel--;\n }\n\n if (!output.isEmpty() && !context.compress && this.firstRoot) {\n output.add('\\n');\n }\n },\n\n joinSelectors(paths, context, selectors) {\n for (let s = 0; s < selectors.length; s++) {\n this.joinSelector(paths, context, selectors[s]);\n }\n },\n\n joinSelector(paths, context, selector) {\n\n function createParenthesis(elementsToPak, originalElement) {\n let replacementParen, j;\n if (elementsToPak.length === 0) {\n replacementParen = new Paren(elementsToPak[0]);\n } else {\n const insideParent = new Array(elementsToPak.length);\n for (j = 0; j < elementsToPak.length; j++) {\n insideParent[j] = new Element(\n null,\n elementsToPak[j],\n originalElement.isVariable,\n originalElement._index,\n originalElement._fileInfo\n );\n }\n replacementParen = new Paren(new Selector(insideParent));\n }\n return replacementParen;\n }\n\n function createSelector(containedElement, originalElement) {\n let element, selector;\n element = new Element(null, containedElement, originalElement.isVariable, originalElement._index, originalElement._fileInfo);\n selector = new Selector([element]);\n return selector;\n }\n\n // joins selector path from `beginningPath` with selector path in `addPath`\n // `replacedElement` contains element that is being replaced by `addPath`\n // returns concatenated path\n function addReplacementIntoPath(beginningPath, addPath, replacedElement, originalSelector) {\n let newSelectorPath, lastSelector, newJoinedSelector;\n // our new selector path\n newSelectorPath = [];\n\n // construct the joined selector - if & is the first thing this will be empty,\n // if not newJoinedSelector will be the last set of elements in the selector\n if (beginningPath.length > 0) {\n newSelectorPath = utils.copyArray(beginningPath);\n lastSelector = newSelectorPath.pop();\n newJoinedSelector = originalSelector.createDerived(utils.copyArray(lastSelector.elements));\n }\n else {\n newJoinedSelector = originalSelector.createDerived([]);\n }\n\n if (addPath.length > 0) {\n // /deep/ is a CSS4 selector - (removed, so should deprecate)\n // that is valid without anything in front of it\n // so if the & does not have a combinator that is \"\" or \" \" then\n // and there is a combinator on the parent, then grab that.\n // this also allows + a { & .b { .a & { ... though not sure why you would want to do that\n let combinator = replacedElement.combinator;\n\n const parentEl = addPath[0].elements[0];\n if (combinator.emptyOrWhitespace && !parentEl.combinator.emptyOrWhitespace) {\n combinator = parentEl.combinator;\n }\n // join the elements so far with the first part of the parent\n newJoinedSelector.elements.push(new Element(\n combinator,\n parentEl.value,\n replacedElement.isVariable,\n replacedElement._index,\n replacedElement._fileInfo\n ));\n newJoinedSelector.elements = newJoinedSelector.elements.concat(addPath[0].elements.slice(1));\n }\n\n // now add the joined selector - but only if it is not empty\n if (newJoinedSelector.elements.length !== 0) {\n newSelectorPath.push(newJoinedSelector);\n }\n\n // put together the parent selectors after the join (e.g. the rest of the parent)\n if (addPath.length > 1) {\n let restOfPath = addPath.slice(1);\n restOfPath = restOfPath.map(function (selector) {\n return selector.createDerived(selector.elements, []);\n });\n newSelectorPath = newSelectorPath.concat(restOfPath);\n }\n return newSelectorPath;\n }\n\n // joins selector path from `beginningPath` with every selector path in `addPaths` array\n // `replacedElement` contains element that is being replaced by `addPath`\n // returns array with all concatenated paths\n function addAllReplacementsIntoPath( beginningPath, addPaths, replacedElement, originalSelector, result) {\n let j;\n for (j = 0; j < beginningPath.length; j++) {\n const newSelectorPath = addReplacementIntoPath(beginningPath[j], addPaths, replacedElement, originalSelector);\n result.push(newSelectorPath);\n }\n return result;\n }\n\n function mergeElementsOnToSelectors(elements, selectors) {\n let i, sel;\n\n if (elements.length === 0) {\n return ;\n }\n if (selectors.length === 0) {\n selectors.push([ new Selector(elements) ]);\n return;\n }\n\n for (i = 0; (sel = selectors[i]); i++) {\n // if the previous thing in sel is a parent this needs to join on to it\n if (sel.length > 0) {\n sel[sel.length - 1] = sel[sel.length - 1].createDerived(sel[sel.length - 1].elements.concat(elements));\n }\n else {\n sel.push(new Selector(elements));\n }\n }\n }\n\n // replace all parent selectors inside `inSelector` by content of `context` array\n // resulting selectors are returned inside `paths` array\n // returns true if `inSelector` contained at least one parent selector\n function replaceParentSelector(paths, context, inSelector) {\n // The paths are [[Selector]]\n // The first list is a list of comma separated selectors\n // The inner list is a list of inheritance separated selectors\n // e.g.\n // .a, .b {\n // .c {\n // }\n // }\n // == [[.a] [.c]] [[.b] [.c]]\n //\n let i, j, k, currentElements, newSelectors, selectorsMultiplied, sel, el, hadParentSelector = false, length, lastSelector;\n function findNestedSelector(element) {\n let maybeSelector;\n if (!(element.value instanceof Paren)) {\n return null;\n }\n\n maybeSelector = element.value.value;\n if (!(maybeSelector instanceof Selector)) {\n return null;\n }\n\n return maybeSelector;\n }\n\n // the elements from the current selector so far\n currentElements = [];\n // the current list of new selectors to add to the path.\n // We will build it up. We initiate it with one empty selector as we \"multiply\" the new selectors\n // by the parents\n newSelectors = [\n []\n ];\n\n for (i = 0; (el = inSelector.elements[i]); i++) {\n // non parent reference elements just get added\n if (el.value !== '&') {\n const nestedSelector = findNestedSelector(el);\n if (nestedSelector != null) {\n // merge the current list of non parent selector elements\n // on to the current list of selectors to add\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n const nestedPaths = [];\n let replaced;\n const replacedNewSelectors = [];\n replaced = replaceParentSelector(nestedPaths, context, nestedSelector);\n hadParentSelector = hadParentSelector || replaced;\n // the nestedPaths array should have only one member - replaceParentSelector does not multiply selectors\n for (k = 0; k < nestedPaths.length; k++) {\n const replacementSelector = createSelector(createParenthesis(nestedPaths[k], el), el);\n addAllReplacementsIntoPath(newSelectors, [replacementSelector], el, inSelector, replacedNewSelectors);\n }\n newSelectors = replacedNewSelectors;\n currentElements = [];\n } else {\n currentElements.push(el);\n }\n\n } else {\n hadParentSelector = true;\n // the new list of selectors to add\n selectorsMultiplied = [];\n\n // merge the current list of non parent selector elements\n // on to the current list of selectors to add\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n // loop through our current selectors\n for (j = 0; j < newSelectors.length; j++) {\n sel = newSelectors[j];\n // if we don't have any parent paths, the & might be in a mixin so that it can be used\n // whether there are parents or not\n if (context.length === 0) {\n // the combinator used on el should now be applied to the next element instead so that\n // it is not lost\n if (sel.length > 0) {\n sel[0].elements.push(new Element(el.combinator, '', el.isVariable, el._index, el._fileInfo));\n }\n selectorsMultiplied.push(sel);\n }\n else {\n // and the parent selectors\n for (k = 0; k < context.length; k++) {\n // We need to put the current selectors\n // then join the last selector's elements on to the parents selectors\n const newSelectorPath = addReplacementIntoPath(sel, context[k], el, inSelector);\n // add that to our new set of selectors\n selectorsMultiplied.push(newSelectorPath);\n }\n }\n }\n\n // our new selectors has been multiplied, so reset the state\n newSelectors = selectorsMultiplied;\n currentElements = [];\n }\n }\n\n // if we have any elements left over (e.g. .a& .b == .b)\n // add them on to all the current selectors\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n for (i = 0; i < newSelectors.length; i++) {\n length = newSelectors[i].length;\n if (length > 0) {\n paths.push(newSelectors[i]);\n lastSelector = newSelectors[i][length - 1];\n newSelectors[i][length - 1] = lastSelector.createDerived(lastSelector.elements, inSelector.extendList);\n }\n }\n\n return hadParentSelector;\n }\n\n function deriveSelector(visibilityInfo, deriveFrom) {\n const newSelector = deriveFrom.createDerived(deriveFrom.elements, deriveFrom.extendList, deriveFrom.evaldCondition);\n newSelector.copyVisibilityInfo(visibilityInfo);\n return newSelector;\n }\n\n // joinSelector code follows\n let i, newPaths, hadParentSelector;\n\n newPaths = [];\n hadParentSelector = replaceParentSelector(newPaths, context, selector);\n\n if (!hadParentSelector) {\n if (context.length > 0) {\n newPaths = [];\n for (i = 0; i < context.length; i++) {\n\n const concatenated = context[i].map(deriveSelector.bind(this, selector.visibilityInfo()));\n\n concatenated.push(selector);\n newPaths.push(concatenated);\n }\n }\n else {\n newPaths = [[selector]];\n }\n }\n\n for (i = 0; i < newPaths.length; i++) {\n paths.push(newPaths[i]);\n }\n\n }\n});\n\nexport default Ruleset;\n","import Node from './node';\nimport Selector from './selector';\nimport Ruleset from './ruleset';\nimport Anonymous from './anonymous';\n\nconst AtRule = function(\n name,\n value,\n rules,\n index,\n currentFileInfo,\n debugInfo,\n isRooted,\n visibilityInfo\n) {\n let i;\n\n this.name = name;\n this.value = (value instanceof Node) ? value : (value ? new Anonymous(value) : value);\n if (rules) {\n if (Array.isArray(rules)) {\n this.rules = rules;\n } else {\n this.rules = [rules];\n this.rules[0].selectors = (new Selector([], null, null, index, currentFileInfo)).createEmptySelectors();\n }\n for (i = 0; i < this.rules.length; i++) {\n this.rules[i].allowImports = true;\n }\n this.setParent(this.rules, this);\n }\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.debugInfo = debugInfo;\n this.isRooted = isRooted || false;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n}\n\nAtRule.prototype = Object.assign(new Node(), {\n type: 'AtRule',\n accept(visitor) {\n const value = this.value, rules = this.rules;\n if (rules) {\n this.rules = visitor.visitArray(rules);\n }\n if (value) {\n this.value = visitor.visit(value);\n }\n },\n\n isRulesetLike() {\n return this.rules || !this.isCharset();\n },\n\n isCharset() {\n return '@charset' === this.name;\n },\n\n genCSS(context, output) {\n const value = this.value, rules = this.rules;\n output.add(this.name, this.fileInfo(), this.getIndex());\n if (value) {\n output.add(' ');\n value.genCSS(context, output);\n }\n if (rules) {\n this.outputRuleset(context, output, rules);\n } else {\n output.add(';');\n }\n },\n\n eval(context) {\n let mediaPathBackup, mediaBlocksBackup, value = this.value, rules = this.rules;\n\n // media stored inside other atrule should not bubble over it\n // backpup media bubbling information\n mediaPathBackup = context.mediaPath;\n mediaBlocksBackup = context.mediaBlocks;\n // deleted media bubbling information\n context.mediaPath = [];\n context.mediaBlocks = [];\n\n if (value) {\n value = value.eval(context);\n }\n if (rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n rules = [rules[0].eval(context)];\n rules[0].root = true;\n }\n // restore media bubbling information\n context.mediaPath = mediaPathBackup;\n context.mediaBlocks = mediaBlocksBackup;\n\n return new AtRule(this.name, value, rules,\n this.getIndex(), this.fileInfo(), this.debugInfo, this.isRooted, this.visibilityInfo());\n },\n\n variable(name) {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.variable.call(this.rules[0], name);\n }\n },\n\n find() {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.find.apply(this.rules[0], arguments);\n }\n },\n\n rulesets() {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.rulesets.apply(this.rules[0]);\n }\n },\n\n outputRuleset(context, output, rules) {\n const ruleCnt = rules.length;\n let i;\n context.tabLevel = (context.tabLevel | 0) + 1;\n\n // Compressed\n if (context.compress) {\n output.add('{');\n for (i = 0; i < ruleCnt; i++) {\n rules[i].genCSS(context, output);\n }\n output.add('}');\n context.tabLevel--;\n return;\n }\n\n // Non-compressed\n const tabSetStr = `\\n${Array(context.tabLevel).join(' ')}`, tabRuleStr = `${tabSetStr} `;\n if (!ruleCnt) {\n output.add(` {${tabSetStr}}`);\n } else {\n output.add(` {${tabRuleStr}`);\n rules[0].genCSS(context, output);\n for (i = 1; i < ruleCnt; i++) {\n output.add(tabRuleStr);\n rules[i].genCSS(context, output);\n }\n output.add(`${tabSetStr}}`);\n }\n\n context.tabLevel--;\n }\n});\n\nexport default AtRule;\n","import Node from './node';\nimport contexts from '../contexts';\nimport * as utils from '../utils';\n\nconst DetachedRuleset = function(ruleset, frames) {\n this.ruleset = ruleset;\n this.frames = frames;\n this.setParent(this.ruleset, this);\n};\n\nDetachedRuleset.prototype = Object.assign(new Node(), {\n type: 'DetachedRuleset',\n evalFirst: true,\n\n accept(visitor) {\n this.ruleset = visitor.visit(this.ruleset);\n },\n\n eval(context) {\n const frames = this.frames || utils.copyArray(context.frames);\n return new DetachedRuleset(this.ruleset, frames);\n },\n\n callEval(context) {\n return this.ruleset.eval(this.frames ? new contexts.Eval(context, this.frames.concat(context.frames)) : context);\n }\n});\n\nexport default DetachedRuleset;\n","import Node from './node';\nimport unitConversions from '../data/unit-conversions';\nimport * as utils from '../utils';\n\nconst Unit = function(numerator, denominator, backupUnit) {\n this.numerator = numerator ? utils.copyArray(numerator).sort() : [];\n this.denominator = denominator ? utils.copyArray(denominator).sort() : [];\n if (backupUnit) {\n this.backupUnit = backupUnit;\n } else if (numerator && numerator.length) {\n this.backupUnit = numerator[0];\n }\n};\n\nUnit.prototype = Object.assign(new Node(), {\n type: 'Unit',\n\n clone() {\n return new Unit(utils.copyArray(this.numerator), utils.copyArray(this.denominator), this.backupUnit);\n },\n\n genCSS(context, output) {\n // Dimension checks the unit is singular and throws an error if in strict math mode.\n const strictUnits = context && context.strictUnits;\n if (this.numerator.length === 1) {\n output.add(this.numerator[0]); // the ideal situation\n } else if (!strictUnits && this.backupUnit) {\n output.add(this.backupUnit);\n } else if (!strictUnits && this.denominator.length) {\n output.add(this.denominator[0]);\n }\n },\n\n toString() {\n let i, returnStr = this.numerator.join('*');\n for (i = 0; i < this.denominator.length; i++) {\n returnStr += `/${this.denominator[i]}`;\n }\n return returnStr;\n },\n\n compare(other) {\n return this.is(other.toString()) ? 0 : undefined;\n },\n\n is(unitString) {\n return this.toString().toUpperCase() === unitString.toUpperCase();\n },\n\n isLength() {\n return RegExp('^(px|em|ex|ch|rem|in|cm|mm|pc|pt|ex|vw|vh|vmin|vmax)$', 'gi').test(this.toCSS());\n },\n\n isEmpty() {\n return this.numerator.length === 0 && this.denominator.length === 0;\n },\n\n isSingular() {\n return this.numerator.length <= 1 && this.denominator.length === 0;\n },\n\n map(callback) {\n let i;\n\n for (i = 0; i < this.numerator.length; i++) {\n this.numerator[i] = callback(this.numerator[i], false);\n }\n\n for (i = 0; i < this.denominator.length; i++) {\n this.denominator[i] = callback(this.denominator[i], true);\n }\n },\n\n usedUnits() {\n let group;\n const result = {};\n let mapUnit;\n let groupName;\n\n mapUnit = function (atomicUnit) {\n /* jshint loopfunc:true */\n if (group.hasOwnProperty(atomicUnit) && !result[groupName]) {\n result[groupName] = atomicUnit;\n }\n\n return atomicUnit;\n };\n\n for (groupName in unitConversions) {\n if (unitConversions.hasOwnProperty(groupName)) {\n group = unitConversions[groupName];\n\n this.map(mapUnit);\n }\n }\n\n return result;\n },\n\n cancel() {\n const counter = {};\n let atomicUnit;\n let i;\n\n for (i = 0; i < this.numerator.length; i++) {\n atomicUnit = this.numerator[i];\n counter[atomicUnit] = (counter[atomicUnit] || 0) + 1;\n }\n\n for (i = 0; i < this.denominator.length; i++) {\n atomicUnit = this.denominator[i];\n counter[atomicUnit] = (counter[atomicUnit] || 0) - 1;\n }\n\n this.numerator = [];\n this.denominator = [];\n\n for (atomicUnit in counter) {\n if (counter.hasOwnProperty(atomicUnit)) {\n const count = counter[atomicUnit];\n\n if (count > 0) {\n for (i = 0; i < count; i++) {\n this.numerator.push(atomicUnit);\n }\n } else if (count < 0) {\n for (i = 0; i < -count; i++) {\n this.denominator.push(atomicUnit);\n }\n }\n }\n }\n\n this.numerator.sort();\n this.denominator.sort();\n }\n});\n\nexport default Unit;\n","import Node from './node';\nimport unitConversions from '../data/unit-conversions';\nimport Unit from './unit';\nimport Color from './color';\n\n//\n// A number with a unit\n//\nconst Dimension = function(value, unit) {\n this.value = parseFloat(value);\n if (isNaN(this.value)) {\n throw new Error('Dimension is not a number.');\n }\n this.unit = (unit && unit instanceof Unit) ? unit :\n new Unit(unit ? [unit] : undefined);\n this.setParent(this.unit, this);\n};\n\nDimension.prototype = Object.assign(new Node(), {\n type: 'Dimension',\n\n accept(visitor) {\n this.unit = visitor.visit(this.unit);\n },\n\n eval(context) {\n return this;\n },\n\n toColor() {\n return new Color([this.value, this.value, this.value]);\n },\n\n genCSS(context, output) {\n if ((context && context.strictUnits) && !this.unit.isSingular()) {\n throw new Error(`Multiple units in dimension. Correct the units or use the unit function. Bad unit: ${this.unit.toString()}`);\n }\n\n const value = this.fround(context, this.value);\n let strValue = String(value);\n\n if (value !== 0 && value < 0.000001 && value > -0.000001) {\n // would be output 1e-6 etc.\n strValue = value.toFixed(20).replace(/0+$/, '');\n }\n\n if (context && context.compress) {\n // Zero values doesn't need a unit\n if (value === 0 && this.unit.isLength()) {\n output.add(strValue);\n return;\n }\n\n // Float values doesn't need a leading zero\n if (value > 0 && value < 1) {\n strValue = (strValue).substr(1);\n }\n }\n\n output.add(strValue);\n this.unit.genCSS(context, output);\n },\n\n // In an operation between two Dimensions,\n // we default to the first Dimension's unit,\n // so `1px + 2` will yield `3px`.\n operate(context, op, other) {\n /* jshint noempty:false */\n let value = this._operate(context, op, this.value, other.value), unit = this.unit.clone();\n\n if (op === '+' || op === '-') {\n if (unit.numerator.length === 0 && unit.denominator.length === 0) {\n unit = other.unit.clone();\n if (this.unit.backupUnit) {\n unit.backupUnit = this.unit.backupUnit;\n }\n } else if (other.unit.numerator.length === 0 && unit.denominator.length === 0) {\n // do nothing\n } else {\n other = other.convertTo(this.unit.usedUnits());\n\n if (context.strictUnits && other.unit.toString() !== unit.toString()) {\n throw new Error(`Incompatible units. Change the units or use the unit function. `\n + `Bad units: '${unit.toString()}' and '${other.unit.toString()}'.`);\n }\n\n value = this._operate(context, op, this.value, other.value);\n }\n } else if (op === '*') {\n unit.numerator = unit.numerator.concat(other.unit.numerator).sort();\n unit.denominator = unit.denominator.concat(other.unit.denominator).sort();\n unit.cancel();\n } else if (op === '/') {\n unit.numerator = unit.numerator.concat(other.unit.denominator).sort();\n unit.denominator = unit.denominator.concat(other.unit.numerator).sort();\n unit.cancel();\n }\n return new Dimension(value, unit);\n },\n\n compare(other) {\n let a, b;\n\n if (!(other instanceof Dimension)) {\n return undefined;\n }\n\n if (this.unit.isEmpty() || other.unit.isEmpty()) {\n a = this;\n b = other;\n } else {\n a = this.unify();\n b = other.unify();\n if (a.unit.compare(b.unit) !== 0) {\n return undefined;\n }\n }\n\n return Node.numericCompare(a.value, b.value);\n },\n\n unify() {\n return this.convertTo({ length: 'px', duration: 's', angle: 'rad' });\n },\n\n convertTo(conversions) {\n let value = this.value;\n const unit = this.unit.clone();\n let i;\n let groupName;\n let group;\n let targetUnit;\n let derivedConversions = {};\n let applyUnit;\n\n if (typeof conversions === 'string') {\n for (i in unitConversions) {\n if (unitConversions[i].hasOwnProperty(conversions)) {\n derivedConversions = {};\n derivedConversions[i] = conversions;\n }\n }\n conversions = derivedConversions;\n }\n applyUnit = function (atomicUnit, denominator) {\n /* jshint loopfunc:true */\n if (group.hasOwnProperty(atomicUnit)) {\n if (denominator) {\n value = value / (group[atomicUnit] / group[targetUnit]);\n } else {\n value = value * (group[atomicUnit] / group[targetUnit]);\n }\n\n return targetUnit;\n }\n\n return atomicUnit;\n };\n\n for (groupName in conversions) {\n if (conversions.hasOwnProperty(groupName)) {\n targetUnit = conversions[groupName];\n group = unitConversions[groupName];\n\n unit.map(applyUnit);\n }\n }\n\n unit.cancel();\n\n return new Dimension(value, unit);\n }\n});\n\nexport default Dimension;\n","import Node from './node';\nimport Color from './color';\nimport Dimension from './dimension';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\n\nconst Operation = function(op, operands, isSpaced) {\n this.op = op.trim();\n this.operands = operands;\n this.isSpaced = isSpaced;\n};\n\nOperation.prototype = Object.assign(new Node(), {\n type: 'Operation',\n\n accept(visitor) {\n this.operands = visitor.visitArray(this.operands);\n },\n\n eval(context) {\n let a = this.operands[0].eval(context), b = this.operands[1].eval(context), op;\n\n if (context.isMathOn(this.op)) {\n op = this.op === './' ? '/' : this.op;\n if (a instanceof Dimension && b instanceof Color) {\n a = a.toColor();\n }\n if (b instanceof Dimension && a instanceof Color) {\n b = b.toColor();\n }\n if (!a.operate) {\n if (a instanceof Operation && a.op === '/' && context.math === MATH.PARENS_DIVISION) {\n return new Operation(this.op, [a, b], this.isSpaced);\n }\n throw { type: 'Operation',\n message: 'Operation on an invalid type' };\n }\n\n return a.operate(context, op, b);\n } else {\n return new Operation(this.op, [a, b], this.isSpaced);\n }\n },\n\n genCSS(context, output) {\n this.operands[0].genCSS(context, output);\n if (this.isSpaced) {\n output.add(' ');\n }\n output.add(this.op);\n if (this.isSpaced) {\n output.add(' ');\n }\n this.operands[1].genCSS(context, output);\n }\n});\n\nexport default Operation;\n","import Node from './node';\nimport Paren from './paren';\nimport Comment from './comment';\nimport Dimension from './dimension';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\nconst Expression = function(value, noSpacing) {\n this.value = value;\n this.noSpacing = noSpacing;\n if (!value) {\n throw new Error('Expression requires an array parameter');\n }\n};\n\nExpression.prototype = Object.assign(new Node(), {\n type: 'Expression',\n\n accept(visitor) {\n this.value = visitor.visitArray(this.value);\n },\n\n eval(context) {\n let returnValue;\n const mathOn = context.isMathOn();\n const inParenthesis = this.parens;\n\n let doubleParen = false;\n if (inParenthesis) {\n context.inParenthesis();\n }\n if (this.value.length > 1) {\n returnValue = new Expression(this.value.map(function (e) {\n if (!e.eval) {\n return e;\n }\n return e.eval(context);\n }), this.noSpacing);\n } else if (this.value.length === 1) {\n if (this.value[0].parens && !this.value[0].parensInOp && !context.inCalc) {\n doubleParen = true;\n }\n returnValue = this.value[0].eval(context);\n } else {\n returnValue = this;\n }\n if (inParenthesis) {\n context.outOfParenthesis();\n }\n if (this.parens && this.parensInOp && !mathOn && !doubleParen \n && (!(returnValue instanceof Dimension))) {\n returnValue = new Paren(returnValue);\n }\n return returnValue;\n },\n\n genCSS(context, output) {\n for (let i = 0; i < this.value.length; i++) {\n this.value[i].genCSS(context, output);\n if (!this.noSpacing && i + 1 < this.value.length) {\n output.add(' ');\n }\n }\n },\n\n throwAwayComments() {\n this.value = this.value.filter(function(v) {\n return !(v instanceof Comment);\n });\n }\n});\n\nexport default Expression;\n","import Expression from '../tree/expression';\n\nclass functionCaller {\n constructor(name, context, index, currentFileInfo) {\n this.name = name.toLowerCase();\n this.index = index;\n this.context = context;\n this.currentFileInfo = currentFileInfo;\n\n this.func = context.frames[0].functionRegistry.get(this.name);\n }\n\n isValid() {\n return Boolean(this.func);\n }\n\n call(args) {\n if (!(Array.isArray(args))) {\n args = [args];\n }\n const evalArgs = this.func.evalArgs;\n if (evalArgs !== false) {\n args = args.map(a => a.eval(this.context));\n }\n const commentFilter = item => !(item.type === 'Comment');\n\n // This code is terrible and should be replaced as per this issue...\n // https://github.com/less/less.js/issues/2477\n args = args\n .filter(commentFilter)\n .map(item => {\n if (item.type === 'Expression') {\n const subNodes = item.value.filter(commentFilter);\n if (subNodes.length === 1) {\n return subNodes[0];\n } else {\n return new Expression(subNodes);\n }\n }\n return item;\n });\n\n if (evalArgs === false) {\n return this.func(this.context, ...args);\n }\n\n return this.func(...args);\n }\n}\n\nexport default functionCaller;\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport function __createBinding(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n result.default = mod;\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to get private field on non-instance\");\r\n }\r\n return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to set private field on non-instance\");\r\n }\r\n privateMap.set(receiver, value);\r\n return value;\r\n}\r\n","import Node from './node';\nimport Anonymous from './anonymous';\nimport FunctionCaller from '../functions/function-caller';\n\n//\n// A function call node.\n//\nconst Call = function(name, args, index, currentFileInfo) {\n this.name = name;\n this.args = args;\n this.calc = name === 'calc';\n this._index = index;\n this._fileInfo = currentFileInfo;\n}\n\nCall.prototype = Object.assign(new Node(), {\n type: 'Call',\n\n accept(visitor) {\n if (this.args) {\n this.args = visitor.visitArray(this.args);\n }\n },\n\n //\n // When evaluating a function call,\n // we either find the function in the functionRegistry,\n // in which case we call it, passing the evaluated arguments,\n // if this returns null or we cannot find the function, we\n // simply print it out as it appeared originally [2].\n //\n // The reason why we evaluate the arguments, is in the case where\n // we try to pass a variable to a function, like: `saturate(@color)`.\n // The function should receive the value, not the variable.\n //\n eval(context) {\n /**\n * Turn off math for calc(), and switch back on for evaluating nested functions\n */\n const currentMathContext = context.mathOn;\n context.mathOn = !this.calc;\n if (this.calc || context.inCalc) {\n context.enterCalc();\n }\n\n const exitCalc = () => {\n if (this.calc || context.inCalc) {\n context.exitCalc();\n }\n context.mathOn = currentMathContext;\n };\n\n let result;\n const funcCaller = new FunctionCaller(this.name, context, this.getIndex(), this.fileInfo());\n\n if (funcCaller.isValid()) {\n try {\n result = funcCaller.call(this.args);\n exitCalc();\n } catch (e) {\n if (e.hasOwnProperty('line') && e.hasOwnProperty('column')) {\n throw e;\n }\n throw { \n type: e.type || 'Runtime',\n message: `Error evaluating function \\`${this.name}\\`${e.message ? `: ${e.message}` : ''}`,\n index: this.getIndex(), \n filename: this.fileInfo().filename,\n line: e.lineNumber,\n column: e.columnNumber\n };\n }\n }\n\n if (result !== null && result !== undefined) {\n // Results that that are not nodes are cast as Anonymous nodes\n // Falsy values or booleans are returned as empty nodes\n if (!(result instanceof Node)) {\n if (!result || result === true) {\n result = new Anonymous(null); \n }\n else {\n result = new Anonymous(result.toString()); \n }\n \n }\n result._index = this._index;\n result._fileInfo = this._fileInfo;\n return result;\n }\n\n const args = this.args.map(a => a.eval(context));\n exitCalc();\n\n return new Call(this.name, args, this.getIndex(), this.fileInfo());\n },\n\n genCSS(context, output) {\n output.add(`${this.name}(`, this.fileInfo(), this.getIndex());\n\n for (let i = 0; i < this.args.length; i++) {\n this.args[i].genCSS(context, output);\n if (i + 1 < this.args.length) {\n output.add(', ');\n }\n }\n\n output.add(')');\n }\n});\n\nexport default Call;\n","import Node from './node';\nimport Call from './call';\n\nconst Variable = function(name, index, currentFileInfo) {\n this.name = name;\n this._index = index;\n this._fileInfo = currentFileInfo;\n};\n\nVariable.prototype = Object.assign(new Node(), {\n type: 'Variable',\n\n eval(context) {\n let variable, name = this.name;\n\n if (name.indexOf('@@') === 0) {\n name = `@${new Variable(name.slice(1), this.getIndex(), this.fileInfo()).eval(context).value}`;\n }\n\n if (this.evaluating) {\n throw { type: 'Name',\n message: `Recursive variable definition for ${name}`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n this.evaluating = true;\n\n variable = this.find(context.frames, function (frame) {\n const v = frame.variable(name);\n if (v) {\n if (v.important) {\n const importantScope = context.importantScope[context.importantScope.length - 1];\n importantScope.important = v.important;\n }\n // If in calc, wrap vars in a function call to cascade evaluate args first\n if (context.inCalc) {\n return (new Call('_SELF', [v.value])).eval(context);\n }\n else {\n return v.value.eval(context);\n }\n }\n });\n if (variable) {\n this.evaluating = false;\n return variable;\n } else {\n throw { type: 'Name',\n message: `variable ${name} is undefined`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n },\n\n find(obj, fun) {\n for (let i = 0, r; i < obj.length; i++) {\n r = fun.call(obj, obj[i]);\n if (r) { return r; }\n }\n return null;\n }\n});\n\nexport default Variable;\n","import Node from './node';\nimport Declaration from './declaration';\n\nconst Property = function(name, index, currentFileInfo) {\n this.name = name;\n this._index = index;\n this._fileInfo = currentFileInfo;\n};\n\nProperty.prototype = Object.assign(new Node(), {\n type: 'Property',\n\n eval(context) {\n let property;\n const name = this.name;\n // TODO: shorten this reference\n const mergeRules = context.pluginManager.less.visitors.ToCSSVisitor.prototype._mergeRules;\n\n if (this.evaluating) {\n throw { type: 'Name',\n message: `Recursive property reference for ${name}`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n this.evaluating = true;\n\n property = this.find(context.frames, function (frame) {\n let v;\n const vArr = frame.property(name);\n if (vArr) {\n for (let i = 0; i < vArr.length; i++) {\n v = vArr[i];\n\n vArr[i] = new Declaration(v.name,\n v.value,\n v.important,\n v.merge,\n v.index,\n v.currentFileInfo,\n v.inline,\n v.variable\n );\n }\n mergeRules(vArr);\n\n v = vArr[vArr.length - 1];\n if (v.important) {\n const importantScope = context.importantScope[context.importantScope.length - 1];\n importantScope.important = v.important;\n }\n v = v.value.eval(context);\n return v;\n }\n });\n if (property) {\n this.evaluating = false;\n return property;\n } else {\n throw { type: 'Name',\n message: `Property '${name}' is undefined`,\n filename: this.currentFileInfo.filename,\n index: this.index };\n }\n },\n\n find(obj, fun) {\n for (let i = 0, r; i < obj.length; i++) {\n r = fun.call(obj, obj[i]);\n if (r) { return r; }\n }\n return null;\n }\n});\n\nexport default Property;\n","import Node from './node';\n\nconst Attribute = function(key, op, value) {\n this.key = key;\n this.op = op;\n this.value = value;\n}\n\nAttribute.prototype = Object.assign(new Node(), {\n type: 'Attribute',\n\n eval(context) {\n return new Attribute(this.key.eval ? this.key.eval(context) : this.key,\n this.op, (this.value && this.value.eval) ? this.value.eval(context) : this.value);\n },\n\n genCSS(context, output) {\n output.add(this.toCSS(context));\n },\n\n toCSS(context) {\n let value = this.key.toCSS ? this.key.toCSS(context) : this.key;\n\n if (this.op) {\n value += this.op;\n value += (this.value.toCSS ? this.value.toCSS(context) : this.value);\n }\n\n return `[${value}]`;\n }\n});\n\nexport default Attribute;\n","import Node from './node';\nimport Variable from './variable';\nimport Property from './property';\n\n\nconst Quoted = function(str, content, escaped, index, currentFileInfo) {\n this.escaped = (escaped == null) ? true : escaped;\n this.value = content || '';\n this.quote = str.charAt(0);\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.variableRegex = /@\\{([\\w-]+)\\}/g;\n this.propRegex = /\\$\\{([\\w-]+)\\}/g;\n this.allowRoot = escaped;\n};\n\nQuoted.prototype = Object.assign(new Node(), {\n type: 'Quoted',\n\n genCSS(context, output) {\n if (!this.escaped) {\n output.add(this.quote, this.fileInfo(), this.getIndex());\n }\n output.add(this.value);\n if (!this.escaped) {\n output.add(this.quote);\n }\n },\n\n containsVariables() {\n return this.value.match(this.variableRegex);\n },\n\n eval(context) {\n const that = this;\n let value = this.value;\n const variableReplacement = function (_, name) {\n const v = new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context, true);\n return (v instanceof Quoted) ? v.value : v.toCSS();\n };\n const propertyReplacement = function (_, name) {\n const v = new Property(`$${name}`, that.getIndex(), that.fileInfo()).eval(context, true);\n return (v instanceof Quoted) ? v.value : v.toCSS();\n };\n function iterativeReplace(value, regexp, replacementFnc) {\n let evaluatedValue = value;\n do {\n value = evaluatedValue.toString();\n evaluatedValue = value.replace(regexp, replacementFnc);\n } while (value !== evaluatedValue);\n return evaluatedValue;\n }\n value = iterativeReplace(value, this.variableRegex, variableReplacement);\n value = iterativeReplace(value, this.propRegex, propertyReplacement);\n return new Quoted(this.quote + value + this.quote, value, this.escaped, this.getIndex(), this.fileInfo());\n },\n\n compare(other) {\n // when comparing quoted strings allow the quote to differ\n if (other.type === 'Quoted' && !this.escaped && !other.escaped) {\n return Node.numericCompare(this.value, other.value);\n } else {\n return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined;\n }\n }\n});\n\nexport default Quoted;\n","import Node from './node';\n\nfunction escapePath(path) {\n return path.replace(/[\\(\\)'\"\\s]/g, function(match) { return `\\\\${match}`; });\n}\n\nconst URL = function(val, index, currentFileInfo, isEvald) {\n this.value = val;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.isEvald = isEvald;\n};\n\nURL.prototype = Object.assign(new Node(), {\n type: 'Url',\n\n accept(visitor) {\n this.value = visitor.visit(this.value);\n },\n\n genCSS(context, output) {\n output.add('url(');\n this.value.genCSS(context, output);\n output.add(')');\n },\n\n eval(context) {\n const val = this.value.eval(context);\n let rootpath;\n\n if (!this.isEvald) {\n // Add the rootpath if the URL requires a rewrite\n rootpath = this.fileInfo() && this.fileInfo().rootpath;\n if (typeof rootpath === 'string' &&\n typeof val.value === 'string' &&\n context.pathRequiresRewrite(val.value)) {\n if (!val.quote) {\n rootpath = escapePath(rootpath);\n }\n val.value = context.rewritePath(val.value, rootpath);\n } else {\n val.value = context.normalizePath(val.value);\n }\n\n // Add url args if enabled\n if (context.urlArgs) {\n if (!val.value.match(/^\\s*data:/)) {\n const delimiter = val.value.indexOf('?') === -1 ? '?' : '&';\n const urlArgs = delimiter + context.urlArgs;\n if (val.value.indexOf('#') !== -1) {\n val.value = val.value.replace('#', `${urlArgs}#`);\n } else {\n val.value += urlArgs;\n }\n }\n }\n }\n\n return new URL(val, this.getIndex(), this.fileInfo(), true);\n }\n});\n\nexport default URL;\n","import Ruleset from './ruleset';\nimport Value from './value';\nimport Selector from './selector';\nimport Anonymous from './anonymous';\nimport Expression from './expression';\nimport AtRule from './atrule';\nimport * as utils from '../utils';\n\nconst Media = function(value, features, index, currentFileInfo, visibilityInfo) {\n this._index = index;\n this._fileInfo = currentFileInfo;\n\n const selectors = (new Selector([], null, null, this._index, this._fileInfo)).createEmptySelectors();\n\n this.features = new Value(features);\n this.rules = [new Ruleset(selectors, value)];\n this.rules[0].allowImports = true;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n this.setParent(selectors, this);\n this.setParent(this.features, this);\n this.setParent(this.rules, this);\n};\n\nMedia.prototype = Object.assign(new AtRule(), {\n type: 'Media',\n\n isRulesetLike() {\n return true;\n },\n\n accept(visitor) {\n if (this.features) {\n this.features = visitor.visit(this.features);\n }\n if (this.rules) {\n this.rules = visitor.visitArray(this.rules);\n }\n },\n\n genCSS(context, output) {\n output.add('@media ', this._fileInfo, this._index);\n this.features.genCSS(context, output);\n this.outputRuleset(context, output, this.rules);\n },\n\n eval(context) {\n if (!context.mediaBlocks) {\n context.mediaBlocks = [];\n context.mediaPath = [];\n }\n\n const media = new Media(null, [], this._index, this._fileInfo, this.visibilityInfo());\n if (this.debugInfo) {\n this.rules[0].debugInfo = this.debugInfo;\n media.debugInfo = this.debugInfo;\n }\n \n media.features = this.features.eval(context);\n\n context.mediaPath.push(media);\n context.mediaBlocks.push(media);\n\n this.rules[0].functionRegistry = context.frames[0].functionRegistry.inherit();\n context.frames.unshift(this.rules[0]);\n media.rules = [this.rules[0].eval(context)];\n context.frames.shift();\n\n context.mediaPath.pop();\n\n return context.mediaPath.length === 0 ? media.evalTop(context) :\n media.evalNested(context);\n },\n\n evalTop(context) {\n let result = this;\n\n // Render all dependent Media blocks.\n if (context.mediaBlocks.length > 1) {\n const selectors = (new Selector([], null, null, this.getIndex(), this.fileInfo())).createEmptySelectors();\n result = new Ruleset(selectors, context.mediaBlocks);\n result.multiMedia = true;\n result.copyVisibilityInfo(this.visibilityInfo());\n this.setParent(result, this);\n }\n\n delete context.mediaBlocks;\n delete context.mediaPath;\n\n return result;\n },\n\n evalNested(context) {\n let i;\n let value;\n const path = context.mediaPath.concat([this]);\n\n // Extract the media-query conditions separated with `,` (OR).\n for (i = 0; i < path.length; i++) {\n value = path[i].features instanceof Value ?\n path[i].features.value : path[i].features;\n path[i] = Array.isArray(value) ? value : [value];\n }\n\n // Trace all permutations to generate the resulting media-query.\n //\n // (a, b and c) with nested (d, e) ->\n // a and d\n // a and e\n // b and c and d\n // b and c and e\n this.features = new Value(this.permute(path).map(path => {\n path = path.map(fragment => fragment.toCSS ? fragment : new Anonymous(fragment));\n\n for (i = path.length - 1; i > 0; i--) {\n path.splice(i, 0, new Anonymous('and'));\n }\n\n return new Expression(path);\n }));\n this.setParent(this.features, this);\n\n // Fake a tree-node that doesn't output anything.\n return new Ruleset([], []);\n },\n\n permute(arr) {\n if (arr.length === 0) {\n return [];\n } else if (arr.length === 1) {\n return arr[0];\n } else {\n const result = [];\n const rest = this.permute(arr.slice(1));\n for (let i = 0; i < rest.length; i++) {\n for (let j = 0; j < arr[0].length; j++) {\n result.push([arr[0][j]].concat(rest[i]));\n }\n }\n return result;\n }\n },\n\n bubbleSelectors(selectors) {\n if (!selectors) {\n return;\n }\n this.rules = [new Ruleset(utils.copyArray(selectors), [this.rules[0]])];\n this.setParent(this.rules, this);\n }\n});\n\nexport default Media;\n","import Node from './node';\nimport Media from './media';\nimport URL from './url';\nimport Quoted from './quoted';\nimport Ruleset from './ruleset';\nimport Anonymous from './anonymous';\nimport * as utils from '../utils';\nimport LessError from '../less-error';\n\n//\n// CSS @import node\n//\n// The general strategy here is that we don't want to wait\n// for the parsing to be completed, before we start importing\n// the file. That's because in the context of a browser,\n// most of the time will be spent waiting for the server to respond.\n//\n// On creation, we push the import path to our import queue, though\n// `import,push`, we also pass it a callback, which it'll call once\n// the file has been fetched, and parsed.\n//\nconst Import = function(path, features, options, index, currentFileInfo, visibilityInfo) {\n this.options = options;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.path = path;\n this.features = features;\n this.allowRoot = true;\n\n if (this.options.less !== undefined || this.options.inline) {\n this.css = !this.options.less || this.options.inline;\n } else {\n const pathValue = this.getPath();\n if (pathValue && /[#\\.\\&\\?]css([\\?;].*)?$/.test(pathValue)) {\n this.css = true;\n }\n }\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.features, this);\n this.setParent(this.path, this);\n};\n\nImport.prototype = Object.assign(new Node(), {\n type: 'Import',\n\n accept(visitor) {\n if (this.features) {\n this.features = visitor.visit(this.features);\n }\n this.path = visitor.visit(this.path);\n if (!this.options.isPlugin && !this.options.inline && this.root) {\n this.root = visitor.visit(this.root);\n }\n },\n\n genCSS(context, output) {\n if (this.css && this.path._fileInfo.reference === undefined) {\n output.add('@import ', this._fileInfo, this._index);\n this.path.genCSS(context, output);\n if (this.features) {\n output.add(' ');\n this.features.genCSS(context, output);\n }\n output.add(';');\n }\n },\n\n getPath() {\n return (this.path instanceof URL) ?\n this.path.value.value : this.path.value;\n },\n\n isVariableImport() {\n let path = this.path;\n if (path instanceof URL) {\n path = path.value;\n }\n if (path instanceof Quoted) {\n return path.containsVariables();\n }\n\n return true;\n },\n\n evalForImport(context) {\n let path = this.path;\n\n if (path instanceof URL) {\n path = path.value;\n }\n\n return new Import(path.eval(context), this.features, this.options, this._index, this._fileInfo, this.visibilityInfo());\n },\n\n evalPath(context) {\n const path = this.path.eval(context);\n const fileInfo = this._fileInfo;\n\n if (!(path instanceof URL)) {\n // Add the rootpath if the URL requires a rewrite\n const pathValue = path.value;\n if (fileInfo &&\n pathValue &&\n context.pathRequiresRewrite(pathValue)) {\n path.value = context.rewritePath(pathValue, fileInfo.rootpath);\n } else {\n path.value = context.normalizePath(path.value);\n }\n }\n\n return path;\n },\n\n eval(context) {\n const result = this.doEval(context);\n if (this.options.reference || this.blocksVisibility()) {\n if (result.length || result.length === 0) {\n result.forEach(function (node) {\n node.addVisibilityBlock();\n }\n );\n } else {\n result.addVisibilityBlock();\n }\n }\n return result;\n },\n\n doEval(context) {\n let ruleset;\n let registry;\n const features = this.features && this.features.eval(context);\n\n if (this.options.isPlugin) {\n if (this.root && this.root.eval) {\n try {\n this.root.eval(context);\n }\n catch (e) {\n e.message = 'Plugin error during evaluation';\n throw new LessError(e, this.root.imports, this.root.filename);\n }\n }\n registry = context.frames[0] && context.frames[0].functionRegistry;\n if ( registry && this.root && this.root.functions ) {\n registry.addMultiple( this.root.functions );\n }\n\n return [];\n }\n\n if (this.skip) {\n if (typeof this.skip === 'function') {\n this.skip = this.skip();\n }\n if (this.skip) {\n return [];\n }\n }\n if (this.options.inline) {\n const contents = new Anonymous(this.root, 0,\n {\n filename: this.importedFilename,\n reference: this.path._fileInfo && this.path._fileInfo.reference\n }, true, true);\n\n return this.features ? new Media([contents], this.features.value) : [contents];\n } else if (this.css) {\n const newImport = new Import(this.evalPath(context), features, this.options, this._index);\n if (!newImport.css && this.error) {\n throw this.error;\n }\n return newImport;\n } else if (this.root) {\n ruleset = new Ruleset(null, utils.copyArray(this.root.rules));\n ruleset.evalImports(context);\n\n return this.features ? new Media(ruleset.rules, this.features.value) : ruleset.rules;\n } else {\n return [];\n }\n }\n});\n\nexport default Import;\n","import Node from './node';\nimport Variable from './variable';\n\nconst JsEvalNode = function() {};\n\nJsEvalNode.prototype = Object.assign(new Node(), {\n evaluateJavaScript(expression, context) {\n let result;\n const that = this;\n const evalContext = {};\n\n if (!context.javascriptEnabled) {\n throw { message: 'Inline JavaScript is not enabled. Is it set in your options?',\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n expression = expression.replace(/@\\{([\\w-]+)\\}/g, function (_, name) {\n return that.jsify(new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context));\n });\n\n try {\n expression = new Function(`return (${expression})`);\n } catch (e) {\n throw { message: `JavaScript evaluation error: ${e.message} from \\`${expression}\\`` ,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n const variables = context.frames[0].variables();\n for (const k in variables) {\n if (variables.hasOwnProperty(k)) {\n /* jshint loopfunc:true */\n evalContext[k.slice(1)] = {\n value: variables[k].value,\n toJS: function () {\n return this.value.eval(context).toCSS();\n }\n };\n }\n }\n\n try {\n result = expression.call(evalContext);\n } catch (e) {\n throw { message: `JavaScript evaluation error: '${e.name}: ${e.message.replace(/[\"]/g, '\\'')}'` ,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n return result;\n },\n\n jsify(obj) {\n if (Array.isArray(obj.value) && (obj.value.length > 1)) {\n return `[${obj.value.map(function (v) { return v.toCSS(); }).join(', ')}]`;\n } else {\n return obj.toCSS();\n }\n }\n});\n\nexport default JsEvalNode;\n","import JsEvalNode from './js-eval-node';\nimport Dimension from './dimension';\nimport Quoted from './quoted';\nimport Anonymous from './anonymous';\n\nconst JavaScript = function(string, escaped, index, currentFileInfo) {\n this.escaped = escaped;\n this.expression = string;\n this._index = index;\n this._fileInfo = currentFileInfo;\n}\n\nJavaScript.prototype = Object.assign(new JsEvalNode(), {\n type: 'JavaScript',\n\n eval(context) {\n const result = this.evaluateJavaScript(this.expression, context);\n const type = typeof result;\n\n if (type === 'number' && !isNaN(result)) {\n return new Dimension(result);\n } else if (type === 'string') {\n return new Quoted(`\"${result}\"`, result, this.escaped, this._index);\n } else if (Array.isArray(result)) {\n return new Anonymous(result.join(', '));\n } else {\n return new Anonymous(result);\n }\n }\n});\n\nexport default JavaScript;\n","import Node from './node';\n\nconst Assignment = function(key, val) {\n this.key = key;\n this.value = val;\n}\n\nAssignment.prototype = Object.assign(new Node(), {\n type: 'Assignment',\n\n accept(visitor) {\n this.value = visitor.visit(this.value);\n },\n\n eval(context) {\n if (this.value.eval) {\n return new Assignment(this.key, this.value.eval(context));\n }\n return this;\n },\n\n genCSS(context, output) {\n output.add(`${this.key}=`);\n if (this.value.genCSS) {\n this.value.genCSS(context, output);\n } else {\n output.add(this.value);\n }\n }\n});\n\nexport default Assignment;\n","import Node from './node';\n\nconst Condition = function(op, l, r, i, negate) {\n this.op = op.trim();\n this.lvalue = l;\n this.rvalue = r;\n this._index = i;\n this.negate = negate;\n};\n\nCondition.prototype = Object.assign(new Node(), {\n type: 'Condition',\n\n accept(visitor) {\n this.lvalue = visitor.visit(this.lvalue);\n this.rvalue = visitor.visit(this.rvalue);\n },\n\n eval(context) {\n const result = (function (op, a, b) {\n switch (op) {\n case 'and': return a && b;\n case 'or': return a || b;\n default:\n switch (Node.compare(a, b)) {\n case -1:\n return op === '<' || op === '=<' || op === '<=';\n case 0:\n return op === '=' || op === '>=' || op === '=<' || op === '<=';\n case 1:\n return op === '>' || op === '>=';\n default:\n return false;\n }\n }\n })(this.op, this.lvalue.eval(context), this.rvalue.eval(context));\n\n return this.negate ? !result : result;\n }\n});\n\nexport default Condition;\n","import Node from './node';\n\nconst UnicodeDescriptor = function(value) {\n this.value = value;\n}\n\nUnicodeDescriptor.prototype = Object.assign(new Node(), {\n type: 'UnicodeDescriptor'\n})\n\nexport default UnicodeDescriptor;\n","import Node from './node';\nimport Operation from './operation';\nimport Dimension from './dimension';\n\nconst Negative = function(node) {\n this.value = node;\n};\n\nNegative.prototype = Object.assign(new Node(), {\n type: 'Negative',\n\n genCSS(context, output) {\n output.add('-');\n this.value.genCSS(context, output);\n },\n\n eval(context) {\n if (context.isMathOn()) {\n return (new Operation('*', [new Dimension(-1), this.value])).eval(context);\n }\n return new Negative(this.value.eval(context));\n }\n});\n\nexport default Negative;\n","import Node from './node';\nimport Selector from './selector';\n\nconst Extend = function(selector, option, index, currentFileInfo, visibilityInfo) {\n this.selector = selector;\n this.option = option;\n this.object_id = Extend.next_id++;\n this.parent_ids = [this.object_id];\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n\n switch (option) {\n case 'all':\n this.allowBefore = true;\n this.allowAfter = true;\n break;\n default:\n this.allowBefore = false;\n this.allowAfter = false;\n break;\n }\n this.setParent(this.selector, this);\n};\n\nExtend.prototype = Object.assign(new Node(), {\n type: 'Extend',\n\n accept(visitor) {\n this.selector = visitor.visit(this.selector);\n },\n\n eval(context) {\n return new Extend(this.selector.eval(context), this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n },\n\n clone(context) {\n return new Extend(this.selector, this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n },\n\n // it concatenates (joins) all selectors in selector array\n findSelfSelectors(selectors) {\n let selfElements = [], i, selectorElements;\n\n for (i = 0; i < selectors.length; i++) {\n selectorElements = selectors[i].elements;\n // duplicate the logic in genCSS function inside the selector node.\n // future TODO - move both logics into the selector joiner visitor\n if (i > 0 && selectorElements.length && selectorElements[0].combinator.value === '') {\n selectorElements[0].combinator.value = ' ';\n }\n selfElements = selfElements.concat(selectors[i].elements);\n }\n\n this.selfSelectors = [new Selector(selfElements)];\n this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo());\n }\n});\n\nExtend.next_id = 0;\nexport default Extend;\n","import Node from './node';\nimport Variable from './variable';\nimport Ruleset from './ruleset';\nimport DetachedRuleset from './detached-ruleset';\nimport LessError from '../less-error';\n\nconst VariableCall = function(variable, index, currentFileInfo) {\n this.variable = variable;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.allowRoot = true;\n};\n\nVariableCall.prototype = Object.assign(new Node(), {\n type: 'VariableCall',\n\n eval(context) {\n let rules;\n let detachedRuleset = new Variable(this.variable, this.getIndex(), this.fileInfo()).eval(context);\n const error = new LessError({message: `Could not evaluate variable call ${this.variable}`});\n\n if (!detachedRuleset.ruleset) {\n if (detachedRuleset.rules) {\n rules = detachedRuleset;\n }\n else if (Array.isArray(detachedRuleset)) {\n rules = new Ruleset('', detachedRuleset);\n }\n else if (Array.isArray(detachedRuleset.value)) {\n rules = new Ruleset('', detachedRuleset.value);\n }\n else {\n throw error;\n }\n detachedRuleset = new DetachedRuleset(rules);\n }\n\n if (detachedRuleset.ruleset) {\n return detachedRuleset.callEval(context);\n }\n throw error;\n }\n});\n\nexport default VariableCall;\n","import Node from './node';\nimport Variable from './variable';\nimport Ruleset from './ruleset';\nimport Selector from './selector';\n\nconst NamespaceValue = function(ruleCall, lookups, index, fileInfo) {\n this.value = ruleCall;\n this.lookups = lookups;\n this._index = index;\n this._fileInfo = fileInfo;\n};\n\nNamespaceValue.prototype = Object.assign(new Node(), {\n type: 'NamespaceValue',\n\n eval(context) {\n let i, j, name, rules = this.value.eval(context);\n \n for (i = 0; i < this.lookups.length; i++) {\n name = this.lookups[i];\n\n /**\n * Eval'd DRs return rulesets.\n * Eval'd mixins return rules, so let's make a ruleset if we need it.\n * We need to do this because of late parsing of values\n */\n if (Array.isArray(rules)) {\n rules = new Ruleset([new Selector()], rules);\n }\n\n if (name === '') {\n rules = rules.lastDeclaration();\n }\n else if (name.charAt(0) === '@') {\n if (name.charAt(1) === '@') {\n name = `@${new Variable(name.substr(1)).eval(context).value}`;\n }\n if (rules.variables) {\n rules = rules.variable(name);\n }\n \n if (!rules) {\n throw { type: 'Name',\n message: `variable ${name} not found`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n }\n else {\n if (name.substring(0, 2) === '$@') {\n name = `$${new Variable(name.substr(1)).eval(context).value}`;\n }\n else {\n name = name.charAt(0) === '$' ? name : `$${name}`;\n }\n if (rules.properties) {\n rules = rules.property(name);\n }\n \n if (!rules) {\n throw { type: 'Name',\n message: `property \"${name.substr(1)}\" not found`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n // Properties are an array of values, since a ruleset can have multiple props.\n // We pick the last one (the \"cascaded\" value)\n rules = rules[rules.length - 1];\n }\n\n if (rules.value) {\n rules = rules.eval(context).value;\n }\n if (rules.ruleset) {\n rules = rules.ruleset.eval(context);\n }\n }\n return rules;\n }\n});\n\nexport default NamespaceValue;\n","import Selector from './selector';\nimport Element from './element';\nimport Ruleset from './ruleset';\nimport Declaration from './declaration';\nimport DetachedRuleset from './detached-ruleset';\nimport Expression from './expression';\nimport contexts from '../contexts';\nimport * as utils from '../utils';\n\nconst Definition = function(name, params, rules, condition, variadic, frames, visibilityInfo) {\n this.name = name || 'anonymous mixin';\n this.selectors = [new Selector([new Element(null, name, false, this._index, this._fileInfo)])];\n this.params = params;\n this.condition = condition;\n this.variadic = variadic;\n this.arity = params.length;\n this.rules = rules;\n this._lookups = {};\n const optionalParameters = [];\n this.required = params.reduce(function (count, p) {\n if (!p.name || (p.name && !p.value)) {\n return count + 1;\n }\n else {\n optionalParameters.push(p.name);\n return count;\n }\n }, 0);\n this.optionalParameters = optionalParameters;\n this.frames = frames;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n}\n\nDefinition.prototype = Object.assign(new Ruleset(), {\n type: 'MixinDefinition',\n evalFirst: true,\n\n accept(visitor) {\n if (this.params && this.params.length) {\n this.params = visitor.visitArray(this.params);\n }\n this.rules = visitor.visitArray(this.rules);\n if (this.condition) {\n this.condition = visitor.visit(this.condition);\n }\n },\n\n evalParams(context, mixinEnv, args, evaldArguments) {\n /* jshint boss:true */\n const frame = new Ruleset(null, null);\n\n let varargs;\n let arg;\n const params = utils.copyArray(this.params);\n let i;\n let j;\n let val;\n let name;\n let isNamedFound;\n let argIndex;\n let argsLength = 0;\n\n if (mixinEnv.frames && mixinEnv.frames[0] && mixinEnv.frames[0].functionRegistry) {\n frame.functionRegistry = mixinEnv.frames[0].functionRegistry.inherit();\n }\n mixinEnv = new contexts.Eval(mixinEnv, [frame].concat(mixinEnv.frames));\n\n if (args) {\n args = utils.copyArray(args);\n argsLength = args.length;\n\n for (i = 0; i < argsLength; i++) {\n arg = args[i];\n if (name = (arg && arg.name)) {\n isNamedFound = false;\n for (j = 0; j < params.length; j++) {\n if (!evaldArguments[j] && name === params[j].name) {\n evaldArguments[j] = arg.value.eval(context);\n frame.prependRule(new Declaration(name, arg.value.eval(context)));\n isNamedFound = true;\n break;\n }\n }\n if (isNamedFound) {\n args.splice(i, 1);\n i--;\n continue;\n } else {\n throw { type: 'Runtime', message: `Named argument for ${this.name} ${args[i].name} not found` };\n }\n }\n }\n }\n argIndex = 0;\n for (i = 0; i < params.length; i++) {\n if (evaldArguments[i]) { continue; }\n\n arg = args && args[argIndex];\n\n if (name = params[i].name) {\n if (params[i].variadic) {\n varargs = [];\n for (j = argIndex; j < argsLength; j++) {\n varargs.push(args[j].value.eval(context));\n }\n frame.prependRule(new Declaration(name, new Expression(varargs).eval(context)));\n } else {\n val = arg && arg.value;\n if (val) {\n // This was a mixin call, pass in a detached ruleset of it's eval'd rules\n if (Array.isArray(val)) {\n val = new DetachedRuleset(new Ruleset('', val));\n }\n else {\n val = val.eval(context);\n }\n } else if (params[i].value) {\n val = params[i].value.eval(mixinEnv);\n frame.resetCache();\n } else {\n throw { type: 'Runtime', message: `wrong number of arguments for ${this.name} (${argsLength} for ${this.arity})` };\n }\n\n frame.prependRule(new Declaration(name, val));\n evaldArguments[i] = val;\n }\n }\n\n if (params[i].variadic && args) {\n for (j = argIndex; j < argsLength; j++) {\n evaldArguments[j] = args[j].value.eval(context);\n }\n }\n argIndex++;\n }\n\n return frame;\n },\n\n makeImportant() {\n const rules = !this.rules ? this.rules : this.rules.map(function (r) {\n if (r.makeImportant) {\n return r.makeImportant(true);\n } else {\n return r;\n }\n });\n const result = new Definition(this.name, this.params, rules, this.condition, this.variadic, this.frames);\n return result;\n },\n\n eval(context) {\n return new Definition(this.name, this.params, this.rules, this.condition, this.variadic, this.frames || utils.copyArray(context.frames));\n },\n\n evalCall(context, args, important) {\n const _arguments = [];\n const mixinFrames = this.frames ? this.frames.concat(context.frames) : context.frames;\n const frame = this.evalParams(context, new contexts.Eval(context, mixinFrames), args, _arguments);\n let rules;\n let ruleset;\n\n frame.prependRule(new Declaration('@arguments', new Expression(_arguments).eval(context)));\n\n rules = utils.copyArray(this.rules);\n\n ruleset = new Ruleset(null, rules);\n ruleset.originalRuleset = this;\n ruleset = ruleset.eval(new contexts.Eval(context, [this, frame].concat(mixinFrames)));\n if (important) {\n ruleset = ruleset.makeImportant();\n }\n return ruleset;\n },\n\n matchCondition(args, context) {\n if (this.condition && !this.condition.eval(\n new contexts.Eval(context,\n [this.evalParams(context, /* the parameter variables */\n new contexts.Eval(context, this.frames ? this.frames.concat(context.frames) : context.frames), args, [])]\n .concat(this.frames || []) // the parent namespace/mixin frames\n .concat(context.frames)))) { // the current environment frames\n return false;\n }\n return true;\n },\n\n matchArgs(args, context) {\n const allArgsCnt = (args && args.length) || 0;\n let len;\n const optionalParameters = this.optionalParameters;\n const requiredArgsCnt = !args ? 0 : args.reduce(function (count, p) {\n if (optionalParameters.indexOf(p.name) < 0) {\n return count + 1;\n } else {\n return count;\n }\n }, 0);\n\n if (!this.variadic) {\n if (requiredArgsCnt < this.required) {\n return false;\n }\n if (allArgsCnt > this.params.length) {\n return false;\n }\n } else {\n if (requiredArgsCnt < (this.required - 1)) {\n return false;\n }\n }\n\n // check patterns\n len = Math.min(requiredArgsCnt, this.arity);\n\n for (let i = 0; i < len; i++) {\n if (!this.params[i].name && !this.params[i].variadic) {\n if (args[i].value.eval(context).toCSS() != this.params[i].value.eval(context).toCSS()) {\n return false;\n }\n }\n }\n return true;\n }\n});\n\nexport default Definition;\n","import Node from './node';\nimport Selector from './selector';\nimport MixinDefinition from './mixin-definition';\nimport defaultFunc from '../functions/default';\n\nconst MixinCall = function(elements, args, index, currentFileInfo, important) {\n this.selector = new Selector(elements);\n this.arguments = args || [];\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.important = important;\n this.allowRoot = true;\n this.setParent(this.selector, this);\n};\n\nMixinCall.prototype = Object.assign(new Node(), {\n type: 'MixinCall',\n\n accept(visitor) {\n if (this.selector) {\n this.selector = visitor.visit(this.selector);\n }\n if (this.arguments.length) {\n this.arguments = visitor.visitArray(this.arguments);\n }\n },\n\n eval(context) {\n let mixins;\n let mixin;\n let mixinPath;\n const args = [];\n let arg;\n let argValue;\n const rules = [];\n let match = false;\n let i;\n let m;\n let f;\n let isRecursive;\n let isOneFound;\n const candidates = [];\n let candidate;\n const conditionResult = [];\n let defaultResult;\n const defFalseEitherCase = -1;\n const defNone = 0;\n const defTrue = 1;\n const defFalse = 2;\n let count;\n let originalRuleset;\n let noArgumentsFilter;\n\n this.selector = this.selector.eval(context);\n\n function calcDefGroup(mixin, mixinPath) {\n let f, p, namespace;\n\n for (f = 0; f < 2; f++) {\n conditionResult[f] = true;\n defaultFunc.value(f);\n for (p = 0; p < mixinPath.length && conditionResult[f]; p++) {\n namespace = mixinPath[p];\n if (namespace.matchCondition) {\n conditionResult[f] = conditionResult[f] && namespace.matchCondition(null, context);\n }\n }\n if (mixin.matchCondition) {\n conditionResult[f] = conditionResult[f] && mixin.matchCondition(args, context);\n }\n }\n if (conditionResult[0] || conditionResult[1]) {\n if (conditionResult[0] != conditionResult[1]) {\n return conditionResult[1] ?\n defTrue : defFalse;\n }\n\n return defNone;\n }\n return defFalseEitherCase;\n }\n\n for (i = 0; i < this.arguments.length; i++) {\n arg = this.arguments[i];\n argValue = arg.value.eval(context);\n if (arg.expand && Array.isArray(argValue.value)) {\n argValue = argValue.value;\n for (m = 0; m < argValue.length; m++) {\n args.push({value: argValue[m]});\n }\n } else {\n args.push({name: arg.name, value: argValue});\n }\n }\n\n noArgumentsFilter = function(rule) {return rule.matchArgs(null, context);};\n\n for (i = 0; i < context.frames.length; i++) {\n if ((mixins = context.frames[i].find(this.selector, null, noArgumentsFilter)).length > 0) {\n isOneFound = true;\n\n // To make `default()` function independent of definition order we have two \"subpasses\" here.\n // At first we evaluate each guard *twice* (with `default() == true` and `default() == false`),\n // and build candidate list with corresponding flags. Then, when we know all possible matches,\n // we make a final decision.\n\n for (m = 0; m < mixins.length; m++) {\n mixin = mixins[m].rule;\n mixinPath = mixins[m].path;\n isRecursive = false;\n for (f = 0; f < context.frames.length; f++) {\n if ((!(mixin instanceof MixinDefinition)) && mixin === (context.frames[f].originalRuleset || context.frames[f])) {\n isRecursive = true;\n break;\n }\n }\n if (isRecursive) {\n continue;\n }\n\n if (mixin.matchArgs(args, context)) {\n candidate = {mixin, group: calcDefGroup(mixin, mixinPath)};\n\n if (candidate.group !== defFalseEitherCase) {\n candidates.push(candidate);\n }\n\n match = true;\n }\n }\n\n defaultFunc.reset();\n\n count = [0, 0, 0];\n for (m = 0; m < candidates.length; m++) {\n count[candidates[m].group]++;\n }\n\n if (count[defNone] > 0) {\n defaultResult = defFalse;\n } else {\n defaultResult = defTrue;\n if ((count[defTrue] + count[defFalse]) > 1) {\n throw { type: 'Runtime',\n message: `Ambiguous use of \\`default()\\` found when matching for \\`${this.format(args)}\\``,\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n }\n\n for (m = 0; m < candidates.length; m++) {\n candidate = candidates[m].group;\n if ((candidate === defNone) || (candidate === defaultResult)) {\n try {\n mixin = candidates[m].mixin;\n if (!(mixin instanceof MixinDefinition)) {\n originalRuleset = mixin.originalRuleset || mixin;\n mixin = new MixinDefinition('', [], mixin.rules, null, false, null, originalRuleset.visibilityInfo());\n mixin.originalRuleset = originalRuleset;\n }\n const newRules = mixin.evalCall(context, args, this.important).rules;\n this._setVisibilityToReplacement(newRules);\n Array.prototype.push.apply(rules, newRules);\n } catch (e) {\n throw { message: e.message, index: this.getIndex(), filename: this.fileInfo().filename, stack: e.stack };\n }\n }\n }\n\n if (match) {\n return rules;\n }\n }\n }\n if (isOneFound) {\n throw { type: 'Runtime',\n message: `No matching definition was found for \\`${this.format(args)}\\``,\n index: this.getIndex(), filename: this.fileInfo().filename };\n } else {\n throw { type: 'Name',\n message: `${this.selector.toCSS().trim()} is undefined`,\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n },\n\n _setVisibilityToReplacement(replacement) {\n let i, rule;\n if (this.blocksVisibility()) {\n for (i = 0; i < replacement.length; i++) {\n rule = replacement[i];\n rule.addVisibilityBlock();\n }\n }\n },\n\n format(args) {\n return `${this.selector.toCSS().trim()}(${args ? args.map(function (a) {\n let argValue = '';\n if (a.name) {\n argValue += `${a.name}:`;\n }\n if (a.value.toCSS) {\n argValue += a.value.toCSS();\n } else {\n argValue += '???';\n }\n return argValue;\n }).join(', ') : ''})`;\n }\n});\n\nexport default MixinCall;\n","import Node from './node';\nimport Color from './color';\nimport AtRule from './atrule';\nimport DetachedRuleset from './detached-ruleset';\nimport Operation from './operation';\nimport Dimension from './dimension';\nimport Unit from './unit';\nimport Keyword from './keyword';\nimport Variable from './variable';\nimport Property from './property';\nimport Ruleset from './ruleset';\nimport Element from './element';\nimport Attribute from './attribute';\nimport Combinator from './combinator';\nimport Selector from './selector';\nimport Quoted from './quoted';\nimport Expression from './expression';\nimport Declaration from './declaration';\nimport Call from './call';\nimport URL from './url';\nimport Import from './import';\nimport Comment from './comment';\nimport Anonymous from './anonymous';\nimport Value from './value';\nimport JavaScript from './javascript';\nimport Assignment from './assignment';\nimport Condition from './condition';\nimport Paren from './paren';\nimport Media from './media';\nimport UnicodeDescriptor from './unicode-descriptor';\nimport Negative from './negative';\nimport Extend from './extend';\nimport VariableCall from './variable-call';\nimport NamespaceValue from './namespace-value';\n\n// mixins\nimport MixinCall from './mixin-call';\nimport MixinDefinition from './mixin-definition';\n\nexport default {\n Node, Color, AtRule, DetachedRuleset, Operation,\n Dimension, Unit, Keyword, Variable, Property,\n Ruleset, Element, Attribute, Combinator, Selector,\n Quoted, Expression, Declaration, Call, URL, Import,\n Comment, Anonymous, Value, JavaScript, Assignment,\n Condition, Paren, Media, UnicodeDescriptor, Negative,\n Extend, VariableCall, NamespaceValue,\n mixin: {\n Call: MixinCall,\n Definition: MixinDefinition\n }\n};","class AbstractFileManager {\n getPath(filename) {\n let j = filename.lastIndexOf('?');\n if (j > 0) {\n filename = filename.slice(0, j);\n }\n j = filename.lastIndexOf('/');\n if (j < 0) {\n j = filename.lastIndexOf('\\\\');\n }\n if (j < 0) {\n return '';\n }\n return filename.slice(0, j + 1);\n }\n\n tryAppendExtension(path, ext) {\n return /(\\.[a-z]*$)|([\\?;].*)$/.test(path) ? path : path + ext;\n }\n\n tryAppendLessExtension(path) {\n return this.tryAppendExtension(path, '.less');\n }\n\n supportsSync() {\n return false;\n }\n\n alwaysMakePathsAbsolute() {\n return false;\n }\n\n isPathAbsolute(filename) {\n return (/^(?:[a-z-]+:|\\/|\\\\|#)/i).test(filename);\n }\n\n // TODO: pull out / replace?\n join(basePath, laterPath) {\n if (!basePath) {\n return laterPath;\n }\n return basePath + laterPath;\n }\n\n pathDiff(url, baseUrl) {\n // diff between two paths to create a relative path\n\n const urlParts = this.extractUrlParts(url);\n\n const baseUrlParts = this.extractUrlParts(baseUrl);\n let i;\n let max;\n let urlDirectories;\n let baseUrlDirectories;\n let diff = '';\n if (urlParts.hostPart !== baseUrlParts.hostPart) {\n return '';\n }\n max = Math.max(baseUrlParts.directories.length, urlParts.directories.length);\n for (i = 0; i < max; i++) {\n if (baseUrlParts.directories[i] !== urlParts.directories[i]) { break; }\n }\n baseUrlDirectories = baseUrlParts.directories.slice(i);\n urlDirectories = urlParts.directories.slice(i);\n for (i = 0; i < baseUrlDirectories.length - 1; i++) {\n diff += '../';\n }\n for (i = 0; i < urlDirectories.length - 1; i++) {\n diff += `${urlDirectories[i]}/`;\n }\n return diff;\n }\n\n // helper function, not part of API\n extractUrlParts(url, baseUrl) {\n // urlParts[1] = protocol://hostname/ OR /\n // urlParts[2] = / if path relative to host base\n // urlParts[3] = directories\n // urlParts[4] = filename\n // urlParts[5] = parameters\n\n const urlPartsRegex = /^((?:[a-z-]+:)?\\/{2}(?:[^\\/\\?#]*\\/)|([\\/\\\\]))?((?:[^\\/\\\\\\?#]*[\\/\\\\])*)([^\\/\\\\\\?#]*)([#\\?].*)?$/i;\n\n const urlParts = url.match(urlPartsRegex);\n const returner = {};\n let rawDirectories = [];\n const directories = [];\n let i;\n let baseUrlParts;\n\n if (!urlParts) {\n throw new Error(`Could not parse sheet href - '${url}'`);\n }\n\n // Stylesheets in IE don't always return the full path\n if (baseUrl && (!urlParts[1] || urlParts[2])) {\n baseUrlParts = baseUrl.match(urlPartsRegex);\n if (!baseUrlParts) {\n throw new Error(`Could not parse page url - '${baseUrl}'`);\n }\n urlParts[1] = urlParts[1] || baseUrlParts[1] || '';\n if (!urlParts[2]) {\n urlParts[3] = baseUrlParts[3] + urlParts[3];\n }\n }\n\n if (urlParts[3]) {\n rawDirectories = urlParts[3].replace(/\\\\/g, '/').split('/');\n\n // collapse '..' and skip '.'\n for (i = 0; i < rawDirectories.length; i++) {\n\n if (rawDirectories[i] === '..') {\n directories.pop();\n }\n else if (rawDirectories[i] !== '.') {\n directories.push(rawDirectories[i]);\n }\n \n }\n }\n\n returner.hostPart = urlParts[1];\n returner.directories = directories;\n returner.rawPath = (urlParts[1] || '') + rawDirectories.join('/');\n returner.path = (urlParts[1] || '') + directories.join('/');\n returner.filename = urlParts[4];\n returner.fileUrl = returner.path + (urlParts[4] || '');\n returner.url = returner.fileUrl + (urlParts[5] || '');\n return returner;\n }\n}\n\nexport default AbstractFileManager;\n","import functionRegistry from '../functions/function-registry';\nimport LessError from '../less-error';\n\nclass AbstractPluginLoader {\n constructor() {\n // Implemented by Node.js plugin loader\n this.require = function() {\n return null;\n }\n }\n\n evalPlugin(contents, context, imports, pluginOptions, fileInfo) {\n\n let loader, registry, pluginObj, localModule, pluginManager, filename, result;\n\n pluginManager = context.pluginManager;\n\n if (fileInfo) {\n if (typeof fileInfo === 'string') {\n filename = fileInfo;\n }\n else {\n filename = fileInfo.filename;\n }\n }\n const shortname = (new this.less.FileManager()).extractUrlParts(filename).filename;\n\n if (filename) {\n pluginObj = pluginManager.get(filename);\n\n if (pluginObj) {\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n if (result) {\n return result;\n }\n try {\n if (pluginObj.use) {\n pluginObj.use.call(this.context, pluginObj);\n }\n }\n catch (e) {\n e.message = e.message || 'Error during @plugin call';\n return new LessError(e, imports, filename);\n }\n return pluginObj;\n }\n }\n localModule = {\n exports: {},\n pluginManager,\n fileInfo\n };\n registry = functionRegistry.create();\n\n const registerPlugin = function(obj) {\n pluginObj = obj;\n };\n\n try {\n loader = new Function('module', 'require', 'registerPlugin', 'functions', 'tree', 'less', 'fileInfo', contents);\n loader(localModule, this.require(filename), registerPlugin, registry, this.less.tree, this.less, fileInfo);\n }\n catch (e) {\n return new LessError(e, imports, filename);\n }\n\n if (!pluginObj) {\n pluginObj = localModule.exports;\n }\n pluginObj = this.validatePlugin(pluginObj, filename, shortname);\n\n if (pluginObj instanceof LessError) {\n return pluginObj;\n }\n\n if (pluginObj) {\n pluginObj.imports = imports;\n pluginObj.filename = filename;\n\n // For < 3.x (or unspecified minVersion) - setOptions() before install()\n if (!pluginObj.minVersion || this.compareVersion('3.0.0', pluginObj.minVersion) < 0) {\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n\n if (result) {\n return result;\n }\n }\n\n // Run on first load\n pluginManager.addPlugin(pluginObj, fileInfo.filename, registry);\n pluginObj.functions = registry.getLocalFunctions();\n\n // Need to call setOptions again because the pluginObj might have functions\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n if (result) {\n return result;\n }\n\n // Run every @plugin call\n try {\n if (pluginObj.use) {\n pluginObj.use.call(this.context, pluginObj);\n }\n }\n catch (e) {\n e.message = e.message || 'Error during @plugin call';\n return new LessError(e, imports, filename);\n }\n\n }\n else {\n return new LessError({ message: 'Not a valid plugin' }, imports, filename);\n }\n\n return pluginObj;\n\n }\n\n trySetOptions(plugin, filename, name, options) {\n if (options && !plugin.setOptions) {\n return new LessError({\n message: `Options have been provided but the plugin ${name} does not support any options.`\n });\n }\n try {\n plugin.setOptions && plugin.setOptions(options);\n }\n catch (e) {\n return new LessError(e);\n }\n }\n\n validatePlugin(plugin, filename, name) {\n if (plugin) {\n // support plugins being a function\n // so that the plugin can be more usable programmatically\n if (typeof plugin === 'function') {\n plugin = new plugin();\n }\n\n if (plugin.minVersion) {\n if (this.compareVersion(plugin.minVersion, this.less.version) < 0) {\n return new LessError({\n message: `Plugin ${name} requires version ${this.versionToString(plugin.minVersion)}`\n });\n }\n }\n return plugin;\n }\n return null;\n }\n\n compareVersion(aVersion, bVersion) {\n if (typeof aVersion === 'string') {\n aVersion = aVersion.match(/^(\\d+)\\.?(\\d+)?\\.?(\\d+)?/);\n aVersion.shift();\n }\n for (let i = 0; i < aVersion.length; i++) {\n if (aVersion[i] !== bVersion[i]) {\n return parseInt(aVersion[i]) > parseInt(bVersion[i]) ? -1 : 1;\n }\n }\n return 0;\n }\n\n versionToString(version) {\n let versionString = '';\n for (let i = 0; i < version.length; i++) {\n versionString += (versionString ? '.' : '') + version[i];\n }\n return versionString;\n }\n\n printUsage(plugins) {\n for (let i = 0; i < plugins.length; i++) {\n const plugin = plugins[i];\n if (plugin.printUsage) {\n plugin.printUsage();\n }\n }\n }\n}\n\nexport default AbstractPluginLoader;\n\n","import tree from '../tree';\n\nconst _visitArgs = { visitDeeper: true };\nlet _hasIndexed = false;\n\nfunction _noop(node) {\n return node;\n}\n\nfunction indexNodeTypes(parent, ticker) {\n // add .typeIndex to tree node types for lookup table\n let key, child;\n for (key in parent) { \n /* eslint guard-for-in: 0 */\n child = parent[key];\n switch (typeof child) {\n case 'function':\n // ignore bound functions directly on tree which do not have a prototype\n // or aren't nodes\n if (child.prototype && child.prototype.type) {\n child.prototype.typeIndex = ticker++;\n }\n break;\n case 'object':\n ticker = indexNodeTypes(child, ticker);\n break;\n \n }\n }\n return ticker;\n}\n\nclass Visitor {\n constructor(implementation) {\n this._implementation = implementation;\n this._visitInCache = {};\n this._visitOutCache = {};\n\n if (!_hasIndexed) {\n indexNodeTypes(tree, 1);\n _hasIndexed = true;\n }\n }\n\n visit(node) {\n if (!node) {\n return node;\n }\n\n const nodeTypeIndex = node.typeIndex;\n if (!nodeTypeIndex) {\n // MixinCall args aren't a node type?\n if (node.value && node.value.typeIndex) {\n this.visit(node.value);\n }\n return node;\n }\n\n const impl = this._implementation;\n let func = this._visitInCache[nodeTypeIndex];\n let funcOut = this._visitOutCache[nodeTypeIndex];\n const visitArgs = _visitArgs;\n let fnName;\n\n visitArgs.visitDeeper = true;\n\n if (!func) {\n fnName = `visit${node.type}`;\n func = impl[fnName] || _noop;\n funcOut = impl[`${fnName}Out`] || _noop;\n this._visitInCache[nodeTypeIndex] = func;\n this._visitOutCache[nodeTypeIndex] = funcOut;\n }\n\n if (func !== _noop) {\n const newNode = func.call(impl, node, visitArgs);\n if (node && impl.isReplacing) {\n node = newNode;\n }\n }\n\n if (visitArgs.visitDeeper && node) {\n if (node.length) {\n for (let i = 0, cnt = node.length; i < cnt; i++) {\n if (node[i].accept) {\n node[i].accept(this);\n }\n }\n } else if (node.accept) {\n node.accept(this);\n }\n }\n\n if (funcOut != _noop) {\n funcOut.call(impl, node);\n }\n\n return node;\n }\n\n visitArray(nodes, nonReplacing) {\n if (!nodes) {\n return nodes;\n }\n\n const cnt = nodes.length;\n let i;\n\n // Non-replacing\n if (nonReplacing || !this._implementation.isReplacing) {\n for (i = 0; i < cnt; i++) {\n this.visit(nodes[i]);\n }\n return nodes;\n }\n\n // Replacing\n const out = [];\n for (i = 0; i < cnt; i++) {\n const evald = this.visit(nodes[i]);\n if (evald === undefined) { continue; }\n if (!evald.splice) {\n out.push(evald);\n } else if (evald.length) {\n this.flatten(evald, out);\n }\n }\n return out;\n }\n\n flatten(arr, out) {\n if (!out) {\n out = [];\n }\n\n let cnt, i, item, nestedCnt, j, nestedItem;\n\n for (i = 0, cnt = arr.length; i < cnt; i++) {\n item = arr[i];\n if (item === undefined) {\n continue;\n }\n if (!item.splice) {\n out.push(item);\n continue;\n }\n\n for (j = 0, nestedCnt = item.length; j < nestedCnt; j++) {\n nestedItem = item[j];\n if (nestedItem === undefined) {\n continue;\n }\n if (!nestedItem.splice) {\n out.push(nestedItem);\n } else if (nestedItem.length) {\n this.flatten(nestedItem, out);\n }\n }\n }\n\n return out;\n }\n}\n\nexport default Visitor;\n","class ImportSequencer {\n constructor(onSequencerEmpty) {\n this.imports = [];\n this.variableImports = [];\n this._onSequencerEmpty = onSequencerEmpty;\n this._currentDepth = 0;\n }\n\n addImport(callback) {\n const importSequencer = this,\n importItem = {\n callback,\n args: null,\n isReady: false\n };\n this.imports.push(importItem);\n return function() {\n importItem.args = Array.prototype.slice.call(arguments, 0);\n importItem.isReady = true;\n importSequencer.tryRun();\n };\n }\n\n addVariableImport(callback) {\n this.variableImports.push(callback);\n }\n\n tryRun() {\n this._currentDepth++;\n try {\n while (true) {\n while (this.imports.length > 0) {\n const importItem = this.imports[0];\n if (!importItem.isReady) {\n return;\n }\n this.imports = this.imports.slice(1);\n importItem.callback.apply(null, importItem.args);\n }\n if (this.variableImports.length === 0) {\n break;\n }\n const variableImport = this.variableImports[0];\n this.variableImports = this.variableImports.slice(1);\n variableImport();\n }\n } finally {\n this._currentDepth--;\n }\n if (this._currentDepth === 0 && this._onSequencerEmpty) {\n this._onSequencerEmpty();\n }\n }\n}\n\nexport default ImportSequencer;\n","import contexts from '../contexts';\nimport Visitor from './visitor';\nimport ImportSequencer from './import-sequencer';\nimport * as utils from '../utils';\n\nconst ImportVisitor = function(importer, finish) {\n\n this._visitor = new Visitor(this);\n this._importer = importer;\n this._finish = finish;\n this.context = new contexts.Eval();\n this.importCount = 0;\n this.onceFileDetectionMap = {};\n this.recursionDetector = {};\n this._sequencer = new ImportSequencer(this._onSequencerEmpty.bind(this));\n};\n\nImportVisitor.prototype = {\n isReplacing: false,\n run: function (root) {\n try {\n // process the contents\n this._visitor.visit(root);\n }\n catch (e) {\n this.error = e;\n }\n\n this.isFinished = true;\n this._sequencer.tryRun();\n },\n _onSequencerEmpty: function() {\n if (!this.isFinished) {\n return;\n }\n this._finish(this.error);\n },\n visitImport: function (importNode, visitArgs) {\n const inlineCSS = importNode.options.inline;\n\n if (!importNode.css || inlineCSS) {\n\n const context = new contexts.Eval(this.context, utils.copyArray(this.context.frames));\n const importParent = context.frames[0];\n\n this.importCount++;\n if (importNode.isVariableImport()) {\n this._sequencer.addVariableImport(this.processImportNode.bind(this, importNode, context, importParent));\n } else {\n this.processImportNode(importNode, context, importParent);\n }\n }\n visitArgs.visitDeeper = false;\n },\n processImportNode: function(importNode, context, importParent) {\n let evaldImportNode;\n const inlineCSS = importNode.options.inline;\n\n try {\n evaldImportNode = importNode.evalForImport(context);\n } catch (e) {\n if (!e.filename) { e.index = importNode.getIndex(); e.filename = importNode.fileInfo().filename; }\n // attempt to eval properly and treat as css\n importNode.css = true;\n // if that fails, this error will be thrown\n importNode.error = e;\n }\n\n if (evaldImportNode && (!evaldImportNode.css || inlineCSS)) {\n\n if (evaldImportNode.options.multiple) {\n context.importMultiple = true;\n }\n\n // try appending if we haven't determined if it is css or not\n const tryAppendLessExtension = evaldImportNode.css === undefined;\n\n for (let i = 0; i < importParent.rules.length; i++) {\n if (importParent.rules[i] === importNode) {\n importParent.rules[i] = evaldImportNode;\n break;\n }\n }\n\n const onImported = this.onImported.bind(this, evaldImportNode, context), sequencedOnImported = this._sequencer.addImport(onImported);\n\n this._importer.push(evaldImportNode.getPath(), tryAppendLessExtension, evaldImportNode.fileInfo(),\n evaldImportNode.options, sequencedOnImported);\n } else {\n this.importCount--;\n if (this.isFinished) {\n this._sequencer.tryRun();\n }\n }\n },\n onImported: function (importNode, context, e, root, importedAtRoot, fullPath) {\n if (e) {\n if (!e.filename) {\n e.index = importNode.getIndex(); e.filename = importNode.fileInfo().filename;\n }\n this.error = e;\n }\n\n const importVisitor = this,\n inlineCSS = importNode.options.inline,\n isPlugin = importNode.options.isPlugin,\n isOptional = importNode.options.optional,\n duplicateImport = importedAtRoot || fullPath in importVisitor.recursionDetector;\n\n if (!context.importMultiple) {\n if (duplicateImport) {\n importNode.skip = true;\n } else {\n importNode.skip = function() {\n if (fullPath in importVisitor.onceFileDetectionMap) {\n return true;\n }\n importVisitor.onceFileDetectionMap[fullPath] = true;\n return false;\n };\n }\n }\n\n if (!fullPath && isOptional) {\n importNode.skip = true;\n }\n\n if (root) {\n importNode.root = root;\n importNode.importedFilename = fullPath;\n\n if (!inlineCSS && !isPlugin && (context.importMultiple || !duplicateImport)) {\n importVisitor.recursionDetector[fullPath] = true;\n\n const oldContext = this.context;\n this.context = context;\n try {\n this._visitor.visit(root);\n } catch (e) {\n this.error = e;\n }\n this.context = oldContext;\n }\n }\n\n importVisitor.importCount--;\n\n if (importVisitor.isFinished) {\n importVisitor._sequencer.tryRun();\n }\n },\n visitDeclaration: function (declNode, visitArgs) {\n if (declNode.value.type === 'DetachedRuleset') {\n this.context.frames.unshift(declNode);\n } else {\n visitArgs.visitDeeper = false;\n }\n },\n visitDeclarationOut: function(declNode) {\n if (declNode.value.type === 'DetachedRuleset') {\n this.context.frames.shift();\n }\n },\n visitAtRule: function (atRuleNode, visitArgs) {\n this.context.frames.unshift(atRuleNode);\n },\n visitAtRuleOut: function (atRuleNode) {\n this.context.frames.shift();\n },\n visitMixinDefinition: function (mixinDefinitionNode, visitArgs) {\n this.context.frames.unshift(mixinDefinitionNode);\n },\n visitMixinDefinitionOut: function (mixinDefinitionNode) {\n this.context.frames.shift();\n },\n visitRuleset: function (rulesetNode, visitArgs) {\n this.context.frames.unshift(rulesetNode);\n },\n visitRulesetOut: function (rulesetNode) {\n this.context.frames.shift();\n },\n visitMedia: function (mediaNode, visitArgs) {\n this.context.frames.unshift(mediaNode.rules[0]);\n },\n visitMediaOut: function (mediaNode) {\n this.context.frames.shift();\n }\n};\nexport default ImportVisitor;\n","class SetTreeVisibilityVisitor {\n constructor(visible) {\n this.visible = visible;\n }\n\n run(root) {\n this.visit(root);\n }\n\n visitArray(nodes) {\n if (!nodes) {\n return nodes;\n }\n\n const cnt = nodes.length;\n let i;\n for (i = 0; i < cnt; i++) {\n this.visit(nodes[i]);\n }\n return nodes;\n }\n\n visit(node) {\n if (!node) {\n return node;\n }\n if (node.constructor === Array) {\n return this.visitArray(node);\n }\n\n if (!node.blocksVisibility || node.blocksVisibility()) {\n return node;\n }\n if (this.visible) {\n node.ensureVisibility();\n } else {\n node.ensureInvisibility();\n }\n\n node.accept(this);\n return node;\n }\n}\n\nexport default SetTreeVisibilityVisitor;","import tree from '../tree';\nimport Visitor from './visitor';\nimport logger from '../logger';\nimport * as utils from '../utils';\n\n/* jshint loopfunc:true */\n\nclass ExtendFinderVisitor {\n constructor() {\n this._visitor = new Visitor(this);\n this.contexts = [];\n this.allExtendsStack = [[]];\n }\n\n run(root) {\n root = this._visitor.visit(root);\n root.allExtends = this.allExtendsStack[0];\n return root;\n }\n\n visitDeclaration(declNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n if (rulesetNode.root) {\n return;\n }\n\n let i;\n let j;\n let extend;\n const allSelectorsExtendList = [];\n let extendList;\n\n // get &:extend(.a); rules which apply to all selectors in this ruleset\n const rules = rulesetNode.rules, ruleCnt = rules ? rules.length : 0;\n for (i = 0; i < ruleCnt; i++) {\n if (rulesetNode.rules[i] instanceof tree.Extend) {\n allSelectorsExtendList.push(rules[i]);\n rulesetNode.extendOnEveryPath = true;\n }\n }\n\n // now find every selector and apply the extends that apply to all extends\n // and the ones which apply to an individual extend\n const paths = rulesetNode.paths;\n for (i = 0; i < paths.length; i++) {\n const selectorPath = paths[i], selector = selectorPath[selectorPath.length - 1], selExtendList = selector.extendList;\n\n extendList = selExtendList ? utils.copyArray(selExtendList).concat(allSelectorsExtendList)\n : allSelectorsExtendList;\n\n if (extendList) {\n extendList = extendList.map(function(allSelectorsExtend) {\n return allSelectorsExtend.clone();\n });\n }\n\n for (j = 0; j < extendList.length; j++) {\n this.foundExtends = true;\n extend = extendList[j];\n extend.findSelfSelectors(selectorPath);\n extend.ruleset = rulesetNode;\n if (j === 0) { extend.firstExtendOnThisSelectorPath = true; }\n this.allExtendsStack[this.allExtendsStack.length - 1].push(extend);\n }\n }\n\n this.contexts.push(rulesetNode.selectors);\n }\n\n visitRulesetOut(rulesetNode) {\n if (!rulesetNode.root) {\n this.contexts.length = this.contexts.length - 1;\n }\n }\n\n visitMedia(mediaNode, visitArgs) {\n mediaNode.allExtends = [];\n this.allExtendsStack.push(mediaNode.allExtends);\n }\n\n visitMediaOut(mediaNode) {\n this.allExtendsStack.length = this.allExtendsStack.length - 1;\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n atRuleNode.allExtends = [];\n this.allExtendsStack.push(atRuleNode.allExtends);\n }\n\n visitAtRuleOut(atRuleNode) {\n this.allExtendsStack.length = this.allExtendsStack.length - 1;\n }\n}\n\nclass ProcessExtendsVisitor {\n constructor() {\n this._visitor = new Visitor(this);\n }\n\n run(root) {\n const extendFinder = new ExtendFinderVisitor();\n this.extendIndices = {};\n extendFinder.run(root);\n if (!extendFinder.foundExtends) { return root; }\n root.allExtends = root.allExtends.concat(this.doExtendChaining(root.allExtends, root.allExtends));\n this.allExtendsStack = [root.allExtends];\n const newRoot = this._visitor.visit(root);\n this.checkExtendsForNonMatched(root.allExtends);\n return newRoot;\n }\n\n checkExtendsForNonMatched(extendList) {\n const indices = this.extendIndices;\n extendList.filter(function(extend) {\n return !extend.hasFoundMatches && extend.parent_ids.length == 1;\n }).forEach(function(extend) {\n let selector = '_unknown_';\n try {\n selector = extend.selector.toCSS({});\n }\n catch (_) {}\n\n if (!indices[`${extend.index} ${selector}`]) {\n indices[`${extend.index} ${selector}`] = true;\n logger.warn(`extend '${selector}' has no matches`);\n }\n });\n }\n\n doExtendChaining(extendsList, extendsListTarget, iterationCount) {\n //\n // chaining is different from normal extension.. if we extend an extend then we are not just copying, altering\n // and pasting the selector we would do normally, but we are also adding an extend with the same target selector\n // this means this new extend can then go and alter other extends\n //\n // this method deals with all the chaining work - without it, extend is flat and doesn't work on other extend selectors\n // this is also the most expensive.. and a match on one selector can cause an extension of a selector we had already\n // processed if we look at each selector at a time, as is done in visitRuleset\n\n let extendIndex;\n\n let targetExtendIndex;\n let matches;\n const extendsToAdd = [];\n let newSelector;\n const extendVisitor = this;\n let selectorPath;\n let extend;\n let targetExtend;\n let newExtend;\n\n iterationCount = iterationCount || 0;\n\n // loop through comparing every extend with every target extend.\n // a target extend is the one on the ruleset we are looking at copy/edit/pasting in place\n // e.g. .a:extend(.b) {} and .b:extend(.c) {} then the first extend extends the second one\n // and the second is the target.\n // the separation into two lists allows us to process a subset of chains with a bigger set, as is the\n // case when processing media queries\n for (extendIndex = 0; extendIndex < extendsList.length; extendIndex++) {\n for (targetExtendIndex = 0; targetExtendIndex < extendsListTarget.length; targetExtendIndex++) {\n\n extend = extendsList[extendIndex];\n targetExtend = extendsListTarget[targetExtendIndex];\n\n // look for circular references\n if ( extend.parent_ids.indexOf( targetExtend.object_id ) >= 0 ) { continue; }\n\n // find a match in the target extends self selector (the bit before :extend)\n selectorPath = [targetExtend.selfSelectors[0]];\n matches = extendVisitor.findMatch(extend, selectorPath);\n\n if (matches.length) {\n extend.hasFoundMatches = true;\n\n // we found a match, so for each self selector..\n extend.selfSelectors.forEach(function(selfSelector) {\n const info = targetExtend.visibilityInfo();\n\n // process the extend as usual\n newSelector = extendVisitor.extendSelector(matches, selectorPath, selfSelector, extend.isVisible());\n\n // but now we create a new extend from it\n newExtend = new(tree.Extend)(targetExtend.selector, targetExtend.option, 0, targetExtend.fileInfo(), info);\n newExtend.selfSelectors = newSelector;\n\n // add the extend onto the list of extends for that selector\n newSelector[newSelector.length - 1].extendList = [newExtend];\n\n // record that we need to add it.\n extendsToAdd.push(newExtend);\n newExtend.ruleset = targetExtend.ruleset;\n\n // remember its parents for circular references\n newExtend.parent_ids = newExtend.parent_ids.concat(targetExtend.parent_ids, extend.parent_ids);\n\n // only process the selector once.. if we have :extend(.a,.b) then multiple\n // extends will look at the same selector path, so when extending\n // we know that any others will be duplicates in terms of what is added to the css\n if (targetExtend.firstExtendOnThisSelectorPath) {\n newExtend.firstExtendOnThisSelectorPath = true;\n targetExtend.ruleset.paths.push(newSelector);\n }\n });\n }\n }\n }\n\n if (extendsToAdd.length) {\n // try to detect circular references to stop a stack overflow.\n // may no longer be needed.\n this.extendChainCount++;\n if (iterationCount > 100) {\n let selectorOne = '{unable to calculate}';\n let selectorTwo = '{unable to calculate}';\n try {\n selectorOne = extendsToAdd[0].selfSelectors[0].toCSS();\n selectorTwo = extendsToAdd[0].selector.toCSS();\n }\n catch (e) {}\n throw { message: `extend circular reference detected. One of the circular extends is currently:${selectorOne}:extend(${selectorTwo})`};\n }\n\n // now process the new extends on the existing rules so that we can handle a extending b extending c extending\n // d extending e...\n return extendsToAdd.concat(extendVisitor.doExtendChaining(extendsToAdd, extendsListTarget, iterationCount + 1));\n } else {\n return extendsToAdd;\n }\n }\n\n visitDeclaration(ruleNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitSelector(selectorNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n if (rulesetNode.root) {\n return;\n }\n let matches;\n let pathIndex;\n let extendIndex;\n const allExtends = this.allExtendsStack[this.allExtendsStack.length - 1];\n const selectorsToAdd = [];\n const extendVisitor = this;\n let selectorPath;\n\n // look at each selector path in the ruleset, find any extend matches and then copy, find and replace\n\n for (extendIndex = 0; extendIndex < allExtends.length; extendIndex++) {\n for (pathIndex = 0; pathIndex < rulesetNode.paths.length; pathIndex++) {\n selectorPath = rulesetNode.paths[pathIndex];\n\n // extending extends happens initially, before the main pass\n if (rulesetNode.extendOnEveryPath) { continue; }\n const extendList = selectorPath[selectorPath.length - 1].extendList;\n if (extendList && extendList.length) { continue; }\n\n matches = this.findMatch(allExtends[extendIndex], selectorPath);\n\n if (matches.length) {\n allExtends[extendIndex].hasFoundMatches = true;\n\n allExtends[extendIndex].selfSelectors.forEach(function(selfSelector) {\n let extendedSelectors;\n extendedSelectors = extendVisitor.extendSelector(matches, selectorPath, selfSelector, allExtends[extendIndex].isVisible());\n selectorsToAdd.push(extendedSelectors);\n });\n }\n }\n }\n rulesetNode.paths = rulesetNode.paths.concat(selectorsToAdd);\n }\n\n findMatch(extend, haystackSelectorPath) {\n //\n // look through the haystack selector path to try and find the needle - extend.selector\n // returns an array of selector matches that can then be replaced\n //\n let haystackSelectorIndex;\n\n let hackstackSelector;\n let hackstackElementIndex;\n let haystackElement;\n let targetCombinator;\n let i;\n const extendVisitor = this;\n const needleElements = extend.selector.elements;\n const potentialMatches = [];\n let potentialMatch;\n const matches = [];\n\n // loop through the haystack elements\n for (haystackSelectorIndex = 0; haystackSelectorIndex < haystackSelectorPath.length; haystackSelectorIndex++) {\n hackstackSelector = haystackSelectorPath[haystackSelectorIndex];\n\n for (hackstackElementIndex = 0; hackstackElementIndex < hackstackSelector.elements.length; hackstackElementIndex++) {\n\n haystackElement = hackstackSelector.elements[hackstackElementIndex];\n\n // if we allow elements before our match we can add a potential match every time. otherwise only at the first element.\n if (extend.allowBefore || (haystackSelectorIndex === 0 && hackstackElementIndex === 0)) {\n potentialMatches.push({pathIndex: haystackSelectorIndex, index: hackstackElementIndex, matched: 0,\n initialCombinator: haystackElement.combinator});\n }\n\n for (i = 0; i < potentialMatches.length; i++) {\n potentialMatch = potentialMatches[i];\n\n // selectors add \" \" onto the first element. When we use & it joins the selectors together, but if we don't\n // then each selector in haystackSelectorPath has a space before it added in the toCSS phase. so we need to\n // work out what the resulting combinator will be\n targetCombinator = haystackElement.combinator.value;\n if (targetCombinator === '' && hackstackElementIndex === 0) {\n targetCombinator = ' ';\n }\n\n // if we don't match, null our match to indicate failure\n if (!extendVisitor.isElementValuesEqual(needleElements[potentialMatch.matched].value, haystackElement.value) ||\n (potentialMatch.matched > 0 && needleElements[potentialMatch.matched].combinator.value !== targetCombinator)) {\n potentialMatch = null;\n } else {\n potentialMatch.matched++;\n }\n\n // if we are still valid and have finished, test whether we have elements after and whether these are allowed\n if (potentialMatch) {\n potentialMatch.finished = potentialMatch.matched === needleElements.length;\n if (potentialMatch.finished &&\n (!extend.allowAfter &&\n (hackstackElementIndex + 1 < hackstackSelector.elements.length || haystackSelectorIndex + 1 < haystackSelectorPath.length))) {\n potentialMatch = null;\n }\n }\n // if null we remove, if not, we are still valid, so either push as a valid match or continue\n if (potentialMatch) {\n if (potentialMatch.finished) {\n potentialMatch.length = needleElements.length;\n potentialMatch.endPathIndex = haystackSelectorIndex;\n potentialMatch.endPathElementIndex = hackstackElementIndex + 1; // index after end of match\n potentialMatches.length = 0; // we don't allow matches to overlap, so start matching again\n matches.push(potentialMatch);\n }\n } else {\n potentialMatches.splice(i, 1);\n i--;\n }\n }\n }\n }\n return matches;\n }\n\n isElementValuesEqual(elementValue1, elementValue2) {\n if (typeof elementValue1 === 'string' || typeof elementValue2 === 'string') {\n return elementValue1 === elementValue2;\n }\n if (elementValue1 instanceof tree.Attribute) {\n if (elementValue1.op !== elementValue2.op || elementValue1.key !== elementValue2.key) {\n return false;\n }\n if (!elementValue1.value || !elementValue2.value) {\n if (elementValue1.value || elementValue2.value) {\n return false;\n }\n return true;\n }\n elementValue1 = elementValue1.value.value || elementValue1.value;\n elementValue2 = elementValue2.value.value || elementValue2.value;\n return elementValue1 === elementValue2;\n }\n elementValue1 = elementValue1.value;\n elementValue2 = elementValue2.value;\n if (elementValue1 instanceof tree.Selector) {\n if (!(elementValue2 instanceof tree.Selector) || elementValue1.elements.length !== elementValue2.elements.length) {\n return false;\n }\n for (let i = 0; i < elementValue1.elements.length; i++) {\n if (elementValue1.elements[i].combinator.value !== elementValue2.elements[i].combinator.value) {\n if (i !== 0 || (elementValue1.elements[i].combinator.value || ' ') !== (elementValue2.elements[i].combinator.value || ' ')) {\n return false;\n }\n }\n if (!this.isElementValuesEqual(elementValue1.elements[i].value, elementValue2.elements[i].value)) {\n return false;\n }\n }\n return true;\n }\n return false;\n }\n\n extendSelector(matches, selectorPath, replacementSelector, isVisible) {\n\n // for a set of matches, replace each match with the replacement selector\n\n let currentSelectorPathIndex = 0, currentSelectorPathElementIndex = 0, path = [], matchIndex, selector, firstElement, match, newElements;\n\n for (matchIndex = 0; matchIndex < matches.length; matchIndex++) {\n match = matches[matchIndex];\n selector = selectorPath[match.pathIndex];\n firstElement = new tree.Element(\n match.initialCombinator,\n replacementSelector.elements[0].value,\n replacementSelector.elements[0].isVariable,\n replacementSelector.elements[0].getIndex(),\n replacementSelector.elements[0].fileInfo()\n );\n\n if (match.pathIndex > currentSelectorPathIndex && currentSelectorPathElementIndex > 0) {\n path[path.length - 1].elements = path[path.length - 1]\n .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex));\n currentSelectorPathElementIndex = 0;\n currentSelectorPathIndex++;\n }\n\n newElements = selector.elements\n .slice(currentSelectorPathElementIndex, match.index)\n .concat([firstElement])\n .concat(replacementSelector.elements.slice(1));\n\n if (currentSelectorPathIndex === match.pathIndex && matchIndex > 0) {\n path[path.length - 1].elements =\n path[path.length - 1].elements.concat(newElements);\n } else {\n path = path.concat(selectorPath.slice(currentSelectorPathIndex, match.pathIndex));\n\n path.push(new tree.Selector(\n newElements\n ));\n }\n currentSelectorPathIndex = match.endPathIndex;\n currentSelectorPathElementIndex = match.endPathElementIndex;\n if (currentSelectorPathElementIndex >= selectorPath[currentSelectorPathIndex].elements.length) {\n currentSelectorPathElementIndex = 0;\n currentSelectorPathIndex++;\n }\n }\n\n if (currentSelectorPathIndex < selectorPath.length && currentSelectorPathElementIndex > 0) {\n path[path.length - 1].elements = path[path.length - 1]\n .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex));\n currentSelectorPathIndex++;\n }\n\n path = path.concat(selectorPath.slice(currentSelectorPathIndex, selectorPath.length));\n path = path.map(function (currentValue) {\n // we can re-use elements here, because the visibility property matters only for selectors\n const derived = currentValue.createDerived(currentValue.elements);\n if (isVisible) {\n derived.ensureVisibility();\n } else {\n derived.ensureInvisibility();\n }\n return derived;\n });\n return path;\n }\n\n visitMedia(mediaNode, visitArgs) {\n let newAllExtends = mediaNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]);\n newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, mediaNode.allExtends));\n this.allExtendsStack.push(newAllExtends);\n }\n\n visitMediaOut(mediaNode) {\n const lastIndex = this.allExtendsStack.length - 1;\n this.allExtendsStack.length = lastIndex;\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n let newAllExtends = atRuleNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]);\n newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, atRuleNode.allExtends));\n this.allExtendsStack.push(newAllExtends);\n }\n\n visitAtRuleOut(atRuleNode) {\n const lastIndex = this.allExtendsStack.length - 1;\n this.allExtendsStack.length = lastIndex;\n }\n}\n\nexport default ProcessExtendsVisitor;\n","import Visitor from './visitor';\n\nclass JoinSelectorVisitor {\n constructor() {\n this.contexts = [[]];\n this._visitor = new Visitor(this);\n }\n\n run(root) {\n return this._visitor.visit(root);\n }\n\n visitDeclaration(declNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n const paths = [];\n let selectors;\n\n this.contexts.push(paths);\n\n if (!rulesetNode.root) {\n selectors = rulesetNode.selectors;\n if (selectors) {\n selectors = selectors.filter(function(selector) { return selector.getIsOutput(); });\n rulesetNode.selectors = selectors.length ? selectors : (selectors = null);\n if (selectors) { rulesetNode.joinSelectors(paths, context, selectors); }\n }\n if (!selectors) { rulesetNode.rules = null; }\n rulesetNode.paths = paths;\n }\n }\n\n visitRulesetOut(rulesetNode) {\n this.contexts.length = this.contexts.length - 1;\n }\n\n visitMedia(mediaNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n mediaNode.rules[0].root = (context.length === 0 || context[0].multiMedia);\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n if (atRuleNode.rules && atRuleNode.rules.length) {\n atRuleNode.rules[0].root = (atRuleNode.isRooted || context.length === 0 || null);\n }\n }\n}\n\nexport default JoinSelectorVisitor;\n","import tree from '../tree';\nimport Visitor from './visitor';\n\nclass CSSVisitorUtils {\n constructor(context) {\n this._visitor = new Visitor(this);\n this._context = context;\n }\n\n containsSilentNonBlockedChild(bodyRules) {\n let rule;\n if (!bodyRules) {\n return false;\n }\n for (let r = 0; r < bodyRules.length; r++) {\n rule = bodyRules[r];\n if (rule.isSilent && rule.isSilent(this._context) && !rule.blocksVisibility()) {\n // the atrule contains something that was referenced (likely by extend)\n // therefore it needs to be shown in output too\n return true;\n }\n }\n return false;\n }\n\n keepOnlyVisibleChilds(owner) {\n if (owner && owner.rules) {\n owner.rules = owner.rules.filter(thing => thing.isVisible());\n }\n }\n\n isEmpty(owner) {\n return (owner && owner.rules) \n ? (owner.rules.length === 0) : true;\n }\n\n hasVisibleSelector(rulesetNode) {\n return (rulesetNode && rulesetNode.paths)\n ? (rulesetNode.paths.length > 0) : false;\n }\n\n resolveVisibility(node, originalRules) {\n if (!node.blocksVisibility()) {\n if (this.isEmpty(node) && !this.containsSilentNonBlockedChild(originalRules)) {\n return ;\n }\n\n return node;\n }\n\n const compiledRulesBody = node.rules[0];\n this.keepOnlyVisibleChilds(compiledRulesBody);\n\n if (this.isEmpty(compiledRulesBody)) {\n return ;\n }\n\n node.ensureVisibility();\n node.removeVisibilityBlock();\n\n return node;\n }\n\n isVisibleRuleset(rulesetNode) {\n if (rulesetNode.firstRoot) {\n return true;\n }\n\n if (this.isEmpty(rulesetNode)) {\n return false;\n }\n\n if (!rulesetNode.root && !this.hasVisibleSelector(rulesetNode)) {\n return false;\n }\n\n return true;\n }\n}\n\nconst ToCSSVisitor = function(context) {\n this._visitor = new Visitor(this);\n this._context = context;\n this.utils = new CSSVisitorUtils(context);\n};\n\nToCSSVisitor.prototype = {\n isReplacing: true,\n run: function (root) {\n return this._visitor.visit(root);\n },\n\n visitDeclaration: function (declNode, visitArgs) {\n if (declNode.blocksVisibility() || declNode.variable) {\n return;\n }\n return declNode;\n },\n\n visitMixinDefinition: function (mixinNode, visitArgs) {\n // mixin definitions do not get eval'd - this means they keep state\n // so we have to clear that state here so it isn't used if toCSS is called twice\n mixinNode.frames = [];\n },\n\n visitExtend: function (extendNode, visitArgs) {\n },\n\n visitComment: function (commentNode, visitArgs) {\n if (commentNode.blocksVisibility() || commentNode.isSilent(this._context)) {\n return;\n }\n return commentNode;\n },\n\n visitMedia: function(mediaNode, visitArgs) {\n const originalRules = mediaNode.rules[0].rules;\n mediaNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n\n return this.utils.resolveVisibility(mediaNode, originalRules);\n },\n\n visitImport: function (importNode, visitArgs) {\n if (importNode.blocksVisibility()) {\n return ;\n }\n return importNode;\n },\n\n visitAtRule: function(atRuleNode, visitArgs) {\n if (atRuleNode.rules && atRuleNode.rules.length) {\n return this.visitAtRuleWithBody(atRuleNode, visitArgs);\n } else {\n return this.visitAtRuleWithoutBody(atRuleNode, visitArgs);\n }\n },\n\n visitAnonymous: function(anonymousNode, visitArgs) {\n if (!anonymousNode.blocksVisibility()) {\n anonymousNode.accept(this._visitor);\n return anonymousNode;\n }\n },\n\n visitAtRuleWithBody: function(atRuleNode, visitArgs) {\n // if there is only one nested ruleset and that one has no path, then it is\n // just fake ruleset\n function hasFakeRuleset(atRuleNode) {\n const bodyRules = atRuleNode.rules;\n return bodyRules.length === 1 && (!bodyRules[0].paths || bodyRules[0].paths.length === 0);\n }\n function getBodyRules(atRuleNode) {\n const nodeRules = atRuleNode.rules;\n if (hasFakeRuleset(atRuleNode)) {\n return nodeRules[0].rules;\n }\n\n return nodeRules;\n }\n // it is still true that it is only one ruleset in array\n // this is last such moment\n // process childs\n const originalRules = getBodyRules(atRuleNode);\n atRuleNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n\n if (!this.utils.isEmpty(atRuleNode)) {\n this._mergeRules(atRuleNode.rules[0].rules);\n }\n\n return this.utils.resolveVisibility(atRuleNode, originalRules);\n },\n\n visitAtRuleWithoutBody: function(atRuleNode, visitArgs) {\n if (atRuleNode.blocksVisibility()) {\n return;\n }\n\n if (atRuleNode.name === '@charset') {\n // Only output the debug info together with subsequent @charset definitions\n // a comment (or @media statement) before the actual @charset atrule would\n // be considered illegal css as it has to be on the first line\n if (this.charset) {\n if (atRuleNode.debugInfo) {\n const comment = new tree.Comment(`/* ${atRuleNode.toCSS(this._context).replace(/\\n/g, '')} */\\n`);\n comment.debugInfo = atRuleNode.debugInfo;\n return this._visitor.visit(comment);\n }\n return;\n }\n this.charset = true;\n }\n\n return atRuleNode;\n },\n\n checkValidNodes: function(rules, isRoot) {\n if (!rules) {\n return;\n }\n\n for (let i = 0; i < rules.length; i++) {\n const ruleNode = rules[i];\n if (isRoot && ruleNode instanceof tree.Declaration && !ruleNode.variable) {\n throw { message: 'Properties must be inside selector blocks. They cannot be in the root',\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n if (ruleNode instanceof tree.Call) {\n throw { message: `Function '${ruleNode.name}' did not return a root node`,\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n if (ruleNode.type && !ruleNode.allowRoot) {\n throw { message: `${ruleNode.type} node returned by a function is not valid here`,\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n }\n },\n\n visitRuleset: function (rulesetNode, visitArgs) {\n // at this point rulesets are nested into each other\n let rule;\n\n const rulesets = [];\n\n this.checkValidNodes(rulesetNode.rules, rulesetNode.firstRoot);\n\n if (!rulesetNode.root) {\n // remove invisible paths\n this._compileRulesetPaths(rulesetNode);\n\n // remove rulesets from this ruleset body and compile them separately\n const nodeRules = rulesetNode.rules;\n\n let nodeRuleCnt = nodeRules ? nodeRules.length : 0;\n for (let i = 0; i < nodeRuleCnt; ) {\n rule = nodeRules[i];\n if (rule && rule.rules) {\n // visit because we are moving them out from being a child\n rulesets.push(this._visitor.visit(rule));\n nodeRules.splice(i, 1);\n nodeRuleCnt--;\n continue;\n }\n i++;\n }\n // accept the visitor to remove rules and refactor itself\n // then we can decide nogw whether we want it or not\n // compile body\n if (nodeRuleCnt > 0) {\n rulesetNode.accept(this._visitor);\n } else {\n rulesetNode.rules = null;\n }\n visitArgs.visitDeeper = false;\n } else { // if (! rulesetNode.root) {\n rulesetNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n }\n\n if (rulesetNode.rules) {\n this._mergeRules(rulesetNode.rules);\n this._removeDuplicateRules(rulesetNode.rules);\n }\n\n // now decide whether we keep the ruleset\n if (this.utils.isVisibleRuleset(rulesetNode)) {\n rulesetNode.ensureVisibility();\n rulesets.splice(0, 0, rulesetNode);\n }\n\n if (rulesets.length === 1) {\n return rulesets[0];\n }\n return rulesets;\n },\n\n _compileRulesetPaths: function(rulesetNode) {\n if (rulesetNode.paths) {\n rulesetNode.paths = rulesetNode.paths\n .filter(p => {\n let i;\n if (p[0].elements[0].combinator.value === ' ') {\n p[0].elements[0].combinator = new(tree.Combinator)('');\n }\n for (i = 0; i < p.length; i++) {\n if (p[i].isVisible() && p[i].getIsOutput()) {\n return true;\n }\n }\n return false;\n });\n }\n },\n\n _removeDuplicateRules: function(rules) {\n if (!rules) { return; }\n\n // remove duplicates\n const ruleCache = {};\n\n let ruleList;\n let rule;\n let i;\n\n for (i = rules.length - 1; i >= 0 ; i--) {\n rule = rules[i];\n if (rule instanceof tree.Declaration) {\n if (!ruleCache[rule.name]) {\n ruleCache[rule.name] = rule;\n } else {\n ruleList = ruleCache[rule.name];\n if (ruleList instanceof tree.Declaration) {\n ruleList = ruleCache[rule.name] = [ruleCache[rule.name].toCSS(this._context)];\n }\n const ruleCSS = rule.toCSS(this._context);\n if (ruleList.indexOf(ruleCSS) !== -1) {\n rules.splice(i, 1);\n } else {\n ruleList.push(ruleCSS);\n }\n }\n }\n }\n },\n\n _mergeRules: function(rules) {\n if (!rules) {\n return; \n }\n\n const groups = {};\n const groupsArr = [];\n\n for (let i = 0; i < rules.length; i++) {\n const rule = rules[i];\n if (rule.merge) {\n const key = rule.name;\n groups[key] ? rules.splice(i--, 1) : \n groupsArr.push(groups[key] = []);\n groups[key].push(rule);\n }\n }\n\n groupsArr.forEach(group => {\n if (group.length > 0) {\n const result = group[0];\n let space = [];\n const comma = [new tree.Expression(space)];\n group.forEach(rule => {\n if ((rule.merge === '+') && (space.length > 0)) {\n comma.push(new tree.Expression(space = []));\n }\n space.push(rule.value);\n result.important = result.important || rule.important;\n });\n result.value = new tree.Value(comma);\n }\n });\n }\n};\n\nexport default ToCSSVisitor;\n","import Visitor from './visitor';\nimport ImportVisitor from './import-visitor';\nimport MarkVisibleSelectorsVisitor from './set-tree-visibility-visitor';\nimport ExtendVisitor from './extend-visitor';\nimport JoinSelectorVisitor from './join-selector-visitor';\nimport ToCSSVisitor from './to-css-visitor';\n\nexport default {\n Visitor,\n ImportVisitor,\n MarkVisibleSelectorsVisitor,\n ExtendVisitor,\n JoinSelectorVisitor,\n ToCSSVisitor\n};\n","import chunker from './chunker';\n\nexport default () => {\n let // Less input string\n input;\n\n let // current chunk\n j;\n\n const // holds state for backtracking\n saveStack = [];\n\n let // furthest index the parser has gone to\n furthest;\n\n let // if this is furthest we got to, this is the probably cause\n furthestPossibleErrorMessage;\n\n let // chunkified input\n chunks;\n\n let // current chunk\n current;\n\n let // index of current chunk, in `input`\n currentPos;\n\n const parserInput = {};\n const CHARCODE_SPACE = 32;\n const CHARCODE_TAB = 9;\n const CHARCODE_LF = 10;\n const CHARCODE_CR = 13;\n const CHARCODE_PLUS = 43;\n const CHARCODE_COMMA = 44;\n const CHARCODE_FORWARD_SLASH = 47;\n const CHARCODE_9 = 57;\n\n function skipWhitespace(length) {\n const oldi = parserInput.i;\n const oldj = j;\n const curr = parserInput.i - currentPos;\n const endIndex = parserInput.i + current.length - curr;\n const mem = (parserInput.i += length);\n const inp = input;\n let c;\n let nextChar;\n let comment;\n\n for (; parserInput.i < endIndex; parserInput.i++) {\n c = inp.charCodeAt(parserInput.i);\n\n if (parserInput.autoCommentAbsorb && c === CHARCODE_FORWARD_SLASH) {\n nextChar = inp.charAt(parserInput.i + 1);\n if (nextChar === '/') {\n comment = {index: parserInput.i, isLineComment: true};\n let nextNewLine = inp.indexOf('\\n', parserInput.i + 2);\n if (nextNewLine < 0) {\n nextNewLine = endIndex;\n }\n parserInput.i = nextNewLine;\n comment.text = inp.substr(comment.index, parserInput.i - comment.index);\n parserInput.commentStore.push(comment);\n continue;\n } else if (nextChar === '*') {\n const nextStarSlash = inp.indexOf('*/', parserInput.i + 2);\n if (nextStarSlash >= 0) {\n comment = {\n index: parserInput.i,\n text: inp.substr(parserInput.i, nextStarSlash + 2 - parserInput.i),\n isLineComment: false\n };\n parserInput.i += comment.text.length - 1;\n parserInput.commentStore.push(comment);\n continue;\n }\n }\n break;\n }\n\n if ((c !== CHARCODE_SPACE) && (c !== CHARCODE_LF) && (c !== CHARCODE_TAB) && (c !== CHARCODE_CR)) {\n break;\n }\n }\n\n current = current.slice(length + parserInput.i - mem + curr);\n currentPos = parserInput.i;\n\n if (!current.length) {\n if (j < chunks.length - 1) {\n current = chunks[++j];\n skipWhitespace(0); // skip space at the beginning of a chunk\n return true; // things changed\n }\n parserInput.finished = true;\n }\n\n return oldi !== parserInput.i || oldj !== j;\n }\n\n parserInput.save = () => {\n currentPos = parserInput.i;\n saveStack.push( { current, i: parserInput.i, j });\n };\n parserInput.restore = possibleErrorMessage => {\n\n if (parserInput.i > furthest || (parserInput.i === furthest && possibleErrorMessage && !furthestPossibleErrorMessage)) {\n furthest = parserInput.i;\n furthestPossibleErrorMessage = possibleErrorMessage;\n }\n const state = saveStack.pop();\n current = state.current;\n currentPos = parserInput.i = state.i;\n j = state.j;\n };\n parserInput.forget = () => {\n saveStack.pop();\n };\n parserInput.isWhitespace = offset => {\n const pos = parserInput.i + (offset || 0);\n const code = input.charCodeAt(pos);\n return (code === CHARCODE_SPACE || code === CHARCODE_CR || code === CHARCODE_TAB || code === CHARCODE_LF);\n };\n\n // Specialization of $(tok)\n parserInput.$re = tok => {\n if (parserInput.i > currentPos) {\n current = current.slice(parserInput.i - currentPos);\n currentPos = parserInput.i;\n }\n\n const m = tok.exec(current);\n if (!m) {\n return null;\n }\n\n skipWhitespace(m[0].length);\n if (typeof m === 'string') {\n return m;\n }\n\n return m.length === 1 ? m[0] : m;\n };\n\n parserInput.$char = tok => {\n if (input.charAt(parserInput.i) !== tok) {\n return null;\n }\n skipWhitespace(1);\n return tok;\n };\n\n parserInput.$str = tok => {\n const tokLength = tok.length;\n\n // https://jsperf.com/string-startswith/21\n for (let i = 0; i < tokLength; i++) {\n if (input.charAt(parserInput.i + i) !== tok.charAt(i)) {\n return null;\n }\n }\n\n skipWhitespace(tokLength);\n return tok;\n };\n\n parserInput.$quoted = loc => {\n const pos = loc || parserInput.i;\n const startChar = input.charAt(pos);\n\n if (startChar !== '\\'' && startChar !== '\"') {\n return;\n }\n const length = input.length;\n const currentPosition = pos;\n\n for (let i = 1; i + currentPosition < length; i++) {\n const nextChar = input.charAt(i + currentPosition);\n switch (nextChar) {\n case '\\\\':\n i++;\n continue;\n case '\\r':\n case '\\n':\n break;\n case startChar:\n const str = input.substr(currentPosition, i + 1);\n if (!loc && loc !== 0) {\n skipWhitespace(i + 1);\n return str\n }\n return [startChar, str];\n default:\n }\n }\n return null;\n };\n\n /**\n * Permissive parsing. Ignores everything except matching {} [] () and quotes\n * until matching token (outside of blocks)\n */\n parserInput.$parseUntil = tok => {\n let quote = '';\n let returnVal = null;\n let inComment = false;\n let blockDepth = 0;\n const blockStack = [];\n const parseGroups = [];\n const length = input.length;\n const startPos = parserInput.i;\n let lastPos = parserInput.i;\n let i = parserInput.i;\n let loop = true;\n let testChar;\n\n if (typeof tok === 'string') {\n testChar = char => char === tok\n } else {\n testChar = char => tok.test(char)\n }\n\n do {\n let prevChar;\n let nextChar = input.charAt(i);\n if (blockDepth === 0 && testChar(nextChar)) {\n returnVal = input.substr(lastPos, i - lastPos);\n if (returnVal) {\n parseGroups.push(returnVal);\n }\n else {\n parseGroups.push(' ');\n }\n returnVal = parseGroups;\n skipWhitespace(i - startPos);\n loop = false\n } else {\n if (inComment) {\n if (nextChar === '*' && \n input.charAt(i + 1) === '/') {\n i++;\n blockDepth--;\n inComment = false;\n }\n i++;\n continue;\n }\n switch (nextChar) {\n case '\\\\':\n i++;\n nextChar = input.charAt(i);\n parseGroups.push(input.substr(lastPos, i - lastPos + 1));\n lastPos = i + 1;\n break;\n case '/':\n if (input.charAt(i + 1) === '*') {\n i++;\n inComment = true;\n blockDepth++;\n }\n break;\n case '\\'':\n case '\"':\n quote = parserInput.$quoted(i);\n if (quote) {\n parseGroups.push(input.substr(lastPos, i - lastPos), quote);\n i += quote[1].length - 1;\n lastPos = i + 1;\n }\n else {\n skipWhitespace(i - startPos);\n returnVal = nextChar;\n loop = false;\n }\n break;\n case '{':\n blockStack.push('}');\n blockDepth++;\n break;\n case '(':\n blockStack.push(')');\n blockDepth++;\n break;\n case '[':\n blockStack.push(']');\n blockDepth++;\n break;\n case '}':\n case ')':\n case ']':\n const expected = blockStack.pop();\n if (nextChar === expected) {\n blockDepth--;\n } else {\n // move the parser to the error and return expected\n skipWhitespace(i - startPos);\n returnVal = expected;\n loop = false;\n }\n }\n i++;\n if (i > length) {\n loop = false;\n }\n }\n prevChar = nextChar;\n } while (loop);\n\n return returnVal ? returnVal : null;\n }\n\n parserInput.autoCommentAbsorb = true;\n parserInput.commentStore = [];\n parserInput.finished = false;\n\n // Same as $(), but don't change the state of the parser,\n // just return the match.\n parserInput.peek = tok => {\n if (typeof tok === 'string') {\n // https://jsperf.com/string-startswith/21\n for (let i = 0; i < tok.length; i++) {\n if (input.charAt(parserInput.i + i) !== tok.charAt(i)) {\n return false;\n }\n }\n return true;\n } else {\n return tok.test(current);\n }\n };\n\n // Specialization of peek()\n // TODO remove or change some currentChar calls to peekChar\n parserInput.peekChar = tok => input.charAt(parserInput.i) === tok;\n\n parserInput.currentChar = () => input.charAt(parserInput.i);\n\n parserInput.prevChar = () => input.charAt(parserInput.i - 1);\n\n parserInput.getInput = () => input;\n\n parserInput.peekNotNumeric = () => {\n const c = input.charCodeAt(parserInput.i);\n // Is the first char of the dimension 0-9, '.', '+' or '-'\n return (c > CHARCODE_9 || c < CHARCODE_PLUS) || c === CHARCODE_FORWARD_SLASH || c === CHARCODE_COMMA;\n };\n\n parserInput.start = (str, chunkInput, failFunction) => {\n input = str;\n parserInput.i = j = currentPos = furthest = 0;\n\n // chunking apparently makes things quicker (but my tests indicate\n // it might actually make things slower in node at least)\n // and it is a non-perfect parse - it can't recognise\n // unquoted urls, meaning it can't distinguish comments\n // meaning comments with quotes or {}() in them get 'counted'\n // and then lead to parse errors.\n // In addition if the chunking chunks in the wrong place we might\n // not be able to parse a parser statement in one go\n // this is officially deprecated but can be switched on via an option\n // in the case it causes too much performance issues.\n if (chunkInput) {\n chunks = chunker(str, failFunction);\n } else {\n chunks = [str];\n }\n\n current = chunks[0];\n\n skipWhitespace(0);\n };\n\n parserInput.end = () => {\n let message;\n const isFinished = parserInput.i >= input.length;\n\n if (parserInput.i < furthest) {\n message = furthestPossibleErrorMessage;\n parserInput.i = furthest;\n }\n return {\n isFinished,\n furthest: parserInput.i,\n furthestPossibleErrorMessage: message,\n furthestReachedEnd: parserInput.i >= input.length - 1,\n furthestChar: input[parserInput.i]\n };\n };\n\n return parserInput;\n};\n","// Split the input into chunks.\nexport default function (input, fail) {\n const len = input.length;\n let level = 0;\n let parenLevel = 0;\n let lastOpening;\n let lastOpeningParen;\n let lastMultiComment;\n let lastMultiCommentEndBrace;\n const chunks = [];\n let emitFrom = 0;\n let chunkerCurrentIndex;\n let currentChunkStartIndex;\n let cc;\n let cc2;\n let matched;\n\n function emitChunk(force) {\n const len = chunkerCurrentIndex - emitFrom;\n if (((len < 512) && !force) || !len) {\n return;\n }\n chunks.push(input.slice(emitFrom, chunkerCurrentIndex + 1));\n emitFrom = chunkerCurrentIndex + 1;\n }\n\n for (chunkerCurrentIndex = 0; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc = input.charCodeAt(chunkerCurrentIndex);\n if (((cc >= 97) && (cc <= 122)) || (cc < 34)) {\n // a-z or whitespace\n continue;\n }\n\n switch (cc) {\n case 40: // (\n parenLevel++;\n lastOpeningParen = chunkerCurrentIndex;\n continue;\n case 41: // )\n if (--parenLevel < 0) {\n return fail('missing opening `(`', chunkerCurrentIndex);\n }\n continue;\n case 59: // ;\n if (!parenLevel) { emitChunk(); }\n continue;\n case 123: // {\n level++;\n lastOpening = chunkerCurrentIndex;\n continue;\n case 125: // }\n if (--level < 0) {\n return fail('missing opening `{`', chunkerCurrentIndex);\n }\n if (!level && !parenLevel) { emitChunk(); }\n continue;\n case 92: // \\\n if (chunkerCurrentIndex < len - 1) { chunkerCurrentIndex++; continue; }\n return fail('unescaped `\\\\`', chunkerCurrentIndex);\n case 34:\n case 39:\n case 96: // \", ' and `\n matched = 0;\n currentChunkStartIndex = chunkerCurrentIndex;\n for (chunkerCurrentIndex = chunkerCurrentIndex + 1; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if (cc2 > 96) { continue; }\n if (cc2 == cc) { matched = 1; break; }\n if (cc2 == 92) { // \\\n if (chunkerCurrentIndex == len - 1) {\n return fail('unescaped `\\\\`', chunkerCurrentIndex);\n }\n chunkerCurrentIndex++;\n }\n }\n if (matched) { continue; }\n return fail(`unmatched \\`${String.fromCharCode(cc)}\\``, currentChunkStartIndex);\n case 47: // /, check for comment\n if (parenLevel || (chunkerCurrentIndex == len - 1)) { continue; }\n cc2 = input.charCodeAt(chunkerCurrentIndex + 1);\n if (cc2 == 47) {\n // //, find lnfeed\n for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if ((cc2 <= 13) && ((cc2 == 10) || (cc2 == 13))) { break; }\n }\n } else if (cc2 == 42) {\n // /*, find */\n lastMultiComment = currentChunkStartIndex = chunkerCurrentIndex;\n for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len - 1; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if (cc2 == 125) { lastMultiCommentEndBrace = chunkerCurrentIndex; }\n if (cc2 != 42) { continue; }\n if (input.charCodeAt(chunkerCurrentIndex + 1) == 47) { break; }\n }\n if (chunkerCurrentIndex == len - 1) {\n return fail('missing closing `*/`', currentChunkStartIndex);\n }\n chunkerCurrentIndex++;\n }\n continue;\n case 42: // *, check for unmatched */\n if ((chunkerCurrentIndex < len - 1) && (input.charCodeAt(chunkerCurrentIndex + 1) == 47)) {\n return fail('unmatched `/*`', chunkerCurrentIndex);\n }\n continue;\n }\n }\n\n if (level !== 0) {\n if ((lastMultiComment > lastOpening) && (lastMultiCommentEndBrace > lastMultiComment)) {\n return fail('missing closing `}` or `*/`', lastOpening);\n } else {\n return fail('missing closing `}`', lastOpening);\n }\n } else if (parenLevel !== 0) {\n return fail('missing closing `)`', lastOpeningParen);\n }\n\n emitChunk(true);\n return chunks;\n};\n","import LessError from '../less-error';\nimport tree from '../tree';\nimport visitors from '../visitors';\nimport getParserInput from './parser-input';\nimport * as utils from '../utils';\nimport functionRegistry from '../functions/function-registry';\n\n//\n// less.js - parser\n//\n// A relatively straight-forward predictive parser.\n// There is no tokenization/lexing stage, the input is parsed\n// in one sweep.\n//\n// To make the parser fast enough to run in the browser, several\n// optimization had to be made:\n//\n// - Matching and slicing on a huge input is often cause of slowdowns.\n// The solution is to chunkify the input into smaller strings.\n// The chunks are stored in the `chunks` var,\n// `j` holds the current chunk index, and `currentPos` holds\n// the index of the current chunk in relation to `input`.\n// This gives us an almost 4x speed-up.\n//\n// - In many cases, we don't need to match individual tokens;\n// for example, if a value doesn't hold any variables, operations\n// or dynamic references, the parser can effectively 'skip' it,\n// treating it as a literal.\n// An example would be '1px solid #000' - which evaluates to itself,\n// we don't need to know what the individual components are.\n// The drawback, of course is that you don't get the benefits of\n// syntax-checking on the CSS. This gives us a 50% speed-up in the parser,\n// and a smaller speed-up in the code-gen.\n//\n//\n// Token matching is done with the `$` function, which either takes\n// a terminal string or regexp, or a non-terminal function to call.\n// It also takes care of moving all the indices forwards.\n//\n\nconst Parser = function Parser(context, imports, fileInfo) {\n let parsers;\n const parserInput = getParserInput();\n\n function error(msg, type) {\n throw new LessError(\n {\n index: parserInput.i,\n filename: fileInfo.filename,\n type: type || 'Syntax',\n message: msg\n },\n imports\n );\n }\n\n function expect(arg, msg) {\n // some older browsers return typeof 'function' for RegExp\n const result = (arg instanceof Function) ? arg.call(parsers) : parserInput.$re(arg);\n if (result) {\n return result;\n }\n \n error(msg || (typeof arg === 'string'\n ? `expected '${arg}' got '${parserInput.currentChar()}'`\n : 'unexpected token'));\n }\n\n // Specialization of expect()\n function expectChar(arg, msg) {\n if (parserInput.$char(arg)) {\n return arg;\n }\n error(msg || `expected '${arg}' got '${parserInput.currentChar()}'`);\n }\n\n function getDebugInfo(index) {\n const filename = fileInfo.filename;\n\n return {\n lineNumber: utils.getLocation(index, parserInput.getInput()).line + 1,\n fileName: filename\n };\n }\n\n /**\n * Used after initial parsing to create nodes on the fly\n * \n * @param {String} str - string to parse \n * @param {Array} parseList - array of parsers to run input through e.g. [\"value\", \"important\"]\n * @param {Number} currentIndex - start number to begin indexing\n * @param {Object} fileInfo - fileInfo to attach to created nodes\n */\n function parseNode(str, parseList, currentIndex, fileInfo, callback) {\n let result;\n const returnNodes = [];\n const parser = parserInput;\n\n try {\n parser.start(str, false, function fail(msg, index) {\n callback({\n message: msg,\n index: index + currentIndex\n });\n });\n for (let x = 0, p, i; (p = parseList[x]); x++) {\n i = parser.i;\n result = parsers[p]();\n if (result) {\n try {\n result._index = i + currentIndex;\n result._fileInfo = fileInfo;\n } catch (e) {}\n returnNodes.push(result);\n }\n else {\n returnNodes.push(null);\n }\n }\n\n const endInfo = parser.end();\n if (endInfo.isFinished) {\n callback(null, returnNodes);\n }\n else {\n callback(true, null);\n }\n } catch (e) {\n throw new LessError({\n index: e.index + currentIndex,\n message: e.message\n }, imports, fileInfo.filename);\n }\n }\n\n //\n // The Parser\n //\n return {\n parserInput,\n imports,\n fileInfo,\n parseNode,\n //\n // Parse an input string into an abstract syntax tree,\n // @param str A string containing 'less' markup\n // @param callback call `callback` when done.\n // @param [additionalData] An optional map which can contains vars - a map (key, value) of variables to apply\n //\n parse: function (str, callback, additionalData) {\n let root;\n let error = null;\n let globalVars;\n let modifyVars;\n let ignored;\n let preText = '';\n\n globalVars = (additionalData && additionalData.globalVars) ? `${Parser.serializeVars(additionalData.globalVars)}\\n` : '';\n modifyVars = (additionalData && additionalData.modifyVars) ? `\\n${Parser.serializeVars(additionalData.modifyVars)}` : '';\n\n if (context.pluginManager) {\n const preProcessors = context.pluginManager.getPreProcessors();\n for (let i = 0; i < preProcessors.length; i++) {\n str = preProcessors[i].process(str, { context, imports, fileInfo });\n }\n }\n\n if (globalVars || (additionalData && additionalData.banner)) {\n preText = ((additionalData && additionalData.banner) ? additionalData.banner : '') + globalVars;\n ignored = imports.contentsIgnoredChars;\n ignored[fileInfo.filename] = ignored[fileInfo.filename] || 0;\n ignored[fileInfo.filename] += preText.length;\n }\n\n str = str.replace(/\\r\\n?/g, '\\n');\n // Remove potential UTF Byte Order Mark\n str = preText + str.replace(/^\\uFEFF/, '') + modifyVars;\n imports.contents[fileInfo.filename] = str;\n\n // Start with the primary rule.\n // The whole syntax tree is held under a Ruleset node,\n // with the `root` property set to true, so no `{}` are\n // output. The callback is called when the input is parsed.\n try {\n parserInput.start(str, context.chunkInput, function fail(msg, index) {\n throw new LessError({\n index,\n type: 'Parse',\n message: msg,\n filename: fileInfo.filename\n }, imports);\n });\n\n tree.Node.prototype.parse = this;\n root = new tree.Ruleset(null, this.parsers.primary());\n tree.Node.prototype.rootNode = root;\n root.root = true;\n root.firstRoot = true;\n root.functionRegistry = functionRegistry.inherit();\n \n } catch (e) {\n return callback(new LessError(e, imports, fileInfo.filename));\n }\n\n // If `i` is smaller than the `input.length - 1`,\n // it means the parser wasn't able to parse the whole\n // string, so we've got a parsing error.\n //\n // We try to extract a \\n delimited string,\n // showing the line where the parse error occurred.\n // We split it up into two parts (the part which parsed,\n // and the part which didn't), so we can color them differently.\n const endInfo = parserInput.end();\n if (!endInfo.isFinished) {\n\n let message = endInfo.furthestPossibleErrorMessage;\n\n if (!message) {\n message = 'Unrecognised input';\n if (endInfo.furthestChar === '}') {\n message += '. Possibly missing opening \\'{\\'';\n } else if (endInfo.furthestChar === ')') {\n message += '. Possibly missing opening \\'(\\'';\n } else if (endInfo.furthestReachedEnd) {\n message += '. Possibly missing something';\n }\n }\n\n error = new LessError({\n type: 'Parse',\n message,\n index: endInfo.furthest,\n filename: fileInfo.filename\n }, imports);\n }\n\n const finish = e => {\n e = error || e || imports.error;\n\n if (e) {\n if (!(e instanceof LessError)) {\n e = new LessError(e, imports, fileInfo.filename);\n }\n\n return callback(e);\n }\n else {\n return callback(null, root);\n }\n };\n\n if (context.processImports !== false) {\n new visitors.ImportVisitor(imports, finish)\n .run(root);\n } else {\n return finish();\n }\n },\n\n //\n // Here in, the parsing rules/functions\n //\n // The basic structure of the syntax tree generated is as follows:\n //\n // Ruleset -> Declaration -> Value -> Expression -> Entity\n //\n // Here's some Less code:\n //\n // .class {\n // color: #fff;\n // border: 1px solid #000;\n // width: @w + 4px;\n // > .child {...}\n // }\n //\n // And here's what the parse tree might look like:\n //\n // Ruleset (Selector '.class', [\n // Declaration (\"color\", Value ([Expression [Color #fff]]))\n // Declaration (\"border\", Value ([Expression [Dimension 1px][Keyword \"solid\"][Color #000]]))\n // Declaration (\"width\", Value ([Expression [Operation \" + \" [Variable \"@w\"][Dimension 4px]]]))\n // Ruleset (Selector [Element '>', '.child'], [...])\n // ])\n //\n // In general, most rules will try to parse a token with the `$re()` function, and if the return\n // value is truly, will return a new node, of the relevant type. Sometimes, we need to check\n // first, before parsing, that's when we use `peek()`.\n //\n parsers: parsers = {\n //\n // The `primary` rule is the *entry* and *exit* point of the parser.\n // The rules here can appear at any level of the parse tree.\n //\n // The recursive nature of the grammar is an interplay between the `block`\n // rule, which represents `{ ... }`, the `ruleset` rule, and this `primary` rule,\n // as represented by this simplified grammar:\n //\n // primary → (ruleset | declaration)+\n // ruleset → selector+ block\n // block → '{' primary '}'\n //\n // Only at one point is the primary rule not called from the\n // block rule: at the root level.\n //\n primary: function () {\n const mixin = this.mixin;\n let root = [];\n let node;\n\n while (true) {\n while (true) {\n node = this.comment();\n if (!node) { break; }\n root.push(node);\n }\n // always process comments before deciding if finished\n if (parserInput.finished) {\n break;\n }\n if (parserInput.peek('}')) {\n break;\n }\n\n node = this.extendRule();\n if (node) {\n root = root.concat(node);\n continue;\n }\n\n node = mixin.definition() || this.declaration() || mixin.call(false, false) || \n this.ruleset() || this.variableCall() || this.entities.call() || this.atrule();\n if (node) {\n root.push(node);\n } else {\n let foundSemiColon = false;\n while (parserInput.$char(';')) {\n foundSemiColon = true;\n }\n if (!foundSemiColon) {\n break;\n }\n }\n }\n\n return root;\n },\n\n // comments are collected by the main parsing mechanism and then assigned to nodes\n // where the current structure allows it\n comment: function () {\n if (parserInput.commentStore.length) {\n const comment = parserInput.commentStore.shift();\n return new(tree.Comment)(comment.text, comment.isLineComment, comment.index, fileInfo);\n }\n },\n\n //\n // Entities are tokens which can be found inside an Expression\n //\n entities: {\n mixinLookup: function() {\n return parsers.mixin.call(true, true);\n },\n //\n // A string, which supports escaping \" and '\n //\n // \"milky way\" 'he\\'s the one!'\n //\n quoted: function (forceEscaped) {\n let str;\n const index = parserInput.i;\n let isEscaped = false;\n\n parserInput.save();\n if (parserInput.$char('~')) {\n isEscaped = true;\n } else if (forceEscaped) {\n parserInput.restore();\n return;\n }\n\n str = parserInput.$quoted();\n if (!str) {\n parserInput.restore();\n return;\n }\n parserInput.forget();\n\n return new(tree.Quoted)(str.charAt(0), str.substr(1, str.length - 2), isEscaped, index, fileInfo);\n },\n\n //\n // A catch-all word, such as:\n //\n // black border-collapse\n //\n keyword: function () {\n const k = parserInput.$char('%') || parserInput.$re(/^\\[?(?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+\\]?/);\n if (k) {\n return tree.Color.fromKeyword(k) || new(tree.Keyword)(k);\n }\n },\n\n //\n // A function call\n //\n // rgb(255, 0, 255)\n //\n // The arguments are parsed with the `entities.arguments` parser.\n //\n call: function () {\n let name;\n let args;\n let func;\n const index = parserInput.i;\n\n // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18\n if (parserInput.peek(/^url\\(/i)) {\n return;\n }\n\n parserInput.save();\n\n name = parserInput.$re(/^([\\w-]+|%|~|progid:[\\w\\.]+)\\(/);\n if (!name) {\n parserInput.forget(); \n return;\n }\n\n name = name[1];\n func = this.customFuncCall(name);\n if (func) {\n args = func.parse();\n if (args && func.stop) {\n parserInput.forget();\n return args;\n }\n }\n\n args = this.arguments(args);\n\n if (!parserInput.$char(')')) {\n parserInput.restore('Could not parse call arguments or missing \\')\\'');\n return;\n }\n\n parserInput.forget();\n\n return new(tree.Call)(name, args, index, fileInfo);\n },\n \n //\n // Parsing rules for functions with non-standard args, e.g.:\n //\n // boolean(not(2 > 1))\n //\n // This is a quick prototype, to be modified/improved when\n // more custom-parsed funcs come (e.g. `selector(...)`)\n //\n\n customFuncCall: function (name) {\n /* Ideally the table is to be moved out of here for faster perf.,\n but it's quite tricky since it relies on all these `parsers`\n and `expect` available only here */\n return {\n alpha: f(parsers.ieAlpha, true),\n boolean: f(condition),\n 'if': f(condition)\n }[name.toLowerCase()];\n\n function f(parse, stop) {\n return {\n parse, // parsing function\n stop // when true - stop after parse() and return its result, \n // otherwise continue for plain args\n };\n }\n \n function condition() {\n return [expect(parsers.condition, 'expected condition')];\n }\n },\n\n arguments: function (prevArgs) {\n let argsComma = prevArgs || [];\n const argsSemiColon = [];\n let isSemiColonSeparated;\n let value;\n\n parserInput.save();\n\n while (true) {\n if (prevArgs) {\n prevArgs = false;\n } else {\n value = parsers.detachedRuleset() || this.assignment() || parsers.expression();\n if (!value) {\n break;\n }\n\n if (value.value && value.value.length == 1) {\n value = value.value[0];\n }\n\n argsComma.push(value);\n }\n\n if (parserInput.$char(',')) {\n continue;\n }\n\n if (parserInput.$char(';') || isSemiColonSeparated) {\n isSemiColonSeparated = true;\n value = (argsComma.length < 1) ? argsComma[0]\n : new tree.Value(argsComma);\n argsSemiColon.push(value);\n argsComma = [];\n }\n }\n\n parserInput.forget();\n return isSemiColonSeparated ? argsSemiColon : argsComma;\n },\n literal: function () {\n return this.dimension() ||\n this.color() ||\n this.quoted() ||\n this.unicodeDescriptor();\n },\n\n // Assignments are argument entities for calls.\n // They are present in ie filter properties as shown below.\n //\n // filter: progid:DXImageTransform.Microsoft.Alpha( *opacity=50* )\n //\n\n assignment: function () {\n let key;\n let value;\n parserInput.save();\n key = parserInput.$re(/^\\w+(?=\\s?=)/i);\n if (!key) {\n parserInput.restore();\n return;\n }\n if (!parserInput.$char('=')) {\n parserInput.restore();\n return;\n }\n value = parsers.entity();\n if (value) {\n parserInput.forget();\n return new(tree.Assignment)(key, value);\n } else {\n parserInput.restore();\n }\n },\n\n //\n // Parse url() tokens\n //\n // We use a specific rule for urls, because they don't really behave like\n // standard function calls. The difference is that the argument doesn't have\n // to be enclosed within a string, so it can't be parsed as an Expression.\n //\n url: function () {\n let value;\n const index = parserInput.i;\n\n parserInput.autoCommentAbsorb = false;\n\n if (!parserInput.$str('url(')) {\n parserInput.autoCommentAbsorb = true;\n return;\n }\n\n value = this.quoted() || this.variable() || this.property() ||\n parserInput.$re(/^(?:(?:\\\\[\\(\\)'\"])|[^\\(\\)'\"])+/) || '';\n\n parserInput.autoCommentAbsorb = true;\n\n expectChar(')');\n\n return new(tree.URL)((value.value != null || \n value instanceof tree.Variable || \n value instanceof tree.Property) ?\n value : new(tree.Anonymous)(value, index), index, fileInfo);\n },\n\n //\n // A Variable entity, such as `@fink`, in\n //\n // width: @fink + 2px\n //\n // We use a different parser for variable definitions,\n // see `parsers.variable`.\n //\n variable: function () {\n let ch;\n let name;\n const index = parserInput.i;\n\n parserInput.save();\n if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^@@?[\\w-]+/))) {\n ch = parserInput.currentChar();\n if (ch === '(' || ch === '[' && !parserInput.prevChar().match(/^\\s/)) {\n // this may be a VariableCall lookup\n const result = parsers.variableCall(name);\n if (result) {\n parserInput.forget();\n return result;\n }\n }\n parserInput.forget();\n return new(tree.Variable)(name, index, fileInfo);\n }\n parserInput.restore();\n },\n\n // A variable entity using the protective {} e.g. @{var}\n variableCurly: function () {\n let curly;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '@' && (curly = parserInput.$re(/^@\\{([\\w-]+)\\}/))) {\n return new(tree.Variable)(`@${curly[1]}`, index, fileInfo);\n }\n },\n //\n // A Property accessor, such as `$color`, in\n //\n // background-color: $color\n //\n property: function () {\n let name;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '$' && (name = parserInput.$re(/^\\$[\\w-]+/))) {\n return new(tree.Property)(name, index, fileInfo);\n }\n },\n\n // A property entity useing the protective {} e.g. ${prop}\n propertyCurly: function () {\n let curly;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '$' && (curly = parserInput.$re(/^\\$\\{([\\w-]+)\\}/))) {\n return new(tree.Property)(`$${curly[1]}`, index, fileInfo);\n }\n },\n //\n // A Hexadecimal color\n //\n // #4F3C2F\n //\n // `rgb` and `hsl` colors are parsed through the `entities.call` parser.\n //\n color: function () {\n let rgb;\n parserInput.save();\n\n if (parserInput.currentChar() === '#' && (rgb = parserInput.$re(/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})([\\w.#\\[])?/))) {\n if (!rgb[2]) {\n parserInput.forget();\n return new(tree.Color)(rgb[1], undefined, rgb[0]);\n } \n }\n parserInput.restore();\n },\n\n colorKeyword: function () {\n parserInput.save();\n const autoCommentAbsorb = parserInput.autoCommentAbsorb;\n parserInput.autoCommentAbsorb = false;\n const k = parserInput.$re(/^[_A-Za-z-][_A-Za-z0-9-]+/);\n parserInput.autoCommentAbsorb = autoCommentAbsorb;\n if (!k) {\n parserInput.forget();\n return;\n }\n parserInput.restore();\n const color = tree.Color.fromKeyword(k);\n if (color) {\n parserInput.$str(k);\n return color;\n }\n },\n\n //\n // A Dimension, that is, a number and a unit\n //\n // 0.5em 95%\n //\n dimension: function () {\n if (parserInput.peekNotNumeric()) {\n return;\n }\n\n const value = parserInput.$re(/^([+-]?\\d*\\.?\\d+)(%|[a-z_]+)?/i);\n if (value) {\n return new(tree.Dimension)(value[1], value[2]);\n }\n },\n\n //\n // A unicode descriptor, as is used in unicode-range\n //\n // U+0?? or U+00A1-00A9\n //\n unicodeDescriptor: function () {\n let ud;\n\n ud = parserInput.$re(/^U\\+[0-9a-fA-F?]+(\\-[0-9a-fA-F?]+)?/);\n if (ud) {\n return new(tree.UnicodeDescriptor)(ud[0]);\n }\n },\n\n //\n // JavaScript code to be evaluated\n //\n // `window.location.href`\n //\n javascript: function () {\n let js;\n const index = parserInput.i;\n\n parserInput.save();\n\n const escape = parserInput.$char('~');\n const jsQuote = parserInput.$char('`');\n\n if (!jsQuote) {\n parserInput.restore();\n return;\n }\n\n js = parserInput.$re(/^[^`]*`/);\n if (js) {\n parserInput.forget();\n return new(tree.JavaScript)(js.substr(0, js.length - 1), Boolean(escape), index, fileInfo);\n }\n parserInput.restore('invalid javascript definition');\n }\n },\n\n //\n // The variable part of a variable definition. Used in the `rule` parser\n //\n // @fink:\n //\n variable: function () {\n let name;\n\n if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^(@[\\w-]+)\\s*:/))) { return name[1]; }\n },\n\n //\n // Call a variable value to retrieve a detached ruleset\n // or a value from a detached ruleset's rules.\n //\n // @fink();\n // @fink;\n // color: @fink[@color];\n //\n variableCall: function (parsedName) {\n let lookups;\n const i = parserInput.i;\n const inValue = !!parsedName;\n let name = parsedName;\n\n parserInput.save();\n\n if (name || (parserInput.currentChar() === '@'\n && (name = parserInput.$re(/^(@[\\w-]+)(\\(\\s*\\))?/)))) {\n\n lookups = this.mixin.ruleLookups();\n\n if (!lookups && ((inValue && parserInput.$str('()') !== '()') || (name[2] !== '()'))) {\n parserInput.restore('Missing \\'[...]\\' lookup in variable call');\n return;\n }\n\n if (!inValue) {\n name = name[1];\n }\n\n const call = new tree.VariableCall(name, i, fileInfo);\n if (!inValue && parsers.end()) {\n parserInput.forget();\n return call;\n }\n else {\n parserInput.forget();\n return new tree.NamespaceValue(call, lookups, i, fileInfo);\n }\n }\n\n parserInput.restore();\n },\n\n //\n // extend syntax - used to extend selectors\n //\n extend: function(isRule) {\n let elements;\n let e;\n const index = parserInput.i;\n let option;\n let extendList;\n let extend;\n\n if (!parserInput.$str(isRule ? '&:extend(' : ':extend(')) {\n return;\n }\n\n do {\n option = null;\n elements = null;\n while (!(option = parserInput.$re(/^(all)(?=\\s*(\\)|,))/))) {\n e = this.element();\n if (!e) {\n break;\n }\n if (elements) {\n elements.push(e);\n } else {\n elements = [ e ];\n }\n }\n\n option = option && option[1];\n if (!elements) {\n error('Missing target selector for :extend().');\n }\n extend = new(tree.Extend)(new(tree.Selector)(elements), option, index, fileInfo);\n if (extendList) {\n extendList.push(extend);\n } else {\n extendList = [ extend ];\n }\n } while (parserInput.$char(','));\n\n expect(/^\\)/);\n\n if (isRule) {\n expect(/^;/);\n }\n\n return extendList;\n },\n\n //\n // extendRule - used in a rule to extend all the parent selectors\n //\n extendRule: function() {\n return this.extend(true);\n },\n\n //\n // Mixins\n //\n mixin: {\n //\n // A Mixin call, with an optional argument list\n //\n // #mixins > .square(#fff);\n // #mixins.square(#fff);\n // .rounded(4px, black);\n // .button;\n //\n // We can lookup / return a value using the lookup syntax:\n //\n // color: #mixin.square(#fff)[@color];\n //\n // The `while` loop is there because mixins can be\n // namespaced, but we only support the child and descendant\n // selector for now.\n //\n call: function (inValue, getLookup) {\n const s = parserInput.currentChar();\n let important = false;\n let lookups;\n const index = parserInput.i;\n let elements;\n let args;\n let hasParens;\n\n if (s !== '.' && s !== '#') { return; }\n\n parserInput.save(); // stop us absorbing part of an invalid selector\n\n elements = this.elements();\n\n if (elements) {\n if (parserInput.$char('(')) {\n args = this.args(true).args;\n expectChar(')');\n hasParens = true;\n }\n\n if (getLookup !== false) {\n lookups = this.ruleLookups();\n }\n if (getLookup === true && !lookups) {\n parserInput.restore();\n return;\n }\n\n if (!lookups && !hasParens) {\n // This isn't a valid mixin call\n parserInput.restore('Unrecognized input. Possibly missing \\'(\\' in mixin call.');\n return;\n }\n\n if (!inValue && parsers.important()) {\n important = true;\n }\n\n if (inValue || parsers.end()) {\n parserInput.forget();\n const mixin = new(tree.mixin.Call)(elements, args, index, fileInfo, !lookups && important);\n if (lookups) {\n return new tree.NamespaceValue(mixin, lookups);\n }\n else {\n return mixin;\n }\n }\n }\n\n parserInput.restore();\n },\n /**\n * Matching elements for mixins\n * (Start with . or # and can have > )\n */\n elements: function() {\n let elements;\n let e;\n let c;\n let elem;\n let elemIndex;\n const re = /^[#.](?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/;\n while (true) {\n elemIndex = parserInput.i;\n e = parserInput.$re(re);\n \n if (!e) {\n break;\n }\n elem = new(tree.Element)(c, e, false, elemIndex, fileInfo);\n if (elements) {\n elements.push(elem);\n } else {\n elements = [ elem ];\n }\n c = parserInput.$char('>');\n }\n return elements;\n },\n args: function (isCall) {\n const entities = parsers.entities;\n const returner = { args:null, variadic: false };\n let expressions = [];\n const argsSemiColon = [];\n const argsComma = [];\n let isSemiColonSeparated;\n let expressionContainsNamed;\n let name;\n let nameLoop;\n let value;\n let arg;\n let expand;\n let hasSep = true;\n\n parserInput.save();\n\n while (true) {\n if (isCall) {\n arg = parsers.detachedRuleset() || parsers.expression();\n } else {\n parserInput.commentStore.length = 0;\n if (parserInput.$str('...')) {\n returner.variadic = true;\n if (parserInput.$char(';') && !isSemiColonSeparated) {\n isSemiColonSeparated = true;\n }\n (isSemiColonSeparated ? argsSemiColon : argsComma)\n .push({ variadic: true });\n break;\n }\n arg = entities.variable() || entities.property() || entities.literal() || entities.keyword() || this.call(true);\n }\n\n if (!arg || !hasSep) {\n break;\n }\n\n nameLoop = null;\n if (arg.throwAwayComments) {\n arg.throwAwayComments();\n }\n value = arg;\n let val = null;\n\n if (isCall) {\n // Variable\n if (arg.value && arg.value.length == 1) {\n val = arg.value[0];\n }\n } else {\n val = arg;\n }\n\n if (val && (val instanceof tree.Variable || val instanceof tree.Property)) {\n if (parserInput.$char(':')) {\n if (expressions.length > 0) {\n if (isSemiColonSeparated) {\n error('Cannot mix ; and , as delimiter types');\n }\n expressionContainsNamed = true;\n }\n\n value = parsers.detachedRuleset() || parsers.expression();\n\n if (!value) {\n if (isCall) {\n error('could not understand value for named argument');\n } else {\n parserInput.restore();\n returner.args = [];\n return returner;\n }\n }\n nameLoop = (name = val.name);\n } else if (parserInput.$str('...')) {\n if (!isCall) {\n returner.variadic = true;\n if (parserInput.$char(';') && !isSemiColonSeparated) {\n isSemiColonSeparated = true;\n }\n (isSemiColonSeparated ? argsSemiColon : argsComma)\n .push({ name: arg.name, variadic: true });\n break;\n } else {\n expand = true;\n }\n } else if (!isCall) {\n name = nameLoop = val.name;\n value = null;\n }\n }\n\n if (value) {\n expressions.push(value);\n }\n\n argsComma.push({ name:nameLoop, value, expand });\n\n if (parserInput.$char(',')) {\n hasSep = true;\n continue;\n }\n hasSep = parserInput.$char(';') === ';';\n\n if (hasSep || isSemiColonSeparated) {\n\n if (expressionContainsNamed) {\n error('Cannot mix ; and , as delimiter types');\n }\n\n isSemiColonSeparated = true;\n\n if (expressions.length > 1) {\n value = new(tree.Value)(expressions);\n }\n argsSemiColon.push({ name, value, expand });\n\n name = null;\n expressions = [];\n expressionContainsNamed = false;\n }\n }\n\n parserInput.forget();\n returner.args = isSemiColonSeparated ? argsSemiColon : argsComma;\n return returner;\n },\n //\n // A Mixin definition, with a list of parameters\n //\n // .rounded (@radius: 2px, @color) {\n // ...\n // }\n //\n // Until we have a finer grained state-machine, we have to\n // do a look-ahead, to make sure we don't have a mixin call.\n // See the `rule` function for more information.\n //\n // We start by matching `.rounded (`, and then proceed on to\n // the argument list, which has optional default values.\n // We store the parameters in `params`, with a `value` key,\n // if there is a value, such as in the case of `@radius`.\n //\n // Once we've got our params list, and a closing `)`, we parse\n // the `{...}` block.\n //\n definition: function () {\n let name;\n let params = [];\n let match;\n let ruleset;\n let cond;\n let variadic = false;\n if ((parserInput.currentChar() !== '.' && parserInput.currentChar() !== '#') ||\n parserInput.peek(/^[^{]*\\}/)) {\n return;\n }\n\n parserInput.save();\n\n match = parserInput.$re(/^([#.](?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\\s*\\(/);\n if (match) {\n name = match[1];\n\n const argInfo = this.args(false);\n params = argInfo.args;\n variadic = argInfo.variadic;\n\n // .mixincall(\"@{a}\");\n // looks a bit like a mixin definition..\n // also\n // .mixincall(@a: {rule: set;});\n // so we have to be nice and restore\n if (!parserInput.$char(')')) {\n parserInput.restore('Missing closing \\')\\'');\n return;\n }\n\n parserInput.commentStore.length = 0;\n\n if (parserInput.$str('when')) { // Guard\n cond = expect(parsers.conditions, 'expected condition');\n }\n\n ruleset = parsers.block();\n\n if (ruleset) {\n parserInput.forget();\n return new(tree.mixin.Definition)(name, params, ruleset, cond, variadic);\n } else {\n parserInput.restore();\n }\n } else {\n parserInput.restore();\n }\n },\n \n ruleLookups: function() {\n let rule;\n let args;\n const lookups = [];\n\n if (parserInput.currentChar() !== '[') { \n return;\n }\n\n while (true) {\n parserInput.save();\n args = null;\n rule = this.lookupValue();\n if (!rule && rule !== '') {\n parserInput.restore();\n break;\n }\n lookups.push(rule);\n parserInput.forget();\n }\n if (lookups.length > 0) {\n return lookups;\n }\n },\n \n lookupValue: function() {\n parserInput.save();\n \n if (!parserInput.$char('[')) { \n parserInput.restore();\n return;\n }\n \n const name = parserInput.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/);\n \n if (!parserInput.$char(']')) {\n parserInput.restore();\n return;\n } \n\n if (name || name === '') {\n parserInput.forget();\n return name;\n }\n \n parserInput.restore();\n }\n },\n //\n // Entities are the smallest recognized token,\n // and can be found inside a rule's value.\n //\n entity: function () {\n const entities = this.entities;\n\n return this.comment() || entities.literal() || entities.variable() || entities.url() ||\n entities.property() || entities.call() || entities.keyword() || this.mixin.call(true) ||\n entities.javascript();\n },\n\n //\n // A Declaration terminator. Note that we use `peek()` to check for '}',\n // because the `block` rule will be expecting it, but we still need to make sure\n // it's there, if ';' was omitted.\n //\n end: function () {\n return parserInput.$char(';') || parserInput.peek('}');\n },\n\n //\n // IE's alpha function\n //\n // alpha(opacity=88)\n //\n ieAlpha: function () {\n let value;\n\n // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18\n if (!parserInput.$re(/^opacity=/i)) { return; }\n value = parserInput.$re(/^\\d+/);\n if (!value) {\n value = expect(parsers.entities.variable, 'Could not parse alpha');\n value = `@{${value.name.slice(1)}}`;\n }\n expectChar(')');\n return new tree.Quoted('', `alpha(opacity=${value})`);\n },\n\n //\n // A Selector Element\n //\n // div\n // + h1\n // #socks\n // input[type=\"text\"]\n //\n // Elements are the building blocks for Selectors,\n // they are made out of a `Combinator` (see combinator rule),\n // and an element name, such as a tag a class, or `*`.\n //\n element: function () {\n let e;\n let c;\n let v;\n const index = parserInput.i;\n\n c = this.combinator();\n\n e = parserInput.$re(/^(?:\\d+\\.\\d+|\\d+)%/) ||\n parserInput.$re(/^(?:[.#]?|:*)(?:[\\w-]|[^\\x00-\\x9f]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/) ||\n parserInput.$char('*') || parserInput.$char('&') || this.attribute() ||\n parserInput.$re(/^\\([^&()@]+\\)/) || parserInput.$re(/^[\\.#:](?=@)/) ||\n this.entities.variableCurly();\n\n if (!e) {\n parserInput.save();\n if (parserInput.$char('(')) {\n if ((v = this.selector(false)) && parserInput.$char(')')) {\n e = new(tree.Paren)(v);\n parserInput.forget();\n } else {\n parserInput.restore('Missing closing \\')\\'');\n }\n } else {\n parserInput.forget();\n }\n }\n\n if (e) { return new(tree.Element)(c, e, e instanceof tree.Variable, index, fileInfo); }\n },\n\n //\n // Combinators combine elements together, in a Selector.\n //\n // Because our parser isn't white-space sensitive, special care\n // has to be taken, when parsing the descendant combinator, ` `,\n // as it's an empty space. We have to check the previous character\n // in the input, to see if it's a ` ` character. More info on how\n // we deal with this in *combinator.js*.\n //\n combinator: function () {\n let c = parserInput.currentChar();\n\n if (c === '/') {\n parserInput.save();\n const slashedCombinator = parserInput.$re(/^\\/[a-z]+\\//i);\n if (slashedCombinator) {\n parserInput.forget();\n return new(tree.Combinator)(slashedCombinator);\n }\n parserInput.restore();\n }\n\n if (c === '>' || c === '+' || c === '~' || c === '|' || c === '^') {\n parserInput.i++;\n if (c === '^' && parserInput.currentChar() === '^') {\n c = '^^';\n parserInput.i++;\n }\n while (parserInput.isWhitespace()) { parserInput.i++; }\n return new(tree.Combinator)(c);\n } else if (parserInput.isWhitespace(-1)) {\n return new(tree.Combinator)(' ');\n } else {\n return new(tree.Combinator)(null);\n }\n },\n //\n // A CSS Selector\n // with less extensions e.g. the ability to extend and guard\n //\n // .class > div + h1\n // li a:hover\n //\n // Selectors are made out of one or more Elements, see above.\n //\n selector: function (isLess) {\n const index = parserInput.i;\n let elements;\n let extendList;\n let c;\n let e;\n let allExtends;\n let when;\n let condition;\n isLess = isLess !== false;\n while ((isLess && (extendList = this.extend())) || (isLess && (when = parserInput.$str('when'))) || (e = this.element())) {\n if (when) {\n condition = expect(this.conditions, 'expected condition');\n } else if (condition) {\n error('CSS guard can only be used at the end of selector');\n } else if (extendList) {\n if (allExtends) {\n allExtends = allExtends.concat(extendList);\n } else {\n allExtends = extendList;\n }\n } else {\n if (allExtends) { error('Extend can only be used at the end of selector'); }\n c = parserInput.currentChar();\n if (elements) {\n elements.push(e);\n } else {\n elements = [ e ];\n }\n e = null;\n }\n if (c === '{' || c === '}' || c === ';' || c === ',' || c === ')') {\n break;\n }\n }\n\n if (elements) { return new(tree.Selector)(elements, allExtends, condition, index, fileInfo); }\n if (allExtends) { error('Extend must be used to extend a selector, it cannot be used on its own'); }\n },\n selectors: function () {\n let s;\n let selectors;\n while (true) {\n s = this.selector();\n if (!s) {\n break;\n }\n if (selectors) {\n selectors.push(s);\n } else {\n selectors = [ s ];\n }\n parserInput.commentStore.length = 0;\n if (s.condition && selectors.length > 1) {\n error(\"Guards are only currently allowed on a single selector.\");\n }\n if (!parserInput.$char(',')) { break; }\n if (s.condition) {\n error(\"Guards are only currently allowed on a single selector.\");\n }\n parserInput.commentStore.length = 0;\n }\n return selectors;\n },\n attribute: function () {\n if (!parserInput.$char('[')) { return; }\n\n const entities = this.entities;\n let key;\n let val;\n let op;\n\n if (!(key = entities.variableCurly())) {\n key = expect(/^(?:[_A-Za-z0-9-\\*]*\\|)?(?:[_A-Za-z0-9-]|\\\\.)+/);\n }\n\n op = parserInput.$re(/^[|~*$^]?=/);\n if (op) {\n val = entities.quoted() || parserInput.$re(/^[0-9]+%/) || parserInput.$re(/^[\\w-]+/) || entities.variableCurly();\n }\n\n expectChar(']');\n\n return new(tree.Attribute)(key, op, val);\n },\n\n //\n // The `block` rule is used by `ruleset` and `mixin.definition`.\n // It's a wrapper around the `primary` rule, with added `{}`.\n //\n block: function () {\n let content;\n if (parserInput.$char('{') && (content = this.primary()) && parserInput.$char('}')) {\n return content;\n }\n },\n\n blockRuleset: function() {\n let block = this.block();\n\n if (block) {\n block = new tree.Ruleset(null, block);\n }\n return block;\n },\n\n detachedRuleset: function() {\n let argInfo;\n let params;\n let variadic;\n\n parserInput.save();\n if (parserInput.$re(/^[.#]\\(/)) {\n /**\n * DR args currently only implemented for each() function, and not \n * yet settable as `@dr: #(@arg) {}`\n * This should be done when DRs are merged with mixins.\n * See: https://github.com/less/less-meta/issues/16\n */\n argInfo = this.mixin.args(false);\n params = argInfo.args;\n variadic = argInfo.variadic;\n if (!parserInput.$char(')')) {\n parserInput.restore();\n return;\n }\n }\n const blockRuleset = this.blockRuleset();\n if (blockRuleset) {\n parserInput.forget();\n if (params) {\n return new tree.mixin.Definition(null, params, blockRuleset, null, variadic);\n }\n return new tree.DetachedRuleset(blockRuleset);\n }\n parserInput.restore();\n },\n\n //\n // div, .class, body > p {...}\n //\n ruleset: function () {\n let selectors;\n let rules;\n let debugInfo;\n\n parserInput.save();\n\n if (context.dumpLineNumbers) {\n debugInfo = getDebugInfo(parserInput.i);\n }\n\n selectors = this.selectors();\n\n if (selectors && (rules = this.block())) {\n parserInput.forget();\n const ruleset = new(tree.Ruleset)(selectors, rules, context.strictImports);\n if (context.dumpLineNumbers) {\n ruleset.debugInfo = debugInfo;\n }\n return ruleset;\n } else {\n parserInput.restore();\n }\n },\n declaration: function () {\n let name;\n let value;\n const index = parserInput.i;\n let hasDR;\n const c = parserInput.currentChar();\n let important;\n let merge;\n let isVariable;\n\n if (c === '.' || c === '#' || c === '&' || c === ':') { return; }\n\n parserInput.save();\n\n name = this.variable() || this.ruleProperty();\n if (name) {\n isVariable = typeof name === 'string';\n\n if (isVariable) {\n value = this.detachedRuleset();\n if (value) {\n hasDR = true;\n }\n }\n\n parserInput.commentStore.length = 0;\n if (!value) {\n // a name returned by this.ruleProperty() is always an array of the form:\n // [string-1, ..., string-n, \"\"] or [string-1, ..., string-n, \"+\"]\n // where each item is a tree.Keyword or tree.Variable\n merge = !isVariable && name.length > 1 && name.pop().value;\n\n // Custom property values get permissive parsing\n if (name[0].value && name[0].value.slice(0, 2) === '--') {\n value = this.permissiveValue();\n }\n // Try to store values as anonymous\n // If we need the value later we'll re-parse it in ruleset.parseValue\n else {\n value = this.anonymousValue();\n }\n if (value) {\n parserInput.forget();\n // anonymous values absorb the end ';' which is required for them to work\n return new(tree.Declaration)(name, value, false, merge, index, fileInfo);\n }\n\n if (!value) {\n value = this.value();\n }\n\n if (value) {\n important = this.important();\n } else if (isVariable) {\n // As a last resort, try permissiveValue\n value = this.permissiveValue();\n }\n }\n\n if (value && (this.end() || hasDR)) {\n parserInput.forget();\n return new(tree.Declaration)(name, value, important, merge, index, fileInfo);\n }\n else {\n parserInput.restore();\n }\n } else {\n parserInput.restore();\n }\n },\n anonymousValue: function () {\n const index = parserInput.i;\n const match = parserInput.$re(/^([^.#@\\$+\\/'\"*`(;{}-]*);/);\n if (match) {\n return new(tree.Anonymous)(match[1], index);\n }\n },\n /**\n * Used for custom properties, at-rules, and variables (as fallback)\n * Parses almost anything inside of {} [] () \"\" blocks\n * until it reaches outer-most tokens.\n * \n * First, it will try to parse comments and entities to reach\n * the end. This is mostly like the Expression parser except no\n * math is allowed.\n */\n permissiveValue: function (untilTokens) {\n let i;\n let e;\n let done;\n let value;\n const tok = untilTokens || ';';\n const index = parserInput.i;\n const result = [];\n\n function testCurrentChar() {\n const char = parserInput.currentChar();\n if (typeof tok === 'string') {\n return char === tok;\n } else {\n return tok.test(char);\n }\n }\n if (testCurrentChar()) {\n return;\n }\n value = [];\n do {\n e = this.comment();\n if (e) {\n value.push(e);\n continue;\n }\n e = this.entity();\n if (e) {\n value.push(e);\n }\n } while (e);\n\n done = testCurrentChar();\n\n if (value.length > 0) {\n value = new(tree.Expression)(value);\n if (done) {\n return value;\n }\n else {\n result.push(value);\n }\n // Preserve space before $parseUntil as it will not\n if (parserInput.prevChar() === ' ') {\n result.push(new tree.Anonymous(' ', index));\n }\n }\n parserInput.save();\n\n value = parserInput.$parseUntil(tok);\n\n if (value) {\n if (typeof value === 'string') {\n error(`Expected '${value}'`, 'Parse');\n }\n if (value.length === 1 && value[0] === ' ') {\n parserInput.forget();\n return new tree.Anonymous('', index);\n }\n let item;\n for (i = 0; i < value.length; i++) {\n item = value[i];\n if (Array.isArray(item)) {\n // Treat actual quotes as normal quoted values\n result.push(new tree.Quoted(item[0], item[1], true, index, fileInfo));\n }\n else {\n if (i === value.length - 1) {\n item = item.trim();\n }\n // Treat like quoted values, but replace vars like unquoted expressions\n const quote = new tree.Quoted('\\'', item, true, index, fileInfo);\n quote.variableRegex = /@([\\w-]+)/g;\n quote.propRegex = /\\$([\\w-]+)/g;\n result.push(quote);\n }\n }\n parserInput.forget();\n return new tree.Expression(result, true);\n }\n parserInput.restore();\n },\n\n //\n // An @import atrule\n //\n // @import \"lib\";\n //\n // Depending on our environment, importing is done differently:\n // In the browser, it's an XHR request, in Node, it would be a\n // file-system operation. The function used for importing is\n // stored in `import`, which we pass to the Import constructor.\n //\n 'import': function () {\n let path;\n let features;\n const index = parserInput.i;\n\n const dir = parserInput.$re(/^@import?\\s+/);\n\n if (dir) {\n const options = (dir ? this.importOptions() : null) || {};\n\n if ((path = this.entities.quoted() || this.entities.url())) {\n features = this.mediaFeatures();\n\n if (!parserInput.$char(';')) {\n parserInput.i = index;\n error('missing semi-colon or unrecognised media features on import');\n }\n features = features && new(tree.Value)(features);\n return new(tree.Import)(path, features, options, index, fileInfo);\n }\n else {\n parserInput.i = index;\n error('malformed import statement');\n }\n }\n },\n\n importOptions: function() {\n let o;\n const options = {};\n let optionName;\n let value;\n\n // list of options, surrounded by parens\n if (!parserInput.$char('(')) { return null; }\n do {\n o = this.importOption();\n if (o) {\n optionName = o;\n value = true;\n switch (optionName) {\n case 'css':\n optionName = 'less';\n value = false;\n break;\n case 'once':\n optionName = 'multiple';\n value = false;\n break;\n }\n options[optionName] = value;\n if (!parserInput.$char(',')) { break; }\n }\n } while (o);\n expectChar(')');\n return options;\n },\n\n importOption: function() {\n const opt = parserInput.$re(/^(less|css|multiple|once|inline|reference|optional)/);\n if (opt) {\n return opt[1];\n }\n },\n\n mediaFeature: function () {\n const entities = this.entities;\n const nodes = [];\n let e;\n let p;\n parserInput.save();\n do {\n e = entities.keyword() || entities.variable() || entities.mixinLookup();\n if (e) {\n nodes.push(e);\n } else if (parserInput.$char('(')) {\n p = this.property();\n e = this.value();\n if (parserInput.$char(')')) {\n if (p && e) {\n nodes.push(new(tree.Paren)(new(tree.Declaration)(p, e, null, null, parserInput.i, fileInfo, true)));\n } else if (e) {\n nodes.push(new(tree.Paren)(e));\n } else {\n error('badly formed media feature definition');\n }\n } else {\n error('Missing closing \\')\\'', 'Parse');\n }\n }\n } while (e);\n\n parserInput.forget();\n if (nodes.length > 0) {\n return new(tree.Expression)(nodes);\n }\n },\n\n mediaFeatures: function () {\n const entities = this.entities;\n const features = [];\n let e;\n do {\n e = this.mediaFeature();\n if (e) {\n features.push(e);\n if (!parserInput.$char(',')) { break; }\n } else {\n e = entities.variable() || entities.mixinLookup();\n if (e) {\n features.push(e);\n if (!parserInput.$char(',')) { break; }\n }\n }\n } while (e);\n\n return features.length > 0 ? features : null;\n },\n\n media: function () {\n let features;\n let rules;\n let media;\n let debugInfo;\n const index = parserInput.i;\n\n if (context.dumpLineNumbers) {\n debugInfo = getDebugInfo(index);\n }\n\n parserInput.save();\n\n if (parserInput.$str('@media')) {\n features = this.mediaFeatures();\n\n rules = this.block();\n\n if (!rules) {\n error('media definitions require block statements after any features');\n }\n\n parserInput.forget();\n\n media = new(tree.Media)(rules, features, index, fileInfo);\n if (context.dumpLineNumbers) {\n media.debugInfo = debugInfo;\n }\n\n return media;\n }\n\n parserInput.restore();\n },\n\n //\n\n // A @plugin directive, used to import plugins dynamically.\n //\n // @plugin (args) \"lib\";\n //\n plugin: function () {\n let path;\n let args;\n let options;\n const index = parserInput.i;\n const dir = parserInput.$re(/^@plugin?\\s+/);\n\n if (dir) {\n args = this.pluginArgs();\n\n if (args) {\n options = {\n pluginArgs: args,\n isPlugin: true\n };\n }\n else {\n options = { isPlugin: true };\n }\n\n if ((path = this.entities.quoted() || this.entities.url())) {\n\n if (!parserInput.$char(';')) {\n parserInput.i = index;\n error('missing semi-colon on @plugin');\n }\n return new(tree.Import)(path, null, options, index, fileInfo);\n }\n else {\n parserInput.i = index;\n error('malformed @plugin statement');\n }\n }\n },\n\n pluginArgs: function() {\n // list of options, surrounded by parens\n parserInput.save();\n if (!parserInput.$char('(')) {\n parserInput.restore();\n return null;\n }\n const args = parserInput.$re(/^\\s*([^\\);]+)\\)\\s*/);\n if (args[1]) {\n parserInput.forget();\n return args[1].trim();\n }\n else { \n parserInput.restore();\n return null;\n }\n },\n\n //\n // A CSS AtRule\n //\n // @charset \"utf-8\";\n //\n atrule: function () {\n const index = parserInput.i;\n let name;\n let value;\n let rules;\n let nonVendorSpecificName;\n let hasIdentifier;\n let hasExpression;\n let hasUnknown;\n let hasBlock = true;\n let isRooted = true;\n\n if (parserInput.currentChar() !== '@') { return; }\n\n value = this['import']() || this.plugin() || this.media();\n if (value) {\n return value;\n }\n\n parserInput.save();\n\n name = parserInput.$re(/^@[a-z-]+/);\n\n if (!name) { return; }\n\n nonVendorSpecificName = name;\n if (name.charAt(1) == '-' && name.indexOf('-', 2) > 0) {\n nonVendorSpecificName = `@${name.slice(name.indexOf('-', 2) + 1)}`;\n }\n\n switch (nonVendorSpecificName) {\n case '@charset':\n hasIdentifier = true;\n hasBlock = false;\n break;\n case '@namespace':\n hasExpression = true;\n hasBlock = false;\n break;\n case '@keyframes':\n case '@counter-style':\n hasIdentifier = true;\n break;\n case '@document':\n case '@supports':\n hasUnknown = true;\n isRooted = false;\n break;\n default:\n hasUnknown = true;\n break;\n }\n\n parserInput.commentStore.length = 0;\n\n if (hasIdentifier) {\n value = this.entity();\n if (!value) {\n error(`expected ${name} identifier`);\n }\n } else if (hasExpression) {\n value = this.expression();\n if (!value) {\n error(`expected ${name} expression`);\n }\n } else if (hasUnknown) {\n value = this.permissiveValue(/^[{;]/);\n hasBlock = (parserInput.currentChar() === '{');\n if (!value) {\n if (!hasBlock && parserInput.currentChar() !== ';') {\n error(`${name} rule is missing block or ending semi-colon`);\n }\n }\n else if (!value.value) {\n value = null;\n }\n }\n\n if (hasBlock) {\n rules = this.blockRuleset();\n }\n\n if (rules || (!hasBlock && value && parserInput.$char(';'))) {\n parserInput.forget();\n return new(tree.AtRule)(name, value, rules, index, fileInfo,\n context.dumpLineNumbers ? getDebugInfo(index) : null,\n isRooted\n );\n }\n\n parserInput.restore('at-rule options not recognised');\n },\n\n //\n // A Value is a comma-delimited list of Expressions\n //\n // font-family: Baskerville, Georgia, serif;\n //\n // In a Rule, a Value represents everything after the `:`,\n // and before the `;`.\n //\n value: function () {\n let e;\n const expressions = [];\n const index = parserInput.i;\n\n do {\n e = this.expression();\n if (e) {\n expressions.push(e);\n if (!parserInput.$char(',')) { break; }\n }\n } while (e);\n\n if (expressions.length > 0) {\n return new(tree.Value)(expressions, index);\n }\n },\n important: function () {\n if (parserInput.currentChar() === '!') {\n return parserInput.$re(/^! *important/);\n }\n },\n sub: function () {\n let a;\n let e;\n\n parserInput.save();\n if (parserInput.$char('(')) {\n a = this.addition();\n if (a && parserInput.$char(')')) {\n parserInput.forget();\n e = new(tree.Expression)([a]);\n e.parens = true;\n return e;\n }\n parserInput.restore('Expected \\')\\'');\n return;\n }\n parserInput.restore();\n },\n multiplication: function () {\n let m;\n let a;\n let op;\n let operation;\n let isSpaced;\n m = this.operand();\n if (m) {\n isSpaced = parserInput.isWhitespace(-1);\n while (true) {\n if (parserInput.peek(/^\\/[*\\/]/)) {\n break;\n }\n\n parserInput.save();\n\n op = parserInput.$char('/') || parserInput.$char('*') || parserInput.$str('./');\n\n if (!op) { parserInput.forget(); break; }\n\n a = this.operand();\n\n if (!a) { parserInput.restore(); break; }\n parserInput.forget();\n\n m.parensInOp = true;\n a.parensInOp = true;\n operation = new(tree.Operation)(op, [operation || m, a], isSpaced);\n isSpaced = parserInput.isWhitespace(-1);\n }\n return operation || m;\n }\n },\n addition: function () {\n let m;\n let a;\n let op;\n let operation;\n let isSpaced;\n m = this.multiplication();\n if (m) {\n isSpaced = parserInput.isWhitespace(-1);\n while (true) {\n op = parserInput.$re(/^[-+]\\s+/) || (!isSpaced && (parserInput.$char('+') || parserInput.$char('-')));\n if (!op) {\n break;\n }\n a = this.multiplication();\n if (!a) {\n break;\n }\n\n m.parensInOp = true;\n a.parensInOp = true;\n operation = new(tree.Operation)(op, [operation || m, a], isSpaced);\n isSpaced = parserInput.isWhitespace(-1);\n }\n return operation || m;\n }\n },\n conditions: function () {\n let a;\n let b;\n const index = parserInput.i;\n let condition;\n\n a = this.condition(true);\n if (a) {\n while (true) {\n if (!parserInput.peek(/^,\\s*(not\\s*)?\\(/) || !parserInput.$char(',')) {\n break;\n }\n b = this.condition(true);\n if (!b) {\n break;\n }\n condition = new(tree.Condition)('or', condition || a, b, index);\n }\n return condition || a;\n }\n },\n condition: function (needsParens) {\n let result;\n let logical;\n let next;\n function or() {\n return parserInput.$str('or');\n }\n\n result = this.conditionAnd(needsParens);\n if (!result) {\n return ;\n }\n logical = or();\n if (logical) {\n next = this.condition(needsParens);\n if (next) {\n result = new(tree.Condition)(logical, result, next);\n } else {\n return ;\n }\n }\n return result;\n },\n conditionAnd: function (needsParens) {\n let result;\n let logical;\n let next;\n const self = this;\n function insideCondition() {\n const cond = self.negatedCondition(needsParens) || self.parenthesisCondition(needsParens);\n if (!cond && !needsParens) {\n return self.atomicCondition(needsParens);\n }\n return cond;\n }\n function and() {\n return parserInput.$str('and');\n }\n\n result = insideCondition();\n if (!result) {\n return ;\n }\n logical = and();\n if (logical) {\n next = this.conditionAnd(needsParens);\n if (next) {\n result = new(tree.Condition)(logical, result, next);\n } else {\n return ;\n }\n }\n return result;\n },\n negatedCondition: function (needsParens) {\n if (parserInput.$str('not')) {\n const result = this.parenthesisCondition(needsParens);\n if (result) {\n result.negate = !result.negate;\n }\n return result;\n }\n },\n parenthesisCondition: function (needsParens) {\n function tryConditionFollowedByParenthesis(me) {\n let body;\n parserInput.save();\n body = me.condition(needsParens);\n if (!body) {\n parserInput.restore();\n return ;\n }\n if (!parserInput.$char(')')) {\n parserInput.restore();\n return ;\n }\n parserInput.forget();\n return body;\n }\n\n let body;\n parserInput.save();\n if (!parserInput.$str('(')) {\n parserInput.restore();\n return ;\n }\n body = tryConditionFollowedByParenthesis(this);\n if (body) {\n parserInput.forget();\n return body;\n }\n\n body = this.atomicCondition(needsParens);\n if (!body) {\n parserInput.restore();\n return ;\n }\n if (!parserInput.$char(')')) {\n parserInput.restore(`expected ')' got '${parserInput.currentChar()}'`);\n return ;\n }\n parserInput.forget();\n return body;\n },\n atomicCondition: function (needsParens) {\n const entities = this.entities;\n const index = parserInput.i;\n let a;\n let b;\n let c;\n let op;\n\n function cond() {\n return this.addition() || entities.keyword() || entities.quoted() || entities.mixinLookup();\n }\n cond = cond.bind(this);\n\n a = cond();\n if (a) {\n if (parserInput.$char('>')) {\n if (parserInput.$char('=')) {\n op = '>=';\n } else {\n op = '>';\n }\n } else\n if (parserInput.$char('<')) {\n if (parserInput.$char('=')) {\n op = '<=';\n } else {\n op = '<';\n }\n } else\n if (parserInput.$char('=')) {\n if (parserInput.$char('>')) {\n op = '=>';\n } else if (parserInput.$char('<')) {\n op = '=<';\n } else {\n op = '=';\n }\n }\n if (op) {\n b = cond();\n if (b) {\n c = new(tree.Condition)(op, a, b, index, false);\n } else {\n error('expected expression');\n }\n } else {\n c = new(tree.Condition)('=', a, new(tree.Keyword)('true'), index, false);\n }\n return c;\n }\n },\n\n //\n // An operand is anything that can be part of an operation,\n // such as a Color, or a Variable\n //\n operand: function () {\n const entities = this.entities;\n let negate;\n\n if (parserInput.peek(/^-[@\\$\\(]/)) {\n negate = parserInput.$char('-');\n }\n\n let o = this.sub() || entities.dimension() ||\n entities.color() || entities.variable() ||\n entities.property() || entities.call() ||\n entities.quoted(true) || entities.colorKeyword() ||\n entities.mixinLookup();\n\n if (negate) {\n o.parensInOp = true;\n o = new(tree.Negative)(o);\n }\n\n return o;\n },\n\n //\n // Expressions either represent mathematical operations,\n // or white-space delimited Entities.\n //\n // 1px solid black\n // @var * 2\n //\n expression: function () {\n const entities = [];\n let e;\n let delim;\n const index = parserInput.i;\n\n do {\n e = this.comment();\n if (e) {\n entities.push(e);\n continue;\n }\n e = this.addition() || this.entity();\n\n if (e instanceof tree.Comment) {\n e = null;\n }\n\n if (e) {\n entities.push(e);\n // operations do not allow keyword \"/\" dimension (e.g. small/20px) so we support that here\n if (!parserInput.peek(/^\\/[\\/*]/)) {\n delim = parserInput.$char('/');\n if (delim) {\n entities.push(new(tree.Anonymous)(delim, index));\n }\n }\n }\n } while (e);\n if (entities.length > 0) {\n return new(tree.Expression)(entities);\n }\n },\n property: function () {\n const name = parserInput.$re(/^(\\*?-?[_a-zA-Z0-9-]+)\\s*:/);\n if (name) {\n return name[1];\n }\n },\n ruleProperty: function () {\n let name = [];\n const index = [];\n let s;\n let k;\n\n parserInput.save();\n\n const simpleProperty = parserInput.$re(/^([_a-zA-Z0-9-]+)\\s*:/);\n if (simpleProperty) {\n name = [new(tree.Keyword)(simpleProperty[1])];\n parserInput.forget();\n return name;\n }\n\n function match(re) {\n const i = parserInput.i;\n const chunk = parserInput.$re(re);\n if (chunk) {\n index.push(i);\n return name.push(chunk[1]);\n }\n }\n\n match(/^(\\*?)/);\n while (true) {\n if (!match(/^((?:[\\w-]+)|(?:[@\\$]\\{[\\w-]+\\}))/)) {\n break;\n }\n }\n\n if ((name.length > 1) && match(/^((?:\\+_|\\+)?)\\s*:/)) {\n parserInput.forget();\n\n // at last, we have the complete match now. move forward,\n // convert name particles to tree objects and return:\n if (name[0] === '') {\n name.shift();\n index.shift();\n }\n for (k = 0; k < name.length; k++) {\n s = name[k];\n name[k] = (s.charAt(0) !== '@' && s.charAt(0) !== '$') ?\n new(tree.Keyword)(s) :\n (s.charAt(0) === '@' ?\n new(tree.Variable)(`@${s.slice(2, -1)}`, index[k], fileInfo) :\n new(tree.Property)(`$${s.slice(2, -1)}`, index[k], fileInfo));\n }\n return name;\n }\n parserInput.restore();\n }\n }\n };\n};\nParser.serializeVars = vars => {\n let s = '';\n\n for (const name in vars) {\n if (Object.hasOwnProperty.call(vars, name)) {\n const value = vars[name];\n s += `${((name[0] === '@') ? '' : '@') + name}: ${value}${(String(value).slice(-1) === ';') ? '' : ';'}`;\n }\n }\n\n return s;\n};\n\nexport default Parser;\n","import Anonymous from '../tree/anonymous';\nimport Keyword from '../tree/keyword';\n\nfunction boolean(condition) {\n return condition ? Keyword.True : Keyword.False;\n}\n\n/**\n * Functions with evalArgs set to false are sent context\n * as the first argument.\n */\nfunction If(context, condition, trueValue, falseValue) {\n return condition.eval(context) ? trueValue.eval(context)\n : (falseValue ? falseValue.eval(context) : new Anonymous);\n}\nIf.evalArgs = false;\n\nfunction isdefined(context, variable) {\n try {\n variable.eval(context);\n return Keyword.True;\n } catch (e) {\n return Keyword.False;\n }\n}\n\nisdefined.evalArgs = false;\n\nexport default { isdefined, boolean, 'if': If };\n","import Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nimport Expression from '../tree/expression';\nimport Operation from '../tree/operation';\nlet colorFunctions;\n\nfunction clamp(val) {\n return Math.min(1, Math.max(0, val));\n}\nfunction hsla(origColor, hsl) {\n const color = colorFunctions.hsla(hsl.h, hsl.s, hsl.l, hsl.a);\n if (color) {\n if (origColor.value && \n /^(rgb|hsl)/.test(origColor.value)) {\n color.value = origColor.value;\n } else {\n color.value = 'rgb';\n }\n return color;\n }\n}\nfunction toHSL(color) {\n if (color.toHSL) {\n return color.toHSL();\n } else {\n throw new Error('Argument cannot be evaluated to a color');\n }\n}\n\nfunction toHSV(color) {\n if (color.toHSV) {\n return color.toHSV();\n } else {\n throw new Error('Argument cannot be evaluated to a color');\n }\n}\n\nfunction number(n) {\n if (n instanceof Dimension) {\n return parseFloat(n.unit.is('%') ? n.value / 100 : n.value);\n } else if (typeof n === 'number') {\n return n;\n } else {\n throw {\n type: 'Argument',\n message: 'color functions take numbers as parameters'\n };\n }\n}\nfunction scaled(n, size) {\n if (n instanceof Dimension && n.unit.is('%')) {\n return parseFloat(n.value * size / 100);\n } else {\n return number(n);\n }\n}\ncolorFunctions = {\n rgb: function (r, g, b) {\n let a = 1\n /**\n * Comma-less syntax\n * e.g. rgb(0 128 255 / 50%)\n */\n if (r instanceof Expression) {\n const val = r.value\n r = val[0]\n g = val[1]\n b = val[2]\n /** \n * @todo - should this be normalized in\n * function caller? Or parsed differently?\n */\n if (b instanceof Operation) {\n const op = b\n b = op.operands[0]\n a = op.operands[1]\n }\n }\n const color = colorFunctions.rgba(r, g, b, a);\n if (color) {\n color.value = 'rgb';\n return color;\n }\n },\n rgba: function (r, g, b, a) {\n try {\n if (r instanceof Color) {\n if (g) {\n a = number(g);\n } else {\n a = r.alpha;\n }\n return new Color(r.rgb, a, 'rgba');\n }\n const rgb = [r, g, b].map(c => scaled(c, 255));\n a = number(a);\n return new Color(rgb, a, 'rgba');\n }\n catch (e) {}\n },\n hsl: function (h, s, l) {\n let a = 1\n if (h instanceof Expression) {\n const val = h.value\n h = val[0]\n s = val[1]\n l = val[2]\n\n if (l instanceof Operation) {\n const op = l\n l = op.operands[0]\n a = op.operands[1]\n }\n }\n const color = colorFunctions.hsla(h, s, l, a);\n if (color) {\n color.value = 'hsl';\n return color;\n }\n },\n hsla: function (h, s, l, a) {\n try {\n if (h instanceof Color) {\n if (s) {\n a = number(s);\n } else {\n a = h.alpha;\n }\n return new Color(h.rgb, a, 'hsla');\n }\n\n let m1;\n let m2;\n\n function hue(h) {\n h = h < 0 ? h + 1 : (h > 1 ? h - 1 : h);\n if (h * 6 < 1) {\n return m1 + (m2 - m1) * h * 6;\n }\n else if (h * 2 < 1) {\n return m2;\n }\n else if (h * 3 < 2) {\n return m1 + (m2 - m1) * (2 / 3 - h) * 6;\n }\n else {\n return m1;\n }\n }\n\n h = (number(h) % 360) / 360;\n s = clamp(number(s));l = clamp(number(l));a = clamp(number(a));\n\n m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n m1 = l * 2 - m2;\n\n const rgb = [\n hue(h + 1 / 3) * 255,\n hue(h) * 255,\n hue(h - 1 / 3) * 255\n ];\n a = number(a);\n return new Color(rgb, a, 'hsla');\n }\n catch (e) {}\n },\n\n hsv: function(h, s, v) {\n return colorFunctions.hsva(h, s, v, 1.0);\n },\n\n hsva: function(h, s, v, a) {\n h = ((number(h) % 360) / 360) * 360;\n s = number(s);v = number(v);a = number(a);\n\n let i;\n let f;\n i = Math.floor((h / 60) % 6);\n f = (h / 60) - i;\n\n const vs = [v,\n v * (1 - s),\n v * (1 - f * s),\n v * (1 - (1 - f) * s)];\n const perm = [[0, 3, 1],\n [2, 0, 1],\n [1, 0, 3],\n [1, 2, 0],\n [3, 1, 0],\n [0, 1, 2]];\n\n return colorFunctions.rgba(vs[perm[i][0]] * 255,\n vs[perm[i][1]] * 255,\n vs[perm[i][2]] * 255,\n a);\n },\n\n hue: function (color) {\n return new Dimension(toHSL(color).h);\n },\n saturation: function (color) {\n return new Dimension(toHSL(color).s * 100, '%');\n },\n lightness: function (color) {\n return new Dimension(toHSL(color).l * 100, '%');\n },\n hsvhue: function(color) {\n return new Dimension(toHSV(color).h);\n },\n hsvsaturation: function (color) {\n return new Dimension(toHSV(color).s * 100, '%');\n },\n hsvvalue: function (color) {\n return new Dimension(toHSV(color).v * 100, '%');\n },\n red: function (color) {\n return new Dimension(color.rgb[0]);\n },\n green: function (color) {\n return new Dimension(color.rgb[1]);\n },\n blue: function (color) {\n return new Dimension(color.rgb[2]);\n },\n alpha: function (color) {\n return new Dimension(toHSL(color).a);\n },\n luma: function (color) {\n return new Dimension(color.luma() * color.alpha * 100, '%');\n },\n luminance: function (color) {\n const luminance =\n (0.2126 * color.rgb[0] / 255) +\n (0.7152 * color.rgb[1] / 255) +\n (0.0722 * color.rgb[2] / 255);\n\n return new Dimension(luminance * color.alpha * 100, '%');\n },\n saturate: function (color, amount, method) {\n // filter: saturate(3.2);\n // should be kept as is, so check for color\n if (!color.rgb) {\n return null;\n }\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.s += hsl.s * amount.value / 100;\n }\n else {\n hsl.s += amount.value / 100;\n }\n hsl.s = clamp(hsl.s);\n return hsla(color, hsl);\n },\n desaturate: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.s -= hsl.s * amount.value / 100;\n }\n else {\n hsl.s -= amount.value / 100;\n }\n hsl.s = clamp(hsl.s);\n return hsla(color, hsl);\n },\n lighten: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.l += hsl.l * amount.value / 100;\n }\n else {\n hsl.l += amount.value / 100;\n }\n hsl.l = clamp(hsl.l);\n return hsla(color, hsl);\n },\n darken: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.l -= hsl.l * amount.value / 100;\n }\n else {\n hsl.l -= amount.value / 100;\n }\n hsl.l = clamp(hsl.l);\n return hsla(color, hsl);\n },\n fadein: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.a += hsl.a * amount.value / 100;\n }\n else {\n hsl.a += amount.value / 100;\n }\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n fadeout: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.a -= hsl.a * amount.value / 100;\n }\n else {\n hsl.a -= amount.value / 100;\n }\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n fade: function (color, amount) {\n const hsl = toHSL(color);\n\n hsl.a = amount.value / 100;\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n spin: function (color, amount) {\n const hsl = toHSL(color);\n const hue = (hsl.h + amount.value) % 360;\n\n hsl.h = hue < 0 ? 360 + hue : hue;\n\n return hsla(color, hsl);\n },\n //\n // Copyright (c) 2006-2009 Hampton Catlin, Natalie Weizenbaum, and Chris Eppstein\n // http://sass-lang.com\n //\n mix: function (color1, color2, weight) {\n if (!weight) {\n weight = new Dimension(50);\n }\n const p = weight.value / 100.0;\n const w = p * 2 - 1;\n const a = toHSL(color1).a - toHSL(color2).a;\n\n const w1 = (((w * a == -1) ? w : (w + a) / (1 + w * a)) + 1) / 2.0;\n const w2 = 1 - w1;\n\n const rgb = [color1.rgb[0] * w1 + color2.rgb[0] * w2,\n color1.rgb[1] * w1 + color2.rgb[1] * w2,\n color1.rgb[2] * w1 + color2.rgb[2] * w2];\n\n const alpha = color1.alpha * p + color2.alpha * (1 - p);\n\n return new Color(rgb, alpha);\n },\n greyscale: function (color) {\n return colorFunctions.desaturate(color, new Dimension(100));\n },\n contrast: function (color, dark, light, threshold) {\n // filter: contrast(3.2);\n // should be kept as is, so check for color\n if (!color.rgb) {\n return null;\n }\n if (typeof light === 'undefined') {\n light = colorFunctions.rgba(255, 255, 255, 1.0);\n }\n if (typeof dark === 'undefined') {\n dark = colorFunctions.rgba(0, 0, 0, 1.0);\n }\n // Figure out which is actually light and dark:\n if (dark.luma() > light.luma()) {\n const t = light;\n light = dark;\n dark = t;\n }\n if (typeof threshold === 'undefined') {\n threshold = 0.43;\n } else {\n threshold = number(threshold);\n }\n if (color.luma() < threshold) {\n return light;\n } else {\n return dark;\n }\n },\n // Changes made in 2.7.0 - Reverted in 3.0.0\n // contrast: function (color, color1, color2, threshold) {\n // // Return which of `color1` and `color2` has the greatest contrast with `color`\n // // according to the standard WCAG contrast ratio calculation.\n // // http://www.w3.org/TR/WCAG20/#contrast-ratiodef\n // // The threshold param is no longer used, in line with SASS.\n // // filter: contrast(3.2);\n // // should be kept as is, so check for color\n // if (!color.rgb) {\n // return null;\n // }\n // if (typeof color1 === 'undefined') {\n // color1 = colorFunctions.rgba(0, 0, 0, 1.0);\n // }\n // if (typeof color2 === 'undefined') {\n // color2 = colorFunctions.rgba(255, 255, 255, 1.0);\n // }\n // var contrast1, contrast2;\n // var luma = color.luma();\n // var luma1 = color1.luma();\n // var luma2 = color2.luma();\n // // Calculate contrast ratios for each color\n // if (luma > luma1) {\n // contrast1 = (luma + 0.05) / (luma1 + 0.05);\n // } else {\n // contrast1 = (luma1 + 0.05) / (luma + 0.05);\n // }\n // if (luma > luma2) {\n // contrast2 = (luma + 0.05) / (luma2 + 0.05);\n // } else {\n // contrast2 = (luma2 + 0.05) / (luma + 0.05);\n // }\n // if (contrast1 > contrast2) {\n // return color1;\n // } else {\n // return color2;\n // }\n // },\n argb: function (color) {\n return new Anonymous(color.toARGB());\n },\n color: function(c) {\n if ((c instanceof Quoted) &&\n (/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})$/i.test(c.value))) {\n const val = c.value.slice(1);\n return new Color(val, undefined, `#${val}`);\n }\n if ((c instanceof Color) || (c = Color.fromKeyword(c.value))) {\n c.value = undefined;\n return c;\n }\n throw {\n type: 'Argument',\n message: 'argument must be a color keyword or 3|4|6|8 digit hex e.g. #FFF'\n };\n },\n tint: function(color, amount) {\n return colorFunctions.mix(colorFunctions.rgb(255, 255, 255), color, amount);\n },\n shade: function(color, amount) {\n return colorFunctions.mix(colorFunctions.rgb(0, 0, 0), color, amount);\n }\n};\n\nexport default colorFunctions;\n","import Color from '../tree/color';\n\n// Color Blending\n// ref: http://www.w3.org/TR/compositing-1\n\nfunction colorBlend(mode, color1, color2) {\n const ab = color1.alpha; // result\n\n let // backdrop\n cb;\n\n const as = color2.alpha;\n\n let // source\n cs;\n\n let ar;\n let cr;\n const r = [];\n\n ar = as + ab * (1 - as);\n for (let i = 0; i < 3; i++) {\n cb = color1.rgb[i] / 255;\n cs = color2.rgb[i] / 255;\n cr = mode(cb, cs);\n if (ar) {\n cr = (as * cs + ab * (cb -\n as * (cb + cs - cr))) / ar;\n }\n r[i] = cr * 255;\n }\n\n return new Color(r, ar);\n}\n\nconst colorBlendModeFunctions = {\n multiply: function(cb, cs) {\n return cb * cs;\n },\n screen: function(cb, cs) {\n return cb + cs - cb * cs;\n },\n overlay: function(cb, cs) {\n cb *= 2;\n return (cb <= 1) ?\n colorBlendModeFunctions.multiply(cb, cs) :\n colorBlendModeFunctions.screen(cb - 1, cs);\n },\n softlight: function(cb, cs) {\n let d = 1;\n let e = cb;\n if (cs > 0.5) {\n e = 1;\n d = (cb > 0.25) ? Math.sqrt(cb)\n : ((16 * cb - 12) * cb + 4) * cb;\n }\n return cb - (1 - 2 * cs) * e * (d - cb);\n },\n hardlight: function(cb, cs) {\n return colorBlendModeFunctions.overlay(cs, cb);\n },\n difference: function(cb, cs) {\n return Math.abs(cb - cs);\n },\n exclusion: function(cb, cs) {\n return cb + cs - 2 * cb * cs;\n },\n\n // non-w3c functions:\n average: function(cb, cs) {\n return (cb + cs) / 2;\n },\n negation: function(cb, cs) {\n return 1 - Math.abs(cb + cs - 1);\n }\n};\n\nfor (const f in colorBlendModeFunctions) {\n if (colorBlendModeFunctions.hasOwnProperty(f)) {\n colorBlend[f] = colorBlend.bind(null, colorBlendModeFunctions[f]);\n }\n}\n\nexport default colorBlend;\n","import Comment from '../tree/comment';\nimport Node from '../tree/node';\nimport Dimension from '../tree/dimension';\nimport Declaration from '../tree/declaration';\nimport Expression from '../tree/expression';\nimport Ruleset from '../tree/ruleset';\nimport Selector from '../tree/selector';\nimport Element from '../tree/element';\nimport Quote from '../tree/quoted';\nimport Value from '../tree/value';\n\nconst getItemsFromNode = node => {\n // handle non-array values as an array of length 1\n // return 'undefined' if index is invalid\n const items = Array.isArray(node.value) ?\n node.value : Array(node);\n\n return items;\n};\n\nexport default {\n _SELF: function(n) {\n return n;\n },\n '~': function(...expr) {\n if (expr.length === 1) {\n return expr[0];\n }\n return new Value(expr);\n },\n extract: function(values, index) {\n // (1-based index)\n index = index.value - 1;\n\n return getItemsFromNode(values)[index];\n },\n length: function(values) {\n return new Dimension(getItemsFromNode(values).length);\n },\n /**\n * Creates a Less list of incremental values.\n * Modeled after Lodash's range function, also exists natively in PHP\n * \n * @param {Dimension} [start=1]\n * @param {Dimension} end - e.g. 10 or 10px - unit is added to output\n * @param {Dimension} [step=1] \n */\n range: function(start, end, step) {\n let from;\n let to;\n let stepValue = 1;\n const list = [];\n if (end) {\n to = end;\n from = start.value;\n if (step) {\n stepValue = step.value;\n }\n }\n else {\n from = 1;\n to = start;\n }\n\n for (let i = from; i <= to.value; i += stepValue) {\n list.push(new Dimension(i, to.unit));\n }\n\n return new Expression(list);\n },\n each: function(list, rs) {\n const rules = [];\n let newRules;\n let iterator;\n\n const tryEval = val => {\n if (val instanceof Node) {\n return val.eval(this.context);\n }\n return val;\n };\n\n if (list.value && !(list instanceof Quote)) {\n if (Array.isArray(list.value)) {\n iterator = list.value.map(tryEval);\n } else {\n iterator = [tryEval(list.value)];\n }\n } else if (list.ruleset) {\n iterator = tryEval(list.ruleset).rules;\n } else if (list.rules) {\n iterator = list.rules.map(tryEval);\n } else if (Array.isArray(list)) {\n iterator = list.map(tryEval);\n } else {\n iterator = [tryEval(list)];\n }\n\n let valueName = '@value';\n let keyName = '@key';\n let indexName = '@index';\n\n if (rs.params) {\n valueName = rs.params[0] && rs.params[0].name;\n keyName = rs.params[1] && rs.params[1].name;\n indexName = rs.params[2] && rs.params[2].name;\n rs = rs.rules;\n } else {\n rs = rs.ruleset;\n }\n\n for (let i = 0; i < iterator.length; i++) {\n let key;\n let value;\n const item = iterator[i];\n if (item instanceof Declaration) {\n key = typeof item.name === 'string' ? item.name : item.name[0].value;\n value = item.value;\n } else {\n key = new Dimension(i + 1);\n value = item;\n }\n\n if (item instanceof Comment) {\n continue;\n }\n\n newRules = rs.rules.slice(0);\n if (valueName) {\n newRules.push(new Declaration(valueName,\n value,\n false, false, this.index, this.currentFileInfo));\n }\n if (indexName) {\n newRules.push(new Declaration(indexName,\n new Dimension(i + 1),\n false, false, this.index, this.currentFileInfo));\n }\n if (keyName) {\n newRules.push(new Declaration(keyName,\n key,\n false, false, this.index, this.currentFileInfo));\n }\n\n rules.push(new Ruleset([ new(Selector)([ new Element(\"\", '&') ]) ],\n newRules,\n rs.strictImports,\n rs.visibilityInfo()\n ));\n }\n\n return new Ruleset([ new(Selector)([ new Element(\"\", '&') ]) ],\n rules,\n rs.strictImports,\n rs.visibilityInfo()\n ).eval(this.context);\n }\n};\n","import Dimension from '../tree/dimension';\n\nconst MathHelper = (fn, unit, n) => {\n if (!(n instanceof Dimension)) {\n throw { type: 'Argument', message: 'argument must be a number' };\n }\n if (unit == null) {\n unit = n.unit;\n } else {\n n = n.unify();\n }\n return new Dimension(fn(parseFloat(n.value)), unit);\n};\n\nexport default MathHelper;","import mathHelper from './math-helper.js';\n\nconst mathFunctions = {\n // name, unit\n ceil: null,\n floor: null,\n sqrt: null,\n abs: null,\n tan: '',\n sin: '',\n cos: '',\n atan: 'rad',\n asin: 'rad',\n acos: 'rad'\n};\n\nfor (const f in mathFunctions) {\n if (mathFunctions.hasOwnProperty(f)) {\n mathFunctions[f] = mathHelper.bind(null, Math[f], mathFunctions[f]);\n }\n}\n\nmathFunctions.round = (n, f) => {\n const fraction = typeof f === 'undefined' ? 0 : f.value;\n return mathHelper(num => num.toFixed(fraction), null, n);\n};\n\nexport default mathFunctions;\n","import Dimension from '../tree/dimension';\nimport Anonymous from '../tree/anonymous';\nimport mathHelper from './math-helper.js';\n\nconst minMax = function (isMin, args) {\n args = Array.prototype.slice.call(args);\n switch (args.length) {\n case 0: throw { type: 'Argument', message: 'one or more arguments required' };\n }\n let i; // key is the unit.toString() for unified Dimension values,\n let j;\n let current;\n let currentUnified;\n let referenceUnified;\n let unit;\n let unitStatic;\n let unitClone;\n\n const // elems only contains original argument values.\n order = [];\n\n const values = {};\n // value is the index into the order array.\n for (i = 0; i < args.length; i++) {\n current = args[i];\n if (!(current instanceof Dimension)) {\n if (Array.isArray(args[i].value)) {\n Array.prototype.push.apply(args, Array.prototype.slice.call(args[i].value));\n }\n continue;\n }\n currentUnified = current.unit.toString() === '' && unitClone !== undefined ? new Dimension(current.value, unitClone).unify() : current.unify();\n unit = currentUnified.unit.toString() === '' && unitStatic !== undefined ? unitStatic : currentUnified.unit.toString();\n unitStatic = unit !== '' && unitStatic === undefined || unit !== '' && order[0].unify().unit.toString() === '' ? unit : unitStatic;\n unitClone = unit !== '' && unitClone === undefined ? current.unit.toString() : unitClone;\n j = values[''] !== undefined && unit !== '' && unit === unitStatic ? values[''] : values[unit];\n if (j === undefined) {\n if (unitStatic !== undefined && unit !== unitStatic) {\n throw { type: 'Argument', message: 'incompatible types' };\n }\n values[unit] = order.length;\n order.push(current);\n continue;\n }\n referenceUnified = order[j].unit.toString() === '' && unitClone !== undefined ? new Dimension(order[j].value, unitClone).unify() : order[j].unify();\n if ( isMin && currentUnified.value < referenceUnified.value ||\n !isMin && currentUnified.value > referenceUnified.value) {\n order[j] = current;\n }\n }\n if (order.length == 1) {\n return order[0];\n }\n args = order.map(function (a) { return a.toCSS(this.context); }).join(this.context.compress ? ',' : ', ');\n return new Anonymous(`${isMin ? 'min' : 'max'}(${args})`);\n};\n\nexport default {\n min: function(...args) {\n try {\n return minMax(true, args);\n } catch (e) {}\n },\n max: function(...args) {\n try {\n return minMax(false, args);\n } catch (e) {}\n },\n convert: function (val, unit) {\n return val.convertTo(unit.value);\n },\n pi: function () {\n return new Dimension(Math.PI);\n },\n mod: function(a, b) {\n return new Dimension(a.value % b.value, a.unit);\n },\n pow: function(x, y) {\n if (typeof x === 'number' && typeof y === 'number') {\n x = new Dimension(x);\n y = new Dimension(y);\n } else if (!(x instanceof Dimension) || !(y instanceof Dimension)) {\n throw { type: 'Argument', message: 'arguments must be numbers' };\n }\n\n return new Dimension(Math.pow(x.value, y.value), x.unit);\n },\n percentage: function (n) {\n const result = mathHelper(num => num * 100, '%', n);\n\n return result;\n }\n};\n","import Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nimport JavaScript from '../tree/javascript';\n\nexport default {\n e: function (str) {\n return new Quoted('\"', str instanceof JavaScript ? str.evaluated : str.value, true);\n },\n escape: function (str) {\n return new Anonymous(\n encodeURI(str.value).replace(/=/g, '%3D').replace(/:/g, '%3A').replace(/#/g, '%23').replace(/;/g, '%3B')\n .replace(/\\(/g, '%28').replace(/\\)/g, '%29'));\n },\n replace: function (string, pattern, replacement, flags) {\n let result = string.value;\n replacement = (replacement.type === 'Quoted') ?\n replacement.value : replacement.toCSS();\n result = result.replace(new RegExp(pattern.value, flags ? flags.value : ''), replacement);\n return new Quoted(string.quote || '', result, string.escaped);\n },\n '%': function (string /* arg, arg, ... */) {\n const args = Array.prototype.slice.call(arguments, 1);\n let result = string.value;\n\n for (let i = 0; i < args.length; i++) {\n /* jshint loopfunc:true */\n result = result.replace(/%[sda]/i, token => {\n const value = ((args[i].type === 'Quoted') &&\n token.match(/s/i)) ? args[i].value : args[i].toCSS();\n return token.match(/[A-Z]$/) ? encodeURIComponent(value) : value;\n });\n }\n result = result.replace(/%%/g, '%');\n return new Quoted(string.quote || '', result, string.escaped);\n }\n};\n","import Keyword from '../tree/keyword';\nimport DetachedRuleset from '../tree/detached-ruleset';\nimport Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nimport URL from '../tree/url';\nimport Operation from '../tree/operation';\n\nconst isa = (n, Type) => (n instanceof Type) ? Keyword.True : Keyword.False;\nconst isunit = (n, unit) => {\n if (unit === undefined) {\n throw { type: 'Argument', message: 'missing the required second argument to isunit.' };\n }\n unit = typeof unit.value === 'string' ? unit.value : unit;\n if (typeof unit !== 'string') {\n throw { type: 'Argument', message: 'Second argument to isunit should be a unit or a string.' };\n }\n return (n instanceof Dimension) && n.unit.is(unit) ? Keyword.True : Keyword.False;\n};\n\nexport default {\n isruleset: function (n) {\n return isa(n, DetachedRuleset);\n },\n iscolor: function (n) {\n return isa(n, Color);\n },\n isnumber: function (n) {\n return isa(n, Dimension);\n },\n isstring: function (n) {\n return isa(n, Quoted);\n },\n iskeyword: function (n) {\n return isa(n, Keyword);\n },\n isurl: function (n) {\n return isa(n, URL);\n },\n ispixel: function (n) {\n return isunit(n, 'px');\n },\n ispercentage: function (n) {\n return isunit(n, '%');\n },\n isem: function (n) {\n return isunit(n, 'em');\n },\n isunit,\n unit: function (val, unit) {\n if (!(val instanceof Dimension)) {\n throw { type: 'Argument',\n message: `the first argument to unit must be a number${val instanceof Operation ? '. Have you forgotten parenthesis?' : ''}` };\n }\n if (unit) {\n if (unit instanceof Keyword) {\n unit = unit.value;\n } else {\n unit = unit.toCSS();\n }\n } else {\n unit = '';\n }\n return new Dimension(val.value, unit);\n },\n 'get-unit': function (n) {\n return new Anonymous(n.unit);\n }\n};\n","import functionRegistry from './function-registry';\nimport functionCaller from './function-caller';\n\nimport boolean from './boolean';\nimport defaultFunc from './default';\nimport color from './color';\nimport colorBlending from './color-blending';\nimport dataUri from './data-uri';\nimport list from './list';\nimport math from './math';\nimport number from './number';\nimport string from './string';\nimport svg from './svg';\nimport types from './types';\n\nexport default environment => {\n const functions = { functionRegistry, functionCaller };\n\n // register functions\n functionRegistry.addMultiple(boolean);\n functionRegistry.add('default', defaultFunc.eval.bind(defaultFunc));\n functionRegistry.addMultiple(color);\n functionRegistry.addMultiple(colorBlending);\n functionRegistry.addMultiple(dataUri(environment));\n functionRegistry.addMultiple(list);\n functionRegistry.addMultiple(math);\n functionRegistry.addMultiple(number);\n functionRegistry.addMultiple(string);\n functionRegistry.addMultiple(svg(environment));\n functionRegistry.addMultiple(types);\n\n return functions;\n};\n","import Quoted from '../tree/quoted';\nimport URL from '../tree/url';\nimport * as utils from '../utils';\nimport logger from '../logger';\n\nexport default environment => {\n \n const fallback = (functionThis, node) => new URL(node, functionThis.index, functionThis.currentFileInfo).eval(functionThis.context); \n\n return { 'data-uri': function(mimetypeNode, filePathNode) {\n\n if (!filePathNode) {\n filePathNode = mimetypeNode;\n mimetypeNode = null;\n }\n\n let mimetype = mimetypeNode && mimetypeNode.value;\n let filePath = filePathNode.value;\n const currentFileInfo = this.currentFileInfo;\n const currentDirectory = currentFileInfo.rewriteUrls ?\n currentFileInfo.currentDirectory : currentFileInfo.entryPath;\n\n const fragmentStart = filePath.indexOf('#');\n let fragment = '';\n if (fragmentStart !== -1) {\n fragment = filePath.slice(fragmentStart);\n filePath = filePath.slice(0, fragmentStart);\n }\n const context = utils.clone(this.context);\n context.rawBuffer = true;\n\n const fileManager = environment.getFileManager(filePath, currentDirectory, context, environment, true);\n\n if (!fileManager) {\n return fallback(this, filePathNode);\n }\n\n let useBase64 = false;\n\n // detect the mimetype if not given\n if (!mimetypeNode) {\n\n mimetype = environment.mimeLookup(filePath);\n\n if (mimetype === 'image/svg+xml') {\n useBase64 = false;\n } else {\n // use base 64 unless it's an ASCII or UTF-8 format\n const charset = environment.charsetLookup(mimetype);\n useBase64 = ['US-ASCII', 'UTF-8'].indexOf(charset) < 0;\n }\n if (useBase64) { mimetype += ';base64'; }\n }\n else {\n useBase64 = /;base64$/.test(mimetype);\n }\n\n const fileSync = fileManager.loadFileSync(filePath, currentDirectory, context, environment);\n if (!fileSync.contents) {\n logger.warn(`Skipped data-uri embedding of ${filePath} because file not found`);\n return fallback(this, filePathNode || mimetypeNode);\n }\n let buf = fileSync.contents;\n if (useBase64 && !environment.encodeBase64) {\n return fallback(this, filePathNode);\n }\n\n buf = useBase64 ? environment.encodeBase64(buf) : encodeURIComponent(buf);\n\n const uri = `data:${mimetype},${buf}${fragment}`;\n\n return new URL(new Quoted(`\"${uri}\"`, uri, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo);\n }};\n};\n","import Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Expression from '../tree/expression';\nimport Quoted from '../tree/quoted';\nimport URL from '../tree/url';\n\nexport default environment => {\n return { 'svg-gradient': function(direction) {\n let stops;\n let gradientDirectionSvg;\n let gradientType = 'linear';\n let rectangleDimension = 'x=\"0\" y=\"0\" width=\"1\" height=\"1\"';\n const renderEnv = {compress: false};\n let returner;\n const directionValue = direction.toCSS(renderEnv);\n let i;\n let color;\n let position;\n let positionValue;\n let alpha;\n\n function throwArgumentDescriptor() {\n throw { type: 'Argument',\n message: 'svg-gradient expects direction, start_color [start_position], [color position,]...,' +\n ' end_color [end_position] or direction, color list' };\n }\n\n if (arguments.length == 2) {\n if (arguments[1].value.length < 2) {\n throwArgumentDescriptor();\n }\n stops = arguments[1].value;\n } else if (arguments.length < 3) {\n throwArgumentDescriptor();\n } else {\n stops = Array.prototype.slice.call(arguments, 1);\n }\n\n switch (directionValue) {\n case 'to bottom':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"0%\" y2=\"100%\"';\n break;\n case 'to right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"100%\" y2=\"0%\"';\n break;\n case 'to bottom right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"100%\" y2=\"100%\"';\n break;\n case 'to top right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"100%\" x2=\"100%\" y2=\"0%\"';\n break;\n case 'ellipse':\n case 'ellipse at center':\n gradientType = 'radial';\n gradientDirectionSvg = 'cx=\"50%\" cy=\"50%\" r=\"75%\"';\n rectangleDimension = 'x=\"-50\" y=\"-50\" width=\"101\" height=\"101\"';\n break;\n default:\n throw { type: 'Argument', message: 'svg-gradient direction must be \\'to bottom\\', \\'to right\\',' +\n ' \\'to bottom right\\', \\'to top right\\' or \\'ellipse at center\\'' };\n }\n returner = `<${gradientType}Gradient id=\"g\" ${gradientDirectionSvg}>`;\n\n for (i = 0; i < stops.length; i += 1) {\n if (stops[i] instanceof Expression) {\n color = stops[i].value[0];\n position = stops[i].value[1];\n } else {\n color = stops[i];\n position = undefined;\n }\n\n if (!(color instanceof Color) || (!((i === 0 || i + 1 === stops.length) && position === undefined) && !(position instanceof Dimension))) {\n throwArgumentDescriptor();\n }\n positionValue = position ? position.toCSS(renderEnv) : i === 0 ? '0%' : '100%';\n alpha = color.alpha;\n returner += ``;\n }\n returner += ``;\n\n returner = encodeURIComponent(returner);\n\n returner = `data:image/svg+xml,${returner}`;\n return new URL(new Quoted(`'${returner}'`, returner, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo);\n }};\n};\n","import contexts from './contexts';\nimport visitor from './visitors';\nimport tree from './tree';\n\nexport default function(root, options) {\n options = options || {};\n let evaldRoot;\n let variables = options.variables;\n const evalEnv = new contexts.Eval(options);\n\n //\n // Allows setting variables with a hash, so:\n //\n // `{ color: new tree.Color('#f01') }` will become:\n //\n // new tree.Declaration('@color',\n // new tree.Value([\n // new tree.Expression([\n // new tree.Color('#f01')\n // ])\n // ])\n // )\n //\n if (typeof variables === 'object' && !Array.isArray(variables)) {\n variables = Object.keys(variables).map(function (k) {\n let value = variables[k];\n\n if (!(value instanceof tree.Value)) {\n if (!(value instanceof tree.Expression)) {\n value = new tree.Expression([value]);\n }\n value = new tree.Value([value]);\n }\n return new tree.Declaration(`@${k}`, value, false, null, 0);\n });\n evalEnv.frames = [new tree.Ruleset(null, variables)];\n }\n\n const visitors = [\n new visitor.JoinSelectorVisitor(),\n new visitor.MarkVisibleSelectorsVisitor(true),\n new visitor.ExtendVisitor(),\n new visitor.ToCSSVisitor({compress: Boolean(options.compress)})\n ];\n\n const preEvalVisitors = [];\n let v;\n let visitorIterator;\n\n /**\n * first() / get() allows visitors to be added while visiting\n * \n * @todo Add scoping for visitors just like functions for @plugin; right now they're global\n */\n if (options.pluginManager) {\n visitorIterator = options.pluginManager.visitor();\n for (var i = 0; i < 2; i++) {\n visitorIterator.first();\n while ((v = visitorIterator.get())) {\n if (v.isPreEvalVisitor) {\n if (i === 0 || preEvalVisitors.indexOf(v) === -1) {\n preEvalVisitors.push(v);\n v.run(root);\n }\n }\n else {\n if (i === 0 || visitors.indexOf(v) === -1) {\n if (v.isPreVisitor) {\n visitors.unshift(v);\n }\n else {\n visitors.push(v);\n }\n }\n }\n }\n }\n }\n\n evaldRoot = root.eval(evalEnv);\n\n for (var i = 0; i < visitors.length; i++) {\n visitors[i].run(evaldRoot);\n }\n\n // Run any remaining visitors added after eval pass\n if (options.pluginManager) {\n visitorIterator.first();\n while ((v = visitorIterator.get())) {\n if (visitors.indexOf(v) === -1 && preEvalVisitors.indexOf(v) === -1) {\n v.run(evaldRoot);\n }\n }\n }\n\n return evaldRoot;\n};\n","/**\n * Plugin Manager\n */\nclass PluginManager {\n constructor(less) {\n this.less = less;\n this.visitors = [];\n this.preProcessors = [];\n this.postProcessors = [];\n this.installedPlugins = [];\n this.fileManagers = [];\n this.iterator = -1;\n this.pluginCache = {};\n this.Loader = new less.PluginLoader(less);\n }\n\n /**\n * Adds all the plugins in the array\n * @param {Array} plugins\n */\n addPlugins(plugins) {\n if (plugins) {\n for (let i = 0; i < plugins.length; i++) {\n this.addPlugin(plugins[i]);\n }\n }\n }\n\n /**\n *\n * @param plugin\n * @param {String} filename\n */\n addPlugin(plugin, filename, functionRegistry) {\n this.installedPlugins.push(plugin);\n if (filename) {\n this.pluginCache[filename] = plugin;\n }\n if (plugin.install) {\n plugin.install(this.less, this, functionRegistry || this.less.functions.functionRegistry);\n }\n }\n\n /**\n *\n * @param filename\n */\n get(filename) {\n return this.pluginCache[filename];\n }\n\n /**\n * Adds a visitor. The visitor object has options on itself to determine\n * when it should run.\n * @param visitor\n */\n addVisitor(visitor) {\n this.visitors.push(visitor);\n }\n\n /**\n * Adds a pre processor object\n * @param {object} preProcessor\n * @param {number} priority - guidelines 1 = before import, 1000 = import, 2000 = after import\n */\n addPreProcessor(preProcessor, priority) {\n let indexToInsertAt;\n for (indexToInsertAt = 0; indexToInsertAt < this.preProcessors.length; indexToInsertAt++) {\n if (this.preProcessors[indexToInsertAt].priority >= priority) {\n break;\n }\n }\n this.preProcessors.splice(indexToInsertAt, 0, {preProcessor, priority});\n }\n\n /**\n * Adds a post processor object\n * @param {object} postProcessor\n * @param {number} priority - guidelines 1 = before compression, 1000 = compression, 2000 = after compression\n */\n addPostProcessor(postProcessor, priority) {\n let indexToInsertAt;\n for (indexToInsertAt = 0; indexToInsertAt < this.postProcessors.length; indexToInsertAt++) {\n if (this.postProcessors[indexToInsertAt].priority >= priority) {\n break;\n }\n }\n this.postProcessors.splice(indexToInsertAt, 0, {postProcessor, priority});\n }\n\n /**\n *\n * @param manager\n */\n addFileManager(manager) {\n this.fileManagers.push(manager);\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getPreProcessors() {\n const preProcessors = [];\n for (let i = 0; i < this.preProcessors.length; i++) {\n preProcessors.push(this.preProcessors[i].preProcessor);\n }\n return preProcessors;\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getPostProcessors() {\n const postProcessors = [];\n for (let i = 0; i < this.postProcessors.length; i++) {\n postProcessors.push(this.postProcessors[i].postProcessor);\n }\n return postProcessors;\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getVisitors() {\n return this.visitors;\n }\n\n visitor() {\n const self = this;\n return {\n first: function() {\n self.iterator = -1;\n return self.visitors[self.iterator];\n },\n get: function() {\n self.iterator += 1;\n return self.visitors[self.iterator];\n }\n };\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getFileManagers() {\n return this.fileManagers;\n }\n}\n\nlet pm;\n\nconst PluginManagerFactory = function(less, newFactory) {\n if (newFactory || !pm) {\n pm = new PluginManager(less);\n }\n return pm;\n};\n\n//\nexport default PluginManagerFactory;\n","'use strict';\n\nfunction parseNodeVersion(version) {\n var match = version.match(/^v(\\d{1,2})\\.(\\d{1,2})\\.(\\d{1,2})(?:-([0-9A-Za-z-.]+))?(?:\\+([0-9A-Za-z-.]+))?$/); // eslint-disable-line max-len\n if (!match) {\n throw new Error('Unable to parse: ' + version);\n }\n\n var res = {\n major: parseInt(match[1], 10),\n minor: parseInt(match[2], 10),\n patch: parseInt(match[3], 10),\n pre: match[4] || '',\n build: match[5] || '',\n };\n\n return res;\n}\n\nmodule.exports = parseNodeVersion;\n","/* global window, XMLHttpRequest */\n\nimport AbstractFileManager from '../less/environment/abstract-file-manager.js';\n\nlet options;\nlet logger;\nlet fileCache = {};\n\n// TODOS - move log somewhere. pathDiff and doing something similar in node. use pathDiff in the other browser file for the initial load\nconst FileManager = function() {}\nFileManager.prototype = Object.assign(new AbstractFileManager(), {\n alwaysMakePathsAbsolute() {\n return true;\n },\n\n join(basePath, laterPath) {\n if (!basePath) {\n return laterPath;\n }\n return this.extractUrlParts(laterPath, basePath).path;\n },\n\n doXHR(url, type, callback, errback) {\n const xhr = new XMLHttpRequest();\n const async = options.isFileProtocol ? options.fileAsync : true;\n\n if (typeof xhr.overrideMimeType === 'function') {\n xhr.overrideMimeType('text/css');\n }\n logger.debug(`XHR: Getting '${url}'`);\n xhr.open('GET', url, async);\n xhr.setRequestHeader('Accept', type || 'text/x-less, text/css; q=0.9, */*; q=0.5');\n xhr.send(null);\n\n function handleResponse(xhr, callback, errback) {\n if (xhr.status >= 200 && xhr.status < 300) {\n callback(xhr.responseText,\n xhr.getResponseHeader('Last-Modified'));\n } else if (typeof errback === 'function') {\n errback(xhr.status, url);\n }\n }\n\n if (options.isFileProtocol && !options.fileAsync) {\n if (xhr.status === 0 || (xhr.status >= 200 && xhr.status < 300)) {\n callback(xhr.responseText);\n } else {\n errback(xhr.status, url);\n }\n } else if (async) {\n xhr.onreadystatechange = () => {\n if (xhr.readyState == 4) {\n handleResponse(xhr, callback, errback);\n }\n };\n } else {\n handleResponse(xhr, callback, errback);\n }\n },\n\n supports() {\n return true;\n },\n\n clearFileCache() {\n fileCache = {};\n },\n\n loadFile(filename, currentDirectory, options, environment) {\n // TODO: Add prefix support like less-node?\n // What about multiple paths?\n\n if (currentDirectory && !this.isPathAbsolute(filename)) {\n filename = currentDirectory + filename;\n }\n\n filename = options.ext ? this.tryAppendExtension(filename, options.ext) : filename;\n\n options = options || {};\n\n // sheet may be set to the stylesheet for the initial load or a collection of properties including\n // some context variables for imports\n const hrefParts = this.extractUrlParts(filename, window.location.href);\n const href = hrefParts.url;\n const self = this;\n \n return new Promise((resolve, reject) => {\n if (options.useFileCache && fileCache[href]) {\n try {\n const lessText = fileCache[href];\n return resolve({ contents: lessText, filename: href, webInfo: { lastModified: new Date() }});\n } catch (e) {\n return reject({ filename: href, message: `Error loading file ${href} error was ${e.message}` });\n }\n }\n\n self.doXHR(href, options.mime, function doXHRCallback(data, lastModified) {\n // per file cache\n fileCache[href] = data;\n\n // Use remote copy (re-parse)\n resolve({ contents: data, filename: href, webInfo: { lastModified }});\n }, function doXHRError(status, url) {\n reject({ type: 'File', message: `'${url}' wasn't found (${status})`, href });\n });\n });\n }\n});\n\nexport default (opts, log) => {\n options = opts;\n logger = log;\n return FileManager;\n}\n","import Environment from './environment/environment';\nimport data from './data';\nimport tree from './tree';\nimport AbstractFileManager from './environment/abstract-file-manager';\nimport AbstractPluginLoader from './environment/abstract-plugin-loader';\nimport visitors from './visitors';\nimport Parser from './parser/parser';\nimport functions from './functions';\nimport contexts from './contexts';\nimport LessError from './less-error';\nimport transformTree from './transform-tree';\nimport * as utils from './utils';\nimport PluginManager from './plugin-manager';\nimport logger from './logger';\nimport SourceMapOutput from './source-map-output';\nimport SourceMapBuilder from './source-map-builder';\nimport ParseTree from './parse-tree';\nimport ImportManager from './import-manager';\nimport Parse from './parse';\nimport Render from './render';\nimport { version } from '../../package.json';\nimport parseVersion from 'parse-node-version';\n\nexport default function(environment, fileManagers) {\n let sourceMapOutput, sourceMapBuilder, parseTree, importManager;\n\n environment = new Environment(environment, fileManagers);\n sourceMapOutput = SourceMapOutput(environment);\n sourceMapBuilder = SourceMapBuilder(sourceMapOutput, environment);\n parseTree = ParseTree(sourceMapBuilder);\n importManager = ImportManager(environment);\n\n const render = Render(environment, parseTree, importManager);\n const parse = Parse(environment, parseTree, importManager);\n\n const v = parseVersion(version);\n const initial = {\n version: [v.major, v.minor, v.patch],\n data,\n tree,\n Environment,\n AbstractFileManager,\n AbstractPluginLoader,\n environment,\n visitors,\n Parser,\n functions: functions(environment),\n contexts,\n SourceMapOutput: sourceMapOutput,\n SourceMapBuilder: sourceMapBuilder,\n ParseTree: parseTree,\n ImportManager: importManager,\n render,\n parse,\n LessError,\n transformTree,\n utils,\n PluginManager,\n logger\n };\n\n // Create a public API\n\n const ctor = function(t) {\n return function() {\n const obj = Object.create(t.prototype);\n t.apply(obj, Array.prototype.slice.call(arguments, 0));\n return obj;\n };\n };\n let t;\n const api = Object.create(initial);\n for (const n in initial.tree) {\n /* eslint guard-for-in: 0 */\n t = initial.tree[n];\n if (typeof t === 'function') {\n api[n.toLowerCase()] = ctor(t);\n }\n else {\n api[n] = Object.create(null);\n for (const o in t) {\n /* eslint guard-for-in: 0 */\n api[n][o.toLowerCase()] = ctor(t[o]);\n }\n }\n }\n\n /**\n * Some of the functions assume a `this` context of the API object,\n * which causes it to fail when wrapped for ES6 imports.\n * \n * An assumed `this` should be removed in the future.\n */\n initial.parse = initial.parse.bind(api);\n initial.render = initial.render.bind(api);\n\n return api;\n};\n","import LessError from './less-error';\nimport transformTree from './transform-tree';\nimport logger from './logger';\n\nexport default function(SourceMapBuilder) {\n class ParseTree {\n constructor(root, imports) {\n this.root = root;\n this.imports = imports;\n }\n\n toCSS(options) {\n let evaldRoot;\n const result = {};\n let sourceMapBuilder;\n try {\n evaldRoot = transformTree(this.root, options);\n } catch (e) {\n throw new LessError(e, this.imports);\n }\n\n try {\n const compress = Boolean(options.compress);\n if (compress) {\n logger.warn('The compress option has been deprecated. ' + \n 'We recommend you use a dedicated css minifier, for instance see less-plugin-clean-css.');\n }\n\n const toCSSOptions = {\n compress,\n dumpLineNumbers: options.dumpLineNumbers,\n strictUnits: Boolean(options.strictUnits),\n numPrecision: 8};\n\n if (options.sourceMap) {\n sourceMapBuilder = new SourceMapBuilder(options.sourceMap);\n result.css = sourceMapBuilder.toCSS(evaldRoot, toCSSOptions, this.imports);\n } else {\n result.css = evaldRoot.toCSS(toCSSOptions);\n }\n } catch (e) {\n throw new LessError(e, this.imports);\n }\n\n if (options.pluginManager) {\n const postProcessors = options.pluginManager.getPostProcessors();\n for (let i = 0; i < postProcessors.length; i++) {\n result.css = postProcessors[i].process(result.css, { sourceMap: sourceMapBuilder, options, imports: this.imports });\n }\n }\n if (options.sourceMap) {\n result.map = sourceMapBuilder.getExternalSourceMap();\n }\n\n result.imports = [];\n for (const file in this.imports.files) {\n if (this.imports.files.hasOwnProperty(file) && file !== this.imports.rootFilename) {\n result.imports.push(file);\n }\n }\n return result;\n }\n }\n\n return ParseTree;\n};\n","export default function (SourceMapOutput, environment) {\n class SourceMapBuilder {\n constructor(options) {\n this.options = options;\n }\n\n toCSS(rootNode, options, imports) {\n const sourceMapOutput = new SourceMapOutput(\n {\n contentsIgnoredCharsMap: imports.contentsIgnoredChars,\n rootNode,\n contentsMap: imports.contents,\n sourceMapFilename: this.options.sourceMapFilename,\n sourceMapURL: this.options.sourceMapURL,\n outputFilename: this.options.sourceMapOutputFilename,\n sourceMapBasepath: this.options.sourceMapBasepath,\n sourceMapRootpath: this.options.sourceMapRootpath,\n outputSourceFiles: this.options.outputSourceFiles,\n sourceMapGenerator: this.options.sourceMapGenerator,\n sourceMapFileInline: this.options.sourceMapFileInline, \n disableSourcemapAnnotation: this.options.disableSourcemapAnnotation\n });\n\n const css = sourceMapOutput.toCSS(options);\n this.sourceMap = sourceMapOutput.sourceMap;\n this.sourceMapURL = sourceMapOutput.sourceMapURL;\n if (this.options.sourceMapInputFilename) {\n this.sourceMapInputFilename = sourceMapOutput.normalizeFilename(this.options.sourceMapInputFilename);\n }\n if (this.options.sourceMapBasepath !== undefined && this.sourceMapURL !== undefined) {\n this.sourceMapURL = sourceMapOutput.removeBasepath(this.sourceMapURL);\n }\n return css + this.getCSSAppendage();\n }\n\n getCSSAppendage() {\n\n let sourceMapURL = this.sourceMapURL;\n if (this.options.sourceMapFileInline) {\n if (this.sourceMap === undefined) {\n return '';\n }\n sourceMapURL = `data:application/json;base64,${environment.encodeBase64(this.sourceMap)}`;\n }\n\n if (this.options.disableSourcemapAnnotation) {\n return '';\n }\n\n if (sourceMapURL) {\n return `/*# sourceMappingURL=${sourceMapURL} */`;\n }\n return '';\n }\n\n getExternalSourceMap() {\n return this.sourceMap;\n }\n\n setExternalSourceMap(sourceMap) {\n this.sourceMap = sourceMap;\n }\n\n isInline() {\n return this.options.sourceMapFileInline;\n }\n\n getSourceMapURL() {\n return this.sourceMapURL;\n }\n\n getOutputFilename() {\n return this.options.sourceMapOutputFilename;\n }\n\n getInputFilename() {\n return this.sourceMapInputFilename;\n }\n }\n\n return SourceMapBuilder;\n};\n","export default function (environment) {\n class SourceMapOutput {\n constructor(options) {\n this._css = [];\n this._rootNode = options.rootNode;\n this._contentsMap = options.contentsMap;\n this._contentsIgnoredCharsMap = options.contentsIgnoredCharsMap;\n if (options.sourceMapFilename) {\n this._sourceMapFilename = options.sourceMapFilename.replace(/\\\\/g, '/');\n }\n this._outputFilename = options.outputFilename;\n this.sourceMapURL = options.sourceMapURL;\n if (options.sourceMapBasepath) {\n this._sourceMapBasepath = options.sourceMapBasepath.replace(/\\\\/g, '/');\n }\n if (options.sourceMapRootpath) {\n this._sourceMapRootpath = options.sourceMapRootpath.replace(/\\\\/g, '/');\n if (this._sourceMapRootpath.charAt(this._sourceMapRootpath.length - 1) !== '/') {\n this._sourceMapRootpath += '/';\n }\n } else {\n this._sourceMapRootpath = '';\n }\n this._outputSourceFiles = options.outputSourceFiles;\n this._sourceMapGeneratorConstructor = environment.getSourceMapGenerator();\n\n this._lineNumber = 0;\n this._column = 0;\n }\n\n removeBasepath(path) {\n if (this._sourceMapBasepath && path.indexOf(this._sourceMapBasepath) === 0) {\n path = path.substring(this._sourceMapBasepath.length);\n if (path.charAt(0) === '\\\\' || path.charAt(0) === '/') {\n path = path.substring(1);\n }\n }\n\n return path;\n }\n\n normalizeFilename(filename) {\n filename = filename.replace(/\\\\/g, '/');\n filename = this.removeBasepath(filename);\n return (this._sourceMapRootpath || '') + filename;\n }\n\n add(chunk, fileInfo, index, mapLines) {\n\n // ignore adding empty strings\n if (!chunk) {\n return;\n }\n\n let lines, sourceLines, columns, sourceColumns, i;\n\n if (fileInfo && fileInfo.filename) {\n let inputSource = this._contentsMap[fileInfo.filename];\n\n // remove vars/banner added to the top of the file\n if (this._contentsIgnoredCharsMap[fileInfo.filename]) {\n // adjust the index\n index -= this._contentsIgnoredCharsMap[fileInfo.filename];\n if (index < 0) { index = 0; }\n // adjust the source\n inputSource = inputSource.slice(this._contentsIgnoredCharsMap[fileInfo.filename]);\n }\n\n /** \n * ignore empty content, or failsafe\n * if contents map is incorrect\n */\n if (inputSource === undefined) {\n this._css.push(chunk);\n return;\n }\n\n inputSource = inputSource.substring(0, index);\n sourceLines = inputSource.split('\\n');\n sourceColumns = sourceLines[sourceLines.length - 1];\n }\n\n lines = chunk.split('\\n');\n columns = lines[lines.length - 1];\n\n if (fileInfo && fileInfo.filename) {\n if (!mapLines) {\n this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + 1, column: this._column},\n original: { line: sourceLines.length, column: sourceColumns.length},\n source: this.normalizeFilename(fileInfo.filename)});\n } else {\n for (i = 0; i < lines.length; i++) {\n this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + i + 1, column: i === 0 ? this._column : 0},\n original: { line: sourceLines.length + i, column: i === 0 ? sourceColumns.length : 0},\n source: this.normalizeFilename(fileInfo.filename)});\n }\n }\n }\n\n if (lines.length === 1) {\n this._column += columns.length;\n } else {\n this._lineNumber += lines.length - 1;\n this._column = columns.length;\n }\n\n this._css.push(chunk);\n }\n\n isEmpty() {\n return this._css.length === 0;\n }\n\n toCSS(context) {\n this._sourceMapGenerator = new this._sourceMapGeneratorConstructor({ file: this._outputFilename, sourceRoot: null });\n\n if (this._outputSourceFiles) {\n for (const filename in this._contentsMap) {\n if (this._contentsMap.hasOwnProperty(filename)) {\n let source = this._contentsMap[filename];\n if (this._contentsIgnoredCharsMap[filename]) {\n source = source.slice(this._contentsIgnoredCharsMap[filename]);\n }\n this._sourceMapGenerator.setSourceContent(this.normalizeFilename(filename), source);\n }\n }\n }\n\n this._rootNode.genCSS(context, this);\n\n if (this._css.length > 0) {\n let sourceMapURL;\n const sourceMapContent = JSON.stringify(this._sourceMapGenerator.toJSON());\n\n if (this.sourceMapURL) {\n sourceMapURL = this.sourceMapURL;\n } else if (this._sourceMapFilename) {\n sourceMapURL = this._sourceMapFilename;\n }\n this.sourceMapURL = sourceMapURL;\n\n this.sourceMap = sourceMapContent;\n }\n\n return this._css.join('');\n }\n }\n\n return SourceMapOutput;\n};\n","import contexts from './contexts';\nimport Parser from './parser/parser';\nimport LessError from './less-error';\nimport * as utils from './utils';\nimport logger from './logger';\n\nexport default function(environment) {\n // FileInfo = {\n // 'rewriteUrls' - option - whether to adjust URL's to be relative\n // 'filename' - full resolved filename of current file\n // 'rootpath' - path to append to normal URLs for this node\n // 'currentDirectory' - path to the current file, absolute\n // 'rootFilename' - filename of the base file\n // 'entryPath' - absolute path to the entry file\n // 'reference' - whether the file should not be output and only output parts that are referenced\n\n class ImportManager {\n constructor(less, context, rootFileInfo) {\n this.less = less;\n this.rootFilename = rootFileInfo.filename;\n this.paths = context.paths || []; // Search paths, when importing\n this.contents = {}; // map - filename to contents of all the files\n this.contentsIgnoredChars = {}; // map - filename to lines at the beginning of each file to ignore\n this.mime = context.mime;\n this.error = null;\n this.context = context;\n // Deprecated? Unused outside of here, could be useful.\n this.queue = []; // Files which haven't been imported yet\n this.files = {}; // Holds the imported parse trees.\n }\n\n /**\n * Add an import to be imported\n * @param path - the raw path\n * @param tryAppendExtension - whether to try appending a file extension (.less or .js if the path has no extension)\n * @param currentFileInfo - the current file info (used for instance to work out relative paths)\n * @param importOptions - import options\n * @param callback - callback for when it is imported\n */\n push(path, tryAppendExtension, currentFileInfo, importOptions, callback) {\n const importManager = this, pluginLoader = this.context.pluginManager.Loader;\n\n this.queue.push(path);\n\n const fileParsedFunc = function (e, root, fullPath) {\n importManager.queue.splice(importManager.queue.indexOf(path), 1); // Remove the path from the queue\n\n const importedEqualsRoot = fullPath === importManager.rootFilename;\n if (importOptions.optional && e) {\n callback(null, {rules:[]}, false, null);\n logger.info(`The file ${fullPath} was skipped because it was not found and the import was marked optional.`);\n }\n else {\n // Inline imports aren't cached here.\n // If we start to cache them, please make sure they won't conflict with non-inline imports of the\n // same name as they used to do before this comment and the condition below have been added.\n if (!importManager.files[fullPath] && !importOptions.inline) {\n importManager.files[fullPath] = { root, options: importOptions };\n }\n if (e && !importManager.error) { importManager.error = e; }\n callback(e, root, importedEqualsRoot, fullPath);\n }\n };\n\n const newFileInfo = {\n rewriteUrls: this.context.rewriteUrls,\n entryPath: currentFileInfo.entryPath,\n rootpath: currentFileInfo.rootpath,\n rootFilename: currentFileInfo.rootFilename\n };\n\n const fileManager = environment.getFileManager(path, currentFileInfo.currentDirectory, this.context, environment);\n\n if (!fileManager) {\n fileParsedFunc({ message: `Could not find a file-manager for ${path}` });\n return;\n }\n\n const loadFileCallback = function(loadedFile) {\n let plugin;\n const resolvedFilename = loadedFile.filename;\n const contents = loadedFile.contents.replace(/^\\uFEFF/, '');\n\n // Pass on an updated rootpath if path of imported file is relative and file\n // is in a (sub|sup) directory\n //\n // Examples:\n // - If path of imported file is 'module/nav/nav.less' and rootpath is 'less/',\n // then rootpath should become 'less/module/nav/'\n // - If path of imported file is '../mixins.less' and rootpath is 'less/',\n // then rootpath should become 'less/../'\n newFileInfo.currentDirectory = fileManager.getPath(resolvedFilename);\n if (newFileInfo.rewriteUrls) {\n newFileInfo.rootpath = fileManager.join(\n (importManager.context.rootpath || ''),\n fileManager.pathDiff(newFileInfo.currentDirectory, newFileInfo.entryPath));\n\n if (!fileManager.isPathAbsolute(newFileInfo.rootpath) && fileManager.alwaysMakePathsAbsolute()) {\n newFileInfo.rootpath = fileManager.join(newFileInfo.entryPath, newFileInfo.rootpath);\n }\n }\n newFileInfo.filename = resolvedFilename;\n\n const newEnv = new contexts.Parse(importManager.context);\n\n newEnv.processImports = false;\n importManager.contents[resolvedFilename] = contents;\n\n if (currentFileInfo.reference || importOptions.reference) {\n newFileInfo.reference = true;\n }\n\n if (importOptions.isPlugin) {\n plugin = pluginLoader.evalPlugin(contents, newEnv, importManager, importOptions.pluginArgs, newFileInfo);\n if (plugin instanceof LessError) {\n fileParsedFunc(plugin, null, resolvedFilename);\n }\n else {\n fileParsedFunc(null, plugin, resolvedFilename);\n }\n } else if (importOptions.inline) {\n fileParsedFunc(null, contents, resolvedFilename);\n } else {\n // import (multiple) parse trees apparently get altered and can't be cached.\n // TODO: investigate why this is\n if (importManager.files[resolvedFilename]\n && !importManager.files[resolvedFilename].options.multiple\n && !importOptions.multiple) {\n\n fileParsedFunc(null, importManager.files[resolvedFilename].root, resolvedFilename);\n }\n else {\n new Parser(newEnv, importManager, newFileInfo).parse(contents, function (e, root) {\n fileParsedFunc(e, root, resolvedFilename);\n });\n }\n }\n };\n let loadedFile;\n let promise;\n const context = utils.clone(this.context);\n\n if (tryAppendExtension) {\n context.ext = importOptions.isPlugin ? '.js' : '.less';\n }\n\n if (importOptions.isPlugin) {\n context.mime = 'application/javascript';\n\n if (context.syncImport) {\n loadedFile = pluginLoader.loadPluginSync(path, currentFileInfo.currentDirectory, context, environment, fileManager);\n } else {\n promise = pluginLoader.loadPlugin(path, currentFileInfo.currentDirectory, context, environment, fileManager);\n }\n }\n else {\n if (context.syncImport) {\n loadedFile = fileManager.loadFileSync(path, currentFileInfo.currentDirectory, context, environment);\n } else {\n promise = fileManager.loadFile(path, currentFileInfo.currentDirectory, context, environment,\n (err, loadedFile) => {\n if (err) {\n fileParsedFunc(err);\n } else {\n loadFileCallback(loadedFile);\n }\n });\n }\n }\n if (loadedFile) {\n if (!loadedFile.filename) {\n fileParsedFunc(loadedFile);\n } else {\n loadFileCallback(loadedFile);\n }\n } else if (promise) {\n promise.then(loadFileCallback, fileParsedFunc);\n }\n }\n }\n\n return ImportManager;\n};\n","import * as utils from './utils';\n\nexport default function(environment, ParseTree, ImportManager) {\n const render = function (input, options, callback) {\n if (typeof options === 'function') {\n callback = options;\n options = utils.copyOptions(this.options, {});\n }\n else {\n options = utils.copyOptions(this.options, options || {});\n }\n\n if (!callback) {\n const self = this;\n return new Promise(function (resolve, reject) {\n render.call(self, input, options, function(err, output) {\n if (err) {\n reject(err);\n } else {\n resolve(output);\n }\n });\n });\n } else {\n this.parse(input, options, function(err, root, imports, options) {\n if (err) { return callback(err); }\n\n let result;\n try {\n const parseTree = new ParseTree(root, imports);\n result = parseTree.toCSS(options);\n }\n catch (err) { return callback(err); }\n\n callback(null, result);\n });\n }\n };\n\n return render;\n};\n","import contexts from './contexts';\nimport Parser from './parser/parser';\nimport PluginManager from './plugin-manager';\nimport LessError from './less-error';\nimport * as utils from './utils';\n\nexport default function(environment, ParseTree, ImportManager) {\n const parse = function (input, options, callback) {\n\n if (typeof options === 'function') {\n callback = options;\n options = utils.copyOptions(this.options, {});\n }\n else {\n options = utils.copyOptions(this.options, options || {});\n }\n\n if (!callback) {\n const self = this;\n return new Promise(function (resolve, reject) {\n parse.call(self, input, options, function(err, output) {\n if (err) {\n reject(err);\n } else {\n resolve(output);\n }\n });\n });\n } else {\n let context;\n let rootFileInfo;\n const pluginManager = new PluginManager(this, !options.reUsePluginManager);\n\n options.pluginManager = pluginManager;\n\n context = new contexts.Parse(options);\n\n if (options.rootFileInfo) {\n rootFileInfo = options.rootFileInfo;\n } else {\n const filename = options.filename || 'input';\n const entryPath = filename.replace(/[^\\/\\\\]*$/, '');\n rootFileInfo = {\n filename,\n rewriteUrls: context.rewriteUrls,\n rootpath: context.rootpath || '',\n currentDirectory: entryPath,\n entryPath,\n rootFilename: filename\n };\n // add in a missing trailing slash\n if (rootFileInfo.rootpath && rootFileInfo.rootpath.slice(-1) !== '/') {\n rootFileInfo.rootpath += '/';\n }\n }\n\n const imports = new ImportManager(this, context, rootFileInfo);\n this.importManager = imports;\n\n // TODO: allow the plugins to be just a list of paths or names\n // Do an async plugin queue like lessc\n\n if (options.plugins) {\n options.plugins.forEach(function(plugin) {\n let evalResult, contents;\n if (plugin.fileContent) {\n contents = plugin.fileContent.replace(/^\\uFEFF/, '');\n evalResult = pluginManager.Loader.evalPlugin(contents, context, imports, plugin.options, plugin.filename);\n if (evalResult instanceof LessError) {\n return callback(evalResult);\n }\n }\n else {\n pluginManager.addPlugin(plugin);\n }\n });\n }\n\n new Parser(context, imports, rootFileInfo)\n .parse(input, function (e, root) {\n if (e) { return callback(e); }\n callback(null, root, imports, options);\n }, options);\n }\n };\n return parse;\n};\n","// TODO: Add tests for browser @plugin\n/* global window */\n\nimport AbstractPluginLoader from '../less/environment/abstract-plugin-loader.js';\n\n/**\n * Browser Plugin Loader\n */\nconst PluginLoader = function(less) {\n this.less = less;\n // Should we shim this.require for browser? Probably not?\n};\n\nPluginLoader.prototype = Object.assign(new AbstractPluginLoader(), {\n loadPlugin(filename, basePath, context, environment, fileManager) {\n return new Promise((fulfill, reject) => {\n fileManager.loadFile(filename, basePath, context, environment)\n .then(fulfill).catch(reject);\n });\n }\n});\n\nexport default PluginLoader;\n\n","import * as utils from './utils';\nimport browser from './browser';\n\nexport default (window, less, options) => {\n\n function errorHTML(e, rootHref) {\n const id = `less-error-message:${utils.extractId(rootHref || '')}`;\n const template = '
  • {content}
  • ';\n const elem = window.document.createElement('div');\n let timer;\n let content;\n const errors = [];\n const filename = e.filename || rootHref;\n const filenameNoPath = filename.match(/([^\\/]+(\\?.*)?)$/)[1];\n\n elem.id = id;\n elem.className = 'less-error-message';\n\n content = `

    ${e.type || 'Syntax'}Error: ${e.message || 'There is an error in your .less file'}` + \n `

    in ${filenameNoPath} `;\n\n const errorline = (e, i, classname) => {\n if (e.extract[i] !== undefined) {\n errors.push(template.replace(/\\{line\\}/, (parseInt(e.line, 10) || 0) + (i - 1))\n .replace(/\\{class\\}/, classname)\n .replace(/\\{content\\}/, e.extract[i]));\n }\n };\n\n if (e.line) {\n errorline(e, 0, '');\n errorline(e, 1, 'line');\n errorline(e, 2, '');\n content += `on line ${e.line}, column ${e.column + 1}:

      ${errors.join('')}
    `;\n }\n if (e.stack && (e.extract || options.logLevel >= 4)) {\n content += `
    Stack Trace
    ${e.stack.split('\\n').slice(1).join('
    ')}`;\n }\n elem.innerHTML = content;\n\n // CSS for error messages\n browser.createCSS(window.document, [\n '.less-error-message ul, .less-error-message li {',\n 'list-style-type: none;',\n 'margin-right: 15px;',\n 'padding: 4px 0;',\n 'margin: 0;',\n '}',\n '.less-error-message label {',\n 'font-size: 12px;',\n 'margin-right: 15px;',\n 'padding: 4px 0;',\n 'color: #cc7777;',\n '}',\n '.less-error-message pre {',\n 'color: #dd6666;',\n 'padding: 4px 0;',\n 'margin: 0;',\n 'display: inline-block;',\n '}',\n '.less-error-message pre.line {',\n 'color: #ff0000;',\n '}',\n '.less-error-message h3 {',\n 'font-size: 20px;',\n 'font-weight: bold;',\n 'padding: 15px 0 5px 0;',\n 'margin: 0;',\n '}',\n '.less-error-message a {',\n 'color: #10a',\n '}',\n '.less-error-message .error {',\n 'color: red;',\n 'font-weight: bold;',\n 'padding-bottom: 2px;',\n 'border-bottom: 1px dashed red;',\n '}'\n ].join('\\n'), { title: 'error-message' });\n\n elem.style.cssText = [\n 'font-family: Arial, sans-serif',\n 'border: 1px solid #e00',\n 'background-color: #eee',\n 'border-radius: 5px',\n '-webkit-border-radius: 5px',\n '-moz-border-radius: 5px',\n 'color: #e00',\n 'padding: 15px',\n 'margin-bottom: 15px'\n ].join(';');\n\n if (options.env === 'development') {\n timer = setInterval(() => {\n const document = window.document;\n const body = document.body;\n if (body) {\n if (document.getElementById(id)) {\n body.replaceChild(elem, document.getElementById(id));\n } else {\n body.insertBefore(elem, body.firstChild);\n }\n clearInterval(timer);\n }\n }, 10);\n }\n }\n\n function removeErrorHTML(path) {\n const node = window.document.getElementById(`less-error-message:${utils.extractId(path)}`);\n if (node) {\n node.parentNode.removeChild(node);\n }\n }\n\n function removeErrorConsole(path) {\n // no action\n }\n\n function removeError(path) {\n if (!options.errorReporting || options.errorReporting === 'html') {\n removeErrorHTML(path);\n } else if (options.errorReporting === 'console') {\n removeErrorConsole(path);\n } else if (typeof options.errorReporting === 'function') {\n options.errorReporting('remove', path);\n }\n }\n\n function errorConsole(e, rootHref) {\n const template = '{line} {content}';\n const filename = e.filename || rootHref;\n const errors = [];\n let content = `${e.type || 'Syntax'}Error: ${e.message || 'There is an error in your .less file'} in ${filename}`;\n\n const errorline = (e, i, classname) => {\n if (e.extract[i] !== undefined) {\n errors.push(template.replace(/\\{line\\}/, (parseInt(e.line, 10) || 0) + (i - 1))\n .replace(/\\{class\\}/, classname)\n .replace(/\\{content\\}/, e.extract[i]));\n }\n };\n\n if (e.line) {\n errorline(e, 0, '');\n errorline(e, 1, 'line');\n errorline(e, 2, '');\n content += ` on line ${e.line}, column ${e.column + 1}:\\n${errors.join('\\n')}`;\n }\n if (e.stack && (e.extract || options.logLevel >= 4)) {\n content += `\\nStack Trace\\n${e.stack}`;\n }\n less.logger.error(content);\n }\n\n function error(e, rootHref) {\n if (!options.errorReporting || options.errorReporting === 'html') {\n errorHTML(e, rootHref);\n } else if (options.errorReporting === 'console') {\n errorConsole(e, rootHref);\n } else if (typeof options.errorReporting === 'function') {\n options.errorReporting('add', e, rootHref);\n }\n }\n\n return {\n add: error,\n remove: removeError\n };\n};\n","/**\n * Kicks off less and compiles any stylesheets\n * used in the browser distributed version of less\n * to kick-start less using the browser api\n */\n/* global window, document */\n\nimport defaultOptions from '../less/default-options';\nimport addDefaultOptions from './add-default-options';\nimport root from './index';\n\nconst options = defaultOptions();\n\nif (window.less) {\n for (const key in window.less) {\n if (window.less.hasOwnProperty(key)) {\n options[key] = window.less[key];\n }\n }\n}\naddDefaultOptions(window, options);\n\noptions.plugins = options.plugins || [];\n\nif (window.LESS_PLUGINS) {\n options.plugins = options.plugins.concat(window.LESS_PLUGINS);\n}\n\nconst less = root(window, options);\nexport default less;\n\nwindow.less = less;\n\nlet css;\nlet head;\nlet style;\n\n// Always restore page visibility\nfunction resolveOrReject(data) {\n if (data.filename) {\n console.warn(data);\n }\n if (!options.async) {\n head.removeChild(style);\n }\n}\n\nif (options.onReady) {\n if (/!watch/.test(window.location.hash)) {\n less.watch();\n }\n // Simulate synchronous stylesheet loading by hiding page rendering\n if (!options.async) {\n css = 'body { display: none !important }';\n head = document.head || document.getElementsByTagName('head')[0];\n style = document.createElement('style');\n\n style.type = 'text/css';\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n\n head.appendChild(style);\n }\n less.registerStylesheetsImmediately();\n less.pageLoadFinished = less.refresh(less.env === 'development').then(resolveOrReject, resolveOrReject);\n}\n","// Export a new default each time\nexport default function() {\n return {\n /* Inline Javascript - @plugin still allowed */\n javascriptEnabled: false,\n\n /* Outputs a makefile import dependency list to stdout. */\n depends: false,\n\n /* (DEPRECATED) Compress using less built-in compression. \n * This does an okay job but does not utilise all the tricks of \n * dedicated css compression. */\n compress: false,\n\n /* Runs the less parser and just reports errors without any output. */\n lint: false,\n\n /* Sets available include paths.\n * If the file in an @import rule does not exist at that exact location, \n * less will look for it at the location(s) passed to this option. \n * You might use this for instance to specify a path to a library which \n * you want to be referenced simply and relatively in the less files. */\n paths: [],\n\n /* color output in the terminal */\n color: true,\n\n /* The strictImports controls whether the compiler will allow an @import inside of either \n * @media blocks or (a later addition) other selector blocks.\n * See: https://github.com/less/less.js/issues/656 */\n strictImports: false,\n\n /* Allow Imports from Insecure HTTPS Hosts */\n insecure: false,\n\n /* Allows you to add a path to every generated import and url in your css. \n * This does not affect less import statements that are processed, just ones \n * that are left in the output css. */\n rootpath: '',\n\n /* By default URLs are kept as-is, so if you import a file in a sub-directory \n * that references an image, exactly the same URL will be output in the css. \n * This option allows you to re-write URL's in imported files so that the \n * URL is always relative to the base imported file */\n rewriteUrls: false,\n\n /* How to process math \n * 0 always - eagerly try to solve all operations\n * 1 parens-division - require parens for division \"/\"\n * 2 parens | strict - require parens for all operations\n * 3 strict-legacy - legacy strict behavior (super-strict)\n */\n math: 1,\n\n /* Without this option, less attempts to guess at the output unit when it does maths. */\n strictUnits: false,\n\n /* Effectively the declaration is put at the top of your base Less file, \n * meaning it can be used but it also can be overridden if this variable \n * is defined in the file. */\n globalVars: null,\n\n /* As opposed to the global variable option, this puts the declaration at the\n * end of your base file, meaning it will override anything defined in your Less file. */\n modifyVars: null,\n\n /* This option allows you to specify a argument to go on to every URL. */\n urlArgs: ''\n }\n};","import {addDataAttr} from './utils';\nimport browser from './browser';\n\nexport default (window, options) => {\n\n // use options from the current script tag data attribues\n addDataAttr(options, browser.currentScript(window));\n\n if (options.isFileProtocol === undefined) {\n options.isFileProtocol = /^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(window.location.protocol);\n }\n\n // Load styles asynchronously (default: false)\n //\n // This is set to `false` by default, so that the body\n // doesn't start loading before the stylesheets are parsed.\n // Setting this to `true` can result in flickering.\n //\n options.async = options.async || false;\n options.fileAsync = options.fileAsync || false;\n\n // Interval between watch polls\n options.poll = options.poll || (options.isFileProtocol ? 1000 : 1500);\n\n options.env = options.env || (window.location.hostname == '127.0.0.1' ||\n window.location.hostname == '0.0.0.0' ||\n window.location.hostname == 'localhost' ||\n (window.location.port &&\n window.location.port.length > 0) ||\n options.isFileProtocol ? 'development'\n : 'production');\n\n const dumpLineNumbers = /!dumpLineNumbers:(comments|mediaquery|all)/.exec(window.location.hash);\n if (dumpLineNumbers) {\n options.dumpLineNumbers = dumpLineNumbers[1];\n }\n\n if (options.useFileCache === undefined) {\n options.useFileCache = true;\n }\n\n if (options.onReady === undefined) {\n options.onReady = true;\n }\n\n if (options.relativeUrls) {\n options.rewriteUrls = 'all';\n }\n};\n","//\n// index.js\n// Should expose the additional browser functions on to the less object\n//\nimport {addDataAttr} from './utils';\nimport lessRoot from '../less';\nimport browser from './browser';\nimport FM from './file-manager';\nimport PluginLoader from './plugin-loader';\nimport LogListener from './log-listener';\nimport ErrorReporting from './error-reporting';\nimport Cache from './cache';\nimport ImageSize from './image-size';\n\nexport default (window, options) => {\n const document = window.document;\n const less = lessRoot();\n\n less.options = options;\n const environment = less.environment;\n const FileManager = FM(options, less.logger);\n const fileManager = new FileManager();\n environment.addFileManager(fileManager);\n less.FileManager = FileManager;\n less.PluginLoader = PluginLoader;\n\n LogListener(less, options);\n const errors = ErrorReporting(window, less, options);\n const cache = less.cache = options.cache || Cache(window, options, less.logger);\n ImageSize(less.environment);\n\n // Setup user functions - Deprecate?\n if (options.functions) {\n less.functions.functionRegistry.addMultiple(options.functions);\n }\n\n const typePattern = /^text\\/(x-)?less$/;\n\n function clone(obj) {\n const cloned = {};\n for (const prop in obj) {\n if (obj.hasOwnProperty(prop)) {\n cloned[prop] = obj[prop];\n }\n }\n return cloned;\n }\n\n // only really needed for phantom\n function bind(func, thisArg) {\n const curryArgs = Array.prototype.slice.call(arguments, 2);\n return function() {\n const args = curryArgs.concat(Array.prototype.slice.call(arguments, 0));\n return func.apply(thisArg, args);\n };\n }\n\n function loadStyles(modifyVars) {\n const styles = document.getElementsByTagName('style');\n let style;\n\n for (let i = 0; i < styles.length; i++) {\n style = styles[i];\n if (style.type.match(typePattern)) {\n const instanceOptions = clone(options);\n instanceOptions.modifyVars = modifyVars;\n const lessText = style.innerHTML || '';\n instanceOptions.filename = document.location.href.replace(/#.*$/, '');\n\n /* jshint loopfunc:true */\n // use closure to store current style\n less.render(lessText, instanceOptions,\n bind((style, e, result) => {\n if (e) {\n errors.add(e, 'inline');\n } else {\n style.type = 'text/css';\n if (style.styleSheet) {\n style.styleSheet.cssText = result.css;\n } else {\n style.innerHTML = result.css;\n }\n }\n }, null, style));\n }\n }\n }\n\n function loadStyleSheet(sheet, callback, reload, remaining, modifyVars) {\n\n const instanceOptions = clone(options);\n addDataAttr(instanceOptions, sheet);\n instanceOptions.mime = sheet.type;\n\n if (modifyVars) {\n instanceOptions.modifyVars = modifyVars;\n }\n\n function loadInitialFileCallback(loadedFile) {\n const data = loadedFile.contents;\n const path = loadedFile.filename;\n const webInfo = loadedFile.webInfo;\n\n const newFileInfo = {\n currentDirectory: fileManager.getPath(path),\n filename: path,\n rootFilename: path,\n rewriteUrls: instanceOptions.rewriteUrls\n };\n\n newFileInfo.entryPath = newFileInfo.currentDirectory;\n newFileInfo.rootpath = instanceOptions.rootpath || newFileInfo.currentDirectory;\n\n if (webInfo) {\n webInfo.remaining = remaining;\n\n const css = cache.getCSS(path, webInfo, instanceOptions.modifyVars);\n if (!reload && css) {\n webInfo.local = true;\n callback(null, css, data, sheet, webInfo, path);\n return;\n }\n\n }\n\n // TODO add tests around how this behaves when reloading\n errors.remove(path);\n\n instanceOptions.rootFileInfo = newFileInfo;\n less.render(data, instanceOptions, (e, result) => {\n if (e) {\n e.href = path;\n callback(e);\n } else {\n cache.setCSS(sheet.href, webInfo.lastModified, instanceOptions.modifyVars, result.css);\n callback(null, result.css, data, sheet, webInfo, path);\n }\n });\n }\n\n fileManager.loadFile(sheet.href, null, instanceOptions, environment)\n .then(loadedFile => {\n loadInitialFileCallback(loadedFile);\n }).catch(err => {\n console.log(err);\n callback(err);\n });\n\n }\n\n function loadStyleSheets(callback, reload, modifyVars) {\n for (let i = 0; i < less.sheets.length; i++) {\n loadStyleSheet(less.sheets[i], callback, reload, less.sheets.length - (i + 1), modifyVars);\n }\n }\n\n function initRunningMode() {\n if (less.env === 'development') {\n less.watchTimer = setInterval(() => {\n if (less.watchMode) {\n fileManager.clearFileCache();\n loadStyleSheets((e, css, _, sheet, webInfo) => {\n if (e) {\n errors.add(e, e.href || sheet.href);\n } else if (css) {\n browser.createCSS(window.document, css, sheet);\n }\n });\n }\n }, options.poll);\n }\n }\n\n //\n // Watch mode\n //\n less.watch = function () {\n if (!less.watchMode ) {\n less.env = 'development';\n initRunningMode();\n }\n this.watchMode = true;\n return true;\n };\n\n less.unwatch = function () {clearInterval(less.watchTimer); this.watchMode = false; return false; };\n\n //\n // Synchronously get all tags with the 'rel' attribute set to\n // \"stylesheet/less\".\n //\n less.registerStylesheetsImmediately = () => {\n const links = document.getElementsByTagName('link');\n less.sheets = [];\n\n for (let i = 0; i < links.length; i++) {\n if (links[i].rel === 'stylesheet/less' || (links[i].rel.match(/stylesheet/) &&\n (links[i].type.match(typePattern)))) {\n less.sheets.push(links[i]);\n }\n }\n };\n\n //\n // Asynchronously get all tags with the 'rel' attribute set to\n // \"stylesheet/less\", returning a Promise.\n //\n less.registerStylesheets = () => new Promise((resolve, reject) => {\n less.registerStylesheetsImmediately();\n resolve();\n });\n\n //\n // With this function, it's possible to alter variables and re-render\n // CSS without reloading less-files\n //\n less.modifyVars = record => less.refresh(true, record, false);\n\n less.refresh = (reload, modifyVars, clearFileCache) => {\n if ((reload || clearFileCache) && clearFileCache !== false) {\n fileManager.clearFileCache();\n }\n return new Promise((resolve, reject) => {\n let startTime;\n let endTime;\n let totalMilliseconds;\n let remainingSheets;\n startTime = endTime = new Date();\n\n // Set counter for remaining unprocessed sheets\n remainingSheets = less.sheets.length;\n\n if (remainingSheets === 0) {\n\n endTime = new Date();\n totalMilliseconds = endTime - startTime;\n less.logger.info('Less has finished and no sheets were loaded.');\n resolve({\n startTime,\n endTime,\n totalMilliseconds,\n sheets: less.sheets.length\n });\n\n } else {\n // Relies on less.sheets array, callback seems to be guaranteed to be called for every element of the array\n loadStyleSheets((e, css, _, sheet, webInfo) => {\n if (e) {\n errors.add(e, e.href || sheet.href);\n reject(e);\n return;\n }\n if (webInfo.local) {\n less.logger.info(`Loading ${sheet.href} from cache.`);\n } else {\n less.logger.info(`Rendered ${sheet.href} successfully.`);\n }\n browser.createCSS(window.document, css, sheet);\n less.logger.info(`CSS for ${sheet.href} generated in ${new Date() - endTime}ms`);\n\n // Count completed sheet\n remainingSheets--;\n\n // Check if the last remaining sheet was processed and then call the promise\n if (remainingSheets === 0) {\n totalMilliseconds = new Date() - startTime;\n less.logger.info(`Less has finished. CSS generated in ${totalMilliseconds}ms`);\n resolve({\n startTime,\n endTime,\n totalMilliseconds,\n sheets: less.sheets.length\n });\n }\n endTime = new Date();\n }, reload, modifyVars);\n }\n\n loadStyles(modifyVars);\n });\n };\n\n less.refreshStyles = loadStyles;\n return less;\n};\n","export default (less, options) => {\n const logLevel_debug = 4;\n const logLevel_info = 3;\n const logLevel_warn = 2;\n const logLevel_error = 1;\n\n // The amount of logging in the javascript console.\n // 3 - Debug, information and errors\n // 2 - Information and errors\n // 1 - Errors\n // 0 - None\n // Defaults to 2\n options.logLevel = typeof options.logLevel !== 'undefined' ? options.logLevel : (options.env === 'development' ? logLevel_info : logLevel_error);\n\n if (!options.loggers) {\n options.loggers = [{\n debug: function(msg) {\n if (options.logLevel >= logLevel_debug) {\n console.log(msg);\n }\n },\n info: function(msg) {\n if (options.logLevel >= logLevel_info) {\n console.log(msg);\n }\n },\n warn: function(msg) {\n if (options.logLevel >= logLevel_warn) {\n console.warn(msg);\n }\n },\n error: function(msg) {\n if (options.logLevel >= logLevel_error) {\n console.error(msg);\n }\n }\n }];\n }\n for (let i = 0; i < options.loggers.length; i++) {\n less.logger.addListener(options.loggers[i]);\n }\n};\n","// Cache system is a bit outdated and could do with work\n\nexport default (window, options, logger) => {\n let cache = null;\n if (options.env !== 'development') {\n try {\n cache = (typeof window.localStorage === 'undefined') ? null : window.localStorage;\n } catch (_) {}\n }\n return {\n setCSS: function(path, lastModified, modifyVars, styles) {\n if (cache) {\n logger.info(`saving ${path} to cache.`);\n try {\n cache.setItem(path, styles);\n cache.setItem(`${path}:timestamp`, lastModified);\n if (modifyVars) {\n cache.setItem(`${path}:vars`, JSON.stringify(modifyVars));\n }\n } catch (e) {\n // TODO - could do with adding more robust error handling\n logger.error(`failed to save \"${path}\" to local storage for caching.`);\n }\n }\n },\n getCSS: function(path, webInfo, modifyVars) {\n const css = cache && cache.getItem(path);\n const timestamp = cache && cache.getItem(`${path}:timestamp`);\n let vars = cache && cache.getItem(`${path}:vars`);\n\n modifyVars = modifyVars || {};\n vars = vars || \"{}\"; // if not set, treat as the JSON representation of an empty object\n\n if (timestamp && webInfo.lastModified &&\n (new Date(webInfo.lastModified).valueOf() ===\n new Date(timestamp).valueOf()) &&\n JSON.stringify(modifyVars) === vars) {\n // Use local copy\n return css;\n }\n }\n };\n};\n","\nimport functionRegistry from './../less/functions/function-registry';\n\nexport default () => {\n function imageSize() {\n throw {\n type: 'Runtime',\n message: 'Image size functions are not supported in browser version of less'\n };\n }\n\n const imageFunctions = {\n 'image-size': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n },\n 'image-width': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n },\n 'image-height': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n }\n };\n\n functionRegistry.addMultiple(imageFunctions);\n};\n"],"names":["extractId","href","replace","addDataAttr","options","tag","opt","dataset","hasOwnProperty","JSON","parse","_","document","styles","sheet","id","title","utils.extractId","oldStyleNode","getElementById","keepOldStyleNode","styleNode","createElement","setAttribute","media","styleSheet","appendChild","createTextNode","childNodes","length","firstChild","nodeValue","head","getElementsByTagName","nextEl","nextSibling","parentNode","insertBefore","removeChild","cssText","e","Error","window","scripts","currentScript","error","msg","this","_fireEvent","warn","info","debug","addListener","listener","_listeners","push","removeListener","i","splice","type","logFunction","externalEnvironment","fileManagers","requiredFunctions","functions","concat","propName","environmentFunc","bind","Environment","filename","currentDirectory","environment","isSync","logger","pluginManager","getFileManagers","fileManager","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgrey","darkgreen","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","grey","green","greenyellow","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgrey","lightgreen","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","m","cm","mm","in","px","pt","pc","duration","s","ms","angle","rad","Math","PI","deg","grad","turn","colors","unitConversions","parent","visibilityBlocks","undefined","nodeVisible","rootNode","parsed","self","Object","defineProperty","get","fileInfo","getIndex","Node","nodes","set","node","Array","isArray","forEach","_index","_fileInfo","context","strs","genCSS","add","chunk","index","isEmpty","join","output","value","visitor","visit","op","a","b","precision","numPrecision","Number","toFixed","compare","Color","rgb","originalForm","match","map","c","parseInt","alpha","split","clamp","v","max","min","toHex","round","toString","prototype","assign","luma","r","g","pow","toCSS","doNotCompress","color","colorFunction","compress","args","fround","indexOf","toHSL","h","l","toRGB","splitcolor","operate","other","_operate","d","toHSV","toARGB","x","fromKeyword","keyword","key","toLowerCase","slice","Paren","eval","_noSpaceCombinators"," ","|","Combinator","emptyOrWhitespace","trim","spaceOrEmpty","Element","combinator","isVariable","currentFileInfo","visibilityInfo","copyVisibilityInfo","setParent","accept","clone","firstSelector","charAt","ALWAYS","PARENS_DIVISION","PARENS","RewriteUrls","getType","payload","call","copy","target","constructor","getPrototypeOf","il","arguments","k","j","jl","__spreadArrays","getOwnPropertyNames","getOwnPropertySymbols","reduce","carry","props","includes","newVal","originalObject","includeNonenumerable","propType","propertyIsEnumerable","enumerable","writable","configurable","assignProp","nonenumerable","getLocation","inputStream","n","line","column","copyArray","arr","obj","cloned","prop","defaults","obj1","obj2","newObj","_defaults","defaults_1","copyOptions","opts","strictMath","math","Constants.Math","relativeUrls","rewriteUrls","Constants.RewriteUrls","flattenArray","result","length_1","anonymousFunc","LessError","fileContentMap","currentFilename","message","stack","input","contents","loc","utils.getLocation","col","callLine","lines","found","func","Function","lineAdjust","callExtract","extract","create","F","stylize","str","errorTxt","substr","Selector","elements","extendList","condition","evaldCondition","getElements","mixinElements_","visitArray","createDerived","newSelector","mediaEmpty","els","parseNode","err","imports","createEmptySelectors","el","sels","olen","len","mixinElements","shift","isJustParentSelector","extend","getIsOutput","Value","Keyword","True","False","Anonymous","mapLines","rulesetLike","allowRoot","isRulesetLike","Boolean","MATH","Declaration","name","important","merge","inline","variable","lastRule","prevMath","evaldValue","mathBypass","evalName","importantScope","importantResult","pop","makeImportant","ctx","lineSeparator","dumpLineNumbers","debugInfo","asComment","asMediaQuery","lineNumber","fileName","filenameWithProtocol","test","Comment","isLineComment","getDebugInfo","isSilent","isCompressed","contexts","copyFromOriginal","original","destination","propertiesToCopy","parseCopyProperties","Parse","paths","evalCopyProperties","isPathRelative","path","isPathLocalRelative","Eval","frames","enterCalc","calcStack","inCalc","exitCalc","inParenthesis","parensStack","outOfParenthesis","mathOn","isMathOn","pathRequiresRewrite","rewritePath","rootpath","newPath","normalizePath","segment","segments","reverse","makeRegistry","base","_data","addMultiple","keys","_this","getLocalFunctions","inherit","defaultFunc","value_","error_","reset","Ruleset","selectors","rules","strictImports","_lookups","_variables","_properties","isRuleset","selCnt","selector","hasVariable","hasOnePassingSelector","toParseSelectors","utils.flattenArray","rule","subRule","utils.copyArray","ruleset","originalRuleset","root","firstRoot","allowImports","functionRegistry","globalFunctionRegistry","ctxFrames","unshift","ctxSelectors","evalImports","rsRules","evalFirst","mediaBlockCount","mediaBlocks","filter","apply","resetCache","bubbleSelectors","importRules","matchArgs","matchCondition","lastSelector","_rulesets","variables","hash","vars","name_1","properties","name_2","decl","parseValue","property","lastDeclaration","toParse","transformDeclaration","nodes_1","rulesets","filtRules","prependRule","find","foundMixins","ruleNodes","tabLevel","sep","tabRuleStr","tabSetStr","charsetNodeIndex","importNodeIndex","isCharset","pathCnt","pathSubCnt","currentLastRule","isVisible","joinSelectors","joinSelector","createParenthesis","elementsToPak","originalElement","replacementParen","insideParent","createSelector","containedElement","element","addReplacementIntoPath","beginningPath","addPath","replacedElement","originalSelector","newSelectorPath","newJoinedSelector","parentEl","restOfPath","addAllReplacementsIntoPath","addPaths","mergeElementsOnToSelectors","sel","deriveSelector","deriveFrom","newPaths","replaceParentSelector","inSelector","currentElements","newSelectors","selectorsMultiplied","maybeSelector","hadParentSelector","nestedSelector","replaced","nestedPaths","replacedNewSelectors","concatenated","AtRule","isRooted","outputRuleset","mediaPathBackup","mediaBlocksBackup","mediaPath","ruleCnt","DetachedRuleset","callEval","Unit","numerator","denominator","backupUnit","sort","strictUnits","returnStr","is","unitString","toUpperCase","isLength","RegExp","isSingular","callback","usedUnits","group","mapUnit","groupName","atomicUnit","cancel","counter","count","Dimension","unit","parseFloat","isNaN","toColor","strValue","String","convertTo","unify","numericCompare","conversions","targetUnit","applyUnit","derivedConversions","Operation","operands","isSpaced","Expression","noSpacing","returnValue","parens","doubleParen","parensInOp","throwAwayComments","functionCaller","evalArgs","commentFilter","item","subNodes","Call","calc","currentMathContext","funcCaller","FunctionCaller","isValid","columnNumber","Variable","evaluating","frame","fun","Property","mergeRules","less","visitors","ToCSSVisitor","_mergeRules","vArr","Attribute","Quoted","content","escaped","quote","variableRegex","propRegex","containsVariables","that","iterativeReplace","regexp","replacementFnc","evaluatedValue","URL","val","isEvald","urlArgs","Media","features","evalTop","evalNested","multiMedia","permute","fragment","rest","Import","css","pathValue","getPath","isPlugin","reference","isVariableImport","evalForImport","evalPath","doEval","blocksVisibility","addVisibilityBlock","registry","skip","importedFilename","newImport","JsEvalNode","evaluateJavaScript","expression","evalContext","javascriptEnabled","jsify","toJS","JavaScript","string","Assignment","Condition","negate","lvalue","rvalue","UnicodeDescriptor","Negative","Extend","option","object_id","next_id","parent_ids","allowBefore","allowAfter","findSelfSelectors","selectorElements","selfElements","selfSelectors","VariableCall","detachedRuleset","NamespaceValue","ruleCall","lookups","substring","Definition","params","variadic","arity","optionalParameters","required","p","evalParams","mixinEnv","evaldArguments","varargs","arg","isNamedFound","argIndex","argsLength","evalCall","_arguments","mixinFrames","allArgsCnt","requiredArgsCnt","MixinCall","mixins","mixin","mixinPath","argValue","f","isRecursive","isOneFound","candidate","defaultResult","noArgumentsFilter","candidates","conditionResult","calcDefGroup","namespace","expand","MixinDefinition","format","newRules","_setVisibilityToReplacement","replacement","AbstractFileManager","lastIndexOf","ext","tryAppendExtension","basePath","laterPath","url","baseUrl","urlDirectories","baseUrlDirectories","urlParts","extractUrlParts","baseUrlParts","diff","hostPart","directories","urlPartsRegex","returner","rawDirectories","rawPath","fileUrl","require","AbstractPluginLoader","pluginOptions","pluginObj","localModule","shortname","FileManager","trySetOptions","use","exports","loader","tree","validatePlugin","minVersion","compareVersion","addPlugin","plugin","setOptions","version","versionToString","aVersion","bVersion","versionString","plugins","printUsage","_visitArgs","visitDeeper","_hasIndexed","_noop","implementation","_implementation","_visitInCache","_visitOutCache","indexNodeTypes","ticker","child","typeIndex","Visitor","nodeTypeIndex","fnName","impl","funcOut","visitArgs","newNode","isReplacing","cnt","nonReplacing","out","evald","flatten","nestedCnt","nestedItem","onSequencerEmpty","variableImports","_onSequencerEmpty","_currentDepth","ImportSequencer","importSequencer","importItem","isReady","tryRun","variableImport","ImportVisitor","importer","finish","_visitor","_importer","_finish","importCount","onceFileDetectionMap","recursionDetector","_sequencer","run","isFinished","visitImport","importNode","inlineCSS","importParent","addVariableImport","processImportNode","evaldImportNode","multiple","importMultiple","tryAppendLessExtension","onImported","sequencedOnImported","addImport","importedAtRoot","fullPath","importVisitor","isOptional","optional","duplicateImport","oldContext","visitDeclaration","declNode","visitDeclarationOut","visitAtRule","atRuleNode","visitAtRuleOut","visitMixinDefinition","mixinDefinitionNode","visitMixinDefinitionOut","visitRuleset","rulesetNode","visitRulesetOut","visitMedia","mediaNode","visitMediaOut","visible","SetTreeVisibilityVisitor","ensureVisibility","ensureInvisibility","allExtendsStack","ExtendFinderVisitor","allExtends","allSelectorsExtendList","extendOnEveryPath","selectorPath","selExtendList","allSelectorsExtend","foundExtends","firstExtendOnThisSelectorPath","ProcessExtendsVisitor","extendFinder","extendIndices","doExtendChaining","newRoot","checkExtendsForNonMatched","indices","hasFoundMatches","extendsList","extendsListTarget","iterationCount","extendIndex","targetExtendIndex","matches","targetExtend","newExtend","extendsToAdd","extendVisitor","findMatch","selfSelector","extendSelector","extendChainCount","selectorOne","selectorTwo","ruleNode","selectorNode","pathIndex","selectorsToAdd","extendedSelectors","haystackSelectorPath","haystackSelectorIndex","hackstackSelector","hackstackElementIndex","haystackElement","targetCombinator","potentialMatch","needleElements","potentialMatches","matched","initialCombinator","isElementValuesEqual","finished","endPathIndex","endPathElementIndex","elementValue1","elementValue2","replacementSelector","matchIndex","firstElement","newElements","currentSelectorPathIndex","currentSelectorPathElementIndex","currentValue","derived","newAllExtends","lastIndex","JoinSelectorVisitor","_context","CSSVisitorUtils","bodyRules","owner","thing","originalRules","containsSilentNonBlockedChild","compiledRulesBody","keepOnlyVisibleChilds","removeVisibilityBlock","hasVisibleSelector","utils","mixinNode","visitExtend","extendNode","visitComment","commentNode","resolveVisibility","visitAtRuleWithBody","visitAtRuleWithoutBody","visitAnonymous","anonymousNode","nodeRules","hasFakeRuleset","getBodyRules","charset","comment","checkValidNodes","isRoot","_compileRulesetPaths","nodeRuleCnt","_removeDuplicateRules","isVisibleRuleset","ruleList","ruleCache","ruleCSS","groups","groupsArr","result_1","space_1","comma_1","MarkVisibleSelectorsVisitor","ExtendVisitor","furthest","furthestPossibleErrorMessage","chunks","current","currentPos","saveStack","parserInput","skipWhitespace","nextChar","oldi","oldj","curr","endIndex","mem","inp","charCodeAt","autoCommentAbsorb","nextNewLine","text","commentStore","nextStarSlash","save","restore","possibleErrorMessage","state","forget","isWhitespace","offset","pos","code","$re","tok","exec","$char","$str","tokLength","$quoted","startChar","currentPosition","$parseUntil","testChar","returnVal","inComment","blockDepth","blockStack","parseGroups","startPos","lastPos","loop","char","expected","peek","peekChar","currentChar","prevChar","getInput","peekNotNumeric","start","chunkInput","failFunction","fail","lastOpening","lastOpeningParen","lastMultiComment","lastMultiCommentEndBrace","chunkerCurrentIndex","currentChunkStartIndex","cc","cc2","level","parenLevel","emitFrom","emitChunk","force","fromCharCode","chunker","end","furthestReachedEnd","furthestChar","Parser","parsers","getParserInput","expect","expectChar","parseList","currentIndex","returnNodes","parser","additionalData","globalVars","modifyVars","ignored","preText","serializeVars","preProcessors","getPreProcessors","process","banner","contentsIgnoredChars","primary","endInfo","processImports","extendRule","definition","declaration","variableCall","entities","atrule","foundSemiColon","mixinLookup","quoted","forceEscaped","isEscaped","customFuncCall","stop","ieAlpha","boolean","if","prevArgs","isSemiColonSeparated","argsComma","argsSemiColon","assignment","literal","dimension","unicodeDescriptor","entity","ch","variableCurly","curly","propertyCurly","colorKeyword","ud","javascript","js","escape","parsedName","inValue","ruleLookups","isRule","getLookup","hasParens","elem","elemIndex","re","isCall","expressionContainsNamed","nameLoop","expressions","hasSep","cond","argInfo","conditions","block","lookupValue","attribute","slashedCombinator","isLess","when","blockRuleset","hasDR","ruleProperty","permissiveValue","anonymousValue","untilTokens","done","testCurrentChar","import","dir","importOptions","mediaFeatures","o","optionName","importOption","mediaFeature","pluginArgs","nonVendorSpecificName","hasIdentifier","hasExpression","hasUnknown","hasBlock","sub","addition","multiplication","operation","operand","needsParens","logical","next","conditionAnd","negatedCondition","parenthesisCondition","atomicCondition","body","me","tryConditionFollowedByParenthesis","delim","simpleProperty","If","trueValue","falseValue","isdefined","colorFunctions","hsla","origColor","hsl","number","rgba","size","m1_1","m2_1","hue","hsv","hsva","vs","floor","perm","saturation","lightness","hsvhue","hsvsaturation","hsvvalue","luminance","saturate","amount","method","desaturate","lighten","darken","fadein","fadeout","fade","spin","mix","color1","color2","weight","w","w1","w2","greyscale","contrast","dark","light","threshold","t","argb","tint","shade","colorBlend","mode","cb","cs","ar","cr","ab","as","colorBlendModeFunctions","multiply","screen","overlay","softlight","sqrt","hardlight","difference","abs","exclusion","average","negation","getItemsFromNode","_SELF","~","_i","expr","values","range","step","from","to","stepValue","list","each","rs","iterator","tryEval","Quote","valueName","keyName","indexName","MathHelper","fn","mathFunctions","ceil","sin","cos","atan","asin","acos","mathHelper","fraction","num","minMax","isMin","currentUnified","referenceUnified","unitStatic","unitClone","order","convert","pi","mod","y","percentage","evaluated","encodeURI","pattern","flags","%","token","encodeURIComponent","isa","Type","isunit","isruleset","iscolor","isnumber","isstring","iskeyword","isurl","ispixel","ispercentage","isem","get-unit","colorBlending","fallback","functionThis","data-uri","mimetypeNode","filePathNode","mimetype","filePath","entryPath","fragmentStart","utils.clone","rawBuffer","getFileManager","useBase64","mimeLookup","charsetLookup","fileSync","loadFileSync","buf","encodeBase64","uri","dataUri","svg-gradient","direction","stops","gradientDirectionSvg","position","positionValue","gradientType","rectangleDimension","renderEnv","directionValue","throwArgumentDescriptor","types","evaldRoot","evalEnv","visitorIterator","preEvalVisitors","first","isPreEvalVisitor","isPreVisitor","pm","postProcessors","installedPlugins","pluginCache","Loader","PluginLoader","PluginManager","install","preProcessor","priority","indexToInsertAt","postProcessor","manager","PluginManagerFactory","newFactory","major","minor","patch","pre","build","sourceMapOutput","sourceMapBuilder","parseTree","importManager","SourceMapBuilder","ParseTree","transformTree","toCSSOptions","sourceMap","getPostProcessors","file","getExternalSourceMap","files","rootFilename","SourceMapOutput","contentsIgnoredCharsMap","contentsMap","sourceMapFilename","sourceMapURL","outputFilename","sourceMapOutputFilename","sourceMapBasepath","sourceMapRootpath","outputSourceFiles","sourceMapGenerator","sourceMapFileInline","disableSourcemapAnnotation","sourceMapInputFilename","normalizeFilename","removeBasepath","getCSSAppendage","_css","_rootNode","_contentsMap","_contentsIgnoredCharsMap","_sourceMapFilename","_outputFilename","_sourceMapBasepath","_sourceMapRootpath","_outputSourceFiles","_sourceMapGeneratorConstructor","getSourceMapGenerator","_lineNumber","_column","sourceLines","columns","sourceColumns","inputSource","_sourceMapGenerator","addMapping","generated","source","sourceRoot","setSourceContent","sourceMapContent","stringify","toJSON","rootFileInfo","mime","queue","ImportManager","pluginLoader","fileParsedFunc","importedEqualsRoot","newFileInfo","loadedFile","promise","loadFileCallback","resolvedFilename","pathDiff","isPathAbsolute","alwaysMakePathsAbsolute","newEnv","evalPlugin","syncImport","loadPluginSync","loadPlugin","loadFile","then","render","utils.copyOptions","self_1","Promise","resolve","reject","Render","context_1","pluginManager_1","reUsePluginManager","imports_1","evalResult","fileContent","parseVersion","initial","data","ctor","api","fileCache","doXHR","errback","xhr","XMLHttpRequest","async","isFileProtocol","fileAsync","handleResponse","status","responseText","getResponseHeader","overrideMimeType","open","setRequestHeader","send","onreadystatechange","readyState","supports","clearFileCache","location","useFileCache","lessText","webInfo","lastModified","Date","log","fulfill","catch","rootHref","errorReporting","errors","errorline","classname","logLevel","errorConsole","timer","filenameNoPath","className","innerHTML","browser","style","env","setInterval","replaceChild","clearInterval","errorHTML","remove","removeErrorHTML","depends","lint","insecure","protocol","poll","hostname","port","onReady","addDefaultOptions","LESS_PLUGINS","lessRoot","FM","addFileManager","loggers","console","LogListener","ErrorReporting","cache","localStorage","setCSS","setItem","getCSS","getItem","timestamp","valueOf","Cache","imageSize","imageFunctions","image-size","image-width","image-height","ImageSize","typePattern","thisArg","curryArgs","loadStyles","instanceOptions","loadStyleSheet","reload","remaining","local","loadInitialFileCallback","loadStyleSheets","sheets","watch","watchMode","watchTimer","unwatch","registerStylesheetsImmediately","links","rel","registerStylesheets","record","refresh","startTime","endTime","totalMilliseconds","remainingSheets","refreshStyles","resolveOrReject","pageLoadFinished"],"mappings":"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"} \ No newline at end of file diff --git a/lerna.json b/lerna.json index 3c2210171..d27fc5bf8 100644 --- a/lerna.json +++ b/lerna.json @@ -3,5 +3,5 @@ "packages/*" ], "npmClient": "npm", - "version": "3.13.0" + "version": "4.0.0" } diff --git a/packages/less/Gruntfile.js b/packages/less/Gruntfile.js index 7e2817367..83b06a5c8 100644 --- a/packages/less/Gruntfile.js +++ b/packages/less/Gruntfile.js @@ -283,7 +283,7 @@ module.exports = function(grunt) { eslint: { target: [ "test/**/*.js", - "lib/less*/**/*.js", + "src/less*/**/*.js", "!test/less/errors/plugin/plugin-error.js" ], options: { diff --git a/packages/less/bin/lessc b/packages/less/bin/lessc index 18599a728..6037df5e8 100755 --- a/packages/less/bin/lessc +++ b/packages/less/bin/lessc @@ -554,7 +554,7 @@ function processPluginQueue() { if (checkArgFunc(arg, match[2])) { if (checkBooleanArg(match[2])) { - options.math = Constants.Math.STRICT_LEGACY; + options.math = Constants.Math.PARENS; } } @@ -562,8 +562,19 @@ function processPluginQueue() { case 'm': case 'math': - if (checkArgFunc(arg, match[2])) { - options.math = match[2]; + var m = match[2]; + if (checkArgFunc(arg, m)) { + if (m === 'always') { + console.warn('--math=always is deprecated and will be removed in the future.'); + options.math = Constants.Math.ALWAYS; + } else if (m === 'parens-division') { + options.math = Constants.Math.PARENS_DIVISION; + } else if (m === 'parens' || m === 'strict') { + options.math = Constants.Math.PARENS; + } else if (m === 'strict-legacy') { + console.warn('--math=strict-legacy has been removed. Defaulting to --math=strict'); + options.math = Constants.Math.PARENS; + } } break; diff --git a/packages/less/build/rollup.js b/packages/less/build/rollup.js index 9f7e42e99..75fa660e7 100644 --- a/packages/less/build/rollup.js +++ b/packages/less/build/rollup.js @@ -1,6 +1,7 @@ const rollup = require('rollup'); const typescript = require('rollup-plugin-typescript2'); const commonjs = require('rollup-plugin-commonjs'); +const json = require('@rollup/plugin-json'); const resolve = require('rollup-plugin-node-resolve'); const terser = require('rollup-plugin-terser').terser; const banner = require('./banner'); @@ -28,6 +29,7 @@ async function buildBrowser() { plugins: [ resolve(), commonjs(), + json(), typescript({ verbosity: 2, tsconfigDefaults: { diff --git a/packages/less/dist/less.js b/packages/less/dist/less.js index a881ab4b9..e71e5fc5b 100644 --- a/packages/less/dist/less.js +++ b/packages/less/dist/less.js @@ -1,5 +1,5 @@ /** - * Less - Leaner CSS v3.13.1 + * Less - Leaner CSS v4.0.0 * http://lesscss.org * * Copyright (c) 2009-2020, Alexis Sellier @@ -9,11267 +9,11264 @@ */ (function (global, factory) { - typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : - typeof define === 'function' && define.amd ? define(factory) : - (global = global || self, global.less = factory()); + typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : + typeof define === 'function' && define.amd ? define(factory) : + (global = global || self, global.less = factory()); }(this, (function () { 'use strict'; - // Export a new default each time - var defaultOptions = (function () { return ({ - /* Inline Javascript - @plugin still allowed */ - javascriptEnabled: false, - /* Outputs a makefile import dependency list to stdout. */ - depends: false, - /* (DEPRECATED) Compress using less built-in compression. - * This does an okay job but does not utilise all the tricks of - * dedicated css compression. */ - compress: false, - /* Runs the less parser and just reports errors without any output. */ - lint: false, - /* Sets available include paths. - * If the file in an @import rule does not exist at that exact location, - * less will look for it at the location(s) passed to this option. - * You might use this for instance to specify a path to a library which - * you want to be referenced simply and relatively in the less files. */ - paths: [], - /* color output in the terminal */ - color: true, - /* The strictImports controls whether the compiler will allow an @import inside of either - * @media blocks or (a later addition) other selector blocks. - * See: https://github.com/less/less.js/issues/656 */ - strictImports: false, - /* Allow Imports from Insecure HTTPS Hosts */ - insecure: false, - /* Allows you to add a path to every generated import and url in your css. - * This does not affect less import statements that are processed, just ones - * that are left in the output css. */ - rootpath: '', - /* By default URLs are kept as-is, so if you import a file in a sub-directory - * that references an image, exactly the same URL will be output in the css. - * This option allows you to re-write URL's in imported files so that the - * URL is always relative to the base imported file */ - rewriteUrls: false, - /* How to process math - * 0 always - eagerly try to solve all operations - * 1 parens-division - require parens for division "/" - * 2 parens | strict - require parens for all operations - * 3 strict-legacy - legacy strict behavior (super-strict) - */ - math: 0, - /* Without this option, less attempts to guess at the output unit when it does maths. */ - strictUnits: false, - /* Effectively the declaration is put at the top of your base Less file, - * meaning it can be used but it also can be overridden if this variable - * is defined in the file. */ - globalVars: null, - /* As opposed to the global variable option, this puts the declaration at the - * end of your base file, meaning it will override anything defined in your Less file. */ - modifyVars: null, - /* This option allows you to specify a argument to go on to every URL. */ - urlArgs: '' - }); }); + // Export a new default each time + function defaultOptions () { + return { + /* Inline Javascript - @plugin still allowed */ + javascriptEnabled: false, + /* Outputs a makefile import dependency list to stdout. */ + depends: false, + /* (DEPRECATED) Compress using less built-in compression. + * This does an okay job but does not utilise all the tricks of + * dedicated css compression. */ + compress: false, + /* Runs the less parser and just reports errors without any output. */ + lint: false, + /* Sets available include paths. + * If the file in an @import rule does not exist at that exact location, + * less will look for it at the location(s) passed to this option. + * You might use this for instance to specify a path to a library which + * you want to be referenced simply and relatively in the less files. */ + paths: [], + /* color output in the terminal */ + color: true, + /* The strictImports controls whether the compiler will allow an @import inside of either + * @media blocks or (a later addition) other selector blocks. + * See: https://github.com/less/less.js/issues/656 */ + strictImports: false, + /* Allow Imports from Insecure HTTPS Hosts */ + insecure: false, + /* Allows you to add a path to every generated import and url in your css. + * This does not affect less import statements that are processed, just ones + * that are left in the output css. */ + rootpath: '', + /* By default URLs are kept as-is, so if you import a file in a sub-directory + * that references an image, exactly the same URL will be output in the css. + * This option allows you to re-write URL's in imported files so that the + * URL is always relative to the base imported file */ + rewriteUrls: false, + /* How to process math + * 0 always - eagerly try to solve all operations + * 1 parens-division - require parens for division "/" + * 2 parens | strict - require parens for all operations + * 3 strict-legacy - legacy strict behavior (super-strict) + */ + math: 1, + /* Without this option, less attempts to guess at the output unit when it does maths. */ + strictUnits: false, + /* Effectively the declaration is put at the top of your base Less file, + * meaning it can be used but it also can be overridden if this variable + * is defined in the file. */ + globalVars: null, + /* As opposed to the global variable option, this puts the declaration at the + * end of your base file, meaning it will override anything defined in your Less file. */ + modifyVars: null, + /* This option allows you to specify a argument to go on to every URL. */ + urlArgs: '' + }; + } - function extractId(href) { - return href.replace(/^[a-z-]+:\/+?[^\/]+/, '') // Remove protocol & domain - .replace(/[\?\&]livereload=\w+/, '') // Remove LiveReload cachebuster - .replace(/^\//, '') // Remove root / - .replace(/\.[a-zA-Z]+$/, '') // Remove simple extension - .replace(/[^\.\w-]+/g, '-') // Replace illegal characters - .replace(/\./g, ':'); // Replace dots with colons(for valid id) - } - function addDataAttr(options, tag) { - for (var opt in tag.dataset) { - if (tag.dataset.hasOwnProperty(opt)) { - if (opt === 'env' || opt === 'dumpLineNumbers' || opt === 'rootpath' || opt === 'errorReporting') { - options[opt] = tag.dataset[opt]; - } - else { - try { - options[opt] = JSON.parse(tag.dataset[opt]); - } - catch (_) { } - } - } - } - } + function extractId(href) { + return href.replace(/^[a-z-]+:\/+?[^\/]+/, '') // Remove protocol & domain + .replace(/[\?\&]livereload=\w+/, '') // Remove LiveReload cachebuster + .replace(/^\//, '') // Remove root / + .replace(/\.[a-zA-Z]+$/, '') // Remove simple extension + .replace(/[^\.\w-]+/g, '-') // Replace illegal characters + .replace(/\./g, ':'); // Replace dots with colons(for valid id) + } + function addDataAttr(options, tag) { + for (var opt in tag.dataset) { + if (tag.dataset.hasOwnProperty(opt)) { + if (opt === 'env' || opt === 'dumpLineNumbers' || opt === 'rootpath' || opt === 'errorReporting') { + options[opt] = tag.dataset[opt]; + } + else { + try { + options[opt] = JSON.parse(tag.dataset[opt]); + } + catch (_) { } + } + } + } + } - var browser = { - createCSS: function (document, styles, sheet) { - // Strip the query-string - var href = sheet.href || ''; - // If there is no title set, use the filename, minus the extension - var id = "less:" + (sheet.title || extractId(href)); - // If this has already been inserted into the DOM, we may need to replace it - var oldStyleNode = document.getElementById(id); - var keepOldStyleNode = false; - // Create a new stylesheet node for insertion or (if necessary) replacement - var styleNode = document.createElement('style'); - styleNode.setAttribute('type', 'text/css'); - if (sheet.media) { - styleNode.setAttribute('media', sheet.media); - } - styleNode.id = id; - if (!styleNode.styleSheet) { - styleNode.appendChild(document.createTextNode(styles)); - // If new contents match contents of oldStyleNode, don't replace oldStyleNode - keepOldStyleNode = (oldStyleNode !== null && oldStyleNode.childNodes.length > 0 && styleNode.childNodes.length > 0 && - oldStyleNode.firstChild.nodeValue === styleNode.firstChild.nodeValue); - } - var head = document.getElementsByTagName('head')[0]; - // If there is no oldStyleNode, just append; otherwise, only append if we need - // to replace oldStyleNode with an updated stylesheet - if (oldStyleNode === null || keepOldStyleNode === false) { - var nextEl = sheet && sheet.nextSibling || null; - if (nextEl) { - nextEl.parentNode.insertBefore(styleNode, nextEl); - } - else { - head.appendChild(styleNode); - } - } - if (oldStyleNode && keepOldStyleNode === false) { - oldStyleNode.parentNode.removeChild(oldStyleNode); - } - // For IE. - // This needs to happen *after* the style element is added to the DOM, otherwise IE 7 and 8 may crash. - // See http://social.msdn.microsoft.com/Forums/en-US/7e081b65-878a-4c22-8e68-c10d39c2ed32/internet-explorer-crashes-appending-style-element-to-head - if (styleNode.styleSheet) { - try { - styleNode.styleSheet.cssText = styles; - } - catch (e) { - throw new Error('Couldn\'t reassign styleSheet.cssText.'); - } - } - }, - currentScript: function (window) { - var document = window.document; - return document.currentScript || (function () { - var scripts = document.getElementsByTagName('script'); - return scripts[scripts.length - 1]; - })(); - } - }; + var browser = { + createCSS: function (document, styles, sheet) { + // Strip the query-string + var href = sheet.href || ''; + // If there is no title set, use the filename, minus the extension + var id = "less:" + (sheet.title || extractId(href)); + // If this has already been inserted into the DOM, we may need to replace it + var oldStyleNode = document.getElementById(id); + var keepOldStyleNode = false; + // Create a new stylesheet node for insertion or (if necessary) replacement + var styleNode = document.createElement('style'); + styleNode.setAttribute('type', 'text/css'); + if (sheet.media) { + styleNode.setAttribute('media', sheet.media); + } + styleNode.id = id; + if (!styleNode.styleSheet) { + styleNode.appendChild(document.createTextNode(styles)); + // If new contents match contents of oldStyleNode, don't replace oldStyleNode + keepOldStyleNode = (oldStyleNode !== null && oldStyleNode.childNodes.length > 0 && styleNode.childNodes.length > 0 && + oldStyleNode.firstChild.nodeValue === styleNode.firstChild.nodeValue); + } + var head = document.getElementsByTagName('head')[0]; + // If there is no oldStyleNode, just append; otherwise, only append if we need + // to replace oldStyleNode with an updated stylesheet + if (oldStyleNode === null || keepOldStyleNode === false) { + var nextEl = sheet && sheet.nextSibling || null; + if (nextEl) { + nextEl.parentNode.insertBefore(styleNode, nextEl); + } + else { + head.appendChild(styleNode); + } + } + if (oldStyleNode && keepOldStyleNode === false) { + oldStyleNode.parentNode.removeChild(oldStyleNode); + } + // For IE. + // This needs to happen *after* the style element is added to the DOM, otherwise IE 7 and 8 may crash. + // See http://social.msdn.microsoft.com/Forums/en-US/7e081b65-878a-4c22-8e68-c10d39c2ed32/internet-explorer-crashes-appending-style-element-to-head + if (styleNode.styleSheet) { + try { + styleNode.styleSheet.cssText = styles; + } + catch (e) { + throw new Error('Couldn\'t reassign styleSheet.cssText.'); + } + } + }, + currentScript: function (window) { + var document = window.document; + return document.currentScript || (function () { + var scripts = document.getElementsByTagName('script'); + return scripts[scripts.length - 1]; + })(); + } + }; - var addDefaultOptions = (function (window, options) { - // use options from the current script tag data attribues - addDataAttr(options, browser.currentScript(window)); - if (options.isFileProtocol === undefined) { - options.isFileProtocol = /^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(window.location.protocol); - } - // Load styles asynchronously (default: false) - // - // This is set to `false` by default, so that the body - // doesn't start loading before the stylesheets are parsed. - // Setting this to `true` can result in flickering. - // - options.async = options.async || false; - options.fileAsync = options.fileAsync || false; - // Interval between watch polls - options.poll = options.poll || (options.isFileProtocol ? 1000 : 1500); - options.env = options.env || (window.location.hostname == '127.0.0.1' || - window.location.hostname == '0.0.0.0' || - window.location.hostname == 'localhost' || - (window.location.port && - window.location.port.length > 0) || - options.isFileProtocol ? 'development' - : 'production'); - var dumpLineNumbers = /!dumpLineNumbers:(comments|mediaquery|all)/.exec(window.location.hash); - if (dumpLineNumbers) { - options.dumpLineNumbers = dumpLineNumbers[1]; - } - if (options.useFileCache === undefined) { - options.useFileCache = true; - } - if (options.onReady === undefined) { - options.onReady = true; - } - if (options.relativeUrls) { - options.rewriteUrls = 'all'; - } - }); + var addDefaultOptions = (function (window, options) { + // use options from the current script tag data attribues + addDataAttr(options, browser.currentScript(window)); + if (options.isFileProtocol === undefined) { + options.isFileProtocol = /^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(window.location.protocol); + } + // Load styles asynchronously (default: false) + // + // This is set to `false` by default, so that the body + // doesn't start loading before the stylesheets are parsed. + // Setting this to `true` can result in flickering. + // + options.async = options.async || false; + options.fileAsync = options.fileAsync || false; + // Interval between watch polls + options.poll = options.poll || (options.isFileProtocol ? 1000 : 1500); + options.env = options.env || (window.location.hostname == '127.0.0.1' || + window.location.hostname == '0.0.0.0' || + window.location.hostname == 'localhost' || + (window.location.port && + window.location.port.length > 0) || + options.isFileProtocol ? 'development' + : 'production'); + var dumpLineNumbers = /!dumpLineNumbers:(comments|mediaquery|all)/.exec(window.location.hash); + if (dumpLineNumbers) { + options.dumpLineNumbers = dumpLineNumbers[1]; + } + if (options.useFileCache === undefined) { + options.useFileCache = true; + } + if (options.onReady === undefined) { + options.onReady = true; + } + if (options.relativeUrls) { + options.rewriteUrls = 'all'; + } + }); - /*! ***************************************************************************** - Copyright (c) Microsoft Corporation. + var logger = { + error: function (msg) { + this._fireEvent('error', msg); + }, + warn: function (msg) { + this._fireEvent('warn', msg); + }, + info: function (msg) { + this._fireEvent('info', msg); + }, + debug: function (msg) { + this._fireEvent('debug', msg); + }, + addListener: function (listener) { + this._listeners.push(listener); + }, + removeListener: function (listener) { + for (var i = 0; i < this._listeners.length; i++) { + if (this._listeners[i] === listener) { + this._listeners.splice(i, 1); + return; + } + } + }, + _fireEvent: function (type, msg) { + for (var i = 0; i < this._listeners.length; i++) { + var logFunction = this._listeners[i][type]; + if (logFunction) { + logFunction(msg); + } + } + }, + _listeners: [] + }; - Permission to use, copy, modify, and/or distribute this software for any - purpose with or without fee is hereby granted. + /** + * @todo Document why this abstraction exists, and the relationship between + * environment, file managers, and plugin manager + */ + var Environment = /** @class */ (function () { + function Environment(externalEnvironment, fileManagers) { + this.fileManagers = fileManagers || []; + externalEnvironment = externalEnvironment || {}; + var optionalFunctions = ['encodeBase64', 'mimeLookup', 'charsetLookup', 'getSourceMapGenerator']; + var requiredFunctions = []; + var functions = requiredFunctions.concat(optionalFunctions); + for (var i = 0; i < functions.length; i++) { + var propName = functions[i]; + var environmentFunc = externalEnvironment[propName]; + if (environmentFunc) { + this[propName] = environmentFunc.bind(externalEnvironment); + } + else if (i < requiredFunctions.length) { + this.warn("missing required function in environment - " + propName); + } + } + } + Environment.prototype.getFileManager = function (filename, currentDirectory, options, environment, isSync) { + if (!filename) { + logger.warn('getFileManager called with no filename.. Please report this issue. continuing.'); + } + if (currentDirectory == null) { + logger.warn('getFileManager called with null directory.. Please report this issue. continuing.'); + } + var fileManagers = this.fileManagers; + if (options.pluginManager) { + fileManagers = [].concat(fileManagers).concat(options.pluginManager.getFileManagers()); + } + for (var i = fileManagers.length - 1; i >= 0; i--) { + var fileManager = fileManagers[i]; + if (fileManager[isSync ? 'supportsSync' : 'supports'](filename, currentDirectory, options, environment)) { + return fileManager; + } + } + return null; + }; + Environment.prototype.addFileManager = function (fileManager) { + this.fileManagers.push(fileManager); + }; + Environment.prototype.clearFileManagers = function () { + this.fileManagers = []; + }; + return Environment; + }()); - THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH - REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY - AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, - INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM - LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR - OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR - PERFORMANCE OF THIS SOFTWARE. - ***************************************************************************** */ - /* global Reflect, Promise */ - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) - if (b.hasOwnProperty(p)) - d[p] = b[p]; }; - return extendStatics(d, b); - }; - function __extends(d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - } - function __spreadArrays() { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) - s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; - } + var colors = { + 'aliceblue': '#f0f8ff', + 'antiquewhite': '#faebd7', + 'aqua': '#00ffff', + 'aquamarine': '#7fffd4', + 'azure': '#f0ffff', + 'beige': '#f5f5dc', + 'bisque': '#ffe4c4', + 'black': '#000000', + 'blanchedalmond': '#ffebcd', + 'blue': '#0000ff', + 'blueviolet': '#8a2be2', + 'brown': '#a52a2a', + 'burlywood': '#deb887', + 'cadetblue': '#5f9ea0', + 'chartreuse': '#7fff00', + 'chocolate': '#d2691e', + 'coral': '#ff7f50', + 'cornflowerblue': '#6495ed', + 'cornsilk': '#fff8dc', + 'crimson': '#dc143c', + 'cyan': '#00ffff', + 'darkblue': '#00008b', + 'darkcyan': '#008b8b', + 'darkgoldenrod': '#b8860b', + 'darkgray': '#a9a9a9', + 'darkgrey': '#a9a9a9', + 'darkgreen': '#006400', + 'darkkhaki': '#bdb76b', + 'darkmagenta': '#8b008b', + 'darkolivegreen': '#556b2f', + 'darkorange': '#ff8c00', + 'darkorchid': '#9932cc', + 'darkred': '#8b0000', + 'darksalmon': '#e9967a', + 'darkseagreen': '#8fbc8f', + 'darkslateblue': '#483d8b', + 'darkslategray': '#2f4f4f', + 'darkslategrey': '#2f4f4f', + 'darkturquoise': '#00ced1', + 'darkviolet': '#9400d3', + 'deeppink': '#ff1493', + 'deepskyblue': '#00bfff', + 'dimgray': '#696969', + 'dimgrey': '#696969', + 'dodgerblue': '#1e90ff', + 'firebrick': '#b22222', + 'floralwhite': '#fffaf0', + 'forestgreen': '#228b22', + 'fuchsia': '#ff00ff', + 'gainsboro': '#dcdcdc', + 'ghostwhite': '#f8f8ff', + 'gold': '#ffd700', + 'goldenrod': '#daa520', + 'gray': '#808080', + 'grey': '#808080', + 'green': '#008000', + 'greenyellow': '#adff2f', + 'honeydew': '#f0fff0', + 'hotpink': '#ff69b4', + 'indianred': '#cd5c5c', + 'indigo': '#4b0082', + 'ivory': '#fffff0', + 'khaki': '#f0e68c', + 'lavender': '#e6e6fa', + 'lavenderblush': '#fff0f5', + 'lawngreen': '#7cfc00', + 'lemonchiffon': '#fffacd', + 'lightblue': '#add8e6', + 'lightcoral': '#f08080', + 'lightcyan': '#e0ffff', + 'lightgoldenrodyellow': '#fafad2', + 'lightgray': '#d3d3d3', + 'lightgrey': '#d3d3d3', + 'lightgreen': '#90ee90', + 'lightpink': '#ffb6c1', + 'lightsalmon': '#ffa07a', + 'lightseagreen': '#20b2aa', + 'lightskyblue': '#87cefa', + 'lightslategray': '#778899', + 'lightslategrey': '#778899', + 'lightsteelblue': '#b0c4de', + 'lightyellow': '#ffffe0', + 'lime': '#00ff00', + 'limegreen': '#32cd32', + 'linen': '#faf0e6', + 'magenta': '#ff00ff', + 'maroon': '#800000', + 'mediumaquamarine': '#66cdaa', + 'mediumblue': '#0000cd', + 'mediumorchid': '#ba55d3', + 'mediumpurple': '#9370d8', + 'mediumseagreen': '#3cb371', + 'mediumslateblue': '#7b68ee', + 'mediumspringgreen': '#00fa9a', + 'mediumturquoise': '#48d1cc', + 'mediumvioletred': '#c71585', + 'midnightblue': '#191970', + 'mintcream': '#f5fffa', + 'mistyrose': '#ffe4e1', + 'moccasin': '#ffe4b5', + 'navajowhite': '#ffdead', + 'navy': '#000080', + 'oldlace': '#fdf5e6', + 'olive': '#808000', + 'olivedrab': '#6b8e23', + 'orange': '#ffa500', + 'orangered': '#ff4500', + 'orchid': '#da70d6', + 'palegoldenrod': '#eee8aa', + 'palegreen': '#98fb98', + 'paleturquoise': '#afeeee', + 'palevioletred': '#d87093', + 'papayawhip': '#ffefd5', + 'peachpuff': '#ffdab9', + 'peru': '#cd853f', + 'pink': '#ffc0cb', + 'plum': '#dda0dd', + 'powderblue': '#b0e0e6', + 'purple': '#800080', + 'rebeccapurple': '#663399', + 'red': '#ff0000', + 'rosybrown': '#bc8f8f', + 'royalblue': '#4169e1', + 'saddlebrown': '#8b4513', + 'salmon': '#fa8072', + 'sandybrown': '#f4a460', + 'seagreen': '#2e8b57', + 'seashell': '#fff5ee', + 'sienna': '#a0522d', + 'silver': '#c0c0c0', + 'skyblue': '#87ceeb', + 'slateblue': '#6a5acd', + 'slategray': '#708090', + 'slategrey': '#708090', + 'snow': '#fffafa', + 'springgreen': '#00ff7f', + 'steelblue': '#4682b4', + 'tan': '#d2b48c', + 'teal': '#008080', + 'thistle': '#d8bfd8', + 'tomato': '#ff6347', + 'turquoise': '#40e0d0', + 'violet': '#ee82ee', + 'wheat': '#f5deb3', + 'white': '#ffffff', + 'whitesmoke': '#f5f5f5', + 'yellow': '#ffff00', + 'yellowgreen': '#9acd32' + }; - var colors = { - 'aliceblue': '#f0f8ff', - 'antiquewhite': '#faebd7', - 'aqua': '#00ffff', - 'aquamarine': '#7fffd4', - 'azure': '#f0ffff', - 'beige': '#f5f5dc', - 'bisque': '#ffe4c4', - 'black': '#000000', - 'blanchedalmond': '#ffebcd', - 'blue': '#0000ff', - 'blueviolet': '#8a2be2', - 'brown': '#a52a2a', - 'burlywood': '#deb887', - 'cadetblue': '#5f9ea0', - 'chartreuse': '#7fff00', - 'chocolate': '#d2691e', - 'coral': '#ff7f50', - 'cornflowerblue': '#6495ed', - 'cornsilk': '#fff8dc', - 'crimson': '#dc143c', - 'cyan': '#00ffff', - 'darkblue': '#00008b', - 'darkcyan': '#008b8b', - 'darkgoldenrod': '#b8860b', - 'darkgray': '#a9a9a9', - 'darkgrey': '#a9a9a9', - 'darkgreen': '#006400', - 'darkkhaki': '#bdb76b', - 'darkmagenta': '#8b008b', - 'darkolivegreen': '#556b2f', - 'darkorange': '#ff8c00', - 'darkorchid': '#9932cc', - 'darkred': '#8b0000', - 'darksalmon': '#e9967a', - 'darkseagreen': '#8fbc8f', - 'darkslateblue': '#483d8b', - 'darkslategray': '#2f4f4f', - 'darkslategrey': '#2f4f4f', - 'darkturquoise': '#00ced1', - 'darkviolet': '#9400d3', - 'deeppink': '#ff1493', - 'deepskyblue': '#00bfff', - 'dimgray': '#696969', - 'dimgrey': '#696969', - 'dodgerblue': '#1e90ff', - 'firebrick': '#b22222', - 'floralwhite': '#fffaf0', - 'forestgreen': '#228b22', - 'fuchsia': '#ff00ff', - 'gainsboro': '#dcdcdc', - 'ghostwhite': '#f8f8ff', - 'gold': '#ffd700', - 'goldenrod': '#daa520', - 'gray': '#808080', - 'grey': '#808080', - 'green': '#008000', - 'greenyellow': '#adff2f', - 'honeydew': '#f0fff0', - 'hotpink': '#ff69b4', - 'indianred': '#cd5c5c', - 'indigo': '#4b0082', - 'ivory': '#fffff0', - 'khaki': '#f0e68c', - 'lavender': '#e6e6fa', - 'lavenderblush': '#fff0f5', - 'lawngreen': '#7cfc00', - 'lemonchiffon': '#fffacd', - 'lightblue': '#add8e6', - 'lightcoral': '#f08080', - 'lightcyan': '#e0ffff', - 'lightgoldenrodyellow': '#fafad2', - 'lightgray': '#d3d3d3', - 'lightgrey': '#d3d3d3', - 'lightgreen': '#90ee90', - 'lightpink': '#ffb6c1', - 'lightsalmon': '#ffa07a', - 'lightseagreen': '#20b2aa', - 'lightskyblue': '#87cefa', - 'lightslategray': '#778899', - 'lightslategrey': '#778899', - 'lightsteelblue': '#b0c4de', - 'lightyellow': '#ffffe0', - 'lime': '#00ff00', - 'limegreen': '#32cd32', - 'linen': '#faf0e6', - 'magenta': '#ff00ff', - 'maroon': '#800000', - 'mediumaquamarine': '#66cdaa', - 'mediumblue': '#0000cd', - 'mediumorchid': '#ba55d3', - 'mediumpurple': '#9370d8', - 'mediumseagreen': '#3cb371', - 'mediumslateblue': '#7b68ee', - 'mediumspringgreen': '#00fa9a', - 'mediumturquoise': '#48d1cc', - 'mediumvioletred': '#c71585', - 'midnightblue': '#191970', - 'mintcream': '#f5fffa', - 'mistyrose': '#ffe4e1', - 'moccasin': '#ffe4b5', - 'navajowhite': '#ffdead', - 'navy': '#000080', - 'oldlace': '#fdf5e6', - 'olive': '#808000', - 'olivedrab': '#6b8e23', - 'orange': '#ffa500', - 'orangered': '#ff4500', - 'orchid': '#da70d6', - 'palegoldenrod': '#eee8aa', - 'palegreen': '#98fb98', - 'paleturquoise': '#afeeee', - 'palevioletred': '#d87093', - 'papayawhip': '#ffefd5', - 'peachpuff': '#ffdab9', - 'peru': '#cd853f', - 'pink': '#ffc0cb', - 'plum': '#dda0dd', - 'powderblue': '#b0e0e6', - 'purple': '#800080', - 'rebeccapurple': '#663399', - 'red': '#ff0000', - 'rosybrown': '#bc8f8f', - 'royalblue': '#4169e1', - 'saddlebrown': '#8b4513', - 'salmon': '#fa8072', - 'sandybrown': '#f4a460', - 'seagreen': '#2e8b57', - 'seashell': '#fff5ee', - 'sienna': '#a0522d', - 'silver': '#c0c0c0', - 'skyblue': '#87ceeb', - 'slateblue': '#6a5acd', - 'slategray': '#708090', - 'slategrey': '#708090', - 'snow': '#fffafa', - 'springgreen': '#00ff7f', - 'steelblue': '#4682b4', - 'tan': '#d2b48c', - 'teal': '#008080', - 'thistle': '#d8bfd8', - 'tomato': '#ff6347', - 'turquoise': '#40e0d0', - 'violet': '#ee82ee', - 'wheat': '#f5deb3', - 'white': '#ffffff', - 'whitesmoke': '#f5f5f5', - 'yellow': '#ffff00', - 'yellowgreen': '#9acd32' - }; + var unitConversions = { + length: { + 'm': 1, + 'cm': 0.01, + 'mm': 0.001, + 'in': 0.0254, + 'px': 0.0254 / 96, + 'pt': 0.0254 / 72, + 'pc': 0.0254 / 72 * 12 + }, + duration: { + 's': 1, + 'ms': 0.001 + }, + angle: { + 'rad': 1 / (2 * Math.PI), + 'deg': 1 / 360, + 'grad': 1 / 400, + 'turn': 1 + } + }; - var unitConversions = { - length: { - 'm': 1, - 'cm': 0.01, - 'mm': 0.001, - 'in': 0.0254, - 'px': 0.0254 / 96, - 'pt': 0.0254 / 72, - 'pc': 0.0254 / 72 * 12 - }, - duration: { - 's': 1, - 'ms': 0.001 - }, - angle: { - 'rad': 1 / (2 * Math.PI), - 'deg': 1 / 360, - 'grad': 1 / 400, - 'turn': 1 - } - }; + var data = { colors: colors, unitConversions: unitConversions }; - var data = { colors: colors, unitConversions: unitConversions }; + /** + * The reason why Node is a class and other nodes simply do not extend + * from Node (since we're transpiling) is due to this issue: + * + * https://github.com/less/less.js/issues/3434 + */ + var Node = /** @class */ (function () { + function Node() { + this.parent = null; + this.visibilityBlocks = undefined; + this.nodeVisible = undefined; + this.rootNode = null; + this.parsed = null; + var self = this; + Object.defineProperty(this, 'currentFileInfo', { + get: function () { return self.fileInfo(); } + }); + Object.defineProperty(this, 'index', { + get: function () { return self.getIndex(); } + }); + } + Node.prototype.setParent = function (nodes, parent) { + function set(node) { + if (node && node instanceof Node) { + node.parent = parent; + } + } + if (Array.isArray(nodes)) { + nodes.forEach(set); + } + else { + set(nodes); + } + }; + Node.prototype.getIndex = function () { + return this._index || (this.parent && this.parent.getIndex()) || 0; + }; + Node.prototype.fileInfo = function () { + return this._fileInfo || (this.parent && this.parent.fileInfo()) || {}; + }; + Node.prototype.isRulesetLike = function () { return false; }; + Node.prototype.toCSS = function (context) { + var strs = []; + this.genCSS(context, { + add: function (chunk, fileInfo, index) { + strs.push(chunk); + }, + isEmpty: function () { + return strs.length === 0; + } + }); + return strs.join(''); + }; + Node.prototype.genCSS = function (context, output) { + output.add(this.value); + }; + Node.prototype.accept = function (visitor) { + this.value = visitor.visit(this.value); + }; + Node.prototype.eval = function () { return this; }; + Node.prototype._operate = function (context, op, a, b) { + switch (op) { + case '+': return a + b; + case '-': return a - b; + case '*': return a * b; + case '/': return a / b; + } + }; + Node.prototype.fround = function (context, value) { + var precision = context && context.numPrecision; + // add "epsilon" to ensure numbers like 1.000000005 (represented as 1.000000004999...) are properly rounded: + return (precision) ? Number((value + 2e-16).toFixed(precision)) : value; + }; + Node.compare = function (a, b) { + /* returns: + -1: a < b + 0: a = b + 1: a > b + and *any* other value for a != b (e.g. undefined, NaN, -2 etc.) */ + if ((a.compare) && + // for "symmetric results" force toCSS-based comparison + // of Quoted or Anonymous if either value is one of those + !(b.type === 'Quoted' || b.type === 'Anonymous')) { + return a.compare(b); + } + else if (b.compare) { + return -b.compare(a); + } + else if (a.type !== b.type) { + return undefined; + } + a = a.value; + b = b.value; + if (!Array.isArray(a)) { + return a === b ? 0 : undefined; + } + if (a.length !== b.length) { + return undefined; + } + for (var i = 0; i < a.length; i++) { + if (Node.compare(a[i], b[i]) !== 0) { + return undefined; + } + } + return 0; + }; + Node.numericCompare = function (a, b) { + return a < b ? -1 + : a === b ? 0 + : a > b ? 1 : undefined; + }; + // Returns true if this node represents root of ast imported by reference + Node.prototype.blocksVisibility = function () { + if (this.visibilityBlocks == null) { + this.visibilityBlocks = 0; + } + return this.visibilityBlocks !== 0; + }; + Node.prototype.addVisibilityBlock = function () { + if (this.visibilityBlocks == null) { + this.visibilityBlocks = 0; + } + this.visibilityBlocks = this.visibilityBlocks + 1; + }; + Node.prototype.removeVisibilityBlock = function () { + if (this.visibilityBlocks == null) { + this.visibilityBlocks = 0; + } + this.visibilityBlocks = this.visibilityBlocks - 1; + }; + // Turns on node visibility - if called node will be shown in output regardless + // of whether it comes from import by reference or not + Node.prototype.ensureVisibility = function () { + this.nodeVisible = true; + }; + // Turns off node visibility - if called node will NOT be shown in output regardless + // of whether it comes from import by reference or not + Node.prototype.ensureInvisibility = function () { + this.nodeVisible = false; + }; + // return values: + // false - the node must not be visible + // true - the node must be visible + // undefined or null - the node has the same visibility as its parent + Node.prototype.isVisible = function () { + return this.nodeVisible; + }; + Node.prototype.visibilityInfo = function () { + return { + visibilityBlocks: this.visibilityBlocks, + nodeVisible: this.nodeVisible + }; + }; + Node.prototype.copyVisibilityInfo = function (info) { + if (!info) { + return; + } + this.visibilityBlocks = info.visibilityBlocks; + this.nodeVisible = info.nodeVisible; + }; + return Node; + }()); - /** - * The reason why Node is a class and other nodes simply do not extend - * from Node (since we're transpiling) is due to this issue: - * - * https://github.com/less/less.js/issues/3434 - */ - var Node = /** @class */ (function () { - function Node() { - this.parent = null; - this.visibilityBlocks = undefined; - this.nodeVisible = undefined; - this.rootNode = null; - this.parsed = null; - var self = this; - Object.defineProperty(this, 'currentFileInfo', { - get: function () { return self.fileInfo(); } - }); - Object.defineProperty(this, 'index', { - get: function () { return self.getIndex(); } - }); - } - Node.prototype.setParent = function (nodes, parent) { - function set(node) { - if (node && node instanceof Node) { - node.parent = parent; - } - } - if (Array.isArray(nodes)) { - nodes.forEach(set); - } - else { - set(nodes); - } - }; - Node.prototype.getIndex = function () { - return this._index || (this.parent && this.parent.getIndex()) || 0; - }; - Node.prototype.fileInfo = function () { - return this._fileInfo || (this.parent && this.parent.fileInfo()) || {}; - }; - Node.prototype.isRulesetLike = function () { - return false; - }; - Node.prototype.toCSS = function (context) { - var strs = []; - this.genCSS(context, { - add: function (chunk, fileInfo, index) { - strs.push(chunk); - }, - isEmpty: function () { - return strs.length === 0; - } - }); - return strs.join(''); - }; - Node.prototype.genCSS = function (context, output) { - output.add(this.value); - }; - Node.prototype.accept = function (visitor) { - this.value = visitor.visit(this.value); - }; - Node.prototype.eval = function () { return this; }; - Node.prototype._operate = function (context, op, a, b) { - switch (op) { - case '+': return a + b; - case '-': return a - b; - case '*': return a * b; - case '/': return a / b; - } - }; - Node.prototype.fround = function (context, value) { - var precision = context && context.numPrecision; - // add "epsilon" to ensure numbers like 1.000000005 (represented as 1.000000004999...) are properly rounded: - return (precision) ? Number((value + 2e-16).toFixed(precision)) : value; - }; - // Returns true if this node represents root of ast imported by reference - Node.prototype.blocksVisibility = function () { - if (this.visibilityBlocks == null) { - this.visibilityBlocks = 0; - } - return this.visibilityBlocks !== 0; - }; - Node.prototype.addVisibilityBlock = function () { - if (this.visibilityBlocks == null) { - this.visibilityBlocks = 0; - } - this.visibilityBlocks = this.visibilityBlocks + 1; - }; - Node.prototype.removeVisibilityBlock = function () { - if (this.visibilityBlocks == null) { - this.visibilityBlocks = 0; - } - this.visibilityBlocks = this.visibilityBlocks - 1; - }; - // Turns on node visibility - if called node will be shown in output regardless - // of whether it comes from import by reference or not - Node.prototype.ensureVisibility = function () { - this.nodeVisible = true; - }; - // Turns off node visibility - if called node will NOT be shown in output regardless - // of whether it comes from import by reference or not - Node.prototype.ensureInvisibility = function () { - this.nodeVisible = false; - }; - // return values: - // false - the node must not be visible - // true - the node must be visible - // undefined or null - the node has the same visibility as its parent - Node.prototype.isVisible = function () { - return this.nodeVisible; - }; - Node.prototype.visibilityInfo = function () { - return { - visibilityBlocks: this.visibilityBlocks, - nodeVisible: this.nodeVisible - }; - }; - Node.prototype.copyVisibilityInfo = function (info) { - if (!info) { - return; - } - this.visibilityBlocks = info.visibilityBlocks; - this.nodeVisible = info.nodeVisible; - }; - return Node; - }()); - Node.compare = function (a, b) { - /* returns: - -1: a < b - 0: a = b - 1: a > b - and *any* other value for a != b (e.g. undefined, NaN, -2 etc.) */ - if ((a.compare) && - // for "symmetric results" force toCSS-based comparison - // of Quoted or Anonymous if either value is one of those - !(b.type === 'Quoted' || b.type === 'Anonymous')) { - return a.compare(b); - } - else if (b.compare) { - return -b.compare(a); - } - else if (a.type !== b.type) { - return undefined; - } - a = a.value; - b = b.value; - if (!Array.isArray(a)) { - return a === b ? 0 : undefined; - } - if (a.length !== b.length) { - return undefined; - } - for (var i = 0; i < a.length; i++) { - if (Node.compare(a[i], b[i]) !== 0) { - return undefined; - } - } - return 0; - }; - Node.numericCompare = function (a, b) { return a < b ? -1 - : a === b ? 0 - : a > b ? 1 : undefined; }; + // + // RGB Colors - #ff0014, #eee + // + var Color = function (rgb, a, originalForm) { + var self = this; + // + // The end goal here, is to parse the arguments + // into an integer triplet, such as `128, 255, 0` + // + // This facilitates operations and conversions. + // + if (Array.isArray(rgb)) { + this.rgb = rgb; + } + else if (rgb.length >= 6) { + this.rgb = []; + rgb.match(/.{2}/g).map(function (c, i) { + if (i < 3) { + self.rgb.push(parseInt(c, 16)); + } + else { + self.alpha = (parseInt(c, 16)) / 255; + } + }); + } + else { + this.rgb = []; + rgb.split('').map(function (c, i) { + if (i < 3) { + self.rgb.push(parseInt(c + c, 16)); + } + else { + self.alpha = (parseInt(c + c, 16)) / 255; + } + }); + } + this.alpha = this.alpha || (typeof a === 'number' ? a : 1); + if (typeof originalForm !== 'undefined') { + this.value = originalForm; + } + }; + Color.prototype = Object.assign(new Node(), { + type: 'Color', + luma: function () { + var r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255; + r = (r <= 0.03928) ? r / 12.92 : Math.pow(((r + 0.055) / 1.055), 2.4); + g = (g <= 0.03928) ? g / 12.92 : Math.pow(((g + 0.055) / 1.055), 2.4); + b = (b <= 0.03928) ? b / 12.92 : Math.pow(((b + 0.055) / 1.055), 2.4); + return 0.2126 * r + 0.7152 * g + 0.0722 * b; + }, + genCSS: function (context, output) { + output.add(this.toCSS(context)); + }, + toCSS: function (context, doNotCompress) { + var compress = context && context.compress && !doNotCompress; + var color; + var alpha; + var colorFunction; + var args = []; + // `value` is set if this color was originally + // converted from a named color string so we need + // to respect this and try to output named color too. + alpha = this.fround(context, this.alpha); + if (this.value) { + if (this.value.indexOf('rgb') === 0) { + if (alpha < 1) { + colorFunction = 'rgba'; + } + } + else if (this.value.indexOf('hsl') === 0) { + if (alpha < 1) { + colorFunction = 'hsla'; + } + else { + colorFunction = 'hsl'; + } + } + else { + return this.value; + } + } + else { + if (alpha < 1) { + colorFunction = 'rgba'; + } + } + switch (colorFunction) { + case 'rgba': + args = this.rgb.map(function (c) { + return clamp(Math.round(c), 255); + }).concat(clamp(alpha, 1)); + break; + case 'hsla': + args.push(clamp(alpha, 1)); + case 'hsl': + color = this.toHSL(); + args = [ + this.fround(context, color.h), + this.fround(context, color.s * 100) + "%", + this.fround(context, color.l * 100) + "%" + ].concat(args); + } + if (colorFunction) { + // Values are capped between `0` and `255`, rounded and zero-padded. + return colorFunction + "(" + args.join("," + (compress ? '' : ' ')) + ")"; + } + color = this.toRGB(); + if (compress) { + var splitcolor = color.split(''); + // Convert color to short format + if (splitcolor[1] === splitcolor[2] && splitcolor[3] === splitcolor[4] && splitcolor[5] === splitcolor[6]) { + color = "#" + splitcolor[1] + splitcolor[3] + splitcolor[5]; + } + } + return color; + }, + // + // Operations have to be done per-channel, if not, + // channels will spill onto each other. Once we have + // our result, in the form of an integer triplet, + // we create a new Color node to hold the result. + // + operate: function (context, op, other) { + var rgb = new Array(3); + var alpha = this.alpha * (1 - other.alpha) + other.alpha; + for (var c = 0; c < 3; c++) { + rgb[c] = this._operate(context, op, this.rgb[c], other.rgb[c]); + } + return new Color(rgb, alpha); + }, + toRGB: function () { + return toHex(this.rgb); + }, + toHSL: function () { + var r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255, a = this.alpha; + var max = Math.max(r, g, b), min = Math.min(r, g, b); + var h; + var s; + var l = (max + min) / 2; + var d = max - min; + if (max === min) { + h = s = 0; + } + else { + s = l > 0.5 ? d / (2 - max - min) : d / (max + min); + switch (max) { + case r: + h = (g - b) / d + (g < b ? 6 : 0); + break; + case g: + h = (b - r) / d + 2; + break; + case b: + h = (r - g) / d + 4; + break; + } + h /= 6; + } + return { h: h * 360, s: s, l: l, a: a }; + }, + // Adapted from http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript + toHSV: function () { + var r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255, a = this.alpha; + var max = Math.max(r, g, b), min = Math.min(r, g, b); + var h; + var s; + var v = max; + var d = max - min; + if (max === 0) { + s = 0; + } + else { + s = d / max; + } + if (max === min) { + h = 0; + } + else { + switch (max) { + case r: + h = (g - b) / d + (g < b ? 6 : 0); + break; + case g: + h = (b - r) / d + 2; + break; + case b: + h = (r - g) / d + 4; + break; + } + h /= 6; + } + return { h: h * 360, s: s, v: v, a: a }; + }, + toARGB: function () { + return toHex([this.alpha * 255].concat(this.rgb)); + }, + compare: function (x) { + return (x.rgb && + x.rgb[0] === this.rgb[0] && + x.rgb[1] === this.rgb[1] && + x.rgb[2] === this.rgb[2] && + x.alpha === this.alpha) ? 0 : undefined; + } + }); + Color.fromKeyword = function (keyword) { + var c; + var key = keyword.toLowerCase(); + if (colors.hasOwnProperty(key)) { + c = new Color(colors[key].slice(1)); + } + else if (key === 'transparent') { + c = new Color([0, 0, 0], 0); + } + if (c) { + c.value = keyword; + return c; + } + }; + function clamp(v, max) { + return Math.min(Math.max(v, 0), max); + } + function toHex(v) { + return "#" + v.map(function (c) { + c = clamp(Math.round(c), 255); + return (c < 16 ? '0' : '') + c.toString(16); + }).join(''); + } - // - // RGB Colors - #ff0014, #eee - // - var Color = function (rgb, a, originalForm) { - var self = this; - // - // The end goal here, is to parse the arguments - // into an integer triplet, such as `128, 255, 0` - // - // This facilitates operations and conversions. - // - if (Array.isArray(rgb)) { - this.rgb = rgb; - } - else if (rgb.length >= 6) { - this.rgb = []; - rgb.match(/.{2}/g).map(function (c, i) { - if (i < 3) { - self.rgb.push(parseInt(c, 16)); - } - else { - self.alpha = (parseInt(c, 16)) / 255; - } - }); - } - else { - this.rgb = []; - rgb.split('').map(function (c, i) { - if (i < 3) { - self.rgb.push(parseInt(c + c, 16)); - } - else { - self.alpha = (parseInt(c + c, 16)) / 255; - } - }); - } - this.alpha = this.alpha || (typeof a === 'number' ? a : 1); - if (typeof originalForm !== 'undefined') { - this.value = originalForm; - } - }; - Color.prototype = new Node(); - Color.prototype.luma = function () { - var r = this.rgb[0] / 255; - var g = this.rgb[1] / 255; - var b = this.rgb[2] / 255; - r = (r <= 0.03928) ? r / 12.92 : Math.pow(((r + 0.055) / 1.055), 2.4); - g = (g <= 0.03928) ? g / 12.92 : Math.pow(((g + 0.055) / 1.055), 2.4); - b = (b <= 0.03928) ? b / 12.92 : Math.pow(((b + 0.055) / 1.055), 2.4); - return 0.2126 * r + 0.7152 * g + 0.0722 * b; - }; - Color.prototype.genCSS = function (context, output) { - output.add(this.toCSS(context)); - }; - Color.prototype.toCSS = function (context, doNotCompress) { - var compress = context && context.compress && !doNotCompress; - var color; - var alpha; - var colorFunction; - var args = []; - // `value` is set if this color was originally - // converted from a named color string so we need - // to respect this and try to output named color too. - alpha = this.fround(context, this.alpha); - if (this.value) { - if (this.value.indexOf('rgb') === 0) { - if (alpha < 1) { - colorFunction = 'rgba'; - } - } - else if (this.value.indexOf('hsl') === 0) { - if (alpha < 1) { - colorFunction = 'hsla'; - } - else { - colorFunction = 'hsl'; - } - } - else { - return this.value; - } - } - else { - if (alpha < 1) { - colorFunction = 'rgba'; - } - } - switch (colorFunction) { - case 'rgba': - args = this.rgb.map(function (c) { return clamp(Math.round(c), 255); }).concat(clamp(alpha, 1)); - break; - case 'hsla': - args.push(clamp(alpha, 1)); - case 'hsl': - color = this.toHSL(); - args = [ - this.fround(context, color.h), - this.fround(context, color.s * 100) + "%", - this.fround(context, color.l * 100) + "%" - ].concat(args); - } - if (colorFunction) { - // Values are capped between `0` and `255`, rounded and zero-padded. - return colorFunction + "(" + args.join("," + (compress ? '' : ' ')) + ")"; - } - color = this.toRGB(); - if (compress) { - var splitcolor = color.split(''); - // Convert color to short format - if (splitcolor[1] === splitcolor[2] && splitcolor[3] === splitcolor[4] && splitcolor[5] === splitcolor[6]) { - color = "#" + splitcolor[1] + splitcolor[3] + splitcolor[5]; - } - } - return color; - }; - // - // Operations have to be done per-channel, if not, - // channels will spill onto each other. Once we have - // our result, in the form of an integer triplet, - // we create a new Color node to hold the result. - // - Color.prototype.operate = function (context, op, other) { - var rgb = new Array(3); - var alpha = this.alpha * (1 - other.alpha) + other.alpha; - for (var c = 0; c < 3; c++) { - rgb[c] = this._operate(context, op, this.rgb[c], other.rgb[c]); - } - return new Color(rgb, alpha); - }; - Color.prototype.toRGB = function () { - return toHex(this.rgb); - }; - Color.prototype.toHSL = function () { - var r = this.rgb[0] / 255; - var g = this.rgb[1] / 255; - var b = this.rgb[2] / 255; - var a = this.alpha; - var max = Math.max(r, g, b); - var min = Math.min(r, g, b); - var h; - var s; - var l = (max + min) / 2; - var d = max - min; - if (max === min) { - h = s = 0; - } - else { - s = l > 0.5 ? d / (2 - max - min) : d / (max + min); - switch (max) { - case r: - h = (g - b) / d + (g < b ? 6 : 0); - break; - case g: - h = (b - r) / d + 2; - break; - case b: - h = (r - g) / d + 4; - break; - } - h /= 6; - } - return { h: h * 360, s: s, l: l, a: a }; - }; - // Adapted from http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript - Color.prototype.toHSV = function () { - var r = this.rgb[0] / 255; - var g = this.rgb[1] / 255; - var b = this.rgb[2] / 255; - var a = this.alpha; - var max = Math.max(r, g, b); - var min = Math.min(r, g, b); - var h; - var s; - var v = max; - var d = max - min; - if (max === 0) { - s = 0; - } - else { - s = d / max; - } - if (max === min) { - h = 0; - } - else { - switch (max) { - case r: - h = (g - b) / d + (g < b ? 6 : 0); - break; - case g: - h = (b - r) / d + 2; - break; - case b: - h = (r - g) / d + 4; - break; - } - h /= 6; - } - return { h: h * 360, s: s, v: v, a: a }; - }; - Color.prototype.toARGB = function () { - return toHex([this.alpha * 255].concat(this.rgb)); - }; - Color.prototype.compare = function (x) { - return (x.rgb && - x.rgb[0] === this.rgb[0] && - x.rgb[1] === this.rgb[1] && - x.rgb[2] === this.rgb[2] && - x.alpha === this.alpha) ? 0 : undefined; - }; - Color.prototype.type = 'Color'; - function clamp(v, max) { - return Math.min(Math.max(v, 0), max); - } - function toHex(v) { - return "#" + v.map(function (c) { - c = clamp(Math.round(c), 255); - return (c < 16 ? '0' : '') + c.toString(16); - }).join(''); - } - Color.fromKeyword = function (keyword) { - var c; - var key = keyword.toLowerCase(); - if (colors.hasOwnProperty(key)) { - c = new Color(colors[key].slice(1)); - } - else if (key === 'transparent') { - c = new Color([0, 0, 0], 0); - } - if (c) { - c.value = keyword; - return c; - } - }; + var Paren = function (node) { + this.value = node; + }; + Paren.prototype = Object.assign(new Node(), { + type: 'Paren', + genCSS: function (context, output) { + output.add('('); + this.value.genCSS(context, output); + output.add(')'); + }, + eval: function (context) { + return new Paren(this.value.eval(context)); + } + }); - var Paren = function (node) { - this.value = node; - }; - Paren.prototype = new Node(); - Paren.prototype.genCSS = function (context, output) { - output.add('('); - this.value.genCSS(context, output); - output.add(')'); - }; - Paren.prototype.eval = function (context) { - return new Paren(this.value.eval(context)); - }; - Paren.prototype.type = 'Paren'; + var _noSpaceCombinators = { + '': true, + ' ': true, + '|': true + }; + var Combinator = function (value) { + if (value === ' ') { + this.value = ' '; + this.emptyOrWhitespace = true; + } + else { + this.value = value ? value.trim() : ''; + this.emptyOrWhitespace = this.value === ''; + } + }; + Combinator.prototype = Object.assign(new Node(), { + type: 'Combinator', + genCSS: function (context, output) { + var spaceOrEmpty = (context.compress || _noSpaceCombinators[this.value]) ? '' : ' '; + output.add(spaceOrEmpty + this.value + spaceOrEmpty); + } + }); - var _noSpaceCombinators = { - '': true, - ' ': true, - '|': true - }; - var Combinator = function (value) { - if (value === ' ') { - this.value = ' '; - this.emptyOrWhitespace = true; - } - else { - this.value = value ? value.trim() : ''; - this.emptyOrWhitespace = this.value === ''; - } - }; - Combinator.prototype = new Node(); - Combinator.prototype.genCSS = function (context, output) { - var spaceOrEmpty = (context.compress || _noSpaceCombinators[this.value]) ? '' : ' '; - output.add(spaceOrEmpty + this.value + spaceOrEmpty); - }; - Combinator.prototype.type = 'Combinator'; + var Element = function (combinator, value, isVariable, index, currentFileInfo, visibilityInfo) { + this.combinator = combinator instanceof Combinator ? + combinator : new Combinator(combinator); + if (typeof value === 'string') { + this.value = value.trim(); + } + else if (value) { + this.value = value; + } + else { + this.value = ''; + } + this.isVariable = isVariable; + this._index = index; + this._fileInfo = currentFileInfo; + this.copyVisibilityInfo(visibilityInfo); + this.setParent(this.combinator, this); + }; + Element.prototype = Object.assign(new Node(), { + type: 'Element', + accept: function (visitor) { + var value = this.value; + this.combinator = visitor.visit(this.combinator); + if (typeof value === 'object') { + this.value = visitor.visit(value); + } + }, + eval: function (context) { + return new Element(this.combinator, this.value.eval ? this.value.eval(context) : this.value, this.isVariable, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + }, + clone: function () { + return new Element(this.combinator, this.value, this.isVariable, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + }, + genCSS: function (context, output) { + output.add(this.toCSS(context), this.fileInfo(), this.getIndex()); + }, + toCSS: function (context) { + context = context || {}; + var value = this.value; + var firstSelector = context.firstSelector; + if (value instanceof Paren) { + // selector in parens should not be affected by outer selector + // flags (breaks only interpolated selectors - see #1973) + context.firstSelector = true; + } + value = value.toCSS ? value.toCSS(context) : value; + context.firstSelector = firstSelector; + if (value === '' && this.combinator.value.charAt(0) === '&') { + return ''; + } + else { + return this.combinator.toCSS(context) + value; + } + } + }); - var Element = function (combinator, value, isVariable, index, currentFileInfo, visibilityInfo) { - this.combinator = combinator instanceof Combinator ? - combinator : new Combinator(combinator); - if (typeof value === 'string') { - this.value = value.trim(); - } - else if (value) { - this.value = value; - } - else { - this.value = ''; - } - this.isVariable = isVariable; - this._index = index; - this._fileInfo = currentFileInfo; - this.copyVisibilityInfo(visibilityInfo); - this.setParent(this.combinator, this); - }; - Element.prototype = new Node(); - Element.prototype.accept = function (visitor) { - var value = this.value; - this.combinator = visitor.visit(this.combinator); - if (typeof value === 'object') { - this.value = visitor.visit(value); - } - }; - Element.prototype.eval = function (context) { - return new Element(this.combinator, this.value.eval ? this.value.eval(context) : this.value, this.isVariable, this.getIndex(), this.fileInfo(), this.visibilityInfo()); - }; - Element.prototype.clone = function () { - return new Element(this.combinator, this.value, this.isVariable, this.getIndex(), this.fileInfo(), this.visibilityInfo()); - }; - Element.prototype.genCSS = function (context, output) { - output.add(this.toCSS(context), this.fileInfo(), this.getIndex()); - }; - Element.prototype.toCSS = function (context) { - if (context === void 0) { context = {}; } - var value = this.value; - var firstSelector = context.firstSelector; - if (value instanceof Paren) { - // selector in parens should not be affected by outer selector - // flags (breaks only interpolated selectors - see #1973) - context.firstSelector = true; - } - value = value.toCSS ? value.toCSS(context) : value; - context.firstSelector = firstSelector; - if (value === '' && this.combinator.value.charAt(0) === '&') { - return ''; - } - else { - return this.combinator.toCSS(context) + value; - } - }; - Element.prototype.type = 'Element'; + var Math$1 = { + ALWAYS: 0, + PARENS_DIVISION: 1, + PARENS: 2 + // removed - STRICT_LEGACY: 3 + }; + var RewriteUrls = { + OFF: 0, + LOCAL: 1, + ALL: 2 + }; - var Math$1 = { - ALWAYS: 0, - PARENS_DIVISION: 1, - PARENS: 2, - STRICT_LEGACY: 3 - }; - var RewriteUrls = { - OFF: 0, - LOCAL: 1, - ALL: 2 - }; + /** + * Returns the object type of the given payload + * + * @param {*} payload + * @returns {string} + */ + function getType(payload) { + return Object.prototype.toString.call(payload).slice(8, -1); + } + /** + * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes) + * + * @param {*} payload + * @returns {payload is Record} + */ + function isPlainObject(payload) { + if (getType(payload) !== 'Object') + return false; + return payload.constructor === Object && Object.getPrototypeOf(payload) === Object.prototype; + } + /** + * Returns whether the payload is an array + * + * @param {any} payload + * @returns {payload is any[]} + */ + function isArray(payload) { + return getType(payload) === 'Array'; + } - /** - * Returns the object type of the given payload - * - * @param {*} payload - * @returns {string} - */ - function getType(payload) { - return Object.prototype.toString.call(payload).slice(8, -1); - } - /** - * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes) - * - * @param {*} payload - * @returns {payload is Record} - */ - function isPlainObject(payload) { - if (getType(payload) !== 'Object') - return false; - return payload.constructor === Object && Object.getPrototypeOf(payload) === Object.prototype; - } - /** - * Returns whether the payload is an array - * - * @param {any} payload - * @returns {payload is any[]} - */ - function isArray(payload) { - return getType(payload) === 'Array'; - } + /*! ***************************************************************************** + Copyright (c) Microsoft Corporation. All rights reserved. + Licensed under the Apache License, Version 2.0 (the "License"); you may not use + this file except in compliance with the License. You may obtain a copy of the + License at http://www.apache.org/licenses/LICENSE-2.0 - /*! ***************************************************************************** - Copyright (c) Microsoft Corporation. All rights reserved. - Licensed under the Apache License, Version 2.0 (the "License"); you may not use - this file except in compliance with the License. You may obtain a copy of the - License at http://www.apache.org/licenses/LICENSE-2.0 + THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED + WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, + MERCHANTABLITY OR NON-INFRINGEMENT. - THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY - KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED - WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, - MERCHANTABLITY OR NON-INFRINGEMENT. + See the Apache Version 2.0 License for specific language governing permissions + and limitations under the License. + ***************************************************************************** */ + function __spreadArrays() { + for (var s = 0, i = 0, il = arguments.length; i < il; i++) + s += arguments[i].length; + for (var r = Array(s), k = 0, i = 0; i < il; i++) + for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) + r[k] = a[j]; + return r; + } + function assignProp(carry, key, newVal, originalObject, includeNonenumerable) { + var propType = {}.propertyIsEnumerable.call(originalObject, key) + ? 'enumerable' + : 'nonenumerable'; + if (propType === 'enumerable') + carry[key] = newVal; + if (includeNonenumerable && propType === 'nonenumerable') { + Object.defineProperty(carry, key, { + value: newVal, + enumerable: false, + writable: true, + configurable: true, + }); + } + } + /** + * Copy (clone) an object and all its props recursively to get rid of any prop referenced of the original object. Arrays are also cloned, however objects inside arrays are still linked. + * + * @export + * @template T + * @param {T} target Target can be anything + * @param {Options} [options={}] Options can be `props` or `nonenumerable` + * @returns {T} the target with replaced values + * @export + */ + function copy(target, options) { + if (options === void 0) { + options = {}; + } + if (isArray(target)) + return target.map(function (i) { return copy(i, options); }); + if (!isPlainObject(target)) + return target; + var props = Object.getOwnPropertyNames(target); + var symbols = Object.getOwnPropertySymbols(target); + return __spreadArrays(props, symbols).reduce(function (carry, key) { + if (isArray(options.props) && !options.props.includes(key)) { + return carry; + } + var val = target[key]; + var newVal = copy(val, options); + assignProp(carry, key, newVal, target, options.nonenumerable); + return carry; + }, {}); + } - See the Apache Version 2.0 License for specific language governing permissions - and limitations under the License. - ***************************************************************************** */ - function __spreadArrays$1() { - for (var s = 0, i = 0, il = arguments.length; i < il; i++) - s += arguments[i].length; - for (var r = Array(s), k = 0, i = 0; i < il; i++) - for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) - r[k] = a[j]; - return r; - } - function assignProp(carry, key, newVal, originalObject, includeNonenumerable) { - var propType = {}.propertyIsEnumerable.call(originalObject, key) - ? 'enumerable' - : 'nonenumerable'; - if (propType === 'enumerable') - carry[key] = newVal; - if (includeNonenumerable && propType === 'nonenumerable') { - Object.defineProperty(carry, key, { - value: newVal, - enumerable: false, - writable: true, - configurable: true, - }); - } - } - /** - * Copy (clone) an object and all its props recursively to get rid of any prop referenced of the original object. Arrays are also cloned, however objects inside arrays are still linked. - * - * @export - * @template T - * @param {T} target Target can be anything - * @param {Options} [options={}] Options can be `props` or `nonenumerable` - * @returns {T} the target with replaced values - * @export - */ - function copy(target, options) { - if (options === void 0) { - options = {}; - } - if (isArray(target)) - return target.map(function (i) { return copy(i, options); }); - if (!isPlainObject(target)) - return target; - var props = Object.getOwnPropertyNames(target); - var symbols = Object.getOwnPropertySymbols(target); - return __spreadArrays$1(props, symbols).reduce(function (carry, key) { - if (isArray(options.props) && !options.props.includes(key)) { - return carry; - } - var val = target[key]; - var newVal = copy(val, options); - assignProp(carry, key, newVal, target, options.nonenumerable); - return carry; - }, {}); - } + /* jshint proto: true */ + function getLocation(index, inputStream) { + var n = index + 1; + var line = null; + var column = -1; + while (--n >= 0 && inputStream.charAt(n) !== '\n') { + column++; + } + if (typeof index === 'number') { + line = (inputStream.slice(0, index).match(/\n/g) || '').length; + } + return { + line: line, + column: column + }; + } + function copyArray(arr) { + var i; + var length = arr.length; + var copy = new Array(length); + for (i = 0; i < length; i++) { + copy[i] = arr[i]; + } + return copy; + } + function clone(obj) { + var cloned = {}; + for (var prop in obj) { + if (obj.hasOwnProperty(prop)) { + cloned[prop] = obj[prop]; + } + } + return cloned; + } + function defaults(obj1, obj2) { + var newObj = obj2 || {}; + if (!obj2._defaults) { + newObj = {}; + var defaults_1 = copy(obj1); + newObj._defaults = defaults_1; + var cloned = obj2 ? copy(obj2) : {}; + Object.assign(newObj, defaults_1, cloned); + } + return newObj; + } + function copyOptions(obj1, obj2) { + if (obj2 && obj2._defaults) { + return obj2; + } + var opts = defaults(obj1, obj2); + if (opts.strictMath) { + opts.math = Math$1.PARENS; + } + // Back compat with changed relativeUrls option + if (opts.relativeUrls) { + opts.rewriteUrls = RewriteUrls.ALL; + } + if (typeof opts.math === 'string') { + switch (opts.math.toLowerCase()) { + case 'always': + opts.math = Math$1.ALWAYS; + break; + case 'parens-division': + opts.math = Math$1.PARENS_DIVISION; + break; + case 'strict': + case 'parens': + opts.math = Math$1.PARENS; + break; + default: + opts.math = Math$1.PARENS; + } + } + if (typeof opts.rewriteUrls === 'string') { + switch (opts.rewriteUrls.toLowerCase()) { + case 'off': + opts.rewriteUrls = RewriteUrls.OFF; + break; + case 'local': + opts.rewriteUrls = RewriteUrls.LOCAL; + break; + case 'all': + opts.rewriteUrls = RewriteUrls.ALL; + break; + } + } + return opts; + } + function merge(obj1, obj2) { + for (var prop in obj2) { + if (obj2.hasOwnProperty(prop)) { + obj1[prop] = obj2[prop]; + } + } + return obj1; + } + function flattenArray(arr, result) { + if (result === void 0) { result = []; } + for (var i = 0, length_1 = arr.length; i < length_1; i++) { + var value = arr[i]; + if (Array.isArray(value)) { + flattenArray(value, result); + } + else { + if (value !== undefined) { + result.push(value); + } + } + } + return result; + } - /* jshint proto: true */ - function getLocation(index, inputStream) { - var n = index + 1; - var line = null; - var column = -1; - while (--n >= 0 && inputStream.charAt(n) !== '\n') { - column++; - } - if (typeof index === 'number') { - line = (inputStream.slice(0, index).match(/\n/g) || '').length; - } - return { - line: line, - column: column - }; - } - function copyArray(arr) { - var i; - var length = arr.length; - var copy = new Array(length); - for (i = 0; i < length; i++) { - copy[i] = arr[i]; - } - return copy; - } - function clone(obj) { - var cloned = {}; - for (var prop in obj) { - if (obj.hasOwnProperty(prop)) { - cloned[prop] = obj[prop]; - } - } - return cloned; - } - function defaults(obj1, obj2) { - var newObj = obj2 || {}; - if (!obj2._defaults) { - newObj = {}; - var defaults_1 = copy(obj1); - newObj._defaults = defaults_1; - var cloned = obj2 ? copy(obj2) : {}; - Object.assign(newObj, defaults_1, cloned); - } - return newObj; - } - function copyOptions(obj1, obj2) { - if (obj2 && obj2._defaults) { - return obj2; - } - var opts = defaults(obj1, obj2); - if (opts.strictMath) { - opts.math = Math$1.STRICT_LEGACY; - } - // Back compat with changed relativeUrls option - if (opts.relativeUrls) { - opts.rewriteUrls = RewriteUrls.ALL; - } - if (typeof opts.math === 'string') { - switch (opts.math.toLowerCase()) { - case 'always': - opts.math = Math$1.ALWAYS; - break; - case 'parens-division': - opts.math = Math$1.PARENS_DIVISION; - break; - case 'strict': - case 'parens': - opts.math = Math$1.PARENS; - break; - case 'strict-legacy': - opts.math = Math$1.STRICT_LEGACY; - } - } - if (typeof opts.rewriteUrls === 'string') { - switch (opts.rewriteUrls.toLowerCase()) { - case 'off': - opts.rewriteUrls = RewriteUrls.OFF; - break; - case 'local': - opts.rewriteUrls = RewriteUrls.LOCAL; - break; - case 'all': - opts.rewriteUrls = RewriteUrls.ALL; - break; - } - } - return opts; - } - function merge(obj1, obj2) { - for (var prop in obj2) { - if (obj2.hasOwnProperty(prop)) { - obj1[prop] = obj2[prop]; - } - } - return obj1; - } - function flattenArray(arr, result) { - if (result === void 0) { result = []; } - for (var i = 0, length_1 = arr.length; i < length_1; i++) { - var value = arr[i]; - if (Array.isArray(value)) { - flattenArray(value, result); - } - else { - if (value !== undefined) { - result.push(value); - } - } - } - return result; - } + var utils = /*#__PURE__*/Object.freeze({ + __proto__: null, + getLocation: getLocation, + copyArray: copyArray, + clone: clone, + defaults: defaults, + copyOptions: copyOptions, + merge: merge, + flattenArray: flattenArray + }); - var utils = /*#__PURE__*/Object.freeze({ - __proto__: null, - getLocation: getLocation, - copyArray: copyArray, - clone: clone, - defaults: defaults, - copyOptions: copyOptions, - merge: merge, - flattenArray: flattenArray - }); + var anonymousFunc = /(|Function):(\d+):(\d+)/; + /** + * This is a centralized class of any error that could be thrown internally (mostly by the parser). + * Besides standard .message it keeps some additional data like a path to the file where the error + * occurred along with line and column numbers. + * + * @class + * @extends Error + * @type {module.LessError} + * + * @prop {string} type + * @prop {string} filename + * @prop {number} index + * @prop {number} line + * @prop {number} column + * @prop {number} callLine + * @prop {number} callExtract + * @prop {string[]} extract + * + * @param {Object} e - An error object to wrap around or just a descriptive object + * @param {Object} fileContentMap - An object with file contents in 'contents' property (like importManager) @todo - move to fileManager? + * @param {string} [currentFilename] + */ + var LessError = function (e, fileContentMap, currentFilename) { + Error.call(this); + var filename = e.filename || currentFilename; + this.message = e.message; + this.stack = e.stack; + if (fileContentMap && filename) { + var input = fileContentMap.contents[filename]; + var loc = getLocation(e.index, input); + var line = loc.line; + var col = loc.column; + var callLine = e.call && getLocation(e.call, input).line; + var lines = input ? input.split('\n') : ''; + this.type = e.type || 'Syntax'; + this.filename = filename; + this.index = e.index; + this.line = typeof line === 'number' ? line + 1 : null; + this.column = col; + if (!this.line && this.stack) { + var found = this.stack.match(anonymousFunc); + /** + * We have to figure out how this environment stringifies anonymous functions + * so we can correctly map plugin errors. + * + * Note, in Node 8, the output of anonymous funcs varied based on parameters + * being present or not, so we inject dummy params. + */ + var func = new Function('a', 'throw new Error()'); + var lineAdjust = 0; + try { + func(); + } + catch (e) { + var match = e.stack.match(anonymousFunc); + var line = parseInt(match[2]); + lineAdjust = 1 - line; + } + if (found) { + if (found[2]) { + this.line = parseInt(found[2]) + lineAdjust; + } + if (found[3]) { + this.column = parseInt(found[3]); + } + } + } + this.callLine = callLine + 1; + this.callExtract = lines[callLine]; + this.extract = [ + lines[this.line - 2], + lines[this.line - 1], + lines[this.line] + ]; + } + }; + if (typeof Object.create === 'undefined') { + var F = function () { }; + F.prototype = Error.prototype; + LessError.prototype = new F(); + } + else { + LessError.prototype = Object.create(Error.prototype); + } + LessError.prototype.constructor = LessError; + /** + * An overridden version of the default Object.prototype.toString + * which uses additional information to create a helpful message. + * + * @param {Object} options + * @returns {string} + */ + LessError.prototype.toString = function (options) { + options = options || {}; + var message = ''; + var extract = this.extract || []; + var error = []; + var stylize = function (str) { return str; }; + if (options.stylize) { + var type = typeof options.stylize; + if (type !== 'function') { + throw Error("options.stylize should be a function, got a " + type + "!"); + } + stylize = options.stylize; + } + if (this.line !== null) { + if (typeof extract[0] === 'string') { + error.push(stylize(this.line - 1 + " " + extract[0], 'grey')); + } + if (typeof extract[1] === 'string') { + var errorTxt = this.line + " "; + if (extract[1]) { + errorTxt += extract[1].slice(0, this.column) + + stylize(stylize(stylize(extract[1].substr(this.column, 1), 'bold') + + extract[1].slice(this.column + 1), 'red'), 'inverse'); + } + error.push(errorTxt); + } + if (typeof extract[2] === 'string') { + error.push(stylize(this.line + 1 + " " + extract[2], 'grey')); + } + error = error.join('\n') + stylize('', 'reset') + "\n"; + } + message += stylize(this.type + "Error: " + this.message, 'red'); + if (this.filename) { + message += stylize(' in ', 'red') + this.filename; + } + if (this.line) { + message += stylize(" on line " + this.line + ", column " + (this.column + 1) + ":", 'grey'); + } + message += "\n" + error; + if (this.callLine) { + message += stylize('from ', 'red') + (this.filename || '') + "/n"; + message += stylize(this.callLine, 'grey') + " " + this.callExtract + "/n"; + } + return message; + }; - var anonymousFunc = /(|Function):(\d+):(\d+)/; - /** - * This is a centralized class of any error that could be thrown internally (mostly by the parser). - * Besides standard .message it keeps some additional data like a path to the file where the error - * occurred along with line and column numbers. - * - * @class - * @extends Error - * @type {module.LessError} - * - * @prop {string} type - * @prop {string} filename - * @prop {number} index - * @prop {number} line - * @prop {number} column - * @prop {number} callLine - * @prop {number} callExtract - * @prop {string[]} extract - * - * @param {Object} e - An error object to wrap around or just a descriptive object - * @param {Object} fileContentMap - An object with file contents in 'contents' property (like importManager) @todo - move to fileManager? - * @param {string} [currentFilename] - */ - var LessError = function LessError(e, fileContentMap, currentFilename) { - Error.call(this); - var filename = e.filename || currentFilename; - this.message = e.message; - this.stack = e.stack; - if (fileContentMap && filename) { - var input = fileContentMap.contents[filename]; - var loc = getLocation(e.index, input); - var line = loc.line; - var col = loc.column; - var callLine = e.call && getLocation(e.call, input).line; - var lines = input ? input.split('\n') : ''; - this.type = e.type || 'Syntax'; - this.filename = filename; - this.index = e.index; - this.line = typeof line === 'number' ? line + 1 : null; - this.column = col; - if (!this.line && this.stack) { - var found = this.stack.match(anonymousFunc); - /** - * We have to figure out how this environment stringifies anonymous functions - * so we can correctly map plugin errors. - * - * Note, in Node 8, the output of anonymous funcs varied based on parameters - * being present or not, so we inject dummy params. - */ - var func = new Function('a', 'throw new Error()'); - var lineAdjust = 0; - try { - func(); - } - catch (e) { - var match = e.stack.match(anonymousFunc); - var line_1 = parseInt(match[2]); - lineAdjust = 1 - line_1; - } - if (found) { - if (found[2]) { - this.line = parseInt(found[2]) + lineAdjust; - } - if (found[3]) { - this.column = parseInt(found[3]); - } - } - } - this.callLine = callLine + 1; - this.callExtract = lines[callLine]; - this.extract = [ - lines[this.line - 2], - lines[this.line - 1], - lines[this.line] - ]; - } - }; - if (typeof Object.create === 'undefined') { - var F = function () { }; - F.prototype = Error.prototype; - LessError.prototype = new F(); - } - else { - LessError.prototype = Object.create(Error.prototype); - } - LessError.prototype.constructor = LessError; - /** - * An overridden version of the default Object.prototype.toString - * which uses additional information to create a helpful message. - * - * @param {Object} options - * @returns {string} - */ - LessError.prototype.toString = function (options) { - if (options === void 0) { options = {}; } - var message = ''; - var extract = this.extract || []; - var error = []; - var stylize = function (str) { return str; }; - if (options.stylize) { - var type = typeof options.stylize; - if (type !== 'function') { - throw Error("options.stylize should be a function, got a " + type + "!"); - } - stylize = options.stylize; - } - if (this.line !== null) { - if (typeof extract[0] === 'string') { - error.push(stylize(this.line - 1 + " " + extract[0], 'grey')); - } - if (typeof extract[1] === 'string') { - var errorTxt = this.line + " "; - if (extract[1]) { - errorTxt += extract[1].slice(0, this.column) + - stylize(stylize(stylize(extract[1].substr(this.column, 1), 'bold') + - extract[1].slice(this.column + 1), 'red'), 'inverse'); - } - error.push(errorTxt); - } - if (typeof extract[2] === 'string') { - error.push(stylize(this.line + 1 + " " + extract[2], 'grey')); - } - error = error.join('\n') + stylize('', 'reset') + "\n"; - } - message += stylize(this.type + "Error: " + this.message, 'red'); - if (this.filename) { - message += stylize(' in ', 'red') + this.filename; - } - if (this.line) { - message += stylize(" on line " + this.line + ", column " + (this.column + 1) + ":", 'grey'); - } - message += "\n" + error; - if (this.callLine) { - message += stylize('from ', 'red') + (this.filename || '') + "/n"; - message += stylize(this.callLine, 'grey') + " " + this.callExtract + "/n"; - } - return message; - }; + var Selector = function (elements, extendList, condition, index, currentFileInfo, visibilityInfo) { + this.extendList = extendList; + this.condition = condition; + this.evaldCondition = !condition; + this._index = index; + this._fileInfo = currentFileInfo; + this.elements = this.getElements(elements); + this.mixinElements_ = undefined; + this.copyVisibilityInfo(visibilityInfo); + this.setParent(this.elements, this); + }; + Selector.prototype = Object.assign(new Node(), { + type: 'Selector', + accept: function (visitor) { + if (this.elements) { + this.elements = visitor.visitArray(this.elements); + } + if (this.extendList) { + this.extendList = visitor.visitArray(this.extendList); + } + if (this.condition) { + this.condition = visitor.visit(this.condition); + } + }, + createDerived: function (elements, extendList, evaldCondition) { + elements = this.getElements(elements); + var newSelector = new Selector(elements, extendList || this.extendList, null, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + newSelector.evaldCondition = (evaldCondition != null) ? evaldCondition : this.evaldCondition; + newSelector.mediaEmpty = this.mediaEmpty; + return newSelector; + }, + getElements: function (els) { + if (!els) { + return [new Element('', '&', false, this._index, this._fileInfo)]; + } + if (typeof els === 'string') { + this.parse.parseNode(els, ['selector'], this._index, this._fileInfo, function (err, result) { + if (err) { + throw new LessError({ + index: err.index, + message: err.message + }, this.parse.imports, this._fileInfo.filename); + } + els = result[0].elements; + }); + } + return els; + }, + createEmptySelectors: function () { + var el = new Element('', '&', false, this._index, this._fileInfo), sels = [new Selector([el], null, null, this._index, this._fileInfo)]; + sels[0].mediaEmpty = true; + return sels; + }, + match: function (other) { + var elements = this.elements; + var len = elements.length; + var olen; + var i; + other = other.mixinElements(); + olen = other.length; + if (olen === 0 || len < olen) { + return 0; + } + else { + for (i = 0; i < olen; i++) { + if (elements[i].value !== other[i]) { + return 0; + } + } + } + return olen; // return number of matched elements + }, + mixinElements: function () { + if (this.mixinElements_) { + return this.mixinElements_; + } + var elements = this.elements.map(function (v) { + return v.combinator.value + (v.value.value || v.value); + }).join('').match(/[,&#\*\.\w-]([\w-]|(\\.))*/g); + if (elements) { + if (elements[0] === '&') { + elements.shift(); + } + } + else { + elements = []; + } + return (this.mixinElements_ = elements); + }, + isJustParentSelector: function () { + return !this.mediaEmpty && + this.elements.length === 1 && + this.elements[0].value === '&' && + (this.elements[0].combinator.value === ' ' || this.elements[0].combinator.value === ''); + }, + eval: function (context) { + var evaldCondition = this.condition && this.condition.eval(context); + var elements = this.elements; + var extendList = this.extendList; + elements = elements && elements.map(function (e) { return e.eval(context); }); + extendList = extendList && extendList.map(function (extend) { return extend.eval(context); }); + return this.createDerived(elements, extendList, evaldCondition); + }, + genCSS: function (context, output) { + var i, element; + if ((!context || !context.firstSelector) && this.elements[0].combinator.value === '') { + output.add(' ', this.fileInfo(), this.getIndex()); + } + for (i = 0; i < this.elements.length; i++) { + element = this.elements[i]; + element.genCSS(context, output); + } + }, + getIsOutput: function () { + return this.evaldCondition; + } + }); - var Selector = function (elements, extendList, condition, index, currentFileInfo, visibilityInfo) { - this.extendList = extendList; - this.condition = condition; - this.evaldCondition = !condition; - this._index = index; - this._fileInfo = currentFileInfo; - this.elements = this.getElements(elements); - this.mixinElements_ = undefined; - this.copyVisibilityInfo(visibilityInfo); - this.setParent(this.elements, this); - }; - Selector.prototype = new Node(); - Selector.prototype.accept = function (visitor) { - if (this.elements) { - this.elements = visitor.visitArray(this.elements); - } - if (this.extendList) { - this.extendList = visitor.visitArray(this.extendList); - } - if (this.condition) { - this.condition = visitor.visit(this.condition); - } - }; - Selector.prototype.createDerived = function (elements, extendList, evaldCondition) { - elements = this.getElements(elements); - var newSelector = new Selector(elements, extendList || this.extendList, null, this.getIndex(), this.fileInfo(), this.visibilityInfo()); - newSelector.evaldCondition = (evaldCondition != null) ? evaldCondition : this.evaldCondition; - newSelector.mediaEmpty = this.mediaEmpty; - return newSelector; - }; - Selector.prototype.getElements = function (els) { - if (!els) { - return [new Element('', '&', false, this._index, this._fileInfo)]; - } - if (typeof els === 'string') { - this.parse.parseNode(els, ['selector'], this._index, this._fileInfo, function (err, result) { - if (err) { - throw new LessError({ - index: err.index, - message: err.message - }, this.parse.imports, this._fileInfo.filename); - } - els = result[0].elements; - }); - } - return els; - }; - Selector.prototype.createEmptySelectors = function () { - var el = new Element('', '&', false, this._index, this._fileInfo); - var sels = [new Selector([el], null, null, this._index, this._fileInfo)]; - sels[0].mediaEmpty = true; - return sels; - }; - Selector.prototype.match = function (other) { - var elements = this.elements; - var len = elements.length; - var olen; - var i; - other = other.mixinElements(); - olen = other.length; - if (olen === 0 || len < olen) { - return 0; - } - else { - for (i = 0; i < olen; i++) { - if (elements[i].value !== other[i]) { - return 0; - } - } - } - return olen; // return number of matched elements - }; - Selector.prototype.mixinElements = function () { - if (this.mixinElements_) { - return this.mixinElements_; - } - var elements = this.elements.map(function (v) { return v.combinator.value + (v.value.value || v.value); }).join('').match(/[,&#\*\.\w-]([\w-]|(\\.))*/g); - if (elements) { - if (elements[0] === '&') { - elements.shift(); - } - } - else { - elements = []; - } - return (this.mixinElements_ = elements); - }; - Selector.prototype.isJustParentSelector = function () { - return !this.mediaEmpty && - this.elements.length === 1 && - this.elements[0].value === '&' && - (this.elements[0].combinator.value === ' ' || this.elements[0].combinator.value === ''); - }; - Selector.prototype.eval = function (context) { - var evaldCondition = this.condition && this.condition.eval(context); - var elements = this.elements; - var extendList = this.extendList; - elements = elements && elements.map(function (e) { return e.eval(context); }); - extendList = extendList && extendList.map(function (extend) { return extend.eval(context); }); - return this.createDerived(elements, extendList, evaldCondition); - }; - Selector.prototype.genCSS = function (context, output) { - var i; - var element; - if ((!context || !context.firstSelector) && this.elements[0].combinator.value === '') { - output.add(' ', this.fileInfo(), this.getIndex()); - } - for (i = 0; i < this.elements.length; i++) { - element = this.elements[i]; - element.genCSS(context, output); - } - }; - Selector.prototype.getIsOutput = function () { - return this.evaldCondition; - }; - Selector.prototype.type = 'Selector'; + var Value = function (value) { + if (!value) { + throw new Error('Value requires an array argument'); + } + if (!Array.isArray(value)) { + this.value = [value]; + } + else { + this.value = value; + } + }; + Value.prototype = Object.assign(new Node(), { + type: 'Value', + accept: function (visitor) { + if (this.value) { + this.value = visitor.visitArray(this.value); + } + }, + eval: function (context) { + if (this.value.length === 1) { + return this.value[0].eval(context); + } + else { + return new Value(this.value.map(function (v) { + return v.eval(context); + })); + } + }, + genCSS: function (context, output) { + var i; + for (i = 0; i < this.value.length; i++) { + this.value[i].genCSS(context, output); + if (i + 1 < this.value.length) { + output.add((context && context.compress) ? ',' : ', '); + } + } + } + }); - var Value = function (value) { - if (!value) { - throw new Error('Value requires an array argument'); - } - if (!Array.isArray(value)) { - this.value = [value]; - } - else { - this.value = value; - } - }; - Value.prototype = new Node(); - Value.prototype.accept = function (visitor) { - if (this.value) { - this.value = visitor.visitArray(this.value); - } - }; - Value.prototype.eval = function (context) { - if (this.value.length === 1) { - return this.value[0].eval(context); - } - else { - return new Value(this.value.map(function (v) { return v.eval(context); })); - } - }; - Value.prototype.genCSS = function (context, output) { - var i; - for (i = 0; i < this.value.length; i++) { - this.value[i].genCSS(context, output); - if (i + 1 < this.value.length) { - output.add((context && context.compress) ? ',' : ', '); - } - } - }; - Value.prototype.type = 'Value'; + var Keyword = function (value) { + this.value = value; + }; + Keyword.prototype = Object.assign(new Node(), { + type: 'Keyword', + genCSS: function (context, output) { + if (this.value === '%') { + throw { type: 'Syntax', message: 'Invalid % without number' }; + } + output.add(this.value); + } + }); + Keyword.True = new Keyword('true'); + Keyword.False = new Keyword('false'); - var Keyword = function (value) { - this.value = value; - }; - Keyword.prototype = new Node(); - Keyword.prototype.genCSS = function (context, output) { - if (this.value === '%') { - throw { type: 'Syntax', message: 'Invalid % without number' }; - } - output.add(this.value); - }; - Keyword.prototype.type = 'Keyword'; - Keyword.True = new Keyword('true'); - Keyword.False = new Keyword('false'); + var Anonymous = function (value, index, currentFileInfo, mapLines, rulesetLike, visibilityInfo) { + this.value = value; + this._index = index; + this._fileInfo = currentFileInfo; + this.mapLines = mapLines; + this.rulesetLike = (typeof rulesetLike === 'undefined') ? false : rulesetLike; + this.allowRoot = true; + this.copyVisibilityInfo(visibilityInfo); + }; + Anonymous.prototype = Object.assign(new Node(), { + type: 'Anonymous', + eval: function () { + return new Anonymous(this.value, this._index, this._fileInfo, this.mapLines, this.rulesetLike, this.visibilityInfo()); + }, + compare: function (other) { + return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; + }, + isRulesetLike: function () { + return this.rulesetLike; + }, + genCSS: function (context, output) { + this.nodeVisible = Boolean(this.value); + if (this.nodeVisible) { + output.add(this.value, this._fileInfo, this._index, this.mapLines); + } + } + }); - var Anonymous = function (value, index, currentFileInfo, mapLines, rulesetLike, visibilityInfo) { - this.value = value; - this._index = index; - this._fileInfo = currentFileInfo; - this.mapLines = mapLines; - this.rulesetLike = (typeof rulesetLike === 'undefined') ? false : rulesetLike; - this.allowRoot = true; - this.copyVisibilityInfo(visibilityInfo); - }; - Anonymous.prototype = new Node(); - Anonymous.prototype.eval = function () { - return new Anonymous(this.value, this._index, this._fileInfo, this.mapLines, this.rulesetLike, this.visibilityInfo()); - }; - Anonymous.prototype.compare = function (other) { - return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; - }; - Anonymous.prototype.isRulesetLike = function () { - return this.rulesetLike; - }; - Anonymous.prototype.genCSS = function (context, output) { - this.nodeVisible = Boolean(this.value); - if (this.nodeVisible) { - output.add(this.value, this._fileInfo, this._index, this.mapLines); - } - }; - Anonymous.prototype.type = 'Anonymous'; + var MATH = Math$1; + function evalName(context, name) { + var value = ''; + var i; + var n = name.length; + var output = { add: function (s) { value += s; } }; + for (i = 0; i < n; i++) { + name[i].eval(context).genCSS(context, output); + } + return value; + } + var Declaration = function (name, value, important, merge, index, currentFileInfo, inline, variable) { + this.name = name; + this.value = (value instanceof Node) ? value : new Value([value ? new Anonymous(value) : null]); + this.important = important ? " " + important.trim() : ''; + this.merge = merge; + this._index = index; + this._fileInfo = currentFileInfo; + this.inline = inline || false; + this.variable = (variable !== undefined) ? variable + : (name.charAt && (name.charAt(0) === '@')); + this.allowRoot = true; + this.setParent(this.value, this); + }; + Declaration.prototype = Object.assign(new Node(), { + type: 'Declaration', + genCSS: function (context, output) { + output.add(this.name + (context.compress ? ':' : ': '), this.fileInfo(), this.getIndex()); + try { + this.value.genCSS(context, output); + } + catch (e) { + e.index = this._index; + e.filename = this._fileInfo.filename; + throw e; + } + output.add(this.important + ((this.inline || (context.lastRule && context.compress)) ? '' : ';'), this._fileInfo, this._index); + }, + eval: function (context) { + var mathBypass = false, prevMath, name = this.name, evaldValue, variable = this.variable; + if (typeof name !== 'string') { + // expand 'primitive' name directly to get + // things faster (~10% for benchmark.less): + name = (name.length === 1) && (name[0] instanceof Keyword) ? + name[0].value : evalName(context, name); + variable = false; // never treat expanded interpolation as new variable name + } + // @todo remove when parens-division is default + if (name === 'font' && context.math === MATH.ALWAYS) { + mathBypass = true; + prevMath = context.math; + context.math = MATH.PARENS_DIVISION; + } + try { + context.importantScope.push({}); + evaldValue = this.value.eval(context); + if (!this.variable && evaldValue.type === 'DetachedRuleset') { + throw { message: 'Rulesets cannot be evaluated on a property.', + index: this.getIndex(), filename: this.fileInfo().filename }; + } + var important = this.important; + var importantResult = context.importantScope.pop(); + if (!important && importantResult.important) { + important = importantResult.important; + } + return new Declaration(name, evaldValue, important, this.merge, this.getIndex(), this.fileInfo(), this.inline, variable); + } + catch (e) { + if (typeof e.index !== 'number') { + e.index = this.getIndex(); + e.filename = this.fileInfo().filename; + } + throw e; + } + finally { + if (mathBypass) { + context.math = prevMath; + } + } + }, + makeImportant: function () { + return new Declaration(this.name, this.value, '!important', this.merge, this.getIndex(), this.fileInfo(), this.inline); + } + }); - var MATH = Math$1; - var Declaration = function (name, value, important, merge, index, currentFileInfo, inline, variable) { - this.name = name; - this.value = (value instanceof Node) ? value : new Value([value ? new Anonymous(value) : null]); - this.important = important ? " " + important.trim() : ''; - this.merge = merge; - this._index = index; - this._fileInfo = currentFileInfo; - this.inline = inline || false; - this.variable = (variable !== undefined) ? variable - : (name.charAt && (name.charAt(0) === '@')); - this.allowRoot = true; - this.setParent(this.value, this); - }; - Declaration.prototype = new Node(); - Declaration.prototype.genCSS = function (context, output) { - output.add(this.name + (context.compress ? ':' : ': '), this.fileInfo(), this.getIndex()); - try { - this.value.genCSS(context, output); - } - catch (e) { - e.index = this._index; - e.filename = this._fileInfo.filename; - throw e; - } - output.add(this.important + ((this.inline || (context.lastRule && context.compress)) ? '' : ';'), this._fileInfo, this._index); - }; - Declaration.prototype.eval = function (context) { - var mathBypass = false; - var prevMath; - var name = this.name; - var evaldValue; - var variable = this.variable; - if (typeof name !== 'string') { - // expand 'primitive' name directly to get - // things faster (~10% for benchmark.less): - name = (name.length === 1) && (name[0] instanceof Keyword) ? - name[0].value : evalName(context, name); - variable = false; // never treat expanded interpolation as new variable name - } - // @todo remove when parens-division is default - if (name === 'font' && context.math === MATH.ALWAYS) { - mathBypass = true; - prevMath = context.math; - context.math = MATH.PARENS_DIVISION; - } - try { - context.importantScope.push({}); - evaldValue = this.value.eval(context); - if (!this.variable && evaldValue.type === 'DetachedRuleset') { - throw { message: 'Rulesets cannot be evaluated on a property.', - index: this.getIndex(), filename: this.fileInfo().filename }; - } - var important = this.important; - var importantResult = context.importantScope.pop(); - if (!important && importantResult.important) { - important = importantResult.important; - } - return new Declaration(name, evaldValue, important, this.merge, this.getIndex(), this.fileInfo(), this.inline, variable); - } - catch (e) { - if (typeof e.index !== 'number') { - e.index = this.getIndex(); - e.filename = this.fileInfo().filename; - } - throw e; - } - finally { - if (mathBypass) { - context.math = prevMath; - } - } - }; - Declaration.prototype.makeImportant = function () { - return new Declaration(this.name, this.value, '!important', this.merge, this.getIndex(), this.fileInfo(), this.inline); - }; - function evalName(context, name) { - var value = ''; - var i; - var n = name.length; - var output = { add: function (s) { value += s; } }; - for (i = 0; i < n; i++) { - name[i].eval(context).genCSS(context, output); - } - return value; - } - Declaration.prototype.type = 'Declaration'; + var debugInfo = /** @class */ (function () { + function debugInfo(context, ctx, lineSeparator) { + var result = ''; + if (context.dumpLineNumbers && !context.compress) { + switch (context.dumpLineNumbers) { + case 'comments': + result = debugInfo.asComment(ctx); + break; + case 'mediaquery': + result = debugInfo.asMediaQuery(ctx); + break; + case 'all': + result = debugInfo.asComment(ctx) + (lineSeparator || '') + debugInfo.asMediaQuery(ctx); + break; + } + } + return result; + } + debugInfo.asComment = function (ctx) { + return "/* line " + ctx.debugInfo.lineNumber + ", " + ctx.debugInfo.fileName + " */\n"; + }; + debugInfo.asMediaQuery = function (ctx) { + var filenameWithProtocol = ctx.debugInfo.fileName; + if (!/^[a-z]+:\/\//i.test(filenameWithProtocol)) { + filenameWithProtocol = "file://" + filenameWithProtocol; + } + return "@media -sass-debug-info{filename{font-family:" + filenameWithProtocol.replace(/([.:\/\\])/g, function (a) { + if (a == '\\') { + a = '\/'; + } + return "\\" + a; + }) + "}line{font-family:\\00003" + ctx.debugInfo.lineNumber + "}}\n"; + }; + return debugInfo; + }()); - var debugInfo = function (context, ctx, lineSeparator) { - var result = ''; - if (context.dumpLineNumbers && !context.compress) { - switch (context.dumpLineNumbers) { - case 'comments': - result = debugInfo.asComment(ctx); - break; - case 'mediaquery': - result = debugInfo.asMediaQuery(ctx); - break; - case 'all': - result = debugInfo.asComment(ctx) + (lineSeparator || '') + debugInfo.asMediaQuery(ctx); - break; - } - } - return result; - }; - debugInfo.asComment = function (ctx) { return ctx.debugInfo ? "/* line " + ctx.debugInfo.lineNumber + ", " + ctx.debugInfo.fileName + " */\n" : ''; }; - debugInfo.asMediaQuery = function (ctx) { - if (!ctx.debugInfo) { - return ''; - } - var filenameWithProtocol = ctx.debugInfo.fileName; - if (!/^[a-z]+:\/\//i.test(filenameWithProtocol)) { - filenameWithProtocol = "file://" + filenameWithProtocol; - } - return "@media -sass-debug-info{filename{font-family:" + filenameWithProtocol.replace(/([.:\/\\])/g, function (a) { - if (a == '\\') { - a = '\/'; - } - return "\\" + a; - }) + "}line{font-family:\\00003" + ctx.debugInfo.lineNumber + "}}\n"; - }; + var Comment = function (value, isLineComment, index, currentFileInfo) { + this.value = value; + this.isLineComment = isLineComment; + this._index = index; + this._fileInfo = currentFileInfo; + this.allowRoot = true; + }; + Comment.prototype = Object.assign(new Node(), { + type: 'Comment', + genCSS: function (context, output) { + if (this.debugInfo) { + output.add(debugInfo(context, this), this.fileInfo(), this.getIndex()); + } + output.add(this.value); + }, + isSilent: function (context) { + var isCompressed = context.compress && this.value[2] !== '!'; + return this.isLineComment || isCompressed; + } + }); - var Comment = function (value, isLineComment, index, currentFileInfo) { - this.value = value; - this.isLineComment = isLineComment; - this._index = index; - this._fileInfo = currentFileInfo; - this.allowRoot = true; - }; - Comment.prototype = new Node(); - Comment.prototype.genCSS = function (context, output) { - if (this.debugInfo) { - output.add(debugInfo(context, this), this.fileInfo(), this.getIndex()); - } - output.add(this.value); - }; - Comment.prototype.isSilent = function (context) { - var isCompressed = context.compress && this.value[2] !== '!'; - return this.isLineComment || isCompressed; - }; - Comment.prototype.type = 'Comment'; + var contexts = {}; + var copyFromOriginal = function copyFromOriginal(original, destination, propertiesToCopy) { + if (!original) { + return; + } + for (var i = 0; i < propertiesToCopy.length; i++) { + if (original.hasOwnProperty(propertiesToCopy[i])) { + destination[propertiesToCopy[i]] = original[propertiesToCopy[i]]; + } + } + }; + /* + parse is used whilst parsing + */ + var parseCopyProperties = [ + // options + 'paths', + 'rewriteUrls', + 'rootpath', + 'strictImports', + 'insecure', + 'dumpLineNumbers', + 'compress', + 'syncImport', + 'chunkInput', + 'mime', + 'useFileCache', + // context + 'processImports', + // Used by the import manager to stop multiple import visitors being created. + 'pluginManager' // Used as the plugin manager for the session + ]; + contexts.Parse = function (options) { + copyFromOriginal(options, this, parseCopyProperties); + if (typeof this.paths === 'string') { + this.paths = [this.paths]; + } + }; + var evalCopyProperties = [ + 'paths', + 'compress', + 'math', + 'strictUnits', + 'sourceMap', + 'importMultiple', + 'urlArgs', + 'javascriptEnabled', + 'pluginManager', + 'importantScope', + 'rewriteUrls' // option - whether to adjust URL's to be relative + ]; + contexts.Eval = function (options, frames) { + copyFromOriginal(options, this, evalCopyProperties); + if (typeof this.paths === 'string') { + this.paths = [this.paths]; + } + this.frames = frames || []; + this.importantScope = this.importantScope || []; + }; + contexts.Eval.prototype.enterCalc = function () { + if (!this.calcStack) { + this.calcStack = []; + } + this.calcStack.push(true); + this.inCalc = true; + }; + contexts.Eval.prototype.exitCalc = function () { + this.calcStack.pop(); + if (!this.calcStack.length) { + this.inCalc = false; + } + }; + contexts.Eval.prototype.inParenthesis = function () { + if (!this.parensStack) { + this.parensStack = []; + } + this.parensStack.push(true); + }; + contexts.Eval.prototype.outOfParenthesis = function () { + this.parensStack.pop(); + }; + contexts.Eval.prototype.inCalc = false; + contexts.Eval.prototype.mathOn = true; + contexts.Eval.prototype.isMathOn = function (op) { + if (!this.mathOn) { + return false; + } + if (op === '/' && this.math !== Math$1.ALWAYS && (!this.parensStack || !this.parensStack.length)) { + return false; + } + if (this.math > Math$1.PARENS_DIVISION) { + return this.parensStack && this.parensStack.length; + } + return true; + }; + contexts.Eval.prototype.pathRequiresRewrite = function (path) { + var isRelative = this.rewriteUrls === RewriteUrls.LOCAL ? isPathLocalRelative : isPathRelative; + return isRelative(path); + }; + contexts.Eval.prototype.rewritePath = function (path, rootpath) { + var newPath; + rootpath = rootpath || ''; + newPath = this.normalizePath(rootpath + path); + // If a path was explicit relative and the rootpath was not an absolute path + // we must ensure that the new path is also explicit relative. + if (isPathLocalRelative(path) && + isPathRelative(rootpath) && + isPathLocalRelative(newPath) === false) { + newPath = "./" + newPath; + } + return newPath; + }; + contexts.Eval.prototype.normalizePath = function (path) { + var segments = path.split('/').reverse(); + var segment; + path = []; + while (segments.length !== 0) { + segment = segments.pop(); + switch (segment) { + case '.': + break; + case '..': + if ((path.length === 0) || (path[path.length - 1] === '..')) { + path.push(segment); + } + else { + path.pop(); + } + break; + default: + path.push(segment); + break; + } + } + return path.join('/'); + }; + function isPathRelative(path) { + return !/^(?:[a-z-]+:|\/|#)/i.test(path); + } + function isPathLocalRelative(path) { + return path.charAt(0) === '.'; + } + // todo - do the same for the toCSS ? - var contexts = {}; - var copyFromOriginal = function copyFromOriginal(original, destination, propertiesToCopy) { - if (!original) { - return; - } - for (var i = 0; i < propertiesToCopy.length; i++) { - if (original.hasOwnProperty(propertiesToCopy[i])) { - destination[propertiesToCopy[i]] = original[propertiesToCopy[i]]; - } - } - }; - /* - parse is used whilst parsing - */ - var parseCopyProperties = [ - // options - 'paths', - 'rewriteUrls', - 'rootpath', - 'strictImports', - 'insecure', - 'dumpLineNumbers', - 'compress', - 'syncImport', - 'chunkInput', - 'mime', - 'useFileCache', - // context - 'processImports', - // Used by the import manager to stop multiple import visitors being created. - 'pluginManager' // Used as the plugin manager for the session - ]; - contexts.Parse = function (options) { - copyFromOriginal(options, this, parseCopyProperties); - if (typeof this.paths === 'string') { - this.paths = [this.paths]; - } - }; - var evalCopyProperties = [ - 'paths', - 'compress', - 'math', - 'strictUnits', - 'sourceMap', - 'importMultiple', - 'urlArgs', - 'javascriptEnabled', - 'pluginManager', - 'importantScope', - 'rewriteUrls' // option - whether to adjust URL's to be relative - ]; - function isPathRelative(path) { - return !/^(?:[a-z-]+:|\/|#)/i.test(path); - } - function isPathLocalRelative(path) { - return path.charAt(0) === '.'; - } - contexts.Eval = /** @class */ (function () { - function Eval(options, frames) { - copyFromOriginal(options, this, evalCopyProperties); - if (typeof this.paths === 'string') { - this.paths = [this.paths]; - } - this.frames = frames || []; - this.importantScope = this.importantScope || []; - this.inCalc = false; - this.mathOn = true; - } - Eval.prototype.enterCalc = function () { - if (!this.calcStack) { - this.calcStack = []; - } - this.calcStack.push(true); - this.inCalc = true; - }; - Eval.prototype.exitCalc = function () { - this.calcStack.pop(); - if (!this.calcStack.length) { - this.inCalc = false; - } - }; - Eval.prototype.inParenthesis = function () { - if (!this.parensStack) { - this.parensStack = []; - } - this.parensStack.push(true); - }; - Eval.prototype.outOfParenthesis = function () { - this.parensStack.pop(); - }; - Eval.prototype.isMathOn = function (op) { - if (!this.mathOn) { - return false; - } - if (op === '/' && this.math !== Math$1.ALWAYS && (!this.parensStack || !this.parensStack.length)) { - return false; - } - if (this.math > Math$1.PARENS_DIVISION) { - return this.parensStack && this.parensStack.length; - } - return true; - }; - Eval.prototype.pathRequiresRewrite = function (path) { - var isRelative = this.rewriteUrls === RewriteUrls.LOCAL ? isPathLocalRelative : isPathRelative; - return isRelative(path); - }; - Eval.prototype.rewritePath = function (path, rootpath) { - var newPath; - rootpath = rootpath || ''; - newPath = this.normalizePath(rootpath + path); - // If a path was explicit relative and the rootpath was not an absolute path - // we must ensure that the new path is also explicit relative. - if (isPathLocalRelative(path) && - isPathRelative(rootpath) && - isPathLocalRelative(newPath) === false) { - newPath = "./" + newPath; - } - return newPath; - }; - Eval.prototype.normalizePath = function (path) { - var segments = path.split('/').reverse(); - var segment; - path = []; - while (segments.length !== 0) { - segment = segments.pop(); - switch (segment) { - case '.': - break; - case '..': - if ((path.length === 0) || (path[path.length - 1] === '..')) { - path.push(segment); - } - else { - path.pop(); - } - break; - default: - path.push(segment); - break; - } - } - return path.join('/'); - }; - return Eval; - }()); + function makeRegistry(base) { + return { + _data: {}, + add: function (name, func) { + // precautionary case conversion, as later querying of + // the registry by function-caller uses lower case as well. + name = name.toLowerCase(); + if (this._data.hasOwnProperty(name)) ; + this._data[name] = func; + }, + addMultiple: function (functions) { + var _this = this; + Object.keys(functions).forEach(function (name) { + _this.add(name, functions[name]); + }); + }, + get: function (name) { + return this._data[name] || (base && base.get(name)); + }, + getLocalFunctions: function () { + return this._data; + }, + inherit: function () { + return makeRegistry(this); + }, + create: function (base) { + return makeRegistry(base); + } + }; + } + var functionRegistry = makeRegistry(null); - function makeRegistry(base) { - return { - _data: {}, - add: function (name, func) { - // precautionary case conversion, as later querying of - // the registry by function-caller uses lower case as well. - name = name.toLowerCase(); - if (this._data.hasOwnProperty(name)) ; - this._data[name] = func; - }, - addMultiple: function (functions) { - var _this = this; - Object.keys(functions).forEach(function (name) { - _this.add(name, functions[name]); - }); - }, - get: function (name) { - return this._data[name] || (base && base.get(name)); - }, - getLocalFunctions: function () { - return this._data; - }, - inherit: function () { - return makeRegistry(this); - }, - create: function (base) { - return makeRegistry(base); - } - }; - } - var functionRegistry = makeRegistry(null); + var defaultFunc = { + eval: function () { + var v = this.value_; + var e = this.error_; + if (e) { + throw e; + } + if (v != null) { + return v ? Keyword.True : Keyword.False; + } + }, + value: function (v) { + this.value_ = v; + }, + error: function (e) { + this.error_ = e; + }, + reset: function () { + this.value_ = this.error_ = null; + } + }; - var defaultFunc = { - eval: function () { - var v = this.value_; - var e = this.error_; - if (e) { - throw e; - } - if (v != null) { - return v ? Keyword.True : Keyword.False; - } - }, - value: function (v) { - this.value_ = v; - }, - error: function (e) { - this.error_ = e; - }, - reset: function () { - this.value_ = this.error_ = null; - } - }; + var Ruleset = function (selectors, rules, strictImports, visibilityInfo) { + this.selectors = selectors; + this.rules = rules; + this._lookups = {}; + this._variables = null; + this._properties = null; + this.strictImports = strictImports; + this.copyVisibilityInfo(visibilityInfo); + this.allowRoot = true; + this.setParent(this.selectors, this); + this.setParent(this.rules, this); + }; + Ruleset.prototype = Object.assign(new Node(), { + type: 'Ruleset', + isRuleset: true, + isRulesetLike: function () { return true; }, + accept: function (visitor) { + if (this.paths) { + this.paths = visitor.visitArray(this.paths, true); + } + else if (this.selectors) { + this.selectors = visitor.visitArray(this.selectors); + } + if (this.rules && this.rules.length) { + this.rules = visitor.visitArray(this.rules); + } + }, + eval: function (context) { + var selectors; + var selCnt; + var selector; + var i; + var hasVariable; + var hasOnePassingSelector = false; + if (this.selectors && (selCnt = this.selectors.length)) { + selectors = new Array(selCnt); + defaultFunc.error({ + type: 'Syntax', + message: 'it is currently only allowed in parametric mixin guards,' + }); + for (i = 0; i < selCnt; i++) { + selector = this.selectors[i].eval(context); + for (var j = 0; j < selector.elements.length; j++) { + if (selector.elements[j].isVariable) { + hasVariable = true; + break; + } + } + selectors[i] = selector; + if (selector.evaldCondition) { + hasOnePassingSelector = true; + } + } + if (hasVariable) { + var toParseSelectors = new Array(selCnt); + for (i = 0; i < selCnt; i++) { + selector = selectors[i]; + toParseSelectors[i] = selector.toCSS(context); + } + this.parse.parseNode(toParseSelectors.join(','), ["selectors"], selectors[0].getIndex(), selectors[0].fileInfo(), function (err, result) { + if (result) { + selectors = flattenArray(result); + } + }); + } + defaultFunc.reset(); + } + else { + hasOnePassingSelector = true; + } + var rules = this.rules ? copyArray(this.rules) : null; + var ruleset = new Ruleset(selectors, rules, this.strictImports, this.visibilityInfo()); + var rule; + var subRule; + ruleset.originalRuleset = this; + ruleset.root = this.root; + ruleset.firstRoot = this.firstRoot; + ruleset.allowImports = this.allowImports; + if (this.debugInfo) { + ruleset.debugInfo = this.debugInfo; + } + if (!hasOnePassingSelector) { + rules.length = 0; + } + // inherit a function registry from the frames stack when possible; + // otherwise from the global registry + ruleset.functionRegistry = (function (frames) { + var i = 0; + var n = frames.length; + var found; + for (; i !== n; ++i) { + found = frames[i].functionRegistry; + if (found) { + return found; + } + } + return functionRegistry; + }(context.frames)).inherit(); + // push the current ruleset to the frames stack + var ctxFrames = context.frames; + ctxFrames.unshift(ruleset); + // currrent selectors + var ctxSelectors = context.selectors; + if (!ctxSelectors) { + context.selectors = ctxSelectors = []; + } + ctxSelectors.unshift(this.selectors); + // Evaluate imports + if (ruleset.root || ruleset.allowImports || !ruleset.strictImports) { + ruleset.evalImports(context); + } + // Store the frames around mixin definitions, + // so they can be evaluated like closures when the time comes. + var rsRules = ruleset.rules; + for (i = 0; (rule = rsRules[i]); i++) { + if (rule.evalFirst) { + rsRules[i] = rule.eval(context); + } + } + var mediaBlockCount = (context.mediaBlocks && context.mediaBlocks.length) || 0; + // Evaluate mixin calls. + for (i = 0; (rule = rsRules[i]); i++) { + if (rule.type === 'MixinCall') { + /* jshint loopfunc:true */ + rules = rule.eval(context).filter(function (r) { + if ((r instanceof Declaration) && r.variable) { + // do not pollute the scope if the variable is + // already there. consider returning false here + // but we need a way to "return" variable from mixins + return !(ruleset.variable(r.name)); + } + return true; + }); + rsRules.splice.apply(rsRules, [i, 1].concat(rules)); + i += rules.length - 1; + ruleset.resetCache(); + } + else if (rule.type === 'VariableCall') { + /* jshint loopfunc:true */ + rules = rule.eval(context).rules.filter(function (r) { + if ((r instanceof Declaration) && r.variable) { + // do not pollute the scope at all + return false; + } + return true; + }); + rsRules.splice.apply(rsRules, [i, 1].concat(rules)); + i += rules.length - 1; + ruleset.resetCache(); + } + } + // Evaluate everything else + for (i = 0; (rule = rsRules[i]); i++) { + if (!rule.evalFirst) { + rsRules[i] = rule = rule.eval ? rule.eval(context) : rule; + } + } + // Evaluate everything else + for (i = 0; (rule = rsRules[i]); i++) { + // for rulesets, check if it is a css guard and can be removed + if (rule instanceof Ruleset && rule.selectors && rule.selectors.length === 1) { + // check if it can be folded in (e.g. & where) + if (rule.selectors[0] && rule.selectors[0].isJustParentSelector()) { + rsRules.splice(i--, 1); + for (var j = 0; (subRule = rule.rules[j]); j++) { + if (subRule instanceof Node) { + subRule.copyVisibilityInfo(rule.visibilityInfo()); + if (!(subRule instanceof Declaration) || !subRule.variable) { + rsRules.splice(++i, 0, subRule); + } + } + } + } + } + } + // Pop the stack + ctxFrames.shift(); + ctxSelectors.shift(); + if (context.mediaBlocks) { + for (i = mediaBlockCount; i < context.mediaBlocks.length; i++) { + context.mediaBlocks[i].bubbleSelectors(selectors); + } + } + return ruleset; + }, + evalImports: function (context) { + var rules = this.rules; + var i; + var importRules; + if (!rules) { + return; + } + for (i = 0; i < rules.length; i++) { + if (rules[i].type === 'Import') { + importRules = rules[i].eval(context); + if (importRules && (importRules.length || importRules.length === 0)) { + rules.splice.apply(rules, [i, 1].concat(importRules)); + i += importRules.length - 1; + } + else { + rules.splice(i, 1, importRules); + } + this.resetCache(); + } + } + }, + makeImportant: function () { + var result = new Ruleset(this.selectors, this.rules.map(function (r) { + if (r.makeImportant) { + return r.makeImportant(); + } + else { + return r; + } + }), this.strictImports, this.visibilityInfo()); + return result; + }, + matchArgs: function (args) { + return !args || args.length === 0; + }, + // lets you call a css selector with a guard + matchCondition: function (args, context) { + var lastSelector = this.selectors[this.selectors.length - 1]; + if (!lastSelector.evaldCondition) { + return false; + } + if (lastSelector.condition && + !lastSelector.condition.eval(new contexts.Eval(context, context.frames))) { + return false; + } + return true; + }, + resetCache: function () { + this._rulesets = null; + this._variables = null; + this._properties = null; + this._lookups = {}; + }, + variables: function () { + if (!this._variables) { + this._variables = !this.rules ? {} : this.rules.reduce(function (hash, r) { + if (r instanceof Declaration && r.variable === true) { + hash[r.name] = r; + } + // when evaluating variables in an import statement, imports have not been eval'd + // so we need to go inside import statements. + // guard against root being a string (in the case of inlined less) + if (r.type === 'Import' && r.root && r.root.variables) { + var vars = r.root.variables(); + for (var name_1 in vars) { + if (vars.hasOwnProperty(name_1)) { + hash[name_1] = r.root.variable(name_1); + } + } + } + return hash; + }, {}); + } + return this._variables; + }, + properties: function () { + if (!this._properties) { + this._properties = !this.rules ? {} : this.rules.reduce(function (hash, r) { + if (r instanceof Declaration && r.variable !== true) { + var name_2 = (r.name.length === 1) && (r.name[0] instanceof Keyword) ? + r.name[0].value : r.name; + // Properties don't overwrite as they can merge + if (!hash["$" + name_2]) { + hash["$" + name_2] = [r]; + } + else { + hash["$" + name_2].push(r); + } + } + return hash; + }, {}); + } + return this._properties; + }, + variable: function (name) { + var decl = this.variables()[name]; + if (decl) { + return this.parseValue(decl); + } + }, + property: function (name) { + var decl = this.properties()[name]; + if (decl) { + return this.parseValue(decl); + } + }, + lastDeclaration: function () { + for (var i = this.rules.length; i > 0; i--) { + var decl = this.rules[i - 1]; + if (decl instanceof Declaration) { + return this.parseValue(decl); + } + } + }, + parseValue: function (toParse) { + var self = this; + function transformDeclaration(decl) { + if (decl.value instanceof Anonymous && !decl.parsed) { + if (typeof decl.value.value === 'string') { + this.parse.parseNode(decl.value.value, ['value', 'important'], decl.value.getIndex(), decl.fileInfo(), function (err, result) { + if (err) { + decl.parsed = true; + } + if (result) { + decl.value = result[0]; + decl.important = result[1] || ''; + decl.parsed = true; + } + }); + } + else { + decl.parsed = true; + } + return decl; + } + else { + return decl; + } + } + if (!Array.isArray(toParse)) { + return transformDeclaration.call(self, toParse); + } + else { + var nodes_1 = []; + toParse.forEach(function (n) { + nodes_1.push(transformDeclaration.call(self, n)); + }); + return nodes_1; + } + }, + rulesets: function () { + if (!this.rules) { + return []; + } + var filtRules = []; + var rules = this.rules; + var i; + var rule; + for (i = 0; (rule = rules[i]); i++) { + if (rule.isRuleset) { + filtRules.push(rule); + } + } + return filtRules; + }, + prependRule: function (rule) { + var rules = this.rules; + if (rules) { + rules.unshift(rule); + } + else { + this.rules = [rule]; + } + this.setParent(rule, this); + }, + find: function (selector, self, filter) { + self = self || this; + var rules = []; + var match; + var foundMixins; + var key = selector.toCSS(); + if (key in this._lookups) { + return this._lookups[key]; + } + this.rulesets().forEach(function (rule) { + if (rule !== self) { + for (var j = 0; j < rule.selectors.length; j++) { + match = selector.match(rule.selectors[j]); + if (match) { + if (selector.elements.length > match) { + if (!filter || filter(rule)) { + foundMixins = rule.find(new Selector(selector.elements.slice(match)), self, filter); + for (var i = 0; i < foundMixins.length; ++i) { + foundMixins[i].path.push(rule); + } + Array.prototype.push.apply(rules, foundMixins); + } + } + else { + rules.push({ rule: rule, path: [] }); + } + break; + } + } + } + }); + this._lookups[key] = rules; + return rules; + }, + genCSS: function (context, output) { + var i; + var j; + var charsetRuleNodes = []; + var ruleNodes = []; + var // Line number debugging + debugInfo$1; + var rule; + var path; + context.tabLevel = (context.tabLevel || 0); + if (!this.root) { + context.tabLevel++; + } + var tabRuleStr = context.compress ? '' : Array(context.tabLevel + 1).join(' '); + var tabSetStr = context.compress ? '' : Array(context.tabLevel).join(' '); + var sep; + var charsetNodeIndex = 0; + var importNodeIndex = 0; + for (i = 0; (rule = this.rules[i]); i++) { + if (rule instanceof Comment) { + if (importNodeIndex === i) { + importNodeIndex++; + } + ruleNodes.push(rule); + } + else if (rule.isCharset && rule.isCharset()) { + ruleNodes.splice(charsetNodeIndex, 0, rule); + charsetNodeIndex++; + importNodeIndex++; + } + else if (rule.type === 'Import') { + ruleNodes.splice(importNodeIndex, 0, rule); + importNodeIndex++; + } + else { + ruleNodes.push(rule); + } + } + ruleNodes = charsetRuleNodes.concat(ruleNodes); + // If this is the root node, we don't render + // a selector, or {}. + if (!this.root) { + debugInfo$1 = debugInfo(context, this, tabSetStr); + if (debugInfo$1) { + output.add(debugInfo$1); + output.add(tabSetStr); + } + var paths = this.paths; + var pathCnt = paths.length; + var pathSubCnt = void 0; + sep = context.compress ? ',' : (",\n" + tabSetStr); + for (i = 0; i < pathCnt; i++) { + path = paths[i]; + if (!(pathSubCnt = path.length)) { + continue; + } + if (i > 0) { + output.add(sep); + } + context.firstSelector = true; + path[0].genCSS(context, output); + context.firstSelector = false; + for (j = 1; j < pathSubCnt; j++) { + path[j].genCSS(context, output); + } + } + output.add((context.compress ? '{' : ' {\n') + tabRuleStr); + } + // Compile rules and rulesets + for (i = 0; (rule = ruleNodes[i]); i++) { + if (i + 1 === ruleNodes.length) { + context.lastRule = true; + } + var currentLastRule = context.lastRule; + if (rule.isRulesetLike(rule)) { + context.lastRule = false; + } + if (rule.genCSS) { + rule.genCSS(context, output); + } + else if (rule.value) { + output.add(rule.value.toString()); + } + context.lastRule = currentLastRule; + if (!context.lastRule && rule.isVisible()) { + output.add(context.compress ? '' : ("\n" + tabRuleStr)); + } + else { + context.lastRule = false; + } + } + if (!this.root) { + output.add((context.compress ? '}' : "\n" + tabSetStr + "}")); + context.tabLevel--; + } + if (!output.isEmpty() && !context.compress && this.firstRoot) { + output.add('\n'); + } + }, + joinSelectors: function (paths, context, selectors) { + for (var s = 0; s < selectors.length; s++) { + this.joinSelector(paths, context, selectors[s]); + } + }, + joinSelector: function (paths, context, selector) { + function createParenthesis(elementsToPak, originalElement) { + var replacementParen, j; + if (elementsToPak.length === 0) { + replacementParen = new Paren(elementsToPak[0]); + } + else { + var insideParent = new Array(elementsToPak.length); + for (j = 0; j < elementsToPak.length; j++) { + insideParent[j] = new Element(null, elementsToPak[j], originalElement.isVariable, originalElement._index, originalElement._fileInfo); + } + replacementParen = new Paren(new Selector(insideParent)); + } + return replacementParen; + } + function createSelector(containedElement, originalElement) { + var element, selector; + element = new Element(null, containedElement, originalElement.isVariable, originalElement._index, originalElement._fileInfo); + selector = new Selector([element]); + return selector; + } + // joins selector path from `beginningPath` with selector path in `addPath` + // `replacedElement` contains element that is being replaced by `addPath` + // returns concatenated path + function addReplacementIntoPath(beginningPath, addPath, replacedElement, originalSelector) { + var newSelectorPath, lastSelector, newJoinedSelector; + // our new selector path + newSelectorPath = []; + // construct the joined selector - if & is the first thing this will be empty, + // if not newJoinedSelector will be the last set of elements in the selector + if (beginningPath.length > 0) { + newSelectorPath = copyArray(beginningPath); + lastSelector = newSelectorPath.pop(); + newJoinedSelector = originalSelector.createDerived(copyArray(lastSelector.elements)); + } + else { + newJoinedSelector = originalSelector.createDerived([]); + } + if (addPath.length > 0) { + // /deep/ is a CSS4 selector - (removed, so should deprecate) + // that is valid without anything in front of it + // so if the & does not have a combinator that is "" or " " then + // and there is a combinator on the parent, then grab that. + // this also allows + a { & .b { .a & { ... though not sure why you would want to do that + var combinator = replacedElement.combinator; + var parentEl = addPath[0].elements[0]; + if (combinator.emptyOrWhitespace && !parentEl.combinator.emptyOrWhitespace) { + combinator = parentEl.combinator; + } + // join the elements so far with the first part of the parent + newJoinedSelector.elements.push(new Element(combinator, parentEl.value, replacedElement.isVariable, replacedElement._index, replacedElement._fileInfo)); + newJoinedSelector.elements = newJoinedSelector.elements.concat(addPath[0].elements.slice(1)); + } + // now add the joined selector - but only if it is not empty + if (newJoinedSelector.elements.length !== 0) { + newSelectorPath.push(newJoinedSelector); + } + // put together the parent selectors after the join (e.g. the rest of the parent) + if (addPath.length > 1) { + var restOfPath = addPath.slice(1); + restOfPath = restOfPath.map(function (selector) { + return selector.createDerived(selector.elements, []); + }); + newSelectorPath = newSelectorPath.concat(restOfPath); + } + return newSelectorPath; + } + // joins selector path from `beginningPath` with every selector path in `addPaths` array + // `replacedElement` contains element that is being replaced by `addPath` + // returns array with all concatenated paths + function addAllReplacementsIntoPath(beginningPath, addPaths, replacedElement, originalSelector, result) { + var j; + for (j = 0; j < beginningPath.length; j++) { + var newSelectorPath = addReplacementIntoPath(beginningPath[j], addPaths, replacedElement, originalSelector); + result.push(newSelectorPath); + } + return result; + } + function mergeElementsOnToSelectors(elements, selectors) { + var i, sel; + if (elements.length === 0) { + return; + } + if (selectors.length === 0) { + selectors.push([new Selector(elements)]); + return; + } + for (i = 0; (sel = selectors[i]); i++) { + // if the previous thing in sel is a parent this needs to join on to it + if (sel.length > 0) { + sel[sel.length - 1] = sel[sel.length - 1].createDerived(sel[sel.length - 1].elements.concat(elements)); + } + else { + sel.push(new Selector(elements)); + } + } + } + // replace all parent selectors inside `inSelector` by content of `context` array + // resulting selectors are returned inside `paths` array + // returns true if `inSelector` contained at least one parent selector + function replaceParentSelector(paths, context, inSelector) { + // The paths are [[Selector]] + // The first list is a list of comma separated selectors + // The inner list is a list of inheritance separated selectors + // e.g. + // .a, .b { + // .c { + // } + // } + // == [[.a] [.c]] [[.b] [.c]] + // + var i, j, k, currentElements, newSelectors, selectorsMultiplied, sel, el, hadParentSelector = false, length, lastSelector; + function findNestedSelector(element) { + var maybeSelector; + if (!(element.value instanceof Paren)) { + return null; + } + maybeSelector = element.value.value; + if (!(maybeSelector instanceof Selector)) { + return null; + } + return maybeSelector; + } + // the elements from the current selector so far + currentElements = []; + // the current list of new selectors to add to the path. + // We will build it up. We initiate it with one empty selector as we "multiply" the new selectors + // by the parents + newSelectors = [ + [] + ]; + for (i = 0; (el = inSelector.elements[i]); i++) { + // non parent reference elements just get added + if (el.value !== '&') { + var nestedSelector = findNestedSelector(el); + if (nestedSelector != null) { + // merge the current list of non parent selector elements + // on to the current list of selectors to add + mergeElementsOnToSelectors(currentElements, newSelectors); + var nestedPaths = []; + var replaced = void 0; + var replacedNewSelectors = []; + replaced = replaceParentSelector(nestedPaths, context, nestedSelector); + hadParentSelector = hadParentSelector || replaced; + // the nestedPaths array should have only one member - replaceParentSelector does not multiply selectors + for (k = 0; k < nestedPaths.length; k++) { + var replacementSelector = createSelector(createParenthesis(nestedPaths[k], el), el); + addAllReplacementsIntoPath(newSelectors, [replacementSelector], el, inSelector, replacedNewSelectors); + } + newSelectors = replacedNewSelectors; + currentElements = []; + } + else { + currentElements.push(el); + } + } + else { + hadParentSelector = true; + // the new list of selectors to add + selectorsMultiplied = []; + // merge the current list of non parent selector elements + // on to the current list of selectors to add + mergeElementsOnToSelectors(currentElements, newSelectors); + // loop through our current selectors + for (j = 0; j < newSelectors.length; j++) { + sel = newSelectors[j]; + // if we don't have any parent paths, the & might be in a mixin so that it can be used + // whether there are parents or not + if (context.length === 0) { + // the combinator used on el should now be applied to the next element instead so that + // it is not lost + if (sel.length > 0) { + sel[0].elements.push(new Element(el.combinator, '', el.isVariable, el._index, el._fileInfo)); + } + selectorsMultiplied.push(sel); + } + else { + // and the parent selectors + for (k = 0; k < context.length; k++) { + // We need to put the current selectors + // then join the last selector's elements on to the parents selectors + var newSelectorPath = addReplacementIntoPath(sel, context[k], el, inSelector); + // add that to our new set of selectors + selectorsMultiplied.push(newSelectorPath); + } + } + } + // our new selectors has been multiplied, so reset the state + newSelectors = selectorsMultiplied; + currentElements = []; + } + } + // if we have any elements left over (e.g. .a& .b == .b) + // add them on to all the current selectors + mergeElementsOnToSelectors(currentElements, newSelectors); + for (i = 0; i < newSelectors.length; i++) { + length = newSelectors[i].length; + if (length > 0) { + paths.push(newSelectors[i]); + lastSelector = newSelectors[i][length - 1]; + newSelectors[i][length - 1] = lastSelector.createDerived(lastSelector.elements, inSelector.extendList); + } + } + return hadParentSelector; + } + function deriveSelector(visibilityInfo, deriveFrom) { + var newSelector = deriveFrom.createDerived(deriveFrom.elements, deriveFrom.extendList, deriveFrom.evaldCondition); + newSelector.copyVisibilityInfo(visibilityInfo); + return newSelector; + } + // joinSelector code follows + var i, newPaths, hadParentSelector; + newPaths = []; + hadParentSelector = replaceParentSelector(newPaths, context, selector); + if (!hadParentSelector) { + if (context.length > 0) { + newPaths = []; + for (i = 0; i < context.length; i++) { + var concatenated = context[i].map(deriveSelector.bind(this, selector.visibilityInfo())); + concatenated.push(selector); + newPaths.push(concatenated); + } + } + else { + newPaths = [[selector]]; + } + } + for (i = 0; i < newPaths.length; i++) { + paths.push(newPaths[i]); + } + } + }); - var Ruleset = function (selectors, rules, strictImports, visibilityInfo) { - this.selectors = selectors; - this.rules = rules; - this._lookups = {}; - this._variables = null; - this._properties = null; - this.strictImports = strictImports; - this.copyVisibilityInfo(visibilityInfo); - this.allowRoot = true; - this.setParent(this.selectors, this); - this.setParent(this.rules, this); - }; - Ruleset.prototype = new Node(); - Ruleset.prototype.isRulesetLike = function () { - return true; - }; - Ruleset.prototype.accept = function (visitor) { - if (this.paths) { - this.paths = visitor.visitArray(this.paths, true); - } - else if (this.selectors) { - this.selectors = visitor.visitArray(this.selectors); - } - if (this.rules && this.rules.length) { - this.rules = visitor.visitArray(this.rules); - } - }; - Ruleset.prototype.eval = function (context) { - var selectors; - var selCnt; - var selector; - var i; - var hasVariable; - var hasOnePassingSelector = false; - if (this.selectors && (selCnt = this.selectors.length)) { - selectors = new Array(selCnt); - defaultFunc.error({ - type: 'Syntax', - message: 'it is currently only allowed in parametric mixin guards,' - }); - for (i = 0; i < selCnt; i++) { - selector = this.selectors[i].eval(context); - for (var j = 0; j < selector.elements.length; j++) { - if (selector.elements[j].isVariable) { - hasVariable = true; - break; - } - } - selectors[i] = selector; - if (selector.evaldCondition) { - hasOnePassingSelector = true; - } - } - if (hasVariable) { - var toParseSelectors = new Array(selCnt); - for (i = 0; i < selCnt; i++) { - selector = selectors[i]; - toParseSelectors[i] = selector.toCSS(context); - } - this.parse.parseNode(toParseSelectors.join(','), ["selectors"], selectors[0].getIndex(), selectors[0].fileInfo(), function (err, result) { - if (result) { - selectors = flattenArray(result); - } - }); - } - defaultFunc.reset(); - } - else { - hasOnePassingSelector = true; - } - var rules = this.rules ? copyArray(this.rules) : null; - var ruleset = new Ruleset(selectors, rules, this.strictImports, this.visibilityInfo()); - var rule; - var subRule; - ruleset.originalRuleset = this; - ruleset.root = this.root; - ruleset.firstRoot = this.firstRoot; - ruleset.allowImports = this.allowImports; - if (this.debugInfo) { - ruleset.debugInfo = this.debugInfo; - } - if (!hasOnePassingSelector) { - rules.length = 0; - } - // inherit a function registry from the frames stack when possible; - // otherwise from the global registry - ruleset.functionRegistry = (function (frames) { - var i = 0; - var n = frames.length; - var found; - for (; i !== n; ++i) { - found = frames[i].functionRegistry; - if (found) { - return found; - } - } - return functionRegistry; - })(context.frames).inherit(); - // push the current ruleset to the frames stack - var ctxFrames = context.frames; - ctxFrames.unshift(ruleset); - // currrent selectors - var ctxSelectors = context.selectors; - if (!ctxSelectors) { - context.selectors = ctxSelectors = []; - } - ctxSelectors.unshift(this.selectors); - // Evaluate imports - if (ruleset.root || ruleset.allowImports || !ruleset.strictImports) { - ruleset.evalImports(context); - } - // Store the frames around mixin definitions, - // so they can be evaluated like closures when the time comes. - var rsRules = ruleset.rules; - for (i = 0; (rule = rsRules[i]); i++) { - if (rule.evalFirst) { - rsRules[i] = rule.eval(context); - } - } - var mediaBlockCount = (context.mediaBlocks && context.mediaBlocks.length) || 0; - // Evaluate mixin calls. - for (i = 0; (rule = rsRules[i]); i++) { - if (rule.type === 'MixinCall') { - /* jshint loopfunc:true */ - rules = rule.eval(context).filter(function (r) { - if ((r instanceof Declaration) && r.variable) { - // do not pollute the scope if the variable is - // already there. consider returning false here - // but we need a way to "return" variable from mixins - return !(ruleset.variable(r.name)); - } - return true; - }); - rsRules.splice.apply(rsRules, [i, 1].concat(rules)); - i += rules.length - 1; - ruleset.resetCache(); - } - else if (rule.type === 'VariableCall') { - /* jshint loopfunc:true */ - rules = rule.eval(context).rules.filter(function (r) { - if ((r instanceof Declaration) && r.variable) { - // do not pollute the scope at all - return false; - } - return true; - }); - rsRules.splice.apply(rsRules, [i, 1].concat(rules)); - i += rules.length - 1; - ruleset.resetCache(); - } - } - // Evaluate everything else - for (i = 0; (rule = rsRules[i]); i++) { - if (!rule.evalFirst) { - rsRules[i] = rule = rule.eval ? rule.eval(context) : rule; - } - } - // Evaluate everything else - for (i = 0; (rule = rsRules[i]); i++) { - // for rulesets, check if it is a css guard and can be removed - if (rule instanceof Ruleset && rule.selectors && rule.selectors.length === 1) { - // check if it can be folded in (e.g. & where) - if (rule.selectors[0] && rule.selectors[0].isJustParentSelector()) { - rsRules.splice(i--, 1); - for (var j = 0; (subRule = rule.rules[j]); j++) { - if (subRule instanceof Node) { - subRule.copyVisibilityInfo(rule.visibilityInfo()); - if (!(subRule instanceof Declaration) || !subRule.variable) { - rsRules.splice(++i, 0, subRule); - } - } - } - } - } - } - // Pop the stack - ctxFrames.shift(); - ctxSelectors.shift(); - if (context.mediaBlocks) { - for (i = mediaBlockCount; i < context.mediaBlocks.length; i++) { - context.mediaBlocks[i].bubbleSelectors(selectors); - } - } - return ruleset; - }; - Ruleset.prototype.evalImports = function (context) { - var rules = this.rules; - var i; - var importRules; - if (!rules) { - return; - } - for (i = 0; i < rules.length; i++) { - if (rules[i].type === 'Import') { - importRules = rules[i].eval(context); - if (importRules && (importRules.length || importRules.length === 0)) { - rules.splice.apply(rules, [i, 1].concat(importRules)); - i += importRules.length - 1; - } - else { - rules.splice(i, 1, importRules); - } - this.resetCache(); - } - } - }; - Ruleset.prototype.makeImportant = function () { - var result = new Ruleset(this.selectors, this.rules.map(function (r) { - if (r.makeImportant) { - return r.makeImportant(); - } - else { - return r; - } - }), this.strictImports, this.visibilityInfo()); - return result; - }; - Ruleset.prototype.matchArgs = function (args) { - return !args || args.length === 0; - }; - // lets you call a css selector with a guard - Ruleset.prototype.matchCondition = function (args, context) { - var lastSelector = this.selectors[this.selectors.length - 1]; - if (!lastSelector.evaldCondition) { - return false; - } - if (lastSelector.condition && - !lastSelector.condition.eval(new contexts.Eval(context, context.frames))) { - return false; - } - return true; - }; - Ruleset.prototype.resetCache = function () { - this._rulesets = null; - this._variables = null; - this._properties = null; - this._lookups = {}; - }; - Ruleset.prototype.variables = function () { - if (!this._variables) { - this._variables = !this.rules ? {} : this.rules.reduce(function (hash, r) { - if (r instanceof Declaration && r.variable === true) { - hash[r.name] = r; - } - // when evaluating variables in an import statement, imports have not been eval'd - // so we need to go inside import statements. - // guard against root being a string (in the case of inlined less) - if (r.type === 'Import' && r.root && r.root.variables) { - var vars = r.root.variables(); - for (var name_1 in vars) { - if (vars.hasOwnProperty(name_1)) { - hash[name_1] = r.root.variable(name_1); - } - } - } - return hash; - }, {}); - } - return this._variables; - }; - Ruleset.prototype.properties = function () { - if (!this._properties) { - this._properties = !this.rules ? {} : this.rules.reduce(function (hash, r) { - if (r instanceof Declaration && r.variable !== true) { - var name_2 = (r.name.length === 1) && (r.name[0] instanceof Keyword) ? - r.name[0].value : r.name; - // Properties don't overwrite as they can merge - if (!hash["$" + name_2]) { - hash["$" + name_2] = [r]; - } - else { - hash["$" + name_2].push(r); - } - } - return hash; - }, {}); - } - return this._properties; - }; - Ruleset.prototype.variable = function (name) { - var decl = this.variables()[name]; - if (decl) { - return this.parseValue(decl); - } - }; - Ruleset.prototype.property = function (name) { - var decl = this.properties()[name]; - if (decl) { - return this.parseValue(decl); - } - }; - Ruleset.prototype.lastDeclaration = function () { - for (var i = this.rules.length; i > 0; i--) { - var decl = this.rules[i - 1]; - if (decl instanceof Declaration) { - return this.parseValue(decl); - } - } - }; - Ruleset.prototype.parseValue = function (toParse) { - var self = this; - function transformDeclaration(decl) { - if (decl.value instanceof Anonymous && !decl.parsed) { - if (typeof decl.value.value === 'string') { - this.parse.parseNode(decl.value.value, ['value', 'important'], decl.value.getIndex(), decl.fileInfo(), function (err, result) { - if (err) { - decl.parsed = true; - } - if (result) { - decl.value = result[0]; - decl.important = result[1] || ''; - decl.parsed = true; - } - }); - } - else { - decl.parsed = true; - } - return decl; - } - else { - return decl; - } - } - if (!Array.isArray(toParse)) { - return transformDeclaration.call(self, toParse); - } - else { - var nodes_1 = []; - toParse.forEach(function (n) { - nodes_1.push(transformDeclaration.call(self, n)); - }); - return nodes_1; - } - }; - Ruleset.prototype.rulesets = function () { - if (!this.rules) { - return []; - } - var filtRules = []; - var rules = this.rules; - var i; - var rule; - for (i = 0; (rule = rules[i]); i++) { - if (rule.isRuleset) { - filtRules.push(rule); - } - } - return filtRules; - }; - Ruleset.prototype.prependRule = function (rule) { - var rules = this.rules; - if (rules) { - rules.unshift(rule); - } - else { - this.rules = [rule]; - } - this.setParent(rule, this); - }; - Ruleset.prototype.find = function (selector, self, filter) { - if (self === void 0) { self = this; } - var rules = []; - var match; - var foundMixins; - var key = selector.toCSS(); - if (key in this._lookups) { - return this._lookups[key]; - } - this.rulesets().forEach(function (rule) { - if (rule !== self) { - for (var j = 0; j < rule.selectors.length; j++) { - match = selector.match(rule.selectors[j]); - if (match) { - if (selector.elements.length > match) { - if (!filter || filter(rule)) { - foundMixins = rule.find(new Selector(selector.elements.slice(match)), self, filter); - for (var i = 0; i < foundMixins.length; ++i) { - foundMixins[i].path.push(rule); - } - Array.prototype.push.apply(rules, foundMixins); - } - } - else { - rules.push({ rule: rule, path: [] }); - } - break; - } - } - } - }); - this._lookups[key] = rules; - return rules; - }; - Ruleset.prototype.genCSS = function (context, output) { - var i; - var j; - var charsetRuleNodes = []; - var ruleNodes = []; - var // Line number debugging - debugInfo$1; - var rule; - var path; - context.tabLevel = (context.tabLevel || 0); - if (!this.root) { - context.tabLevel++; - } - var tabRuleStr = context.compress ? '' : Array(context.tabLevel + 1).join(' '); - var tabSetStr = context.compress ? '' : Array(context.tabLevel).join(' '); - var sep; - var charsetNodeIndex = 0; - var importNodeIndex = 0; - for (i = 0; (rule = this.rules[i]); i++) { - if (rule instanceof Comment) { - if (importNodeIndex === i) { - importNodeIndex++; - } - ruleNodes.push(rule); - } - else if (rule.isCharset && rule.isCharset()) { - ruleNodes.splice(charsetNodeIndex, 0, rule); - charsetNodeIndex++; - importNodeIndex++; - } - else if (rule.type === 'Import') { - ruleNodes.splice(importNodeIndex, 0, rule); - importNodeIndex++; - } - else { - ruleNodes.push(rule); - } - } - ruleNodes = charsetRuleNodes.concat(ruleNodes); - // If this is the root node, we don't render - // a selector, or {}. - if (!this.root) { - debugInfo$1 = debugInfo(context, this, tabSetStr); - if (debugInfo$1) { - output.add(debugInfo$1); - output.add(tabSetStr); - } - var paths = this.paths; - var pathCnt = paths.length; - var pathSubCnt = void 0; - sep = context.compress ? ',' : (",\n" + tabSetStr); - for (i = 0; i < pathCnt; i++) { - path = paths[i]; - if (!(pathSubCnt = path.length)) { - continue; - } - if (i > 0) { - output.add(sep); - } - context.firstSelector = true; - path[0].genCSS(context, output); - context.firstSelector = false; - for (j = 1; j < pathSubCnt; j++) { - path[j].genCSS(context, output); - } - } - output.add((context.compress ? '{' : ' {\n') + tabRuleStr); - } - // Compile rules and rulesets - for (i = 0; (rule = ruleNodes[i]); i++) { - if (i + 1 === ruleNodes.length) { - context.lastRule = true; - } - var currentLastRule = context.lastRule; - if (rule.isRulesetLike(rule)) { - context.lastRule = false; - } - if (rule.genCSS) { - rule.genCSS(context, output); - } - else if (rule.value) { - output.add(rule.value.toString()); - } - context.lastRule = currentLastRule; - if (!context.lastRule && rule.isVisible()) { - output.add(context.compress ? '' : ("\n" + tabRuleStr)); - } - else { - context.lastRule = false; - } - } - if (!this.root) { - output.add((context.compress ? '}' : "\n" + tabSetStr + "}")); - context.tabLevel--; - } - if (!output.isEmpty() && !context.compress && this.firstRoot) { - output.add('\n'); - } - }; - Ruleset.prototype.joinSelectors = function (paths, context, selectors) { - for (var s = 0; s < selectors.length; s++) { - this.joinSelector(paths, context, selectors[s]); - } - }; - Ruleset.prototype.joinSelector = function (paths, context, selector) { - function createParenthesis(elementsToPak, originalElement) { - var replacementParen; - var j; - if (elementsToPak.length === 0) { - replacementParen = new Paren(elementsToPak[0]); - } - else { - var insideParent = new Array(elementsToPak.length); - for (j = 0; j < elementsToPak.length; j++) { - insideParent[j] = new Element(null, elementsToPak[j], originalElement.isVariable, originalElement._index, originalElement._fileInfo); - } - replacementParen = new Paren(new Selector(insideParent)); - } - return replacementParen; - } - function createSelector(containedElement, originalElement) { - var element; - var selector; - element = new Element(null, containedElement, originalElement.isVariable, originalElement._index, originalElement._fileInfo); - selector = new Selector([element]); - return selector; - } - // joins selector path from `beginningPath` with selector path in `addPath` - // `replacedElement` contains element that is being replaced by `addPath` - // returns concatenated path - function addReplacementIntoPath(beginningPath, addPath, replacedElement, originalSelector) { - var newSelectorPath; - var lastSelector; - var newJoinedSelector; - // our new selector path - newSelectorPath = []; - // construct the joined selector - if & is the first thing this will be empty, - // if not newJoinedSelector will be the last set of elements in the selector - if (beginningPath.length > 0) { - newSelectorPath = copyArray(beginningPath); - lastSelector = newSelectorPath.pop(); - newJoinedSelector = originalSelector.createDerived(copyArray(lastSelector.elements)); - } - else { - newJoinedSelector = originalSelector.createDerived([]); - } - if (addPath.length > 0) { - // /deep/ is a CSS4 selector - (removed, so should deprecate) - // that is valid without anything in front of it - // so if the & does not have a combinator that is "" or " " then - // and there is a combinator on the parent, then grab that. - // this also allows + a { & .b { .a & { ... though not sure why you would want to do that - var combinator = replacedElement.combinator; - var parentEl = addPath[0].elements[0]; - if (combinator.emptyOrWhitespace && !parentEl.combinator.emptyOrWhitespace) { - combinator = parentEl.combinator; - } - // join the elements so far with the first part of the parent - newJoinedSelector.elements.push(new Element(combinator, parentEl.value, replacedElement.isVariable, replacedElement._index, replacedElement._fileInfo)); - newJoinedSelector.elements = newJoinedSelector.elements.concat(addPath[0].elements.slice(1)); - } - // now add the joined selector - but only if it is not empty - if (newJoinedSelector.elements.length !== 0) { - newSelectorPath.push(newJoinedSelector); - } - // put together the parent selectors after the join (e.g. the rest of the parent) - if (addPath.length > 1) { - var restOfPath = addPath.slice(1); - restOfPath = restOfPath.map(function (selector) { return selector.createDerived(selector.elements, []); }); - newSelectorPath = newSelectorPath.concat(restOfPath); - } - return newSelectorPath; - } - // joins selector path from `beginningPath` with every selector path in `addPaths` array - // `replacedElement` contains element that is being replaced by `addPath` - // returns array with all concatenated paths - function addAllReplacementsIntoPath(beginningPath, addPaths, replacedElement, originalSelector, result) { - var j; - for (j = 0; j < beginningPath.length; j++) { - var newSelectorPath = addReplacementIntoPath(beginningPath[j], addPaths, replacedElement, originalSelector); - result.push(newSelectorPath); - } - return result; - } - function mergeElementsOnToSelectors(elements, selectors) { - var i; - var sel; - if (elements.length === 0) { - return; - } - if (selectors.length === 0) { - selectors.push([new Selector(elements)]); - return; - } - for (i = 0; (sel = selectors[i]); i++) { - // if the previous thing in sel is a parent this needs to join on to it - if (sel.length > 0) { - sel[sel.length - 1] = sel[sel.length - 1].createDerived(sel[sel.length - 1].elements.concat(elements)); - } - else { - sel.push(new Selector(elements)); - } - } - } - // replace all parent selectors inside `inSelector` by content of `context` array - // resulting selectors are returned inside `paths` array - // returns true if `inSelector` contained at least one parent selector - function replaceParentSelector(paths, context, inSelector) { - // The paths are [[Selector]] - // The first list is a list of comma separated selectors - // The inner list is a list of inheritance separated selectors - // e.g. - // .a, .b { - // .c { - // } - // } - // == [[.a] [.c]] [[.b] [.c]] - // - var i; - var j; - var k; - var currentElements; - var newSelectors; - var selectorsMultiplied; - var sel; - var el; - var hadParentSelector = false; - var length; - var lastSelector; - function findNestedSelector(element) { - var maybeSelector; - if (!(element.value instanceof Paren)) { - return null; - } - maybeSelector = element.value.value; - if (!(maybeSelector instanceof Selector)) { - return null; - } - return maybeSelector; - } - // the elements from the current selector so far - currentElements = []; - // the current list of new selectors to add to the path. - // We will build it up. We initiate it with one empty selector as we "multiply" the new selectors - // by the parents - newSelectors = [ - [] - ]; - for (i = 0; (el = inSelector.elements[i]); i++) { - // non parent reference elements just get added - if (el.value !== '&') { - var nestedSelector = findNestedSelector(el); - if (nestedSelector != null) { - // merge the current list of non parent selector elements - // on to the current list of selectors to add - mergeElementsOnToSelectors(currentElements, newSelectors); - var nestedPaths = []; - var replaced = void 0; - var replacedNewSelectors = []; - replaced = replaceParentSelector(nestedPaths, context, nestedSelector); - hadParentSelector = hadParentSelector || replaced; - // the nestedPaths array should have only one member - replaceParentSelector does not multiply selectors - for (k = 0; k < nestedPaths.length; k++) { - var replacementSelector = createSelector(createParenthesis(nestedPaths[k], el), el); - addAllReplacementsIntoPath(newSelectors, [replacementSelector], el, inSelector, replacedNewSelectors); - } - newSelectors = replacedNewSelectors; - currentElements = []; - } - else { - currentElements.push(el); - } - } - else { - hadParentSelector = true; - // the new list of selectors to add - selectorsMultiplied = []; - // merge the current list of non parent selector elements - // on to the current list of selectors to add - mergeElementsOnToSelectors(currentElements, newSelectors); - // loop through our current selectors - for (j = 0; j < newSelectors.length; j++) { - sel = newSelectors[j]; - // if we don't have any parent paths, the & might be in a mixin so that it can be used - // whether there are parents or not - if (context.length === 0) { - // the combinator used on el should now be applied to the next element instead so that - // it is not lost - if (sel.length > 0) { - sel[0].elements.push(new Element(el.combinator, '', el.isVariable, el._index, el._fileInfo)); - } - selectorsMultiplied.push(sel); - } - else { - // and the parent selectors - for (k = 0; k < context.length; k++) { - // We need to put the current selectors - // then join the last selector's elements on to the parents selectors - var newSelectorPath = addReplacementIntoPath(sel, context[k], el, inSelector); - // add that to our new set of selectors - selectorsMultiplied.push(newSelectorPath); - } - } - } - // our new selectors has been multiplied, so reset the state - newSelectors = selectorsMultiplied; - currentElements = []; - } - } - // if we have any elements left over (e.g. .a& .b == .b) - // add them on to all the current selectors - mergeElementsOnToSelectors(currentElements, newSelectors); - for (i = 0; i < newSelectors.length; i++) { - length = newSelectors[i].length; - if (length > 0) { - paths.push(newSelectors[i]); - lastSelector = newSelectors[i][length - 1]; - newSelectors[i][length - 1] = lastSelector.createDerived(lastSelector.elements, inSelector.extendList); - } - } - return hadParentSelector; - } - function deriveSelector(visibilityInfo, deriveFrom) { - var newSelector = deriveFrom.createDerived(deriveFrom.elements, deriveFrom.extendList, deriveFrom.evaldCondition); - newSelector.copyVisibilityInfo(visibilityInfo); - return newSelector; - } - // joinSelector code follows - var i; - var newPaths; - var hadParentSelector; - newPaths = []; - hadParentSelector = replaceParentSelector(newPaths, context, selector); - if (!hadParentSelector) { - if (context.length > 0) { - newPaths = []; - for (i = 0; i < context.length; i++) { - var concatenated = context[i].map(deriveSelector.bind(this, selector.visibilityInfo())); - concatenated.push(selector); - newPaths.push(concatenated); - } - } - else { - newPaths = [[selector]]; - } - } - for (i = 0; i < newPaths.length; i++) { - paths.push(newPaths[i]); - } - }; - Ruleset.prototype.type = 'Ruleset'; - Ruleset.prototype.isRuleset = true; + var AtRule = function (name, value, rules, index, currentFileInfo, debugInfo, isRooted, visibilityInfo) { + var i; + this.name = name; + this.value = (value instanceof Node) ? value : (value ? new Anonymous(value) : value); + if (rules) { + if (Array.isArray(rules)) { + this.rules = rules; + } + else { + this.rules = [rules]; + this.rules[0].selectors = (new Selector([], null, null, index, currentFileInfo)).createEmptySelectors(); + } + for (i = 0; i < this.rules.length; i++) { + this.rules[i].allowImports = true; + } + this.setParent(this.rules, this); + } + this._index = index; + this._fileInfo = currentFileInfo; + this.debugInfo = debugInfo; + this.isRooted = isRooted || false; + this.copyVisibilityInfo(visibilityInfo); + this.allowRoot = true; + }; + AtRule.prototype = Object.assign(new Node(), { + type: 'AtRule', + accept: function (visitor) { + var value = this.value, rules = this.rules; + if (rules) { + this.rules = visitor.visitArray(rules); + } + if (value) { + this.value = visitor.visit(value); + } + }, + isRulesetLike: function () { + return this.rules || !this.isCharset(); + }, + isCharset: function () { + return '@charset' === this.name; + }, + genCSS: function (context, output) { + var value = this.value, rules = this.rules; + output.add(this.name, this.fileInfo(), this.getIndex()); + if (value) { + output.add(' '); + value.genCSS(context, output); + } + if (rules) { + this.outputRuleset(context, output, rules); + } + else { + output.add(';'); + } + }, + eval: function (context) { + var mediaPathBackup, mediaBlocksBackup, value = this.value, rules = this.rules; + // media stored inside other atrule should not bubble over it + // backpup media bubbling information + mediaPathBackup = context.mediaPath; + mediaBlocksBackup = context.mediaBlocks; + // deleted media bubbling information + context.mediaPath = []; + context.mediaBlocks = []; + if (value) { + value = value.eval(context); + } + if (rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + rules = [rules[0].eval(context)]; + rules[0].root = true; + } + // restore media bubbling information + context.mediaPath = mediaPathBackup; + context.mediaBlocks = mediaBlocksBackup; + return new AtRule(this.name, value, rules, this.getIndex(), this.fileInfo(), this.debugInfo, this.isRooted, this.visibilityInfo()); + }, + variable: function (name) { + if (this.rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + return Ruleset.prototype.variable.call(this.rules[0], name); + } + }, + find: function () { + if (this.rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + return Ruleset.prototype.find.apply(this.rules[0], arguments); + } + }, + rulesets: function () { + if (this.rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + return Ruleset.prototype.rulesets.apply(this.rules[0]); + } + }, + outputRuleset: function (context, output, rules) { + var ruleCnt = rules.length; + var i; + context.tabLevel = (context.tabLevel | 0) + 1; + // Compressed + if (context.compress) { + output.add('{'); + for (i = 0; i < ruleCnt; i++) { + rules[i].genCSS(context, output); + } + output.add('}'); + context.tabLevel--; + return; + } + // Non-compressed + var tabSetStr = "\n" + Array(context.tabLevel).join(' '), tabRuleStr = tabSetStr + " "; + if (!ruleCnt) { + output.add(" {" + tabSetStr + "}"); + } + else { + output.add(" {" + tabRuleStr); + rules[0].genCSS(context, output); + for (i = 1; i < ruleCnt; i++) { + output.add(tabRuleStr); + rules[i].genCSS(context, output); + } + output.add(tabSetStr + "}"); + } + context.tabLevel--; + } + }); - var AtRule = function (name, value, rules, index, currentFileInfo, debugInfo, isRooted, visibilityInfo) { - var i; - this.name = name; - this.value = (value instanceof Node) ? value : (value ? new Anonymous(value) : value); - if (rules) { - if (Array.isArray(rules)) { - this.rules = rules; - } - else { - this.rules = [rules]; - this.rules[0].selectors = (new Selector([], null, null, index, currentFileInfo)).createEmptySelectors(); - } - for (i = 0; i < this.rules.length; i++) { - this.rules[i].allowImports = true; - } - this.setParent(this.rules, this); - } - this._index = index; - this._fileInfo = currentFileInfo; - this.debugInfo = debugInfo; - this.isRooted = isRooted || false; - this.copyVisibilityInfo(visibilityInfo); - this.allowRoot = true; - }; - AtRule.prototype = new Node(); - AtRule.prototype.accept = function (visitor) { - var value = this.value; - var rules = this.rules; - if (rules) { - this.rules = visitor.visitArray(rules); - } - if (value) { - this.value = visitor.visit(value); - } - }; - AtRule.prototype.isRulesetLike = function () { - return this.rules || !this.isCharset(); - }; - AtRule.prototype.isCharset = function () { - return '@charset' === this.name; - }; - AtRule.prototype.genCSS = function (context, output) { - var value = this.value; - var rules = this.rules; - output.add(this.name, this.fileInfo(), this.getIndex()); - if (value) { - output.add(' '); - value.genCSS(context, output); - } - if (rules) { - this.outputRuleset(context, output, rules); - } - else { - output.add(';'); - } - }; - AtRule.prototype.eval = function (context) { - var mediaPathBackup; - var mediaBlocksBackup; - var value = this.value; - var rules = this.rules; - // media stored inside other atrule should not bubble over it - // backpup media bubbling information - mediaPathBackup = context.mediaPath; - mediaBlocksBackup = context.mediaBlocks; - // deleted media bubbling information - context.mediaPath = []; - context.mediaBlocks = []; - if (value) { - value = value.eval(context); - } - if (rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - rules = [rules[0].eval(context)]; - rules[0].root = true; - } - // restore media bubbling information - context.mediaPath = mediaPathBackup; - context.mediaBlocks = mediaBlocksBackup; - return new AtRule(this.name, value, rules, this.getIndex(), this.fileInfo(), this.debugInfo, this.isRooted, this.visibilityInfo()); - }; - AtRule.prototype.variable = function (name) { - if (this.rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - return Ruleset.prototype.variable.call(this.rules[0], name); - } - }; - AtRule.prototype.find = function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - if (this.rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - return Ruleset.prototype.find.apply(this.rules[0], args); - } - }; - AtRule.prototype.rulesets = function () { - if (this.rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - return Ruleset.prototype.rulesets.apply(this.rules[0]); - } - }; - AtRule.prototype.outputRuleset = function (context, output, rules) { - var ruleCnt = rules.length; - var i; - context.tabLevel = (context.tabLevel | 0) + 1; - // Compressed - if (context.compress) { - output.add('{'); - for (i = 0; i < ruleCnt; i++) { - rules[i].genCSS(context, output); - } - output.add('}'); - context.tabLevel--; - return; - } - // Non-compressed - var tabSetStr = "\n" + Array(context.tabLevel).join(' '); - var tabRuleStr = tabSetStr + " "; - if (!ruleCnt) { - output.add(" {" + tabSetStr + "}"); - } - else { - output.add(" {" + tabRuleStr); - rules[0].genCSS(context, output); - for (i = 1; i < ruleCnt; i++) { - output.add(tabRuleStr); - rules[i].genCSS(context, output); - } - output.add(tabSetStr + "}"); - } - context.tabLevel--; - }; - AtRule.prototype.type = 'AtRule'; + var DetachedRuleset = function (ruleset, frames) { + this.ruleset = ruleset; + this.frames = frames; + this.setParent(this.ruleset, this); + }; + DetachedRuleset.prototype = Object.assign(new Node(), { + type: 'DetachedRuleset', + evalFirst: true, + accept: function (visitor) { + this.ruleset = visitor.visit(this.ruleset); + }, + eval: function (context) { + var frames = this.frames || copyArray(context.frames); + return new DetachedRuleset(this.ruleset, frames); + }, + callEval: function (context) { + return this.ruleset.eval(this.frames ? new contexts.Eval(context, this.frames.concat(context.frames)) : context); + } + }); - var DetachedRuleset = function (ruleset, frames) { - this.ruleset = ruleset; - this.frames = frames; - this.setParent(this.ruleset, this); - }; - DetachedRuleset.prototype = new Node(); - DetachedRuleset.prototype.accept = function (visitor) { - this.ruleset = visitor.visit(this.ruleset); - }; - DetachedRuleset.prototype.eval = function (context) { - var frames = this.frames || copyArray(context.frames); - return new DetachedRuleset(this.ruleset, frames); - }; - DetachedRuleset.prototype.callEval = function (context) { - return this.ruleset.eval(this.frames ? new contexts.Eval(context, this.frames.concat(context.frames)) : context); - }; - DetachedRuleset.prototype.type = 'DetachedRuleset'; - DetachedRuleset.prototype.evalFirst = true; + var Unit = function (numerator, denominator, backupUnit) { + this.numerator = numerator ? copyArray(numerator).sort() : []; + this.denominator = denominator ? copyArray(denominator).sort() : []; + if (backupUnit) { + this.backupUnit = backupUnit; + } + else if (numerator && numerator.length) { + this.backupUnit = numerator[0]; + } + }; + Unit.prototype = Object.assign(new Node(), { + type: 'Unit', + clone: function () { + return new Unit(copyArray(this.numerator), copyArray(this.denominator), this.backupUnit); + }, + genCSS: function (context, output) { + // Dimension checks the unit is singular and throws an error if in strict math mode. + var strictUnits = context && context.strictUnits; + if (this.numerator.length === 1) { + output.add(this.numerator[0]); // the ideal situation + } + else if (!strictUnits && this.backupUnit) { + output.add(this.backupUnit); + } + else if (!strictUnits && this.denominator.length) { + output.add(this.denominator[0]); + } + }, + toString: function () { + var i, returnStr = this.numerator.join('*'); + for (i = 0; i < this.denominator.length; i++) { + returnStr += "/" + this.denominator[i]; + } + return returnStr; + }, + compare: function (other) { + return this.is(other.toString()) ? 0 : undefined; + }, + is: function (unitString) { + return this.toString().toUpperCase() === unitString.toUpperCase(); + }, + isLength: function () { + return RegExp('^(px|em|ex|ch|rem|in|cm|mm|pc|pt|ex|vw|vh|vmin|vmax)$', 'gi').test(this.toCSS()); + }, + isEmpty: function () { + return this.numerator.length === 0 && this.denominator.length === 0; + }, + isSingular: function () { + return this.numerator.length <= 1 && this.denominator.length === 0; + }, + map: function (callback) { + var i; + for (i = 0; i < this.numerator.length; i++) { + this.numerator[i] = callback(this.numerator[i], false); + } + for (i = 0; i < this.denominator.length; i++) { + this.denominator[i] = callback(this.denominator[i], true); + } + }, + usedUnits: function () { + var group; + var result = {}; + var mapUnit; + var groupName; + mapUnit = function (atomicUnit) { + /* jshint loopfunc:true */ + if (group.hasOwnProperty(atomicUnit) && !result[groupName]) { + result[groupName] = atomicUnit; + } + return atomicUnit; + }; + for (groupName in unitConversions) { + if (unitConversions.hasOwnProperty(groupName)) { + group = unitConversions[groupName]; + this.map(mapUnit); + } + } + return result; + }, + cancel: function () { + var counter = {}; + var atomicUnit; + var i; + for (i = 0; i < this.numerator.length; i++) { + atomicUnit = this.numerator[i]; + counter[atomicUnit] = (counter[atomicUnit] || 0) + 1; + } + for (i = 0; i < this.denominator.length; i++) { + atomicUnit = this.denominator[i]; + counter[atomicUnit] = (counter[atomicUnit] || 0) - 1; + } + this.numerator = []; + this.denominator = []; + for (atomicUnit in counter) { + if (counter.hasOwnProperty(atomicUnit)) { + var count = counter[atomicUnit]; + if (count > 0) { + for (i = 0; i < count; i++) { + this.numerator.push(atomicUnit); + } + } + else if (count < 0) { + for (i = 0; i < -count; i++) { + this.denominator.push(atomicUnit); + } + } + } + } + this.numerator.sort(); + this.denominator.sort(); + } + }); - var Unit = function (numerator, denominator, backupUnit) { - this.numerator = numerator ? copyArray(numerator).sort() : []; - this.denominator = denominator ? copyArray(denominator).sort() : []; - if (backupUnit) { - this.backupUnit = backupUnit; - } - else if (numerator && numerator.length) { - this.backupUnit = numerator[0]; - } - }; - Unit.prototype = new Node(); - Unit.prototype.clone = function () { - return new Unit(copyArray(this.numerator), copyArray(this.denominator), this.backupUnit); - }; - Unit.prototype.genCSS = function (context, output) { - // Dimension checks the unit is singular and throws an error if in strict math mode. - var strictUnits = context && context.strictUnits; - if (this.numerator.length === 1) { - output.add(this.numerator[0]); // the ideal situation - } - else if (!strictUnits && this.backupUnit) { - output.add(this.backupUnit); - } - else if (!strictUnits && this.denominator.length) { - output.add(this.denominator[0]); - } - }; - Unit.prototype.toString = function () { - var i; - var returnStr = this.numerator.join('*'); - for (i = 0; i < this.denominator.length; i++) { - returnStr += "/" + this.denominator[i]; - } - return returnStr; - }; - Unit.prototype.compare = function (other) { - return this.is(other.toString()) ? 0 : undefined; - }; - Unit.prototype.is = function (unitString) { - return this.toString().toUpperCase() === unitString.toUpperCase(); - }; - Unit.prototype.isLength = function () { - return RegExp('^(px|em|ex|ch|rem|in|cm|mm|pc|pt|ex|vw|vh|vmin|vmax)$', 'gi').test(this.toCSS()); - }; - Unit.prototype.isEmpty = function () { - return this.numerator.length === 0 && this.denominator.length === 0; - }; - Unit.prototype.isSingular = function () { - return this.numerator.length <= 1 && this.denominator.length === 0; - }; - Unit.prototype.map = function (callback) { - var i; - for (i = 0; i < this.numerator.length; i++) { - this.numerator[i] = callback(this.numerator[i], false); - } - for (i = 0; i < this.denominator.length; i++) { - this.denominator[i] = callback(this.denominator[i], true); - } - }; - Unit.prototype.usedUnits = function () { - var group; - var result = {}; - var mapUnit; - var groupName; - mapUnit = function (atomicUnit) { - /* jshint loopfunc:true */ - if (group.hasOwnProperty(atomicUnit) && !result[groupName]) { - result[groupName] = atomicUnit; - } - return atomicUnit; - }; - for (groupName in unitConversions) { - if (unitConversions.hasOwnProperty(groupName)) { - group = unitConversions[groupName]; - this.map(mapUnit); - } - } - return result; - }; - Unit.prototype.cancel = function () { - var counter = {}; - var atomicUnit; - var i; - for (i = 0; i < this.numerator.length; i++) { - atomicUnit = this.numerator[i]; - counter[atomicUnit] = (counter[atomicUnit] || 0) + 1; - } - for (i = 0; i < this.denominator.length; i++) { - atomicUnit = this.denominator[i]; - counter[atomicUnit] = (counter[atomicUnit] || 0) - 1; - } - this.numerator = []; - this.denominator = []; - for (atomicUnit in counter) { - if (counter.hasOwnProperty(atomicUnit)) { - var count = counter[atomicUnit]; - if (count > 0) { - for (i = 0; i < count; i++) { - this.numerator.push(atomicUnit); - } - } - else if (count < 0) { - for (i = 0; i < -count; i++) { - this.denominator.push(atomicUnit); - } - } - } - } - this.numerator.sort(); - this.denominator.sort(); - }; - Unit.prototype.type = 'Unit'; + // + // A number with a unit + // + var Dimension = function (value, unit) { + this.value = parseFloat(value); + if (isNaN(this.value)) { + throw new Error('Dimension is not a number.'); + } + this.unit = (unit && unit instanceof Unit) ? unit : + new Unit(unit ? [unit] : undefined); + this.setParent(this.unit, this); + }; + Dimension.prototype = Object.assign(new Node(), { + type: 'Dimension', + accept: function (visitor) { + this.unit = visitor.visit(this.unit); + }, + eval: function (context) { + return this; + }, + toColor: function () { + return new Color([this.value, this.value, this.value]); + }, + genCSS: function (context, output) { + if ((context && context.strictUnits) && !this.unit.isSingular()) { + throw new Error("Multiple units in dimension. Correct the units or use the unit function. Bad unit: " + this.unit.toString()); + } + var value = this.fround(context, this.value); + var strValue = String(value); + if (value !== 0 && value < 0.000001 && value > -0.000001) { + // would be output 1e-6 etc. + strValue = value.toFixed(20).replace(/0+$/, ''); + } + if (context && context.compress) { + // Zero values doesn't need a unit + if (value === 0 && this.unit.isLength()) { + output.add(strValue); + return; + } + // Float values doesn't need a leading zero + if (value > 0 && value < 1) { + strValue = (strValue).substr(1); + } + } + output.add(strValue); + this.unit.genCSS(context, output); + }, + // In an operation between two Dimensions, + // we default to the first Dimension's unit, + // so `1px + 2` will yield `3px`. + operate: function (context, op, other) { + /* jshint noempty:false */ + var value = this._operate(context, op, this.value, other.value), unit = this.unit.clone(); + if (op === '+' || op === '-') { + if (unit.numerator.length === 0 && unit.denominator.length === 0) { + unit = other.unit.clone(); + if (this.unit.backupUnit) { + unit.backupUnit = this.unit.backupUnit; + } + } + else if (other.unit.numerator.length === 0 && unit.denominator.length === 0) ; + else { + other = other.convertTo(this.unit.usedUnits()); + if (context.strictUnits && other.unit.toString() !== unit.toString()) { + throw new Error("Incompatible units. Change the units or use the unit function. " + + ("Bad units: '" + unit.toString() + "' and '" + other.unit.toString() + "'.")); + } + value = this._operate(context, op, this.value, other.value); + } + } + else if (op === '*') { + unit.numerator = unit.numerator.concat(other.unit.numerator).sort(); + unit.denominator = unit.denominator.concat(other.unit.denominator).sort(); + unit.cancel(); + } + else if (op === '/') { + unit.numerator = unit.numerator.concat(other.unit.denominator).sort(); + unit.denominator = unit.denominator.concat(other.unit.numerator).sort(); + unit.cancel(); + } + return new Dimension(value, unit); + }, + compare: function (other) { + var a, b; + if (!(other instanceof Dimension)) { + return undefined; + } + if (this.unit.isEmpty() || other.unit.isEmpty()) { + a = this; + b = other; + } + else { + a = this.unify(); + b = other.unify(); + if (a.unit.compare(b.unit) !== 0) { + return undefined; + } + } + return Node.numericCompare(a.value, b.value); + }, + unify: function () { + return this.convertTo({ length: 'px', duration: 's', angle: 'rad' }); + }, + convertTo: function (conversions) { + var value = this.value; + var unit = this.unit.clone(); + var i; + var groupName; + var group; + var targetUnit; + var derivedConversions = {}; + var applyUnit; + if (typeof conversions === 'string') { + for (i in unitConversions) { + if (unitConversions[i].hasOwnProperty(conversions)) { + derivedConversions = {}; + derivedConversions[i] = conversions; + } + } + conversions = derivedConversions; + } + applyUnit = function (atomicUnit, denominator) { + /* jshint loopfunc:true */ + if (group.hasOwnProperty(atomicUnit)) { + if (denominator) { + value = value / (group[atomicUnit] / group[targetUnit]); + } + else { + value = value * (group[atomicUnit] / group[targetUnit]); + } + return targetUnit; + } + return atomicUnit; + }; + for (groupName in conversions) { + if (conversions.hasOwnProperty(groupName)) { + targetUnit = conversions[groupName]; + group = unitConversions[groupName]; + unit.map(applyUnit); + } + } + unit.cancel(); + return new Dimension(value, unit); + } + }); - // - // A number with a unit - // - var Dimension = function (value, unit) { - this.value = parseFloat(value); - if (isNaN(this.value)) { - throw new Error('Dimension is not a number.'); - } - this.unit = (unit && unit instanceof Unit) ? unit : - new Unit(unit ? [unit] : undefined); - this.setParent(this.unit, this); - }; - Dimension.prototype = new Node(); - Dimension.prototype.accept = function (visitor) { - this.unit = visitor.visit(this.unit); - }; - Dimension.prototype.eval = function (context) { - return this; - }; - Dimension.prototype.toColor = function () { - return new Color([this.value, this.value, this.value]); - }; - Dimension.prototype.genCSS = function (context, output) { - if ((context && context.strictUnits) && !this.unit.isSingular()) { - throw new Error("Multiple units in dimension. Correct the units or use the unit function. Bad unit: " + this.unit.toString()); - } - var value = this.fround(context, this.value); - var strValue = String(value); - if (value !== 0 && value < 0.000001 && value > -0.000001) { - // would be output 1e-6 etc. - strValue = value.toFixed(20).replace(/0+$/, ''); - } - if (context && context.compress) { - // Zero values doesn't need a unit - if (value === 0 && this.unit.isLength()) { - output.add(strValue); - return; - } - // Float values doesn't need a leading zero - if (value > 0 && value < 1) { - strValue = (strValue).substr(1); - } - } - output.add(strValue); - this.unit.genCSS(context, output); - }; - // In an operation between two Dimensions, - // we default to the first Dimension's unit, - // so `1px + 2` will yield `3px`. - Dimension.prototype.operate = function (context, op, other) { - /* jshint noempty:false */ - var value = this._operate(context, op, this.value, other.value); - var unit = this.unit.clone(); - if (op === '+' || op === '-') { - if (unit.numerator.length === 0 && unit.denominator.length === 0) { - unit = other.unit.clone(); - if (this.unit.backupUnit) { - unit.backupUnit = this.unit.backupUnit; - } - } - else if (other.unit.numerator.length === 0 && unit.denominator.length === 0) ; - else { - other = other.convertTo(this.unit.usedUnits()); - if (context.strictUnits && other.unit.toString() !== unit.toString()) { - throw new Error("Incompatible units. Change the units or use the unit function. " + - ("Bad units: '" + unit.toString() + "' and '" + other.unit.toString() + "'.")); - } - value = this._operate(context, op, this.value, other.value); - } - } - else if (op === '*') { - unit.numerator = unit.numerator.concat(other.unit.numerator).sort(); - unit.denominator = unit.denominator.concat(other.unit.denominator).sort(); - unit.cancel(); - } - else if (op === '/') { - unit.numerator = unit.numerator.concat(other.unit.denominator).sort(); - unit.denominator = unit.denominator.concat(other.unit.numerator).sort(); - unit.cancel(); - } - return new Dimension(value, unit); - }; - Dimension.prototype.compare = function (other) { - var a; - var b; - if (!(other instanceof Dimension)) { - return undefined; - } - if (this.unit.isEmpty() || other.unit.isEmpty()) { - a = this; - b = other; - } - else { - a = this.unify(); - b = other.unify(); - if (a.unit.compare(b.unit) !== 0) { - return undefined; - } - } - return Node.numericCompare(a.value, b.value); - }; - Dimension.prototype.unify = function () { - return this.convertTo({ length: 'px', duration: 's', angle: 'rad' }); - }; - Dimension.prototype.convertTo = function (conversions) { - var value = this.value; - var unit = this.unit.clone(); - var i; - var groupName; - var group; - var targetUnit; - var derivedConversions = {}; - var applyUnit; - if (typeof conversions === 'string') { - for (i in unitConversions) { - if (unitConversions[i].hasOwnProperty(conversions)) { - derivedConversions = {}; - derivedConversions[i] = conversions; - } - } - conversions = derivedConversions; - } - applyUnit = function (atomicUnit, denominator) { - /* jshint loopfunc:true */ - if (group.hasOwnProperty(atomicUnit)) { - if (denominator) { - value = value / (group[atomicUnit] / group[targetUnit]); - } - else { - value = value * (group[atomicUnit] / group[targetUnit]); - } - return targetUnit; - } - return atomicUnit; - }; - for (groupName in conversions) { - if (conversions.hasOwnProperty(groupName)) { - targetUnit = conversions[groupName]; - group = unitConversions[groupName]; - unit.map(applyUnit); - } - } - unit.cancel(); - return new Dimension(value, unit); - }; - Dimension.prototype.type = 'Dimension'; + var MATH$1 = Math$1; + var Operation = function (op, operands, isSpaced) { + this.op = op.trim(); + this.operands = operands; + this.isSpaced = isSpaced; + }; + Operation.prototype = Object.assign(new Node(), { + type: 'Operation', + accept: function (visitor) { + this.operands = visitor.visitArray(this.operands); + }, + eval: function (context) { + var a = this.operands[0].eval(context), b = this.operands[1].eval(context), op; + if (context.isMathOn(this.op)) { + op = this.op === './' ? '/' : this.op; + if (a instanceof Dimension && b instanceof Color) { + a = a.toColor(); + } + if (b instanceof Dimension && a instanceof Color) { + b = b.toColor(); + } + if (!a.operate) { + if (a instanceof Operation && a.op === '/' && context.math === MATH$1.PARENS_DIVISION) { + return new Operation(this.op, [a, b], this.isSpaced); + } + throw { type: 'Operation', + message: 'Operation on an invalid type' }; + } + return a.operate(context, op, b); + } + else { + return new Operation(this.op, [a, b], this.isSpaced); + } + }, + genCSS: function (context, output) { + this.operands[0].genCSS(context, output); + if (this.isSpaced) { + output.add(' '); + } + output.add(this.op); + if (this.isSpaced) { + output.add(' '); + } + this.operands[1].genCSS(context, output); + } + }); - var MATH$1 = Math$1; - var Operation = function (op, operands, isSpaced) { - this.op = op.trim(); - this.operands = operands; - this.isSpaced = isSpaced; - }; - Operation.prototype = new Node(); - Operation.prototype.accept = function (visitor) { - this.operands = visitor.visitArray(this.operands); - }; - Operation.prototype.eval = function (context) { - var a = this.operands[0].eval(context); - var b = this.operands[1].eval(context); - var op; - if (context.isMathOn(this.op)) { - op = this.op === './' ? '/' : this.op; - if (a instanceof Dimension && b instanceof Color) { - a = a.toColor(); - } - if (b instanceof Dimension && a instanceof Color) { - b = b.toColor(); - } - if (!a.operate) { - if (a instanceof Operation && a.op === '/' && context.math === MATH$1.PARENS_DIVISION) { - return new Operation(this.op, [a, b], this.isSpaced); - } - throw { type: 'Operation', - message: 'Operation on an invalid type' }; - } - return a.operate(context, op, b); - } - else { - return new Operation(this.op, [a, b], this.isSpaced); - } - }; - Operation.prototype.genCSS = function (context, output) { - this.operands[0].genCSS(context, output); - if (this.isSpaced) { - output.add(' '); - } - output.add(this.op); - if (this.isSpaced) { - output.add(' '); - } - this.operands[1].genCSS(context, output); - }; - Operation.prototype.type = 'Operation'; + /*! ***************************************************************************** + Copyright (c) Microsoft Corporation. - var MATH$2 = Math$1; - var Expression = function (value, noSpacing) { - this.value = value; - this.noSpacing = noSpacing; - if (!value) { - throw new Error('Expression requires an array parameter'); - } - }; - Expression.prototype = new Node(); - Expression.prototype.accept = function (visitor) { - this.value = visitor.visitArray(this.value); - }; - Expression.prototype.eval = function (context) { - var returnValue; - var mathOn = context.isMathOn(); - var inParenthesis = this.parens && - (context.math !== MATH$2.STRICT_LEGACY || !this.parensInOp); - var doubleParen = false; - if (inParenthesis) { - context.inParenthesis(); - } - if (this.value.length > 1) { - returnValue = new Expression(this.value.map(function (e) { - if (!e.eval) { - return e; - } - return e.eval(context); - }), this.noSpacing); - } - else if (this.value.length === 1) { - if (this.value[0].parens && !this.value[0].parensInOp && !context.inCalc) { - doubleParen = true; - } - returnValue = this.value[0].eval(context); - } - else { - returnValue = this; - } - if (inParenthesis) { - context.outOfParenthesis(); - } - if (this.parens && this.parensInOp && !mathOn && !doubleParen - && (!(returnValue instanceof Dimension))) { - returnValue = new Paren(returnValue); - } - return returnValue; - }; - Expression.prototype.genCSS = function (context, output) { - for (var i = 0; i < this.value.length; i++) { - this.value[i].genCSS(context, output); - if (!this.noSpacing && i + 1 < this.value.length) { - output.add(' '); - } - } - }; - Expression.prototype.throwAwayComments = function () { - this.value = this.value.filter(function (v) { return !(v instanceof Comment); }); - }; - Expression.prototype.type = 'Expression'; + Permission to use, copy, modify, and/or distribute this software for any + purpose with or without fee is hereby granted. - var functionCaller = /** @class */ (function () { - function functionCaller(name, context, index, currentFileInfo) { - this.name = name.toLowerCase(); - this.index = index; - this.context = context; - this.currentFileInfo = currentFileInfo; - this.func = context.frames[0].functionRegistry.get(this.name); - } - functionCaller.prototype.isValid = function () { - return Boolean(this.func); - }; - functionCaller.prototype.call = function (args) { - var _this = this; - var evalArgs = this.func.evalArgs; - if (evalArgs !== false) { - args = args.map(function (a) { return a.eval(_this.context); }); - } - // This code is terrible and should be replaced as per this issue... - // https://github.com/less/less.js/issues/2477 - if (Array.isArray(args)) { - args = args.filter(function (item) { - if (item.type === 'Comment') { - return false; - } - return true; - }) - .map(function (item) { - if (item.type === 'Expression') { - var subNodes = item.value.filter(function (item) { - if (item.type === 'Comment') { - return false; - } - return true; - }); - if (subNodes.length === 1) { - return subNodes[0]; - } - else { - return new Expression(subNodes); - } - } - return item; - }); - } - if (evalArgs === false) { - return this.func.apply(this, __spreadArrays([this.context], args)); - } - return this.func.apply(this, args); - }; - return functionCaller; - }()); + THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH + REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY + AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, + INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM + LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR + OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR + PERFORMANCE OF THIS SOFTWARE. + ***************************************************************************** */ + function __spreadArrays$1() { + for (var s = 0, i = 0, il = arguments.length; i < il; i++) + s += arguments[i].length; + for (var r = Array(s), k = 0, i = 0; i < il; i++) + for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) + r[k] = a[j]; + return r; + } - // - // A function call node. - // - var Call = function (name, args, index, currentFileInfo) { - this.name = name; - this.args = args; - this.calc = name === 'calc'; - this._index = index; - this._fileInfo = currentFileInfo; - }; - Call.prototype = new Node(); - Call.prototype.accept = function (visitor) { - if (this.args) { - this.args = visitor.visitArray(this.args); - } - }; - // - // When evaluating a function call, - // we either find the function in the functionRegistry, - // in which case we call it, passing the evaluated arguments, - // if this returns null or we cannot find the function, we - // simply print it out as it appeared originally [2]. - // - // The reason why we evaluate the arguments, is in the case where - // we try to pass a variable to a function, like: `saturate(@color)`. - // The function should receive the value, not the variable. - // - Call.prototype.eval = function (context) { - var _this = this; - /** - * Turn off math for calc(), and switch back on for evaluating nested functions - */ - var currentMathContext = context.mathOn; - context.mathOn = !this.calc; - if (this.calc || context.inCalc) { - context.enterCalc(); - } - var exitCalc = function () { - if (_this.calc || context.inCalc) { - context.exitCalc(); - } - context.mathOn = currentMathContext; - }; - var result; - var funcCaller = new functionCaller(this.name, context, this.getIndex(), this.fileInfo()); - if (funcCaller.isValid()) { - try { - result = funcCaller.call(this.args); - exitCalc(); - } - catch (e) { - if (e.hasOwnProperty('line') && e.hasOwnProperty('column')) { - throw e; - } - throw { - type: e.type || 'Runtime', - message: "error evaluating function `" + this.name + "`" + (e.message ? ": " + e.message : ''), - index: this.getIndex(), - filename: this.fileInfo().filename, - line: e.lineNumber, - column: e.columnNumber - }; - } - if (result !== null && result !== undefined) { - // Results that that are not nodes are cast as Anonymous nodes - // Falsy values or booleans are returned as empty nodes - if (!(result instanceof Node)) { - if (!result || result === true) { - result = new Anonymous(null); - } - else { - result = new Anonymous(result.toString()); - } - } - result._index = this._index; - result._fileInfo = this._fileInfo; - return result; - } - } - var args = this.args.map(function (a) { return a.eval(context); }); - exitCalc(); - return new Call(this.name, args, this.getIndex(), this.fileInfo()); - }; - Call.prototype.genCSS = function (context, output) { - output.add(this.name + "(", this.fileInfo(), this.getIndex()); - for (var i = 0; i < this.args.length; i++) { - this.args[i].genCSS(context, output); - if (i + 1 < this.args.length) { - output.add(', '); - } - } - output.add(')'); - }; - Call.prototype.type = 'Call'; + var Expression = function (value, noSpacing) { + this.value = value; + this.noSpacing = noSpacing; + if (!value) { + throw new Error('Expression requires an array parameter'); + } + }; + Expression.prototype = Object.assign(new Node(), { + type: 'Expression', + accept: function (visitor) { + this.value = visitor.visitArray(this.value); + }, + eval: function (context) { + var returnValue; + var mathOn = context.isMathOn(); + var inParenthesis = this.parens; + var doubleParen = false; + if (inParenthesis) { + context.inParenthesis(); + } + if (this.value.length > 1) { + returnValue = new Expression(this.value.map(function (e) { + if (!e.eval) { + return e; + } + return e.eval(context); + }), this.noSpacing); + } + else if (this.value.length === 1) { + if (this.value[0].parens && !this.value[0].parensInOp && !context.inCalc) { + doubleParen = true; + } + returnValue = this.value[0].eval(context); + } + else { + returnValue = this; + } + if (inParenthesis) { + context.outOfParenthesis(); + } + if (this.parens && this.parensInOp && !mathOn && !doubleParen + && (!(returnValue instanceof Dimension))) { + returnValue = new Paren(returnValue); + } + return returnValue; + }, + genCSS: function (context, output) { + for (var i = 0; i < this.value.length; i++) { + this.value[i].genCSS(context, output); + if (!this.noSpacing && i + 1 < this.value.length) { + output.add(' '); + } + } + }, + throwAwayComments: function () { + this.value = this.value.filter(function (v) { + return !(v instanceof Comment); + }); + } + }); - var Variable = function (name, index, currentFileInfo) { - this.name = name; - this._index = index; - this._fileInfo = currentFileInfo; - }; - Variable.prototype = new Node(); - Variable.prototype.eval = function (context) { - var variable; - var name = this.name; - if (name.indexOf('@@') === 0) { - name = "@" + new Variable(name.slice(1), this.getIndex(), this.fileInfo()).eval(context).value; - } - if (this.evaluating) { - throw { type: 'Name', message: "Recursive variable definition for " + name, filename: this.fileInfo().filename, - index: this.getIndex() }; - } - this.evaluating = true; - variable = this.find(context.frames, function (frame) { - var v = frame.variable(name); - if (v) { - if (v.important) { - var importantScope = context.importantScope[context.importantScope.length - 1]; - importantScope.important = v.important; - } - // If in calc, wrap vars in a function call to cascade evaluate args first - if (context.inCalc) { - return (new Call('_SELF', [v.value])).eval(context); - } - else { - return v.value.eval(context); - } - } - }); - if (variable) { - this.evaluating = false; - return variable; - } - else { - throw { type: 'Name', message: "variable " + name + " is undefined", filename: this.fileInfo().filename, - index: this.getIndex() }; - } - }; - Variable.prototype.find = function (obj, fun) { - for (var i = 0, r = void 0; i < obj.length; i++) { - r = fun.call(obj, obj[i]); - if (r) { - return r; - } - } - return null; - }; - Variable.prototype.type = 'Variable'; + var functionCaller = /** @class */ (function () { + function functionCaller(name, context, index, currentFileInfo) { + this.name = name.toLowerCase(); + this.index = index; + this.context = context; + this.currentFileInfo = currentFileInfo; + this.func = context.frames[0].functionRegistry.get(this.name); + } + functionCaller.prototype.isValid = function () { + return Boolean(this.func); + }; + functionCaller.prototype.call = function (args) { + var _this = this; + if (!(Array.isArray(args))) { + args = [args]; + } + var evalArgs = this.func.evalArgs; + if (evalArgs !== false) { + args = args.map(function (a) { return a.eval(_this.context); }); + } + var commentFilter = function (item) { return !(item.type === 'Comment'); }; + // This code is terrible and should be replaced as per this issue... + // https://github.com/less/less.js/issues/2477 + args = args + .filter(commentFilter) + .map(function (item) { + if (item.type === 'Expression') { + var subNodes = item.value.filter(commentFilter); + if (subNodes.length === 1) { + return subNodes[0]; + } + else { + return new Expression(subNodes); + } + } + return item; + }); + if (evalArgs === false) { + return this.func.apply(this, __spreadArrays$1([this.context], args)); + } + return this.func.apply(this, args); + }; + return functionCaller; + }()); - var Property = function (name, index, currentFileInfo) { - this.name = name; - this._index = index; - this._fileInfo = currentFileInfo; - }; - Property.prototype = new Node(); - Property.prototype.eval = function (context) { - var property; - var name = this.name; - // TODO: shorten this reference - var mergeRules = context.pluginManager.less.visitors.ToCSSVisitor.prototype._mergeRules; - if (this.evaluating) { - throw { type: 'Name', message: "Recursive property reference for " + name, filename: this.fileInfo().filename, - index: this.getIndex() }; - } - this.evaluating = true; - property = this.find(context.frames, function (frame) { - var v; - var vArr = frame.property(name); - if (vArr) { - for (var i = 0; i < vArr.length; i++) { - v = vArr[i]; - vArr[i] = new Declaration(v.name, v.value, v.important, v.merge, v.index, v.currentFileInfo, v.inline, v.variable); - } - mergeRules(vArr); - v = vArr[vArr.length - 1]; - if (v.important) { - var importantScope = context.importantScope[context.importantScope.length - 1]; - importantScope.important = v.important; - } - v = v.value.eval(context); - return v; - } - }); - if (property) { - this.evaluating = false; - return property; - } - else { - throw { type: 'Name', message: "Property '" + name + "' is undefined", filename: this.currentFileInfo.filename, - index: this.index }; - } - }; - Property.prototype.find = function (obj, fun) { - for (var i = 0, r = void 0; i < obj.length; i++) { - r = fun.call(obj, obj[i]); - if (r) { - return r; - } - } - return null; - }; - Property.prototype.type = 'Property'; + // + // A function call node. + // + var Call = function (name, args, index, currentFileInfo) { + this.name = name; + this.args = args; + this.calc = name === 'calc'; + this._index = index; + this._fileInfo = currentFileInfo; + }; + Call.prototype = Object.assign(new Node(), { + type: 'Call', + accept: function (visitor) { + if (this.args) { + this.args = visitor.visitArray(this.args); + } + }, + // + // When evaluating a function call, + // we either find the function in the functionRegistry, + // in which case we call it, passing the evaluated arguments, + // if this returns null or we cannot find the function, we + // simply print it out as it appeared originally [2]. + // + // The reason why we evaluate the arguments, is in the case where + // we try to pass a variable to a function, like: `saturate(@color)`. + // The function should receive the value, not the variable. + // + eval: function (context) { + var _this = this; + /** + * Turn off math for calc(), and switch back on for evaluating nested functions + */ + var currentMathContext = context.mathOn; + context.mathOn = !this.calc; + if (this.calc || context.inCalc) { + context.enterCalc(); + } + var exitCalc = function () { + if (_this.calc || context.inCalc) { + context.exitCalc(); + } + context.mathOn = currentMathContext; + }; + var result; + var funcCaller = new functionCaller(this.name, context, this.getIndex(), this.fileInfo()); + if (funcCaller.isValid()) { + try { + result = funcCaller.call(this.args); + exitCalc(); + } + catch (e) { + if (e.hasOwnProperty('line') && e.hasOwnProperty('column')) { + throw e; + } + throw { + type: e.type || 'Runtime', + message: "Error evaluating function `" + this.name + "`" + (e.message ? ": " + e.message : ''), + index: this.getIndex(), + filename: this.fileInfo().filename, + line: e.lineNumber, + column: e.columnNumber + }; + } + } + if (result !== null && result !== undefined) { + // Results that that are not nodes are cast as Anonymous nodes + // Falsy values or booleans are returned as empty nodes + if (!(result instanceof Node)) { + if (!result || result === true) { + result = new Anonymous(null); + } + else { + result = new Anonymous(result.toString()); + } + } + result._index = this._index; + result._fileInfo = this._fileInfo; + return result; + } + var args = this.args.map(function (a) { return a.eval(context); }); + exitCalc(); + return new Call(this.name, args, this.getIndex(), this.fileInfo()); + }, + genCSS: function (context, output) { + output.add(this.name + "(", this.fileInfo(), this.getIndex()); + for (var i = 0; i < this.args.length; i++) { + this.args[i].genCSS(context, output); + if (i + 1 < this.args.length) { + output.add(', '); + } + } + output.add(')'); + } + }); - var Attribute = function (key, op, value) { - this.key = key; - this.op = op; - this.value = value; - }; - Attribute.prototype = new Node(); - Attribute.prototype.eval = function (context) { - return new Attribute(this.key.eval ? this.key.eval(context) : this.key, this.op, (this.value && this.value.eval) ? this.value.eval(context) : this.value); - }; - Attribute.prototype.genCSS = function (context, output) { - output.add(this.toCSS(context)); - }; - Attribute.prototype.toCSS = function (context) { - var value = this.key.toCSS ? this.key.toCSS(context) : this.key; - if (this.op) { - value += this.op; - value += (this.value.toCSS ? this.value.toCSS(context) : this.value); - } - return "[" + value + "]"; - }; - Attribute.prototype.type = 'Attribute'; + var Variable = function (name, index, currentFileInfo) { + this.name = name; + this._index = index; + this._fileInfo = currentFileInfo; + }; + Variable.prototype = Object.assign(new Node(), { + type: 'Variable', + eval: function (context) { + var variable, name = this.name; + if (name.indexOf('@@') === 0) { + name = "@" + new Variable(name.slice(1), this.getIndex(), this.fileInfo()).eval(context).value; + } + if (this.evaluating) { + throw { type: 'Name', message: "Recursive variable definition for " + name, filename: this.fileInfo().filename, + index: this.getIndex() }; + } + this.evaluating = true; + variable = this.find(context.frames, function (frame) { + var v = frame.variable(name); + if (v) { + if (v.important) { + var importantScope = context.importantScope[context.importantScope.length - 1]; + importantScope.important = v.important; + } + // If in calc, wrap vars in a function call to cascade evaluate args first + if (context.inCalc) { + return (new Call('_SELF', [v.value])).eval(context); + } + else { + return v.value.eval(context); + } + } + }); + if (variable) { + this.evaluating = false; + return variable; + } + else { + throw { type: 'Name', message: "variable " + name + " is undefined", filename: this.fileInfo().filename, + index: this.getIndex() }; + } + }, + find: function (obj, fun) { + for (var i = 0, r = void 0; i < obj.length; i++) { + r = fun.call(obj, obj[i]); + if (r) { + return r; + } + } + return null; + } + }); - var Quoted = function (str, content, escaped, index, currentFileInfo) { - this.escaped = (escaped == null) ? true : escaped; - this.value = content || ''; - this.quote = str.charAt(0); - this._index = index; - this._fileInfo = currentFileInfo; - this.variableRegex = /@\{([\w-]+)\}/g; - this.propRegex = /\$\{([\w-]+)\}/g; - this.allowRoot = escaped; - }; - Quoted.prototype = new Node(); - Quoted.prototype.genCSS = function (context, output) { - if (!this.escaped) { - output.add(this.quote, this.fileInfo(), this.getIndex()); - } - output.add(this.value); - if (!this.escaped) { - output.add(this.quote); - } - }; - Quoted.prototype.containsVariables = function () { - return this.value.match(this.variableRegex); - }; - Quoted.prototype.eval = function (context) { - var that = this; - var value = this.value; - var variableReplacement = function (_, name) { - var v = new Variable("@" + name, that.getIndex(), that.fileInfo()).eval(context, true); - return (v instanceof Quoted) ? v.value : v.toCSS(); - }; - var propertyReplacement = function (_, name) { - var v = new Property("$" + name, that.getIndex(), that.fileInfo()).eval(context, true); - return (v instanceof Quoted) ? v.value : v.toCSS(); - }; - function iterativeReplace(value, regexp, replacementFnc) { - var evaluatedValue = value; - do { - value = evaluatedValue.toString(); - evaluatedValue = value.replace(regexp, replacementFnc); - } while (value !== evaluatedValue); - return evaluatedValue; - } - value = iterativeReplace(value, this.variableRegex, variableReplacement); - value = iterativeReplace(value, this.propRegex, propertyReplacement); - return new Quoted(this.quote + value + this.quote, value, this.escaped, this.getIndex(), this.fileInfo()); - }; - Quoted.prototype.compare = function (other) { - // when comparing quoted strings allow the quote to differ - if (other.type === 'Quoted' && !this.escaped && !other.escaped) { - return Node.numericCompare(this.value, other.value); - } - else { - return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; - } - }; - Quoted.prototype.type = 'Quoted'; + var Property = function (name, index, currentFileInfo) { + this.name = name; + this._index = index; + this._fileInfo = currentFileInfo; + }; + Property.prototype = Object.assign(new Node(), { + type: 'Property', + eval: function (context) { + var property; + var name = this.name; + // TODO: shorten this reference + var mergeRules = context.pluginManager.less.visitors.ToCSSVisitor.prototype._mergeRules; + if (this.evaluating) { + throw { type: 'Name', message: "Recursive property reference for " + name, filename: this.fileInfo().filename, + index: this.getIndex() }; + } + this.evaluating = true; + property = this.find(context.frames, function (frame) { + var v; + var vArr = frame.property(name); + if (vArr) { + for (var i = 0; i < vArr.length; i++) { + v = vArr[i]; + vArr[i] = new Declaration(v.name, v.value, v.important, v.merge, v.index, v.currentFileInfo, v.inline, v.variable); + } + mergeRules(vArr); + v = vArr[vArr.length - 1]; + if (v.important) { + var importantScope = context.importantScope[context.importantScope.length - 1]; + importantScope.important = v.important; + } + v = v.value.eval(context); + return v; + } + }); + if (property) { + this.evaluating = false; + return property; + } + else { + throw { type: 'Name', message: "Property '" + name + "' is undefined", filename: this.currentFileInfo.filename, + index: this.index }; + } + }, + find: function (obj, fun) { + for (var i = 0, r = void 0; i < obj.length; i++) { + r = fun.call(obj, obj[i]); + if (r) { + return r; + } + } + return null; + } + }); - var URL = function (val, index, currentFileInfo, isEvald) { - this.value = val; - this._index = index; - this._fileInfo = currentFileInfo; - this.isEvald = isEvald; - }; - URL.prototype = new Node(); - URL.prototype.accept = function (visitor) { - this.value = visitor.visit(this.value); - }; - URL.prototype.genCSS = function (context, output) { - output.add('url('); - this.value.genCSS(context, output); - output.add(')'); - }; - URL.prototype.eval = function (context) { - var val = this.value.eval(context); - var rootpath; - if (!this.isEvald) { - // Add the rootpath if the URL requires a rewrite - rootpath = this.fileInfo() && this.fileInfo().rootpath; - if (typeof rootpath === 'string' && - typeof val.value === 'string' && - context.pathRequiresRewrite(val.value)) { - if (!val.quote) { - rootpath = escapePath(rootpath); - } - val.value = context.rewritePath(val.value, rootpath); - } - else { - val.value = context.normalizePath(val.value); - } - // Add url args if enabled - if (context.urlArgs) { - if (!val.value.match(/^\s*data:/)) { - var delimiter = val.value.indexOf('?') === -1 ? '?' : '&'; - var urlArgs = delimiter + context.urlArgs; - if (val.value.indexOf('#') !== -1) { - val.value = val.value.replace('#', urlArgs + "#"); - } - else { - val.value += urlArgs; - } - } - } - } - return new URL(val, this.getIndex(), this.fileInfo(), true); - }; - URL.prototype.type = 'Url'; - function escapePath(path) { - return path.replace(/[\(\)'"\s]/g, function (match) { return "\\" + match; }); - } + var Attribute = function (key, op, value) { + this.key = key; + this.op = op; + this.value = value; + }; + Attribute.prototype = Object.assign(new Node(), { + type: 'Attribute', + eval: function (context) { + return new Attribute(this.key.eval ? this.key.eval(context) : this.key, this.op, (this.value && this.value.eval) ? this.value.eval(context) : this.value); + }, + genCSS: function (context, output) { + output.add(this.toCSS(context)); + }, + toCSS: function (context) { + var value = this.key.toCSS ? this.key.toCSS(context) : this.key; + if (this.op) { + value += this.op; + value += (this.value.toCSS ? this.value.toCSS(context) : this.value); + } + return "[" + value + "]"; + } + }); - var Media = function (value, features, index, currentFileInfo, visibilityInfo) { - this._index = index; - this._fileInfo = currentFileInfo; - var selectors = (new Selector([], null, null, this._index, this._fileInfo)).createEmptySelectors(); - this.features = new Value(features); - this.rules = [new Ruleset(selectors, value)]; - this.rules[0].allowImports = true; - this.copyVisibilityInfo(visibilityInfo); - this.allowRoot = true; - this.setParent(selectors, this); - this.setParent(this.features, this); - this.setParent(this.rules, this); - }; - Media.prototype = new AtRule(); - Media.prototype.isRulesetLike = function () { - return true; - }; - Media.prototype.accept = function (visitor) { - if (this.features) { - this.features = visitor.visit(this.features); - } - if (this.rules) { - this.rules = visitor.visitArray(this.rules); - } - }; - Media.prototype.genCSS = function (context, output) { - output.add('@media ', this._fileInfo, this._index); - this.features.genCSS(context, output); - this.outputRuleset(context, output, this.rules); - }; - Media.prototype.eval = function (context) { - if (!context.mediaBlocks) { - context.mediaBlocks = []; - context.mediaPath = []; - } - var media = new Media(null, [], this._index, this._fileInfo, this.visibilityInfo()); - if (this.debugInfo) { - this.rules[0].debugInfo = this.debugInfo; - media.debugInfo = this.debugInfo; - } - media.features = this.features.eval(context); - context.mediaPath.push(media); - context.mediaBlocks.push(media); - this.rules[0].functionRegistry = context.frames[0].functionRegistry.inherit(); - context.frames.unshift(this.rules[0]); - media.rules = [this.rules[0].eval(context)]; - context.frames.shift(); - context.mediaPath.pop(); - return context.mediaPath.length === 0 ? media.evalTop(context) : - media.evalNested(context); - }; - Media.prototype.evalTop = function (context) { - var result = this; - // Render all dependent Media blocks. - if (context.mediaBlocks.length > 1) { - var selectors = (new Selector([], null, null, this.getIndex(), this.fileInfo())).createEmptySelectors(); - result = new Ruleset(selectors, context.mediaBlocks); - result.multiMedia = true; - result.copyVisibilityInfo(this.visibilityInfo()); - this.setParent(result, this); - } - delete context.mediaBlocks; - delete context.mediaPath; - return result; - }; - Media.prototype.evalNested = function (context) { - var i; - var value; - var path = context.mediaPath.concat([this]); - // Extract the media-query conditions separated with `,` (OR). - for (i = 0; i < path.length; i++) { - value = path[i].features instanceof Value ? - path[i].features.value : path[i].features; - path[i] = Array.isArray(value) ? value : [value]; - } - // Trace all permutations to generate the resulting media-query. - // - // (a, b and c) with nested (d, e) -> - // a and d - // a and e - // b and c and d - // b and c and e - this.features = new Value(this.permute(path).map(function (path) { - path = path.map(function (fragment) { return fragment.toCSS ? fragment : new Anonymous(fragment); }); - for (i = path.length - 1; i > 0; i--) { - path.splice(i, 0, new Anonymous('and')); - } - return new Expression(path); - })); - this.setParent(this.features, this); - // Fake a tree-node that doesn't output anything. - return new Ruleset([], []); - }; - Media.prototype.permute = function (arr) { - if (arr.length === 0) { - return []; - } - else if (arr.length === 1) { - return arr[0]; - } - else { - var result = []; - var rest = this.permute(arr.slice(1)); - for (var i = 0; i < rest.length; i++) { - for (var j = 0; j < arr[0].length; j++) { - result.push([arr[0][j]].concat(rest[i])); - } - } - return result; - } - }; - Media.prototype.bubbleSelectors = function (selectors) { - if (!selectors) { - return; - } - this.rules = [new Ruleset(copyArray(selectors), [this.rules[0]])]; - this.setParent(this.rules, this); - }; - Media.prototype.type = 'Media'; + var Quoted = function (str, content, escaped, index, currentFileInfo) { + this.escaped = (escaped == null) ? true : escaped; + this.value = content || ''; + this.quote = str.charAt(0); + this._index = index; + this._fileInfo = currentFileInfo; + this.variableRegex = /@\{([\w-]+)\}/g; + this.propRegex = /\$\{([\w-]+)\}/g; + this.allowRoot = escaped; + }; + Quoted.prototype = Object.assign(new Node(), { + type: 'Quoted', + genCSS: function (context, output) { + if (!this.escaped) { + output.add(this.quote, this.fileInfo(), this.getIndex()); + } + output.add(this.value); + if (!this.escaped) { + output.add(this.quote); + } + }, + containsVariables: function () { + return this.value.match(this.variableRegex); + }, + eval: function (context) { + var that = this; + var value = this.value; + var variableReplacement = function (_, name) { + var v = new Variable("@" + name, that.getIndex(), that.fileInfo()).eval(context, true); + return (v instanceof Quoted) ? v.value : v.toCSS(); + }; + var propertyReplacement = function (_, name) { + var v = new Property("$" + name, that.getIndex(), that.fileInfo()).eval(context, true); + return (v instanceof Quoted) ? v.value : v.toCSS(); + }; + function iterativeReplace(value, regexp, replacementFnc) { + var evaluatedValue = value; + do { + value = evaluatedValue.toString(); + evaluatedValue = value.replace(regexp, replacementFnc); + } while (value !== evaluatedValue); + return evaluatedValue; + } + value = iterativeReplace(value, this.variableRegex, variableReplacement); + value = iterativeReplace(value, this.propRegex, propertyReplacement); + return new Quoted(this.quote + value + this.quote, value, this.escaped, this.getIndex(), this.fileInfo()); + }, + compare: function (other) { + // when comparing quoted strings allow the quote to differ + if (other.type === 'Quoted' && !this.escaped && !other.escaped) { + return Node.numericCompare(this.value, other.value); + } + else { + return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; + } + } + }); - // - // CSS @import node - // - // The general strategy here is that we don't want to wait - // for the parsing to be completed, before we start importing - // the file. That's because in the context of a browser, - // most of the time will be spent waiting for the server to respond. - // - // On creation, we push the import path to our import queue, though - // `import,push`, we also pass it a callback, which it'll call once - // the file has been fetched, and parsed. - // - var Import = function (path, features, options, index, currentFileInfo, visibilityInfo) { - this.options = options; - this._index = index; - this._fileInfo = currentFileInfo; - this.path = path; - this.features = features; - this.allowRoot = true; - if (this.options.less !== undefined || this.options.inline) { - this.css = !this.options.less || this.options.inline; - } - else { - var pathValue = this.getPath(); - if (pathValue && /[#\.\&\?]css([\?;].*)?$/.test(pathValue)) { - this.css = true; - } - } - this.copyVisibilityInfo(visibilityInfo); - this.setParent(this.features, this); - this.setParent(this.path, this); - }; - Import.prototype = new Node(); - Import.prototype.accept = function (visitor) { - if (this.features) { - this.features = visitor.visit(this.features); - } - this.path = visitor.visit(this.path); - if (!this.options.isPlugin && !this.options.inline && this.root) { - this.root = visitor.visit(this.root); - } - }; - Import.prototype.genCSS = function (context, output) { - if (this.css && this.path._fileInfo.reference === undefined) { - output.add('@import ', this._fileInfo, this._index); - this.path.genCSS(context, output); - if (this.features) { - output.add(' '); - this.features.genCSS(context, output); - } - output.add(';'); - } - }; - Import.prototype.getPath = function () { - return (this.path instanceof URL) ? - this.path.value.value : this.path.value; - }; - Import.prototype.isVariableImport = function () { - var path = this.path; - if (path instanceof URL) { - path = path.value; - } - if (path instanceof Quoted) { - return path.containsVariables(); - } - return true; - }; - Import.prototype.evalForImport = function (context) { - var path = this.path; - if (path instanceof URL) { - path = path.value; - } - return new Import(path.eval(context), this.features, this.options, this._index, this._fileInfo, this.visibilityInfo()); - }; - Import.prototype.evalPath = function (context) { - var path = this.path.eval(context); - var fileInfo = this._fileInfo; - if (!(path instanceof URL)) { - // Add the rootpath if the URL requires a rewrite - var pathValue = path.value; - if (fileInfo && - pathValue && - context.pathRequiresRewrite(pathValue)) { - path.value = context.rewritePath(pathValue, fileInfo.rootpath); - } - else { - path.value = context.normalizePath(path.value); - } - } - return path; - }; - Import.prototype.eval = function (context) { - var result = this.doEval(context); - if (this.options.reference || this.blocksVisibility()) { - if (result.length || result.length === 0) { - result.forEach(function (node) { - node.addVisibilityBlock(); - }); - } - else { - result.addVisibilityBlock(); - } - } - return result; - }; - Import.prototype.doEval = function (context) { - var ruleset; - var registry; - var features = this.features && this.features.eval(context); - if (this.options.isPlugin) { - if (this.root && this.root.eval) { - try { - this.root.eval(context); - } - catch (e) { - e.message = 'Plugin error during evaluation'; - throw new LessError(e, this.root.imports, this.root.filename); - } - } - registry = context.frames[0] && context.frames[0].functionRegistry; - if (registry && this.root && this.root.functions) { - registry.addMultiple(this.root.functions); - } - return []; - } - if (this.skip) { - if (typeof this.skip === 'function') { - this.skip = this.skip(); - } - if (this.skip) { - return []; - } - } - if (this.options.inline) { - var contents = new Anonymous(this.root, 0, { - filename: this.importedFilename, - reference: this.path._fileInfo && this.path._fileInfo.reference - }, true, true); - return this.features ? new Media([contents], this.features.value) : [contents]; - } - else if (this.css) { - var newImport = new Import(this.evalPath(context), features, this.options, this._index); - if (!newImport.css && this.error) { - throw this.error; - } - return newImport; - } - else if (this.root) { - ruleset = new Ruleset(null, copyArray(this.root.rules)); - ruleset.evalImports(context); - return this.features ? new Media(ruleset.rules, this.features.value) : ruleset.rules; - } - else { - return []; - } - }; - Import.prototype.type = 'Import'; + function escapePath(path) { + return path.replace(/[\(\)'"\s]/g, function (match) { return "\\" + match; }); + } + var URL = function (val, index, currentFileInfo, isEvald) { + this.value = val; + this._index = index; + this._fileInfo = currentFileInfo; + this.isEvald = isEvald; + }; + URL.prototype = Object.assign(new Node(), { + type: 'Url', + accept: function (visitor) { + this.value = visitor.visit(this.value); + }, + genCSS: function (context, output) { + output.add('url('); + this.value.genCSS(context, output); + output.add(')'); + }, + eval: function (context) { + var val = this.value.eval(context); + var rootpath; + if (!this.isEvald) { + // Add the rootpath if the URL requires a rewrite + rootpath = this.fileInfo() && this.fileInfo().rootpath; + if (typeof rootpath === 'string' && + typeof val.value === 'string' && + context.pathRequiresRewrite(val.value)) { + if (!val.quote) { + rootpath = escapePath(rootpath); + } + val.value = context.rewritePath(val.value, rootpath); + } + else { + val.value = context.normalizePath(val.value); + } + // Add url args if enabled + if (context.urlArgs) { + if (!val.value.match(/^\s*data:/)) { + var delimiter = val.value.indexOf('?') === -1 ? '?' : '&'; + var urlArgs = delimiter + context.urlArgs; + if (val.value.indexOf('#') !== -1) { + val.value = val.value.replace('#', urlArgs + "#"); + } + else { + val.value += urlArgs; + } + } + } + } + return new URL(val, this.getIndex(), this.fileInfo(), true); + } + }); - var JsEvalNode = function () { }; - JsEvalNode.prototype = new Node(); - JsEvalNode.prototype.evaluateJavaScript = function (expression, context) { - var result; - var that = this; - var evalContext = {}; - if (!context.javascriptEnabled) { - throw { message: 'Inline JavaScript is not enabled. Is it set in your options?', - filename: this.fileInfo().filename, - index: this.getIndex() }; - } - expression = expression.replace(/@\{([\w-]+)\}/g, function (_, name) { return that.jsify(new Variable("@" + name, that.getIndex(), that.fileInfo()).eval(context)); }); - try { - expression = new Function("return (" + expression + ")"); - } - catch (e) { - throw { message: "JavaScript evaluation error: " + e.message + " from `" + expression + "`", filename: this.fileInfo().filename, - index: this.getIndex() }; - } - var variables = context.frames[0].variables(); - for (var k in variables) { - if (variables.hasOwnProperty(k)) { - /* jshint loopfunc:true */ - evalContext[k.slice(1)] = { - value: variables[k].value, - toJS: function () { - return this.value.eval(context).toCSS(); - } - }; - } - } - try { - result = expression.call(evalContext); - } - catch (e) { - throw { message: "JavaScript evaluation error: '" + e.name + ": " + e.message.replace(/["]/g, '\'') + "'", filename: this.fileInfo().filename, - index: this.getIndex() }; - } - return result; - }; - JsEvalNode.prototype.jsify = function (obj) { - if (Array.isArray(obj.value) && (obj.value.length > 1)) { - return "[" + obj.value.map(function (v) { return v.toCSS(); }).join(', ') + "]"; - } - else { - return obj.toCSS(); - } - }; + var Media = function (value, features, index, currentFileInfo, visibilityInfo) { + this._index = index; + this._fileInfo = currentFileInfo; + var selectors = (new Selector([], null, null, this._index, this._fileInfo)).createEmptySelectors(); + this.features = new Value(features); + this.rules = [new Ruleset(selectors, value)]; + this.rules[0].allowImports = true; + this.copyVisibilityInfo(visibilityInfo); + this.allowRoot = true; + this.setParent(selectors, this); + this.setParent(this.features, this); + this.setParent(this.rules, this); + }; + Media.prototype = Object.assign(new AtRule(), { + type: 'Media', + isRulesetLike: function () { + return true; + }, + accept: function (visitor) { + if (this.features) { + this.features = visitor.visit(this.features); + } + if (this.rules) { + this.rules = visitor.visitArray(this.rules); + } + }, + genCSS: function (context, output) { + output.add('@media ', this._fileInfo, this._index); + this.features.genCSS(context, output); + this.outputRuleset(context, output, this.rules); + }, + eval: function (context) { + if (!context.mediaBlocks) { + context.mediaBlocks = []; + context.mediaPath = []; + } + var media = new Media(null, [], this._index, this._fileInfo, this.visibilityInfo()); + if (this.debugInfo) { + this.rules[0].debugInfo = this.debugInfo; + media.debugInfo = this.debugInfo; + } + media.features = this.features.eval(context); + context.mediaPath.push(media); + context.mediaBlocks.push(media); + this.rules[0].functionRegistry = context.frames[0].functionRegistry.inherit(); + context.frames.unshift(this.rules[0]); + media.rules = [this.rules[0].eval(context)]; + context.frames.shift(); + context.mediaPath.pop(); + return context.mediaPath.length === 0 ? media.evalTop(context) : + media.evalNested(context); + }, + evalTop: function (context) { + var result = this; + // Render all dependent Media blocks. + if (context.mediaBlocks.length > 1) { + var selectors = (new Selector([], null, null, this.getIndex(), this.fileInfo())).createEmptySelectors(); + result = new Ruleset(selectors, context.mediaBlocks); + result.multiMedia = true; + result.copyVisibilityInfo(this.visibilityInfo()); + this.setParent(result, this); + } + delete context.mediaBlocks; + delete context.mediaPath; + return result; + }, + evalNested: function (context) { + var i; + var value; + var path = context.mediaPath.concat([this]); + // Extract the media-query conditions separated with `,` (OR). + for (i = 0; i < path.length; i++) { + value = path[i].features instanceof Value ? + path[i].features.value : path[i].features; + path[i] = Array.isArray(value) ? value : [value]; + } + // Trace all permutations to generate the resulting media-query. + // + // (a, b and c) with nested (d, e) -> + // a and d + // a and e + // b and c and d + // b and c and e + this.features = new Value(this.permute(path).map(function (path) { + path = path.map(function (fragment) { return fragment.toCSS ? fragment : new Anonymous(fragment); }); + for (i = path.length - 1; i > 0; i--) { + path.splice(i, 0, new Anonymous('and')); + } + return new Expression(path); + })); + this.setParent(this.features, this); + // Fake a tree-node that doesn't output anything. + return new Ruleset([], []); + }, + permute: function (arr) { + if (arr.length === 0) { + return []; + } + else if (arr.length === 1) { + return arr[0]; + } + else { + var result = []; + var rest = this.permute(arr.slice(1)); + for (var i = 0; i < rest.length; i++) { + for (var j = 0; j < arr[0].length; j++) { + result.push([arr[0][j]].concat(rest[i])); + } + } + return result; + } + }, + bubbleSelectors: function (selectors) { + if (!selectors) { + return; + } + this.rules = [new Ruleset(copyArray(selectors), [this.rules[0]])]; + this.setParent(this.rules, this); + } + }); - var JavaScript = function (string, escaped, index, currentFileInfo) { - this.escaped = escaped; - this.expression = string; - this._index = index; - this._fileInfo = currentFileInfo; - }; - JavaScript.prototype = new JsEvalNode(); - JavaScript.prototype.eval = function (context) { - var result = this.evaluateJavaScript(this.expression, context); - var type = typeof result; - if (type === 'number' && !isNaN(result)) { - return new Dimension(result); - } - else if (type === 'string') { - return new Quoted("\"" + result + "\"", result, this.escaped, this._index); - } - else if (Array.isArray(result)) { - return new Anonymous(result.join(', ')); - } - else { - return new Anonymous(result); - } - }; - JavaScript.prototype.type = 'JavaScript'; + // + // CSS @import node + // + // The general strategy here is that we don't want to wait + // for the parsing to be completed, before we start importing + // the file. That's because in the context of a browser, + // most of the time will be spent waiting for the server to respond. + // + // On creation, we push the import path to our import queue, though + // `import,push`, we also pass it a callback, which it'll call once + // the file has been fetched, and parsed. + // + var Import = function (path, features, options, index, currentFileInfo, visibilityInfo) { + this.options = options; + this._index = index; + this._fileInfo = currentFileInfo; + this.path = path; + this.features = features; + this.allowRoot = true; + if (this.options.less !== undefined || this.options.inline) { + this.css = !this.options.less || this.options.inline; + } + else { + var pathValue = this.getPath(); + if (pathValue && /[#\.\&\?]css([\?;].*)?$/.test(pathValue)) { + this.css = true; + } + } + this.copyVisibilityInfo(visibilityInfo); + this.setParent(this.features, this); + this.setParent(this.path, this); + }; + Import.prototype = Object.assign(new Node(), { + type: 'Import', + accept: function (visitor) { + if (this.features) { + this.features = visitor.visit(this.features); + } + this.path = visitor.visit(this.path); + if (!this.options.isPlugin && !this.options.inline && this.root) { + this.root = visitor.visit(this.root); + } + }, + genCSS: function (context, output) { + if (this.css && this.path._fileInfo.reference === undefined) { + output.add('@import ', this._fileInfo, this._index); + this.path.genCSS(context, output); + if (this.features) { + output.add(' '); + this.features.genCSS(context, output); + } + output.add(';'); + } + }, + getPath: function () { + return (this.path instanceof URL) ? + this.path.value.value : this.path.value; + }, + isVariableImport: function () { + var path = this.path; + if (path instanceof URL) { + path = path.value; + } + if (path instanceof Quoted) { + return path.containsVariables(); + } + return true; + }, + evalForImport: function (context) { + var path = this.path; + if (path instanceof URL) { + path = path.value; + } + return new Import(path.eval(context), this.features, this.options, this._index, this._fileInfo, this.visibilityInfo()); + }, + evalPath: function (context) { + var path = this.path.eval(context); + var fileInfo = this._fileInfo; + if (!(path instanceof URL)) { + // Add the rootpath if the URL requires a rewrite + var pathValue = path.value; + if (fileInfo && + pathValue && + context.pathRequiresRewrite(pathValue)) { + path.value = context.rewritePath(pathValue, fileInfo.rootpath); + } + else { + path.value = context.normalizePath(path.value); + } + } + return path; + }, + eval: function (context) { + var result = this.doEval(context); + if (this.options.reference || this.blocksVisibility()) { + if (result.length || result.length === 0) { + result.forEach(function (node) { + node.addVisibilityBlock(); + }); + } + else { + result.addVisibilityBlock(); + } + } + return result; + }, + doEval: function (context) { + var ruleset; + var registry; + var features = this.features && this.features.eval(context); + if (this.options.isPlugin) { + if (this.root && this.root.eval) { + try { + this.root.eval(context); + } + catch (e) { + e.message = 'Plugin error during evaluation'; + throw new LessError(e, this.root.imports, this.root.filename); + } + } + registry = context.frames[0] && context.frames[0].functionRegistry; + if (registry && this.root && this.root.functions) { + registry.addMultiple(this.root.functions); + } + return []; + } + if (this.skip) { + if (typeof this.skip === 'function') { + this.skip = this.skip(); + } + if (this.skip) { + return []; + } + } + if (this.options.inline) { + var contents = new Anonymous(this.root, 0, { + filename: this.importedFilename, + reference: this.path._fileInfo && this.path._fileInfo.reference + }, true, true); + return this.features ? new Media([contents], this.features.value) : [contents]; + } + else if (this.css) { + var newImport = new Import(this.evalPath(context), features, this.options, this._index); + if (!newImport.css && this.error) { + throw this.error; + } + return newImport; + } + else if (this.root) { + ruleset = new Ruleset(null, copyArray(this.root.rules)); + ruleset.evalImports(context); + return this.features ? new Media(ruleset.rules, this.features.value) : ruleset.rules; + } + else { + return []; + } + } + }); - var Assignment = function (key, val) { - this.key = key; - this.value = val; - }; - Assignment.prototype = new Node(); - Assignment.prototype.accept = function (visitor) { - this.value = visitor.visit(this.value); - }; - Assignment.prototype.eval = function (context) { - if (this.value.eval) { - return new Assignment(this.key, this.value.eval(context)); - } - return this; - }; - Assignment.prototype.genCSS = function (context, output) { - output.add(this.key + "="); - if (this.value.genCSS) { - this.value.genCSS(context, output); - } - else { - output.add(this.value); - } - }; - Assignment.prototype.type = 'Assignment'; + var JsEvalNode = function () { }; + JsEvalNode.prototype = Object.assign(new Node(), { + evaluateJavaScript: function (expression, context) { + var result; + var that = this; + var evalContext = {}; + if (!context.javascriptEnabled) { + throw { message: 'Inline JavaScript is not enabled. Is it set in your options?', + filename: this.fileInfo().filename, + index: this.getIndex() }; + } + expression = expression.replace(/@\{([\w-]+)\}/g, function (_, name) { + return that.jsify(new Variable("@" + name, that.getIndex(), that.fileInfo()).eval(context)); + }); + try { + expression = new Function("return (" + expression + ")"); + } + catch (e) { + throw { message: "JavaScript evaluation error: " + e.message + " from `" + expression + "`", filename: this.fileInfo().filename, + index: this.getIndex() }; + } + var variables = context.frames[0].variables(); + for (var k in variables) { + if (variables.hasOwnProperty(k)) { + /* jshint loopfunc:true */ + evalContext[k.slice(1)] = { + value: variables[k].value, + toJS: function () { + return this.value.eval(context).toCSS(); + } + }; + } + } + try { + result = expression.call(evalContext); + } + catch (e) { + throw { message: "JavaScript evaluation error: '" + e.name + ": " + e.message.replace(/["]/g, '\'') + "'", filename: this.fileInfo().filename, + index: this.getIndex() }; + } + return result; + }, + jsify: function (obj) { + if (Array.isArray(obj.value) && (obj.value.length > 1)) { + return "[" + obj.value.map(function (v) { return v.toCSS(); }).join(', ') + "]"; + } + else { + return obj.toCSS(); + } + } + }); - var Condition = function (op, l, r, i, negate) { - this.op = op.trim(); - this.lvalue = l; - this.rvalue = r; - this._index = i; - this.negate = negate; - }; - Condition.prototype = new Node(); - Condition.prototype.accept = function (visitor) { - this.lvalue = visitor.visit(this.lvalue); - this.rvalue = visitor.visit(this.rvalue); - }; - Condition.prototype.eval = function (context) { - var result = (function (op, a, b) { - switch (op) { - case 'and': return a && b; - case 'or': return a || b; - default: - switch (Node.compare(a, b)) { - case -1: - return op === '<' || op === '=<' || op === '<='; - case 0: - return op === '=' || op === '>=' || op === '=<' || op === '<='; - case 1: - return op === '>' || op === '>='; - default: - return false; - } - } - })(this.op, this.lvalue.eval(context), this.rvalue.eval(context)); - return this.negate ? !result : result; - }; - Condition.prototype.type = 'Condition'; + var JavaScript = function (string, escaped, index, currentFileInfo) { + this.escaped = escaped; + this.expression = string; + this._index = index; + this._fileInfo = currentFileInfo; + }; + JavaScript.prototype = Object.assign(new JsEvalNode(), { + type: 'JavaScript', + eval: function (context) { + var result = this.evaluateJavaScript(this.expression, context); + var type = typeof result; + if (type === 'number' && !isNaN(result)) { + return new Dimension(result); + } + else if (type === 'string') { + return new Quoted("\"" + result + "\"", result, this.escaped, this._index); + } + else if (Array.isArray(result)) { + return new Anonymous(result.join(', ')); + } + else { + return new Anonymous(result); + } + } + }); - var UnicodeDescriptor = function (value) { - this.value = value; - }; - UnicodeDescriptor.prototype = new Node(); - UnicodeDescriptor.prototype.type = 'UnicodeDescriptor'; + var Assignment = function (key, val) { + this.key = key; + this.value = val; + }; + Assignment.prototype = Object.assign(new Node(), { + type: 'Assignment', + accept: function (visitor) { + this.value = visitor.visit(this.value); + }, + eval: function (context) { + if (this.value.eval) { + return new Assignment(this.key, this.value.eval(context)); + } + return this; + }, + genCSS: function (context, output) { + output.add(this.key + "="); + if (this.value.genCSS) { + this.value.genCSS(context, output); + } + else { + output.add(this.value); + } + } + }); - var Negative = function (node) { - this.value = node; - }; - Negative.prototype = new Node(); - Negative.prototype.genCSS = function (context, output) { - output.add('-'); - this.value.genCSS(context, output); - }; - Negative.prototype.eval = function (context) { - if (context.isMathOn()) { - return (new Operation('*', [new Dimension(-1), this.value])).eval(context); - } - return new Negative(this.value.eval(context)); - }; - Negative.prototype.type = 'Negative'; + var Condition = function (op, l, r, i, negate) { + this.op = op.trim(); + this.lvalue = l; + this.rvalue = r; + this._index = i; + this.negate = negate; + }; + Condition.prototype = Object.assign(new Node(), { + type: 'Condition', + accept: function (visitor) { + this.lvalue = visitor.visit(this.lvalue); + this.rvalue = visitor.visit(this.rvalue); + }, + eval: function (context) { + var result = (function (op, a, b) { + switch (op) { + case 'and': return a && b; + case 'or': return a || b; + default: + switch (Node.compare(a, b)) { + case -1: + return op === '<' || op === '=<' || op === '<='; + case 0: + return op === '=' || op === '>=' || op === '=<' || op === '<='; + case 1: + return op === '>' || op === '>='; + default: + return false; + } + } + })(this.op, this.lvalue.eval(context), this.rvalue.eval(context)); + return this.negate ? !result : result; + } + }); - var Extend = function (selector, option, index, currentFileInfo, visibilityInfo) { - this.selector = selector; - this.option = option; - this.object_id = Extend.next_id++; - this.parent_ids = [this.object_id]; - this._index = index; - this._fileInfo = currentFileInfo; - this.copyVisibilityInfo(visibilityInfo); - this.allowRoot = true; - switch (option) { - case 'all': - this.allowBefore = true; - this.allowAfter = true; - break; - default: - this.allowBefore = false; - this.allowAfter = false; - break; - } - this.setParent(this.selector, this); - }; - Extend.prototype = new Node(); - Extend.prototype.accept = function (visitor) { - this.selector = visitor.visit(this.selector); - }; - Extend.prototype.eval = function (context) { - return new Extend(this.selector.eval(context), this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); - }; - Extend.prototype.clone = function (context) { - return new Extend(this.selector, this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); - }; - // it concatenates (joins) all selectors in selector array - Extend.prototype.findSelfSelectors = function (selectors) { - var selfElements = []; - var i; - var selectorElements; - for (i = 0; i < selectors.length; i++) { - selectorElements = selectors[i].elements; - // duplicate the logic in genCSS function inside the selector node. - // future TODO - move both logics into the selector joiner visitor - if (i > 0 && selectorElements.length && selectorElements[0].combinator.value === '') { - selectorElements[0].combinator.value = ' '; - } - selfElements = selfElements.concat(selectors[i].elements); - } - this.selfSelectors = [new Selector(selfElements)]; - this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo()); - }; - /** - * Used with the extend visitor - */ - Extend.next_id = 0; - Extend.prototype.type = 'Extend'; + var UnicodeDescriptor = function (value) { + this.value = value; + }; + UnicodeDescriptor.prototype = Object.assign(new Node(), { + type: 'UnicodeDescriptor' + }); - var VariableCall = function (variable, index, currentFileInfo) { - this.variable = variable; - this._index = index; - this._fileInfo = currentFileInfo; - this.allowRoot = true; - }; - VariableCall.prototype = new Node(); - VariableCall.prototype.eval = function (context) { - var rules; - var detachedRuleset = new Variable(this.variable, this.getIndex(), this.fileInfo()).eval(context); - var error = new LessError({ message: "Could not evaluate variable call " + this.variable }); - if (!detachedRuleset.ruleset) { - if (detachedRuleset.rules) { - rules = detachedRuleset; - } - else if (Array.isArray(detachedRuleset)) { - rules = new Ruleset('', detachedRuleset); - } - else if (Array.isArray(detachedRuleset.value)) { - rules = new Ruleset('', detachedRuleset.value); - } - else { - throw error; - } - detachedRuleset = new DetachedRuleset(rules); - } - if (detachedRuleset.ruleset) { - return detachedRuleset.callEval(context); - } - throw error; - }; - VariableCall.prototype.type = 'VariableCall'; + var Negative = function (node) { + this.value = node; + }; + Negative.prototype = Object.assign(new Node(), { + type: 'Negative', + genCSS: function (context, output) { + output.add('-'); + this.value.genCSS(context, output); + }, + eval: function (context) { + if (context.isMathOn()) { + return (new Operation('*', [new Dimension(-1), this.value])).eval(context); + } + return new Negative(this.value.eval(context)); + } + }); - var NamespaceValue = function (ruleCall, lookups, index, fileInfo) { - this.value = ruleCall; - this.lookups = lookups; - this._index = index; - this._fileInfo = fileInfo; - }; - NamespaceValue.prototype = new Node(); - NamespaceValue.prototype.eval = function (context) { - var i; - var name; - var rules = this.value.eval(context); - for (i = 0; i < this.lookups.length; i++) { - name = this.lookups[i]; - /** - * Eval'd DRs return rulesets. - * Eval'd mixins return rules, so let's make a ruleset if we need it. - * We need to do this because of late parsing of values - */ - if (Array.isArray(rules)) { - rules = new Ruleset([new Selector()], rules); - } - if (name === '') { - rules = rules.lastDeclaration(); - } - else if (name.charAt(0) === '@') { - if (name.charAt(1) === '@') { - name = "@" + new Variable(name.substr(1)).eval(context).value; - } - if (rules.variables) { - rules = rules.variable(name); - } - if (!rules) { - throw { type: 'Name', message: "variable " + name + " not found", filename: this.fileInfo().filename, - index: this.getIndex() }; - } - } - else { - if (name.substring(0, 2) === '$@') { - name = "$" + new Variable(name.substr(1)).eval(context).value; - } - else { - name = name.charAt(0) === '$' ? name : "$" + name; - } - if (rules.properties) { - rules = rules.property(name); - } - if (!rules) { - throw { type: 'Name', message: "property \"" + name.substr(1) + "\" not found", filename: this.fileInfo().filename, - index: this.getIndex() }; - } - // Properties are an array of values, since a ruleset can have multiple props. - // We pick the last one (the "cascaded" value) - rules = rules[rules.length - 1]; - } - if (rules.value) { - rules = rules.eval(context).value; - } - if (rules.ruleset) { - rules = rules.ruleset.eval(context); - } - } - return rules; - }; - NamespaceValue.prototype.type = 'NamespaceValue'; + var Extend = function (selector, option, index, currentFileInfo, visibilityInfo) { + this.selector = selector; + this.option = option; + this.object_id = Extend.next_id++; + this.parent_ids = [this.object_id]; + this._index = index; + this._fileInfo = currentFileInfo; + this.copyVisibilityInfo(visibilityInfo); + this.allowRoot = true; + switch (option) { + case 'all': + this.allowBefore = true; + this.allowAfter = true; + break; + default: + this.allowBefore = false; + this.allowAfter = false; + break; + } + this.setParent(this.selector, this); + }; + Extend.prototype = Object.assign(new Node(), { + type: 'Extend', + accept: function (visitor) { + this.selector = visitor.visit(this.selector); + }, + eval: function (context) { + return new Extend(this.selector.eval(context), this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + }, + clone: function (context) { + return new Extend(this.selector, this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + }, + // it concatenates (joins) all selectors in selector array + findSelfSelectors: function (selectors) { + var selfElements = [], i, selectorElements; + for (i = 0; i < selectors.length; i++) { + selectorElements = selectors[i].elements; + // duplicate the logic in genCSS function inside the selector node. + // future TODO - move both logics into the selector joiner visitor + if (i > 0 && selectorElements.length && selectorElements[0].combinator.value === '') { + selectorElements[0].combinator.value = ' '; + } + selfElements = selfElements.concat(selectors[i].elements); + } + this.selfSelectors = [new Selector(selfElements)]; + this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo()); + } + }); + Extend.next_id = 0; - var Definition = function (name, params, rules, condition, variadic, frames, visibilityInfo) { - this.name = name || 'anonymous mixin'; - this.selectors = [new Selector([new Element(null, name, false, this._index, this._fileInfo)])]; - this.params = params; - this.condition = condition; - this.variadic = variadic; - this.arity = params.length; - this.rules = rules; - this._lookups = {}; - var optionalParameters = []; - this.required = params.reduce(function (count, p) { - if (!p.name || (p.name && !p.value)) { - return count + 1; - } - else { - optionalParameters.push(p.name); - return count; - } - }, 0); - this.optionalParameters = optionalParameters; - this.frames = frames; - this.copyVisibilityInfo(visibilityInfo); - this.allowRoot = true; - }; - Definition.prototype = new Ruleset(); - Definition.prototype.accept = function (visitor) { - if (this.params && this.params.length) { - this.params = visitor.visitArray(this.params); - } - this.rules = visitor.visitArray(this.rules); - if (this.condition) { - this.condition = visitor.visit(this.condition); - } - }; - Definition.prototype.evalParams = function (context, mixinEnv, args, evaldArguments) { - /* jshint boss:true */ - var frame = new Ruleset(null, null); - var varargs; - var arg; - var params = copyArray(this.params); - var i; - var j; - var val; - var name; - var isNamedFound; - var argIndex; - var argsLength = 0; - if (mixinEnv.frames && mixinEnv.frames[0] && mixinEnv.frames[0].functionRegistry) { - frame.functionRegistry = mixinEnv.frames[0].functionRegistry.inherit(); - } - mixinEnv = new contexts.Eval(mixinEnv, [frame].concat(mixinEnv.frames)); - if (args) { - args = copyArray(args); - argsLength = args.length; - for (i = 0; i < argsLength; i++) { - arg = args[i]; - if (name = (arg && arg.name)) { - isNamedFound = false; - for (j = 0; j < params.length; j++) { - if (!evaldArguments[j] && name === params[j].name) { - evaldArguments[j] = arg.value.eval(context); - frame.prependRule(new Declaration(name, arg.value.eval(context))); - isNamedFound = true; - break; - } - } - if (isNamedFound) { - args.splice(i, 1); - i--; - continue; - } - else { - throw { type: 'Runtime', message: "Named argument for " + this.name + " " + args[i].name + " not found" }; - } - } - } - } - argIndex = 0; - for (i = 0; i < params.length; i++) { - if (evaldArguments[i]) { - continue; - } - arg = args && args[argIndex]; - if (name = params[i].name) { - if (params[i].variadic) { - varargs = []; - for (j = argIndex; j < argsLength; j++) { - varargs.push(args[j].value.eval(context)); - } - frame.prependRule(new Declaration(name, new Expression(varargs).eval(context))); - } - else { - val = arg && arg.value; - if (val) { - // This was a mixin call, pass in a detached ruleset of it's eval'd rules - if (Array.isArray(val)) { - val = new DetachedRuleset(new Ruleset('', val)); - } - else { - val = val.eval(context); - } - } - else if (params[i].value) { - val = params[i].value.eval(mixinEnv); - frame.resetCache(); - } - else { - throw { type: 'Runtime', message: "wrong number of arguments for " + this.name + " (" + argsLength + " for " + this.arity + ")" }; - } - frame.prependRule(new Declaration(name, val)); - evaldArguments[i] = val; - } - } - if (params[i].variadic && args) { - for (j = argIndex; j < argsLength; j++) { - evaldArguments[j] = args[j].value.eval(context); - } - } - argIndex++; - } - return frame; - }; - Definition.prototype.makeImportant = function () { - var rules = !this.rules ? this.rules : this.rules.map(function (r) { - if (r.makeImportant) { - return r.makeImportant(true); - } - else { - return r; - } - }); - var result = new Definition(this.name, this.params, rules, this.condition, this.variadic, this.frames); - return result; - }; - Definition.prototype.eval = function (context) { - return new Definition(this.name, this.params, this.rules, this.condition, this.variadic, this.frames || copyArray(context.frames)); - }; - Definition.prototype.evalCall = function (context, args, important) { - var _arguments = []; - var mixinFrames = this.frames ? this.frames.concat(context.frames) : context.frames; - var frame = this.evalParams(context, new contexts.Eval(context, mixinFrames), args, _arguments); - var rules; - var ruleset; - frame.prependRule(new Declaration('@arguments', new Expression(_arguments).eval(context))); - rules = copyArray(this.rules); - ruleset = new Ruleset(null, rules); - ruleset.originalRuleset = this; - ruleset = ruleset.eval(new contexts.Eval(context, [this, frame].concat(mixinFrames))); - if (important) { - ruleset = ruleset.makeImportant(); - } - return ruleset; - }; - Definition.prototype.matchCondition = function (args, context) { - if (this.condition && !this.condition.eval(new contexts.Eval(context, [this.evalParams(context, /* the parameter variables */ new contexts.Eval(context, this.frames ? this.frames.concat(context.frames) : context.frames), args, [])] - .concat(this.frames || []) // the parent namespace/mixin frames - .concat(context.frames)))) { // the current environment frames - return false; - } - return true; - }; - Definition.prototype.matchArgs = function (args, context) { - var allArgsCnt = (args && args.length) || 0; - var len; - var optionalParameters = this.optionalParameters; - var requiredArgsCnt = !args ? 0 : args.reduce(function (count, p) { - if (optionalParameters.indexOf(p.name) < 0) { - return count + 1; - } - else { - return count; - } - }, 0); - if (!this.variadic) { - if (requiredArgsCnt < this.required) { - return false; - } - if (allArgsCnt > this.params.length) { - return false; - } - } - else { - if (requiredArgsCnt < (this.required - 1)) { - return false; - } - } - // check patterns - len = Math.min(requiredArgsCnt, this.arity); - for (var i = 0; i < len; i++) { - if (!this.params[i].name && !this.params[i].variadic) { - if (args[i].value.eval(context).toCSS() != this.params[i].value.eval(context).toCSS()) { - return false; - } - } - } - return true; - }; - Definition.prototype.type = 'MixinDefinition'; - Definition.prototype.evalFirst = true; + var VariableCall = function (variable, index, currentFileInfo) { + this.variable = variable; + this._index = index; + this._fileInfo = currentFileInfo; + this.allowRoot = true; + }; + VariableCall.prototype = Object.assign(new Node(), { + type: 'VariableCall', + eval: function (context) { + var rules; + var detachedRuleset = new Variable(this.variable, this.getIndex(), this.fileInfo()).eval(context); + var error = new LessError({ message: "Could not evaluate variable call " + this.variable }); + if (!detachedRuleset.ruleset) { + if (detachedRuleset.rules) { + rules = detachedRuleset; + } + else if (Array.isArray(detachedRuleset)) { + rules = new Ruleset('', detachedRuleset); + } + else if (Array.isArray(detachedRuleset.value)) { + rules = new Ruleset('', detachedRuleset.value); + } + else { + throw error; + } + detachedRuleset = new DetachedRuleset(rules); + } + if (detachedRuleset.ruleset) { + return detachedRuleset.callEval(context); + } + throw error; + } + }); - var MixinCall = function (elements, args, index, currentFileInfo, important) { - this.selector = new Selector(elements); - this.arguments = args || []; - this._index = index; - this._fileInfo = currentFileInfo; - this.important = important; - this.allowRoot = true; - this.setParent(this.selector, this); - }; - MixinCall.prototype = new Node(); - MixinCall.prototype.accept = function (visitor) { - if (this.selector) { - this.selector = visitor.visit(this.selector); - } - if (this.arguments.length) { - this.arguments = visitor.visitArray(this.arguments); - } - }; - MixinCall.prototype.eval = function (context) { - var mixins; - var mixin; - var mixinPath; - var args = []; - var arg; - var argValue; - var rules = []; - var match = false; - var i; - var m; - var f; - var isRecursive; - var isOneFound; - var candidates = []; - var candidate; - var conditionResult = []; - var defaultResult; - var defFalseEitherCase = -1; - var defNone = 0; - var defTrue = 1; - var defFalse = 2; - var count; - var originalRuleset; - var noArgumentsFilter; - this.selector = this.selector.eval(context); - function calcDefGroup(mixin, mixinPath) { - var f; - var p; - var namespace; - for (f = 0; f < 2; f++) { - conditionResult[f] = true; - defaultFunc.value(f); - for (p = 0; p < mixinPath.length && conditionResult[f]; p++) { - namespace = mixinPath[p]; - if (namespace.matchCondition) { - conditionResult[f] = conditionResult[f] && namespace.matchCondition(null, context); - } - } - if (mixin.matchCondition) { - conditionResult[f] = conditionResult[f] && mixin.matchCondition(args, context); - } - } - if (conditionResult[0] || conditionResult[1]) { - if (conditionResult[0] != conditionResult[1]) { - return conditionResult[1] ? - defTrue : defFalse; - } - return defNone; - } - return defFalseEitherCase; - } - for (i = 0; i < this.arguments.length; i++) { - arg = this.arguments[i]; - argValue = arg.value.eval(context); - if (arg.expand && Array.isArray(argValue.value)) { - argValue = argValue.value; - for (m = 0; m < argValue.length; m++) { - args.push({ value: argValue[m] }); - } - } - else { - args.push({ name: arg.name, value: argValue }); - } - } - noArgumentsFilter = function (rule) { return rule.matchArgs(null, context); }; - for (i = 0; i < context.frames.length; i++) { - if ((mixins = context.frames[i].find(this.selector, null, noArgumentsFilter)).length > 0) { - isOneFound = true; - // To make `default()` function independent of definition order we have two "subpasses" here. - // At first we evaluate each guard *twice* (with `default() == true` and `default() == false`), - // and build candidate list with corresponding flags. Then, when we know all possible matches, - // we make a final decision. - for (m = 0; m < mixins.length; m++) { - mixin = mixins[m].rule; - mixinPath = mixins[m].path; - isRecursive = false; - for (f = 0; f < context.frames.length; f++) { - if ((!(mixin instanceof Definition)) && mixin === (context.frames[f].originalRuleset || context.frames[f])) { - isRecursive = true; - break; - } - } - if (isRecursive) { - continue; - } - if (mixin.matchArgs(args, context)) { - candidate = { mixin: mixin, group: calcDefGroup(mixin, mixinPath) }; - if (candidate.group !== defFalseEitherCase) { - candidates.push(candidate); - } - match = true; - } - } - defaultFunc.reset(); - count = [0, 0, 0]; - for (m = 0; m < candidates.length; m++) { - count[candidates[m].group]++; - } - if (count[defNone] > 0) { - defaultResult = defFalse; - } - else { - defaultResult = defTrue; - if ((count[defTrue] + count[defFalse]) > 1) { - throw { type: 'Runtime', message: "Ambiguous use of `default()` found when matching for `" + this.format(args) + "`", index: this.getIndex(), filename: this.fileInfo().filename }; - } - } - for (m = 0; m < candidates.length; m++) { - candidate = candidates[m].group; - if ((candidate === defNone) || (candidate === defaultResult)) { - try { - mixin = candidates[m].mixin; - if (!(mixin instanceof Definition)) { - originalRuleset = mixin.originalRuleset || mixin; - mixin = new Definition('', [], mixin.rules, null, false, null, originalRuleset.visibilityInfo()); - mixin.originalRuleset = originalRuleset; - } - var newRules = mixin.evalCall(context, args, this.important).rules; - this._setVisibilityToReplacement(newRules); - Array.prototype.push.apply(rules, newRules); - } - catch (e) { - throw { message: e.message, index: this.getIndex(), filename: this.fileInfo().filename, stack: e.stack }; - } - } - } - if (match) { - return rules; - } - } - } - if (isOneFound) { - throw { type: 'Runtime', message: "No matching definition was found for `" + this.format(args) + "`", index: this.getIndex(), filename: this.fileInfo().filename }; - } - else { - throw { type: 'Name', message: this.selector.toCSS().trim() + " is undefined", index: this.getIndex(), filename: this.fileInfo().filename }; - } - }; - MixinCall.prototype._setVisibilityToReplacement = function (replacement) { - var i; - var rule; - if (this.blocksVisibility()) { - for (i = 0; i < replacement.length; i++) { - rule = replacement[i]; - rule.addVisibilityBlock(); - } - } - }; - MixinCall.prototype.format = function (args) { - return this.selector.toCSS().trim() + "(" + (args ? args.map(function (a) { - var argValue = ''; - if (a.name) { - argValue += a.name + ":"; - } - if (a.value.toCSS) { - argValue += a.value.toCSS(); - } - else { - argValue += '???'; - } - return argValue; - }).join(', ') : '') + ")"; - }; - MixinCall.prototype.type = 'MixinCall'; + var NamespaceValue = function (ruleCall, lookups, index, fileInfo) { + this.value = ruleCall; + this.lookups = lookups; + this._index = index; + this._fileInfo = fileInfo; + }; + NamespaceValue.prototype = Object.assign(new Node(), { + type: 'NamespaceValue', + eval: function (context) { + var i, name, rules = this.value.eval(context); + for (i = 0; i < this.lookups.length; i++) { + name = this.lookups[i]; + /** + * Eval'd DRs return rulesets. + * Eval'd mixins return rules, so let's make a ruleset if we need it. + * We need to do this because of late parsing of values + */ + if (Array.isArray(rules)) { + rules = new Ruleset([new Selector()], rules); + } + if (name === '') { + rules = rules.lastDeclaration(); + } + else if (name.charAt(0) === '@') { + if (name.charAt(1) === '@') { + name = "@" + new Variable(name.substr(1)).eval(context).value; + } + if (rules.variables) { + rules = rules.variable(name); + } + if (!rules) { + throw { type: 'Name', message: "variable " + name + " not found", filename: this.fileInfo().filename, + index: this.getIndex() }; + } + } + else { + if (name.substring(0, 2) === '$@') { + name = "$" + new Variable(name.substr(1)).eval(context).value; + } + else { + name = name.charAt(0) === '$' ? name : "$" + name; + } + if (rules.properties) { + rules = rules.property(name); + } + if (!rules) { + throw { type: 'Name', message: "property \"" + name.substr(1) + "\" not found", filename: this.fileInfo().filename, + index: this.getIndex() }; + } + // Properties are an array of values, since a ruleset can have multiple props. + // We pick the last one (the "cascaded" value) + rules = rules[rules.length - 1]; + } + if (rules.value) { + rules = rules.eval(context).value; + } + if (rules.ruleset) { + rules = rules.ruleset.eval(context); + } + } + return rules; + } + }); - var tree = { - Node: Node, Color: Color, AtRule: AtRule, DetachedRuleset: DetachedRuleset, Operation: Operation, - Dimension: Dimension, Unit: Unit, Keyword: Keyword, Variable: Variable, Property: Property, - Ruleset: Ruleset, Element: Element, Attribute: Attribute, Combinator: Combinator, Selector: Selector, - Quoted: Quoted, Expression: Expression, Declaration: Declaration, Call: Call, URL: URL, Import: Import, - Comment: Comment, Anonymous: Anonymous, Value: Value, JavaScript: JavaScript, Assignment: Assignment, - Condition: Condition, Paren: Paren, Media: Media, UnicodeDescriptor: UnicodeDescriptor, Negative: Negative, - Extend: Extend, VariableCall: VariableCall, NamespaceValue: NamespaceValue, - mixin: { - Call: MixinCall, - Definition: Definition - } - }; + var Definition = function (name, params, rules, condition, variadic, frames, visibilityInfo) { + this.name = name || 'anonymous mixin'; + this.selectors = [new Selector([new Element(null, name, false, this._index, this._fileInfo)])]; + this.params = params; + this.condition = condition; + this.variadic = variadic; + this.arity = params.length; + this.rules = rules; + this._lookups = {}; + var optionalParameters = []; + this.required = params.reduce(function (count, p) { + if (!p.name || (p.name && !p.value)) { + return count + 1; + } + else { + optionalParameters.push(p.name); + return count; + } + }, 0); + this.optionalParameters = optionalParameters; + this.frames = frames; + this.copyVisibilityInfo(visibilityInfo); + this.allowRoot = true; + }; + Definition.prototype = Object.assign(new Ruleset(), { + type: 'MixinDefinition', + evalFirst: true, + accept: function (visitor) { + if (this.params && this.params.length) { + this.params = visitor.visitArray(this.params); + } + this.rules = visitor.visitArray(this.rules); + if (this.condition) { + this.condition = visitor.visit(this.condition); + } + }, + evalParams: function (context, mixinEnv, args, evaldArguments) { + /* jshint boss:true */ + var frame = new Ruleset(null, null); + var varargs; + var arg; + var params = copyArray(this.params); + var i; + var j; + var val; + var name; + var isNamedFound; + var argIndex; + var argsLength = 0; + if (mixinEnv.frames && mixinEnv.frames[0] && mixinEnv.frames[0].functionRegistry) { + frame.functionRegistry = mixinEnv.frames[0].functionRegistry.inherit(); + } + mixinEnv = new contexts.Eval(mixinEnv, [frame].concat(mixinEnv.frames)); + if (args) { + args = copyArray(args); + argsLength = args.length; + for (i = 0; i < argsLength; i++) { + arg = args[i]; + if (name = (arg && arg.name)) { + isNamedFound = false; + for (j = 0; j < params.length; j++) { + if (!evaldArguments[j] && name === params[j].name) { + evaldArguments[j] = arg.value.eval(context); + frame.prependRule(new Declaration(name, arg.value.eval(context))); + isNamedFound = true; + break; + } + } + if (isNamedFound) { + args.splice(i, 1); + i--; + continue; + } + else { + throw { type: 'Runtime', message: "Named argument for " + this.name + " " + args[i].name + " not found" }; + } + } + } + } + argIndex = 0; + for (i = 0; i < params.length; i++) { + if (evaldArguments[i]) { + continue; + } + arg = args && args[argIndex]; + if (name = params[i].name) { + if (params[i].variadic) { + varargs = []; + for (j = argIndex; j < argsLength; j++) { + varargs.push(args[j].value.eval(context)); + } + frame.prependRule(new Declaration(name, new Expression(varargs).eval(context))); + } + else { + val = arg && arg.value; + if (val) { + // This was a mixin call, pass in a detached ruleset of it's eval'd rules + if (Array.isArray(val)) { + val = new DetachedRuleset(new Ruleset('', val)); + } + else { + val = val.eval(context); + } + } + else if (params[i].value) { + val = params[i].value.eval(mixinEnv); + frame.resetCache(); + } + else { + throw { type: 'Runtime', message: "wrong number of arguments for " + this.name + " (" + argsLength + " for " + this.arity + ")" }; + } + frame.prependRule(new Declaration(name, val)); + evaldArguments[i] = val; + } + } + if (params[i].variadic && args) { + for (j = argIndex; j < argsLength; j++) { + evaldArguments[j] = args[j].value.eval(context); + } + } + argIndex++; + } + return frame; + }, + makeImportant: function () { + var rules = !this.rules ? this.rules : this.rules.map(function (r) { + if (r.makeImportant) { + return r.makeImportant(true); + } + else { + return r; + } + }); + var result = new Definition(this.name, this.params, rules, this.condition, this.variadic, this.frames); + return result; + }, + eval: function (context) { + return new Definition(this.name, this.params, this.rules, this.condition, this.variadic, this.frames || copyArray(context.frames)); + }, + evalCall: function (context, args, important) { + var _arguments = []; + var mixinFrames = this.frames ? this.frames.concat(context.frames) : context.frames; + var frame = this.evalParams(context, new contexts.Eval(context, mixinFrames), args, _arguments); + var rules; + var ruleset; + frame.prependRule(new Declaration('@arguments', new Expression(_arguments).eval(context))); + rules = copyArray(this.rules); + ruleset = new Ruleset(null, rules); + ruleset.originalRuleset = this; + ruleset = ruleset.eval(new contexts.Eval(context, [this, frame].concat(mixinFrames))); + if (important) { + ruleset = ruleset.makeImportant(); + } + return ruleset; + }, + matchCondition: function (args, context) { + if (this.condition && !this.condition.eval(new contexts.Eval(context, [this.evalParams(context, /* the parameter variables */ new contexts.Eval(context, this.frames ? this.frames.concat(context.frames) : context.frames), args, [])] + .concat(this.frames || []) // the parent namespace/mixin frames + .concat(context.frames)))) { // the current environment frames + return false; + } + return true; + }, + matchArgs: function (args, context) { + var allArgsCnt = (args && args.length) || 0; + var len; + var optionalParameters = this.optionalParameters; + var requiredArgsCnt = !args ? 0 : args.reduce(function (count, p) { + if (optionalParameters.indexOf(p.name) < 0) { + return count + 1; + } + else { + return count; + } + }, 0); + if (!this.variadic) { + if (requiredArgsCnt < this.required) { + return false; + } + if (allArgsCnt > this.params.length) { + return false; + } + } + else { + if (requiredArgsCnt < (this.required - 1)) { + return false; + } + } + // check patterns + len = Math.min(requiredArgsCnt, this.arity); + for (var i = 0; i < len; i++) { + if (!this.params[i].name && !this.params[i].variadic) { + if (args[i].value.eval(context).toCSS() != this.params[i].value.eval(context).toCSS()) { + return false; + } + } + } + return true; + } + }); - var logger = { - error: function (msg) { - this._fireEvent('error', msg); - }, - warn: function (msg) { - this._fireEvent('warn', msg); - }, - info: function (msg) { - this._fireEvent('info', msg); - }, - debug: function (msg) { - this._fireEvent('debug', msg); - }, - addListener: function (listener) { - this._listeners.push(listener); - }, - removeListener: function (listener) { - for (var i = 0; i < this._listeners.length; i++) { - if (this._listeners[i] === listener) { - this._listeners.splice(i, 1); - return; - } - } - }, - _fireEvent: function (type, msg) { - for (var i = 0; i < this._listeners.length; i++) { - var logFunction = this._listeners[i][type]; - if (logFunction) { - logFunction(msg); - } - } - }, - _listeners: [] - }; + var MixinCall = function (elements, args, index, currentFileInfo, important) { + this.selector = new Selector(elements); + this.arguments = args || []; + this._index = index; + this._fileInfo = currentFileInfo; + this.important = important; + this.allowRoot = true; + this.setParent(this.selector, this); + }; + MixinCall.prototype = Object.assign(new Node(), { + type: 'MixinCall', + accept: function (visitor) { + if (this.selector) { + this.selector = visitor.visit(this.selector); + } + if (this.arguments.length) { + this.arguments = visitor.visitArray(this.arguments); + } + }, + eval: function (context) { + var mixins; + var mixin; + var mixinPath; + var args = []; + var arg; + var argValue; + var rules = []; + var match = false; + var i; + var m; + var f; + var isRecursive; + var isOneFound; + var candidates = []; + var candidate; + var conditionResult = []; + var defaultResult; + var defFalseEitherCase = -1; + var defNone = 0; + var defTrue = 1; + var defFalse = 2; + var count; + var originalRuleset; + var noArgumentsFilter; + this.selector = this.selector.eval(context); + function calcDefGroup(mixin, mixinPath) { + var f, p, namespace; + for (f = 0; f < 2; f++) { + conditionResult[f] = true; + defaultFunc.value(f); + for (p = 0; p < mixinPath.length && conditionResult[f]; p++) { + namespace = mixinPath[p]; + if (namespace.matchCondition) { + conditionResult[f] = conditionResult[f] && namespace.matchCondition(null, context); + } + } + if (mixin.matchCondition) { + conditionResult[f] = conditionResult[f] && mixin.matchCondition(args, context); + } + } + if (conditionResult[0] || conditionResult[1]) { + if (conditionResult[0] != conditionResult[1]) { + return conditionResult[1] ? + defTrue : defFalse; + } + return defNone; + } + return defFalseEitherCase; + } + for (i = 0; i < this.arguments.length; i++) { + arg = this.arguments[i]; + argValue = arg.value.eval(context); + if (arg.expand && Array.isArray(argValue.value)) { + argValue = argValue.value; + for (m = 0; m < argValue.length; m++) { + args.push({ value: argValue[m] }); + } + } + else { + args.push({ name: arg.name, value: argValue }); + } + } + noArgumentsFilter = function (rule) { return rule.matchArgs(null, context); }; + for (i = 0; i < context.frames.length; i++) { + if ((mixins = context.frames[i].find(this.selector, null, noArgumentsFilter)).length > 0) { + isOneFound = true; + // To make `default()` function independent of definition order we have two "subpasses" here. + // At first we evaluate each guard *twice* (with `default() == true` and `default() == false`), + // and build candidate list with corresponding flags. Then, when we know all possible matches, + // we make a final decision. + for (m = 0; m < mixins.length; m++) { + mixin = mixins[m].rule; + mixinPath = mixins[m].path; + isRecursive = false; + for (f = 0; f < context.frames.length; f++) { + if ((!(mixin instanceof Definition)) && mixin === (context.frames[f].originalRuleset || context.frames[f])) { + isRecursive = true; + break; + } + } + if (isRecursive) { + continue; + } + if (mixin.matchArgs(args, context)) { + candidate = { mixin: mixin, group: calcDefGroup(mixin, mixinPath) }; + if (candidate.group !== defFalseEitherCase) { + candidates.push(candidate); + } + match = true; + } + } + defaultFunc.reset(); + count = [0, 0, 0]; + for (m = 0; m < candidates.length; m++) { + count[candidates[m].group]++; + } + if (count[defNone] > 0) { + defaultResult = defFalse; + } + else { + defaultResult = defTrue; + if ((count[defTrue] + count[defFalse]) > 1) { + throw { type: 'Runtime', message: "Ambiguous use of `default()` found when matching for `" + this.format(args) + "`", index: this.getIndex(), filename: this.fileInfo().filename }; + } + } + for (m = 0; m < candidates.length; m++) { + candidate = candidates[m].group; + if ((candidate === defNone) || (candidate === defaultResult)) { + try { + mixin = candidates[m].mixin; + if (!(mixin instanceof Definition)) { + originalRuleset = mixin.originalRuleset || mixin; + mixin = new Definition('', [], mixin.rules, null, false, null, originalRuleset.visibilityInfo()); + mixin.originalRuleset = originalRuleset; + } + var newRules = mixin.evalCall(context, args, this.important).rules; + this._setVisibilityToReplacement(newRules); + Array.prototype.push.apply(rules, newRules); + } + catch (e) { + throw { message: e.message, index: this.getIndex(), filename: this.fileInfo().filename, stack: e.stack }; + } + } + } + if (match) { + return rules; + } + } + } + if (isOneFound) { + throw { type: 'Runtime', message: "No matching definition was found for `" + this.format(args) + "`", index: this.getIndex(), filename: this.fileInfo().filename }; + } + else { + throw { type: 'Name', message: this.selector.toCSS().trim() + " is undefined", index: this.getIndex(), filename: this.fileInfo().filename }; + } + }, + _setVisibilityToReplacement: function (replacement) { + var i, rule; + if (this.blocksVisibility()) { + for (i = 0; i < replacement.length; i++) { + rule = replacement[i]; + rule.addVisibilityBlock(); + } + } + }, + format: function (args) { + return this.selector.toCSS().trim() + "(" + (args ? args.map(function (a) { + var argValue = ''; + if (a.name) { + argValue += a.name + ":"; + } + if (a.value.toCSS) { + argValue += a.value.toCSS(); + } + else { + argValue += '???'; + } + return argValue; + }).join(', ') : '') + ")"; + } + }); - /** - * @todo Document why this abstraction exists, and the relationship between - * environment, file managers, and plugin manager - */ - var environment = /** @class */ (function () { - function environment(externalEnvironment, fileManagers) { - this.fileManagers = fileManagers || []; - externalEnvironment = externalEnvironment || {}; - var optionalFunctions = ['encodeBase64', 'mimeLookup', 'charsetLookup', 'getSourceMapGenerator']; - var requiredFunctions = []; - var functions = requiredFunctions.concat(optionalFunctions); - for (var i = 0; i < functions.length; i++) { - var propName = functions[i]; - var environmentFunc = externalEnvironment[propName]; - if (environmentFunc) { - this[propName] = environmentFunc.bind(externalEnvironment); - } - else if (i < requiredFunctions.length) { - this.warn("missing required function in environment - " + propName); - } - } - } - environment.prototype.getFileManager = function (filename, currentDirectory, options, environment, isSync) { - if (!filename) { - logger.warn('getFileManager called with no filename.. Please report this issue. continuing.'); - } - if (currentDirectory == null) { - logger.warn('getFileManager called with null directory.. Please report this issue. continuing.'); - } - var fileManagers = this.fileManagers; - if (options.pluginManager) { - fileManagers = [].concat(fileManagers).concat(options.pluginManager.getFileManagers()); - } - for (var i = fileManagers.length - 1; i >= 0; i--) { - var fileManager = fileManagers[i]; - if (fileManager[isSync ? 'supportsSync' : 'supports'](filename, currentDirectory, options, environment)) { - return fileManager; - } - } - return null; - }; - environment.prototype.addFileManager = function (fileManager) { - this.fileManagers.push(fileManager); - }; - environment.prototype.clearFileManagers = function () { - this.fileManagers = []; - }; - return environment; - }()); + var tree = { + Node: Node, Color: Color, AtRule: AtRule, DetachedRuleset: DetachedRuleset, Operation: Operation, + Dimension: Dimension, Unit: Unit, Keyword: Keyword, Variable: Variable, Property: Property, + Ruleset: Ruleset, Element: Element, Attribute: Attribute, Combinator: Combinator, Selector: Selector, + Quoted: Quoted, Expression: Expression, Declaration: Declaration, Call: Call, URL: URL, Import: Import, + Comment: Comment, Anonymous: Anonymous, Value: Value, JavaScript: JavaScript, Assignment: Assignment, + Condition: Condition, Paren: Paren, Media: Media, UnicodeDescriptor: UnicodeDescriptor, Negative: Negative, + Extend: Extend, VariableCall: VariableCall, NamespaceValue: NamespaceValue, + mixin: { + Call: MixinCall, + Definition: Definition + } + }; - var AbstractFileManager = /** @class */ (function () { - function AbstractFileManager() { - } - AbstractFileManager.prototype.getPath = function (filename) { - var j = filename.lastIndexOf('?'); - if (j > 0) { - filename = filename.slice(0, j); - } - j = filename.lastIndexOf('/'); - if (j < 0) { - j = filename.lastIndexOf('\\'); - } - if (j < 0) { - return ''; - } - return filename.slice(0, j + 1); - }; - AbstractFileManager.prototype.tryAppendExtension = function (path, ext) { - return /(\.[a-z]*$)|([\?;].*)$/.test(path) ? path : path + ext; - }; - AbstractFileManager.prototype.tryAppendLessExtension = function (path) { - return this.tryAppendExtension(path, '.less'); - }; - AbstractFileManager.prototype.supportsSync = function () { return false; }; - AbstractFileManager.prototype.alwaysMakePathsAbsolute = function () { return false; }; - AbstractFileManager.prototype.isPathAbsolute = function (filename) { - return (/^(?:[a-z-]+:|\/|\\|#)/i).test(filename); - }; - // TODO: pull out / replace? - AbstractFileManager.prototype.join = function (basePath, laterPath) { - if (!basePath) { - return laterPath; - } - return basePath + laterPath; - }; - AbstractFileManager.prototype.pathDiff = function (url, baseUrl) { - // diff between two paths to create a relative path - var urlParts = this.extractUrlParts(url); - var baseUrlParts = this.extractUrlParts(baseUrl); - var i; - var max; - var urlDirectories; - var baseUrlDirectories; - var diff = ''; - if (urlParts.hostPart !== baseUrlParts.hostPart) { - return ''; - } - max = Math.max(baseUrlParts.directories.length, urlParts.directories.length); - for (i = 0; i < max; i++) { - if (baseUrlParts.directories[i] !== urlParts.directories[i]) { - break; - } - } - baseUrlDirectories = baseUrlParts.directories.slice(i); - urlDirectories = urlParts.directories.slice(i); - for (i = 0; i < baseUrlDirectories.length - 1; i++) { - diff += '../'; - } - for (i = 0; i < urlDirectories.length - 1; i++) { - diff += urlDirectories[i] + "/"; - } - return diff; - }; - // helper function, not part of API - AbstractFileManager.prototype.extractUrlParts = function (url, baseUrl) { - // urlParts[1] = protocol://hostname/ OR / - // urlParts[2] = / if path relative to host base - // urlParts[3] = directories - // urlParts[4] = filename - // urlParts[5] = parameters - var urlPartsRegex = /^((?:[a-z-]+:)?\/{2}(?:[^\/\?#]*\/)|([\/\\]))?((?:[^\/\\\?#]*[\/\\])*)([^\/\\\?#]*)([#\?].*)?$/i; - var urlParts = url.match(urlPartsRegex); - var returner = {}; - var rawDirectories = []; - var directories = []; - var i; - var baseUrlParts; - if (!urlParts) { - throw new Error("Could not parse sheet href - '" + url + "'"); - } - // Stylesheets in IE don't always return the full path - if (baseUrl && (!urlParts[1] || urlParts[2])) { - baseUrlParts = baseUrl.match(urlPartsRegex); - if (!baseUrlParts) { - throw new Error("Could not parse page url - '" + baseUrl + "'"); - } - urlParts[1] = urlParts[1] || baseUrlParts[1] || ''; - if (!urlParts[2]) { - urlParts[3] = baseUrlParts[3] + urlParts[3]; - } - } - if (urlParts[3]) { - rawDirectories = urlParts[3].replace(/\\/g, '/').split('/'); - // collapse '..' and skip '.' - for (i = 0; i < rawDirectories.length; i++) { - if (rawDirectories[i] === '..') { - directories.pop(); - } - else if (rawDirectories[i] !== '.') { - directories.push(rawDirectories[i]); - } - } - } - returner.hostPart = urlParts[1]; - returner.directories = directories; - returner.rawPath = (urlParts[1] || '') + rawDirectories.join('/'); - returner.path = (urlParts[1] || '') + directories.join('/'); - returner.filename = urlParts[4]; - returner.fileUrl = returner.path + (urlParts[4] || ''); - returner.url = returner.fileUrl + (urlParts[5] || ''); - return returner; - }; - return AbstractFileManager; - }()); + var AbstractFileManager = /** @class */ (function () { + function AbstractFileManager() { + } + AbstractFileManager.prototype.getPath = function (filename) { + var j = filename.lastIndexOf('?'); + if (j > 0) { + filename = filename.slice(0, j); + } + j = filename.lastIndexOf('/'); + if (j < 0) { + j = filename.lastIndexOf('\\'); + } + if (j < 0) { + return ''; + } + return filename.slice(0, j + 1); + }; + AbstractFileManager.prototype.tryAppendExtension = function (path, ext) { + return /(\.[a-z]*$)|([\?;].*)$/.test(path) ? path : path + ext; + }; + AbstractFileManager.prototype.tryAppendLessExtension = function (path) { + return this.tryAppendExtension(path, '.less'); + }; + AbstractFileManager.prototype.supportsSync = function () { + return false; + }; + AbstractFileManager.prototype.alwaysMakePathsAbsolute = function () { + return false; + }; + AbstractFileManager.prototype.isPathAbsolute = function (filename) { + return (/^(?:[a-z-]+:|\/|\\|#)/i).test(filename); + }; + // TODO: pull out / replace? + AbstractFileManager.prototype.join = function (basePath, laterPath) { + if (!basePath) { + return laterPath; + } + return basePath + laterPath; + }; + AbstractFileManager.prototype.pathDiff = function (url, baseUrl) { + // diff between two paths to create a relative path + var urlParts = this.extractUrlParts(url); + var baseUrlParts = this.extractUrlParts(baseUrl); + var i; + var max; + var urlDirectories; + var baseUrlDirectories; + var diff = ''; + if (urlParts.hostPart !== baseUrlParts.hostPart) { + return ''; + } + max = Math.max(baseUrlParts.directories.length, urlParts.directories.length); + for (i = 0; i < max; i++) { + if (baseUrlParts.directories[i] !== urlParts.directories[i]) { + break; + } + } + baseUrlDirectories = baseUrlParts.directories.slice(i); + urlDirectories = urlParts.directories.slice(i); + for (i = 0; i < baseUrlDirectories.length - 1; i++) { + diff += '../'; + } + for (i = 0; i < urlDirectories.length - 1; i++) { + diff += urlDirectories[i] + "/"; + } + return diff; + }; + // helper function, not part of API + AbstractFileManager.prototype.extractUrlParts = function (url, baseUrl) { + // urlParts[1] = protocol://hostname/ OR / + // urlParts[2] = / if path relative to host base + // urlParts[3] = directories + // urlParts[4] = filename + // urlParts[5] = parameters + var urlPartsRegex = /^((?:[a-z-]+:)?\/{2}(?:[^\/\?#]*\/)|([\/\\]))?((?:[^\/\\\?#]*[\/\\])*)([^\/\\\?#]*)([#\?].*)?$/i; + var urlParts = url.match(urlPartsRegex); + var returner = {}; + var rawDirectories = []; + var directories = []; + var i; + var baseUrlParts; + if (!urlParts) { + throw new Error("Could not parse sheet href - '" + url + "'"); + } + // Stylesheets in IE don't always return the full path + if (baseUrl && (!urlParts[1] || urlParts[2])) { + baseUrlParts = baseUrl.match(urlPartsRegex); + if (!baseUrlParts) { + throw new Error("Could not parse page url - '" + baseUrl + "'"); + } + urlParts[1] = urlParts[1] || baseUrlParts[1] || ''; + if (!urlParts[2]) { + urlParts[3] = baseUrlParts[3] + urlParts[3]; + } + } + if (urlParts[3]) { + rawDirectories = urlParts[3].replace(/\\/g, '/').split('/'); + // collapse '..' and skip '.' + for (i = 0; i < rawDirectories.length; i++) { + if (rawDirectories[i] === '..') { + directories.pop(); + } + else if (rawDirectories[i] !== '.') { + directories.push(rawDirectories[i]); + } + } + } + returner.hostPart = urlParts[1]; + returner.directories = directories; + returner.rawPath = (urlParts[1] || '') + rawDirectories.join('/'); + returner.path = (urlParts[1] || '') + directories.join('/'); + returner.filename = urlParts[4]; + returner.fileUrl = returner.path + (urlParts[4] || ''); + returner.url = returner.fileUrl + (urlParts[5] || ''); + return returner; + }; + return AbstractFileManager; + }()); - var AbstractPluginLoader = /** @class */ (function () { - function AbstractPluginLoader() { - // Implemented by Node.js plugin loader - this.require = function () { return null; }; - } - AbstractPluginLoader.prototype.evalPlugin = function (contents, context, imports, pluginOptions, fileInfo) { - var loader; - var registry; - var pluginObj; - var localModule; - var pluginManager; - var filename; - var result; - pluginManager = context.pluginManager; - if (fileInfo) { - if (typeof fileInfo === 'string') { - filename = fileInfo; - } - else { - filename = fileInfo.filename; - } - } - var shortname = (new this.less.FileManager()).extractUrlParts(filename).filename; - if (filename) { - pluginObj = pluginManager.get(filename); - if (pluginObj) { - result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); - if (result) { - return result; - } - try { - if (pluginObj.use) { - pluginObj.use.call(this.context, pluginObj); - } - } - catch (e) { - e.message = e.message || 'Error during @plugin call'; - return new LessError(e, imports, filename); - } - return pluginObj; - } - } - localModule = { - exports: {}, - pluginManager: pluginManager, - fileInfo: fileInfo - }; - registry = functionRegistry.create(); - var registerPlugin = function (obj) { - pluginObj = obj; - }; - try { - loader = new Function('module', 'require', 'registerPlugin', 'functions', 'tree', 'less', 'fileInfo', contents); - loader(localModule, this.require(filename), registerPlugin, registry, this.less.tree, this.less, fileInfo); - } - catch (e) { - return new LessError(e, imports, filename); - } - if (!pluginObj) { - pluginObj = localModule.exports; - } - pluginObj = this.validatePlugin(pluginObj, filename, shortname); - if (pluginObj instanceof LessError) { - return pluginObj; - } - if (pluginObj) { - pluginObj.imports = imports; - pluginObj.filename = filename; - // For < 3.x (or unspecified minVersion) - setOptions() before install() - if (!pluginObj.minVersion || this.compareVersion('3.0.0', pluginObj.minVersion) < 0) { - result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); - if (result) { - return result; - } - } - // Run on first load - pluginManager.addPlugin(pluginObj, fileInfo.filename, registry); - pluginObj.functions = registry.getLocalFunctions(); - // Need to call setOptions again because the pluginObj might have functions - result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); - if (result) { - return result; - } - // Run every @plugin call - try { - if (pluginObj.use) { - pluginObj.use.call(this.context, pluginObj); - } - } - catch (e) { - e.message = e.message || 'Error during @plugin call'; - return new LessError(e, imports, filename); - } - } - else { - return new LessError({ message: 'Not a valid plugin' }, imports, filename); - } - return pluginObj; - }; - AbstractPluginLoader.prototype.trySetOptions = function (plugin, filename, name, options) { - if (options && !plugin.setOptions) { - return new LessError({ - message: "Options have been provided but the plugin " + name + " does not support any options." - }); - } - try { - plugin.setOptions && plugin.setOptions(options); - } - catch (e) { - return new LessError(e); - } - }; - AbstractPluginLoader.prototype.validatePlugin = function (plugin, filename, name) { - if (plugin) { - // support plugins being a function - // so that the plugin can be more usable programmatically - if (typeof plugin === 'function') { - plugin = new plugin(); - } - if (plugin.minVersion) { - if (this.compareVersion(plugin.minVersion, this.less.version) < 0) { - return new LessError({ - message: "Plugin " + name + " requires version " + this.versionToString(plugin.minVersion) - }); - } - } - return plugin; - } - return null; - }; - AbstractPluginLoader.prototype.compareVersion = function (aVersion, bVersion) { - if (typeof aVersion === 'string') { - aVersion = aVersion.match(/^(\d+)\.?(\d+)?\.?(\d+)?/); - aVersion.shift(); - } - for (var i = 0; i < aVersion.length; i++) { - if (aVersion[i] !== bVersion[i]) { - return parseInt(aVersion[i]) > parseInt(bVersion[i]) ? -1 : 1; - } - } - return 0; - }; - AbstractPluginLoader.prototype.versionToString = function (version) { - var versionString = ''; - for (var i = 0; i < version.length; i++) { - versionString += (versionString ? '.' : '') + version[i]; - } - return versionString; - }; - AbstractPluginLoader.prototype.printUsage = function (plugins) { - for (var i = 0; i < plugins.length; i++) { - var plugin = plugins[i]; - if (plugin.printUsage) { - plugin.printUsage(); - } - } - }; - return AbstractPluginLoader; - }()); + var AbstractPluginLoader = /** @class */ (function () { + function AbstractPluginLoader() { + // Implemented by Node.js plugin loader + this.require = function () { + return null; + }; + } + AbstractPluginLoader.prototype.evalPlugin = function (contents, context, imports, pluginOptions, fileInfo) { + var loader, registry, pluginObj, localModule, pluginManager, filename, result; + pluginManager = context.pluginManager; + if (fileInfo) { + if (typeof fileInfo === 'string') { + filename = fileInfo; + } + else { + filename = fileInfo.filename; + } + } + var shortname = (new this.less.FileManager()).extractUrlParts(filename).filename; + if (filename) { + pluginObj = pluginManager.get(filename); + if (pluginObj) { + result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); + if (result) { + return result; + } + try { + if (pluginObj.use) { + pluginObj.use.call(this.context, pluginObj); + } + } + catch (e) { + e.message = e.message || 'Error during @plugin call'; + return new LessError(e, imports, filename); + } + return pluginObj; + } + } + localModule = { + exports: {}, + pluginManager: pluginManager, + fileInfo: fileInfo + }; + registry = functionRegistry.create(); + var registerPlugin = function (obj) { + pluginObj = obj; + }; + try { + loader = new Function('module', 'require', 'registerPlugin', 'functions', 'tree', 'less', 'fileInfo', contents); + loader(localModule, this.require(filename), registerPlugin, registry, this.less.tree, this.less, fileInfo); + } + catch (e) { + return new LessError(e, imports, filename); + } + if (!pluginObj) { + pluginObj = localModule.exports; + } + pluginObj = this.validatePlugin(pluginObj, filename, shortname); + if (pluginObj instanceof LessError) { + return pluginObj; + } + if (pluginObj) { + pluginObj.imports = imports; + pluginObj.filename = filename; + // For < 3.x (or unspecified minVersion) - setOptions() before install() + if (!pluginObj.minVersion || this.compareVersion('3.0.0', pluginObj.minVersion) < 0) { + result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); + if (result) { + return result; + } + } + // Run on first load + pluginManager.addPlugin(pluginObj, fileInfo.filename, registry); + pluginObj.functions = registry.getLocalFunctions(); + // Need to call setOptions again because the pluginObj might have functions + result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions); + if (result) { + return result; + } + // Run every @plugin call + try { + if (pluginObj.use) { + pluginObj.use.call(this.context, pluginObj); + } + } + catch (e) { + e.message = e.message || 'Error during @plugin call'; + return new LessError(e, imports, filename); + } + } + else { + return new LessError({ message: 'Not a valid plugin' }, imports, filename); + } + return pluginObj; + }; + AbstractPluginLoader.prototype.trySetOptions = function (plugin, filename, name, options) { + if (options && !plugin.setOptions) { + return new LessError({ + message: "Options have been provided but the plugin " + name + " does not support any options." + }); + } + try { + plugin.setOptions && plugin.setOptions(options); + } + catch (e) { + return new LessError(e); + } + }; + AbstractPluginLoader.prototype.validatePlugin = function (plugin, filename, name) { + if (plugin) { + // support plugins being a function + // so that the plugin can be more usable programmatically + if (typeof plugin === 'function') { + plugin = new plugin(); + } + if (plugin.minVersion) { + if (this.compareVersion(plugin.minVersion, this.less.version) < 0) { + return new LessError({ + message: "Plugin " + name + " requires version " + this.versionToString(plugin.minVersion) + }); + } + } + return plugin; + } + return null; + }; + AbstractPluginLoader.prototype.compareVersion = function (aVersion, bVersion) { + if (typeof aVersion === 'string') { + aVersion = aVersion.match(/^(\d+)\.?(\d+)?\.?(\d+)?/); + aVersion.shift(); + } + for (var i = 0; i < aVersion.length; i++) { + if (aVersion[i] !== bVersion[i]) { + return parseInt(aVersion[i]) > parseInt(bVersion[i]) ? -1 : 1; + } + } + return 0; + }; + AbstractPluginLoader.prototype.versionToString = function (version) { + var versionString = ''; + for (var i = 0; i < version.length; i++) { + versionString += (versionString ? '.' : '') + version[i]; + } + return versionString; + }; + AbstractPluginLoader.prototype.printUsage = function (plugins) { + for (var i = 0; i < plugins.length; i++) { + var plugin = plugins[i]; + if (plugin.printUsage) { + plugin.printUsage(); + } + } + }; + return AbstractPluginLoader; + }()); - var _visitArgs = { visitDeeper: true }; - var _hasIndexed = false; - function _noop(node) { - return node; - } - function indexNodeTypes(parent, ticker) { - // add .typeIndex to tree node types for lookup table - var key; - var child; - for (key in parent) { - /* eslint guard-for-in: 0 */ - child = parent[key]; - switch (typeof child) { - case 'function': - // ignore bound functions directly on tree which do not have a prototype - // or aren't nodes - if (child.prototype && child.prototype.type) { - child.prototype.typeIndex = ticker++; - } - break; - case 'object': - ticker = indexNodeTypes(child, ticker); - break; - } - } - return ticker; - } - var Visitor = /** @class */ (function () { - function Visitor(implementation) { - this._implementation = implementation; - this._visitInCache = {}; - this._visitOutCache = {}; - if (!_hasIndexed) { - indexNodeTypes(tree, 1); - _hasIndexed = true; - } - } - Visitor.prototype.visit = function (node) { - if (!node) { - return node; - } - var nodeTypeIndex = node.typeIndex; - if (!nodeTypeIndex) { - // MixinCall args aren't a node type? - if (node.value && node.value.typeIndex) { - this.visit(node.value); - } - return node; - } - var impl = this._implementation; - var func = this._visitInCache[nodeTypeIndex]; - var funcOut = this._visitOutCache[nodeTypeIndex]; - var visitArgs = _visitArgs; - var fnName; - visitArgs.visitDeeper = true; - if (!func) { - fnName = "visit" + node.type; - func = impl[fnName] || _noop; - funcOut = impl[fnName + "Out"] || _noop; - this._visitInCache[nodeTypeIndex] = func; - this._visitOutCache[nodeTypeIndex] = funcOut; - } - if (func !== _noop) { - var newNode = func.call(impl, node, visitArgs); - if (node && impl.isReplacing) { - node = newNode; - } - } - if (visitArgs.visitDeeper && node) { - if (node.length) { - for (var i = 0, cnt = node.length; i < cnt; i++) { - if (node[i].accept) { - node[i].accept(this); - } - } - } - else if (node.accept) { - node.accept(this); - } - } - if (funcOut != _noop) { - funcOut.call(impl, node); - } - return node; - }; - Visitor.prototype.visitArray = function (nodes, nonReplacing) { - if (!nodes) { - return nodes; - } - var cnt = nodes.length; - var i; - // Non-replacing - if (nonReplacing || !this._implementation.isReplacing) { - for (i = 0; i < cnt; i++) { - this.visit(nodes[i]); - } - return nodes; - } - // Replacing - var out = []; - for (i = 0; i < cnt; i++) { - var evald = this.visit(nodes[i]); - if (evald === undefined) { - continue; - } - if (!evald.splice) { - out.push(evald); - } - else if (evald.length) { - this.flatten(evald, out); - } - } - return out; - }; - Visitor.prototype.flatten = function (arr, out) { - if (!out) { - out = []; - } - var cnt; - var i; - var item; - var nestedCnt; - var j; - var nestedItem; - for (i = 0, cnt = arr.length; i < cnt; i++) { - item = arr[i]; - if (item === undefined) { - continue; - } - if (!item.splice) { - out.push(item); - continue; - } - for (j = 0, nestedCnt = item.length; j < nestedCnt; j++) { - nestedItem = item[j]; - if (nestedItem === undefined) { - continue; - } - if (!nestedItem.splice) { - out.push(nestedItem); - } - else if (nestedItem.length) { - this.flatten(nestedItem, out); - } - } - } - return out; - }; - return Visitor; - }()); + var _visitArgs = { visitDeeper: true }; + var _hasIndexed = false; + function _noop(node) { + return node; + } + function indexNodeTypes(parent, ticker) { + // add .typeIndex to tree node types for lookup table + var key, child; + for (key in parent) { + /* eslint guard-for-in: 0 */ + child = parent[key]; + switch (typeof child) { + case 'function': + // ignore bound functions directly on tree which do not have a prototype + // or aren't nodes + if (child.prototype && child.prototype.type) { + child.prototype.typeIndex = ticker++; + } + break; + case 'object': + ticker = indexNodeTypes(child, ticker); + break; + } + } + return ticker; + } + var Visitor = /** @class */ (function () { + function Visitor(implementation) { + this._implementation = implementation; + this._visitInCache = {}; + this._visitOutCache = {}; + if (!_hasIndexed) { + indexNodeTypes(tree, 1); + _hasIndexed = true; + } + } + Visitor.prototype.visit = function (node) { + if (!node) { + return node; + } + var nodeTypeIndex = node.typeIndex; + if (!nodeTypeIndex) { + // MixinCall args aren't a node type? + if (node.value && node.value.typeIndex) { + this.visit(node.value); + } + return node; + } + var impl = this._implementation; + var func = this._visitInCache[nodeTypeIndex]; + var funcOut = this._visitOutCache[nodeTypeIndex]; + var visitArgs = _visitArgs; + var fnName; + visitArgs.visitDeeper = true; + if (!func) { + fnName = "visit" + node.type; + func = impl[fnName] || _noop; + funcOut = impl[fnName + "Out"] || _noop; + this._visitInCache[nodeTypeIndex] = func; + this._visitOutCache[nodeTypeIndex] = funcOut; + } + if (func !== _noop) { + var newNode = func.call(impl, node, visitArgs); + if (node && impl.isReplacing) { + node = newNode; + } + } + if (visitArgs.visitDeeper && node) { + if (node.length) { + for (var i = 0, cnt = node.length; i < cnt; i++) { + if (node[i].accept) { + node[i].accept(this); + } + } + } + else if (node.accept) { + node.accept(this); + } + } + if (funcOut != _noop) { + funcOut.call(impl, node); + } + return node; + }; + Visitor.prototype.visitArray = function (nodes, nonReplacing) { + if (!nodes) { + return nodes; + } + var cnt = nodes.length; + var i; + // Non-replacing + if (nonReplacing || !this._implementation.isReplacing) { + for (i = 0; i < cnt; i++) { + this.visit(nodes[i]); + } + return nodes; + } + // Replacing + var out = []; + for (i = 0; i < cnt; i++) { + var evald = this.visit(nodes[i]); + if (evald === undefined) { + continue; + } + if (!evald.splice) { + out.push(evald); + } + else if (evald.length) { + this.flatten(evald, out); + } + } + return out; + }; + Visitor.prototype.flatten = function (arr, out) { + if (!out) { + out = []; + } + var cnt, i, item, nestedCnt, j, nestedItem; + for (i = 0, cnt = arr.length; i < cnt; i++) { + item = arr[i]; + if (item === undefined) { + continue; + } + if (!item.splice) { + out.push(item); + continue; + } + for (j = 0, nestedCnt = item.length; j < nestedCnt; j++) { + nestedItem = item[j]; + if (nestedItem === undefined) { + continue; + } + if (!nestedItem.splice) { + out.push(nestedItem); + } + else if (nestedItem.length) { + this.flatten(nestedItem, out); + } + } + } + return out; + }; + return Visitor; + }()); - var ImportSequencer = /** @class */ (function () { - function ImportSequencer(onSequencerEmpty) { - this.imports = []; - this.variableImports = []; - this._onSequencerEmpty = onSequencerEmpty; - this._currentDepth = 0; - } - ImportSequencer.prototype.addImport = function (callback) { - var importSequencer = this; - var importItem = { - callback: callback, - args: null, - isReady: false - }; - this.imports.push(importItem); - return function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - importItem.args = Array.prototype.slice.call(args, 0); - importItem.isReady = true; - importSequencer.tryRun(); - }; - }; - ImportSequencer.prototype.addVariableImport = function (callback) { - this.variableImports.push(callback); - }; - ImportSequencer.prototype.tryRun = function () { - this._currentDepth++; - try { - while (true) { - while (this.imports.length > 0) { - var importItem = this.imports[0]; - if (!importItem.isReady) { - return; - } - this.imports = this.imports.slice(1); - importItem.callback.apply(null, importItem.args); - } - if (this.variableImports.length === 0) { - break; - } - var variableImport = this.variableImports[0]; - this.variableImports = this.variableImports.slice(1); - variableImport(); - } - } - finally { - this._currentDepth--; - } - if (this._currentDepth === 0 && this._onSequencerEmpty) { - this._onSequencerEmpty(); - } - }; - return ImportSequencer; - }()); + var ImportSequencer = /** @class */ (function () { + function ImportSequencer(onSequencerEmpty) { + this.imports = []; + this.variableImports = []; + this._onSequencerEmpty = onSequencerEmpty; + this._currentDepth = 0; + } + ImportSequencer.prototype.addImport = function (callback) { + var importSequencer = this, importItem = { + callback: callback, + args: null, + isReady: false + }; + this.imports.push(importItem); + return function () { + importItem.args = Array.prototype.slice.call(arguments, 0); + importItem.isReady = true; + importSequencer.tryRun(); + }; + }; + ImportSequencer.prototype.addVariableImport = function (callback) { + this.variableImports.push(callback); + }; + ImportSequencer.prototype.tryRun = function () { + this._currentDepth++; + try { + while (true) { + while (this.imports.length > 0) { + var importItem = this.imports[0]; + if (!importItem.isReady) { + return; + } + this.imports = this.imports.slice(1); + importItem.callback.apply(null, importItem.args); + } + if (this.variableImports.length === 0) { + break; + } + var variableImport = this.variableImports[0]; + this.variableImports = this.variableImports.slice(1); + variableImport(); + } + } + finally { + this._currentDepth--; + } + if (this._currentDepth === 0 && this._onSequencerEmpty) { + this._onSequencerEmpty(); + } + }; + return ImportSequencer; + }()); - var ImportVisitor = function (importer, finish) { - this._visitor = new Visitor(this); - this._importer = importer; - this._finish = finish; - this.context = new contexts.Eval(); - this.importCount = 0; - this.onceFileDetectionMap = {}; - this.recursionDetector = {}; - this._sequencer = new ImportSequencer(this._onSequencerEmpty.bind(this)); - }; - ImportVisitor.prototype = { - isReplacing: false, - run: function (root) { - try { - // process the contents - this._visitor.visit(root); - } - catch (e) { - this.error = e; - } - this.isFinished = true; - this._sequencer.tryRun(); - }, - _onSequencerEmpty: function () { - if (!this.isFinished) { - return; - } - this._finish(this.error); - }, - visitImport: function (importNode, visitArgs) { - var inlineCSS = importNode.options.inline; - if (!importNode.css || inlineCSS) { - var context = new contexts.Eval(this.context, copyArray(this.context.frames)); - var importParent = context.frames[0]; - this.importCount++; - if (importNode.isVariableImport()) { - this._sequencer.addVariableImport(this.processImportNode.bind(this, importNode, context, importParent)); - } - else { - this.processImportNode(importNode, context, importParent); - } - } - visitArgs.visitDeeper = false; - }, - processImportNode: function (importNode, context, importParent) { - var evaldImportNode; - var inlineCSS = importNode.options.inline; - try { - evaldImportNode = importNode.evalForImport(context); - } - catch (e) { - if (!e.filename) { - e.index = importNode.getIndex(); - e.filename = importNode.fileInfo().filename; - } - // attempt to eval properly and treat as css - importNode.css = true; - // if that fails, this error will be thrown - importNode.error = e; - } - if (evaldImportNode && (!evaldImportNode.css || inlineCSS)) { - if (evaldImportNode.options.multiple) { - context.importMultiple = true; - } - // try appending if we haven't determined if it is css or not - var tryAppendLessExtension = evaldImportNode.css === undefined; - for (var i = 0; i < importParent.rules.length; i++) { - if (importParent.rules[i] === importNode) { - importParent.rules[i] = evaldImportNode; - break; - } - } - var onImported = this.onImported.bind(this, evaldImportNode, context); - var sequencedOnImported = this._sequencer.addImport(onImported); - this._importer.push(evaldImportNode.getPath(), tryAppendLessExtension, evaldImportNode.fileInfo(), evaldImportNode.options, sequencedOnImported); - } - else { - this.importCount--; - if (this.isFinished) { - this._sequencer.tryRun(); - } - } - }, - onImported: function (importNode, context, e, root, importedAtRoot, fullPath) { - if (e) { - if (!e.filename) { - e.index = importNode.getIndex(); - e.filename = importNode.fileInfo().filename; - } - this.error = e; - } - var importVisitor = this; - var inlineCSS = importNode.options.inline; - var isPlugin = importNode.options.isPlugin; - var isOptional = importNode.options.optional; - var duplicateImport = importedAtRoot || fullPath in importVisitor.recursionDetector; - if (!context.importMultiple) { - if (duplicateImport) { - importNode.skip = true; - } - else { - importNode.skip = function () { - if (fullPath in importVisitor.onceFileDetectionMap) { - return true; - } - importVisitor.onceFileDetectionMap[fullPath] = true; - return false; - }; - } - } - if (!fullPath && isOptional) { - importNode.skip = true; - } - if (root) { - importNode.root = root; - importNode.importedFilename = fullPath; - if (!inlineCSS && !isPlugin && (context.importMultiple || !duplicateImport)) { - importVisitor.recursionDetector[fullPath] = true; - var oldContext = this.context; - this.context = context; - try { - this._visitor.visit(root); - } - catch (e) { - this.error = e; - } - this.context = oldContext; - } - } - importVisitor.importCount--; - if (importVisitor.isFinished) { - importVisitor._sequencer.tryRun(); - } - }, - visitDeclaration: function (declNode, visitArgs) { - if (declNode.value.type === 'DetachedRuleset') { - this.context.frames.unshift(declNode); - } - else { - visitArgs.visitDeeper = false; - } - }, - visitDeclarationOut: function (declNode) { - if (declNode.value.type === 'DetachedRuleset') { - this.context.frames.shift(); - } - }, - visitAtRule: function (atRuleNode, visitArgs) { - this.context.frames.unshift(atRuleNode); - }, - visitAtRuleOut: function (atRuleNode) { - this.context.frames.shift(); - }, - visitMixinDefinition: function (mixinDefinitionNode, visitArgs) { - this.context.frames.unshift(mixinDefinitionNode); - }, - visitMixinDefinitionOut: function (mixinDefinitionNode) { - this.context.frames.shift(); - }, - visitRuleset: function (rulesetNode, visitArgs) { - this.context.frames.unshift(rulesetNode); - }, - visitRulesetOut: function (rulesetNode) { - this.context.frames.shift(); - }, - visitMedia: function (mediaNode, visitArgs) { - this.context.frames.unshift(mediaNode.rules[0]); - }, - visitMediaOut: function (mediaNode) { - this.context.frames.shift(); - } - }; + var ImportVisitor = function (importer, finish) { + this._visitor = new Visitor(this); + this._importer = importer; + this._finish = finish; + this.context = new contexts.Eval(); + this.importCount = 0; + this.onceFileDetectionMap = {}; + this.recursionDetector = {}; + this._sequencer = new ImportSequencer(this._onSequencerEmpty.bind(this)); + }; + ImportVisitor.prototype = { + isReplacing: false, + run: function (root) { + try { + // process the contents + this._visitor.visit(root); + } + catch (e) { + this.error = e; + } + this.isFinished = true; + this._sequencer.tryRun(); + }, + _onSequencerEmpty: function () { + if (!this.isFinished) { + return; + } + this._finish(this.error); + }, + visitImport: function (importNode, visitArgs) { + var inlineCSS = importNode.options.inline; + if (!importNode.css || inlineCSS) { + var context = new contexts.Eval(this.context, copyArray(this.context.frames)); + var importParent = context.frames[0]; + this.importCount++; + if (importNode.isVariableImport()) { + this._sequencer.addVariableImport(this.processImportNode.bind(this, importNode, context, importParent)); + } + else { + this.processImportNode(importNode, context, importParent); + } + } + visitArgs.visitDeeper = false; + }, + processImportNode: function (importNode, context, importParent) { + var evaldImportNode; + var inlineCSS = importNode.options.inline; + try { + evaldImportNode = importNode.evalForImport(context); + } + catch (e) { + if (!e.filename) { + e.index = importNode.getIndex(); + e.filename = importNode.fileInfo().filename; + } + // attempt to eval properly and treat as css + importNode.css = true; + // if that fails, this error will be thrown + importNode.error = e; + } + if (evaldImportNode && (!evaldImportNode.css || inlineCSS)) { + if (evaldImportNode.options.multiple) { + context.importMultiple = true; + } + // try appending if we haven't determined if it is css or not + var tryAppendLessExtension = evaldImportNode.css === undefined; + for (var i = 0; i < importParent.rules.length; i++) { + if (importParent.rules[i] === importNode) { + importParent.rules[i] = evaldImportNode; + break; + } + } + var onImported = this.onImported.bind(this, evaldImportNode, context), sequencedOnImported = this._sequencer.addImport(onImported); + this._importer.push(evaldImportNode.getPath(), tryAppendLessExtension, evaldImportNode.fileInfo(), evaldImportNode.options, sequencedOnImported); + } + else { + this.importCount--; + if (this.isFinished) { + this._sequencer.tryRun(); + } + } + }, + onImported: function (importNode, context, e, root, importedAtRoot, fullPath) { + if (e) { + if (!e.filename) { + e.index = importNode.getIndex(); + e.filename = importNode.fileInfo().filename; + } + this.error = e; + } + var importVisitor = this, inlineCSS = importNode.options.inline, isPlugin = importNode.options.isPlugin, isOptional = importNode.options.optional, duplicateImport = importedAtRoot || fullPath in importVisitor.recursionDetector; + if (!context.importMultiple) { + if (duplicateImport) { + importNode.skip = true; + } + else { + importNode.skip = function () { + if (fullPath in importVisitor.onceFileDetectionMap) { + return true; + } + importVisitor.onceFileDetectionMap[fullPath] = true; + return false; + }; + } + } + if (!fullPath && isOptional) { + importNode.skip = true; + } + if (root) { + importNode.root = root; + importNode.importedFilename = fullPath; + if (!inlineCSS && !isPlugin && (context.importMultiple || !duplicateImport)) { + importVisitor.recursionDetector[fullPath] = true; + var oldContext = this.context; + this.context = context; + try { + this._visitor.visit(root); + } + catch (e) { + this.error = e; + } + this.context = oldContext; + } + } + importVisitor.importCount--; + if (importVisitor.isFinished) { + importVisitor._sequencer.tryRun(); + } + }, + visitDeclaration: function (declNode, visitArgs) { + if (declNode.value.type === 'DetachedRuleset') { + this.context.frames.unshift(declNode); + } + else { + visitArgs.visitDeeper = false; + } + }, + visitDeclarationOut: function (declNode) { + if (declNode.value.type === 'DetachedRuleset') { + this.context.frames.shift(); + } + }, + visitAtRule: function (atRuleNode, visitArgs) { + this.context.frames.unshift(atRuleNode); + }, + visitAtRuleOut: function (atRuleNode) { + this.context.frames.shift(); + }, + visitMixinDefinition: function (mixinDefinitionNode, visitArgs) { + this.context.frames.unshift(mixinDefinitionNode); + }, + visitMixinDefinitionOut: function (mixinDefinitionNode) { + this.context.frames.shift(); + }, + visitRuleset: function (rulesetNode, visitArgs) { + this.context.frames.unshift(rulesetNode); + }, + visitRulesetOut: function (rulesetNode) { + this.context.frames.shift(); + }, + visitMedia: function (mediaNode, visitArgs) { + this.context.frames.unshift(mediaNode.rules[0]); + }, + visitMediaOut: function (mediaNode) { + this.context.frames.shift(); + } + }; - var SetTreeVisibilityVisitor = /** @class */ (function () { - function SetTreeVisibilityVisitor(visible) { - this.visible = visible; - } - SetTreeVisibilityVisitor.prototype.run = function (root) { - this.visit(root); - }; - SetTreeVisibilityVisitor.prototype.visitArray = function (nodes) { - if (!nodes) { - return nodes; - } - var cnt = nodes.length; - var i; - for (i = 0; i < cnt; i++) { - this.visit(nodes[i]); - } - return nodes; - }; - SetTreeVisibilityVisitor.prototype.visit = function (node) { - if (!node) { - return node; - } - if (node.constructor === Array) { - return this.visitArray(node); - } - if (!node.blocksVisibility || node.blocksVisibility()) { - return node; - } - if (this.visible) { - node.ensureVisibility(); - } - else { - node.ensureInvisibility(); - } - node.accept(this); - return node; - }; - return SetTreeVisibilityVisitor; - }()); + var SetTreeVisibilityVisitor = /** @class */ (function () { + function SetTreeVisibilityVisitor(visible) { + this.visible = visible; + } + SetTreeVisibilityVisitor.prototype.run = function (root) { + this.visit(root); + }; + SetTreeVisibilityVisitor.prototype.visitArray = function (nodes) { + if (!nodes) { + return nodes; + } + var cnt = nodes.length; + var i; + for (i = 0; i < cnt; i++) { + this.visit(nodes[i]); + } + return nodes; + }; + SetTreeVisibilityVisitor.prototype.visit = function (node) { + if (!node) { + return node; + } + if (node.constructor === Array) { + return this.visitArray(node); + } + if (!node.blocksVisibility || node.blocksVisibility()) { + return node; + } + if (this.visible) { + node.ensureVisibility(); + } + else { + node.ensureInvisibility(); + } + node.accept(this); + return node; + }; + return SetTreeVisibilityVisitor; + }()); - /* jshint loopfunc:true */ - var ExtendFinderVisitor = /** @class */ (function () { - function ExtendFinderVisitor() { - this._visitor = new Visitor(this); - this.contexts = []; - this.allExtendsStack = [[]]; - } - ExtendFinderVisitor.prototype.run = function (root) { - root = this._visitor.visit(root); - root.allExtends = this.allExtendsStack[0]; - return root; - }; - ExtendFinderVisitor.prototype.visitDeclaration = function (declNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - ExtendFinderVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - ExtendFinderVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { - if (rulesetNode.root) { - return; - } - var i; - var j; - var extend; - var allSelectorsExtendList = []; - var extendList; - // get &:extend(.a); rules which apply to all selectors in this ruleset - var rules = rulesetNode.rules; - var ruleCnt = rules ? rules.length : 0; - for (i = 0; i < ruleCnt; i++) { - if (rulesetNode.rules[i] instanceof tree.Extend) { - allSelectorsExtendList.push(rules[i]); - rulesetNode.extendOnEveryPath = true; - } - } - // now find every selector and apply the extends that apply to all extends - // and the ones which apply to an individual extend - var paths = rulesetNode.paths; - for (i = 0; i < paths.length; i++) { - var selectorPath = paths[i]; - var selector = selectorPath[selectorPath.length - 1]; - var selExtendList = selector.extendList; - extendList = selExtendList ? copyArray(selExtendList).concat(allSelectorsExtendList) - : allSelectorsExtendList; - if (extendList) { - extendList = extendList.map(function (allSelectorsExtend) { return allSelectorsExtend.clone(); }); - } - for (j = 0; j < extendList.length; j++) { - this.foundExtends = true; - extend = extendList[j]; - extend.findSelfSelectors(selectorPath); - extend.ruleset = rulesetNode; - if (j === 0) { - extend.firstExtendOnThisSelectorPath = true; - } - this.allExtendsStack[this.allExtendsStack.length - 1].push(extend); - } - } - this.contexts.push(rulesetNode.selectors); - }; - ExtendFinderVisitor.prototype.visitRulesetOut = function (rulesetNode) { - if (!rulesetNode.root) { - this.contexts.length = this.contexts.length - 1; - } - }; - ExtendFinderVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { - mediaNode.allExtends = []; - this.allExtendsStack.push(mediaNode.allExtends); - }; - ExtendFinderVisitor.prototype.visitMediaOut = function (mediaNode) { - this.allExtendsStack.length = this.allExtendsStack.length - 1; - }; - ExtendFinderVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { - atRuleNode.allExtends = []; - this.allExtendsStack.push(atRuleNode.allExtends); - }; - ExtendFinderVisitor.prototype.visitAtRuleOut = function (atRuleNode) { - this.allExtendsStack.length = this.allExtendsStack.length - 1; - }; - return ExtendFinderVisitor; - }()); - var ProcessExtendsVisitor = /** @class */ (function () { - function ProcessExtendsVisitor() { - this._visitor = new Visitor(this); - } - ProcessExtendsVisitor.prototype.run = function (root) { - var extendFinder = new ExtendFinderVisitor(); - this.extendIndices = {}; - extendFinder.run(root); - if (!extendFinder.foundExtends) { - return root; - } - root.allExtends = root.allExtends.concat(this.doExtendChaining(root.allExtends, root.allExtends)); - this.allExtendsStack = [root.allExtends]; - var newRoot = this._visitor.visit(root); - this.checkExtendsForNonMatched(root.allExtends); - return newRoot; - }; - ProcessExtendsVisitor.prototype.checkExtendsForNonMatched = function (extendList) { - var indices = this.extendIndices; - extendList.filter(function (extend) { return !extend.hasFoundMatches && extend.parent_ids.length == 1; }).forEach(function (extend) { - var selector = '_unknown_'; - try { - selector = extend.selector.toCSS({}); - } - catch (_) { } - if (!indices[extend.index + " " + selector]) { - indices[extend.index + " " + selector] = true; - logger.warn("extend '" + selector + "' has no matches"); - } - }); - }; - ProcessExtendsVisitor.prototype.doExtendChaining = function (extendsList, extendsListTarget, iterationCount) { - // - // chaining is different from normal extension.. if we extend an extend then we are not just copying, altering - // and pasting the selector we would do normally, but we are also adding an extend with the same target selector - // this means this new extend can then go and alter other extends - // - // this method deals with all the chaining work - without it, extend is flat and doesn't work on other extend selectors - // this is also the most expensive.. and a match on one selector can cause an extension of a selector we had already - // processed if we look at each selector at a time, as is done in visitRuleset - var extendIndex; - var targetExtendIndex; - var matches; - var extendsToAdd = []; - var newSelector; - var extendVisitor = this; - var selectorPath; - var extend; - var targetExtend; - var newExtend; - iterationCount = iterationCount || 0; - // loop through comparing every extend with every target extend. - // a target extend is the one on the ruleset we are looking at copy/edit/pasting in place - // e.g. .a:extend(.b) {} and .b:extend(.c) {} then the first extend extends the second one - // and the second is the target. - // the separation into two lists allows us to process a subset of chains with a bigger set, as is the - // case when processing media queries - for (extendIndex = 0; extendIndex < extendsList.length; extendIndex++) { - for (targetExtendIndex = 0; targetExtendIndex < extendsListTarget.length; targetExtendIndex++) { - extend = extendsList[extendIndex]; - targetExtend = extendsListTarget[targetExtendIndex]; - // look for circular references - if (extend.parent_ids.indexOf(targetExtend.object_id) >= 0) { - continue; - } - // find a match in the target extends self selector (the bit before :extend) - selectorPath = [targetExtend.selfSelectors[0]]; - matches = extendVisitor.findMatch(extend, selectorPath); - if (matches.length) { - extend.hasFoundMatches = true; - // we found a match, so for each self selector.. - extend.selfSelectors.forEach(function (selfSelector) { - var info = targetExtend.visibilityInfo(); - // process the extend as usual - newSelector = extendVisitor.extendSelector(matches, selectorPath, selfSelector, extend.isVisible()); - // but now we create a new extend from it - newExtend = new (tree.Extend)(targetExtend.selector, targetExtend.option, 0, targetExtend.fileInfo(), info); - newExtend.selfSelectors = newSelector; - // add the extend onto the list of extends for that selector - newSelector[newSelector.length - 1].extendList = [newExtend]; - // record that we need to add it. - extendsToAdd.push(newExtend); - newExtend.ruleset = targetExtend.ruleset; - // remember its parents for circular references - newExtend.parent_ids = newExtend.parent_ids.concat(targetExtend.parent_ids, extend.parent_ids); - // only process the selector once.. if we have :extend(.a,.b) then multiple - // extends will look at the same selector path, so when extending - // we know that any others will be duplicates in terms of what is added to the css - if (targetExtend.firstExtendOnThisSelectorPath) { - newExtend.firstExtendOnThisSelectorPath = true; - targetExtend.ruleset.paths.push(newSelector); - } - }); - } - } - } - if (extendsToAdd.length) { - // try to detect circular references to stop a stack overflow. - // may no longer be needed. - this.extendChainCount++; - if (iterationCount > 100) { - var selectorOne = '{unable to calculate}'; - var selectorTwo = '{unable to calculate}'; - try { - selectorOne = extendsToAdd[0].selfSelectors[0].toCSS(); - selectorTwo = extendsToAdd[0].selector.toCSS(); - } - catch (e) { } - throw { message: "extend circular reference detected. One of the circular extends is currently:" + selectorOne + ":extend(" + selectorTwo + ")" }; - } - // now process the new extends on the existing rules so that we can handle a extending b extending c extending - // d extending e... - return extendsToAdd.concat(extendVisitor.doExtendChaining(extendsToAdd, extendsListTarget, iterationCount + 1)); - } - else { - return extendsToAdd; - } - }; - ProcessExtendsVisitor.prototype.visitDeclaration = function (ruleNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - ProcessExtendsVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - ProcessExtendsVisitor.prototype.visitSelector = function (selectorNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - ProcessExtendsVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { - if (rulesetNode.root) { - return; - } - var matches; - var pathIndex; - var extendIndex; - var allExtends = this.allExtendsStack[this.allExtendsStack.length - 1]; - var selectorsToAdd = []; - var extendVisitor = this; - var selectorPath; - // look at each selector path in the ruleset, find any extend matches and then copy, find and replace - for (extendIndex = 0; extendIndex < allExtends.length; extendIndex++) { - for (pathIndex = 0; pathIndex < rulesetNode.paths.length; pathIndex++) { - selectorPath = rulesetNode.paths[pathIndex]; - // extending extends happens initially, before the main pass - if (rulesetNode.extendOnEveryPath) { - continue; - } - var extendList = selectorPath[selectorPath.length - 1].extendList; - if (extendList && extendList.length) { - continue; - } - matches = this.findMatch(allExtends[extendIndex], selectorPath); - if (matches.length) { - allExtends[extendIndex].hasFoundMatches = true; - allExtends[extendIndex].selfSelectors.forEach(function (selfSelector) { - var extendedSelectors; - extendedSelectors = extendVisitor.extendSelector(matches, selectorPath, selfSelector, allExtends[extendIndex].isVisible()); - selectorsToAdd.push(extendedSelectors); - }); - } - } - } - rulesetNode.paths = rulesetNode.paths.concat(selectorsToAdd); - }; - ProcessExtendsVisitor.prototype.findMatch = function (extend, haystackSelectorPath) { - // - // look through the haystack selector path to try and find the needle - extend.selector - // returns an array of selector matches that can then be replaced - // - var haystackSelectorIndex; - var hackstackSelector; - var hackstackElementIndex; - var haystackElement; - var targetCombinator; - var i; - var extendVisitor = this; - var needleElements = extend.selector.elements; - var potentialMatches = []; - var potentialMatch; - var matches = []; - // loop through the haystack elements - for (haystackSelectorIndex = 0; haystackSelectorIndex < haystackSelectorPath.length; haystackSelectorIndex++) { - hackstackSelector = haystackSelectorPath[haystackSelectorIndex]; - for (hackstackElementIndex = 0; hackstackElementIndex < hackstackSelector.elements.length; hackstackElementIndex++) { - haystackElement = hackstackSelector.elements[hackstackElementIndex]; - // if we allow elements before our match we can add a potential match every time. otherwise only at the first element. - if (extend.allowBefore || (haystackSelectorIndex === 0 && hackstackElementIndex === 0)) { - potentialMatches.push({ pathIndex: haystackSelectorIndex, index: hackstackElementIndex, matched: 0, - initialCombinator: haystackElement.combinator }); - } - for (i = 0; i < potentialMatches.length; i++) { - potentialMatch = potentialMatches[i]; - // selectors add " " onto the first element. When we use & it joins the selectors together, but if we don't - // then each selector in haystackSelectorPath has a space before it added in the toCSS phase. so we need to - // work out what the resulting combinator will be - targetCombinator = haystackElement.combinator.value; - if (targetCombinator === '' && hackstackElementIndex === 0) { - targetCombinator = ' '; - } - // if we don't match, null our match to indicate failure - if (!extendVisitor.isElementValuesEqual(needleElements[potentialMatch.matched].value, haystackElement.value) || - (potentialMatch.matched > 0 && needleElements[potentialMatch.matched].combinator.value !== targetCombinator)) { - potentialMatch = null; - } - else { - potentialMatch.matched++; - } - // if we are still valid and have finished, test whether we have elements after and whether these are allowed - if (potentialMatch) { - potentialMatch.finished = potentialMatch.matched === needleElements.length; - if (potentialMatch.finished && - (!extend.allowAfter && - (hackstackElementIndex + 1 < hackstackSelector.elements.length || haystackSelectorIndex + 1 < haystackSelectorPath.length))) { - potentialMatch = null; - } - } - // if null we remove, if not, we are still valid, so either push as a valid match or continue - if (potentialMatch) { - if (potentialMatch.finished) { - potentialMatch.length = needleElements.length; - potentialMatch.endPathIndex = haystackSelectorIndex; - potentialMatch.endPathElementIndex = hackstackElementIndex + 1; // index after end of match - potentialMatches.length = 0; // we don't allow matches to overlap, so start matching again - matches.push(potentialMatch); - } - } - else { - potentialMatches.splice(i, 1); - i--; - } - } - } - } - return matches; - }; - ProcessExtendsVisitor.prototype.isElementValuesEqual = function (elementValue1, elementValue2) { - if (typeof elementValue1 === 'string' || typeof elementValue2 === 'string') { - return elementValue1 === elementValue2; - } - if (elementValue1 instanceof tree.Attribute) { - if (elementValue1.op !== elementValue2.op || elementValue1.key !== elementValue2.key) { - return false; - } - if (!elementValue1.value || !elementValue2.value) { - if (elementValue1.value || elementValue2.value) { - return false; - } - return true; - } - elementValue1 = elementValue1.value.value || elementValue1.value; - elementValue2 = elementValue2.value.value || elementValue2.value; - return elementValue1 === elementValue2; - } - elementValue1 = elementValue1.value; - elementValue2 = elementValue2.value; - if (elementValue1 instanceof tree.Selector) { - if (!(elementValue2 instanceof tree.Selector) || elementValue1.elements.length !== elementValue2.elements.length) { - return false; - } - for (var i = 0; i < elementValue1.elements.length; i++) { - if (elementValue1.elements[i].combinator.value !== elementValue2.elements[i].combinator.value) { - if (i !== 0 || (elementValue1.elements[i].combinator.value || ' ') !== (elementValue2.elements[i].combinator.value || ' ')) { - return false; - } - } - if (!this.isElementValuesEqual(elementValue1.elements[i].value, elementValue2.elements[i].value)) { - return false; - } - } - return true; - } - return false; - }; - ProcessExtendsVisitor.prototype.extendSelector = function (matches, selectorPath, replacementSelector, isVisible) { - // for a set of matches, replace each match with the replacement selector - var currentSelectorPathIndex = 0; - var currentSelectorPathElementIndex = 0; - var path = []; - var matchIndex; - var selector; - var firstElement; - var match; - var newElements; - for (matchIndex = 0; matchIndex < matches.length; matchIndex++) { - match = matches[matchIndex]; - selector = selectorPath[match.pathIndex]; - firstElement = new tree.Element(match.initialCombinator, replacementSelector.elements[0].value, replacementSelector.elements[0].isVariable, replacementSelector.elements[0].getIndex(), replacementSelector.elements[0].fileInfo()); - if (match.pathIndex > currentSelectorPathIndex && currentSelectorPathElementIndex > 0) { - path[path.length - 1].elements = path[path.length - 1] - .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex)); - currentSelectorPathElementIndex = 0; - currentSelectorPathIndex++; - } - newElements = selector.elements - .slice(currentSelectorPathElementIndex, match.index) - .concat([firstElement]) - .concat(replacementSelector.elements.slice(1)); - if (currentSelectorPathIndex === match.pathIndex && matchIndex > 0) { - path[path.length - 1].elements = - path[path.length - 1].elements.concat(newElements); - } - else { - path = path.concat(selectorPath.slice(currentSelectorPathIndex, match.pathIndex)); - path.push(new tree.Selector(newElements)); - } - currentSelectorPathIndex = match.endPathIndex; - currentSelectorPathElementIndex = match.endPathElementIndex; - if (currentSelectorPathElementIndex >= selectorPath[currentSelectorPathIndex].elements.length) { - currentSelectorPathElementIndex = 0; - currentSelectorPathIndex++; - } - } - if (currentSelectorPathIndex < selectorPath.length && currentSelectorPathElementIndex > 0) { - path[path.length - 1].elements = path[path.length - 1] - .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex)); - currentSelectorPathIndex++; - } - path = path.concat(selectorPath.slice(currentSelectorPathIndex, selectorPath.length)); - path = path.map(function (currentValue) { - // we can re-use elements here, because the visibility property matters only for selectors - var derived = currentValue.createDerived(currentValue.elements); - if (isVisible) { - derived.ensureVisibility(); - } - else { - derived.ensureInvisibility(); - } - return derived; - }); - return path; - }; - ProcessExtendsVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { - var newAllExtends = mediaNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]); - newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, mediaNode.allExtends)); - this.allExtendsStack.push(newAllExtends); - }; - ProcessExtendsVisitor.prototype.visitMediaOut = function (mediaNode) { - var lastIndex = this.allExtendsStack.length - 1; - this.allExtendsStack.length = lastIndex; - }; - ProcessExtendsVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { - var newAllExtends = atRuleNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]); - newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, atRuleNode.allExtends)); - this.allExtendsStack.push(newAllExtends); - }; - ProcessExtendsVisitor.prototype.visitAtRuleOut = function (atRuleNode) { - var lastIndex = this.allExtendsStack.length - 1; - this.allExtendsStack.length = lastIndex; - }; - return ProcessExtendsVisitor; - }()); + /* jshint loopfunc:true */ + var ExtendFinderVisitor = /** @class */ (function () { + function ExtendFinderVisitor() { + this._visitor = new Visitor(this); + this.contexts = []; + this.allExtendsStack = [[]]; + } + ExtendFinderVisitor.prototype.run = function (root) { + root = this._visitor.visit(root); + root.allExtends = this.allExtendsStack[0]; + return root; + }; + ExtendFinderVisitor.prototype.visitDeclaration = function (declNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + ExtendFinderVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + ExtendFinderVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { + if (rulesetNode.root) { + return; + } + var i; + var j; + var extend; + var allSelectorsExtendList = []; + var extendList; + // get &:extend(.a); rules which apply to all selectors in this ruleset + var rules = rulesetNode.rules, ruleCnt = rules ? rules.length : 0; + for (i = 0; i < ruleCnt; i++) { + if (rulesetNode.rules[i] instanceof tree.Extend) { + allSelectorsExtendList.push(rules[i]); + rulesetNode.extendOnEveryPath = true; + } + } + // now find every selector and apply the extends that apply to all extends + // and the ones which apply to an individual extend + var paths = rulesetNode.paths; + for (i = 0; i < paths.length; i++) { + var selectorPath = paths[i], selector = selectorPath[selectorPath.length - 1], selExtendList = selector.extendList; + extendList = selExtendList ? copyArray(selExtendList).concat(allSelectorsExtendList) + : allSelectorsExtendList; + if (extendList) { + extendList = extendList.map(function (allSelectorsExtend) { + return allSelectorsExtend.clone(); + }); + } + for (j = 0; j < extendList.length; j++) { + this.foundExtends = true; + extend = extendList[j]; + extend.findSelfSelectors(selectorPath); + extend.ruleset = rulesetNode; + if (j === 0) { + extend.firstExtendOnThisSelectorPath = true; + } + this.allExtendsStack[this.allExtendsStack.length - 1].push(extend); + } + } + this.contexts.push(rulesetNode.selectors); + }; + ExtendFinderVisitor.prototype.visitRulesetOut = function (rulesetNode) { + if (!rulesetNode.root) { + this.contexts.length = this.contexts.length - 1; + } + }; + ExtendFinderVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { + mediaNode.allExtends = []; + this.allExtendsStack.push(mediaNode.allExtends); + }; + ExtendFinderVisitor.prototype.visitMediaOut = function (mediaNode) { + this.allExtendsStack.length = this.allExtendsStack.length - 1; + }; + ExtendFinderVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { + atRuleNode.allExtends = []; + this.allExtendsStack.push(atRuleNode.allExtends); + }; + ExtendFinderVisitor.prototype.visitAtRuleOut = function (atRuleNode) { + this.allExtendsStack.length = this.allExtendsStack.length - 1; + }; + return ExtendFinderVisitor; + }()); + var ProcessExtendsVisitor = /** @class */ (function () { + function ProcessExtendsVisitor() { + this._visitor = new Visitor(this); + } + ProcessExtendsVisitor.prototype.run = function (root) { + var extendFinder = new ExtendFinderVisitor(); + this.extendIndices = {}; + extendFinder.run(root); + if (!extendFinder.foundExtends) { + return root; + } + root.allExtends = root.allExtends.concat(this.doExtendChaining(root.allExtends, root.allExtends)); + this.allExtendsStack = [root.allExtends]; + var newRoot = this._visitor.visit(root); + this.checkExtendsForNonMatched(root.allExtends); + return newRoot; + }; + ProcessExtendsVisitor.prototype.checkExtendsForNonMatched = function (extendList) { + var indices = this.extendIndices; + extendList.filter(function (extend) { + return !extend.hasFoundMatches && extend.parent_ids.length == 1; + }).forEach(function (extend) { + var selector = '_unknown_'; + try { + selector = extend.selector.toCSS({}); + } + catch (_) { } + if (!indices[extend.index + " " + selector]) { + indices[extend.index + " " + selector] = true; + logger.warn("extend '" + selector + "' has no matches"); + } + }); + }; + ProcessExtendsVisitor.prototype.doExtendChaining = function (extendsList, extendsListTarget, iterationCount) { + // + // chaining is different from normal extension.. if we extend an extend then we are not just copying, altering + // and pasting the selector we would do normally, but we are also adding an extend with the same target selector + // this means this new extend can then go and alter other extends + // + // this method deals with all the chaining work - without it, extend is flat and doesn't work on other extend selectors + // this is also the most expensive.. and a match on one selector can cause an extension of a selector we had already + // processed if we look at each selector at a time, as is done in visitRuleset + var extendIndex; + var targetExtendIndex; + var matches; + var extendsToAdd = []; + var newSelector; + var extendVisitor = this; + var selectorPath; + var extend; + var targetExtend; + var newExtend; + iterationCount = iterationCount || 0; + // loop through comparing every extend with every target extend. + // a target extend is the one on the ruleset we are looking at copy/edit/pasting in place + // e.g. .a:extend(.b) {} and .b:extend(.c) {} then the first extend extends the second one + // and the second is the target. + // the separation into two lists allows us to process a subset of chains with a bigger set, as is the + // case when processing media queries + for (extendIndex = 0; extendIndex < extendsList.length; extendIndex++) { + for (targetExtendIndex = 0; targetExtendIndex < extendsListTarget.length; targetExtendIndex++) { + extend = extendsList[extendIndex]; + targetExtend = extendsListTarget[targetExtendIndex]; + // look for circular references + if (extend.parent_ids.indexOf(targetExtend.object_id) >= 0) { + continue; + } + // find a match in the target extends self selector (the bit before :extend) + selectorPath = [targetExtend.selfSelectors[0]]; + matches = extendVisitor.findMatch(extend, selectorPath); + if (matches.length) { + extend.hasFoundMatches = true; + // we found a match, so for each self selector.. + extend.selfSelectors.forEach(function (selfSelector) { + var info = targetExtend.visibilityInfo(); + // process the extend as usual + newSelector = extendVisitor.extendSelector(matches, selectorPath, selfSelector, extend.isVisible()); + // but now we create a new extend from it + newExtend = new (tree.Extend)(targetExtend.selector, targetExtend.option, 0, targetExtend.fileInfo(), info); + newExtend.selfSelectors = newSelector; + // add the extend onto the list of extends for that selector + newSelector[newSelector.length - 1].extendList = [newExtend]; + // record that we need to add it. + extendsToAdd.push(newExtend); + newExtend.ruleset = targetExtend.ruleset; + // remember its parents for circular references + newExtend.parent_ids = newExtend.parent_ids.concat(targetExtend.parent_ids, extend.parent_ids); + // only process the selector once.. if we have :extend(.a,.b) then multiple + // extends will look at the same selector path, so when extending + // we know that any others will be duplicates in terms of what is added to the css + if (targetExtend.firstExtendOnThisSelectorPath) { + newExtend.firstExtendOnThisSelectorPath = true; + targetExtend.ruleset.paths.push(newSelector); + } + }); + } + } + } + if (extendsToAdd.length) { + // try to detect circular references to stop a stack overflow. + // may no longer be needed. + this.extendChainCount++; + if (iterationCount > 100) { + var selectorOne = '{unable to calculate}'; + var selectorTwo = '{unable to calculate}'; + try { + selectorOne = extendsToAdd[0].selfSelectors[0].toCSS(); + selectorTwo = extendsToAdd[0].selector.toCSS(); + } + catch (e) { } + throw { message: "extend circular reference detected. One of the circular extends is currently:" + selectorOne + ":extend(" + selectorTwo + ")" }; + } + // now process the new extends on the existing rules so that we can handle a extending b extending c extending + // d extending e... + return extendsToAdd.concat(extendVisitor.doExtendChaining(extendsToAdd, extendsListTarget, iterationCount + 1)); + } + else { + return extendsToAdd; + } + }; + ProcessExtendsVisitor.prototype.visitDeclaration = function (ruleNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + ProcessExtendsVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + ProcessExtendsVisitor.prototype.visitSelector = function (selectorNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + ProcessExtendsVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { + if (rulesetNode.root) { + return; + } + var matches; + var pathIndex; + var extendIndex; + var allExtends = this.allExtendsStack[this.allExtendsStack.length - 1]; + var selectorsToAdd = []; + var extendVisitor = this; + var selectorPath; + // look at each selector path in the ruleset, find any extend matches and then copy, find and replace + for (extendIndex = 0; extendIndex < allExtends.length; extendIndex++) { + for (pathIndex = 0; pathIndex < rulesetNode.paths.length; pathIndex++) { + selectorPath = rulesetNode.paths[pathIndex]; + // extending extends happens initially, before the main pass + if (rulesetNode.extendOnEveryPath) { + continue; + } + var extendList = selectorPath[selectorPath.length - 1].extendList; + if (extendList && extendList.length) { + continue; + } + matches = this.findMatch(allExtends[extendIndex], selectorPath); + if (matches.length) { + allExtends[extendIndex].hasFoundMatches = true; + allExtends[extendIndex].selfSelectors.forEach(function (selfSelector) { + var extendedSelectors; + extendedSelectors = extendVisitor.extendSelector(matches, selectorPath, selfSelector, allExtends[extendIndex].isVisible()); + selectorsToAdd.push(extendedSelectors); + }); + } + } + } + rulesetNode.paths = rulesetNode.paths.concat(selectorsToAdd); + }; + ProcessExtendsVisitor.prototype.findMatch = function (extend, haystackSelectorPath) { + // + // look through the haystack selector path to try and find the needle - extend.selector + // returns an array of selector matches that can then be replaced + // + var haystackSelectorIndex; + var hackstackSelector; + var hackstackElementIndex; + var haystackElement; + var targetCombinator; + var i; + var extendVisitor = this; + var needleElements = extend.selector.elements; + var potentialMatches = []; + var potentialMatch; + var matches = []; + // loop through the haystack elements + for (haystackSelectorIndex = 0; haystackSelectorIndex < haystackSelectorPath.length; haystackSelectorIndex++) { + hackstackSelector = haystackSelectorPath[haystackSelectorIndex]; + for (hackstackElementIndex = 0; hackstackElementIndex < hackstackSelector.elements.length; hackstackElementIndex++) { + haystackElement = hackstackSelector.elements[hackstackElementIndex]; + // if we allow elements before our match we can add a potential match every time. otherwise only at the first element. + if (extend.allowBefore || (haystackSelectorIndex === 0 && hackstackElementIndex === 0)) { + potentialMatches.push({ pathIndex: haystackSelectorIndex, index: hackstackElementIndex, matched: 0, + initialCombinator: haystackElement.combinator }); + } + for (i = 0; i < potentialMatches.length; i++) { + potentialMatch = potentialMatches[i]; + // selectors add " " onto the first element. When we use & it joins the selectors together, but if we don't + // then each selector in haystackSelectorPath has a space before it added in the toCSS phase. so we need to + // work out what the resulting combinator will be + targetCombinator = haystackElement.combinator.value; + if (targetCombinator === '' && hackstackElementIndex === 0) { + targetCombinator = ' '; + } + // if we don't match, null our match to indicate failure + if (!extendVisitor.isElementValuesEqual(needleElements[potentialMatch.matched].value, haystackElement.value) || + (potentialMatch.matched > 0 && needleElements[potentialMatch.matched].combinator.value !== targetCombinator)) { + potentialMatch = null; + } + else { + potentialMatch.matched++; + } + // if we are still valid and have finished, test whether we have elements after and whether these are allowed + if (potentialMatch) { + potentialMatch.finished = potentialMatch.matched === needleElements.length; + if (potentialMatch.finished && + (!extend.allowAfter && + (hackstackElementIndex + 1 < hackstackSelector.elements.length || haystackSelectorIndex + 1 < haystackSelectorPath.length))) { + potentialMatch = null; + } + } + // if null we remove, if not, we are still valid, so either push as a valid match or continue + if (potentialMatch) { + if (potentialMatch.finished) { + potentialMatch.length = needleElements.length; + potentialMatch.endPathIndex = haystackSelectorIndex; + potentialMatch.endPathElementIndex = hackstackElementIndex + 1; // index after end of match + potentialMatches.length = 0; // we don't allow matches to overlap, so start matching again + matches.push(potentialMatch); + } + } + else { + potentialMatches.splice(i, 1); + i--; + } + } + } + } + return matches; + }; + ProcessExtendsVisitor.prototype.isElementValuesEqual = function (elementValue1, elementValue2) { + if (typeof elementValue1 === 'string' || typeof elementValue2 === 'string') { + return elementValue1 === elementValue2; + } + if (elementValue1 instanceof tree.Attribute) { + if (elementValue1.op !== elementValue2.op || elementValue1.key !== elementValue2.key) { + return false; + } + if (!elementValue1.value || !elementValue2.value) { + if (elementValue1.value || elementValue2.value) { + return false; + } + return true; + } + elementValue1 = elementValue1.value.value || elementValue1.value; + elementValue2 = elementValue2.value.value || elementValue2.value; + return elementValue1 === elementValue2; + } + elementValue1 = elementValue1.value; + elementValue2 = elementValue2.value; + if (elementValue1 instanceof tree.Selector) { + if (!(elementValue2 instanceof tree.Selector) || elementValue1.elements.length !== elementValue2.elements.length) { + return false; + } + for (var i = 0; i < elementValue1.elements.length; i++) { + if (elementValue1.elements[i].combinator.value !== elementValue2.elements[i].combinator.value) { + if (i !== 0 || (elementValue1.elements[i].combinator.value || ' ') !== (elementValue2.elements[i].combinator.value || ' ')) { + return false; + } + } + if (!this.isElementValuesEqual(elementValue1.elements[i].value, elementValue2.elements[i].value)) { + return false; + } + } + return true; + } + return false; + }; + ProcessExtendsVisitor.prototype.extendSelector = function (matches, selectorPath, replacementSelector, isVisible) { + // for a set of matches, replace each match with the replacement selector + var currentSelectorPathIndex = 0, currentSelectorPathElementIndex = 0, path = [], matchIndex, selector, firstElement, match, newElements; + for (matchIndex = 0; matchIndex < matches.length; matchIndex++) { + match = matches[matchIndex]; + selector = selectorPath[match.pathIndex]; + firstElement = new tree.Element(match.initialCombinator, replacementSelector.elements[0].value, replacementSelector.elements[0].isVariable, replacementSelector.elements[0].getIndex(), replacementSelector.elements[0].fileInfo()); + if (match.pathIndex > currentSelectorPathIndex && currentSelectorPathElementIndex > 0) { + path[path.length - 1].elements = path[path.length - 1] + .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex)); + currentSelectorPathElementIndex = 0; + currentSelectorPathIndex++; + } + newElements = selector.elements + .slice(currentSelectorPathElementIndex, match.index) + .concat([firstElement]) + .concat(replacementSelector.elements.slice(1)); + if (currentSelectorPathIndex === match.pathIndex && matchIndex > 0) { + path[path.length - 1].elements = + path[path.length - 1].elements.concat(newElements); + } + else { + path = path.concat(selectorPath.slice(currentSelectorPathIndex, match.pathIndex)); + path.push(new tree.Selector(newElements)); + } + currentSelectorPathIndex = match.endPathIndex; + currentSelectorPathElementIndex = match.endPathElementIndex; + if (currentSelectorPathElementIndex >= selectorPath[currentSelectorPathIndex].elements.length) { + currentSelectorPathElementIndex = 0; + currentSelectorPathIndex++; + } + } + if (currentSelectorPathIndex < selectorPath.length && currentSelectorPathElementIndex > 0) { + path[path.length - 1].elements = path[path.length - 1] + .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex)); + currentSelectorPathIndex++; + } + path = path.concat(selectorPath.slice(currentSelectorPathIndex, selectorPath.length)); + path = path.map(function (currentValue) { + // we can re-use elements here, because the visibility property matters only for selectors + var derived = currentValue.createDerived(currentValue.elements); + if (isVisible) { + derived.ensureVisibility(); + } + else { + derived.ensureInvisibility(); + } + return derived; + }); + return path; + }; + ProcessExtendsVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { + var newAllExtends = mediaNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]); + newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, mediaNode.allExtends)); + this.allExtendsStack.push(newAllExtends); + }; + ProcessExtendsVisitor.prototype.visitMediaOut = function (mediaNode) { + var lastIndex = this.allExtendsStack.length - 1; + this.allExtendsStack.length = lastIndex; + }; + ProcessExtendsVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { + var newAllExtends = atRuleNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]); + newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, atRuleNode.allExtends)); + this.allExtendsStack.push(newAllExtends); + }; + ProcessExtendsVisitor.prototype.visitAtRuleOut = function (atRuleNode) { + var lastIndex = this.allExtendsStack.length - 1; + this.allExtendsStack.length = lastIndex; + }; + return ProcessExtendsVisitor; + }()); - var JoinSelectorVisitor = /** @class */ (function () { - function JoinSelectorVisitor() { - this.contexts = [[]]; - this._visitor = new Visitor(this); - } - JoinSelectorVisitor.prototype.run = function (root) { - return this._visitor.visit(root); - }; - JoinSelectorVisitor.prototype.visitDeclaration = function (declNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - JoinSelectorVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { - visitArgs.visitDeeper = false; - }; - JoinSelectorVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { - var context = this.contexts[this.contexts.length - 1]; - var paths = []; - var selectors; - this.contexts.push(paths); - if (!rulesetNode.root) { - selectors = rulesetNode.selectors; - if (selectors) { - selectors = selectors.filter(function (selector) { return selector.getIsOutput(); }); - rulesetNode.selectors = selectors.length ? selectors : (selectors = null); - if (selectors) { - rulesetNode.joinSelectors(paths, context, selectors); - } - } - if (!selectors) { - rulesetNode.rules = null; - } - rulesetNode.paths = paths; - } - }; - JoinSelectorVisitor.prototype.visitRulesetOut = function (rulesetNode) { - this.contexts.length = this.contexts.length - 1; - }; - JoinSelectorVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { - var context = this.contexts[this.contexts.length - 1]; - mediaNode.rules[0].root = (context.length === 0 || context[0].multiMedia); - }; - JoinSelectorVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { - var context = this.contexts[this.contexts.length - 1]; - if (atRuleNode.rules && atRuleNode.rules.length) { - atRuleNode.rules[0].root = (atRuleNode.isRooted || context.length === 0 || null); - } - }; - return JoinSelectorVisitor; - }()); + var JoinSelectorVisitor = /** @class */ (function () { + function JoinSelectorVisitor() { + this.contexts = [[]]; + this._visitor = new Visitor(this); + } + JoinSelectorVisitor.prototype.run = function (root) { + return this._visitor.visit(root); + }; + JoinSelectorVisitor.prototype.visitDeclaration = function (declNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + JoinSelectorVisitor.prototype.visitMixinDefinition = function (mixinDefinitionNode, visitArgs) { + visitArgs.visitDeeper = false; + }; + JoinSelectorVisitor.prototype.visitRuleset = function (rulesetNode, visitArgs) { + var context = this.contexts[this.contexts.length - 1]; + var paths = []; + var selectors; + this.contexts.push(paths); + if (!rulesetNode.root) { + selectors = rulesetNode.selectors; + if (selectors) { + selectors = selectors.filter(function (selector) { return selector.getIsOutput(); }); + rulesetNode.selectors = selectors.length ? selectors : (selectors = null); + if (selectors) { + rulesetNode.joinSelectors(paths, context, selectors); + } + } + if (!selectors) { + rulesetNode.rules = null; + } + rulesetNode.paths = paths; + } + }; + JoinSelectorVisitor.prototype.visitRulesetOut = function (rulesetNode) { + this.contexts.length = this.contexts.length - 1; + }; + JoinSelectorVisitor.prototype.visitMedia = function (mediaNode, visitArgs) { + var context = this.contexts[this.contexts.length - 1]; + mediaNode.rules[0].root = (context.length === 0 || context[0].multiMedia); + }; + JoinSelectorVisitor.prototype.visitAtRule = function (atRuleNode, visitArgs) { + var context = this.contexts[this.contexts.length - 1]; + if (atRuleNode.rules && atRuleNode.rules.length) { + atRuleNode.rules[0].root = (atRuleNode.isRooted || context.length === 0 || null); + } + }; + return JoinSelectorVisitor; + }()); - var CSSVisitorUtils = /** @class */ (function () { - function CSSVisitorUtils(context) { - this._visitor = new Visitor(this); - this._context = context; - } - CSSVisitorUtils.prototype.containsSilentNonBlockedChild = function (bodyRules) { - var rule; - if (!bodyRules) { - return false; - } - for (var r = 0; r < bodyRules.length; r++) { - rule = bodyRules[r]; - if (rule.isSilent && rule.isSilent(this._context) && !rule.blocksVisibility()) { - // the atrule contains something that was referenced (likely by extend) - // therefore it needs to be shown in output too - return true; - } - } - return false; - }; - CSSVisitorUtils.prototype.keepOnlyVisibleChilds = function (owner) { - if (owner && owner.rules) { - owner.rules = owner.rules.filter(function (thing) { return thing.isVisible(); }); - } - }; - CSSVisitorUtils.prototype.isEmpty = function (owner) { - return (owner && owner.rules) - ? (owner.rules.length === 0) : true; - }; - CSSVisitorUtils.prototype.hasVisibleSelector = function (rulesetNode) { - return (rulesetNode && rulesetNode.paths) - ? (rulesetNode.paths.length > 0) : false; - }; - CSSVisitorUtils.prototype.resolveVisibility = function (node, originalRules) { - if (!node.blocksVisibility()) { - if (this.isEmpty(node) && !this.containsSilentNonBlockedChild(originalRules)) { - return; - } - return node; - } - var compiledRulesBody = node.rules[0]; - this.keepOnlyVisibleChilds(compiledRulesBody); - if (this.isEmpty(compiledRulesBody)) { - return; - } - node.ensureVisibility(); - node.removeVisibilityBlock(); - return node; - }; - CSSVisitorUtils.prototype.isVisibleRuleset = function (rulesetNode) { - if (rulesetNode.firstRoot) { - return true; - } - if (this.isEmpty(rulesetNode)) { - return false; - } - if (!rulesetNode.root && !this.hasVisibleSelector(rulesetNode)) { - return false; - } - return true; - }; - return CSSVisitorUtils; - }()); - var ToCSSVisitor = function (context) { - this._visitor = new Visitor(this); - this._context = context; - this.utils = new CSSVisitorUtils(context); - }; - ToCSSVisitor.prototype = { - isReplacing: true, - run: function (root) { - return this._visitor.visit(root); - }, - visitDeclaration: function (declNode, visitArgs) { - if (declNode.blocksVisibility() || declNode.variable) { - return; - } - return declNode; - }, - visitMixinDefinition: function (mixinNode, visitArgs) { - // mixin definitions do not get eval'd - this means they keep state - // so we have to clear that state here so it isn't used if toCSS is called twice - mixinNode.frames = []; - }, - visitExtend: function (extendNode, visitArgs) { - }, - visitComment: function (commentNode, visitArgs) { - if (commentNode.blocksVisibility() || commentNode.isSilent(this._context)) { - return; - } - return commentNode; - }, - visitMedia: function (mediaNode, visitArgs) { - var originalRules = mediaNode.rules[0].rules; - mediaNode.accept(this._visitor); - visitArgs.visitDeeper = false; - return this.utils.resolveVisibility(mediaNode, originalRules); - }, - visitImport: function (importNode, visitArgs) { - if (importNode.blocksVisibility()) { - return; - } - return importNode; - }, - visitAtRule: function (atRuleNode, visitArgs) { - if (atRuleNode.rules && atRuleNode.rules.length) { - return this.visitAtRuleWithBody(atRuleNode, visitArgs); - } - else { - return this.visitAtRuleWithoutBody(atRuleNode, visitArgs); - } - }, - visitAnonymous: function (anonymousNode, visitArgs) { - if (!anonymousNode.blocksVisibility()) { - anonymousNode.accept(this._visitor); - return anonymousNode; - } - }, - visitAtRuleWithBody: function (atRuleNode, visitArgs) { - // if there is only one nested ruleset and that one has no path, then it is - // just fake ruleset - function hasFakeRuleset(atRuleNode) { - var bodyRules = atRuleNode.rules; - return bodyRules.length === 1 && (!bodyRules[0].paths || bodyRules[0].paths.length === 0); - } - function getBodyRules(atRuleNode) { - var nodeRules = atRuleNode.rules; - if (hasFakeRuleset(atRuleNode)) { - return nodeRules[0].rules; - } - return nodeRules; - } - // it is still true that it is only one ruleset in array - // this is last such moment - // process childs - var originalRules = getBodyRules(atRuleNode); - atRuleNode.accept(this._visitor); - visitArgs.visitDeeper = false; - if (!this.utils.isEmpty(atRuleNode)) { - this._mergeRules(atRuleNode.rules[0].rules); - } - return this.utils.resolveVisibility(atRuleNode, originalRules); - }, - visitAtRuleWithoutBody: function (atRuleNode, visitArgs) { - if (atRuleNode.blocksVisibility()) { - return; - } - if (atRuleNode.name === '@charset') { - // Only output the debug info together with subsequent @charset definitions - // a comment (or @media statement) before the actual @charset atrule would - // be considered illegal css as it has to be on the first line - if (this.charset) { - if (atRuleNode.debugInfo) { - var comment = new tree.Comment("/* " + atRuleNode.toCSS(this._context).replace(/\n/g, '') + " */\n"); - comment.debugInfo = atRuleNode.debugInfo; - return this._visitor.visit(comment); - } - return; - } - this.charset = true; - } - return atRuleNode; - }, - checkValidNodes: function (rules, isRoot) { - if (!rules) { - return; - } - for (var i = 0; i < rules.length; i++) { - var ruleNode = rules[i]; - if (isRoot && ruleNode instanceof tree.Declaration && !ruleNode.variable) { - throw { message: 'Properties must be inside selector blocks. They cannot be in the root', - index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; - } - if (ruleNode instanceof tree.Call) { - throw { message: "Function '" + ruleNode.name + "' is undefined", index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; - } - if (ruleNode.type && !ruleNode.allowRoot) { - throw { message: ruleNode.type + " node returned by a function is not valid here", index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; - } - } - }, - visitRuleset: function (rulesetNode, visitArgs) { - // at this point rulesets are nested into each other - var rule; - var rulesets = []; - this.checkValidNodes(rulesetNode.rules, rulesetNode.firstRoot); - if (!rulesetNode.root) { - // remove invisible paths - this._compileRulesetPaths(rulesetNode); - // remove rulesets from this ruleset body and compile them separately - var nodeRules = rulesetNode.rules; - var nodeRuleCnt = nodeRules ? nodeRules.length : 0; - for (var i = 0; i < nodeRuleCnt;) { - rule = nodeRules[i]; - if (rule && rule.rules) { - // visit because we are moving them out from being a child - rulesets.push(this._visitor.visit(rule)); - nodeRules.splice(i, 1); - nodeRuleCnt--; - continue; - } - i++; - } - // accept the visitor to remove rules and refactor itself - // then we can decide nogw whether we want it or not - // compile body - if (nodeRuleCnt > 0) { - rulesetNode.accept(this._visitor); - } - else { - rulesetNode.rules = null; - } - visitArgs.visitDeeper = false; - } - else { // if (! rulesetNode.root) { - rulesetNode.accept(this._visitor); - visitArgs.visitDeeper = false; - } - if (rulesetNode.rules) { - this._mergeRules(rulesetNode.rules); - this._removeDuplicateRules(rulesetNode.rules); - } - // now decide whether we keep the ruleset - if (this.utils.isVisibleRuleset(rulesetNode)) { - rulesetNode.ensureVisibility(); - rulesets.splice(0, 0, rulesetNode); - } - if (rulesets.length === 1) { - return rulesets[0]; - } - return rulesets; - }, - _compileRulesetPaths: function (rulesetNode) { - if (rulesetNode.paths) { - rulesetNode.paths = rulesetNode.paths - .filter(function (p) { - var i; - if (p[0].elements[0].combinator.value === ' ') { - p[0].elements[0].combinator = new (tree.Combinator)(''); - } - for (i = 0; i < p.length; i++) { - if (p[i].isVisible() && p[i].getIsOutput()) { - return true; - } - } - return false; - }); - } - }, - _removeDuplicateRules: function (rules) { - if (!rules) { - return; - } - // remove duplicates - var ruleCache = {}; - var ruleList; - var rule; - var i; - for (i = rules.length - 1; i >= 0; i--) { - rule = rules[i]; - if (rule instanceof tree.Declaration) { - if (!ruleCache[rule.name]) { - ruleCache[rule.name] = rule; - } - else { - ruleList = ruleCache[rule.name]; - if (ruleList instanceof tree.Declaration) { - ruleList = ruleCache[rule.name] = [ruleCache[rule.name].toCSS(this._context)]; - } - var ruleCSS = rule.toCSS(this._context); - if (ruleList.indexOf(ruleCSS) !== -1) { - rules.splice(i, 1); - } - else { - ruleList.push(ruleCSS); - } - } - } - } - }, - _mergeRules: function (rules) { - if (!rules) { - return; - } - var groups = {}; - var groupsArr = []; - for (var i = 0; i < rules.length; i++) { - var rule = rules[i]; - if (rule.merge) { - var key = rule.name; - groups[key] ? rules.splice(i--, 1) : - groupsArr.push(groups[key] = []); - groups[key].push(rule); - } - } - groupsArr.forEach(function (group) { - if (group.length > 0) { - var result_1 = group[0]; - var space_1 = []; - var comma_1 = [new tree.Expression(space_1)]; - group.forEach(function (rule) { - if ((rule.merge === '+') && (space_1.length > 0)) { - comma_1.push(new tree.Expression(space_1 = [])); - } - space_1.push(rule.value); - result_1.important = result_1.important || rule.important; - }); - result_1.value = new tree.Value(comma_1); - } - }); - } - }; + var CSSVisitorUtils = /** @class */ (function () { + function CSSVisitorUtils(context) { + this._visitor = new Visitor(this); + this._context = context; + } + CSSVisitorUtils.prototype.containsSilentNonBlockedChild = function (bodyRules) { + var rule; + if (!bodyRules) { + return false; + } + for (var r = 0; r < bodyRules.length; r++) { + rule = bodyRules[r]; + if (rule.isSilent && rule.isSilent(this._context) && !rule.blocksVisibility()) { + // the atrule contains something that was referenced (likely by extend) + // therefore it needs to be shown in output too + return true; + } + } + return false; + }; + CSSVisitorUtils.prototype.keepOnlyVisibleChilds = function (owner) { + if (owner && owner.rules) { + owner.rules = owner.rules.filter(function (thing) { return thing.isVisible(); }); + } + }; + CSSVisitorUtils.prototype.isEmpty = function (owner) { + return (owner && owner.rules) + ? (owner.rules.length === 0) : true; + }; + CSSVisitorUtils.prototype.hasVisibleSelector = function (rulesetNode) { + return (rulesetNode && rulesetNode.paths) + ? (rulesetNode.paths.length > 0) : false; + }; + CSSVisitorUtils.prototype.resolveVisibility = function (node, originalRules) { + if (!node.blocksVisibility()) { + if (this.isEmpty(node) && !this.containsSilentNonBlockedChild(originalRules)) { + return; + } + return node; + } + var compiledRulesBody = node.rules[0]; + this.keepOnlyVisibleChilds(compiledRulesBody); + if (this.isEmpty(compiledRulesBody)) { + return; + } + node.ensureVisibility(); + node.removeVisibilityBlock(); + return node; + }; + CSSVisitorUtils.prototype.isVisibleRuleset = function (rulesetNode) { + if (rulesetNode.firstRoot) { + return true; + } + if (this.isEmpty(rulesetNode)) { + return false; + } + if (!rulesetNode.root && !this.hasVisibleSelector(rulesetNode)) { + return false; + } + return true; + }; + return CSSVisitorUtils; + }()); + var ToCSSVisitor = function (context) { + this._visitor = new Visitor(this); + this._context = context; + this.utils = new CSSVisitorUtils(context); + }; + ToCSSVisitor.prototype = { + isReplacing: true, + run: function (root) { + return this._visitor.visit(root); + }, + visitDeclaration: function (declNode, visitArgs) { + if (declNode.blocksVisibility() || declNode.variable) { + return; + } + return declNode; + }, + visitMixinDefinition: function (mixinNode, visitArgs) { + // mixin definitions do not get eval'd - this means they keep state + // so we have to clear that state here so it isn't used if toCSS is called twice + mixinNode.frames = []; + }, + visitExtend: function (extendNode, visitArgs) { + }, + visitComment: function (commentNode, visitArgs) { + if (commentNode.blocksVisibility() || commentNode.isSilent(this._context)) { + return; + } + return commentNode; + }, + visitMedia: function (mediaNode, visitArgs) { + var originalRules = mediaNode.rules[0].rules; + mediaNode.accept(this._visitor); + visitArgs.visitDeeper = false; + return this.utils.resolveVisibility(mediaNode, originalRules); + }, + visitImport: function (importNode, visitArgs) { + if (importNode.blocksVisibility()) { + return; + } + return importNode; + }, + visitAtRule: function (atRuleNode, visitArgs) { + if (atRuleNode.rules && atRuleNode.rules.length) { + return this.visitAtRuleWithBody(atRuleNode, visitArgs); + } + else { + return this.visitAtRuleWithoutBody(atRuleNode, visitArgs); + } + }, + visitAnonymous: function (anonymousNode, visitArgs) { + if (!anonymousNode.blocksVisibility()) { + anonymousNode.accept(this._visitor); + return anonymousNode; + } + }, + visitAtRuleWithBody: function (atRuleNode, visitArgs) { + // if there is only one nested ruleset and that one has no path, then it is + // just fake ruleset + function hasFakeRuleset(atRuleNode) { + var bodyRules = atRuleNode.rules; + return bodyRules.length === 1 && (!bodyRules[0].paths || bodyRules[0].paths.length === 0); + } + function getBodyRules(atRuleNode) { + var nodeRules = atRuleNode.rules; + if (hasFakeRuleset(atRuleNode)) { + return nodeRules[0].rules; + } + return nodeRules; + } + // it is still true that it is only one ruleset in array + // this is last such moment + // process childs + var originalRules = getBodyRules(atRuleNode); + atRuleNode.accept(this._visitor); + visitArgs.visitDeeper = false; + if (!this.utils.isEmpty(atRuleNode)) { + this._mergeRules(atRuleNode.rules[0].rules); + } + return this.utils.resolveVisibility(atRuleNode, originalRules); + }, + visitAtRuleWithoutBody: function (atRuleNode, visitArgs) { + if (atRuleNode.blocksVisibility()) { + return; + } + if (atRuleNode.name === '@charset') { + // Only output the debug info together with subsequent @charset definitions + // a comment (or @media statement) before the actual @charset atrule would + // be considered illegal css as it has to be on the first line + if (this.charset) { + if (atRuleNode.debugInfo) { + var comment = new tree.Comment("/* " + atRuleNode.toCSS(this._context).replace(/\n/g, '') + " */\n"); + comment.debugInfo = atRuleNode.debugInfo; + return this._visitor.visit(comment); + } + return; + } + this.charset = true; + } + return atRuleNode; + }, + checkValidNodes: function (rules, isRoot) { + if (!rules) { + return; + } + for (var i = 0; i < rules.length; i++) { + var ruleNode = rules[i]; + if (isRoot && ruleNode instanceof tree.Declaration && !ruleNode.variable) { + throw { message: 'Properties must be inside selector blocks. They cannot be in the root', + index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; + } + if (ruleNode instanceof tree.Call) { + throw { message: "Function '" + ruleNode.name + "' did not return a root node", index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; + } + if (ruleNode.type && !ruleNode.allowRoot) { + throw { message: ruleNode.type + " node returned by a function is not valid here", index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename }; + } + } + }, + visitRuleset: function (rulesetNode, visitArgs) { + // at this point rulesets are nested into each other + var rule; + var rulesets = []; + this.checkValidNodes(rulesetNode.rules, rulesetNode.firstRoot); + if (!rulesetNode.root) { + // remove invisible paths + this._compileRulesetPaths(rulesetNode); + // remove rulesets from this ruleset body and compile them separately + var nodeRules = rulesetNode.rules; + var nodeRuleCnt = nodeRules ? nodeRules.length : 0; + for (var i = 0; i < nodeRuleCnt;) { + rule = nodeRules[i]; + if (rule && rule.rules) { + // visit because we are moving them out from being a child + rulesets.push(this._visitor.visit(rule)); + nodeRules.splice(i, 1); + nodeRuleCnt--; + continue; + } + i++; + } + // accept the visitor to remove rules and refactor itself + // then we can decide nogw whether we want it or not + // compile body + if (nodeRuleCnt > 0) { + rulesetNode.accept(this._visitor); + } + else { + rulesetNode.rules = null; + } + visitArgs.visitDeeper = false; + } + else { // if (! rulesetNode.root) { + rulesetNode.accept(this._visitor); + visitArgs.visitDeeper = false; + } + if (rulesetNode.rules) { + this._mergeRules(rulesetNode.rules); + this._removeDuplicateRules(rulesetNode.rules); + } + // now decide whether we keep the ruleset + if (this.utils.isVisibleRuleset(rulesetNode)) { + rulesetNode.ensureVisibility(); + rulesets.splice(0, 0, rulesetNode); + } + if (rulesets.length === 1) { + return rulesets[0]; + } + return rulesets; + }, + _compileRulesetPaths: function (rulesetNode) { + if (rulesetNode.paths) { + rulesetNode.paths = rulesetNode.paths + .filter(function (p) { + var i; + if (p[0].elements[0].combinator.value === ' ') { + p[0].elements[0].combinator = new (tree.Combinator)(''); + } + for (i = 0; i < p.length; i++) { + if (p[i].isVisible() && p[i].getIsOutput()) { + return true; + } + } + return false; + }); + } + }, + _removeDuplicateRules: function (rules) { + if (!rules) { + return; + } + // remove duplicates + var ruleCache = {}; + var ruleList; + var rule; + var i; + for (i = rules.length - 1; i >= 0; i--) { + rule = rules[i]; + if (rule instanceof tree.Declaration) { + if (!ruleCache[rule.name]) { + ruleCache[rule.name] = rule; + } + else { + ruleList = ruleCache[rule.name]; + if (ruleList instanceof tree.Declaration) { + ruleList = ruleCache[rule.name] = [ruleCache[rule.name].toCSS(this._context)]; + } + var ruleCSS = rule.toCSS(this._context); + if (ruleList.indexOf(ruleCSS) !== -1) { + rules.splice(i, 1); + } + else { + ruleList.push(ruleCSS); + } + } + } + } + }, + _mergeRules: function (rules) { + if (!rules) { + return; + } + var groups = {}; + var groupsArr = []; + for (var i = 0; i < rules.length; i++) { + var rule = rules[i]; + if (rule.merge) { + var key = rule.name; + groups[key] ? rules.splice(i--, 1) : + groupsArr.push(groups[key] = []); + groups[key].push(rule); + } + } + groupsArr.forEach(function (group) { + if (group.length > 0) { + var result_1 = group[0]; + var space_1 = []; + var comma_1 = [new tree.Expression(space_1)]; + group.forEach(function (rule) { + if ((rule.merge === '+') && (space_1.length > 0)) { + comma_1.push(new tree.Expression(space_1 = [])); + } + space_1.push(rule.value); + result_1.important = result_1.important || rule.important; + }); + result_1.value = new tree.Value(comma_1); + } + }); + } + }; - var visitors = { - Visitor: Visitor, - ImportVisitor: ImportVisitor, - MarkVisibleSelectorsVisitor: SetTreeVisibilityVisitor, - ExtendVisitor: ProcessExtendsVisitor, - JoinSelectorVisitor: JoinSelectorVisitor, - ToCSSVisitor: ToCSSVisitor - }; + var visitors = { + Visitor: Visitor, + ImportVisitor: ImportVisitor, + MarkVisibleSelectorsVisitor: SetTreeVisibilityVisitor, + ExtendVisitor: ProcessExtendsVisitor, + JoinSelectorVisitor: JoinSelectorVisitor, + ToCSSVisitor: ToCSSVisitor + }; - // Split the input into chunks. - var chunker = (function (input, fail) { - var len = input.length; - var level = 0; - var parenLevel = 0; - var lastOpening; - var lastOpeningParen; - var lastMultiComment; - var lastMultiCommentEndBrace; - var chunks = []; - var emitFrom = 0; - var chunkerCurrentIndex; - var currentChunkStartIndex; - var cc; - var cc2; - var matched; - function emitChunk(force) { - var len = chunkerCurrentIndex - emitFrom; - if (((len < 512) && !force) || !len) { - return; - } - chunks.push(input.slice(emitFrom, chunkerCurrentIndex + 1)); - emitFrom = chunkerCurrentIndex + 1; - } - for (chunkerCurrentIndex = 0; chunkerCurrentIndex < len; chunkerCurrentIndex++) { - cc = input.charCodeAt(chunkerCurrentIndex); - if (((cc >= 97) && (cc <= 122)) || (cc < 34)) { - // a-z or whitespace - continue; - } - switch (cc) { - case 40: // ( - parenLevel++; - lastOpeningParen = chunkerCurrentIndex; - continue; - case 41: // ) - if (--parenLevel < 0) { - return fail('missing opening `(`', chunkerCurrentIndex); - } - continue; - case 59: // ; - if (!parenLevel) { - emitChunk(); - } - continue; - case 123: // { - level++; - lastOpening = chunkerCurrentIndex; - continue; - case 125: // } - if (--level < 0) { - return fail('missing opening `{`', chunkerCurrentIndex); - } - if (!level && !parenLevel) { - emitChunk(); - } - continue; - case 92: // \ - if (chunkerCurrentIndex < len - 1) { - chunkerCurrentIndex++; - continue; - } - return fail('unescaped `\\`', chunkerCurrentIndex); - case 34: - case 39: - case 96: // ", ' and ` - matched = 0; - currentChunkStartIndex = chunkerCurrentIndex; - for (chunkerCurrentIndex = chunkerCurrentIndex + 1; chunkerCurrentIndex < len; chunkerCurrentIndex++) { - cc2 = input.charCodeAt(chunkerCurrentIndex); - if (cc2 > 96) { - continue; - } - if (cc2 == cc) { - matched = 1; - break; - } - if (cc2 == 92) { // \ - if (chunkerCurrentIndex == len - 1) { - return fail('unescaped `\\`', chunkerCurrentIndex); - } - chunkerCurrentIndex++; - } - } - if (matched) { - continue; - } - return fail("unmatched `" + String.fromCharCode(cc) + "`", currentChunkStartIndex); - case 47: // /, check for comment - if (parenLevel || (chunkerCurrentIndex == len - 1)) { - continue; - } - cc2 = input.charCodeAt(chunkerCurrentIndex + 1); - if (cc2 == 47) { - // //, find lnfeed - for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len; chunkerCurrentIndex++) { - cc2 = input.charCodeAt(chunkerCurrentIndex); - if ((cc2 <= 13) && ((cc2 == 10) || (cc2 == 13))) { - break; - } - } - } - else if (cc2 == 42) { - // /*, find */ - lastMultiComment = currentChunkStartIndex = chunkerCurrentIndex; - for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len - 1; chunkerCurrentIndex++) { - cc2 = input.charCodeAt(chunkerCurrentIndex); - if (cc2 == 125) { - lastMultiCommentEndBrace = chunkerCurrentIndex; - } - if (cc2 != 42) { - continue; - } - if (input.charCodeAt(chunkerCurrentIndex + 1) == 47) { - break; - } - } - if (chunkerCurrentIndex == len - 1) { - return fail('missing closing `*/`', currentChunkStartIndex); - } - chunkerCurrentIndex++; - } - continue; - case 42: // *, check for unmatched */ - if ((chunkerCurrentIndex < len - 1) && (input.charCodeAt(chunkerCurrentIndex + 1) == 47)) { - return fail('unmatched `/*`', chunkerCurrentIndex); - } - continue; - } - } - if (level !== 0) { - if ((lastMultiComment > lastOpening) && (lastMultiCommentEndBrace > lastMultiComment)) { - return fail('missing closing `}` or `*/`', lastOpening); - } - else { - return fail('missing closing `}`', lastOpening); - } - } - else if (parenLevel !== 0) { - return fail('missing closing `)`', lastOpeningParen); - } - emitChunk(true); - return chunks; - }); + // Split the input into chunks. + function chunker (input, fail) { + var len = input.length; + var level = 0; + var parenLevel = 0; + var lastOpening; + var lastOpeningParen; + var lastMultiComment; + var lastMultiCommentEndBrace; + var chunks = []; + var emitFrom = 0; + var chunkerCurrentIndex; + var currentChunkStartIndex; + var cc; + var cc2; + var matched; + function emitChunk(force) { + var len = chunkerCurrentIndex - emitFrom; + if (((len < 512) && !force) || !len) { + return; + } + chunks.push(input.slice(emitFrom, chunkerCurrentIndex + 1)); + emitFrom = chunkerCurrentIndex + 1; + } + for (chunkerCurrentIndex = 0; chunkerCurrentIndex < len; chunkerCurrentIndex++) { + cc = input.charCodeAt(chunkerCurrentIndex); + if (((cc >= 97) && (cc <= 122)) || (cc < 34)) { + // a-z or whitespace + continue; + } + switch (cc) { + case 40: // ( + parenLevel++; + lastOpeningParen = chunkerCurrentIndex; + continue; + case 41: // ) + if (--parenLevel < 0) { + return fail('missing opening `(`', chunkerCurrentIndex); + } + continue; + case 59: // ; + if (!parenLevel) { + emitChunk(); + } + continue; + case 123: // { + level++; + lastOpening = chunkerCurrentIndex; + continue; + case 125: // } + if (--level < 0) { + return fail('missing opening `{`', chunkerCurrentIndex); + } + if (!level && !parenLevel) { + emitChunk(); + } + continue; + case 92: // \ + if (chunkerCurrentIndex < len - 1) { + chunkerCurrentIndex++; + continue; + } + return fail('unescaped `\\`', chunkerCurrentIndex); + case 34: + case 39: + case 96: // ", ' and ` + matched = 0; + currentChunkStartIndex = chunkerCurrentIndex; + for (chunkerCurrentIndex = chunkerCurrentIndex + 1; chunkerCurrentIndex < len; chunkerCurrentIndex++) { + cc2 = input.charCodeAt(chunkerCurrentIndex); + if (cc2 > 96) { + continue; + } + if (cc2 == cc) { + matched = 1; + break; + } + if (cc2 == 92) { // \ + if (chunkerCurrentIndex == len - 1) { + return fail('unescaped `\\`', chunkerCurrentIndex); + } + chunkerCurrentIndex++; + } + } + if (matched) { + continue; + } + return fail("unmatched `" + String.fromCharCode(cc) + "`", currentChunkStartIndex); + case 47: // /, check for comment + if (parenLevel || (chunkerCurrentIndex == len - 1)) { + continue; + } + cc2 = input.charCodeAt(chunkerCurrentIndex + 1); + if (cc2 == 47) { + // //, find lnfeed + for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len; chunkerCurrentIndex++) { + cc2 = input.charCodeAt(chunkerCurrentIndex); + if ((cc2 <= 13) && ((cc2 == 10) || (cc2 == 13))) { + break; + } + } + } + else if (cc2 == 42) { + // /*, find */ + lastMultiComment = currentChunkStartIndex = chunkerCurrentIndex; + for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len - 1; chunkerCurrentIndex++) { + cc2 = input.charCodeAt(chunkerCurrentIndex); + if (cc2 == 125) { + lastMultiCommentEndBrace = chunkerCurrentIndex; + } + if (cc2 != 42) { + continue; + } + if (input.charCodeAt(chunkerCurrentIndex + 1) == 47) { + break; + } + } + if (chunkerCurrentIndex == len - 1) { + return fail('missing closing `*/`', currentChunkStartIndex); + } + chunkerCurrentIndex++; + } + continue; + case 42: // *, check for unmatched */ + if ((chunkerCurrentIndex < len - 1) && (input.charCodeAt(chunkerCurrentIndex + 1) == 47)) { + return fail('unmatched `/*`', chunkerCurrentIndex); + } + continue; + } + } + if (level !== 0) { + if ((lastMultiComment > lastOpening) && (lastMultiCommentEndBrace > lastMultiComment)) { + return fail('missing closing `}` or `*/`', lastOpening); + } + else { + return fail('missing closing `}`', lastOpening); + } + } + else if (parenLevel !== 0) { + return fail('missing closing `)`', lastOpeningParen); + } + emitChunk(true); + return chunks; + } - var getParserInput = (function () { - var // Less input string - input; - var // current chunk - j; - var // holds state for backtracking - saveStack = []; - var // furthest index the parser has gone to - furthest; - var // if this is furthest we got to, this is the probably cause - furthestPossibleErrorMessage; - var // chunkified input - chunks; - var // current chunk - current; - var // index of current chunk, in `input` - currentPos; - var parserInput = {}; - var CHARCODE_SPACE = 32; - var CHARCODE_TAB = 9; - var CHARCODE_LF = 10; - var CHARCODE_CR = 13; - var CHARCODE_PLUS = 43; - var CHARCODE_COMMA = 44; - var CHARCODE_FORWARD_SLASH = 47; - var CHARCODE_9 = 57; - function skipWhitespace(length) { - var oldi = parserInput.i; - var oldj = j; - var curr = parserInput.i - currentPos; - var endIndex = parserInput.i + current.length - curr; - var mem = (parserInput.i += length); - var inp = input; - var c; - var nextChar; - var comment; - for (; parserInput.i < endIndex; parserInput.i++) { - c = inp.charCodeAt(parserInput.i); - if (parserInput.autoCommentAbsorb && c === CHARCODE_FORWARD_SLASH) { - nextChar = inp.charAt(parserInput.i + 1); - if (nextChar === '/') { - comment = { index: parserInput.i, isLineComment: true }; - var nextNewLine = inp.indexOf('\n', parserInput.i + 2); - if (nextNewLine < 0) { - nextNewLine = endIndex; - } - parserInput.i = nextNewLine; - comment.text = inp.substr(comment.index, parserInput.i - comment.index); - parserInput.commentStore.push(comment); - continue; - } - else if (nextChar === '*') { - var nextStarSlash = inp.indexOf('*/', parserInput.i + 2); - if (nextStarSlash >= 0) { - comment = { - index: parserInput.i, - text: inp.substr(parserInput.i, nextStarSlash + 2 - parserInput.i), - isLineComment: false - }; - parserInput.i += comment.text.length - 1; - parserInput.commentStore.push(comment); - continue; - } - } - break; - } - if ((c !== CHARCODE_SPACE) && (c !== CHARCODE_LF) && (c !== CHARCODE_TAB) && (c !== CHARCODE_CR)) { - break; - } - } - current = current.slice(length + parserInput.i - mem + curr); - currentPos = parserInput.i; - if (!current.length) { - if (j < chunks.length - 1) { - current = chunks[++j]; - skipWhitespace(0); // skip space at the beginning of a chunk - return true; // things changed - } - parserInput.finished = true; - } - return oldi !== parserInput.i || oldj !== j; - } - parserInput.save = function () { - currentPos = parserInput.i; - saveStack.push({ current: current, i: parserInput.i, j: j }); - }; - parserInput.restore = function (possibleErrorMessage) { - if (parserInput.i > furthest || (parserInput.i === furthest && possibleErrorMessage && !furthestPossibleErrorMessage)) { - furthest = parserInput.i; - furthestPossibleErrorMessage = possibleErrorMessage; - } - var state = saveStack.pop(); - current = state.current; - currentPos = parserInput.i = state.i; - j = state.j; - }; - parserInput.forget = function () { - saveStack.pop(); - }; - parserInput.isWhitespace = function (offset) { - var pos = parserInput.i + (offset || 0); - var code = input.charCodeAt(pos); - return (code === CHARCODE_SPACE || code === CHARCODE_CR || code === CHARCODE_TAB || code === CHARCODE_LF); - }; - // Specialization of $(tok) - parserInput.$re = function (tok) { - if (parserInput.i > currentPos) { - current = current.slice(parserInput.i - currentPos); - currentPos = parserInput.i; - } - var m = tok.exec(current); - if (!m) { - return null; - } - skipWhitespace(m[0].length); - if (typeof m === 'string') { - return m; - } - return m.length === 1 ? m[0] : m; - }; - parserInput.$char = function (tok) { - if (input.charAt(parserInput.i) !== tok) { - return null; - } - skipWhitespace(1); - return tok; - }; - parserInput.$str = function (tok) { - var tokLength = tok.length; - // https://jsperf.com/string-startswith/21 - for (var i = 0; i < tokLength; i++) { - if (input.charAt(parserInput.i + i) !== tok.charAt(i)) { - return null; - } - } - skipWhitespace(tokLength); - return tok; - }; - parserInput.$quoted = function (loc) { - var pos = loc || parserInput.i; - var startChar = input.charAt(pos); - if (startChar !== '\'' && startChar !== '"') { - return; - } - var length = input.length; - var currentPosition = pos; - for (var i = 1; i + currentPosition < length; i++) { - var nextChar = input.charAt(i + currentPosition); - switch (nextChar) { - case '\\': - i++; - continue; - case '\r': - case '\n': - break; - case startChar: - var str = input.substr(currentPosition, i + 1); - if (!loc && loc !== 0) { - skipWhitespace(i + 1); - return str; - } - return [startChar, str]; - } - } - return null; - }; - /** - * Permissive parsing. Ignores everything except matching {} [] () and quotes - * until matching token (outside of blocks) - */ - parserInput.$parseUntil = function (tok) { - var quote = ''; - var returnVal = null; - var inComment = false; - var blockDepth = 0; - var blockStack = []; - var parseGroups = []; - var length = input.length; - var startPos = parserInput.i; - var lastPos = parserInput.i; - var i = parserInput.i; - var loop = true; - var testChar; - if (typeof tok === 'string') { - testChar = function (char) { return char === tok; }; - } - else { - testChar = function (char) { return tok.test(char); }; - } - do { - var nextChar = input.charAt(i); - if (blockDepth === 0 && testChar(nextChar)) { - returnVal = input.substr(lastPos, i - lastPos); - if (returnVal) { - parseGroups.push(returnVal); - } - else { - parseGroups.push(' '); - } - returnVal = parseGroups; - skipWhitespace(i - startPos); - loop = false; - } - else { - if (inComment) { - if (nextChar === '*' && - input.charAt(i + 1) === '/') { - i++; - blockDepth--; - inComment = false; - } - i++; - continue; - } - switch (nextChar) { - case '\\': - i++; - nextChar = input.charAt(i); - parseGroups.push(input.substr(lastPos, i - lastPos + 1)); - lastPos = i + 1; - break; - case '/': - if (input.charAt(i + 1) === '*') { - i++; - inComment = true; - blockDepth++; - } - break; - case '\'': - case '"': - quote = parserInput.$quoted(i); - if (quote) { - parseGroups.push(input.substr(lastPos, i - lastPos), quote); - i += quote[1].length - 1; - lastPos = i + 1; - } - else { - skipWhitespace(i - startPos); - returnVal = nextChar; - loop = false; - } - break; - case '{': - blockStack.push('}'); - blockDepth++; - break; - case '(': - blockStack.push(')'); - blockDepth++; - break; - case '[': - blockStack.push(']'); - blockDepth++; - break; - case '}': - case ')': - case ']': - var expected = blockStack.pop(); - if (nextChar === expected) { - blockDepth--; - } - else { - // move the parser to the error and return expected - skipWhitespace(i - startPos); - returnVal = expected; - loop = false; - } - } - i++; - if (i > length) { - loop = false; - } - } - } while (loop); - return returnVal ? returnVal : null; - }; - parserInput.autoCommentAbsorb = true; - parserInput.commentStore = []; - parserInput.finished = false; - // Same as $(), but don't change the state of the parser, - // just return the match. - parserInput.peek = function (tok) { - if (typeof tok === 'string') { - // https://jsperf.com/string-startswith/21 - for (var i = 0; i < tok.length; i++) { - if (input.charAt(parserInput.i + i) !== tok.charAt(i)) { - return false; - } - } - return true; - } - else { - return tok.test(current); - } - }; - // Specialization of peek() - // TODO remove or change some currentChar calls to peekChar - parserInput.peekChar = function (tok) { return input.charAt(parserInput.i) === tok; }; - parserInput.currentChar = function () { return input.charAt(parserInput.i); }; - parserInput.prevChar = function () { return input.charAt(parserInput.i - 1); }; - parserInput.getInput = function () { return input; }; - parserInput.peekNotNumeric = function () { - var c = input.charCodeAt(parserInput.i); - // Is the first char of the dimension 0-9, '.', '+' or '-' - return (c > CHARCODE_9 || c < CHARCODE_PLUS) || c === CHARCODE_FORWARD_SLASH || c === CHARCODE_COMMA; - }; - parserInput.start = function (str, chunkInput, failFunction) { - input = str; - parserInput.i = j = currentPos = furthest = 0; - // chunking apparently makes things quicker (but my tests indicate - // it might actually make things slower in node at least) - // and it is a non-perfect parse - it can't recognise - // unquoted urls, meaning it can't distinguish comments - // meaning comments with quotes or {}() in them get 'counted' - // and then lead to parse errors. - // In addition if the chunking chunks in the wrong place we might - // not be able to parse a parser statement in one go - // this is officially deprecated but can be switched on via an option - // in the case it causes too much performance issues. - if (chunkInput) { - chunks = chunker(str, failFunction); - } - else { - chunks = [str]; - } - current = chunks[0]; - skipWhitespace(0); - }; - parserInput.end = function () { - var message; - var isFinished = parserInput.i >= input.length; - if (parserInput.i < furthest) { - message = furthestPossibleErrorMessage; - parserInput.i = furthest; - } - return { - isFinished: isFinished, - furthest: parserInput.i, - furthestPossibleErrorMessage: message, - furthestReachedEnd: parserInput.i >= input.length - 1, - furthestChar: input[parserInput.i] - }; - }; - return parserInput; - }); + var getParserInput = (function () { + var // Less input string + input; + var // current chunk + j; + var // holds state for backtracking + saveStack = []; + var // furthest index the parser has gone to + furthest; + var // if this is furthest we got to, this is the probably cause + furthestPossibleErrorMessage; + var // chunkified input + chunks; + var // current chunk + current; + var // index of current chunk, in `input` + currentPos; + var parserInput = {}; + var CHARCODE_SPACE = 32; + var CHARCODE_TAB = 9; + var CHARCODE_LF = 10; + var CHARCODE_CR = 13; + var CHARCODE_PLUS = 43; + var CHARCODE_COMMA = 44; + var CHARCODE_FORWARD_SLASH = 47; + var CHARCODE_9 = 57; + function skipWhitespace(length) { + var oldi = parserInput.i; + var oldj = j; + var curr = parserInput.i - currentPos; + var endIndex = parserInput.i + current.length - curr; + var mem = (parserInput.i += length); + var inp = input; + var c; + var nextChar; + var comment; + for (; parserInput.i < endIndex; parserInput.i++) { + c = inp.charCodeAt(parserInput.i); + if (parserInput.autoCommentAbsorb && c === CHARCODE_FORWARD_SLASH) { + nextChar = inp.charAt(parserInput.i + 1); + if (nextChar === '/') { + comment = { index: parserInput.i, isLineComment: true }; + var nextNewLine = inp.indexOf('\n', parserInput.i + 2); + if (nextNewLine < 0) { + nextNewLine = endIndex; + } + parserInput.i = nextNewLine; + comment.text = inp.substr(comment.index, parserInput.i - comment.index); + parserInput.commentStore.push(comment); + continue; + } + else if (nextChar === '*') { + var nextStarSlash = inp.indexOf('*/', parserInput.i + 2); + if (nextStarSlash >= 0) { + comment = { + index: parserInput.i, + text: inp.substr(parserInput.i, nextStarSlash + 2 - parserInput.i), + isLineComment: false + }; + parserInput.i += comment.text.length - 1; + parserInput.commentStore.push(comment); + continue; + } + } + break; + } + if ((c !== CHARCODE_SPACE) && (c !== CHARCODE_LF) && (c !== CHARCODE_TAB) && (c !== CHARCODE_CR)) { + break; + } + } + current = current.slice(length + parserInput.i - mem + curr); + currentPos = parserInput.i; + if (!current.length) { + if (j < chunks.length - 1) { + current = chunks[++j]; + skipWhitespace(0); // skip space at the beginning of a chunk + return true; // things changed + } + parserInput.finished = true; + } + return oldi !== parserInput.i || oldj !== j; + } + parserInput.save = function () { + currentPos = parserInput.i; + saveStack.push({ current: current, i: parserInput.i, j: j }); + }; + parserInput.restore = function (possibleErrorMessage) { + if (parserInput.i > furthest || (parserInput.i === furthest && possibleErrorMessage && !furthestPossibleErrorMessage)) { + furthest = parserInput.i; + furthestPossibleErrorMessage = possibleErrorMessage; + } + var state = saveStack.pop(); + current = state.current; + currentPos = parserInput.i = state.i; + j = state.j; + }; + parserInput.forget = function () { + saveStack.pop(); + }; + parserInput.isWhitespace = function (offset) { + var pos = parserInput.i + (offset || 0); + var code = input.charCodeAt(pos); + return (code === CHARCODE_SPACE || code === CHARCODE_CR || code === CHARCODE_TAB || code === CHARCODE_LF); + }; + // Specialization of $(tok) + parserInput.$re = function (tok) { + if (parserInput.i > currentPos) { + current = current.slice(parserInput.i - currentPos); + currentPos = parserInput.i; + } + var m = tok.exec(current); + if (!m) { + return null; + } + skipWhitespace(m[0].length); + if (typeof m === 'string') { + return m; + } + return m.length === 1 ? m[0] : m; + }; + parserInput.$char = function (tok) { + if (input.charAt(parserInput.i) !== tok) { + return null; + } + skipWhitespace(1); + return tok; + }; + parserInput.$str = function (tok) { + var tokLength = tok.length; + // https://jsperf.com/string-startswith/21 + for (var i = 0; i < tokLength; i++) { + if (input.charAt(parserInput.i + i) !== tok.charAt(i)) { + return null; + } + } + skipWhitespace(tokLength); + return tok; + }; + parserInput.$quoted = function (loc) { + var pos = loc || parserInput.i; + var startChar = input.charAt(pos); + if (startChar !== '\'' && startChar !== '"') { + return; + } + var length = input.length; + var currentPosition = pos; + for (var i = 1; i + currentPosition < length; i++) { + var nextChar = input.charAt(i + currentPosition); + switch (nextChar) { + case '\\': + i++; + continue; + case '\r': + case '\n': + break; + case startChar: + var str = input.substr(currentPosition, i + 1); + if (!loc && loc !== 0) { + skipWhitespace(i + 1); + return str; + } + return [startChar, str]; + } + } + return null; + }; + /** + * Permissive parsing. Ignores everything except matching {} [] () and quotes + * until matching token (outside of blocks) + */ + parserInput.$parseUntil = function (tok) { + var quote = ''; + var returnVal = null; + var inComment = false; + var blockDepth = 0; + var blockStack = []; + var parseGroups = []; + var length = input.length; + var startPos = parserInput.i; + var lastPos = parserInput.i; + var i = parserInput.i; + var loop = true; + var testChar; + if (typeof tok === 'string') { + testChar = function (char) { return char === tok; }; + } + else { + testChar = function (char) { return tok.test(char); }; + } + do { + var nextChar = input.charAt(i); + if (blockDepth === 0 && testChar(nextChar)) { + returnVal = input.substr(lastPos, i - lastPos); + if (returnVal) { + parseGroups.push(returnVal); + } + else { + parseGroups.push(' '); + } + returnVal = parseGroups; + skipWhitespace(i - startPos); + loop = false; + } + else { + if (inComment) { + if (nextChar === '*' && + input.charAt(i + 1) === '/') { + i++; + blockDepth--; + inComment = false; + } + i++; + continue; + } + switch (nextChar) { + case '\\': + i++; + nextChar = input.charAt(i); + parseGroups.push(input.substr(lastPos, i - lastPos + 1)); + lastPos = i + 1; + break; + case '/': + if (input.charAt(i + 1) === '*') { + i++; + inComment = true; + blockDepth++; + } + break; + case '\'': + case '"': + quote = parserInput.$quoted(i); + if (quote) { + parseGroups.push(input.substr(lastPos, i - lastPos), quote); + i += quote[1].length - 1; + lastPos = i + 1; + } + else { + skipWhitespace(i - startPos); + returnVal = nextChar; + loop = false; + } + break; + case '{': + blockStack.push('}'); + blockDepth++; + break; + case '(': + blockStack.push(')'); + blockDepth++; + break; + case '[': + blockStack.push(']'); + blockDepth++; + break; + case '}': + case ')': + case ']': + var expected = blockStack.pop(); + if (nextChar === expected) { + blockDepth--; + } + else { + // move the parser to the error and return expected + skipWhitespace(i - startPos); + returnVal = expected; + loop = false; + } + } + i++; + if (i > length) { + loop = false; + } + } + } while (loop); + return returnVal ? returnVal : null; + }; + parserInput.autoCommentAbsorb = true; + parserInput.commentStore = []; + parserInput.finished = false; + // Same as $(), but don't change the state of the parser, + // just return the match. + parserInput.peek = function (tok) { + if (typeof tok === 'string') { + // https://jsperf.com/string-startswith/21 + for (var i = 0; i < tok.length; i++) { + if (input.charAt(parserInput.i + i) !== tok.charAt(i)) { + return false; + } + } + return true; + } + else { + return tok.test(current); + } + }; + // Specialization of peek() + // TODO remove or change some currentChar calls to peekChar + parserInput.peekChar = function (tok) { return input.charAt(parserInput.i) === tok; }; + parserInput.currentChar = function () { return input.charAt(parserInput.i); }; + parserInput.prevChar = function () { return input.charAt(parserInput.i - 1); }; + parserInput.getInput = function () { return input; }; + parserInput.peekNotNumeric = function () { + var c = input.charCodeAt(parserInput.i); + // Is the first char of the dimension 0-9, '.', '+' or '-' + return (c > CHARCODE_9 || c < CHARCODE_PLUS) || c === CHARCODE_FORWARD_SLASH || c === CHARCODE_COMMA; + }; + parserInput.start = function (str, chunkInput, failFunction) { + input = str; + parserInput.i = j = currentPos = furthest = 0; + // chunking apparently makes things quicker (but my tests indicate + // it might actually make things slower in node at least) + // and it is a non-perfect parse - it can't recognise + // unquoted urls, meaning it can't distinguish comments + // meaning comments with quotes or {}() in them get 'counted' + // and then lead to parse errors. + // In addition if the chunking chunks in the wrong place we might + // not be able to parse a parser statement in one go + // this is officially deprecated but can be switched on via an option + // in the case it causes too much performance issues. + if (chunkInput) { + chunks = chunker(str, failFunction); + } + else { + chunks = [str]; + } + current = chunks[0]; + skipWhitespace(0); + }; + parserInput.end = function () { + var message; + var isFinished = parserInput.i >= input.length; + if (parserInput.i < furthest) { + message = furthestPossibleErrorMessage; + parserInput.i = furthest; + } + return { + isFinished: isFinished, + furthest: parserInput.i, + furthestPossibleErrorMessage: message, + furthestReachedEnd: parserInput.i >= input.length - 1, + furthestChar: input[parserInput.i] + }; + }; + return parserInput; + }); - // - // less.js - parser - // - // A relatively straight-forward predictive parser. - // There is no tokenization/lexing stage, the input is parsed - // in one sweep. - // - // To make the parser fast enough to run in the browser, several - // optimization had to be made: - // - // - Matching and slicing on a huge input is often cause of slowdowns. - // The solution is to chunkify the input into smaller strings. - // The chunks are stored in the `chunks` var, - // `j` holds the current chunk index, and `currentPos` holds - // the index of the current chunk in relation to `input`. - // This gives us an almost 4x speed-up. - // - // - In many cases, we don't need to match individual tokens; - // for example, if a value doesn't hold any variables, operations - // or dynamic references, the parser can effectively 'skip' it, - // treating it as a literal. - // An example would be '1px solid #000' - which evaluates to itself, - // we don't need to know what the individual components are. - // The drawback, of course is that you don't get the benefits of - // syntax-checking on the CSS. This gives us a 50% speed-up in the parser, - // and a smaller speed-up in the code-gen. - // - // - // Token matching is done with the `$` function, which either takes - // a terminal string or regexp, or a non-terminal function to call. - // It also takes care of moving all the indices forwards. - // - var Parser = function Parser(context, imports, fileInfo) { - var parsers; - var parserInput = getParserInput(); - function error(msg, type) { - throw new LessError({ - index: parserInput.i, - filename: fileInfo.filename, - type: type || 'Syntax', - message: msg - }, imports); - } - function expect(arg, msg) { - // some older browsers return typeof 'function' for RegExp - var result = (arg instanceof Function) ? arg.call(parsers) : parserInput.$re(arg); - if (result) { - return result; - } - error(msg || (typeof arg === 'string' - ? "expected '" + arg + "' got '" + parserInput.currentChar() + "'" - : 'unexpected token')); - } - // Specialization of expect() - function expectChar(arg, msg) { - if (parserInput.$char(arg)) { - return arg; - } - error(msg || "expected '" + arg + "' got '" + parserInput.currentChar() + "'"); - } - function getDebugInfo(index) { - var filename = fileInfo.filename; - return { - lineNumber: getLocation(index, parserInput.getInput()).line + 1, - fileName: filename - }; - } - /** - * Used after initial parsing to create nodes on the fly - * - * @param {String} str - string to parse - * @param {Array} parseList - array of parsers to run input through e.g. ["value", "important"] - * @param {Number} currentIndex - start number to begin indexing - * @param {Object} fileInfo - fileInfo to attach to created nodes - */ - function parseNode(str, parseList, currentIndex, fileInfo, callback) { - var result; - var returnNodes = []; - var parser = parserInput; - try { - parser.start(str, false, function fail(msg, index) { - callback({ - message: msg, - index: index + currentIndex - }); - }); - for (var x = 0, p = void 0, i = void 0; (p = parseList[x]); x++) { - i = parser.i; - result = parsers[p](); - if (result) { - try { - result._index = i + currentIndex; - result._fileInfo = fileInfo; - } - catch (e) { } - returnNodes.push(result); - } - else { - returnNodes.push(null); - } - } - var endInfo = parser.end(); - if (endInfo.isFinished) { - callback(null, returnNodes); - } - else { - callback(true, null); - } - } - catch (e) { - throw new LessError({ - index: e.index + currentIndex, - message: e.message - }, imports, fileInfo.filename); - } - } - // - // The Parser - // - return { - parserInput: parserInput, - imports: imports, - fileInfo: fileInfo, - parseNode: parseNode, - // - // Parse an input string into an abstract syntax tree, - // @param str A string containing 'less' markup - // @param callback call `callback` when done. - // @param [additionalData] An optional map which can contains vars - a map (key, value) of variables to apply - // - parse: function (str, callback, additionalData) { - var root; - var error = null; - var globalVars; - var modifyVars; - var ignored; - var preText = ''; - globalVars = (additionalData && additionalData.globalVars) ? Parser.serializeVars(additionalData.globalVars) + "\n" : ''; - modifyVars = (additionalData && additionalData.modifyVars) ? "\n" + Parser.serializeVars(additionalData.modifyVars) : ''; - if (context.pluginManager) { - var preProcessors = context.pluginManager.getPreProcessors(); - for (var i = 0; i < preProcessors.length; i++) { - str = preProcessors[i].process(str, { context: context, imports: imports, fileInfo: fileInfo }); - } - } - if (globalVars || (additionalData && additionalData.banner)) { - preText = ((additionalData && additionalData.banner) ? additionalData.banner : '') + globalVars; - ignored = imports.contentsIgnoredChars; - ignored[fileInfo.filename] = ignored[fileInfo.filename] || 0; - ignored[fileInfo.filename] += preText.length; - } - str = str.replace(/\r\n?/g, '\n'); - // Remove potential UTF Byte Order Mark - str = preText + str.replace(/^\uFEFF/, '') + modifyVars; - imports.contents[fileInfo.filename] = str; - // Start with the primary rule. - // The whole syntax tree is held under a Ruleset node, - // with the `root` property set to true, so no `{}` are - // output. The callback is called when the input is parsed. - try { - parserInput.start(str, context.chunkInput, function fail(msg, index) { - throw new LessError({ - index: index, - type: 'Parse', - message: msg, - filename: fileInfo.filename - }, imports); - }); - tree.Node.prototype.parse = this; - root = new tree.Ruleset(null, this.parsers.primary()); - tree.Node.prototype.rootNode = root; - root.root = true; - root.firstRoot = true; - root.functionRegistry = functionRegistry.inherit(); - } - catch (e) { - return callback(new LessError(e, imports, fileInfo.filename)); - } - // If `i` is smaller than the `input.length - 1`, - // it means the parser wasn't able to parse the whole - // string, so we've got a parsing error. - // - // We try to extract a \n delimited string, - // showing the line where the parse error occurred. - // We split it up into two parts (the part which parsed, - // and the part which didn't), so we can color them differently. - var endInfo = parserInput.end(); - if (!endInfo.isFinished) { - var message = endInfo.furthestPossibleErrorMessage; - if (!message) { - message = 'Unrecognised input'; - if (endInfo.furthestChar === '}') { - message += '. Possibly missing opening \'{\''; - } - else if (endInfo.furthestChar === ')') { - message += '. Possibly missing opening \'(\''; - } - else if (endInfo.furthestReachedEnd) { - message += '. Possibly missing something'; - } - } - error = new LessError({ - type: 'Parse', - message: message, - index: endInfo.furthest, - filename: fileInfo.filename - }, imports); - } - var finish = function (e) { - e = error || e || imports.error; - if (e) { - if (!(e instanceof LessError)) { - e = new LessError(e, imports, fileInfo.filename); - } - return callback(e); - } - else { - return callback(null, root); - } - }; - if (context.processImports !== false) { - new visitors.ImportVisitor(imports, finish) - .run(root); - } - else { - return finish(); - } - }, - // - // Here in, the parsing rules/functions - // - // The basic structure of the syntax tree generated is as follows: - // - // Ruleset -> Declaration -> Value -> Expression -> Entity - // - // Here's some Less code: - // - // .class { - // color: #fff; - // border: 1px solid #000; - // width: @w + 4px; - // > .child {...} - // } - // - // And here's what the parse tree might look like: - // - // Ruleset (Selector '.class', [ - // Declaration ("color", Value ([Expression [Color #fff]])) - // Declaration ("border", Value ([Expression [Dimension 1px][Keyword "solid"][Color #000]])) - // Declaration ("width", Value ([Expression [Operation " + " [Variable "@w"][Dimension 4px]]])) - // Ruleset (Selector [Element '>', '.child'], [...]) - // ]) - // - // In general, most rules will try to parse a token with the `$re()` function, and if the return - // value is truly, will return a new node, of the relevant type. Sometimes, we need to check - // first, before parsing, that's when we use `peek()`. - // - parsers: parsers = { - // - // The `primary` rule is the *entry* and *exit* point of the parser. - // The rules here can appear at any level of the parse tree. - // - // The recursive nature of the grammar is an interplay between the `block` - // rule, which represents `{ ... }`, the `ruleset` rule, and this `primary` rule, - // as represented by this simplified grammar: - // - // primary → (ruleset | declaration)+ - // ruleset → selector+ block - // block → '{' primary '}' - // - // Only at one point is the primary rule not called from the - // block rule: at the root level. - // - primary: function () { - var mixin = this.mixin; - var root = []; - var node; - while (true) { - while (true) { - node = this.comment(); - if (!node) { - break; - } - root.push(node); - } - // always process comments before deciding if finished - if (parserInput.finished) { - break; - } - if (parserInput.peek('}')) { - break; - } - node = this.extendRule(); - if (node) { - root = root.concat(node); - continue; - } - node = mixin.definition() || this.declaration() || mixin.call(false, false) || - this.ruleset() || this.variableCall() || this.entities.call() || this.atrule(); - if (node) { - root.push(node); - } - else { - var foundSemiColon = false; - while (parserInput.$char(';')) { - foundSemiColon = true; - } - if (!foundSemiColon) { - break; - } - } - } - return root; - }, - // comments are collected by the main parsing mechanism and then assigned to nodes - // where the current structure allows it - comment: function () { - if (parserInput.commentStore.length) { - var comment = parserInput.commentStore.shift(); - return new (tree.Comment)(comment.text, comment.isLineComment, comment.index, fileInfo); - } - }, - // - // Entities are tokens which can be found inside an Expression - // - entities: { - mixinLookup: function () { - return parsers.mixin.call(true, true); - }, - // - // A string, which supports escaping " and ' - // - // "milky way" 'he\'s the one!' - // - quoted: function (forceEscaped) { - var str; - var index = parserInput.i; - var isEscaped = false; - parserInput.save(); - if (parserInput.$char('~')) { - isEscaped = true; - } - else if (forceEscaped) { - parserInput.restore(); - return; - } - str = parserInput.$quoted(); - if (!str) { - parserInput.restore(); - return; - } - parserInput.forget(); - return new (tree.Quoted)(str.charAt(0), str.substr(1, str.length - 2), isEscaped, index, fileInfo); - }, - // - // A catch-all word, such as: - // - // black border-collapse - // - keyword: function () { - var k = parserInput.$char('%') || parserInput.$re(/^\[?(?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+\]?/); - if (k) { - return tree.Color.fromKeyword(k) || new (tree.Keyword)(k); - } - }, - // - // A function call - // - // rgb(255, 0, 255) - // - // The arguments are parsed with the `entities.arguments` parser. - // - call: function () { - var name; - var args; - var func; - var index = parserInput.i; - // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18 - if (parserInput.peek(/^url\(/i)) { - return; - } - parserInput.save(); - name = parserInput.$re(/^([\w-]+|%|progid:[\w\.]+)\(/); - if (!name) { - parserInput.forget(); - return; - } - name = name[1]; - func = this.customFuncCall(name); - if (func) { - args = func.parse(); - if (args && func.stop) { - parserInput.forget(); - return args; - } - } - args = this.arguments(args); - if (!parserInput.$char(')')) { - parserInput.restore('Could not parse call arguments or missing \')\''); - return; - } - parserInput.forget(); - return new (tree.Call)(name, args, index, fileInfo); - }, - // - // Parsing rules for functions with non-standard args, e.g.: - // - // boolean(not(2 > 1)) - // - // This is a quick prototype, to be modified/improved when - // more custom-parsed funcs come (e.g. `selector(...)`) - // - customFuncCall: function (name) { - /* Ideally the table is to be moved out of here for faster perf., - but it's quite tricky since it relies on all these `parsers` - and `expect` available only here */ - return { - alpha: f(parsers.ieAlpha, true), - boolean: f(condition), - 'if': f(condition) - }[name.toLowerCase()]; - function f(parse, stop) { - return { - parse: parse, - stop: stop // when true - stop after parse() and return its result, - // otherwise continue for plain args - }; - } - function condition() { - return [expect(parsers.condition, 'expected condition')]; - } - }, - arguments: function (prevArgs) { - var argsComma = prevArgs || []; - var argsSemiColon = []; - var isSemiColonSeparated; - var value; - parserInput.save(); - while (true) { - if (prevArgs) { - prevArgs = false; - } - else { - value = parsers.detachedRuleset() || this.assignment() || parsers.expression(); - if (!value) { - break; - } - if (value.value && value.value.length == 1) { - value = value.value[0]; - } - argsComma.push(value); - } - if (parserInput.$char(',')) { - continue; - } - if (parserInput.$char(';') || isSemiColonSeparated) { - isSemiColonSeparated = true; - value = (argsComma.length < 1) ? argsComma[0] - : new tree.Value(argsComma); - argsSemiColon.push(value); - argsComma = []; - } - } - parserInput.forget(); - return isSemiColonSeparated ? argsSemiColon : argsComma; - }, - literal: function () { - return this.dimension() || - this.color() || - this.quoted() || - this.unicodeDescriptor(); - }, - // Assignments are argument entities for calls. - // They are present in ie filter properties as shown below. - // - // filter: progid:DXImageTransform.Microsoft.Alpha( *opacity=50* ) - // - assignment: function () { - var key; - var value; - parserInput.save(); - key = parserInput.$re(/^\w+(?=\s?=)/i); - if (!key) { - parserInput.restore(); - return; - } - if (!parserInput.$char('=')) { - parserInput.restore(); - return; - } - value = parsers.entity(); - if (value) { - parserInput.forget(); - return new (tree.Assignment)(key, value); - } - else { - parserInput.restore(); - } - }, - // - // Parse url() tokens - // - // We use a specific rule for urls, because they don't really behave like - // standard function calls. The difference is that the argument doesn't have - // to be enclosed within a string, so it can't be parsed as an Expression. - // - url: function () { - var value; - var index = parserInput.i; - parserInput.autoCommentAbsorb = false; - if (!parserInput.$str('url(')) { - parserInput.autoCommentAbsorb = true; - return; - } - value = this.quoted() || this.variable() || this.property() || - parserInput.$re(/^(?:(?:\\[\(\)'"])|[^\(\)'"])+/) || ''; - parserInput.autoCommentAbsorb = true; - expectChar(')'); - return new (tree.URL)((value.value != null || - value instanceof tree.Variable || - value instanceof tree.Property) ? - value : new (tree.Anonymous)(value, index), index, fileInfo); - }, - // - // A Variable entity, such as `@fink`, in - // - // width: @fink + 2px - // - // We use a different parser for variable definitions, - // see `parsers.variable`. - // - variable: function () { - var ch; - var name; - var index = parserInput.i; - parserInput.save(); - if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^@@?[\w-]+/))) { - ch = parserInput.currentChar(); - if (ch === '(' || ch === '[' && !parserInput.prevChar().match(/^\s/)) { - // this may be a VariableCall lookup - var result = parsers.variableCall(name); - if (result) { - parserInput.forget(); - return result; - } - } - parserInput.forget(); - return new (tree.Variable)(name, index, fileInfo); - } - parserInput.restore(); - }, - // A variable entity using the protective {} e.g. @{var} - variableCurly: function () { - var curly; - var index = parserInput.i; - if (parserInput.currentChar() === '@' && (curly = parserInput.$re(/^@\{([\w-]+)\}/))) { - return new (tree.Variable)("@" + curly[1], index, fileInfo); - } - }, - // - // A Property accessor, such as `$color`, in - // - // background-color: $color - // - property: function () { - var name; - var index = parserInput.i; - if (parserInput.currentChar() === '$' && (name = parserInput.$re(/^\$[\w-]+/))) { - return new (tree.Property)(name, index, fileInfo); - } - }, - // A property entity useing the protective {} e.g. ${prop} - propertyCurly: function () { - var curly; - var index = parserInput.i; - if (parserInput.currentChar() === '$' && (curly = parserInput.$re(/^\$\{([\w-]+)\}/))) { - return new (tree.Property)("$" + curly[1], index, fileInfo); - } - }, - // - // A Hexadecimal color - // - // #4F3C2F - // - // `rgb` and `hsl` colors are parsed through the `entities.call` parser. - // - color: function () { - var rgb; - parserInput.save(); - if (parserInput.currentChar() === '#' && (rgb = parserInput.$re(/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})([\w.#\[])?/))) { - if (!rgb[2]) { - parserInput.forget(); - return new (tree.Color)(rgb[1], undefined, rgb[0]); - } - } - parserInput.restore(); - }, - colorKeyword: function () { - parserInput.save(); - var autoCommentAbsorb = parserInput.autoCommentAbsorb; - parserInput.autoCommentAbsorb = false; - var k = parserInput.$re(/^[_A-Za-z-][_A-Za-z0-9-]+/); - parserInput.autoCommentAbsorb = autoCommentAbsorb; - if (!k) { - parserInput.forget(); - return; - } - parserInput.restore(); - var color = tree.Color.fromKeyword(k); - if (color) { - parserInput.$str(k); - return color; - } - }, - // - // A Dimension, that is, a number and a unit - // - // 0.5em 95% - // - dimension: function () { - if (parserInput.peekNotNumeric()) { - return; - } - var value = parserInput.$re(/^([+-]?\d*\.?\d+)(%|[a-z_]+)?/i); - if (value) { - return new (tree.Dimension)(value[1], value[2]); - } - }, - // - // A unicode descriptor, as is used in unicode-range - // - // U+0?? or U+00A1-00A9 - // - unicodeDescriptor: function () { - var ud; - ud = parserInput.$re(/^U\+[0-9a-fA-F?]+(\-[0-9a-fA-F?]+)?/); - if (ud) { - return new (tree.UnicodeDescriptor)(ud[0]); - } - }, - // - // JavaScript code to be evaluated - // - // `window.location.href` - // - javascript: function () { - var js; - var index = parserInput.i; - parserInput.save(); - var escape = parserInput.$char('~'); - var jsQuote = parserInput.$char('`'); - if (!jsQuote) { - parserInput.restore(); - return; - } - js = parserInput.$re(/^[^`]*`/); - if (js) { - parserInput.forget(); - return new (tree.JavaScript)(js.substr(0, js.length - 1), Boolean(escape), index, fileInfo); - } - parserInput.restore('invalid javascript definition'); - } - }, - // - // The variable part of a variable definition. Used in the `rule` parser - // - // @fink: - // - variable: function () { - var name; - if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^(@[\w-]+)\s*:/))) { - return name[1]; - } - }, - // - // Call a variable value to retrieve a detached ruleset - // or a value from a detached ruleset's rules. - // - // @fink(); - // @fink; - // color: @fink[@color]; - // - variableCall: function (parsedName) { - var lookups; - var i = parserInput.i; - var inValue = !!parsedName; - var name = parsedName; - parserInput.save(); - if (name || (parserInput.currentChar() === '@' - && (name = parserInput.$re(/^(@[\w-]+)(\(\s*\))?/)))) { - lookups = this.mixin.ruleLookups(); - if (!lookups && ((inValue && parserInput.$str('()') !== '()') || (name[2] !== '()'))) { - parserInput.restore('Missing \'[...]\' lookup in variable call'); - return; - } - if (!inValue) { - name = name[1]; - } - var call = new tree.VariableCall(name, i, fileInfo); - if (!inValue && parsers.end()) { - parserInput.forget(); - return call; - } - else { - parserInput.forget(); - return new tree.NamespaceValue(call, lookups, i, fileInfo); - } - } - parserInput.restore(); - }, - // - // extend syntax - used to extend selectors - // - extend: function (isRule) { - var elements; - var e; - var index = parserInput.i; - var option; - var extendList; - var extend; - if (!parserInput.$str(isRule ? '&:extend(' : ':extend(')) { - return; - } - do { - option = null; - elements = null; - while (!(option = parserInput.$re(/^(all)(?=\s*(\)|,))/))) { - e = this.element(); - if (!e) { - break; - } - if (elements) { - elements.push(e); - } - else { - elements = [e]; - } - } - option = option && option[1]; - if (!elements) { - error('Missing target selector for :extend().'); - } - extend = new (tree.Extend)(new (tree.Selector)(elements), option, index, fileInfo); - if (extendList) { - extendList.push(extend); - } - else { - extendList = [extend]; - } - } while (parserInput.$char(',')); - expect(/^\)/); - if (isRule) { - expect(/^;/); - } - return extendList; - }, - // - // extendRule - used in a rule to extend all the parent selectors - // - extendRule: function () { - return this.extend(true); - }, - // - // Mixins - // - mixin: { - // - // A Mixin call, with an optional argument list - // - // #mixins > .square(#fff); - // #mixins.square(#fff); - // .rounded(4px, black); - // .button; - // - // We can lookup / return a value using the lookup syntax: - // - // color: #mixin.square(#fff)[@color]; - // - // The `while` loop is there because mixins can be - // namespaced, but we only support the child and descendant - // selector for now. - // - call: function (inValue, getLookup) { - var s = parserInput.currentChar(); - var important = false; - var lookups; - var index = parserInput.i; - var elements; - var args; - var hasParens; - if (s !== '.' && s !== '#') { - return; - } - parserInput.save(); // stop us absorbing part of an invalid selector - elements = this.elements(); - if (elements) { - if (parserInput.$char('(')) { - args = this.args(true).args; - expectChar(')'); - hasParens = true; - } - if (getLookup !== false) { - lookups = this.ruleLookups(); - } - if (getLookup === true && !lookups) { - parserInput.restore(); - return; - } - if (inValue && !lookups && !hasParens) { - // This isn't a valid in-value mixin call - parserInput.restore(); - return; - } - if (!inValue && parsers.important()) { - important = true; - } - if (inValue || parsers.end()) { - parserInput.forget(); - var mixin = new (tree.mixin.Call)(elements, args, index, fileInfo, !lookups && important); - if (lookups) { - return new tree.NamespaceValue(mixin, lookups); - } - else { - return mixin; - } - } - } - parserInput.restore(); - }, - /** - * Matching elements for mixins - * (Start with . or # and can have > ) - */ - elements: function () { - var elements; - var e; - var c; - var elem; - var elemIndex; - var re = /^[#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/; - while (true) { - elemIndex = parserInput.i; - e = parserInput.$re(re); - if (!e) { - break; - } - elem = new (tree.Element)(c, e, false, elemIndex, fileInfo); - if (elements) { - elements.push(elem); - } - else { - elements = [elem]; - } - c = parserInput.$char('>'); - } - return elements; - }, - args: function (isCall) { - var entities = parsers.entities; - var returner = { args: null, variadic: false }; - var expressions = []; - var argsSemiColon = []; - var argsComma = []; - var isSemiColonSeparated; - var expressionContainsNamed; - var name; - var nameLoop; - var value; - var arg; - var expand; - var hasSep = true; - parserInput.save(); - while (true) { - if (isCall) { - arg = parsers.detachedRuleset() || parsers.expression(); - } - else { - parserInput.commentStore.length = 0; - if (parserInput.$str('...')) { - returner.variadic = true; - if (parserInput.$char(';') && !isSemiColonSeparated) { - isSemiColonSeparated = true; - } - (isSemiColonSeparated ? argsSemiColon : argsComma) - .push({ variadic: true }); - break; - } - arg = entities.variable() || entities.property() || entities.literal() || entities.keyword() || this.call(true); - } - if (!arg || !hasSep) { - break; - } - nameLoop = null; - if (arg.throwAwayComments) { - arg.throwAwayComments(); - } - value = arg; - var val = null; - if (isCall) { - // Variable - if (arg.value && arg.value.length == 1) { - val = arg.value[0]; - } - } - else { - val = arg; - } - if (val && (val instanceof tree.Variable || val instanceof tree.Property)) { - if (parserInput.$char(':')) { - if (expressions.length > 0) { - if (isSemiColonSeparated) { - error('Cannot mix ; and , as delimiter types'); - } - expressionContainsNamed = true; - } - value = parsers.detachedRuleset() || parsers.expression(); - if (!value) { - if (isCall) { - error('could not understand value for named argument'); - } - else { - parserInput.restore(); - returner.args = []; - return returner; - } - } - nameLoop = (name = val.name); - } - else if (parserInput.$str('...')) { - if (!isCall) { - returner.variadic = true; - if (parserInput.$char(';') && !isSemiColonSeparated) { - isSemiColonSeparated = true; - } - (isSemiColonSeparated ? argsSemiColon : argsComma) - .push({ name: arg.name, variadic: true }); - break; - } - else { - expand = true; - } - } - else if (!isCall) { - name = nameLoop = val.name; - value = null; - } - } - if (value) { - expressions.push(value); - } - argsComma.push({ name: nameLoop, value: value, expand: expand }); - if (parserInput.$char(',')) { - hasSep = true; - continue; - } - hasSep = parserInput.$char(';') === ';'; - if (hasSep || isSemiColonSeparated) { - if (expressionContainsNamed) { - error('Cannot mix ; and , as delimiter types'); - } - isSemiColonSeparated = true; - if (expressions.length > 1) { - value = new (tree.Value)(expressions); - } - argsSemiColon.push({ name: name, value: value, expand: expand }); - name = null; - expressions = []; - expressionContainsNamed = false; - } - } - parserInput.forget(); - returner.args = isSemiColonSeparated ? argsSemiColon : argsComma; - return returner; - }, - // - // A Mixin definition, with a list of parameters - // - // .rounded (@radius: 2px, @color) { - // ... - // } - // - // Until we have a finer grained state-machine, we have to - // do a look-ahead, to make sure we don't have a mixin call. - // See the `rule` function for more information. - // - // We start by matching `.rounded (`, and then proceed on to - // the argument list, which has optional default values. - // We store the parameters in `params`, with a `value` key, - // if there is a value, such as in the case of `@radius`. - // - // Once we've got our params list, and a closing `)`, we parse - // the `{...}` block. - // - definition: function () { - var name; - var params = []; - var match; - var ruleset; - var cond; - var variadic = false; - if ((parserInput.currentChar() !== '.' && parserInput.currentChar() !== '#') || - parserInput.peek(/^[^{]*\}/)) { - return; - } - parserInput.save(); - match = parserInput.$re(/^([#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\s*\(/); - if (match) { - name = match[1]; - var argInfo = this.args(false); - params = argInfo.args; - variadic = argInfo.variadic; - // .mixincall("@{a}"); - // looks a bit like a mixin definition.. - // also - // .mixincall(@a: {rule: set;}); - // so we have to be nice and restore - if (!parserInput.$char(')')) { - parserInput.restore('Missing closing \')\''); - return; - } - parserInput.commentStore.length = 0; - if (parserInput.$str('when')) { // Guard - cond = expect(parsers.conditions, 'expected condition'); - } - ruleset = parsers.block(); - if (ruleset) { - parserInput.forget(); - return new (tree.mixin.Definition)(name, params, ruleset, cond, variadic); - } - else { - parserInput.restore(); - } - } - else { - parserInput.restore(); - } - }, - ruleLookups: function () { - var rule; - var lookups = []; - if (parserInput.currentChar() !== '[') { - return; - } - while (true) { - parserInput.save(); - rule = this.lookupValue(); - if (!rule && rule !== '') { - parserInput.restore(); - break; - } - lookups.push(rule); - parserInput.forget(); - } - if (lookups.length > 0) { - return lookups; - } - }, - lookupValue: function () { - parserInput.save(); - if (!parserInput.$char('[')) { - parserInput.restore(); - return; - } - var name = parserInput.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/); - if (!parserInput.$char(']')) { - parserInput.restore(); - return; - } - if (name || name === '') { - parserInput.forget(); - return name; - } - parserInput.restore(); - } - }, - // - // Entities are the smallest recognized token, - // and can be found inside a rule's value. - // - entity: function () { - var entities = this.entities; - return this.comment() || entities.literal() || entities.variable() || entities.url() || - entities.property() || entities.call() || entities.keyword() || this.mixin.call(true) || - entities.javascript(); - }, - // - // A Declaration terminator. Note that we use `peek()` to check for '}', - // because the `block` rule will be expecting it, but we still need to make sure - // it's there, if ';' was omitted. - // - end: function () { - return parserInput.$char(';') || parserInput.peek('}'); - }, - // - // IE's alpha function - // - // alpha(opacity=88) - // - ieAlpha: function () { - var value; - // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18 - if (!parserInput.$re(/^opacity=/i)) { - return; - } - value = parserInput.$re(/^\d+/); - if (!value) { - value = expect(parsers.entities.variable, 'Could not parse alpha'); - value = "@{" + value.name.slice(1) + "}"; - } - expectChar(')'); - return new tree.Quoted('', "alpha(opacity=" + value + ")"); - }, - // - // A Selector Element - // - // div - // + h1 - // #socks - // input[type="text"] - // - // Elements are the building blocks for Selectors, - // they are made out of a `Combinator` (see combinator rule), - // and an element name, such as a tag a class, or `*`. - // - element: function () { - var e; - var c; - var v; - var index = parserInput.i; - c = this.combinator(); - e = parserInput.$re(/^(?:\d+\.\d+|\d+)%/) || - parserInput.$re(/^(?:[.#]?|:*)(?:[\w-]|[^\x00-\x9f]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/) || - parserInput.$char('*') || parserInput.$char('&') || this.attribute() || - parserInput.$re(/^\([^&()@]+\)/) || parserInput.$re(/^[\.#:](?=@)/) || - this.entities.variableCurly(); - if (!e) { - parserInput.save(); - if (parserInput.$char('(')) { - if ((v = this.selector(false)) && parserInput.$char(')')) { - e = new (tree.Paren)(v); - parserInput.forget(); - } - else { - parserInput.restore('Missing closing \')\''); - } - } - else { - parserInput.forget(); - } - } - if (e) { - return new (tree.Element)(c, e, e instanceof tree.Variable, index, fileInfo); - } - }, - // - // Combinators combine elements together, in a Selector. - // - // Because our parser isn't white-space sensitive, special care - // has to be taken, when parsing the descendant combinator, ` `, - // as it's an empty space. We have to check the previous character - // in the input, to see if it's a ` ` character. More info on how - // we deal with this in *combinator.js*. - // - combinator: function () { - var c = parserInput.currentChar(); - if (c === '/') { - parserInput.save(); - var slashedCombinator = parserInput.$re(/^\/[a-z]+\//i); - if (slashedCombinator) { - parserInput.forget(); - return new (tree.Combinator)(slashedCombinator); - } - parserInput.restore(); - } - if (c === '>' || c === '+' || c === '~' || c === '|' || c === '^') { - parserInput.i++; - if (c === '^' && parserInput.currentChar() === '^') { - c = '^^'; - parserInput.i++; - } - while (parserInput.isWhitespace()) { - parserInput.i++; - } - return new (tree.Combinator)(c); - } - else if (parserInput.isWhitespace(-1)) { - return new (tree.Combinator)(' '); - } - else { - return new (tree.Combinator)(null); - } - }, - // - // A CSS Selector - // with less extensions e.g. the ability to extend and guard - // - // .class > div + h1 - // li a:hover - // - // Selectors are made out of one or more Elements, see above. - // - selector: function (isLess) { - var index = parserInput.i; - var elements; - var extendList; - var c; - var e; - var allExtends; - var when; - var condition; - isLess = isLess !== false; - while ((isLess && (extendList = this.extend())) || (isLess && (when = parserInput.$str('when'))) || (e = this.element())) { - if (when) { - condition = expect(this.conditions, 'expected condition'); - } - else if (condition) { - error('CSS guard can only be used at the end of selector'); - } - else if (extendList) { - if (allExtends) { - allExtends = allExtends.concat(extendList); - } - else { - allExtends = extendList; - } - } - else { - if (allExtends) { - error('Extend can only be used at the end of selector'); - } - c = parserInput.currentChar(); - if (elements) { - elements.push(e); - } - else { - elements = [e]; - } - e = null; - } - if (c === '{' || c === '}' || c === ';' || c === ',' || c === ')') { - break; - } - } - if (elements) { - return new (tree.Selector)(elements, allExtends, condition, index, fileInfo); - } - if (allExtends) { - error('Extend must be used to extend a selector, it cannot be used on its own'); - } - }, - selectors: function () { - var s; - var selectors; - while (true) { - s = this.selector(); - if (!s) { - break; - } - if (selectors) { - selectors.push(s); - } - else { - selectors = [s]; - } - parserInput.commentStore.length = 0; - if (s.condition && selectors.length > 1) { - error("Guards are only currently allowed on a single selector."); - } - if (!parserInput.$char(',')) { - break; - } - if (s.condition) { - error("Guards are only currently allowed on a single selector."); - } - parserInput.commentStore.length = 0; - } - return selectors; - }, - attribute: function () { - if (!parserInput.$char('[')) { - return; - } - var entities = this.entities; - var key; - var val; - var op; - if (!(key = entities.variableCurly())) { - key = expect(/^(?:[_A-Za-z0-9-\*]*\|)?(?:[_A-Za-z0-9-]|\\.)+/); - } - op = parserInput.$re(/^[|~*$^]?=/); - if (op) { - val = entities.quoted() || parserInput.$re(/^[0-9]+%/) || parserInput.$re(/^[\w-]+/) || entities.variableCurly(); - } - expectChar(']'); - return new (tree.Attribute)(key, op, val); - }, - // - // The `block` rule is used by `ruleset` and `mixin.definition`. - // It's a wrapper around the `primary` rule, with added `{}`. - // - block: function () { - var content; - if (parserInput.$char('{') && (content = this.primary()) && parserInput.$char('}')) { - return content; - } - }, - blockRuleset: function () { - var block = this.block(); - if (block) { - block = new tree.Ruleset(null, block); - } - return block; - }, - detachedRuleset: function () { - var argInfo; - var params; - var variadic; - parserInput.save(); - if (parserInput.$re(/^[.#]\(/)) { - /** - * DR args currently only implemented for each() function, and not - * yet settable as `@dr: #(@arg) {}` - * This should be done when DRs are merged with mixins. - * See: https://github.com/less/less-meta/issues/16 - */ - argInfo = this.mixin.args(false); - params = argInfo.args; - variadic = argInfo.variadic; - if (!parserInput.$char(')')) { - parserInput.restore(); - return; - } - } - var blockRuleset = this.blockRuleset(); - if (blockRuleset) { - parserInput.forget(); - if (params) { - return new tree.mixin.Definition(null, params, blockRuleset, null, variadic); - } - return new tree.DetachedRuleset(blockRuleset); - } - parserInput.restore(); - }, - // - // div, .class, body > p {...} - // - ruleset: function () { - var selectors; - var rules; - var debugInfo; - parserInput.save(); - if (context.dumpLineNumbers) { - debugInfo = getDebugInfo(parserInput.i); - } - selectors = this.selectors(); - if (selectors && (rules = this.block())) { - parserInput.forget(); - var ruleset = new (tree.Ruleset)(selectors, rules, context.strictImports); - if (context.dumpLineNumbers) { - ruleset.debugInfo = debugInfo; - } - return ruleset; - } - else { - parserInput.restore(); - } - }, - declaration: function () { - var name; - var value; - var index = parserInput.i; - var hasDR; - var c = parserInput.currentChar(); - var important; - var merge; - var isVariable; - if (c === '.' || c === '#' || c === '&' || c === ':') { - return; - } - parserInput.save(); - name = this.variable() || this.ruleProperty(); - if (name) { - isVariable = typeof name === 'string'; - if (isVariable) { - value = this.detachedRuleset(); - if (value) { - hasDR = true; - } - } - parserInput.commentStore.length = 0; - if (!value) { - // a name returned by this.ruleProperty() is always an array of the form: - // [string-1, ..., string-n, ""] or [string-1, ..., string-n, "+"] - // where each item is a tree.Keyword or tree.Variable - merge = !isVariable && name.length > 1 && name.pop().value; - // Custom property values get permissive parsing - if (name[0].value && name[0].value.slice(0, 2) === '--') { - value = this.permissiveValue(); - } - // Try to store values as anonymous - // If we need the value later we'll re-parse it in ruleset.parseValue - else { - value = this.anonymousValue(); - } - if (value) { - parserInput.forget(); - // anonymous values absorb the end ';' which is required for them to work - return new (tree.Declaration)(name, value, false, merge, index, fileInfo); - } - if (!value) { - value = this.value(); - } - if (value) { - important = this.important(); - } - else if (isVariable) { - // As a last resort, try permissiveValue - value = this.permissiveValue(); - } - } - if (value && (this.end() || hasDR)) { - parserInput.forget(); - return new (tree.Declaration)(name, value, important, merge, index, fileInfo); - } - else { - parserInput.restore(); - } - } - else { - parserInput.restore(); - } - }, - anonymousValue: function () { - var index = parserInput.i; - var match = parserInput.$re(/^([^.#@\$+\/'"*`(;{}-]*);/); - if (match) { - return new (tree.Anonymous)(match[1], index); - } - }, - /** - * Used for custom properties, at-rules, and variables (as fallback) - * Parses almost anything inside of {} [] () "" blocks - * until it reaches outer-most tokens. - * - * First, it will try to parse comments and entities to reach - * the end. This is mostly like the Expression parser except no - * math is allowed. - */ - permissiveValue: function (untilTokens) { - var i; - var e; - var done; - var value; - var tok = untilTokens || ';'; - var index = parserInput.i; - var result = []; - function testCurrentChar() { - var char = parserInput.currentChar(); - if (typeof tok === 'string') { - return char === tok; - } - else { - return tok.test(char); - } - } - if (testCurrentChar()) { - return; - } - value = []; - do { - e = this.comment(); - if (e) { - value.push(e); - continue; - } - e = this.entity(); - if (e) { - value.push(e); - } - } while (e); - done = testCurrentChar(); - if (value.length > 0) { - value = new (tree.Expression)(value); - if (done) { - return value; - } - else { - result.push(value); - } - // Preserve space before $parseUntil as it will not - if (parserInput.prevChar() === ' ') { - result.push(new tree.Anonymous(' ', index)); - } - } - parserInput.save(); - value = parserInput.$parseUntil(tok); - if (value) { - if (typeof value === 'string') { - error("Expected '" + value + "'", 'Parse'); - } - if (value.length === 1 && value[0] === ' ') { - parserInput.forget(); - return new tree.Anonymous('', index); - } - var item = void 0; - for (i = 0; i < value.length; i++) { - item = value[i]; - if (Array.isArray(item)) { - // Treat actual quotes as normal quoted values - result.push(new tree.Quoted(item[0], item[1], true, index, fileInfo)); - } - else { - if (i === value.length - 1) { - item = item.trim(); - } - // Treat like quoted values, but replace vars like unquoted expressions - var quote = new tree.Quoted('\'', item, true, index, fileInfo); - quote.variableRegex = /@([\w-]+)/g; - quote.propRegex = /\$([\w-]+)/g; - result.push(quote); - } - } - parserInput.forget(); - return new tree.Expression(result, true); - } - parserInput.restore(); - }, - // - // An @import atrule - // - // @import "lib"; - // - // Depending on our environment, importing is done differently: - // In the browser, it's an XHR request, in Node, it would be a - // file-system operation. The function used for importing is - // stored in `import`, which we pass to the Import constructor. - // - 'import': function () { - var path; - var features; - var index = parserInput.i; - var dir = parserInput.$re(/^@import?\s+/); - if (dir) { - var options = (dir ? this.importOptions() : null) || {}; - if ((path = this.entities.quoted() || this.entities.url())) { - features = this.mediaFeatures(); - if (!parserInput.$char(';')) { - parserInput.i = index; - error('missing semi-colon or unrecognised media features on import'); - } - features = features && new (tree.Value)(features); - return new (tree.Import)(path, features, options, index, fileInfo); - } - else { - parserInput.i = index; - error('malformed import statement'); - } - } - }, - importOptions: function () { - var o; - var options = {}; - var optionName; - var value; - // list of options, surrounded by parens - if (!parserInput.$char('(')) { - return null; - } - do { - o = this.importOption(); - if (o) { - optionName = o; - value = true; - switch (optionName) { - case 'css': - optionName = 'less'; - value = false; - break; - case 'once': - optionName = 'multiple'; - value = false; - break; - } - options[optionName] = value; - if (!parserInput.$char(',')) { - break; - } - } - } while (o); - expectChar(')'); - return options; - }, - importOption: function () { - var opt = parserInput.$re(/^(less|css|multiple|once|inline|reference|optional)/); - if (opt) { - return opt[1]; - } - }, - mediaFeature: function () { - var entities = this.entities; - var nodes = []; - var e; - var p; - parserInput.save(); - do { - e = entities.keyword() || entities.variable() || entities.mixinLookup(); - if (e) { - nodes.push(e); - } - else if (parserInput.$char('(')) { - p = this.property(); - e = this.value(); - if (parserInput.$char(')')) { - if (p && e) { - nodes.push(new (tree.Paren)(new (tree.Declaration)(p, e, null, null, parserInput.i, fileInfo, true))); - } - else if (e) { - nodes.push(new (tree.Paren)(e)); - } - else { - error('badly formed media feature definition'); - } - } - else { - error('Missing closing \')\'', 'Parse'); - } - } - } while (e); - parserInput.forget(); - if (nodes.length > 0) { - return new (tree.Expression)(nodes); - } - }, - mediaFeatures: function () { - var entities = this.entities; - var features = []; - var e; - do { - e = this.mediaFeature(); - if (e) { - features.push(e); - if (!parserInput.$char(',')) { - break; - } - } - else { - e = entities.variable() || entities.mixinLookup(); - if (e) { - features.push(e); - if (!parserInput.$char(',')) { - break; - } - } - } - } while (e); - return features.length > 0 ? features : null; - }, - media: function () { - var features; - var rules; - var media; - var debugInfo; - var index = parserInput.i; - if (context.dumpLineNumbers) { - debugInfo = getDebugInfo(index); - } - parserInput.save(); - if (parserInput.$str('@media')) { - features = this.mediaFeatures(); - rules = this.block(); - if (!rules) { - error('media definitions require block statements after any features'); - } - parserInput.forget(); - media = new (tree.Media)(rules, features, index, fileInfo); - if (context.dumpLineNumbers) { - media.debugInfo = debugInfo; - } - return media; - } - parserInput.restore(); - }, - // - // A @plugin directive, used to import plugins dynamically. - // - // @plugin (args) "lib"; - // - plugin: function () { - var path; - var args; - var options; - var index = parserInput.i; - var dir = parserInput.$re(/^@plugin?\s+/); - if (dir) { - args = this.pluginArgs(); - if (args) { - options = { - pluginArgs: args, - isPlugin: true - }; - } - else { - options = { isPlugin: true }; - } - if ((path = this.entities.quoted() || this.entities.url())) { - if (!parserInput.$char(';')) { - parserInput.i = index; - error('missing semi-colon on @plugin'); - } - return new (tree.Import)(path, null, options, index, fileInfo); - } - else { - parserInput.i = index; - error('malformed @plugin statement'); - } - } - }, - pluginArgs: function () { - // list of options, surrounded by parens - parserInput.save(); - if (!parserInput.$char('(')) { - parserInput.restore(); - return null; - } - var args = parserInput.$re(/^\s*([^\);]+)\)\s*/); - if (args[1]) { - parserInput.forget(); - return args[1].trim(); - } - else { - parserInput.restore(); - return null; - } - }, - // - // A CSS AtRule - // - // @charset "utf-8"; - // - atrule: function () { - var index = parserInput.i; - var name; - var value; - var rules; - var nonVendorSpecificName; - var hasIdentifier; - var hasExpression; - var hasUnknown; - var hasBlock = true; - var isRooted = true; - if (parserInput.currentChar() !== '@') { - return; - } - value = this['import']() || this.plugin() || this.media(); - if (value) { - return value; - } - parserInput.save(); - name = parserInput.$re(/^@[a-z-]+/); - if (!name) { - return; - } - nonVendorSpecificName = name; - if (name.charAt(1) == '-' && name.indexOf('-', 2) > 0) { - nonVendorSpecificName = "@" + name.slice(name.indexOf('-', 2) + 1); - } - switch (nonVendorSpecificName) { - case '@charset': - hasIdentifier = true; - hasBlock = false; - break; - case '@namespace': - hasExpression = true; - hasBlock = false; - break; - case '@keyframes': - case '@counter-style': - hasIdentifier = true; - break; - case '@document': - case '@supports': - hasUnknown = true; - isRooted = false; - break; - default: - hasUnknown = true; - break; - } - parserInput.commentStore.length = 0; - if (hasIdentifier) { - value = this.entity(); - if (!value) { - error("expected " + name + " identifier"); - } - } - else if (hasExpression) { - value = this.expression(); - if (!value) { - error("expected " + name + " expression"); - } - } - else if (hasUnknown) { - value = this.permissiveValue(/^[{;]/); - hasBlock = (parserInput.currentChar() === '{'); - if (!value) { - if (!hasBlock && parserInput.currentChar() !== ';') { - error(name + " rule is missing block or ending semi-colon"); - } - } - else if (!value.value) { - value = null; - } - } - if (hasBlock) { - rules = this.blockRuleset(); - } - if (rules || (!hasBlock && value && parserInput.$char(';'))) { - parserInput.forget(); - return new (tree.AtRule)(name, value, rules, index, fileInfo, context.dumpLineNumbers ? getDebugInfo(index) : null, isRooted); - } - parserInput.restore('at-rule options not recognised'); - }, - // - // A Value is a comma-delimited list of Expressions - // - // font-family: Baskerville, Georgia, serif; - // - // In a Rule, a Value represents everything after the `:`, - // and before the `;`. - // - value: function () { - var e; - var expressions = []; - var index = parserInput.i; - do { - e = this.expression(); - if (e) { - expressions.push(e); - if (!parserInput.$char(',')) { - break; - } - } - } while (e); - if (expressions.length > 0) { - return new (tree.Value)(expressions, index); - } - }, - important: function () { - if (parserInput.currentChar() === '!') { - return parserInput.$re(/^! *important/); - } - }, - sub: function () { - var a; - var e; - parserInput.save(); - if (parserInput.$char('(')) { - a = this.addition(); - if (a && parserInput.$char(')')) { - parserInput.forget(); - e = new (tree.Expression)([a]); - e.parens = true; - return e; - } - parserInput.restore('Expected \')\''); - return; - } - parserInput.restore(); - }, - multiplication: function () { - var m; - var a; - var op; - var operation; - var isSpaced; - m = this.operand(); - if (m) { - isSpaced = parserInput.isWhitespace(-1); - while (true) { - if (parserInput.peek(/^\/[*\/]/)) { - break; - } - parserInput.save(); - op = parserInput.$char('/') || parserInput.$char('*') || parserInput.$str('./'); - if (!op) { - parserInput.forget(); - break; - } - a = this.operand(); - if (!a) { - parserInput.restore(); - break; - } - parserInput.forget(); - m.parensInOp = true; - a.parensInOp = true; - operation = new (tree.Operation)(op, [operation || m, a], isSpaced); - isSpaced = parserInput.isWhitespace(-1); - } - return operation || m; - } - }, - addition: function () { - var m; - var a; - var op; - var operation; - var isSpaced; - m = this.multiplication(); - if (m) { - isSpaced = parserInput.isWhitespace(-1); - while (true) { - op = parserInput.$re(/^[-+]\s+/) || (!isSpaced && (parserInput.$char('+') || parserInput.$char('-'))); - if (!op) { - break; - } - a = this.multiplication(); - if (!a) { - break; - } - m.parensInOp = true; - a.parensInOp = true; - operation = new (tree.Operation)(op, [operation || m, a], isSpaced); - isSpaced = parserInput.isWhitespace(-1); - } - return operation || m; - } - }, - conditions: function () { - var a; - var b; - var index = parserInput.i; - var condition; - a = this.condition(true); - if (a) { - while (true) { - if (!parserInput.peek(/^,\s*(not\s*)?\(/) || !parserInput.$char(',')) { - break; - } - b = this.condition(true); - if (!b) { - break; - } - condition = new (tree.Condition)('or', condition || a, b, index); - } - return condition || a; - } - }, - condition: function (needsParens) { - var result; - var logical; - var next; - function or() { - return parserInput.$str('or'); - } - result = this.conditionAnd(needsParens); - if (!result) { - return; - } - logical = or(); - if (logical) { - next = this.condition(needsParens); - if (next) { - result = new (tree.Condition)(logical, result, next); - } - else { - return; - } - } - return result; - }, - conditionAnd: function (needsParens) { - var result; - var logical; - var next; - var self = this; - function insideCondition() { - var cond = self.negatedCondition(needsParens) || self.parenthesisCondition(needsParens); - if (!cond && !needsParens) { - return self.atomicCondition(needsParens); - } - return cond; - } - function and() { - return parserInput.$str('and'); - } - result = insideCondition(); - if (!result) { - return; - } - logical = and(); - if (logical) { - next = this.conditionAnd(needsParens); - if (next) { - result = new (tree.Condition)(logical, result, next); - } - else { - return; - } - } - return result; - }, - negatedCondition: function (needsParens) { - if (parserInput.$str('not')) { - var result = this.parenthesisCondition(needsParens); - if (result) { - result.negate = !result.negate; - } - return result; - } - }, - parenthesisCondition: function (needsParens) { - function tryConditionFollowedByParenthesis(me) { - var body; - parserInput.save(); - body = me.condition(needsParens); - if (!body) { - parserInput.restore(); - return; - } - if (!parserInput.$char(')')) { - parserInput.restore(); - return; - } - parserInput.forget(); - return body; - } - var body; - parserInput.save(); - if (!parserInput.$str('(')) { - parserInput.restore(); - return; - } - body = tryConditionFollowedByParenthesis(this); - if (body) { - parserInput.forget(); - return body; - } - body = this.atomicCondition(needsParens); - if (!body) { - parserInput.restore(); - return; - } - if (!parserInput.$char(')')) { - parserInput.restore("expected ')' got '" + parserInput.currentChar() + "'"); - return; - } - parserInput.forget(); - return body; - }, - atomicCondition: function (needsParens) { - var entities = this.entities; - var index = parserInput.i; - var a; - var b; - var c; - var op; - function cond() { - return this.addition() || entities.keyword() || entities.quoted() || entities.mixinLookup(); - } - cond = cond.bind(this); - a = cond(); - if (a) { - if (parserInput.$char('>')) { - if (parserInput.$char('=')) { - op = '>='; - } - else { - op = '>'; - } - } - else if (parserInput.$char('<')) { - if (parserInput.$char('=')) { - op = '<='; - } - else { - op = '<'; - } - } - else if (parserInput.$char('=')) { - if (parserInput.$char('>')) { - op = '=>'; - } - else if (parserInput.$char('<')) { - op = '=<'; - } - else { - op = '='; - } - } - if (op) { - b = cond(); - if (b) { - c = new (tree.Condition)(op, a, b, index, false); - } - else { - error('expected expression'); - } - } - else { - c = new (tree.Condition)('=', a, new (tree.Keyword)('true'), index, false); - } - return c; - } - }, - // - // An operand is anything that can be part of an operation, - // such as a Color, or a Variable - // - operand: function () { - var entities = this.entities; - var negate; - if (parserInput.peek(/^-[@\$\(]/)) { - negate = parserInput.$char('-'); - } - var o = this.sub() || entities.dimension() || - entities.color() || entities.variable() || - entities.property() || entities.call() || - entities.quoted(true) || entities.colorKeyword() || - entities.mixinLookup(); - if (negate) { - o.parensInOp = true; - o = new (tree.Negative)(o); - } - return o; - }, - // - // Expressions either represent mathematical operations, - // or white-space delimited Entities. - // - // 1px solid black - // @var * 2 - // - expression: function () { - var entities = []; - var e; - var delim; - var index = parserInput.i; - do { - e = this.comment(); - if (e) { - entities.push(e); - continue; - } - e = this.addition() || this.entity(); - if (e instanceof tree.Comment) { - e = null; - } - if (e) { - entities.push(e); - // operations do not allow keyword "/" dimension (e.g. small/20px) so we support that here - if (!parserInput.peek(/^\/[\/*]/)) { - delim = parserInput.$char('/'); - if (delim) { - entities.push(new (tree.Anonymous)(delim, index)); - } - } - } - } while (e); - if (entities.length > 0) { - return new (tree.Expression)(entities); - } - }, - property: function () { - var name = parserInput.$re(/^(\*?-?[_a-zA-Z0-9-]+)\s*:/); - if (name) { - return name[1]; - } - }, - ruleProperty: function () { - var name = []; - var index = []; - var s; - var k; - parserInput.save(); - var simpleProperty = parserInput.$re(/^([_a-zA-Z0-9-]+)\s*:/); - if (simpleProperty) { - name = [new (tree.Keyword)(simpleProperty[1])]; - parserInput.forget(); - return name; - } - function match(re) { - var i = parserInput.i; - var chunk = parserInput.$re(re); - if (chunk) { - index.push(i); - return name.push(chunk[1]); - } - } - match(/^(\*?)/); - while (true) { - if (!match(/^((?:[\w-]+)|(?:[@\$]\{[\w-]+\}))/)) { - break; - } - } - if ((name.length > 1) && match(/^((?:\+_|\+)?)\s*:/)) { - parserInput.forget(); - // at last, we have the complete match now. move forward, - // convert name particles to tree objects and return: - if (name[0] === '') { - name.shift(); - index.shift(); - } - for (k = 0; k < name.length; k++) { - s = name[k]; - name[k] = (s.charAt(0) !== '@' && s.charAt(0) !== '$') ? - new (tree.Keyword)(s) : - (s.charAt(0) === '@' ? - new (tree.Variable)("@" + s.slice(2, -1), index[k], fileInfo) : - new (tree.Property)("$" + s.slice(2, -1), index[k], fileInfo)); - } - return name; - } - parserInput.restore(); - } - } - }; - }; - Parser.serializeVars = function (vars) { - var s = ''; - for (var name_1 in vars) { - if (Object.hasOwnProperty.call(vars, name_1)) { - var value = vars[name_1]; - s += ((name_1[0] === '@') ? '' : '@') + name_1 + ": " + value + ((String(value).slice(-1) === ';') ? '' : ';'); - } - } - return s; - }; + // + // less.js - parser + // + // A relatively straight-forward predictive parser. + // There is no tokenization/lexing stage, the input is parsed + // in one sweep. + // + // To make the parser fast enough to run in the browser, several + // optimization had to be made: + // + // - Matching and slicing on a huge input is often cause of slowdowns. + // The solution is to chunkify the input into smaller strings. + // The chunks are stored in the `chunks` var, + // `j` holds the current chunk index, and `currentPos` holds + // the index of the current chunk in relation to `input`. + // This gives us an almost 4x speed-up. + // + // - In many cases, we don't need to match individual tokens; + // for example, if a value doesn't hold any variables, operations + // or dynamic references, the parser can effectively 'skip' it, + // treating it as a literal. + // An example would be '1px solid #000' - which evaluates to itself, + // we don't need to know what the individual components are. + // The drawback, of course is that you don't get the benefits of + // syntax-checking on the CSS. This gives us a 50% speed-up in the parser, + // and a smaller speed-up in the code-gen. + // + // + // Token matching is done with the `$` function, which either takes + // a terminal string or regexp, or a non-terminal function to call. + // It also takes care of moving all the indices forwards. + // + var Parser = function Parser(context, imports, fileInfo) { + var parsers; + var parserInput = getParserInput(); + function error(msg, type) { + throw new LessError({ + index: parserInput.i, + filename: fileInfo.filename, + type: type || 'Syntax', + message: msg + }, imports); + } + function expect(arg, msg) { + // some older browsers return typeof 'function' for RegExp + var result = (arg instanceof Function) ? arg.call(parsers) : parserInput.$re(arg); + if (result) { + return result; + } + error(msg || (typeof arg === 'string' + ? "expected '" + arg + "' got '" + parserInput.currentChar() + "'" + : 'unexpected token')); + } + // Specialization of expect() + function expectChar(arg, msg) { + if (parserInput.$char(arg)) { + return arg; + } + error(msg || "expected '" + arg + "' got '" + parserInput.currentChar() + "'"); + } + function getDebugInfo(index) { + var filename = fileInfo.filename; + return { + lineNumber: getLocation(index, parserInput.getInput()).line + 1, + fileName: filename + }; + } + /** + * Used after initial parsing to create nodes on the fly + * + * @param {String} str - string to parse + * @param {Array} parseList - array of parsers to run input through e.g. ["value", "important"] + * @param {Number} currentIndex - start number to begin indexing + * @param {Object} fileInfo - fileInfo to attach to created nodes + */ + function parseNode(str, parseList, currentIndex, fileInfo, callback) { + var result; + var returnNodes = []; + var parser = parserInput; + try { + parser.start(str, false, function fail(msg, index) { + callback({ + message: msg, + index: index + currentIndex + }); + }); + for (var x = 0, p = void 0, i = void 0; (p = parseList[x]); x++) { + i = parser.i; + result = parsers[p](); + if (result) { + try { + result._index = i + currentIndex; + result._fileInfo = fileInfo; + } + catch (e) { } + returnNodes.push(result); + } + else { + returnNodes.push(null); + } + } + var endInfo = parser.end(); + if (endInfo.isFinished) { + callback(null, returnNodes); + } + else { + callback(true, null); + } + } + catch (e) { + throw new LessError({ + index: e.index + currentIndex, + message: e.message + }, imports, fileInfo.filename); + } + } + // + // The Parser + // + return { + parserInput: parserInput, + imports: imports, + fileInfo: fileInfo, + parseNode: parseNode, + // + // Parse an input string into an abstract syntax tree, + // @param str A string containing 'less' markup + // @param callback call `callback` when done. + // @param [additionalData] An optional map which can contains vars - a map (key, value) of variables to apply + // + parse: function (str, callback, additionalData) { + var root; + var error = null; + var globalVars; + var modifyVars; + var ignored; + var preText = ''; + globalVars = (additionalData && additionalData.globalVars) ? Parser.serializeVars(additionalData.globalVars) + "\n" : ''; + modifyVars = (additionalData && additionalData.modifyVars) ? "\n" + Parser.serializeVars(additionalData.modifyVars) : ''; + if (context.pluginManager) { + var preProcessors = context.pluginManager.getPreProcessors(); + for (var i = 0; i < preProcessors.length; i++) { + str = preProcessors[i].process(str, { context: context, imports: imports, fileInfo: fileInfo }); + } + } + if (globalVars || (additionalData && additionalData.banner)) { + preText = ((additionalData && additionalData.banner) ? additionalData.banner : '') + globalVars; + ignored = imports.contentsIgnoredChars; + ignored[fileInfo.filename] = ignored[fileInfo.filename] || 0; + ignored[fileInfo.filename] += preText.length; + } + str = str.replace(/\r\n?/g, '\n'); + // Remove potential UTF Byte Order Mark + str = preText + str.replace(/^\uFEFF/, '') + modifyVars; + imports.contents[fileInfo.filename] = str; + // Start with the primary rule. + // The whole syntax tree is held under a Ruleset node, + // with the `root` property set to true, so no `{}` are + // output. The callback is called when the input is parsed. + try { + parserInput.start(str, context.chunkInput, function fail(msg, index) { + throw new LessError({ + index: index, + type: 'Parse', + message: msg, + filename: fileInfo.filename + }, imports); + }); + tree.Node.prototype.parse = this; + root = new tree.Ruleset(null, this.parsers.primary()); + tree.Node.prototype.rootNode = root; + root.root = true; + root.firstRoot = true; + root.functionRegistry = functionRegistry.inherit(); + } + catch (e) { + return callback(new LessError(e, imports, fileInfo.filename)); + } + // If `i` is smaller than the `input.length - 1`, + // it means the parser wasn't able to parse the whole + // string, so we've got a parsing error. + // + // We try to extract a \n delimited string, + // showing the line where the parse error occurred. + // We split it up into two parts (the part which parsed, + // and the part which didn't), so we can color them differently. + var endInfo = parserInput.end(); + if (!endInfo.isFinished) { + var message = endInfo.furthestPossibleErrorMessage; + if (!message) { + message = 'Unrecognised input'; + if (endInfo.furthestChar === '}') { + message += '. Possibly missing opening \'{\''; + } + else if (endInfo.furthestChar === ')') { + message += '. Possibly missing opening \'(\''; + } + else if (endInfo.furthestReachedEnd) { + message += '. Possibly missing something'; + } + } + error = new LessError({ + type: 'Parse', + message: message, + index: endInfo.furthest, + filename: fileInfo.filename + }, imports); + } + var finish = function (e) { + e = error || e || imports.error; + if (e) { + if (!(e instanceof LessError)) { + e = new LessError(e, imports, fileInfo.filename); + } + return callback(e); + } + else { + return callback(null, root); + } + }; + if (context.processImports !== false) { + new visitors.ImportVisitor(imports, finish) + .run(root); + } + else { + return finish(); + } + }, + // + // Here in, the parsing rules/functions + // + // The basic structure of the syntax tree generated is as follows: + // + // Ruleset -> Declaration -> Value -> Expression -> Entity + // + // Here's some Less code: + // + // .class { + // color: #fff; + // border: 1px solid #000; + // width: @w + 4px; + // > .child {...} + // } + // + // And here's what the parse tree might look like: + // + // Ruleset (Selector '.class', [ + // Declaration ("color", Value ([Expression [Color #fff]])) + // Declaration ("border", Value ([Expression [Dimension 1px][Keyword "solid"][Color #000]])) + // Declaration ("width", Value ([Expression [Operation " + " [Variable "@w"][Dimension 4px]]])) + // Ruleset (Selector [Element '>', '.child'], [...]) + // ]) + // + // In general, most rules will try to parse a token with the `$re()` function, and if the return + // value is truly, will return a new node, of the relevant type. Sometimes, we need to check + // first, before parsing, that's when we use `peek()`. + // + parsers: parsers = { + // + // The `primary` rule is the *entry* and *exit* point of the parser. + // The rules here can appear at any level of the parse tree. + // + // The recursive nature of the grammar is an interplay between the `block` + // rule, which represents `{ ... }`, the `ruleset` rule, and this `primary` rule, + // as represented by this simplified grammar: + // + // primary → (ruleset | declaration)+ + // ruleset → selector+ block + // block → '{' primary '}' + // + // Only at one point is the primary rule not called from the + // block rule: at the root level. + // + primary: function () { + var mixin = this.mixin; + var root = []; + var node; + while (true) { + while (true) { + node = this.comment(); + if (!node) { + break; + } + root.push(node); + } + // always process comments before deciding if finished + if (parserInput.finished) { + break; + } + if (parserInput.peek('}')) { + break; + } + node = this.extendRule(); + if (node) { + root = root.concat(node); + continue; + } + node = mixin.definition() || this.declaration() || mixin.call(false, false) || + this.ruleset() || this.variableCall() || this.entities.call() || this.atrule(); + if (node) { + root.push(node); + } + else { + var foundSemiColon = false; + while (parserInput.$char(';')) { + foundSemiColon = true; + } + if (!foundSemiColon) { + break; + } + } + } + return root; + }, + // comments are collected by the main parsing mechanism and then assigned to nodes + // where the current structure allows it + comment: function () { + if (parserInput.commentStore.length) { + var comment = parserInput.commentStore.shift(); + return new (tree.Comment)(comment.text, comment.isLineComment, comment.index, fileInfo); + } + }, + // + // Entities are tokens which can be found inside an Expression + // + entities: { + mixinLookup: function () { + return parsers.mixin.call(true, true); + }, + // + // A string, which supports escaping " and ' + // + // "milky way" 'he\'s the one!' + // + quoted: function (forceEscaped) { + var str; + var index = parserInput.i; + var isEscaped = false; + parserInput.save(); + if (parserInput.$char('~')) { + isEscaped = true; + } + else if (forceEscaped) { + parserInput.restore(); + return; + } + str = parserInput.$quoted(); + if (!str) { + parserInput.restore(); + return; + } + parserInput.forget(); + return new (tree.Quoted)(str.charAt(0), str.substr(1, str.length - 2), isEscaped, index, fileInfo); + }, + // + // A catch-all word, such as: + // + // black border-collapse + // + keyword: function () { + var k = parserInput.$char('%') || parserInput.$re(/^\[?(?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+\]?/); + if (k) { + return tree.Color.fromKeyword(k) || new (tree.Keyword)(k); + } + }, + // + // A function call + // + // rgb(255, 0, 255) + // + // The arguments are parsed with the `entities.arguments` parser. + // + call: function () { + var name; + var args; + var func; + var index = parserInput.i; + // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18 + if (parserInput.peek(/^url\(/i)) { + return; + } + parserInput.save(); + name = parserInput.$re(/^([\w-]+|%|~|progid:[\w\.]+)\(/); + if (!name) { + parserInput.forget(); + return; + } + name = name[1]; + func = this.customFuncCall(name); + if (func) { + args = func.parse(); + if (args && func.stop) { + parserInput.forget(); + return args; + } + } + args = this.arguments(args); + if (!parserInput.$char(')')) { + parserInput.restore('Could not parse call arguments or missing \')\''); + return; + } + parserInput.forget(); + return new (tree.Call)(name, args, index, fileInfo); + }, + // + // Parsing rules for functions with non-standard args, e.g.: + // + // boolean(not(2 > 1)) + // + // This is a quick prototype, to be modified/improved when + // more custom-parsed funcs come (e.g. `selector(...)`) + // + customFuncCall: function (name) { + /* Ideally the table is to be moved out of here for faster perf., + but it's quite tricky since it relies on all these `parsers` + and `expect` available only here */ + return { + alpha: f(parsers.ieAlpha, true), + boolean: f(condition), + 'if': f(condition) + }[name.toLowerCase()]; + function f(parse, stop) { + return { + parse: parse, + stop: stop // when true - stop after parse() and return its result, + // otherwise continue for plain args + }; + } + function condition() { + return [expect(parsers.condition, 'expected condition')]; + } + }, + arguments: function (prevArgs) { + var argsComma = prevArgs || []; + var argsSemiColon = []; + var isSemiColonSeparated; + var value; + parserInput.save(); + while (true) { + if (prevArgs) { + prevArgs = false; + } + else { + value = parsers.detachedRuleset() || this.assignment() || parsers.expression(); + if (!value) { + break; + } + if (value.value && value.value.length == 1) { + value = value.value[0]; + } + argsComma.push(value); + } + if (parserInput.$char(',')) { + continue; + } + if (parserInput.$char(';') || isSemiColonSeparated) { + isSemiColonSeparated = true; + value = (argsComma.length < 1) ? argsComma[0] + : new tree.Value(argsComma); + argsSemiColon.push(value); + argsComma = []; + } + } + parserInput.forget(); + return isSemiColonSeparated ? argsSemiColon : argsComma; + }, + literal: function () { + return this.dimension() || + this.color() || + this.quoted() || + this.unicodeDescriptor(); + }, + // Assignments are argument entities for calls. + // They are present in ie filter properties as shown below. + // + // filter: progid:DXImageTransform.Microsoft.Alpha( *opacity=50* ) + // + assignment: function () { + var key; + var value; + parserInput.save(); + key = parserInput.$re(/^\w+(?=\s?=)/i); + if (!key) { + parserInput.restore(); + return; + } + if (!parserInput.$char('=')) { + parserInput.restore(); + return; + } + value = parsers.entity(); + if (value) { + parserInput.forget(); + return new (tree.Assignment)(key, value); + } + else { + parserInput.restore(); + } + }, + // + // Parse url() tokens + // + // We use a specific rule for urls, because they don't really behave like + // standard function calls. The difference is that the argument doesn't have + // to be enclosed within a string, so it can't be parsed as an Expression. + // + url: function () { + var value; + var index = parserInput.i; + parserInput.autoCommentAbsorb = false; + if (!parserInput.$str('url(')) { + parserInput.autoCommentAbsorb = true; + return; + } + value = this.quoted() || this.variable() || this.property() || + parserInput.$re(/^(?:(?:\\[\(\)'"])|[^\(\)'"])+/) || ''; + parserInput.autoCommentAbsorb = true; + expectChar(')'); + return new (tree.URL)((value.value != null || + value instanceof tree.Variable || + value instanceof tree.Property) ? + value : new (tree.Anonymous)(value, index), index, fileInfo); + }, + // + // A Variable entity, such as `@fink`, in + // + // width: @fink + 2px + // + // We use a different parser for variable definitions, + // see `parsers.variable`. + // + variable: function () { + var ch; + var name; + var index = parserInput.i; + parserInput.save(); + if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^@@?[\w-]+/))) { + ch = parserInput.currentChar(); + if (ch === '(' || ch === '[' && !parserInput.prevChar().match(/^\s/)) { + // this may be a VariableCall lookup + var result = parsers.variableCall(name); + if (result) { + parserInput.forget(); + return result; + } + } + parserInput.forget(); + return new (tree.Variable)(name, index, fileInfo); + } + parserInput.restore(); + }, + // A variable entity using the protective {} e.g. @{var} + variableCurly: function () { + var curly; + var index = parserInput.i; + if (parserInput.currentChar() === '@' && (curly = parserInput.$re(/^@\{([\w-]+)\}/))) { + return new (tree.Variable)("@" + curly[1], index, fileInfo); + } + }, + // + // A Property accessor, such as `$color`, in + // + // background-color: $color + // + property: function () { + var name; + var index = parserInput.i; + if (parserInput.currentChar() === '$' && (name = parserInput.$re(/^\$[\w-]+/))) { + return new (tree.Property)(name, index, fileInfo); + } + }, + // A property entity useing the protective {} e.g. ${prop} + propertyCurly: function () { + var curly; + var index = parserInput.i; + if (parserInput.currentChar() === '$' && (curly = parserInput.$re(/^\$\{([\w-]+)\}/))) { + return new (tree.Property)("$" + curly[1], index, fileInfo); + } + }, + // + // A Hexadecimal color + // + // #4F3C2F + // + // `rgb` and `hsl` colors are parsed through the `entities.call` parser. + // + color: function () { + var rgb; + parserInput.save(); + if (parserInput.currentChar() === '#' && (rgb = parserInput.$re(/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})([\w.#\[])?/))) { + if (!rgb[2]) { + parserInput.forget(); + return new (tree.Color)(rgb[1], undefined, rgb[0]); + } + } + parserInput.restore(); + }, + colorKeyword: function () { + parserInput.save(); + var autoCommentAbsorb = parserInput.autoCommentAbsorb; + parserInput.autoCommentAbsorb = false; + var k = parserInput.$re(/^[_A-Za-z-][_A-Za-z0-9-]+/); + parserInput.autoCommentAbsorb = autoCommentAbsorb; + if (!k) { + parserInput.forget(); + return; + } + parserInput.restore(); + var color = tree.Color.fromKeyword(k); + if (color) { + parserInput.$str(k); + return color; + } + }, + // + // A Dimension, that is, a number and a unit + // + // 0.5em 95% + // + dimension: function () { + if (parserInput.peekNotNumeric()) { + return; + } + var value = parserInput.$re(/^([+-]?\d*\.?\d+)(%|[a-z_]+)?/i); + if (value) { + return new (tree.Dimension)(value[1], value[2]); + } + }, + // + // A unicode descriptor, as is used in unicode-range + // + // U+0?? or U+00A1-00A9 + // + unicodeDescriptor: function () { + var ud; + ud = parserInput.$re(/^U\+[0-9a-fA-F?]+(\-[0-9a-fA-F?]+)?/); + if (ud) { + return new (tree.UnicodeDescriptor)(ud[0]); + } + }, + // + // JavaScript code to be evaluated + // + // `window.location.href` + // + javascript: function () { + var js; + var index = parserInput.i; + parserInput.save(); + var escape = parserInput.$char('~'); + var jsQuote = parserInput.$char('`'); + if (!jsQuote) { + parserInput.restore(); + return; + } + js = parserInput.$re(/^[^`]*`/); + if (js) { + parserInput.forget(); + return new (tree.JavaScript)(js.substr(0, js.length - 1), Boolean(escape), index, fileInfo); + } + parserInput.restore('invalid javascript definition'); + } + }, + // + // The variable part of a variable definition. Used in the `rule` parser + // + // @fink: + // + variable: function () { + var name; + if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^(@[\w-]+)\s*:/))) { + return name[1]; + } + }, + // + // Call a variable value to retrieve a detached ruleset + // or a value from a detached ruleset's rules. + // + // @fink(); + // @fink; + // color: @fink[@color]; + // + variableCall: function (parsedName) { + var lookups; + var i = parserInput.i; + var inValue = !!parsedName; + var name = parsedName; + parserInput.save(); + if (name || (parserInput.currentChar() === '@' + && (name = parserInput.$re(/^(@[\w-]+)(\(\s*\))?/)))) { + lookups = this.mixin.ruleLookups(); + if (!lookups && ((inValue && parserInput.$str('()') !== '()') || (name[2] !== '()'))) { + parserInput.restore('Missing \'[...]\' lookup in variable call'); + return; + } + if (!inValue) { + name = name[1]; + } + var call = new tree.VariableCall(name, i, fileInfo); + if (!inValue && parsers.end()) { + parserInput.forget(); + return call; + } + else { + parserInput.forget(); + return new tree.NamespaceValue(call, lookups, i, fileInfo); + } + } + parserInput.restore(); + }, + // + // extend syntax - used to extend selectors + // + extend: function (isRule) { + var elements; + var e; + var index = parserInput.i; + var option; + var extendList; + var extend; + if (!parserInput.$str(isRule ? '&:extend(' : ':extend(')) { + return; + } + do { + option = null; + elements = null; + while (!(option = parserInput.$re(/^(all)(?=\s*(\)|,))/))) { + e = this.element(); + if (!e) { + break; + } + if (elements) { + elements.push(e); + } + else { + elements = [e]; + } + } + option = option && option[1]; + if (!elements) { + error('Missing target selector for :extend().'); + } + extend = new (tree.Extend)(new (tree.Selector)(elements), option, index, fileInfo); + if (extendList) { + extendList.push(extend); + } + else { + extendList = [extend]; + } + } while (parserInput.$char(',')); + expect(/^\)/); + if (isRule) { + expect(/^;/); + } + return extendList; + }, + // + // extendRule - used in a rule to extend all the parent selectors + // + extendRule: function () { + return this.extend(true); + }, + // + // Mixins + // + mixin: { + // + // A Mixin call, with an optional argument list + // + // #mixins > .square(#fff); + // #mixins.square(#fff); + // .rounded(4px, black); + // .button; + // + // We can lookup / return a value using the lookup syntax: + // + // color: #mixin.square(#fff)[@color]; + // + // The `while` loop is there because mixins can be + // namespaced, but we only support the child and descendant + // selector for now. + // + call: function (inValue, getLookup) { + var s = parserInput.currentChar(); + var important = false; + var lookups; + var index = parserInput.i; + var elements; + var args; + var hasParens; + if (s !== '.' && s !== '#') { + return; + } + parserInput.save(); // stop us absorbing part of an invalid selector + elements = this.elements(); + if (elements) { + if (parserInput.$char('(')) { + args = this.args(true).args; + expectChar(')'); + hasParens = true; + } + if (getLookup !== false) { + lookups = this.ruleLookups(); + } + if (getLookup === true && !lookups) { + parserInput.restore(); + return; + } + if (!lookups && !hasParens) { + // This isn't a valid mixin call + parserInput.restore('Unrecognized input. Possibly missing \'(\' in mixin call.'); + return; + } + if (!inValue && parsers.important()) { + important = true; + } + if (inValue || parsers.end()) { + parserInput.forget(); + var mixin = new (tree.mixin.Call)(elements, args, index, fileInfo, !lookups && important); + if (lookups) { + return new tree.NamespaceValue(mixin, lookups); + } + else { + return mixin; + } + } + } + parserInput.restore(); + }, + /** + * Matching elements for mixins + * (Start with . or # and can have > ) + */ + elements: function () { + var elements; + var e; + var c; + var elem; + var elemIndex; + var re = /^[#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/; + while (true) { + elemIndex = parserInput.i; + e = parserInput.$re(re); + if (!e) { + break; + } + elem = new (tree.Element)(c, e, false, elemIndex, fileInfo); + if (elements) { + elements.push(elem); + } + else { + elements = [elem]; + } + c = parserInput.$char('>'); + } + return elements; + }, + args: function (isCall) { + var entities = parsers.entities; + var returner = { args: null, variadic: false }; + var expressions = []; + var argsSemiColon = []; + var argsComma = []; + var isSemiColonSeparated; + var expressionContainsNamed; + var name; + var nameLoop; + var value; + var arg; + var expand; + var hasSep = true; + parserInput.save(); + while (true) { + if (isCall) { + arg = parsers.detachedRuleset() || parsers.expression(); + } + else { + parserInput.commentStore.length = 0; + if (parserInput.$str('...')) { + returner.variadic = true; + if (parserInput.$char(';') && !isSemiColonSeparated) { + isSemiColonSeparated = true; + } + (isSemiColonSeparated ? argsSemiColon : argsComma) + .push({ variadic: true }); + break; + } + arg = entities.variable() || entities.property() || entities.literal() || entities.keyword() || this.call(true); + } + if (!arg || !hasSep) { + break; + } + nameLoop = null; + if (arg.throwAwayComments) { + arg.throwAwayComments(); + } + value = arg; + var val = null; + if (isCall) { + // Variable + if (arg.value && arg.value.length == 1) { + val = arg.value[0]; + } + } + else { + val = arg; + } + if (val && (val instanceof tree.Variable || val instanceof tree.Property)) { + if (parserInput.$char(':')) { + if (expressions.length > 0) { + if (isSemiColonSeparated) { + error('Cannot mix ; and , as delimiter types'); + } + expressionContainsNamed = true; + } + value = parsers.detachedRuleset() || parsers.expression(); + if (!value) { + if (isCall) { + error('could not understand value for named argument'); + } + else { + parserInput.restore(); + returner.args = []; + return returner; + } + } + nameLoop = (name = val.name); + } + else if (parserInput.$str('...')) { + if (!isCall) { + returner.variadic = true; + if (parserInput.$char(';') && !isSemiColonSeparated) { + isSemiColonSeparated = true; + } + (isSemiColonSeparated ? argsSemiColon : argsComma) + .push({ name: arg.name, variadic: true }); + break; + } + else { + expand = true; + } + } + else if (!isCall) { + name = nameLoop = val.name; + value = null; + } + } + if (value) { + expressions.push(value); + } + argsComma.push({ name: nameLoop, value: value, expand: expand }); + if (parserInput.$char(',')) { + hasSep = true; + continue; + } + hasSep = parserInput.$char(';') === ';'; + if (hasSep || isSemiColonSeparated) { + if (expressionContainsNamed) { + error('Cannot mix ; and , as delimiter types'); + } + isSemiColonSeparated = true; + if (expressions.length > 1) { + value = new (tree.Value)(expressions); + } + argsSemiColon.push({ name: name, value: value, expand: expand }); + name = null; + expressions = []; + expressionContainsNamed = false; + } + } + parserInput.forget(); + returner.args = isSemiColonSeparated ? argsSemiColon : argsComma; + return returner; + }, + // + // A Mixin definition, with a list of parameters + // + // .rounded (@radius: 2px, @color) { + // ... + // } + // + // Until we have a finer grained state-machine, we have to + // do a look-ahead, to make sure we don't have a mixin call. + // See the `rule` function for more information. + // + // We start by matching `.rounded (`, and then proceed on to + // the argument list, which has optional default values. + // We store the parameters in `params`, with a `value` key, + // if there is a value, such as in the case of `@radius`. + // + // Once we've got our params list, and a closing `)`, we parse + // the `{...}` block. + // + definition: function () { + var name; + var params = []; + var match; + var ruleset; + var cond; + var variadic = false; + if ((parserInput.currentChar() !== '.' && parserInput.currentChar() !== '#') || + parserInput.peek(/^[^{]*\}/)) { + return; + } + parserInput.save(); + match = parserInput.$re(/^([#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\s*\(/); + if (match) { + name = match[1]; + var argInfo = this.args(false); + params = argInfo.args; + variadic = argInfo.variadic; + // .mixincall("@{a}"); + // looks a bit like a mixin definition.. + // also + // .mixincall(@a: {rule: set;}); + // so we have to be nice and restore + if (!parserInput.$char(')')) { + parserInput.restore('Missing closing \')\''); + return; + } + parserInput.commentStore.length = 0; + if (parserInput.$str('when')) { // Guard + cond = expect(parsers.conditions, 'expected condition'); + } + ruleset = parsers.block(); + if (ruleset) { + parserInput.forget(); + return new (tree.mixin.Definition)(name, params, ruleset, cond, variadic); + } + else { + parserInput.restore(); + } + } + else { + parserInput.restore(); + } + }, + ruleLookups: function () { + var rule; + var lookups = []; + if (parserInput.currentChar() !== '[') { + return; + } + while (true) { + parserInput.save(); + rule = this.lookupValue(); + if (!rule && rule !== '') { + parserInput.restore(); + break; + } + lookups.push(rule); + parserInput.forget(); + } + if (lookups.length > 0) { + return lookups; + } + }, + lookupValue: function () { + parserInput.save(); + if (!parserInput.$char('[')) { + parserInput.restore(); + return; + } + var name = parserInput.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/); + if (!parserInput.$char(']')) { + parserInput.restore(); + return; + } + if (name || name === '') { + parserInput.forget(); + return name; + } + parserInput.restore(); + } + }, + // + // Entities are the smallest recognized token, + // and can be found inside a rule's value. + // + entity: function () { + var entities = this.entities; + return this.comment() || entities.literal() || entities.variable() || entities.url() || + entities.property() || entities.call() || entities.keyword() || this.mixin.call(true) || + entities.javascript(); + }, + // + // A Declaration terminator. Note that we use `peek()` to check for '}', + // because the `block` rule will be expecting it, but we still need to make sure + // it's there, if ';' was omitted. + // + end: function () { + return parserInput.$char(';') || parserInput.peek('}'); + }, + // + // IE's alpha function + // + // alpha(opacity=88) + // + ieAlpha: function () { + var value; + // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18 + if (!parserInput.$re(/^opacity=/i)) { + return; + } + value = parserInput.$re(/^\d+/); + if (!value) { + value = expect(parsers.entities.variable, 'Could not parse alpha'); + value = "@{" + value.name.slice(1) + "}"; + } + expectChar(')'); + return new tree.Quoted('', "alpha(opacity=" + value + ")"); + }, + // + // A Selector Element + // + // div + // + h1 + // #socks + // input[type="text"] + // + // Elements are the building blocks for Selectors, + // they are made out of a `Combinator` (see combinator rule), + // and an element name, such as a tag a class, or `*`. + // + element: function () { + var e; + var c; + var v; + var index = parserInput.i; + c = this.combinator(); + e = parserInput.$re(/^(?:\d+\.\d+|\d+)%/) || + parserInput.$re(/^(?:[.#]?|:*)(?:[\w-]|[^\x00-\x9f]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/) || + parserInput.$char('*') || parserInput.$char('&') || this.attribute() || + parserInput.$re(/^\([^&()@]+\)/) || parserInput.$re(/^[\.#:](?=@)/) || + this.entities.variableCurly(); + if (!e) { + parserInput.save(); + if (parserInput.$char('(')) { + if ((v = this.selector(false)) && parserInput.$char(')')) { + e = new (tree.Paren)(v); + parserInput.forget(); + } + else { + parserInput.restore('Missing closing \')\''); + } + } + else { + parserInput.forget(); + } + } + if (e) { + return new (tree.Element)(c, e, e instanceof tree.Variable, index, fileInfo); + } + }, + // + // Combinators combine elements together, in a Selector. + // + // Because our parser isn't white-space sensitive, special care + // has to be taken, when parsing the descendant combinator, ` `, + // as it's an empty space. We have to check the previous character + // in the input, to see if it's a ` ` character. More info on how + // we deal with this in *combinator.js*. + // + combinator: function () { + var c = parserInput.currentChar(); + if (c === '/') { + parserInput.save(); + var slashedCombinator = parserInput.$re(/^\/[a-z]+\//i); + if (slashedCombinator) { + parserInput.forget(); + return new (tree.Combinator)(slashedCombinator); + } + parserInput.restore(); + } + if (c === '>' || c === '+' || c === '~' || c === '|' || c === '^') { + parserInput.i++; + if (c === '^' && parserInput.currentChar() === '^') { + c = '^^'; + parserInput.i++; + } + while (parserInput.isWhitespace()) { + parserInput.i++; + } + return new (tree.Combinator)(c); + } + else if (parserInput.isWhitespace(-1)) { + return new (tree.Combinator)(' '); + } + else { + return new (tree.Combinator)(null); + } + }, + // + // A CSS Selector + // with less extensions e.g. the ability to extend and guard + // + // .class > div + h1 + // li a:hover + // + // Selectors are made out of one or more Elements, see above. + // + selector: function (isLess) { + var index = parserInput.i; + var elements; + var extendList; + var c; + var e; + var allExtends; + var when; + var condition; + isLess = isLess !== false; + while ((isLess && (extendList = this.extend())) || (isLess && (when = parserInput.$str('when'))) || (e = this.element())) { + if (when) { + condition = expect(this.conditions, 'expected condition'); + } + else if (condition) { + error('CSS guard can only be used at the end of selector'); + } + else if (extendList) { + if (allExtends) { + allExtends = allExtends.concat(extendList); + } + else { + allExtends = extendList; + } + } + else { + if (allExtends) { + error('Extend can only be used at the end of selector'); + } + c = parserInput.currentChar(); + if (elements) { + elements.push(e); + } + else { + elements = [e]; + } + e = null; + } + if (c === '{' || c === '}' || c === ';' || c === ',' || c === ')') { + break; + } + } + if (elements) { + return new (tree.Selector)(elements, allExtends, condition, index, fileInfo); + } + if (allExtends) { + error('Extend must be used to extend a selector, it cannot be used on its own'); + } + }, + selectors: function () { + var s; + var selectors; + while (true) { + s = this.selector(); + if (!s) { + break; + } + if (selectors) { + selectors.push(s); + } + else { + selectors = [s]; + } + parserInput.commentStore.length = 0; + if (s.condition && selectors.length > 1) { + error("Guards are only currently allowed on a single selector."); + } + if (!parserInput.$char(',')) { + break; + } + if (s.condition) { + error("Guards are only currently allowed on a single selector."); + } + parserInput.commentStore.length = 0; + } + return selectors; + }, + attribute: function () { + if (!parserInput.$char('[')) { + return; + } + var entities = this.entities; + var key; + var val; + var op; + if (!(key = entities.variableCurly())) { + key = expect(/^(?:[_A-Za-z0-9-\*]*\|)?(?:[_A-Za-z0-9-]|\\.)+/); + } + op = parserInput.$re(/^[|~*$^]?=/); + if (op) { + val = entities.quoted() || parserInput.$re(/^[0-9]+%/) || parserInput.$re(/^[\w-]+/) || entities.variableCurly(); + } + expectChar(']'); + return new (tree.Attribute)(key, op, val); + }, + // + // The `block` rule is used by `ruleset` and `mixin.definition`. + // It's a wrapper around the `primary` rule, with added `{}`. + // + block: function () { + var content; + if (parserInput.$char('{') && (content = this.primary()) && parserInput.$char('}')) { + return content; + } + }, + blockRuleset: function () { + var block = this.block(); + if (block) { + block = new tree.Ruleset(null, block); + } + return block; + }, + detachedRuleset: function () { + var argInfo; + var params; + var variadic; + parserInput.save(); + if (parserInput.$re(/^[.#]\(/)) { + /** + * DR args currently only implemented for each() function, and not + * yet settable as `@dr: #(@arg) {}` + * This should be done when DRs are merged with mixins. + * See: https://github.com/less/less-meta/issues/16 + */ + argInfo = this.mixin.args(false); + params = argInfo.args; + variadic = argInfo.variadic; + if (!parserInput.$char(')')) { + parserInput.restore(); + return; + } + } + var blockRuleset = this.blockRuleset(); + if (blockRuleset) { + parserInput.forget(); + if (params) { + return new tree.mixin.Definition(null, params, blockRuleset, null, variadic); + } + return new tree.DetachedRuleset(blockRuleset); + } + parserInput.restore(); + }, + // + // div, .class, body > p {...} + // + ruleset: function () { + var selectors; + var rules; + var debugInfo; + parserInput.save(); + if (context.dumpLineNumbers) { + debugInfo = getDebugInfo(parserInput.i); + } + selectors = this.selectors(); + if (selectors && (rules = this.block())) { + parserInput.forget(); + var ruleset = new (tree.Ruleset)(selectors, rules, context.strictImports); + if (context.dumpLineNumbers) { + ruleset.debugInfo = debugInfo; + } + return ruleset; + } + else { + parserInput.restore(); + } + }, + declaration: function () { + var name; + var value; + var index = parserInput.i; + var hasDR; + var c = parserInput.currentChar(); + var important; + var merge; + var isVariable; + if (c === '.' || c === '#' || c === '&' || c === ':') { + return; + } + parserInput.save(); + name = this.variable() || this.ruleProperty(); + if (name) { + isVariable = typeof name === 'string'; + if (isVariable) { + value = this.detachedRuleset(); + if (value) { + hasDR = true; + } + } + parserInput.commentStore.length = 0; + if (!value) { + // a name returned by this.ruleProperty() is always an array of the form: + // [string-1, ..., string-n, ""] or [string-1, ..., string-n, "+"] + // where each item is a tree.Keyword or tree.Variable + merge = !isVariable && name.length > 1 && name.pop().value; + // Custom property values get permissive parsing + if (name[0].value && name[0].value.slice(0, 2) === '--') { + value = this.permissiveValue(); + } + // Try to store values as anonymous + // If we need the value later we'll re-parse it in ruleset.parseValue + else { + value = this.anonymousValue(); + } + if (value) { + parserInput.forget(); + // anonymous values absorb the end ';' which is required for them to work + return new (tree.Declaration)(name, value, false, merge, index, fileInfo); + } + if (!value) { + value = this.value(); + } + if (value) { + important = this.important(); + } + else if (isVariable) { + // As a last resort, try permissiveValue + value = this.permissiveValue(); + } + } + if (value && (this.end() || hasDR)) { + parserInput.forget(); + return new (tree.Declaration)(name, value, important, merge, index, fileInfo); + } + else { + parserInput.restore(); + } + } + else { + parserInput.restore(); + } + }, + anonymousValue: function () { + var index = parserInput.i; + var match = parserInput.$re(/^([^.#@\$+\/'"*`(;{}-]*);/); + if (match) { + return new (tree.Anonymous)(match[1], index); + } + }, + /** + * Used for custom properties, at-rules, and variables (as fallback) + * Parses almost anything inside of {} [] () "" blocks + * until it reaches outer-most tokens. + * + * First, it will try to parse comments and entities to reach + * the end. This is mostly like the Expression parser except no + * math is allowed. + */ + permissiveValue: function (untilTokens) { + var i; + var e; + var done; + var value; + var tok = untilTokens || ';'; + var index = parserInput.i; + var result = []; + function testCurrentChar() { + var char = parserInput.currentChar(); + if (typeof tok === 'string') { + return char === tok; + } + else { + return tok.test(char); + } + } + if (testCurrentChar()) { + return; + } + value = []; + do { + e = this.comment(); + if (e) { + value.push(e); + continue; + } + e = this.entity(); + if (e) { + value.push(e); + } + } while (e); + done = testCurrentChar(); + if (value.length > 0) { + value = new (tree.Expression)(value); + if (done) { + return value; + } + else { + result.push(value); + } + // Preserve space before $parseUntil as it will not + if (parserInput.prevChar() === ' ') { + result.push(new tree.Anonymous(' ', index)); + } + } + parserInput.save(); + value = parserInput.$parseUntil(tok); + if (value) { + if (typeof value === 'string') { + error("Expected '" + value + "'", 'Parse'); + } + if (value.length === 1 && value[0] === ' ') { + parserInput.forget(); + return new tree.Anonymous('', index); + } + var item = void 0; + for (i = 0; i < value.length; i++) { + item = value[i]; + if (Array.isArray(item)) { + // Treat actual quotes as normal quoted values + result.push(new tree.Quoted(item[0], item[1], true, index, fileInfo)); + } + else { + if (i === value.length - 1) { + item = item.trim(); + } + // Treat like quoted values, but replace vars like unquoted expressions + var quote = new tree.Quoted('\'', item, true, index, fileInfo); + quote.variableRegex = /@([\w-]+)/g; + quote.propRegex = /\$([\w-]+)/g; + result.push(quote); + } + } + parserInput.forget(); + return new tree.Expression(result, true); + } + parserInput.restore(); + }, + // + // An @import atrule + // + // @import "lib"; + // + // Depending on our environment, importing is done differently: + // In the browser, it's an XHR request, in Node, it would be a + // file-system operation. The function used for importing is + // stored in `import`, which we pass to the Import constructor. + // + 'import': function () { + var path; + var features; + var index = parserInput.i; + var dir = parserInput.$re(/^@import?\s+/); + if (dir) { + var options = (dir ? this.importOptions() : null) || {}; + if ((path = this.entities.quoted() || this.entities.url())) { + features = this.mediaFeatures(); + if (!parserInput.$char(';')) { + parserInput.i = index; + error('missing semi-colon or unrecognised media features on import'); + } + features = features && new (tree.Value)(features); + return new (tree.Import)(path, features, options, index, fileInfo); + } + else { + parserInput.i = index; + error('malformed import statement'); + } + } + }, + importOptions: function () { + var o; + var options = {}; + var optionName; + var value; + // list of options, surrounded by parens + if (!parserInput.$char('(')) { + return null; + } + do { + o = this.importOption(); + if (o) { + optionName = o; + value = true; + switch (optionName) { + case 'css': + optionName = 'less'; + value = false; + break; + case 'once': + optionName = 'multiple'; + value = false; + break; + } + options[optionName] = value; + if (!parserInput.$char(',')) { + break; + } + } + } while (o); + expectChar(')'); + return options; + }, + importOption: function () { + var opt = parserInput.$re(/^(less|css|multiple|once|inline|reference|optional)/); + if (opt) { + return opt[1]; + } + }, + mediaFeature: function () { + var entities = this.entities; + var nodes = []; + var e; + var p; + parserInput.save(); + do { + e = entities.keyword() || entities.variable() || entities.mixinLookup(); + if (e) { + nodes.push(e); + } + else if (parserInput.$char('(')) { + p = this.property(); + e = this.value(); + if (parserInput.$char(')')) { + if (p && e) { + nodes.push(new (tree.Paren)(new (tree.Declaration)(p, e, null, null, parserInput.i, fileInfo, true))); + } + else if (e) { + nodes.push(new (tree.Paren)(e)); + } + else { + error('badly formed media feature definition'); + } + } + else { + error('Missing closing \')\'', 'Parse'); + } + } + } while (e); + parserInput.forget(); + if (nodes.length > 0) { + return new (tree.Expression)(nodes); + } + }, + mediaFeatures: function () { + var entities = this.entities; + var features = []; + var e; + do { + e = this.mediaFeature(); + if (e) { + features.push(e); + if (!parserInput.$char(',')) { + break; + } + } + else { + e = entities.variable() || entities.mixinLookup(); + if (e) { + features.push(e); + if (!parserInput.$char(',')) { + break; + } + } + } + } while (e); + return features.length > 0 ? features : null; + }, + media: function () { + var features; + var rules; + var media; + var debugInfo; + var index = parserInput.i; + if (context.dumpLineNumbers) { + debugInfo = getDebugInfo(index); + } + parserInput.save(); + if (parserInput.$str('@media')) { + features = this.mediaFeatures(); + rules = this.block(); + if (!rules) { + error('media definitions require block statements after any features'); + } + parserInput.forget(); + media = new (tree.Media)(rules, features, index, fileInfo); + if (context.dumpLineNumbers) { + media.debugInfo = debugInfo; + } + return media; + } + parserInput.restore(); + }, + // + // A @plugin directive, used to import plugins dynamically. + // + // @plugin (args) "lib"; + // + plugin: function () { + var path; + var args; + var options; + var index = parserInput.i; + var dir = parserInput.$re(/^@plugin?\s+/); + if (dir) { + args = this.pluginArgs(); + if (args) { + options = { + pluginArgs: args, + isPlugin: true + }; + } + else { + options = { isPlugin: true }; + } + if ((path = this.entities.quoted() || this.entities.url())) { + if (!parserInput.$char(';')) { + parserInput.i = index; + error('missing semi-colon on @plugin'); + } + return new (tree.Import)(path, null, options, index, fileInfo); + } + else { + parserInput.i = index; + error('malformed @plugin statement'); + } + } + }, + pluginArgs: function () { + // list of options, surrounded by parens + parserInput.save(); + if (!parserInput.$char('(')) { + parserInput.restore(); + return null; + } + var args = parserInput.$re(/^\s*([^\);]+)\)\s*/); + if (args[1]) { + parserInput.forget(); + return args[1].trim(); + } + else { + parserInput.restore(); + return null; + } + }, + // + // A CSS AtRule + // + // @charset "utf-8"; + // + atrule: function () { + var index = parserInput.i; + var name; + var value; + var rules; + var nonVendorSpecificName; + var hasIdentifier; + var hasExpression; + var hasUnknown; + var hasBlock = true; + var isRooted = true; + if (parserInput.currentChar() !== '@') { + return; + } + value = this['import']() || this.plugin() || this.media(); + if (value) { + return value; + } + parserInput.save(); + name = parserInput.$re(/^@[a-z-]+/); + if (!name) { + return; + } + nonVendorSpecificName = name; + if (name.charAt(1) == '-' && name.indexOf('-', 2) > 0) { + nonVendorSpecificName = "@" + name.slice(name.indexOf('-', 2) + 1); + } + switch (nonVendorSpecificName) { + case '@charset': + hasIdentifier = true; + hasBlock = false; + break; + case '@namespace': + hasExpression = true; + hasBlock = false; + break; + case '@keyframes': + case '@counter-style': + hasIdentifier = true; + break; + case '@document': + case '@supports': + hasUnknown = true; + isRooted = false; + break; + default: + hasUnknown = true; + break; + } + parserInput.commentStore.length = 0; + if (hasIdentifier) { + value = this.entity(); + if (!value) { + error("expected " + name + " identifier"); + } + } + else if (hasExpression) { + value = this.expression(); + if (!value) { + error("expected " + name + " expression"); + } + } + else if (hasUnknown) { + value = this.permissiveValue(/^[{;]/); + hasBlock = (parserInput.currentChar() === '{'); + if (!value) { + if (!hasBlock && parserInput.currentChar() !== ';') { + error(name + " rule is missing block or ending semi-colon"); + } + } + else if (!value.value) { + value = null; + } + } + if (hasBlock) { + rules = this.blockRuleset(); + } + if (rules || (!hasBlock && value && parserInput.$char(';'))) { + parserInput.forget(); + return new (tree.AtRule)(name, value, rules, index, fileInfo, context.dumpLineNumbers ? getDebugInfo(index) : null, isRooted); + } + parserInput.restore('at-rule options not recognised'); + }, + // + // A Value is a comma-delimited list of Expressions + // + // font-family: Baskerville, Georgia, serif; + // + // In a Rule, a Value represents everything after the `:`, + // and before the `;`. + // + value: function () { + var e; + var expressions = []; + var index = parserInput.i; + do { + e = this.expression(); + if (e) { + expressions.push(e); + if (!parserInput.$char(',')) { + break; + } + } + } while (e); + if (expressions.length > 0) { + return new (tree.Value)(expressions, index); + } + }, + important: function () { + if (parserInput.currentChar() === '!') { + return parserInput.$re(/^! *important/); + } + }, + sub: function () { + var a; + var e; + parserInput.save(); + if (parserInput.$char('(')) { + a = this.addition(); + if (a && parserInput.$char(')')) { + parserInput.forget(); + e = new (tree.Expression)([a]); + e.parens = true; + return e; + } + parserInput.restore('Expected \')\''); + return; + } + parserInput.restore(); + }, + multiplication: function () { + var m; + var a; + var op; + var operation; + var isSpaced; + m = this.operand(); + if (m) { + isSpaced = parserInput.isWhitespace(-1); + while (true) { + if (parserInput.peek(/^\/[*\/]/)) { + break; + } + parserInput.save(); + op = parserInput.$char('/') || parserInput.$char('*') || parserInput.$str('./'); + if (!op) { + parserInput.forget(); + break; + } + a = this.operand(); + if (!a) { + parserInput.restore(); + break; + } + parserInput.forget(); + m.parensInOp = true; + a.parensInOp = true; + operation = new (tree.Operation)(op, [operation || m, a], isSpaced); + isSpaced = parserInput.isWhitespace(-1); + } + return operation || m; + } + }, + addition: function () { + var m; + var a; + var op; + var operation; + var isSpaced; + m = this.multiplication(); + if (m) { + isSpaced = parserInput.isWhitespace(-1); + while (true) { + op = parserInput.$re(/^[-+]\s+/) || (!isSpaced && (parserInput.$char('+') || parserInput.$char('-'))); + if (!op) { + break; + } + a = this.multiplication(); + if (!a) { + break; + } + m.parensInOp = true; + a.parensInOp = true; + operation = new (tree.Operation)(op, [operation || m, a], isSpaced); + isSpaced = parserInput.isWhitespace(-1); + } + return operation || m; + } + }, + conditions: function () { + var a; + var b; + var index = parserInput.i; + var condition; + a = this.condition(true); + if (a) { + while (true) { + if (!parserInput.peek(/^,\s*(not\s*)?\(/) || !parserInput.$char(',')) { + break; + } + b = this.condition(true); + if (!b) { + break; + } + condition = new (tree.Condition)('or', condition || a, b, index); + } + return condition || a; + } + }, + condition: function (needsParens) { + var result; + var logical; + var next; + function or() { + return parserInput.$str('or'); + } + result = this.conditionAnd(needsParens); + if (!result) { + return; + } + logical = or(); + if (logical) { + next = this.condition(needsParens); + if (next) { + result = new (tree.Condition)(logical, result, next); + } + else { + return; + } + } + return result; + }, + conditionAnd: function (needsParens) { + var result; + var logical; + var next; + var self = this; + function insideCondition() { + var cond = self.negatedCondition(needsParens) || self.parenthesisCondition(needsParens); + if (!cond && !needsParens) { + return self.atomicCondition(needsParens); + } + return cond; + } + function and() { + return parserInput.$str('and'); + } + result = insideCondition(); + if (!result) { + return; + } + logical = and(); + if (logical) { + next = this.conditionAnd(needsParens); + if (next) { + result = new (tree.Condition)(logical, result, next); + } + else { + return; + } + } + return result; + }, + negatedCondition: function (needsParens) { + if (parserInput.$str('not')) { + var result = this.parenthesisCondition(needsParens); + if (result) { + result.negate = !result.negate; + } + return result; + } + }, + parenthesisCondition: function (needsParens) { + function tryConditionFollowedByParenthesis(me) { + var body; + parserInput.save(); + body = me.condition(needsParens); + if (!body) { + parserInput.restore(); + return; + } + if (!parserInput.$char(')')) { + parserInput.restore(); + return; + } + parserInput.forget(); + return body; + } + var body; + parserInput.save(); + if (!parserInput.$str('(')) { + parserInput.restore(); + return; + } + body = tryConditionFollowedByParenthesis(this); + if (body) { + parserInput.forget(); + return body; + } + body = this.atomicCondition(needsParens); + if (!body) { + parserInput.restore(); + return; + } + if (!parserInput.$char(')')) { + parserInput.restore("expected ')' got '" + parserInput.currentChar() + "'"); + return; + } + parserInput.forget(); + return body; + }, + atomicCondition: function (needsParens) { + var entities = this.entities; + var index = parserInput.i; + var a; + var b; + var c; + var op; + function cond() { + return this.addition() || entities.keyword() || entities.quoted() || entities.mixinLookup(); + } + cond = cond.bind(this); + a = cond(); + if (a) { + if (parserInput.$char('>')) { + if (parserInput.$char('=')) { + op = '>='; + } + else { + op = '>'; + } + } + else if (parserInput.$char('<')) { + if (parserInput.$char('=')) { + op = '<='; + } + else { + op = '<'; + } + } + else if (parserInput.$char('=')) { + if (parserInput.$char('>')) { + op = '=>'; + } + else if (parserInput.$char('<')) { + op = '=<'; + } + else { + op = '='; + } + } + if (op) { + b = cond(); + if (b) { + c = new (tree.Condition)(op, a, b, index, false); + } + else { + error('expected expression'); + } + } + else { + c = new (tree.Condition)('=', a, new (tree.Keyword)('true'), index, false); + } + return c; + } + }, + // + // An operand is anything that can be part of an operation, + // such as a Color, or a Variable + // + operand: function () { + var entities = this.entities; + var negate; + if (parserInput.peek(/^-[@\$\(]/)) { + negate = parserInput.$char('-'); + } + var o = this.sub() || entities.dimension() || + entities.color() || entities.variable() || + entities.property() || entities.call() || + entities.quoted(true) || entities.colorKeyword() || + entities.mixinLookup(); + if (negate) { + o.parensInOp = true; + o = new (tree.Negative)(o); + } + return o; + }, + // + // Expressions either represent mathematical operations, + // or white-space delimited Entities. + // + // 1px solid black + // @var * 2 + // + expression: function () { + var entities = []; + var e; + var delim; + var index = parserInput.i; + do { + e = this.comment(); + if (e) { + entities.push(e); + continue; + } + e = this.addition() || this.entity(); + if (e instanceof tree.Comment) { + e = null; + } + if (e) { + entities.push(e); + // operations do not allow keyword "/" dimension (e.g. small/20px) so we support that here + if (!parserInput.peek(/^\/[\/*]/)) { + delim = parserInput.$char('/'); + if (delim) { + entities.push(new (tree.Anonymous)(delim, index)); + } + } + } + } while (e); + if (entities.length > 0) { + return new (tree.Expression)(entities); + } + }, + property: function () { + var name = parserInput.$re(/^(\*?-?[_a-zA-Z0-9-]+)\s*:/); + if (name) { + return name[1]; + } + }, + ruleProperty: function () { + var name = []; + var index = []; + var s; + var k; + parserInput.save(); + var simpleProperty = parserInput.$re(/^([_a-zA-Z0-9-]+)\s*:/); + if (simpleProperty) { + name = [new (tree.Keyword)(simpleProperty[1])]; + parserInput.forget(); + return name; + } + function match(re) { + var i = parserInput.i; + var chunk = parserInput.$re(re); + if (chunk) { + index.push(i); + return name.push(chunk[1]); + } + } + match(/^(\*?)/); + while (true) { + if (!match(/^((?:[\w-]+)|(?:[@\$]\{[\w-]+\}))/)) { + break; + } + } + if ((name.length > 1) && match(/^((?:\+_|\+)?)\s*:/)) { + parserInput.forget(); + // at last, we have the complete match now. move forward, + // convert name particles to tree objects and return: + if (name[0] === '') { + name.shift(); + index.shift(); + } + for (k = 0; k < name.length; k++) { + s = name[k]; + name[k] = (s.charAt(0) !== '@' && s.charAt(0) !== '$') ? + new (tree.Keyword)(s) : + (s.charAt(0) === '@' ? + new (tree.Variable)("@" + s.slice(2, -1), index[k], fileInfo) : + new (tree.Property)("$" + s.slice(2, -1), index[k], fileInfo)); + } + return name; + } + parserInput.restore(); + } + } + }; + }; + Parser.serializeVars = function (vars) { + var s = ''; + for (var name_1 in vars) { + if (Object.hasOwnProperty.call(vars, name_1)) { + var value = vars[name_1]; + s += ((name_1[0] === '@') ? '' : '@') + name_1 + ": " + value + ((String(value).slice(-1) === ';') ? '' : ';'); + } + } + return s; + }; - function boolean(condition) { - return condition ? Keyword.True : Keyword.False; - } - /** - * Functions with evalArgs set to false are sent context - * as the first argument. - */ - function If(context, condition, trueValue, falseValue) { - return condition.eval(context) ? trueValue.eval(context) - : (falseValue ? falseValue.eval(context) : new Anonymous); - } - If.evalArgs = false; - var boolean$1 = { boolean: boolean, 'if': If }; + function boolean(condition) { + return condition ? Keyword.True : Keyword.False; + } + /** + * Functions with evalArgs set to false are sent context + * as the first argument. + */ + function If(context, condition, trueValue, falseValue) { + return condition.eval(context) ? trueValue.eval(context) + : (falseValue ? falseValue.eval(context) : new Anonymous); + } + If.evalArgs = false; + function isdefined(context, variable) { + try { + variable.eval(context); + return Keyword.True; + } + catch (e) { + return Keyword.False; + } + } + isdefined.evalArgs = false; + var boolean$1 = { isdefined: isdefined, boolean: boolean, 'if': If }; - var colorFunctions; - function clamp$1(val) { - return Math.min(1, Math.max(0, val)); - } - function hsla(origColor, hsl) { - var color = colorFunctions.hsla(hsl.h, hsl.s, hsl.l, hsl.a); - if (color) { - if (origColor.value && - /^(rgb|hsl)/.test(origColor.value)) { - color.value = origColor.value; - } - else { - color.value = 'rgb'; - } - return color; - } - } - function toHSL(color) { - if (color.toHSL) { - return color.toHSL(); - } - else { - throw new Error('Argument cannot be evaluated to a color'); - } - } - function toHSV(color) { - if (color.toHSV) { - return color.toHSV(); - } - else { - throw new Error('Argument cannot be evaluated to a color'); - } - } - function number(n) { - if (n instanceof Dimension) { - return parseFloat(n.unit.is('%') ? n.value / 100 : n.value); - } - else if (typeof n === 'number') { - return n; - } - else { - throw { - type: 'Argument', - message: 'color functions take numbers as parameters' - }; - } - } - function scaled(n, size) { - if (n instanceof Dimension && n.unit.is('%')) { - return parseFloat(n.value * size / 100); - } - else { - return number(n); - } - } - colorFunctions = { - rgb: function (r, g, b) { - var color = colorFunctions.rgba(r, g, b, 1.0); - if (color) { - color.value = 'rgb'; - return color; - } - }, - rgba: function (r, g, b, a) { - try { - if (r instanceof Color) { - if (g) { - a = number(g); - } - else { - a = r.alpha; - } - return new Color(r.rgb, a, 'rgba'); - } - var rgb = [r, g, b].map(function (c) { return scaled(c, 255); }); - a = number(a); - return new Color(rgb, a, 'rgba'); - } - catch (e) { } - }, - hsl: function (h, s, l) { - var color = colorFunctions.hsla(h, s, l, 1.0); - if (color) { - color.value = 'hsl'; - return color; - } - }, - hsla: function (h, s, l, a) { - try { - if (h instanceof Color) { - if (s) { - a = number(s); - } - else { - a = h.alpha; - } - return new Color(h.rgb, a, 'hsla'); - } - var m1_1; - var m2_1; - function hue(h) { - h = h < 0 ? h + 1 : (h > 1 ? h - 1 : h); - if (h * 6 < 1) { - return m1_1 + (m2_1 - m1_1) * h * 6; - } - else if (h * 2 < 1) { - return m2_1; - } - else if (h * 3 < 2) { - return m1_1 + (m2_1 - m1_1) * (2 / 3 - h) * 6; - } - else { - return m1_1; - } - } - h = (number(h) % 360) / 360; - s = clamp$1(number(s)); - l = clamp$1(number(l)); - a = clamp$1(number(a)); - m2_1 = l <= 0.5 ? l * (s + 1) : l + s - l * s; - m1_1 = l * 2 - m2_1; - var rgb = [ - hue(h + 1 / 3) * 255, - hue(h) * 255, - hue(h - 1 / 3) * 255 - ]; - a = number(a); - return new Color(rgb, a, 'hsla'); - } - catch (e) { } - }, - hsv: function (h, s, v) { - return colorFunctions.hsva(h, s, v, 1.0); - }, - hsva: function (h, s, v, a) { - h = ((number(h) % 360) / 360) * 360; - s = number(s); - v = number(v); - a = number(a); - var i; - var f; - i = Math.floor((h / 60) % 6); - f = (h / 60) - i; - var vs = [v, - v * (1 - s), - v * (1 - f * s), - v * (1 - (1 - f) * s)]; - var perm = [[0, 3, 1], - [2, 0, 1], - [1, 0, 3], - [1, 2, 0], - [3, 1, 0], - [0, 1, 2]]; - return colorFunctions.rgba(vs[perm[i][0]] * 255, vs[perm[i][1]] * 255, vs[perm[i][2]] * 255, a); - }, - hue: function (color) { - return new Dimension(toHSL(color).h); - }, - saturation: function (color) { - return new Dimension(toHSL(color).s * 100, '%'); - }, - lightness: function (color) { - return new Dimension(toHSL(color).l * 100, '%'); - }, - hsvhue: function (color) { - return new Dimension(toHSV(color).h); - }, - hsvsaturation: function (color) { - return new Dimension(toHSV(color).s * 100, '%'); - }, - hsvvalue: function (color) { - return new Dimension(toHSV(color).v * 100, '%'); - }, - red: function (color) { - return new Dimension(color.rgb[0]); - }, - green: function (color) { - return new Dimension(color.rgb[1]); - }, - blue: function (color) { - return new Dimension(color.rgb[2]); - }, - alpha: function (color) { - return new Dimension(toHSL(color).a); - }, - luma: function (color) { - return new Dimension(color.luma() * color.alpha * 100, '%'); - }, - luminance: function (color) { - var luminance = (0.2126 * color.rgb[0] / 255) + - (0.7152 * color.rgb[1] / 255) + - (0.0722 * color.rgb[2] / 255); - return new Dimension(luminance * color.alpha * 100, '%'); - }, - saturate: function (color, amount, method) { - // filter: saturate(3.2); - // should be kept as is, so check for color - if (!color.rgb) { - return null; - } - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.s += hsl.s * amount.value / 100; - } - else { - hsl.s += amount.value / 100; - } - hsl.s = clamp$1(hsl.s); - return hsla(color, hsl); - }, - desaturate: function (color, amount, method) { - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.s -= hsl.s * amount.value / 100; - } - else { - hsl.s -= amount.value / 100; - } - hsl.s = clamp$1(hsl.s); - return hsla(color, hsl); - }, - lighten: function (color, amount, method) { - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.l += hsl.l * amount.value / 100; - } - else { - hsl.l += amount.value / 100; - } - hsl.l = clamp$1(hsl.l); - return hsla(color, hsl); - }, - darken: function (color, amount, method) { - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.l -= hsl.l * amount.value / 100; - } - else { - hsl.l -= amount.value / 100; - } - hsl.l = clamp$1(hsl.l); - return hsla(color, hsl); - }, - fadein: function (color, amount, method) { - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.a += hsl.a * amount.value / 100; - } - else { - hsl.a += amount.value / 100; - } - hsl.a = clamp$1(hsl.a); - return hsla(color, hsl); - }, - fadeout: function (color, amount, method) { - var hsl = toHSL(color); - if (typeof method !== 'undefined' && method.value === 'relative') { - hsl.a -= hsl.a * amount.value / 100; - } - else { - hsl.a -= amount.value / 100; - } - hsl.a = clamp$1(hsl.a); - return hsla(color, hsl); - }, - fade: function (color, amount) { - var hsl = toHSL(color); - hsl.a = amount.value / 100; - hsl.a = clamp$1(hsl.a); - return hsla(color, hsl); - }, - spin: function (color, amount) { - var hsl = toHSL(color); - var hue = (hsl.h + amount.value) % 360; - hsl.h = hue < 0 ? 360 + hue : hue; - return hsla(color, hsl); - }, - // - // Copyright (c) 2006-2009 Hampton Catlin, Natalie Weizenbaum, and Chris Eppstein - // http://sass-lang.com - // - mix: function (color1, color2, weight) { - if (!weight) { - weight = new Dimension(50); - } - var p = weight.value / 100.0; - var w = p * 2 - 1; - var a = toHSL(color1).a - toHSL(color2).a; - var w1 = (((w * a == -1) ? w : (w + a) / (1 + w * a)) + 1) / 2.0; - var w2 = 1 - w1; - var rgb = [color1.rgb[0] * w1 + color2.rgb[0] * w2, - color1.rgb[1] * w1 + color2.rgb[1] * w2, - color1.rgb[2] * w1 + color2.rgb[2] * w2]; - var alpha = color1.alpha * p + color2.alpha * (1 - p); - return new Color(rgb, alpha); - }, - greyscale: function (color) { - return colorFunctions.desaturate(color, new Dimension(100)); - }, - contrast: function (color, dark, light, threshold) { - // filter: contrast(3.2); - // should be kept as is, so check for color - if (!color.rgb) { - return null; - } - if (typeof light === 'undefined') { - light = colorFunctions.rgba(255, 255, 255, 1.0); - } - if (typeof dark === 'undefined') { - dark = colorFunctions.rgba(0, 0, 0, 1.0); - } - // Figure out which is actually light and dark: - if (dark.luma() > light.luma()) { - var t = light; - light = dark; - dark = t; - } - if (typeof threshold === 'undefined') { - threshold = 0.43; - } - else { - threshold = number(threshold); - } - if (color.luma() < threshold) { - return light; - } - else { - return dark; - } - }, - // Changes made in 2.7.0 - Reverted in 3.0.0 - // contrast: function (color, color1, color2, threshold) { - // // Return which of `color1` and `color2` has the greatest contrast with `color` - // // according to the standard WCAG contrast ratio calculation. - // // http://www.w3.org/TR/WCAG20/#contrast-ratiodef - // // The threshold param is no longer used, in line with SASS. - // // filter: contrast(3.2); - // // should be kept as is, so check for color - // if (!color.rgb) { - // return null; - // } - // if (typeof color1 === 'undefined') { - // color1 = colorFunctions.rgba(0, 0, 0, 1.0); - // } - // if (typeof color2 === 'undefined') { - // color2 = colorFunctions.rgba(255, 255, 255, 1.0); - // } - // var contrast1, contrast2; - // var luma = color.luma(); - // var luma1 = color1.luma(); - // var luma2 = color2.luma(); - // // Calculate contrast ratios for each color - // if (luma > luma1) { - // contrast1 = (luma + 0.05) / (luma1 + 0.05); - // } else { - // contrast1 = (luma1 + 0.05) / (luma + 0.05); - // } - // if (luma > luma2) { - // contrast2 = (luma + 0.05) / (luma2 + 0.05); - // } else { - // contrast2 = (luma2 + 0.05) / (luma + 0.05); - // } - // if (contrast1 > contrast2) { - // return color1; - // } else { - // return color2; - // } - // }, - argb: function (color) { - return new Anonymous(color.toARGB()); - }, - color: function (c) { - if ((c instanceof Quoted) && - (/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})$/i.test(c.value))) { - var val = c.value.slice(1); - return new Color(val, undefined, "#" + val); - } - if ((c instanceof Color) || (c = Color.fromKeyword(c.value))) { - c.value = undefined; - return c; - } - throw { - type: 'Argument', - message: 'argument must be a color keyword or 3|4|6|8 digit hex e.g. #FFF' - }; - }, - tint: function (color, amount) { - return colorFunctions.mix(colorFunctions.rgb(255, 255, 255), color, amount); - }, - shade: function (color, amount) { - return colorFunctions.mix(colorFunctions.rgb(0, 0, 0), color, amount); - } - }; - var color = colorFunctions; + var colorFunctions; + function clamp$1(val) { + return Math.min(1, Math.max(0, val)); + } + function hsla(origColor, hsl) { + var color = colorFunctions.hsla(hsl.h, hsl.s, hsl.l, hsl.a); + if (color) { + if (origColor.value && + /^(rgb|hsl)/.test(origColor.value)) { + color.value = origColor.value; + } + else { + color.value = 'rgb'; + } + return color; + } + } + function toHSL(color) { + if (color.toHSL) { + return color.toHSL(); + } + else { + throw new Error('Argument cannot be evaluated to a color'); + } + } + function toHSV(color) { + if (color.toHSV) { + return color.toHSV(); + } + else { + throw new Error('Argument cannot be evaluated to a color'); + } + } + function number(n) { + if (n instanceof Dimension) { + return parseFloat(n.unit.is('%') ? n.value / 100 : n.value); + } + else if (typeof n === 'number') { + return n; + } + else { + throw { + type: 'Argument', + message: 'color functions take numbers as parameters' + }; + } + } + function scaled(n, size) { + if (n instanceof Dimension && n.unit.is('%')) { + return parseFloat(n.value * size / 100); + } + else { + return number(n); + } + } + colorFunctions = { + rgb: function (r, g, b) { + var a = 1; + /** + * Comma-less syntax + * e.g. rgb(0 128 255 / 50%) + */ + if (r instanceof Expression) { + var val = r.value; + r = val[0]; + g = val[1]; + b = val[2]; + /** + * @todo - should this be normalized in + * function caller? Or parsed differently? + */ + if (b instanceof Operation) { + var op = b; + b = op.operands[0]; + a = op.operands[1]; + } + } + var color = colorFunctions.rgba(r, g, b, a); + if (color) { + color.value = 'rgb'; + return color; + } + }, + rgba: function (r, g, b, a) { + try { + if (r instanceof Color) { + if (g) { + a = number(g); + } + else { + a = r.alpha; + } + return new Color(r.rgb, a, 'rgba'); + } + var rgb = [r, g, b].map(function (c) { return scaled(c, 255); }); + a = number(a); + return new Color(rgb, a, 'rgba'); + } + catch (e) { } + }, + hsl: function (h, s, l) { + var a = 1; + if (h instanceof Expression) { + var val = h.value; + h = val[0]; + s = val[1]; + l = val[2]; + if (l instanceof Operation) { + var op = l; + l = op.operands[0]; + a = op.operands[1]; + } + } + var color = colorFunctions.hsla(h, s, l, a); + if (color) { + color.value = 'hsl'; + return color; + } + }, + hsla: function (h, s, l, a) { + try { + if (h instanceof Color) { + if (s) { + a = number(s); + } + else { + a = h.alpha; + } + return new Color(h.rgb, a, 'hsla'); + } + var m1_1; + var m2_1; + function hue(h) { + h = h < 0 ? h + 1 : (h > 1 ? h - 1 : h); + if (h * 6 < 1) { + return m1_1 + (m2_1 - m1_1) * h * 6; + } + else if (h * 2 < 1) { + return m2_1; + } + else if (h * 3 < 2) { + return m1_1 + (m2_1 - m1_1) * (2 / 3 - h) * 6; + } + else { + return m1_1; + } + } + h = (number(h) % 360) / 360; + s = clamp$1(number(s)); + l = clamp$1(number(l)); + a = clamp$1(number(a)); + m2_1 = l <= 0.5 ? l * (s + 1) : l + s - l * s; + m1_1 = l * 2 - m2_1; + var rgb = [ + hue(h + 1 / 3) * 255, + hue(h) * 255, + hue(h - 1 / 3) * 255 + ]; + a = number(a); + return new Color(rgb, a, 'hsla'); + } + catch (e) { } + }, + hsv: function (h, s, v) { + return colorFunctions.hsva(h, s, v, 1.0); + }, + hsva: function (h, s, v, a) { + h = ((number(h) % 360) / 360) * 360; + s = number(s); + v = number(v); + a = number(a); + var i; + var f; + i = Math.floor((h / 60) % 6); + f = (h / 60) - i; + var vs = [v, + v * (1 - s), + v * (1 - f * s), + v * (1 - (1 - f) * s)]; + var perm = [[0, 3, 1], + [2, 0, 1], + [1, 0, 3], + [1, 2, 0], + [3, 1, 0], + [0, 1, 2]]; + return colorFunctions.rgba(vs[perm[i][0]] * 255, vs[perm[i][1]] * 255, vs[perm[i][2]] * 255, a); + }, + hue: function (color) { + return new Dimension(toHSL(color).h); + }, + saturation: function (color) { + return new Dimension(toHSL(color).s * 100, '%'); + }, + lightness: function (color) { + return new Dimension(toHSL(color).l * 100, '%'); + }, + hsvhue: function (color) { + return new Dimension(toHSV(color).h); + }, + hsvsaturation: function (color) { + return new Dimension(toHSV(color).s * 100, '%'); + }, + hsvvalue: function (color) { + return new Dimension(toHSV(color).v * 100, '%'); + }, + red: function (color) { + return new Dimension(color.rgb[0]); + }, + green: function (color) { + return new Dimension(color.rgb[1]); + }, + blue: function (color) { + return new Dimension(color.rgb[2]); + }, + alpha: function (color) { + return new Dimension(toHSL(color).a); + }, + luma: function (color) { + return new Dimension(color.luma() * color.alpha * 100, '%'); + }, + luminance: function (color) { + var luminance = (0.2126 * color.rgb[0] / 255) + + (0.7152 * color.rgb[1] / 255) + + (0.0722 * color.rgb[2] / 255); + return new Dimension(luminance * color.alpha * 100, '%'); + }, + saturate: function (color, amount, method) { + // filter: saturate(3.2); + // should be kept as is, so check for color + if (!color.rgb) { + return null; + } + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.s += hsl.s * amount.value / 100; + } + else { + hsl.s += amount.value / 100; + } + hsl.s = clamp$1(hsl.s); + return hsla(color, hsl); + }, + desaturate: function (color, amount, method) { + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.s -= hsl.s * amount.value / 100; + } + else { + hsl.s -= amount.value / 100; + } + hsl.s = clamp$1(hsl.s); + return hsla(color, hsl); + }, + lighten: function (color, amount, method) { + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.l += hsl.l * amount.value / 100; + } + else { + hsl.l += amount.value / 100; + } + hsl.l = clamp$1(hsl.l); + return hsla(color, hsl); + }, + darken: function (color, amount, method) { + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.l -= hsl.l * amount.value / 100; + } + else { + hsl.l -= amount.value / 100; + } + hsl.l = clamp$1(hsl.l); + return hsla(color, hsl); + }, + fadein: function (color, amount, method) { + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.a += hsl.a * amount.value / 100; + } + else { + hsl.a += amount.value / 100; + } + hsl.a = clamp$1(hsl.a); + return hsla(color, hsl); + }, + fadeout: function (color, amount, method) { + var hsl = toHSL(color); + if (typeof method !== 'undefined' && method.value === 'relative') { + hsl.a -= hsl.a * amount.value / 100; + } + else { + hsl.a -= amount.value / 100; + } + hsl.a = clamp$1(hsl.a); + return hsla(color, hsl); + }, + fade: function (color, amount) { + var hsl = toHSL(color); + hsl.a = amount.value / 100; + hsl.a = clamp$1(hsl.a); + return hsla(color, hsl); + }, + spin: function (color, amount) { + var hsl = toHSL(color); + var hue = (hsl.h + amount.value) % 360; + hsl.h = hue < 0 ? 360 + hue : hue; + return hsla(color, hsl); + }, + // + // Copyright (c) 2006-2009 Hampton Catlin, Natalie Weizenbaum, and Chris Eppstein + // http://sass-lang.com + // + mix: function (color1, color2, weight) { + if (!weight) { + weight = new Dimension(50); + } + var p = weight.value / 100.0; + var w = p * 2 - 1; + var a = toHSL(color1).a - toHSL(color2).a; + var w1 = (((w * a == -1) ? w : (w + a) / (1 + w * a)) + 1) / 2.0; + var w2 = 1 - w1; + var rgb = [color1.rgb[0] * w1 + color2.rgb[0] * w2, + color1.rgb[1] * w1 + color2.rgb[1] * w2, + color1.rgb[2] * w1 + color2.rgb[2] * w2]; + var alpha = color1.alpha * p + color2.alpha * (1 - p); + return new Color(rgb, alpha); + }, + greyscale: function (color) { + return colorFunctions.desaturate(color, new Dimension(100)); + }, + contrast: function (color, dark, light, threshold) { + // filter: contrast(3.2); + // should be kept as is, so check for color + if (!color.rgb) { + return null; + } + if (typeof light === 'undefined') { + light = colorFunctions.rgba(255, 255, 255, 1.0); + } + if (typeof dark === 'undefined') { + dark = colorFunctions.rgba(0, 0, 0, 1.0); + } + // Figure out which is actually light and dark: + if (dark.luma() > light.luma()) { + var t = light; + light = dark; + dark = t; + } + if (typeof threshold === 'undefined') { + threshold = 0.43; + } + else { + threshold = number(threshold); + } + if (color.luma() < threshold) { + return light; + } + else { + return dark; + } + }, + // Changes made in 2.7.0 - Reverted in 3.0.0 + // contrast: function (color, color1, color2, threshold) { + // // Return which of `color1` and `color2` has the greatest contrast with `color` + // // according to the standard WCAG contrast ratio calculation. + // // http://www.w3.org/TR/WCAG20/#contrast-ratiodef + // // The threshold param is no longer used, in line with SASS. + // // filter: contrast(3.2); + // // should be kept as is, so check for color + // if (!color.rgb) { + // return null; + // } + // if (typeof color1 === 'undefined') { + // color1 = colorFunctions.rgba(0, 0, 0, 1.0); + // } + // if (typeof color2 === 'undefined') { + // color2 = colorFunctions.rgba(255, 255, 255, 1.0); + // } + // var contrast1, contrast2; + // var luma = color.luma(); + // var luma1 = color1.luma(); + // var luma2 = color2.luma(); + // // Calculate contrast ratios for each color + // if (luma > luma1) { + // contrast1 = (luma + 0.05) / (luma1 + 0.05); + // } else { + // contrast1 = (luma1 + 0.05) / (luma + 0.05); + // } + // if (luma > luma2) { + // contrast2 = (luma + 0.05) / (luma2 + 0.05); + // } else { + // contrast2 = (luma2 + 0.05) / (luma + 0.05); + // } + // if (contrast1 > contrast2) { + // return color1; + // } else { + // return color2; + // } + // }, + argb: function (color) { + return new Anonymous(color.toARGB()); + }, + color: function (c) { + if ((c instanceof Quoted) && + (/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})$/i.test(c.value))) { + var val = c.value.slice(1); + return new Color(val, undefined, "#" + val); + } + if ((c instanceof Color) || (c = Color.fromKeyword(c.value))) { + c.value = undefined; + return c; + } + throw { + type: 'Argument', + message: 'argument must be a color keyword or 3|4|6|8 digit hex e.g. #FFF' + }; + }, + tint: function (color, amount) { + return colorFunctions.mix(colorFunctions.rgb(255, 255, 255), color, amount); + }, + shade: function (color, amount) { + return colorFunctions.mix(colorFunctions.rgb(0, 0, 0), color, amount); + } + }; + var color = colorFunctions; - // Color Blending - // ref: http://www.w3.org/TR/compositing-1 - function colorBlend(mode, color1, color2) { - var ab = color1.alpha; // result - var // backdrop - cb; - var as = color2.alpha; - var // source - cs; - var ar; - var cr; - var r = []; - ar = as + ab * (1 - as); - for (var i = 0; i < 3; i++) { - cb = color1.rgb[i] / 255; - cs = color2.rgb[i] / 255; - cr = mode(cb, cs); - if (ar) { - cr = (as * cs + ab * (cb - - as * (cb + cs - cr))) / ar; - } - r[i] = cr * 255; - } - return new Color(r, ar); - } - var colorBlendModeFunctions = { - multiply: function (cb, cs) { - return cb * cs; - }, - screen: function (cb, cs) { - return cb + cs - cb * cs; - }, - overlay: function (cb, cs) { - cb *= 2; - return (cb <= 1) ? - colorBlendModeFunctions.multiply(cb, cs) : - colorBlendModeFunctions.screen(cb - 1, cs); - }, - softlight: function (cb, cs) { - var d = 1; - var e = cb; - if (cs > 0.5) { - e = 1; - d = (cb > 0.25) ? Math.sqrt(cb) - : ((16 * cb - 12) * cb + 4) * cb; - } - return cb - (1 - 2 * cs) * e * (d - cb); - }, - hardlight: function (cb, cs) { - return colorBlendModeFunctions.overlay(cs, cb); - }, - difference: function (cb, cs) { - return Math.abs(cb - cs); - }, - exclusion: function (cb, cs) { - return cb + cs - 2 * cb * cs; - }, - // non-w3c functions: - average: function (cb, cs) { - return (cb + cs) / 2; - }, - negation: function (cb, cs) { - return 1 - Math.abs(cb + cs - 1); - } - }; - for (var f in colorBlendModeFunctions) { - if (colorBlendModeFunctions.hasOwnProperty(f)) { - colorBlend[f] = colorBlend.bind(null, colorBlendModeFunctions[f]); - } - } + // Color Blending + // ref: http://www.w3.org/TR/compositing-1 + function colorBlend(mode, color1, color2) { + var ab = color1.alpha; // result + var // backdrop + cb; + var as = color2.alpha; + var // source + cs; + var ar; + var cr; + var r = []; + ar = as + ab * (1 - as); + for (var i = 0; i < 3; i++) { + cb = color1.rgb[i] / 255; + cs = color2.rgb[i] / 255; + cr = mode(cb, cs); + if (ar) { + cr = (as * cs + ab * (cb - + as * (cb + cs - cr))) / ar; + } + r[i] = cr * 255; + } + return new Color(r, ar); + } + var colorBlendModeFunctions = { + multiply: function (cb, cs) { + return cb * cs; + }, + screen: function (cb, cs) { + return cb + cs - cb * cs; + }, + overlay: function (cb, cs) { + cb *= 2; + return (cb <= 1) ? + colorBlendModeFunctions.multiply(cb, cs) : + colorBlendModeFunctions.screen(cb - 1, cs); + }, + softlight: function (cb, cs) { + var d = 1; + var e = cb; + if (cs > 0.5) { + e = 1; + d = (cb > 0.25) ? Math.sqrt(cb) + : ((16 * cb - 12) * cb + 4) * cb; + } + return cb - (1 - 2 * cs) * e * (d - cb); + }, + hardlight: function (cb, cs) { + return colorBlendModeFunctions.overlay(cs, cb); + }, + difference: function (cb, cs) { + return Math.abs(cb - cs); + }, + exclusion: function (cb, cs) { + return cb + cs - 2 * cb * cs; + }, + // non-w3c functions: + average: function (cb, cs) { + return (cb + cs) / 2; + }, + negation: function (cb, cs) { + return 1 - Math.abs(cb + cs - 1); + } + }; + for (var f in colorBlendModeFunctions) { + if (colorBlendModeFunctions.hasOwnProperty(f)) { + colorBlend[f] = colorBlend.bind(null, colorBlendModeFunctions[f]); + } + } - var dataUri = (function (environment) { - var fallback = function (functionThis, node) { return new URL(node, functionThis.index, functionThis.currentFileInfo).eval(functionThis.context); }; - return { 'data-uri': function (mimetypeNode, filePathNode) { - if (!filePathNode) { - filePathNode = mimetypeNode; - mimetypeNode = null; - } - var mimetype = mimetypeNode && mimetypeNode.value; - var filePath = filePathNode.value; - var currentFileInfo = this.currentFileInfo; - var currentDirectory = currentFileInfo.rewriteUrls ? - currentFileInfo.currentDirectory : currentFileInfo.entryPath; - var fragmentStart = filePath.indexOf('#'); - var fragment = ''; - if (fragmentStart !== -1) { - fragment = filePath.slice(fragmentStart); - filePath = filePath.slice(0, fragmentStart); - } - var context = clone(this.context); - context.rawBuffer = true; - var fileManager = environment.getFileManager(filePath, currentDirectory, context, environment, true); - if (!fileManager) { - return fallback(this, filePathNode); - } - var useBase64 = false; - // detect the mimetype if not given - if (!mimetypeNode) { - mimetype = environment.mimeLookup(filePath); - if (mimetype === 'image/svg+xml') { - useBase64 = false; - } - else { - // use base 64 unless it's an ASCII or UTF-8 format - var charset = environment.charsetLookup(mimetype); - useBase64 = ['US-ASCII', 'UTF-8'].indexOf(charset) < 0; - } - if (useBase64) { - mimetype += ';base64'; - } - } - else { - useBase64 = /;base64$/.test(mimetype); - } - var fileSync = fileManager.loadFileSync(filePath, currentDirectory, context, environment); - if (!fileSync.contents) { - logger.warn("Skipped data-uri embedding of " + filePath + " because file not found"); - return fallback(this, filePathNode || mimetypeNode); - } - var buf = fileSync.contents; - if (useBase64 && !environment.encodeBase64) { - return fallback(this, filePathNode); - } - buf = useBase64 ? environment.encodeBase64(buf) : encodeURIComponent(buf); - var uri = "data:" + mimetype + "," + buf + fragment; - return new URL(new Quoted("\"" + uri + "\"", uri, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo); - } }; - }); + var dataUri = (function (environment) { + var fallback = function (functionThis, node) { return new URL(node, functionThis.index, functionThis.currentFileInfo).eval(functionThis.context); }; + return { 'data-uri': function (mimetypeNode, filePathNode) { + if (!filePathNode) { + filePathNode = mimetypeNode; + mimetypeNode = null; + } + var mimetype = mimetypeNode && mimetypeNode.value; + var filePath = filePathNode.value; + var currentFileInfo = this.currentFileInfo; + var currentDirectory = currentFileInfo.rewriteUrls ? + currentFileInfo.currentDirectory : currentFileInfo.entryPath; + var fragmentStart = filePath.indexOf('#'); + var fragment = ''; + if (fragmentStart !== -1) { + fragment = filePath.slice(fragmentStart); + filePath = filePath.slice(0, fragmentStart); + } + var context = clone(this.context); + context.rawBuffer = true; + var fileManager = environment.getFileManager(filePath, currentDirectory, context, environment, true); + if (!fileManager) { + return fallback(this, filePathNode); + } + var useBase64 = false; + // detect the mimetype if not given + if (!mimetypeNode) { + mimetype = environment.mimeLookup(filePath); + if (mimetype === 'image/svg+xml') { + useBase64 = false; + } + else { + // use base 64 unless it's an ASCII or UTF-8 format + var charset = environment.charsetLookup(mimetype); + useBase64 = ['US-ASCII', 'UTF-8'].indexOf(charset) < 0; + } + if (useBase64) { + mimetype += ';base64'; + } + } + else { + useBase64 = /;base64$/.test(mimetype); + } + var fileSync = fileManager.loadFileSync(filePath, currentDirectory, context, environment); + if (!fileSync.contents) { + logger.warn("Skipped data-uri embedding of " + filePath + " because file not found"); + return fallback(this, filePathNode || mimetypeNode); + } + var buf = fileSync.contents; + if (useBase64 && !environment.encodeBase64) { + return fallback(this, filePathNode); + } + buf = useBase64 ? environment.encodeBase64(buf) : encodeURIComponent(buf); + var uri = "data:" + mimetype + "," + buf + fragment; + return new URL(new Quoted("\"" + uri + "\"", uri, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo); + } }; + }); - var getItemsFromNode = function (node) { - // handle non-array values as an array of length 1 - // return 'undefined' if index is invalid - var items = Array.isArray(node.value) ? - node.value : Array(node); - return items; - }; - var list = { - _SELF: function (n) { - return n; - }, - extract: function (values, index) { - // (1-based index) - index = index.value - 1; - return getItemsFromNode(values)[index]; - }, - length: function (values) { - return new Dimension(getItemsFromNode(values).length); - }, - /** - * Creates a Less list of incremental values. - * Modeled after Lodash's range function, also exists natively in PHP - * - * @param {Dimension} [start=1] - * @param {Dimension} end - e.g. 10 or 10px - unit is added to output - * @param {Dimension} [step=1] - */ - range: function (start, end, step) { - var from; - var to; - var stepValue = 1; - var list = []; - if (end) { - to = end; - from = start.value; - if (step) { - stepValue = step.value; - } - } - else { - from = 1; - to = start; - } - for (var i = from; i <= to.value; i += stepValue) { - list.push(new Dimension(i, to.unit)); - } - return new Expression(list); - }, - each: function (list, rs) { - var _this = this; - var rules = []; - var newRules; - var iterator; - var tryEval = function (val) { - if (val instanceof Node) { - return val.eval(_this.context); - } - return val; - }; - if (list.value && !(list instanceof Quoted)) { - if (Array.isArray(list.value)) { - iterator = list.value.map(tryEval); - } - else { - iterator = [tryEval(list.value)]; - } - } - else if (list.ruleset) { - iterator = tryEval(list.ruleset).rules; - } - else if (list.rules) { - iterator = list.rules.map(tryEval); - } - else if (Array.isArray(list)) { - iterator = list.map(tryEval); - } - else { - iterator = [tryEval(list)]; - } - var valueName = '@value'; - var keyName = '@key'; - var indexName = '@index'; - if (rs.params) { - valueName = rs.params[0] && rs.params[0].name; - keyName = rs.params[1] && rs.params[1].name; - indexName = rs.params[2] && rs.params[2].name; - rs = rs.rules; - } - else { - rs = rs.ruleset; - } - for (var i = 0; i < iterator.length; i++) { - var key = void 0; - var value = void 0; - var item = iterator[i]; - if (item instanceof Declaration) { - key = typeof item.name === 'string' ? item.name : item.name[0].value; - value = item.value; - } - else { - key = new Dimension(i + 1); - value = item; - } - if (item instanceof Comment) { - continue; - } - newRules = rs.rules.slice(0); - if (valueName) { - newRules.push(new Declaration(valueName, value, false, false, this.index, this.currentFileInfo)); - } - if (indexName) { - newRules.push(new Declaration(indexName, new Dimension(i + 1), false, false, this.index, this.currentFileInfo)); - } - if (keyName) { - newRules.push(new Declaration(keyName, key, false, false, this.index, this.currentFileInfo)); - } - rules.push(new Ruleset([new (Selector)([new Element("", '&')])], newRules, rs.strictImports, rs.visibilityInfo())); - } - return new Ruleset([new (Selector)([new Element("", '&')])], rules, rs.strictImports, rs.visibilityInfo()).eval(this.context); - } - }; + var getItemsFromNode = function (node) { + // handle non-array values as an array of length 1 + // return 'undefined' if index is invalid + var items = Array.isArray(node.value) ? + node.value : Array(node); + return items; + }; + var list = { + _SELF: function (n) { + return n; + }, + '~': function () { + var expr = []; + for (var _i = 0; _i < arguments.length; _i++) { + expr[_i] = arguments[_i]; + } + if (expr.length === 1) { + return expr[0]; + } + return new Value(expr); + }, + extract: function (values, index) { + // (1-based index) + index = index.value - 1; + return getItemsFromNode(values)[index]; + }, + length: function (values) { + return new Dimension(getItemsFromNode(values).length); + }, + /** + * Creates a Less list of incremental values. + * Modeled after Lodash's range function, also exists natively in PHP + * + * @param {Dimension} [start=1] + * @param {Dimension} end - e.g. 10 or 10px - unit is added to output + * @param {Dimension} [step=1] + */ + range: function (start, end, step) { + var from; + var to; + var stepValue = 1; + var list = []; + if (end) { + to = end; + from = start.value; + if (step) { + stepValue = step.value; + } + } + else { + from = 1; + to = start; + } + for (var i = from; i <= to.value; i += stepValue) { + list.push(new Dimension(i, to.unit)); + } + return new Expression(list); + }, + each: function (list, rs) { + var _this = this; + var rules = []; + var newRules; + var iterator; + var tryEval = function (val) { + if (val instanceof Node) { + return val.eval(_this.context); + } + return val; + }; + if (list.value && !(list instanceof Quoted)) { + if (Array.isArray(list.value)) { + iterator = list.value.map(tryEval); + } + else { + iterator = [tryEval(list.value)]; + } + } + else if (list.ruleset) { + iterator = tryEval(list.ruleset).rules; + } + else if (list.rules) { + iterator = list.rules.map(tryEval); + } + else if (Array.isArray(list)) { + iterator = list.map(tryEval); + } + else { + iterator = [tryEval(list)]; + } + var valueName = '@value'; + var keyName = '@key'; + var indexName = '@index'; + if (rs.params) { + valueName = rs.params[0] && rs.params[0].name; + keyName = rs.params[1] && rs.params[1].name; + indexName = rs.params[2] && rs.params[2].name; + rs = rs.rules; + } + else { + rs = rs.ruleset; + } + for (var i = 0; i < iterator.length; i++) { + var key = void 0; + var value = void 0; + var item = iterator[i]; + if (item instanceof Declaration) { + key = typeof item.name === 'string' ? item.name : item.name[0].value; + value = item.value; + } + else { + key = new Dimension(i + 1); + value = item; + } + if (item instanceof Comment) { + continue; + } + newRules = rs.rules.slice(0); + if (valueName) { + newRules.push(new Declaration(valueName, value, false, false, this.index, this.currentFileInfo)); + } + if (indexName) { + newRules.push(new Declaration(indexName, new Dimension(i + 1), false, false, this.index, this.currentFileInfo)); + } + if (keyName) { + newRules.push(new Declaration(keyName, key, false, false, this.index, this.currentFileInfo)); + } + rules.push(new Ruleset([new (Selector)([new Element("", '&')])], newRules, rs.strictImports, rs.visibilityInfo())); + } + return new Ruleset([new (Selector)([new Element("", '&')])], rules, rs.strictImports, rs.visibilityInfo()).eval(this.context); + } + }; - var MathHelper = function (fn, unit, n) { - if (!(n instanceof Dimension)) { - throw { type: 'Argument', message: 'argument must be a number' }; - } - if (unit == null) { - unit = n.unit; - } - else { - n = n.unify(); - } - return new Dimension(fn(parseFloat(n.value)), unit); - }; + var MathHelper = function (fn, unit, n) { + if (!(n instanceof Dimension)) { + throw { type: 'Argument', message: 'argument must be a number' }; + } + if (unit == null) { + unit = n.unit; + } + else { + n = n.unify(); + } + return new Dimension(fn(parseFloat(n.value)), unit); + }; - var mathFunctions = { - // name, unit - ceil: null, - floor: null, - sqrt: null, - abs: null, - tan: '', - sin: '', - cos: '', - atan: 'rad', - asin: 'rad', - acos: 'rad' - }; - for (var f$1 in mathFunctions) { - if (mathFunctions.hasOwnProperty(f$1)) { - mathFunctions[f$1] = MathHelper.bind(null, Math[f$1], mathFunctions[f$1]); - } - } - mathFunctions.round = function (n, f) { - var fraction = typeof f === 'undefined' ? 0 : f.value; - return MathHelper(function (num) { return num.toFixed(fraction); }, null, n); - }; + var mathFunctions = { + // name, unit + ceil: null, + floor: null, + sqrt: null, + abs: null, + tan: '', + sin: '', + cos: '', + atan: 'rad', + asin: 'rad', + acos: 'rad' + }; + for (var f$1 in mathFunctions) { + if (mathFunctions.hasOwnProperty(f$1)) { + mathFunctions[f$1] = MathHelper.bind(null, Math[f$1], mathFunctions[f$1]); + } + } + mathFunctions.round = function (n, f) { + var fraction = typeof f === 'undefined' ? 0 : f.value; + return MathHelper(function (num) { return num.toFixed(fraction); }, null, n); + }; - var minMax = function (isMin, args) { - args = Array.prototype.slice.call(args); - switch (args.length) { - case 0: throw { type: 'Argument', message: 'one or more arguments required' }; - } - var i; // key is the unit.toString() for unified Dimension values, - var j; - var current; - var currentUnified; - var referenceUnified; - var unit; - var unitStatic; - var unitClone; - var // elems only contains original argument values. - order = []; - var values = {}; - // value is the index into the order array. - for (i = 0; i < args.length; i++) { - current = args[i]; - if (!(current instanceof Dimension)) { - if (Array.isArray(args[i].value)) { - Array.prototype.push.apply(args, Array.prototype.slice.call(args[i].value)); - } - continue; - } - currentUnified = current.unit.toString() === '' && unitClone !== undefined ? new Dimension(current.value, unitClone).unify() : current.unify(); - unit = currentUnified.unit.toString() === '' && unitStatic !== undefined ? unitStatic : currentUnified.unit.toString(); - unitStatic = unit !== '' && unitStatic === undefined || unit !== '' && order[0].unify().unit.toString() === '' ? unit : unitStatic; - unitClone = unit !== '' && unitClone === undefined ? current.unit.toString() : unitClone; - j = values[''] !== undefined && unit !== '' && unit === unitStatic ? values[''] : values[unit]; - if (j === undefined) { - if (unitStatic !== undefined && unit !== unitStatic) { - throw { type: 'Argument', message: 'incompatible types' }; - } - values[unit] = order.length; - order.push(current); - continue; - } - referenceUnified = order[j].unit.toString() === '' && unitClone !== undefined ? new Dimension(order[j].value, unitClone).unify() : order[j].unify(); - if (isMin && currentUnified.value < referenceUnified.value || - !isMin && currentUnified.value > referenceUnified.value) { - order[j] = current; - } - } - if (order.length == 1) { - return order[0]; - } - args = order.map(function (a) { return a.toCSS(this.context); }).join(this.context.compress ? ',' : ', '); - return new Anonymous((isMin ? 'min' : 'max') + "(" + args + ")"); - }; - var number$1 = { - min: function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - return minMax(true, args); - }, - max: function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - return minMax(false, args); - }, - convert: function (val, unit) { - return val.convertTo(unit.value); - }, - pi: function () { - return new Dimension(Math.PI); - }, - mod: function (a, b) { - return new Dimension(a.value % b.value, a.unit); - }, - pow: function (x, y) { - if (typeof x === 'number' && typeof y === 'number') { - x = new Dimension(x); - y = new Dimension(y); - } - else if (!(x instanceof Dimension) || !(y instanceof Dimension)) { - throw { type: 'Argument', message: 'arguments must be numbers' }; - } - return new Dimension(Math.pow(x.value, y.value), x.unit); - }, - percentage: function (n) { - var result = MathHelper(function (num) { return num * 100; }, '%', n); - return result; - } - }; + var minMax = function (isMin, args) { + args = Array.prototype.slice.call(args); + switch (args.length) { + case 0: throw { type: 'Argument', message: 'one or more arguments required' }; + } + var i; // key is the unit.toString() for unified Dimension values, + var j; + var current; + var currentUnified; + var referenceUnified; + var unit; + var unitStatic; + var unitClone; + var // elems only contains original argument values. + order = []; + var values = {}; + // value is the index into the order array. + for (i = 0; i < args.length; i++) { + current = args[i]; + if (!(current instanceof Dimension)) { + if (Array.isArray(args[i].value)) { + Array.prototype.push.apply(args, Array.prototype.slice.call(args[i].value)); + } + continue; + } + currentUnified = current.unit.toString() === '' && unitClone !== undefined ? new Dimension(current.value, unitClone).unify() : current.unify(); + unit = currentUnified.unit.toString() === '' && unitStatic !== undefined ? unitStatic : currentUnified.unit.toString(); + unitStatic = unit !== '' && unitStatic === undefined || unit !== '' && order[0].unify().unit.toString() === '' ? unit : unitStatic; + unitClone = unit !== '' && unitClone === undefined ? current.unit.toString() : unitClone; + j = values[''] !== undefined && unit !== '' && unit === unitStatic ? values[''] : values[unit]; + if (j === undefined) { + if (unitStatic !== undefined && unit !== unitStatic) { + throw { type: 'Argument', message: 'incompatible types' }; + } + values[unit] = order.length; + order.push(current); + continue; + } + referenceUnified = order[j].unit.toString() === '' && unitClone !== undefined ? new Dimension(order[j].value, unitClone).unify() : order[j].unify(); + if (isMin && currentUnified.value < referenceUnified.value || + !isMin && currentUnified.value > referenceUnified.value) { + order[j] = current; + } + } + if (order.length == 1) { + return order[0]; + } + args = order.map(function (a) { return a.toCSS(this.context); }).join(this.context.compress ? ',' : ', '); + return new Anonymous((isMin ? 'min' : 'max') + "(" + args + ")"); + }; + var number$1 = { + min: function () { + var args = []; + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + try { + return minMax(true, args); + } + catch (e) { } + }, + max: function () { + var args = []; + for (var _i = 0; _i < arguments.length; _i++) { + args[_i] = arguments[_i]; + } + try { + return minMax(false, args); + } + catch (e) { } + }, + convert: function (val, unit) { + return val.convertTo(unit.value); + }, + pi: function () { + return new Dimension(Math.PI); + }, + mod: function (a, b) { + return new Dimension(a.value % b.value, a.unit); + }, + pow: function (x, y) { + if (typeof x === 'number' && typeof y === 'number') { + x = new Dimension(x); + y = new Dimension(y); + } + else if (!(x instanceof Dimension) || !(y instanceof Dimension)) { + throw { type: 'Argument', message: 'arguments must be numbers' }; + } + return new Dimension(Math.pow(x.value, y.value), x.unit); + }, + percentage: function (n) { + var result = MathHelper(function (num) { return num * 100; }, '%', n); + return result; + } + }; - var string = { - e: function (str) { - return new Quoted('"', str instanceof JavaScript ? str.evaluated : str.value, true); - }, - escape: function (str) { - return new Anonymous(encodeURI(str.value).replace(/=/g, '%3D').replace(/:/g, '%3A').replace(/#/g, '%23').replace(/;/g, '%3B') - .replace(/\(/g, '%28').replace(/\)/g, '%29')); - }, - replace: function (string, pattern, replacement, flags) { - var result = string.value; - replacement = (replacement.type === 'Quoted') ? - replacement.value : replacement.toCSS(); - result = result.replace(new RegExp(pattern.value, flags ? flags.value : ''), replacement); - return new Quoted(string.quote || '', result, string.escaped); - }, - '%': function (string /* arg, arg, ... */) { - var args = Array.prototype.slice.call(arguments, 1); - var result = string.value; - var _loop_1 = function (i) { - /* jshint loopfunc:true */ - result = result.replace(/%[sda]/i, function (token) { - var value = ((args[i].type === 'Quoted') && - token.match(/s/i)) ? args[i].value : args[i].toCSS(); - return token.match(/[A-Z]$/) ? encodeURIComponent(value) : value; - }); - }; - for (var i = 0; i < args.length; i++) { - _loop_1(i); - } - result = result.replace(/%%/g, '%'); - return new Quoted(string.quote || '', result, string.escaped); - } - }; + var string = { + e: function (str) { + return new Quoted('"', str instanceof JavaScript ? str.evaluated : str.value, true); + }, + escape: function (str) { + return new Anonymous(encodeURI(str.value).replace(/=/g, '%3D').replace(/:/g, '%3A').replace(/#/g, '%23').replace(/;/g, '%3B') + .replace(/\(/g, '%28').replace(/\)/g, '%29')); + }, + replace: function (string, pattern, replacement, flags) { + var result = string.value; + replacement = (replacement.type === 'Quoted') ? + replacement.value : replacement.toCSS(); + result = result.replace(new RegExp(pattern.value, flags ? flags.value : ''), replacement); + return new Quoted(string.quote || '', result, string.escaped); + }, + '%': function (string /* arg, arg, ... */) { + var args = Array.prototype.slice.call(arguments, 1); + var result = string.value; + var _loop_1 = function (i) { + /* jshint loopfunc:true */ + result = result.replace(/%[sda]/i, function (token) { + var value = ((args[i].type === 'Quoted') && + token.match(/s/i)) ? args[i].value : args[i].toCSS(); + return token.match(/[A-Z]$/) ? encodeURIComponent(value) : value; + }); + }; + for (var i = 0; i < args.length; i++) { + _loop_1(i); + } + result = result.replace(/%%/g, '%'); + return new Quoted(string.quote || '', result, string.escaped); + } + }; - var svg = (function (environment) { - return { 'svg-gradient': function (direction) { - var stops; - var gradientDirectionSvg; - var gradientType = 'linear'; - var rectangleDimension = 'x="0" y="0" width="1" height="1"'; - var renderEnv = { compress: false }; - var returner; - var directionValue = direction.toCSS(renderEnv); - var i; - var color; - var position; - var positionValue; - var alpha; - function throwArgumentDescriptor() { - throw { type: 'Argument', - message: 'svg-gradient expects direction, start_color [start_position], [color position,]...,' + - ' end_color [end_position] or direction, color list' }; - } - if (arguments.length == 2) { - if (arguments[1].value.length < 2) { - throwArgumentDescriptor(); - } - stops = arguments[1].value; - } - else if (arguments.length < 3) { - throwArgumentDescriptor(); - } - else { - stops = Array.prototype.slice.call(arguments, 1); - } - switch (directionValue) { - case 'to bottom': - gradientDirectionSvg = 'x1="0%" y1="0%" x2="0%" y2="100%"'; - break; - case 'to right': - gradientDirectionSvg = 'x1="0%" y1="0%" x2="100%" y2="0%"'; - break; - case 'to bottom right': - gradientDirectionSvg = 'x1="0%" y1="0%" x2="100%" y2="100%"'; - break; - case 'to top right': - gradientDirectionSvg = 'x1="0%" y1="100%" x2="100%" y2="0%"'; - break; - case 'ellipse': - case 'ellipse at center': - gradientType = 'radial'; - gradientDirectionSvg = 'cx="50%" cy="50%" r="75%"'; - rectangleDimension = 'x="-50" y="-50" width="101" height="101"'; - break; - default: - throw { type: 'Argument', message: 'svg-gradient direction must be \'to bottom\', \'to right\',' + - ' \'to bottom right\', \'to top right\' or \'ellipse at center\'' }; - } - returner = "<" + gradientType + "Gradient id=\"g\" " + gradientDirectionSvg + ">"; - for (i = 0; i < stops.length; i += 1) { - if (stops[i] instanceof Expression) { - color = stops[i].value[0]; - position = stops[i].value[1]; - } - else { - color = stops[i]; - position = undefined; - } - if (!(color instanceof Color) || (!((i === 0 || i + 1 === stops.length) && position === undefined) && !(position instanceof Dimension))) { - throwArgumentDescriptor(); - } - positionValue = position ? position.toCSS(renderEnv) : i === 0 ? '0%' : '100%'; - alpha = color.alpha; - returner += ""; - } - returner += ""; - returner = encodeURIComponent(returner); - returner = "data:image/svg+xml," + returner; - return new URL(new Quoted("'" + returner + "'", returner, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo); - } }; - }); + var svg = (function (environment) { + return { 'svg-gradient': function (direction) { + var stops; + var gradientDirectionSvg; + var gradientType = 'linear'; + var rectangleDimension = 'x="0" y="0" width="1" height="1"'; + var renderEnv = { compress: false }; + var returner; + var directionValue = direction.toCSS(renderEnv); + var i; + var color; + var position; + var positionValue; + var alpha; + function throwArgumentDescriptor() { + throw { type: 'Argument', + message: 'svg-gradient expects direction, start_color [start_position], [color position,]...,' + + ' end_color [end_position] or direction, color list' }; + } + if (arguments.length == 2) { + if (arguments[1].value.length < 2) { + throwArgumentDescriptor(); + } + stops = arguments[1].value; + } + else if (arguments.length < 3) { + throwArgumentDescriptor(); + } + else { + stops = Array.prototype.slice.call(arguments, 1); + } + switch (directionValue) { + case 'to bottom': + gradientDirectionSvg = 'x1="0%" y1="0%" x2="0%" y2="100%"'; + break; + case 'to right': + gradientDirectionSvg = 'x1="0%" y1="0%" x2="100%" y2="0%"'; + break; + case 'to bottom right': + gradientDirectionSvg = 'x1="0%" y1="0%" x2="100%" y2="100%"'; + break; + case 'to top right': + gradientDirectionSvg = 'x1="0%" y1="100%" x2="100%" y2="0%"'; + break; + case 'ellipse': + case 'ellipse at center': + gradientType = 'radial'; + gradientDirectionSvg = 'cx="50%" cy="50%" r="75%"'; + rectangleDimension = 'x="-50" y="-50" width="101" height="101"'; + break; + default: + throw { type: 'Argument', message: 'svg-gradient direction must be \'to bottom\', \'to right\',' + + ' \'to bottom right\', \'to top right\' or \'ellipse at center\'' }; + } + returner = "<" + gradientType + "Gradient id=\"g\" " + gradientDirectionSvg + ">"; + for (i = 0; i < stops.length; i += 1) { + if (stops[i] instanceof Expression) { + color = stops[i].value[0]; + position = stops[i].value[1]; + } + else { + color = stops[i]; + position = undefined; + } + if (!(color instanceof Color) || (!((i === 0 || i + 1 === stops.length) && position === undefined) && !(position instanceof Dimension))) { + throwArgumentDescriptor(); + } + positionValue = position ? position.toCSS(renderEnv) : i === 0 ? '0%' : '100%'; + alpha = color.alpha; + returner += ""; + } + returner += ""; + returner = encodeURIComponent(returner); + returner = "data:image/svg+xml," + returner; + return new URL(new Quoted("'" + returner + "'", returner, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo); + } }; + }); - var isa = function (n, Type) { return (n instanceof Type) ? Keyword.True : Keyword.False; }; - var isunit = function (n, unit) { - if (unit === undefined) { - throw { type: 'Argument', message: 'missing the required second argument to isunit.' }; - } - unit = typeof unit.value === 'string' ? unit.value : unit; - if (typeof unit !== 'string') { - throw { type: 'Argument', message: 'Second argument to isunit should be a unit or a string.' }; - } - return (n instanceof Dimension) && n.unit.is(unit) ? Keyword.True : Keyword.False; - }; - var types = { - isruleset: function (n) { - return isa(n, DetachedRuleset); - }, - iscolor: function (n) { - return isa(n, Color); - }, - isnumber: function (n) { - return isa(n, Dimension); - }, - isstring: function (n) { - return isa(n, Quoted); - }, - iskeyword: function (n) { - return isa(n, Keyword); - }, - isurl: function (n) { - return isa(n, URL); - }, - ispixel: function (n) { - return isunit(n, 'px'); - }, - ispercentage: function (n) { - return isunit(n, '%'); - }, - isem: function (n) { - return isunit(n, 'em'); - }, - isunit: isunit, - unit: function (val, unit) { - if (!(val instanceof Dimension)) { - throw { type: 'Argument', message: "the first argument to unit must be a number" + (val instanceof Operation ? '. Have you forgotten parenthesis?' : '') }; - } - if (unit) { - if (unit instanceof Keyword) { - unit = unit.value; - } - else { - unit = unit.toCSS(); - } - } - else { - unit = ''; - } - return new Dimension(val.value, unit); - }, - 'get-unit': function (n) { - return new Anonymous(n.unit); - } - }; + var isa = function (n, Type) { return (n instanceof Type) ? Keyword.True : Keyword.False; }; + var isunit = function (n, unit) { + if (unit === undefined) { + throw { type: 'Argument', message: 'missing the required second argument to isunit.' }; + } + unit = typeof unit.value === 'string' ? unit.value : unit; + if (typeof unit !== 'string') { + throw { type: 'Argument', message: 'Second argument to isunit should be a unit or a string.' }; + } + return (n instanceof Dimension) && n.unit.is(unit) ? Keyword.True : Keyword.False; + }; + var types = { + isruleset: function (n) { + return isa(n, DetachedRuleset); + }, + iscolor: function (n) { + return isa(n, Color); + }, + isnumber: function (n) { + return isa(n, Dimension); + }, + isstring: function (n) { + return isa(n, Quoted); + }, + iskeyword: function (n) { + return isa(n, Keyword); + }, + isurl: function (n) { + return isa(n, URL); + }, + ispixel: function (n) { + return isunit(n, 'px'); + }, + ispercentage: function (n) { + return isunit(n, '%'); + }, + isem: function (n) { + return isunit(n, 'em'); + }, + isunit: isunit, + unit: function (val, unit) { + if (!(val instanceof Dimension)) { + throw { type: 'Argument', message: "the first argument to unit must be a number" + (val instanceof Operation ? '. Have you forgotten parenthesis?' : '') }; + } + if (unit) { + if (unit instanceof Keyword) { + unit = unit.value; + } + else { + unit = unit.toCSS(); + } + } + else { + unit = ''; + } + return new Dimension(val.value, unit); + }, + 'get-unit': function (n) { + return new Anonymous(n.unit); + } + }; - var Functions = (function (environment) { - var functions = { functionRegistry: functionRegistry, functionCaller: functionCaller }; - // register functions - functionRegistry.addMultiple(boolean$1); - functionRegistry.add('default', defaultFunc.eval.bind(defaultFunc)); - functionRegistry.addMultiple(color); - functionRegistry.addMultiple(colorBlend); - functionRegistry.addMultiple(dataUri(environment)); - functionRegistry.addMultiple(list); - functionRegistry.addMultiple(mathFunctions); - functionRegistry.addMultiple(number$1); - functionRegistry.addMultiple(string); - functionRegistry.addMultiple(svg()); - functionRegistry.addMultiple(types); - return functions; - }); + var functions = (function (environment) { + var functions = { functionRegistry: functionRegistry, functionCaller: functionCaller }; + // register functions + functionRegistry.addMultiple(boolean$1); + functionRegistry.add('default', defaultFunc.eval.bind(defaultFunc)); + functionRegistry.addMultiple(color); + functionRegistry.addMultiple(colorBlend); + functionRegistry.addMultiple(dataUri(environment)); + functionRegistry.addMultiple(list); + functionRegistry.addMultiple(mathFunctions); + functionRegistry.addMultiple(number$1); + functionRegistry.addMultiple(string); + functionRegistry.addMultiple(svg()); + functionRegistry.addMultiple(types); + return functions; + }); - var sourceMapOutput = (function (environment) { - var SourceMapOutput = /** @class */ (function () { - function SourceMapOutput(options) { - this._css = []; - this._rootNode = options.rootNode; - this._contentsMap = options.contentsMap; - this._contentsIgnoredCharsMap = options.contentsIgnoredCharsMap; - if (options.sourceMapFilename) { - this._sourceMapFilename = options.sourceMapFilename.replace(/\\/g, '/'); - } - this._outputFilename = options.outputFilename; - this.sourceMapURL = options.sourceMapURL; - if (options.sourceMapBasepath) { - this._sourceMapBasepath = options.sourceMapBasepath.replace(/\\/g, '/'); - } - if (options.sourceMapRootpath) { - this._sourceMapRootpath = options.sourceMapRootpath.replace(/\\/g, '/'); - if (this._sourceMapRootpath.charAt(this._sourceMapRootpath.length - 1) !== '/') { - this._sourceMapRootpath += '/'; - } - } - else { - this._sourceMapRootpath = ''; - } - this._outputSourceFiles = options.outputSourceFiles; - this._sourceMapGeneratorConstructor = environment.getSourceMapGenerator(); - this._lineNumber = 0; - this._column = 0; - } - SourceMapOutput.prototype.removeBasepath = function (path) { - if (this._sourceMapBasepath && path.indexOf(this._sourceMapBasepath) === 0) { - path = path.substring(this._sourceMapBasepath.length); - if (path.charAt(0) === '\\' || path.charAt(0) === '/') { - path = path.substring(1); - } - } - return path; - }; - SourceMapOutput.prototype.normalizeFilename = function (filename) { - filename = filename.replace(/\\/g, '/'); - filename = this.removeBasepath(filename); - return (this._sourceMapRootpath || '') + filename; - }; - SourceMapOutput.prototype.add = function (chunk, fileInfo, index, mapLines) { - // ignore adding empty strings - if (!chunk) { - return; - } - var lines; - var sourceLines; - var columns; - var sourceColumns; - var i; - if (fileInfo && fileInfo.filename) { - var inputSource = this._contentsMap[fileInfo.filename]; - // remove vars/banner added to the top of the file - if (this._contentsIgnoredCharsMap[fileInfo.filename]) { - // adjust the index - index -= this._contentsIgnoredCharsMap[fileInfo.filename]; - if (index < 0) { - index = 0; - } - // adjust the source - inputSource = inputSource.slice(this._contentsIgnoredCharsMap[fileInfo.filename]); - } - /** - * ignore empty content, or failsafe - * if contents map is incorrect - */ - if (inputSource === undefined) { - this._css.push(chunk); - return; - } - inputSource = inputSource.substring(0, index); - sourceLines = inputSource.split('\n'); - sourceColumns = sourceLines[sourceLines.length - 1]; - } - lines = chunk.split('\n'); - columns = lines[lines.length - 1]; - if (fileInfo && fileInfo.filename) { - if (!mapLines) { - this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + 1, column: this._column }, - original: { line: sourceLines.length, column: sourceColumns.length }, - source: this.normalizeFilename(fileInfo.filename) }); - } - else { - for (i = 0; i < lines.length; i++) { - this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + i + 1, column: i === 0 ? this._column : 0 }, - original: { line: sourceLines.length + i, column: i === 0 ? sourceColumns.length : 0 }, - source: this.normalizeFilename(fileInfo.filename) }); - } - } - } - if (lines.length === 1) { - this._column += columns.length; - } - else { - this._lineNumber += lines.length - 1; - this._column = columns.length; - } - this._css.push(chunk); - }; - SourceMapOutput.prototype.isEmpty = function () { - return this._css.length === 0; - }; - SourceMapOutput.prototype.toCSS = function (context) { - this._sourceMapGenerator = new this._sourceMapGeneratorConstructor({ file: this._outputFilename, sourceRoot: null }); - if (this._outputSourceFiles) { - for (var filename in this._contentsMap) { - if (this._contentsMap.hasOwnProperty(filename)) { - var source = this._contentsMap[filename]; - if (this._contentsIgnoredCharsMap[filename]) { - source = source.slice(this._contentsIgnoredCharsMap[filename]); - } - this._sourceMapGenerator.setSourceContent(this.normalizeFilename(filename), source); - } - } - } - this._rootNode.genCSS(context, this); - if (this._css.length > 0) { - var sourceMapURL = void 0; - var sourceMapContent = JSON.stringify(this._sourceMapGenerator.toJSON()); - if (this.sourceMapURL) { - sourceMapURL = this.sourceMapURL; - } - else if (this._sourceMapFilename) { - sourceMapURL = this._sourceMapFilename; - } - this.sourceMapURL = sourceMapURL; - this.sourceMap = sourceMapContent; - } - return this._css.join(''); - }; - return SourceMapOutput; - }()); - return SourceMapOutput; - }); + function transformTree (root, options) { + options = options || {}; + var evaldRoot; + var variables = options.variables; + var evalEnv = new contexts.Eval(options); + // + // Allows setting variables with a hash, so: + // + // `{ color: new tree.Color('#f01') }` will become: + // + // new tree.Declaration('@color', + // new tree.Value([ + // new tree.Expression([ + // new tree.Color('#f01') + // ]) + // ]) + // ) + // + if (typeof variables === 'object' && !Array.isArray(variables)) { + variables = Object.keys(variables).map(function (k) { + var value = variables[k]; + if (!(value instanceof tree.Value)) { + if (!(value instanceof tree.Expression)) { + value = new tree.Expression([value]); + } + value = new tree.Value([value]); + } + return new tree.Declaration("@" + k, value, false, null, 0); + }); + evalEnv.frames = [new tree.Ruleset(null, variables)]; + } + var visitors$1 = [ + new visitors.JoinSelectorVisitor(), + new visitors.MarkVisibleSelectorsVisitor(true), + new visitors.ExtendVisitor(), + new visitors.ToCSSVisitor({ compress: Boolean(options.compress) }) + ]; + var preEvalVisitors = []; + var v; + var visitorIterator; + /** + * first() / get() allows visitors to be added while visiting + * + * @todo Add scoping for visitors just like functions for @plugin; right now they're global + */ + if (options.pluginManager) { + visitorIterator = options.pluginManager.visitor(); + for (var i = 0; i < 2; i++) { + visitorIterator.first(); + while ((v = visitorIterator.get())) { + if (v.isPreEvalVisitor) { + if (i === 0 || preEvalVisitors.indexOf(v) === -1) { + preEvalVisitors.push(v); + v.run(root); + } + } + else { + if (i === 0 || visitors$1.indexOf(v) === -1) { + if (v.isPreVisitor) { + visitors$1.unshift(v); + } + else { + visitors$1.push(v); + } + } + } + } + } + } + evaldRoot = root.eval(evalEnv); + for (var i = 0; i < visitors$1.length; i++) { + visitors$1[i].run(evaldRoot); + } + // Run any remaining visitors added after eval pass + if (options.pluginManager) { + visitorIterator.first(); + while ((v = visitorIterator.get())) { + if (visitors$1.indexOf(v) === -1 && preEvalVisitors.indexOf(v) === -1) { + v.run(evaldRoot); + } + } + } + return evaldRoot; + } - var sourceMapBuilder = (function (SourceMapOutput, environment) { - var SourceMapBuilder = /** @class */ (function () { - function SourceMapBuilder(options) { - this.options = options; - } - SourceMapBuilder.prototype.toCSS = function (rootNode, options, imports) { - var sourceMapOutput = new SourceMapOutput({ - contentsIgnoredCharsMap: imports.contentsIgnoredChars, - rootNode: rootNode, - contentsMap: imports.contents, - sourceMapFilename: this.options.sourceMapFilename, - sourceMapURL: this.options.sourceMapURL, - outputFilename: this.options.sourceMapOutputFilename, - sourceMapBasepath: this.options.sourceMapBasepath, - sourceMapRootpath: this.options.sourceMapRootpath, - outputSourceFiles: this.options.outputSourceFiles, - sourceMapGenerator: this.options.sourceMapGenerator, - sourceMapFileInline: this.options.sourceMapFileInline, - disableSourcemapAnnotation: this.options.disableSourcemapAnnotation - }); - var css = sourceMapOutput.toCSS(options); - this.sourceMap = sourceMapOutput.sourceMap; - this.sourceMapURL = sourceMapOutput.sourceMapURL; - if (this.options.sourceMapInputFilename) { - this.sourceMapInputFilename = sourceMapOutput.normalizeFilename(this.options.sourceMapInputFilename); - } - if (this.options.sourceMapBasepath !== undefined && this.sourceMapURL !== undefined) { - this.sourceMapURL = sourceMapOutput.removeBasepath(this.sourceMapURL); - } - return css + this.getCSSAppendage(); - }; - SourceMapBuilder.prototype.getCSSAppendage = function () { - var sourceMapURL = this.sourceMapURL; - if (this.options.sourceMapFileInline) { - if (this.sourceMap === undefined) { - return ''; - } - sourceMapURL = "data:application/json;base64," + environment.encodeBase64(this.sourceMap); - } - if (this.options.disableSourcemapAnnotation) { - return ''; - } - if (sourceMapURL) { - return "/*# sourceMappingURL=" + sourceMapURL + " */"; - } - return ''; - }; - SourceMapBuilder.prototype.getExternalSourceMap = function () { - return this.sourceMap; - }; - SourceMapBuilder.prototype.setExternalSourceMap = function (sourceMap) { - this.sourceMap = sourceMap; - }; - SourceMapBuilder.prototype.isInline = function () { - return this.options.sourceMapFileInline; - }; - SourceMapBuilder.prototype.getSourceMapURL = function () { - return this.sourceMapURL; - }; - SourceMapBuilder.prototype.getOutputFilename = function () { - return this.options.sourceMapOutputFilename; - }; - SourceMapBuilder.prototype.getInputFilename = function () { - return this.sourceMapInputFilename; - }; - return SourceMapBuilder; - }()); - return SourceMapBuilder; - }); + /** + * Plugin Manager + */ + var PluginManager = /** @class */ (function () { + function PluginManager(less) { + this.less = less; + this.visitors = []; + this.preProcessors = []; + this.postProcessors = []; + this.installedPlugins = []; + this.fileManagers = []; + this.iterator = -1; + this.pluginCache = {}; + this.Loader = new less.PluginLoader(less); + } + /** + * Adds all the plugins in the array + * @param {Array} plugins + */ + PluginManager.prototype.addPlugins = function (plugins) { + if (plugins) { + for (var i = 0; i < plugins.length; i++) { + this.addPlugin(plugins[i]); + } + } + }; + /** + * + * @param plugin + * @param {String} filename + */ + PluginManager.prototype.addPlugin = function (plugin, filename, functionRegistry) { + this.installedPlugins.push(plugin); + if (filename) { + this.pluginCache[filename] = plugin; + } + if (plugin.install) { + plugin.install(this.less, this, functionRegistry || this.less.functions.functionRegistry); + } + }; + /** + * + * @param filename + */ + PluginManager.prototype.get = function (filename) { + return this.pluginCache[filename]; + }; + /** + * Adds a visitor. The visitor object has options on itself to determine + * when it should run. + * @param visitor + */ + PluginManager.prototype.addVisitor = function (visitor) { + this.visitors.push(visitor); + }; + /** + * Adds a pre processor object + * @param {object} preProcessor + * @param {number} priority - guidelines 1 = before import, 1000 = import, 2000 = after import + */ + PluginManager.prototype.addPreProcessor = function (preProcessor, priority) { + var indexToInsertAt; + for (indexToInsertAt = 0; indexToInsertAt < this.preProcessors.length; indexToInsertAt++) { + if (this.preProcessors[indexToInsertAt].priority >= priority) { + break; + } + } + this.preProcessors.splice(indexToInsertAt, 0, { preProcessor: preProcessor, priority: priority }); + }; + /** + * Adds a post processor object + * @param {object} postProcessor + * @param {number} priority - guidelines 1 = before compression, 1000 = compression, 2000 = after compression + */ + PluginManager.prototype.addPostProcessor = function (postProcessor, priority) { + var indexToInsertAt; + for (indexToInsertAt = 0; indexToInsertAt < this.postProcessors.length; indexToInsertAt++) { + if (this.postProcessors[indexToInsertAt].priority >= priority) { + break; + } + } + this.postProcessors.splice(indexToInsertAt, 0, { postProcessor: postProcessor, priority: priority }); + }; + /** + * + * @param manager + */ + PluginManager.prototype.addFileManager = function (manager) { + this.fileManagers.push(manager); + }; + /** + * + * @returns {Array} + * @private + */ + PluginManager.prototype.getPreProcessors = function () { + var preProcessors = []; + for (var i = 0; i < this.preProcessors.length; i++) { + preProcessors.push(this.preProcessors[i].preProcessor); + } + return preProcessors; + }; + /** + * + * @returns {Array} + * @private + */ + PluginManager.prototype.getPostProcessors = function () { + var postProcessors = []; + for (var i = 0; i < this.postProcessors.length; i++) { + postProcessors.push(this.postProcessors[i].postProcessor); + } + return postProcessors; + }; + /** + * + * @returns {Array} + * @private + */ + PluginManager.prototype.getVisitors = function () { + return this.visitors; + }; + PluginManager.prototype.visitor = function () { + var self = this; + return { + first: function () { + self.iterator = -1; + return self.visitors[self.iterator]; + }, + get: function () { + self.iterator += 1; + return self.visitors[self.iterator]; + } + }; + }; + /** + * + * @returns {Array} + * @private + */ + PluginManager.prototype.getFileManagers = function () { + return this.fileManagers; + }; + return PluginManager; + }()); + var pm; + var PluginManagerFactory = function (less, newFactory) { + if (newFactory || !pm) { + pm = new PluginManager(less); + } + return pm; + }; - var transformTree = (function (root, options) { - if (options === void 0) { options = {}; } - var evaldRoot; - var variables = options.variables; - var evalEnv = new contexts.Eval(options); - // - // Allows setting variables with a hash, so: - // - // `{ color: new tree.Color('#f01') }` will become: - // - // new tree.Declaration('@color', - // new tree.Value([ - // new tree.Expression([ - // new tree.Color('#f01') - // ]) - // ]) - // ) - // - if (typeof variables === 'object' && !Array.isArray(variables)) { - variables = Object.keys(variables).map(function (k) { - var value = variables[k]; - if (!(value instanceof tree.Value)) { - if (!(value instanceof tree.Expression)) { - value = new tree.Expression([value]); - } - value = new tree.Value([value]); - } - return new tree.Declaration("@" + k, value, false, null, 0); - }); - evalEnv.frames = [new tree.Ruleset(null, variables)]; - } - var visitors$1 = [ - new visitors.JoinSelectorVisitor(), - new visitors.MarkVisibleSelectorsVisitor(true), - new visitors.ExtendVisitor(), - new visitors.ToCSSVisitor({ compress: Boolean(options.compress) }) - ]; - var preEvalVisitors = []; - var v; - var visitorIterator; - /** - * first() / get() allows visitors to be added while visiting - * - * @todo Add scoping for visitors just like functions for @plugin; right now they're global - */ - if (options.pluginManager) { - visitorIterator = options.pluginManager.visitor(); - for (var i = 0; i < 2; i++) { - visitorIterator.first(); - while ((v = visitorIterator.get())) { - if (v.isPreEvalVisitor) { - if (i === 0 || preEvalVisitors.indexOf(v) === -1) { - preEvalVisitors.push(v); - v.run(root); - } - } - else { - if (i === 0 || visitors$1.indexOf(v) === -1) { - if (v.isPreVisitor) { - visitors$1.unshift(v); - } - else { - visitors$1.push(v); - } - } - } - } - } - } - evaldRoot = root.eval(evalEnv); - for (var i = 0; i < visitors$1.length; i++) { - visitors$1[i].run(evaldRoot); - } - // Run any remaining visitors added after eval pass - if (options.pluginManager) { - visitorIterator.first(); - while ((v = visitorIterator.get())) { - if (visitors$1.indexOf(v) === -1 && preEvalVisitors.indexOf(v) === -1) { - v.run(evaldRoot); - } - } - } - return evaldRoot; - }); + function SourceMapOutput (environment) { + var SourceMapOutput = /** @class */ (function () { + function SourceMapOutput(options) { + this._css = []; + this._rootNode = options.rootNode; + this._contentsMap = options.contentsMap; + this._contentsIgnoredCharsMap = options.contentsIgnoredCharsMap; + if (options.sourceMapFilename) { + this._sourceMapFilename = options.sourceMapFilename.replace(/\\/g, '/'); + } + this._outputFilename = options.outputFilename; + this.sourceMapURL = options.sourceMapURL; + if (options.sourceMapBasepath) { + this._sourceMapBasepath = options.sourceMapBasepath.replace(/\\/g, '/'); + } + if (options.sourceMapRootpath) { + this._sourceMapRootpath = options.sourceMapRootpath.replace(/\\/g, '/'); + if (this._sourceMapRootpath.charAt(this._sourceMapRootpath.length - 1) !== '/') { + this._sourceMapRootpath += '/'; + } + } + else { + this._sourceMapRootpath = ''; + } + this._outputSourceFiles = options.outputSourceFiles; + this._sourceMapGeneratorConstructor = environment.getSourceMapGenerator(); + this._lineNumber = 0; + this._column = 0; + } + SourceMapOutput.prototype.removeBasepath = function (path) { + if (this._sourceMapBasepath && path.indexOf(this._sourceMapBasepath) === 0) { + path = path.substring(this._sourceMapBasepath.length); + if (path.charAt(0) === '\\' || path.charAt(0) === '/') { + path = path.substring(1); + } + } + return path; + }; + SourceMapOutput.prototype.normalizeFilename = function (filename) { + filename = filename.replace(/\\/g, '/'); + filename = this.removeBasepath(filename); + return (this._sourceMapRootpath || '') + filename; + }; + SourceMapOutput.prototype.add = function (chunk, fileInfo, index, mapLines) { + // ignore adding empty strings + if (!chunk) { + return; + } + var lines, sourceLines, columns, sourceColumns, i; + if (fileInfo && fileInfo.filename) { + var inputSource = this._contentsMap[fileInfo.filename]; + // remove vars/banner added to the top of the file + if (this._contentsIgnoredCharsMap[fileInfo.filename]) { + // adjust the index + index -= this._contentsIgnoredCharsMap[fileInfo.filename]; + if (index < 0) { + index = 0; + } + // adjust the source + inputSource = inputSource.slice(this._contentsIgnoredCharsMap[fileInfo.filename]); + } + /** + * ignore empty content, or failsafe + * if contents map is incorrect + */ + if (inputSource === undefined) { + this._css.push(chunk); + return; + } + inputSource = inputSource.substring(0, index); + sourceLines = inputSource.split('\n'); + sourceColumns = sourceLines[sourceLines.length - 1]; + } + lines = chunk.split('\n'); + columns = lines[lines.length - 1]; + if (fileInfo && fileInfo.filename) { + if (!mapLines) { + this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + 1, column: this._column }, + original: { line: sourceLines.length, column: sourceColumns.length }, + source: this.normalizeFilename(fileInfo.filename) }); + } + else { + for (i = 0; i < lines.length; i++) { + this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + i + 1, column: i === 0 ? this._column : 0 }, + original: { line: sourceLines.length + i, column: i === 0 ? sourceColumns.length : 0 }, + source: this.normalizeFilename(fileInfo.filename) }); + } + } + } + if (lines.length === 1) { + this._column += columns.length; + } + else { + this._lineNumber += lines.length - 1; + this._column = columns.length; + } + this._css.push(chunk); + }; + SourceMapOutput.prototype.isEmpty = function () { + return this._css.length === 0; + }; + SourceMapOutput.prototype.toCSS = function (context) { + this._sourceMapGenerator = new this._sourceMapGeneratorConstructor({ file: this._outputFilename, sourceRoot: null }); + if (this._outputSourceFiles) { + for (var filename in this._contentsMap) { + if (this._contentsMap.hasOwnProperty(filename)) { + var source = this._contentsMap[filename]; + if (this._contentsIgnoredCharsMap[filename]) { + source = source.slice(this._contentsIgnoredCharsMap[filename]); + } + this._sourceMapGenerator.setSourceContent(this.normalizeFilename(filename), source); + } + } + } + this._rootNode.genCSS(context, this); + if (this._css.length > 0) { + var sourceMapURL = void 0; + var sourceMapContent = JSON.stringify(this._sourceMapGenerator.toJSON()); + if (this.sourceMapURL) { + sourceMapURL = this.sourceMapURL; + } + else if (this._sourceMapFilename) { + sourceMapURL = this._sourceMapFilename; + } + this.sourceMapURL = sourceMapURL; + this.sourceMap = sourceMapContent; + } + return this._css.join(''); + }; + return SourceMapOutput; + }()); + return SourceMapOutput; + } - var parseTree = (function (SourceMapBuilder) { - var ParseTree = /** @class */ (function () { - function ParseTree(root, imports) { - this.root = root; - this.imports = imports; - } - ParseTree.prototype.toCSS = function (options) { - var evaldRoot; - var result = {}; - var sourceMapBuilder; - try { - evaldRoot = transformTree(this.root, options); - } - catch (e) { - throw new LessError(e, this.imports); - } - try { - var compress = Boolean(options.compress); - if (compress) { - logger.warn('The compress option has been deprecated. ' + - 'We recommend you use a dedicated css minifier, for instance see less-plugin-clean-css.'); - } - var toCSSOptions = { - compress: compress, - dumpLineNumbers: options.dumpLineNumbers, - strictUnits: Boolean(options.strictUnits), - numPrecision: 8 - }; - if (options.sourceMap) { - sourceMapBuilder = new SourceMapBuilder(options.sourceMap); - result.css = sourceMapBuilder.toCSS(evaldRoot, toCSSOptions, this.imports); - } - else { - result.css = evaldRoot.toCSS(toCSSOptions); - } - } - catch (e) { - throw new LessError(e, this.imports); - } - if (options.pluginManager) { - var postProcessors = options.pluginManager.getPostProcessors(); - for (var i = 0; i < postProcessors.length; i++) { - result.css = postProcessors[i].process(result.css, { sourceMap: sourceMapBuilder, options: options, imports: this.imports }); - } - } - if (options.sourceMap) { - result.map = sourceMapBuilder.getExternalSourceMap(); - } - result.imports = []; - for (var file in this.imports.files) { - if (this.imports.files.hasOwnProperty(file) && file !== this.imports.rootFilename) { - result.imports.push(file); - } - } - return result; - }; - return ParseTree; - }()); - return ParseTree; - }); + function SourceMapBuilder (SourceMapOutput, environment) { + var SourceMapBuilder = /** @class */ (function () { + function SourceMapBuilder(options) { + this.options = options; + } + SourceMapBuilder.prototype.toCSS = function (rootNode, options, imports) { + var sourceMapOutput = new SourceMapOutput({ + contentsIgnoredCharsMap: imports.contentsIgnoredChars, + rootNode: rootNode, + contentsMap: imports.contents, + sourceMapFilename: this.options.sourceMapFilename, + sourceMapURL: this.options.sourceMapURL, + outputFilename: this.options.sourceMapOutputFilename, + sourceMapBasepath: this.options.sourceMapBasepath, + sourceMapRootpath: this.options.sourceMapRootpath, + outputSourceFiles: this.options.outputSourceFiles, + sourceMapGenerator: this.options.sourceMapGenerator, + sourceMapFileInline: this.options.sourceMapFileInline, + disableSourcemapAnnotation: this.options.disableSourcemapAnnotation + }); + var css = sourceMapOutput.toCSS(options); + this.sourceMap = sourceMapOutput.sourceMap; + this.sourceMapURL = sourceMapOutput.sourceMapURL; + if (this.options.sourceMapInputFilename) { + this.sourceMapInputFilename = sourceMapOutput.normalizeFilename(this.options.sourceMapInputFilename); + } + if (this.options.sourceMapBasepath !== undefined && this.sourceMapURL !== undefined) { + this.sourceMapURL = sourceMapOutput.removeBasepath(this.sourceMapURL); + } + return css + this.getCSSAppendage(); + }; + SourceMapBuilder.prototype.getCSSAppendage = function () { + var sourceMapURL = this.sourceMapURL; + if (this.options.sourceMapFileInline) { + if (this.sourceMap === undefined) { + return ''; + } + sourceMapURL = "data:application/json;base64," + environment.encodeBase64(this.sourceMap); + } + if (this.options.disableSourcemapAnnotation) { + return ''; + } + if (sourceMapURL) { + return "/*# sourceMappingURL=" + sourceMapURL + " */"; + } + return ''; + }; + SourceMapBuilder.prototype.getExternalSourceMap = function () { + return this.sourceMap; + }; + SourceMapBuilder.prototype.setExternalSourceMap = function (sourceMap) { + this.sourceMap = sourceMap; + }; + SourceMapBuilder.prototype.isInline = function () { + return this.options.sourceMapFileInline; + }; + SourceMapBuilder.prototype.getSourceMapURL = function () { + return this.sourceMapURL; + }; + SourceMapBuilder.prototype.getOutputFilename = function () { + return this.options.sourceMapOutputFilename; + }; + SourceMapBuilder.prototype.getInputFilename = function () { + return this.sourceMapInputFilename; + }; + return SourceMapBuilder; + }()); + return SourceMapBuilder; + } - function importManager (environment) { - // FileInfo = { - // 'rewriteUrls' - option - whether to adjust URL's to be relative - // 'filename' - full resolved filename of current file - // 'rootpath' - path to append to normal URLs for this node - // 'currentDirectory' - path to the current file, absolute - // 'rootFilename' - filename of the base file - // 'entryPath' - absolute path to the entry file - // 'reference' - whether the file should not be output and only output parts that are referenced - var ImportManager = /** @class */ (function () { - function ImportManager(less, context, rootFileInfo) { - this.less = less; - this.rootFilename = rootFileInfo.filename; - this.paths = context.paths || []; // Search paths, when importing - this.contents = {}; // map - filename to contents of all the files - this.contentsIgnoredChars = {}; // map - filename to lines at the beginning of each file to ignore - this.mime = context.mime; - this.error = null; - this.context = context; - // Deprecated? Unused outside of here, could be useful. - this.queue = []; // Files which haven't been imported yet - this.files = {}; // Holds the imported parse trees. - } - /** - * Add an import to be imported - * @param path - the raw path - * @param tryAppendExtension - whether to try appending a file extension (.less or .js if the path has no extension) - * @param currentFileInfo - the current file info (used for instance to work out relative paths) - * @param importOptions - import options - * @param callback - callback for when it is imported - */ - ImportManager.prototype.push = function (path, tryAppendExtension, currentFileInfo, importOptions, callback) { - var importManager = this, pluginLoader = this.context.pluginManager.Loader; - this.queue.push(path); - var fileParsedFunc = function (e, root, fullPath) { - importManager.queue.splice(importManager.queue.indexOf(path), 1); // Remove the path from the queue - var importedEqualsRoot = fullPath === importManager.rootFilename; - if (importOptions.optional && e) { - callback(null, { rules: [] }, false, null); - logger.info("The file " + fullPath + " was skipped because it was not found and the import was marked optional."); - } - else { - // Inline imports aren't cached here. - // If we start to cache them, please make sure they won't conflict with non-inline imports of the - // same name as they used to do before this comment and the condition below have been added. - if (!importManager.files[fullPath] && !importOptions.inline) { - importManager.files[fullPath] = { root: root, options: importOptions }; - } - if (e && !importManager.error) { - importManager.error = e; - } - callback(e, root, importedEqualsRoot, fullPath); - } - }; - var newFileInfo = { - rewriteUrls: this.context.rewriteUrls, - entryPath: currentFileInfo.entryPath, - rootpath: currentFileInfo.rootpath, - rootFilename: currentFileInfo.rootFilename - }; - var fileManager = environment.getFileManager(path, currentFileInfo.currentDirectory, this.context, environment); - if (!fileManager) { - fileParsedFunc({ message: "Could not find a file-manager for " + path }); - return; - } - var loadFileCallback = function (loadedFile) { - var plugin; - var resolvedFilename = loadedFile.filename; - var contents = loadedFile.contents.replace(/^\uFEFF/, ''); - // Pass on an updated rootpath if path of imported file is relative and file - // is in a (sub|sup) directory - // - // Examples: - // - If path of imported file is 'module/nav/nav.less' and rootpath is 'less/', - // then rootpath should become 'less/module/nav/' - // - If path of imported file is '../mixins.less' and rootpath is 'less/', - // then rootpath should become 'less/../' - newFileInfo.currentDirectory = fileManager.getPath(resolvedFilename); - if (newFileInfo.rewriteUrls) { - newFileInfo.rootpath = fileManager.join((importManager.context.rootpath || ''), fileManager.pathDiff(newFileInfo.currentDirectory, newFileInfo.entryPath)); - if (!fileManager.isPathAbsolute(newFileInfo.rootpath) && fileManager.alwaysMakePathsAbsolute()) { - newFileInfo.rootpath = fileManager.join(newFileInfo.entryPath, newFileInfo.rootpath); - } - } - newFileInfo.filename = resolvedFilename; - var newEnv = new contexts.Parse(importManager.context); - newEnv.processImports = false; - importManager.contents[resolvedFilename] = contents; - if (currentFileInfo.reference || importOptions.reference) { - newFileInfo.reference = true; - } - if (importOptions.isPlugin) { - plugin = pluginLoader.evalPlugin(contents, newEnv, importManager, importOptions.pluginArgs, newFileInfo); - if (plugin instanceof LessError) { - fileParsedFunc(plugin, null, resolvedFilename); - } - else { - fileParsedFunc(null, plugin, resolvedFilename); - } - } - else if (importOptions.inline) { - fileParsedFunc(null, contents, resolvedFilename); - } - else { - // import (multiple) parse trees apparently get altered and can't be cached. - // TODO: investigate why this is - if (importManager.files[resolvedFilename] - && !importManager.files[resolvedFilename].options.multiple - && !importOptions.multiple) { - fileParsedFunc(null, importManager.files[resolvedFilename].root, resolvedFilename); - } - else { - new Parser(newEnv, importManager, newFileInfo).parse(contents, function (e, root) { - fileParsedFunc(e, root, resolvedFilename); - }); - } - } - }; - var loadedFile; - var promise; - var context = clone(this.context); - if (tryAppendExtension) { - context.ext = importOptions.isPlugin ? '.js' : '.less'; - } - if (importOptions.isPlugin) { - context.mime = 'application/javascript'; - if (context.syncImport) { - loadedFile = pluginLoader.loadPluginSync(path, currentFileInfo.currentDirectory, context, environment, fileManager); - } - else { - promise = pluginLoader.loadPlugin(path, currentFileInfo.currentDirectory, context, environment, fileManager); - } - } - else { - if (context.syncImport) { - loadedFile = fileManager.loadFileSync(path, currentFileInfo.currentDirectory, context, environment); - } - else { - promise = fileManager.loadFile(path, currentFileInfo.currentDirectory, context, environment, function (err, loadedFile) { - if (err) { - fileParsedFunc(err); - } - else { - loadFileCallback(loadedFile); - } - }); - } - } - if (loadedFile) { - if (!loadedFile.filename) { - fileParsedFunc(loadedFile); - } - else { - loadFileCallback(loadedFile); - } - } - else if (promise) { - promise.then(loadFileCallback, fileParsedFunc); - } - }; - return ImportManager; - }()); - return ImportManager; - } + function ParseTree (SourceMapBuilder) { + var ParseTree = /** @class */ (function () { + function ParseTree(root, imports) { + this.root = root; + this.imports = imports; + } + ParseTree.prototype.toCSS = function (options) { + var evaldRoot; + var result = {}; + var sourceMapBuilder; + try { + evaldRoot = transformTree(this.root, options); + } + catch (e) { + throw new LessError(e, this.imports); + } + try { + var compress = Boolean(options.compress); + if (compress) { + logger.warn('The compress option has been deprecated. ' + + 'We recommend you use a dedicated css minifier, for instance see less-plugin-clean-css.'); + } + var toCSSOptions = { + compress: compress, + dumpLineNumbers: options.dumpLineNumbers, + strictUnits: Boolean(options.strictUnits), + numPrecision: 8 + }; + if (options.sourceMap) { + sourceMapBuilder = new SourceMapBuilder(options.sourceMap); + result.css = sourceMapBuilder.toCSS(evaldRoot, toCSSOptions, this.imports); + } + else { + result.css = evaldRoot.toCSS(toCSSOptions); + } + } + catch (e) { + throw new LessError(e, this.imports); + } + if (options.pluginManager) { + var postProcessors = options.pluginManager.getPostProcessors(); + for (var i = 0; i < postProcessors.length; i++) { + result.css = postProcessors[i].process(result.css, { sourceMap: sourceMapBuilder, options: options, imports: this.imports }); + } + } + if (options.sourceMap) { + result.map = sourceMapBuilder.getExternalSourceMap(); + } + result.imports = []; + for (var file in this.imports.files) { + if (this.imports.files.hasOwnProperty(file) && file !== this.imports.rootFilename) { + result.imports.push(file); + } + } + return result; + }; + return ParseTree; + }()); + return ParseTree; + } - var Render = (function (environment, ParseTree, ImportManager) { - var render = function (input, options, callback) { - if (typeof options === 'function') { - callback = options; - options = copyOptions(this.options, {}); - } - else { - options = copyOptions(this.options, options || {}); - } - if (!callback) { - var self_1 = this; - return new Promise(function (resolve, reject) { - render.call(self_1, input, options, function (err, output) { - if (err) { - reject(err); - } - else { - resolve(output); - } - }); - }); - } - else { - this.parse(input, options, function (err, root, imports, options) { - if (err) { - return callback(err); - } - var result; - try { - var parseTree = new ParseTree(root, imports); - result = parseTree.toCSS(options); - } - catch (err) { - return callback(err); - } - callback(null, result); - }); - } - }; - return render; - }); + function ImportManager (environment) { + // FileInfo = { + // 'rewriteUrls' - option - whether to adjust URL's to be relative + // 'filename' - full resolved filename of current file + // 'rootpath' - path to append to normal URLs for this node + // 'currentDirectory' - path to the current file, absolute + // 'rootFilename' - filename of the base file + // 'entryPath' - absolute path to the entry file + // 'reference' - whether the file should not be output and only output parts that are referenced + var ImportManager = /** @class */ (function () { + function ImportManager(less, context, rootFileInfo) { + this.less = less; + this.rootFilename = rootFileInfo.filename; + this.paths = context.paths || []; // Search paths, when importing + this.contents = {}; // map - filename to contents of all the files + this.contentsIgnoredChars = {}; // map - filename to lines at the beginning of each file to ignore + this.mime = context.mime; + this.error = null; + this.context = context; + // Deprecated? Unused outside of here, could be useful. + this.queue = []; // Files which haven't been imported yet + this.files = {}; // Holds the imported parse trees. + } + /** + * Add an import to be imported + * @param path - the raw path + * @param tryAppendExtension - whether to try appending a file extension (.less or .js if the path has no extension) + * @param currentFileInfo - the current file info (used for instance to work out relative paths) + * @param importOptions - import options + * @param callback - callback for when it is imported + */ + ImportManager.prototype.push = function (path, tryAppendExtension, currentFileInfo, importOptions, callback) { + var importManager = this, pluginLoader = this.context.pluginManager.Loader; + this.queue.push(path); + var fileParsedFunc = function (e, root, fullPath) { + importManager.queue.splice(importManager.queue.indexOf(path), 1); // Remove the path from the queue + var importedEqualsRoot = fullPath === importManager.rootFilename; + if (importOptions.optional && e) { + callback(null, { rules: [] }, false, null); + logger.info("The file " + fullPath + " was skipped because it was not found and the import was marked optional."); + } + else { + // Inline imports aren't cached here. + // If we start to cache them, please make sure they won't conflict with non-inline imports of the + // same name as they used to do before this comment and the condition below have been added. + if (!importManager.files[fullPath] && !importOptions.inline) { + importManager.files[fullPath] = { root: root, options: importOptions }; + } + if (e && !importManager.error) { + importManager.error = e; + } + callback(e, root, importedEqualsRoot, fullPath); + } + }; + var newFileInfo = { + rewriteUrls: this.context.rewriteUrls, + entryPath: currentFileInfo.entryPath, + rootpath: currentFileInfo.rootpath, + rootFilename: currentFileInfo.rootFilename + }; + var fileManager = environment.getFileManager(path, currentFileInfo.currentDirectory, this.context, environment); + if (!fileManager) { + fileParsedFunc({ message: "Could not find a file-manager for " + path }); + return; + } + var loadFileCallback = function (loadedFile) { + var plugin; + var resolvedFilename = loadedFile.filename; + var contents = loadedFile.contents.replace(/^\uFEFF/, ''); + // Pass on an updated rootpath if path of imported file is relative and file + // is in a (sub|sup) directory + // + // Examples: + // - If path of imported file is 'module/nav/nav.less' and rootpath is 'less/', + // then rootpath should become 'less/module/nav/' + // - If path of imported file is '../mixins.less' and rootpath is 'less/', + // then rootpath should become 'less/../' + newFileInfo.currentDirectory = fileManager.getPath(resolvedFilename); + if (newFileInfo.rewriteUrls) { + newFileInfo.rootpath = fileManager.join((importManager.context.rootpath || ''), fileManager.pathDiff(newFileInfo.currentDirectory, newFileInfo.entryPath)); + if (!fileManager.isPathAbsolute(newFileInfo.rootpath) && fileManager.alwaysMakePathsAbsolute()) { + newFileInfo.rootpath = fileManager.join(newFileInfo.entryPath, newFileInfo.rootpath); + } + } + newFileInfo.filename = resolvedFilename; + var newEnv = new contexts.Parse(importManager.context); + newEnv.processImports = false; + importManager.contents[resolvedFilename] = contents; + if (currentFileInfo.reference || importOptions.reference) { + newFileInfo.reference = true; + } + if (importOptions.isPlugin) { + plugin = pluginLoader.evalPlugin(contents, newEnv, importManager, importOptions.pluginArgs, newFileInfo); + if (plugin instanceof LessError) { + fileParsedFunc(plugin, null, resolvedFilename); + } + else { + fileParsedFunc(null, plugin, resolvedFilename); + } + } + else if (importOptions.inline) { + fileParsedFunc(null, contents, resolvedFilename); + } + else { + // import (multiple) parse trees apparently get altered and can't be cached. + // TODO: investigate why this is + if (importManager.files[resolvedFilename] + && !importManager.files[resolvedFilename].options.multiple + && !importOptions.multiple) { + fileParsedFunc(null, importManager.files[resolvedFilename].root, resolvedFilename); + } + else { + new Parser(newEnv, importManager, newFileInfo).parse(contents, function (e, root) { + fileParsedFunc(e, root, resolvedFilename); + }); + } + } + }; + var loadedFile; + var promise; + var context = clone(this.context); + if (tryAppendExtension) { + context.ext = importOptions.isPlugin ? '.js' : '.less'; + } + if (importOptions.isPlugin) { + context.mime = 'application/javascript'; + if (context.syncImport) { + loadedFile = pluginLoader.loadPluginSync(path, currentFileInfo.currentDirectory, context, environment, fileManager); + } + else { + promise = pluginLoader.loadPlugin(path, currentFileInfo.currentDirectory, context, environment, fileManager); + } + } + else { + if (context.syncImport) { + loadedFile = fileManager.loadFileSync(path, currentFileInfo.currentDirectory, context, environment); + } + else { + promise = fileManager.loadFile(path, currentFileInfo.currentDirectory, context, environment, function (err, loadedFile) { + if (err) { + fileParsedFunc(err); + } + else { + loadFileCallback(loadedFile); + } + }); + } + } + if (loadedFile) { + if (!loadedFile.filename) { + fileParsedFunc(loadedFile); + } + else { + loadFileCallback(loadedFile); + } + } + else if (promise) { + promise.then(loadFileCallback, fileParsedFunc); + } + }; + return ImportManager; + }()); + return ImportManager; + } - /** - * Plugin Manager - */ - var PluginManager = /** @class */ (function () { - function PluginManager(less) { - this.less = less; - this.visitors = []; - this.preProcessors = []; - this.postProcessors = []; - this.installedPlugins = []; - this.fileManagers = []; - this.iterator = -1; - this.pluginCache = {}; - this.Loader = new less.PluginLoader(less); - } - /** - * Adds all the plugins in the array - * @param {Array} plugins - */ - PluginManager.prototype.addPlugins = function (plugins) { - if (plugins) { - for (var i = 0; i < plugins.length; i++) { - this.addPlugin(plugins[i]); - } - } - }; - /** - * - * @param plugin - * @param {String} filename - */ - PluginManager.prototype.addPlugin = function (plugin, filename, functionRegistry) { - this.installedPlugins.push(plugin); - if (filename) { - this.pluginCache[filename] = plugin; - } - if (plugin.install) { - plugin.install(this.less, this, functionRegistry || this.less.functions.functionRegistry); - } - }; - /** - * - * @param filename - */ - PluginManager.prototype.get = function (filename) { - return this.pluginCache[filename]; - }; - /** - * Adds a visitor. The visitor object has options on itself to determine - * when it should run. - * @param visitor - */ - PluginManager.prototype.addVisitor = function (visitor) { - this.visitors.push(visitor); - }; - /** - * Adds a pre processor object - * @param {object} preProcessor - * @param {number} priority - guidelines 1 = before import, 1000 = import, 2000 = after import - */ - PluginManager.prototype.addPreProcessor = function (preProcessor, priority) { - var indexToInsertAt; - for (indexToInsertAt = 0; indexToInsertAt < this.preProcessors.length; indexToInsertAt++) { - if (this.preProcessors[indexToInsertAt].priority >= priority) { - break; - } - } - this.preProcessors.splice(indexToInsertAt, 0, { preProcessor: preProcessor, priority: priority }); - }; - /** - * Adds a post processor object - * @param {object} postProcessor - * @param {number} priority - guidelines 1 = before compression, 1000 = compression, 2000 = after compression - */ - PluginManager.prototype.addPostProcessor = function (postProcessor, priority) { - var indexToInsertAt; - for (indexToInsertAt = 0; indexToInsertAt < this.postProcessors.length; indexToInsertAt++) { - if (this.postProcessors[indexToInsertAt].priority >= priority) { - break; - } - } - this.postProcessors.splice(indexToInsertAt, 0, { postProcessor: postProcessor, priority: priority }); - }; - /** - * - * @param manager - */ - PluginManager.prototype.addFileManager = function (manager) { - this.fileManagers.push(manager); - }; - /** - * - * @returns {Array} - * @private - */ - PluginManager.prototype.getPreProcessors = function () { - var preProcessors = []; - for (var i = 0; i < this.preProcessors.length; i++) { - preProcessors.push(this.preProcessors[i].preProcessor); - } - return preProcessors; - }; - /** - * - * @returns {Array} - * @private - */ - PluginManager.prototype.getPostProcessors = function () { - var postProcessors = []; - for (var i = 0; i < this.postProcessors.length; i++) { - postProcessors.push(this.postProcessors[i].postProcessor); - } - return postProcessors; - }; - /** - * - * @returns {Array} - * @private - */ - PluginManager.prototype.getVisitors = function () { - return this.visitors; - }; - PluginManager.prototype.visitor = function () { - var self = this; - return { - first: function () { - self.iterator = -1; - return self.visitors[self.iterator]; - }, - get: function () { - self.iterator += 1; - return self.visitors[self.iterator]; - } - }; - }; - /** - * - * @returns {Array} - * @private - */ - PluginManager.prototype.getFileManagers = function () { - return this.fileManagers; - }; - return PluginManager; - }()); - var pm; - function PluginManagerFactory(less, newFactory) { - if (newFactory || !pm) { - pm = new PluginManager(less); - } - return pm; - } + function Parse (environment, ParseTree, ImportManager) { + var parse = function (input, options, callback) { + if (typeof options === 'function') { + callback = options; + options = copyOptions(this.options, {}); + } + else { + options = copyOptions(this.options, options || {}); + } + if (!callback) { + var self_1 = this; + return new Promise(function (resolve, reject) { + parse.call(self_1, input, options, function (err, output) { + if (err) { + reject(err); + } + else { + resolve(output); + } + }); + }); + } + else { + var context_1; + var rootFileInfo = void 0; + var pluginManager_1 = new PluginManagerFactory(this, !options.reUsePluginManager); + options.pluginManager = pluginManager_1; + context_1 = new contexts.Parse(options); + if (options.rootFileInfo) { + rootFileInfo = options.rootFileInfo; + } + else { + var filename = options.filename || 'input'; + var entryPath = filename.replace(/[^\/\\]*$/, ''); + rootFileInfo = { + filename: filename, + rewriteUrls: context_1.rewriteUrls, + rootpath: context_1.rootpath || '', + currentDirectory: entryPath, + entryPath: entryPath, + rootFilename: filename + }; + // add in a missing trailing slash + if (rootFileInfo.rootpath && rootFileInfo.rootpath.slice(-1) !== '/') { + rootFileInfo.rootpath += '/'; + } + } + var imports_1 = new ImportManager(this, context_1, rootFileInfo); + this.importManager = imports_1; + // TODO: allow the plugins to be just a list of paths or names + // Do an async plugin queue like lessc + if (options.plugins) { + options.plugins.forEach(function (plugin) { + var evalResult, contents; + if (plugin.fileContent) { + contents = plugin.fileContent.replace(/^\uFEFF/, ''); + evalResult = pluginManager_1.Loader.evalPlugin(contents, context_1, imports_1, plugin.options, plugin.filename); + if (evalResult instanceof LessError) { + return callback(evalResult); + } + } + else { + pluginManager_1.addPlugin(plugin); + } + }); + } + new Parser(context_1, imports_1, rootFileInfo) + .parse(input, function (e, root) { + if (e) { + return callback(e); + } + callback(null, root, imports_1, options); + }, options); + } + }; + return parse; + } - var Parse = (function (environment, ParseTree, ImportManager) { - var parse = function (input, options, callback) { - if (typeof options === 'function') { - callback = options; - options = copyOptions(this.options, {}); - } - else { - options = copyOptions(this.options, options || {}); - } - if (!callback) { - var self_1 = this; - return new Promise(function (resolve, reject) { - parse.call(self_1, input, options, function (err, output) { - if (err) { - reject(err); - } - else { - resolve(output); - } - }); - }); - } - else { - var context_1; - var rootFileInfo = void 0; - var pluginManager_1 = new PluginManagerFactory(this, !options.reUsePluginManager); - options.pluginManager = pluginManager_1; - context_1 = new contexts.Parse(options); - if (options.rootFileInfo) { - rootFileInfo = options.rootFileInfo; - } - else { - var filename = options.filename || 'input'; - var entryPath = filename.replace(/[^\/\\]*$/, ''); - rootFileInfo = { - filename: filename, - rewriteUrls: context_1.rewriteUrls, - rootpath: context_1.rootpath || '', - currentDirectory: entryPath, - entryPath: entryPath, - rootFilename: filename - }; - // add in a missing trailing slash - if (rootFileInfo.rootpath && rootFileInfo.rootpath.slice(-1) !== '/') { - rootFileInfo.rootpath += '/'; - } - } - var imports_1 = new ImportManager(this, context_1, rootFileInfo); - this.importManager = imports_1; - // TODO: allow the plugins to be just a list of paths or names - // Do an async plugin queue like lessc - if (options.plugins) { - options.plugins.forEach(function (plugin) { - var evalResult; - var contents; - if (plugin.fileContent) { - contents = plugin.fileContent.replace(/^\uFEFF/, ''); - evalResult = pluginManager_1.Loader.evalPlugin(contents, context_1, imports_1, plugin.options, plugin.filename); - if (evalResult instanceof LessError) { - return callback(evalResult); - } - } - else { - pluginManager_1.addPlugin(plugin); - } - }); - } - new Parser(context_1, imports_1, rootFileInfo) - .parse(input, function (e, root) { - if (e) { - return callback(e); - } - callback(null, root, imports_1, options); - }, options); - } - }; - return parse; - }); + function Render (environment, ParseTree, ImportManager) { + var render = function (input, options, callback) { + if (typeof options === 'function') { + callback = options; + options = copyOptions(this.options, {}); + } + else { + options = copyOptions(this.options, options || {}); + } + if (!callback) { + var self_1 = this; + return new Promise(function (resolve, reject) { + render.call(self_1, input, options, function (err, output) { + if (err) { + reject(err); + } + else { + resolve(output); + } + }); + }); + } + else { + this.parse(input, options, function (err, root, imports, options) { + if (err) { + return callback(err); + } + var result; + try { + var parseTree = new ParseTree(root, imports); + result = parseTree.toCSS(options); + } + catch (err) { + return callback(err); + } + callback(null, result); + }); + } + }; + return render; + } - var lessRoot = (function (environment$1, fileManagers) { - /** - * @todo - * This original code could be improved quite a bit. - * Many classes / modules currently add side-effects / mutations to passed in objects, - * which makes it hard to refactor and reason about. - */ - environment$1 = new environment(environment$1, fileManagers); - var SourceMapOutput = sourceMapOutput(environment$1); - var SourceMapBuilder = sourceMapBuilder(SourceMapOutput, environment$1); - var ParseTree = parseTree(SourceMapBuilder); - var ImportManager = importManager(environment$1); - var render = Render(environment$1, ParseTree); - var parse = Parse(environment$1, ParseTree, ImportManager); - var functions = Functions(environment$1); - /** - * @todo - * This root properties / methods need to be organized. - * It's not clear what should / must be public and why. - */ - var initial = { - version: [3, 13, 1], - data: data, - tree: tree, - Environment: environment, - AbstractFileManager: AbstractFileManager, - AbstractPluginLoader: AbstractPluginLoader, - environment: environment$1, - visitors: visitors, - Parser: Parser, - functions: functions, - contexts: contexts, - SourceMapOutput: SourceMapOutput, - SourceMapBuilder: SourceMapBuilder, - ParseTree: ParseTree, - ImportManager: ImportManager, - render: render, - parse: parse, - LessError: LessError, - transformTree: transformTree, - utils: utils, - PluginManager: PluginManagerFactory, - logger: logger - }; - // Create a public API - var ctor = function (t) { return function () { - var args = []; - for (var _i = 0; _i < arguments.length; _i++) { - args[_i] = arguments[_i]; - } - return new (t.bind.apply(t, __spreadArrays([void 0], args)))(); - }; }; - var t; - var api = Object.create(initial); - for (var n in initial.tree) { - /* eslint guard-for-in: 0 */ - t = initial.tree[n]; - if (typeof t === 'function') { - api[n.toLowerCase()] = ctor(t); - } - else { - api[n] = Object.create(null); - for (var o in t) { - /* eslint guard-for-in: 0 */ - api[n][o.toLowerCase()] = ctor(t[o]); - } - } - } - /** - * Some of the functions assume a `this` context of the API object, - * which causes it to fail when wrapped for ES6 imports. - * - * An assumed `this` should be removed in the future. - */ - initial.parse = initial.parse.bind(api); - initial.render = initial.render.bind(api); - return api; - }); + var version = "4.0.0"; - /* global window, XMLHttpRequest */ - var options; - var logger$1; - var fileCache = {}; - // TODOS - move log somewhere. pathDiff and doing something similar in node. use pathDiff in the other browser file for the initial load - var FileManager = /** @class */ (function (_super) { - __extends(FileManager, _super); - function FileManager() { - return _super !== null && _super.apply(this, arguments) || this; - } - FileManager.prototype.alwaysMakePathsAbsolute = function () { - return true; - }; - FileManager.prototype.join = function (basePath, laterPath) { - if (!basePath) { - return laterPath; - } - return this.extractUrlParts(laterPath, basePath).path; - }; - FileManager.prototype.doXHR = function (url, type, callback, errback) { - var xhr = new XMLHttpRequest(); - var async = options.isFileProtocol ? options.fileAsync : true; - if (typeof xhr.overrideMimeType === 'function') { - xhr.overrideMimeType('text/css'); - } - logger$1.debug("XHR: Getting '" + url + "'"); - xhr.open('GET', url, async); - xhr.setRequestHeader('Accept', type || 'text/x-less, text/css; q=0.9, */*; q=0.5'); - xhr.send(null); - function handleResponse(xhr, callback, errback) { - if (xhr.status >= 200 && xhr.status < 300) { - callback(xhr.responseText, xhr.getResponseHeader('Last-Modified')); - } - else if (typeof errback === 'function') { - errback(xhr.status, url); - } - } - if (options.isFileProtocol && !options.fileAsync) { - if (xhr.status === 0 || (xhr.status >= 200 && xhr.status < 300)) { - callback(xhr.responseText); - } - else { - errback(xhr.status, url); - } - } - else if (async) { - xhr.onreadystatechange = function () { - if (xhr.readyState == 4) { - handleResponse(xhr, callback, errback); - } - }; - } - else { - handleResponse(xhr, callback, errback); - } - }; - FileManager.prototype.supports = function () { - return true; - }; - FileManager.prototype.clearFileCache = function () { - fileCache = {}; - }; - FileManager.prototype.loadFile = function (filename, currentDirectory, options, environment) { - // TODO: Add prefix support like less-node? - // What about multiple paths? - if (currentDirectory && !this.isPathAbsolute(filename)) { - filename = currentDirectory + filename; - } - filename = options.ext ? this.tryAppendExtension(filename, options.ext) : filename; - options = options || {}; - // sheet may be set to the stylesheet for the initial load or a collection of properties including - // some context variables for imports - var hrefParts = this.extractUrlParts(filename, window.location.href); - var href = hrefParts.url; - var self = this; - return new Promise(function (resolve, reject) { - if (options.useFileCache && fileCache[href]) { - try { - var lessText = fileCache[href]; - return resolve({ contents: lessText, filename: href, webInfo: { lastModified: new Date() } }); - } - catch (e) { - return reject({ filename: href, message: "Error loading file " + href + " error was " + e.message }); - } - } - self.doXHR(href, options.mime, function doXHRCallback(data, lastModified) { - // per file cache - fileCache[href] = data; - // Use remote copy (re-parse) - resolve({ contents: data, filename: href, webInfo: { lastModified: lastModified } }); - }, function doXHRError(status, url) { - reject({ type: 'File', message: "'" + url + "' wasn't found (" + status + ")", href: href }); - }); - }); - }; - return FileManager; - }(AbstractFileManager)); - var FM = (function (opts, log) { - options = opts; - logger$1 = log; - return FileManager; - }); + function parseNodeVersion(version) { + var match = version.match(/^v(\d{1,2})\.(\d{1,2})\.(\d{1,2})(?:-([0-9A-Za-z-.]+))?(?:\+([0-9A-Za-z-.]+))?$/); // eslint-disable-line max-len + if (!match) { + throw new Error('Unable to parse: ' + version); + } + var res = { + major: parseInt(match[1], 10), + minor: parseInt(match[2], 10), + patch: parseInt(match[3], 10), + pre: match[4] || '', + build: match[5] || '', + }; + return res; + } + var parseNodeVersion_1 = parseNodeVersion; - // TODO: Add tests for browser @plugin - /** - * Browser Plugin Loader - */ - var PluginLoader = /** @class */ (function (_super) { - __extends(PluginLoader, _super); - function PluginLoader(less) { - var _this = _super.call(this) || this; - _this.less = less; - return _this; - // Should we shim this.require for browser? Probably not? - } - PluginLoader.prototype.loadPlugin = function (filename, basePath, context, environment, fileManager) { - return new Promise(function (fulfill, reject) { - fileManager.loadFile(filename, basePath, context, environment) - .then(fulfill).catch(reject); - }); - }; - return PluginLoader; - }(AbstractPluginLoader)); + function lessRoot (environment, fileManagers) { + var sourceMapOutput, sourceMapBuilder, parseTree, importManager; + environment = new Environment(environment, fileManagers); + sourceMapOutput = SourceMapOutput(environment); + sourceMapBuilder = SourceMapBuilder(sourceMapOutput, environment); + parseTree = ParseTree(sourceMapBuilder); + importManager = ImportManager(environment); + var render = Render(environment, parseTree); + var parse = Parse(environment, parseTree, importManager); + var v = parseNodeVersion_1(version); + var initial = { + version: [v.major, v.minor, v.patch], + data: data, + tree: tree, + Environment: Environment, + AbstractFileManager: AbstractFileManager, + AbstractPluginLoader: AbstractPluginLoader, + environment: environment, + visitors: visitors, + Parser: Parser, + functions: functions(environment), + contexts: contexts, + SourceMapOutput: sourceMapOutput, + SourceMapBuilder: sourceMapBuilder, + ParseTree: parseTree, + ImportManager: importManager, + render: render, + parse: parse, + LessError: LessError, + transformTree: transformTree, + utils: utils, + PluginManager: PluginManagerFactory, + logger: logger + }; + // Create a public API + var ctor = function (t) { + return function () { + var obj = Object.create(t.prototype); + t.apply(obj, Array.prototype.slice.call(arguments, 0)); + return obj; + }; + }; + var t; + var api = Object.create(initial); + for (var n in initial.tree) { + /* eslint guard-for-in: 0 */ + t = initial.tree[n]; + if (typeof t === 'function') { + api[n.toLowerCase()] = ctor(t); + } + else { + api[n] = Object.create(null); + for (var o in t) { + /* eslint guard-for-in: 0 */ + api[n][o.toLowerCase()] = ctor(t[o]); + } + } + } + /** + * Some of the functions assume a `this` context of the API object, + * which causes it to fail when wrapped for ES6 imports. + * + * An assumed `this` should be removed in the future. + */ + initial.parse = initial.parse.bind(api); + initial.render = initial.render.bind(api); + return api; + } - var LogListener = (function (less, options) { - var logLevel_debug = 4; - var logLevel_info = 3; - var logLevel_warn = 2; - var logLevel_error = 1; - // The amount of logging in the javascript console. - // 3 - Debug, information and errors - // 2 - Information and errors - // 1 - Errors - // 0 - None - // Defaults to 2 - options.logLevel = typeof options.logLevel !== 'undefined' ? options.logLevel : (options.env === 'development' ? logLevel_info : logLevel_error); - if (!options.loggers) { - options.loggers = [{ - debug: function (msg) { - if (options.logLevel >= logLevel_debug) { - console.log(msg); - } - }, - info: function (msg) { - if (options.logLevel >= logLevel_info) { - console.log(msg); - } - }, - warn: function (msg) { - if (options.logLevel >= logLevel_warn) { - console.warn(msg); - } - }, - error: function (msg) { - if (options.logLevel >= logLevel_error) { - console.error(msg); - } - } - }]; - } - for (var i = 0; i < options.loggers.length; i++) { - less.logger.addListener(options.loggers[i]); - } - }); + /* global window, XMLHttpRequest */ + var options; + var logger$1; + var fileCache = {}; + // TODOS - move log somewhere. pathDiff and doing something similar in node. use pathDiff in the other browser file for the initial load + var FileManager = function () { }; + FileManager.prototype = Object.assign(new AbstractFileManager(), { + alwaysMakePathsAbsolute: function () { + return true; + }, + join: function (basePath, laterPath) { + if (!basePath) { + return laterPath; + } + return this.extractUrlParts(laterPath, basePath).path; + }, + doXHR: function (url, type, callback, errback) { + var xhr = new XMLHttpRequest(); + var async = options.isFileProtocol ? options.fileAsync : true; + if (typeof xhr.overrideMimeType === 'function') { + xhr.overrideMimeType('text/css'); + } + logger$1.debug("XHR: Getting '" + url + "'"); + xhr.open('GET', url, async); + xhr.setRequestHeader('Accept', type || 'text/x-less, text/css; q=0.9, */*; q=0.5'); + xhr.send(null); + function handleResponse(xhr, callback, errback) { + if (xhr.status >= 200 && xhr.status < 300) { + callback(xhr.responseText, xhr.getResponseHeader('Last-Modified')); + } + else if (typeof errback === 'function') { + errback(xhr.status, url); + } + } + if (options.isFileProtocol && !options.fileAsync) { + if (xhr.status === 0 || (xhr.status >= 200 && xhr.status < 300)) { + callback(xhr.responseText); + } + else { + errback(xhr.status, url); + } + } + else if (async) { + xhr.onreadystatechange = function () { + if (xhr.readyState == 4) { + handleResponse(xhr, callback, errback); + } + }; + } + else { + handleResponse(xhr, callback, errback); + } + }, + supports: function () { + return true; + }, + clearFileCache: function () { + fileCache = {}; + }, + loadFile: function (filename, currentDirectory, options, environment) { + // TODO: Add prefix support like less-node? + // What about multiple paths? + if (currentDirectory && !this.isPathAbsolute(filename)) { + filename = currentDirectory + filename; + } + filename = options.ext ? this.tryAppendExtension(filename, options.ext) : filename; + options = options || {}; + // sheet may be set to the stylesheet for the initial load or a collection of properties including + // some context variables for imports + var hrefParts = this.extractUrlParts(filename, window.location.href); + var href = hrefParts.url; + var self = this; + return new Promise(function (resolve, reject) { + if (options.useFileCache && fileCache[href]) { + try { + var lessText = fileCache[href]; + return resolve({ contents: lessText, filename: href, webInfo: { lastModified: new Date() } }); + } + catch (e) { + return reject({ filename: href, message: "Error loading file " + href + " error was " + e.message }); + } + } + self.doXHR(href, options.mime, function doXHRCallback(data, lastModified) { + // per file cache + fileCache[href] = data; + // Use remote copy (re-parse) + resolve({ contents: data, filename: href, webInfo: { lastModified: lastModified } }); + }, function doXHRError(status, url) { + reject({ type: 'File', message: "'" + url + "' wasn't found (" + status + ")", href: href }); + }); + }); + } + }); + var FM = (function (opts, log) { + options = opts; + logger$1 = log; + return FileManager; + }); - var ErrorReporting = (function (window, less, options) { - function errorHTML(e, rootHref) { - var id = "less-error-message:" + extractId(rootHref || ''); - var template = '
  • {content}
  • '; - var elem = window.document.createElement('div'); - var timer; - var content; - var errors = []; - var filename = e.filename || rootHref; - var filenameNoPath = filename.match(/([^\/]+(\?.*)?)$/)[1]; - elem.id = id; - elem.className = 'less-error-message'; - content = "

    " + (e.type || 'Syntax') + "Error: " + (e.message || 'There is an error in your .less file') + - ("

    in " + filenameNoPath + " "); - var errorline = function (e, i, classname) { - if (e.extract[i] !== undefined) { - errors.push(template.replace(/\{line\}/, (parseInt(e.line, 10) || 0) + (i - 1)) - .replace(/\{class\}/, classname) - .replace(/\{content\}/, e.extract[i])); - } - }; - if (e.line) { - errorline(e, 0, ''); - errorline(e, 1, 'line'); - errorline(e, 2, ''); - content += "on line " + e.line + ", column " + (e.column + 1) + ":

      " + errors.join('') + "
    "; - } - if (e.stack && (e.extract || options.logLevel >= 4)) { - content += "
    Stack Trace
    " + e.stack.split('\n').slice(1).join('
    '); - } - elem.innerHTML = content; - // CSS for error messages - browser.createCSS(window.document, [ - '.less-error-message ul, .less-error-message li {', - 'list-style-type: none;', - 'margin-right: 15px;', - 'padding: 4px 0;', - 'margin: 0;', - '}', - '.less-error-message label {', - 'font-size: 12px;', - 'margin-right: 15px;', - 'padding: 4px 0;', - 'color: #cc7777;', - '}', - '.less-error-message pre {', - 'color: #dd6666;', - 'padding: 4px 0;', - 'margin: 0;', - 'display: inline-block;', - '}', - '.less-error-message pre.line {', - 'color: #ff0000;', - '}', - '.less-error-message h3 {', - 'font-size: 20px;', - 'font-weight: bold;', - 'padding: 15px 0 5px 0;', - 'margin: 0;', - '}', - '.less-error-message a {', - 'color: #10a', - '}', - '.less-error-message .error {', - 'color: red;', - 'font-weight: bold;', - 'padding-bottom: 2px;', - 'border-bottom: 1px dashed red;', - '}' - ].join('\n'), { title: 'error-message' }); - elem.style.cssText = [ - 'font-family: Arial, sans-serif', - 'border: 1px solid #e00', - 'background-color: #eee', - 'border-radius: 5px', - '-webkit-border-radius: 5px', - '-moz-border-radius: 5px', - 'color: #e00', - 'padding: 15px', - 'margin-bottom: 15px' - ].join(';'); - if (options.env === 'development') { - timer = setInterval(function () { - var document = window.document; - var body = document.body; - if (body) { - if (document.getElementById(id)) { - body.replaceChild(elem, document.getElementById(id)); - } - else { - body.insertBefore(elem, body.firstChild); - } - clearInterval(timer); - } - }, 10); - } - } - function removeErrorHTML(path) { - var node = window.document.getElementById("less-error-message:" + extractId(path)); - if (node) { - node.parentNode.removeChild(node); - } - } - function removeError(path) { - if (!options.errorReporting || options.errorReporting === 'html') { - removeErrorHTML(path); - } - else if (options.errorReporting === 'console') ; - else if (typeof options.errorReporting === 'function') { - options.errorReporting('remove', path); - } - } - function errorConsole(e, rootHref) { - var template = '{line} {content}'; - var filename = e.filename || rootHref; - var errors = []; - var content = (e.type || 'Syntax') + "Error: " + (e.message || 'There is an error in your .less file') + " in " + filename; - var errorline = function (e, i, classname) { - if (e.extract[i] !== undefined) { - errors.push(template.replace(/\{line\}/, (parseInt(e.line, 10) || 0) + (i - 1)) - .replace(/\{class\}/, classname) - .replace(/\{content\}/, e.extract[i])); - } - }; - if (e.line) { - errorline(e, 0, ''); - errorline(e, 1, 'line'); - errorline(e, 2, ''); - content += " on line " + e.line + ", column " + (e.column + 1) + ":\n" + errors.join('\n'); - } - if (e.stack && (e.extract || options.logLevel >= 4)) { - content += "\nStack Trace\n" + e.stack; - } - less.logger.error(content); - } - function error(e, rootHref) { - if (!options.errorReporting || options.errorReporting === 'html') { - errorHTML(e, rootHref); - } - else if (options.errorReporting === 'console') { - errorConsole(e, rootHref); - } - else if (typeof options.errorReporting === 'function') { - options.errorReporting('add', e, rootHref); - } - } - return { - add: error, - remove: removeError - }; - }); + // TODO: Add tests for browser @plugin + /** + * Browser Plugin Loader + */ + var PluginLoader = function (less) { + this.less = less; + // Should we shim this.require for browser? Probably not? + }; + PluginLoader.prototype = Object.assign(new AbstractPluginLoader(), { + loadPlugin: function (filename, basePath, context, environment, fileManager) { + return new Promise(function (fulfill, reject) { + fileManager.loadFile(filename, basePath, context, environment) + .then(fulfill).catch(reject); + }); + } + }); - // Cache system is a bit outdated and could do with work - var Cache = (function (window, options, logger) { - var cache = null; - if (options.env !== 'development') { - try { - cache = (typeof window.localStorage === 'undefined') ? null : window.localStorage; - } - catch (_) { } - } - return { - setCSS: function (path, lastModified, modifyVars, styles) { - if (cache) { - logger.info("saving " + path + " to cache."); - try { - cache.setItem(path, styles); - cache.setItem(path + ":timestamp", lastModified); - if (modifyVars) { - cache.setItem(path + ":vars", JSON.stringify(modifyVars)); - } - } - catch (e) { - // TODO - could do with adding more robust error handling - logger.error("failed to save \"" + path + "\" to local storage for caching."); - } - } - }, - getCSS: function (path, webInfo, modifyVars) { - var css = cache && cache.getItem(path); - var timestamp = cache && cache.getItem(path + ":timestamp"); - var vars = cache && cache.getItem(path + ":vars"); - modifyVars = modifyVars || {}; - vars = vars || "{}"; // if not set, treat as the JSON representation of an empty object - if (timestamp && webInfo.lastModified && - (new Date(webInfo.lastModified).valueOf() === - new Date(timestamp).valueOf()) && - JSON.stringify(modifyVars) === vars) { - // Use local copy - return css; - } - } - }; - }); + var LogListener = (function (less, options) { + var logLevel_debug = 4; + var logLevel_info = 3; + var logLevel_warn = 2; + var logLevel_error = 1; + // The amount of logging in the javascript console. + // 3 - Debug, information and errors + // 2 - Information and errors + // 1 - Errors + // 0 - None + // Defaults to 2 + options.logLevel = typeof options.logLevel !== 'undefined' ? options.logLevel : (options.env === 'development' ? logLevel_info : logLevel_error); + if (!options.loggers) { + options.loggers = [{ + debug: function (msg) { + if (options.logLevel >= logLevel_debug) { + console.log(msg); + } + }, + info: function (msg) { + if (options.logLevel >= logLevel_info) { + console.log(msg); + } + }, + warn: function (msg) { + if (options.logLevel >= logLevel_warn) { + console.warn(msg); + } + }, + error: function (msg) { + if (options.logLevel >= logLevel_error) { + console.error(msg); + } + } + }]; + } + for (var i = 0; i < options.loggers.length; i++) { + less.logger.addListener(options.loggers[i]); + } + }); - var ImageSize = (function () { - function imageSize() { - throw { - type: 'Runtime', - message: 'Image size functions are not supported in browser version of less' - }; - } - var imageFunctions = { - 'image-size': function (filePathNode) { - imageSize(); - return -1; - }, - 'image-width': function (filePathNode) { - imageSize(); - return -1; - }, - 'image-height': function (filePathNode) { - imageSize(); - return -1; - } - }; - functionRegistry.addMultiple(imageFunctions); - }); + var ErrorReporting = (function (window, less, options) { + function errorHTML(e, rootHref) { + var id = "less-error-message:" + extractId(rootHref || ''); + var template = '
  • {content}
  • '; + var elem = window.document.createElement('div'); + var timer; + var content; + var errors = []; + var filename = e.filename || rootHref; + var filenameNoPath = filename.match(/([^\/]+(\?.*)?)$/)[1]; + elem.id = id; + elem.className = 'less-error-message'; + content = "

    " + (e.type || 'Syntax') + "Error: " + (e.message || 'There is an error in your .less file') + + ("

    in " + filenameNoPath + " "); + var errorline = function (e, i, classname) { + if (e.extract[i] !== undefined) { + errors.push(template.replace(/\{line\}/, (parseInt(e.line, 10) || 0) + (i - 1)) + .replace(/\{class\}/, classname) + .replace(/\{content\}/, e.extract[i])); + } + }; + if (e.line) { + errorline(e, 0, ''); + errorline(e, 1, 'line'); + errorline(e, 2, ''); + content += "on line " + e.line + ", column " + (e.column + 1) + ":

      " + errors.join('') + "
    "; + } + if (e.stack && (e.extract || options.logLevel >= 4)) { + content += "
    Stack Trace
    " + e.stack.split('\n').slice(1).join('
    '); + } + elem.innerHTML = content; + // CSS for error messages + browser.createCSS(window.document, [ + '.less-error-message ul, .less-error-message li {', + 'list-style-type: none;', + 'margin-right: 15px;', + 'padding: 4px 0;', + 'margin: 0;', + '}', + '.less-error-message label {', + 'font-size: 12px;', + 'margin-right: 15px;', + 'padding: 4px 0;', + 'color: #cc7777;', + '}', + '.less-error-message pre {', + 'color: #dd6666;', + 'padding: 4px 0;', + 'margin: 0;', + 'display: inline-block;', + '}', + '.less-error-message pre.line {', + 'color: #ff0000;', + '}', + '.less-error-message h3 {', + 'font-size: 20px;', + 'font-weight: bold;', + 'padding: 15px 0 5px 0;', + 'margin: 0;', + '}', + '.less-error-message a {', + 'color: #10a', + '}', + '.less-error-message .error {', + 'color: red;', + 'font-weight: bold;', + 'padding-bottom: 2px;', + 'border-bottom: 1px dashed red;', + '}' + ].join('\n'), { title: 'error-message' }); + elem.style.cssText = [ + 'font-family: Arial, sans-serif', + 'border: 1px solid #e00', + 'background-color: #eee', + 'border-radius: 5px', + '-webkit-border-radius: 5px', + '-moz-border-radius: 5px', + 'color: #e00', + 'padding: 15px', + 'margin-bottom: 15px' + ].join(';'); + if (options.env === 'development') { + timer = setInterval(function () { + var document = window.document; + var body = document.body; + if (body) { + if (document.getElementById(id)) { + body.replaceChild(elem, document.getElementById(id)); + } + else { + body.insertBefore(elem, body.firstChild); + } + clearInterval(timer); + } + }, 10); + } + } + function removeErrorHTML(path) { + var node = window.document.getElementById("less-error-message:" + extractId(path)); + if (node) { + node.parentNode.removeChild(node); + } + } + function removeError(path) { + if (!options.errorReporting || options.errorReporting === 'html') { + removeErrorHTML(path); + } + else if (options.errorReporting === 'console') ; + else if (typeof options.errorReporting === 'function') { + options.errorReporting('remove', path); + } + } + function errorConsole(e, rootHref) { + var template = '{line} {content}'; + var filename = e.filename || rootHref; + var errors = []; + var content = (e.type || 'Syntax') + "Error: " + (e.message || 'There is an error in your .less file') + " in " + filename; + var errorline = function (e, i, classname) { + if (e.extract[i] !== undefined) { + errors.push(template.replace(/\{line\}/, (parseInt(e.line, 10) || 0) + (i - 1)) + .replace(/\{class\}/, classname) + .replace(/\{content\}/, e.extract[i])); + } + }; + if (e.line) { + errorline(e, 0, ''); + errorline(e, 1, 'line'); + errorline(e, 2, ''); + content += " on line " + e.line + ", column " + (e.column + 1) + ":\n" + errors.join('\n'); + } + if (e.stack && (e.extract || options.logLevel >= 4)) { + content += "\nStack Trace\n" + e.stack; + } + less.logger.error(content); + } + function error(e, rootHref) { + if (!options.errorReporting || options.errorReporting === 'html') { + errorHTML(e, rootHref); + } + else if (options.errorReporting === 'console') { + errorConsole(e, rootHref); + } + else if (typeof options.errorReporting === 'function') { + options.errorReporting('add', e, rootHref); + } + } + return { + add: error, + remove: removeError + }; + }); - // - var root = (function (window, options) { - var document = window.document; - var less = lessRoot(); - less.options = options; - var environment = less.environment; - var FileManager = FM(options, less.logger); - var fileManager = new FileManager(); - environment.addFileManager(fileManager); - less.FileManager = FileManager; - less.PluginLoader = PluginLoader; - LogListener(less, options); - var errors = ErrorReporting(window, less, options); - var cache = less.cache = options.cache || Cache(window, options, less.logger); - ImageSize(less.environment); - // Setup user functions - Deprecate? - if (options.functions) { - less.functions.functionRegistry.addMultiple(options.functions); - } - var typePattern = /^text\/(x-)?less$/; - function clone(obj) { - var cloned = {}; - for (var prop in obj) { - if (obj.hasOwnProperty(prop)) { - cloned[prop] = obj[prop]; - } - } - return cloned; - } - // only really needed for phantom - function bind(func, thisArg) { - var curryArgs = Array.prototype.slice.call(arguments, 2); - return function () { - var args = curryArgs.concat(Array.prototype.slice.call(arguments, 0)); - return func.apply(thisArg, args); - }; - } - function loadStyles(modifyVars) { - var styles = document.getElementsByTagName('style'); - var style; - for (var i = 0; i < styles.length; i++) { - style = styles[i]; - if (style.type.match(typePattern)) { - var instanceOptions = clone(options); - instanceOptions.modifyVars = modifyVars; - var lessText = style.innerHTML || ''; - instanceOptions.filename = document.location.href.replace(/#.*$/, ''); - /* jshint loopfunc:true */ - // use closure to store current style - less.render(lessText, instanceOptions, bind(function (style, e, result) { - if (e) { - errors.add(e, 'inline'); - } - else { - style.type = 'text/css'; - if (style.styleSheet) { - style.styleSheet.cssText = result.css; - } - else { - style.innerHTML = result.css; - } - } - }, null, style)); - } - } - } - function loadStyleSheet(sheet, callback, reload, remaining, modifyVars) { - var instanceOptions = clone(options); - addDataAttr(instanceOptions, sheet); - instanceOptions.mime = sheet.type; - if (modifyVars) { - instanceOptions.modifyVars = modifyVars; - } - function loadInitialFileCallback(loadedFile) { - var data = loadedFile.contents; - var path = loadedFile.filename; - var webInfo = loadedFile.webInfo; - var newFileInfo = { - currentDirectory: fileManager.getPath(path), - filename: path, - rootFilename: path, - rewriteUrls: instanceOptions.rewriteUrls - }; - newFileInfo.entryPath = newFileInfo.currentDirectory; - newFileInfo.rootpath = instanceOptions.rootpath || newFileInfo.currentDirectory; - if (webInfo) { - webInfo.remaining = remaining; - var css = cache.getCSS(path, webInfo, instanceOptions.modifyVars); - if (!reload && css) { - webInfo.local = true; - callback(null, css, data, sheet, webInfo, path); - return; - } - } - // TODO add tests around how this behaves when reloading - errors.remove(path); - instanceOptions.rootFileInfo = newFileInfo; - less.render(data, instanceOptions, function (e, result) { - if (e) { - e.href = path; - callback(e); - } - else { - cache.setCSS(sheet.href, webInfo.lastModified, instanceOptions.modifyVars, result.css); - callback(null, result.css, data, sheet, webInfo, path); - } - }); - } - fileManager.loadFile(sheet.href, null, instanceOptions, environment) - .then(function (loadedFile) { - loadInitialFileCallback(loadedFile); - }).catch(function (err) { - console.log(err); - callback(err); - }); - } - function loadStyleSheets(callback, reload, modifyVars) { - for (var i = 0; i < less.sheets.length; i++) { - loadStyleSheet(less.sheets[i], callback, reload, less.sheets.length - (i + 1), modifyVars); - } - } - function initRunningMode() { - if (less.env === 'development') { - less.watchTimer = setInterval(function () { - if (less.watchMode) { - fileManager.clearFileCache(); - loadStyleSheets(function (e, css, _, sheet, webInfo) { - if (e) { - errors.add(e, e.href || sheet.href); - } - else if (css) { - browser.createCSS(window.document, css, sheet); - } - }); - } - }, options.poll); - } - } - // - // Watch mode - // - less.watch = function () { - if (!less.watchMode) { - less.env = 'development'; - initRunningMode(); - } - this.watchMode = true; - return true; - }; - less.unwatch = function () { clearInterval(less.watchTimer); this.watchMode = false; return false; }; - // - // Synchronously get all tags with the 'rel' attribute set to - // "stylesheet/less". - // - less.registerStylesheetsImmediately = function () { - var links = document.getElementsByTagName('link'); - less.sheets = []; - for (var i = 0; i < links.length; i++) { - if (links[i].rel === 'stylesheet/less' || (links[i].rel.match(/stylesheet/) && - (links[i].type.match(typePattern)))) { - less.sheets.push(links[i]); - } - } - }; - // - // Asynchronously get all tags with the 'rel' attribute set to - // "stylesheet/less", returning a Promise. - // - less.registerStylesheets = function () { return new Promise(function (resolve, reject) { - less.registerStylesheetsImmediately(); - resolve(); - }); }; - // - // With this function, it's possible to alter variables and re-render - // CSS without reloading less-files - // - less.modifyVars = function (record) { return less.refresh(true, record, false); }; - less.refresh = function (reload, modifyVars, clearFileCache) { - if ((reload || clearFileCache) && clearFileCache !== false) { - fileManager.clearFileCache(); - } - return new Promise(function (resolve, reject) { - var startTime; - var endTime; - var totalMilliseconds; - var remainingSheets; - startTime = endTime = new Date(); - // Set counter for remaining unprocessed sheets - remainingSheets = less.sheets.length; - if (remainingSheets === 0) { - endTime = new Date(); - totalMilliseconds = endTime - startTime; - less.logger.info('Less has finished and no sheets were loaded.'); - resolve({ - startTime: startTime, - endTime: endTime, - totalMilliseconds: totalMilliseconds, - sheets: less.sheets.length - }); - } - else { - // Relies on less.sheets array, callback seems to be guaranteed to be called for every element of the array - loadStyleSheets(function (e, css, _, sheet, webInfo) { - if (e) { - errors.add(e, e.href || sheet.href); - reject(e); - return; - } - if (webInfo.local) { - less.logger.info("Loading " + sheet.href + " from cache."); - } - else { - less.logger.info("Rendered " + sheet.href + " successfully."); - } - browser.createCSS(window.document, css, sheet); - less.logger.info("CSS for " + sheet.href + " generated in " + (new Date() - endTime) + "ms"); - // Count completed sheet - remainingSheets--; - // Check if the last remaining sheet was processed and then call the promise - if (remainingSheets === 0) { - totalMilliseconds = new Date() - startTime; - less.logger.info("Less has finished. CSS generated in " + totalMilliseconds + "ms"); - resolve({ - startTime: startTime, - endTime: endTime, - totalMilliseconds: totalMilliseconds, - sheets: less.sheets.length - }); - } - endTime = new Date(); - }, reload, modifyVars); - } - loadStyles(modifyVars); - }); - }; - less.refreshStyles = loadStyles; - return less; - }); + // Cache system is a bit outdated and could do with work + var Cache = (function (window, options, logger) { + var cache = null; + if (options.env !== 'development') { + try { + cache = (typeof window.localStorage === 'undefined') ? null : window.localStorage; + } + catch (_) { } + } + return { + setCSS: function (path, lastModified, modifyVars, styles) { + if (cache) { + logger.info("saving " + path + " to cache."); + try { + cache.setItem(path, styles); + cache.setItem(path + ":timestamp", lastModified); + if (modifyVars) { + cache.setItem(path + ":vars", JSON.stringify(modifyVars)); + } + } + catch (e) { + // TODO - could do with adding more robust error handling + logger.error("failed to save \"" + path + "\" to local storage for caching."); + } + } + }, + getCSS: function (path, webInfo, modifyVars) { + var css = cache && cache.getItem(path); + var timestamp = cache && cache.getItem(path + ":timestamp"); + var vars = cache && cache.getItem(path + ":vars"); + modifyVars = modifyVars || {}; + vars = vars || "{}"; // if not set, treat as the JSON representation of an empty object + if (timestamp && webInfo.lastModified && + (new Date(webInfo.lastModified).valueOf() === + new Date(timestamp).valueOf()) && + JSON.stringify(modifyVars) === vars) { + // Use local copy + return css; + } + } + }; + }); - /** - * Kicks off less and compiles any stylesheets - * used in the browser distributed version of less - * to kick-start less using the browser api - */ - var options$1 = defaultOptions(); - if (window.less) { - for (var key in window.less) { - if (window.less.hasOwnProperty(key)) { - options$1[key] = window.less[key]; - } - } - } - addDefaultOptions(window, options$1); - options$1.plugins = options$1.plugins || []; - if (window.LESS_PLUGINS) { - options$1.plugins = options$1.plugins.concat(window.LESS_PLUGINS); - } - var less = root(window, options$1); - window.less = less; - var css; - var head; - var style; - // Always restore page visibility - function resolveOrReject(data) { - if (data.filename) { - console.warn(data); - } - if (!options$1.async) { - head.removeChild(style); - } - } - if (options$1.onReady) { - if (/!watch/.test(window.location.hash)) { - less.watch(); - } - // Simulate synchronous stylesheet loading by hiding page rendering - if (!options$1.async) { - css = 'body { display: none !important }'; - head = document.head || document.getElementsByTagName('head')[0]; - style = document.createElement('style'); - style.type = 'text/css'; - if (style.styleSheet) { - style.styleSheet.cssText = css; - } - else { - style.appendChild(document.createTextNode(css)); - } - head.appendChild(style); - } - less.registerStylesheetsImmediately(); - less.pageLoadFinished = less.refresh(less.env === 'development').then(resolveOrReject, resolveOrReject); - } + var ImageSize = (function () { + function imageSize() { + throw { + type: 'Runtime', + message: 'Image size functions are not supported in browser version of less' + }; + } + var imageFunctions = { + 'image-size': function (filePathNode) { + imageSize(); + return -1; + }, + 'image-width': function (filePathNode) { + imageSize(); + return -1; + }, + 'image-height': function (filePathNode) { + imageSize(); + return -1; + } + }; + functionRegistry.addMultiple(imageFunctions); + }); - return less; + // + var root = (function (window, options) { + var document = window.document; + var less = lessRoot(); + less.options = options; + var environment = less.environment; + var FileManager = FM(options, less.logger); + var fileManager = new FileManager(); + environment.addFileManager(fileManager); + less.FileManager = FileManager; + less.PluginLoader = PluginLoader; + LogListener(less, options); + var errors = ErrorReporting(window, less, options); + var cache = less.cache = options.cache || Cache(window, options, less.logger); + ImageSize(less.environment); + // Setup user functions - Deprecate? + if (options.functions) { + less.functions.functionRegistry.addMultiple(options.functions); + } + var typePattern = /^text\/(x-)?less$/; + function clone(obj) { + var cloned = {}; + for (var prop in obj) { + if (obj.hasOwnProperty(prop)) { + cloned[prop] = obj[prop]; + } + } + return cloned; + } + // only really needed for phantom + function bind(func, thisArg) { + var curryArgs = Array.prototype.slice.call(arguments, 2); + return function () { + var args = curryArgs.concat(Array.prototype.slice.call(arguments, 0)); + return func.apply(thisArg, args); + }; + } + function loadStyles(modifyVars) { + var styles = document.getElementsByTagName('style'); + var style; + for (var i = 0; i < styles.length; i++) { + style = styles[i]; + if (style.type.match(typePattern)) { + var instanceOptions = clone(options); + instanceOptions.modifyVars = modifyVars; + var lessText = style.innerHTML || ''; + instanceOptions.filename = document.location.href.replace(/#.*$/, ''); + /* jshint loopfunc:true */ + // use closure to store current style + less.render(lessText, instanceOptions, bind(function (style, e, result) { + if (e) { + errors.add(e, 'inline'); + } + else { + style.type = 'text/css'; + if (style.styleSheet) { + style.styleSheet.cssText = result.css; + } + else { + style.innerHTML = result.css; + } + } + }, null, style)); + } + } + } + function loadStyleSheet(sheet, callback, reload, remaining, modifyVars) { + var instanceOptions = clone(options); + addDataAttr(instanceOptions, sheet); + instanceOptions.mime = sheet.type; + if (modifyVars) { + instanceOptions.modifyVars = modifyVars; + } + function loadInitialFileCallback(loadedFile) { + var data = loadedFile.contents; + var path = loadedFile.filename; + var webInfo = loadedFile.webInfo; + var newFileInfo = { + currentDirectory: fileManager.getPath(path), + filename: path, + rootFilename: path, + rewriteUrls: instanceOptions.rewriteUrls + }; + newFileInfo.entryPath = newFileInfo.currentDirectory; + newFileInfo.rootpath = instanceOptions.rootpath || newFileInfo.currentDirectory; + if (webInfo) { + webInfo.remaining = remaining; + var css = cache.getCSS(path, webInfo, instanceOptions.modifyVars); + if (!reload && css) { + webInfo.local = true; + callback(null, css, data, sheet, webInfo, path); + return; + } + } + // TODO add tests around how this behaves when reloading + errors.remove(path); + instanceOptions.rootFileInfo = newFileInfo; + less.render(data, instanceOptions, function (e, result) { + if (e) { + e.href = path; + callback(e); + } + else { + cache.setCSS(sheet.href, webInfo.lastModified, instanceOptions.modifyVars, result.css); + callback(null, result.css, data, sheet, webInfo, path); + } + }); + } + fileManager.loadFile(sheet.href, null, instanceOptions, environment) + .then(function (loadedFile) { + loadInitialFileCallback(loadedFile); + }).catch(function (err) { + console.log(err); + callback(err); + }); + } + function loadStyleSheets(callback, reload, modifyVars) { + for (var i = 0; i < less.sheets.length; i++) { + loadStyleSheet(less.sheets[i], callback, reload, less.sheets.length - (i + 1), modifyVars); + } + } + function initRunningMode() { + if (less.env === 'development') { + less.watchTimer = setInterval(function () { + if (less.watchMode) { + fileManager.clearFileCache(); + loadStyleSheets(function (e, css, _, sheet, webInfo) { + if (e) { + errors.add(e, e.href || sheet.href); + } + else if (css) { + browser.createCSS(window.document, css, sheet); + } + }); + } + }, options.poll); + } + } + // + // Watch mode + // + less.watch = function () { + if (!less.watchMode) { + less.env = 'development'; + initRunningMode(); + } + this.watchMode = true; + return true; + }; + less.unwatch = function () { clearInterval(less.watchTimer); this.watchMode = false; return false; }; + // + // Synchronously get all tags with the 'rel' attribute set to + // "stylesheet/less". + // + less.registerStylesheetsImmediately = function () { + var links = document.getElementsByTagName('link'); + less.sheets = []; + for (var i = 0; i < links.length; i++) { + if (links[i].rel === 'stylesheet/less' || (links[i].rel.match(/stylesheet/) && + (links[i].type.match(typePattern)))) { + less.sheets.push(links[i]); + } + } + }; + // + // Asynchronously get all tags with the 'rel' attribute set to + // "stylesheet/less", returning a Promise. + // + less.registerStylesheets = function () { return new Promise(function (resolve, reject) { + less.registerStylesheetsImmediately(); + resolve(); + }); }; + // + // With this function, it's possible to alter variables and re-render + // CSS without reloading less-files + // + less.modifyVars = function (record) { return less.refresh(true, record, false); }; + less.refresh = function (reload, modifyVars, clearFileCache) { + if ((reload || clearFileCache) && clearFileCache !== false) { + fileManager.clearFileCache(); + } + return new Promise(function (resolve, reject) { + var startTime; + var endTime; + var totalMilliseconds; + var remainingSheets; + startTime = endTime = new Date(); + // Set counter for remaining unprocessed sheets + remainingSheets = less.sheets.length; + if (remainingSheets === 0) { + endTime = new Date(); + totalMilliseconds = endTime - startTime; + less.logger.info('Less has finished and no sheets were loaded.'); + resolve({ + startTime: startTime, + endTime: endTime, + totalMilliseconds: totalMilliseconds, + sheets: less.sheets.length + }); + } + else { + // Relies on less.sheets array, callback seems to be guaranteed to be called for every element of the array + loadStyleSheets(function (e, css, _, sheet, webInfo) { + if (e) { + errors.add(e, e.href || sheet.href); + reject(e); + return; + } + if (webInfo.local) { + less.logger.info("Loading " + sheet.href + " from cache."); + } + else { + less.logger.info("Rendered " + sheet.href + " successfully."); + } + browser.createCSS(window.document, css, sheet); + less.logger.info("CSS for " + sheet.href + " generated in " + (new Date() - endTime) + "ms"); + // Count completed sheet + remainingSheets--; + // Check if the last remaining sheet was processed and then call the promise + if (remainingSheets === 0) { + totalMilliseconds = new Date() - startTime; + less.logger.info("Less has finished. CSS generated in " + totalMilliseconds + "ms"); + resolve({ + startTime: startTime, + endTime: endTime, + totalMilliseconds: totalMilliseconds, + sheets: less.sheets.length + }); + } + endTime = new Date(); + }, reload, modifyVars); + } + loadStyles(modifyVars); + }); + }; + less.refreshStyles = loadStyles; + return less; + }); + + /** + * Kicks off less and compiles any stylesheets + * used in the browser distributed version of less + * to kick-start less using the browser api + */ + var options$1 = defaultOptions(); + if (window.less) { + for (var key in window.less) { + if (window.less.hasOwnProperty(key)) { + options$1[key] = window.less[key]; + } + } + } + addDefaultOptions(window, options$1); + options$1.plugins = options$1.plugins || []; + if (window.LESS_PLUGINS) { + options$1.plugins = options$1.plugins.concat(window.LESS_PLUGINS); + } + var less = root(window, options$1); + window.less = less; + var css; + var head; + var style; + // Always restore page visibility + function resolveOrReject(data) { + if (data.filename) { + console.warn(data); + } + if (!options$1.async) { + head.removeChild(style); + } + } + if (options$1.onReady) { + if (/!watch/.test(window.location.hash)) { + less.watch(); + } + // Simulate synchronous stylesheet loading by hiding page rendering + if (!options$1.async) { + css = 'body { display: none !important }'; + head = document.head || document.getElementsByTagName('head')[0]; + style = document.createElement('style'); + style.type = 'text/css'; + if (style.styleSheet) { + style.styleSheet.cssText = css; + } + else { + style.appendChild(document.createTextNode(css)); + } + head.appendChild(style); + } + less.registerStylesheetsImmediately(); + less.pageLoadFinished = less.refresh(less.env === 'development').then(resolveOrReject, resolveOrReject); + } + + return less; }))); diff --git a/packages/less/dist/less.min.js b/packages/less/dist/less.min.js index 88206ab4b..050af49bb 100644 --- a/packages/less/dist/less.min.js +++ b/packages/less/dist/less.min.js @@ -1,5 +1,5 @@ /** - * Less - Leaner CSS v3.13.1 + * Less - Leaner CSS v4.0.0 * http://lesscss.org * * Copyright (c) 2009-2020, Alexis Sellier @@ -7,5 +7,5 @@ * * @license Apache-2.0 */ -!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(e=e||self).less=t()}(this,(function(){"use strict";function e(e){return e.replace(/^[a-z-]+:\/+?[^\/]+/,"").replace(/[\?\&]livereload=\w+/,"").replace(/^\//,"").replace(/\.[a-zA-Z]+$/,"").replace(/[^\.\w-]+/g,"-").replace(/\./g,":")}function t(e,t){for(var i in t.dataset)if(t.dataset.hasOwnProperty(i))if("env"===i||"dumpLineNumbers"===i||"rootpath"===i||"errorReporting"===i)e[i]=t.dataset[i];else try{e[i]=JSON.parse(t.dataset[i])}catch(e){}}var i=function(t,i,n){var r=n.href||"",s="less:"+(n.title||e(r)),o=t.getElementById(s),a=!1,l=t.createElement("style");l.setAttribute("type","text/css"),n.media&&l.setAttribute("media",n.media),l.id=s,l.styleSheet||(l.appendChild(t.createTextNode(i)),a=null!==o&&o.childNodes.length>0&&l.childNodes.length>0&&o.firstChild.nodeValue===l.firstChild.nodeValue);var u=t.getElementsByTagName("head")[0];if(null===o||!1===a){var h=n&&n.nextSibling||null;h?h.parentNode.insertBefore(l,h):u.appendChild(l)}if(o&&!1===a&&o.parentNode.removeChild(o),l.styleSheet)try{l.styleSheet.cssText=i}catch(e){throw new Error("Couldn't reassign styleSheet.cssText.")}},n=function(e){var t,i=e.document;return i.currentScript||(t=i.getElementsByTagName("script"))[t.length-1]},r=function(e,t){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var i in t)t.hasOwnProperty(i)&&(e[i]=t[i])})(e,t)};function s(e,t){function i(){this.constructor=e}r(e,t),e.prototype=null===t?Object.create(t):(i.prototype=t.prototype,new i)}function o(){for(var e=0,t=0,i=arguments.length;tt?1:void 0};var c=function(e,t,i){var n=this;Array.isArray(e)?this.rgb=e:e.length>=6?(this.rgb=[],e.match(/.{2}/g).map((function(e,t){t<3?n.rgb.push(parseInt(e,16)):n.alpha=parseInt(e,16)/255}))):(this.rgb=[],e.split("").map((function(e,t){t<3?n.rgb.push(parseInt(e+e,16)):n.alpha=parseInt(e+e,16)/255}))),this.alpha=this.alpha||("number"==typeof t?t:1),void 0!==i&&(this.value=i)};function f(e,t){return Math.min(Math.max(e,0),t)}function p(e){return"#"+e.map((function(e){return((e=f(Math.round(e),255))<16?"0":"")+e.toString(16)})).join("")}(c.prototype=new h).luma=function(){var e=this.rgb[0]/255,t=this.rgb[1]/255,i=this.rgb[2]/255;return.2126*(e=e<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4))+.7152*(t=t<=.03928?t/12.92:Math.pow((t+.055)/1.055,2.4))+.0722*(i=i<=.03928?i/12.92:Math.pow((i+.055)/1.055,2.4))},c.prototype.genCSS=function(e,t){t.add(this.toCSS(e))},c.prototype.toCSS=function(e,t){var i,n,r,s=e&&e.compress&&!t,o=[];if(n=this.fround(e,this.alpha),this.value)if(0===this.value.indexOf("rgb"))n<1&&(r="rgba");else{if(0!==this.value.indexOf("hsl"))return this.value;r=n<1?"hsla":"hsl"}else n<1&&(r="rgba");switch(r){case"rgba":o=this.rgb.map((function(e){return f(Math.round(e),255)})).concat(f(n,1));break;case"hsla":o.push(f(n,1));case"hsl":i=this.toHSL(),o=[this.fround(e,i.h),this.fround(e,100*i.s)+"%",this.fround(e,100*i.l)+"%"].concat(o)}if(r)return r+"("+o.join(","+(s?"":" "))+")";if(i=this.toRGB(),s){var a=i.split("");a[1]===a[2]&&a[3]===a[4]&&a[5]===a[6]&&(i="#"+a[1]+a[3]+a[5])}return i},c.prototype.operate=function(e,t,i){for(var n=new Array(3),r=this.alpha*(1-i.alpha)+i.alpha,s=0;s<3;s++)n[s]=this._operate(e,t,this.rgb[s],i.rgb[s]);return new c(n,r)},c.prototype.toRGB=function(){return p(this.rgb)},c.prototype.toHSL=function(){var e,t,i=this.rgb[0]/255,n=this.rgb[1]/255,r=this.rgb[2]/255,s=this.alpha,o=Math.max(i,n,r),a=Math.min(i,n,r),l=(o+a)/2,u=o-a;if(o===a)e=t=0;else{switch(t=l>.5?u/(2-o-a):u/(o+a),o){case i:e=(n-r)/u+(n=0&&"\n"!==t.charAt(i);)r++;return"number"==typeof e&&(n=(t.slice(0,e).match(/\n/g)||"").length),{line:n,column:r}}function _(e){var t,i=e.length,n=new Array(i);for(t=0;t|Function):(\d+):(\d+)/,F=function(e,t,i){Error.call(this);var n=e.filename||i;if(this.message=e.message,this.stack=e.stack,t&&n){var r=t.contents[n],s=k(e.index,r),o=s.line,a=s.column,l=e.call&&k(e.call,r).line,u=r?r.split("\n"):"";if(this.type=e.type||"Syntax",this.filename=n,this.index=e.index,this.line="number"==typeof o?o+1:null,this.column=a,!this.line&&this.stack){var h=this.stack.match(V),c=new Function("a","throw new Error()"),f=0;try{c()}catch(e){var p=e.stack.match(V);f=1-parseInt(p[2])}h&&(h[2]&&(this.line=parseInt(h[2])+f),h[3]&&(this.column=parseInt(h[3])))}this.callLine=l+1,this.callExtract=u[l],this.extract=[u[this.line-2],u[this.line-1],u[this.line]]}};if(void 0===Object.create){var $=function(){};$.prototype=Error.prototype,F.prototype=new $}else F.prototype=Object.create(Error.prototype);F.prototype.constructor=F,F.prototype.toString=function(e){void 0===e&&(e={});var t="",i=this.extract||[],n=[],r=function(e){return e};if(e.stylize){var s=typeof e.stylize;if("function"!==s)throw Error("options.stylize should be a function, got a "+s+"!");r=e.stylize}if(null!==this.line){if("string"==typeof i[0]&&n.push(r(this.line-1+" "+i[0],"grey")),"string"==typeof i[1]){var o=this.line+" ";i[1]&&(o+=i[1].slice(0,this.column)+r(r(r(i[1].substr(this.column,1),"bold")+i[1].slice(this.column+1),"red"),"inverse")),n.push(o)}"string"==typeof i[2]&&n.push(r(this.line+1+" "+i[2],"grey")),n=n.join("\n")+r("","reset")+"\n"}return t+=r(this.type+"Error: "+this.message,"red"),this.filename&&(t+=r(" in ","red")+this.filename),this.line&&(t+=r(" on line "+this.line+", column "+(this.column+1)+":","grey")),t+="\n"+n,this.callLine&&(t+=r("from ","red")+(this.filename||"")+"/n",t+=r(this.callLine,"grey")+" "+this.callExtract+"/n"),t};var O=function(e,t,i,n,r,s){this.extendList=t,this.condition=i,this.evaldCondition=!i,this._index=n,this._fileInfo=r,this.elements=this.getElements(e),this.mixinElements_=void 0,this.copyVisibilityInfo(s),this.setParent(this.elements,this)};(O.prototype=new h).accept=function(e){this.elements&&(this.elements=e.visitArray(this.elements)),this.extendList&&(this.extendList=e.visitArray(this.extendList)),this.condition&&(this.condition=e.visit(this.condition))},O.prototype.createDerived=function(e,t,i){e=this.getElements(e);var n=new O(e,t||this.extendList,null,this.getIndex(),this.fileInfo(),this.visibilityInfo());return n.evaldCondition=null!=i?i:this.evaldCondition,n.mediaEmpty=this.mediaEmpty,n},O.prototype.getElements=function(e){return e?("string"==typeof e&&this.parse.parseNode(e,["selector"],this._index,this._fileInfo,(function(t,i){if(t)throw new F({index:t.index,message:t.message},this.parse.imports,this._fileInfo.filename);e=i[0].elements})),e):[new g("","&",!1,this._index,this._fileInfo)]},O.prototype.createEmptySelectors=function(){var e=new g("","&",!1,this._index,this._fileInfo),t=[new O([e],null,null,this._index,this._fileInfo)];return t[0].mediaEmpty=!0,t},O.prototype.match=function(e){var t,i,n=this.elements,r=n.length;if(0===(t=(e=e.mixinElements()).length)||ry.PARENS_DIVISION)||this.parensStack&&this.parensStack.length))},e.prototype.pathRequiresRewrite=function(e){return(this.rewriteUrls===w?H:J)(e)},e.prototype.rewritePath=function(e,t){var i;return t=t||"",i=this.normalizePath(t+e),H(e)&&J(t)&&!1===H(i)&&(i="./"+i),i},e.prototype.normalizePath=function(e){var t,i=e.split("/").reverse();for(e=[];0!==i.length;)switch(t=i.pop()){case".":break;case"..":0===e.length||".."===e[e.length-1]?e.push(t):e.pop();break;default:e.push(t)}return e.join("/")},e}();var Q=function e(t){return{_data:{},add:function(e,t){e=e.toLowerCase(),this._data.hasOwnProperty(e),this._data[e]=t},addMultiple:function(e){var t=this;Object.keys(e).forEach((function(i){t.add(i,e[i])}))},get:function(e){return this._data[e]||t&&t.get(e)},getLocalFunctions:function(){return this._data},inherit:function(){return e(this)},create:function(t){return e(t)}}}(null),K={eval:function(){var e=this.value_,t=this.error_;if(t)throw t;if(null!=e)return e?N.True:N.False},value:function(e){this.value_=e},error:function(e){this.error_=e},reset:function(){this.value_=this.error_=null}},Z=function(e,t,i,n){this.selectors=e,this.rules=t,this._lookups={},this._variables=null,this._properties=null,this.strictImports=i,this.copyVisibilityInfo(n),this.allowRoot=!0,this.setParent(this.selectors,this),this.setParent(this.rules,this)};(Z.prototype=new h).isRulesetLike=function(){return!0},Z.prototype.accept=function(e){this.paths?this.paths=e.visitArray(this.paths,!0):this.selectors&&(this.selectors=e.visitArray(this.selectors)),this.rules&&this.rules.length&&(this.rules=e.visitArray(this.rules))},Z.prototype.eval=function(e){var t,i,n,r,s,o=!1;if(this.selectors&&(i=this.selectors.length)){for(t=new Array(i),K.error({type:"Syntax",message:"it is currently only allowed in parametric mixin guards,"}),r=0;r0;e--){var t=this.rules[e-1];if(t instanceof U)return this.parseValue(t)}},Z.prototype.parseValue=function(e){var t=this;function i(e){return e.value instanceof D&&!e.parsed?("string"==typeof e.value.value?this.parse.parseNode(e.value.value,["value","important"],e.value.getIndex(),e.fileInfo(),(function(t,i){t&&(e.parsed=!0),i&&(e.value=i[0],e.important=i[1]||"",e.parsed=!0)})):e.parsed=!0,e):e}if(Array.isArray(e)){var n=[];return e.forEach((function(e){n.push(i.call(t,e))})),n}return i.call(t,e)},Z.prototype.rulesets=function(){if(!this.rules)return[];var e,t,i=[],n=this.rules;for(e=0;t=n[e];e++)t.isRuleset&&i.push(t);return i},Z.prototype.prependRule=function(e){var t=this.rules;t?t.unshift(e):this.rules=[e],this.setParent(e,this)},Z.prototype.find=function(e,t,i){void 0===t&&(t=this);var n,r,s=[],o=e.toCSS();return o in this._lookups?this._lookups[o]:(this.rulesets().forEach((function(o){if(o!==t)for(var a=0;an){if(!i||i(o)){r=o.find(new O(e.elements.slice(n)),t,i);for(var l=0;l0&&t.add(l),e.firstSelector=!0,o[0].genCSS(e,t),e.firstSelector=!1,n=1;n0?(s=(r=_(e)).pop(),o=n.createDerived(_(s.elements))):o=n.createDerived([]),t.length>0){var a=i.combinator,l=t[0].elements[0];a.emptyOrWhitespace&&!l.combinator.emptyOrWhitespace&&(a=l.combinator),o.elements.push(new g(a,l.value,i.isVariable,i._index,i._fileInfo)),o.elements=o.elements.concat(t[0].elements.slice(1))}if(0!==o.elements.length&&r.push(o),t.length>1){var u=t.slice(1);u=u.map((function(e){return e.createDerived(e.elements,[])})),r=r.concat(u)}return r}function o(e,t,i,n,r){var o;for(o=0;o0?n[n.length-1]=n[n.length-1].createDerived(n[n.length-1].elements.concat(e)):n.push(new O(e));else t.push([new O(e)])}function l(e,t){var i=t.createDerived(t.elements,t.extendList,t.evaldCondition);return i.copyVisibilityInfo(e),i}var u,h;if(!function e(t,i,l){var u,h,c,f,p,v,m,y,b,w,x,S,I=!1;for(f=[],p=[[]],u=0;y=l.elements[u];u++)if("&"!==y.value){var C=(S=void 0,(x=y).value instanceof d&&(S=x.value.value)instanceof O?S:null);if(null!=C){a(f,p);var k,_=[],A=[];for(k=e(_,i,C),I=I||k,c=0;c<_.length;c++){o(p,[r(n(_[c],y),y)],y,l,A)}p=A,f=[]}else f.push(y)}else{for(I=!0,v=[],a(f,p),h=0;h0&&m[0].elements.push(new g(y.combinator,"",y.isVariable,y._index,y._fileInfo)),v.push(m);else for(c=0;c0&&(t.push(p[u]),w=p[u][b-1],p[u][b-1]=w.createDerived(w.elements,l.extendList));return I}(h=[],t,i))if(t.length>0)for(h=[],u=0;u0)for(t=0;t-1e-6&&(n=i.toFixed(20).replace(/0+$/,"")),e&&e.compress){if(0===i&&this.unit.isLength())return void t.add(n);i>0&&i<1&&(n=n.substr(1))}t.add(n),this.unit.genCSS(e,t)},te.prototype.operate=function(e,t,i){var n=this._operate(e,t,this.value,i.value),r=this.unit.clone();if("+"===t||"-"===t)if(0===r.numerator.length&&0===r.denominator.length)r=i.unit.clone(),this.unit.backupUnit&&(r.backupUnit=this.unit.backupUnit);else if(0===i.unit.numerator.length&&0===r.denominator.length);else{if(i=i.convertTo(this.unit.usedUnits()),e.strictUnits&&i.unit.toString()!==r.toString())throw new Error("Incompatible units. Change the units or use the unit function. Bad units: '"+r.toString()+"' and '"+i.unit.toString()+"'.");n=this._operate(e,t,this.value,i.value)}else"*"===t?(r.numerator=r.numerator.concat(i.unit.numerator).sort(),r.denominator=r.denominator.concat(i.unit.denominator).sort(),r.cancel()):"/"===t&&(r.numerator=r.numerator.concat(i.unit.denominator).sort(),r.denominator=r.denominator.concat(i.unit.numerator).sort(),r.cancel());return new te(n,r)},te.prototype.compare=function(e){var t,i;if(e instanceof te){if(this.unit.isEmpty()||e.unit.isEmpty())t=this,i=e;else if(t=this.unify(),i=e.unify(),0!==t.unit.compare(i.unit))return;return h.numericCompare(t.value,i.value)}},te.prototype.unify=function(){return this.convertTo({length:"px",duration:"s",angle:"rad"})},te.prototype.convertTo=function(e){var t,i,n,r,s,o=this.value,a=this.unit.clone(),u={};if("string"==typeof e){for(t in l)l[t].hasOwnProperty(e)&&((u={})[t]=e);e=u}for(i in s=function(e,t){return n.hasOwnProperty(e)?(t?o/=n[e]/n[r]:o*=n[e]/n[r],r):e},e)e.hasOwnProperty(i)&&(r=e[i],n=l[i],a.map(s));return a.cancel(),new te(o,a)},te.prototype.type="Dimension";var ie=y,ne=function(e,t,i){this.op=e.trim(),this.operands=t,this.isSpaced=i};(ne.prototype=new h).accept=function(e){this.operands=e.visitArray(this.operands)},ne.prototype.eval=function(e){var t,i=this.operands[0].eval(e),n=this.operands[1].eval(e);if(e.isMathOn(this.op)){if(t="./"===this.op?"/":this.op,i instanceof te&&n instanceof c&&(i=i.toColor()),n instanceof te&&i instanceof c&&(n=n.toColor()),!i.operate){if(i instanceof ne&&"/"===i.op&&e.math===ie.PARENS_DIVISION)return new ne(this.op,[i,n],this.isSpaced);throw{type:"Operation",message:"Operation on an invalid type"}}return i.operate(e,t,n)}return new ne(this.op,[i,n],this.isSpaced)},ne.prototype.genCSS=function(e,t){this.operands[0].genCSS(e,t),this.isSpaced&&t.add(" "),t.add(this.op),this.isSpaced&&t.add(" "),this.operands[1].genCSS(e,t)},ne.prototype.type="Operation";var re=y,se=function(e,t){if(this.value=e,this.noSpacing=t,!e)throw new Error("Expression requires an array parameter")};(se.prototype=new h).accept=function(e){this.value=e.visitArray(this.value)},se.prototype.eval=function(e){var t,i=e.isMathOn(),n=this.parens&&(e.math!==re.STRICT_LEGACY||!this.parensInOp),r=!1;return n&&e.inParenthesis(),this.value.length>1?t=new se(this.value.map((function(t){return t.eval?t.eval(e):t})),this.noSpacing):1===this.value.length?(!this.value[0].parens||this.value[0].parensInOp||e.inCalc||(r=!0),t=this.value[0].eval(e)):t=this,n&&e.outOfParenthesis(),!this.parens||!this.parensInOp||i||r||t instanceof te||(t=new d(t)),t},se.prototype.genCSS=function(e,t){for(var i=0;i1){var i=new O([],null,null,this.getIndex(),this.fileInfo()).createEmptySelectors();(t=new Z(i,e.mediaBlocks)).multiMedia=!0,t.copyVisibilityInfo(this.visibilityInfo()),this.setParent(t,this)}return delete e.mediaBlocks,delete e.mediaPath,t},pe.prototype.evalNested=function(e){var t,i,n=e.mediaPath.concat([this]);for(t=0;t0;t--)e.splice(t,0,new D("and"));return new se(e)}))),this.setParent(this.features,this),new Z([],[])},pe.prototype.permute=function(e){if(0===e.length)return[];if(1===e.length)return e[0];for(var t=[],i=this.permute(e.slice(1)),n=0;n1?"["+e.value.map((function(e){return e.toCSS()})).join(", ")+"]":e.toCSS()};var me=function(e,t,i,n){this.escaped=t,this.expression=e,this._index=i,this._fileInfo=n};(me.prototype=new ve).eval=function(e){var t=this.evaluateJavaScript(this.expression,e),i=typeof t;return"number"!==i||isNaN(t)?"string"===i?new ce('"'+t+'"',t,this.escaped,this._index):Array.isArray(t)?new D(t.join(", ")):new D(t):new te(t)},me.prototype.type="JavaScript";var ge=function(e,t){this.key=e,this.value=t};(ge.prototype=new h).accept=function(e){this.value=e.visit(this.value)},ge.prototype.eval=function(e){return this.value.eval?new ge(this.key,this.value.eval(e)):this},ge.prototype.genCSS=function(e,t){t.add(this.key+"="),this.value.genCSS?this.value.genCSS(e,t):t.add(this.value)},ge.prototype.type="Assignment";var ye=function(e,t,i,n,r){this.op=e.trim(),this.lvalue=t,this.rvalue=i,this._index=n,this.negate=r};(ye.prototype=new h).accept=function(e){this.lvalue=e.visit(this.lvalue),this.rvalue=e.visit(this.rvalue)},ye.prototype.eval=function(e){var t=function(e,t,i){switch(e){case"and":return t&&i;case"or":return t||i;default:switch(h.compare(t,i)){case-1:return"<"===e||"=<"===e||"<="===e;case 0:return"="===e||">="===e||"=<"===e||"<="===e;case 1:return">"===e||">="===e;default:return!1}}}(this.op,this.lvalue.eval(e),this.rvalue.eval(e));return this.negate?!t:t},ye.prototype.type="Condition";var be=function(e){this.value=e};(be.prototype=new h).type="UnicodeDescriptor";var we=function(e){this.value=e};(we.prototype=new h).genCSS=function(e,t){t.add("-"),this.value.genCSS(e,t)},we.prototype.eval=function(e){return e.isMathOn()?new ne("*",[new te(-1),this.value]).eval(e):new we(this.value.eval(e))},we.prototype.type="Negative";var xe=function(e,t,i,n,r){switch(this.selector=e,this.option=t,this.object_id=xe.next_id++,this.parent_ids=[this.object_id],this._index=i,this._fileInfo=n,this.copyVisibilityInfo(r),this.allowRoot=!0,t){case"all":this.allowBefore=!0,this.allowAfter=!0;break;default:this.allowBefore=!1,this.allowAfter=!1}this.setParent(this.selector,this)};xe.prototype=new h,xe.prototype.accept=function(e){this.selector=e.visit(this.selector)},xe.prototype.eval=function(e){return new xe(this.selector.eval(e),this.option,this.getIndex(),this.fileInfo(),this.visibilityInfo())},xe.prototype.clone=function(e){return new xe(this.selector,this.option,this.getIndex(),this.fileInfo(),this.visibilityInfo())},xe.prototype.findSelfSelectors=function(e){var t,i,n=[];for(t=0;t0&&i.length&&""===i[0].combinator.value&&(i[0].combinator.value=" "),n=n.concat(e[t].elements);this.selfSelectors=[new O(n)],this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo())},xe.next_id=0,xe.prototype.type="Extend";var Se=function(e,t,i){this.variable=e,this._index=t,this._fileInfo=i,this.allowRoot=!0};(Se.prototype=new h).eval=function(e){var t,i=new le(this.variable,this.getIndex(),this.fileInfo()).eval(e),n=new F({message:"Could not evaluate variable call "+this.variable});if(!i.ruleset){if(i.rules)t=i;else if(Array.isArray(i))t=new Z("",i);else{if(!Array.isArray(i.value))throw n;t=new Z("",i.value)}i=new X(t)}if(i.ruleset)return i.callEval(e);throw n},Se.prototype.type="VariableCall";var Ie=function(e,t,i,n){this.value=e,this.lookups=t,this._index=i,this._fileInfo=n};(Ie.prototype=new h).eval=function(e){var t,i,n=this.value.eval(e);for(t=0;tthis.params.length)return!1}i=Math.min(s,this.arity);for(var o=0;o0){for(h=!0,a=0;a0)f=2;else if(f=1,p[1]+p[2]>1)throw{type:"Runtime",message:"Ambiguous use of `default()` found when matching for `"+this.format(m)+"`",index:this.getIndex(),filename:this.fileInfo().filename};for(a=0;a=0;o--){var a=s[o];if(a[r?"supportsSync":"supports"](e,t,i,n))return a}return null},e.prototype.addFileManager=function(e){this.fileManagers.push(e)},e.prototype.clearFileManagers=function(){this.fileManagers=[]},e}(),Pe=function(){function e(){}return e.prototype.getPath=function(e){var t=e.lastIndexOf("?");return t>0&&(e=e.slice(0,t)),(t=e.lastIndexOf("/"))<0&&(t=e.lastIndexOf("\\")),t<0?"":e.slice(0,t+1)},e.prototype.tryAppendExtension=function(e,t){return/(\.[a-z]*$)|([\?;].*)$/.test(e)?e:e+t},e.prototype.tryAppendLessExtension=function(e){return this.tryAppendExtension(e,".less")},e.prototype.supportsSync=function(){return!1},e.prototype.alwaysMakePathsAbsolute=function(){return!1},e.prototype.isPathAbsolute=function(e){return/^(?:[a-z-]+:|\/|\\|#)/i.test(e)},e.prototype.join=function(e,t){return e?e+t:t},e.prototype.pathDiff=function(e,t){var i,n,r,s,o=this.extractUrlParts(e),a=this.extractUrlParts(t),l="";if(o.hostPart!==a.hostPart)return"";for(n=Math.max(a.directories.length,o.directories.length),i=0;iparseInt(t[i])?-1:1;return 0},e.prototype.versionToString=function(e){for(var t="",i=0;i0;){var e=this.imports[0];if(!e.isReady)return;this.imports=this.imports.slice(1),e.callback.apply(null,e.args)}if(0===this.variableImports.length)break;var t=this.variableImports[0];this.variableImports=this.variableImports.slice(1),t()}}finally{this._currentDepth--}0===this._currentDepth&&this._onSequencerEmpty&&this._onSequencerEmpty()},e}(),Le=function(e,t){this._visitor=new $e(this),this._importer=e,this._finish=t,this.context=new T.Eval,this.importCount=0,this.onceFileDetectionMap={},this.recursionDetector={},this._sequencer=new Oe(this._onSequencerEmpty.bind(this))};Le.prototype={isReplacing:!1,run:function(e){try{this._visitor.visit(e)}catch(e){this.error=e}this.isFinished=!0,this._sequencer.tryRun()},_onSequencerEmpty:function(){this.isFinished&&this._finish(this.error)},visitImport:function(e,t){var i=e.options.inline;if(!e.css||i){var n=new T.Eval(this.context,_(this.context.frames)),r=n.frames[0];this.importCount++,e.isVariableImport()?this._sequencer.addVariableImport(this.processImportNode.bind(this,e,n,r)):this.processImportNode(e,n,r)}t.visitDeeper=!1},processImportNode:function(e,t,i){var n,r=e.options.inline;try{n=e.evalForImport(t)}catch(t){t.filename||(t.index=e.getIndex(),t.filename=e.fileInfo().filename),e.css=!0,e.error=t}if(!n||n.css&&!r)this.importCount--,this.isFinished&&this._sequencer.tryRun();else{n.options.multiple&&(t.importMultiple=!0);for(var s=void 0===n.css,o=0;o=0||(a=[u.selfSelectors[0]],(s=f.findMatch(l,a)).length&&(l.hasFoundMatches=!0,l.selfSelectors.forEach((function(e){var t=u.visibilityInfo();o=f.extendSelector(s,a,e,l.isVisible()),(h=new _e.Extend(u.selector,u.option,0,u.fileInfo(),t)).selfSelectors=o,o[o.length-1].extendList=[h],c.push(h),h.ruleset=u.ruleset,h.parent_ids=h.parent_ids.concat(u.parent_ids,l.parent_ids),u.firstExtendOnThisSelectorPath&&(h.firstExtendOnThisSelectorPath=!0,u.ruleset.paths.push(o))}))));if(c.length){if(this.extendChainCount++,i>100){var p="{unable to calculate}",d="{unable to calculate}";try{p=c[0].selfSelectors[0].toCSS(),d=c[0].selector.toCSS()}catch(e){}throw{message:"extend circular reference detected. One of the circular extends is currently:"+p+":extend("+d+")"}}return c.concat(f.doExtendChaining(c,t,i+1))}return c},e.prototype.visitDeclaration=function(e,t){t.visitDeeper=!1},e.prototype.visitMixinDefinition=function(e,t){t.visitDeeper=!1},e.prototype.visitSelector=function(e,t){t.visitDeeper=!1},e.prototype.visitRuleset=function(e,t){if(!e.root){var i,n,r,s,o=this.allExtendsStack[this.allExtendsStack.length-1],a=[],l=this;for(r=0;r0&&u[l.matched].combinator.value!==o?l=null:l.matched++,l&&(l.finished=l.matched===u.length,l.finished&&!e.allowAfter&&(r+1u&&h>0&&(c[c.length-1].elements=c[c.length-1].elements.concat(t[u].elements.slice(h)),h=0,u++),l=s.elements.slice(h,a.index).concat([o]).concat(i.elements.slice(1)),u===a.pathIndex&&r>0?c[c.length-1].elements=c[c.length-1].elements.concat(l):(c=c.concat(t.slice(u,a.pathIndex))).push(new _e.Selector(l)),u=a.endPathIndex,(h=a.endPathElementIndex)>=t[u].elements.length&&(h=0,u++);return u0&&(c[c.length-1].elements=c[c.length-1].elements.concat(t[u].elements.slice(h)),u++),c=(c=c.concat(t.slice(u,t.length))).map((function(e){var t=e.createDerived(e.elements);return n?t.ensureVisibility():t.ensureInvisibility(),t}))},e.prototype.visitMedia=function(e,t){var i=e.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length-1]);i=i.concat(this.doExtendChaining(i,e.allExtends)),this.allExtendsStack.push(i)},e.prototype.visitMediaOut=function(e){var t=this.allExtendsStack.length-1;this.allExtendsStack.length=t},e.prototype.visitAtRule=function(e,t){var i=e.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length-1]);i=i.concat(this.doExtendChaining(i,e.allExtends)),this.allExtendsStack.push(i)},e.prototype.visitAtRuleOut=function(e){var t=this.allExtendsStack.length-1;this.allExtendsStack.length=t},e}(),Ue=function(){function e(){this.contexts=[[]],this._visitor=new $e(this)}return e.prototype.run=function(e){return this._visitor.visit(e)},e.prototype.visitDeclaration=function(e,t){t.visitDeeper=!1},e.prototype.visitMixinDefinition=function(e,t){t.visitDeeper=!1},e.prototype.visitRuleset=function(e,t){var i,n=this.contexts[this.contexts.length-1],r=[];this.contexts.push(r),e.root||((i=e.selectors)&&(i=i.filter((function(e){return e.getIsOutput()})),e.selectors=i.length?i:i=null,i&&e.joinSelectors(r,n,i)),i||(e.rules=null),e.paths=r)},e.prototype.visitRulesetOut=function(e){this.contexts.length=this.contexts.length-1},e.prototype.visitMedia=function(e,t){var i=this.contexts[this.contexts.length-1];e.rules[0].root=0===i.length||i[0].multiMedia},e.prototype.visitAtRule=function(e,t){var i=this.contexts[this.contexts.length-1];e.rules&&e.rules.length&&(e.rules[0].root=e.isRooted||0===i.length||null)},e}(),je=function(){function e(e){this._visitor=new $e(this),this._context=e}return e.prototype.containsSilentNonBlockedChild=function(e){var t;if(!e)return!1;for(var i=0;i0},e.prototype.resolveVisibility=function(e,t){if(!e.blocksVisibility()){if(this.isEmpty(e)&&!this.containsSilentNonBlockedChild(t))return;return e}var i=e.rules[0];if(this.keepOnlyVisibleChilds(i),!this.isEmpty(i))return e.ensureVisibility(),e.removeVisibilityBlock(),e},e.prototype.isVisibleRuleset=function(e){return!!e.firstRoot||!this.isEmpty(e)&&!(!e.root&&!this.hasVisibleSelector(e))},e}(),qe=function(e){this._visitor=new $e(this),this._context=e,this.utils=new je(e)};qe.prototype={isReplacing:!0,run:function(e){return this._visitor.visit(e)},visitDeclaration:function(e,t){if(!e.blocksVisibility()&&!e.variable)return e},visitMixinDefinition:function(e,t){e.frames=[]},visitExtend:function(e,t){},visitComment:function(e,t){if(!e.blocksVisibility()&&!e.isSilent(this._context))return e},visitMedia:function(e,t){var i=e.rules[0].rules;return e.accept(this._visitor),t.visitDeeper=!1,this.utils.resolveVisibility(e,i)},visitImport:function(e,t){if(!e.blocksVisibility())return e},visitAtRule:function(e,t){return e.rules&&e.rules.length?this.visitAtRuleWithBody(e,t):this.visitAtRuleWithoutBody(e,t)},visitAnonymous:function(e,t){if(!e.blocksVisibility())return e.accept(this._visitor),e},visitAtRuleWithBody:function(e,t){var i=function(e){var t=e.rules;return function(e){var t=e.rules;return 1===t.length&&(!t[0].paths||0===t[0].paths.length)}(e)?t[0].rules:t}(e);return e.accept(this._visitor),t.visitDeeper=!1,this.utils.isEmpty(e)||this._mergeRules(e.rules[0].rules),this.utils.resolveVisibility(e,i)},visitAtRuleWithoutBody:function(e,t){if(!e.blocksVisibility()){if("@charset"===e.name){if(this.charset){if(e.debugInfo){var i=new _e.Comment("/* "+e.toCSS(this._context).replace(/\n/g,"")+" */\n");return i.debugInfo=e.debugInfo,this._visitor.visit(i)}return}this.charset=!0}return e}},checkValidNodes:function(e,t){if(e)for(var i=0;i0?e.accept(this._visitor):e.rules=null,t.visitDeeper=!1}return e.rules&&(this._mergeRules(e.rules),this._removeDuplicateRules(e.rules)),this.utils.isVisibleRuleset(e)&&(e.ensureVisibility(),n.splice(0,0,e)),1===n.length?n[0]:n},_compileRulesetPaths:function(e){e.paths&&(e.paths=e.paths.filter((function(e){var t;for(" "===e[0].elements[0].combinator.value&&(e[0].elements[0].combinator=new _e.Combinator("")),t=0;t=0;n--)if((i=e[n])instanceof _e.Declaration)if(r[i.name]){(t=r[i.name])instanceof _e.Declaration&&(t=r[i.name]=[r[i.name].toCSS(this._context)]);var s=i.toCSS(this._context);-1!==t.indexOf(s)?e.splice(n,1):t.push(s)}else r[i.name]=i}},_mergeRules:function(e){if(e){for(var t={},i=[],n=0;n0){var t=e[0],i=[],n=[new _e.Expression(i)];e.forEach((function(e){"+"===e.merge&&i.length>0&&n.push(new _e.Expression(i=[])),i.push(e.value),t.important=t.important||e.important})),t.value=new _e.Value(n)}}))}}};var Te={Visitor:$e,ImportVisitor:Le,MarkVisibleSelectorsVisitor:Ne,ExtendVisitor:Be,JoinSelectorVisitor:Ue,ToCSSVisitor:qe},ze=function(){var e,t,i,n,r,s,o,a=[],l={};function u(i){for(var n,a,h,c=l.i,f=t,p=l.i-o,d=l.i+s.length-p,v=l.i+=i,m=e;l.i=0){h={index:l.i,text:m.substr(l.i,y+2-l.i),isLineComment:!1},l.i+=h.text.length-1,l.commentStore.push(h);continue}}break}if(32!==n&&10!==n&&9!==n&&13!==n)break}if(s=s.slice(i+l.i-v+p),o=l.i,!s.length){if(ti||l.i===i&&e&&!n)&&(i=l.i,n=e);var r=a.pop();s=r.current,o=l.i=r.i,t=r.j},l.forget=function(){a.pop()},l.isWhitespace=function(t){var i=l.i+(t||0),n=e.charCodeAt(i);return 32===n||13===n||9===n||10===n},l.$re=function(e){l.i>o&&(s=s.slice(l.i-o),o=l.i);var t=e.exec(s);return t?(u(t[0].length),"string"==typeof t?t:1===t.length?t[0]:t):null},l.$char=function(t){return e.charAt(l.i)!==t?null:(u(1),t)},l.$str=function(t){for(var i=t.length,n=0;nc&&(v=!1)}}while(v);return r||null},l.autoCommentAbsorb=!0,l.commentStore=[],l.finished=!1,l.peek=function(t){if("string"==typeof t){for(var i=0;i57||t<43||47===t||44===t},l.start=function(n,a,h){e=n,l.i=t=o=i=0,r=a?function(e,t){var i,n,r,s,o,a,l,u,h,c=e.length,f=0,p=0,d=[],v=0;function m(t){var i=o-v;i<512&&!t||!i||(d.push(e.slice(v,o+1)),v=o+1)}for(o=0;o=97&&l<=122||l<34))switch(l){case 40:p++,n=o;continue;case 41:if(--p<0)return t("missing opening `(`",o);continue;case 59:p||m();continue;case 123:f++,i=o;continue;case 125:if(--f<0)return t("missing opening `{`",o);f||p||m();continue;case 92:if(o96)){if(u==l){h=1;break}if(92==u){if(o==c-1)return t("unescaped `\\`",o);o++}}if(h)continue;return t("unmatched `"+String.fromCharCode(l)+"`",a);case 47:if(p||o==c-1)continue;if(47==(u=e.charCodeAt(o+1)))for(o+=2;oi&&s>r?"missing closing `}` or `*/`":"missing closing `}`",i):0!==p?t("missing closing `)`",n):(m(!0),d)}(n,h):[n],s=r[0],u(0)},l.end=function(){var t,r=l.i>=e.length;return l.i=e.length-1,furthestChar:e[l.i]}},l},Ge=function e(t,i,n){var r,s=ze();function o(e,t){throw new F({index:s.i,filename:n.filename,type:t||"Syntax",message:e},i)}function a(e,t){var i=e instanceof Function?e.call(r):s.$re(e);if(i)return i;o(t||("string"==typeof e?"expected '"+e+"' got '"+s.currentChar()+"'":"unexpected token"))}function l(e,t){if(s.$char(e))return e;o(t||"expected '"+e+"' got '"+s.currentChar()+"'")}function u(e){var t=n.filename;return{lineNumber:k(e,s.getInput()).line+1,fileName:t}}return{parserInput:s,imports:i,fileInfo:n,parseNode:function(e,t,n,o,a){var l,u=[],h=s;try{h.start(e,!1,(function(e,t){a({message:e,index:t+n})}));for(var c=0,f=void 0,p=void 0;f=t[c];c++)if(p=h.i,l=r[f]()){try{l._index=p+n,l._fileInfo=o}catch(e){}u.push(l)}else u.push(null);h.end().isFinished?a(null,u):a(!0,null)}catch(e){throw new F({index:e.index+n,message:e.message},i,o.filename)}},parse:function(r,o,a){var l,u,h,c,f=null,p="";if(u=a&&a.globalVars?e.serializeVars(a.globalVars)+"\n":"",h=a&&a.modifyVars?"\n"+e.serializeVars(a.modifyVars):"",t.pluginManager)for(var d=t.pluginManager.getPreProcessors(),v=0;v");return e},args:function(e){var t,i,n,a,l,u,h,c=r.entities,f={args:null,variadic:!1},p=[],d=[],v=[],m=!0;for(s.save();;){if(e)u=r.detachedRuleset()||r.expression();else{if(s.commentStore.length=0,s.$str("...")){f.variadic=!0,s.$char(";")&&!t&&(t=!0),(t?d:v).push({variadic:!0});break}u=c.variable()||c.property()||c.literal()||c.keyword()||this.call(!0)}if(!u||!m)break;a=null,u.throwAwayComments&&u.throwAwayComments(),l=u;var g=null;if(e?u.value&&1==u.value.length&&(g=u.value[0]):g=u,g&&(g instanceof _e.Variable||g instanceof _e.Property))if(s.$char(":")){if(p.length>0&&(t&&o("Cannot mix ; and , as delimiter types"),i=!0),!(l=r.detachedRuleset()||r.expression())){if(!e)return s.restore(),f.args=[],f;o("could not understand value for named argument")}a=n=g.name}else if(s.$str("...")){if(!e){f.variadic=!0,s.$char(";")&&!t&&(t=!0),(t?d:v).push({name:u.name,variadic:!0});break}h=!0}else e||(n=a=g.name,l=null);l&&p.push(l),v.push({name:a,value:l,expand:h}),s.$char(",")?m=!0:((m=";"===s.$char(";"))||t)&&(i&&o("Cannot mix ; and , as delimiter types"),t=!0,p.length>1&&(l=new _e.Value(p)),d.push({name:n,value:l,expand:h}),n=null,p=[],i=!1)}return s.forget(),f.args=t?d:v,f},definition:function(){var e,t,i,n,o=[],l=!1;if(!("."!==s.currentChar()&&"#"!==s.currentChar()||s.peek(/^[^{]*\}/)))if(s.save(),t=s.$re(/^([#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\s*\(/)){e=t[1];var u=this.args(!1);if(o=u.args,l=u.variadic,!s.$char(")"))return void s.restore("Missing closing ')'");if(s.commentStore.length=0,s.$str("when")&&(n=a(r.conditions,"expected condition")),i=r.block())return s.forget(),new _e.mixin.Definition(e,o,i,n,l);s.restore()}else s.restore()},ruleLookups:function(){var e,t=[];if("["===s.currentChar()){for(;;){if(s.save(),!(e=this.lookupValue())&&""!==e){s.restore();break}t.push(e),s.forget()}return t.length>0?t:void 0}},lookupValue:function(){if(s.save(),s.$char("[")){var e=s.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/);if(s.$char("]"))return e||""===e?(s.forget(),e):void s.restore();s.restore()}else s.restore()}},entity:function(){var e=this.entities;return this.comment()||e.literal()||e.variable()||e.url()||e.property()||e.call()||e.keyword()||this.mixin.call(!0)||e.javascript()},end:function(){return s.$char(";")||s.peek("}")},ieAlpha:function(){var e;if(s.$re(/^opacity=/i))return(e=s.$re(/^\d+/))||(e="@{"+(e=a(r.entities.variable,"Could not parse alpha")).name.slice(1)+"}"),l(")"),new _e.Quoted("","alpha(opacity="+e+")")},element:function(){var e,t,i,r=s.i;if(t=this.combinator(),(e=s.$re(/^(?:\d+\.\d+|\d+)%/)||s.$re(/^(?:[.#]?|:*)(?:[\w-]|[^\x00-\x9f]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/)||s.$char("*")||s.$char("&")||this.attribute()||s.$re(/^\([^&()@]+\)/)||s.$re(/^[\.#:](?=@)/)||this.entities.variableCurly())||(s.save(),s.$char("(")?(i=this.selector(!1))&&s.$char(")")?(e=new _e.Paren(i),s.forget()):s.restore("Missing closing ')'"):s.forget()),e)return new _e.Element(t,e,e instanceof _e.Variable,r,n)},combinator:function(){var e=s.currentChar();if("/"===e){s.save();var t=s.$re(/^\/[a-z]+\//i);if(t)return s.forget(),new _e.Combinator(t);s.restore()}if(">"===e||"+"===e||"~"===e||"|"===e||"^"===e){for(s.i++,"^"===e&&"^"===s.currentChar()&&(e="^^",s.i++);s.isWhitespace();)s.i++;return new _e.Combinator(e)}return s.isWhitespace(-1)?new _e.Combinator(" "):new _e.Combinator(null)},selector:function(e){var t,i,r,l,u,h,c,f=s.i;for(e=!1!==e;(e&&(i=this.extend())||e&&(h=s.$str("when"))||(l=this.element()))&&(h?c=a(this.conditions,"expected condition"):c?o("CSS guard can only be used at the end of selector"):i?u=u?u.concat(i):i:(u&&o("Extend can only be used at the end of selector"),r=s.currentChar(),t?t.push(l):t=[l],l=null),"{"!==r&&"}"!==r&&";"!==r&&","!==r&&")"!==r););if(t)return new _e.Selector(t,u,c,f,n);u&&o("Extend must be used to extend a selector, it cannot be used on its own")},selectors:function(){for(var e,t;(e=this.selector())&&(t?t.push(e):t=[e],s.commentStore.length=0,e.condition&&t.length>1&&o("Guards are only currently allowed on a single selector."),s.$char(","));)e.condition&&o("Guards are only currently allowed on a single selector."),s.commentStore.length=0;return t},attribute:function(){if(s.$char("[")){var e,t,i,n=this.entities;return(e=n.variableCurly())||(e=a(/^(?:[_A-Za-z0-9-\*]*\|)?(?:[_A-Za-z0-9-]|\\.)+/)),(i=s.$re(/^[|~*$^]?=/))&&(t=n.quoted()||s.$re(/^[0-9]+%/)||s.$re(/^[\w-]+/)||n.variableCurly()),l("]"),new _e.Attribute(e,i,t)}},block:function(){var e;if(s.$char("{")&&(e=this.primary())&&s.$char("}"))return e},blockRuleset:function(){var e=this.block();return e&&(e=new _e.Ruleset(null,e)),e},detachedRuleset:function(){var e,t,i;if(s.save(),!s.$re(/^[.#]\(/)||(t=(e=this.mixin.args(!1)).args,i=e.variadic,s.$char(")"))){var n=this.blockRuleset();if(n)return s.forget(),t?new _e.mixin.Definition(null,t,n,null,i):new _e.DetachedRuleset(n);s.restore()}else s.restore()},ruleset:function(){var e,i,n;if(s.save(),t.dumpLineNumbers&&(n=u(s.i)),(e=this.selectors())&&(i=this.block())){s.forget();var r=new _e.Ruleset(e,i,t.strictImports);return t.dumpLineNumbers&&(r.debugInfo=n),r}s.restore()},declaration:function(){var e,t,i,r,o,a,l=s.i,u=s.currentChar();if("."!==u&&"#"!==u&&"&"!==u&&":"!==u)if(s.save(),e=this.variable()||this.ruleProperty()){if((a="string"==typeof e)&&(t=this.detachedRuleset())&&(i=!0),s.commentStore.length=0,!t){if(o=!a&&e.length>1&&e.pop().value,t=e[0].value&&"--"===e[0].value.slice(0,2)?this.permissiveValue():this.anonymousValue())return s.forget(),new _e.Declaration(e,t,!1,o,l,n);t||(t=this.value()),t?r=this.important():a&&(t=this.permissiveValue())}if(t&&(this.end()||i))return s.forget(),new _e.Declaration(e,t,r,o,l,n);s.restore()}else s.restore()},anonymousValue:function(){var e=s.i,t=s.$re(/^([^.#@\$+\/'"*`(;{}-]*);/);if(t)return new _e.Anonymous(t[1],e)},permissiveValue:function(e){var t,i,r,a,l=e||";",u=s.i,h=[];function c(){var e=s.currentChar();return"string"==typeof l?e===l:l.test(e)}if(!c()){a=[];do{((i=this.comment())||(i=this.entity()))&&a.push(i)}while(i);if(r=c(),a.length>0){if(a=new _e.Expression(a),r)return a;h.push(a)," "===s.prevChar()&&h.push(new _e.Anonymous(" ",u))}if(s.save(),a=s.$parseUntil(l)){if("string"==typeof a&&o("Expected '"+a+"'","Parse"),1===a.length&&" "===a[0])return s.forget(),new _e.Anonymous("",u);var f=void 0;for(t=0;t0)return new _e.Expression(r)},mediaFeatures:function(){var e,t=this.entities,i=[];do{if(e=this.mediaFeature()){if(i.push(e),!s.$char(","))break}else if((e=t.variable()||t.mixinLookup())&&(i.push(e),!s.$char(",")))break}while(e);return i.length>0?i:null},media:function(){var e,i,r,a,l=s.i;if(t.dumpLineNumbers&&(a=u(l)),s.save(),s.$str("@media"))return e=this.mediaFeatures(),(i=this.block())||o("media definitions require block statements after any features"),s.forget(),r=new _e.Media(i,e,l,n),t.dumpLineNumbers&&(r.debugInfo=a),r;s.restore()},plugin:function(){var e,t,i,r=s.i;if(s.$re(/^@plugin?\s+/)){if(i=(t=this.pluginArgs())?{pluginArgs:t,isPlugin:!0}:{isPlugin:!0},e=this.entities.quoted()||this.entities.url())return s.$char(";")||(s.i=r,o("missing semi-colon on @plugin")),new _e.Import(e,null,i,r,n);s.i=r,o("malformed @plugin statement")}},pluginArgs:function(){if(s.save(),!s.$char("("))return s.restore(),null;var e=s.$re(/^\s*([^\);]+)\)\s*/);return e[1]?(s.forget(),e[1].trim()):(s.restore(),null)},atrule:function(){var e,i,r,a,l,h,c,f=s.i,p=!0,d=!0;if("@"===s.currentChar()){if(i=this.import()||this.plugin()||this.media())return i;if(s.save(),e=s.$re(/^@[a-z-]+/)){switch(a=e,"-"==e.charAt(1)&&e.indexOf("-",2)>0&&(a="@"+e.slice(e.indexOf("-",2)+1)),a){case"@charset":l=!0,p=!1;break;case"@namespace":h=!0,p=!1;break;case"@keyframes":case"@counter-style":l=!0;break;case"@document":case"@supports":c=!0,d=!1;break;default:c=!0}if(s.commentStore.length=0,l?(i=this.entity())||o("expected "+e+" identifier"):h?(i=this.expression())||o("expected "+e+" expression"):c&&(i=this.permissiveValue(/^[{;]/),p="{"===s.currentChar(),i?i.value||(i=null):p||";"===s.currentChar()||o(e+" rule is missing block or ending semi-colon")),p&&(r=this.blockRuleset()),r||!p&&i&&s.$char(";"))return s.forget(),new _e.AtRule(e,i,r,f,n,t.dumpLineNumbers?u(f):null,d);s.restore("at-rule options not recognised")}}},value:function(){var e,t=[],i=s.i;do{if((e=this.expression())&&(t.push(e),!s.$char(",")))break}while(e);if(t.length>0)return new _e.Value(t,i)},important:function(){if("!"===s.currentChar())return s.$re(/^! *important/)},sub:function(){var e,t;if(s.save(),s.$char("("))return(e=this.addition())&&s.$char(")")?(s.forget(),(t=new _e.Expression([e])).parens=!0,t):void s.restore("Expected ')'");s.restore()},multiplication:function(){var e,t,i,n,r;if(e=this.operand()){for(r=s.isWhitespace(-1);!s.peek(/^\/[*\/]/);){if(s.save(),!(i=s.$char("/")||s.$char("*")||s.$str("./"))){s.forget();break}if(!(t=this.operand())){s.restore();break}s.forget(),e.parensInOp=!0,t.parensInOp=!0,n=new _e.Operation(i,[n||e,t],r),r=s.isWhitespace(-1)}return n||e}},addition:function(){var e,t,i,n,r;if(e=this.multiplication()){for(r=s.isWhitespace(-1);(i=s.$re(/^[-+]\s+/)||!r&&(s.$char("+")||s.$char("-")))&&(t=this.multiplication());)e.parensInOp=!0,t.parensInOp=!0,n=new _e.Operation(i,[n||e,t],r),r=s.isWhitespace(-1);return n||e}},conditions:function(){var e,t,i,n=s.i;if(e=this.condition(!0)){for(;s.peek(/^,\s*(not\s*)?\(/)&&s.$char(",")&&(t=this.condition(!0));)i=new _e.Condition("or",i||e,t,n);return i||e}},condition:function(e){var t,i,n;if(t=this.conditionAnd(e)){if(i=s.$str("or")){if(!(n=this.condition(e)))return;t=new _e.Condition(i,t,n)}return t}},conditionAnd:function(e){var t,i,n,r,o=this;if(t=(r=o.negatedCondition(e)||o.parenthesisCondition(e))||e?r:o.atomicCondition(e)){if(i=s.$str("and")){if(!(n=this.conditionAnd(e)))return;t=new _e.Condition(i,t,n)}return t}},negatedCondition:function(e){if(s.$str("not")){var t=this.parenthesisCondition(e);return t&&(t.negate=!t.negate),t}},parenthesisCondition:function(e){var t;if(s.save(),s.$str("(")){if(t=function(t){var i;if(s.save(),i=t.condition(e)){if(s.$char(")"))return s.forget(),i;s.restore()}else s.restore()}(this))return s.forget(),t;if(t=this.atomicCondition(e)){if(s.$char(")"))return s.forget(),t;s.restore("expected ')' got '"+s.currentChar()+"'")}else s.restore()}else s.restore()},atomicCondition:function(e){var t,i,n,r,a=this.entities,l=s.i;function u(){return this.addition()||a.keyword()||a.quoted()||a.mixinLookup()}if(t=(u=u.bind(this))())return s.$char(">")?r=s.$char("=")?">=":">":s.$char("<")?r=s.$char("=")?"<=":"<":s.$char("=")&&(r=s.$char(">")?"=>":s.$char("<")?"=<":"="),r?(i=u())?n=new _e.Condition(r,t,i,l,!1):o("expected expression"):n=new _e.Condition("=",t,new _e.Keyword("true"),l,!1),n},operand:function(){var e,t=this.entities;s.peek(/^-[@\$\(]/)&&(e=s.$char("-"));var i=this.sub()||t.dimension()||t.color()||t.variable()||t.property()||t.call()||t.quoted(!0)||t.colorKeyword()||t.mixinLookup();return e&&(i.parensInOp=!0,i=new _e.Negative(i)),i},expression:function(){var e,t,i=[],n=s.i;do{(e=this.comment())?i.push(e):((e=this.addition()||this.entity())instanceof _e.Comment&&(e=null),e&&(i.push(e),s.peek(/^\/[\/*]/)||(t=s.$char("/"))&&i.push(new _e.Anonymous(t,n))))}while(e);if(i.length>0)return new _e.Expression(i)},property:function(){var e=s.$re(/^(\*?-?[_a-zA-Z0-9-]+)\s*:/);if(e)return e[1]},ruleProperty:function(){var e,t,i=[],r=[];s.save();var o=s.$re(/^([_a-zA-Z0-9-]+)\s*:/);if(o)return i=[new _e.Keyword(o[1])],s.forget(),i;function a(e){var t=s.i,n=s.$re(e);if(n)return r.push(t),i.push(n[1])}for(a(/^(\*?)/);a(/^((?:[\w-]+)|(?:[@\$]\{[\w-]+\}))/););if(i.length>1&&a(/^((?:\+_|\+)?)\s*:/)){for(s.forget(),""===i[0]&&(i.shift(),r.shift()),t=0;t1?e-1:e)<1?r+(s-r)*e*6:2*e<1?s:3*e<2?r+(s-r)*(2/3-e)*6:r}e=Xe(e)%360/360,t=Qe(Xe(t)),i=Qe(Xe(i)),n=Qe(Xe(n)),r=2*i-(s=i<=.5?i*(t+1):i+t-i*t);var a=[255*o(e+1/3),255*o(e),255*o(e-1/3)];return n=Xe(n),new c(a,n,"hsla")}catch(e){}},hsv:function(e,t,i){return Je.hsva(e,t,i,1)},hsva:function(e,t,i,n){var r,s;e=Xe(e)%360/360*360,t=Xe(t),i=Xe(i),n=Xe(n);var o=[i,i*(1-t),i*(1-(s=e/60-(r=Math.floor(e/60%6)))*t),i*(1-(1-s)*t)],a=[[0,3,1],[2,0,1],[1,0,3],[1,2,0],[3,1,0],[0,1,2]];return Je.rgba(255*o[a[r][0]],255*o[a[r][1]],255*o[a[r][2]],n)},hue:function(e){return new te(Ze(e).h)},saturation:function(e){return new te(100*Ze(e).s,"%")},lightness:function(e){return new te(100*Ze(e).l,"%")},hsvhue:function(e){return new te(Ye(e).h)},hsvsaturation:function(e){return new te(100*Ye(e).s,"%")},hsvvalue:function(e){return new te(100*Ye(e).v,"%")},red:function(e){return new te(e.rgb[0])},green:function(e){return new te(e.rgb[1])},blue:function(e){return new te(e.rgb[2])},alpha:function(e){return new te(Ze(e).a)},luma:function(e){return new te(e.luma()*e.alpha*100,"%")},luminance:function(e){var t=.2126*e.rgb[0]/255+.7152*e.rgb[1]/255+.0722*e.rgb[2]/255;return new te(t*e.alpha*100,"%")},saturate:function(e,t,i){if(!e.rgb)return null;var n=Ze(e);return void 0!==i&&"relative"===i.value?n.s+=n.s*t.value/100:n.s+=t.value/100,n.s=Qe(n.s),Ke(e,n)},desaturate:function(e,t,i){var n=Ze(e);return void 0!==i&&"relative"===i.value?n.s-=n.s*t.value/100:n.s-=t.value/100,n.s=Qe(n.s),Ke(e,n)},lighten:function(e,t,i){var n=Ze(e);return void 0!==i&&"relative"===i.value?n.l+=n.l*t.value/100:n.l+=t.value/100,n.l=Qe(n.l),Ke(e,n)},darken:function(e,t,i){var n=Ze(e);return void 0!==i&&"relative"===i.value?n.l-=n.l*t.value/100:n.l-=t.value/100,n.l=Qe(n.l),Ke(e,n)},fadein:function(e,t,i){var n=Ze(e);return void 0!==i&&"relative"===i.value?n.a+=n.a*t.value/100:n.a+=t.value/100,n.a=Qe(n.a),Ke(e,n)},fadeout:function(e,t,i){var n=Ze(e);return void 0!==i&&"relative"===i.value?n.a-=n.a*t.value/100:n.a-=t.value/100,n.a=Qe(n.a),Ke(e,n)},fade:function(e,t){var i=Ze(e);return i.a=t.value/100,i.a=Qe(i.a),Ke(e,i)},spin:function(e,t){var i=Ze(e),n=(i.h+t.value)%360;return i.h=n<0?360+n:n,Ke(e,i)},mix:function(e,t,i){i||(i=new te(50));var n=i.value/100,r=2*n-1,s=Ze(e).a-Ze(t).a,o=((r*s==-1?r:(r+s)/(1+r*s))+1)/2,a=1-o,l=[e.rgb[0]*o+t.rgb[0]*a,e.rgb[1]*o+t.rgb[1]*a,e.rgb[2]*o+t.rgb[2]*a],u=e.alpha*n+t.alpha*(1-n);return new c(l,u)},greyscale:function(e){return Je.desaturate(e,new te(100))},contrast:function(e,t,i,n){if(!e.rgb)return null;if(void 0===i&&(i=Je.rgba(255,255,255,1)),void 0===t&&(t=Je.rgba(0,0,0,1)),t.luma()>i.luma()){var r=i;i=t,t=r}return n=void 0===n?.43:Xe(n),e.luma().5&&(n=1,i=e>.25?Math.sqrt(e):((16*e-12)*e+4)*e),e-(1-2*t)*n*(i-e)},hardlight:function(e,t){return it.overlay(t,e)},difference:function(e,t){return Math.abs(e-t)},exclusion:function(e,t){return e+t-2*e*t},average:function(e,t){return(e+t)/2},negation:function(e,t){return 1-Math.abs(e+t-1)}};for(var nt in it)it.hasOwnProperty(nt)&&(tt[nt]=tt.bind(null,it[nt]));var rt=function(e){return Array.isArray(e.value)?e.value:Array(e)},st={_SELF:function(e){return e},extract:function(e,t){return t=t.value-1,rt(e)[t]},length:function(e){return new te(rt(e).length)},range:function(e,t,i){var n,r,s=1,o=[];t?(r=t,n=e.value,i&&(s=i.value)):(n=1,r=e);for(var a=n;a<=r.value;a+=s)o.push(new te(a,r.unit));return new se(o)},each:function(e,t){var i,n,r=this,s=[],o=function(e){return e instanceof h?e.eval(r.context):e};n=!e.value||e instanceof ce?e.ruleset?o(e.ruleset).rules:e.rules?e.rules.map(o):Array.isArray(e)?e.map(o):[o(e)]:Array.isArray(e.value)?e.value.map(o):[o(e.value)];var a="@value",l="@key",u="@index";t.params?(a=t.params[0]&&t.params[0].name,l=t.params[1]&&t.params[1].name,u=t.params[2]&&t.params[2].name,t=t.rules):t=t.ruleset;for(var c=0;co.value)&&(h[n]=r);else{if(void 0!==l&&a!==l)throw{type:"Argument",message:"incompatible types"};c[a]=h.length,h.push(r)}else Array.isArray(t[i].value)&&Array.prototype.push.apply(t,Array.prototype.slice.call(t[i].value));return 1==h.length?h[0]:(t=h.map((function(e){return e.toCSS(this.context)})).join(this.context.compress?",":", "),new D((e?"min":"max")+"("+t+")"))},ht={min:function(){for(var e=[],t=0;t",r=0;r";return n+="',n=encodeURIComponent(n),new fe(new ce("'"+(n="data:image/svg+xml,"+n)+"'",n,!1,this.index,this.currentFileInfo),this.index,this.currentFileInfo)}}),Q.addMultiple(dt),t},mt=function(e,t){var i;void 0===t&&(t={});var n=t.variables,r=new T.Eval(t);"object"!=typeof n||Array.isArray(n)||(n=Object.keys(n).map((function(e){var t=n[e];return t instanceof _e.Value||(t instanceof _e.Expression||(t=new _e.Expression([t])),t=new _e.Value([t])),new _e.Declaration("@"+e,t,!1,null,0)})),r.frames=[new _e.Ruleset(null,n)]);var s,o,a=[new Te.JoinSelectorVisitor,new Te.MarkVisibleSelectorsVisitor(!0),new Te.ExtendVisitor,new Te.ToCSSVisitor({compress:Boolean(t.compress)})],l=[];if(t.pluginManager){o=t.pluginManager.visitor();for(var u=0;u<2;u++)for(o.first();s=o.get();)s.isPreEvalVisitor?0!==u&&-1!==l.indexOf(s)||(l.push(s),s.run(e)):0!==u&&-1!==a.indexOf(s)||(s.isPreVisitor?a.unshift(s):a.push(s))}i=e.eval(r);for(u=0;u=t);i++);this.preProcessors.splice(i,0,{preProcessor:e,priority:t})},e.prototype.addPostProcessor=function(e,t){var i;for(i=0;i=t);i++);this.postProcessors.splice(i,0,{postProcessor:e,priority:t})},e.prototype.addFileManager=function(e){this.fileManagers.push(e)},e.prototype.getPreProcessors=function(){for(var e=[],t=0;t0){var n=void 0,r=JSON.stringify(this._sourceMapGenerator.toJSON());this.sourceMapURL?n=this.sourceMapURL:this._sourceMapFilename&&(n=this._sourceMapFilename),this.sourceMapURL=n,this.sourceMap=r}return this._css.join("")},t}()}(e=new Me(e,t)),r=function(e,t){return function(){function i(e){this.options=e}return i.prototype.toCSS=function(t,i,n){var r=new e({contentsIgnoredCharsMap:n.contentsIgnoredChars,rootNode:t,contentsMap:n.contents,sourceMapFilename:this.options.sourceMapFilename,sourceMapURL:this.options.sourceMapURL,outputFilename:this.options.sourceMapOutputFilename,sourceMapBasepath:this.options.sourceMapBasepath,sourceMapRootpath:this.options.sourceMapRootpath,outputSourceFiles:this.options.outputSourceFiles,sourceMapGenerator:this.options.sourceMapGenerator,sourceMapFileInline:this.options.sourceMapFileInline,disableSourcemapAnnotation:this.options.disableSourcemapAnnotation}),s=r.toCSS(i);return this.sourceMap=r.sourceMap,this.sourceMapURL=r.sourceMapURL,this.options.sourceMapInputFilename&&(this.sourceMapInputFilename=r.normalizeFilename(this.options.sourceMapInputFilename)),void 0!==this.options.sourceMapBasepath&&void 0!==this.sourceMapURL&&(this.sourceMapURL=r.removeBasepath(this.sourceMapURL)),s+this.getCSSAppendage()},i.prototype.getCSSAppendage=function(){var e=this.sourceMapURL;if(this.options.sourceMapFileInline){if(void 0===this.sourceMap)return"";e="data:application/json;base64,"+t.encodeBase64(this.sourceMap)}return this.options.disableSourcemapAnnotation?"":e?"/*# sourceMappingURL="+e+" */":""},i.prototype.getExternalSourceMap=function(){return this.sourceMap},i.prototype.setExternalSourceMap=function(e){this.sourceMap=e},i.prototype.isInline=function(){return this.options.sourceMapFileInline},i.prototype.getSourceMapURL=function(){return this.sourceMapURL},i.prototype.getOutputFilename=function(){return this.options.sourceMapOutputFilename},i.prototype.getInputFilename=function(){return this.sourceMapInputFilename},i}()}(n,e),s=function(e){return function(){function t(e,t){this.root=e,this.imports=t}return t.prototype.toCSS=function(t){var i,n,r={};try{i=mt(this.root,t)}catch(e){throw new F(e,this.imports)}try{var s=Boolean(t.compress);s&&Ae.warn("The compress option has been deprecated. We recommend you use a dedicated css minifier, for instance see less-plugin-clean-css.");var o={compress:s,dumpLineNumbers:t.dumpLineNumbers,strictUnits:Boolean(t.strictUnits),numPrecision:8};t.sourceMap?(n=new e(t.sourceMap),r.css=n.toCSS(i,o,this.imports)):r.css=i.toCSS(o)}catch(e){throw new F(e,this.imports)}if(t.pluginManager)for(var a=t.pluginManager.getPostProcessors(),l=0;l=200&&t.status<300?i(t.responseText,t.getResponseHeader("Last-Modified")):"function"==typeof n&&n(t.status,e)}"function"==typeof r.overrideMimeType&&r.overrideMimeType("text/css"),xt.debug("XHR: Getting '"+e+"'"),r.open("GET",e,s),r.setRequestHeader("Accept",t||"text/x-less, text/css; q=0.9, */*; q=0.5"),r.send(null),wt.isFileProtocol&&!wt.fileAsync?0===r.status||r.status>=200&&r.status<300?i(r.responseText):n(r.status,e):s?r.onreadystatechange=function(){4==r.readyState&&o(r,i,n)}:o(r,i,n)},t.prototype.supports=function(){return!0},t.prototype.clearFileCache=function(){It={}},t.prototype.loadFile=function(e,t,i,n){t&&!this.isPathAbsolute(e)&&(e=t+e),e=i.ext?this.tryAppendExtension(e,i.ext):e,i=i||{};var r=this.extractUrlParts(e,window.location.href).url,s=this;return new Promise((function(e,t){if(i.useFileCache&&It[r])try{var n=It[r];return e({contents:n,filename:r,webInfo:{lastModified:new Date}})}catch(e){return t({filename:r,message:"Error loading file "+r+" error was "+e.message})}s.doXHR(r,i.mime,(function(t,i){It[r]=t,e({contents:t,filename:r,webInfo:{lastModified:i}})}),(function(e,i){t({type:"File",message:"'"+i+"' wasn't found ("+e+")",href:r})}))}))},t}(Pe),kt=function(e,t){return wt=e,xt=t,Ct},_t=function(e){function t(t){var i=e.call(this)||this;return i.less=t,i}return s(t,e),t.prototype.loadPlugin=function(e,t,i,n,r){return new Promise((function(s,o){r.loadFile(e,t,i,n).then(s).catch(o)}))},t}(Ee),At=function(t,n,r){return{add:function(s,o){r.errorReporting&&"html"!==r.errorReporting?"console"===r.errorReporting?function(e,t){var i=e.filename||t,s=[],o=(e.type||"Syntax")+"Error: "+(e.message||"There is an error in your .less file")+" in "+i,a=function(e,t,i){void 0!==e.extract[t]&&s.push("{line} {content}".replace(/\{line\}/,(parseInt(e.line,10)||0)+(t-1)).replace(/\{class\}/,i).replace(/\{content\}/,e.extract[t]))};e.line&&(a(e,0,""),a(e,1,"line"),a(e,2,""),o+=" on line "+e.line+", column "+(e.column+1)+":\n"+s.join("\n")),e.stack&&(e.extract||r.logLevel>=4)&&(o+="\nStack Trace\n"+e.stack),n.logger.error(o)}(s,o):"function"==typeof r.errorReporting&&r.errorReporting("add",s,o):function(n,s){var o,a,l="less-error-message:"+e(s||""),u=t.document.createElement("div"),h=[],c=n.filename||s,f=c.match(/([^\/]+(\?.*)?)$/)[1];u.id=l,u.className="less-error-message",a="

    "+(n.type||"Syntax")+"Error: "+(n.message||"There is an error in your .less file")+'

    in '+f+" ";var p=function(e,t,i){void 0!==e.extract[t]&&h.push('

  • {content}
  • '.replace(/\{line\}/,(parseInt(e.line,10)||0)+(t-1)).replace(/\{class\}/,i).replace(/\{content\}/,e.extract[t]))};n.line&&(p(n,0,""),p(n,1,"line"),p(n,2,""),a+="on line "+n.line+", column "+(n.column+1)+":

      "+h.join("")+"
    "),n.stack&&(n.extract||r.logLevel>=4)&&(a+="
    Stack Trace
    "+n.stack.split("\n").slice(1).join("
    ")),u.innerHTML=a,i(t.document,[".less-error-message ul, .less-error-message li {","list-style-type: none;","margin-right: 15px;","padding: 4px 0;","margin: 0;","}",".less-error-message label {","font-size: 12px;","margin-right: 15px;","padding: 4px 0;","color: #cc7777;","}",".less-error-message pre {","color: #dd6666;","padding: 4px 0;","margin: 0;","display: inline-block;","}",".less-error-message pre.line {","color: #ff0000;","}",".less-error-message h3 {","font-size: 20px;","font-weight: bold;","padding: 15px 0 5px 0;","margin: 0;","}",".less-error-message a {","color: #10a","}",".less-error-message .error {","color: red;","font-weight: bold;","padding-bottom: 2px;","border-bottom: 1px dashed red;","}"].join("\n"),{title:"error-message"}),u.style.cssText=["font-family: Arial, sans-serif","border: 1px solid #e00","background-color: #eee","border-radius: 5px","-webkit-border-radius: 5px","-moz-border-radius: 5px","color: #e00","padding: 15px","margin-bottom: 15px"].join(";"),"development"===r.env&&(o=setInterval((function(){var e=t.document,i=e.body;i&&(e.getElementById(l)?i.replaceChild(u,e.getElementById(l)):i.insertBefore(u,i.firstChild),clearInterval(o))}),10))}(s,o)},remove:function(i){r.errorReporting&&"html"!==r.errorReporting?"console"===r.errorReporting||"function"==typeof r.errorReporting&&r.errorReporting("remove",i):function(i){var n=t.document.getElementById("less-error-message:"+e(i));n&&n.parentNode.removeChild(n)}(i)}}},Mt={javascriptEnabled:!1,depends:!1,compress:!1,lint:!1,paths:[],color:!0,strictImports:!1,insecure:!1,rootpath:"",rewriteUrls:!1,math:0,strictUnits:!1,globalVars:null,modifyVars:null,urlArgs:""};if(window.less)for(var Pt in window.less)window.less.hasOwnProperty(Pt)&&(Mt[Pt]=window.less[Pt]);!function(e,i){t(i,n(e)),void 0===i.isFileProtocol&&(i.isFileProtocol=/^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(e.location.protocol)),i.async=i.async||!1,i.fileAsync=i.fileAsync||!1,i.poll=i.poll||(i.isFileProtocol?1e3:1500),i.env=i.env||("127.0.0.1"==e.location.hostname||"0.0.0.0"==e.location.hostname||"localhost"==e.location.hostname||e.location.port&&e.location.port.length>0||i.isFileProtocol?"development":"production");var r=/!dumpLineNumbers:(comments|mediaquery|all)/.exec(e.location.hash);r&&(i.dumpLineNumbers=r[1]),void 0===i.useFileCache&&(i.useFileCache=!0),void 0===i.onReady&&(i.onReady=!0),i.relativeUrls&&(i.rewriteUrls="all")}(window,Mt),Mt.plugins=Mt.plugins||[],window.LESS_PLUGINS&&(Mt.plugins=Mt.plugins.concat(window.LESS_PLUGINS));var Et,Rt,Vt,Ft=function(e,n){var r=e.document,s=St();s.options=n;var o=s.environment,a=kt(n,s.logger),l=new a;o.addFileManager(l),s.FileManager=a,s.PluginLoader=_t,function(e,t){t.logLevel=void 0!==t.logLevel?t.logLevel:"development"===t.env?3:1,t.loggers||(t.loggers=[{debug:function(e){t.logLevel>=4&&console.log(e)},info:function(e){t.logLevel>=3&&console.log(e)},warn:function(e){t.logLevel>=2&&console.warn(e)},error:function(e){t.logLevel>=1&&console.error(e)}}]);for(var i=0;i0&&l.childNodes.length>0&&o.firstChild.nodeValue===l.firstChild.nodeValue);var u=t.getElementsByTagName("head")[0];if(null===o||!1===a){var c=n&&n.nextSibling||null;c?c.parentNode.insertBefore(l,c):u.appendChild(l)}if(o&&!1===a&&o.parentNode.removeChild(o),l.styleSheet)try{l.styleSheet.cssText=i}catch(e){throw new Error("Couldn't reassign styleSheet.cssText.")}},n=function(e){var t,i=e.document;return i.currentScript||(t=i.getElementsByTagName("script"))[t.length-1]},r={error:function(e){this._fireEvent("error",e)},warn:function(e){this._fireEvent("warn",e)},info:function(e){this._fireEvent("info",e)},debug:function(e){this._fireEvent("debug",e)},addListener:function(e){this._listeners.push(e)},removeListener:function(e){for(var t=0;t=0;a--){var l=o[a];if(l[s?"supportsSync":"supports"](e,t,i,n))return l}return null},e.prototype.addFileManager=function(e){this.fileManagers.push(e)},e.prototype.clearFileManagers=function(){this.fileManagers=[]},e}(),o={aliceblue:"#f0f8ff",antiquewhite:"#faebd7",aqua:"#00ffff",aquamarine:"#7fffd4",azure:"#f0ffff",beige:"#f5f5dc",bisque:"#ffe4c4",black:"#000000",blanchedalmond:"#ffebcd",blue:"#0000ff",blueviolet:"#8a2be2",brown:"#a52a2a",burlywood:"#deb887",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",cornflowerblue:"#6495ed",cornsilk:"#fff8dc",crimson:"#dc143c",cyan:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkgray:"#a9a9a9",darkgrey:"#a9a9a9",darkgreen:"#006400",darkkhaki:"#bdb76b",darkmagenta:"#8b008b",darkolivegreen:"#556b2f",darkorange:"#ff8c00",darkorchid:"#9932cc",darkred:"#8b0000",darksalmon:"#e9967a",darkseagreen:"#8fbc8f",darkslateblue:"#483d8b",darkslategray:"#2f4f4f",darkslategrey:"#2f4f4f",darkturquoise:"#00ced1",darkviolet:"#9400d3",deeppink:"#ff1493",deepskyblue:"#00bfff",dimgray:"#696969",dimgrey:"#696969",dodgerblue:"#1e90ff",firebrick:"#b22222",floralwhite:"#fffaf0",forestgreen:"#228b22",fuchsia:"#ff00ff",gainsboro:"#dcdcdc",ghostwhite:"#f8f8ff",gold:"#ffd700",goldenrod:"#daa520",gray:"#808080",grey:"#808080",green:"#008000",greenyellow:"#adff2f",honeydew:"#f0fff0",hotpink:"#ff69b4",indianred:"#cd5c5c",indigo:"#4b0082",ivory:"#fffff0",khaki:"#f0e68c",lavender:"#e6e6fa",lavenderblush:"#fff0f5",lawngreen:"#7cfc00",lemonchiffon:"#fffacd",lightblue:"#add8e6",lightcoral:"#f08080",lightcyan:"#e0ffff",lightgoldenrodyellow:"#fafad2",lightgray:"#d3d3d3",lightgrey:"#d3d3d3",lightgreen:"#90ee90",lightpink:"#ffb6c1",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",lightskyblue:"#87cefa",lightslategray:"#778899",lightslategrey:"#778899",lightsteelblue:"#b0c4de",lightyellow:"#ffffe0",lime:"#00ff00",limegreen:"#32cd32",linen:"#faf0e6",magenta:"#ff00ff",maroon:"#800000",mediumaquamarine:"#66cdaa",mediumblue:"#0000cd",mediumorchid:"#ba55d3",mediumpurple:"#9370d8",mediumseagreen:"#3cb371",mediumslateblue:"#7b68ee",mediumspringgreen:"#00fa9a",mediumturquoise:"#48d1cc",mediumvioletred:"#c71585",midnightblue:"#191970",mintcream:"#f5fffa",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",navajowhite:"#ffdead",navy:"#000080",oldlace:"#fdf5e6",olive:"#808000",olivedrab:"#6b8e23",orange:"#ffa500",orangered:"#ff4500",orchid:"#da70d6",palegoldenrod:"#eee8aa",palegreen:"#98fb98",paleturquoise:"#afeeee",palevioletred:"#d87093",papayawhip:"#ffefd5",peachpuff:"#ffdab9",peru:"#cd853f",pink:"#ffc0cb",plum:"#dda0dd",powderblue:"#b0e0e6",purple:"#800080",rebeccapurple:"#663399",red:"#ff0000",rosybrown:"#bc8f8f",royalblue:"#4169e1",saddlebrown:"#8b4513",salmon:"#fa8072",sandybrown:"#f4a460",seagreen:"#2e8b57",seashell:"#fff5ee",sienna:"#a0522d",silver:"#c0c0c0",skyblue:"#87ceeb",slateblue:"#6a5acd",slategray:"#708090",slategrey:"#708090",snow:"#fffafa",springgreen:"#00ff7f",steelblue:"#4682b4",tan:"#d2b48c",teal:"#008080",thistle:"#d8bfd8",tomato:"#ff6347",turquoise:"#40e0d0",violet:"#ee82ee",wheat:"#f5deb3",white:"#ffffff",whitesmoke:"#f5f5f5",yellow:"#ffff00",yellowgreen:"#9acd32"},a={length:{m:1,cm:.01,mm:.001,in:.0254,px:.0254/96,pt:.0254/72,pc:.0254/72*12},duration:{s:1,ms:.001},angle:{rad:1/(2*Math.PI),deg:1/360,grad:1/400,turn:1}},l={colors:o,unitConversions:a},u=function(){function e(){this.parent=null,this.visibilityBlocks=void 0,this.nodeVisible=void 0,this.rootNode=null,this.parsed=null;var e=this;Object.defineProperty(this,"currentFileInfo",{get:function(){return e.fileInfo()}}),Object.defineProperty(this,"index",{get:function(){return e.getIndex()}})}return e.prototype.setParent=function(t,i){function n(t){t&&t instanceof e&&(t.parent=i)}Array.isArray(t)?t.forEach(n):n(t)},e.prototype.getIndex=function(){return this._index||this.parent&&this.parent.getIndex()||0},e.prototype.fileInfo=function(){return this._fileInfo||this.parent&&this.parent.fileInfo()||{}},e.prototype.isRulesetLike=function(){return!1},e.prototype.toCSS=function(e){var t=[];return this.genCSS(e,{add:function(e,i,n){t.push(e)},isEmpty:function(){return 0===t.length}}),t.join("")},e.prototype.genCSS=function(e,t){t.add(this.value)},e.prototype.accept=function(e){this.value=e.visit(this.value)},e.prototype.eval=function(){return this},e.prototype._operate=function(e,t,i,n){switch(t){case"+":return i+n;case"-":return i-n;case"*":return i*n;case"/":return i/n}},e.prototype.fround=function(e,t){var i=e&&e.numPrecision;return i?Number((t+2e-16).toFixed(i)):t},e.compare=function(t,i){if(t.compare&&"Quoted"!==i.type&&"Anonymous"!==i.type)return t.compare(i);if(i.compare)return-i.compare(t);if(t.type===i.type){if(t=t.value,i=i.value,!Array.isArray(t))return t===i?0:void 0;if(t.length===i.length){for(var n=0;nt?1:void 0},e.prototype.blocksVisibility=function(){return null==this.visibilityBlocks&&(this.visibilityBlocks=0),0!==this.visibilityBlocks},e.prototype.addVisibilityBlock=function(){null==this.visibilityBlocks&&(this.visibilityBlocks=0),this.visibilityBlocks=this.visibilityBlocks+1},e.prototype.removeVisibilityBlock=function(){null==this.visibilityBlocks&&(this.visibilityBlocks=0),this.visibilityBlocks=this.visibilityBlocks-1},e.prototype.ensureVisibility=function(){this.nodeVisible=!0},e.prototype.ensureInvisibility=function(){this.nodeVisible=!1},e.prototype.isVisible=function(){return this.nodeVisible},e.prototype.visibilityInfo=function(){return{visibilityBlocks:this.visibilityBlocks,nodeVisible:this.nodeVisible}},e.prototype.copyVisibilityInfo=function(e){e&&(this.visibilityBlocks=e.visibilityBlocks,this.nodeVisible=e.nodeVisible)},e}(),c=function(e,t,i){var n=this;Array.isArray(e)?this.rgb=e:e.length>=6?(this.rgb=[],e.match(/.{2}/g).map((function(e,t){t<3?n.rgb.push(parseInt(e,16)):n.alpha=parseInt(e,16)/255}))):(this.rgb=[],e.split("").map((function(e,t){t<3?n.rgb.push(parseInt(e+e,16)):n.alpha=parseInt(e+e,16)/255}))),this.alpha=this.alpha||("number"==typeof t?t:1),void 0!==i&&(this.value=i)};function h(e,t){return Math.min(Math.max(e,0),t)}function f(e){return"#"+e.map((function(e){return((e=h(Math.round(e),255))<16?"0":"")+e.toString(16)})).join("")}c.prototype=Object.assign(new u,{type:"Color",luma:function(){var e=this.rgb[0]/255,t=this.rgb[1]/255,i=this.rgb[2]/255;return.2126*(e=e<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4))+.7152*(t=t<=.03928?t/12.92:Math.pow((t+.055)/1.055,2.4))+.0722*(i=i<=.03928?i/12.92:Math.pow((i+.055)/1.055,2.4))},genCSS:function(e,t){t.add(this.toCSS(e))},toCSS:function(e,t){var i,n,r,s=e&&e.compress&&!t,o=[];if(n=this.fround(e,this.alpha),this.value)if(0===this.value.indexOf("rgb"))n<1&&(r="rgba");else{if(0!==this.value.indexOf("hsl"))return this.value;r=n<1?"hsla":"hsl"}else n<1&&(r="rgba");switch(r){case"rgba":o=this.rgb.map((function(e){return h(Math.round(e),255)})).concat(h(n,1));break;case"hsla":o.push(h(n,1));case"hsl":i=this.toHSL(),o=[this.fround(e,i.h),this.fround(e,100*i.s)+"%",this.fround(e,100*i.l)+"%"].concat(o)}if(r)return r+"("+o.join(","+(s?"":" "))+")";if(i=this.toRGB(),s){var a=i.split("");a[1]===a[2]&&a[3]===a[4]&&a[5]===a[6]&&(i="#"+a[1]+a[3]+a[5])}return i},operate:function(e,t,i){for(var n=new Array(3),r=this.alpha*(1-i.alpha)+i.alpha,s=0;s<3;s++)n[s]=this._operate(e,t,this.rgb[s],i.rgb[s]);return new c(n,r)},toRGB:function(){return f(this.rgb)},toHSL:function(){var e,t,i=this.rgb[0]/255,n=this.rgb[1]/255,r=this.rgb[2]/255,s=this.alpha,o=Math.max(i,n,r),a=Math.min(i,n,r),l=(o+a)/2,u=o-a;if(o===a)e=t=0;else{switch(t=l>.5?u/(2-o-a):u/(o+a),o){case i:e=(n-r)/u+(n=0&&"\n"!==t.charAt(i);)r++;return"number"==typeof e&&(n=(t.slice(0,e).match(/\n/g)||"").length),{line:n,column:r}}function k(e){var t,i=e.length,n=new Array(i);for(t=0;t|Function):(\d+):(\d+)/,O=function(e,t,i){Error.call(this);var n=e.filename||i;if(this.message=e.message,this.stack=e.stack,t&&n){var r=t.contents[n],s=C(e.index,r),o=s.line,a=s.column,l=e.call&&C(e.call,r).line,u=r?r.split("\n"):"";if(this.type=e.type||"Syntax",this.filename=n,this.index=e.index,this.line="number"==typeof o?o+1:null,this.column=a,!this.line&&this.stack){var c=this.stack.match(R),h=new Function("a","throw new Error()"),f=0;try{h()}catch(e){var p=e.stack.match(R);f=1-(o=parseInt(p[2]))}c&&(c[2]&&(this.line=parseInt(c[2])+f),c[3]&&(this.column=parseInt(c[3])))}this.callLine=l+1,this.callExtract=u[l],this.extract=[u[this.line-2],u[this.line-1],u[this.line]]}};if(void 0===Object.create){var V=function(){};V.prototype=Error.prototype,O.prototype=new V}else O.prototype=Object.create(Error.prototype);O.prototype.constructor=O,O.prototype.toString=function(e){e=e||{};var t="",i=this.extract||[],n=[],r=function(e){return e};if(e.stylize){var s=typeof e.stylize;if("function"!==s)throw Error("options.stylize should be a function, got a "+s+"!");r=e.stylize}if(null!==this.line){if("string"==typeof i[0]&&n.push(r(this.line-1+" "+i[0],"grey")),"string"==typeof i[1]){var o=this.line+" ";i[1]&&(o+=i[1].slice(0,this.column)+r(r(r(i[1].substr(this.column,1),"bold")+i[1].slice(this.column+1),"red"),"inverse")),n.push(o)}"string"==typeof i[2]&&n.push(r(this.line+1+" "+i[2],"grey")),n=n.join("\n")+r("","reset")+"\n"}return t+=r(this.type+"Error: "+this.message,"red"),this.filename&&(t+=r(" in ","red")+this.filename),this.line&&(t+=r(" on line "+this.line+", column "+(this.column+1)+":","grey")),t+="\n"+n,this.callLine&&(t+=r("from ","red")+(this.filename||"")+"/n",t+=r(this.callLine,"grey")+" "+this.callExtract+"/n"),t};var F=function(e,t,i,n,r,s){this.extendList=t,this.condition=i,this.evaldCondition=!i,this._index=n,this._fileInfo=r,this.elements=this.getElements(e),this.mixinElements_=void 0,this.copyVisibilityInfo(s),this.setParent(this.elements,this)};F.prototype=Object.assign(new u,{type:"Selector",accept:function(e){this.elements&&(this.elements=e.visitArray(this.elements)),this.extendList&&(this.extendList=e.visitArray(this.extendList)),this.condition&&(this.condition=e.visit(this.condition))},createDerived:function(e,t,i){e=this.getElements(e);var n=new F(e,t||this.extendList,null,this.getIndex(),this.fileInfo(),this.visibilityInfo());return n.evaldCondition=null!=i?i:this.evaldCondition,n.mediaEmpty=this.mediaEmpty,n},getElements:function(e){return e?("string"==typeof e&&this.parse.parseNode(e,["selector"],this._index,this._fileInfo,(function(t,i){if(t)throw new O({index:t.index,message:t.message},this.parse.imports,this._fileInfo.filename);e=i[0].elements})),e):[new m("","&",!1,this._index,this._fileInfo)]},createEmptySelectors:function(){var e=new m("","&",!1,this._index,this._fileInfo),t=[new F([e],null,null,this._index,this._fileInfo)];return t[0].mediaEmpty=!0,t},match:function(e){var t,i,n=this.elements,r=n.length;if(0===(t=(e=e.mixinElements()).length)||rg.PARENS_DIVISION)||this.parensStack&&this.parensStack.length))},q.Eval.prototype.pathRequiresRewrite=function(e){return(this.rewriteUrls===b?J:W)(e)},q.Eval.prototype.rewritePath=function(e,t){var i;return t=t||"",i=this.normalizePath(t+e),J(e)&&W(t)&&!1===J(i)&&(i="./"+i),i},q.Eval.prototype.normalizePath=function(e){var t,i=e.split("/").reverse();for(e=[];0!==i.length;)switch(t=i.pop()){case".":break;case"..":0===e.length||".."===e[e.length-1]?e.push(t):e.pop();break;default:e.push(t)}return e.join("/")};var H=function e(t){return{_data:{},add:function(e,t){e=e.toLowerCase(),this._data.hasOwnProperty(e),this._data[e]=t},addMultiple:function(e){var t=this;Object.keys(e).forEach((function(i){t.add(i,e[i])}))},get:function(e){return this._data[e]||t&&t.get(e)},getLocalFunctions:function(){return this._data},inherit:function(){return e(this)},create:function(t){return e(t)}}}(null),Q={eval:function(){var e=this.value_,t=this.error_;if(t)throw t;if(null!=e)return e?L.True:L.False},value:function(e){this.value_=e},error:function(e){this.error_=e},reset:function(){this.value_=this.error_=null}},K=function(e,t,i,n){this.selectors=e,this.rules=t,this._lookups={},this._variables=null,this._properties=null,this.strictImports=i,this.copyVisibilityInfo(n),this.allowRoot=!0,this.setParent(this.selectors,this),this.setParent(this.rules,this)};K.prototype=Object.assign(new u,{type:"Ruleset",isRuleset:!0,isRulesetLike:function(){return!0},accept:function(e){this.paths?this.paths=e.visitArray(this.paths,!0):this.selectors&&(this.selectors=e.visitArray(this.selectors)),this.rules&&this.rules.length&&(this.rules=e.visitArray(this.rules))},eval:function(e){var t,i,n,r,s,o=!1;if(this.selectors&&(i=this.selectors.length)){for(t=new Array(i),Q.error({type:"Syntax",message:"it is currently only allowed in parametric mixin guards,"}),r=0;r0;e--){var t=this.rules[e-1];if(t instanceof D)return this.parseValue(t)}},parseValue:function(e){var t=this;function i(e){return e.value instanceof j&&!e.parsed?("string"==typeof e.value.value?this.parse.parseNode(e.value.value,["value","important"],e.value.getIndex(),e.fileInfo(),(function(t,i){t&&(e.parsed=!0),i&&(e.value=i[0],e.important=i[1]||"",e.parsed=!0)})):e.parsed=!0,e):e}if(Array.isArray(e)){var n=[];return e.forEach((function(e){n.push(i.call(t,e))})),n}return i.call(t,e)},rulesets:function(){if(!this.rules)return[];var e,t,i=[],n=this.rules;for(e=0;t=n[e];e++)t.isRuleset&&i.push(t);return i},prependRule:function(e){var t=this.rules;t?t.unshift(e):this.rules=[e],this.setParent(e,this)},find:function(e,t,i){t=t||this;var n,r,s=[],o=e.toCSS();return o in this._lookups?this._lookups[o]:(this.rulesets().forEach((function(o){if(o!==t)for(var a=0;an){if(!i||i(o)){r=o.find(new F(e.elements.slice(n)),t,i);for(var l=0;l0&&t.add(l),e.firstSelector=!0,o[0].genCSS(e,t),e.firstSelector=!1,n=1;n0?(s=(r=k(e)).pop(),o=n.createDerived(k(s.elements))):o=n.createDerived([]),t.length>0){var a=i.combinator,l=t[0].elements[0];a.emptyOrWhitespace&&!l.combinator.emptyOrWhitespace&&(a=l.combinator),o.elements.push(new m(a,l.value,i.isVariable,i._index,i._fileInfo)),o.elements=o.elements.concat(t[0].elements.slice(1))}if(0!==o.elements.length&&r.push(o),t.length>1){var u=t.slice(1);u=u.map((function(e){return e.createDerived(e.elements,[])})),r=r.concat(u)}return r}function o(e,t,i,n,r){var o;for(o=0;o0?n[n.length-1]=n[n.length-1].createDerived(n[n.length-1].elements.concat(e)):n.push(new F(e));else t.push([new F(e)])}function l(e,t){var i=t.createDerived(t.elements,t.extendList,t.evaldCondition);return i.copyVisibilityInfo(e),i}var u,c;if(!function e(t,i,l){var u,c,h,f,v,d,g,y,b,w,x,S,I=!1;for(f=[],v=[[]],u=0;y=l.elements[u];u++)if("&"!==y.value){var C=(S=void 0,(x=y).value instanceof p&&(S=x.value.value)instanceof F?S:null);if(null!=C){a(f,v);var k,_=[],A=[];for(k=e(_,i,C),I=I||k,h=0;h<_.length;h++){o(v,[r(n(_[h],y),y)],y,l,A)}v=A,f=[]}else f.push(y)}else{for(I=!0,d=[],a(f,v),c=0;c0&&g[0].elements.push(new m(y.combinator,"",y.isVariable,y._index,y._fileInfo)),d.push(g);else for(h=0;h0&&(t.push(v[u]),w=v[u][b-1],v[u][b-1]=w.createDerived(w.elements,l.extendList));return I}(c=[],t,i))if(t.length>0)for(c=[],u=0;u0)for(t=0;t-1e-6&&(n=i.toFixed(20).replace(/0+$/,"")),e&&e.compress){if(0===i&&this.unit.isLength())return void t.add(n);i>0&&i<1&&(n=n.substr(1))}t.add(n),this.unit.genCSS(e,t)},operate:function(e,t,i){var n=this._operate(e,t,this.value,i.value),r=this.unit.clone();if("+"===t||"-"===t)if(0===r.numerator.length&&0===r.denominator.length)r=i.unit.clone(),this.unit.backupUnit&&(r.backupUnit=this.unit.backupUnit);else if(0===i.unit.numerator.length&&0===r.denominator.length);else{if(i=i.convertTo(this.unit.usedUnits()),e.strictUnits&&i.unit.toString()!==r.toString())throw new Error("Incompatible units. Change the units or use the unit function. Bad units: '"+r.toString()+"' and '"+i.unit.toString()+"'.");n=this._operate(e,t,this.value,i.value)}else"*"===t?(r.numerator=r.numerator.concat(i.unit.numerator).sort(),r.denominator=r.denominator.concat(i.unit.denominator).sort(),r.cancel()):"/"===t&&(r.numerator=r.numerator.concat(i.unit.denominator).sort(),r.denominator=r.denominator.concat(i.unit.numerator).sort(),r.cancel());return new ee(n,r)},compare:function(e){var t,i;if(e instanceof ee){if(this.unit.isEmpty()||e.unit.isEmpty())t=this,i=e;else if(t=this.unify(),i=e.unify(),0!==t.unit.compare(i.unit))return;return u.numericCompare(t.value,i.value)}},unify:function(){return this.convertTo({length:"px",duration:"s",angle:"rad"})},convertTo:function(e){var t,i,n,r,s,o=this.value,l=this.unit.clone(),u={};if("string"==typeof e){for(t in a)a[t].hasOwnProperty(e)&&((u={})[t]=e);e=u}for(i in s=function(e,t){return n.hasOwnProperty(e)?(t?o/=n[e]/n[r]:o*=n[e]/n[r],r):e},e)e.hasOwnProperty(i)&&(r=e[i],n=a[i],l.map(s));return l.cancel(),new ee(o,l)}});var te=g,ie=function(e,t,i){this.op=e.trim(),this.operands=t,this.isSpaced=i};ie.prototype=Object.assign(new u,{type:"Operation",accept:function(e){this.operands=e.visitArray(this.operands)},eval:function(e){var t,i=this.operands[0].eval(e),n=this.operands[1].eval(e);if(e.isMathOn(this.op)){if(t="./"===this.op?"/":this.op,i instanceof ee&&n instanceof c&&(i=i.toColor()),n instanceof ee&&i instanceof c&&(n=n.toColor()),!i.operate){if(i instanceof ie&&"/"===i.op&&e.math===te.PARENS_DIVISION)return new ie(this.op,[i,n],this.isSpaced);throw{type:"Operation",message:"Operation on an invalid type"}}return i.operate(e,t,n)}return new ie(this.op,[i,n],this.isSpaced)},genCSS:function(e,t){this.operands[0].genCSS(e,t),this.isSpaced&&t.add(" "),t.add(this.op),this.isSpaced&&t.add(" "),this.operands[1].genCSS(e,t)}});var ne=function(e,t){if(this.value=e,this.noSpacing=t,!e)throw new Error("Expression requires an array parameter")};ne.prototype=Object.assign(new u,{type:"Expression",accept:function(e){this.value=e.visitArray(this.value)},eval:function(e){var t,i=e.isMathOn(),n=this.parens,r=!1;return n&&e.inParenthesis(),this.value.length>1?t=new ne(this.value.map((function(t){return t.eval?t.eval(e):t})),this.noSpacing):1===this.value.length?(!this.value[0].parens||this.value[0].parensInOp||e.inCalc||(r=!0),t=this.value[0].eval(e)):t=this,n&&e.outOfParenthesis(),!this.parens||!this.parensInOp||i||r||t instanceof ee||(t=new p(t)),t},genCSS:function(e,t){for(var i=0;i1){var i=new F([],null,null,this.getIndex(),this.fileInfo()).createEmptySelectors();(t=new K(i,e.mediaBlocks)).multiMedia=!0,t.copyVisibilityInfo(this.visibilityInfo()),this.setParent(t,this)}return delete e.mediaBlocks,delete e.mediaPath,t},evalNested:function(e){var t,i,n=e.mediaPath.concat([this]);for(t=0;t0;t--)e.splice(t,0,new j("and"));return new ne(e)}))),this.setParent(this.features,this),new K([],[])},permute:function(e){if(0===e.length)return[];if(1===e.length)return e[0];for(var t=[],i=this.permute(e.slice(1)),n=0;n1?"["+e.value.map((function(e){return e.toCSS()})).join(", ")+"]":e.toCSS()}});var ve=function(e,t,i,n){this.escaped=t,this.expression=e,this._index=i,this._fileInfo=n};ve.prototype=Object.assign(new pe,{type:"JavaScript",eval:function(e){var t=this.evaluateJavaScript(this.expression,e),i=typeof t;return"number"!==i||isNaN(t)?"string"===i?new ue('"'+t+'"',t,this.escaped,this._index):Array.isArray(t)?new j(t.join(", ")):new j(t):new ee(t)}});var de=function(e,t){this.key=e,this.value=t};de.prototype=Object.assign(new u,{type:"Assignment",accept:function(e){this.value=e.visit(this.value)},eval:function(e){return this.value.eval?new de(this.key,this.value.eval(e)):this},genCSS:function(e,t){t.add(this.key+"="),this.value.genCSS?this.value.genCSS(e,t):t.add(this.value)}});var me=function(e,t,i,n,r){this.op=e.trim(),this.lvalue=t,this.rvalue=i,this._index=n,this.negate=r};me.prototype=Object.assign(new u,{type:"Condition",accept:function(e){this.lvalue=e.visit(this.lvalue),this.rvalue=e.visit(this.rvalue)},eval:function(e){var t=function(e,t,i){switch(e){case"and":return t&&i;case"or":return t||i;default:switch(u.compare(t,i)){case-1:return"<"===e||"=<"===e||"<="===e;case 0:return"="===e||">="===e||"=<"===e||"<="===e;case 1:return">"===e||">="===e;default:return!1}}}(this.op,this.lvalue.eval(e),this.rvalue.eval(e));return this.negate?!t:t}});var ge=function(e){this.value=e};ge.prototype=Object.assign(new u,{type:"UnicodeDescriptor"});var ye=function(e){this.value=e};ye.prototype=Object.assign(new u,{type:"Negative",genCSS:function(e,t){t.add("-"),this.value.genCSS(e,t)},eval:function(e){return e.isMathOn()?new ie("*",[new ee(-1),this.value]).eval(e):new ye(this.value.eval(e))}});var be=function(e,t,i,n,r){switch(this.selector=e,this.option=t,this.object_id=be.next_id++,this.parent_ids=[this.object_id],this._index=i,this._fileInfo=n,this.copyVisibilityInfo(r),this.allowRoot=!0,t){case"all":this.allowBefore=!0,this.allowAfter=!0;break;default:this.allowBefore=!1,this.allowAfter=!1}this.setParent(this.selector,this)};be.prototype=Object.assign(new u,{type:"Extend",accept:function(e){this.selector=e.visit(this.selector)},eval:function(e){return new be(this.selector.eval(e),this.option,this.getIndex(),this.fileInfo(),this.visibilityInfo())},clone:function(e){return new be(this.selector,this.option,this.getIndex(),this.fileInfo(),this.visibilityInfo())},findSelfSelectors:function(e){var t,i,n=[];for(t=0;t0&&i.length&&""===i[0].combinator.value&&(i[0].combinator.value=" "),n=n.concat(e[t].elements);this.selfSelectors=[new F(n)],this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo())}}),be.next_id=0;var we=function(e,t,i){this.variable=e,this._index=t,this._fileInfo=i,this.allowRoot=!0};we.prototype=Object.assign(new u,{type:"VariableCall",eval:function(e){var t,i=new oe(this.variable,this.getIndex(),this.fileInfo()).eval(e),n=new O({message:"Could not evaluate variable call "+this.variable});if(!i.ruleset){if(i.rules)t=i;else if(Array.isArray(i))t=new K("",i);else{if(!Array.isArray(i.value))throw n;t=new K("",i.value)}i=new X(t)}if(i.ruleset)return i.callEval(e);throw n}});var xe=function(e,t,i,n){this.value=e,this.lookups=t,this._index=i,this._fileInfo=n};xe.prototype=Object.assign(new u,{type:"NamespaceValue",eval:function(e){var t,i,n=this.value.eval(e);for(t=0;tthis.params.length)return!1}i=Math.min(s,this.arity);for(var o=0;o0){for(c=!0,a=0;a0)f=2;else if(f=1,p[1]+p[2]>1)throw{type:"Runtime",message:"Ambiguous use of `default()` found when matching for `"+this.format(m)+"`",index:this.getIndex(),filename:this.fileInfo().filename};for(a=0;a0&&(e=e.slice(0,t)),(t=e.lastIndexOf("/"))<0&&(t=e.lastIndexOf("\\")),t<0?"":e.slice(0,t+1)},e.prototype.tryAppendExtension=function(e,t){return/(\.[a-z]*$)|([\?;].*)$/.test(e)?e:e+t},e.prototype.tryAppendLessExtension=function(e){return this.tryAppendExtension(e,".less")},e.prototype.supportsSync=function(){return!1},e.prototype.alwaysMakePathsAbsolute=function(){return!1},e.prototype.isPathAbsolute=function(e){return/^(?:[a-z-]+:|\/|\\|#)/i.test(e)},e.prototype.join=function(e,t){return e?e+t:t},e.prototype.pathDiff=function(e,t){var i,n,r,s,o=this.extractUrlParts(e),a=this.extractUrlParts(t),l="";if(o.hostPart!==a.hostPart)return"";for(n=Math.max(a.directories.length,o.directories.length),i=0;iparseInt(t[i])?-1:1;return 0},e.prototype.versionToString=function(e){for(var t="",i=0;i0;){var e=this.imports[0];if(!e.isReady)return;this.imports=this.imports.slice(1),e.callback.apply(null,e.args)}if(0===this.variableImports.length)break;var t=this.variableImports[0];this.variableImports=this.variableImports.slice(1),t()}}finally{this._currentDepth--}0===this._currentDepth&&this._onSequencerEmpty&&this._onSequencerEmpty()},e}(),Oe=function(e,t){this._visitor=new Pe(this),this._importer=e,this._finish=t,this.context=new q.Eval,this.importCount=0,this.onceFileDetectionMap={},this.recursionDetector={},this._sequencer=new Re(this._onSequencerEmpty.bind(this))};Oe.prototype={isReplacing:!1,run:function(e){try{this._visitor.visit(e)}catch(e){this.error=e}this.isFinished=!0,this._sequencer.tryRun()},_onSequencerEmpty:function(){this.isFinished&&this._finish(this.error)},visitImport:function(e,t){var i=e.options.inline;if(!e.css||i){var n=new q.Eval(this.context,k(this.context.frames)),r=n.frames[0];this.importCount++,e.isVariableImport()?this._sequencer.addVariableImport(this.processImportNode.bind(this,e,n,r)):this.processImportNode(e,n,r)}t.visitDeeper=!1},processImportNode:function(e,t,i){var n,r=e.options.inline;try{n=e.evalForImport(t)}catch(t){t.filename||(t.index=e.getIndex(),t.filename=e.fileInfo().filename),e.css=!0,e.error=t}if(!n||n.css&&!r)this.importCount--,this.isFinished&&this._sequencer.tryRun();else{n.options.multiple&&(t.importMultiple=!0);for(var s=void 0===n.css,o=0;o=0||(a=[u.selfSelectors[0]],(s=f.findMatch(l,a)).length&&(l.hasFoundMatches=!0,l.selfSelectors.forEach((function(e){var t=u.visibilityInfo();o=f.extendSelector(s,a,e,l.isVisible()),(c=new Ce.Extend(u.selector,u.option,0,u.fileInfo(),t)).selfSelectors=o,o[o.length-1].extendList=[c],h.push(c),c.ruleset=u.ruleset,c.parent_ids=c.parent_ids.concat(u.parent_ids,l.parent_ids),u.firstExtendOnThisSelectorPath&&(c.firstExtendOnThisSelectorPath=!0,u.ruleset.paths.push(o))}))));if(h.length){if(this.extendChainCount++,i>100){var p="{unable to calculate}",v="{unable to calculate}";try{p=h[0].selfSelectors[0].toCSS(),v=h[0].selector.toCSS()}catch(e){}throw{message:"extend circular reference detected. One of the circular extends is currently:"+p+":extend("+v+")"}}return h.concat(f.doExtendChaining(h,t,i+1))}return h},e.prototype.visitDeclaration=function(e,t){t.visitDeeper=!1},e.prototype.visitMixinDefinition=function(e,t){t.visitDeeper=!1},e.prototype.visitSelector=function(e,t){t.visitDeeper=!1},e.prototype.visitRuleset=function(e,t){if(!e.root){var i,n,r,s,o=this.allExtendsStack[this.allExtendsStack.length-1],a=[],l=this;for(r=0;r0&&u[l.matched].combinator.value!==o?l=null:l.matched++,l&&(l.finished=l.matched===u.length,l.finished&&!e.allowAfter&&(r+1u&&c>0&&(h[h.length-1].elements=h[h.length-1].elements.concat(t[u].elements.slice(c)),c=0,u++),l=s.elements.slice(c,a.index).concat([o]).concat(i.elements.slice(1)),u===a.pathIndex&&r>0?h[h.length-1].elements=h[h.length-1].elements.concat(l):(h=h.concat(t.slice(u,a.pathIndex))).push(new Ce.Selector(l)),u=a.endPathIndex,(c=a.endPathElementIndex)>=t[u].elements.length&&(c=0,u++);return u0&&(h[h.length-1].elements=h[h.length-1].elements.concat(t[u].elements.slice(c)),u++),h=(h=h.concat(t.slice(u,t.length))).map((function(e){var t=e.createDerived(e.elements);return n?t.ensureVisibility():t.ensureInvisibility(),t}))},e.prototype.visitMedia=function(e,t){var i=e.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length-1]);i=i.concat(this.doExtendChaining(i,e.allExtends)),this.allExtendsStack.push(i)},e.prototype.visitMediaOut=function(e){var t=this.allExtendsStack.length-1;this.allExtendsStack.length=t},e.prototype.visitAtRule=function(e,t){var i=e.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length-1]);i=i.concat(this.doExtendChaining(i,e.allExtends)),this.allExtendsStack.push(i)},e.prototype.visitAtRuleOut=function(e){var t=this.allExtendsStack.length-1;this.allExtendsStack.length=t},e}(),Le=function(){function e(){this.contexts=[[]],this._visitor=new Pe(this)}return e.prototype.run=function(e){return this._visitor.visit(e)},e.prototype.visitDeclaration=function(e,t){t.visitDeeper=!1},e.prototype.visitMixinDefinition=function(e,t){t.visitDeeper=!1},e.prototype.visitRuleset=function(e,t){var i,n=this.contexts[this.contexts.length-1],r=[];this.contexts.push(r),e.root||((i=e.selectors)&&(i=i.filter((function(e){return e.getIsOutput()})),e.selectors=i.length?i:i=null,i&&e.joinSelectors(r,n,i)),i||(e.rules=null),e.paths=r)},e.prototype.visitRulesetOut=function(e){this.contexts.length=this.contexts.length-1},e.prototype.visitMedia=function(e,t){var i=this.contexts[this.contexts.length-1];e.rules[0].root=0===i.length||i[0].multiMedia},e.prototype.visitAtRule=function(e,t){var i=this.contexts[this.contexts.length-1];e.rules&&e.rules.length&&(e.rules[0].root=e.isRooted||0===i.length||null)},e}(),je=function(){function e(e){this._visitor=new Pe(this),this._context=e}return e.prototype.containsSilentNonBlockedChild=function(e){var t;if(!e)return!1;for(var i=0;i0},e.prototype.resolveVisibility=function(e,t){if(!e.blocksVisibility()){if(this.isEmpty(e)&&!this.containsSilentNonBlockedChild(t))return;return e}var i=e.rules[0];if(this.keepOnlyVisibleChilds(i),!this.isEmpty(i))return e.ensureVisibility(),e.removeVisibilityBlock(),e},e.prototype.isVisibleRuleset=function(e){return!!e.firstRoot||!this.isEmpty(e)&&!(!e.root&&!this.hasVisibleSelector(e))},e}(),Ne=function(e){this._visitor=new Pe(this),this._context=e,this.utils=new je(e)};Ne.prototype={isReplacing:!0,run:function(e){return this._visitor.visit(e)},visitDeclaration:function(e,t){if(!e.blocksVisibility()&&!e.variable)return e},visitMixinDefinition:function(e,t){e.frames=[]},visitExtend:function(e,t){},visitComment:function(e,t){if(!e.blocksVisibility()&&!e.isSilent(this._context))return e},visitMedia:function(e,t){var i=e.rules[0].rules;return e.accept(this._visitor),t.visitDeeper=!1,this.utils.resolveVisibility(e,i)},visitImport:function(e,t){if(!e.blocksVisibility())return e},visitAtRule:function(e,t){return e.rules&&e.rules.length?this.visitAtRuleWithBody(e,t):this.visitAtRuleWithoutBody(e,t)},visitAnonymous:function(e,t){if(!e.blocksVisibility())return e.accept(this._visitor),e},visitAtRuleWithBody:function(e,t){var i=function(e){var t=e.rules;return function(e){var t=e.rules;return 1===t.length&&(!t[0].paths||0===t[0].paths.length)}(e)?t[0].rules:t}(e);return e.accept(this._visitor),t.visitDeeper=!1,this.utils.isEmpty(e)||this._mergeRules(e.rules[0].rules),this.utils.resolveVisibility(e,i)},visitAtRuleWithoutBody:function(e,t){if(!e.blocksVisibility()){if("@charset"===e.name){if(this.charset){if(e.debugInfo){var i=new Ce.Comment("/* "+e.toCSS(this._context).replace(/\n/g,"")+" */\n");return i.debugInfo=e.debugInfo,this._visitor.visit(i)}return}this.charset=!0}return e}},checkValidNodes:function(e,t){if(e)for(var i=0;i0?e.accept(this._visitor):e.rules=null,t.visitDeeper=!1}return e.rules&&(this._mergeRules(e.rules),this._removeDuplicateRules(e.rules)),this.utils.isVisibleRuleset(e)&&(e.ensureVisibility(),n.splice(0,0,e)),1===n.length?n[0]:n},_compileRulesetPaths:function(e){e.paths&&(e.paths=e.paths.filter((function(e){var t;for(" "===e[0].elements[0].combinator.value&&(e[0].elements[0].combinator=new Ce.Combinator("")),t=0;t=0;n--)if((i=e[n])instanceof Ce.Declaration)if(r[i.name]){(t=r[i.name])instanceof Ce.Declaration&&(t=r[i.name]=[r[i.name].toCSS(this._context)]);var s=i.toCSS(this._context);-1!==t.indexOf(s)?e.splice(n,1):t.push(s)}else r[i.name]=i}},_mergeRules:function(e){if(e){for(var t={},i=[],n=0;n0){var t=e[0],i=[],n=[new Ce.Expression(i)];e.forEach((function(e){"+"===e.merge&&i.length>0&&n.push(new Ce.Expression(i=[])),i.push(e.value),t.important=t.important||e.important})),t.value=new Ce.Value(n)}}))}}};var De={Visitor:Pe,ImportVisitor:Oe,MarkVisibleSelectorsVisitor:Ve,ExtendVisitor:$e,JoinSelectorVisitor:Le,ToCSSVisitor:Ne};var Ue=function(){var e,t,i,n,r,s,o,a=[],l={};function u(i){for(var n,a,c,h=l.i,f=t,p=l.i-o,v=l.i+s.length-p,d=l.i+=i,m=e;l.i=0){c={index:l.i,text:m.substr(l.i,y+2-l.i),isLineComment:!1},l.i+=c.text.length-1,l.commentStore.push(c);continue}}break}if(32!==n&&10!==n&&9!==n&&13!==n)break}if(s=s.slice(i+l.i-d+p),o=l.i,!s.length){if(ti||l.i===i&&e&&!n)&&(i=l.i,n=e);var r=a.pop();s=r.current,o=l.i=r.i,t=r.j},l.forget=function(){a.pop()},l.isWhitespace=function(t){var i=l.i+(t||0),n=e.charCodeAt(i);return 32===n||13===n||9===n||10===n},l.$re=function(e){l.i>o&&(s=s.slice(l.i-o),o=l.i);var t=e.exec(s);return t?(u(t[0].length),"string"==typeof t?t:1===t.length?t[0]:t):null},l.$char=function(t){return e.charAt(l.i)!==t?null:(u(1),t)},l.$str=function(t){for(var i=t.length,n=0;nh&&(d=!1)}}while(d);return r||null},l.autoCommentAbsorb=!0,l.commentStore=[],l.finished=!1,l.peek=function(t){if("string"==typeof t){for(var i=0;i57||t<43||47===t||44===t},l.start=function(n,a,c){e=n,l.i=t=o=i=0,r=a?function(e,t){var i,n,r,s,o,a,l,u,c,h=e.length,f=0,p=0,v=[],d=0;function m(t){var i=o-d;i<512&&!t||!i||(v.push(e.slice(d,o+1)),d=o+1)}for(o=0;o=97&&l<=122||l<34))switch(l){case 40:p++,n=o;continue;case 41:if(--p<0)return t("missing opening `(`",o);continue;case 59:p||m();continue;case 123:f++,i=o;continue;case 125:if(--f<0)return t("missing opening `{`",o);f||p||m();continue;case 92:if(o96)){if(u==l){c=1;break}if(92==u){if(o==h-1)return t("unescaped `\\`",o);o++}}if(c)continue;return t("unmatched `"+String.fromCharCode(l)+"`",a);case 47:if(p||o==h-1)continue;if(47==(u=e.charCodeAt(o+1)))for(o+=2;oi&&s>r?"missing closing `}` or `*/`":"missing closing `}`",i):0!==p?t("missing closing `)`",n):(m(!0),v)}(n,c):[n],s=r[0],u(0)},l.end=function(){var t,r=l.i>=e.length;return l.i=e.length-1,furthestChar:e[l.i]}},l},Be=function e(t,i,n){var r,s=Ue();function o(e,t){throw new O({index:s.i,filename:n.filename,type:t||"Syntax",message:e},i)}function a(e,t){var i=e instanceof Function?e.call(r):s.$re(e);if(i)return i;o(t||("string"==typeof e?"expected '"+e+"' got '"+s.currentChar()+"'":"unexpected token"))}function l(e,t){if(s.$char(e))return e;o(t||"expected '"+e+"' got '"+s.currentChar()+"'")}function u(e){var t=n.filename;return{lineNumber:C(e,s.getInput()).line+1,fileName:t}}return{parserInput:s,imports:i,fileInfo:n,parseNode:function(e,t,n,o,a){var l,u=[],c=s;try{c.start(e,!1,(function(e,t){a({message:e,index:t+n})}));for(var h=0,f=void 0,p=void 0;f=t[h];h++)if(p=c.i,l=r[f]()){try{l._index=p+n,l._fileInfo=o}catch(e){}u.push(l)}else u.push(null);c.end().isFinished?a(null,u):a(!0,null)}catch(e){throw new O({index:e.index+n,message:e.message},i,o.filename)}},parse:function(r,o,a){var l,u,c,h,f=null,p="";if(u=a&&a.globalVars?e.serializeVars(a.globalVars)+"\n":"",c=a&&a.modifyVars?"\n"+e.serializeVars(a.modifyVars):"",t.pluginManager)for(var v=t.pluginManager.getPreProcessors(),d=0;d");return e},args:function(e){var t,i,n,a,l,u,c,h=r.entities,f={args:null,variadic:!1},p=[],v=[],d=[],m=!0;for(s.save();;){if(e)u=r.detachedRuleset()||r.expression();else{if(s.commentStore.length=0,s.$str("...")){f.variadic=!0,s.$char(";")&&!t&&(t=!0),(t?v:d).push({variadic:!0});break}u=h.variable()||h.property()||h.literal()||h.keyword()||this.call(!0)}if(!u||!m)break;a=null,u.throwAwayComments&&u.throwAwayComments(),l=u;var g=null;if(e?u.value&&1==u.value.length&&(g=u.value[0]):g=u,g&&(g instanceof Ce.Variable||g instanceof Ce.Property))if(s.$char(":")){if(p.length>0&&(t&&o("Cannot mix ; and , as delimiter types"),i=!0),!(l=r.detachedRuleset()||r.expression())){if(!e)return s.restore(),f.args=[],f;o("could not understand value for named argument")}a=n=g.name}else if(s.$str("...")){if(!e){f.variadic=!0,s.$char(";")&&!t&&(t=!0),(t?v:d).push({name:u.name,variadic:!0});break}c=!0}else e||(n=a=g.name,l=null);l&&p.push(l),d.push({name:a,value:l,expand:c}),s.$char(",")?m=!0:((m=";"===s.$char(";"))||t)&&(i&&o("Cannot mix ; and , as delimiter types"),t=!0,p.length>1&&(l=new Ce.Value(p)),v.push({name:n,value:l,expand:c}),n=null,p=[],i=!1)}return s.forget(),f.args=t?v:d,f},definition:function(){var e,t,i,n,o=[],l=!1;if(!("."!==s.currentChar()&&"#"!==s.currentChar()||s.peek(/^[^{]*\}/)))if(s.save(),t=s.$re(/^([#.](?:[\w-]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\s*\(/)){e=t[1];var u=this.args(!1);if(o=u.args,l=u.variadic,!s.$char(")"))return void s.restore("Missing closing ')'");if(s.commentStore.length=0,s.$str("when")&&(n=a(r.conditions,"expected condition")),i=r.block())return s.forget(),new Ce.mixin.Definition(e,o,i,n,l);s.restore()}else s.restore()},ruleLookups:function(){var e,t=[];if("["===s.currentChar()){for(;;){if(s.save(),!(e=this.lookupValue())&&""!==e){s.restore();break}t.push(e),s.forget()}return t.length>0?t:void 0}},lookupValue:function(){if(s.save(),s.$char("[")){var e=s.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/);if(s.$char("]"))return e||""===e?(s.forget(),e):void s.restore();s.restore()}else s.restore()}},entity:function(){var e=this.entities;return this.comment()||e.literal()||e.variable()||e.url()||e.property()||e.call()||e.keyword()||this.mixin.call(!0)||e.javascript()},end:function(){return s.$char(";")||s.peek("}")},ieAlpha:function(){var e;if(s.$re(/^opacity=/i))return(e=s.$re(/^\d+/))||(e="@{"+(e=a(r.entities.variable,"Could not parse alpha")).name.slice(1)+"}"),l(")"),new Ce.Quoted("","alpha(opacity="+e+")")},element:function(){var e,t,i,r=s.i;if(t=this.combinator(),(e=s.$re(/^(?:\d+\.\d+|\d+)%/)||s.$re(/^(?:[.#]?|:*)(?:[\w-]|[^\x00-\x9f]|\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/)||s.$char("*")||s.$char("&")||this.attribute()||s.$re(/^\([^&()@]+\)/)||s.$re(/^[\.#:](?=@)/)||this.entities.variableCurly())||(s.save(),s.$char("(")?(i=this.selector(!1))&&s.$char(")")?(e=new Ce.Paren(i),s.forget()):s.restore("Missing closing ')'"):s.forget()),e)return new Ce.Element(t,e,e instanceof Ce.Variable,r,n)},combinator:function(){var e=s.currentChar();if("/"===e){s.save();var t=s.$re(/^\/[a-z]+\//i);if(t)return s.forget(),new Ce.Combinator(t);s.restore()}if(">"===e||"+"===e||"~"===e||"|"===e||"^"===e){for(s.i++,"^"===e&&"^"===s.currentChar()&&(e="^^",s.i++);s.isWhitespace();)s.i++;return new Ce.Combinator(e)}return s.isWhitespace(-1)?new Ce.Combinator(" "):new Ce.Combinator(null)},selector:function(e){var t,i,r,l,u,c,h,f=s.i;for(e=!1!==e;(e&&(i=this.extend())||e&&(c=s.$str("when"))||(l=this.element()))&&(c?h=a(this.conditions,"expected condition"):h?o("CSS guard can only be used at the end of selector"):i?u=u?u.concat(i):i:(u&&o("Extend can only be used at the end of selector"),r=s.currentChar(),t?t.push(l):t=[l],l=null),"{"!==r&&"}"!==r&&";"!==r&&","!==r&&")"!==r););if(t)return new Ce.Selector(t,u,h,f,n);u&&o("Extend must be used to extend a selector, it cannot be used on its own")},selectors:function(){for(var e,t;(e=this.selector())&&(t?t.push(e):t=[e],s.commentStore.length=0,e.condition&&t.length>1&&o("Guards are only currently allowed on a single selector."),s.$char(","));)e.condition&&o("Guards are only currently allowed on a single selector."),s.commentStore.length=0;return t},attribute:function(){if(s.$char("[")){var e,t,i,n=this.entities;return(e=n.variableCurly())||(e=a(/^(?:[_A-Za-z0-9-\*]*\|)?(?:[_A-Za-z0-9-]|\\.)+/)),(i=s.$re(/^[|~*$^]?=/))&&(t=n.quoted()||s.$re(/^[0-9]+%/)||s.$re(/^[\w-]+/)||n.variableCurly()),l("]"),new Ce.Attribute(e,i,t)}},block:function(){var e;if(s.$char("{")&&(e=this.primary())&&s.$char("}"))return e},blockRuleset:function(){var e=this.block();return e&&(e=new Ce.Ruleset(null,e)),e},detachedRuleset:function(){var e,t,i;if(s.save(),!s.$re(/^[.#]\(/)||(t=(e=this.mixin.args(!1)).args,i=e.variadic,s.$char(")"))){var n=this.blockRuleset();if(n)return s.forget(),t?new Ce.mixin.Definition(null,t,n,null,i):new Ce.DetachedRuleset(n);s.restore()}else s.restore()},ruleset:function(){var e,i,n;if(s.save(),t.dumpLineNumbers&&(n=u(s.i)),(e=this.selectors())&&(i=this.block())){s.forget();var r=new Ce.Ruleset(e,i,t.strictImports);return t.dumpLineNumbers&&(r.debugInfo=n),r}s.restore()},declaration:function(){var e,t,i,r,o,a,l=s.i,u=s.currentChar();if("."!==u&&"#"!==u&&"&"!==u&&":"!==u)if(s.save(),e=this.variable()||this.ruleProperty()){if((a="string"==typeof e)&&(t=this.detachedRuleset())&&(i=!0),s.commentStore.length=0,!t){if(o=!a&&e.length>1&&e.pop().value,t=e[0].value&&"--"===e[0].value.slice(0,2)?this.permissiveValue():this.anonymousValue())return s.forget(),new Ce.Declaration(e,t,!1,o,l,n);t||(t=this.value()),t?r=this.important():a&&(t=this.permissiveValue())}if(t&&(this.end()||i))return s.forget(),new Ce.Declaration(e,t,r,o,l,n);s.restore()}else s.restore()},anonymousValue:function(){var e=s.i,t=s.$re(/^([^.#@\$+\/'"*`(;{}-]*);/);if(t)return new Ce.Anonymous(t[1],e)},permissiveValue:function(e){var t,i,r,a,l=e||";",u=s.i,c=[];function h(){var e=s.currentChar();return"string"==typeof l?e===l:l.test(e)}if(!h()){a=[];do{((i=this.comment())||(i=this.entity()))&&a.push(i)}while(i);if(r=h(),a.length>0){if(a=new Ce.Expression(a),r)return a;c.push(a)," "===s.prevChar()&&c.push(new Ce.Anonymous(" ",u))}if(s.save(),a=s.$parseUntil(l)){if("string"==typeof a&&o("Expected '"+a+"'","Parse"),1===a.length&&" "===a[0])return s.forget(),new Ce.Anonymous("",u);var f=void 0;for(t=0;t0)return new Ce.Expression(r)},mediaFeatures:function(){var e,t=this.entities,i=[];do{if(e=this.mediaFeature()){if(i.push(e),!s.$char(","))break}else if((e=t.variable()||t.mixinLookup())&&(i.push(e),!s.$char(",")))break}while(e);return i.length>0?i:null},media:function(){var e,i,r,a,l=s.i;if(t.dumpLineNumbers&&(a=u(l)),s.save(),s.$str("@media"))return e=this.mediaFeatures(),(i=this.block())||o("media definitions require block statements after any features"),s.forget(),r=new Ce.Media(i,e,l,n),t.dumpLineNumbers&&(r.debugInfo=a),r;s.restore()},plugin:function(){var e,t,i,r=s.i;if(s.$re(/^@plugin?\s+/)){if(i=(t=this.pluginArgs())?{pluginArgs:t,isPlugin:!0}:{isPlugin:!0},e=this.entities.quoted()||this.entities.url())return s.$char(";")||(s.i=r,o("missing semi-colon on @plugin")),new Ce.Import(e,null,i,r,n);s.i=r,o("malformed @plugin statement")}},pluginArgs:function(){if(s.save(),!s.$char("("))return s.restore(),null;var e=s.$re(/^\s*([^\);]+)\)\s*/);return e[1]?(s.forget(),e[1].trim()):(s.restore(),null)},atrule:function(){var e,i,r,a,l,c,h,f=s.i,p=!0,v=!0;if("@"===s.currentChar()){if(i=this.import()||this.plugin()||this.media())return i;if(s.save(),e=s.$re(/^@[a-z-]+/)){switch(a=e,"-"==e.charAt(1)&&e.indexOf("-",2)>0&&(a="@"+e.slice(e.indexOf("-",2)+1)),a){case"@charset":l=!0,p=!1;break;case"@namespace":c=!0,p=!1;break;case"@keyframes":case"@counter-style":l=!0;break;case"@document":case"@supports":h=!0,v=!1;break;default:h=!0}if(s.commentStore.length=0,l?(i=this.entity())||o("expected "+e+" identifier"):c?(i=this.expression())||o("expected "+e+" expression"):h&&(i=this.permissiveValue(/^[{;]/),p="{"===s.currentChar(),i?i.value||(i=null):p||";"===s.currentChar()||o(e+" rule is missing block or ending semi-colon")),p&&(r=this.blockRuleset()),r||!p&&i&&s.$char(";"))return s.forget(),new Ce.AtRule(e,i,r,f,n,t.dumpLineNumbers?u(f):null,v);s.restore("at-rule options not recognised")}}},value:function(){var e,t=[],i=s.i;do{if((e=this.expression())&&(t.push(e),!s.$char(",")))break}while(e);if(t.length>0)return new Ce.Value(t,i)},important:function(){if("!"===s.currentChar())return s.$re(/^! *important/)},sub:function(){var e,t;if(s.save(),s.$char("("))return(e=this.addition())&&s.$char(")")?(s.forget(),(t=new Ce.Expression([e])).parens=!0,t):void s.restore("Expected ')'");s.restore()},multiplication:function(){var e,t,i,n,r;if(e=this.operand()){for(r=s.isWhitespace(-1);!s.peek(/^\/[*\/]/);){if(s.save(),!(i=s.$char("/")||s.$char("*")||s.$str("./"))){s.forget();break}if(!(t=this.operand())){s.restore();break}s.forget(),e.parensInOp=!0,t.parensInOp=!0,n=new Ce.Operation(i,[n||e,t],r),r=s.isWhitespace(-1)}return n||e}},addition:function(){var e,t,i,n,r;if(e=this.multiplication()){for(r=s.isWhitespace(-1);(i=s.$re(/^[-+]\s+/)||!r&&(s.$char("+")||s.$char("-")))&&(t=this.multiplication());)e.parensInOp=!0,t.parensInOp=!0,n=new Ce.Operation(i,[n||e,t],r),r=s.isWhitespace(-1);return n||e}},conditions:function(){var e,t,i,n=s.i;if(e=this.condition(!0)){for(;s.peek(/^,\s*(not\s*)?\(/)&&s.$char(",")&&(t=this.condition(!0));)i=new Ce.Condition("or",i||e,t,n);return i||e}},condition:function(e){var t,i,n;if(t=this.conditionAnd(e)){if(i=s.$str("or")){if(!(n=this.condition(e)))return;t=new Ce.Condition(i,t,n)}return t}},conditionAnd:function(e){var t,i,n,r,o=this;if(t=(r=o.negatedCondition(e)||o.parenthesisCondition(e))||e?r:o.atomicCondition(e)){if(i=s.$str("and")){if(!(n=this.conditionAnd(e)))return;t=new Ce.Condition(i,t,n)}return t}},negatedCondition:function(e){if(s.$str("not")){var t=this.parenthesisCondition(e);return t&&(t.negate=!t.negate),t}},parenthesisCondition:function(e){var t;if(s.save(),s.$str("(")){if(t=function(t){var i;if(s.save(),i=t.condition(e)){if(s.$char(")"))return s.forget(),i;s.restore()}else s.restore()}(this))return s.forget(),t;if(t=this.atomicCondition(e)){if(s.$char(")"))return s.forget(),t;s.restore("expected ')' got '"+s.currentChar()+"'")}else s.restore()}else s.restore()},atomicCondition:function(e){var t,i,n,r,a=this.entities,l=s.i;function u(){return this.addition()||a.keyword()||a.quoted()||a.mixinLookup()}if(t=(u=u.bind(this))())return s.$char(">")?r=s.$char("=")?">=":">":s.$char("<")?r=s.$char("=")?"<=":"<":s.$char("=")&&(r=s.$char(">")?"=>":s.$char("<")?"=<":"="),r?(i=u())?n=new Ce.Condition(r,t,i,l,!1):o("expected expression"):n=new Ce.Condition("=",t,new Ce.Keyword("true"),l,!1),n},operand:function(){var e,t=this.entities;s.peek(/^-[@\$\(]/)&&(e=s.$char("-"));var i=this.sub()||t.dimension()||t.color()||t.variable()||t.property()||t.call()||t.quoted(!0)||t.colorKeyword()||t.mixinLookup();return e&&(i.parensInOp=!0,i=new Ce.Negative(i)),i},expression:function(){var e,t,i=[],n=s.i;do{(e=this.comment())?i.push(e):((e=this.addition()||this.entity())instanceof Ce.Comment&&(e=null),e&&(i.push(e),s.peek(/^\/[\/*]/)||(t=s.$char("/"))&&i.push(new Ce.Anonymous(t,n))))}while(e);if(i.length>0)return new Ce.Expression(i)},property:function(){var e=s.$re(/^(\*?-?[_a-zA-Z0-9-]+)\s*:/);if(e)return e[1]},ruleProperty:function(){var e,t,i=[],r=[];s.save();var o=s.$re(/^([_a-zA-Z0-9-]+)\s*:/);if(o)return i=[new Ce.Keyword(o[1])],s.forget(),i;function a(e){var t=s.i,n=s.$re(e);if(n)return r.push(t),i.push(n[1])}for(a(/^(\*?)/);a(/^((?:[\w-]+)|(?:[@\$]\{[\w-]+\}))/););if(i.length>1&&a(/^((?:\+_|\+)?)\s*:/)){for(s.forget(),""===i[0]&&(i.shift(),r.shift()),t=0;t1?e-1:e)<1?r+(s-r)*e*6:2*e<1?s:3*e<2?r+(s-r)*(2/3-e)*6:r}e=Ke(e)%360/360,t=We(Ke(t)),i=We(Ke(i)),n=We(Ke(n)),r=2*i-(s=i<=.5?i*(t+1):i+t-i*t);var a=[255*o(e+1/3),255*o(e),255*o(e-1/3)];return n=Ke(n),new c(a,n,"hsla")}catch(e){}},hsv:function(e,t,i){return ze.hsva(e,t,i,1)},hsva:function(e,t,i,n){var r,s;e=Ke(e)%360/360*360,t=Ke(t),i=Ke(i),n=Ke(n);var o=[i,i*(1-t),i*(1-(s=e/60-(r=Math.floor(e/60%6)))*t),i*(1-(1-s)*t)],a=[[0,3,1],[2,0,1],[1,0,3],[1,2,0],[3,1,0],[0,1,2]];return ze.rgba(255*o[a[r][0]],255*o[a[r][1]],255*o[a[r][2]],n)},hue:function(e){return new ee(He(e).h)},saturation:function(e){return new ee(100*He(e).s,"%")},lightness:function(e){return new ee(100*He(e).l,"%")},hsvhue:function(e){return new ee(Qe(e).h)},hsvsaturation:function(e){return new ee(100*Qe(e).s,"%")},hsvvalue:function(e){return new ee(100*Qe(e).v,"%")},red:function(e){return new ee(e.rgb[0])},green:function(e){return new ee(e.rgb[1])},blue:function(e){return new ee(e.rgb[2])},alpha:function(e){return new ee(He(e).a)},luma:function(e){return new ee(e.luma()*e.alpha*100,"%")},luminance:function(e){var t=.2126*e.rgb[0]/255+.7152*e.rgb[1]/255+.0722*e.rgb[2]/255;return new ee(t*e.alpha*100,"%")},saturate:function(e,t,i){if(!e.rgb)return null;var n=He(e);return void 0!==i&&"relative"===i.value?n.s+=n.s*t.value/100:n.s+=t.value/100,n.s=We(n.s),Je(e,n)},desaturate:function(e,t,i){var n=He(e);return void 0!==i&&"relative"===i.value?n.s-=n.s*t.value/100:n.s-=t.value/100,n.s=We(n.s),Je(e,n)},lighten:function(e,t,i){var n=He(e);return void 0!==i&&"relative"===i.value?n.l+=n.l*t.value/100:n.l+=t.value/100,n.l=We(n.l),Je(e,n)},darken:function(e,t,i){var n=He(e);return void 0!==i&&"relative"===i.value?n.l-=n.l*t.value/100:n.l-=t.value/100,n.l=We(n.l),Je(e,n)},fadein:function(e,t,i){var n=He(e);return void 0!==i&&"relative"===i.value?n.a+=n.a*t.value/100:n.a+=t.value/100,n.a=We(n.a),Je(e,n)},fadeout:function(e,t,i){var n=He(e);return void 0!==i&&"relative"===i.value?n.a-=n.a*t.value/100:n.a-=t.value/100,n.a=We(n.a),Je(e,n)},fade:function(e,t){var i=He(e);return i.a=t.value/100,i.a=We(i.a),Je(e,i)},spin:function(e,t){var i=He(e),n=(i.h+t.value)%360;return i.h=n<0?360+n:n,Je(e,i)},mix:function(e,t,i){i||(i=new ee(50));var n=i.value/100,r=2*n-1,s=He(e).a-He(t).a,o=((r*s==-1?r:(r+s)/(1+r*s))+1)/2,a=1-o,l=[e.rgb[0]*o+t.rgb[0]*a,e.rgb[1]*o+t.rgb[1]*a,e.rgb[2]*o+t.rgb[2]*a],u=e.alpha*n+t.alpha*(1-n);return new c(l,u)},greyscale:function(e){return ze.desaturate(e,new ee(100))},contrast:function(e,t,i,n){if(!e.rgb)return null;if(void 0===i&&(i=ze.rgba(255,255,255,1)),void 0===t&&(t=ze.rgba(0,0,0,1)),t.luma()>i.luma()){var r=i;i=t,t=r}return n=void 0===n?.43:Ke(n),e.luma().5&&(n=1,i=e>.25?Math.sqrt(e):((16*e-12)*e+4)*e),e-(1-2*t)*n*(i-e)},hardlight:function(e,t){return Ye.overlay(t,e)},difference:function(e,t){return Math.abs(e-t)},exclusion:function(e,t){return e+t-2*e*t},average:function(e,t){return(e+t)/2},negation:function(e,t){return 1-Math.abs(e+t-1)}};for(var et in Ye)Ye.hasOwnProperty(et)&&(Xe[et]=Xe.bind(null,Ye[et]));var tt=function(e){return Array.isArray(e.value)?e.value:Array(e)},it={_SELF:function(e){return e},"~":function(){for(var e=[],t=0;to.value)&&(c[n]=r);else{if(void 0!==l&&a!==l)throw{type:"Argument",message:"incompatible types"};h[a]=c.length,c.push(r)}else Array.isArray(t[i].value)&&Array.prototype.push.apply(t,Array.prototype.slice.call(t[i].value));return 1==c.length?c[0]:(t=c.map((function(e){return e.toCSS(this.context)})).join(this.context.compress?",":", "),new j((e?"min":"max")+"("+t+")"))},at={min:function(){for(var e=[],t=0;t",r=0;r";return n+="',n=encodeURIComponent(n),new ce(new ue("'"+(n="data:image/svg+xml,"+n)+"'",n,!1,this.index,this.currentFileInfo),this.index,this.currentFileInfo)}}),H.addMultiple(ht),t};function pt(e,t){var i,n=(t=t||{}).variables,r=new q.Eval(t);"object"!=typeof n||Array.isArray(n)||(n=Object.keys(n).map((function(e){var t=n[e];return t instanceof Ce.Value||(t instanceof Ce.Expression||(t=new Ce.Expression([t])),t=new Ce.Value([t])),new Ce.Declaration("@"+e,t,!1,null,0)})),r.frames=[new Ce.Ruleset(null,n)]);var s,o,a=[new De.JoinSelectorVisitor,new De.MarkVisibleSelectorsVisitor(!0),new De.ExtendVisitor,new De.ToCSSVisitor({compress:Boolean(t.compress)})],l=[];if(t.pluginManager){o=t.pluginManager.visitor();for(var u=0;u<2;u++)for(o.first();s=o.get();)s.isPreEvalVisitor?0!==u&&-1!==l.indexOf(s)||(l.push(s),s.run(e)):0!==u&&-1!==a.indexOf(s)||(s.isPreVisitor?a.unshift(s):a.push(s))}i=e.eval(r);for(u=0;u=t);i++);this.preProcessors.splice(i,0,{preProcessor:e,priority:t})},e.prototype.addPostProcessor=function(e,t){var i;for(i=0;i=t);i++);this.postProcessors.splice(i,0,{postProcessor:e,priority:t})},e.prototype.addFileManager=function(e){this.fileManagers.push(e)},e.prototype.getPreProcessors=function(){for(var e=[],t=0;t0){var n=void 0,r=JSON.stringify(this._sourceMapGenerator.toJSON());this.sourceMapURL?n=this.sourceMapURL:this._sourceMapFilename&&(n=this._sourceMapFilename),this.sourceMapURL=n,this.sourceMap=r}return this._css.join("")},t}()}(e=new s(e,t)),e)),a=function(e){return function(){function t(e,t,i){this.less=e,this.rootFilename=i.filename,this.paths=t.paths||[],this.contents={},this.contentsIgnoredChars={},this.mime=t.mime,this.error=null,this.context=t,this.queue=[],this.files={}}return t.prototype.push=function(t,i,n,s,o){var a=this,l=this.context.pluginManager.Loader;this.queue.push(t);var u=function(e,i,n){a.queue.splice(a.queue.indexOf(t),1);var l=n===a.rootFilename;s.optional&&e?(o(null,{rules:[]},!1,null),r.info("The file "+n+" was skipped because it was not found and the import was marked optional.")):(a.files[n]||s.inline||(a.files[n]={root:i,options:s}),e&&!a.error&&(a.error=e),o(e,i,l,n))},c={rewriteUrls:this.context.rewriteUrls,entryPath:n.entryPath,rootpath:n.rootpath,rootFilename:n.rootFilename},h=e.getFileManager(t,n.currentDirectory,this.context,e);if(h){var f,p,v=function(e){var t,i=e.filename,r=e.contents.replace(/^\uFEFF/,"");c.currentDirectory=h.getPath(i),c.rewriteUrls&&(c.rootpath=h.join(a.context.rootpath||"",h.pathDiff(c.currentDirectory,c.entryPath)),!h.isPathAbsolute(c.rootpath)&&h.alwaysMakePathsAbsolute()&&(c.rootpath=h.join(c.entryPath,c.rootpath))),c.filename=i;var o=new q.Parse(a.context);o.processImports=!1,a.contents[i]=r,(n.reference||s.reference)&&(c.reference=!0),s.isPlugin?(t=l.evalPlugin(r,o,a,s.pluginArgs,c))instanceof O?u(t,null,i):u(null,t,i):s.inline?u(null,r,i):!a.files[i]||a.files[i].options.multiple||s.multiple?new Be(o,a,c).parse(r,(function(e,t){u(e,t,i)})):u(null,a.files[i].root,i)},d=_(this.context);i&&(d.ext=s.isPlugin?".js":".less"),s.isPlugin?(d.mime="application/javascript",d.syncImport?f=l.loadPluginSync(t,n.currentDirectory,d,e,h):p=l.loadPlugin(t,n.currentDirectory,d,e,h)):d.syncImport?f=h.loadFileSync(t,n.currentDirectory,d,e):p=h.loadFile(t,n.currentDirectory,d,e,(function(e,t){e?u(e):v(t)})),f?f.filename?v(f):u(f):p&&p.then(v,u)}else u({message:"Could not find a file-manager for "+t})},t}()}(e);var u,c=function(e,t,i){var n=function(e,i,r){if("function"==typeof i?(r=i,i=M(this.options,{})):i=M(this.options,i||{}),!r){var s=this;return new Promise((function(t,r){n.call(s,e,i,(function(e,i){e?r(e):t(i)}))}))}this.parse(e,i,(function(e,i,n,s){if(e)return r(e);var o;try{o=new t(i,n).toCSS(s)}catch(e){return r(e)}r(null,o)}))};return n}(0,o),h=function(e,t,i){var n=function(e,t,r){if("function"==typeof t?(r=t,t=M(this.options,{})):t=M(this.options,t||{}),!r){var s=this;return new Promise((function(i,r){n.call(s,e,t,(function(e,t){e?r(e):i(t)}))}))}var o,a=void 0,l=new mt(this,!t.reUsePluginManager);if(t.pluginManager=l,o=new q.Parse(t),t.rootFileInfo)a=t.rootFileInfo;else{var u=t.filename||"input",c=u.replace(/[^\/\\]*$/,"");(a={filename:u,rewriteUrls:o.rewriteUrls,rootpath:o.rootpath||"",currentDirectory:c,entryPath:c,rootFilename:u}).rootpath&&"/"!==a.rootpath.slice(-1)&&(a.rootpath+="/")}var h=new i(this,o,a);this.importManager=h,t.plugins&&t.plugins.forEach((function(e){var t,i;if(e.fileContent){if(i=e.fileContent.replace(/^\uFEFF/,""),(t=l.Loader.evalPlugin(i,o,h,e.options,e.filename))instanceof O)return r(t)}else l.addPlugin(e)})),new Be(o,h,a).parse(e,(function(e,i){if(e)return r(e);r(null,i,h,t)}),t)};return n}(0,0,a),f=bt("4.0.0"),p={version:[f.major,f.minor,f.patch],data:l,tree:Ce,Environment:s,AbstractFileManager:ke,AbstractPluginLoader:_e,environment:e,visitors:De,Parser:Be,functions:ft(e),contexts:q,SourceMapOutput:i,SourceMapBuilder:n,ParseTree:o,ImportManager:a,render:c,parse:h,LessError:O,transformTree:pt,utils:P,PluginManager:mt,logger:r},v=function(e){return function(){var t=Object.create(e.prototype);return e.apply(t,Array.prototype.slice.call(arguments,0)),t}},d=Object.create(p);for(var m in p.tree)if("function"==typeof(u=p.tree[m]))d[m.toLowerCase()]=v(u);else for(var g in d[m]=Object.create(null),u)d[m][g.toLowerCase()]=v(u[g]);return p.parse=p.parse.bind(d),p.render=p.render.bind(d),d}var xt={},St=function(){};St.prototype=Object.assign(new ke,{alwaysMakePathsAbsolute:function(){return!0},join:function(e,t){return e?this.extractUrlParts(t,e).path:t},doXHR:function(e,t,i,n){var r=new XMLHttpRequest,s=!gt.isFileProtocol||gt.fileAsync;function o(t,i,n){t.status>=200&&t.status<300?i(t.responseText,t.getResponseHeader("Last-Modified")):"function"==typeof n&&n(t.status,e)}"function"==typeof r.overrideMimeType&&r.overrideMimeType("text/css"),yt.debug("XHR: Getting '"+e+"'"),r.open("GET",e,s),r.setRequestHeader("Accept",t||"text/x-less, text/css; q=0.9, */*; q=0.5"),r.send(null),gt.isFileProtocol&&!gt.fileAsync?0===r.status||r.status>=200&&r.status<300?i(r.responseText):n(r.status,e):s?r.onreadystatechange=function(){4==r.readyState&&o(r,i,n)}:o(r,i,n)},supports:function(){return!0},clearFileCache:function(){xt={}},loadFile:function(e,t,i,n){t&&!this.isPathAbsolute(e)&&(e=t+e),e=i.ext?this.tryAppendExtension(e,i.ext):e,i=i||{};var r=this.extractUrlParts(e,window.location.href).url,s=this;return new Promise((function(e,t){if(i.useFileCache&&xt[r])try{var n=xt[r];return e({contents:n,filename:r,webInfo:{lastModified:new Date}})}catch(e){return t({filename:r,message:"Error loading file "+r+" error was "+e.message})}s.doXHR(r,i.mime,(function(t,i){xt[r]=t,e({contents:t,filename:r,webInfo:{lastModified:i}})}),(function(e,i){t({type:"File",message:"'"+i+"' wasn't found ("+e+")",href:r})}))}))}});var It=function(e,t){return gt=e,yt=t,St},Ct=function(e){this.less=e};Ct.prototype=Object.assign(new _e,{loadPlugin:function(e,t,i,n,r){return new Promise((function(s,o){r.loadFile(e,t,i,n).then(s).catch(o)}))}});var kt=function(t,n,r){return{add:function(s,o){r.errorReporting&&"html"!==r.errorReporting?"console"===r.errorReporting?function(e,t){var i=e.filename||t,s=[],o=(e.type||"Syntax")+"Error: "+(e.message||"There is an error in your .less file")+" in "+i,a=function(e,t,i){void 0!==e.extract[t]&&s.push("{line} {content}".replace(/\{line\}/,(parseInt(e.line,10)||0)+(t-1)).replace(/\{class\}/,i).replace(/\{content\}/,e.extract[t]))};e.line&&(a(e,0,""),a(e,1,"line"),a(e,2,""),o+=" on line "+e.line+", column "+(e.column+1)+":\n"+s.join("\n")),e.stack&&(e.extract||r.logLevel>=4)&&(o+="\nStack Trace\n"+e.stack),n.logger.error(o)}(s,o):"function"==typeof r.errorReporting&&r.errorReporting("add",s,o):function(n,s){var o,a,l="less-error-message:"+e(s||""),u=t.document.createElement("div"),c=[],h=n.filename||s,f=h.match(/([^\/]+(\?.*)?)$/)[1];u.id=l,u.className="less-error-message",a="

    "+(n.type||"Syntax")+"Error: "+(n.message||"There is an error in your .less file")+'

    in '+f+" ";var p=function(e,t,i){void 0!==e.extract[t]&&c.push('

  • {content}
  • '.replace(/\{line\}/,(parseInt(e.line,10)||0)+(t-1)).replace(/\{class\}/,i).replace(/\{content\}/,e.extract[t]))};n.line&&(p(n,0,""),p(n,1,"line"),p(n,2,""),a+="on line "+n.line+", column "+(n.column+1)+":

      "+c.join("")+"
    "),n.stack&&(n.extract||r.logLevel>=4)&&(a+="
    Stack Trace
    "+n.stack.split("\n").slice(1).join("
    ")),u.innerHTML=a,i(t.document,[".less-error-message ul, .less-error-message li {","list-style-type: none;","margin-right: 15px;","padding: 4px 0;","margin: 0;","}",".less-error-message label {","font-size: 12px;","margin-right: 15px;","padding: 4px 0;","color: #cc7777;","}",".less-error-message pre {","color: #dd6666;","padding: 4px 0;","margin: 0;","display: inline-block;","}",".less-error-message pre.line {","color: #ff0000;","}",".less-error-message h3 {","font-size: 20px;","font-weight: bold;","padding: 15px 0 5px 0;","margin: 0;","}",".less-error-message a {","color: #10a","}",".less-error-message .error {","color: red;","font-weight: bold;","padding-bottom: 2px;","border-bottom: 1px dashed red;","}"].join("\n"),{title:"error-message"}),u.style.cssText=["font-family: Arial, sans-serif","border: 1px solid #e00","background-color: #eee","border-radius: 5px","-webkit-border-radius: 5px","-moz-border-radius: 5px","color: #e00","padding: 15px","margin-bottom: 15px"].join(";"),"development"===r.env&&(o=setInterval((function(){var e=t.document,i=e.body;i&&(e.getElementById(l)?i.replaceChild(u,e.getElementById(l)):i.insertBefore(u,i.firstChild),clearInterval(o))}),10))}(s,o)},remove:function(i){r.errorReporting&&"html"!==r.errorReporting?"console"===r.errorReporting||"function"==typeof r.errorReporting&&r.errorReporting("remove",i):function(i){var n=t.document.getElementById("less-error-message:"+e(i));n&&n.parentNode.removeChild(n)}(i)}}},_t={javascriptEnabled:!1,depends:!1,compress:!1,lint:!1,paths:[],color:!0,strictImports:!1,insecure:!1,rootpath:"",rewriteUrls:!1,math:1,strictUnits:!1,globalVars:null,modifyVars:null,urlArgs:""};if(window.less)for(var At in window.less)window.less.hasOwnProperty(At)&&(_t[At]=window.less[At]);!function(e,i){t(i,n(e)),void 0===i.isFileProtocol&&(i.isFileProtocol=/^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(e.location.protocol)),i.async=i.async||!1,i.fileAsync=i.fileAsync||!1,i.poll=i.poll||(i.isFileProtocol?1e3:1500),i.env=i.env||("127.0.0.1"==e.location.hostname||"0.0.0.0"==e.location.hostname||"localhost"==e.location.hostname||e.location.port&&e.location.port.length>0||i.isFileProtocol?"development":"production");var r=/!dumpLineNumbers:(comments|mediaquery|all)/.exec(e.location.hash);r&&(i.dumpLineNumbers=r[1]),void 0===i.useFileCache&&(i.useFileCache=!0),void 0===i.onReady&&(i.onReady=!0),i.relativeUrls&&(i.rewriteUrls="all")}(window,_t),_t.plugins=_t.plugins||[],window.LESS_PLUGINS&&(_t.plugins=_t.plugins.concat(window.LESS_PLUGINS));var Mt,Et,Pt,Rt=function(e,n){var r=e.document,s=wt();s.options=n;var o=s.environment,a=It(n,s.logger),l=new a;o.addFileManager(l),s.FileManager=a,s.PluginLoader=Ct,function(e,t){t.logLevel=void 0!==t.logLevel?t.logLevel:"development"===t.env?3:1,t.loggers||(t.loggers=[{debug:function(e){t.logLevel>=4&&console.log(e)},info:function(e){t.logLevel>=3&&console.log(e)},warn:function(e){t.logLevel>=2&&console.warn(e)},error:function(e){t.logLevel>=1&&console.error(e)}}]);for(var i=0;i 0 && styleNode.childNodes.length > 0 &&\n oldStyleNode.firstChild.nodeValue === styleNode.firstChild.nodeValue);\n }\n\n const head = document.getElementsByTagName('head')[0];\n\n // If there is no oldStyleNode, just append; otherwise, only append if we need\n // to replace oldStyleNode with an updated stylesheet\n if (oldStyleNode === null || keepOldStyleNode === false) {\n const nextEl = sheet && sheet.nextSibling || null;\n if (nextEl) {\n nextEl.parentNode.insertBefore(styleNode, nextEl);\n } else {\n head.appendChild(styleNode);\n }\n }\n if (oldStyleNode && keepOldStyleNode === false) {\n oldStyleNode.parentNode.removeChild(oldStyleNode);\n }\n\n // For IE.\n // This needs to happen *after* the style element is added to the DOM, otherwise IE 7 and 8 may crash.\n // See http://social.msdn.microsoft.com/Forums/en-US/7e081b65-878a-4c22-8e68-c10d39c2ed32/internet-explorer-crashes-appending-style-element-to-head\n if (styleNode.styleSheet) {\n try {\n styleNode.styleSheet.cssText = styles;\n } catch (e) {\n throw new Error('Couldn\\'t reassign styleSheet.cssText.');\n }\n }\n },\n currentScript: function(window) {\n const document = window.document;\n return document.currentScript || (() => {\n const scripts = document.getElementsByTagName('script');\n return scripts[scripts.length - 1];\n })();\n }\n};\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport function __createBinding(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n result.default = mod;\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to get private field on non-instance\");\r\n }\r\n return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to set private field on non-instance\");\r\n }\r\n privateMap.set(receiver, value);\r\n return value;\r\n}\r\n","export default {\n 'aliceblue':'#f0f8ff',\n 'antiquewhite':'#faebd7',\n 'aqua':'#00ffff',\n 'aquamarine':'#7fffd4',\n 'azure':'#f0ffff',\n 'beige':'#f5f5dc',\n 'bisque':'#ffe4c4',\n 'black':'#000000',\n 'blanchedalmond':'#ffebcd',\n 'blue':'#0000ff',\n 'blueviolet':'#8a2be2',\n 'brown':'#a52a2a',\n 'burlywood':'#deb887',\n 'cadetblue':'#5f9ea0',\n 'chartreuse':'#7fff00',\n 'chocolate':'#d2691e',\n 'coral':'#ff7f50',\n 'cornflowerblue':'#6495ed',\n 'cornsilk':'#fff8dc',\n 'crimson':'#dc143c',\n 'cyan':'#00ffff',\n 'darkblue':'#00008b',\n 'darkcyan':'#008b8b',\n 'darkgoldenrod':'#b8860b',\n 'darkgray':'#a9a9a9',\n 'darkgrey':'#a9a9a9',\n 'darkgreen':'#006400',\n 'darkkhaki':'#bdb76b',\n 'darkmagenta':'#8b008b',\n 'darkolivegreen':'#556b2f',\n 'darkorange':'#ff8c00',\n 'darkorchid':'#9932cc',\n 'darkred':'#8b0000',\n 'darksalmon':'#e9967a',\n 'darkseagreen':'#8fbc8f',\n 'darkslateblue':'#483d8b',\n 'darkslategray':'#2f4f4f',\n 'darkslategrey':'#2f4f4f',\n 'darkturquoise':'#00ced1',\n 'darkviolet':'#9400d3',\n 'deeppink':'#ff1493',\n 'deepskyblue':'#00bfff',\n 'dimgray':'#696969',\n 'dimgrey':'#696969',\n 'dodgerblue':'#1e90ff',\n 'firebrick':'#b22222',\n 'floralwhite':'#fffaf0',\n 'forestgreen':'#228b22',\n 'fuchsia':'#ff00ff',\n 'gainsboro':'#dcdcdc',\n 'ghostwhite':'#f8f8ff',\n 'gold':'#ffd700',\n 'goldenrod':'#daa520',\n 'gray':'#808080',\n 'grey':'#808080',\n 'green':'#008000',\n 'greenyellow':'#adff2f',\n 'honeydew':'#f0fff0',\n 'hotpink':'#ff69b4',\n 'indianred':'#cd5c5c',\n 'indigo':'#4b0082',\n 'ivory':'#fffff0',\n 'khaki':'#f0e68c',\n 'lavender':'#e6e6fa',\n 'lavenderblush':'#fff0f5',\n 'lawngreen':'#7cfc00',\n 'lemonchiffon':'#fffacd',\n 'lightblue':'#add8e6',\n 'lightcoral':'#f08080',\n 'lightcyan':'#e0ffff',\n 'lightgoldenrodyellow':'#fafad2',\n 'lightgray':'#d3d3d3',\n 'lightgrey':'#d3d3d3',\n 'lightgreen':'#90ee90',\n 'lightpink':'#ffb6c1',\n 'lightsalmon':'#ffa07a',\n 'lightseagreen':'#20b2aa',\n 'lightskyblue':'#87cefa',\n 'lightslategray':'#778899',\n 'lightslategrey':'#778899',\n 'lightsteelblue':'#b0c4de',\n 'lightyellow':'#ffffe0',\n 'lime':'#00ff00',\n 'limegreen':'#32cd32',\n 'linen':'#faf0e6',\n 'magenta':'#ff00ff',\n 'maroon':'#800000',\n 'mediumaquamarine':'#66cdaa',\n 'mediumblue':'#0000cd',\n 'mediumorchid':'#ba55d3',\n 'mediumpurple':'#9370d8',\n 'mediumseagreen':'#3cb371',\n 'mediumslateblue':'#7b68ee',\n 'mediumspringgreen':'#00fa9a',\n 'mediumturquoise':'#48d1cc',\n 'mediumvioletred':'#c71585',\n 'midnightblue':'#191970',\n 'mintcream':'#f5fffa',\n 'mistyrose':'#ffe4e1',\n 'moccasin':'#ffe4b5',\n 'navajowhite':'#ffdead',\n 'navy':'#000080',\n 'oldlace':'#fdf5e6',\n 'olive':'#808000',\n 'olivedrab':'#6b8e23',\n 'orange':'#ffa500',\n 'orangered':'#ff4500',\n 'orchid':'#da70d6',\n 'palegoldenrod':'#eee8aa',\n 'palegreen':'#98fb98',\n 'paleturquoise':'#afeeee',\n 'palevioletred':'#d87093',\n 'papayawhip':'#ffefd5',\n 'peachpuff':'#ffdab9',\n 'peru':'#cd853f',\n 'pink':'#ffc0cb',\n 'plum':'#dda0dd',\n 'powderblue':'#b0e0e6',\n 'purple':'#800080',\n 'rebeccapurple':'#663399',\n 'red':'#ff0000',\n 'rosybrown':'#bc8f8f',\n 'royalblue':'#4169e1',\n 'saddlebrown':'#8b4513',\n 'salmon':'#fa8072',\n 'sandybrown':'#f4a460',\n 'seagreen':'#2e8b57',\n 'seashell':'#fff5ee',\n 'sienna':'#a0522d',\n 'silver':'#c0c0c0',\n 'skyblue':'#87ceeb',\n 'slateblue':'#6a5acd',\n 'slategray':'#708090',\n 'slategrey':'#708090',\n 'snow':'#fffafa',\n 'springgreen':'#00ff7f',\n 'steelblue':'#4682b4',\n 'tan':'#d2b48c',\n 'teal':'#008080',\n 'thistle':'#d8bfd8',\n 'tomato':'#ff6347',\n 'turquoise':'#40e0d0',\n 'violet':'#ee82ee',\n 'wheat':'#f5deb3',\n 'white':'#ffffff',\n 'whitesmoke':'#f5f5f5',\n 'yellow':'#ffff00',\n 'yellowgreen':'#9acd32'\n};","export default {\n length: {\n 'm': 1,\n 'cm': 0.01,\n 'mm': 0.001,\n 'in': 0.0254,\n 'px': 0.0254 / 96,\n 'pt': 0.0254 / 72,\n 'pc': 0.0254 / 72 * 12\n },\n duration: {\n 's': 1,\n 'ms': 0.001\n },\n angle: {\n 'rad': 1 / (2 * Math.PI),\n 'deg': 1 / 360,\n 'grad': 1 / 400,\n 'turn': 1\n }\n};","import colors from './colors';\nimport unitConversions from './unit-conversions';\n\nexport default { colors, unitConversions };\n","/**\n * The reason why Node is a class and other nodes simply do not extend\n * from Node (since we're transpiling) is due to this issue:\n * \n * https://github.com/less/less.js/issues/3434\n */\nclass Node {\n constructor() {\n this.parent = null;\n this.visibilityBlocks = undefined;\n this.nodeVisible = undefined;\n this.rootNode = null;\n this.parsed = null;\n\n const self = this;\n Object.defineProperty(this, 'currentFileInfo', {\n get: function() { return self.fileInfo(); }\n });\n Object.defineProperty(this, 'index', {\n get: function() { return self.getIndex(); }\n });\n\n }\n\n setParent(nodes, parent) {\n function set(node) {\n if (node && node instanceof Node) {\n node.parent = parent;\n }\n }\n if (Array.isArray(nodes)) {\n nodes.forEach(set);\n }\n else {\n set(nodes);\n }\n }\n\n getIndex() {\n return this._index || (this.parent && this.parent.getIndex()) || 0;\n }\n\n fileInfo() {\n return this._fileInfo || (this.parent && this.parent.fileInfo()) || {};\n }\n\n isRulesetLike() {\n return false;\n }\n\n toCSS(context) {\n const strs = [];\n this.genCSS(context, {\n add: function(chunk, fileInfo, index) {\n strs.push(chunk);\n },\n isEmpty: function () {\n return strs.length === 0;\n }\n });\n return strs.join('');\n }\n\n genCSS(context, output) {\n output.add(this.value);\n }\n\n accept(visitor) {\n this.value = visitor.visit(this.value);\n }\n\n eval() { return this; }\n\n _operate(context, op, a, b) {\n switch (op) {\n case '+': return a + b;\n case '-': return a - b;\n case '*': return a * b;\n case '/': return a / b;\n }\n }\n\n fround(context, value) {\n const precision = context && context.numPrecision;\n // add \"epsilon\" to ensure numbers like 1.000000005 (represented as 1.000000004999...) are properly rounded:\n return (precision) ? Number((value + 2e-16).toFixed(precision)) : value;\n }\n\n // Returns true if this node represents root of ast imported by reference\n blocksVisibility() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n return this.visibilityBlocks !== 0;\n }\n\n addVisibilityBlock() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n this.visibilityBlocks = this.visibilityBlocks + 1;\n }\n\n removeVisibilityBlock() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n this.visibilityBlocks = this.visibilityBlocks - 1;\n }\n\n // Turns on node visibility - if called node will be shown in output regardless\n // of whether it comes from import by reference or not\n ensureVisibility() {\n this.nodeVisible = true;\n }\n\n // Turns off node visibility - if called node will NOT be shown in output regardless\n // of whether it comes from import by reference or not\n ensureInvisibility() {\n this.nodeVisible = false;\n }\n\n // return values:\n // false - the node must not be visible\n // true - the node must be visible\n // undefined or null - the node has the same visibility as its parent\n isVisible() {\n return this.nodeVisible;\n }\n\n visibilityInfo() {\n return {\n visibilityBlocks: this.visibilityBlocks,\n nodeVisible: this.nodeVisible\n };\n }\n\n copyVisibilityInfo(info) {\n if (!info) {\n return;\n }\n this.visibilityBlocks = info.visibilityBlocks;\n this.nodeVisible = info.nodeVisible;\n }\n}\n\nNode.compare = (a, b) => {\n /* returns:\n -1: a < b\n 0: a = b\n 1: a > b\n and *any* other value for a != b (e.g. undefined, NaN, -2 etc.) */\n\n if ((a.compare) &&\n // for \"symmetric results\" force toCSS-based comparison\n // of Quoted or Anonymous if either value is one of those\n !(b.type === 'Quoted' || b.type === 'Anonymous')) {\n return a.compare(b);\n } else if (b.compare) {\n return -b.compare(a);\n } else if (a.type !== b.type) {\n return undefined;\n }\n\n a = a.value;\n b = b.value;\n if (!Array.isArray(a)) {\n return a === b ? 0 : undefined;\n }\n if (a.length !== b.length) {\n return undefined;\n }\n for (let i = 0; i < a.length; i++) {\n if (Node.compare(a[i], b[i]) !== 0) {\n return undefined;\n }\n }\n return 0;\n};\n\nNode.numericCompare = (a, b) => a < b ? -1\n : a === b ? 0\n : a > b ? 1 : undefined;\nexport default Node;\n","import Node from './node';\nimport colors from '../data/colors';\n\n//\n// RGB Colors - #ff0014, #eee\n//\nconst Color = function(rgb, a, originalForm) {\n const self = this;\n //\n // The end goal here, is to parse the arguments\n // into an integer triplet, such as `128, 255, 0`\n //\n // This facilitates operations and conversions.\n //\n if (Array.isArray(rgb)) {\n this.rgb = rgb;\n } else if (rgb.length >= 6) {\n this.rgb = [];\n rgb.match(/.{2}/g).map((c, i) => {\n if (i < 3) {\n self.rgb.push(parseInt(c, 16));\n } else {\n self.alpha = (parseInt(c, 16)) / 255;\n }\n });\n } else {\n this.rgb = [];\n rgb.split('').map((c, i) => {\n if (i < 3) {\n self.rgb.push(parseInt(c + c, 16));\n } else {\n self.alpha = (parseInt(c + c, 16)) / 255;\n }\n });\n }\n this.alpha = this.alpha || (typeof a === 'number' ? a : 1);\n if (typeof originalForm !== 'undefined') {\n this.value = originalForm;\n }\n};\n\nColor.prototype = new Node();\n\nColor.prototype.luma = function() {\n let r = this.rgb[0] / 255;\n let g = this.rgb[1] / 255;\n let b = this.rgb[2] / 255;\n\n r = (r <= 0.03928) ? r / 12.92 : Math.pow(((r + 0.055) / 1.055), 2.4);\n g = (g <= 0.03928) ? g / 12.92 : Math.pow(((g + 0.055) / 1.055), 2.4);\n b = (b <= 0.03928) ? b / 12.92 : Math.pow(((b + 0.055) / 1.055), 2.4);\n\n return 0.2126 * r + 0.7152 * g + 0.0722 * b;\n};\n\nColor.prototype.genCSS = function(context, output) {\n output.add(this.toCSS(context));\n};\n\nColor.prototype.toCSS = function(context, doNotCompress) {\n const compress = context && context.compress && !doNotCompress;\n let color;\n let alpha;\n let colorFunction;\n let args = [];\n\n // `value` is set if this color was originally\n // converted from a named color string so we need\n // to respect this and try to output named color too.\n alpha = this.fround(context, this.alpha);\n\n if (this.value) {\n if (this.value.indexOf('rgb') === 0) {\n if (alpha < 1) {\n colorFunction = 'rgba';\n }\n } else if (this.value.indexOf('hsl') === 0) {\n if (alpha < 1) {\n colorFunction = 'hsla';\n } else {\n colorFunction = 'hsl';\n }\n } else {\n return this.value;\n }\n } else {\n if (alpha < 1) {\n colorFunction = 'rgba';\n }\n }\n\n switch (colorFunction) {\n case 'rgba':\n args = this.rgb.map(c => clamp(Math.round(c), 255)).concat(clamp(alpha, 1));\n break;\n case 'hsla':\n args.push(clamp(alpha, 1));\n case 'hsl':\n color = this.toHSL();\n args = [\n this.fround(context, color.h),\n `${this.fround(context, color.s * 100)}%`,\n `${this.fround(context, color.l * 100)}%`\n ].concat(args);\n }\n\n if (colorFunction) {\n // Values are capped between `0` and `255`, rounded and zero-padded.\n return `${colorFunction}(${args.join(`,${compress ? '' : ' '}`)})`;\n }\n\n color = this.toRGB();\n\n if (compress) {\n const splitcolor = color.split('');\n\n // Convert color to short format\n if (splitcolor[1] === splitcolor[2] && splitcolor[3] === splitcolor[4] && splitcolor[5] === splitcolor[6]) {\n color = `#${splitcolor[1]}${splitcolor[3]}${splitcolor[5]}`;\n }\n }\n\n return color;\n};\n\n//\n// Operations have to be done per-channel, if not,\n// channels will spill onto each other. Once we have\n// our result, in the form of an integer triplet,\n// we create a new Color node to hold the result.\n//\nColor.prototype.operate = function(context, op, other) {\n const rgb = new Array(3);\n const alpha = this.alpha * (1 - other.alpha) + other.alpha;\n for (let c = 0; c < 3; c++) {\n rgb[c] = this._operate(context, op, this.rgb[c], other.rgb[c]);\n }\n return new Color(rgb, alpha);\n};\n\nColor.prototype.toRGB = function() {\n return toHex(this.rgb);\n};\n\nColor.prototype.toHSL = function() {\n const r = this.rgb[0] / 255;\n const g = this.rgb[1] / 255;\n const b = this.rgb[2] / 255;\n const a = this.alpha;\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n let h;\n let s;\n const l = (max + min) / 2;\n const d = max - min;\n\n if (max === min) {\n h = s = 0;\n } else {\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n\n switch (max) {\n case r: h = (g - b) / d + (g < b ? 6 : 0); break;\n case g: h = (b - r) / d + 2; break;\n case b: h = (r - g) / d + 4; break;\n }\n h /= 6;\n }\n return { h: h * 360, s, l, a };\n};\n\n// Adapted from http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript\nColor.prototype.toHSV = function() {\n const r = this.rgb[0] / 255;\n const g = this.rgb[1] / 255;\n const b = this.rgb[2] / 255;\n const a = this.alpha;\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n let h;\n let s;\n const v = max;\n\n const d = max - min;\n if (max === 0) {\n s = 0;\n } else {\n s = d / max;\n }\n\n if (max === min) {\n h = 0;\n } else {\n switch (max) {\n case r: h = (g - b) / d + (g < b ? 6 : 0); break;\n case g: h = (b - r) / d + 2; break;\n case b: h = (r - g) / d + 4; break;\n }\n h /= 6;\n }\n return { h: h * 360, s, v, a };\n};\n\nColor.prototype.toARGB = function() {\n return toHex([this.alpha * 255].concat(this.rgb));\n};\n\nColor.prototype.compare = function(x) {\n return (x.rgb &&\n x.rgb[0] === this.rgb[0] &&\n x.rgb[1] === this.rgb[1] &&\n x.rgb[2] === this.rgb[2] &&\n x.alpha === this.alpha) ? 0 : undefined;\n};\n\nColor.prototype.type = 'Color';\n\nfunction clamp(v, max) {\n return Math.min(Math.max(v, 0), max);\n}\n\nfunction toHex(v) {\n return `#${v.map(c => {\n c = clamp(Math.round(c), 255);\n return (c < 16 ? '0' : '') + c.toString(16);\n }).join('')}`;\n}\n\nColor.fromKeyword = keyword => {\n let c;\n const key = keyword.toLowerCase();\n if (colors.hasOwnProperty(key)) {\n c = new Color(colors[key].slice(1));\n }\n else if (key === 'transparent') {\n c = new Color([0, 0, 0], 0);\n }\n\n if (c) {\n c.value = keyword;\n return c;\n }\n};\n\nexport default Color;\n","import Node from './node';\n\nconst Paren = function(node) {\n this.value = node;\n};\n\nParen.prototype = new Node();\n\nParen.prototype.genCSS = function(context, output) {\n output.add('(');\n this.value.genCSS(context, output);\n output.add(')');\n}\n\nParen.prototype.eval = function(context) {\n return new Paren(this.value.eval(context));\n};\n\nParen.prototype.type = 'Paren';\nexport default Paren;\n","import Node from './node';\nconst _noSpaceCombinators = {\n '': true,\n ' ': true,\n '|': true\n};\n\nconst Combinator = function(value) {\n if (value === ' ') {\n this.value = ' ';\n this.emptyOrWhitespace = true;\n } else {\n this.value = value ? value.trim() : '';\n this.emptyOrWhitespace = this.value === '';\n }\n};\n\nCombinator.prototype = new Node();\n\nCombinator.prototype.genCSS = function(context, output) {\n const spaceOrEmpty = (context.compress || _noSpaceCombinators[this.value]) ? '' : ' ';\n output.add(spaceOrEmpty + this.value + spaceOrEmpty);\n};\n\nCombinator.prototype.type = 'Combinator';\n\nexport default Combinator;\n","import Node from './node';\nimport Paren from './paren';\nimport Combinator from './combinator';\n\nconst Element = function(combinator, value, isVariable, index, currentFileInfo, visibilityInfo) {\n this.combinator = combinator instanceof Combinator ?\n combinator : new Combinator(combinator);\n\n if (typeof value === 'string') {\n this.value = value.trim();\n } else if (value) {\n this.value = value;\n } else {\n this.value = '';\n }\n this.isVariable = isVariable;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.combinator, this);\n};\n\nElement.prototype = new Node();\n\nElement.prototype.accept = function(visitor) {\n const value = this.value;\n this.combinator = visitor.visit(this.combinator);\n if (typeof value === 'object') {\n this.value = visitor.visit(value);\n }\n};\n\nElement.prototype.eval = function(context) {\n return new Element(this.combinator,\n this.value.eval ? this.value.eval(context) : this.value,\n this.isVariable,\n this.getIndex(),\n this.fileInfo(), this.visibilityInfo());\n};\n\nElement.prototype.clone = function() {\n return new Element(this.combinator,\n this.value,\n this.isVariable,\n this.getIndex(),\n this.fileInfo(), this.visibilityInfo());\n};\n\nElement.prototype.genCSS = function(context, output) {\n output.add(this.toCSS(context), this.fileInfo(), this.getIndex());\n};\n\nElement.prototype.toCSS = function(context = {}) {\n let value = this.value;\n const firstSelector = context.firstSelector;\n if (value instanceof Paren) {\n // selector in parens should not be affected by outer selector\n // flags (breaks only interpolated selectors - see #1973)\n context.firstSelector = true;\n }\n value = value.toCSS ? value.toCSS(context) : value;\n context.firstSelector = firstSelector;\n if (value === '' && this.combinator.value.charAt(0) === '&') {\n return '';\n } else {\n return this.combinator.toCSS(context) + value;\n }\n};\n\nElement.prototype.type = 'Element';\nexport default Element;\n","\nexport const Math = {\n ALWAYS: 0,\n PARENS_DIVISION: 1,\n PARENS: 2,\n STRICT_LEGACY: 3\n};\n\nexport const RewriteUrls = {\n OFF: 0,\n LOCAL: 1,\n ALL: 2\n};","/**\r\n * Returns the object type of the given payload\r\n *\r\n * @param {*} payload\r\n * @returns {string}\r\n */\r\nfunction getType(payload) {\r\n return Object.prototype.toString.call(payload).slice(8, -1);\r\n}\r\n/**\r\n * Returns whether the payload is undefined\r\n *\r\n * @param {*} payload\r\n * @returns {payload is undefined}\r\n */\r\nfunction isUndefined(payload) {\r\n return getType(payload) === 'Undefined';\r\n}\r\n/**\r\n * Returns whether the payload is null\r\n *\r\n * @param {*} payload\r\n * @returns {payload is null}\r\n */\r\nfunction isNull(payload) {\r\n return getType(payload) === 'Null';\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isPlainObject(payload) {\r\n if (getType(payload) !== 'Object')\r\n return false;\r\n return payload.constructor === Object && Object.getPrototypeOf(payload) === Object.prototype;\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isObject(payload) {\r\n return isPlainObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a an empty object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is { [K in any]: never }}\r\n */\r\nfunction isEmptyObject(payload) {\r\n return isPlainObject(payload) && Object.keys(payload).length === 0;\r\n}\r\n/**\r\n * Returns whether the payload is an any kind of object (including special classes or objects with different prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isAnyObject(payload) {\r\n return getType(payload) === 'Object';\r\n}\r\n/**\r\n * Returns whether the payload is an object like a type passed in < >\r\n *\r\n * Usage: isObjectLike<{id: any}>(payload) // will make sure it's an object and has an `id` prop.\r\n *\r\n * @template T this must be passed in < >\r\n * @param {*} payload\r\n * @returns {payload is T}\r\n */\r\nfunction isObjectLike(payload) {\r\n return isAnyObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a function (regular or async)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is AnyFunction}\r\n */\r\nfunction isFunction(payload) {\r\n return typeof payload === \"function\";\r\n}\r\n/**\r\n * Returns whether the payload is an array\r\n *\r\n * @param {any} payload\r\n * @returns {payload is any[]}\r\n */\r\nfunction isArray(payload) {\r\n return getType(payload) === 'Array';\r\n}\r\n/**\r\n * Returns whether the payload is a an array with at least 1 item\r\n *\r\n * @param {*} payload\r\n * @returns {payload is any[]}\r\n */\r\nfunction isFullArray(payload) {\r\n return isArray(payload) && payload.length > 0;\r\n}\r\n/**\r\n * Returns whether the payload is a an empty array\r\n *\r\n * @param {*} payload\r\n * @returns {payload is []}\r\n */\r\nfunction isEmptyArray(payload) {\r\n return isArray(payload) && payload.length === 0;\r\n}\r\n/**\r\n * Returns whether the payload is a string\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isString(payload) {\r\n return getType(payload) === 'String';\r\n}\r\n/**\r\n * Returns whether the payload is a string, BUT returns false for ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isFullString(payload) {\r\n return isString(payload) && payload !== '';\r\n}\r\n/**\r\n * Returns whether the payload is ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isEmptyString(payload) {\r\n return payload === '';\r\n}\r\n/**\r\n * Returns whether the payload is a number (but not NaN)\r\n *\r\n * This will return `false` for `NaN`!!\r\n *\r\n * @param {*} payload\r\n * @returns {payload is number}\r\n */\r\nfunction isNumber(payload) {\r\n return getType(payload) === 'Number' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a boolean\r\n *\r\n * @param {*} payload\r\n * @returns {payload is boolean}\r\n */\r\nfunction isBoolean(payload) {\r\n return getType(payload) === 'Boolean';\r\n}\r\n/**\r\n * Returns whether the payload is a regular expression (RegExp)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is RegExp}\r\n */\r\nfunction isRegExp(payload) {\r\n return getType(payload) === 'RegExp';\r\n}\r\n/**\r\n * Returns whether the payload is a Map\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Map}\r\n */\r\nfunction isMap(payload) {\r\n return getType(payload) === 'Map';\r\n}\r\n/**\r\n * Returns whether the payload is a WeakMap\r\n *\r\n * @param {*} payload\r\n * @returns {payload is WeakMap}\r\n */\r\nfunction isWeakMap(payload) {\r\n return getType(payload) === 'WeakMap';\r\n}\r\n/**\r\n * Returns whether the payload is a Set\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Set}\r\n */\r\nfunction isSet(payload) {\r\n return getType(payload) === 'Set';\r\n}\r\n/**\r\n * Returns whether the payload is a WeakSet\r\n *\r\n * @param {*} payload\r\n * @returns {payload is WeakSet}\r\n */\r\nfunction isWeakSet(payload) {\r\n return getType(payload) === 'WeakSet';\r\n}\r\n/**\r\n * Returns whether the payload is a Symbol\r\n *\r\n * @param {*} payload\r\n * @returns {payload is symbol}\r\n */\r\nfunction isSymbol(payload) {\r\n return getType(payload) === 'Symbol';\r\n}\r\n/**\r\n * Returns whether the payload is a Date, and that the date is valid\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Date}\r\n */\r\nfunction isDate(payload) {\r\n return getType(payload) === 'Date' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a Blob\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Blob}\r\n */\r\nfunction isBlob(payload) {\r\n return getType(payload) === 'Blob';\r\n}\r\n/**\r\n * Returns whether the payload is a File\r\n *\r\n * @param {*} payload\r\n * @returns {payload is File}\r\n */\r\nfunction isFile(payload) {\r\n return getType(payload) === 'File';\r\n}\r\n/**\r\n * Returns whether the payload is a Promise\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Promise}\r\n */\r\nfunction isPromise(payload) {\r\n return getType(payload) === 'Promise';\r\n}\r\n/**\r\n * Returns whether the payload is an Error\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Error}\r\n */\r\nfunction isError(payload) {\r\n return getType(payload) === 'Error';\r\n}\r\n/**\r\n * Returns whether the payload is literally the value `NaN` (it's `NaN` and also a `number`)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is typeof NaN}\r\n */\r\nfunction isNaNValue(payload) {\r\n return getType(payload) === 'Number' && isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a primitive type (eg. Boolean | Null | Undefined | Number | String | Symbol)\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is boolean | null | undefined | number | string | symbol)}\r\n */\r\nfunction isPrimitive(payload) {\r\n return (isBoolean(payload) ||\r\n isNull(payload) ||\r\n isUndefined(payload) ||\r\n isNumber(payload) ||\r\n isString(payload) ||\r\n isSymbol(payload));\r\n}\r\n/**\r\n * Returns true whether the payload is null or undefined\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is null | undefined)}\r\n */\r\nfunction isNullOrUndefined(payload) {\r\n return isNull(payload) || isUndefined(payload);\r\n}\r\n/**\r\n * Does a generic check to check that the given payload is of a given type.\r\n * In cases like Number, it will return true for NaN as NaN is a Number (thanks javascript!);\r\n * It will, however, differentiate between object and null\r\n *\r\n * @template T\r\n * @param {*} payload\r\n * @param {T} type\r\n * @throws {TypeError} Will throw type error if type is an invalid type\r\n * @returns {payload is T}\r\n */\r\nfunction isType(payload, type) {\r\n if (!(type instanceof Function)) {\r\n throw new TypeError('Type must be a function');\r\n }\r\n if (!Object.prototype.hasOwnProperty.call(type, 'prototype')) {\r\n throw new TypeError('Type is not a class');\r\n }\r\n // Classes usually have names (as functions usually have names)\r\n var name = type.name;\r\n return getType(payload) === name || Boolean(payload && payload.constructor === type);\r\n}\n\nexport { getType, isAnyObject, isArray, isBlob, isBoolean, isDate, isEmptyArray, isEmptyObject, isEmptyString, isError, isFile, isFullArray, isFullString, isFunction, isMap, isNaNValue, isNull, isNullOrUndefined, isNumber, isObject, isObjectLike, isPlainObject, isPrimitive, isPromise, isRegExp, isSet, isString, isSymbol, isType, isUndefined, isWeakMap, isWeakSet };\n","import { isArray, isPlainObject } from 'is-what';\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n\r\nfunction __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\n\nfunction assignProp(carry, key, newVal, originalObject, includeNonenumerable) {\r\n var propType = {}.propertyIsEnumerable.call(originalObject, key)\r\n ? 'enumerable'\r\n : 'nonenumerable';\r\n if (propType === 'enumerable')\r\n carry[key] = newVal;\r\n if (includeNonenumerable && propType === 'nonenumerable') {\r\n Object.defineProperty(carry, key, {\r\n value: newVal,\r\n enumerable: false,\r\n writable: true,\r\n configurable: true,\r\n });\r\n }\r\n}\r\n/**\r\n * Copy (clone) an object and all its props recursively to get rid of any prop referenced of the original object. Arrays are also cloned, however objects inside arrays are still linked.\r\n *\r\n * @export\r\n * @template T\r\n * @param {T} target Target can be anything\r\n * @param {Options} [options={}] Options can be `props` or `nonenumerable`\r\n * @returns {T} the target with replaced values\r\n * @export\r\n */\r\nfunction copy(target, options) {\r\n if (options === void 0) { options = {}; }\r\n if (isArray(target))\r\n return target.map(function (i) { return copy(i, options); });\r\n if (!isPlainObject(target))\r\n return target;\r\n var props = Object.getOwnPropertyNames(target);\r\n var symbols = Object.getOwnPropertySymbols(target);\r\n return __spreadArrays(props, symbols).reduce(function (carry, key) {\r\n if (isArray(options.props) && !options.props.includes(key)) {\r\n return carry;\r\n }\r\n var val = target[key];\r\n var newVal = copy(val, options);\r\n assignProp(carry, key, newVal, target, options.nonenumerable);\r\n return carry;\r\n }, {});\r\n}\n\nexport { copy };\n","/* jshint proto: true */\nimport * as Constants from './constants';\nimport { copy } from 'copy-anything';\n\nexport function getLocation(index, inputStream) {\n let n = index + 1;\n let line = null;\n let column = -1;\n\n while (--n >= 0 && inputStream.charAt(n) !== '\\n') {\n column++;\n }\n\n if (typeof index === 'number') {\n line = (inputStream.slice(0, index).match(/\\n/g) || '').length;\n }\n\n return {\n line,\n column\n };\n}\n\nexport function copyArray(arr) {\n let i;\n const length = arr.length;\n const copy = new Array(length);\n\n for (i = 0; i < length; i++) {\n copy[i] = arr[i];\n }\n return copy;\n}\n\nexport function clone(obj) {\n const cloned = {};\n for (const prop in obj) {\n if (obj.hasOwnProperty(prop)) {\n cloned[prop] = obj[prop];\n }\n }\n return cloned;\n}\n\nexport function defaults(obj1, obj2) {\n let newObj = obj2 || {};\n if (!obj2._defaults) {\n newObj = {};\n const defaults = copy(obj1);\n newObj._defaults = defaults;\n const cloned = obj2 ? copy(obj2) : {};\n Object.assign(newObj, defaults, cloned);\n }\n return newObj;\n}\n\nexport function copyOptions(obj1, obj2) {\n if (obj2 && obj2._defaults) {\n return obj2;\n }\n const opts = defaults(obj1, obj2);\n if (opts.strictMath) {\n opts.math = Constants.Math.STRICT_LEGACY;\n }\n // Back compat with changed relativeUrls option\n if (opts.relativeUrls) {\n opts.rewriteUrls = Constants.RewriteUrls.ALL;\n }\n if (typeof opts.math === 'string') {\n switch (opts.math.toLowerCase()) {\n case 'always':\n opts.math = Constants.Math.ALWAYS;\n break;\n case 'parens-division':\n opts.math = Constants.Math.PARENS_DIVISION;\n break;\n case 'strict':\n case 'parens':\n opts.math = Constants.Math.PARENS;\n break;\n case 'strict-legacy':\n opts.math = Constants.Math.STRICT_LEGACY;\n }\n }\n if (typeof opts.rewriteUrls === 'string') {\n switch (opts.rewriteUrls.toLowerCase()) {\n case 'off':\n opts.rewriteUrls = Constants.RewriteUrls.OFF;\n break;\n case 'local':\n opts.rewriteUrls = Constants.RewriteUrls.LOCAL;\n break;\n case 'all':\n opts.rewriteUrls = Constants.RewriteUrls.ALL;\n break;\n }\n }\n return opts;\n}\n\nexport function merge(obj1, obj2) {\n for (const prop in obj2) {\n if (obj2.hasOwnProperty(prop)) {\n obj1[prop] = obj2[prop];\n }\n }\n return obj1;\n}\n\nexport function flattenArray(arr, result = []) {\n for (let i = 0, length = arr.length; i < length; i++) {\n const value = arr[i];\n if (Array.isArray(value)) {\n flattenArray(value, result);\n } else {\n if (value !== undefined) {\n result.push(value);\n }\n }\n }\n return result;\n}","import * as utils from './utils';\n\nconst anonymousFunc = /(|Function):(\\d+):(\\d+)/;\n\n/**\n * This is a centralized class of any error that could be thrown internally (mostly by the parser).\n * Besides standard .message it keeps some additional data like a path to the file where the error\n * occurred along with line and column numbers.\n *\n * @class\n * @extends Error\n * @type {module.LessError}\n *\n * @prop {string} type\n * @prop {string} filename\n * @prop {number} index\n * @prop {number} line\n * @prop {number} column\n * @prop {number} callLine\n * @prop {number} callExtract\n * @prop {string[]} extract\n *\n * @param {Object} e - An error object to wrap around or just a descriptive object\n * @param {Object} fileContentMap - An object with file contents in 'contents' property (like importManager) @todo - move to fileManager?\n * @param {string} [currentFilename]\n */\nconst LessError = function LessError(e, fileContentMap, currentFilename) {\n Error.call(this);\n\n const filename = e.filename || currentFilename;\n\n this.message = e.message;\n this.stack = e.stack;\n\n if (fileContentMap && filename) {\n const input = fileContentMap.contents[filename];\n const loc = utils.getLocation(e.index, input);\n const line = loc.line;\n const col = loc.column;\n const callLine = e.call && utils.getLocation(e.call, input).line;\n const lines = input ? input.split('\\n') : '';\n\n this.type = e.type || 'Syntax';\n this.filename = filename;\n this.index = e.index;\n this.line = typeof line === 'number' ? line + 1 : null;\n this.column = col;\n\n if (!this.line && this.stack) {\n const found = this.stack.match(anonymousFunc);\n\n /**\n * We have to figure out how this environment stringifies anonymous functions\n * so we can correctly map plugin errors.\n * \n * Note, in Node 8, the output of anonymous funcs varied based on parameters\n * being present or not, so we inject dummy params.\n */\n const func = new Function('a', 'throw new Error()');\n let lineAdjust = 0;\n try {\n func();\n } catch (e) {\n const match = e.stack.match(anonymousFunc);\n const line = parseInt(match[2]);\n lineAdjust = 1 - line;\n }\n\n if (found) {\n if (found[2]) {\n this.line = parseInt(found[2]) + lineAdjust;\n }\n if (found[3]) {\n this.column = parseInt(found[3]);\n }\n }\n }\n\n this.callLine = callLine + 1;\n this.callExtract = lines[callLine];\n\n this.extract = [\n lines[this.line - 2],\n lines[this.line - 1],\n lines[this.line]\n ];\n }\n\n};\n\nif (typeof Object.create === 'undefined') {\n const F = () => {};\n F.prototype = Error.prototype;\n LessError.prototype = new F();\n} else {\n LessError.prototype = Object.create(Error.prototype);\n}\n\nLessError.prototype.constructor = LessError;\n\n/**\n * An overridden version of the default Object.prototype.toString\n * which uses additional information to create a helpful message.\n *\n * @param {Object} options\n * @returns {string}\n */\nLessError.prototype.toString = function(options = {}) {\n let message = '';\n const extract = this.extract || [];\n let error = [];\n let stylize = str => str;\n if (options.stylize) {\n const type = typeof options.stylize;\n if (type !== 'function') {\n throw Error(`options.stylize should be a function, got a ${type}!`);\n }\n stylize = options.stylize;\n }\n\n if (this.line !== null) {\n if (typeof extract[0] === 'string') {\n error.push(stylize(`${this.line - 1} ${extract[0]}`, 'grey'));\n }\n\n if (typeof extract[1] === 'string') {\n let errorTxt = `${this.line} `;\n if (extract[1]) {\n errorTxt += extract[1].slice(0, this.column) +\n stylize(stylize(stylize(extract[1].substr(this.column, 1), 'bold') +\n extract[1].slice(this.column + 1), 'red'), 'inverse');\n }\n error.push(errorTxt);\n }\n\n if (typeof extract[2] === 'string') {\n error.push(stylize(`${this.line + 1} ${extract[2]}`, 'grey'));\n }\n error = `${error.join('\\n') + stylize('', 'reset')}\\n`;\n }\n\n message += stylize(`${this.type}Error: ${this.message}`, 'red');\n if (this.filename) {\n message += stylize(' in ', 'red') + this.filename;\n }\n if (this.line) {\n message += stylize(` on line ${this.line}, column ${this.column + 1}:`, 'grey');\n }\n\n message += `\\n${error}`;\n\n if (this.callLine) {\n message += `${stylize('from ', 'red') + (this.filename || '')}/n`;\n message += `${stylize(this.callLine, 'grey')} ${this.callExtract}/n`;\n }\n\n return message;\n};\n\nexport default LessError;","import Node from './node';\nimport Element from './element';\nimport LessError from '../less-error';\n\nconst Selector = function(elements, extendList, condition, index, currentFileInfo, visibilityInfo) {\n this.extendList = extendList;\n this.condition = condition;\n this.evaldCondition = !condition;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.elements = this.getElements(elements);\n this.mixinElements_ = undefined;\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.elements, this);\n}\n\nSelector.prototype = new Node();\n\nSelector.prototype.accept = function(visitor) {\n if (this.elements) {\n this.elements = visitor.visitArray(this.elements);\n }\n if (this.extendList) {\n this.extendList = visitor.visitArray(this.extendList);\n }\n if (this.condition) {\n this.condition = visitor.visit(this.condition);\n }\n};\n\nSelector.prototype.createDerived = function(elements, extendList, evaldCondition) {\n elements = this.getElements(elements);\n const newSelector = new Selector(elements, extendList || this.extendList,\n null, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n newSelector.evaldCondition = (evaldCondition != null) ? evaldCondition : this.evaldCondition;\n newSelector.mediaEmpty = this.mediaEmpty;\n return newSelector;\n};\n\nSelector.prototype.getElements = function(els) {\n if (!els) {\n return [new Element('', '&', false, this._index, this._fileInfo)];\n }\n if (typeof els === 'string') {\n this.parse.parseNode(\n els, \n ['selector'],\n this._index, \n this._fileInfo, \n function(err, result) {\n if (err) {\n throw new LessError({\n index: err.index,\n message: err.message\n }, this.parse.imports, this._fileInfo.filename);\n }\n els = result[0].elements;\n });\n }\n return els;\n};\n\nSelector.prototype.createEmptySelectors = function() {\n const el = new Element('', '&', false, this._index, this._fileInfo);\n const sels = [new Selector([el], null, null, this._index, this._fileInfo)];\n sels[0].mediaEmpty = true;\n return sels;\n};\n\nSelector.prototype.match = function(other) {\n const elements = this.elements;\n const len = elements.length;\n let olen;\n let i;\n\n other = other.mixinElements();\n olen = other.length;\n if (olen === 0 || len < olen) {\n return 0;\n } else {\n for (i = 0; i < olen; i++) {\n if (elements[i].value !== other[i]) {\n return 0;\n }\n }\n }\n\n return olen; // return number of matched elements\n};\n\nSelector.prototype.mixinElements = function() {\n if (this.mixinElements_) {\n return this.mixinElements_;\n }\n\n let elements = this.elements.map( v => v.combinator.value + (v.value.value || v.value)).join('').match(/[,&#\\*\\.\\w-]([\\w-]|(\\\\.))*/g);\n\n if (elements) {\n if (elements[0] === '&') {\n elements.shift();\n }\n } else {\n elements = [];\n }\n\n return (this.mixinElements_ = elements);\n};\n\nSelector.prototype.isJustParentSelector = function() {\n return !this.mediaEmpty &&\n this.elements.length === 1 &&\n this.elements[0].value === '&' &&\n (this.elements[0].combinator.value === ' ' || this.elements[0].combinator.value === '');\n};\n\nSelector.prototype.eval = function(context) {\n const evaldCondition = this.condition && this.condition.eval(context);\n let elements = this.elements;\n let extendList = this.extendList;\n\n elements = elements && elements.map(e => e.eval(context));\n extendList = extendList && extendList.map(extend => extend.eval(context));\n\n return this.createDerived(elements, extendList, evaldCondition);\n};\n\nSelector.prototype.genCSS = function(context, output) {\n let i;\n let element;\n if ((!context || !context.firstSelector) && this.elements[0].combinator.value === '') {\n output.add(' ', this.fileInfo(), this.getIndex());\n }\n for (i = 0; i < this.elements.length; i++) {\n element = this.elements[i];\n element.genCSS(context, output);\n }\n};\n\nSelector.prototype.getIsOutput = function() {\n return this.evaldCondition;\n};\n\nSelector.prototype.type = 'Selector';\nexport default Selector;\n","import Node from './node';\n\nconst Value = function(value) {\n if (!value) {\n throw new Error('Value requires an array argument');\n }\n if (!Array.isArray(value)) {\n this.value = [ value ];\n }\n else {\n this.value = value;\n }\n};\n\nValue.prototype = new Node();\n\nValue.prototype.accept = function(visitor) {\n if (this.value) {\n this.value = visitor.visitArray(this.value);\n }\n};\n\nValue.prototype.eval = function(context) {\n if (this.value.length === 1) {\n return this.value[0].eval(context);\n } else {\n return new Value(this.value.map(v => v.eval(context)));\n }\n};\n\nValue.prototype.genCSS = function(context, output) {\n let i;\n for (i = 0; i < this.value.length; i++) {\n this.value[i].genCSS(context, output);\n if (i + 1 < this.value.length) {\n output.add((context && context.compress) ? ',' : ', ');\n }\n }\n};\n\nValue.prototype.type = 'Value';\nexport default Value;\n","import Node from './node';\n\nconst Keyword = function(value) {\n this.value = value;\n};\n\nKeyword.prototype = new Node();\n\nKeyword.prototype.genCSS = function(context, output) {\n if (this.value === '%') { throw { type: 'Syntax', message: 'Invalid % without number' }; }\n output.add(this.value);\n};\n\nKeyword.prototype.type = 'Keyword';\n\nKeyword.True = new Keyword('true');\nKeyword.False = new Keyword('false');\n\nexport default Keyword;\n","import Node from './node';\nimport { extend } from './util';\n\nconst Anonymous = function(value, index, currentFileInfo, mapLines, rulesetLike, visibilityInfo) {\n this.value = value;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.mapLines = mapLines;\n this.rulesetLike = (typeof rulesetLike === 'undefined') ? false : rulesetLike;\n this.allowRoot = true;\n this.copyVisibilityInfo(visibilityInfo);\n}\n\nAnonymous.prototype = new Node();\n\nAnonymous.prototype.eval = function() {\n return new Anonymous(this.value, this._index, this._fileInfo, this.mapLines, this.rulesetLike, this.visibilityInfo());\n};\n\nAnonymous.prototype.compare = function(other) {\n return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined;\n};\n\nAnonymous.prototype.isRulesetLike = function() {\n return this.rulesetLike;\n};\n\nAnonymous.prototype.genCSS = function(context, output) {\n this.nodeVisible = Boolean(this.value);\n if (this.nodeVisible) {\n output.add(this.value, this._fileInfo, this._index, this.mapLines);\n }\n};\n\nAnonymous.prototype.type = 'Anonymous';\nexport default Anonymous;\n","import Node from './node';\nimport Value from './value';\nimport Keyword from './keyword';\nimport Anonymous from './anonymous';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\n\nconst Declaration = function(name, value, important, merge, index, currentFileInfo, inline, variable) {\n this.name = name;\n this.value = (value instanceof Node) ? value : new Value([value ? new Anonymous(value) : null]);\n this.important = important ? ` ${important.trim()}` : '';\n this.merge = merge;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.inline = inline || false;\n this.variable = (variable !== undefined) ? variable\n : (name.charAt && (name.charAt(0) === '@'));\n this.allowRoot = true;\n this.setParent(this.value, this);\n};\n\nDeclaration.prototype = new Node();\n\nDeclaration.prototype.genCSS = function(context, output) {\n output.add(this.name + (context.compress ? ':' : ': '), this.fileInfo(), this.getIndex());\n try {\n this.value.genCSS(context, output);\n }\n catch (e) {\n e.index = this._index;\n e.filename = this._fileInfo.filename;\n throw e;\n }\n output.add(this.important + ((this.inline || (context.lastRule && context.compress)) ? '' : ';'), this._fileInfo, this._index);\n}\n\nDeclaration.prototype.eval = function(context) {\n let mathBypass = false;\n let prevMath;\n let name = this.name;\n let evaldValue;\n let variable = this.variable;\n if (typeof name !== 'string') {\n // expand 'primitive' name directly to get\n // things faster (~10% for benchmark.less):\n name = (name.length === 1) && (name[0] instanceof Keyword) ?\n name[0].value : evalName(context, name);\n variable = false; // never treat expanded interpolation as new variable name\n }\n\n // @todo remove when parens-division is default\n if (name === 'font' && context.math === MATH.ALWAYS) {\n mathBypass = true;\n prevMath = context.math;\n context.math = MATH.PARENS_DIVISION;\n }\n try {\n context.importantScope.push({});\n evaldValue = this.value.eval(context);\n\n if (!this.variable && evaldValue.type === 'DetachedRuleset') {\n throw { message: 'Rulesets cannot be evaluated on a property.',\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n let important = this.important;\n const importantResult = context.importantScope.pop();\n if (!important && importantResult.important) {\n important = importantResult.important;\n }\n\n return new Declaration(name,\n evaldValue,\n important,\n this.merge,\n this.getIndex(), this.fileInfo(), this.inline,\n variable);\n }\n catch (e) {\n if (typeof e.index !== 'number') {\n e.index = this.getIndex();\n e.filename = this.fileInfo().filename;\n }\n throw e;\n }\n finally {\n if (mathBypass) {\n context.math = prevMath;\n }\n }\n};\n\nDeclaration.prototype.makeImportant = function() {\n return new Declaration(this.name,\n this.value,\n '!important',\n this.merge,\n this.getIndex(), this.fileInfo(), this.inline);\n};\n\nfunction evalName(context, name) {\n let value = '';\n let i;\n const n = name.length;\n const output = {add: function (s) {value += s;}};\n for (i = 0; i < n; i++) {\n name[i].eval(context).genCSS(context, output);\n }\n return value;\n}\n\nDeclaration.prototype.type = 'Declaration';\nexport default Declaration;","const debugInfo = (context, ctx, lineSeparator) => {\n let result = '';\n if (context.dumpLineNumbers && !context.compress) {\n switch (context.dumpLineNumbers) {\n case 'comments':\n result = debugInfo.asComment(ctx);\n break;\n case 'mediaquery':\n result = debugInfo.asMediaQuery(ctx);\n break;\n case 'all':\n result = debugInfo.asComment(ctx) + (lineSeparator || '') + debugInfo.asMediaQuery(ctx);\n break;\n }\n }\n return result;\n};\n\ndebugInfo.asComment = ctx => ctx.debugInfo ? `/* line ${ctx.debugInfo.lineNumber}, ${ctx.debugInfo.fileName} */\\n` : '';\n\ndebugInfo.asMediaQuery = ctx => {\n if (!ctx.debugInfo) { return ''; }\n let filenameWithProtocol = ctx.debugInfo.fileName;\n if (!/^[a-z]+:\\/\\//i.test(filenameWithProtocol)) {\n filenameWithProtocol = `file://${filenameWithProtocol}`;\n }\n return `@media -sass-debug-info{filename{font-family:${filenameWithProtocol.replace(/([.:\\/\\\\])/g, a => {\n if (a == '\\\\') {\n a = '\\/';\n }\n return `\\\\${a}`;\n })}}line{font-family:\\\\00003${ctx.debugInfo.lineNumber}}}\\n`;\n};\n\nexport default debugInfo;\n","import Node from './node';\nimport getDebugInfo from './debug-info';\n\nconst Comment = function(value, isLineComment, index, currentFileInfo) {\n this.value = value;\n this.isLineComment = isLineComment;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.allowRoot = true;\n};\n\nComment.prototype = new Node();\n\nComment.prototype.genCSS = function(context, output) {\n if (this.debugInfo) {\n output.add(getDebugInfo(context, this), this.fileInfo(), this.getIndex());\n }\n output.add(this.value);\n};\n\nComment.prototype.isSilent = function(context) {\n const isCompressed = context.compress && this.value[2] !== '!';\n return this.isLineComment || isCompressed;\n};\n\nComment.prototype.type = 'Comment';\nexport default Comment;\n","const contexts = {};\nexport default contexts;\nimport * as Constants from './constants';\n\nconst copyFromOriginal = function copyFromOriginal(original, destination, propertiesToCopy) {\n if (!original) { return; }\n\n for (let i = 0; i < propertiesToCopy.length; i++) {\n if (original.hasOwnProperty(propertiesToCopy[i])) {\n destination[propertiesToCopy[i]] = original[propertiesToCopy[i]];\n }\n }\n};\n\n/*\n parse is used whilst parsing\n */\nconst parseCopyProperties = [\n // options\n 'paths', // option - unmodified - paths to search for imports on\n 'rewriteUrls', // option - whether to adjust URL's to be relative\n 'rootpath', // option - rootpath to append to URL's\n 'strictImports', // option -\n 'insecure', // option - whether to allow imports from insecure ssl hosts\n 'dumpLineNumbers', // option - whether to dump line numbers\n 'compress', // option - whether to compress\n 'syncImport', // option - whether to import synchronously\n 'chunkInput', // option - whether to chunk input. more performant but causes parse issues.\n 'mime', // browser only - mime type for sheet import\n 'useFileCache', // browser only - whether to use the per file session cache\n // context\n 'processImports', // option & context - whether to process imports. if false then imports will not be imported.\n // Used by the import manager to stop multiple import visitors being created.\n 'pluginManager' // Used as the plugin manager for the session\n];\n\ncontexts.Parse = function(options) {\n copyFromOriginal(options, this, parseCopyProperties);\n\n if (typeof this.paths === 'string') { this.paths = [this.paths]; }\n};\n\nconst evalCopyProperties = [\n 'paths', // additional include paths\n 'compress', // whether to compress\n 'math', // whether math has to be within parenthesis\n 'strictUnits', // whether units need to evaluate correctly\n 'sourceMap', // whether to output a source map\n 'importMultiple', // whether we are currently importing multiple copies\n 'urlArgs', // whether to add args into url tokens\n 'javascriptEnabled', // option - whether Inline JavaScript is enabled. if undefined, defaults to false\n 'pluginManager', // Used as the plugin manager for the session\n 'importantScope', // used to bubble up !important statements\n 'rewriteUrls' // option - whether to adjust URL's to be relative\n];\n\nfunction isPathRelative(path) {\n return !/^(?:[a-z-]+:|\\/|#)/i.test(path);\n}\n\nfunction isPathLocalRelative(path) {\n return path.charAt(0) === '.';\n}\n\ncontexts.Eval = class {\n constructor(options, frames) {\n copyFromOriginal(options, this, evalCopyProperties);\n\n if (typeof this.paths === 'string') { this.paths = [this.paths]; }\n\n this.frames = frames || [];\n this.importantScope = this.importantScope || [];\n this.inCalc = false;\n this.mathOn = true;\n }\n\n enterCalc() {\n if (!this.calcStack) {\n this.calcStack = [];\n }\n this.calcStack.push(true);\n this.inCalc = true;\n }\n\n exitCalc() {\n this.calcStack.pop();\n if (!this.calcStack.length) {\n this.inCalc = false;\n }\n }\n\n inParenthesis() {\n if (!this.parensStack) {\n this.parensStack = [];\n }\n this.parensStack.push(true);\n };\n\n outOfParenthesis() {\n this.parensStack.pop();\n };\n\n isMathOn(op) {\n if (!this.mathOn) {\n return false;\n }\n if (op === '/' && this.math !== Constants.Math.ALWAYS && (!this.parensStack || !this.parensStack.length)) {\n return false;\n }\n if (this.math > Constants.Math.PARENS_DIVISION) {\n return this.parensStack && this.parensStack.length;\n }\n return true;\n }\n\n pathRequiresRewrite(path) {\n const isRelative = this.rewriteUrls === Constants.RewriteUrls.LOCAL ? isPathLocalRelative : isPathRelative;\n\n return isRelative(path);\n }\n\n rewritePath(path, rootpath) {\n let newPath;\n\n rootpath = rootpath || '';\n newPath = this.normalizePath(rootpath + path);\n\n // If a path was explicit relative and the rootpath was not an absolute path\n // we must ensure that the new path is also explicit relative.\n if (isPathLocalRelative(path) &&\n isPathRelative(rootpath) &&\n isPathLocalRelative(newPath) === false) {\n newPath = `./${newPath}`;\n }\n\n return newPath;\n }\n\n normalizePath(path) {\n const segments = path.split('/').reverse();\n let segment;\n\n path = [];\n while (segments.length !== 0) {\n segment = segments.pop();\n switch ( segment ) {\n case '.':\n break;\n case '..':\n if ((path.length === 0) || (path[path.length - 1] === '..')) {\n path.push( segment );\n } else {\n path.pop();\n }\n break;\n default:\n path.push(segment);\n break;\n }\n }\n\n return path.join('/');\n }\n}\n","function makeRegistry( base ) {\n return {\n _data: {},\n add: function(name, func) {\n // precautionary case conversion, as later querying of\n // the registry by function-caller uses lower case as well.\n name = name.toLowerCase();\n\n if (this._data.hasOwnProperty(name)) {\n // TODO warn\n }\n this._data[name] = func;\n },\n addMultiple: function(functions) {\n Object.keys(functions).forEach(\n name => {\n this.add(name, functions[name]);\n });\n },\n get: function(name) {\n return this._data[name] || ( base && base.get( name ));\n },\n getLocalFunctions: function() {\n return this._data;\n },\n inherit: function() {\n return makeRegistry( this );\n },\n create: function(base) {\n return makeRegistry(base);\n }\n };\n}\n\nexport default makeRegistry( null );","import Keyword from '../tree/keyword';\n\nconst defaultFunc = {\n eval: function () {\n const v = this.value_;\n const e = this.error_;\n if (e) {\n throw e;\n }\n if (v != null) {\n return v ? Keyword.True : Keyword.False;\n }\n },\n value: function (v) {\n this.value_ = v;\n },\n error: function (e) {\n this.error_ = e;\n },\n reset: function () {\n this.value_ = this.error_ = null;\n }\n};\n\nexport default defaultFunc;\n","import Node from './node';\nimport Declaration from './declaration';\nimport Keyword from './keyword';\nimport Comment from './comment';\nimport Paren from './paren';\nimport Selector from './selector';\nimport Element from './element';\nimport Anonymous from './anonymous';\nimport contexts from '../contexts';\nimport globalFunctionRegistry from '../functions/function-registry';\nimport defaultFunc from '../functions/default';\nimport getDebugInfo from './debug-info';\nimport * as utils from '../utils';\n\nconst Ruleset = function(selectors, rules, strictImports, visibilityInfo) {\n this.selectors = selectors;\n this.rules = rules;\n this._lookups = {};\n this._variables = null;\n this._properties = null;\n this.strictImports = strictImports;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n\n this.setParent(this.selectors, this);\n this.setParent(this.rules, this);\n}\n\nRuleset.prototype = new Node();\n\nRuleset.prototype.isRulesetLike = function() {\n return true;\n};\n\nRuleset.prototype.accept = function(visitor) {\n if (this.paths) {\n this.paths = visitor.visitArray(this.paths, true);\n } else if (this.selectors) {\n this.selectors = visitor.visitArray(this.selectors);\n }\n if (this.rules && this.rules.length) {\n this.rules = visitor.visitArray(this.rules);\n }\n};\n\nRuleset.prototype.eval = function(context) {\n const that = this;\n let selectors;\n let selCnt;\n let selector;\n let i;\n let hasVariable;\n let hasOnePassingSelector = false;\n\n if (this.selectors && (selCnt = this.selectors.length)) {\n selectors = new Array(selCnt);\n defaultFunc.error({\n type: 'Syntax',\n message: 'it is currently only allowed in parametric mixin guards,'\n });\n\n for (i = 0; i < selCnt; i++) {\n selector = this.selectors[i].eval(context);\n for (var j = 0; j < selector.elements.length; j++) {\n if (selector.elements[j].isVariable) {\n hasVariable = true;\n break;\n }\n }\n selectors[i] = selector;\n if (selector.evaldCondition) {\n hasOnePassingSelector = true;\n }\n }\n\n if (hasVariable) {\n const toParseSelectors = new Array(selCnt);\n for (i = 0; i < selCnt; i++) {\n selector = selectors[i];\n toParseSelectors[i] = selector.toCSS(context);\n }\n this.parse.parseNode(\n toParseSelectors.join(','),\n [\"selectors\"], \n selectors[0].getIndex(), \n selectors[0].fileInfo(), \n (err, result) => {\n if (result) {\n selectors = utils.flattenArray(result);\n }\n });\n }\n\n defaultFunc.reset();\n } else {\n hasOnePassingSelector = true;\n }\n\n let rules = this.rules ? utils.copyArray(this.rules) : null;\n const ruleset = new Ruleset(selectors, rules, this.strictImports, this.visibilityInfo());\n let rule;\n let subRule;\n\n ruleset.originalRuleset = this;\n ruleset.root = this.root;\n ruleset.firstRoot = this.firstRoot;\n ruleset.allowImports = this.allowImports;\n\n if (this.debugInfo) {\n ruleset.debugInfo = this.debugInfo;\n }\n\n if (!hasOnePassingSelector) {\n rules.length = 0;\n }\n\n // inherit a function registry from the frames stack when possible;\n // otherwise from the global registry\n ruleset.functionRegistry = (frames => {\n let i = 0;\n const n = frames.length;\n let found;\n for ( ; i !== n ; ++i ) {\n found = frames[ i ].functionRegistry;\n if ( found ) { return found; }\n }\n return globalFunctionRegistry;\n })(context.frames).inherit();\n\n // push the current ruleset to the frames stack\n const ctxFrames = context.frames;\n ctxFrames.unshift(ruleset);\n\n // currrent selectors\n let ctxSelectors = context.selectors;\n if (!ctxSelectors) {\n context.selectors = ctxSelectors = [];\n }\n ctxSelectors.unshift(this.selectors);\n\n // Evaluate imports\n if (ruleset.root || ruleset.allowImports || !ruleset.strictImports) {\n ruleset.evalImports(context);\n }\n\n // Store the frames around mixin definitions,\n // so they can be evaluated like closures when the time comes.\n const rsRules = ruleset.rules;\n for (i = 0; (rule = rsRules[i]); i++) {\n if (rule.evalFirst) {\n rsRules[i] = rule.eval(context);\n }\n }\n\n const mediaBlockCount = (context.mediaBlocks && context.mediaBlocks.length) || 0;\n\n // Evaluate mixin calls.\n for (i = 0; (rule = rsRules[i]); i++) {\n if (rule.type === 'MixinCall') {\n /* jshint loopfunc:true */\n rules = rule.eval(context).filter(r => {\n if ((r instanceof Declaration) && r.variable) {\n // do not pollute the scope if the variable is\n // already there. consider returning false here\n // but we need a way to \"return\" variable from mixins\n return !(ruleset.variable(r.name));\n }\n return true;\n });\n rsRules.splice(...[i, 1].concat(rules));\n i += rules.length - 1;\n ruleset.resetCache();\n } else if (rule.type === 'VariableCall') {\n /* jshint loopfunc:true */\n rules = rule.eval(context).rules.filter(r => {\n if ((r instanceof Declaration) && r.variable) {\n // do not pollute the scope at all\n return false;\n }\n return true;\n });\n rsRules.splice(...[i, 1].concat(rules));\n i += rules.length - 1;\n ruleset.resetCache();\n }\n }\n\n // Evaluate everything else\n for (i = 0; (rule = rsRules[i]); i++) {\n if (!rule.evalFirst) {\n rsRules[i] = rule = rule.eval ? rule.eval(context) : rule;\n }\n }\n\n // Evaluate everything else\n for (i = 0; (rule = rsRules[i]); i++) {\n // for rulesets, check if it is a css guard and can be removed\n if (rule instanceof Ruleset && rule.selectors && rule.selectors.length === 1) {\n // check if it can be folded in (e.g. & where)\n if (rule.selectors[0] && rule.selectors[0].isJustParentSelector()) {\n rsRules.splice(i--, 1);\n\n for (var j = 0; (subRule = rule.rules[j]); j++) {\n if (subRule instanceof Node) {\n subRule.copyVisibilityInfo(rule.visibilityInfo());\n if (!(subRule instanceof Declaration) || !subRule.variable) {\n rsRules.splice(++i, 0, subRule);\n }\n }\n }\n }\n }\n }\n\n // Pop the stack\n ctxFrames.shift();\n ctxSelectors.shift();\n\n if (context.mediaBlocks) {\n for (i = mediaBlockCount; i < context.mediaBlocks.length; i++) {\n context.mediaBlocks[i].bubbleSelectors(selectors);\n }\n }\n\n return ruleset;\n};\n\nRuleset.prototype.evalImports = function(context) {\n const rules = this.rules;\n let i;\n let importRules;\n if (!rules) { return; }\n\n for (i = 0; i < rules.length; i++) {\n if (rules[i].type === 'Import') {\n importRules = rules[i].eval(context);\n if (importRules && (importRules.length || importRules.length === 0)) {\n rules.splice(...[i, 1].concat(importRules));\n i += importRules.length - 1;\n } else {\n rules.splice(i, 1, importRules);\n }\n this.resetCache();\n }\n }\n};\n\nRuleset.prototype.makeImportant = function() {\n const result = new Ruleset(this.selectors, this.rules.map(r => {\n if (r.makeImportant) {\n return r.makeImportant();\n } else {\n return r;\n }\n }), this.strictImports, this.visibilityInfo());\n\n return result;\n};\n\nRuleset.prototype.matchArgs = function(args) {\n return !args || args.length === 0;\n};\n\n// lets you call a css selector with a guard\nRuleset.prototype.matchCondition = function(args, context) {\n const lastSelector = this.selectors[this.selectors.length - 1];\n if (!lastSelector.evaldCondition) {\n return false;\n }\n if (lastSelector.condition &&\n !lastSelector.condition.eval(\n new contexts.Eval(context,\n context.frames))) {\n return false;\n }\n return true;\n};\n\nRuleset.prototype.resetCache = function() {\n this._rulesets = null;\n this._variables = null;\n this._properties = null;\n this._lookups = {};\n};\n\nRuleset.prototype.variables = function() {\n if (!this._variables) {\n this._variables = !this.rules ? {} : this.rules.reduce((hash, r) => {\n if (r instanceof Declaration && r.variable === true) {\n hash[r.name] = r;\n }\n // when evaluating variables in an import statement, imports have not been eval'd\n // so we need to go inside import statements.\n // guard against root being a string (in the case of inlined less)\n if (r.type === 'Import' && r.root && r.root.variables) {\n const vars = r.root.variables();\n for (const name in vars) {\n if (vars.hasOwnProperty(name)) {\n hash[name] = r.root.variable(name);\n }\n }\n }\n return hash;\n }, {});\n }\n return this._variables;\n};\n\nRuleset.prototype.properties = function() {\n if (!this._properties) {\n this._properties = !this.rules ? {} : this.rules.reduce((hash, r) => {\n if (r instanceof Declaration && r.variable !== true) {\n const name = (r.name.length === 1) && (r.name[0] instanceof Keyword) ?\n r.name[0].value : r.name;\n // Properties don't overwrite as they can merge\n if (!hash[`$${name}`]) {\n hash[`$${name}`] = [ r ];\n }\n else {\n hash[`$${name}`].push(r);\n }\n }\n return hash;\n }, {});\n }\n return this._properties;\n};\n\nRuleset.prototype.variable = function(name) {\n const decl = this.variables()[name];\n if (decl) {\n return this.parseValue(decl);\n }\n};\n\nRuleset.prototype.property = function(name) {\n const decl = this.properties()[name];\n if (decl) {\n return this.parseValue(decl);\n }\n};\n\nRuleset.prototype.lastDeclaration = function() {\n for (let i = this.rules.length; i > 0; i--) {\n const decl = this.rules[i - 1];\n if (decl instanceof Declaration) {\n return this.parseValue(decl);\n }\n }\n};\n\nRuleset.prototype.parseValue = function(toParse) {\n const self = this;\n function transformDeclaration(decl) {\n if (decl.value instanceof Anonymous && !decl.parsed) {\n if (typeof decl.value.value === 'string') {\n this.parse.parseNode(\n decl.value.value,\n ['value', 'important'], \n decl.value.getIndex(), \n decl.fileInfo(), \n (err, result) => {\n if (err) {\n decl.parsed = true;\n }\n if (result) {\n decl.value = result[0];\n decl.important = result[1] || '';\n decl.parsed = true;\n }\n });\n } else {\n decl.parsed = true;\n }\n\n return decl;\n }\n else {\n return decl;\n }\n }\n if (!Array.isArray(toParse)) {\n return transformDeclaration.call(self, toParse);\n }\n else {\n const nodes = [];\n toParse.forEach(n => {\n nodes.push(transformDeclaration.call(self, n));\n });\n return nodes;\n }\n};\n\nRuleset.prototype.rulesets = function() {\n if (!this.rules) { return []; }\n\n const filtRules = [];\n const rules = this.rules;\n let i;\n let rule;\n\n for (i = 0; (rule = rules[i]); i++) {\n if (rule.isRuleset) {\n filtRules.push(rule);\n }\n }\n\n return filtRules;\n};\n\nRuleset.prototype.prependRule = function(rule) {\n const rules = this.rules;\n if (rules) {\n rules.unshift(rule);\n } else {\n this.rules = [ rule ];\n }\n this.setParent(rule, this);\n};\n\nRuleset.prototype.find = function(selector, self = this, filter) {\n const rules = [];\n let match;\n let foundMixins;\n const key = selector.toCSS();\n\n if (key in this._lookups) { return this._lookups[key]; }\n\n this.rulesets().forEach(rule => {\n if (rule !== self) {\n for (let j = 0; j < rule.selectors.length; j++) {\n match = selector.match(rule.selectors[j]);\n if (match) {\n if (selector.elements.length > match) {\n if (!filter || filter(rule)) {\n foundMixins = rule.find(new Selector(selector.elements.slice(match)), self, filter);\n for (let i = 0; i < foundMixins.length; ++i) {\n foundMixins[i].path.push(rule);\n }\n Array.prototype.push.apply(rules, foundMixins);\n }\n } else {\n rules.push({ rule, path: []});\n }\n break;\n }\n }\n }\n });\n this._lookups[key] = rules;\n return rules;\n};\n\nRuleset.prototype.genCSS = function(context, output) {\n let i;\n let j;\n const charsetRuleNodes = [];\n let ruleNodes = [];\n\n let // Line number debugging\n debugInfo;\n\n let rule;\n let path;\n\n context.tabLevel = (context.tabLevel || 0);\n\n if (!this.root) {\n context.tabLevel++;\n }\n\n const tabRuleStr = context.compress ? '' : Array(context.tabLevel + 1).join(' ');\n const tabSetStr = context.compress ? '' : Array(context.tabLevel).join(' ');\n let sep;\n\n let charsetNodeIndex = 0;\n let importNodeIndex = 0;\n for (i = 0; (rule = this.rules[i]); i++) {\n if (rule instanceof Comment) {\n if (importNodeIndex === i) {\n importNodeIndex++;\n }\n ruleNodes.push(rule);\n } else if (rule.isCharset && rule.isCharset()) {\n ruleNodes.splice(charsetNodeIndex, 0, rule);\n charsetNodeIndex++;\n importNodeIndex++;\n } else if (rule.type === 'Import') {\n ruleNodes.splice(importNodeIndex, 0, rule);\n importNodeIndex++;\n } else {\n ruleNodes.push(rule);\n }\n }\n ruleNodes = charsetRuleNodes.concat(ruleNodes);\n\n // If this is the root node, we don't render\n // a selector, or {}.\n if (!this.root) {\n debugInfo = getDebugInfo(context, this, tabSetStr);\n\n if (debugInfo) {\n output.add(debugInfo);\n output.add(tabSetStr);\n }\n\n const paths = this.paths;\n const pathCnt = paths.length;\n let pathSubCnt;\n\n sep = context.compress ? ',' : (`,\\n${tabSetStr}`);\n\n for (i = 0; i < pathCnt; i++) {\n path = paths[i];\n if (!(pathSubCnt = path.length)) { continue; }\n if (i > 0) { output.add(sep); }\n\n context.firstSelector = true;\n path[0].genCSS(context, output);\n\n context.firstSelector = false;\n for (j = 1; j < pathSubCnt; j++) {\n path[j].genCSS(context, output);\n }\n }\n\n output.add((context.compress ? '{' : ' {\\n') + tabRuleStr);\n }\n\n // Compile rules and rulesets\n for (i = 0; (rule = ruleNodes[i]); i++) {\n\n if (i + 1 === ruleNodes.length) {\n context.lastRule = true;\n }\n\n const currentLastRule = context.lastRule;\n if (rule.isRulesetLike(rule)) {\n context.lastRule = false;\n }\n\n if (rule.genCSS) {\n rule.genCSS(context, output);\n } else if (rule.value) {\n output.add(rule.value.toString());\n }\n\n context.lastRule = currentLastRule;\n\n if (!context.lastRule && rule.isVisible()) {\n output.add(context.compress ? '' : (`\\n${tabRuleStr}`));\n } else {\n context.lastRule = false;\n }\n }\n\n if (!this.root) {\n output.add((context.compress ? '}' : `\\n${tabSetStr}}`));\n context.tabLevel--;\n }\n\n if (!output.isEmpty() && !context.compress && this.firstRoot) {\n output.add('\\n');\n }\n};\n\nRuleset.prototype.joinSelectors = function(paths, context, selectors) {\n for (let s = 0; s < selectors.length; s++) {\n this.joinSelector(paths, context, selectors[s]);\n }\n};\n\nRuleset.prototype.joinSelector = function(paths, context, selector) {\n function createParenthesis(elementsToPak, originalElement) {\n let replacementParen;\n let j;\n if (elementsToPak.length === 0) {\n replacementParen = new Paren(elementsToPak[0]);\n } else {\n const insideParent = new Array(elementsToPak.length);\n for (j = 0; j < elementsToPak.length; j++) {\n insideParent[j] = new Element(\n null,\n elementsToPak[j],\n originalElement.isVariable,\n originalElement._index,\n originalElement._fileInfo\n );\n }\n replacementParen = new Paren(new Selector(insideParent));\n }\n return replacementParen;\n }\n\n function createSelector(containedElement, originalElement) {\n let element;\n let selector;\n element = new Element(null, containedElement, originalElement.isVariable, originalElement._index, originalElement._fileInfo);\n selector = new Selector([element]);\n return selector;\n }\n\n // joins selector path from `beginningPath` with selector path in `addPath`\n // `replacedElement` contains element that is being replaced by `addPath`\n // returns concatenated path\n function addReplacementIntoPath(beginningPath, addPath, replacedElement, originalSelector) {\n let newSelectorPath;\n let lastSelector;\n let newJoinedSelector;\n // our new selector path\n newSelectorPath = [];\n\n // construct the joined selector - if & is the first thing this will be empty,\n // if not newJoinedSelector will be the last set of elements in the selector\n if (beginningPath.length > 0) {\n newSelectorPath = utils.copyArray(beginningPath);\n lastSelector = newSelectorPath.pop();\n newJoinedSelector = originalSelector.createDerived(utils.copyArray(lastSelector.elements));\n }\n else {\n newJoinedSelector = originalSelector.createDerived([]);\n }\n\n if (addPath.length > 0) {\n // /deep/ is a CSS4 selector - (removed, so should deprecate)\n // that is valid without anything in front of it\n // so if the & does not have a combinator that is \"\" or \" \" then\n // and there is a combinator on the parent, then grab that.\n // this also allows + a { & .b { .a & { ... though not sure why you would want to do that\n let combinator = replacedElement.combinator;\n\n const parentEl = addPath[0].elements[0];\n if (combinator.emptyOrWhitespace && !parentEl.combinator.emptyOrWhitespace) {\n combinator = parentEl.combinator;\n }\n // join the elements so far with the first part of the parent\n newJoinedSelector.elements.push(new Element(\n combinator,\n parentEl.value,\n replacedElement.isVariable,\n replacedElement._index,\n replacedElement._fileInfo\n ));\n newJoinedSelector.elements = newJoinedSelector.elements.concat(addPath[0].elements.slice(1));\n }\n\n // now add the joined selector - but only if it is not empty\n if (newJoinedSelector.elements.length !== 0) {\n newSelectorPath.push(newJoinedSelector);\n }\n\n // put together the parent selectors after the join (e.g. the rest of the parent)\n if (addPath.length > 1) {\n let restOfPath = addPath.slice(1);\n restOfPath = restOfPath.map(selector => selector.createDerived(selector.elements, []));\n newSelectorPath = newSelectorPath.concat(restOfPath);\n }\n return newSelectorPath;\n }\n\n // joins selector path from `beginningPath` with every selector path in `addPaths` array\n // `replacedElement` contains element that is being replaced by `addPath`\n // returns array with all concatenated paths\n function addAllReplacementsIntoPath( beginningPath, addPaths, replacedElement, originalSelector, result) {\n let j;\n for (j = 0; j < beginningPath.length; j++) {\n const newSelectorPath = addReplacementIntoPath(beginningPath[j], addPaths, replacedElement, originalSelector);\n result.push(newSelectorPath);\n }\n return result;\n }\n\n function mergeElementsOnToSelectors(elements, selectors) {\n let i;\n let sel;\n\n if (elements.length === 0) {\n return ;\n }\n if (selectors.length === 0) {\n selectors.push([ new Selector(elements) ]);\n return;\n }\n\n for (i = 0; (sel = selectors[i]); i++) {\n // if the previous thing in sel is a parent this needs to join on to it\n if (sel.length > 0) {\n sel[sel.length - 1] = sel[sel.length - 1].createDerived(sel[sel.length - 1].elements.concat(elements));\n }\n else {\n sel.push(new Selector(elements));\n }\n }\n }\n\n // replace all parent selectors inside `inSelector` by content of `context` array\n // resulting selectors are returned inside `paths` array\n // returns true if `inSelector` contained at least one parent selector\n function replaceParentSelector(paths, context, inSelector) {\n // The paths are [[Selector]]\n // The first list is a list of comma separated selectors\n // The inner list is a list of inheritance separated selectors\n // e.g.\n // .a, .b {\n // .c {\n // }\n // }\n // == [[.a] [.c]] [[.b] [.c]]\n //\n let i;\n\n let j;\n let k;\n let currentElements;\n let newSelectors;\n let selectorsMultiplied;\n let sel;\n let el;\n let hadParentSelector = false;\n let length;\n let lastSelector;\n function findNestedSelector(element) {\n let maybeSelector;\n if (!(element.value instanceof Paren)) {\n return null;\n }\n\n maybeSelector = element.value.value;\n if (!(maybeSelector instanceof Selector)) {\n return null;\n }\n\n return maybeSelector;\n }\n\n // the elements from the current selector so far\n currentElements = [];\n // the current list of new selectors to add to the path.\n // We will build it up. We initiate it with one empty selector as we \"multiply\" the new selectors\n // by the parents\n newSelectors = [\n []\n ];\n\n for (i = 0; (el = inSelector.elements[i]); i++) {\n // non parent reference elements just get added\n if (el.value !== '&') {\n const nestedSelector = findNestedSelector(el);\n if (nestedSelector != null) {\n // merge the current list of non parent selector elements\n // on to the current list of selectors to add\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n const nestedPaths = [];\n let replaced;\n const replacedNewSelectors = [];\n replaced = replaceParentSelector(nestedPaths, context, nestedSelector);\n hadParentSelector = hadParentSelector || replaced;\n // the nestedPaths array should have only one member - replaceParentSelector does not multiply selectors\n for (k = 0; k < nestedPaths.length; k++) {\n const replacementSelector = createSelector(createParenthesis(nestedPaths[k], el), el);\n addAllReplacementsIntoPath(newSelectors, [replacementSelector], el, inSelector, replacedNewSelectors);\n }\n newSelectors = replacedNewSelectors;\n currentElements = [];\n } else {\n currentElements.push(el);\n }\n\n } else {\n hadParentSelector = true;\n // the new list of selectors to add\n selectorsMultiplied = [];\n\n // merge the current list of non parent selector elements\n // on to the current list of selectors to add\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n // loop through our current selectors\n for (j = 0; j < newSelectors.length; j++) {\n sel = newSelectors[j];\n // if we don't have any parent paths, the & might be in a mixin so that it can be used\n // whether there are parents or not\n if (context.length === 0) {\n // the combinator used on el should now be applied to the next element instead so that\n // it is not lost\n if (sel.length > 0) {\n sel[0].elements.push(new Element(el.combinator, '', el.isVariable, el._index, el._fileInfo));\n }\n selectorsMultiplied.push(sel);\n }\n else {\n // and the parent selectors\n for (k = 0; k < context.length; k++) {\n // We need to put the current selectors\n // then join the last selector's elements on to the parents selectors\n const newSelectorPath = addReplacementIntoPath(sel, context[k], el, inSelector);\n // add that to our new set of selectors\n selectorsMultiplied.push(newSelectorPath);\n }\n }\n }\n\n // our new selectors has been multiplied, so reset the state\n newSelectors = selectorsMultiplied;\n currentElements = [];\n }\n }\n\n // if we have any elements left over (e.g. .a& .b == .b)\n // add them on to all the current selectors\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n for (i = 0; i < newSelectors.length; i++) {\n length = newSelectors[i].length;\n if (length > 0) {\n paths.push(newSelectors[i]);\n lastSelector = newSelectors[i][length - 1];\n newSelectors[i][length - 1] = lastSelector.createDerived(lastSelector.elements, inSelector.extendList);\n }\n }\n\n return hadParentSelector;\n }\n\n function deriveSelector(visibilityInfo, deriveFrom) {\n const newSelector = deriveFrom.createDerived(deriveFrom.elements, deriveFrom.extendList, deriveFrom.evaldCondition);\n newSelector.copyVisibilityInfo(visibilityInfo);\n return newSelector;\n }\n\n // joinSelector code follows\n let i;\n\n let newPaths;\n let hadParentSelector;\n\n newPaths = [];\n hadParentSelector = replaceParentSelector(newPaths, context, selector);\n\n if (!hadParentSelector) {\n if (context.length > 0) {\n newPaths = [];\n for (i = 0; i < context.length; i++) {\n\n const concatenated = context[i].map(deriveSelector.bind(this, selector.visibilityInfo()));\n\n concatenated.push(selector);\n newPaths.push(concatenated);\n }\n }\n else {\n newPaths = [[selector]];\n }\n }\n\n for (i = 0; i < newPaths.length; i++) {\n paths.push(newPaths[i]);\n }\n};\n\nRuleset.prototype.type = 'Ruleset';\nRuleset.prototype.isRuleset = true;\nexport default Ruleset;\n","import Node from './node';\nimport Selector from './selector';\nimport Ruleset from './ruleset';\nimport Anonymous from './anonymous';\n\nconst AtRule = function(\n name,\n value,\n rules,\n index,\n currentFileInfo,\n debugInfo,\n isRooted,\n visibilityInfo\n) {\n let i;\n\n this.name = name;\n this.value = (value instanceof Node) ? value : (value ? new Anonymous(value) : value);\n if (rules) {\n if (Array.isArray(rules)) {\n this.rules = rules;\n } else {\n this.rules = [rules];\n this.rules[0].selectors = (new Selector([], null, null, index, currentFileInfo)).createEmptySelectors();\n }\n for (i = 0; i < this.rules.length; i++) {\n this.rules[i].allowImports = true;\n }\n this.setParent(this.rules, this);\n }\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.debugInfo = debugInfo;\n this.isRooted = isRooted || false;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n};\n\nAtRule.prototype = new Node();\n\nAtRule.prototype.accept = function(visitor) {\n const value = this.value;\n const rules = this.rules;\n if (rules) {\n this.rules = visitor.visitArray(rules);\n }\n if (value) {\n this.value = visitor.visit(value);\n }\n};\n\nAtRule.prototype.isRulesetLike = function() {\n return this.rules || !this.isCharset();\n};\n\nAtRule.prototype.isCharset = function() {\n return '@charset' === this.name;\n};\n\nAtRule.prototype.genCSS = function(context, output) {\n const value = this.value;\n const rules = this.rules;\n output.add(this.name, this.fileInfo(), this.getIndex());\n if (value) {\n output.add(' ');\n value.genCSS(context, output);\n }\n if (rules) {\n this.outputRuleset(context, output, rules);\n } else {\n output.add(';');\n }\n};\n\nAtRule.prototype.eval = function(context) {\n let mediaPathBackup;\n let mediaBlocksBackup;\n let value = this.value;\n let rules = this.rules;\n\n // media stored inside other atrule should not bubble over it\n // backpup media bubbling information\n mediaPathBackup = context.mediaPath;\n mediaBlocksBackup = context.mediaBlocks;\n // deleted media bubbling information\n context.mediaPath = [];\n context.mediaBlocks = [];\n\n if (value) {\n value = value.eval(context);\n }\n if (rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n rules = [rules[0].eval(context)];\n rules[0].root = true;\n }\n // restore media bubbling information\n context.mediaPath = mediaPathBackup;\n context.mediaBlocks = mediaBlocksBackup;\n\n return new AtRule(this.name, value, rules,\n this.getIndex(), this.fileInfo(), this.debugInfo, this.isRooted, this.visibilityInfo());\n};\n\nAtRule.prototype.variable = function(name) {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.variable.call(this.rules[0], name);\n }\n};\n\nAtRule.prototype.find = function(...args) {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.find.apply(this.rules[0], args);\n }\n};\n\nAtRule.prototype.rulesets = function() {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.rulesets.apply(this.rules[0]);\n }\n};\n\nAtRule.prototype.outputRuleset = function(context, output, rules) {\n const ruleCnt = rules.length;\n let i;\n context.tabLevel = (context.tabLevel | 0) + 1;\n\n // Compressed\n if (context.compress) {\n output.add('{');\n for (i = 0; i < ruleCnt; i++) {\n rules[i].genCSS(context, output);\n }\n output.add('}');\n context.tabLevel--;\n return;\n }\n\n // Non-compressed\n const tabSetStr = `\\n${Array(context.tabLevel).join(' ')}`;\n\n const tabRuleStr = `${tabSetStr} `;\n if (!ruleCnt) {\n output.add(` {${tabSetStr}}`);\n } else {\n output.add(` {${tabRuleStr}`);\n rules[0].genCSS(context, output);\n for (i = 1; i < ruleCnt; i++) {\n output.add(tabRuleStr);\n rules[i].genCSS(context, output);\n }\n output.add(`${tabSetStr}}`);\n }\n\n context.tabLevel--;\n};\n\nAtRule.prototype.type = 'AtRule';\nexport default AtRule;\n","import Node from './node';\nimport contexts from '../contexts';\nimport * as utils from '../utils';\n\nconst DetachedRuleset = function(ruleset, frames) {\n this.ruleset = ruleset;\n this.frames = frames;\n this.setParent(this.ruleset, this);\n};\n\nDetachedRuleset.prototype = new Node();\n\nDetachedRuleset.prototype.accept = function(visitor) {\n this.ruleset = visitor.visit(this.ruleset);\n};\n\nDetachedRuleset.prototype.eval = function(context) {\n const frames = this.frames || utils.copyArray(context.frames);\n return new DetachedRuleset(this.ruleset, frames);\n};\n\nDetachedRuleset.prototype.callEval = function(context) {\n return this.ruleset.eval(this.frames ? new contexts.Eval(context, this.frames.concat(context.frames)) : context);\n};\n\nDetachedRuleset.prototype.type = 'DetachedRuleset';\nDetachedRuleset.prototype.evalFirst = true;\nexport default DetachedRuleset;\n","import Node from './node';\nimport unitConversions from '../data/unit-conversions';\nimport * as utils from '../utils';\n\nconst Unit = function(numerator, denominator, backupUnit) {\n this.numerator = numerator ? utils.copyArray(numerator).sort() : [];\n this.denominator = denominator ? utils.copyArray(denominator).sort() : [];\n if (backupUnit) {\n this.backupUnit = backupUnit;\n } else if (numerator && numerator.length) {\n this.backupUnit = numerator[0];\n }\n};\n\nUnit.prototype = new Node();\n\nUnit.prototype.clone = function() {\n return new Unit(utils.copyArray(this.numerator), utils.copyArray(this.denominator), this.backupUnit);\n};\n\nUnit.prototype.genCSS = function(context, output) {\n // Dimension checks the unit is singular and throws an error if in strict math mode.\n const strictUnits = context && context.strictUnits;\n if (this.numerator.length === 1) {\n output.add(this.numerator[0]); // the ideal situation\n } else if (!strictUnits && this.backupUnit) {\n output.add(this.backupUnit);\n } else if (!strictUnits && this.denominator.length) {\n output.add(this.denominator[0]);\n }\n};\n\nUnit.prototype.toString = function() {\n let i;\n let returnStr = this.numerator.join('*');\n for (i = 0; i < this.denominator.length; i++) {\n returnStr += `/${this.denominator[i]}`;\n }\n return returnStr;\n};\n\nUnit.prototype.compare = function(other) {\n return this.is(other.toString()) ? 0 : undefined;\n};\n\nUnit.prototype.is = function(unitString) {\n return this.toString().toUpperCase() === unitString.toUpperCase();\n};\n\nUnit.prototype.isLength = function() {\n return RegExp('^(px|em|ex|ch|rem|in|cm|mm|pc|pt|ex|vw|vh|vmin|vmax)$', 'gi').test(this.toCSS());\n};\n\nUnit.prototype.isEmpty = function() {\n return this.numerator.length === 0 && this.denominator.length === 0;\n};\n\nUnit.prototype.isSingular = function() {\n return this.numerator.length <= 1 && this.denominator.length === 0;\n};\n\nUnit.prototype.map = function(callback) {\n let i;\n\n for (i = 0; i < this.numerator.length; i++) {\n this.numerator[i] = callback(this.numerator[i], false);\n }\n\n for (i = 0; i < this.denominator.length; i++) {\n this.denominator[i] = callback(this.denominator[i], true);\n }\n};\n\nUnit.prototype.usedUnits = function() {\n let group;\n const result = {};\n let mapUnit;\n let groupName;\n\n mapUnit = atomicUnit => {\n /* jshint loopfunc:true */\n if (group.hasOwnProperty(atomicUnit) && !result[groupName]) {\n result[groupName] = atomicUnit;\n }\n\n return atomicUnit;\n };\n\n for (groupName in unitConversions) {\n if (unitConversions.hasOwnProperty(groupName)) {\n group = unitConversions[groupName];\n\n this.map(mapUnit);\n }\n }\n\n return result;\n};\n\nUnit.prototype.cancel = function() {\n const counter = {};\n let atomicUnit;\n let i;\n\n for (i = 0; i < this.numerator.length; i++) {\n atomicUnit = this.numerator[i];\n counter[atomicUnit] = (counter[atomicUnit] || 0) + 1;\n }\n\n for (i = 0; i < this.denominator.length; i++) {\n atomicUnit = this.denominator[i];\n counter[atomicUnit] = (counter[atomicUnit] || 0) - 1;\n }\n\n this.numerator = [];\n this.denominator = [];\n\n for (atomicUnit in counter) {\n if (counter.hasOwnProperty(atomicUnit)) {\n const count = counter[atomicUnit];\n\n if (count > 0) {\n for (i = 0; i < count; i++) {\n this.numerator.push(atomicUnit);\n }\n } else if (count < 0) {\n for (i = 0; i < -count; i++) {\n this.denominator.push(atomicUnit);\n }\n }\n }\n }\n\n this.numerator.sort();\n this.denominator.sort();\n};\n\nUnit.prototype.type = 'Unit';\nexport default Unit;\n","import Node from './node';\nimport unitConversions from '../data/unit-conversions';\nimport Unit from './unit';\nimport Color from './color';\n\n//\n// A number with a unit\n//\nconst Dimension = function(value, unit) {\n this.value = parseFloat(value);\n if (isNaN(this.value)) {\n throw new Error('Dimension is not a number.');\n }\n this.unit = (unit && unit instanceof Unit) ? unit :\n new Unit(unit ? [unit] : undefined);\n this.setParent(this.unit, this);\n};\n\nDimension.prototype = new Node();\n\nDimension.prototype.accept = function(visitor) {\n this.unit = visitor.visit(this.unit);\n};\n\nDimension.prototype.eval = function(context) {\n return this;\n};\n\nDimension.prototype.toColor = function() {\n return new Color([this.value, this.value, this.value]);\n};\n\nDimension.prototype.genCSS = function(context, output) {\n if ((context && context.strictUnits) && !this.unit.isSingular()) {\n throw new Error(`Multiple units in dimension. Correct the units or use the unit function. Bad unit: ${this.unit.toString()}`);\n }\n\n const value = this.fround(context, this.value);\n let strValue = String(value);\n\n if (value !== 0 && value < 0.000001 && value > -0.000001) {\n // would be output 1e-6 etc.\n strValue = value.toFixed(20).replace(/0+$/, '');\n }\n\n if (context && context.compress) {\n // Zero values doesn't need a unit\n if (value === 0 && this.unit.isLength()) {\n output.add(strValue);\n return;\n }\n\n // Float values doesn't need a leading zero\n if (value > 0 && value < 1) {\n strValue = (strValue).substr(1);\n }\n }\n\n output.add(strValue);\n this.unit.genCSS(context, output);\n};\n\n// In an operation between two Dimensions,\n// we default to the first Dimension's unit,\n// so `1px + 2` will yield `3px`.\nDimension.prototype.operate = function(context, op, other) {\n /* jshint noempty:false */\n let value = this._operate(context, op, this.value, other.value);\n\n let unit = this.unit.clone();\n\n if (op === '+' || op === '-') {\n if (unit.numerator.length === 0 && unit.denominator.length === 0) {\n unit = other.unit.clone();\n if (this.unit.backupUnit) {\n unit.backupUnit = this.unit.backupUnit;\n }\n } else if (other.unit.numerator.length === 0 && unit.denominator.length === 0) {\n // do nothing\n } else {\n other = other.convertTo(this.unit.usedUnits());\n\n if (context.strictUnits && other.unit.toString() !== unit.toString()) {\n throw new Error(`Incompatible units. Change the units or use the unit function. ` + \n `Bad units: '${unit.toString()}' and '${other.unit.toString()}'.`);\n }\n\n value = this._operate(context, op, this.value, other.value);\n }\n } else if (op === '*') {\n unit.numerator = unit.numerator.concat(other.unit.numerator).sort();\n unit.denominator = unit.denominator.concat(other.unit.denominator).sort();\n unit.cancel();\n } else if (op === '/') {\n unit.numerator = unit.numerator.concat(other.unit.denominator).sort();\n unit.denominator = unit.denominator.concat(other.unit.numerator).sort();\n unit.cancel();\n }\n return new Dimension(value, unit);\n};\n\nDimension.prototype.compare = function(other) {\n let a;\n let b;\n\n if (!(other instanceof Dimension)) {\n return undefined;\n }\n\n if (this.unit.isEmpty() || other.unit.isEmpty()) {\n a = this;\n b = other;\n } else {\n a = this.unify();\n b = other.unify();\n if (a.unit.compare(b.unit) !== 0) {\n return undefined;\n }\n }\n\n return Node.numericCompare(a.value, b.value);\n};\n\nDimension.prototype.unify = function() {\n return this.convertTo({ length: 'px', duration: 's', angle: 'rad' });\n};\n\nDimension.prototype.convertTo = function(conversions) {\n let value = this.value;\n const unit = this.unit.clone();\n let i;\n let groupName;\n let group;\n let targetUnit;\n let derivedConversions = {};\n let applyUnit;\n\n if (typeof conversions === 'string') {\n for (i in unitConversions) {\n if (unitConversions[i].hasOwnProperty(conversions)) {\n derivedConversions = {};\n derivedConversions[i] = conversions;\n }\n }\n conversions = derivedConversions;\n }\n applyUnit = (atomicUnit, denominator) => {\n /* jshint loopfunc:true */\n if (group.hasOwnProperty(atomicUnit)) {\n if (denominator) {\n value = value / (group[atomicUnit] / group[targetUnit]);\n } else {\n value = value * (group[atomicUnit] / group[targetUnit]);\n }\n\n return targetUnit;\n }\n\n return atomicUnit;\n };\n\n for (groupName in conversions) {\n if (conversions.hasOwnProperty(groupName)) {\n targetUnit = conversions[groupName];\n group = unitConversions[groupName];\n\n unit.map(applyUnit);\n }\n }\n\n unit.cancel();\n\n return new Dimension(value, unit);\n};\n\nDimension.prototype.type = 'Dimension';\nexport default Dimension;\n","import Node from './node';\nimport Color from './color';\nimport Dimension from './dimension';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\nconst Operation = function(op, operands, isSpaced) {\n this.op = op.trim();\n this.operands = operands;\n this.isSpaced = isSpaced;\n};\n\nOperation.prototype = new Node();\n\nOperation.prototype.accept = function(visitor) {\n this.operands = visitor.visitArray(this.operands);\n}\n\nOperation.prototype.eval = function(context) {\n let a = this.operands[0].eval(context);\n let b = this.operands[1].eval(context);\n let op;\n\n if (context.isMathOn(this.op)) {\n op = this.op === './' ? '/' : this.op;\n if (a instanceof Dimension && b instanceof Color) {\n a = a.toColor();\n }\n if (b instanceof Dimension && a instanceof Color) {\n b = b.toColor();\n }\n if (!a.operate) {\n if (a instanceof Operation && a.op === '/' && context.math === MATH.PARENS_DIVISION) {\n return new Operation(this.op, [a, b], this.isSpaced);\n }\n throw { type: 'Operation',\n message: 'Operation on an invalid type' };\n }\n\n return a.operate(context, op, b);\n } else {\n return new Operation(this.op, [a, b], this.isSpaced);\n }\n};\n\nOperation.prototype.genCSS = function(context, output) {\n this.operands[0].genCSS(context, output);\n if (this.isSpaced) {\n output.add(' ');\n }\n output.add(this.op);\n if (this.isSpaced) {\n output.add(' ');\n }\n this.operands[1].genCSS(context, output);\n};\n\nOperation.prototype.type = 'Operation';\nexport default Operation;\n","import Node from './node';\nimport Paren from './paren';\nimport Comment from './comment';\nimport Dimension from './dimension';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\nconst Expression = function(value, noSpacing) {\n this.value = value;\n this.noSpacing = noSpacing;\n if (!value) {\n throw new Error('Expression requires an array parameter');\n }\n};\n\nExpression.prototype = new Node();\n\nExpression.prototype.accept = function(visitor) {\n this.value = visitor.visitArray(this.value);\n};\n\nExpression.prototype.eval = function(context) {\n let returnValue;\n const mathOn = context.isMathOn();\n\n const inParenthesis = this.parens && \n (context.math !== MATH.STRICT_LEGACY || !this.parensInOp);\n\n let doubleParen = false;\n if (inParenthesis) {\n context.inParenthesis();\n }\n if (this.value.length > 1) {\n returnValue = new Expression(this.value.map(e => {\n if (!e.eval) {\n return e;\n }\n return e.eval(context);\n }), this.noSpacing);\n } else if (this.value.length === 1) {\n if (this.value[0].parens && !this.value[0].parensInOp && !context.inCalc) {\n doubleParen = true;\n }\n returnValue = this.value[0].eval(context);\n } else {\n returnValue = this;\n }\n if (inParenthesis) {\n context.outOfParenthesis();\n }\n if (this.parens && this.parensInOp && !mathOn && !doubleParen \n && (!(returnValue instanceof Dimension))) {\n returnValue = new Paren(returnValue);\n }\n return returnValue;\n};\n\nExpression.prototype.genCSS = function(context, output) {\n for (let i = 0; i < this.value.length; i++) {\n this.value[i].genCSS(context, output);\n if (!this.noSpacing && i + 1 < this.value.length) {\n output.add(' ');\n }\n }\n};\n\nExpression.prototype.throwAwayComments = function() {\n this.value = this.value.filter(v => !(v instanceof Comment));\n};\n\nExpression.prototype.type = 'Expression';\nexport default Expression;\n","import Expression from '../tree/expression';\n\nclass functionCaller {\n constructor(name, context, index, currentFileInfo) {\n this.name = name.toLowerCase();\n this.index = index;\n this.context = context;\n this.currentFileInfo = currentFileInfo;\n\n this.func = context.frames[0].functionRegistry.get(this.name);\n }\n\n isValid() {\n return Boolean(this.func);\n }\n\n call(args) {\n const evalArgs = this.func.evalArgs;\n if (evalArgs !== false) {\n args = args.map(a => a.eval(this.context));\n }\n // This code is terrible and should be replaced as per this issue...\n // https://github.com/less/less.js/issues/2477\n if (Array.isArray(args)) {\n args = args.filter(item => {\n if (item.type === 'Comment') {\n return false;\n }\n return true;\n })\n .map(item => {\n if (item.type === 'Expression') {\n const subNodes = item.value.filter(item => {\n if (item.type === 'Comment') {\n return false;\n }\n return true;\n });\n if (subNodes.length === 1) {\n return subNodes[0];\n } else {\n return new Expression(subNodes);\n }\n }\n return item;\n });\n }\n\n if (evalArgs === false) {\n return this.func(this.context, ...args);\n }\n\n return this.func(...args);\n }\n}\n\nexport default functionCaller;\n","import Node from './node';\nimport Anonymous from './anonymous';\nimport FunctionCaller from '../functions/function-caller';\n\n//\n// A function call node.\n//\nconst Call = function(name, args, index, currentFileInfo) {\n this.name = name;\n this.args = args;\n this.calc = name === 'calc';\n this._index = index;\n this._fileInfo = currentFileInfo;\n}\n\nCall.prototype = new Node();\n\nCall.prototype.accept = function(visitor) {\n if (this.args) {\n this.args = visitor.visitArray(this.args);\n }\n};\n\n//\n// When evaluating a function call,\n// we either find the function in the functionRegistry,\n// in which case we call it, passing the evaluated arguments,\n// if this returns null or we cannot find the function, we\n// simply print it out as it appeared originally [2].\n//\n// The reason why we evaluate the arguments, is in the case where\n// we try to pass a variable to a function, like: `saturate(@color)`.\n// The function should receive the value, not the variable.\n//\nCall.prototype.eval = function(context) {\n /**\n * Turn off math for calc(), and switch back on for evaluating nested functions\n */\n const currentMathContext = context.mathOn;\n context.mathOn = !this.calc;\n if (this.calc || context.inCalc) {\n context.enterCalc();\n }\n\n const exitCalc = () => {\n if (this.calc || context.inCalc) {\n context.exitCalc();\n }\n context.mathOn = currentMathContext;\n };\n\n let result;\n const funcCaller = new FunctionCaller(this.name, context, this.getIndex(), this.fileInfo());\n\n if (funcCaller.isValid()) {\n try {\n result = funcCaller.call(this.args);\n exitCalc();\n } catch (e) {\n if (e.hasOwnProperty('line') && e.hasOwnProperty('column')) {\n throw e\n }\n throw { \n type: e.type || 'Runtime',\n message: `error evaluating function \\`${this.name}\\`${e.message ? `: ${e.message}` : ''}`,\n index: this.getIndex(), \n filename: this.fileInfo().filename,\n line: e.lineNumber,\n column: e.columnNumber\n };\n }\n\n if (result !== null && result !== undefined) {\n // Results that that are not nodes are cast as Anonymous nodes\n // Falsy values or booleans are returned as empty nodes\n if (!(result instanceof Node)) {\n if (!result || result === true) {\n result = new Anonymous(null); \n }\n else {\n result = new Anonymous(result.toString()); \n }\n \n }\n result._index = this._index;\n result._fileInfo = this._fileInfo;\n return result;\n }\n }\n\n const args = this.args.map(a => a.eval(context));\n exitCalc();\n\n return new Call(this.name, args, this.getIndex(), this.fileInfo());\n};\n\nCall.prototype.genCSS = function(context, output) {\n output.add(`${this.name}(`, this.fileInfo(), this.getIndex());\n\n for (let i = 0; i < this.args.length; i++) {\n this.args[i].genCSS(context, output);\n if (i + 1 < this.args.length) {\n output.add(', ');\n }\n }\n\n output.add(')');\n};\n\nCall.prototype.type = 'Call';\nexport default Call;\n","import Node from './node';\nimport Call from './call';\n\nconst Variable = function(name, index, currentFileInfo) {\n this.name = name;\n this._index = index;\n this._fileInfo = currentFileInfo;\n};\n\nVariable.prototype = new Node();\n\nVariable.prototype.eval = function(context) {\n let variable;\n let name = this.name;\n\n if (name.indexOf('@@') === 0) {\n name = `@${new Variable(name.slice(1), this.getIndex(), this.fileInfo()).eval(context).value}`;\n }\n\n if (this.evaluating) {\n throw { type: 'Name',\n message: `Recursive variable definition for ${name}`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n this.evaluating = true;\n\n variable = this.find(context.frames, frame => {\n const v = frame.variable(name);\n if (v) {\n if (v.important) {\n const importantScope = context.importantScope[context.importantScope.length - 1];\n importantScope.important = v.important;\n }\n // If in calc, wrap vars in a function call to cascade evaluate args first\n if (context.inCalc) {\n return (new Call('_SELF', [v.value])).eval(context);\n }\n else {\n return v.value.eval(context);\n }\n }\n });\n if (variable) {\n this.evaluating = false;\n return variable;\n } else {\n throw { type: 'Name',\n message: `variable ${name} is undefined`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n};\n\nVariable.prototype.find = function(obj, fun) {\n for (let i = 0, r; i < obj.length; i++) {\n r = fun.call(obj, obj[i]);\n if (r) { return r; }\n }\n return null;\n};\n\nVariable.prototype.type = 'Variable';\nexport default Variable;\n","import Node from './node';\nimport Declaration from './declaration';\n\nconst Property = function(name, index, currentFileInfo) {\n this.name = name;\n this._index = index;\n this._fileInfo = currentFileInfo;\n};\n\nProperty.prototype = new Node();\n\nProperty.prototype.eval = function(context) {\n let property;\n const name = this.name;\n // TODO: shorten this reference\n const mergeRules = context.pluginManager.less.visitors.ToCSSVisitor.prototype._mergeRules;\n\n if (this.evaluating) {\n throw { type: 'Name',\n message: `Recursive property reference for ${name}`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n this.evaluating = true;\n\n property = this.find(context.frames, frame => {\n let v;\n const vArr = frame.property(name);\n if (vArr) {\n for (let i = 0; i < vArr.length; i++) {\n v = vArr[i];\n\n vArr[i] = new Declaration(v.name,\n v.value,\n v.important,\n v.merge,\n v.index,\n v.currentFileInfo,\n v.inline,\n v.variable\n );\n }\n mergeRules(vArr);\n\n v = vArr[vArr.length - 1];\n if (v.important) {\n const importantScope = context.importantScope[context.importantScope.length - 1];\n importantScope.important = v.important;\n }\n v = v.value.eval(context);\n return v;\n }\n });\n if (property) {\n this.evaluating = false;\n return property;\n } else {\n throw { type: 'Name',\n message: `Property '${name}' is undefined`,\n filename: this.currentFileInfo.filename,\n index: this.index };\n }\n};\n\nProperty.prototype.find = function(obj, fun) {\n for (let i = 0, r; i < obj.length; i++) {\n r = fun.call(obj, obj[i]);\n if (r) { return r; }\n }\n return null;\n};\n\nProperty.prototype.type = 'Property';\nexport default Property;\n","import Node from './node';\n\nconst Attribute = function(key, op, value) {\n this.key = key;\n this.op = op;\n this.value = value;\n};\n\nAttribute.prototype = new Node();\n\nAttribute.prototype.eval = function(context) {\n return new Attribute(this.key.eval ? this.key.eval(context) : this.key,\n this.op, (this.value && this.value.eval) ? this.value.eval(context) : this.value);\n};\n\nAttribute.prototype.genCSS = function(context, output) {\n output.add(this.toCSS(context));\n};\n\nAttribute.prototype.toCSS = function(context) {\n let value = this.key.toCSS ? this.key.toCSS(context) : this.key;\n\n if (this.op) {\n value += this.op;\n value += (this.value.toCSS ? this.value.toCSS(context) : this.value);\n }\n\n return `[${value}]`;\n};\n\nAttribute.prototype.type = 'Attribute';\nexport default Attribute;\n","import Node from './node';\nimport Variable from './variable';\nimport Property from './property';\n\nconst Quoted = function(str, content, escaped, index, currentFileInfo) {\n this.escaped = (escaped == null) ? true : escaped;\n this.value = content || '';\n this.quote = str.charAt(0);\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.variableRegex = /@\\{([\\w-]+)\\}/g;\n this.propRegex = /\\$\\{([\\w-]+)\\}/g;\n this.allowRoot = escaped;\n};\n\nQuoted.prototype = new Node();\n\nQuoted.prototype.genCSS = function(context, output) {\n if (!this.escaped) {\n output.add(this.quote, this.fileInfo(), this.getIndex());\n }\n output.add(this.value);\n if (!this.escaped) {\n output.add(this.quote);\n }\n};\n\nQuoted.prototype.containsVariables = function() {\n return this.value.match(this.variableRegex);\n};\n\nQuoted.prototype.eval = function(context) {\n const that = this;\n let value = this.value;\n const variableReplacement = (_, name) => {\n const v = new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context, true);\n return (v instanceof Quoted) ? v.value : v.toCSS();\n };\n const propertyReplacement = (_, name) => {\n const v = new Property(`$${name}`, that.getIndex(), that.fileInfo()).eval(context, true);\n return (v instanceof Quoted) ? v.value : v.toCSS();\n };\n function iterativeReplace(value, regexp, replacementFnc) {\n let evaluatedValue = value;\n do {\n value = evaluatedValue.toString();\n evaluatedValue = value.replace(regexp, replacementFnc);\n } while (value !== evaluatedValue);\n return evaluatedValue;\n }\n value = iterativeReplace(value, this.variableRegex, variableReplacement);\n value = iterativeReplace(value, this.propRegex, propertyReplacement);\n\n return new Quoted(this.quote + value + this.quote, value, this.escaped, this.getIndex(), this.fileInfo());\n};\n\nQuoted.prototype.compare = function(other) {\n // when comparing quoted strings allow the quote to differ\n if (other.type === 'Quoted' && !this.escaped && !other.escaped) {\n return Node.numericCompare(this.value, other.value);\n } else {\n return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined;\n }\n};\n\nQuoted.prototype.type = 'Quoted';\nexport default Quoted;\n","import Node from './node';\n\nconst URL = function(val, index, currentFileInfo, isEvald) {\n this.value = val;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.isEvald = isEvald;\n};\n\nURL.prototype = new Node();\n\nURL.prototype.accept = function(visitor) {\n this.value = visitor.visit(this.value);\n};\n\nURL.prototype.genCSS = function(context, output) {\n output.add('url(');\n this.value.genCSS(context, output);\n output.add(')');\n};\n\nURL.prototype.eval = function(context) {\n const val = this.value.eval(context);\n let rootpath;\n\n if (!this.isEvald) {\n // Add the rootpath if the URL requires a rewrite\n rootpath = this.fileInfo() && this.fileInfo().rootpath;\n if (typeof rootpath === 'string' &&\n typeof val.value === 'string' &&\n context.pathRequiresRewrite(val.value)) {\n if (!val.quote) {\n rootpath = escapePath(rootpath);\n }\n val.value = context.rewritePath(val.value, rootpath);\n } else {\n val.value = context.normalizePath(val.value);\n }\n\n // Add url args if enabled\n if (context.urlArgs) {\n if (!val.value.match(/^\\s*data:/)) {\n const delimiter = val.value.indexOf('?') === -1 ? '?' : '&';\n const urlArgs = delimiter + context.urlArgs;\n if (val.value.indexOf('#') !== -1) {\n val.value = val.value.replace('#', `${urlArgs}#`);\n } else {\n val.value += urlArgs;\n }\n }\n }\n }\n\n return new URL(val, this.getIndex(), this.fileInfo(), true);\n};\n\nURL.prototype.type = 'Url';\n\nfunction escapePath(path) {\n return path.replace(/[\\(\\)'\"\\s]/g, match => `\\\\${match}`);\n}\n\nexport default URL;\n","import Ruleset from './ruleset';\nimport Value from './value';\nimport Selector from './selector';\nimport Anonymous from './anonymous';\nimport Expression from './expression';\nimport AtRule from './atrule';\nimport * as utils from '../utils';\n\nconst Media = function(value, features, index, currentFileInfo, visibilityInfo) {\n this._index = index;\n this._fileInfo = currentFileInfo;\n\n const selectors = (new Selector([], null, null, this._index, this._fileInfo)).createEmptySelectors();\n\n this.features = new Value(features);\n this.rules = [new Ruleset(selectors, value)];\n this.rules[0].allowImports = true;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n this.setParent(selectors, this);\n this.setParent(this.features, this);\n this.setParent(this.rules, this);\n}\n\nMedia.prototype = new AtRule();\n\nMedia.prototype.isRulesetLike = function() {\n return true;\n};\n\nMedia.prototype.accept = function(visitor) {\n if (this.features) {\n this.features = visitor.visit(this.features);\n }\n if (this.rules) {\n this.rules = visitor.visitArray(this.rules);\n }\n};\n\nMedia.prototype.genCSS = function(context, output) {\n output.add('@media ', this._fileInfo, this._index);\n this.features.genCSS(context, output);\n this.outputRuleset(context, output, this.rules);\n};\n\nMedia.prototype.eval = function(context) {\n if (!context.mediaBlocks) {\n context.mediaBlocks = [];\n context.mediaPath = [];\n }\n\n const media = new Media(null, [], this._index, this._fileInfo, this.visibilityInfo());\n if (this.debugInfo) {\n this.rules[0].debugInfo = this.debugInfo;\n media.debugInfo = this.debugInfo;\n }\n \n media.features = this.features.eval(context);\n\n context.mediaPath.push(media);\n context.mediaBlocks.push(media);\n\n this.rules[0].functionRegistry = context.frames[0].functionRegistry.inherit();\n context.frames.unshift(this.rules[0]);\n media.rules = [this.rules[0].eval(context)];\n context.frames.shift();\n\n context.mediaPath.pop();\n\n return context.mediaPath.length === 0 ? media.evalTop(context) :\n media.evalNested(context);\n};\n\nMedia.prototype.evalTop = function(context) {\n let result = this;\n\n // Render all dependent Media blocks.\n if (context.mediaBlocks.length > 1) {\n const selectors = (new Selector([], null, null, this.getIndex(), this.fileInfo())).createEmptySelectors();\n result = new Ruleset(selectors, context.mediaBlocks);\n result.multiMedia = true;\n result.copyVisibilityInfo(this.visibilityInfo());\n this.setParent(result, this);\n }\n\n delete context.mediaBlocks;\n delete context.mediaPath;\n\n return result;\n};\n\nMedia.prototype.evalNested = function(context) {\n let i;\n let value;\n const path = context.mediaPath.concat([this]);\n\n // Extract the media-query conditions separated with `,` (OR).\n for (i = 0; i < path.length; i++) {\n value = path[i].features instanceof Value ?\n path[i].features.value : path[i].features;\n path[i] = Array.isArray(value) ? value : [value];\n }\n\n // Trace all permutations to generate the resulting media-query.\n //\n // (a, b and c) with nested (d, e) ->\n // a and d\n // a and e\n // b and c and d\n // b and c and e\n this.features = new Value(this.permute(path).map(path => {\n path = path.map(fragment => fragment.toCSS ? fragment : new Anonymous(fragment));\n\n for (i = path.length - 1; i > 0; i--) {\n path.splice(i, 0, new Anonymous('and'));\n }\n\n return new Expression(path);\n }));\n this.setParent(this.features, this);\n\n // Fake a tree-node that doesn't output anything.\n return new Ruleset([], []);\n};\n\nMedia.prototype.permute = function(arr) {\n if (arr.length === 0) {\n return [];\n } else if (arr.length === 1) {\n return arr[0];\n } else {\n const result = [];\n const rest = this.permute(arr.slice(1));\n for (let i = 0; i < rest.length; i++) {\n for (let j = 0; j < arr[0].length; j++) {\n result.push([arr[0][j]].concat(rest[i]));\n }\n }\n return result;\n }\n};\n\nMedia.prototype.bubbleSelectors = function(selectors) {\n if (!selectors) {\n return;\n }\n this.rules = [new Ruleset(utils.copyArray(selectors), [this.rules[0]])];\n this.setParent(this.rules, this);\n};\n\nMedia.prototype.type = 'Media';\nexport default Media;\n","import Node from './node';\nimport Media from './media';\nimport URL from './url';\nimport Quoted from './quoted';\nimport Ruleset from './ruleset';\nimport Anonymous from './anonymous';\nimport * as utils from '../utils';\nimport LessError from '../less-error';\n\n//\n// CSS @import node\n//\n// The general strategy here is that we don't want to wait\n// for the parsing to be completed, before we start importing\n// the file. That's because in the context of a browser,\n// most of the time will be spent waiting for the server to respond.\n//\n// On creation, we push the import path to our import queue, though\n// `import,push`, we also pass it a callback, which it'll call once\n// the file has been fetched, and parsed.\n//\nconst Import = function(path, features, options, index, currentFileInfo, visibilityInfo) {\n this.options = options;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.path = path;\n this.features = features;\n this.allowRoot = true;\n\n if (this.options.less !== undefined || this.options.inline) {\n this.css = !this.options.less || this.options.inline;\n } else {\n const pathValue = this.getPath();\n if (pathValue && /[#\\.\\&\\?]css([\\?;].*)?$/.test(pathValue)) {\n this.css = true;\n }\n }\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.features, this);\n this.setParent(this.path, this);\n}\n\nImport.prototype = new Node();\n\nImport.prototype.accept = function(visitor) {\n if (this.features) {\n this.features = visitor.visit(this.features);\n }\n this.path = visitor.visit(this.path);\n if (!this.options.isPlugin && !this.options.inline && this.root) {\n this.root = visitor.visit(this.root);\n }\n};\n\nImport.prototype.genCSS = function(context, output) {\n if (this.css && this.path._fileInfo.reference === undefined) {\n output.add('@import ', this._fileInfo, this._index);\n this.path.genCSS(context, output);\n if (this.features) {\n output.add(' ');\n this.features.genCSS(context, output);\n }\n output.add(';');\n }\n};\n\nImport.prototype.getPath = function() {\n return (this.path instanceof URL) ?\n this.path.value.value : this.path.value;\n};\n\nImport.prototype.isVariableImport = function() {\n let path = this.path;\n if (path instanceof URL) {\n path = path.value;\n }\n if (path instanceof Quoted) {\n return path.containsVariables();\n }\n\n return true;\n};\n\nImport.prototype.evalForImport = function(context) {\n let path = this.path;\n\n if (path instanceof URL) {\n path = path.value;\n }\n\n return new Import(path.eval(context), this.features, this.options, this._index, this._fileInfo, this.visibilityInfo());\n};\n\nImport.prototype.evalPath = function(context) {\n const path = this.path.eval(context);\n const fileInfo = this._fileInfo;\n\n if (!(path instanceof URL)) {\n // Add the rootpath if the URL requires a rewrite\n const pathValue = path.value;\n if (fileInfo &&\n pathValue &&\n context.pathRequiresRewrite(pathValue)) {\n path.value = context.rewritePath(pathValue, fileInfo.rootpath);\n } else {\n path.value = context.normalizePath(path.value);\n }\n }\n\n return path;\n};\n\nImport.prototype.eval = function(context) {\n const result = this.doEval(context);\n if (this.options.reference || this.blocksVisibility()) {\n if (result.length || result.length === 0) {\n result.forEach(node => {\n node.addVisibilityBlock();\n }\n );\n } else {\n result.addVisibilityBlock();\n }\n }\n return result;\n};\n\nImport.prototype.doEval = function(context) {\n let ruleset;\n let registry;\n const features = this.features && this.features.eval(context);\n\n if (this.options.isPlugin) {\n if (this.root && this.root.eval) {\n try {\n this.root.eval(context);\n }\n catch (e) {\n e.message = 'Plugin error during evaluation';\n throw new LessError(e, this.root.imports, this.root.filename);\n }\n }\n registry = context.frames[0] && context.frames[0].functionRegistry;\n if ( registry && this.root && this.root.functions ) {\n registry.addMultiple( this.root.functions );\n }\n\n return [];\n }\n\n if (this.skip) {\n if (typeof this.skip === 'function') {\n this.skip = this.skip();\n }\n if (this.skip) {\n return [];\n }\n }\n if (this.options.inline) {\n const contents = new Anonymous(this.root, 0,\n {\n filename: this.importedFilename,\n reference: this.path._fileInfo && this.path._fileInfo.reference\n }, true, true);\n\n return this.features ? new Media([contents], this.features.value) : [contents];\n } else if (this.css) {\n const newImport = new Import(this.evalPath(context), features, this.options, this._index);\n if (!newImport.css && this.error) {\n throw this.error;\n }\n return newImport;\n } else if (this.root) {\n ruleset = new Ruleset(null, utils.copyArray(this.root.rules));\n ruleset.evalImports(context);\n\n return this.features ? new Media(ruleset.rules, this.features.value) : ruleset.rules;\n } else {\n return [];\n }\n};\n\nImport.prototype.type = 'Import';\nexport default Import;\n","import Node from './node';\nimport Variable from './variable';\n\nconst JsEvalNode = function() {};\n\nJsEvalNode.prototype = new Node();\n\nJsEvalNode.prototype.evaluateJavaScript = function(expression, context) {\n let result;\n const that = this;\n const evalContext = {};\n\n if (!context.javascriptEnabled) {\n throw { message: 'Inline JavaScript is not enabled. Is it set in your options?',\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n expression = expression.replace(/@\\{([\\w-]+)\\}/g, (_, name) => that.jsify(new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context)));\n\n try {\n expression = new Function(`return (${expression})`);\n } catch (e) {\n throw { message: `JavaScript evaluation error: ${e.message} from \\`${expression}\\`` ,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n const variables = context.frames[0].variables();\n for (const k in variables) {\n if (variables.hasOwnProperty(k)) {\n /* jshint loopfunc:true */\n evalContext[k.slice(1)] = {\n value: variables[k].value,\n toJS: function () {\n return this.value.eval(context).toCSS();\n }\n };\n }\n }\n\n try {\n result = expression.call(evalContext);\n } catch (e) {\n throw { message: `JavaScript evaluation error: '${e.name}: ${e.message.replace(/[\"]/g, '\\'')}'` ,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n return result;\n};\n\nJsEvalNode.prototype.jsify = function(obj) {\n if (Array.isArray(obj.value) && (obj.value.length > 1)) {\n return `[${obj.value.map(v => v.toCSS()).join(', ')}]`;\n } else {\n return obj.toCSS();\n }\n};\n\nexport default JsEvalNode;\n","import JsEvalNode from './js-eval-node';\nimport Dimension from './dimension';\nimport Quoted from './quoted';\nimport Anonymous from './anonymous';\n\nconst JavaScript = function(string, escaped, index, currentFileInfo) {\n this.escaped = escaped;\n this.expression = string;\n this._index = index;\n this._fileInfo = currentFileInfo;\n};\n\nJavaScript.prototype = new JsEvalNode();\n\nJavaScript.prototype.eval = function(context) {\n const result = this.evaluateJavaScript(this.expression, context);\n const type = typeof result;\n\n if (type === 'number' && !isNaN(result)) {\n return new Dimension(result);\n } else if (type === 'string') {\n return new Quoted(`\"${result}\"`, result, this.escaped, this._index);\n } else if (Array.isArray(result)) {\n return new Anonymous(result.join(', '));\n } else {\n return new Anonymous(result);\n }\n};\n\nJavaScript.prototype.type = 'JavaScript';\nexport default JavaScript;\n","import Node from './node';\n\nconst Assignment = function(key, val) {\n this.key = key;\n this.value = val;\n};\n\nAssignment.prototype = new Node();\n\nAssignment.prototype.accept = function(visitor) {\n this.value = visitor.visit(this.value);\n};\n\nAssignment.prototype.eval = function(context) {\n if (this.value.eval) {\n return new Assignment(this.key, this.value.eval(context));\n }\n return this;\n};\n\nAssignment.prototype.genCSS = function(context, output) {\n output.add(`${this.key}=`);\n if (this.value.genCSS) {\n this.value.genCSS(context, output);\n } else {\n output.add(this.value);\n }\n};\n\nAssignment.prototype.type = 'Assignment';\nexport default Assignment;\n","import Node from './node';\n\nconst Condition = function(op, l, r, i, negate) {\n this.op = op.trim();\n this.lvalue = l;\n this.rvalue = r;\n this._index = i;\n this.negate = negate;\n};\n\nCondition.prototype = new Node();\n\nCondition.prototype.accept = function(visitor) {\n this.lvalue = visitor.visit(this.lvalue);\n this.rvalue = visitor.visit(this.rvalue);\n}\n\nCondition.prototype.eval = function(context) {\n const result = ((op, a, b) => {\n switch (op) {\n case 'and': return a && b;\n case 'or': return a || b;\n default:\n switch (Node.compare(a, b)) {\n case -1:\n return op === '<' || op === '=<' || op === '<=';\n case 0:\n return op === '=' || op === '>=' || op === '=<' || op === '<=';\n case 1:\n return op === '>' || op === '>=';\n default:\n return false;\n }\n }\n })(this.op, this.lvalue.eval(context), this.rvalue.eval(context));\n\n return this.negate ? !result : result;\n};\n\nCondition.prototype.type = 'Condition';\nexport default Condition;\n","import Node from './node';\n\nconst UnicodeDescriptor = function(value) {\n this.value = value;\n}\n\nUnicodeDescriptor.prototype = new Node();\nUnicodeDescriptor.prototype.type = 'UnicodeDescriptor';\n\nexport default UnicodeDescriptor;\n","import Node from './node';\nimport Operation from './operation';\nimport Dimension from './dimension';\n\nconst Negative = function(node) {\n this.value = node;\n}\n\nNegative.prototype = new Node();\n\nNegative.prototype.genCSS = function(context, output) {\n output.add('-');\n this.value.genCSS(context, output);\n};\n\nNegative.prototype.eval = function(context) {\n if (context.isMathOn()) {\n return (new Operation('*', [new Dimension(-1), this.value])).eval(context);\n }\n return new Negative(this.value.eval(context));\n};\n\nNegative.prototype.type = 'Negative';\nexport default Negative;\n","import Node from './node';\nimport Selector from './selector';\n\nconst Extend = function(selector, option, index, currentFileInfo, visibilityInfo) {\n this.selector = selector;\n this.option = option;\n this.object_id = Extend.next_id++;\n this.parent_ids = [this.object_id];\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n\n switch (option) {\n case 'all':\n this.allowBefore = true;\n this.allowAfter = true;\n break;\n default:\n this.allowBefore = false;\n this.allowAfter = false;\n break;\n }\n this.setParent(this.selector, this);\n};\n\nExtend.prototype = new Node();\n\nExtend.prototype.accept = function(visitor) {\n this.selector = visitor.visit(this.selector);\n};\n\nExtend.prototype.eval = function(context) {\n return new Extend(this.selector.eval(context), this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n};\n\nExtend.prototype.clone = function(context) {\n return new Extend(this.selector, this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n};\n\n// it concatenates (joins) all selectors in selector array\nExtend.prototype.findSelfSelectors = function(selectors) {\n let selfElements = [];\n let i;\n let selectorElements;\n\n for (i = 0; i < selectors.length; i++) {\n selectorElements = selectors[i].elements;\n // duplicate the logic in genCSS function inside the selector node.\n // future TODO - move both logics into the selector joiner visitor\n if (i > 0 && selectorElements.length && selectorElements[0].combinator.value === '') {\n selectorElements[0].combinator.value = ' ';\n }\n selfElements = selfElements.concat(selectors[i].elements);\n }\n\n this.selfSelectors = [new Selector(selfElements)];\n this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo());\n};\n\n/**\n * Used with the extend visitor\n */\nExtend.next_id = 0;\nExtend.prototype.type = 'Extend';\nexport default Extend;\n","import Node from './node';\nimport Variable from './variable';\nimport Ruleset from './ruleset';\nimport DetachedRuleset from './detached-ruleset';\nimport LessError from '../less-error';\n\nconst VariableCall = function(variable, index, currentFileInfo) {\n this.variable = variable;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.allowRoot = true;\n};\n\nVariableCall.prototype = new Node();\n\nVariableCall.prototype.eval = function(context) {\n let rules;\n let detachedRuleset = new Variable(this.variable, this.getIndex(), this.fileInfo()).eval(context);\n const error = new LessError({message: `Could not evaluate variable call ${this.variable}`});\n\n if (!detachedRuleset.ruleset) {\n if (detachedRuleset.rules) {\n rules = detachedRuleset;\n }\n else if (Array.isArray(detachedRuleset)) {\n rules = new Ruleset('', detachedRuleset);\n }\n else if (Array.isArray(detachedRuleset.value)) {\n rules = new Ruleset('', detachedRuleset.value);\n }\n else {\n throw error;\n }\n detachedRuleset = new DetachedRuleset(rules);\n }\n\n if (detachedRuleset.ruleset) {\n return detachedRuleset.callEval(context);\n }\n throw error;\n};\n\nVariableCall.prototype.type = 'VariableCall';\nexport default VariableCall;\n","import Node from './node';\nimport Variable from './variable';\nimport Ruleset from './ruleset';\nimport Selector from './selector';\n\nconst NamespaceValue = function(ruleCall, lookups, index, fileInfo) {\n this.value = ruleCall;\n this.lookups = lookups;\n this._index = index;\n this._fileInfo = fileInfo;\n}\n\nNamespaceValue.prototype = new Node();\n\nNamespaceValue.prototype.eval = function(context) {\n let i;\n let j;\n let name;\n let rules = this.value.eval(context);\n\n for (i = 0; i < this.lookups.length; i++) {\n name = this.lookups[i];\n\n /**\n * Eval'd DRs return rulesets.\n * Eval'd mixins return rules, so let's make a ruleset if we need it.\n * We need to do this because of late parsing of values\n */\n if (Array.isArray(rules)) {\n rules = new Ruleset([new Selector()], rules);\n }\n\n if (name === '') {\n rules = rules.lastDeclaration();\n }\n else if (name.charAt(0) === '@') {\n if (name.charAt(1) === '@') {\n name = `@${new Variable(name.substr(1)).eval(context).value}`;\n }\n if (rules.variables) {\n rules = rules.variable(name);\n }\n \n if (!rules) {\n throw { type: 'Name',\n message: `variable ${name} not found`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n }\n else {\n if (name.substring(0, 2) === '$@') {\n name = `$${new Variable(name.substr(1)).eval(context).value}`;\n }\n else {\n name = name.charAt(0) === '$' ? name : `$${name}`;\n }\n if (rules.properties) {\n rules = rules.property(name);\n }\n \n if (!rules) {\n throw { type: 'Name',\n message: `property \"${name.substr(1)}\" not found`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n // Properties are an array of values, since a ruleset can have multiple props.\n // We pick the last one (the \"cascaded\" value)\n rules = rules[rules.length - 1];\n }\n\n if (rules.value) {\n rules = rules.eval(context).value;\n }\n if (rules.ruleset) {\n rules = rules.ruleset.eval(context);\n }\n }\n return rules;\n};\n\nNamespaceValue.prototype.type = 'NamespaceValue';\nexport default NamespaceValue;\n","import Selector from './selector';\nimport Element from './element';\nimport Ruleset from './ruleset';\nimport Declaration from './declaration';\nimport DetachedRuleset from './detached-ruleset';\nimport Expression from './expression';\nimport contexts from '../contexts';\nimport * as utils from '../utils';\n\nconst Definition = function(name, params, rules, condition, variadic, frames, visibilityInfo) {\n this.name = name || 'anonymous mixin';\n this.selectors = [new Selector([new Element(null, name, false, this._index, this._fileInfo)])];\n this.params = params;\n this.condition = condition;\n this.variadic = variadic;\n this.arity = params.length;\n this.rules = rules;\n this._lookups = {};\n const optionalParameters = [];\n this.required = params.reduce((count, p) => {\n if (!p.name || (p.name && !p.value)) {\n return count + 1;\n }\n else {\n optionalParameters.push(p.name);\n return count;\n }\n }, 0);\n this.optionalParameters = optionalParameters;\n this.frames = frames;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n};\n\nDefinition.prototype = new Ruleset();\n\nDefinition.prototype.accept = function(visitor) {\n if (this.params && this.params.length) {\n this.params = visitor.visitArray(this.params);\n }\n this.rules = visitor.visitArray(this.rules);\n if (this.condition) {\n this.condition = visitor.visit(this.condition);\n }\n};\n\nDefinition.prototype.evalParams = function(context, mixinEnv, args, evaldArguments) {\n /* jshint boss:true */\n const frame = new Ruleset(null, null);\n\n let varargs;\n let arg;\n const params = utils.copyArray(this.params);\n let i;\n let j;\n let val;\n let name;\n let isNamedFound;\n let argIndex;\n let argsLength = 0;\n\n if (mixinEnv.frames && mixinEnv.frames[0] && mixinEnv.frames[0].functionRegistry) {\n frame.functionRegistry = mixinEnv.frames[0].functionRegistry.inherit();\n }\n mixinEnv = new contexts.Eval(mixinEnv, [frame].concat(mixinEnv.frames));\n\n if (args) {\n args = utils.copyArray(args);\n argsLength = args.length;\n\n for (i = 0; i < argsLength; i++) {\n arg = args[i];\n if (name = (arg && arg.name)) {\n isNamedFound = false;\n for (j = 0; j < params.length; j++) {\n if (!evaldArguments[j] && name === params[j].name) {\n evaldArguments[j] = arg.value.eval(context);\n frame.prependRule(new Declaration(name, arg.value.eval(context)));\n isNamedFound = true;\n break;\n }\n }\n if (isNamedFound) {\n args.splice(i, 1);\n i--;\n continue;\n } else {\n throw { type: 'Runtime', message: `Named argument for ${this.name} ${args[i].name} not found` };\n }\n }\n }\n }\n argIndex = 0;\n for (i = 0; i < params.length; i++) {\n if (evaldArguments[i]) { continue; }\n\n arg = args && args[argIndex];\n\n if (name = params[i].name) {\n if (params[i].variadic) {\n varargs = [];\n for (j = argIndex; j < argsLength; j++) {\n varargs.push(args[j].value.eval(context));\n }\n frame.prependRule(new Declaration(name, new Expression(varargs).eval(context)));\n } else {\n val = arg && arg.value;\n if (val) {\n // This was a mixin call, pass in a detached ruleset of it's eval'd rules\n if (Array.isArray(val)) {\n val = new DetachedRuleset(new Ruleset('', val));\n }\n else {\n val = val.eval(context);\n }\n } else if (params[i].value) {\n val = params[i].value.eval(mixinEnv);\n frame.resetCache();\n } else {\n throw { type: 'Runtime', message: `wrong number of arguments for ${this.name} (${argsLength} for ${this.arity})` };\n }\n\n frame.prependRule(new Declaration(name, val));\n evaldArguments[i] = val;\n }\n }\n\n if (params[i].variadic && args) {\n for (j = argIndex; j < argsLength; j++) {\n evaldArguments[j] = args[j].value.eval(context);\n }\n }\n argIndex++;\n }\n\n return frame;\n};\n\nDefinition.prototype.makeImportant = function() {\n const rules = !this.rules ? this.rules : this.rules.map(r => {\n if (r.makeImportant) {\n return r.makeImportant(true);\n } else {\n return r;\n }\n });\n const result = new Definition(this.name, this.params, rules, this.condition, this.variadic, this.frames);\n return result;\n};\n\nDefinition.prototype.eval = function(context) {\n return new Definition(this.name, this.params, this.rules, this.condition, this.variadic, this.frames || utils.copyArray(context.frames));\n};\n\nDefinition.prototype.evalCall = function(context, args, important) {\n const _arguments = [];\n const mixinFrames = this.frames ? this.frames.concat(context.frames) : context.frames;\n const frame = this.evalParams(context, new contexts.Eval(context, mixinFrames), args, _arguments);\n let rules;\n let ruleset;\n\n frame.prependRule(new Declaration('@arguments', new Expression(_arguments).eval(context)));\n\n rules = utils.copyArray(this.rules);\n\n ruleset = new Ruleset(null, rules);\n ruleset.originalRuleset = this;\n ruleset = ruleset.eval(new contexts.Eval(context, [this, frame].concat(mixinFrames)));\n if (important) {\n ruleset = ruleset.makeImportant();\n }\n return ruleset;\n};\n\nDefinition.prototype.matchCondition = function(args, context) {\n if (this.condition && !this.condition.eval(\n new contexts.Eval(context,\n [this.evalParams(context, /* the parameter variables */\n new contexts.Eval(context, this.frames ? this.frames.concat(context.frames) : context.frames), args, [])]\n .concat(this.frames || []) // the parent namespace/mixin frames\n .concat(context.frames)))) { // the current environment frames\n return false;\n }\n return true;\n};\n\nDefinition.prototype.matchArgs = function(args, context) {\n const allArgsCnt = (args && args.length) || 0;\n let len;\n const optionalParameters = this.optionalParameters;\n const requiredArgsCnt = !args ? 0 : args.reduce((count, p) => {\n if (optionalParameters.indexOf(p.name) < 0) {\n return count + 1;\n } else {\n return count;\n }\n }, 0);\n\n if (!this.variadic) {\n if (requiredArgsCnt < this.required) {\n return false;\n }\n if (allArgsCnt > this.params.length) {\n return false;\n }\n } else {\n if (requiredArgsCnt < (this.required - 1)) {\n return false;\n }\n }\n\n // check patterns\n len = Math.min(requiredArgsCnt, this.arity);\n\n for (let i = 0; i < len; i++) {\n if (!this.params[i].name && !this.params[i].variadic) {\n if (args[i].value.eval(context).toCSS() != this.params[i].value.eval(context).toCSS()) {\n return false;\n }\n }\n }\n return true;\n};\n\nDefinition.prototype.type = 'MixinDefinition';\nDefinition.prototype.evalFirst = true;\nexport default Definition;\n","import Node from './node';\nimport Selector from './selector';\nimport MixinDefinition from './mixin-definition';\nimport defaultFunc from '../functions/default';\n\nconst MixinCall = function(elements, args, index, currentFileInfo, important) {\n this.selector = new Selector(elements);\n this.arguments = args || [];\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.important = important;\n this.allowRoot = true;\n this.setParent(this.selector, this);\n};\n\nMixinCall.prototype = new Node();\n\nMixinCall.prototype.accept = function(visitor) {\n if (this.selector) {\n this.selector = visitor.visit(this.selector);\n }\n if (this.arguments.length) {\n this.arguments = visitor.visitArray(this.arguments);\n }\n};\n\nMixinCall.prototype.eval = function(context) {\n let mixins;\n let mixin;\n let mixinPath;\n const args = [];\n let arg;\n let argValue;\n const rules = [];\n let match = false;\n let i;\n let m;\n let f;\n let isRecursive;\n let isOneFound;\n const candidates = [];\n let candidate;\n const conditionResult = [];\n let defaultResult;\n const defFalseEitherCase = -1;\n const defNone = 0;\n const defTrue = 1;\n const defFalse = 2;\n let count;\n let originalRuleset;\n let noArgumentsFilter;\n\n this.selector = this.selector.eval(context);\n\n function calcDefGroup(mixin, mixinPath) {\n let f;\n let p;\n let namespace;\n\n for (f = 0; f < 2; f++) {\n conditionResult[f] = true;\n defaultFunc.value(f);\n for (p = 0; p < mixinPath.length && conditionResult[f]; p++) {\n namespace = mixinPath[p];\n if (namespace.matchCondition) {\n conditionResult[f] = conditionResult[f] && namespace.matchCondition(null, context);\n }\n }\n if (mixin.matchCondition) {\n conditionResult[f] = conditionResult[f] && mixin.matchCondition(args, context);\n }\n }\n if (conditionResult[0] || conditionResult[1]) {\n if (conditionResult[0] != conditionResult[1]) {\n return conditionResult[1] ?\n defTrue : defFalse;\n }\n\n return defNone;\n }\n return defFalseEitherCase;\n }\n\n for (i = 0; i < this.arguments.length; i++) {\n arg = this.arguments[i];\n argValue = arg.value.eval(context);\n if (arg.expand && Array.isArray(argValue.value)) {\n argValue = argValue.value;\n for (m = 0; m < argValue.length; m++) {\n args.push({value: argValue[m]});\n }\n } else {\n args.push({name: arg.name, value: argValue});\n }\n }\n\n noArgumentsFilter = rule => rule.matchArgs(null, context);\n\n for (i = 0; i < context.frames.length; i++) {\n if ((mixins = context.frames[i].find(this.selector, null, noArgumentsFilter)).length > 0) {\n isOneFound = true;\n\n // To make `default()` function independent of definition order we have two \"subpasses\" here.\n // At first we evaluate each guard *twice* (with `default() == true` and `default() == false`),\n // and build candidate list with corresponding flags. Then, when we know all possible matches,\n // we make a final decision.\n\n for (m = 0; m < mixins.length; m++) {\n mixin = mixins[m].rule;\n mixinPath = mixins[m].path;\n isRecursive = false;\n for (f = 0; f < context.frames.length; f++) {\n if ((!(mixin instanceof MixinDefinition)) && mixin === (context.frames[f].originalRuleset || context.frames[f])) {\n isRecursive = true;\n break;\n }\n }\n if (isRecursive) {\n continue;\n }\n\n if (mixin.matchArgs(args, context)) {\n candidate = {mixin, group: calcDefGroup(mixin, mixinPath)};\n\n if (candidate.group !== defFalseEitherCase) {\n candidates.push(candidate);\n }\n\n match = true;\n }\n }\n\n defaultFunc.reset();\n\n count = [0, 0, 0];\n for (m = 0; m < candidates.length; m++) {\n count[candidates[m].group]++;\n }\n\n if (count[defNone] > 0) {\n defaultResult = defFalse;\n } else {\n defaultResult = defTrue;\n if ((count[defTrue] + count[defFalse]) > 1) {\n throw { type: 'Runtime',\n message: `Ambiguous use of \\`default()\\` found when matching for \\`${this.format(args)}\\``,\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n }\n\n for (m = 0; m < candidates.length; m++) {\n candidate = candidates[m].group;\n if ((candidate === defNone) || (candidate === defaultResult)) {\n try {\n mixin = candidates[m].mixin;\n if (!(mixin instanceof MixinDefinition)) {\n originalRuleset = mixin.originalRuleset || mixin;\n mixin = new MixinDefinition('', [], mixin.rules, null, false, null, originalRuleset.visibilityInfo());\n mixin.originalRuleset = originalRuleset;\n }\n const newRules = mixin.evalCall(context, args, this.important).rules;\n this._setVisibilityToReplacement(newRules);\n Array.prototype.push.apply(rules, newRules);\n } catch (e) {\n throw { message: e.message, index: this.getIndex(), filename: this.fileInfo().filename, stack: e.stack };\n }\n }\n }\n\n if (match) {\n return rules;\n }\n }\n }\n if (isOneFound) {\n throw { type: 'Runtime',\n message: `No matching definition was found for \\`${this.format(args)}\\``,\n index: this.getIndex(), filename: this.fileInfo().filename };\n } else {\n throw { type: 'Name',\n message: `${this.selector.toCSS().trim()} is undefined`,\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n};\n\nMixinCall.prototype._setVisibilityToReplacement = function(replacement) {\n let i;\n let rule;\n if (this.blocksVisibility()) {\n for (i = 0; i < replacement.length; i++) {\n rule = replacement[i];\n rule.addVisibilityBlock();\n }\n }\n};\n\nMixinCall.prototype.format = function(args) {\n return `${this.selector.toCSS().trim()}(${args ? args.map(a => {\n let argValue = '';\n if (a.name) {\n argValue += `${a.name}:`;\n }\n if (a.value.toCSS) {\n argValue += a.value.toCSS();\n } else {\n argValue += '???';\n }\n return argValue;\n }).join(', ') : ''})`;\n};\n\nMixinCall.prototype.type = 'MixinCall';\nexport default MixinCall;\n","import Node from './node';\nimport Color from './color';\nimport AtRule from './atrule';\nimport DetachedRuleset from './detached-ruleset';\nimport Operation from './operation';\nimport Dimension from './dimension';\nimport Unit from './unit';\nimport Keyword from './keyword';\nimport Variable from './variable';\nimport Property from './property';\nimport Ruleset from './ruleset';\nimport Element from './element';\nimport Attribute from './attribute';\nimport Combinator from './combinator';\nimport Selector from './selector';\nimport Quoted from './quoted';\nimport Expression from './expression';\nimport Declaration from './declaration';\nimport Call from './call';\nimport URL from './url';\nimport Import from './import';\nimport Comment from './comment';\nimport Anonymous from './anonymous';\nimport Value from './value';\nimport JavaScript from './javascript';\nimport Assignment from './assignment';\nimport Condition from './condition';\nimport Paren from './paren';\nimport Media from './media';\nimport UnicodeDescriptor from './unicode-descriptor';\nimport Negative from './negative';\nimport Extend from './extend';\nimport VariableCall from './variable-call';\nimport NamespaceValue from './namespace-value';\n\n// mixins\nimport MixinCall from './mixin-call';\nimport MixinDefinition from './mixin-definition';\n\nexport default {\n Node, Color, AtRule, DetachedRuleset, Operation,\n Dimension, Unit, Keyword, Variable, Property,\n Ruleset, Element, Attribute, Combinator, Selector,\n Quoted, Expression, Declaration, Call, URL, Import,\n Comment, Anonymous, Value, JavaScript, Assignment,\n Condition, Paren, Media, UnicodeDescriptor, Negative,\n Extend, VariableCall, NamespaceValue,\n mixin: {\n Call: MixinCall,\n Definition: MixinDefinition\n }\n};","export default {\n error: function(msg) {\n this._fireEvent('error', msg);\n },\n warn: function(msg) {\n this._fireEvent('warn', msg);\n },\n info: function(msg) {\n this._fireEvent('info', msg);\n },\n debug: function(msg) {\n this._fireEvent('debug', msg);\n },\n addListener: function(listener) {\n this._listeners.push(listener);\n },\n removeListener: function(listener) {\n for (let i = 0; i < this._listeners.length; i++) {\n if (this._listeners[i] === listener) {\n this._listeners.splice(i, 1);\n return;\n }\n }\n },\n _fireEvent: function(type, msg) {\n for (let i = 0; i < this._listeners.length; i++) {\n const logFunction = this._listeners[i][type];\n if (logFunction) {\n logFunction(msg);\n }\n }\n },\n _listeners: []\n};\n","/**\n * @todo Document why this abstraction exists, and the relationship between\n * environment, file managers, and plugin manager\n */\n\nimport logger from '../logger';\n\nclass environment {\n constructor(externalEnvironment, fileManagers) {\n this.fileManagers = fileManagers || [];\n externalEnvironment = externalEnvironment || {};\n\n const optionalFunctions = ['encodeBase64', 'mimeLookup', 'charsetLookup', 'getSourceMapGenerator'];\n const requiredFunctions = [];\n const functions = requiredFunctions.concat(optionalFunctions);\n\n for (let i = 0; i < functions.length; i++) {\n const propName = functions[i];\n const environmentFunc = externalEnvironment[propName];\n if (environmentFunc) {\n this[propName] = environmentFunc.bind(externalEnvironment);\n } else if (i < requiredFunctions.length) {\n this.warn(`missing required function in environment - ${propName}`);\n }\n }\n }\n\n getFileManager(filename, currentDirectory, options, environment, isSync) {\n\n if (!filename) {\n logger.warn('getFileManager called with no filename.. Please report this issue. continuing.');\n }\n if (currentDirectory == null) {\n logger.warn('getFileManager called with null directory.. Please report this issue. continuing.');\n }\n\n let fileManagers = this.fileManagers;\n if (options.pluginManager) {\n fileManagers = [].concat(fileManagers).concat(options.pluginManager.getFileManagers());\n }\n for (let i = fileManagers.length - 1; i >= 0 ; i--) {\n const fileManager = fileManagers[i];\n if (fileManager[isSync ? 'supportsSync' : 'supports'](filename, currentDirectory, options, environment)) {\n return fileManager;\n }\n }\n return null;\n }\n\n addFileManager(fileManager) {\n this.fileManagers.push(fileManager);\n }\n\n clearFileManagers() {\n this.fileManagers = [];\n }\n}\n\nexport default environment;\n","class AbstractFileManager {\n getPath(filename) {\n let j = filename.lastIndexOf('?');\n if (j > 0) {\n filename = filename.slice(0, j);\n }\n j = filename.lastIndexOf('/');\n if (j < 0) {\n j = filename.lastIndexOf('\\\\');\n }\n if (j < 0) {\n return '';\n }\n return filename.slice(0, j + 1);\n }\n\n tryAppendExtension(path, ext) {\n return /(\\.[a-z]*$)|([\\?;].*)$/.test(path) ? path : path + ext;\n }\n\n tryAppendLessExtension(path) {\n return this.tryAppendExtension(path, '.less');\n };\n\n supportsSync() { return false; }\n\n alwaysMakePathsAbsolute() { return false; }\n\n isPathAbsolute(filename) {\n return (/^(?:[a-z-]+:|\\/|\\\\|#)/i).test(filename);\n }\n // TODO: pull out / replace?\n join(basePath, laterPath) {\n if (!basePath) {\n return laterPath;\n }\n return basePath + laterPath;\n };\n\n pathDiff(url, baseUrl) {\n // diff between two paths to create a relative path\n const urlParts = this.extractUrlParts(url);\n const baseUrlParts = this.extractUrlParts(baseUrl);\n\n let i;\n let max;\n let urlDirectories;\n let baseUrlDirectories;\n let diff = '';\n if (urlParts.hostPart !== baseUrlParts.hostPart) {\n return '';\n }\n max = Math.max(baseUrlParts.directories.length, urlParts.directories.length);\n for (i = 0; i < max; i++) {\n if (baseUrlParts.directories[i] !== urlParts.directories[i]) { break; }\n }\n baseUrlDirectories = baseUrlParts.directories.slice(i);\n urlDirectories = urlParts.directories.slice(i);\n for (i = 0; i < baseUrlDirectories.length - 1; i++) {\n diff += '../';\n }\n for (i = 0; i < urlDirectories.length - 1; i++) {\n diff += `${urlDirectories[i]}/`;\n }\n return diff;\n };\n // helper function, not part of API\n extractUrlParts(url, baseUrl) {\n // urlParts[1] = protocol://hostname/ OR /\n // urlParts[2] = / if path relative to host base\n // urlParts[3] = directories\n // urlParts[4] = filename\n // urlParts[5] = parameters\n\n const urlPartsRegex = /^((?:[a-z-]+:)?\\/{2}(?:[^\\/\\?#]*\\/)|([\\/\\\\]))?((?:[^\\/\\\\\\?#]*[\\/\\\\])*)([^\\/\\\\\\?#]*)([#\\?].*)?$/i;\n\n const urlParts = url.match(urlPartsRegex);\n const returner = {};\n let rawDirectories = [];\n const directories = [];\n let i;\n let baseUrlParts;\n\n if (!urlParts) {\n throw new Error(`Could not parse sheet href - '${url}'`);\n }\n\n // Stylesheets in IE don't always return the full path\n if (baseUrl && (!urlParts[1] || urlParts[2])) {\n baseUrlParts = baseUrl.match(urlPartsRegex);\n if (!baseUrlParts) {\n throw new Error(`Could not parse page url - '${baseUrl}'`);\n }\n urlParts[1] = urlParts[1] || baseUrlParts[1] || '';\n if (!urlParts[2]) {\n urlParts[3] = baseUrlParts[3] + urlParts[3];\n }\n }\n\n if (urlParts[3]) {\n rawDirectories = urlParts[3].replace(/\\\\/g, '/').split('/');\n\n // collapse '..' and skip '.'\n for (i = 0; i < rawDirectories.length; i++) {\n\n if (rawDirectories[i] === '..') {\n directories.pop();\n }\n else if (rawDirectories[i] !== '.') {\n directories.push(rawDirectories[i]);\n }\n \n }\n }\n\n returner.hostPart = urlParts[1];\n returner.directories = directories;\n returner.rawPath = (urlParts[1] || '') + rawDirectories.join('/');\n returner.path = (urlParts[1] || '') + directories.join('/');\n returner.filename = urlParts[4];\n returner.fileUrl = returner.path + (urlParts[4] || '');\n returner.url = returner.fileUrl + (urlParts[5] || '');\n return returner;\n };\n}\n\nexport default AbstractFileManager;","import functionRegistry from '../functions/function-registry';\nimport LessError from '../less-error';\n\nclass AbstractPluginLoader {\n constructor() {\n // Implemented by Node.js plugin loader\n this.require = () => null\n }\n\n evalPlugin(contents, context, imports, pluginOptions, fileInfo) {\n let loader;\n let registry;\n let pluginObj;\n let localModule;\n let pluginManager;\n let filename;\n let result;\n\n pluginManager = context.pluginManager;\n\n if (fileInfo) {\n if (typeof fileInfo === 'string') {\n filename = fileInfo;\n }\n else {\n filename = fileInfo.filename;\n }\n }\n const shortname = (new this.less.FileManager()).extractUrlParts(filename).filename;\n\n if (filename) {\n pluginObj = pluginManager.get(filename);\n\n if (pluginObj) {\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n if (result) {\n return result;\n }\n try {\n if (pluginObj.use) {\n pluginObj.use.call(this.context, pluginObj);\n }\n }\n catch (e) {\n e.message = e.message || 'Error during @plugin call';\n return new LessError(e, imports, filename);\n }\n return pluginObj;\n }\n }\n localModule = {\n exports: {},\n pluginManager,\n fileInfo\n };\n registry = functionRegistry.create();\n\n const registerPlugin = obj => {\n pluginObj = obj;\n };\n\n try {\n loader = new Function('module', 'require', 'registerPlugin', 'functions', 'tree', 'less', 'fileInfo', contents);\n loader(localModule, this.require(filename), registerPlugin, registry, this.less.tree, this.less, fileInfo);\n }\n catch (e) {\n return new LessError(e, imports, filename);\n }\n\n if (!pluginObj) {\n pluginObj = localModule.exports;\n }\n pluginObj = this.validatePlugin(pluginObj, filename, shortname);\n\n if (pluginObj instanceof LessError) {\n return pluginObj;\n }\n\n if (pluginObj) {\n pluginObj.imports = imports;\n pluginObj.filename = filename;\n\n // For < 3.x (or unspecified minVersion) - setOptions() before install()\n if (!pluginObj.minVersion || this.compareVersion('3.0.0', pluginObj.minVersion) < 0) {\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n\n if (result) {\n return result;\n }\n }\n\n // Run on first load\n pluginManager.addPlugin(pluginObj, fileInfo.filename, registry);\n pluginObj.functions = registry.getLocalFunctions();\n\n // Need to call setOptions again because the pluginObj might have functions\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n if (result) {\n return result;\n }\n\n // Run every @plugin call\n try {\n if (pluginObj.use) {\n pluginObj.use.call(this.context, pluginObj);\n }\n }\n catch (e) {\n e.message = e.message || 'Error during @plugin call';\n return new LessError(e, imports, filename);\n }\n\n }\n else {\n return new LessError({ message: 'Not a valid plugin' }, imports, filename);\n }\n\n return pluginObj;\n }\n\n trySetOptions(plugin, filename, name, options) {\n if (options && !plugin.setOptions) {\n return new LessError({\n message: `Options have been provided but the plugin ${name} does not support any options.`\n });\n }\n try {\n plugin.setOptions && plugin.setOptions(options);\n }\n catch (e) {\n return new LessError(e);\n }\n }\n\n validatePlugin(plugin, filename, name) {\n if (plugin) {\n // support plugins being a function\n // so that the plugin can be more usable programmatically\n if (typeof plugin === 'function') {\n plugin = new plugin();\n }\n\n if (plugin.minVersion) {\n if (this.compareVersion(plugin.minVersion, this.less.version) < 0) {\n return new LessError({\n message: `Plugin ${name} requires version ${this.versionToString(plugin.minVersion)}`\n });\n }\n }\n return plugin;\n }\n return null;\n }\n\n compareVersion(aVersion, bVersion) {\n if (typeof aVersion === 'string') {\n aVersion = aVersion.match(/^(\\d+)\\.?(\\d+)?\\.?(\\d+)?/);\n aVersion.shift();\n }\n for (let i = 0; i < aVersion.length; i++) {\n if (aVersion[i] !== bVersion[i]) {\n return parseInt(aVersion[i]) > parseInt(bVersion[i]) ? -1 : 1;\n }\n }\n return 0;\n }\n\n versionToString(version) {\n let versionString = '';\n for (let i = 0; i < version.length; i++) {\n versionString += (versionString ? '.' : '') + version[i];\n }\n return versionString;\n }\n\n printUsage(plugins) {\n for (let i = 0; i < plugins.length; i++) {\n const plugin = plugins[i];\n if (plugin.printUsage) {\n plugin.printUsage();\n }\n }\n }\n}\n\nexport default AbstractPluginLoader;\n\n","import tree from '../tree';\nconst _visitArgs = { visitDeeper: true };\nlet _hasIndexed = false;\n\nfunction _noop(node) {\n return node;\n}\n\nfunction indexNodeTypes(parent, ticker) {\n // add .typeIndex to tree node types for lookup table\n let key;\n\n let child;\n for (key in parent) { \n /* eslint guard-for-in: 0 */\n child = parent[key];\n switch (typeof child) {\n case 'function':\n // ignore bound functions directly on tree which do not have a prototype\n // or aren't nodes\n if (child.prototype && child.prototype.type) {\n child.prototype.typeIndex = ticker++;\n }\n break;\n case 'object':\n ticker = indexNodeTypes(child, ticker);\n break;\n \n }\n }\n return ticker;\n}\n\nclass Visitor {\n constructor(implementation) {\n this._implementation = implementation;\n this._visitInCache = {};\n this._visitOutCache = {};\n\n if (!_hasIndexed) {\n indexNodeTypes(tree, 1);\n _hasIndexed = true;\n }\n }\n\n visit(node) {\n if (!node) {\n return node;\n }\n\n const nodeTypeIndex = node.typeIndex;\n if (!nodeTypeIndex) {\n // MixinCall args aren't a node type?\n if (node.value && node.value.typeIndex) {\n this.visit(node.value);\n }\n return node;\n }\n\n const impl = this._implementation;\n let func = this._visitInCache[nodeTypeIndex];\n let funcOut = this._visitOutCache[nodeTypeIndex];\n const visitArgs = _visitArgs;\n let fnName;\n\n visitArgs.visitDeeper = true;\n\n if (!func) {\n fnName = `visit${node.type}`;\n func = impl[fnName] || _noop;\n funcOut = impl[`${fnName}Out`] || _noop;\n this._visitInCache[nodeTypeIndex] = func;\n this._visitOutCache[nodeTypeIndex] = funcOut;\n }\n\n if (func !== _noop) {\n const newNode = func.call(impl, node, visitArgs);\n if (node && impl.isReplacing) {\n node = newNode;\n }\n }\n\n if (visitArgs.visitDeeper && node) {\n if (node.length) {\n for (var i = 0, cnt = node.length; i < cnt; i++) {\n if (node[i].accept) {\n node[i].accept(this);\n }\n }\n } else if (node.accept) {\n node.accept(this);\n }\n }\n\n if (funcOut != _noop) {\n funcOut.call(impl, node);\n }\n\n return node;\n }\n\n visitArray(nodes, nonReplacing) {\n if (!nodes) {\n return nodes;\n }\n\n const cnt = nodes.length;\n let i;\n\n // Non-replacing\n if (nonReplacing || !this._implementation.isReplacing) {\n for (i = 0; i < cnt; i++) {\n this.visit(nodes[i]);\n }\n return nodes;\n }\n\n // Replacing\n const out = [];\n for (i = 0; i < cnt; i++) {\n const evald = this.visit(nodes[i]);\n if (evald === undefined) { continue; }\n if (!evald.splice) {\n out.push(evald);\n } else if (evald.length) {\n this.flatten(evald, out);\n }\n }\n return out;\n }\n\n flatten(arr, out) {\n if (!out) {\n out = [];\n }\n\n let cnt;\n let i;\n let item;\n let nestedCnt;\n let j;\n let nestedItem;\n\n for (i = 0, cnt = arr.length; i < cnt; i++) {\n item = arr[i];\n if (item === undefined) {\n continue;\n }\n if (!item.splice) {\n out.push(item);\n continue;\n }\n\n for (j = 0, nestedCnt = item.length; j < nestedCnt; j++) {\n nestedItem = item[j];\n if (nestedItem === undefined) {\n continue;\n }\n if (!nestedItem.splice) {\n out.push(nestedItem);\n } else if (nestedItem.length) {\n this.flatten(nestedItem, out);\n }\n }\n }\n\n return out;\n }\n}\n\nexport default Visitor;\n","class ImportSequencer {\n constructor(onSequencerEmpty) {\n this.imports = [];\n this.variableImports = [];\n this._onSequencerEmpty = onSequencerEmpty;\n this._currentDepth = 0;\n }\n\n addImport(callback) {\n const importSequencer = this;\n\n const importItem = {\n callback,\n args: null,\n isReady: false\n };\n\n this.imports.push(importItem);\n return function(...args) {\n importItem.args = Array.prototype.slice.call(args, 0);\n importItem.isReady = true;\n importSequencer.tryRun();\n };\n }\n\n addVariableImport(callback) {\n this.variableImports.push(callback);\n }\n\n tryRun() {\n this._currentDepth++;\n try {\n while (true) {\n while (this.imports.length > 0) {\n const importItem = this.imports[0];\n if (!importItem.isReady) {\n return;\n }\n this.imports = this.imports.slice(1);\n importItem.callback.apply(null, importItem.args);\n }\n if (this.variableImports.length === 0) {\n break;\n }\n const variableImport = this.variableImports[0];\n this.variableImports = this.variableImports.slice(1);\n variableImport();\n }\n } finally {\n this._currentDepth--;\n }\n if (this._currentDepth === 0 && this._onSequencerEmpty) {\n this._onSequencerEmpty();\n }\n }\n}\n\nexport default ImportSequencer;\n","import contexts from '../contexts';\nimport Visitor from './visitor';\nimport ImportSequencer from './import-sequencer';\nimport * as utils from '../utils';\n\nconst ImportVisitor = function(importer, finish) {\n\n this._visitor = new Visitor(this);\n this._importer = importer;\n this._finish = finish;\n this.context = new contexts.Eval();\n this.importCount = 0;\n this.onceFileDetectionMap = {};\n this.recursionDetector = {};\n this._sequencer = new ImportSequencer(this._onSequencerEmpty.bind(this));\n};\n\nImportVisitor.prototype = {\n isReplacing: false,\n run: function (root) {\n try {\n // process the contents\n this._visitor.visit(root);\n }\n catch (e) {\n this.error = e;\n }\n\n this.isFinished = true;\n this._sequencer.tryRun();\n },\n _onSequencerEmpty: function() {\n if (!this.isFinished) {\n return;\n }\n this._finish(this.error);\n },\n visitImport: function (importNode, visitArgs) {\n const inlineCSS = importNode.options.inline;\n\n if (!importNode.css || inlineCSS) {\n\n const context = new contexts.Eval(this.context, utils.copyArray(this.context.frames));\n const importParent = context.frames[0];\n\n this.importCount++;\n if (importNode.isVariableImport()) {\n this._sequencer.addVariableImport(this.processImportNode.bind(this, importNode, context, importParent));\n } else {\n this.processImportNode(importNode, context, importParent);\n }\n }\n visitArgs.visitDeeper = false;\n },\n processImportNode: function(importNode, context, importParent) {\n let evaldImportNode;\n const inlineCSS = importNode.options.inline;\n\n try {\n evaldImportNode = importNode.evalForImport(context);\n } catch (e) {\n if (!e.filename) { e.index = importNode.getIndex(); e.filename = importNode.fileInfo().filename; }\n // attempt to eval properly and treat as css\n importNode.css = true;\n // if that fails, this error will be thrown\n importNode.error = e;\n }\n\n if (evaldImportNode && (!evaldImportNode.css || inlineCSS)) {\n if (evaldImportNode.options.multiple) {\n context.importMultiple = true;\n }\n\n // try appending if we haven't determined if it is css or not\n const tryAppendLessExtension = evaldImportNode.css === undefined;\n\n for (let i = 0; i < importParent.rules.length; i++) {\n if (importParent.rules[i] === importNode) {\n importParent.rules[i] = evaldImportNode;\n break;\n }\n }\n\n const onImported = this.onImported.bind(this, evaldImportNode, context);\n const sequencedOnImported = this._sequencer.addImport(onImported);\n\n this._importer.push(evaldImportNode.getPath(), tryAppendLessExtension, evaldImportNode.fileInfo(),\n evaldImportNode.options, sequencedOnImported);\n } else {\n this.importCount--;\n if (this.isFinished) {\n this._sequencer.tryRun();\n }\n }\n },\n onImported: function (importNode, context, e, root, importedAtRoot, fullPath) {\n if (e) {\n if (!e.filename) {\n e.index = importNode.getIndex(); e.filename = importNode.fileInfo().filename;\n }\n this.error = e;\n }\n\n const importVisitor = this;\n const inlineCSS = importNode.options.inline;\n const isPlugin = importNode.options.isPlugin;\n const isOptional = importNode.options.optional;\n const duplicateImport = importedAtRoot || fullPath in importVisitor.recursionDetector;\n\n if (!context.importMultiple) {\n if (duplicateImport) {\n importNode.skip = true;\n } else {\n importNode.skip = () => {\n if (fullPath in importVisitor.onceFileDetectionMap) {\n return true;\n }\n importVisitor.onceFileDetectionMap[fullPath] = true;\n return false;\n };\n }\n }\n\n if (!fullPath && isOptional) {\n importNode.skip = true;\n }\n\n if (root) {\n importNode.root = root;\n importNode.importedFilename = fullPath;\n\n if (!inlineCSS && !isPlugin && (context.importMultiple || !duplicateImport)) {\n importVisitor.recursionDetector[fullPath] = true;\n\n const oldContext = this.context;\n this.context = context;\n try {\n this._visitor.visit(root);\n } catch (e) {\n this.error = e;\n }\n this.context = oldContext;\n }\n }\n\n importVisitor.importCount--;\n\n if (importVisitor.isFinished) {\n importVisitor._sequencer.tryRun();\n }\n },\n visitDeclaration: function (declNode, visitArgs) {\n if (declNode.value.type === 'DetachedRuleset') {\n this.context.frames.unshift(declNode);\n } else {\n visitArgs.visitDeeper = false;\n }\n },\n visitDeclarationOut: function(declNode) {\n if (declNode.value.type === 'DetachedRuleset') {\n this.context.frames.shift();\n }\n },\n visitAtRule: function (atRuleNode, visitArgs) {\n this.context.frames.unshift(atRuleNode);\n },\n visitAtRuleOut: function (atRuleNode) {\n this.context.frames.shift();\n },\n visitMixinDefinition: function (mixinDefinitionNode, visitArgs) {\n this.context.frames.unshift(mixinDefinitionNode);\n },\n visitMixinDefinitionOut: function (mixinDefinitionNode) {\n this.context.frames.shift();\n },\n visitRuleset: function (rulesetNode, visitArgs) {\n this.context.frames.unshift(rulesetNode);\n },\n visitRulesetOut: function (rulesetNode) {\n this.context.frames.shift();\n },\n visitMedia: function (mediaNode, visitArgs) {\n this.context.frames.unshift(mediaNode.rules[0]);\n },\n visitMediaOut: function (mediaNode) {\n this.context.frames.shift();\n }\n};\nexport default ImportVisitor;\n","class SetTreeVisibilityVisitor {\n constructor(visible) {\n this.visible = visible;\n }\n\n run(root) {\n this.visit(root);\n }\n\n visitArray(nodes) {\n if (!nodes) {\n return nodes;\n }\n\n const cnt = nodes.length;\n let i;\n for (i = 0; i < cnt; i++) {\n this.visit(nodes[i]);\n }\n return nodes;\n }\n\n visit(node) {\n if (!node) {\n return node;\n }\n if (node.constructor === Array) {\n return this.visitArray(node);\n }\n\n if (!node.blocksVisibility || node.blocksVisibility()) {\n return node;\n }\n if (this.visible) {\n node.ensureVisibility();\n } else {\n node.ensureInvisibility();\n }\n\n node.accept(this);\n return node;\n }\n}\n\nexport default SetTreeVisibilityVisitor;","import tree from '../tree';\nimport Visitor from './visitor';\nimport logger from '../logger';\nimport * as utils from '../utils';\n\n/* jshint loopfunc:true */\n\nclass ExtendFinderVisitor {\n constructor() {\n this._visitor = new Visitor(this);\n this.contexts = [];\n this.allExtendsStack = [[]];\n }\n\n run(root) {\n root = this._visitor.visit(root);\n root.allExtends = this.allExtendsStack[0];\n return root;\n }\n\n visitDeclaration(declNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n if (rulesetNode.root) {\n return;\n }\n\n let i;\n let j;\n let extend;\n const allSelectorsExtendList = [];\n let extendList;\n\n // get &:extend(.a); rules which apply to all selectors in this ruleset\n const rules = rulesetNode.rules;\n\n const ruleCnt = rules ? rules.length : 0;\n for (i = 0; i < ruleCnt; i++) {\n if (rulesetNode.rules[i] instanceof tree.Extend) {\n allSelectorsExtendList.push(rules[i]);\n rulesetNode.extendOnEveryPath = true;\n }\n }\n\n // now find every selector and apply the extends that apply to all extends\n // and the ones which apply to an individual extend\n const paths = rulesetNode.paths;\n for (i = 0; i < paths.length; i++) {\n const selectorPath = paths[i];\n const selector = selectorPath[selectorPath.length - 1];\n const selExtendList = selector.extendList;\n\n extendList = selExtendList ? utils.copyArray(selExtendList).concat(allSelectorsExtendList)\n : allSelectorsExtendList;\n\n if (extendList) {\n extendList = extendList.map(allSelectorsExtend => allSelectorsExtend.clone());\n }\n\n for (j = 0; j < extendList.length; j++) {\n this.foundExtends = true;\n extend = extendList[j];\n extend.findSelfSelectors(selectorPath);\n extend.ruleset = rulesetNode;\n if (j === 0) { extend.firstExtendOnThisSelectorPath = true; }\n this.allExtendsStack[this.allExtendsStack.length - 1].push(extend);\n }\n }\n\n this.contexts.push(rulesetNode.selectors);\n }\n\n visitRulesetOut(rulesetNode) {\n if (!rulesetNode.root) {\n this.contexts.length = this.contexts.length - 1;\n }\n }\n\n visitMedia(mediaNode, visitArgs) {\n mediaNode.allExtends = [];\n this.allExtendsStack.push(mediaNode.allExtends);\n }\n\n visitMediaOut(mediaNode) {\n this.allExtendsStack.length = this.allExtendsStack.length - 1;\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n atRuleNode.allExtends = [];\n this.allExtendsStack.push(atRuleNode.allExtends);\n }\n\n visitAtRuleOut(atRuleNode) {\n this.allExtendsStack.length = this.allExtendsStack.length - 1;\n }\n}\n\nclass ProcessExtendsVisitor {\n constructor() {\n this._visitor = new Visitor(this);\n }\n\n run(root) {\n const extendFinder = new ExtendFinderVisitor();\n this.extendIndices = {};\n extendFinder.run(root);\n if (!extendFinder.foundExtends) { return root; }\n root.allExtends = root.allExtends.concat(this.doExtendChaining(root.allExtends, root.allExtends));\n this.allExtendsStack = [root.allExtends];\n const newRoot = this._visitor.visit(root);\n this.checkExtendsForNonMatched(root.allExtends);\n return newRoot;\n }\n\n checkExtendsForNonMatched(extendList) {\n const indices = this.extendIndices;\n extendList.filter(extend => !extend.hasFoundMatches && extend.parent_ids.length == 1).forEach(extend => {\n let selector = '_unknown_';\n try {\n selector = extend.selector.toCSS({});\n }\n catch (_) {}\n\n if (!indices[`${extend.index} ${selector}`]) {\n indices[`${extend.index} ${selector}`] = true;\n logger.warn(`extend '${selector}' has no matches`);\n }\n });\n }\n\n doExtendChaining(extendsList, extendsListTarget, iterationCount) {\n //\n // chaining is different from normal extension.. if we extend an extend then we are not just copying, altering\n // and pasting the selector we would do normally, but we are also adding an extend with the same target selector\n // this means this new extend can then go and alter other extends\n //\n // this method deals with all the chaining work - without it, extend is flat and doesn't work on other extend selectors\n // this is also the most expensive.. and a match on one selector can cause an extension of a selector we had already\n // processed if we look at each selector at a time, as is done in visitRuleset\n\n let extendIndex;\n\n let targetExtendIndex;\n let matches;\n const extendsToAdd = [];\n let newSelector;\n const extendVisitor = this;\n let selectorPath;\n let extend;\n let targetExtend;\n let newExtend;\n\n iterationCount = iterationCount || 0;\n\n // loop through comparing every extend with every target extend.\n // a target extend is the one on the ruleset we are looking at copy/edit/pasting in place\n // e.g. .a:extend(.b) {} and .b:extend(.c) {} then the first extend extends the second one\n // and the second is the target.\n // the separation into two lists allows us to process a subset of chains with a bigger set, as is the\n // case when processing media queries\n for (extendIndex = 0; extendIndex < extendsList.length; extendIndex++) {\n for (targetExtendIndex = 0; targetExtendIndex < extendsListTarget.length; targetExtendIndex++) {\n\n extend = extendsList[extendIndex];\n targetExtend = extendsListTarget[targetExtendIndex];\n\n // look for circular references\n if ( extend.parent_ids.indexOf( targetExtend.object_id ) >= 0 ) { continue; }\n\n // find a match in the target extends self selector (the bit before :extend)\n selectorPath = [targetExtend.selfSelectors[0]];\n matches = extendVisitor.findMatch(extend, selectorPath);\n\n if (matches.length) {\n extend.hasFoundMatches = true;\n\n // we found a match, so for each self selector..\n extend.selfSelectors.forEach(selfSelector => {\n const info = targetExtend.visibilityInfo();\n\n // process the extend as usual\n newSelector = extendVisitor.extendSelector(matches, selectorPath, selfSelector, extend.isVisible());\n\n // but now we create a new extend from it\n newExtend = new(tree.Extend)(targetExtend.selector, targetExtend.option, 0, targetExtend.fileInfo(), info);\n newExtend.selfSelectors = newSelector;\n\n // add the extend onto the list of extends for that selector\n newSelector[newSelector.length - 1].extendList = [newExtend];\n\n // record that we need to add it.\n extendsToAdd.push(newExtend);\n newExtend.ruleset = targetExtend.ruleset;\n\n // remember its parents for circular references\n newExtend.parent_ids = newExtend.parent_ids.concat(targetExtend.parent_ids, extend.parent_ids);\n\n // only process the selector once.. if we have :extend(.a,.b) then multiple\n // extends will look at the same selector path, so when extending\n // we know that any others will be duplicates in terms of what is added to the css\n if (targetExtend.firstExtendOnThisSelectorPath) {\n newExtend.firstExtendOnThisSelectorPath = true;\n targetExtend.ruleset.paths.push(newSelector);\n }\n });\n }\n }\n }\n\n if (extendsToAdd.length) {\n // try to detect circular references to stop a stack overflow.\n // may no longer be needed.\n this.extendChainCount++;\n if (iterationCount > 100) {\n let selectorOne = '{unable to calculate}';\n let selectorTwo = '{unable to calculate}';\n try {\n selectorOne = extendsToAdd[0].selfSelectors[0].toCSS();\n selectorTwo = extendsToAdd[0].selector.toCSS();\n }\n catch (e) {}\n throw { message: `extend circular reference detected. One of the circular extends is currently:${selectorOne}:extend(${selectorTwo})`};\n }\n\n // now process the new extends on the existing rules so that we can handle a extending b extending c extending\n // d extending e...\n return extendsToAdd.concat(extendVisitor.doExtendChaining(extendsToAdd, extendsListTarget, iterationCount + 1));\n } else {\n return extendsToAdd;\n }\n }\n\n visitDeclaration(ruleNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitSelector(selectorNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n if (rulesetNode.root) {\n return;\n }\n let matches;\n let pathIndex;\n let extendIndex;\n const allExtends = this.allExtendsStack[this.allExtendsStack.length - 1];\n const selectorsToAdd = [];\n const extendVisitor = this;\n let selectorPath;\n\n // look at each selector path in the ruleset, find any extend matches and then copy, find and replace\n\n for (extendIndex = 0; extendIndex < allExtends.length; extendIndex++) {\n for (pathIndex = 0; pathIndex < rulesetNode.paths.length; pathIndex++) {\n selectorPath = rulesetNode.paths[pathIndex];\n\n // extending extends happens initially, before the main pass\n if (rulesetNode.extendOnEveryPath) { continue; }\n const extendList = selectorPath[selectorPath.length - 1].extendList;\n if (extendList && extendList.length) { continue; }\n\n matches = this.findMatch(allExtends[extendIndex], selectorPath);\n\n if (matches.length) {\n allExtends[extendIndex].hasFoundMatches = true;\n\n allExtends[extendIndex].selfSelectors.forEach(selfSelector => {\n let extendedSelectors;\n extendedSelectors = extendVisitor.extendSelector(matches, selectorPath, selfSelector, allExtends[extendIndex].isVisible());\n selectorsToAdd.push(extendedSelectors);\n });\n }\n }\n }\n rulesetNode.paths = rulesetNode.paths.concat(selectorsToAdd);\n }\n\n findMatch(extend, haystackSelectorPath) {\n //\n // look through the haystack selector path to try and find the needle - extend.selector\n // returns an array of selector matches that can then be replaced\n //\n let haystackSelectorIndex;\n\n let hackstackSelector;\n let hackstackElementIndex;\n let haystackElement;\n let targetCombinator;\n let i;\n const extendVisitor = this;\n const needleElements = extend.selector.elements;\n const potentialMatches = [];\n let potentialMatch;\n const matches = [];\n\n // loop through the haystack elements\n for (haystackSelectorIndex = 0; haystackSelectorIndex < haystackSelectorPath.length; haystackSelectorIndex++) {\n hackstackSelector = haystackSelectorPath[haystackSelectorIndex];\n\n for (hackstackElementIndex = 0; hackstackElementIndex < hackstackSelector.elements.length; hackstackElementIndex++) {\n\n haystackElement = hackstackSelector.elements[hackstackElementIndex];\n\n // if we allow elements before our match we can add a potential match every time. otherwise only at the first element.\n if (extend.allowBefore || (haystackSelectorIndex === 0 && hackstackElementIndex === 0)) {\n potentialMatches.push({pathIndex: haystackSelectorIndex, index: hackstackElementIndex, matched: 0,\n initialCombinator: haystackElement.combinator});\n }\n\n for (i = 0; i < potentialMatches.length; i++) {\n potentialMatch = potentialMatches[i];\n\n // selectors add \" \" onto the first element. When we use & it joins the selectors together, but if we don't\n // then each selector in haystackSelectorPath has a space before it added in the toCSS phase. so we need to\n // work out what the resulting combinator will be\n targetCombinator = haystackElement.combinator.value;\n if (targetCombinator === '' && hackstackElementIndex === 0) {\n targetCombinator = ' ';\n }\n\n // if we don't match, null our match to indicate failure\n if (!extendVisitor.isElementValuesEqual(needleElements[potentialMatch.matched].value, haystackElement.value) ||\n (potentialMatch.matched > 0 && needleElements[potentialMatch.matched].combinator.value !== targetCombinator)) {\n potentialMatch = null;\n } else {\n potentialMatch.matched++;\n }\n\n // if we are still valid and have finished, test whether we have elements after and whether these are allowed\n if (potentialMatch) {\n potentialMatch.finished = potentialMatch.matched === needleElements.length;\n if (potentialMatch.finished &&\n (!extend.allowAfter &&\n (hackstackElementIndex + 1 < hackstackSelector.elements.length || haystackSelectorIndex + 1 < haystackSelectorPath.length))) {\n potentialMatch = null;\n }\n }\n // if null we remove, if not, we are still valid, so either push as a valid match or continue\n if (potentialMatch) {\n if (potentialMatch.finished) {\n potentialMatch.length = needleElements.length;\n potentialMatch.endPathIndex = haystackSelectorIndex;\n potentialMatch.endPathElementIndex = hackstackElementIndex + 1; // index after end of match\n potentialMatches.length = 0; // we don't allow matches to overlap, so start matching again\n matches.push(potentialMatch);\n }\n } else {\n potentialMatches.splice(i, 1);\n i--;\n }\n }\n }\n }\n return matches;\n }\n\n isElementValuesEqual(elementValue1, elementValue2) {\n if (typeof elementValue1 === 'string' || typeof elementValue2 === 'string') {\n return elementValue1 === elementValue2;\n }\n if (elementValue1 instanceof tree.Attribute) {\n if (elementValue1.op !== elementValue2.op || elementValue1.key !== elementValue2.key) {\n return false;\n }\n if (!elementValue1.value || !elementValue2.value) {\n if (elementValue1.value || elementValue2.value) {\n return false;\n }\n return true;\n }\n elementValue1 = elementValue1.value.value || elementValue1.value;\n elementValue2 = elementValue2.value.value || elementValue2.value;\n return elementValue1 === elementValue2;\n }\n elementValue1 = elementValue1.value;\n elementValue2 = elementValue2.value;\n if (elementValue1 instanceof tree.Selector) {\n if (!(elementValue2 instanceof tree.Selector) || elementValue1.elements.length !== elementValue2.elements.length) {\n return false;\n }\n for (let i = 0; i < elementValue1.elements.length; i++) {\n if (elementValue1.elements[i].combinator.value !== elementValue2.elements[i].combinator.value) {\n if (i !== 0 || (elementValue1.elements[i].combinator.value || ' ') !== (elementValue2.elements[i].combinator.value || ' ')) {\n return false;\n }\n }\n if (!this.isElementValuesEqual(elementValue1.elements[i].value, elementValue2.elements[i].value)) {\n return false;\n }\n }\n return true;\n }\n return false;\n }\n\n extendSelector(matches, selectorPath, replacementSelector, isVisible) {\n // for a set of matches, replace each match with the replacement selector\n\n let currentSelectorPathIndex = 0;\n\n let currentSelectorPathElementIndex = 0;\n let path = [];\n let matchIndex;\n let selector;\n let firstElement;\n let match;\n let newElements;\n\n for (matchIndex = 0; matchIndex < matches.length; matchIndex++) {\n match = matches[matchIndex];\n selector = selectorPath[match.pathIndex];\n firstElement = new tree.Element(\n match.initialCombinator,\n replacementSelector.elements[0].value,\n replacementSelector.elements[0].isVariable,\n replacementSelector.elements[0].getIndex(),\n replacementSelector.elements[0].fileInfo()\n );\n\n if (match.pathIndex > currentSelectorPathIndex && currentSelectorPathElementIndex > 0) {\n path[path.length - 1].elements = path[path.length - 1]\n .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex));\n currentSelectorPathElementIndex = 0;\n currentSelectorPathIndex++;\n }\n\n newElements = selector.elements\n .slice(currentSelectorPathElementIndex, match.index)\n .concat([firstElement])\n .concat(replacementSelector.elements.slice(1));\n\n if (currentSelectorPathIndex === match.pathIndex && matchIndex > 0) {\n path[path.length - 1].elements =\n path[path.length - 1].elements.concat(newElements);\n } else {\n path = path.concat(selectorPath.slice(currentSelectorPathIndex, match.pathIndex));\n\n path.push(new tree.Selector(\n newElements\n ));\n }\n currentSelectorPathIndex = match.endPathIndex;\n currentSelectorPathElementIndex = match.endPathElementIndex;\n if (currentSelectorPathElementIndex >= selectorPath[currentSelectorPathIndex].elements.length) {\n currentSelectorPathElementIndex = 0;\n currentSelectorPathIndex++;\n }\n }\n\n if (currentSelectorPathIndex < selectorPath.length && currentSelectorPathElementIndex > 0) {\n path[path.length - 1].elements = path[path.length - 1]\n .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex));\n currentSelectorPathIndex++;\n }\n\n path = path.concat(selectorPath.slice(currentSelectorPathIndex, selectorPath.length));\n path = path.map(currentValue => {\n // we can re-use elements here, because the visibility property matters only for selectors\n const derived = currentValue.createDerived(currentValue.elements);\n if (isVisible) {\n derived.ensureVisibility();\n } else {\n derived.ensureInvisibility();\n }\n return derived;\n });\n return path;\n }\n\n visitMedia(mediaNode, visitArgs) {\n let newAllExtends = mediaNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]);\n newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, mediaNode.allExtends));\n this.allExtendsStack.push(newAllExtends);\n }\n\n visitMediaOut(mediaNode) {\n const lastIndex = this.allExtendsStack.length - 1;\n this.allExtendsStack.length = lastIndex;\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n let newAllExtends = atRuleNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]);\n newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, atRuleNode.allExtends));\n this.allExtendsStack.push(newAllExtends);\n }\n\n visitAtRuleOut(atRuleNode) {\n const lastIndex = this.allExtendsStack.length - 1;\n this.allExtendsStack.length = lastIndex;\n }\n}\n\nexport default ProcessExtendsVisitor;\n","import Visitor from './visitor';\n\nclass JoinSelectorVisitor {\n constructor() {\n this.contexts = [[]];\n this._visitor = new Visitor(this);\n }\n\n run(root) {\n return this._visitor.visit(root);\n }\n\n visitDeclaration(declNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n const paths = [];\n let selectors;\n\n this.contexts.push(paths);\n\n if (!rulesetNode.root) {\n selectors = rulesetNode.selectors;\n if (selectors) {\n selectors = selectors.filter(selector => selector.getIsOutput());\n rulesetNode.selectors = selectors.length ? selectors : (selectors = null);\n if (selectors) { rulesetNode.joinSelectors(paths, context, selectors); }\n }\n if (!selectors) { rulesetNode.rules = null; }\n rulesetNode.paths = paths;\n }\n }\n\n visitRulesetOut(rulesetNode) {\n this.contexts.length = this.contexts.length - 1;\n }\n\n visitMedia(mediaNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n mediaNode.rules[0].root = (context.length === 0 || context[0].multiMedia);\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n if (atRuleNode.rules && atRuleNode.rules.length) {\n atRuleNode.rules[0].root = (atRuleNode.isRooted || context.length === 0 || null);\n }\n }\n}\n\nexport default JoinSelectorVisitor;\n","import tree from '../tree';\nimport Visitor from './visitor';\n\nclass CSSVisitorUtils {\n constructor(context) {\n this._visitor = new Visitor(this);\n this._context = context;\n }\n\n containsSilentNonBlockedChild(bodyRules) {\n let rule;\n if (!bodyRules) {\n return false;\n }\n for (let r = 0; r < bodyRules.length; r++) {\n rule = bodyRules[r];\n if (rule.isSilent && rule.isSilent(this._context) && !rule.blocksVisibility()) {\n // the atrule contains something that was referenced (likely by extend)\n // therefore it needs to be shown in output too\n return true;\n }\n }\n return false;\n }\n\n keepOnlyVisibleChilds(owner) {\n if (owner && owner.rules) {\n owner.rules = owner.rules.filter(thing => thing.isVisible());\n }\n }\n\n isEmpty(owner) {\n return (owner && owner.rules) \n ? (owner.rules.length === 0) : true;\n }\n\n hasVisibleSelector(rulesetNode) {\n return (rulesetNode && rulesetNode.paths)\n ? (rulesetNode.paths.length > 0) : false;\n }\n\n resolveVisibility(node, originalRules) {\n if (!node.blocksVisibility()) {\n if (this.isEmpty(node) && !this.containsSilentNonBlockedChild(originalRules)) {\n return ;\n }\n\n return node;\n }\n\n const compiledRulesBody = node.rules[0];\n this.keepOnlyVisibleChilds(compiledRulesBody);\n\n if (this.isEmpty(compiledRulesBody)) {\n return ;\n }\n\n node.ensureVisibility();\n node.removeVisibilityBlock();\n\n return node;\n }\n\n isVisibleRuleset(rulesetNode) {\n if (rulesetNode.firstRoot) {\n return true;\n }\n\n if (this.isEmpty(rulesetNode)) {\n return false;\n }\n\n if (!rulesetNode.root && !this.hasVisibleSelector(rulesetNode)) {\n return false;\n }\n\n return true;\n }\n}\n\nconst ToCSSVisitor = function(context) {\n this._visitor = new Visitor(this);\n this._context = context;\n this.utils = new CSSVisitorUtils(context);\n};\n\nToCSSVisitor.prototype = {\n isReplacing: true,\n run: function (root) {\n return this._visitor.visit(root);\n },\n\n visitDeclaration: function (declNode, visitArgs) {\n if (declNode.blocksVisibility() || declNode.variable) {\n return;\n }\n return declNode;\n },\n\n visitMixinDefinition: function (mixinNode, visitArgs) {\n // mixin definitions do not get eval'd - this means they keep state\n // so we have to clear that state here so it isn't used if toCSS is called twice\n mixinNode.frames = [];\n },\n\n visitExtend: function (extendNode, visitArgs) {\n },\n\n visitComment: function (commentNode, visitArgs) {\n if (commentNode.blocksVisibility() || commentNode.isSilent(this._context)) {\n return;\n }\n return commentNode;\n },\n\n visitMedia: function(mediaNode, visitArgs) {\n const originalRules = mediaNode.rules[0].rules;\n mediaNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n\n return this.utils.resolveVisibility(mediaNode, originalRules);\n },\n\n visitImport: function (importNode, visitArgs) {\n if (importNode.blocksVisibility()) {\n return ;\n }\n return importNode;\n },\n\n visitAtRule: function(atRuleNode, visitArgs) {\n if (atRuleNode.rules && atRuleNode.rules.length) {\n return this.visitAtRuleWithBody(atRuleNode, visitArgs);\n } else {\n return this.visitAtRuleWithoutBody(atRuleNode, visitArgs);\n }\n },\n\n visitAnonymous: function(anonymousNode, visitArgs) {\n if (!anonymousNode.blocksVisibility()) {\n anonymousNode.accept(this._visitor);\n return anonymousNode;\n }\n },\n\n visitAtRuleWithBody: function(atRuleNode, visitArgs) {\n // if there is only one nested ruleset and that one has no path, then it is\n // just fake ruleset\n function hasFakeRuleset(atRuleNode) {\n const bodyRules = atRuleNode.rules;\n return bodyRules.length === 1 && (!bodyRules[0].paths || bodyRules[0].paths.length === 0);\n }\n function getBodyRules(atRuleNode) {\n const nodeRules = atRuleNode.rules;\n if (hasFakeRuleset(atRuleNode)) {\n return nodeRules[0].rules;\n }\n\n return nodeRules;\n }\n // it is still true that it is only one ruleset in array\n // this is last such moment\n // process childs\n const originalRules = getBodyRules(atRuleNode);\n atRuleNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n\n if (!this.utils.isEmpty(atRuleNode)) {\n this._mergeRules(atRuleNode.rules[0].rules);\n }\n\n return this.utils.resolveVisibility(atRuleNode, originalRules);\n },\n\n visitAtRuleWithoutBody: function(atRuleNode, visitArgs) {\n if (atRuleNode.blocksVisibility()) {\n return;\n }\n\n if (atRuleNode.name === '@charset') {\n // Only output the debug info together with subsequent @charset definitions\n // a comment (or @media statement) before the actual @charset atrule would\n // be considered illegal css as it has to be on the first line\n if (this.charset) {\n if (atRuleNode.debugInfo) {\n const comment = new tree.Comment(`/* ${atRuleNode.toCSS(this._context).replace(/\\n/g, '')} */\\n`);\n comment.debugInfo = atRuleNode.debugInfo;\n return this._visitor.visit(comment);\n }\n return;\n }\n this.charset = true;\n }\n\n return atRuleNode;\n },\n\n checkValidNodes: function(rules, isRoot) {\n if (!rules) {\n return;\n }\n\n for (let i = 0; i < rules.length; i++) {\n const ruleNode = rules[i];\n if (isRoot && ruleNode instanceof tree.Declaration && !ruleNode.variable) {\n throw { message: 'Properties must be inside selector blocks. They cannot be in the root',\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n if (ruleNode instanceof tree.Call) {\n throw { message: `Function '${ruleNode.name}' is undefined`,\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n if (ruleNode.type && !ruleNode.allowRoot) {\n throw { message: `${ruleNode.type} node returned by a function is not valid here`,\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n }\n },\n\n visitRuleset: function (rulesetNode, visitArgs) {\n // at this point rulesets are nested into each other\n let rule;\n\n const rulesets = [];\n\n this.checkValidNodes(rulesetNode.rules, rulesetNode.firstRoot);\n\n if (!rulesetNode.root) {\n // remove invisible paths\n this._compileRulesetPaths(rulesetNode);\n\n // remove rulesets from this ruleset body and compile them separately\n const nodeRules = rulesetNode.rules;\n\n let nodeRuleCnt = nodeRules ? nodeRules.length : 0;\n for (let i = 0; i < nodeRuleCnt; ) {\n rule = nodeRules[i];\n if (rule && rule.rules) {\n // visit because we are moving them out from being a child\n rulesets.push(this._visitor.visit(rule));\n nodeRules.splice(i, 1);\n nodeRuleCnt--;\n continue;\n }\n i++;\n }\n // accept the visitor to remove rules and refactor itself\n // then we can decide nogw whether we want it or not\n // compile body\n if (nodeRuleCnt > 0) {\n rulesetNode.accept(this._visitor);\n } else {\n rulesetNode.rules = null;\n }\n visitArgs.visitDeeper = false;\n } else { // if (! rulesetNode.root) {\n rulesetNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n }\n\n if (rulesetNode.rules) {\n this._mergeRules(rulesetNode.rules);\n this._removeDuplicateRules(rulesetNode.rules);\n }\n\n // now decide whether we keep the ruleset\n if (this.utils.isVisibleRuleset(rulesetNode)) {\n rulesetNode.ensureVisibility();\n rulesets.splice(0, 0, rulesetNode);\n }\n\n if (rulesets.length === 1) {\n return rulesets[0];\n }\n return rulesets;\n },\n\n _compileRulesetPaths: function(rulesetNode) {\n if (rulesetNode.paths) {\n rulesetNode.paths = rulesetNode.paths\n .filter(p => {\n let i;\n if (p[0].elements[0].combinator.value === ' ') {\n p[0].elements[0].combinator = new(tree.Combinator)('');\n }\n for (i = 0; i < p.length; i++) {\n if (p[i].isVisible() && p[i].getIsOutput()) {\n return true;\n }\n }\n return false;\n });\n }\n },\n\n _removeDuplicateRules: function(rules) {\n if (!rules) { return; }\n\n // remove duplicates\n const ruleCache = {};\n\n let ruleList;\n let rule;\n let i;\n\n for (i = rules.length - 1; i >= 0 ; i--) {\n rule = rules[i];\n if (rule instanceof tree.Declaration) {\n if (!ruleCache[rule.name]) {\n ruleCache[rule.name] = rule;\n } else {\n ruleList = ruleCache[rule.name];\n if (ruleList instanceof tree.Declaration) {\n ruleList = ruleCache[rule.name] = [ruleCache[rule.name].toCSS(this._context)];\n }\n const ruleCSS = rule.toCSS(this._context);\n if (ruleList.indexOf(ruleCSS) !== -1) {\n rules.splice(i, 1);\n } else {\n ruleList.push(ruleCSS);\n }\n }\n }\n }\n },\n\n _mergeRules: function(rules) {\n if (!rules) {\n return; \n }\n\n const groups = {};\n const groupsArr = [];\n\n for (let i = 0; i < rules.length; i++) {\n const rule = rules[i];\n if (rule.merge) {\n const key = rule.name;\n groups[key] ? rules.splice(i--, 1) : \n groupsArr.push(groups[key] = []);\n groups[key].push(rule);\n }\n }\n\n groupsArr.forEach(group => {\n if (group.length > 0) {\n const result = group[0];\n let space = [];\n const comma = [new tree.Expression(space)];\n group.forEach(rule => {\n if ((rule.merge === '+') && (space.length > 0)) {\n comma.push(new tree.Expression(space = []));\n }\n space.push(rule.value);\n result.important = result.important || rule.important;\n });\n result.value = new tree.Value(comma);\n }\n });\n }\n};\n\nexport default ToCSSVisitor;\n","import Visitor from './visitor';\nimport ImportVisitor from './import-visitor';\nimport MarkVisibleSelectorsVisitor from './set-tree-visibility-visitor';\nimport ExtendVisitor from './extend-visitor';\nimport JoinSelectorVisitor from './join-selector-visitor';\nimport ToCSSVisitor from './to-css-visitor';\n\nexport default {\n Visitor,\n ImportVisitor,\n MarkVisibleSelectorsVisitor,\n ExtendVisitor,\n JoinSelectorVisitor,\n ToCSSVisitor\n};\n","import chunker from './chunker';\n\nexport default () => {\n let // Less input string\n input;\n\n let // current chunk\n j;\n\n const // holds state for backtracking\n saveStack = [];\n\n let // furthest index the parser has gone to\n furthest;\n\n let // if this is furthest we got to, this is the probably cause\n furthestPossibleErrorMessage;\n\n let // chunkified input\n chunks;\n\n let // current chunk\n current;\n\n let // index of current chunk, in `input`\n currentPos;\n\n const parserInput = {};\n const CHARCODE_SPACE = 32;\n const CHARCODE_TAB = 9;\n const CHARCODE_LF = 10;\n const CHARCODE_CR = 13;\n const CHARCODE_PLUS = 43;\n const CHARCODE_COMMA = 44;\n const CHARCODE_FORWARD_SLASH = 47;\n const CHARCODE_9 = 57;\n\n function skipWhitespace(length) {\n const oldi = parserInput.i;\n const oldj = j;\n const curr = parserInput.i - currentPos;\n const endIndex = parserInput.i + current.length - curr;\n const mem = (parserInput.i += length);\n const inp = input;\n let c;\n let nextChar;\n let comment;\n\n for (; parserInput.i < endIndex; parserInput.i++) {\n c = inp.charCodeAt(parserInput.i);\n\n if (parserInput.autoCommentAbsorb && c === CHARCODE_FORWARD_SLASH) {\n nextChar = inp.charAt(parserInput.i + 1);\n if (nextChar === '/') {\n comment = {index: parserInput.i, isLineComment: true};\n let nextNewLine = inp.indexOf('\\n', parserInput.i + 2);\n if (nextNewLine < 0) {\n nextNewLine = endIndex;\n }\n parserInput.i = nextNewLine;\n comment.text = inp.substr(comment.index, parserInput.i - comment.index);\n parserInput.commentStore.push(comment);\n continue;\n } else if (nextChar === '*') {\n const nextStarSlash = inp.indexOf('*/', parserInput.i + 2);\n if (nextStarSlash >= 0) {\n comment = {\n index: parserInput.i,\n text: inp.substr(parserInput.i, nextStarSlash + 2 - parserInput.i),\n isLineComment: false\n };\n parserInput.i += comment.text.length - 1;\n parserInput.commentStore.push(comment);\n continue;\n }\n }\n break;\n }\n\n if ((c !== CHARCODE_SPACE) && (c !== CHARCODE_LF) && (c !== CHARCODE_TAB) && (c !== CHARCODE_CR)) {\n break;\n }\n }\n\n current = current.slice(length + parserInput.i - mem + curr);\n currentPos = parserInput.i;\n\n if (!current.length) {\n if (j < chunks.length - 1) {\n current = chunks[++j];\n skipWhitespace(0); // skip space at the beginning of a chunk\n return true; // things changed\n }\n parserInput.finished = true;\n }\n\n return oldi !== parserInput.i || oldj !== j;\n }\n\n parserInput.save = () => {\n currentPos = parserInput.i;\n saveStack.push( { current, i: parserInput.i, j });\n };\n parserInput.restore = possibleErrorMessage => {\n\n if (parserInput.i > furthest || (parserInput.i === furthest && possibleErrorMessage && !furthestPossibleErrorMessage)) {\n furthest = parserInput.i;\n furthestPossibleErrorMessage = possibleErrorMessage;\n }\n const state = saveStack.pop();\n current = state.current;\n currentPos = parserInput.i = state.i;\n j = state.j;\n };\n parserInput.forget = () => {\n saveStack.pop();\n };\n parserInput.isWhitespace = offset => {\n const pos = parserInput.i + (offset || 0);\n const code = input.charCodeAt(pos);\n return (code === CHARCODE_SPACE || code === CHARCODE_CR || code === CHARCODE_TAB || code === CHARCODE_LF);\n };\n\n // Specialization of $(tok)\n parserInput.$re = tok => {\n if (parserInput.i > currentPos) {\n current = current.slice(parserInput.i - currentPos);\n currentPos = parserInput.i;\n }\n\n const m = tok.exec(current);\n if (!m) {\n return null;\n }\n\n skipWhitespace(m[0].length);\n if (typeof m === 'string') {\n return m;\n }\n\n return m.length === 1 ? m[0] : m;\n };\n\n parserInput.$char = tok => {\n if (input.charAt(parserInput.i) !== tok) {\n return null;\n }\n skipWhitespace(1);\n return tok;\n };\n\n parserInput.$str = tok => {\n const tokLength = tok.length;\n\n // https://jsperf.com/string-startswith/21\n for (let i = 0; i < tokLength; i++) {\n if (input.charAt(parserInput.i + i) !== tok.charAt(i)) {\n return null;\n }\n }\n\n skipWhitespace(tokLength);\n return tok;\n };\n\n parserInput.$quoted = loc => {\n const pos = loc || parserInput.i;\n const startChar = input.charAt(pos);\n\n if (startChar !== '\\'' && startChar !== '\"') {\n return;\n }\n const length = input.length;\n const currentPosition = pos;\n\n for (let i = 1; i + currentPosition < length; i++) {\n const nextChar = input.charAt(i + currentPosition);\n switch (nextChar) {\n case '\\\\':\n i++;\n continue;\n case '\\r':\n case '\\n':\n break;\n case startChar:\n const str = input.substr(currentPosition, i + 1);\n if (!loc && loc !== 0) {\n skipWhitespace(i + 1);\n return str\n }\n return [startChar, str];\n default:\n }\n }\n return null;\n };\n\n /**\n * Permissive parsing. Ignores everything except matching {} [] () and quotes\n * until matching token (outside of blocks)\n */\n parserInput.$parseUntil = tok => {\n let quote = '';\n let returnVal = null;\n let inComment = false;\n let blockDepth = 0;\n const blockStack = [];\n const parseGroups = [];\n const length = input.length;\n const startPos = parserInput.i;\n let lastPos = parserInput.i;\n let i = parserInput.i;\n let loop = true;\n let testChar;\n\n if (typeof tok === 'string') {\n testChar = char => char === tok\n } else {\n testChar = char => tok.test(char)\n }\n\n do {\n let prevChar;\n let nextChar = input.charAt(i);\n if (blockDepth === 0 && testChar(nextChar)) {\n returnVal = input.substr(lastPos, i - lastPos);\n if (returnVal) {\n parseGroups.push(returnVal);\n }\n else {\n parseGroups.push(' ');\n }\n returnVal = parseGroups;\n skipWhitespace(i - startPos);\n loop = false\n } else {\n if (inComment) {\n if (nextChar === '*' && \n input.charAt(i + 1) === '/') {\n i++;\n blockDepth--;\n inComment = false;\n }\n i++;\n continue;\n }\n switch (nextChar) {\n case '\\\\':\n i++;\n nextChar = input.charAt(i);\n parseGroups.push(input.substr(lastPos, i - lastPos + 1));\n lastPos = i + 1;\n break;\n case '/':\n if (input.charAt(i + 1) === '*') {\n i++;\n inComment = true;\n blockDepth++;\n }\n break;\n case '\\'':\n case '\"':\n quote = parserInput.$quoted(i);\n if (quote) {\n parseGroups.push(input.substr(lastPos, i - lastPos), quote);\n i += quote[1].length - 1;\n lastPos = i + 1;\n }\n else {\n skipWhitespace(i - startPos);\n returnVal = nextChar;\n loop = false;\n }\n break;\n case '{':\n blockStack.push('}');\n blockDepth++;\n break;\n case '(':\n blockStack.push(')');\n blockDepth++;\n break;\n case '[':\n blockStack.push(']');\n blockDepth++;\n break;\n case '}':\n case ')':\n case ']':\n const expected = blockStack.pop();\n if (nextChar === expected) {\n blockDepth--;\n } else {\n // move the parser to the error and return expected\n skipWhitespace(i - startPos);\n returnVal = expected;\n loop = false;\n }\n }\n i++;\n if (i > length) {\n loop = false;\n }\n }\n prevChar = nextChar;\n } while (loop);\n\n return returnVal ? returnVal : null;\n }\n\n parserInput.autoCommentAbsorb = true;\n parserInput.commentStore = [];\n parserInput.finished = false;\n\n // Same as $(), but don't change the state of the parser,\n // just return the match.\n parserInput.peek = tok => {\n if (typeof tok === 'string') {\n // https://jsperf.com/string-startswith/21\n for (let i = 0; i < tok.length; i++) {\n if (input.charAt(parserInput.i + i) !== tok.charAt(i)) {\n return false;\n }\n }\n return true;\n } else {\n return tok.test(current);\n }\n };\n\n // Specialization of peek()\n // TODO remove or change some currentChar calls to peekChar\n parserInput.peekChar = tok => input.charAt(parserInput.i) === tok;\n\n parserInput.currentChar = () => input.charAt(parserInput.i);\n\n parserInput.prevChar = () => input.charAt(parserInput.i - 1);\n\n parserInput.getInput = () => input;\n\n parserInput.peekNotNumeric = () => {\n const c = input.charCodeAt(parserInput.i);\n // Is the first char of the dimension 0-9, '.', '+' or '-'\n return (c > CHARCODE_9 || c < CHARCODE_PLUS) || c === CHARCODE_FORWARD_SLASH || c === CHARCODE_COMMA;\n };\n\n parserInput.start = (str, chunkInput, failFunction) => {\n input = str;\n parserInput.i = j = currentPos = furthest = 0;\n\n // chunking apparently makes things quicker (but my tests indicate\n // it might actually make things slower in node at least)\n // and it is a non-perfect parse - it can't recognise\n // unquoted urls, meaning it can't distinguish comments\n // meaning comments with quotes or {}() in them get 'counted'\n // and then lead to parse errors.\n // In addition if the chunking chunks in the wrong place we might\n // not be able to parse a parser statement in one go\n // this is officially deprecated but can be switched on via an option\n // in the case it causes too much performance issues.\n if (chunkInput) {\n chunks = chunker(str, failFunction);\n } else {\n chunks = [str];\n }\n\n current = chunks[0];\n\n skipWhitespace(0);\n };\n\n parserInput.end = () => {\n let message;\n const isFinished = parserInput.i >= input.length;\n\n if (parserInput.i < furthest) {\n message = furthestPossibleErrorMessage;\n parserInput.i = furthest;\n }\n return {\n isFinished,\n furthest: parserInput.i,\n furthestPossibleErrorMessage: message,\n furthestReachedEnd: parserInput.i >= input.length - 1,\n furthestChar: input[parserInput.i]\n };\n };\n\n return parserInput;\n};\n","// Split the input into chunks.\nexport default (input, fail) => {\n const len = input.length;\n let level = 0;\n let parenLevel = 0;\n let lastOpening;\n let lastOpeningParen;\n let lastMultiComment;\n let lastMultiCommentEndBrace;\n const chunks = [];\n let emitFrom = 0;\n let chunkerCurrentIndex;\n let currentChunkStartIndex;\n let cc;\n let cc2;\n let matched;\n\n function emitChunk(force) {\n const len = chunkerCurrentIndex - emitFrom;\n if (((len < 512) && !force) || !len) {\n return;\n }\n chunks.push(input.slice(emitFrom, chunkerCurrentIndex + 1));\n emitFrom = chunkerCurrentIndex + 1;\n }\n\n for (chunkerCurrentIndex = 0; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc = input.charCodeAt(chunkerCurrentIndex);\n if (((cc >= 97) && (cc <= 122)) || (cc < 34)) {\n // a-z or whitespace\n continue;\n }\n\n switch (cc) {\n case 40: // (\n parenLevel++;\n lastOpeningParen = chunkerCurrentIndex;\n continue;\n case 41: // )\n if (--parenLevel < 0) {\n return fail('missing opening `(`', chunkerCurrentIndex);\n }\n continue;\n case 59: // ;\n if (!parenLevel) { emitChunk(); }\n continue;\n case 123: // {\n level++;\n lastOpening = chunkerCurrentIndex;\n continue;\n case 125: // }\n if (--level < 0) {\n return fail('missing opening `{`', chunkerCurrentIndex);\n }\n if (!level && !parenLevel) { emitChunk(); }\n continue;\n case 92: // \\\n if (chunkerCurrentIndex < len - 1) { chunkerCurrentIndex++; continue; }\n return fail('unescaped `\\\\`', chunkerCurrentIndex);\n case 34:\n case 39:\n case 96: // \", ' and `\n matched = 0;\n currentChunkStartIndex = chunkerCurrentIndex;\n for (chunkerCurrentIndex = chunkerCurrentIndex + 1; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if (cc2 > 96) { continue; }\n if (cc2 == cc) { matched = 1; break; }\n if (cc2 == 92) { // \\\n if (chunkerCurrentIndex == len - 1) {\n return fail('unescaped `\\\\`', chunkerCurrentIndex);\n }\n chunkerCurrentIndex++;\n }\n }\n if (matched) { continue; }\n return fail(`unmatched \\`${String.fromCharCode(cc)}\\``, currentChunkStartIndex);\n case 47: // /, check for comment\n if (parenLevel || (chunkerCurrentIndex == len - 1)) { continue; }\n cc2 = input.charCodeAt(chunkerCurrentIndex + 1);\n if (cc2 == 47) {\n // //, find lnfeed\n for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if ((cc2 <= 13) && ((cc2 == 10) || (cc2 == 13))) { break; }\n }\n } else if (cc2 == 42) {\n // /*, find */\n lastMultiComment = currentChunkStartIndex = chunkerCurrentIndex;\n for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len - 1; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if (cc2 == 125) { lastMultiCommentEndBrace = chunkerCurrentIndex; }\n if (cc2 != 42) { continue; }\n if (input.charCodeAt(chunkerCurrentIndex + 1) == 47) { break; }\n }\n if (chunkerCurrentIndex == len - 1) {\n return fail('missing closing `*/`', currentChunkStartIndex);\n }\n chunkerCurrentIndex++;\n }\n continue;\n case 42: // *, check for unmatched */\n if ((chunkerCurrentIndex < len - 1) && (input.charCodeAt(chunkerCurrentIndex + 1) == 47)) {\n return fail('unmatched `/*`', chunkerCurrentIndex);\n }\n continue;\n }\n }\n\n if (level !== 0) {\n if ((lastMultiComment > lastOpening) && (lastMultiCommentEndBrace > lastMultiComment)) {\n return fail('missing closing `}` or `*/`', lastOpening);\n } else {\n return fail('missing closing `}`', lastOpening);\n }\n } else if (parenLevel !== 0) {\n return fail('missing closing `)`', lastOpeningParen);\n }\n\n emitChunk(true);\n return chunks;\n};\n","import LessError from '../less-error';\nimport tree from '../tree';\nimport visitors from '../visitors';\nimport getParserInput from './parser-input';\nimport * as utils from '../utils';\nimport functionRegistry from '../functions/function-registry';\n\n//\n// less.js - parser\n//\n// A relatively straight-forward predictive parser.\n// There is no tokenization/lexing stage, the input is parsed\n// in one sweep.\n//\n// To make the parser fast enough to run in the browser, several\n// optimization had to be made:\n//\n// - Matching and slicing on a huge input is often cause of slowdowns.\n// The solution is to chunkify the input into smaller strings.\n// The chunks are stored in the `chunks` var,\n// `j` holds the current chunk index, and `currentPos` holds\n// the index of the current chunk in relation to `input`.\n// This gives us an almost 4x speed-up.\n//\n// - In many cases, we don't need to match individual tokens;\n// for example, if a value doesn't hold any variables, operations\n// or dynamic references, the parser can effectively 'skip' it,\n// treating it as a literal.\n// An example would be '1px solid #000' - which evaluates to itself,\n// we don't need to know what the individual components are.\n// The drawback, of course is that you don't get the benefits of\n// syntax-checking on the CSS. This gives us a 50% speed-up in the parser,\n// and a smaller speed-up in the code-gen.\n//\n//\n// Token matching is done with the `$` function, which either takes\n// a terminal string or regexp, or a non-terminal function to call.\n// It also takes care of moving all the indices forwards.\n//\n\nconst Parser = function Parser(context, imports, fileInfo) {\n let parsers;\n const parserInput = getParserInput();\n\n function error(msg, type) {\n throw new LessError(\n {\n index: parserInput.i,\n filename: fileInfo.filename,\n type: type || 'Syntax',\n message: msg\n },\n imports\n );\n }\n\n function expect(arg, msg) {\n // some older browsers return typeof 'function' for RegExp\n const result = (arg instanceof Function) ? arg.call(parsers) : parserInput.$re(arg);\n if (result) {\n return result;\n }\n \n error(msg || (typeof arg === 'string'\n ? `expected '${arg}' got '${parserInput.currentChar()}'`\n : 'unexpected token'));\n }\n\n // Specialization of expect()\n function expectChar(arg, msg) {\n if (parserInput.$char(arg)) {\n return arg;\n }\n error(msg || `expected '${arg}' got '${parserInput.currentChar()}'`);\n }\n\n function getDebugInfo(index) {\n const filename = fileInfo.filename;\n\n return {\n lineNumber: utils.getLocation(index, parserInput.getInput()).line + 1,\n fileName: filename\n };\n }\n\n /**\n * Used after initial parsing to create nodes on the fly\n * \n * @param {String} str - string to parse \n * @param {Array} parseList - array of parsers to run input through e.g. [\"value\", \"important\"]\n * @param {Number} currentIndex - start number to begin indexing\n * @param {Object} fileInfo - fileInfo to attach to created nodes\n */\n function parseNode(str, parseList, currentIndex, fileInfo, callback) {\n let result;\n const returnNodes = [];\n const parser = parserInput;\n\n try {\n parser.start(str, false, function fail(msg, index) {\n callback({\n message: msg,\n index: index + currentIndex\n });\n });\n for (let x = 0, p, i; (p = parseList[x]); x++) {\n i = parser.i;\n result = parsers[p]();\n if (result) {\n try {\n result._index = i + currentIndex;\n result._fileInfo = fileInfo;\n } catch (e) {}\n returnNodes.push(result);\n }\n else {\n returnNodes.push(null);\n }\n }\n\n const endInfo = parser.end();\n if (endInfo.isFinished) {\n callback(null, returnNodes);\n }\n else {\n callback(true, null);\n }\n } catch (e) {\n throw new LessError({\n index: e.index + currentIndex,\n message: e.message\n }, imports, fileInfo.filename);\n }\n }\n\n //\n // The Parser\n //\n return {\n parserInput,\n imports,\n fileInfo,\n parseNode,\n //\n // Parse an input string into an abstract syntax tree,\n // @param str A string containing 'less' markup\n // @param callback call `callback` when done.\n // @param [additionalData] An optional map which can contains vars - a map (key, value) of variables to apply\n //\n parse: function (str, callback, additionalData) {\n let root;\n let error = null;\n let globalVars;\n let modifyVars;\n let ignored;\n let preText = '';\n\n globalVars = (additionalData && additionalData.globalVars) ? `${Parser.serializeVars(additionalData.globalVars)}\\n` : '';\n modifyVars = (additionalData && additionalData.modifyVars) ? `\\n${Parser.serializeVars(additionalData.modifyVars)}` : '';\n\n if (context.pluginManager) {\n const preProcessors = context.pluginManager.getPreProcessors();\n for (let i = 0; i < preProcessors.length; i++) {\n str = preProcessors[i].process(str, { context, imports, fileInfo });\n }\n }\n\n if (globalVars || (additionalData && additionalData.banner)) {\n preText = ((additionalData && additionalData.banner) ? additionalData.banner : '') + globalVars;\n ignored = imports.contentsIgnoredChars;\n ignored[fileInfo.filename] = ignored[fileInfo.filename] || 0;\n ignored[fileInfo.filename] += preText.length;\n }\n\n str = str.replace(/\\r\\n?/g, '\\n');\n // Remove potential UTF Byte Order Mark\n str = preText + str.replace(/^\\uFEFF/, '') + modifyVars;\n imports.contents[fileInfo.filename] = str;\n\n // Start with the primary rule.\n // The whole syntax tree is held under a Ruleset node,\n // with the `root` property set to true, so no `{}` are\n // output. The callback is called when the input is parsed.\n try {\n parserInput.start(str, context.chunkInput, function fail(msg, index) {\n throw new LessError({\n index,\n type: 'Parse',\n message: msg,\n filename: fileInfo.filename\n }, imports);\n });\n\n tree.Node.prototype.parse = this;\n root = new tree.Ruleset(null, this.parsers.primary());\n tree.Node.prototype.rootNode = root;\n root.root = true;\n root.firstRoot = true;\n root.functionRegistry = functionRegistry.inherit();\n \n } catch (e) {\n return callback(new LessError(e, imports, fileInfo.filename));\n }\n\n // If `i` is smaller than the `input.length - 1`,\n // it means the parser wasn't able to parse the whole\n // string, so we've got a parsing error.\n //\n // We try to extract a \\n delimited string,\n // showing the line where the parse error occurred.\n // We split it up into two parts (the part which parsed,\n // and the part which didn't), so we can color them differently.\n const endInfo = parserInput.end();\n if (!endInfo.isFinished) {\n\n let message = endInfo.furthestPossibleErrorMessage;\n\n if (!message) {\n message = 'Unrecognised input';\n if (endInfo.furthestChar === '}') {\n message += '. Possibly missing opening \\'{\\'';\n } else if (endInfo.furthestChar === ')') {\n message += '. Possibly missing opening \\'(\\'';\n } else if (endInfo.furthestReachedEnd) {\n message += '. Possibly missing something';\n }\n }\n\n error = new LessError({\n type: 'Parse',\n message,\n index: endInfo.furthest,\n filename: fileInfo.filename\n }, imports);\n }\n\n const finish = e => {\n e = error || e || imports.error;\n\n if (e) {\n if (!(e instanceof LessError)) {\n e = new LessError(e, imports, fileInfo.filename);\n }\n\n return callback(e);\n }\n else {\n return callback(null, root);\n }\n };\n\n if (context.processImports !== false) {\n new visitors.ImportVisitor(imports, finish)\n .run(root);\n } else {\n return finish();\n }\n },\n\n //\n // Here in, the parsing rules/functions\n //\n // The basic structure of the syntax tree generated is as follows:\n //\n // Ruleset -> Declaration -> Value -> Expression -> Entity\n //\n // Here's some Less code:\n //\n // .class {\n // color: #fff;\n // border: 1px solid #000;\n // width: @w + 4px;\n // > .child {...}\n // }\n //\n // And here's what the parse tree might look like:\n //\n // Ruleset (Selector '.class', [\n // Declaration (\"color\", Value ([Expression [Color #fff]]))\n // Declaration (\"border\", Value ([Expression [Dimension 1px][Keyword \"solid\"][Color #000]]))\n // Declaration (\"width\", Value ([Expression [Operation \" + \" [Variable \"@w\"][Dimension 4px]]]))\n // Ruleset (Selector [Element '>', '.child'], [...])\n // ])\n //\n // In general, most rules will try to parse a token with the `$re()` function, and if the return\n // value is truly, will return a new node, of the relevant type. Sometimes, we need to check\n // first, before parsing, that's when we use `peek()`.\n //\n parsers: parsers = {\n //\n // The `primary` rule is the *entry* and *exit* point of the parser.\n // The rules here can appear at any level of the parse tree.\n //\n // The recursive nature of the grammar is an interplay between the `block`\n // rule, which represents `{ ... }`, the `ruleset` rule, and this `primary` rule,\n // as represented by this simplified grammar:\n //\n // primary → (ruleset | declaration)+\n // ruleset → selector+ block\n // block → '{' primary '}'\n //\n // Only at one point is the primary rule not called from the\n // block rule: at the root level.\n //\n primary: function () {\n const mixin = this.mixin;\n let root = [];\n let node;\n\n while (true) {\n while (true) {\n node = this.comment();\n if (!node) { break; }\n root.push(node);\n }\n // always process comments before deciding if finished\n if (parserInput.finished) {\n break;\n }\n if (parserInput.peek('}')) {\n break;\n }\n\n node = this.extendRule();\n if (node) {\n root = root.concat(node);\n continue;\n }\n\n node = mixin.definition() || this.declaration() || mixin.call(false, false) || \n this.ruleset() || this.variableCall() || this.entities.call() || this.atrule();\n if (node) {\n root.push(node);\n } else {\n let foundSemiColon = false;\n while (parserInput.$char(';')) {\n foundSemiColon = true;\n }\n if (!foundSemiColon) {\n break;\n }\n }\n }\n\n return root;\n },\n\n // comments are collected by the main parsing mechanism and then assigned to nodes\n // where the current structure allows it\n comment: function () {\n if (parserInput.commentStore.length) {\n const comment = parserInput.commentStore.shift();\n return new(tree.Comment)(comment.text, comment.isLineComment, comment.index, fileInfo);\n }\n },\n\n //\n // Entities are tokens which can be found inside an Expression\n //\n entities: {\n mixinLookup: function() {\n return parsers.mixin.call(true, true);\n },\n //\n // A string, which supports escaping \" and '\n //\n // \"milky way\" 'he\\'s the one!'\n //\n quoted: function (forceEscaped) {\n let str;\n const index = parserInput.i;\n let isEscaped = false;\n\n parserInput.save();\n if (parserInput.$char('~')) {\n isEscaped = true;\n } else if (forceEscaped) {\n parserInput.restore();\n return;\n }\n\n str = parserInput.$quoted();\n if (!str) {\n parserInput.restore();\n return;\n }\n parserInput.forget();\n\n return new(tree.Quoted)(str.charAt(0), str.substr(1, str.length - 2), isEscaped, index, fileInfo);\n },\n\n //\n // A catch-all word, such as:\n //\n // black border-collapse\n //\n keyword: function () {\n const k = parserInput.$char('%') || parserInput.$re(/^\\[?(?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+\\]?/);\n if (k) {\n return tree.Color.fromKeyword(k) || new(tree.Keyword)(k);\n }\n },\n\n //\n // A function call\n //\n // rgb(255, 0, 255)\n //\n // The arguments are parsed with the `entities.arguments` parser.\n //\n call: function () {\n let name;\n let args;\n let func;\n const index = parserInput.i;\n\n // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18\n if (parserInput.peek(/^url\\(/i)) {\n return;\n }\n\n parserInput.save();\n\n name = parserInput.$re(/^([\\w-]+|%|progid:[\\w\\.]+)\\(/);\n if (!name) {\n parserInput.forget(); \n return;\n }\n\n name = name[1];\n func = this.customFuncCall(name);\n if (func) {\n args = func.parse();\n if (args && func.stop) {\n parserInput.forget();\n return args;\n }\n }\n\n args = this.arguments(args);\n\n if (!parserInput.$char(')')) {\n parserInput.restore('Could not parse call arguments or missing \\')\\'');\n return;\n }\n\n parserInput.forget();\n\n return new(tree.Call)(name, args, index, fileInfo);\n },\n \n //\n // Parsing rules for functions with non-standard args, e.g.:\n //\n // boolean(not(2 > 1))\n //\n // This is a quick prototype, to be modified/improved when\n // more custom-parsed funcs come (e.g. `selector(...)`)\n //\n\n customFuncCall: function (name) {\n /* Ideally the table is to be moved out of here for faster perf.,\n but it's quite tricky since it relies on all these `parsers`\n and `expect` available only here */\n return {\n alpha: f(parsers.ieAlpha, true),\n boolean: f(condition),\n 'if': f(condition)\n }[name.toLowerCase()];\n\n function f(parse, stop) {\n return {\n parse, // parsing function\n stop // when true - stop after parse() and return its result, \n // otherwise continue for plain args\n };\n }\n \n function condition() {\n return [expect(parsers.condition, 'expected condition')];\n }\n },\n\n arguments: function (prevArgs) {\n let argsComma = prevArgs || [];\n const argsSemiColon = [];\n let isSemiColonSeparated;\n let value;\n\n parserInput.save();\n\n while (true) {\n if (prevArgs) {\n prevArgs = false;\n } else {\n value = parsers.detachedRuleset() || this.assignment() || parsers.expression();\n if (!value) {\n break;\n }\n\n if (value.value && value.value.length == 1) {\n value = value.value[0];\n }\n\n argsComma.push(value);\n }\n\n if (parserInput.$char(',')) {\n continue;\n }\n\n if (parserInput.$char(';') || isSemiColonSeparated) {\n isSemiColonSeparated = true;\n value = (argsComma.length < 1) ? argsComma[0]\n : new tree.Value(argsComma);\n argsSemiColon.push(value);\n argsComma = [];\n }\n }\n\n parserInput.forget();\n return isSemiColonSeparated ? argsSemiColon : argsComma;\n },\n literal: function () {\n return this.dimension() ||\n this.color() ||\n this.quoted() ||\n this.unicodeDescriptor();\n },\n\n // Assignments are argument entities for calls.\n // They are present in ie filter properties as shown below.\n //\n // filter: progid:DXImageTransform.Microsoft.Alpha( *opacity=50* )\n //\n\n assignment: function () {\n let key;\n let value;\n parserInput.save();\n key = parserInput.$re(/^\\w+(?=\\s?=)/i);\n if (!key) {\n parserInput.restore();\n return;\n }\n if (!parserInput.$char('=')) {\n parserInput.restore();\n return;\n }\n value = parsers.entity();\n if (value) {\n parserInput.forget();\n return new(tree.Assignment)(key, value);\n } else {\n parserInput.restore();\n }\n },\n\n //\n // Parse url() tokens\n //\n // We use a specific rule for urls, because they don't really behave like\n // standard function calls. The difference is that the argument doesn't have\n // to be enclosed within a string, so it can't be parsed as an Expression.\n //\n url: function () {\n let value;\n const index = parserInput.i;\n\n parserInput.autoCommentAbsorb = false;\n\n if (!parserInput.$str('url(')) {\n parserInput.autoCommentAbsorb = true;\n return;\n }\n\n value = this.quoted() || this.variable() || this.property() ||\n parserInput.$re(/^(?:(?:\\\\[\\(\\)'\"])|[^\\(\\)'\"])+/) || '';\n\n parserInput.autoCommentAbsorb = true;\n\n expectChar(')');\n\n return new(tree.URL)((value.value != null || \n value instanceof tree.Variable || \n value instanceof tree.Property) ?\n value : new(tree.Anonymous)(value, index), index, fileInfo);\n },\n\n //\n // A Variable entity, such as `@fink`, in\n //\n // width: @fink + 2px\n //\n // We use a different parser for variable definitions,\n // see `parsers.variable`.\n //\n variable: function () {\n let ch;\n let name;\n const index = parserInput.i;\n\n parserInput.save();\n if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^@@?[\\w-]+/))) {\n ch = parserInput.currentChar();\n if (ch === '(' || ch === '[' && !parserInput.prevChar().match(/^\\s/)) {\n // this may be a VariableCall lookup\n const result = parsers.variableCall(name);\n if (result) {\n parserInput.forget();\n return result;\n }\n }\n parserInput.forget();\n return new(tree.Variable)(name, index, fileInfo);\n }\n parserInput.restore();\n },\n\n // A variable entity using the protective {} e.g. @{var}\n variableCurly: function () {\n let curly;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '@' && (curly = parserInput.$re(/^@\\{([\\w-]+)\\}/))) {\n return new(tree.Variable)(`@${curly[1]}`, index, fileInfo);\n }\n },\n //\n // A Property accessor, such as `$color`, in\n //\n // background-color: $color\n //\n property: function () {\n let name;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '$' && (name = parserInput.$re(/^\\$[\\w-]+/))) {\n return new(tree.Property)(name, index, fileInfo);\n }\n },\n\n // A property entity useing the protective {} e.g. ${prop}\n propertyCurly: function () {\n let curly;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '$' && (curly = parserInput.$re(/^\\$\\{([\\w-]+)\\}/))) {\n return new(tree.Property)(`$${curly[1]}`, index, fileInfo);\n }\n },\n //\n // A Hexadecimal color\n //\n // #4F3C2F\n //\n // `rgb` and `hsl` colors are parsed through the `entities.call` parser.\n //\n color: function () {\n let rgb;\n parserInput.save();\n\n if (parserInput.currentChar() === '#' && (rgb = parserInput.$re(/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})([\\w.#\\[])?/))) {\n if (!rgb[2]) {\n parserInput.forget();\n return new(tree.Color)(rgb[1], undefined, rgb[0]);\n } \n }\n parserInput.restore();\n },\n\n colorKeyword: function () {\n parserInput.save();\n const autoCommentAbsorb = parserInput.autoCommentAbsorb;\n parserInput.autoCommentAbsorb = false;\n const k = parserInput.$re(/^[_A-Za-z-][_A-Za-z0-9-]+/);\n parserInput.autoCommentAbsorb = autoCommentAbsorb;\n if (!k) {\n parserInput.forget();\n return;\n }\n parserInput.restore();\n const color = tree.Color.fromKeyword(k);\n if (color) {\n parserInput.$str(k);\n return color;\n }\n },\n\n //\n // A Dimension, that is, a number and a unit\n //\n // 0.5em 95%\n //\n dimension: function () {\n if (parserInput.peekNotNumeric()) {\n return;\n }\n\n const value = parserInput.$re(/^([+-]?\\d*\\.?\\d+)(%|[a-z_]+)?/i);\n if (value) {\n return new(tree.Dimension)(value[1], value[2]);\n }\n },\n\n //\n // A unicode descriptor, as is used in unicode-range\n //\n // U+0?? or U+00A1-00A9\n //\n unicodeDescriptor: function () {\n let ud;\n\n ud = parserInput.$re(/^U\\+[0-9a-fA-F?]+(\\-[0-9a-fA-F?]+)?/);\n if (ud) {\n return new(tree.UnicodeDescriptor)(ud[0]);\n }\n },\n\n //\n // JavaScript code to be evaluated\n //\n // `window.location.href`\n //\n javascript: function () {\n let js;\n const index = parserInput.i;\n\n parserInput.save();\n\n const escape = parserInput.$char('~');\n const jsQuote = parserInput.$char('`');\n\n if (!jsQuote) {\n parserInput.restore();\n return;\n }\n\n js = parserInput.$re(/^[^`]*`/);\n if (js) {\n parserInput.forget();\n return new(tree.JavaScript)(js.substr(0, js.length - 1), Boolean(escape), index, fileInfo);\n }\n parserInput.restore('invalid javascript definition');\n }\n },\n\n //\n // The variable part of a variable definition. Used in the `rule` parser\n //\n // @fink:\n //\n variable: function () {\n let name;\n\n if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^(@[\\w-]+)\\s*:/))) { return name[1]; }\n },\n\n //\n // Call a variable value to retrieve a detached ruleset\n // or a value from a detached ruleset's rules.\n //\n // @fink();\n // @fink;\n // color: @fink[@color];\n //\n variableCall: function (parsedName) {\n let lookups;\n const i = parserInput.i;\n const inValue = !!parsedName;\n let name = parsedName;\n\n parserInput.save();\n\n if (name || (parserInput.currentChar() === '@'\n && (name = parserInput.$re(/^(@[\\w-]+)(\\(\\s*\\))?/)))) {\n\n lookups = this.mixin.ruleLookups();\n\n if (!lookups && ((inValue && parserInput.$str('()') !== '()') || (name[2] !== '()'))) {\n parserInput.restore('Missing \\'[...]\\' lookup in variable call');\n return;\n }\n\n if (!inValue) {\n name = name[1];\n }\n\n const call = new tree.VariableCall(name, i, fileInfo);\n if (!inValue && parsers.end()) {\n parserInput.forget();\n return call;\n }\n else {\n parserInput.forget();\n return new tree.NamespaceValue(call, lookups, i, fileInfo);\n }\n }\n\n parserInput.restore();\n },\n\n //\n // extend syntax - used to extend selectors\n //\n extend: function(isRule) {\n let elements;\n let e;\n const index = parserInput.i;\n let option;\n let extendList;\n let extend;\n\n if (!parserInput.$str(isRule ? '&:extend(' : ':extend(')) {\n return;\n }\n\n do {\n option = null;\n elements = null;\n while (!(option = parserInput.$re(/^(all)(?=\\s*(\\)|,))/))) {\n e = this.element();\n if (!e) {\n break;\n }\n if (elements) {\n elements.push(e);\n } else {\n elements = [ e ];\n }\n }\n\n option = option && option[1];\n if (!elements) {\n error('Missing target selector for :extend().');\n }\n extend = new(tree.Extend)(new(tree.Selector)(elements), option, index, fileInfo);\n if (extendList) {\n extendList.push(extend);\n } else {\n extendList = [ extend ];\n }\n } while (parserInput.$char(','));\n\n expect(/^\\)/);\n\n if (isRule) {\n expect(/^;/);\n }\n\n return extendList;\n },\n\n //\n // extendRule - used in a rule to extend all the parent selectors\n //\n extendRule: function() {\n return this.extend(true);\n },\n\n //\n // Mixins\n //\n mixin: {\n //\n // A Mixin call, with an optional argument list\n //\n // #mixins > .square(#fff);\n // #mixins.square(#fff);\n // .rounded(4px, black);\n // .button;\n //\n // We can lookup / return a value using the lookup syntax:\n //\n // color: #mixin.square(#fff)[@color];\n //\n // The `while` loop is there because mixins can be\n // namespaced, but we only support the child and descendant\n // selector for now.\n //\n call: function (inValue, getLookup) {\n const s = parserInput.currentChar();\n let important = false;\n let lookups;\n const index = parserInput.i;\n let elements;\n let args;\n let hasParens;\n\n if (s !== '.' && s !== '#') { return; }\n\n parserInput.save(); // stop us absorbing part of an invalid selector\n\n elements = this.elements();\n\n if (elements) {\n if (parserInput.$char('(')) {\n args = this.args(true).args;\n expectChar(')');\n hasParens = true;\n }\n\n if (getLookup !== false) {\n lookups = this.ruleLookups();\n }\n if (getLookup === true && !lookups) {\n parserInput.restore();\n return;\n }\n\n if (inValue && !lookups && !hasParens) {\n // This isn't a valid in-value mixin call\n parserInput.restore();\n return;\n }\n\n if (!inValue && parsers.important()) {\n important = true;\n }\n\n if (inValue || parsers.end()) {\n parserInput.forget();\n const mixin = new(tree.mixin.Call)(elements, args, index, fileInfo, !lookups && important);\n if (lookups) {\n return new tree.NamespaceValue(mixin, lookups);\n }\n else {\n return mixin;\n }\n }\n }\n\n parserInput.restore();\n },\n /**\n * Matching elements for mixins\n * (Start with . or # and can have > )\n */\n elements: function() {\n let elements;\n let e;\n let c;\n let elem;\n let elemIndex;\n const re = /^[#.](?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/;\n while (true) {\n elemIndex = parserInput.i;\n e = parserInput.$re(re);\n \n if (!e) {\n break;\n }\n elem = new(tree.Element)(c, e, false, elemIndex, fileInfo);\n if (elements) {\n elements.push(elem);\n } else {\n elements = [ elem ];\n }\n c = parserInput.$char('>');\n }\n return elements;\n },\n args: function (isCall) {\n const entities = parsers.entities;\n const returner = { args:null, variadic: false };\n let expressions = [];\n const argsSemiColon = [];\n const argsComma = [];\n let isSemiColonSeparated;\n let expressionContainsNamed;\n let name;\n let nameLoop;\n let value;\n let arg;\n let expand;\n let hasSep = true;\n\n parserInput.save();\n\n while (true) {\n if (isCall) {\n arg = parsers.detachedRuleset() || parsers.expression();\n } else {\n parserInput.commentStore.length = 0;\n if (parserInput.$str('...')) {\n returner.variadic = true;\n if (parserInput.$char(';') && !isSemiColonSeparated) {\n isSemiColonSeparated = true;\n }\n (isSemiColonSeparated ? argsSemiColon : argsComma)\n .push({ variadic: true });\n break;\n }\n arg = entities.variable() || entities.property() || entities.literal() || entities.keyword() || this.call(true);\n }\n\n if (!arg || !hasSep) {\n break;\n }\n\n nameLoop = null;\n if (arg.throwAwayComments) {\n arg.throwAwayComments();\n }\n value = arg;\n let val = null;\n\n if (isCall) {\n // Variable\n if (arg.value && arg.value.length == 1) {\n val = arg.value[0];\n }\n } else {\n val = arg;\n }\n\n if (val && (val instanceof tree.Variable || val instanceof tree.Property)) {\n if (parserInput.$char(':')) {\n if (expressions.length > 0) {\n if (isSemiColonSeparated) {\n error('Cannot mix ; and , as delimiter types');\n }\n expressionContainsNamed = true;\n }\n\n value = parsers.detachedRuleset() || parsers.expression();\n\n if (!value) {\n if (isCall) {\n error('could not understand value for named argument');\n } else {\n parserInput.restore();\n returner.args = [];\n return returner;\n }\n }\n nameLoop = (name = val.name);\n } else if (parserInput.$str('...')) {\n if (!isCall) {\n returner.variadic = true;\n if (parserInput.$char(';') && !isSemiColonSeparated) {\n isSemiColonSeparated = true;\n }\n (isSemiColonSeparated ? argsSemiColon : argsComma)\n .push({ name: arg.name, variadic: true });\n break;\n } else {\n expand = true;\n }\n } else if (!isCall) {\n name = nameLoop = val.name;\n value = null;\n }\n }\n\n if (value) {\n expressions.push(value);\n }\n\n argsComma.push({ name:nameLoop, value, expand });\n\n if (parserInput.$char(',')) {\n hasSep = true;\n continue;\n }\n hasSep = parserInput.$char(';') === ';';\n\n if (hasSep || isSemiColonSeparated) {\n\n if (expressionContainsNamed) {\n error('Cannot mix ; and , as delimiter types');\n }\n\n isSemiColonSeparated = true;\n\n if (expressions.length > 1) {\n value = new(tree.Value)(expressions);\n }\n argsSemiColon.push({ name, value, expand });\n\n name = null;\n expressions = [];\n expressionContainsNamed = false;\n }\n }\n\n parserInput.forget();\n returner.args = isSemiColonSeparated ? argsSemiColon : argsComma;\n return returner;\n },\n //\n // A Mixin definition, with a list of parameters\n //\n // .rounded (@radius: 2px, @color) {\n // ...\n // }\n //\n // Until we have a finer grained state-machine, we have to\n // do a look-ahead, to make sure we don't have a mixin call.\n // See the `rule` function for more information.\n //\n // We start by matching `.rounded (`, and then proceed on to\n // the argument list, which has optional default values.\n // We store the parameters in `params`, with a `value` key,\n // if there is a value, such as in the case of `@radius`.\n //\n // Once we've got our params list, and a closing `)`, we parse\n // the `{...}` block.\n //\n definition: function () {\n let name;\n let params = [];\n let match;\n let ruleset;\n let cond;\n let variadic = false;\n if ((parserInput.currentChar() !== '.' && parserInput.currentChar() !== '#') ||\n parserInput.peek(/^[^{]*\\}/)) {\n return;\n }\n\n parserInput.save();\n\n match = parserInput.$re(/^([#.](?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\\s*\\(/);\n if (match) {\n name = match[1];\n\n const argInfo = this.args(false);\n params = argInfo.args;\n variadic = argInfo.variadic;\n\n // .mixincall(\"@{a}\");\n // looks a bit like a mixin definition..\n // also\n // .mixincall(@a: {rule: set;});\n // so we have to be nice and restore\n if (!parserInput.$char(')')) {\n parserInput.restore('Missing closing \\')\\'');\n return;\n }\n\n parserInput.commentStore.length = 0;\n\n if (parserInput.$str('when')) { // Guard\n cond = expect(parsers.conditions, 'expected condition');\n }\n\n ruleset = parsers.block();\n\n if (ruleset) {\n parserInput.forget();\n return new(tree.mixin.Definition)(name, params, ruleset, cond, variadic);\n } else {\n parserInput.restore();\n }\n } else {\n parserInput.restore();\n }\n },\n \n ruleLookups: function() {\n let rule;\n let args;\n const lookups = [];\n\n if (parserInput.currentChar() !== '[') { \n return;\n }\n\n while (true) {\n parserInput.save();\n args = null;\n rule = this.lookupValue();\n if (!rule && rule !== '') {\n parserInput.restore();\n break;\n }\n lookups.push(rule);\n parserInput.forget();\n }\n if (lookups.length > 0) {\n return lookups;\n }\n },\n \n lookupValue: function() {\n parserInput.save();\n \n if (!parserInput.$char('[')) { \n parserInput.restore();\n return;\n }\n \n const name = parserInput.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/);\n \n if (!parserInput.$char(']')) {\n parserInput.restore();\n return;\n } \n\n if (name || name === '') {\n parserInput.forget();\n return name;\n }\n \n parserInput.restore();\n }\n },\n //\n // Entities are the smallest recognized token,\n // and can be found inside a rule's value.\n //\n entity: function () {\n const entities = this.entities;\n\n return this.comment() || entities.literal() || entities.variable() || entities.url() ||\n entities.property() || entities.call() || entities.keyword() || this.mixin.call(true) ||\n entities.javascript();\n },\n\n //\n // A Declaration terminator. Note that we use `peek()` to check for '}',\n // because the `block` rule will be expecting it, but we still need to make sure\n // it's there, if ';' was omitted.\n //\n end: function () {\n return parserInput.$char(';') || parserInput.peek('}');\n },\n\n //\n // IE's alpha function\n //\n // alpha(opacity=88)\n //\n ieAlpha: function () {\n let value;\n\n // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18\n if (!parserInput.$re(/^opacity=/i)) { return; }\n value = parserInput.$re(/^\\d+/);\n if (!value) {\n value = expect(parsers.entities.variable, 'Could not parse alpha');\n value = `@{${value.name.slice(1)}}`;\n }\n expectChar(')');\n return new tree.Quoted('', `alpha(opacity=${value})`);\n },\n\n //\n // A Selector Element\n //\n // div\n // + h1\n // #socks\n // input[type=\"text\"]\n //\n // Elements are the building blocks for Selectors,\n // they are made out of a `Combinator` (see combinator rule),\n // and an element name, such as a tag a class, or `*`.\n //\n element: function () {\n let e;\n let c;\n let v;\n const index = parserInput.i;\n\n c = this.combinator();\n\n e = parserInput.$re(/^(?:\\d+\\.\\d+|\\d+)%/) ||\n parserInput.$re(/^(?:[.#]?|:*)(?:[\\w-]|[^\\x00-\\x9f]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/) ||\n parserInput.$char('*') || parserInput.$char('&') || this.attribute() ||\n parserInput.$re(/^\\([^&()@]+\\)/) || parserInput.$re(/^[\\.#:](?=@)/) ||\n this.entities.variableCurly();\n\n if (!e) {\n parserInput.save();\n if (parserInput.$char('(')) {\n if ((v = this.selector(false)) && parserInput.$char(')')) {\n e = new(tree.Paren)(v);\n parserInput.forget();\n } else {\n parserInput.restore('Missing closing \\')\\'');\n }\n } else {\n parserInput.forget();\n }\n }\n\n if (e) { return new(tree.Element)(c, e, e instanceof tree.Variable, index, fileInfo); }\n },\n\n //\n // Combinators combine elements together, in a Selector.\n //\n // Because our parser isn't white-space sensitive, special care\n // has to be taken, when parsing the descendant combinator, ` `,\n // as it's an empty space. We have to check the previous character\n // in the input, to see if it's a ` ` character. More info on how\n // we deal with this in *combinator.js*.\n //\n combinator: function () {\n let c = parserInput.currentChar();\n\n if (c === '/') {\n parserInput.save();\n const slashedCombinator = parserInput.$re(/^\\/[a-z]+\\//i);\n if (slashedCombinator) {\n parserInput.forget();\n return new(tree.Combinator)(slashedCombinator);\n }\n parserInput.restore();\n }\n\n if (c === '>' || c === '+' || c === '~' || c === '|' || c === '^') {\n parserInput.i++;\n if (c === '^' && parserInput.currentChar() === '^') {\n c = '^^';\n parserInput.i++;\n }\n while (parserInput.isWhitespace()) { parserInput.i++; }\n return new(tree.Combinator)(c);\n } else if (parserInput.isWhitespace(-1)) {\n return new(tree.Combinator)(' ');\n } else {\n return new(tree.Combinator)(null);\n }\n },\n //\n // A CSS Selector\n // with less extensions e.g. the ability to extend and guard\n //\n // .class > div + h1\n // li a:hover\n //\n // Selectors are made out of one or more Elements, see above.\n //\n selector: function (isLess) {\n const index = parserInput.i;\n let elements;\n let extendList;\n let c;\n let e;\n let allExtends;\n let when;\n let condition;\n isLess = isLess !== false;\n while ((isLess && (extendList = this.extend())) || (isLess && (when = parserInput.$str('when'))) || (e = this.element())) {\n if (when) {\n condition = expect(this.conditions, 'expected condition');\n } else if (condition) {\n error('CSS guard can only be used at the end of selector');\n } else if (extendList) {\n if (allExtends) {\n allExtends = allExtends.concat(extendList);\n } else {\n allExtends = extendList;\n }\n } else {\n if (allExtends) { error('Extend can only be used at the end of selector'); }\n c = parserInput.currentChar();\n if (elements) {\n elements.push(e);\n } else {\n elements = [ e ];\n }\n e = null;\n }\n if (c === '{' || c === '}' || c === ';' || c === ',' || c === ')') {\n break;\n }\n }\n\n if (elements) { return new(tree.Selector)(elements, allExtends, condition, index, fileInfo); }\n if (allExtends) { error('Extend must be used to extend a selector, it cannot be used on its own'); }\n },\n selectors: function () {\n let s;\n let selectors;\n while (true) {\n s = this.selector();\n if (!s) {\n break;\n }\n if (selectors) {\n selectors.push(s);\n } else {\n selectors = [ s ];\n }\n parserInput.commentStore.length = 0;\n if (s.condition && selectors.length > 1) {\n error(\"Guards are only currently allowed on a single selector.\");\n }\n if (!parserInput.$char(',')) { break; }\n if (s.condition) {\n error(\"Guards are only currently allowed on a single selector.\");\n }\n parserInput.commentStore.length = 0;\n }\n return selectors;\n },\n attribute: function () {\n if (!parserInput.$char('[')) { return; }\n\n const entities = this.entities;\n let key;\n let val;\n let op;\n\n if (!(key = entities.variableCurly())) {\n key = expect(/^(?:[_A-Za-z0-9-\\*]*\\|)?(?:[_A-Za-z0-9-]|\\\\.)+/);\n }\n\n op = parserInput.$re(/^[|~*$^]?=/);\n if (op) {\n val = entities.quoted() || parserInput.$re(/^[0-9]+%/) || parserInput.$re(/^[\\w-]+/) || entities.variableCurly();\n }\n\n expectChar(']');\n\n return new(tree.Attribute)(key, op, val);\n },\n\n //\n // The `block` rule is used by `ruleset` and `mixin.definition`.\n // It's a wrapper around the `primary` rule, with added `{}`.\n //\n block: function () {\n let content;\n if (parserInput.$char('{') && (content = this.primary()) && parserInput.$char('}')) {\n return content;\n }\n },\n\n blockRuleset: function() {\n let block = this.block();\n\n if (block) {\n block = new tree.Ruleset(null, block);\n }\n return block;\n },\n\n detachedRuleset: function() {\n let argInfo;\n let params;\n let variadic;\n\n parserInput.save();\n if (parserInput.$re(/^[.#]\\(/)) {\n /**\n * DR args currently only implemented for each() function, and not \n * yet settable as `@dr: #(@arg) {}`\n * This should be done when DRs are merged with mixins.\n * See: https://github.com/less/less-meta/issues/16\n */\n argInfo = this.mixin.args(false);\n params = argInfo.args;\n variadic = argInfo.variadic;\n if (!parserInput.$char(')')) {\n parserInput.restore();\n return;\n }\n }\n const blockRuleset = this.blockRuleset();\n if (blockRuleset) {\n parserInput.forget();\n if (params) {\n return new tree.mixin.Definition(null, params, blockRuleset, null, variadic);\n }\n return new tree.DetachedRuleset(blockRuleset);\n }\n parserInput.restore();\n },\n\n //\n // div, .class, body > p {...}\n //\n ruleset: function () {\n let selectors;\n let rules;\n let debugInfo;\n\n parserInput.save();\n\n if (context.dumpLineNumbers) {\n debugInfo = getDebugInfo(parserInput.i);\n }\n\n selectors = this.selectors();\n\n if (selectors && (rules = this.block())) {\n parserInput.forget();\n const ruleset = new(tree.Ruleset)(selectors, rules, context.strictImports);\n if (context.dumpLineNumbers) {\n ruleset.debugInfo = debugInfo;\n }\n return ruleset;\n } else {\n parserInput.restore();\n }\n },\n declaration: function () {\n let name;\n let value;\n const index = parserInput.i;\n let hasDR;\n const c = parserInput.currentChar();\n let important;\n let merge;\n let isVariable;\n\n if (c === '.' || c === '#' || c === '&' || c === ':') { return; }\n\n parserInput.save();\n\n name = this.variable() || this.ruleProperty();\n if (name) {\n isVariable = typeof name === 'string';\n\n if (isVariable) {\n value = this.detachedRuleset();\n if (value) {\n hasDR = true;\n }\n }\n\n parserInput.commentStore.length = 0;\n if (!value) {\n // a name returned by this.ruleProperty() is always an array of the form:\n // [string-1, ..., string-n, \"\"] or [string-1, ..., string-n, \"+\"]\n // where each item is a tree.Keyword or tree.Variable\n merge = !isVariable && name.length > 1 && name.pop().value;\n\n // Custom property values get permissive parsing\n if (name[0].value && name[0].value.slice(0, 2) === '--') {\n value = this.permissiveValue();\n }\n // Try to store values as anonymous\n // If we need the value later we'll re-parse it in ruleset.parseValue\n else {\n value = this.anonymousValue();\n }\n if (value) {\n parserInput.forget();\n // anonymous values absorb the end ';' which is required for them to work\n return new(tree.Declaration)(name, value, false, merge, index, fileInfo);\n }\n\n if (!value) {\n value = this.value();\n }\n\n if (value) {\n important = this.important();\n } else if (isVariable) {\n // As a last resort, try permissiveValue\n value = this.permissiveValue();\n }\n }\n\n if (value && (this.end() || hasDR)) {\n parserInput.forget();\n return new(tree.Declaration)(name, value, important, merge, index, fileInfo);\n }\n else {\n parserInput.restore();\n }\n } else {\n parserInput.restore();\n }\n },\n anonymousValue: function () {\n const index = parserInput.i;\n const match = parserInput.$re(/^([^.#@\\$+\\/'\"*`(;{}-]*);/);\n if (match) {\n return new(tree.Anonymous)(match[1], index);\n }\n },\n /**\n * Used for custom properties, at-rules, and variables (as fallback)\n * Parses almost anything inside of {} [] () \"\" blocks\n * until it reaches outer-most tokens.\n * \n * First, it will try to parse comments and entities to reach\n * the end. This is mostly like the Expression parser except no\n * math is allowed.\n */\n permissiveValue: function (untilTokens) {\n let i;\n let e;\n let done;\n let value;\n const tok = untilTokens || ';';\n const index = parserInput.i;\n const result = [];\n\n function testCurrentChar() {\n const char = parserInput.currentChar();\n if (typeof tok === 'string') {\n return char === tok;\n } else {\n return tok.test(char);\n }\n }\n if (testCurrentChar()) {\n return;\n }\n value = [];\n do {\n e = this.comment();\n if (e) {\n value.push(e);\n continue;\n }\n e = this.entity();\n if (e) {\n value.push(e);\n }\n } while (e);\n\n done = testCurrentChar();\n\n if (value.length > 0) {\n value = new(tree.Expression)(value);\n if (done) {\n return value;\n }\n else {\n result.push(value);\n }\n // Preserve space before $parseUntil as it will not\n if (parserInput.prevChar() === ' ') {\n result.push(new tree.Anonymous(' ', index));\n }\n }\n parserInput.save();\n\n value = parserInput.$parseUntil(tok);\n\n if (value) {\n if (typeof value === 'string') {\n error(`Expected '${value}'`, 'Parse');\n }\n if (value.length === 1 && value[0] === ' ') {\n parserInput.forget();\n return new tree.Anonymous('', index);\n }\n let item;\n for (i = 0; i < value.length; i++) {\n item = value[i];\n if (Array.isArray(item)) {\n // Treat actual quotes as normal quoted values\n result.push(new tree.Quoted(item[0], item[1], true, index, fileInfo));\n }\n else {\n if (i === value.length - 1) {\n item = item.trim();\n }\n // Treat like quoted values, but replace vars like unquoted expressions\n const quote = new tree.Quoted('\\'', item, true, index, fileInfo);\n quote.variableRegex = /@([\\w-]+)/g;\n quote.propRegex = /\\$([\\w-]+)/g;\n result.push(quote);\n }\n }\n parserInput.forget();\n return new tree.Expression(result, true);\n }\n parserInput.restore();\n },\n\n //\n // An @import atrule\n //\n // @import \"lib\";\n //\n // Depending on our environment, importing is done differently:\n // In the browser, it's an XHR request, in Node, it would be a\n // file-system operation. The function used for importing is\n // stored in `import`, which we pass to the Import constructor.\n //\n 'import': function () {\n let path;\n let features;\n const index = parserInput.i;\n\n const dir = parserInput.$re(/^@import?\\s+/);\n\n if (dir) {\n const options = (dir ? this.importOptions() : null) || {};\n\n if ((path = this.entities.quoted() || this.entities.url())) {\n features = this.mediaFeatures();\n\n if (!parserInput.$char(';')) {\n parserInput.i = index;\n error('missing semi-colon or unrecognised media features on import');\n }\n features = features && new(tree.Value)(features);\n return new(tree.Import)(path, features, options, index, fileInfo);\n }\n else {\n parserInput.i = index;\n error('malformed import statement');\n }\n }\n },\n\n importOptions: function() {\n let o;\n const options = {};\n let optionName;\n let value;\n\n // list of options, surrounded by parens\n if (!parserInput.$char('(')) { return null; }\n do {\n o = this.importOption();\n if (o) {\n optionName = o;\n value = true;\n switch (optionName) {\n case 'css':\n optionName = 'less';\n value = false;\n break;\n case 'once':\n optionName = 'multiple';\n value = false;\n break;\n }\n options[optionName] = value;\n if (!parserInput.$char(',')) { break; }\n }\n } while (o);\n expectChar(')');\n return options;\n },\n\n importOption: function() {\n const opt = parserInput.$re(/^(less|css|multiple|once|inline|reference|optional)/);\n if (opt) {\n return opt[1];\n }\n },\n\n mediaFeature: function () {\n const entities = this.entities;\n const nodes = [];\n let e;\n let p;\n parserInput.save();\n do {\n e = entities.keyword() || entities.variable() || entities.mixinLookup();\n if (e) {\n nodes.push(e);\n } else if (parserInput.$char('(')) {\n p = this.property();\n e = this.value();\n if (parserInput.$char(')')) {\n if (p && e) {\n nodes.push(new(tree.Paren)(new(tree.Declaration)(p, e, null, null, parserInput.i, fileInfo, true)));\n } else if (e) {\n nodes.push(new(tree.Paren)(e));\n } else {\n error('badly formed media feature definition');\n }\n } else {\n error('Missing closing \\')\\'', 'Parse');\n }\n }\n } while (e);\n\n parserInput.forget();\n if (nodes.length > 0) {\n return new(tree.Expression)(nodes);\n }\n },\n\n mediaFeatures: function () {\n const entities = this.entities;\n const features = [];\n let e;\n do {\n e = this.mediaFeature();\n if (e) {\n features.push(e);\n if (!parserInput.$char(',')) { break; }\n } else {\n e = entities.variable() || entities.mixinLookup();\n if (e) {\n features.push(e);\n if (!parserInput.$char(',')) { break; }\n }\n }\n } while (e);\n\n return features.length > 0 ? features : null;\n },\n\n media: function () {\n let features;\n let rules;\n let media;\n let debugInfo;\n const index = parserInput.i;\n\n if (context.dumpLineNumbers) {\n debugInfo = getDebugInfo(index);\n }\n\n parserInput.save();\n\n if (parserInput.$str('@media')) {\n features = this.mediaFeatures();\n\n rules = this.block();\n\n if (!rules) {\n error('media definitions require block statements after any features');\n }\n\n parserInput.forget();\n\n media = new(tree.Media)(rules, features, index, fileInfo);\n if (context.dumpLineNumbers) {\n media.debugInfo = debugInfo;\n }\n\n return media;\n }\n\n parserInput.restore();\n },\n\n //\n\n // A @plugin directive, used to import plugins dynamically.\n //\n // @plugin (args) \"lib\";\n //\n plugin: function () {\n let path;\n let args;\n let options;\n const index = parserInput.i;\n const dir = parserInput.$re(/^@plugin?\\s+/);\n\n if (dir) {\n args = this.pluginArgs();\n\n if (args) {\n options = {\n pluginArgs: args,\n isPlugin: true\n };\n }\n else {\n options = { isPlugin: true };\n }\n\n if ((path = this.entities.quoted() || this.entities.url())) {\n\n if (!parserInput.$char(';')) {\n parserInput.i = index;\n error('missing semi-colon on @plugin');\n }\n return new(tree.Import)(path, null, options, index, fileInfo);\n }\n else {\n parserInput.i = index;\n error('malformed @plugin statement');\n }\n }\n },\n\n pluginArgs: function() {\n // list of options, surrounded by parens\n parserInput.save();\n if (!parserInput.$char('(')) {\n parserInput.restore();\n return null;\n }\n const args = parserInput.$re(/^\\s*([^\\);]+)\\)\\s*/);\n if (args[1]) {\n parserInput.forget();\n return args[1].trim();\n }\n else { \n parserInput.restore();\n return null;\n }\n },\n\n //\n // A CSS AtRule\n //\n // @charset \"utf-8\";\n //\n atrule: function () {\n const index = parserInput.i;\n let name;\n let value;\n let rules;\n let nonVendorSpecificName;\n let hasIdentifier;\n let hasExpression;\n let hasUnknown;\n let hasBlock = true;\n let isRooted = true;\n\n if (parserInput.currentChar() !== '@') { return; }\n\n value = this['import']() || this.plugin() || this.media();\n if (value) {\n return value;\n }\n\n parserInput.save();\n\n name = parserInput.$re(/^@[a-z-]+/);\n\n if (!name) { return; }\n\n nonVendorSpecificName = name;\n if (name.charAt(1) == '-' && name.indexOf('-', 2) > 0) {\n nonVendorSpecificName = `@${name.slice(name.indexOf('-', 2) + 1)}`;\n }\n\n switch (nonVendorSpecificName) {\n case '@charset':\n hasIdentifier = true;\n hasBlock = false;\n break;\n case '@namespace':\n hasExpression = true;\n hasBlock = false;\n break;\n case '@keyframes':\n case '@counter-style':\n hasIdentifier = true;\n break;\n case '@document':\n case '@supports':\n hasUnknown = true;\n isRooted = false;\n break;\n default:\n hasUnknown = true;\n break;\n }\n\n parserInput.commentStore.length = 0;\n\n if (hasIdentifier) {\n value = this.entity();\n if (!value) {\n error(`expected ${name} identifier`);\n }\n } else if (hasExpression) {\n value = this.expression();\n if (!value) {\n error(`expected ${name} expression`);\n }\n } else if (hasUnknown) {\n value = this.permissiveValue(/^[{;]/);\n hasBlock = (parserInput.currentChar() === '{');\n if (!value) {\n if (!hasBlock && parserInput.currentChar() !== ';') {\n error(`${name} rule is missing block or ending semi-colon`);\n }\n }\n else if (!value.value) {\n value = null;\n }\n }\n\n if (hasBlock) {\n rules = this.blockRuleset();\n }\n\n if (rules || (!hasBlock && value && parserInput.$char(';'))) {\n parserInput.forget();\n return new(tree.AtRule)(name, value, rules, index, fileInfo,\n context.dumpLineNumbers ? getDebugInfo(index) : null,\n isRooted\n );\n }\n\n parserInput.restore('at-rule options not recognised');\n },\n\n //\n // A Value is a comma-delimited list of Expressions\n //\n // font-family: Baskerville, Georgia, serif;\n //\n // In a Rule, a Value represents everything after the `:`,\n // and before the `;`.\n //\n value: function () {\n let e;\n const expressions = [];\n const index = parserInput.i;\n\n do {\n e = this.expression();\n if (e) {\n expressions.push(e);\n if (!parserInput.$char(',')) { break; }\n }\n } while (e);\n\n if (expressions.length > 0) {\n return new(tree.Value)(expressions, index);\n }\n },\n important: function () {\n if (parserInput.currentChar() === '!') {\n return parserInput.$re(/^! *important/);\n }\n },\n sub: function () {\n let a;\n let e;\n\n parserInput.save();\n if (parserInput.$char('(')) {\n a = this.addition();\n if (a && parserInput.$char(')')) {\n parserInput.forget();\n e = new(tree.Expression)([a]);\n e.parens = true;\n return e;\n }\n parserInput.restore('Expected \\')\\'');\n return;\n }\n parserInput.restore();\n },\n multiplication: function () {\n let m;\n let a;\n let op;\n let operation;\n let isSpaced;\n m = this.operand();\n if (m) {\n isSpaced = parserInput.isWhitespace(-1);\n while (true) {\n if (parserInput.peek(/^\\/[*\\/]/)) {\n break;\n }\n\n parserInput.save();\n\n op = parserInput.$char('/') || parserInput.$char('*') || parserInput.$str('./');\n\n if (!op) { parserInput.forget(); break; }\n\n a = this.operand();\n\n if (!a) { parserInput.restore(); break; }\n parserInput.forget();\n\n m.parensInOp = true;\n a.parensInOp = true;\n operation = new(tree.Operation)(op, [operation || m, a], isSpaced);\n isSpaced = parserInput.isWhitespace(-1);\n }\n return operation || m;\n }\n },\n addition: function () {\n let m;\n let a;\n let op;\n let operation;\n let isSpaced;\n m = this.multiplication();\n if (m) {\n isSpaced = parserInput.isWhitespace(-1);\n while (true) {\n op = parserInput.$re(/^[-+]\\s+/) || (!isSpaced && (parserInput.$char('+') || parserInput.$char('-')));\n if (!op) {\n break;\n }\n a = this.multiplication();\n if (!a) {\n break;\n }\n\n m.parensInOp = true;\n a.parensInOp = true;\n operation = new(tree.Operation)(op, [operation || m, a], isSpaced);\n isSpaced = parserInput.isWhitespace(-1);\n }\n return operation || m;\n }\n },\n conditions: function () {\n let a;\n let b;\n const index = parserInput.i;\n let condition;\n\n a = this.condition(true);\n if (a) {\n while (true) {\n if (!parserInput.peek(/^,\\s*(not\\s*)?\\(/) || !parserInput.$char(',')) {\n break;\n }\n b = this.condition(true);\n if (!b) {\n break;\n }\n condition = new(tree.Condition)('or', condition || a, b, index);\n }\n return condition || a;\n }\n },\n condition: function (needsParens) {\n let result;\n let logical;\n let next;\n function or() {\n return parserInput.$str('or');\n }\n\n result = this.conditionAnd(needsParens);\n if (!result) {\n return ;\n }\n logical = or();\n if (logical) {\n next = this.condition(needsParens);\n if (next) {\n result = new(tree.Condition)(logical, result, next);\n } else {\n return ;\n }\n }\n return result;\n },\n conditionAnd: function (needsParens) {\n let result;\n let logical;\n let next;\n const self = this;\n function insideCondition() {\n const cond = self.negatedCondition(needsParens) || self.parenthesisCondition(needsParens);\n if (!cond && !needsParens) {\n return self.atomicCondition(needsParens);\n }\n return cond;\n }\n function and() {\n return parserInput.$str('and');\n }\n\n result = insideCondition();\n if (!result) {\n return ;\n }\n logical = and();\n if (logical) {\n next = this.conditionAnd(needsParens);\n if (next) {\n result = new(tree.Condition)(logical, result, next);\n } else {\n return ;\n }\n }\n return result;\n },\n negatedCondition: function (needsParens) {\n if (parserInput.$str('not')) {\n const result = this.parenthesisCondition(needsParens);\n if (result) {\n result.negate = !result.negate;\n }\n return result;\n }\n },\n parenthesisCondition: function (needsParens) {\n function tryConditionFollowedByParenthesis(me) {\n let body;\n parserInput.save();\n body = me.condition(needsParens);\n if (!body) {\n parserInput.restore();\n return ;\n }\n if (!parserInput.$char(')')) {\n parserInput.restore();\n return ;\n }\n parserInput.forget();\n return body;\n }\n\n let body;\n parserInput.save();\n if (!parserInput.$str('(')) {\n parserInput.restore();\n return ;\n }\n body = tryConditionFollowedByParenthesis(this);\n if (body) {\n parserInput.forget();\n return body;\n }\n\n body = this.atomicCondition(needsParens);\n if (!body) {\n parserInput.restore();\n return ;\n }\n if (!parserInput.$char(')')) {\n parserInput.restore(`expected ')' got '${parserInput.currentChar()}'`);\n return ;\n }\n parserInput.forget();\n return body;\n },\n atomicCondition: function (needsParens) {\n const entities = this.entities;\n const index = parserInput.i;\n let a;\n let b;\n let c;\n let op;\n\n function cond() {\n return this.addition() || entities.keyword() || entities.quoted() || entities.mixinLookup();\n }\n cond = cond.bind(this);\n\n a = cond();\n if (a) {\n if (parserInput.$char('>')) {\n if (parserInput.$char('=')) {\n op = '>=';\n } else {\n op = '>';\n }\n } else\n if (parserInput.$char('<')) {\n if (parserInput.$char('=')) {\n op = '<=';\n } else {\n op = '<';\n }\n } else\n if (parserInput.$char('=')) {\n if (parserInput.$char('>')) {\n op = '=>';\n } else if (parserInput.$char('<')) {\n op = '=<';\n } else {\n op = '=';\n }\n }\n if (op) {\n b = cond();\n if (b) {\n c = new(tree.Condition)(op, a, b, index, false);\n } else {\n error('expected expression');\n }\n } else {\n c = new(tree.Condition)('=', a, new(tree.Keyword)('true'), index, false);\n }\n return c;\n }\n },\n\n //\n // An operand is anything that can be part of an operation,\n // such as a Color, or a Variable\n //\n operand: function () {\n const entities = this.entities;\n let negate;\n\n if (parserInput.peek(/^-[@\\$\\(]/)) {\n negate = parserInput.$char('-');\n }\n\n let o = this.sub() || entities.dimension() ||\n entities.color() || entities.variable() ||\n entities.property() || entities.call() ||\n entities.quoted(true) || entities.colorKeyword() ||\n entities.mixinLookup();\n\n if (negate) {\n o.parensInOp = true;\n o = new(tree.Negative)(o);\n }\n\n return o;\n },\n\n //\n // Expressions either represent mathematical operations,\n // or white-space delimited Entities.\n //\n // 1px solid black\n // @var * 2\n //\n expression: function () {\n const entities = [];\n let e;\n let delim;\n const index = parserInput.i;\n\n do {\n e = this.comment();\n if (e) {\n entities.push(e);\n continue;\n }\n e = this.addition() || this.entity();\n\n if (e instanceof tree.Comment) {\n e = null;\n }\n\n if (e) {\n entities.push(e);\n // operations do not allow keyword \"/\" dimension (e.g. small/20px) so we support that here\n if (!parserInput.peek(/^\\/[\\/*]/)) {\n delim = parserInput.$char('/');\n if (delim) {\n entities.push(new(tree.Anonymous)(delim, index));\n }\n }\n }\n } while (e);\n if (entities.length > 0) {\n return new(tree.Expression)(entities);\n }\n },\n property: function () {\n const name = parserInput.$re(/^(\\*?-?[_a-zA-Z0-9-]+)\\s*:/);\n if (name) {\n return name[1];\n }\n },\n ruleProperty: function () {\n let name = [];\n const index = [];\n let s;\n let k;\n\n parserInput.save();\n\n const simpleProperty = parserInput.$re(/^([_a-zA-Z0-9-]+)\\s*:/);\n if (simpleProperty) {\n name = [new(tree.Keyword)(simpleProperty[1])];\n parserInput.forget();\n return name;\n }\n\n function match(re) {\n const i = parserInput.i;\n const chunk = parserInput.$re(re);\n if (chunk) {\n index.push(i);\n return name.push(chunk[1]);\n }\n }\n\n match(/^(\\*?)/);\n while (true) {\n if (!match(/^((?:[\\w-]+)|(?:[@\\$]\\{[\\w-]+\\}))/)) {\n break;\n }\n }\n\n if ((name.length > 1) && match(/^((?:\\+_|\\+)?)\\s*:/)) {\n parserInput.forget();\n\n // at last, we have the complete match now. move forward,\n // convert name particles to tree objects and return:\n if (name[0] === '') {\n name.shift();\n index.shift();\n }\n for (k = 0; k < name.length; k++) {\n s = name[k];\n name[k] = (s.charAt(0) !== '@' && s.charAt(0) !== '$') ?\n new(tree.Keyword)(s) :\n (s.charAt(0) === '@' ?\n new(tree.Variable)(`@${s.slice(2, -1)}`, index[k], fileInfo) :\n new(tree.Property)(`$${s.slice(2, -1)}`, index[k], fileInfo));\n }\n return name;\n }\n parserInput.restore();\n }\n }\n };\n};\nParser.serializeVars = vars => {\n let s = '';\n\n for (const name in vars) {\n if (Object.hasOwnProperty.call(vars, name)) {\n const value = vars[name];\n s += `${((name[0] === '@') ? '' : '@') + name}: ${value}${(String(value).slice(-1) === ';') ? '' : ';'}`;\n }\n }\n\n return s;\n};\n\nexport default Parser;\n","import Anonymous from '../tree/anonymous';\nimport Keyword from '../tree/keyword';\n\nfunction boolean(condition) {\n return condition ? Keyword.True : Keyword.False;\n}\n\n/**\n * Functions with evalArgs set to false are sent context\n * as the first argument.\n */\nfunction If(context, condition, trueValue, falseValue) {\n return condition.eval(context) ? trueValue.eval(context)\n : (falseValue ? falseValue.eval(context) : new Anonymous);\n}\nIf.evalArgs = false\n\nexport default { boolean, 'if': If };\n","import Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nlet colorFunctions;\n\nfunction clamp(val) {\n return Math.min(1, Math.max(0, val));\n}\nfunction hsla(origColor, hsl) {\n const color = colorFunctions.hsla(hsl.h, hsl.s, hsl.l, hsl.a);\n if (color) {\n if (origColor.value && \n /^(rgb|hsl)/.test(origColor.value)) {\n color.value = origColor.value;\n } else {\n color.value = 'rgb';\n }\n return color;\n }\n}\nfunction toHSL(color) {\n if (color.toHSL) {\n return color.toHSL();\n } else {\n throw new Error('Argument cannot be evaluated to a color');\n }\n}\n\nfunction toHSV(color) {\n if (color.toHSV) {\n return color.toHSV();\n } else {\n throw new Error('Argument cannot be evaluated to a color');\n }\n}\n\nfunction number(n) {\n if (n instanceof Dimension) {\n return parseFloat(n.unit.is('%') ? n.value / 100 : n.value);\n } else if (typeof n === 'number') {\n return n;\n } else {\n throw {\n type: 'Argument',\n message: 'color functions take numbers as parameters'\n };\n }\n}\nfunction scaled(n, size) {\n if (n instanceof Dimension && n.unit.is('%')) {\n return parseFloat(n.value * size / 100);\n } else {\n return number(n);\n }\n}\ncolorFunctions = {\n rgb: function (r, g, b) {\n const color = colorFunctions.rgba(r, g, b, 1.0);\n if (color) {\n color.value = 'rgb';\n return color;\n }\n },\n rgba: function (r, g, b, a) {\n try {\n if (r instanceof Color) {\n if (g) {\n a = number(g);\n } else {\n a = r.alpha;\n }\n return new Color(r.rgb, a, 'rgba');\n }\n const rgb = [r, g, b].map(c => scaled(c, 255));\n a = number(a);\n return new Color(rgb, a, 'rgba');\n }\n catch (e) {}\n },\n hsl: function (h, s, l) {\n const color = colorFunctions.hsla(h, s, l, 1.0);\n if (color) {\n color.value = 'hsl';\n return color;\n }\n },\n hsla: function (h, s, l, a) {\n try {\n if (h instanceof Color) {\n if (s) {\n a = number(s);\n } else {\n a = h.alpha;\n }\n return new Color(h.rgb, a, 'hsla');\n }\n\n let m1;\n let m2;\n\n function hue(h) {\n h = h < 0 ? h + 1 : (h > 1 ? h - 1 : h);\n if (h * 6 < 1) {\n return m1 + (m2 - m1) * h * 6;\n }\n else if (h * 2 < 1) {\n return m2;\n }\n else if (h * 3 < 2) {\n return m1 + (m2 - m1) * (2 / 3 - h) * 6;\n }\n else {\n return m1;\n }\n }\n\n h = (number(h) % 360) / 360;\n s = clamp(number(s));l = clamp(number(l));a = clamp(number(a));\n\n m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n m1 = l * 2 - m2;\n\n const rgb = [\n hue(h + 1 / 3) * 255,\n hue(h) * 255,\n hue(h - 1 / 3) * 255\n ];\n a = number(a);\n return new Color(rgb, a, 'hsla');\n }\n catch (e) {}\n },\n\n hsv: function(h, s, v) {\n return colorFunctions.hsva(h, s, v, 1.0);\n },\n\n hsva: function(h, s, v, a) {\n h = ((number(h) % 360) / 360) * 360;\n s = number(s);v = number(v);a = number(a);\n\n let i;\n let f;\n i = Math.floor((h / 60) % 6);\n f = (h / 60) - i;\n\n const vs = [v,\n v * (1 - s),\n v * (1 - f * s),\n v * (1 - (1 - f) * s)];\n const perm = [[0, 3, 1],\n [2, 0, 1],\n [1, 0, 3],\n [1, 2, 0],\n [3, 1, 0],\n [0, 1, 2]];\n\n return colorFunctions.rgba(vs[perm[i][0]] * 255,\n vs[perm[i][1]] * 255,\n vs[perm[i][2]] * 255,\n a);\n },\n\n hue: function (color) {\n return new Dimension(toHSL(color).h);\n },\n saturation: function (color) {\n return new Dimension(toHSL(color).s * 100, '%');\n },\n lightness: function (color) {\n return new Dimension(toHSL(color).l * 100, '%');\n },\n hsvhue: function(color) {\n return new Dimension(toHSV(color).h);\n },\n hsvsaturation: function (color) {\n return new Dimension(toHSV(color).s * 100, '%');\n },\n hsvvalue: function (color) {\n return new Dimension(toHSV(color).v * 100, '%');\n },\n red: function (color) {\n return new Dimension(color.rgb[0]);\n },\n green: function (color) {\n return new Dimension(color.rgb[1]);\n },\n blue: function (color) {\n return new Dimension(color.rgb[2]);\n },\n alpha: function (color) {\n return new Dimension(toHSL(color).a);\n },\n luma: function (color) {\n return new Dimension(color.luma() * color.alpha * 100, '%');\n },\n luminance: function (color) {\n const luminance =\n (0.2126 * color.rgb[0] / 255) +\n (0.7152 * color.rgb[1] / 255) +\n (0.0722 * color.rgb[2] / 255);\n\n return new Dimension(luminance * color.alpha * 100, '%');\n },\n saturate: function (color, amount, method) {\n // filter: saturate(3.2);\n // should be kept as is, so check for color\n if (!color.rgb) {\n return null;\n }\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.s += hsl.s * amount.value / 100;\n }\n else {\n hsl.s += amount.value / 100;\n }\n hsl.s = clamp(hsl.s);\n return hsla(color, hsl);\n },\n desaturate: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.s -= hsl.s * amount.value / 100;\n }\n else {\n hsl.s -= amount.value / 100;\n }\n hsl.s = clamp(hsl.s);\n return hsla(color, hsl);\n },\n lighten: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.l += hsl.l * amount.value / 100;\n }\n else {\n hsl.l += amount.value / 100;\n }\n hsl.l = clamp(hsl.l);\n return hsla(color, hsl);\n },\n darken: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.l -= hsl.l * amount.value / 100;\n }\n else {\n hsl.l -= amount.value / 100;\n }\n hsl.l = clamp(hsl.l);\n return hsla(color, hsl);\n },\n fadein: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.a += hsl.a * amount.value / 100;\n }\n else {\n hsl.a += amount.value / 100;\n }\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n fadeout: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.a -= hsl.a * amount.value / 100;\n }\n else {\n hsl.a -= amount.value / 100;\n }\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n fade: function (color, amount) {\n const hsl = toHSL(color);\n\n hsl.a = amount.value / 100;\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n spin: function (color, amount) {\n const hsl = toHSL(color);\n const hue = (hsl.h + amount.value) % 360;\n\n hsl.h = hue < 0 ? 360 + hue : hue;\n\n return hsla(color, hsl);\n },\n //\n // Copyright (c) 2006-2009 Hampton Catlin, Natalie Weizenbaum, and Chris Eppstein\n // http://sass-lang.com\n //\n mix: function (color1, color2, weight) {\n if (!weight) {\n weight = new Dimension(50);\n }\n const p = weight.value / 100.0;\n const w = p * 2 - 1;\n const a = toHSL(color1).a - toHSL(color2).a;\n\n const w1 = (((w * a == -1) ? w : (w + a) / (1 + w * a)) + 1) / 2.0;\n const w2 = 1 - w1;\n\n const rgb = [color1.rgb[0] * w1 + color2.rgb[0] * w2,\n color1.rgb[1] * w1 + color2.rgb[1] * w2,\n color1.rgb[2] * w1 + color2.rgb[2] * w2];\n\n const alpha = color1.alpha * p + color2.alpha * (1 - p);\n\n return new Color(rgb, alpha);\n },\n greyscale: function (color) {\n return colorFunctions.desaturate(color, new Dimension(100));\n },\n contrast: function (color, dark, light, threshold) {\n // filter: contrast(3.2);\n // should be kept as is, so check for color\n if (!color.rgb) {\n return null;\n }\n if (typeof light === 'undefined') {\n light = colorFunctions.rgba(255, 255, 255, 1.0);\n }\n if (typeof dark === 'undefined') {\n dark = colorFunctions.rgba(0, 0, 0, 1.0);\n }\n // Figure out which is actually light and dark:\n if (dark.luma() > light.luma()) {\n const t = light;\n light = dark;\n dark = t;\n }\n if (typeof threshold === 'undefined') {\n threshold = 0.43;\n } else {\n threshold = number(threshold);\n }\n if (color.luma() < threshold) {\n return light;\n } else {\n return dark;\n }\n },\n // Changes made in 2.7.0 - Reverted in 3.0.0\n // contrast: function (color, color1, color2, threshold) {\n // // Return which of `color1` and `color2` has the greatest contrast with `color`\n // // according to the standard WCAG contrast ratio calculation.\n // // http://www.w3.org/TR/WCAG20/#contrast-ratiodef\n // // The threshold param is no longer used, in line with SASS.\n // // filter: contrast(3.2);\n // // should be kept as is, so check for color\n // if (!color.rgb) {\n // return null;\n // }\n // if (typeof color1 === 'undefined') {\n // color1 = colorFunctions.rgba(0, 0, 0, 1.0);\n // }\n // if (typeof color2 === 'undefined') {\n // color2 = colorFunctions.rgba(255, 255, 255, 1.0);\n // }\n // var contrast1, contrast2;\n // var luma = color.luma();\n // var luma1 = color1.luma();\n // var luma2 = color2.luma();\n // // Calculate contrast ratios for each color\n // if (luma > luma1) {\n // contrast1 = (luma + 0.05) / (luma1 + 0.05);\n // } else {\n // contrast1 = (luma1 + 0.05) / (luma + 0.05);\n // }\n // if (luma > luma2) {\n // contrast2 = (luma + 0.05) / (luma2 + 0.05);\n // } else {\n // contrast2 = (luma2 + 0.05) / (luma + 0.05);\n // }\n // if (contrast1 > contrast2) {\n // return color1;\n // } else {\n // return color2;\n // }\n // },\n argb: function (color) {\n return new Anonymous(color.toARGB());\n },\n color: function(c) {\n if ((c instanceof Quoted) &&\n (/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})$/i.test(c.value))) {\n const val = c.value.slice(1);\n return new Color(val, undefined, `#${val}`);\n }\n if ((c instanceof Color) || (c = Color.fromKeyword(c.value))) {\n c.value = undefined;\n return c;\n }\n throw {\n type: 'Argument',\n message: 'argument must be a color keyword or 3|4|6|8 digit hex e.g. #FFF'\n };\n },\n tint: function(color, amount) {\n return colorFunctions.mix(colorFunctions.rgb(255, 255, 255), color, amount);\n },\n shade: function(color, amount) {\n return colorFunctions.mix(colorFunctions.rgb(0, 0, 0), color, amount);\n }\n};\n\nexport default colorFunctions;\n","import Color from '../tree/color';\n\n// Color Blending\n// ref: http://www.w3.org/TR/compositing-1\n\nfunction colorBlend(mode, color1, color2) {\n const ab = color1.alpha; // result\n\n let // backdrop\n cb;\n\n const as = color2.alpha;\n\n let // source\n cs;\n\n let ar;\n let cr;\n const r = [];\n\n ar = as + ab * (1 - as);\n for (let i = 0; i < 3; i++) {\n cb = color1.rgb[i] / 255;\n cs = color2.rgb[i] / 255;\n cr = mode(cb, cs);\n if (ar) {\n cr = (as * cs + ab * (cb -\n as * (cb + cs - cr))) / ar;\n }\n r[i] = cr * 255;\n }\n\n return new Color(r, ar);\n}\n\nconst colorBlendModeFunctions = {\n multiply: function(cb, cs) {\n return cb * cs;\n },\n screen: function(cb, cs) {\n return cb + cs - cb * cs;\n },\n overlay: function(cb, cs) {\n cb *= 2;\n return (cb <= 1) ?\n colorBlendModeFunctions.multiply(cb, cs) :\n colorBlendModeFunctions.screen(cb - 1, cs);\n },\n softlight: function(cb, cs) {\n let d = 1;\n let e = cb;\n if (cs > 0.5) {\n e = 1;\n d = (cb > 0.25) ? Math.sqrt(cb)\n : ((16 * cb - 12) * cb + 4) * cb;\n }\n return cb - (1 - 2 * cs) * e * (d - cb);\n },\n hardlight: function(cb, cs) {\n return colorBlendModeFunctions.overlay(cs, cb);\n },\n difference: function(cb, cs) {\n return Math.abs(cb - cs);\n },\n exclusion: function(cb, cs) {\n return cb + cs - 2 * cb * cs;\n },\n\n // non-w3c functions:\n average: function(cb, cs) {\n return (cb + cs) / 2;\n },\n negation: function(cb, cs) {\n return 1 - Math.abs(cb + cs - 1);\n }\n};\n\nfor (const f in colorBlendModeFunctions) {\n if (colorBlendModeFunctions.hasOwnProperty(f)) {\n colorBlend[f] = colorBlend.bind(null, colorBlendModeFunctions[f]);\n }\n}\n\nexport default colorBlend;\n","import Comment from '../tree/comment';\nimport Node from '../tree/node';\nimport Dimension from '../tree/dimension';\nimport Declaration from '../tree/declaration';\nimport Expression from '../tree/expression';\nimport Ruleset from '../tree/ruleset';\nimport Selector from '../tree/selector';\nimport Element from '../tree/element';\nimport Quote from '../tree/quoted';\n\nconst getItemsFromNode = node => {\n // handle non-array values as an array of length 1\n // return 'undefined' if index is invalid\n const items = Array.isArray(node.value) ?\n node.value : Array(node);\n\n return items;\n};\n\nexport default {\n _SELF: function(n) {\n return n;\n },\n extract: function(values, index) {\n // (1-based index)\n index = index.value - 1;\n\n return getItemsFromNode(values)[index];\n },\n length: function(values) {\n return new Dimension(getItemsFromNode(values).length);\n },\n /**\n * Creates a Less list of incremental values.\n * Modeled after Lodash's range function, also exists natively in PHP\n * \n * @param {Dimension} [start=1]\n * @param {Dimension} end - e.g. 10 or 10px - unit is added to output\n * @param {Dimension} [step=1] \n */\n range: function(start, end, step) {\n let from;\n let to;\n let stepValue = 1;\n const list = [];\n if (end) {\n to = end;\n from = start.value;\n if (step) {\n stepValue = step.value;\n }\n }\n else {\n from = 1;\n to = start;\n }\n\n for (let i = from; i <= to.value; i += stepValue) {\n list.push(new Dimension(i, to.unit));\n }\n\n return new Expression(list);\n },\n each: function(list, rs) {\n const rules = [];\n let newRules;\n let iterator;\n\n const tryEval = val => {\n if (val instanceof Node) {\n return val.eval(this.context);\n }\n return val;\n };\n\n if (list.value && !(list instanceof Quote)) {\n if (Array.isArray(list.value)) {\n iterator = list.value.map(tryEval);\n } else {\n iterator = [tryEval(list.value)];\n }\n } else if (list.ruleset) {\n iterator = tryEval(list.ruleset).rules;\n } else if (list.rules) {\n iterator = list.rules.map(tryEval);\n } else if (Array.isArray(list)) {\n iterator = list.map(tryEval);\n } else {\n iterator = [tryEval(list)];\n }\n\n let valueName = '@value';\n let keyName = '@key';\n let indexName = '@index';\n\n if (rs.params) {\n valueName = rs.params[0] && rs.params[0].name;\n keyName = rs.params[1] && rs.params[1].name;\n indexName = rs.params[2] && rs.params[2].name;\n rs = rs.rules;\n } else {\n rs = rs.ruleset;\n }\n\n for (let i = 0; i < iterator.length; i++) {\n let key;\n let value;\n const item = iterator[i];\n if (item instanceof Declaration) {\n key = typeof item.name === 'string' ? item.name : item.name[0].value;\n value = item.value;\n } else {\n key = new Dimension(i + 1);\n value = item;\n }\n\n if (item instanceof Comment) {\n continue;\n }\n\n newRules = rs.rules.slice(0);\n if (valueName) {\n newRules.push(new Declaration(valueName,\n value,\n false, false, this.index, this.currentFileInfo));\n }\n if (indexName) {\n newRules.push(new Declaration(indexName,\n new Dimension(i + 1),\n false, false, this.index, this.currentFileInfo));\n }\n if (keyName) {\n newRules.push(new Declaration(keyName,\n key,\n false, false, this.index, this.currentFileInfo));\n }\n\n rules.push(new Ruleset([ new(Selector)([ new Element(\"\", '&') ]) ],\n newRules,\n rs.strictImports,\n rs.visibilityInfo()\n ));\n }\n\n return new Ruleset([ new(Selector)([ new Element(\"\", '&') ]) ],\n rules,\n rs.strictImports,\n rs.visibilityInfo()\n ).eval(this.context);\n }\n};\n","import Dimension from '../tree/dimension';\n\nconst MathHelper = (fn, unit, n) => {\n if (!(n instanceof Dimension)) {\n throw { type: 'Argument', message: 'argument must be a number' };\n }\n if (unit == null) {\n unit = n.unit;\n } else {\n n = n.unify();\n }\n return new Dimension(fn(parseFloat(n.value)), unit);\n};\n\nexport default MathHelper;","import mathHelper from './math-helper.js';\n\nconst mathFunctions = {\n // name, unit\n ceil: null,\n floor: null,\n sqrt: null,\n abs: null,\n tan: '',\n sin: '',\n cos: '',\n atan: 'rad',\n asin: 'rad',\n acos: 'rad'\n};\n\nfor (const f in mathFunctions) {\n if (mathFunctions.hasOwnProperty(f)) {\n mathFunctions[f] = mathHelper.bind(null, Math[f], mathFunctions[f]);\n }\n}\n\nmathFunctions.round = (n, f) => {\n const fraction = typeof f === 'undefined' ? 0 : f.value;\n return mathHelper(num => num.toFixed(fraction), null, n);\n};\n\nexport default mathFunctions;\n","import Dimension from '../tree/dimension';\nimport Anonymous from '../tree/anonymous';\nimport mathHelper from './math-helper.js';\n\nconst minMax = function (isMin, args) {\n args = Array.prototype.slice.call(args);\n switch (args.length) {\n case 0: throw { type: 'Argument', message: 'one or more arguments required' };\n }\n let i; // key is the unit.toString() for unified Dimension values,\n let j;\n let current;\n let currentUnified;\n let referenceUnified;\n let unit;\n let unitStatic;\n let unitClone;\n\n const // elems only contains original argument values.\n order = [];\n\n const values = {};\n // value is the index into the order array.\n for (i = 0; i < args.length; i++) {\n current = args[i];\n if (!(current instanceof Dimension)) {\n if (Array.isArray(args[i].value)) {\n Array.prototype.push.apply(args, Array.prototype.slice.call(args[i].value));\n }\n continue;\n }\n currentUnified = current.unit.toString() === '' && unitClone !== undefined ? new Dimension(current.value, unitClone).unify() : current.unify();\n unit = currentUnified.unit.toString() === '' && unitStatic !== undefined ? unitStatic : currentUnified.unit.toString();\n unitStatic = unit !== '' && unitStatic === undefined || unit !== '' && order[0].unify().unit.toString() === '' ? unit : unitStatic;\n unitClone = unit !== '' && unitClone === undefined ? current.unit.toString() : unitClone;\n j = values[''] !== undefined && unit !== '' && unit === unitStatic ? values[''] : values[unit];\n if (j === undefined) {\n if (unitStatic !== undefined && unit !== unitStatic) {\n throw { type: 'Argument', message: 'incompatible types' };\n }\n values[unit] = order.length;\n order.push(current);\n continue;\n }\n referenceUnified = order[j].unit.toString() === '' && unitClone !== undefined ? new Dimension(order[j].value, unitClone).unify() : order[j].unify();\n if ( isMin && currentUnified.value < referenceUnified.value ||\n !isMin && currentUnified.value > referenceUnified.value) {\n order[j] = current;\n }\n }\n if (order.length == 1) {\n return order[0];\n }\n args = order.map(function (a) { return a.toCSS(this.context); }).join(this.context.compress ? ',' : ', ');\n return new Anonymous(`${isMin ? 'min' : 'max'}(${args})`);\n};\n\nexport default {\n min: function(...args) {\n return minMax(true, args);\n },\n max: function(...args) {\n return minMax(false, args);\n },\n convert: function (val, unit) {\n return val.convertTo(unit.value);\n },\n pi: function () {\n return new Dimension(Math.PI);\n },\n mod: function(a, b) {\n return new Dimension(a.value % b.value, a.unit);\n },\n pow: function(x, y) {\n if (typeof x === 'number' && typeof y === 'number') {\n x = new Dimension(x);\n y = new Dimension(y);\n } else if (!(x instanceof Dimension) || !(y instanceof Dimension)) {\n throw { type: 'Argument', message: 'arguments must be numbers' };\n }\n\n return new Dimension(Math.pow(x.value, y.value), x.unit);\n },\n percentage: function (n) {\n const result = mathHelper(num => num * 100, '%', n);\n\n return result;\n }\n};\n","import Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nimport JavaScript from '../tree/javascript';\n\nexport default {\n e: function (str) {\n return new Quoted('\"', str instanceof JavaScript ? str.evaluated : str.value, true);\n },\n escape: function (str) {\n return new Anonymous(\n encodeURI(str.value).replace(/=/g, '%3D').replace(/:/g, '%3A').replace(/#/g, '%23').replace(/;/g, '%3B')\n .replace(/\\(/g, '%28').replace(/\\)/g, '%29'));\n },\n replace: function (string, pattern, replacement, flags) {\n let result = string.value;\n replacement = (replacement.type === 'Quoted') ?\n replacement.value : replacement.toCSS();\n result = result.replace(new RegExp(pattern.value, flags ? flags.value : ''), replacement);\n return new Quoted(string.quote || '', result, string.escaped);\n },\n '%': function (string /* arg, arg, ... */) {\n const args = Array.prototype.slice.call(arguments, 1);\n let result = string.value;\n\n for (let i = 0; i < args.length; i++) {\n /* jshint loopfunc:true */\n result = result.replace(/%[sda]/i, token => {\n const value = ((args[i].type === 'Quoted') &&\n token.match(/s/i)) ? args[i].value : args[i].toCSS();\n return token.match(/[A-Z]$/) ? encodeURIComponent(value) : value;\n });\n }\n result = result.replace(/%%/g, '%');\n return new Quoted(string.quote || '', result, string.escaped);\n }\n};\n","import Keyword from '../tree/keyword';\nimport DetachedRuleset from '../tree/detached-ruleset';\nimport Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nimport URL from '../tree/url';\nimport Operation from '../tree/operation';\n\nconst isa = (n, Type) => (n instanceof Type) ? Keyword.True : Keyword.False;\nconst isunit = (n, unit) => {\n if (unit === undefined) {\n throw { type: 'Argument', message: 'missing the required second argument to isunit.' };\n }\n unit = typeof unit.value === 'string' ? unit.value : unit;\n if (typeof unit !== 'string') {\n throw { type: 'Argument', message: 'Second argument to isunit should be a unit or a string.' };\n }\n return (n instanceof Dimension) && n.unit.is(unit) ? Keyword.True : Keyword.False;\n};\n\nexport default {\n isruleset: function (n) {\n return isa(n, DetachedRuleset);\n },\n iscolor: function (n) {\n return isa(n, Color);\n },\n isnumber: function (n) {\n return isa(n, Dimension);\n },\n isstring: function (n) {\n return isa(n, Quoted);\n },\n iskeyword: function (n) {\n return isa(n, Keyword);\n },\n isurl: function (n) {\n return isa(n, URL);\n },\n ispixel: function (n) {\n return isunit(n, 'px');\n },\n ispercentage: function (n) {\n return isunit(n, '%');\n },\n isem: function (n) {\n return isunit(n, 'em');\n },\n isunit,\n unit: function (val, unit) {\n if (!(val instanceof Dimension)) {\n throw { type: 'Argument',\n message: `the first argument to unit must be a number${val instanceof Operation ? '. Have you forgotten parenthesis?' : ''}` };\n }\n if (unit) {\n if (unit instanceof Keyword) {\n unit = unit.value;\n } else {\n unit = unit.toCSS();\n }\n } else {\n unit = '';\n }\n return new Dimension(val.value, unit);\n },\n 'get-unit': function (n) {\n return new Anonymous(n.unit);\n }\n};\n","import functionRegistry from './function-registry';\nimport functionCaller from './function-caller';\n\nimport boolean from './boolean';\nimport defaultFunc from './default';\nimport color from './color';\nimport colorBlending from './color-blending';\nimport dataUri from './data-uri';\nimport list from './list';\nimport math from './math';\nimport number from './number';\nimport string from './string';\nimport svg from './svg';\nimport types from './types';\n\nexport default environment => {\n const functions = { functionRegistry, functionCaller };\n\n // register functions\n functionRegistry.addMultiple(boolean);\n functionRegistry.add('default', defaultFunc.eval.bind(defaultFunc));\n functionRegistry.addMultiple(color);\n functionRegistry.addMultiple(colorBlending);\n functionRegistry.addMultiple(dataUri(environment));\n functionRegistry.addMultiple(list);\n functionRegistry.addMultiple(math);\n functionRegistry.addMultiple(number);\n functionRegistry.addMultiple(string);\n functionRegistry.addMultiple(svg(environment));\n functionRegistry.addMultiple(types);\n\n return functions;\n};\n","import Quoted from '../tree/quoted';\nimport URL from '../tree/url';\nimport * as utils from '../utils';\nimport logger from '../logger';\n\nexport default environment => {\n \n const fallback = (functionThis, node) => new URL(node, functionThis.index, functionThis.currentFileInfo).eval(functionThis.context); \n\n return { 'data-uri': function(mimetypeNode, filePathNode) {\n\n if (!filePathNode) {\n filePathNode = mimetypeNode;\n mimetypeNode = null;\n }\n\n let mimetype = mimetypeNode && mimetypeNode.value;\n let filePath = filePathNode.value;\n const currentFileInfo = this.currentFileInfo;\n const currentDirectory = currentFileInfo.rewriteUrls ?\n currentFileInfo.currentDirectory : currentFileInfo.entryPath;\n\n const fragmentStart = filePath.indexOf('#');\n let fragment = '';\n if (fragmentStart !== -1) {\n fragment = filePath.slice(fragmentStart);\n filePath = filePath.slice(0, fragmentStart);\n }\n const context = utils.clone(this.context);\n context.rawBuffer = true;\n\n const fileManager = environment.getFileManager(filePath, currentDirectory, context, environment, true);\n\n if (!fileManager) {\n return fallback(this, filePathNode);\n }\n\n let useBase64 = false;\n\n // detect the mimetype if not given\n if (!mimetypeNode) {\n\n mimetype = environment.mimeLookup(filePath);\n\n if (mimetype === 'image/svg+xml') {\n useBase64 = false;\n } else {\n // use base 64 unless it's an ASCII or UTF-8 format\n const charset = environment.charsetLookup(mimetype);\n useBase64 = ['US-ASCII', 'UTF-8'].indexOf(charset) < 0;\n }\n if (useBase64) { mimetype += ';base64'; }\n }\n else {\n useBase64 = /;base64$/.test(mimetype);\n }\n\n const fileSync = fileManager.loadFileSync(filePath, currentDirectory, context, environment);\n if (!fileSync.contents) {\n logger.warn(`Skipped data-uri embedding of ${filePath} because file not found`);\n return fallback(this, filePathNode || mimetypeNode);\n }\n let buf = fileSync.contents;\n if (useBase64 && !environment.encodeBase64) {\n return fallback(this, filePathNode);\n }\n\n buf = useBase64 ? environment.encodeBase64(buf) : encodeURIComponent(buf);\n\n const uri = `data:${mimetype},${buf}${fragment}`;\n\n return new URL(new Quoted(`\"${uri}\"`, uri, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo);\n }};\n};\n","import Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Expression from '../tree/expression';\nimport Quoted from '../tree/quoted';\nimport URL from '../tree/url';\n\nexport default environment => {\n return { 'svg-gradient': function(direction) {\n let stops;\n let gradientDirectionSvg;\n let gradientType = 'linear';\n let rectangleDimension = 'x=\"0\" y=\"0\" width=\"1\" height=\"1\"';\n const renderEnv = {compress: false};\n let returner;\n const directionValue = direction.toCSS(renderEnv);\n let i;\n let color;\n let position;\n let positionValue;\n let alpha;\n\n function throwArgumentDescriptor() {\n throw { type: 'Argument',\n message: 'svg-gradient expects direction, start_color [start_position], [color position,]...,' +\n ' end_color [end_position] or direction, color list' };\n }\n\n if (arguments.length == 2) {\n if (arguments[1].value.length < 2) {\n throwArgumentDescriptor();\n }\n stops = arguments[1].value;\n } else if (arguments.length < 3) {\n throwArgumentDescriptor();\n } else {\n stops = Array.prototype.slice.call(arguments, 1);\n }\n\n switch (directionValue) {\n case 'to bottom':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"0%\" y2=\"100%\"';\n break;\n case 'to right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"100%\" y2=\"0%\"';\n break;\n case 'to bottom right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"100%\" y2=\"100%\"';\n break;\n case 'to top right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"100%\" x2=\"100%\" y2=\"0%\"';\n break;\n case 'ellipse':\n case 'ellipse at center':\n gradientType = 'radial';\n gradientDirectionSvg = 'cx=\"50%\" cy=\"50%\" r=\"75%\"';\n rectangleDimension = 'x=\"-50\" y=\"-50\" width=\"101\" height=\"101\"';\n break;\n default:\n throw { type: 'Argument', message: 'svg-gradient direction must be \\'to bottom\\', \\'to right\\',' +\n ' \\'to bottom right\\', \\'to top right\\' or \\'ellipse at center\\'' };\n }\n returner = `<${gradientType}Gradient id=\"g\" ${gradientDirectionSvg}>`;\n\n for (i = 0; i < stops.length; i += 1) {\n if (stops[i] instanceof Expression) {\n color = stops[i].value[0];\n position = stops[i].value[1];\n } else {\n color = stops[i];\n position = undefined;\n }\n\n if (!(color instanceof Color) || (!((i === 0 || i + 1 === stops.length) && position === undefined) && !(position instanceof Dimension))) {\n throwArgumentDescriptor();\n }\n positionValue = position ? position.toCSS(renderEnv) : i === 0 ? '0%' : '100%';\n alpha = color.alpha;\n returner += ``;\n }\n returner += ``;\n\n returner = encodeURIComponent(returner);\n\n returner = `data:image/svg+xml,${returner}`;\n return new URL(new Quoted(`'${returner}'`, returner, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo);\n }};\n};\n","import contexts from './contexts';\nimport visitor from './visitors';\nimport tree from './tree';\n\nexport default (root, options = {}) => {\n let evaldRoot;\n let variables = options.variables;\n const evalEnv = new contexts.Eval(options);\n\n //\n // Allows setting variables with a hash, so:\n //\n // `{ color: new tree.Color('#f01') }` will become:\n //\n // new tree.Declaration('@color',\n // new tree.Value([\n // new tree.Expression([\n // new tree.Color('#f01')\n // ])\n // ])\n // )\n //\n if (typeof variables === 'object' && !Array.isArray(variables)) {\n variables = Object.keys(variables).map(k => {\n let value = variables[k];\n\n if (!(value instanceof tree.Value)) {\n if (!(value instanceof tree.Expression)) {\n value = new tree.Expression([value]);\n }\n value = new tree.Value([value]);\n }\n return new tree.Declaration(`@${k}`, value, false, null, 0);\n });\n evalEnv.frames = [new tree.Ruleset(null, variables)];\n }\n\n const visitors = [\n new visitor.JoinSelectorVisitor(),\n new visitor.MarkVisibleSelectorsVisitor(true),\n new visitor.ExtendVisitor(),\n new visitor.ToCSSVisitor({compress: Boolean(options.compress)})\n ];\n\n const preEvalVisitors = [];\n let v;\n let visitorIterator;\n\n /**\n * first() / get() allows visitors to be added while visiting\n * \n * @todo Add scoping for visitors just like functions for @plugin; right now they're global\n */\n if (options.pluginManager) {\n visitorIterator = options.pluginManager.visitor();\n for (var i = 0; i < 2; i++) {\n visitorIterator.first();\n while ((v = visitorIterator.get())) {\n if (v.isPreEvalVisitor) {\n if (i === 0 || preEvalVisitors.indexOf(v) === -1) {\n preEvalVisitors.push(v);\n v.run(root);\n }\n }\n else {\n if (i === 0 || visitors.indexOf(v) === -1) {\n if (v.isPreVisitor) {\n visitors.unshift(v);\n }\n else {\n visitors.push(v);\n }\n }\n }\n }\n }\n }\n\n evaldRoot = root.eval(evalEnv);\n\n for (var i = 0; i < visitors.length; i++) {\n visitors[i].run(evaldRoot);\n }\n\n // Run any remaining visitors added after eval pass\n if (options.pluginManager) {\n visitorIterator.first();\n while ((v = visitorIterator.get())) {\n if (visitors.indexOf(v) === -1 && preEvalVisitors.indexOf(v) === -1) {\n v.run(evaldRoot);\n }\n }\n }\n\n return evaldRoot;\n};\n","/**\n * Plugin Manager\n */\nclass PluginManager {\n constructor(less) {\n this.less = less;\n this.visitors = [];\n this.preProcessors = [];\n this.postProcessors = [];\n this.installedPlugins = [];\n this.fileManagers = [];\n this.iterator = -1;\n this.pluginCache = {};\n this.Loader = new less.PluginLoader(less);\n }\n\n /**\n * Adds all the plugins in the array\n * @param {Array} plugins\n */\n addPlugins(plugins) {\n if (plugins) {\n for (let i = 0; i < plugins.length; i++) {\n this.addPlugin(plugins[i]);\n }\n }\n }\n\n /**\n *\n * @param plugin\n * @param {String} filename\n */\n addPlugin(plugin, filename, functionRegistry) {\n this.installedPlugins.push(plugin);\n if (filename) {\n this.pluginCache[filename] = plugin;\n }\n if (plugin.install) {\n plugin.install(this.less, this, functionRegistry || this.less.functions.functionRegistry);\n }\n }\n\n /**\n *\n * @param filename\n */\n get(filename) {\n return this.pluginCache[filename];\n }\n\n /**\n * Adds a visitor. The visitor object has options on itself to determine\n * when it should run.\n * @param visitor\n */\n addVisitor(visitor) {\n this.visitors.push(visitor);\n }\n\n /**\n * Adds a pre processor object\n * @param {object} preProcessor\n * @param {number} priority - guidelines 1 = before import, 1000 = import, 2000 = after import\n */\n addPreProcessor(preProcessor, priority) {\n let indexToInsertAt;\n for (indexToInsertAt = 0; indexToInsertAt < this.preProcessors.length; indexToInsertAt++) {\n if (this.preProcessors[indexToInsertAt].priority >= priority) {\n break;\n }\n }\n this.preProcessors.splice(indexToInsertAt, 0, {preProcessor, priority});\n }\n\n /**\n * Adds a post processor object\n * @param {object} postProcessor\n * @param {number} priority - guidelines 1 = before compression, 1000 = compression, 2000 = after compression\n */\n addPostProcessor(postProcessor, priority) {\n let indexToInsertAt;\n for (indexToInsertAt = 0; indexToInsertAt < this.postProcessors.length; indexToInsertAt++) {\n if (this.postProcessors[indexToInsertAt].priority >= priority) {\n break;\n }\n }\n this.postProcessors.splice(indexToInsertAt, 0, {postProcessor, priority});\n }\n\n /**\n *\n * @param manager\n */\n addFileManager(manager) {\n this.fileManagers.push(manager);\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getPreProcessors() {\n const preProcessors = [];\n for (let i = 0; i < this.preProcessors.length; i++) {\n preProcessors.push(this.preProcessors[i].preProcessor);\n }\n return preProcessors;\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getPostProcessors() {\n const postProcessors = [];\n for (let i = 0; i < this.postProcessors.length; i++) {\n postProcessors.push(this.postProcessors[i].postProcessor);\n }\n return postProcessors;\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getVisitors() {\n return this.visitors;\n }\n\n visitor() {\n const self = this;\n return {\n first: function() {\n self.iterator = -1;\n return self.visitors[self.iterator];\n },\n get: function() {\n self.iterator += 1;\n return self.visitors[self.iterator];\n }\n };\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getFileManagers() {\n return this.fileManagers;\n }\n}\n\nlet pm;\n\nfunction PluginManagerFactory(less, newFactory) {\n if (newFactory || !pm) {\n pm = new PluginManager(less);\n }\n return pm;\n};\n\n//\nexport default PluginManagerFactory;\n","/* global window, XMLHttpRequest */\n\nimport AbstractFileManager from '../less/environment/abstract-file-manager.js';\n\nlet options;\nlet logger;\nlet fileCache = {};\n\n// TODOS - move log somewhere. pathDiff and doing something similar in node. use pathDiff in the other browser file for the initial load\nclass FileManager extends AbstractFileManager {\n alwaysMakePathsAbsolute() {\n return true;\n }\n\n join(basePath, laterPath) {\n if (!basePath) {\n return laterPath;\n }\n return this.extractUrlParts(laterPath, basePath).path;\n }\n\n doXHR(url, type, callback, errback) {\n const xhr = new XMLHttpRequest();\n const async = options.isFileProtocol ? options.fileAsync : true;\n\n if (typeof xhr.overrideMimeType === 'function') {\n xhr.overrideMimeType('text/css');\n }\n logger.debug(`XHR: Getting '${url}'`);\n xhr.open('GET', url, async);\n xhr.setRequestHeader('Accept', type || 'text/x-less, text/css; q=0.9, */*; q=0.5');\n xhr.send(null);\n\n function handleResponse(xhr, callback, errback) {\n if (xhr.status >= 200 && xhr.status < 300) {\n callback(xhr.responseText,\n xhr.getResponseHeader('Last-Modified'));\n } else if (typeof errback === 'function') {\n errback(xhr.status, url);\n }\n }\n\n if (options.isFileProtocol && !options.fileAsync) {\n if (xhr.status === 0 || (xhr.status >= 200 && xhr.status < 300)) {\n callback(xhr.responseText);\n } else {\n errback(xhr.status, url);\n }\n } else if (async) {\n xhr.onreadystatechange = () => {\n if (xhr.readyState == 4) {\n handleResponse(xhr, callback, errback);\n }\n };\n } else {\n handleResponse(xhr, callback, errback);\n }\n }\n\n supports() {\n return true;\n }\n\n clearFileCache() {\n fileCache = {};\n }\n\n loadFile(filename, currentDirectory, options, environment) {\n // TODO: Add prefix support like less-node?\n // What about multiple paths?\n\n if (currentDirectory && !this.isPathAbsolute(filename)) {\n filename = currentDirectory + filename;\n }\n\n filename = options.ext ? this.tryAppendExtension(filename, options.ext) : filename;\n\n options = options || {};\n\n // sheet may be set to the stylesheet for the initial load or a collection of properties including\n // some context variables for imports\n const hrefParts = this.extractUrlParts(filename, window.location.href);\n const href = hrefParts.url;\n const self = this;\n \n return new Promise((resolve, reject) => {\n if (options.useFileCache && fileCache[href]) {\n try {\n const lessText = fileCache[href];\n return resolve({ contents: lessText, filename: href, webInfo: { lastModified: new Date() }});\n } catch (e) {\n return reject({ filename: href, message: `Error loading file ${href} error was ${e.message}` });\n }\n }\n\n self.doXHR(href, options.mime, function doXHRCallback(data, lastModified) {\n // per file cache\n fileCache[href] = data;\n\n // Use remote copy (re-parse)\n resolve({ contents: data, filename: href, webInfo: { lastModified }});\n }, function doXHRError(status, url) {\n reject({ type: 'File', message: `'${url}' wasn't found (${status})`, href });\n });\n });\n }\n}\n\nexport default (opts, log) => {\n options = opts;\n logger = log;\n return FileManager;\n}\n","import data from './data';\nimport tree from './tree';\nimport Environment from './environment/environment';\nimport AbstractFileManager from './environment/abstract-file-manager';\nimport AbstractPluginLoader from './environment/abstract-plugin-loader';\nimport visitors from './visitors';\nimport Parser from './parser/parser';\nimport Functions from './functions';\nimport contexts from './contexts';\nimport sourceMapOutput from './source-map-output';\nimport sourceMapBuilder from './source-map-builder';\nimport parseTree from './parse-tree';\nimport importManager from './import-manager';\nimport Render from './render';\nimport Parse from './parse';\nimport LessError from './less-error';\nimport transformTree from './transform-tree';\nimport * as utils from './utils';\nimport PluginManager from './plugin-manager';\nimport logger from './logger';\n\nexport default (environment, fileManagers) => {\n /**\n * @todo\n * This original code could be improved quite a bit.\n * Many classes / modules currently add side-effects / mutations to passed in objects,\n * which makes it hard to refactor and reason about. \n */\n environment = new Environment(environment, fileManagers);\n\n const SourceMapOutput = sourceMapOutput(environment);\n const SourceMapBuilder = sourceMapBuilder(SourceMapOutput, environment);\n const ParseTree = parseTree(SourceMapBuilder);\n const ImportManager = importManager(environment);\n const render = Render(environment, ParseTree, ImportManager);\n const parse = Parse(environment, ParseTree, ImportManager);\n const functions = Functions(environment);\n\n /**\n * @todo\n * This root properties / methods need to be organized.\n * It's not clear what should / must be public and why.\n */\n const initial = {\n version: [3, 13, 1],\n data,\n tree,\n Environment,\n AbstractFileManager,\n AbstractPluginLoader,\n environment,\n visitors,\n Parser,\n functions,\n contexts,\n SourceMapOutput,\n SourceMapBuilder,\n ParseTree,\n ImportManager,\n render,\n parse,\n LessError,\n transformTree,\n utils,\n PluginManager,\n logger\n };\n\n // Create a public API\n const ctor = t => function (...args) {\n return new t(...args);\n };\n\n let t;\n const api = Object.create(initial);\n for (const n in initial.tree) {\n /* eslint guard-for-in: 0 */\n t = initial.tree[n];\n if (typeof t === 'function') {\n api[n.toLowerCase()] = ctor(t);\n }\n else {\n api[n] = Object.create(null);\n for (const o in t) {\n /* eslint guard-for-in: 0 */\n api[n][o.toLowerCase()] = ctor(t[o]);\n }\n }\n }\n\n /**\n * Some of the functions assume a `this` context of the API object,\n * which causes it to fail when wrapped for ES6 imports.\n * \n * An assumed `this` should be removed in the future.\n */\n initial.parse = initial.parse.bind(api);\n initial.render = initial.render.bind(api);\n\n return api;\n};\n","export default environment => {\n class SourceMapOutput {\n constructor(options) {\n this._css = [];\n this._rootNode = options.rootNode;\n this._contentsMap = options.contentsMap;\n this._contentsIgnoredCharsMap = options.contentsIgnoredCharsMap;\n if (options.sourceMapFilename) {\n this._sourceMapFilename = options.sourceMapFilename.replace(/\\\\/g, '/');\n }\n this._outputFilename = options.outputFilename;\n this.sourceMapURL = options.sourceMapURL;\n if (options.sourceMapBasepath) {\n this._sourceMapBasepath = options.sourceMapBasepath.replace(/\\\\/g, '/');\n }\n if (options.sourceMapRootpath) {\n this._sourceMapRootpath = options.sourceMapRootpath.replace(/\\\\/g, '/');\n if (this._sourceMapRootpath.charAt(this._sourceMapRootpath.length - 1) !== '/') {\n this._sourceMapRootpath += '/';\n }\n } else {\n this._sourceMapRootpath = '';\n }\n this._outputSourceFiles = options.outputSourceFiles;\n this._sourceMapGeneratorConstructor = environment.getSourceMapGenerator();\n\n this._lineNumber = 0;\n this._column = 0;\n }\n\n removeBasepath(path) {\n if (this._sourceMapBasepath && path.indexOf(this._sourceMapBasepath) === 0) {\n path = path.substring(this._sourceMapBasepath.length);\n if (path.charAt(0) === '\\\\' || path.charAt(0) === '/') {\n path = path.substring(1);\n }\n }\n\n return path;\n }\n\n normalizeFilename(filename) {\n filename = filename.replace(/\\\\/g, '/');\n filename = this.removeBasepath(filename);\n return (this._sourceMapRootpath || '') + filename;\n }\n\n add(chunk, fileInfo, index, mapLines) {\n // ignore adding empty strings\n if (!chunk) {\n return;\n }\n\n let lines;\n let sourceLines;\n let columns;\n let sourceColumns;\n let i;\n\n if (fileInfo && fileInfo.filename) {\n let inputSource = this._contentsMap[fileInfo.filename];\n\n // remove vars/banner added to the top of the file\n if (this._contentsIgnoredCharsMap[fileInfo.filename]) {\n // adjust the index\n index -= this._contentsIgnoredCharsMap[fileInfo.filename];\n if (index < 0) { index = 0; }\n // adjust the source\n inputSource = inputSource.slice(this._contentsIgnoredCharsMap[fileInfo.filename]);\n }\n\n /** \n * ignore empty content, or failsafe\n * if contents map is incorrect\n */\n if (inputSource === undefined) {\n this._css.push(chunk);\n return;\n }\n\n inputSource = inputSource.substring(0, index);\n sourceLines = inputSource.split('\\n');\n sourceColumns = sourceLines[sourceLines.length - 1];\n }\n\n lines = chunk.split('\\n');\n columns = lines[lines.length - 1];\n\n if (fileInfo && fileInfo.filename) {\n if (!mapLines) {\n this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + 1, column: this._column},\n original: { line: sourceLines.length, column: sourceColumns.length},\n source: this.normalizeFilename(fileInfo.filename)});\n } else {\n for (i = 0; i < lines.length; i++) {\n this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + i + 1, column: i === 0 ? this._column : 0},\n original: { line: sourceLines.length + i, column: i === 0 ? sourceColumns.length : 0},\n source: this.normalizeFilename(fileInfo.filename)});\n }\n }\n }\n\n if (lines.length === 1) {\n this._column += columns.length;\n } else {\n this._lineNumber += lines.length - 1;\n this._column = columns.length;\n }\n\n this._css.push(chunk);\n }\n\n isEmpty() {\n return this._css.length === 0;\n }\n\n toCSS(context) {\n this._sourceMapGenerator = new this._sourceMapGeneratorConstructor({ file: this._outputFilename, sourceRoot: null });\n\n if (this._outputSourceFiles) {\n for (const filename in this._contentsMap) {\n if (this._contentsMap.hasOwnProperty(filename)) {\n let source = this._contentsMap[filename];\n if (this._contentsIgnoredCharsMap[filename]) {\n source = source.slice(this._contentsIgnoredCharsMap[filename]);\n }\n this._sourceMapGenerator.setSourceContent(this.normalizeFilename(filename), source);\n }\n }\n }\n\n this._rootNode.genCSS(context, this);\n\n if (this._css.length > 0) {\n let sourceMapURL;\n const sourceMapContent = JSON.stringify(this._sourceMapGenerator.toJSON());\n\n if (this.sourceMapURL) {\n sourceMapURL = this.sourceMapURL;\n } else if (this._sourceMapFilename) {\n sourceMapURL = this._sourceMapFilename;\n }\n this.sourceMapURL = sourceMapURL;\n\n this.sourceMap = sourceMapContent;\n }\n\n return this._css.join('');\n }\n }\n\n return SourceMapOutput;\n};\n","export default (SourceMapOutput, environment) => {\n class SourceMapBuilder {\n constructor(options) {\n this.options = options;\n }\n\n toCSS(rootNode, options, imports) {\n const sourceMapOutput = new SourceMapOutput(\n {\n contentsIgnoredCharsMap: imports.contentsIgnoredChars,\n rootNode,\n contentsMap: imports.contents,\n sourceMapFilename: this.options.sourceMapFilename,\n sourceMapURL: this.options.sourceMapURL,\n outputFilename: this.options.sourceMapOutputFilename,\n sourceMapBasepath: this.options.sourceMapBasepath,\n sourceMapRootpath: this.options.sourceMapRootpath,\n outputSourceFiles: this.options.outputSourceFiles,\n sourceMapGenerator: this.options.sourceMapGenerator,\n sourceMapFileInline: this.options.sourceMapFileInline, \n disableSourcemapAnnotation: this.options.disableSourcemapAnnotation\n });\n\n const css = sourceMapOutput.toCSS(options);\n this.sourceMap = sourceMapOutput.sourceMap;\n this.sourceMapURL = sourceMapOutput.sourceMapURL;\n if (this.options.sourceMapInputFilename) {\n this.sourceMapInputFilename = sourceMapOutput.normalizeFilename(this.options.sourceMapInputFilename);\n }\n if (this.options.sourceMapBasepath !== undefined && this.sourceMapURL !== undefined) {\n this.sourceMapURL = sourceMapOutput.removeBasepath(this.sourceMapURL);\n }\n return css + this.getCSSAppendage();\n }\n\n getCSSAppendage() {\n\n let sourceMapURL = this.sourceMapURL;\n if (this.options.sourceMapFileInline) {\n if (this.sourceMap === undefined) {\n return '';\n }\n sourceMapURL = `data:application/json;base64,${environment.encodeBase64(this.sourceMap)}`;\n }\n\n if (this.options.disableSourcemapAnnotation) {\n return '';\n }\n\n if (sourceMapURL) {\n return `/*# sourceMappingURL=${sourceMapURL} */`;\n }\n return '';\n }\n\n getExternalSourceMap() {\n return this.sourceMap;\n }\n\n setExternalSourceMap(sourceMap) {\n this.sourceMap = sourceMap;\n }\n\n isInline() {\n return this.options.sourceMapFileInline;\n }\n\n getSourceMapURL() {\n return this.sourceMapURL;\n }\n\n getOutputFilename() {\n return this.options.sourceMapOutputFilename;\n }\n\n getInputFilename() {\n return this.sourceMapInputFilename;\n }\n }\n\n return SourceMapBuilder;\n};\n","import LessError from './less-error';\nimport transformTree from './transform-tree';\nimport logger from './logger';\n\nexport default SourceMapBuilder => {\n class ParseTree {\n constructor(root, imports) {\n this.root = root;\n this.imports = imports;\n }\n\n toCSS(options) {\n let evaldRoot;\n const result = {};\n let sourceMapBuilder;\n try {\n evaldRoot = transformTree(this.root, options);\n } catch (e) {\n throw new LessError(e, this.imports);\n }\n\n try {\n const compress = Boolean(options.compress);\n if (compress) {\n logger.warn('The compress option has been deprecated. ' + \n 'We recommend you use a dedicated css minifier, for instance see less-plugin-clean-css.');\n }\n\n const toCSSOptions = {\n compress,\n dumpLineNumbers: options.dumpLineNumbers,\n strictUnits: Boolean(options.strictUnits),\n numPrecision: 8};\n\n if (options.sourceMap) {\n sourceMapBuilder = new SourceMapBuilder(options.sourceMap);\n result.css = sourceMapBuilder.toCSS(evaldRoot, toCSSOptions, this.imports);\n } else {\n result.css = evaldRoot.toCSS(toCSSOptions);\n }\n } catch (e) {\n throw new LessError(e, this.imports);\n }\n\n if (options.pluginManager) {\n const postProcessors = options.pluginManager.getPostProcessors();\n for (let i = 0; i < postProcessors.length; i++) {\n result.css = postProcessors[i].process(result.css, { sourceMap: sourceMapBuilder, options, imports: this.imports });\n }\n }\n if (options.sourceMap) {\n result.map = sourceMapBuilder.getExternalSourceMap();\n }\n\n result.imports = [];\n for (const file in this.imports.files) {\n if (this.imports.files.hasOwnProperty(file) && file !== this.imports.rootFilename) {\n result.imports.push(file);\n }\n }\n return result;\n }\n }\n\n return ParseTree;\n};\n","import contexts from './contexts';\nimport Parser from './parser/parser';\nimport LessError from './less-error';\nimport * as utils from './utils';\nimport logger from './logger';\n\nexport default function(environment) {\n // FileInfo = {\n // 'rewriteUrls' - option - whether to adjust URL's to be relative\n // 'filename' - full resolved filename of current file\n // 'rootpath' - path to append to normal URLs for this node\n // 'currentDirectory' - path to the current file, absolute\n // 'rootFilename' - filename of the base file\n // 'entryPath' - absolute path to the entry file\n // 'reference' - whether the file should not be output and only output parts that are referenced\n\n class ImportManager {\n constructor(less, context, rootFileInfo) {\n this.less = less;\n this.rootFilename = rootFileInfo.filename;\n this.paths = context.paths || []; // Search paths, when importing\n this.contents = {}; // map - filename to contents of all the files\n this.contentsIgnoredChars = {}; // map - filename to lines at the beginning of each file to ignore\n this.mime = context.mime;\n this.error = null;\n this.context = context;\n // Deprecated? Unused outside of here, could be useful.\n this.queue = []; // Files which haven't been imported yet\n this.files = {}; // Holds the imported parse trees.\n }\n\n /**\n * Add an import to be imported\n * @param path - the raw path\n * @param tryAppendExtension - whether to try appending a file extension (.less or .js if the path has no extension)\n * @param currentFileInfo - the current file info (used for instance to work out relative paths)\n * @param importOptions - import options\n * @param callback - callback for when it is imported\n */\n push(path, tryAppendExtension, currentFileInfo, importOptions, callback) {\n const importManager = this, pluginLoader = this.context.pluginManager.Loader;\n\n this.queue.push(path);\n\n const fileParsedFunc = function (e, root, fullPath) {\n importManager.queue.splice(importManager.queue.indexOf(path), 1); // Remove the path from the queue\n\n const importedEqualsRoot = fullPath === importManager.rootFilename;\n if (importOptions.optional && e) {\n callback(null, {rules:[]}, false, null);\n logger.info(`The file ${fullPath} was skipped because it was not found and the import was marked optional.`);\n }\n else {\n // Inline imports aren't cached here.\n // If we start to cache them, please make sure they won't conflict with non-inline imports of the\n // same name as they used to do before this comment and the condition below have been added.\n if (!importManager.files[fullPath] && !importOptions.inline) {\n importManager.files[fullPath] = { root, options: importOptions };\n }\n if (e && !importManager.error) { importManager.error = e; }\n callback(e, root, importedEqualsRoot, fullPath);\n }\n };\n\n const newFileInfo = {\n rewriteUrls: this.context.rewriteUrls,\n entryPath: currentFileInfo.entryPath,\n rootpath: currentFileInfo.rootpath,\n rootFilename: currentFileInfo.rootFilename\n };\n\n const fileManager = environment.getFileManager(path, currentFileInfo.currentDirectory, this.context, environment);\n\n if (!fileManager) {\n fileParsedFunc({ message: `Could not find a file-manager for ${path}` });\n return;\n }\n\n const loadFileCallback = function(loadedFile) {\n let plugin;\n const resolvedFilename = loadedFile.filename;\n const contents = loadedFile.contents.replace(/^\\uFEFF/, '');\n\n // Pass on an updated rootpath if path of imported file is relative and file\n // is in a (sub|sup) directory\n //\n // Examples:\n // - If path of imported file is 'module/nav/nav.less' and rootpath is 'less/',\n // then rootpath should become 'less/module/nav/'\n // - If path of imported file is '../mixins.less' and rootpath is 'less/',\n // then rootpath should become 'less/../'\n newFileInfo.currentDirectory = fileManager.getPath(resolvedFilename);\n if (newFileInfo.rewriteUrls) {\n newFileInfo.rootpath = fileManager.join(\n (importManager.context.rootpath || ''),\n fileManager.pathDiff(newFileInfo.currentDirectory, newFileInfo.entryPath));\n\n if (!fileManager.isPathAbsolute(newFileInfo.rootpath) && fileManager.alwaysMakePathsAbsolute()) {\n newFileInfo.rootpath = fileManager.join(newFileInfo.entryPath, newFileInfo.rootpath);\n }\n }\n newFileInfo.filename = resolvedFilename;\n\n const newEnv = new contexts.Parse(importManager.context);\n\n newEnv.processImports = false;\n importManager.contents[resolvedFilename] = contents;\n\n if (currentFileInfo.reference || importOptions.reference) {\n newFileInfo.reference = true;\n }\n\n if (importOptions.isPlugin) {\n plugin = pluginLoader.evalPlugin(contents, newEnv, importManager, importOptions.pluginArgs, newFileInfo);\n if (plugin instanceof LessError) {\n fileParsedFunc(plugin, null, resolvedFilename);\n }\n else {\n fileParsedFunc(null, plugin, resolvedFilename);\n }\n } else if (importOptions.inline) {\n fileParsedFunc(null, contents, resolvedFilename);\n } else {\n // import (multiple) parse trees apparently get altered and can't be cached.\n // TODO: investigate why this is\n if (importManager.files[resolvedFilename]\n && !importManager.files[resolvedFilename].options.multiple\n && !importOptions.multiple) {\n\n fileParsedFunc(null, importManager.files[resolvedFilename].root, resolvedFilename);\n }\n else {\n new Parser(newEnv, importManager, newFileInfo).parse(contents, function (e, root) {\n fileParsedFunc(e, root, resolvedFilename);\n });\n }\n }\n };\n let loadedFile;\n let promise;\n const context = utils.clone(this.context);\n\n if (tryAppendExtension) {\n context.ext = importOptions.isPlugin ? '.js' : '.less';\n }\n\n if (importOptions.isPlugin) {\n context.mime = 'application/javascript';\n\n if (context.syncImport) {\n loadedFile = pluginLoader.loadPluginSync(path, currentFileInfo.currentDirectory, context, environment, fileManager);\n } else {\n promise = pluginLoader.loadPlugin(path, currentFileInfo.currentDirectory, context, environment, fileManager);\n }\n }\n else {\n if (context.syncImport) {\n loadedFile = fileManager.loadFileSync(path, currentFileInfo.currentDirectory, context, environment);\n } else {\n promise = fileManager.loadFile(path, currentFileInfo.currentDirectory, context, environment,\n (err, loadedFile) => {\n if (err) {\n fileParsedFunc(err);\n } else {\n loadFileCallback(loadedFile);\n }\n });\n }\n }\n if (loadedFile) {\n if (!loadedFile.filename) {\n fileParsedFunc(loadedFile);\n } else {\n loadFileCallback(loadedFile);\n }\n } else if (promise) {\n promise.then(loadFileCallback, fileParsedFunc);\n }\n }\n }\n\n return ImportManager;\n};\n","import * as utils from './utils';\n\nexport default (environment, ParseTree, ImportManager) => {\n const render = function (input, options, callback) {\n if (typeof options === 'function') {\n callback = options;\n options = utils.copyOptions(this.options, {});\n }\n else {\n options = utils.copyOptions(this.options, options || {});\n }\n\n if (!callback) {\n const self = this;\n return new Promise((resolve, reject) => {\n render.call(self, input, options, (err, output) => {\n if (err) {\n reject(err);\n } else {\n resolve(output);\n }\n });\n });\n } else {\n this.parse(input, options, (err, root, imports, options) => {\n if (err) { return callback(err); }\n\n let result;\n try {\n const parseTree = new ParseTree(root, imports);\n result = parseTree.toCSS(options);\n }\n catch (err) { return callback(err); }\n\n callback(null, result);\n });\n }\n };\n\n return render;\n};\n","import contexts from './contexts';\nimport Parser from './parser/parser';\nimport PluginManager from './plugin-manager';\nimport LessError from './less-error';\nimport * as utils from './utils';\n\nexport default (environment, ParseTree, ImportManager) => {\n const parse = function (input, options, callback) {\n\n if (typeof options === 'function') {\n callback = options;\n options = utils.copyOptions(this.options, {});\n }\n else {\n options = utils.copyOptions(this.options, options || {});\n }\n\n if (!callback) {\n const self = this;\n return new Promise((resolve, reject) => {\n parse.call(self, input, options, (err, output) => {\n if (err) {\n reject(err);\n } else {\n resolve(output);\n }\n });\n });\n } else {\n let context;\n let rootFileInfo;\n const pluginManager = new PluginManager(this, !options.reUsePluginManager);\n\n options.pluginManager = pluginManager;\n\n context = new contexts.Parse(options);\n\n if (options.rootFileInfo) {\n rootFileInfo = options.rootFileInfo;\n } else {\n const filename = options.filename || 'input';\n const entryPath = filename.replace(/[^\\/\\\\]*$/, '');\n rootFileInfo = {\n filename,\n rewriteUrls: context.rewriteUrls,\n rootpath: context.rootpath || '',\n currentDirectory: entryPath,\n entryPath,\n rootFilename: filename\n };\n // add in a missing trailing slash\n if (rootFileInfo.rootpath && rootFileInfo.rootpath.slice(-1) !== '/') {\n rootFileInfo.rootpath += '/';\n }\n }\n\n const imports = new ImportManager(this, context, rootFileInfo);\n this.importManager = imports;\n\n // TODO: allow the plugins to be just a list of paths or names\n // Do an async plugin queue like lessc\n\n if (options.plugins) {\n options.plugins.forEach(plugin => {\n let evalResult;\n let contents;\n if (plugin.fileContent) {\n contents = plugin.fileContent.replace(/^\\uFEFF/, '');\n evalResult = pluginManager.Loader.evalPlugin(contents, context, imports, plugin.options, plugin.filename);\n if (evalResult instanceof LessError) {\n return callback(evalResult);\n }\n }\n else {\n pluginManager.addPlugin(plugin);\n }\n });\n }\n\n new Parser(context, imports, rootFileInfo)\n .parse(input, (e, root) => {\n if (e) { return callback(e); }\n callback(null, root, imports, options);\n }, options);\n }\n };\n return parse;\n};\n","// TODO: Add tests for browser @plugin\n/* global window */\n\nimport AbstractPluginLoader from '../less/environment/abstract-plugin-loader.js';\n\n/**\n * Browser Plugin Loader\n */\nclass PluginLoader extends AbstractPluginLoader {\n constructor(less) {\n super();\n\n this.less = less;\n // Should we shim this.require for browser? Probably not?\n }\n\n loadPlugin(filename, basePath, context, environment, fileManager) {\n return new Promise((fulfill, reject) => {\n fileManager.loadFile(filename, basePath, context, environment)\n .then(fulfill).catch(reject);\n });\n }\n}\n\nexport default PluginLoader;\n\n","import * as utils from './utils';\nimport browser from './browser';\n\nexport default (window, less, options) => {\n\n function errorHTML(e, rootHref) {\n const id = `less-error-message:${utils.extractId(rootHref || '')}`;\n const template = '
  • {content}
  • ';\n const elem = window.document.createElement('div');\n let timer;\n let content;\n const errors = [];\n const filename = e.filename || rootHref;\n const filenameNoPath = filename.match(/([^\\/]+(\\?.*)?)$/)[1];\n\n elem.id = id;\n elem.className = 'less-error-message';\n\n content = `

    ${e.type || 'Syntax'}Error: ${e.message || 'There is an error in your .less file'}` + \n `

    in ${filenameNoPath} `;\n\n const errorline = (e, i, classname) => {\n if (e.extract[i] !== undefined) {\n errors.push(template.replace(/\\{line\\}/, (parseInt(e.line, 10) || 0) + (i - 1))\n .replace(/\\{class\\}/, classname)\n .replace(/\\{content\\}/, e.extract[i]));\n }\n };\n\n if (e.line) {\n errorline(e, 0, '');\n errorline(e, 1, 'line');\n errorline(e, 2, '');\n content += `on line ${e.line}, column ${e.column + 1}:

      ${errors.join('')}
    `;\n }\n if (e.stack && (e.extract || options.logLevel >= 4)) {\n content += `
    Stack Trace
    ${e.stack.split('\\n').slice(1).join('
    ')}`;\n }\n elem.innerHTML = content;\n\n // CSS for error messages\n browser.createCSS(window.document, [\n '.less-error-message ul, .less-error-message li {',\n 'list-style-type: none;',\n 'margin-right: 15px;',\n 'padding: 4px 0;',\n 'margin: 0;',\n '}',\n '.less-error-message label {',\n 'font-size: 12px;',\n 'margin-right: 15px;',\n 'padding: 4px 0;',\n 'color: #cc7777;',\n '}',\n '.less-error-message pre {',\n 'color: #dd6666;',\n 'padding: 4px 0;',\n 'margin: 0;',\n 'display: inline-block;',\n '}',\n '.less-error-message pre.line {',\n 'color: #ff0000;',\n '}',\n '.less-error-message h3 {',\n 'font-size: 20px;',\n 'font-weight: bold;',\n 'padding: 15px 0 5px 0;',\n 'margin: 0;',\n '}',\n '.less-error-message a {',\n 'color: #10a',\n '}',\n '.less-error-message .error {',\n 'color: red;',\n 'font-weight: bold;',\n 'padding-bottom: 2px;',\n 'border-bottom: 1px dashed red;',\n '}'\n ].join('\\n'), { title: 'error-message' });\n\n elem.style.cssText = [\n 'font-family: Arial, sans-serif',\n 'border: 1px solid #e00',\n 'background-color: #eee',\n 'border-radius: 5px',\n '-webkit-border-radius: 5px',\n '-moz-border-radius: 5px',\n 'color: #e00',\n 'padding: 15px',\n 'margin-bottom: 15px'\n ].join(';');\n\n if (options.env === 'development') {\n timer = setInterval(() => {\n const document = window.document;\n const body = document.body;\n if (body) {\n if (document.getElementById(id)) {\n body.replaceChild(elem, document.getElementById(id));\n } else {\n body.insertBefore(elem, body.firstChild);\n }\n clearInterval(timer);\n }\n }, 10);\n }\n }\n\n function removeErrorHTML(path) {\n const node = window.document.getElementById(`less-error-message:${utils.extractId(path)}`);\n if (node) {\n node.parentNode.removeChild(node);\n }\n }\n\n function removeErrorConsole(path) {\n // no action\n }\n\n function removeError(path) {\n if (!options.errorReporting || options.errorReporting === 'html') {\n removeErrorHTML(path);\n } else if (options.errorReporting === 'console') {\n removeErrorConsole(path);\n } else if (typeof options.errorReporting === 'function') {\n options.errorReporting('remove', path);\n }\n }\n\n function errorConsole(e, rootHref) {\n const template = '{line} {content}';\n const filename = e.filename || rootHref;\n const errors = [];\n let content = `${e.type || 'Syntax'}Error: ${e.message || 'There is an error in your .less file'} in ${filename}`;\n\n const errorline = (e, i, classname) => {\n if (e.extract[i] !== undefined) {\n errors.push(template.replace(/\\{line\\}/, (parseInt(e.line, 10) || 0) + (i - 1))\n .replace(/\\{class\\}/, classname)\n .replace(/\\{content\\}/, e.extract[i]));\n }\n };\n\n if (e.line) {\n errorline(e, 0, '');\n errorline(e, 1, 'line');\n errorline(e, 2, '');\n content += ` on line ${e.line}, column ${e.column + 1}:\\n${errors.join('\\n')}`;\n }\n if (e.stack && (e.extract || options.logLevel >= 4)) {\n content += `\\nStack Trace\\n${e.stack}`;\n }\n less.logger.error(content);\n }\n\n function error(e, rootHref) {\n if (!options.errorReporting || options.errorReporting === 'html') {\n errorHTML(e, rootHref);\n } else if (options.errorReporting === 'console') {\n errorConsole(e, rootHref);\n } else if (typeof options.errorReporting === 'function') {\n options.errorReporting('add', e, rootHref);\n }\n }\n\n return {\n add: error,\n remove: removeError\n };\n};\n","/**\n * Kicks off less and compiles any stylesheets\n * used in the browser distributed version of less\n * to kick-start less using the browser api\n */\n/* global window, document */\n\nimport defaultOptions from '../less/default-options';\nimport addDefaultOptions from './add-default-options';\nimport root from './index';\n\nconst options = defaultOptions();\n\nif (window.less) {\n for (const key in window.less) {\n if (window.less.hasOwnProperty(key)) {\n options[key] = window.less[key];\n }\n }\n}\naddDefaultOptions(window, options);\n\noptions.plugins = options.plugins || [];\n\nif (window.LESS_PLUGINS) {\n options.plugins = options.plugins.concat(window.LESS_PLUGINS);\n}\n\nconst less = root(window, options);\nexport default less;\n\nwindow.less = less;\n\nlet css;\nlet head;\nlet style;\n\n// Always restore page visibility\nfunction resolveOrReject(data) {\n if (data.filename) {\n console.warn(data);\n }\n if (!options.async) {\n head.removeChild(style);\n }\n}\n\nif (options.onReady) {\n if (/!watch/.test(window.location.hash)) {\n less.watch();\n }\n // Simulate synchronous stylesheet loading by hiding page rendering\n if (!options.async) {\n css = 'body { display: none !important }';\n head = document.head || document.getElementsByTagName('head')[0];\n style = document.createElement('style');\n\n style.type = 'text/css';\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n\n head.appendChild(style);\n }\n less.registerStylesheetsImmediately();\n less.pageLoadFinished = less.refresh(less.env === 'development').then(resolveOrReject, resolveOrReject);\n}\n","// Export a new default each time\nexport default () => ({\n /* Inline Javascript - @plugin still allowed */\n javascriptEnabled: false,\n\n /* Outputs a makefile import dependency list to stdout. */\n depends: false,\n\n /* (DEPRECATED) Compress using less built-in compression. \n * This does an okay job but does not utilise all the tricks of \n * dedicated css compression. */\n compress: false,\n\n /* Runs the less parser and just reports errors without any output. */\n lint: false,\n\n /* Sets available include paths.\n * If the file in an @import rule does not exist at that exact location, \n * less will look for it at the location(s) passed to this option. \n * You might use this for instance to specify a path to a library which \n * you want to be referenced simply and relatively in the less files. */\n paths: [],\n\n /* color output in the terminal */\n color: true,\n\n /* The strictImports controls whether the compiler will allow an @import inside of either \n * @media blocks or (a later addition) other selector blocks.\n * See: https://github.com/less/less.js/issues/656 */\n strictImports: false,\n\n /* Allow Imports from Insecure HTTPS Hosts */\n insecure: false,\n\n /* Allows you to add a path to every generated import and url in your css. \n * This does not affect less import statements that are processed, just ones \n * that are left in the output css. */\n rootpath: '',\n\n /* By default URLs are kept as-is, so if you import a file in a sub-directory \n * that references an image, exactly the same URL will be output in the css. \n * This option allows you to re-write URL's in imported files so that the \n * URL is always relative to the base imported file */\n rewriteUrls: false,\n\n /* How to process math \n * 0 always - eagerly try to solve all operations\n * 1 parens-division - require parens for division \"/\"\n * 2 parens | strict - require parens for all operations\n * 3 strict-legacy - legacy strict behavior (super-strict)\n */\n math: 0,\n\n /* Without this option, less attempts to guess at the output unit when it does maths. */\n strictUnits: false,\n\n /* Effectively the declaration is put at the top of your base Less file, \n * meaning it can be used but it also can be overridden if this variable \n * is defined in the file. */\n globalVars: null,\n\n /* As opposed to the global variable option, this puts the declaration at the\n * end of your base file, meaning it will override anything defined in your Less file. */\n modifyVars: null,\n\n /* This option allows you to specify a argument to go on to every URL. */\n urlArgs: ''\n});","import {addDataAttr} from './utils';\nimport browser from './browser';\n\nexport default (window, options) => {\n\n // use options from the current script tag data attribues\n addDataAttr(options, browser.currentScript(window));\n\n if (options.isFileProtocol === undefined) {\n options.isFileProtocol = /^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(window.location.protocol);\n }\n\n // Load styles asynchronously (default: false)\n //\n // This is set to `false` by default, so that the body\n // doesn't start loading before the stylesheets are parsed.\n // Setting this to `true` can result in flickering.\n //\n options.async = options.async || false;\n options.fileAsync = options.fileAsync || false;\n\n // Interval between watch polls\n options.poll = options.poll || (options.isFileProtocol ? 1000 : 1500);\n\n options.env = options.env || (window.location.hostname == '127.0.0.1' ||\n window.location.hostname == '0.0.0.0' ||\n window.location.hostname == 'localhost' ||\n (window.location.port &&\n window.location.port.length > 0) ||\n options.isFileProtocol ? 'development'\n : 'production');\n\n const dumpLineNumbers = /!dumpLineNumbers:(comments|mediaquery|all)/.exec(window.location.hash);\n if (dumpLineNumbers) {\n options.dumpLineNumbers = dumpLineNumbers[1];\n }\n\n if (options.useFileCache === undefined) {\n options.useFileCache = true;\n }\n\n if (options.onReady === undefined) {\n options.onReady = true;\n }\n\n if (options.relativeUrls) {\n options.rewriteUrls = 'all';\n }\n};\n","//\n// index.js\n// Should expose the additional browser functions on to the less object\n//\nimport {addDataAttr} from './utils';\nimport lessRoot from '../less';\nimport browser from './browser';\nimport FM from './file-manager';\nimport PluginLoader from './plugin-loader';\nimport LogListener from './log-listener';\nimport ErrorReporting from './error-reporting';\nimport Cache from './cache';\nimport ImageSize from './image-size';\n\nexport default (window, options) => {\n const document = window.document;\n const less = lessRoot();\n\n less.options = options;\n const environment = less.environment;\n const FileManager = FM(options, less.logger);\n const fileManager = new FileManager();\n environment.addFileManager(fileManager);\n less.FileManager = FileManager;\n less.PluginLoader = PluginLoader;\n\n LogListener(less, options);\n const errors = ErrorReporting(window, less, options);\n const cache = less.cache = options.cache || Cache(window, options, less.logger);\n ImageSize(less.environment);\n\n // Setup user functions - Deprecate?\n if (options.functions) {\n less.functions.functionRegistry.addMultiple(options.functions);\n }\n\n const typePattern = /^text\\/(x-)?less$/;\n\n function clone(obj) {\n const cloned = {};\n for (const prop in obj) {\n if (obj.hasOwnProperty(prop)) {\n cloned[prop] = obj[prop];\n }\n }\n return cloned;\n }\n\n // only really needed for phantom\n function bind(func, thisArg) {\n const curryArgs = Array.prototype.slice.call(arguments, 2);\n return function() {\n const args = curryArgs.concat(Array.prototype.slice.call(arguments, 0));\n return func.apply(thisArg, args);\n };\n }\n\n function loadStyles(modifyVars) {\n const styles = document.getElementsByTagName('style');\n let style;\n\n for (let i = 0; i < styles.length; i++) {\n style = styles[i];\n if (style.type.match(typePattern)) {\n const instanceOptions = clone(options);\n instanceOptions.modifyVars = modifyVars;\n const lessText = style.innerHTML || '';\n instanceOptions.filename = document.location.href.replace(/#.*$/, '');\n\n /* jshint loopfunc:true */\n // use closure to store current style\n less.render(lessText, instanceOptions,\n bind((style, e, result) => {\n if (e) {\n errors.add(e, 'inline');\n } else {\n style.type = 'text/css';\n if (style.styleSheet) {\n style.styleSheet.cssText = result.css;\n } else {\n style.innerHTML = result.css;\n }\n }\n }, null, style));\n }\n }\n }\n\n function loadStyleSheet(sheet, callback, reload, remaining, modifyVars) {\n\n const instanceOptions = clone(options);\n addDataAttr(instanceOptions, sheet);\n instanceOptions.mime = sheet.type;\n\n if (modifyVars) {\n instanceOptions.modifyVars = modifyVars;\n }\n\n function loadInitialFileCallback(loadedFile) {\n const data = loadedFile.contents;\n const path = loadedFile.filename;\n const webInfo = loadedFile.webInfo;\n\n const newFileInfo = {\n currentDirectory: fileManager.getPath(path),\n filename: path,\n rootFilename: path,\n rewriteUrls: instanceOptions.rewriteUrls\n };\n\n newFileInfo.entryPath = newFileInfo.currentDirectory;\n newFileInfo.rootpath = instanceOptions.rootpath || newFileInfo.currentDirectory;\n\n if (webInfo) {\n webInfo.remaining = remaining;\n\n const css = cache.getCSS(path, webInfo, instanceOptions.modifyVars);\n if (!reload && css) {\n webInfo.local = true;\n callback(null, css, data, sheet, webInfo, path);\n return;\n }\n\n }\n\n // TODO add tests around how this behaves when reloading\n errors.remove(path);\n\n instanceOptions.rootFileInfo = newFileInfo;\n less.render(data, instanceOptions, (e, result) => {\n if (e) {\n e.href = path;\n callback(e);\n } else {\n cache.setCSS(sheet.href, webInfo.lastModified, instanceOptions.modifyVars, result.css);\n callback(null, result.css, data, sheet, webInfo, path);\n }\n });\n }\n\n fileManager.loadFile(sheet.href, null, instanceOptions, environment)\n .then(loadedFile => {\n loadInitialFileCallback(loadedFile);\n }).catch(err => {\n console.log(err);\n callback(err);\n });\n\n }\n\n function loadStyleSheets(callback, reload, modifyVars) {\n for (let i = 0; i < less.sheets.length; i++) {\n loadStyleSheet(less.sheets[i], callback, reload, less.sheets.length - (i + 1), modifyVars);\n }\n }\n\n function initRunningMode() {\n if (less.env === 'development') {\n less.watchTimer = setInterval(() => {\n if (less.watchMode) {\n fileManager.clearFileCache();\n loadStyleSheets((e, css, _, sheet, webInfo) => {\n if (e) {\n errors.add(e, e.href || sheet.href);\n } else if (css) {\n browser.createCSS(window.document, css, sheet);\n }\n });\n }\n }, options.poll);\n }\n }\n\n //\n // Watch mode\n //\n less.watch = function () {\n if (!less.watchMode ) {\n less.env = 'development';\n initRunningMode();\n }\n this.watchMode = true;\n return true;\n };\n\n less.unwatch = function () {clearInterval(less.watchTimer); this.watchMode = false; return false; };\n\n //\n // Synchronously get all tags with the 'rel' attribute set to\n // \"stylesheet/less\".\n //\n less.registerStylesheetsImmediately = () => {\n const links = document.getElementsByTagName('link');\n less.sheets = [];\n\n for (let i = 0; i < links.length; i++) {\n if (links[i].rel === 'stylesheet/less' || (links[i].rel.match(/stylesheet/) &&\n (links[i].type.match(typePattern)))) {\n less.sheets.push(links[i]);\n }\n }\n };\n\n //\n // Asynchronously get all tags with the 'rel' attribute set to\n // \"stylesheet/less\", returning a Promise.\n //\n less.registerStylesheets = () => new Promise((resolve, reject) => {\n less.registerStylesheetsImmediately();\n resolve();\n });\n\n //\n // With this function, it's possible to alter variables and re-render\n // CSS without reloading less-files\n //\n less.modifyVars = record => less.refresh(true, record, false);\n\n less.refresh = (reload, modifyVars, clearFileCache) => {\n if ((reload || clearFileCache) && clearFileCache !== false) {\n fileManager.clearFileCache();\n }\n return new Promise((resolve, reject) => {\n let startTime;\n let endTime;\n let totalMilliseconds;\n let remainingSheets;\n startTime = endTime = new Date();\n\n // Set counter for remaining unprocessed sheets\n remainingSheets = less.sheets.length;\n\n if (remainingSheets === 0) {\n\n endTime = new Date();\n totalMilliseconds = endTime - startTime;\n less.logger.info('Less has finished and no sheets were loaded.');\n resolve({\n startTime,\n endTime,\n totalMilliseconds,\n sheets: less.sheets.length\n });\n\n } else {\n // Relies on less.sheets array, callback seems to be guaranteed to be called for every element of the array\n loadStyleSheets((e, css, _, sheet, webInfo) => {\n if (e) {\n errors.add(e, e.href || sheet.href);\n reject(e);\n return;\n }\n if (webInfo.local) {\n less.logger.info(`Loading ${sheet.href} from cache.`);\n } else {\n less.logger.info(`Rendered ${sheet.href} successfully.`);\n }\n browser.createCSS(window.document, css, sheet);\n less.logger.info(`CSS for ${sheet.href} generated in ${new Date() - endTime}ms`);\n\n // Count completed sheet\n remainingSheets--;\n\n // Check if the last remaining sheet was processed and then call the promise\n if (remainingSheets === 0) {\n totalMilliseconds = new Date() - startTime;\n less.logger.info(`Less has finished. CSS generated in ${totalMilliseconds}ms`);\n resolve({\n startTime,\n endTime,\n totalMilliseconds,\n sheets: less.sheets.length\n });\n }\n endTime = new Date();\n }, reload, modifyVars);\n }\n\n loadStyles(modifyVars);\n });\n };\n\n less.refreshStyles = loadStyles;\n return less;\n};\n","export default (less, options) => {\n const logLevel_debug = 4;\n const logLevel_info = 3;\n const logLevel_warn = 2;\n const logLevel_error = 1;\n\n // The amount of logging in the javascript console.\n // 3 - Debug, information and errors\n // 2 - Information and errors\n // 1 - Errors\n // 0 - None\n // Defaults to 2\n options.logLevel = typeof options.logLevel !== 'undefined' ? options.logLevel : (options.env === 'development' ? logLevel_info : logLevel_error);\n\n if (!options.loggers) {\n options.loggers = [{\n debug: function(msg) {\n if (options.logLevel >= logLevel_debug) {\n console.log(msg);\n }\n },\n info: function(msg) {\n if (options.logLevel >= logLevel_info) {\n console.log(msg);\n }\n },\n warn: function(msg) {\n if (options.logLevel >= logLevel_warn) {\n console.warn(msg);\n }\n },\n error: function(msg) {\n if (options.logLevel >= logLevel_error) {\n console.error(msg);\n }\n }\n }];\n }\n for (let i = 0; i < options.loggers.length; i++) {\n less.logger.addListener(options.loggers[i]);\n }\n};\n","// Cache system is a bit outdated and could do with work\n\nexport default (window, options, logger) => {\n let cache = null;\n if (options.env !== 'development') {\n try {\n cache = (typeof window.localStorage === 'undefined') ? null : window.localStorage;\n } catch (_) {}\n }\n return {\n setCSS: function(path, lastModified, modifyVars, styles) {\n if (cache) {\n logger.info(`saving ${path} to cache.`);\n try {\n cache.setItem(path, styles);\n cache.setItem(`${path}:timestamp`, lastModified);\n if (modifyVars) {\n cache.setItem(`${path}:vars`, JSON.stringify(modifyVars));\n }\n } catch (e) {\n // TODO - could do with adding more robust error handling\n logger.error(`failed to save \"${path}\" to local storage for caching.`);\n }\n }\n },\n getCSS: function(path, webInfo, modifyVars) {\n const css = cache && cache.getItem(path);\n const timestamp = cache && cache.getItem(`${path}:timestamp`);\n let vars = cache && cache.getItem(`${path}:vars`);\n\n modifyVars = modifyVars || {};\n vars = vars || \"{}\"; // if not set, treat as the JSON representation of an empty object\n\n if (timestamp && webInfo.lastModified &&\n (new Date(webInfo.lastModified).valueOf() ===\n new Date(timestamp).valueOf()) &&\n JSON.stringify(modifyVars) === vars) {\n // Use local copy\n return css;\n }\n }\n };\n};\n","\nimport functionRegistry from './../less/functions/function-registry';\n\nexport default () => {\n function imageSize() {\n throw {\n type: 'Runtime',\n message: 'Image size functions are not supported in browser version of less'\n };\n }\n\n const imageFunctions = {\n 'image-size': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n },\n 'image-width': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n },\n 'image-height': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n }\n };\n\n functionRegistry.addMultiple(imageFunctions);\n};\n"],"names":["extractId","href","replace","addDataAttr","options","tag","opt","dataset","hasOwnProperty","JSON","parse","_","document","styles","sheet","id","title","utils.extractId","oldStyleNode","getElementById","keepOldStyleNode","styleNode","createElement","setAttribute","media","styleSheet","appendChild","createTextNode","childNodes","length","firstChild","nodeValue","head","getElementsByTagName","nextEl","nextSibling","parentNode","insertBefore","removeChild","cssText","e","Error","window","scripts","currentScript","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","__extends","__","this","constructor","prototype","create","__spreadArrays","s","i","il","arguments","r","k","a","j","jl","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgrey","darkgreen","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","grey","green","greenyellow","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgrey","lightgreen","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","m","cm","mm","in","px","pt","pc","duration","ms","angle","rad","Math","PI","deg","grad","turn","colors","unitConversions","parent","visibilityBlocks","undefined","nodeVisible","rootNode","parsed","self","defineProperty","get","fileInfo","getIndex","Node","nodes","set","node","isArray","forEach","_index","_fileInfo","context","strs","genCSS","add","chunk","index","push","isEmpty","join","output","value","visitor","visit","op","precision","numPrecision","Number","toFixed","info","compare","type","numericCompare","Color","rgb","originalForm","match","map","c","parseInt","alpha","split","clamp","v","max","min","toHex","round","toString","luma","g","pow","toCSS","doNotCompress","color","colorFunction","compress","args","fround","indexOf","concat","toHSL","h","l","toRGB","splitcolor","operate","other","_operate","toHSV","toARGB","x","fromKeyword","keyword","key","toLowerCase","slice","Paren","eval","_noSpaceCombinators"," ","|","Combinator","emptyOrWhitespace","trim","spaceOrEmpty","Element","combinator","isVariable","currentFileInfo","visibilityInfo","copyVisibilityInfo","setParent","accept","clone","firstSelector","charAt","ALWAYS","PARENS_DIVISION","PARENS","STRICT_LEGACY","RewriteUrls","getType","payload","call","copy","target","getPrototypeOf","getOwnPropertyNames","getOwnPropertySymbols","reduce","carry","props","includes","newVal","originalObject","includeNonenumerable","propType","propertyIsEnumerable","enumerable","writable","configurable","assignProp","nonenumerable","getLocation","inputStream","n","line","column","copyArray","arr","obj","cloned","prop","defaults","obj1","obj2","newObj","_defaults","defaults_1","assign","copyOptions","opts","strictMath","math","Constants.Math","relativeUrls","rewriteUrls","Constants.RewriteUrls","flattenArray","result","length_1","anonymousFunc","LessError","fileContentMap","currentFilename","filename","message","stack","input","contents","loc","utils.getLocation","col","callLine","lines","found","func","Function","lineAdjust","callExtract","extract","F","error","stylize","str","errorTxt","substr","Selector","elements","extendList","condition","evaldCondition","getElements","mixinElements_","visitArray","createDerived","newSelector","mediaEmpty","els","parseNode","err","imports","createEmptySelectors","el","sels","olen","len","mixinElements","shift","isJustParentSelector","extend","getIsOutput","Value","Keyword","True","False","Anonymous","mapLines","rulesetLike","allowRoot","isRulesetLike","Boolean","MATH","Declaration","name","important","merge","inline","variable","lastRule","prevMath","evaldValue","mathBypass","evalName","importantScope","importantResult","pop","makeImportant","debugInfo","ctx","lineSeparator","dumpLineNumbers","asComment","asMediaQuery","lineNumber","fileName","filenameWithProtocol","test","Comment","isLineComment","getDebugInfo","isSilent","isCompressed","contexts","copyFromOriginal","original","destination","propertiesToCopy","parseCopyProperties","Parse","paths","evalCopyProperties","isPathRelative","path","isPathLocalRelative","Eval","frames","inCalc","mathOn","calcStack","parensStack","rootpath","newPath","normalizePath","segment","segments","reverse","makeRegistry","base","_data","addMultiple","functions","keys","_this","getLocalFunctions","inherit","defaultFunc","value_","error_","reset","Ruleset","selectors","rules","strictImports","_lookups","_variables","_properties","selCnt","selector","hasVariable","hasOnePassingSelector","toParseSelectors","utils.flattenArray","rule","subRule","utils.copyArray","ruleset","originalRuleset","root","firstRoot","allowImports","functionRegistry","globalFunctionRegistry","ctxFrames","unshift","ctxSelectors","evalImports","rsRules","evalFirst","mediaBlockCount","mediaBlocks","filter","splice","resetCache","bubbleSelectors","importRules","matchArgs","matchCondition","lastSelector","_rulesets","variables","hash","vars","name_1","properties","name_2","decl","parseValue","property","lastDeclaration","toParse","transformDeclaration","nodes_1","rulesets","filtRules","isRuleset","prependRule","find","foundMixins","apply","ruleNodes","tabLevel","sep","tabRuleStr","tabSetStr","charsetNodeIndex","importNodeIndex","isCharset","pathCnt","pathSubCnt","currentLastRule","isVisible","joinSelectors","joinSelector","createParenthesis","elementsToPak","originalElement","replacementParen","insideParent","createSelector","containedElement","element","addReplacementIntoPath","beginningPath","addPath","replacedElement","originalSelector","newSelectorPath","newJoinedSelector","parentEl","restOfPath","addAllReplacementsIntoPath","addPaths","mergeElementsOnToSelectors","sel","deriveSelector","deriveFrom","newPaths","replaceParentSelector","inSelector","currentElements","newSelectors","selectorsMultiplied","maybeSelector","hadParentSelector","nestedSelector","replaced","nestedPaths","replacedNewSelectors","concatenated","bind","AtRule","isRooted","outputRuleset","mediaPathBackup","mediaBlocksBackup","mediaPath","_i","ruleCnt","DetachedRuleset","callEval","Unit","numerator","denominator","backupUnit","sort","strictUnits","returnStr","is","unitString","toUpperCase","isLength","RegExp","isSingular","callback","usedUnits","group","mapUnit","groupName","atomicUnit","cancel","counter","count","Dimension","unit","parseFloat","isNaN","toColor","strValue","String","convertTo","unify","conversions","targetUnit","applyUnit","derivedConversions","Operation","operands","isSpaced","isMathOn","Expression","noSpacing","returnValue","inParenthesis","parens","parensInOp","doubleParen","outOfParenthesis","throwAwayComments","functionCaller","evalArgs","item","subNodes","Call","calc","currentMathContext","enterCalc","exitCalc","funcCaller","FunctionCaller","isValid","columnNumber","Variable","evaluating","frame","fun","Property","mergeRules","pluginManager","less","visitors","ToCSSVisitor","_mergeRules","vArr","Attribute","Quoted","content","escaped","quote","variableRegex","propRegex","containsVariables","that","iterativeReplace","regexp","replacementFnc","evaluatedValue","URL","val","isEvald","pathRequiresRewrite","rewritePath","urlArgs","Media","features","evalTop","evalNested","multiMedia","permute","fragment","rest","Import","css","pathValue","getPath","isPlugin","reference","isVariableImport","evalForImport","evalPath","doEval","blocksVisibility","addVisibilityBlock","registry","skip","importedFilename","newImport","JsEvalNode","evaluateJavaScript","expression","evalContext","javascriptEnabled","jsify","toJS","JavaScript","string","Assignment","Condition","negate","lvalue","rvalue","UnicodeDescriptor","Negative","Extend","option","object_id","next_id","parent_ids","allowBefore","allowAfter","findSelfSelectors","selectorElements","selfElements","selfSelectors","VariableCall","detachedRuleset","NamespaceValue","ruleCall","lookups","substring","Definition","params","variadic","arity","optionalParameters","required","evalParams","mixinEnv","evaldArguments","varargs","arg","isNamedFound","argIndex","argsLength","evalCall","_arguments","mixinFrames","allArgsCnt","requiredArgsCnt","MixinCall","mixins","mixin","mixinPath","argValue","f","isRecursive","isOneFound","candidate","defaultResult","noArgumentsFilter","candidates","conditionResult","calcDefGroup","namespace","expand","MixinDefinition","format","newRules","_setVisibilityToReplacement","replacement","msg","_fireEvent","warn","debug","addListener","listener","_listeners","removeListener","logFunction","externalEnvironment","fileManagers","requiredFunctions","propName","environmentFunc","environment","currentDirectory","isSync","logger","getFileManagers","fileManager","AbstractFileManager","lastIndexOf","ext","tryAppendExtension","basePath","laterPath","url","baseUrl","urlDirectories","baseUrlDirectories","urlParts","extractUrlParts","baseUrlParts","diff","hostPart","directories","urlPartsRegex","returner","rawDirectories","rawPath","fileUrl","require","AbstractPluginLoader","pluginOptions","pluginObj","localModule","shortname","FileManager","trySetOptions","use","exports","loader","tree","validatePlugin","minVersion","compareVersion","addPlugin","plugin","setOptions","version","versionToString","aVersion","bVersion","versionString","plugins","printUsage","_visitArgs","visitDeeper","_hasIndexed","_noop","implementation","_implementation","_visitInCache","_visitOutCache","indexNodeTypes","ticker","child","typeIndex","Visitor","nodeTypeIndex","fnName","impl","funcOut","visitArgs","newNode","isReplacing","cnt","nonReplacing","out","evald","flatten","nestedCnt","nestedItem","onSequencerEmpty","variableImports","_onSequencerEmpty","_currentDepth","ImportSequencer","importSequencer","importItem","isReady","tryRun","variableImport","ImportVisitor","importer","finish","_visitor","_importer","_finish","importCount","onceFileDetectionMap","recursionDetector","_sequencer","run","isFinished","visitImport","importNode","inlineCSS","importParent","addVariableImport","processImportNode","evaldImportNode","multiple","importMultiple","tryAppendLessExtension","onImported","sequencedOnImported","addImport","importedAtRoot","fullPath","importVisitor","isOptional","optional","duplicateImport","oldContext","visitDeclaration","declNode","visitDeclarationOut","visitAtRule","atRuleNode","visitAtRuleOut","visitMixinDefinition","mixinDefinitionNode","visitMixinDefinitionOut","visitRuleset","rulesetNode","visitRulesetOut","visitMedia","mediaNode","visitMediaOut","visible","SetTreeVisibilityVisitor","ensureVisibility","ensureInvisibility","allExtendsStack","ExtendFinderVisitor","allExtends","allSelectorsExtendList","extendOnEveryPath","selectorPath","selExtendList","allSelectorsExtend","foundExtends","firstExtendOnThisSelectorPath","ProcessExtendsVisitor","extendFinder","extendIndices","doExtendChaining","newRoot","checkExtendsForNonMatched","indices","hasFoundMatches","extendsList","extendsListTarget","iterationCount","extendIndex","targetExtendIndex","matches","targetExtend","newExtend","extendsToAdd","extendVisitor","findMatch","selfSelector","extendSelector","extendChainCount","selectorOne","selectorTwo","ruleNode","selectorNode","pathIndex","selectorsToAdd","extendedSelectors","haystackSelectorPath","haystackSelectorIndex","hackstackSelector","hackstackElementIndex","haystackElement","targetCombinator","potentialMatch","needleElements","potentialMatches","matched","initialCombinator","isElementValuesEqual","finished","endPathIndex","endPathElementIndex","elementValue1","elementValue2","replacementSelector","matchIndex","firstElement","newElements","currentSelectorPathIndex","currentSelectorPathElementIndex","currentValue","derived","newAllExtends","lastIndex","JoinSelectorVisitor","_context","CSSVisitorUtils","bodyRules","owner","thing","originalRules","containsSilentNonBlockedChild","compiledRulesBody","keepOnlyVisibleChilds","removeVisibilityBlock","hasVisibleSelector","utils","mixinNode","visitExtend","extendNode","visitComment","commentNode","resolveVisibility","visitAtRuleWithBody","visitAtRuleWithoutBody","visitAnonymous","anonymousNode","nodeRules","hasFakeRuleset","getBodyRules","charset","comment","checkValidNodes","isRoot","_compileRulesetPaths","nodeRuleCnt","_removeDuplicateRules","isVisibleRuleset","ruleList","ruleCache","ruleCSS","groups","groupsArr","result_1","space_1","comma_1","MarkVisibleSelectorsVisitor","ExtendVisitor","furthest","furthestPossibleErrorMessage","chunks","current","currentPos","saveStack","parserInput","skipWhitespace","nextChar","oldi","oldj","curr","endIndex","mem","inp","charCodeAt","autoCommentAbsorb","nextNewLine","text","commentStore","nextStarSlash","save","restore","possibleErrorMessage","state","forget","isWhitespace","offset","pos","code","$re","tok","exec","$char","$str","tokLength","$quoted","startChar","currentPosition","$parseUntil","testChar","returnVal","inComment","blockDepth","blockStack","parseGroups","startPos","lastPos","loop","char","expected","peek","peekChar","currentChar","prevChar","getInput","peekNotNumeric","start","chunkInput","failFunction","fail","lastOpening","lastOpeningParen","lastMultiComment","lastMultiCommentEndBrace","chunkerCurrentIndex","currentChunkStartIndex","cc","cc2","level","parenLevel","emitFrom","emitChunk","force","fromCharCode","chunker","end","furthestReachedEnd","furthestChar","Parser","parsers","getParserInput","expect","expectChar","parseList","currentIndex","returnNodes","parser","additionalData","globalVars","modifyVars","ignored","preText","serializeVars","preProcessors","getPreProcessors","process","banner","contentsIgnoredChars","primary","endInfo","processImports","extendRule","definition","declaration","variableCall","entities","atrule","foundSemiColon","mixinLookup","quoted","forceEscaped","isEscaped","customFuncCall","stop","ieAlpha","boolean","if","prevArgs","isSemiColonSeparated","argsComma","argsSemiColon","assignment","literal","dimension","unicodeDescriptor","entity","ch","variableCurly","curly","propertyCurly","colorKeyword","ud","javascript","js","escape","parsedName","inValue","ruleLookups","isRule","getLookup","hasParens","elem","elemIndex","re","isCall","expressionContainsNamed","nameLoop","expressions","hasSep","cond","argInfo","conditions","block","lookupValue","attribute","slashedCombinator","isLess","when","blockRuleset","hasDR","ruleProperty","permissiveValue","anonymousValue","untilTokens","done","testCurrentChar","import","dir","importOptions","mediaFeatures","o","optionName","importOption","mediaFeature","pluginArgs","nonVendorSpecificName","hasIdentifier","hasExpression","hasUnknown","hasBlock","sub","addition","multiplication","operation","operand","needsParens","logical","next","conditionAnd","negatedCondition","parenthesisCondition","atomicCondition","body","me","tryConditionFollowedByParenthesis","delim","simpleProperty","If","trueValue","falseValue","colorFunctions","hsla","origColor","hsl","number","rgba","size","m1_1","m2_1","hue","hsv","hsva","vs","floor","perm","saturation","lightness","hsvhue","hsvsaturation","hsvvalue","luminance","saturate","amount","method","desaturate","lighten","darken","fadein","fadeout","fade","spin","mix","color1","color2","weight","w","w1","w2","greyscale","contrast","dark","light","threshold","t","argb","tint","shade","colorBlend","mode","cb","cs","ar","cr","ab","as","colorBlendModeFunctions","multiply","screen","overlay","softlight","sqrt","hardlight","difference","abs","exclusion","average","negation","getItemsFromNode","_SELF","values","range","step","from","to","stepValue","list","each","rs","iterator","tryEval","Quote","valueName","keyName","indexName","MathHelper","fn","mathFunctions","ceil","sin","cos","atan","asin","acos","mathHelper","fraction","num","minMax","isMin","currentUnified","referenceUnified","unitStatic","unitClone","order","convert","pi","mod","y","percentage","evaluated","encodeURI","pattern","flags","%","token","encodeURIComponent","isa","Type","isunit","isruleset","iscolor","isnumber","isstring","iskeyword","isurl","ispixel","ispercentage","isem","get-unit","colorBlending","fallback","functionThis","data-uri","mimetypeNode","filePathNode","mimetype","filePath","entryPath","fragmentStart","utils.clone","rawBuffer","getFileManager","useBase64","mimeLookup","charsetLookup","fileSync","loadFileSync","buf","encodeBase64","uri","dataUri","svg-gradient","direction","stops","gradientDirectionSvg","position","positionValue","gradientType","rectangleDimension","renderEnv","directionValue","throwArgumentDescriptor","types","evaldRoot","evalEnv","visitorIterator","preEvalVisitors","first","isPreEvalVisitor","isPreVisitor","pm","postProcessors","installedPlugins","pluginCache","Loader","PluginLoader","PluginManager","install","preProcessor","priority","indexToInsertAt","postProcessor","manager","PluginManagerFactory","newFactory","SourceMapOutput","_css","_rootNode","_contentsMap","contentsMap","_contentsIgnoredCharsMap","contentsIgnoredCharsMap","sourceMapFilename","_sourceMapFilename","_outputFilename","outputFilename","sourceMapURL","sourceMapBasepath","_sourceMapBasepath","sourceMapRootpath","_sourceMapRootpath","_outputSourceFiles","outputSourceFiles","_sourceMapGeneratorConstructor","getSourceMapGenerator","_lineNumber","_column","removeBasepath","sourceLines","columns","sourceColumns","inputSource","_sourceMapGenerator","addMapping","generated","source","normalizeFilename","file","sourceRoot","setSourceContent","sourceMapContent","stringify","toJSON","sourceMap","sourceMapOutput","Environment","SourceMapBuilder","sourceMapOutputFilename","sourceMapGenerator","sourceMapFileInline","disableSourcemapAnnotation","sourceMapInputFilename","getCSSAppendage","sourceMapBuilder","ParseTree","transformTree","toCSSOptions","getPostProcessors","getExternalSourceMap","files","rootFilename","parseTree","ImportManager","rootFileInfo","mime","queue","importManager","pluginLoader","fileParsedFunc","importedEqualsRoot","newFileInfo","loadedFile","promise","loadFileCallback","resolvedFilename","pathDiff","isPathAbsolute","alwaysMakePathsAbsolute","newEnv","evalPlugin","syncImport","loadPluginSync","loadPlugin","loadFile","then","render","utils.copyOptions","self_1","Promise","resolve","reject","Render","context_1","pluginManager_1","reUsePluginManager","imports_1","evalResult","fileContent","Functions","initial","data","ctor","api","fileCache","errback","xhr","XMLHttpRequest","async","isFileProtocol","fileAsync","handleResponse","status","responseText","getResponseHeader","overrideMimeType","open","setRequestHeader","send","onreadystatechange","readyState","location","useFileCache","lessText","webInfo","lastModified","Date","doXHR","log","_super","fulfill","catch","rootHref","errorReporting","errors","errorline","classname","logLevel","errorConsole","timer","filenameNoPath","className","innerHTML","browser","style","env","setInterval","replaceChild","clearInterval","errorHTML","remove","removeErrorHTML","depends","lint","insecure","protocol","poll","hostname","port","onReady","addDefaultOptions","LESS_PLUGINS","lessRoot","FM","addFileManager","loggers","console","LogListener","ErrorReporting","cache","localStorage","setCSS","setItem","getCSS","getItem","timestamp","valueOf","Cache","imageSize","imageFunctions","image-size","image-width","image-height","ImageSize","typePattern","thisArg","curryArgs","loadStyles","instanceOptions","loadStyleSheet","reload","remaining","local","loadInitialFileCallback","loadStyleSheets","sheets","watch","watchMode","watchTimer","clearFileCache","unwatch","registerStylesheetsImmediately","links","rel","registerStylesheets","record","refresh","startTime","endTime","totalMilliseconds","remainingSheets","refreshStyles","resolveOrReject","pageLoadFinished"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"less.min.js","sources":["../src/less-browser/utils.js","../src/less-browser/browser.js","../src/less/logger.js","../src/less/environment/environment.js","../src/less/data/colors.js","../src/less/data/unit-conversions.js","../src/less/data/index.js","../src/less/tree/node.js","../src/less/tree/color.js","../src/less/tree/paren.js","../src/less/tree/combinator.js","../src/less/tree/element.js","../src/less/constants.js","../node_modules/is-what/dist/index.esm.js","../node_modules/copy-anything/dist/index.esm.js","../src/less/utils.js","../src/less/less-error.js","../src/less/tree/selector.js","../src/less/tree/value.js","../src/less/tree/keyword.js","../src/less/tree/anonymous.js","../src/less/tree/declaration.js","../src/less/tree/debug-info.js","../src/less/tree/comment.js","../src/less/contexts.js","../src/less/functions/function-registry.js","../src/less/functions/default.js","../src/less/tree/ruleset.js","../src/less/tree/atrule.js","../src/less/tree/detached-ruleset.js","../src/less/tree/unit.js","../src/less/tree/dimension.js","../src/less/tree/operation.js","../src/less/tree/expression.js","../src/less/functions/function-caller.js","../node_modules/tslib/tslib.es6.js","../src/less/tree/call.js","../src/less/tree/variable.js","../src/less/tree/property.js","../src/less/tree/attribute.js","../src/less/tree/quoted.js","../src/less/tree/url.js","../src/less/tree/media.js","../src/less/tree/import.js","../src/less/tree/js-eval-node.js","../src/less/tree/javascript.js","../src/less/tree/assignment.js","../src/less/tree/condition.js","../src/less/tree/unicode-descriptor.js","../src/less/tree/negative.js","../src/less/tree/extend.js","../src/less/tree/variable-call.js","../src/less/tree/namespace-value.js","../src/less/tree/mixin-definition.js","../src/less/tree/mixin-call.js","../src/less/tree/index.js","../src/less/environment/abstract-file-manager.js","../src/less/environment/abstract-plugin-loader.js","../src/less/visitors/visitor.js","../src/less/visitors/import-sequencer.js","../src/less/visitors/import-visitor.js","../src/less/visitors/set-tree-visibility-visitor.js","../src/less/visitors/extend-visitor.js","../src/less/visitors/join-selector-visitor.js","../src/less/visitors/to-css-visitor.js","../src/less/visitors/index.js","../src/less/parser/parser-input.js","../src/less/parser/chunker.js","../src/less/parser/parser.js","../src/less/functions/boolean.js","../src/less/functions/color.js","../src/less/functions/color-blending.js","../src/less/functions/list.js","../src/less/functions/math-helper.js","../src/less/functions/math.js","../src/less/functions/number.js","../src/less/functions/string.js","../src/less/functions/types.js","../src/less/functions/index.js","../src/less/functions/data-uri.js","../src/less/functions/svg.js","../src/less/transform-tree.js","../src/less/plugin-manager.js","../node_modules/parse-node-version/index.js","../src/less-browser/file-manager.js","../src/less/index.js","../src/less/parse-tree.js","../src/less/source-map-builder.js","../src/less/source-map-output.js","../src/less/import-manager.js","../src/less/render.js","../src/less/parse.js","../src/less-browser/plugin-loader.js","../src/less-browser/error-reporting.js","../src/less-browser/bootstrap.js","../src/less/default-options.js","../src/less-browser/add-default-options.js","../src/less-browser/index.js","../src/less-browser/log-listener.js","../src/less-browser/cache.js","../src/less-browser/image-size.js"],"sourcesContent":["\nexport function extractId(href) {\n return href.replace(/^[a-z-]+:\\/+?[^\\/]+/, '') // Remove protocol & domain\n .replace(/[\\?\\&]livereload=\\w+/, '') // Remove LiveReload cachebuster\n .replace(/^\\//, '') // Remove root /\n .replace(/\\.[a-zA-Z]+$/, '') // Remove simple extension\n .replace(/[^\\.\\w-]+/g, '-') // Replace illegal characters\n .replace(/\\./g, ':'); // Replace dots with colons(for valid id)\n}\n\nexport function addDataAttr(options, tag) {\n for (const opt in tag.dataset) {\n if (tag.dataset.hasOwnProperty(opt)) {\n if (opt === 'env' || opt === 'dumpLineNumbers' || opt === 'rootpath' || opt === 'errorReporting') {\n options[opt] = tag.dataset[opt];\n } else {\n try {\n options[opt] = JSON.parse(tag.dataset[opt]);\n }\n catch (_) {}\n }\n }\n }\n}\n","import * as utils from './utils';\n\nexport default {\n createCSS: function (document, styles, sheet) {\n // Strip the query-string\n const href = sheet.href || '';\n\n // If there is no title set, use the filename, minus the extension\n const id = `less:${sheet.title || utils.extractId(href)}`;\n\n // If this has already been inserted into the DOM, we may need to replace it\n const oldStyleNode = document.getElementById(id);\n let keepOldStyleNode = false;\n\n // Create a new stylesheet node for insertion or (if necessary) replacement\n const styleNode = document.createElement('style');\n styleNode.setAttribute('type', 'text/css');\n if (sheet.media) {\n styleNode.setAttribute('media', sheet.media);\n }\n styleNode.id = id;\n\n if (!styleNode.styleSheet) {\n styleNode.appendChild(document.createTextNode(styles));\n\n // If new contents match contents of oldStyleNode, don't replace oldStyleNode\n keepOldStyleNode = (oldStyleNode !== null && oldStyleNode.childNodes.length > 0 && styleNode.childNodes.length > 0 &&\n oldStyleNode.firstChild.nodeValue === styleNode.firstChild.nodeValue);\n }\n\n const head = document.getElementsByTagName('head')[0];\n\n // If there is no oldStyleNode, just append; otherwise, only append if we need\n // to replace oldStyleNode with an updated stylesheet\n if (oldStyleNode === null || keepOldStyleNode === false) {\n const nextEl = sheet && sheet.nextSibling || null;\n if (nextEl) {\n nextEl.parentNode.insertBefore(styleNode, nextEl);\n } else {\n head.appendChild(styleNode);\n }\n }\n if (oldStyleNode && keepOldStyleNode === false) {\n oldStyleNode.parentNode.removeChild(oldStyleNode);\n }\n\n // For IE.\n // This needs to happen *after* the style element is added to the DOM, otherwise IE 7 and 8 may crash.\n // See http://social.msdn.microsoft.com/Forums/en-US/7e081b65-878a-4c22-8e68-c10d39c2ed32/internet-explorer-crashes-appending-style-element-to-head\n if (styleNode.styleSheet) {\n try {\n styleNode.styleSheet.cssText = styles;\n } catch (e) {\n throw new Error('Couldn\\'t reassign styleSheet.cssText.');\n }\n }\n },\n currentScript: function(window) {\n const document = window.document;\n return document.currentScript || (() => {\n const scripts = document.getElementsByTagName('script');\n return scripts[scripts.length - 1];\n })();\n }\n};\n","export default {\n error: function(msg) {\n this._fireEvent('error', msg);\n },\n warn: function(msg) {\n this._fireEvent('warn', msg);\n },\n info: function(msg) {\n this._fireEvent('info', msg);\n },\n debug: function(msg) {\n this._fireEvent('debug', msg);\n },\n addListener: function(listener) {\n this._listeners.push(listener);\n },\n removeListener: function(listener) {\n for (let i = 0; i < this._listeners.length; i++) {\n if (this._listeners[i] === listener) {\n this._listeners.splice(i, 1);\n return;\n }\n }\n },\n _fireEvent: function(type, msg) {\n for (let i = 0; i < this._listeners.length; i++) {\n const logFunction = this._listeners[i][type];\n if (logFunction) {\n logFunction(msg);\n }\n }\n },\n _listeners: []\n};\n","/**\n * @todo Document why this abstraction exists, and the relationship between\n * environment, file managers, and plugin manager\n */\n\nimport logger from '../logger';\n\nclass Environment {\n constructor(externalEnvironment, fileManagers) {\n this.fileManagers = fileManagers || [];\n externalEnvironment = externalEnvironment || {};\n\n const optionalFunctions = ['encodeBase64', 'mimeLookup', 'charsetLookup', 'getSourceMapGenerator'];\n const requiredFunctions = [];\n const functions = requiredFunctions.concat(optionalFunctions);\n\n for (let i = 0; i < functions.length; i++) {\n const propName = functions[i];\n const environmentFunc = externalEnvironment[propName];\n if (environmentFunc) {\n this[propName] = environmentFunc.bind(externalEnvironment);\n } else if (i < requiredFunctions.length) {\n this.warn(`missing required function in environment - ${propName}`);\n }\n }\n }\n\n getFileManager(filename, currentDirectory, options, environment, isSync) {\n\n if (!filename) {\n logger.warn('getFileManager called with no filename.. Please report this issue. continuing.');\n }\n if (currentDirectory == null) {\n logger.warn('getFileManager called with null directory.. Please report this issue. continuing.');\n }\n\n let fileManagers = this.fileManagers;\n if (options.pluginManager) {\n fileManagers = [].concat(fileManagers).concat(options.pluginManager.getFileManagers());\n }\n for (let i = fileManagers.length - 1; i >= 0 ; i--) {\n const fileManager = fileManagers[i];\n if (fileManager[isSync ? 'supportsSync' : 'supports'](filename, currentDirectory, options, environment)) {\n return fileManager;\n }\n }\n return null;\n }\n\n addFileManager(fileManager) {\n this.fileManagers.push(fileManager);\n }\n\n clearFileManagers() {\n this.fileManagers = [];\n }\n}\n\nexport default Environment;\n","export default {\n 'aliceblue':'#f0f8ff',\n 'antiquewhite':'#faebd7',\n 'aqua':'#00ffff',\n 'aquamarine':'#7fffd4',\n 'azure':'#f0ffff',\n 'beige':'#f5f5dc',\n 'bisque':'#ffe4c4',\n 'black':'#000000',\n 'blanchedalmond':'#ffebcd',\n 'blue':'#0000ff',\n 'blueviolet':'#8a2be2',\n 'brown':'#a52a2a',\n 'burlywood':'#deb887',\n 'cadetblue':'#5f9ea0',\n 'chartreuse':'#7fff00',\n 'chocolate':'#d2691e',\n 'coral':'#ff7f50',\n 'cornflowerblue':'#6495ed',\n 'cornsilk':'#fff8dc',\n 'crimson':'#dc143c',\n 'cyan':'#00ffff',\n 'darkblue':'#00008b',\n 'darkcyan':'#008b8b',\n 'darkgoldenrod':'#b8860b',\n 'darkgray':'#a9a9a9',\n 'darkgrey':'#a9a9a9',\n 'darkgreen':'#006400',\n 'darkkhaki':'#bdb76b',\n 'darkmagenta':'#8b008b',\n 'darkolivegreen':'#556b2f',\n 'darkorange':'#ff8c00',\n 'darkorchid':'#9932cc',\n 'darkred':'#8b0000',\n 'darksalmon':'#e9967a',\n 'darkseagreen':'#8fbc8f',\n 'darkslateblue':'#483d8b',\n 'darkslategray':'#2f4f4f',\n 'darkslategrey':'#2f4f4f',\n 'darkturquoise':'#00ced1',\n 'darkviolet':'#9400d3',\n 'deeppink':'#ff1493',\n 'deepskyblue':'#00bfff',\n 'dimgray':'#696969',\n 'dimgrey':'#696969',\n 'dodgerblue':'#1e90ff',\n 'firebrick':'#b22222',\n 'floralwhite':'#fffaf0',\n 'forestgreen':'#228b22',\n 'fuchsia':'#ff00ff',\n 'gainsboro':'#dcdcdc',\n 'ghostwhite':'#f8f8ff',\n 'gold':'#ffd700',\n 'goldenrod':'#daa520',\n 'gray':'#808080',\n 'grey':'#808080',\n 'green':'#008000',\n 'greenyellow':'#adff2f',\n 'honeydew':'#f0fff0',\n 'hotpink':'#ff69b4',\n 'indianred':'#cd5c5c',\n 'indigo':'#4b0082',\n 'ivory':'#fffff0',\n 'khaki':'#f0e68c',\n 'lavender':'#e6e6fa',\n 'lavenderblush':'#fff0f5',\n 'lawngreen':'#7cfc00',\n 'lemonchiffon':'#fffacd',\n 'lightblue':'#add8e6',\n 'lightcoral':'#f08080',\n 'lightcyan':'#e0ffff',\n 'lightgoldenrodyellow':'#fafad2',\n 'lightgray':'#d3d3d3',\n 'lightgrey':'#d3d3d3',\n 'lightgreen':'#90ee90',\n 'lightpink':'#ffb6c1',\n 'lightsalmon':'#ffa07a',\n 'lightseagreen':'#20b2aa',\n 'lightskyblue':'#87cefa',\n 'lightslategray':'#778899',\n 'lightslategrey':'#778899',\n 'lightsteelblue':'#b0c4de',\n 'lightyellow':'#ffffe0',\n 'lime':'#00ff00',\n 'limegreen':'#32cd32',\n 'linen':'#faf0e6',\n 'magenta':'#ff00ff',\n 'maroon':'#800000',\n 'mediumaquamarine':'#66cdaa',\n 'mediumblue':'#0000cd',\n 'mediumorchid':'#ba55d3',\n 'mediumpurple':'#9370d8',\n 'mediumseagreen':'#3cb371',\n 'mediumslateblue':'#7b68ee',\n 'mediumspringgreen':'#00fa9a',\n 'mediumturquoise':'#48d1cc',\n 'mediumvioletred':'#c71585',\n 'midnightblue':'#191970',\n 'mintcream':'#f5fffa',\n 'mistyrose':'#ffe4e1',\n 'moccasin':'#ffe4b5',\n 'navajowhite':'#ffdead',\n 'navy':'#000080',\n 'oldlace':'#fdf5e6',\n 'olive':'#808000',\n 'olivedrab':'#6b8e23',\n 'orange':'#ffa500',\n 'orangered':'#ff4500',\n 'orchid':'#da70d6',\n 'palegoldenrod':'#eee8aa',\n 'palegreen':'#98fb98',\n 'paleturquoise':'#afeeee',\n 'palevioletred':'#d87093',\n 'papayawhip':'#ffefd5',\n 'peachpuff':'#ffdab9',\n 'peru':'#cd853f',\n 'pink':'#ffc0cb',\n 'plum':'#dda0dd',\n 'powderblue':'#b0e0e6',\n 'purple':'#800080',\n 'rebeccapurple':'#663399',\n 'red':'#ff0000',\n 'rosybrown':'#bc8f8f',\n 'royalblue':'#4169e1',\n 'saddlebrown':'#8b4513',\n 'salmon':'#fa8072',\n 'sandybrown':'#f4a460',\n 'seagreen':'#2e8b57',\n 'seashell':'#fff5ee',\n 'sienna':'#a0522d',\n 'silver':'#c0c0c0',\n 'skyblue':'#87ceeb',\n 'slateblue':'#6a5acd',\n 'slategray':'#708090',\n 'slategrey':'#708090',\n 'snow':'#fffafa',\n 'springgreen':'#00ff7f',\n 'steelblue':'#4682b4',\n 'tan':'#d2b48c',\n 'teal':'#008080',\n 'thistle':'#d8bfd8',\n 'tomato':'#ff6347',\n 'turquoise':'#40e0d0',\n 'violet':'#ee82ee',\n 'wheat':'#f5deb3',\n 'white':'#ffffff',\n 'whitesmoke':'#f5f5f5',\n 'yellow':'#ffff00',\n 'yellowgreen':'#9acd32'\n};","export default {\n length: {\n 'm': 1,\n 'cm': 0.01,\n 'mm': 0.001,\n 'in': 0.0254,\n 'px': 0.0254 / 96,\n 'pt': 0.0254 / 72,\n 'pc': 0.0254 / 72 * 12\n },\n duration: {\n 's': 1,\n 'ms': 0.001\n },\n angle: {\n 'rad': 1 / (2 * Math.PI),\n 'deg': 1 / 360,\n 'grad': 1 / 400,\n 'turn': 1\n }\n};","import colors from './colors';\nimport unitConversions from './unit-conversions';\n\nexport default { colors, unitConversions };\n","/**\n * The reason why Node is a class and other nodes simply do not extend\n * from Node (since we're transpiling) is due to this issue:\n * \n * https://github.com/less/less.js/issues/3434\n */\nclass Node {\n constructor() {\n this.parent = null;\n this.visibilityBlocks = undefined;\n this.nodeVisible = undefined;\n this.rootNode = null;\n this.parsed = null;\n\n const self = this;\n Object.defineProperty(this, 'currentFileInfo', {\n get: function() { return self.fileInfo(); }\n });\n Object.defineProperty(this, 'index', {\n get: function() { return self.getIndex(); }\n });\n\n }\n\n setParent(nodes, parent) {\n function set(node) {\n if (node && node instanceof Node) {\n node.parent = parent;\n }\n }\n if (Array.isArray(nodes)) {\n nodes.forEach(set);\n }\n else {\n set(nodes);\n }\n }\n\n getIndex() {\n return this._index || (this.parent && this.parent.getIndex()) || 0;\n }\n\n fileInfo() {\n return this._fileInfo || (this.parent && this.parent.fileInfo()) || {};\n }\n\n isRulesetLike() { return false; }\n\n toCSS(context) {\n const strs = [];\n this.genCSS(context, {\n add: function(chunk, fileInfo, index) {\n strs.push(chunk);\n },\n isEmpty: function () {\n return strs.length === 0;\n }\n });\n return strs.join('');\n }\n\n genCSS(context, output) {\n output.add(this.value);\n }\n\n accept(visitor) {\n this.value = visitor.visit(this.value);\n }\n\n eval() { return this; }\n\n _operate(context, op, a, b) {\n switch (op) {\n case '+': return a + b;\n case '-': return a - b;\n case '*': return a * b;\n case '/': return a / b;\n }\n }\n\n fround(context, value) {\n const precision = context && context.numPrecision;\n // add \"epsilon\" to ensure numbers like 1.000000005 (represented as 1.000000004999...) are properly rounded:\n return (precision) ? Number((value + 2e-16).toFixed(precision)) : value;\n }\n\n static compare(a, b) {\n /* returns:\n -1: a < b\n 0: a = b\n 1: a > b\n and *any* other value for a != b (e.g. undefined, NaN, -2 etc.) */\n\n if ((a.compare) &&\n // for \"symmetric results\" force toCSS-based comparison\n // of Quoted or Anonymous if either value is one of those\n !(b.type === 'Quoted' || b.type === 'Anonymous')) {\n return a.compare(b);\n } else if (b.compare) {\n return -b.compare(a);\n } else if (a.type !== b.type) {\n return undefined;\n }\n\n a = a.value;\n b = b.value;\n if (!Array.isArray(a)) {\n return a === b ? 0 : undefined;\n }\n if (a.length !== b.length) {\n return undefined;\n }\n for (let i = 0; i < a.length; i++) {\n if (Node.compare(a[i], b[i]) !== 0) {\n return undefined;\n }\n }\n return 0;\n }\n\n static numericCompare(a, b) {\n return a < b ? -1\n : a === b ? 0\n : a > b ? 1 : undefined;\n }\n\n // Returns true if this node represents root of ast imported by reference\n blocksVisibility() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n return this.visibilityBlocks !== 0;\n }\n\n addVisibilityBlock() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n this.visibilityBlocks = this.visibilityBlocks + 1;\n }\n\n removeVisibilityBlock() {\n if (this.visibilityBlocks == null) {\n this.visibilityBlocks = 0;\n }\n this.visibilityBlocks = this.visibilityBlocks - 1;\n }\n\n // Turns on node visibility - if called node will be shown in output regardless\n // of whether it comes from import by reference or not\n ensureVisibility() {\n this.nodeVisible = true;\n }\n\n // Turns off node visibility - if called node will NOT be shown in output regardless\n // of whether it comes from import by reference or not\n ensureInvisibility() {\n this.nodeVisible = false;\n }\n\n // return values:\n // false - the node must not be visible\n // true - the node must be visible\n // undefined or null - the node has the same visibility as its parent\n isVisible() {\n return this.nodeVisible;\n }\n\n visibilityInfo() {\n return {\n visibilityBlocks: this.visibilityBlocks,\n nodeVisible: this.nodeVisible\n };\n }\n\n copyVisibilityInfo(info) {\n if (!info) {\n return;\n }\n this.visibilityBlocks = info.visibilityBlocks;\n this.nodeVisible = info.nodeVisible;\n }\n}\n\nexport default Node;\n","import Node from './node';\nimport colors from '../data/colors';\n\n//\n// RGB Colors - #ff0014, #eee\n//\nconst Color = function(rgb, a, originalForm) {\n const self = this;\n //\n // The end goal here, is to parse the arguments\n // into an integer triplet, such as `128, 255, 0`\n //\n // This facilitates operations and conversions.\n //\n if (Array.isArray(rgb)) {\n this.rgb = rgb;\n } else if (rgb.length >= 6) {\n this.rgb = [];\n rgb.match(/.{2}/g).map(function (c, i) {\n if (i < 3) {\n self.rgb.push(parseInt(c, 16));\n } else {\n self.alpha = (parseInt(c, 16)) / 255;\n }\n });\n } else {\n this.rgb = [];\n rgb.split('').map(function (c, i) {\n if (i < 3) {\n self.rgb.push(parseInt(c + c, 16));\n } else {\n self.alpha = (parseInt(c + c, 16)) / 255;\n }\n });\n }\n this.alpha = this.alpha || (typeof a === 'number' ? a : 1);\n if (typeof originalForm !== 'undefined') {\n this.value = originalForm;\n }\n}\n\nColor.prototype = Object.assign(new Node(), {\n type: 'Color',\n\n luma() {\n let r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255;\n\n r = (r <= 0.03928) ? r / 12.92 : Math.pow(((r + 0.055) / 1.055), 2.4);\n g = (g <= 0.03928) ? g / 12.92 : Math.pow(((g + 0.055) / 1.055), 2.4);\n b = (b <= 0.03928) ? b / 12.92 : Math.pow(((b + 0.055) / 1.055), 2.4);\n\n return 0.2126 * r + 0.7152 * g + 0.0722 * b;\n },\n\n genCSS(context, output) {\n output.add(this.toCSS(context));\n },\n\n toCSS(context, doNotCompress) {\n const compress = context && context.compress && !doNotCompress;\n let color;\n let alpha;\n let colorFunction;\n let args = [];\n\n // `value` is set if this color was originally\n // converted from a named color string so we need\n // to respect this and try to output named color too.\n alpha = this.fround(context, this.alpha);\n\n if (this.value) {\n if (this.value.indexOf('rgb') === 0) {\n if (alpha < 1) {\n colorFunction = 'rgba';\n }\n } else if (this.value.indexOf('hsl') === 0) {\n if (alpha < 1) {\n colorFunction = 'hsla';\n } else {\n colorFunction = 'hsl';\n }\n } else {\n return this.value;\n }\n } else {\n if (alpha < 1) {\n colorFunction = 'rgba';\n }\n }\n\n switch (colorFunction) {\n case 'rgba':\n args = this.rgb.map(function (c) {\n return clamp(Math.round(c), 255);\n }).concat(clamp(alpha, 1));\n break;\n case 'hsla':\n args.push(clamp(alpha, 1));\n case 'hsl':\n color = this.toHSL();\n args = [\n this.fround(context, color.h),\n `${this.fround(context, color.s * 100)}%`,\n `${this.fround(context, color.l * 100)}%`\n ].concat(args);\n }\n\n if (colorFunction) {\n // Values are capped between `0` and `255`, rounded and zero-padded.\n return `${colorFunction}(${args.join(`,${compress ? '' : ' '}`)})`;\n }\n\n color = this.toRGB();\n\n if (compress) {\n const splitcolor = color.split('');\n\n // Convert color to short format\n if (splitcolor[1] === splitcolor[2] && splitcolor[3] === splitcolor[4] && splitcolor[5] === splitcolor[6]) {\n color = `#${splitcolor[1]}${splitcolor[3]}${splitcolor[5]}`;\n }\n }\n\n return color;\n },\n\n //\n // Operations have to be done per-channel, if not,\n // channels will spill onto each other. Once we have\n // our result, in the form of an integer triplet,\n // we create a new Color node to hold the result.\n //\n operate(context, op, other) {\n const rgb = new Array(3);\n const alpha = this.alpha * (1 - other.alpha) + other.alpha;\n for (let c = 0; c < 3; c++) {\n rgb[c] = this._operate(context, op, this.rgb[c], other.rgb[c]);\n }\n return new Color(rgb, alpha);\n },\n\n toRGB() {\n return toHex(this.rgb);\n },\n\n toHSL() {\n const r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255, a = this.alpha;\n\n const max = Math.max(r, g, b), min = Math.min(r, g, b);\n let h;\n let s;\n const l = (max + min) / 2;\n const d = max - min;\n\n if (max === min) {\n h = s = 0;\n } else {\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n\n switch (max) {\n case r: h = (g - b) / d + (g < b ? 6 : 0); break;\n case g: h = (b - r) / d + 2; break;\n case b: h = (r - g) / d + 4; break;\n }\n h /= 6;\n }\n return { h: h * 360, s, l, a };\n },\n\n // Adapted from http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript\n toHSV() {\n const r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255, a = this.alpha;\n\n const max = Math.max(r, g, b), min = Math.min(r, g, b);\n let h;\n let s;\n const v = max;\n\n const d = max - min;\n if (max === 0) {\n s = 0;\n } else {\n s = d / max;\n }\n\n if (max === min) {\n h = 0;\n } else {\n switch (max) {\n case r: h = (g - b) / d + (g < b ? 6 : 0); break;\n case g: h = (b - r) / d + 2; break;\n case b: h = (r - g) / d + 4; break;\n }\n h /= 6;\n }\n return { h: h * 360, s, v, a };\n },\n\n toARGB() {\n return toHex([this.alpha * 255].concat(this.rgb));\n },\n\n compare(x) {\n return (x.rgb &&\n x.rgb[0] === this.rgb[0] &&\n x.rgb[1] === this.rgb[1] &&\n x.rgb[2] === this.rgb[2] &&\n x.alpha === this.alpha) ? 0 : undefined;\n }\n});\n\nColor.fromKeyword = function(keyword) {\n let c;\n const key = keyword.toLowerCase();\n if (colors.hasOwnProperty(key)) {\n c = new Color(colors[key].slice(1));\n }\n else if (key === 'transparent') {\n c = new Color([0, 0, 0], 0);\n }\n\n if (c) {\n c.value = keyword;\n return c;\n }\n};\n\nfunction clamp(v, max) {\n return Math.min(Math.max(v, 0), max);\n}\n\nfunction toHex(v) {\n return `#${v.map(function (c) {\n c = clamp(Math.round(c), 255);\n return (c < 16 ? '0' : '') + c.toString(16);\n }).join('')}`;\n}\n\nexport default Color;\n","import Node from './node';\n\nconst Paren = function(node) {\n this.value = node;\n};\n\nParen.prototype = Object.assign(new Node(), {\n type: 'Paren',\n\n genCSS(context, output) {\n output.add('(');\n this.value.genCSS(context, output);\n output.add(')');\n },\n\n eval(context) {\n return new Paren(this.value.eval(context));\n }\n});\n\nexport default Paren;\n","import Node from './node';\nconst _noSpaceCombinators = {\n '': true,\n ' ': true,\n '|': true\n};\n\nconst Combinator = function(value) {\n if (value === ' ') {\n this.value = ' ';\n this.emptyOrWhitespace = true;\n } else {\n this.value = value ? value.trim() : '';\n this.emptyOrWhitespace = this.value === '';\n }\n}\n\nCombinator.prototype = Object.assign(new Node(), {\n type: 'Combinator',\n\n genCSS(context, output) {\n const spaceOrEmpty = (context.compress || _noSpaceCombinators[this.value]) ? '' : ' ';\n output.add(spaceOrEmpty + this.value + spaceOrEmpty);\n }\n});\n\nexport default Combinator;\n","import Node from './node';\nimport Paren from './paren';\nimport Combinator from './combinator';\n\nconst Element = function(combinator, value, isVariable, index, currentFileInfo, visibilityInfo) {\n this.combinator = combinator instanceof Combinator ?\n combinator : new Combinator(combinator);\n\n if (typeof value === 'string') {\n this.value = value.trim();\n } else if (value) {\n this.value = value;\n } else {\n this.value = '';\n }\n this.isVariable = isVariable;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.combinator, this);\n}\n\nElement.prototype = Object.assign(new Node(), {\n type: 'Element',\n\n accept(visitor) {\n const value = this.value;\n this.combinator = visitor.visit(this.combinator);\n if (typeof value === 'object') {\n this.value = visitor.visit(value);\n }\n },\n\n eval(context) {\n return new Element(this.combinator,\n this.value.eval ? this.value.eval(context) : this.value,\n this.isVariable,\n this.getIndex(),\n this.fileInfo(), this.visibilityInfo());\n },\n\n clone() {\n return new Element(this.combinator,\n this.value,\n this.isVariable,\n this.getIndex(),\n this.fileInfo(), this.visibilityInfo());\n },\n\n genCSS(context, output) {\n output.add(this.toCSS(context), this.fileInfo(), this.getIndex());\n },\n\n toCSS(context) {\n context = context || {};\n let value = this.value;\n const firstSelector = context.firstSelector;\n if (value instanceof Paren) {\n // selector in parens should not be affected by outer selector\n // flags (breaks only interpolated selectors - see #1973)\n context.firstSelector = true;\n }\n value = value.toCSS ? value.toCSS(context) : value;\n context.firstSelector = firstSelector;\n if (value === '' && this.combinator.value.charAt(0) === '&') {\n return '';\n } else {\n return this.combinator.toCSS(context) + value;\n }\n }\n});\n\nexport default Element;\n","\nexport const Math = {\n ALWAYS: 0,\n PARENS_DIVISION: 1,\n PARENS: 2\n // removed - STRICT_LEGACY: 3\n};\n\nexport const RewriteUrls = {\n OFF: 0,\n LOCAL: 1,\n ALL: 2\n};","/**\r\n * Returns the object type of the given payload\r\n *\r\n * @param {*} payload\r\n * @returns {string}\r\n */\r\nfunction getType(payload) {\r\n return Object.prototype.toString.call(payload).slice(8, -1);\r\n}\r\n/**\r\n * Returns whether the payload is undefined\r\n *\r\n * @param {*} payload\r\n * @returns {payload is undefined}\r\n */\r\nfunction isUndefined(payload) {\r\n return getType(payload) === 'Undefined';\r\n}\r\n/**\r\n * Returns whether the payload is null\r\n *\r\n * @param {*} payload\r\n * @returns {payload is null}\r\n */\r\nfunction isNull(payload) {\r\n return getType(payload) === 'Null';\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isPlainObject(payload) {\r\n if (getType(payload) !== 'Object')\r\n return false;\r\n return payload.constructor === Object && Object.getPrototypeOf(payload) === Object.prototype;\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isObject(payload) {\r\n return isPlainObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a an empty object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is { [K in any]: never }}\r\n */\r\nfunction isEmptyObject(payload) {\r\n return isPlainObject(payload) && Object.keys(payload).length === 0;\r\n}\r\n/**\r\n * Returns whether the payload is an any kind of object (including special classes or objects with different prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Record}\r\n */\r\nfunction isAnyObject(payload) {\r\n return getType(payload) === 'Object';\r\n}\r\n/**\r\n * Returns whether the payload is an object like a type passed in < >\r\n *\r\n * Usage: isObjectLike<{id: any}>(payload) // will make sure it's an object and has an `id` prop.\r\n *\r\n * @template T this must be passed in < >\r\n * @param {*} payload\r\n * @returns {payload is T}\r\n */\r\nfunction isObjectLike(payload) {\r\n return isAnyObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a function (regular or async)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is AnyFunction}\r\n */\r\nfunction isFunction(payload) {\r\n return typeof payload === \"function\";\r\n}\r\n/**\r\n * Returns whether the payload is an array\r\n *\r\n * @param {any} payload\r\n * @returns {payload is any[]}\r\n */\r\nfunction isArray(payload) {\r\n return getType(payload) === 'Array';\r\n}\r\n/**\r\n * Returns whether the payload is a an array with at least 1 item\r\n *\r\n * @param {*} payload\r\n * @returns {payload is any[]}\r\n */\r\nfunction isFullArray(payload) {\r\n return isArray(payload) && payload.length > 0;\r\n}\r\n/**\r\n * Returns whether the payload is a an empty array\r\n *\r\n * @param {*} payload\r\n * @returns {payload is []}\r\n */\r\nfunction isEmptyArray(payload) {\r\n return isArray(payload) && payload.length === 0;\r\n}\r\n/**\r\n * Returns whether the payload is a string\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isString(payload) {\r\n return getType(payload) === 'String';\r\n}\r\n/**\r\n * Returns whether the payload is a string, BUT returns false for ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isFullString(payload) {\r\n return isString(payload) && payload !== '';\r\n}\r\n/**\r\n * Returns whether the payload is ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isEmptyString(payload) {\r\n return payload === '';\r\n}\r\n/**\r\n * Returns whether the payload is a number (but not NaN)\r\n *\r\n * This will return `false` for `NaN`!!\r\n *\r\n * @param {*} payload\r\n * @returns {payload is number}\r\n */\r\nfunction isNumber(payload) {\r\n return getType(payload) === 'Number' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a boolean\r\n *\r\n * @param {*} payload\r\n * @returns {payload is boolean}\r\n */\r\nfunction isBoolean(payload) {\r\n return getType(payload) === 'Boolean';\r\n}\r\n/**\r\n * Returns whether the payload is a regular expression (RegExp)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is RegExp}\r\n */\r\nfunction isRegExp(payload) {\r\n return getType(payload) === 'RegExp';\r\n}\r\n/**\r\n * Returns whether the payload is a Map\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Map}\r\n */\r\nfunction isMap(payload) {\r\n return getType(payload) === 'Map';\r\n}\r\n/**\r\n * Returns whether the payload is a WeakMap\r\n *\r\n * @param {*} payload\r\n * @returns {payload is WeakMap}\r\n */\r\nfunction isWeakMap(payload) {\r\n return getType(payload) === 'WeakMap';\r\n}\r\n/**\r\n * Returns whether the payload is a Set\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Set}\r\n */\r\nfunction isSet(payload) {\r\n return getType(payload) === 'Set';\r\n}\r\n/**\r\n * Returns whether the payload is a WeakSet\r\n *\r\n * @param {*} payload\r\n * @returns {payload is WeakSet}\r\n */\r\nfunction isWeakSet(payload) {\r\n return getType(payload) === 'WeakSet';\r\n}\r\n/**\r\n * Returns whether the payload is a Symbol\r\n *\r\n * @param {*} payload\r\n * @returns {payload is symbol}\r\n */\r\nfunction isSymbol(payload) {\r\n return getType(payload) === 'Symbol';\r\n}\r\n/**\r\n * Returns whether the payload is a Date, and that the date is valid\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Date}\r\n */\r\nfunction isDate(payload) {\r\n return getType(payload) === 'Date' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a Blob\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Blob}\r\n */\r\nfunction isBlob(payload) {\r\n return getType(payload) === 'Blob';\r\n}\r\n/**\r\n * Returns whether the payload is a File\r\n *\r\n * @param {*} payload\r\n * @returns {payload is File}\r\n */\r\nfunction isFile(payload) {\r\n return getType(payload) === 'File';\r\n}\r\n/**\r\n * Returns whether the payload is a Promise\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Promise}\r\n */\r\nfunction isPromise(payload) {\r\n return getType(payload) === 'Promise';\r\n}\r\n/**\r\n * Returns whether the payload is an Error\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Error}\r\n */\r\nfunction isError(payload) {\r\n return getType(payload) === 'Error';\r\n}\r\n/**\r\n * Returns whether the payload is literally the value `NaN` (it's `NaN` and also a `number`)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is typeof NaN}\r\n */\r\nfunction isNaNValue(payload) {\r\n return getType(payload) === 'Number' && isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a primitive type (eg. Boolean | Null | Undefined | Number | String | Symbol)\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is boolean | null | undefined | number | string | symbol)}\r\n */\r\nfunction isPrimitive(payload) {\r\n return (isBoolean(payload) ||\r\n isNull(payload) ||\r\n isUndefined(payload) ||\r\n isNumber(payload) ||\r\n isString(payload) ||\r\n isSymbol(payload));\r\n}\r\n/**\r\n * Returns true whether the payload is null or undefined\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is null | undefined)}\r\n */\r\nfunction isNullOrUndefined(payload) {\r\n return isNull(payload) || isUndefined(payload);\r\n}\r\n/**\r\n * Does a generic check to check that the given payload is of a given type.\r\n * In cases like Number, it will return true for NaN as NaN is a Number (thanks javascript!);\r\n * It will, however, differentiate between object and null\r\n *\r\n * @template T\r\n * @param {*} payload\r\n * @param {T} type\r\n * @throws {TypeError} Will throw type error if type is an invalid type\r\n * @returns {payload is T}\r\n */\r\nfunction isType(payload, type) {\r\n if (!(type instanceof Function)) {\r\n throw new TypeError('Type must be a function');\r\n }\r\n if (!Object.prototype.hasOwnProperty.call(type, 'prototype')) {\r\n throw new TypeError('Type is not a class');\r\n }\r\n // Classes usually have names (as functions usually have names)\r\n var name = type.name;\r\n return getType(payload) === name || Boolean(payload && payload.constructor === type);\r\n}\n\nexport { getType, isAnyObject, isArray, isBlob, isBoolean, isDate, isEmptyArray, isEmptyObject, isEmptyString, isError, isFile, isFullArray, isFullString, isFunction, isMap, isNaNValue, isNull, isNullOrUndefined, isNumber, isObject, isObjectLike, isPlainObject, isPrimitive, isPromise, isRegExp, isSet, isString, isSymbol, isType, isUndefined, isWeakMap, isWeakSet };\n","import { isArray, isPlainObject } from 'is-what';\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n\r\nfunction __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\n\nfunction assignProp(carry, key, newVal, originalObject, includeNonenumerable) {\r\n var propType = {}.propertyIsEnumerable.call(originalObject, key)\r\n ? 'enumerable'\r\n : 'nonenumerable';\r\n if (propType === 'enumerable')\r\n carry[key] = newVal;\r\n if (includeNonenumerable && propType === 'nonenumerable') {\r\n Object.defineProperty(carry, key, {\r\n value: newVal,\r\n enumerable: false,\r\n writable: true,\r\n configurable: true,\r\n });\r\n }\r\n}\r\n/**\r\n * Copy (clone) an object and all its props recursively to get rid of any prop referenced of the original object. Arrays are also cloned, however objects inside arrays are still linked.\r\n *\r\n * @export\r\n * @template T\r\n * @param {T} target Target can be anything\r\n * @param {Options} [options={}] Options can be `props` or `nonenumerable`\r\n * @returns {T} the target with replaced values\r\n * @export\r\n */\r\nfunction copy(target, options) {\r\n if (options === void 0) { options = {}; }\r\n if (isArray(target))\r\n return target.map(function (i) { return copy(i, options); });\r\n if (!isPlainObject(target))\r\n return target;\r\n var props = Object.getOwnPropertyNames(target);\r\n var symbols = Object.getOwnPropertySymbols(target);\r\n return __spreadArrays(props, symbols).reduce(function (carry, key) {\r\n if (isArray(options.props) && !options.props.includes(key)) {\r\n return carry;\r\n }\r\n var val = target[key];\r\n var newVal = copy(val, options);\r\n assignProp(carry, key, newVal, target, options.nonenumerable);\r\n return carry;\r\n }, {});\r\n}\n\nexport { copy };\n","/* jshint proto: true */\nimport * as Constants from './constants';\nimport { copy } from 'copy-anything';\n\nexport function getLocation(index, inputStream) {\n let n = index + 1;\n let line = null;\n let column = -1;\n\n while (--n >= 0 && inputStream.charAt(n) !== '\\n') {\n column++;\n }\n\n if (typeof index === 'number') {\n line = (inputStream.slice(0, index).match(/\\n/g) || '').length;\n }\n\n return {\n line,\n column\n };\n}\n\nexport function copyArray(arr) {\n let i;\n const length = arr.length;\n const copy = new Array(length);\n\n for (i = 0; i < length; i++) {\n copy[i] = arr[i];\n }\n return copy;\n}\n\nexport function clone(obj) {\n const cloned = {};\n for (const prop in obj) {\n if (obj.hasOwnProperty(prop)) {\n cloned[prop] = obj[prop];\n }\n }\n return cloned;\n}\n\nexport function defaults(obj1, obj2) {\n let newObj = obj2 || {};\n if (!obj2._defaults) {\n newObj = {};\n const defaults = copy(obj1);\n newObj._defaults = defaults;\n const cloned = obj2 ? copy(obj2) : {};\n Object.assign(newObj, defaults, cloned);\n }\n return newObj;\n}\n\nexport function copyOptions(obj1, obj2) {\n if (obj2 && obj2._defaults) {\n return obj2;\n }\n const opts = defaults(obj1, obj2);\n if (opts.strictMath) {\n opts.math = Constants.Math.PARENS;\n }\n // Back compat with changed relativeUrls option\n if (opts.relativeUrls) {\n opts.rewriteUrls = Constants.RewriteUrls.ALL;\n }\n if (typeof opts.math === 'string') {\n switch (opts.math.toLowerCase()) {\n case 'always':\n opts.math = Constants.Math.ALWAYS;\n break;\n case 'parens-division':\n opts.math = Constants.Math.PARENS_DIVISION;\n break;\n case 'strict':\n case 'parens':\n opts.math = Constants.Math.PARENS;\n break;\n default:\n opts.math = Constants.Math.PARENS;\n }\n }\n if (typeof opts.rewriteUrls === 'string') {\n switch (opts.rewriteUrls.toLowerCase()) {\n case 'off':\n opts.rewriteUrls = Constants.RewriteUrls.OFF;\n break;\n case 'local':\n opts.rewriteUrls = Constants.RewriteUrls.LOCAL;\n break;\n case 'all':\n opts.rewriteUrls = Constants.RewriteUrls.ALL;\n break;\n }\n }\n return opts;\n}\n\nexport function merge(obj1, obj2) {\n for (const prop in obj2) {\n if (obj2.hasOwnProperty(prop)) {\n obj1[prop] = obj2[prop];\n }\n }\n return obj1;\n}\n\nexport function flattenArray(arr, result = []) {\n for (let i = 0, length = arr.length; i < length; i++) {\n const value = arr[i];\n if (Array.isArray(value)) {\n flattenArray(value, result);\n } else {\n if (value !== undefined) {\n result.push(value);\n }\n }\n }\n return result;\n}","import * as utils from './utils';\n\nconst anonymousFunc = /(|Function):(\\d+):(\\d+)/;\n\n/**\n * This is a centralized class of any error that could be thrown internally (mostly by the parser).\n * Besides standard .message it keeps some additional data like a path to the file where the error\n * occurred along with line and column numbers.\n *\n * @class\n * @extends Error\n * @type {module.LessError}\n *\n * @prop {string} type\n * @prop {string} filename\n * @prop {number} index\n * @prop {number} line\n * @prop {number} column\n * @prop {number} callLine\n * @prop {number} callExtract\n * @prop {string[]} extract\n *\n * @param {Object} e - An error object to wrap around or just a descriptive object\n * @param {Object} fileContentMap - An object with file contents in 'contents' property (like importManager) @todo - move to fileManager?\n * @param {string} [currentFilename]\n */\nconst LessError = function(e, fileContentMap, currentFilename) {\n Error.call(this);\n\n const filename = e.filename || currentFilename;\n\n this.message = e.message;\n this.stack = e.stack;\n\n if (fileContentMap && filename) {\n const input = fileContentMap.contents[filename];\n const loc = utils.getLocation(e.index, input);\n var line = loc.line;\n const col = loc.column;\n const callLine = e.call && utils.getLocation(e.call, input).line;\n const lines = input ? input.split('\\n') : '';\n\n this.type = e.type || 'Syntax';\n this.filename = filename;\n this.index = e.index;\n this.line = typeof line === 'number' ? line + 1 : null;\n this.column = col;\n\n if (!this.line && this.stack) {\n const found = this.stack.match(anonymousFunc);\n\n /**\n * We have to figure out how this environment stringifies anonymous functions\n * so we can correctly map plugin errors.\n * \n * Note, in Node 8, the output of anonymous funcs varied based on parameters\n * being present or not, so we inject dummy params.\n */\n const func = new Function('a', 'throw new Error()');\n let lineAdjust = 0;\n try {\n func();\n } catch (e) {\n const match = e.stack.match(anonymousFunc);\n var line = parseInt(match[2]);\n lineAdjust = 1 - line;\n }\n\n if (found) {\n if (found[2]) {\n this.line = parseInt(found[2]) + lineAdjust;\n }\n if (found[3]) {\n this.column = parseInt(found[3]);\n }\n }\n }\n\n this.callLine = callLine + 1;\n this.callExtract = lines[callLine];\n\n this.extract = [\n lines[this.line - 2],\n lines[this.line - 1],\n lines[this.line]\n ];\n }\n\n};\n\nif (typeof Object.create === 'undefined') {\n const F = function () {};\n F.prototype = Error.prototype;\n LessError.prototype = new F();\n} else {\n LessError.prototype = Object.create(Error.prototype);\n}\n\nLessError.prototype.constructor = LessError;\n\n/**\n * An overridden version of the default Object.prototype.toString\n * which uses additional information to create a helpful message.\n *\n * @param {Object} options\n * @returns {string}\n */\nLessError.prototype.toString = function(options) {\n options = options || {};\n\n let message = '';\n const extract = this.extract || [];\n let error = [];\n let stylize = function (str) { return str; };\n if (options.stylize) {\n const type = typeof options.stylize;\n if (type !== 'function') {\n throw Error(`options.stylize should be a function, got a ${type}!`);\n }\n stylize = options.stylize;\n }\n\n if (this.line !== null) {\n if (typeof extract[0] === 'string') {\n error.push(stylize(`${this.line - 1} ${extract[0]}`, 'grey'));\n }\n\n if (typeof extract[1] === 'string') {\n let errorTxt = `${this.line} `;\n if (extract[1]) {\n errorTxt += extract[1].slice(0, this.column) +\n stylize(stylize(stylize(extract[1].substr(this.column, 1), 'bold') +\n extract[1].slice(this.column + 1), 'red'), 'inverse');\n }\n error.push(errorTxt);\n }\n\n if (typeof extract[2] === 'string') {\n error.push(stylize(`${this.line + 1} ${extract[2]}`, 'grey'));\n }\n error = `${error.join('\\n') + stylize('', 'reset')}\\n`;\n }\n\n message += stylize(`${this.type}Error: ${this.message}`, 'red');\n if (this.filename) {\n message += stylize(' in ', 'red') + this.filename;\n }\n if (this.line) {\n message += stylize(` on line ${this.line}, column ${this.column + 1}:`, 'grey');\n }\n\n message += `\\n${error}`;\n\n if (this.callLine) {\n message += `${stylize('from ', 'red') + (this.filename || '')}/n`;\n message += `${stylize(this.callLine, 'grey')} ${this.callExtract}/n`;\n }\n\n return message;\n};\n\nexport default LessError;","import Node from './node';\nimport Element from './element';\nimport LessError from '../less-error';\n\nconst Selector = function(elements, extendList, condition, index, currentFileInfo, visibilityInfo) {\n this.extendList = extendList;\n this.condition = condition;\n this.evaldCondition = !condition;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.elements = this.getElements(elements);\n this.mixinElements_ = undefined;\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.elements, this);\n};\n\nSelector.prototype = Object.assign(new Node(), {\n type: 'Selector',\n\n accept(visitor) {\n if (this.elements) {\n this.elements = visitor.visitArray(this.elements);\n }\n if (this.extendList) {\n this.extendList = visitor.visitArray(this.extendList);\n }\n if (this.condition) {\n this.condition = visitor.visit(this.condition);\n }\n },\n\n createDerived(elements, extendList, evaldCondition) {\n elements = this.getElements(elements);\n const newSelector = new Selector(elements, extendList || this.extendList,\n null, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n newSelector.evaldCondition = (evaldCondition != null) ? evaldCondition : this.evaldCondition;\n newSelector.mediaEmpty = this.mediaEmpty;\n return newSelector;\n },\n\n getElements(els) {\n if (!els) {\n return [new Element('', '&', false, this._index, this._fileInfo)];\n }\n if (typeof els === 'string') {\n this.parse.parseNode(\n els, \n ['selector'],\n this._index, \n this._fileInfo, \n function(err, result) {\n if (err) {\n throw new LessError({\n index: err.index,\n message: err.message\n }, this.parse.imports, this._fileInfo.filename);\n }\n els = result[0].elements;\n });\n }\n return els;\n },\n\n createEmptySelectors() {\n const el = new Element('', '&', false, this._index, this._fileInfo), sels = [new Selector([el], null, null, this._index, this._fileInfo)];\n sels[0].mediaEmpty = true;\n return sels;\n },\n\n match(other) {\n const elements = this.elements;\n const len = elements.length;\n let olen;\n let i;\n\n other = other.mixinElements();\n olen = other.length;\n if (olen === 0 || len < olen) {\n return 0;\n } else {\n for (i = 0; i < olen; i++) {\n if (elements[i].value !== other[i]) {\n return 0;\n }\n }\n }\n\n return olen; // return number of matched elements\n },\n\n mixinElements() {\n if (this.mixinElements_) {\n return this.mixinElements_;\n }\n\n let elements = this.elements.map( function(v) {\n return v.combinator.value + (v.value.value || v.value);\n }).join('').match(/[,&#\\*\\.\\w-]([\\w-]|(\\\\.))*/g);\n\n if (elements) {\n if (elements[0] === '&') {\n elements.shift();\n }\n } else {\n elements = [];\n }\n\n return (this.mixinElements_ = elements);\n },\n\n isJustParentSelector() {\n return !this.mediaEmpty &&\n this.elements.length === 1 &&\n this.elements[0].value === '&' &&\n (this.elements[0].combinator.value === ' ' || this.elements[0].combinator.value === '');\n },\n\n eval(context) {\n const evaldCondition = this.condition && this.condition.eval(context);\n let elements = this.elements;\n let extendList = this.extendList;\n\n elements = elements && elements.map(function (e) { return e.eval(context); });\n extendList = extendList && extendList.map(function(extend) { return extend.eval(context); });\n\n return this.createDerived(elements, extendList, evaldCondition);\n },\n\n genCSS(context, output) {\n let i, element;\n if ((!context || !context.firstSelector) && this.elements[0].combinator.value === '') {\n output.add(' ', this.fileInfo(), this.getIndex());\n }\n for (i = 0; i < this.elements.length; i++) {\n element = this.elements[i];\n element.genCSS(context, output);\n }\n },\n\n getIsOutput() {\n return this.evaldCondition;\n }\n});\n\nexport default Selector;\n","import Node from './node';\n\nconst Value = function(value) {\n if (!value) {\n throw new Error('Value requires an array argument');\n }\n if (!Array.isArray(value)) {\n this.value = [ value ];\n }\n else {\n this.value = value;\n }\n};\n\nValue.prototype = Object.assign(new Node(), {\n type: 'Value',\n\n accept(visitor) {\n if (this.value) {\n this.value = visitor.visitArray(this.value);\n }\n },\n\n eval(context) {\n if (this.value.length === 1) {\n return this.value[0].eval(context);\n } else {\n return new Value(this.value.map(function (v) {\n return v.eval(context);\n }));\n }\n },\n\n genCSS(context, output) {\n let i;\n for (i = 0; i < this.value.length; i++) {\n this.value[i].genCSS(context, output);\n if (i + 1 < this.value.length) {\n output.add((context && context.compress) ? ',' : ', ');\n }\n }\n }\n});\n\nexport default Value;\n","import Node from './node';\n\nconst Keyword = function(value) {\n this.value = value;\n};\n\nKeyword.prototype = Object.assign(new Node(), {\n type: 'Keyword',\n\n genCSS(context, output) {\n if (this.value === '%') { throw { type: 'Syntax', message: 'Invalid % without number' }; }\n output.add(this.value);\n }\n});\n\nKeyword.True = new Keyword('true');\nKeyword.False = new Keyword('false');\n\nexport default Keyword;\n","import Node from './node';\n\nconst Anonymous = function(value, index, currentFileInfo, mapLines, rulesetLike, visibilityInfo) {\n this.value = value;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.mapLines = mapLines;\n this.rulesetLike = (typeof rulesetLike === 'undefined') ? false : rulesetLike;\n this.allowRoot = true;\n this.copyVisibilityInfo(visibilityInfo);\n}\n\nAnonymous.prototype = Object.assign(new Node(), {\n type: 'Anonymous',\n eval() {\n return new Anonymous(this.value, this._index, this._fileInfo, this.mapLines, this.rulesetLike, this.visibilityInfo());\n },\n compare(other) {\n return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined;\n },\n isRulesetLike() {\n return this.rulesetLike;\n },\n genCSS(context, output) {\n this.nodeVisible = Boolean(this.value);\n if (this.nodeVisible) {\n output.add(this.value, this._fileInfo, this._index, this.mapLines);\n }\n }\n})\n\nexport default Anonymous;\n","import Node from './node';\nimport Value from './value';\nimport Keyword from './keyword';\nimport Anonymous from './anonymous';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\nfunction evalName(context, name) {\n let value = '';\n let i;\n const n = name.length;\n const output = {add: function (s) {value += s;}};\n for (i = 0; i < n; i++) {\n name[i].eval(context).genCSS(context, output);\n }\n return value;\n}\n\nconst Declaration = function(name, value, important, merge, index, currentFileInfo, inline, variable) {\n this.name = name;\n this.value = (value instanceof Node) ? value : new Value([value ? new Anonymous(value) : null]);\n this.important = important ? ` ${important.trim()}` : '';\n this.merge = merge;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.inline = inline || false;\n this.variable = (variable !== undefined) ? variable\n : (name.charAt && (name.charAt(0) === '@'));\n this.allowRoot = true;\n this.setParent(this.value, this);\n};\n\nDeclaration.prototype = Object.assign(new Node(), {\n type: 'Declaration',\n\n genCSS(context, output) {\n output.add(this.name + (context.compress ? ':' : ': '), this.fileInfo(), this.getIndex());\n try {\n this.value.genCSS(context, output);\n }\n catch (e) {\n e.index = this._index;\n e.filename = this._fileInfo.filename;\n throw e;\n }\n output.add(this.important + ((this.inline || (context.lastRule && context.compress)) ? '' : ';'), this._fileInfo, this._index);\n },\n\n eval(context) {\n let mathBypass = false, prevMath, name = this.name, evaldValue, variable = this.variable;\n if (typeof name !== 'string') {\n // expand 'primitive' name directly to get\n // things faster (~10% for benchmark.less):\n name = (name.length === 1) && (name[0] instanceof Keyword) ?\n name[0].value : evalName(context, name);\n variable = false; // never treat expanded interpolation as new variable name\n }\n\n // @todo remove when parens-division is default\n if (name === 'font' && context.math === MATH.ALWAYS) {\n mathBypass = true;\n prevMath = context.math;\n context.math = MATH.PARENS_DIVISION;\n }\n try {\n context.importantScope.push({});\n evaldValue = this.value.eval(context);\n\n if (!this.variable && evaldValue.type === 'DetachedRuleset') {\n throw { message: 'Rulesets cannot be evaluated on a property.',\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n let important = this.important;\n const importantResult = context.importantScope.pop();\n if (!important && importantResult.important) {\n important = importantResult.important;\n }\n\n return new Declaration(name,\n evaldValue,\n important,\n this.merge,\n this.getIndex(), this.fileInfo(), this.inline,\n variable);\n }\n catch (e) {\n if (typeof e.index !== 'number') {\n e.index = this.getIndex();\n e.filename = this.fileInfo().filename;\n }\n throw e;\n }\n finally {\n if (mathBypass) {\n context.math = prevMath;\n }\n }\n },\n\n makeImportant() {\n return new Declaration(this.name,\n this.value,\n '!important',\n this.merge,\n this.getIndex(), this.fileInfo(), this.inline);\n }\n});\n\nexport default Declaration;","class debugInfo {\n constructor(context, ctx, lineSeparator) {\n let result = '';\n if (context.dumpLineNumbers && !context.compress) {\n switch (context.dumpLineNumbers) {\n case 'comments':\n result = debugInfo.asComment(ctx);\n break;\n case 'mediaquery':\n result = debugInfo.asMediaQuery(ctx);\n break;\n case 'all':\n result = debugInfo.asComment(ctx) + (lineSeparator || '') + debugInfo.asMediaQuery(ctx);\n break;\n }\n }\n return result;\n }\n\n static asComment(ctx) {\n return `/* line ${ctx.debugInfo.lineNumber}, ${ctx.debugInfo.fileName} */\\n`;\n }\n\n static asMediaQuery(ctx) {\n let filenameWithProtocol = ctx.debugInfo.fileName;\n if (!/^[a-z]+:\\/\\//i.test(filenameWithProtocol)) {\n filenameWithProtocol = `file://${filenameWithProtocol}`;\n }\n return `@media -sass-debug-info{filename{font-family:${filenameWithProtocol.replace(/([.:\\/\\\\])/g, function (a) {\n if (a == '\\\\') {\n a = '\\/';\n }\n return `\\\\${a}`;\n })}}line{font-family:\\\\00003${ctx.debugInfo.lineNumber}}}\\n`;\n }\n}\n\nexport default debugInfo;\n","import Node from './node';\nimport getDebugInfo from './debug-info';\n\nconst Comment = function(value, isLineComment, index, currentFileInfo) {\n this.value = value;\n this.isLineComment = isLineComment;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.allowRoot = true;\n}\n\nComment.prototype = Object.assign(new Node(), {\n type: 'Comment',\n\n genCSS(context, output) {\n if (this.debugInfo) {\n output.add(getDebugInfo(context, this), this.fileInfo(), this.getIndex());\n }\n output.add(this.value);\n },\n\n isSilent(context) {\n const isCompressed = context.compress && this.value[2] !== '!';\n return this.isLineComment || isCompressed;\n }\n});\n\nexport default Comment;\n","const contexts = {};\nexport default contexts;\nimport * as Constants from './constants';\n\nconst copyFromOriginal = function copyFromOriginal(original, destination, propertiesToCopy) {\n if (!original) { return; }\n\n for (let i = 0; i < propertiesToCopy.length; i++) {\n if (original.hasOwnProperty(propertiesToCopy[i])) {\n destination[propertiesToCopy[i]] = original[propertiesToCopy[i]];\n }\n }\n};\n\n/*\n parse is used whilst parsing\n */\nconst parseCopyProperties = [\n // options\n 'paths', // option - unmodified - paths to search for imports on\n 'rewriteUrls', // option - whether to adjust URL's to be relative\n 'rootpath', // option - rootpath to append to URL's\n 'strictImports', // option -\n 'insecure', // option - whether to allow imports from insecure ssl hosts\n 'dumpLineNumbers', // option - whether to dump line numbers\n 'compress', // option - whether to compress\n 'syncImport', // option - whether to import synchronously\n 'chunkInput', // option - whether to chunk input. more performant but causes parse issues.\n 'mime', // browser only - mime type for sheet import\n 'useFileCache', // browser only - whether to use the per file session cache\n // context\n 'processImports', // option & context - whether to process imports. if false then imports will not be imported.\n // Used by the import manager to stop multiple import visitors being created.\n 'pluginManager' // Used as the plugin manager for the session\n];\n\ncontexts.Parse = function(options) {\n copyFromOriginal(options, this, parseCopyProperties);\n\n if (typeof this.paths === 'string') { this.paths = [this.paths]; }\n};\n\nconst evalCopyProperties = [\n 'paths', // additional include paths\n 'compress', // whether to compress\n 'math', // whether math has to be within parenthesis\n 'strictUnits', // whether units need to evaluate correctly\n 'sourceMap', // whether to output a source map\n 'importMultiple', // whether we are currently importing multiple copies\n 'urlArgs', // whether to add args into url tokens\n 'javascriptEnabled', // option - whether Inline JavaScript is enabled. if undefined, defaults to false\n 'pluginManager', // Used as the plugin manager for the session\n 'importantScope', // used to bubble up !important statements\n 'rewriteUrls' // option - whether to adjust URL's to be relative\n];\n\ncontexts.Eval = function(options, frames) {\n copyFromOriginal(options, this, evalCopyProperties);\n\n if (typeof this.paths === 'string') { this.paths = [this.paths]; }\n\n this.frames = frames || [];\n this.importantScope = this.importantScope || [];\n};\n\ncontexts.Eval.prototype.enterCalc = function () {\n if (!this.calcStack) {\n this.calcStack = [];\n }\n this.calcStack.push(true);\n this.inCalc = true;\n};\n\ncontexts.Eval.prototype.exitCalc = function () {\n this.calcStack.pop();\n if (!this.calcStack.length) {\n this.inCalc = false;\n }\n};\n\ncontexts.Eval.prototype.inParenthesis = function () {\n if (!this.parensStack) {\n this.parensStack = [];\n }\n this.parensStack.push(true);\n};\n\ncontexts.Eval.prototype.outOfParenthesis = function () {\n this.parensStack.pop();\n};\n\ncontexts.Eval.prototype.inCalc = false;\ncontexts.Eval.prototype.mathOn = true;\ncontexts.Eval.prototype.isMathOn = function (op) {\n if (!this.mathOn) {\n return false;\n }\n if (op === '/' && this.math !== Constants.Math.ALWAYS && (!this.parensStack || !this.parensStack.length)) {\n return false;\n }\n if (this.math > Constants.Math.PARENS_DIVISION) {\n return this.parensStack && this.parensStack.length;\n }\n return true;\n};\n\ncontexts.Eval.prototype.pathRequiresRewrite = function (path) {\n const isRelative = this.rewriteUrls === Constants.RewriteUrls.LOCAL ? isPathLocalRelative : isPathRelative;\n\n return isRelative(path);\n};\n\ncontexts.Eval.prototype.rewritePath = function (path, rootpath) {\n let newPath;\n\n rootpath = rootpath || '';\n newPath = this.normalizePath(rootpath + path);\n\n // If a path was explicit relative and the rootpath was not an absolute path\n // we must ensure that the new path is also explicit relative.\n if (isPathLocalRelative(path) &&\n isPathRelative(rootpath) &&\n isPathLocalRelative(newPath) === false) {\n newPath = `./${newPath}`;\n }\n\n return newPath;\n};\n\ncontexts.Eval.prototype.normalizePath = function (path) {\n const segments = path.split('/').reverse();\n let segment;\n\n path = [];\n while (segments.length !== 0) {\n segment = segments.pop();\n switch ( segment ) {\n case '.':\n break;\n case '..':\n if ((path.length === 0) || (path[path.length - 1] === '..')) {\n path.push( segment );\n } else {\n path.pop();\n }\n break;\n default:\n path.push(segment);\n break;\n }\n }\n\n return path.join('/');\n};\n\nfunction isPathRelative(path) {\n return !/^(?:[a-z-]+:|\\/|#)/i.test(path);\n}\n\nfunction isPathLocalRelative(path) {\n return path.charAt(0) === '.';\n}\n\n// todo - do the same for the toCSS ?\n","function makeRegistry( base ) {\n return {\n _data: {},\n add: function(name, func) {\n // precautionary case conversion, as later querying of\n // the registry by function-caller uses lower case as well.\n name = name.toLowerCase();\n\n if (this._data.hasOwnProperty(name)) {\n // TODO warn\n }\n this._data[name] = func;\n },\n addMultiple: function(functions) {\n Object.keys(functions).forEach(\n name => {\n this.add(name, functions[name]);\n });\n },\n get: function(name) {\n return this._data[name] || ( base && base.get( name ));\n },\n getLocalFunctions: function() {\n return this._data;\n },\n inherit: function() {\n return makeRegistry( this );\n },\n create: function(base) {\n return makeRegistry(base);\n }\n };\n}\n\nexport default makeRegistry( null );","import Keyword from '../tree/keyword';\n\nconst defaultFunc = {\n eval: function () {\n const v = this.value_;\n const e = this.error_;\n if (e) {\n throw e;\n }\n if (v != null) {\n return v ? Keyword.True : Keyword.False;\n }\n },\n value: function (v) {\n this.value_ = v;\n },\n error: function (e) {\n this.error_ = e;\n },\n reset: function () {\n this.value_ = this.error_ = null;\n }\n};\n\nexport default defaultFunc;\n","import Node from './node';\nimport Declaration from './declaration';\nimport Keyword from './keyword';\nimport Comment from './comment';\nimport Paren from './paren';\nimport Selector from './selector';\nimport Element from './element';\nimport Anonymous from './anonymous';\nimport contexts from '../contexts';\nimport globalFunctionRegistry from '../functions/function-registry';\nimport defaultFunc from '../functions/default';\nimport getDebugInfo from './debug-info';\nimport * as utils from '../utils';\n\nconst Ruleset = function(selectors, rules, strictImports, visibilityInfo) {\n this.selectors = selectors;\n this.rules = rules;\n this._lookups = {};\n this._variables = null;\n this._properties = null;\n this.strictImports = strictImports;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n\n this.setParent(this.selectors, this);\n this.setParent(this.rules, this);\n}\n\nRuleset.prototype = Object.assign(new Node(), {\n type: 'Ruleset',\n isRuleset: true,\n\n isRulesetLike() { return true; },\n\n accept(visitor) {\n if (this.paths) {\n this.paths = visitor.visitArray(this.paths, true);\n } else if (this.selectors) {\n this.selectors = visitor.visitArray(this.selectors);\n }\n if (this.rules && this.rules.length) {\n this.rules = visitor.visitArray(this.rules);\n }\n },\n\n eval(context) {\n const that = this;\n let selectors;\n let selCnt;\n let selector;\n let i;\n let hasVariable;\n let hasOnePassingSelector = false;\n\n if (this.selectors && (selCnt = this.selectors.length)) {\n selectors = new Array(selCnt);\n defaultFunc.error({\n type: 'Syntax',\n message: 'it is currently only allowed in parametric mixin guards,'\n });\n\n for (i = 0; i < selCnt; i++) {\n selector = this.selectors[i].eval(context);\n for (var j = 0; j < selector.elements.length; j++) {\n if (selector.elements[j].isVariable) {\n hasVariable = true;\n break;\n }\n }\n selectors[i] = selector;\n if (selector.evaldCondition) {\n hasOnePassingSelector = true;\n }\n }\n\n if (hasVariable) {\n const toParseSelectors = new Array(selCnt);\n for (i = 0; i < selCnt; i++) {\n selector = selectors[i];\n toParseSelectors[i] = selector.toCSS(context);\n }\n this.parse.parseNode(\n toParseSelectors.join(','),\n [\"selectors\"], \n selectors[0].getIndex(), \n selectors[0].fileInfo(), \n function(err, result) {\n if (result) {\n selectors = utils.flattenArray(result);\n }\n });\n }\n\n defaultFunc.reset();\n } else {\n hasOnePassingSelector = true;\n }\n\n let rules = this.rules ? utils.copyArray(this.rules) : null;\n const ruleset = new Ruleset(selectors, rules, this.strictImports, this.visibilityInfo());\n let rule;\n let subRule;\n\n ruleset.originalRuleset = this;\n ruleset.root = this.root;\n ruleset.firstRoot = this.firstRoot;\n ruleset.allowImports = this.allowImports;\n\n if (this.debugInfo) {\n ruleset.debugInfo = this.debugInfo;\n }\n\n if (!hasOnePassingSelector) {\n rules.length = 0;\n }\n\n // inherit a function registry from the frames stack when possible;\n // otherwise from the global registry\n ruleset.functionRegistry = (function (frames) {\n let i = 0;\n const n = frames.length;\n let found;\n for ( ; i !== n ; ++i ) {\n found = frames[ i ].functionRegistry;\n if ( found ) { return found; }\n }\n return globalFunctionRegistry;\n }(context.frames)).inherit();\n\n // push the current ruleset to the frames stack\n const ctxFrames = context.frames;\n ctxFrames.unshift(ruleset);\n\n // currrent selectors\n let ctxSelectors = context.selectors;\n if (!ctxSelectors) {\n context.selectors = ctxSelectors = [];\n }\n ctxSelectors.unshift(this.selectors);\n\n // Evaluate imports\n if (ruleset.root || ruleset.allowImports || !ruleset.strictImports) {\n ruleset.evalImports(context);\n }\n\n // Store the frames around mixin definitions,\n // so they can be evaluated like closures when the time comes.\n const rsRules = ruleset.rules;\n for (i = 0; (rule = rsRules[i]); i++) {\n if (rule.evalFirst) {\n rsRules[i] = rule.eval(context);\n }\n }\n\n const mediaBlockCount = (context.mediaBlocks && context.mediaBlocks.length) || 0;\n\n // Evaluate mixin calls.\n for (i = 0; (rule = rsRules[i]); i++) {\n if (rule.type === 'MixinCall') {\n /* jshint loopfunc:true */\n rules = rule.eval(context).filter(function(r) {\n if ((r instanceof Declaration) && r.variable) {\n // do not pollute the scope if the variable is\n // already there. consider returning false here\n // but we need a way to \"return\" variable from mixins\n return !(ruleset.variable(r.name));\n }\n return true;\n });\n rsRules.splice.apply(rsRules, [i, 1].concat(rules));\n i += rules.length - 1;\n ruleset.resetCache();\n } else if (rule.type === 'VariableCall') {\n /* jshint loopfunc:true */\n rules = rule.eval(context).rules.filter(function(r) {\n if ((r instanceof Declaration) && r.variable) {\n // do not pollute the scope at all\n return false;\n }\n return true;\n });\n rsRules.splice.apply(rsRules, [i, 1].concat(rules));\n i += rules.length - 1;\n ruleset.resetCache();\n }\n }\n\n // Evaluate everything else\n for (i = 0; (rule = rsRules[i]); i++) {\n if (!rule.evalFirst) {\n rsRules[i] = rule = rule.eval ? rule.eval(context) : rule;\n }\n }\n\n // Evaluate everything else\n for (i = 0; (rule = rsRules[i]); i++) {\n // for rulesets, check if it is a css guard and can be removed\n if (rule instanceof Ruleset && rule.selectors && rule.selectors.length === 1) {\n // check if it can be folded in (e.g. & where)\n if (rule.selectors[0] && rule.selectors[0].isJustParentSelector()) {\n rsRules.splice(i--, 1);\n\n for (var j = 0; (subRule = rule.rules[j]); j++) {\n if (subRule instanceof Node) {\n subRule.copyVisibilityInfo(rule.visibilityInfo());\n if (!(subRule instanceof Declaration) || !subRule.variable) {\n rsRules.splice(++i, 0, subRule);\n }\n }\n }\n }\n }\n }\n\n // Pop the stack\n ctxFrames.shift();\n ctxSelectors.shift();\n\n if (context.mediaBlocks) {\n for (i = mediaBlockCount; i < context.mediaBlocks.length; i++) {\n context.mediaBlocks[i].bubbleSelectors(selectors);\n }\n }\n\n return ruleset;\n },\n\n evalImports(context) {\n const rules = this.rules;\n let i;\n let importRules;\n if (!rules) { return; }\n\n for (i = 0; i < rules.length; i++) {\n if (rules[i].type === 'Import') {\n importRules = rules[i].eval(context);\n if (importRules && (importRules.length || importRules.length === 0)) {\n rules.splice.apply(rules, [i, 1].concat(importRules));\n i += importRules.length - 1;\n } else {\n rules.splice(i, 1, importRules);\n }\n this.resetCache();\n }\n }\n },\n\n makeImportant() {\n const result = new Ruleset(this.selectors, this.rules.map(function (r) {\n if (r.makeImportant) {\n return r.makeImportant();\n } else {\n return r;\n }\n }), this.strictImports, this.visibilityInfo());\n\n return result;\n },\n\n matchArgs(args) {\n return !args || args.length === 0;\n },\n\n // lets you call a css selector with a guard\n matchCondition(args, context) {\n const lastSelector = this.selectors[this.selectors.length - 1];\n if (!lastSelector.evaldCondition) {\n return false;\n }\n if (lastSelector.condition &&\n !lastSelector.condition.eval(\n new contexts.Eval(context,\n context.frames))) {\n return false;\n }\n return true;\n },\n\n resetCache() {\n this._rulesets = null;\n this._variables = null;\n this._properties = null;\n this._lookups = {};\n },\n\n variables() {\n if (!this._variables) {\n this._variables = !this.rules ? {} : this.rules.reduce(function (hash, r) {\n if (r instanceof Declaration && r.variable === true) {\n hash[r.name] = r;\n }\n // when evaluating variables in an import statement, imports have not been eval'd\n // so we need to go inside import statements.\n // guard against root being a string (in the case of inlined less)\n if (r.type === 'Import' && r.root && r.root.variables) {\n const vars = r.root.variables();\n for (const name in vars) {\n if (vars.hasOwnProperty(name)) {\n hash[name] = r.root.variable(name);\n }\n }\n }\n return hash;\n }, {});\n }\n return this._variables;\n },\n\n properties() {\n if (!this._properties) {\n this._properties = !this.rules ? {} : this.rules.reduce(function (hash, r) {\n if (r instanceof Declaration && r.variable !== true) {\n const name = (r.name.length === 1) && (r.name[0] instanceof Keyword) ?\n r.name[0].value : r.name;\n // Properties don't overwrite as they can merge\n if (!hash[`$${name}`]) {\n hash[`$${name}`] = [ r ];\n }\n else {\n hash[`$${name}`].push(r);\n }\n }\n return hash;\n }, {});\n }\n return this._properties;\n },\n\n variable(name) {\n const decl = this.variables()[name];\n if (decl) {\n return this.parseValue(decl);\n }\n },\n\n property(name) {\n const decl = this.properties()[name];\n if (decl) {\n return this.parseValue(decl);\n }\n },\n\n lastDeclaration() {\n for (let i = this.rules.length; i > 0; i--) {\n const decl = this.rules[i - 1];\n if (decl instanceof Declaration) {\n return this.parseValue(decl);\n }\n }\n },\n\n parseValue(toParse) {\n const self = this;\n function transformDeclaration(decl) {\n if (decl.value instanceof Anonymous && !decl.parsed) {\n if (typeof decl.value.value === 'string') {\n this.parse.parseNode(\n decl.value.value,\n ['value', 'important'], \n decl.value.getIndex(), \n decl.fileInfo(), \n function(err, result) {\n if (err) {\n decl.parsed = true;\n }\n if (result) {\n decl.value = result[0];\n decl.important = result[1] || '';\n decl.parsed = true;\n }\n });\n } else {\n decl.parsed = true;\n }\n\n return decl;\n }\n else {\n return decl;\n }\n }\n if (!Array.isArray(toParse)) {\n return transformDeclaration.call(self, toParse);\n }\n else {\n const nodes = [];\n toParse.forEach(function(n) {\n nodes.push(transformDeclaration.call(self, n));\n });\n return nodes;\n }\n },\n\n rulesets() {\n if (!this.rules) { return []; }\n\n const filtRules = [];\n const rules = this.rules;\n let i;\n let rule;\n\n for (i = 0; (rule = rules[i]); i++) {\n if (rule.isRuleset) {\n filtRules.push(rule);\n }\n }\n\n return filtRules;\n },\n\n prependRule(rule) {\n const rules = this.rules;\n if (rules) {\n rules.unshift(rule);\n } else {\n this.rules = [ rule ];\n }\n this.setParent(rule, this);\n },\n\n find(selector, self, filter) {\n self = self || this;\n const rules = [];\n let match;\n let foundMixins;\n const key = selector.toCSS();\n\n if (key in this._lookups) { return this._lookups[key]; }\n\n this.rulesets().forEach(function (rule) {\n if (rule !== self) {\n for (let j = 0; j < rule.selectors.length; j++) {\n match = selector.match(rule.selectors[j]);\n if (match) {\n if (selector.elements.length > match) {\n if (!filter || filter(rule)) {\n foundMixins = rule.find(new Selector(selector.elements.slice(match)), self, filter);\n for (let i = 0; i < foundMixins.length; ++i) {\n foundMixins[i].path.push(rule);\n }\n Array.prototype.push.apply(rules, foundMixins);\n }\n } else {\n rules.push({ rule, path: []});\n }\n break;\n }\n }\n }\n });\n this._lookups[key] = rules;\n return rules;\n },\n\n genCSS(context, output) {\n let i;\n let j;\n const charsetRuleNodes = [];\n let ruleNodes = [];\n\n let // Line number debugging\n debugInfo;\n\n let rule;\n let path;\n\n context.tabLevel = (context.tabLevel || 0);\n\n if (!this.root) {\n context.tabLevel++;\n }\n\n const tabRuleStr = context.compress ? '' : Array(context.tabLevel + 1).join(' ');\n const tabSetStr = context.compress ? '' : Array(context.tabLevel).join(' ');\n let sep;\n\n let charsetNodeIndex = 0;\n let importNodeIndex = 0;\n for (i = 0; (rule = this.rules[i]); i++) {\n if (rule instanceof Comment) {\n if (importNodeIndex === i) {\n importNodeIndex++;\n }\n ruleNodes.push(rule);\n } else if (rule.isCharset && rule.isCharset()) {\n ruleNodes.splice(charsetNodeIndex, 0, rule);\n charsetNodeIndex++;\n importNodeIndex++;\n } else if (rule.type === 'Import') {\n ruleNodes.splice(importNodeIndex, 0, rule);\n importNodeIndex++;\n } else {\n ruleNodes.push(rule);\n }\n }\n ruleNodes = charsetRuleNodes.concat(ruleNodes);\n\n // If this is the root node, we don't render\n // a selector, or {}.\n if (!this.root) {\n debugInfo = getDebugInfo(context, this, tabSetStr);\n\n if (debugInfo) {\n output.add(debugInfo);\n output.add(tabSetStr);\n }\n\n const paths = this.paths;\n const pathCnt = paths.length;\n let pathSubCnt;\n\n sep = context.compress ? ',' : (`,\\n${tabSetStr}`);\n\n for (i = 0; i < pathCnt; i++) {\n path = paths[i];\n if (!(pathSubCnt = path.length)) { continue; }\n if (i > 0) { output.add(sep); }\n\n context.firstSelector = true;\n path[0].genCSS(context, output);\n\n context.firstSelector = false;\n for (j = 1; j < pathSubCnt; j++) {\n path[j].genCSS(context, output);\n }\n }\n\n output.add((context.compress ? '{' : ' {\\n') + tabRuleStr);\n }\n\n // Compile rules and rulesets\n for (i = 0; (rule = ruleNodes[i]); i++) {\n\n if (i + 1 === ruleNodes.length) {\n context.lastRule = true;\n }\n\n const currentLastRule = context.lastRule;\n if (rule.isRulesetLike(rule)) {\n context.lastRule = false;\n }\n\n if (rule.genCSS) {\n rule.genCSS(context, output);\n } else if (rule.value) {\n output.add(rule.value.toString());\n }\n\n context.lastRule = currentLastRule;\n\n if (!context.lastRule && rule.isVisible()) {\n output.add(context.compress ? '' : (`\\n${tabRuleStr}`));\n } else {\n context.lastRule = false;\n }\n }\n\n if (!this.root) {\n output.add((context.compress ? '}' : `\\n${tabSetStr}}`));\n context.tabLevel--;\n }\n\n if (!output.isEmpty() && !context.compress && this.firstRoot) {\n output.add('\\n');\n }\n },\n\n joinSelectors(paths, context, selectors) {\n for (let s = 0; s < selectors.length; s++) {\n this.joinSelector(paths, context, selectors[s]);\n }\n },\n\n joinSelector(paths, context, selector) {\n\n function createParenthesis(elementsToPak, originalElement) {\n let replacementParen, j;\n if (elementsToPak.length === 0) {\n replacementParen = new Paren(elementsToPak[0]);\n } else {\n const insideParent = new Array(elementsToPak.length);\n for (j = 0; j < elementsToPak.length; j++) {\n insideParent[j] = new Element(\n null,\n elementsToPak[j],\n originalElement.isVariable,\n originalElement._index,\n originalElement._fileInfo\n );\n }\n replacementParen = new Paren(new Selector(insideParent));\n }\n return replacementParen;\n }\n\n function createSelector(containedElement, originalElement) {\n let element, selector;\n element = new Element(null, containedElement, originalElement.isVariable, originalElement._index, originalElement._fileInfo);\n selector = new Selector([element]);\n return selector;\n }\n\n // joins selector path from `beginningPath` with selector path in `addPath`\n // `replacedElement` contains element that is being replaced by `addPath`\n // returns concatenated path\n function addReplacementIntoPath(beginningPath, addPath, replacedElement, originalSelector) {\n let newSelectorPath, lastSelector, newJoinedSelector;\n // our new selector path\n newSelectorPath = [];\n\n // construct the joined selector - if & is the first thing this will be empty,\n // if not newJoinedSelector will be the last set of elements in the selector\n if (beginningPath.length > 0) {\n newSelectorPath = utils.copyArray(beginningPath);\n lastSelector = newSelectorPath.pop();\n newJoinedSelector = originalSelector.createDerived(utils.copyArray(lastSelector.elements));\n }\n else {\n newJoinedSelector = originalSelector.createDerived([]);\n }\n\n if (addPath.length > 0) {\n // /deep/ is a CSS4 selector - (removed, so should deprecate)\n // that is valid without anything in front of it\n // so if the & does not have a combinator that is \"\" or \" \" then\n // and there is a combinator on the parent, then grab that.\n // this also allows + a { & .b { .a & { ... though not sure why you would want to do that\n let combinator = replacedElement.combinator;\n\n const parentEl = addPath[0].elements[0];\n if (combinator.emptyOrWhitespace && !parentEl.combinator.emptyOrWhitespace) {\n combinator = parentEl.combinator;\n }\n // join the elements so far with the first part of the parent\n newJoinedSelector.elements.push(new Element(\n combinator,\n parentEl.value,\n replacedElement.isVariable,\n replacedElement._index,\n replacedElement._fileInfo\n ));\n newJoinedSelector.elements = newJoinedSelector.elements.concat(addPath[0].elements.slice(1));\n }\n\n // now add the joined selector - but only if it is not empty\n if (newJoinedSelector.elements.length !== 0) {\n newSelectorPath.push(newJoinedSelector);\n }\n\n // put together the parent selectors after the join (e.g. the rest of the parent)\n if (addPath.length > 1) {\n let restOfPath = addPath.slice(1);\n restOfPath = restOfPath.map(function (selector) {\n return selector.createDerived(selector.elements, []);\n });\n newSelectorPath = newSelectorPath.concat(restOfPath);\n }\n return newSelectorPath;\n }\n\n // joins selector path from `beginningPath` with every selector path in `addPaths` array\n // `replacedElement` contains element that is being replaced by `addPath`\n // returns array with all concatenated paths\n function addAllReplacementsIntoPath( beginningPath, addPaths, replacedElement, originalSelector, result) {\n let j;\n for (j = 0; j < beginningPath.length; j++) {\n const newSelectorPath = addReplacementIntoPath(beginningPath[j], addPaths, replacedElement, originalSelector);\n result.push(newSelectorPath);\n }\n return result;\n }\n\n function mergeElementsOnToSelectors(elements, selectors) {\n let i, sel;\n\n if (elements.length === 0) {\n return ;\n }\n if (selectors.length === 0) {\n selectors.push([ new Selector(elements) ]);\n return;\n }\n\n for (i = 0; (sel = selectors[i]); i++) {\n // if the previous thing in sel is a parent this needs to join on to it\n if (sel.length > 0) {\n sel[sel.length - 1] = sel[sel.length - 1].createDerived(sel[sel.length - 1].elements.concat(elements));\n }\n else {\n sel.push(new Selector(elements));\n }\n }\n }\n\n // replace all parent selectors inside `inSelector` by content of `context` array\n // resulting selectors are returned inside `paths` array\n // returns true if `inSelector` contained at least one parent selector\n function replaceParentSelector(paths, context, inSelector) {\n // The paths are [[Selector]]\n // The first list is a list of comma separated selectors\n // The inner list is a list of inheritance separated selectors\n // e.g.\n // .a, .b {\n // .c {\n // }\n // }\n // == [[.a] [.c]] [[.b] [.c]]\n //\n let i, j, k, currentElements, newSelectors, selectorsMultiplied, sel, el, hadParentSelector = false, length, lastSelector;\n function findNestedSelector(element) {\n let maybeSelector;\n if (!(element.value instanceof Paren)) {\n return null;\n }\n\n maybeSelector = element.value.value;\n if (!(maybeSelector instanceof Selector)) {\n return null;\n }\n\n return maybeSelector;\n }\n\n // the elements from the current selector so far\n currentElements = [];\n // the current list of new selectors to add to the path.\n // We will build it up. We initiate it with one empty selector as we \"multiply\" the new selectors\n // by the parents\n newSelectors = [\n []\n ];\n\n for (i = 0; (el = inSelector.elements[i]); i++) {\n // non parent reference elements just get added\n if (el.value !== '&') {\n const nestedSelector = findNestedSelector(el);\n if (nestedSelector != null) {\n // merge the current list of non parent selector elements\n // on to the current list of selectors to add\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n const nestedPaths = [];\n let replaced;\n const replacedNewSelectors = [];\n replaced = replaceParentSelector(nestedPaths, context, nestedSelector);\n hadParentSelector = hadParentSelector || replaced;\n // the nestedPaths array should have only one member - replaceParentSelector does not multiply selectors\n for (k = 0; k < nestedPaths.length; k++) {\n const replacementSelector = createSelector(createParenthesis(nestedPaths[k], el), el);\n addAllReplacementsIntoPath(newSelectors, [replacementSelector], el, inSelector, replacedNewSelectors);\n }\n newSelectors = replacedNewSelectors;\n currentElements = [];\n } else {\n currentElements.push(el);\n }\n\n } else {\n hadParentSelector = true;\n // the new list of selectors to add\n selectorsMultiplied = [];\n\n // merge the current list of non parent selector elements\n // on to the current list of selectors to add\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n // loop through our current selectors\n for (j = 0; j < newSelectors.length; j++) {\n sel = newSelectors[j];\n // if we don't have any parent paths, the & might be in a mixin so that it can be used\n // whether there are parents or not\n if (context.length === 0) {\n // the combinator used on el should now be applied to the next element instead so that\n // it is not lost\n if (sel.length > 0) {\n sel[0].elements.push(new Element(el.combinator, '', el.isVariable, el._index, el._fileInfo));\n }\n selectorsMultiplied.push(sel);\n }\n else {\n // and the parent selectors\n for (k = 0; k < context.length; k++) {\n // We need to put the current selectors\n // then join the last selector's elements on to the parents selectors\n const newSelectorPath = addReplacementIntoPath(sel, context[k], el, inSelector);\n // add that to our new set of selectors\n selectorsMultiplied.push(newSelectorPath);\n }\n }\n }\n\n // our new selectors has been multiplied, so reset the state\n newSelectors = selectorsMultiplied;\n currentElements = [];\n }\n }\n\n // if we have any elements left over (e.g. .a& .b == .b)\n // add them on to all the current selectors\n mergeElementsOnToSelectors(currentElements, newSelectors);\n\n for (i = 0; i < newSelectors.length; i++) {\n length = newSelectors[i].length;\n if (length > 0) {\n paths.push(newSelectors[i]);\n lastSelector = newSelectors[i][length - 1];\n newSelectors[i][length - 1] = lastSelector.createDerived(lastSelector.elements, inSelector.extendList);\n }\n }\n\n return hadParentSelector;\n }\n\n function deriveSelector(visibilityInfo, deriveFrom) {\n const newSelector = deriveFrom.createDerived(deriveFrom.elements, deriveFrom.extendList, deriveFrom.evaldCondition);\n newSelector.copyVisibilityInfo(visibilityInfo);\n return newSelector;\n }\n\n // joinSelector code follows\n let i, newPaths, hadParentSelector;\n\n newPaths = [];\n hadParentSelector = replaceParentSelector(newPaths, context, selector);\n\n if (!hadParentSelector) {\n if (context.length > 0) {\n newPaths = [];\n for (i = 0; i < context.length; i++) {\n\n const concatenated = context[i].map(deriveSelector.bind(this, selector.visibilityInfo()));\n\n concatenated.push(selector);\n newPaths.push(concatenated);\n }\n }\n else {\n newPaths = [[selector]];\n }\n }\n\n for (i = 0; i < newPaths.length; i++) {\n paths.push(newPaths[i]);\n }\n\n }\n});\n\nexport default Ruleset;\n","import Node from './node';\nimport Selector from './selector';\nimport Ruleset from './ruleset';\nimport Anonymous from './anonymous';\n\nconst AtRule = function(\n name,\n value,\n rules,\n index,\n currentFileInfo,\n debugInfo,\n isRooted,\n visibilityInfo\n) {\n let i;\n\n this.name = name;\n this.value = (value instanceof Node) ? value : (value ? new Anonymous(value) : value);\n if (rules) {\n if (Array.isArray(rules)) {\n this.rules = rules;\n } else {\n this.rules = [rules];\n this.rules[0].selectors = (new Selector([], null, null, index, currentFileInfo)).createEmptySelectors();\n }\n for (i = 0; i < this.rules.length; i++) {\n this.rules[i].allowImports = true;\n }\n this.setParent(this.rules, this);\n }\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.debugInfo = debugInfo;\n this.isRooted = isRooted || false;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n}\n\nAtRule.prototype = Object.assign(new Node(), {\n type: 'AtRule',\n accept(visitor) {\n const value = this.value, rules = this.rules;\n if (rules) {\n this.rules = visitor.visitArray(rules);\n }\n if (value) {\n this.value = visitor.visit(value);\n }\n },\n\n isRulesetLike() {\n return this.rules || !this.isCharset();\n },\n\n isCharset() {\n return '@charset' === this.name;\n },\n\n genCSS(context, output) {\n const value = this.value, rules = this.rules;\n output.add(this.name, this.fileInfo(), this.getIndex());\n if (value) {\n output.add(' ');\n value.genCSS(context, output);\n }\n if (rules) {\n this.outputRuleset(context, output, rules);\n } else {\n output.add(';');\n }\n },\n\n eval(context) {\n let mediaPathBackup, mediaBlocksBackup, value = this.value, rules = this.rules;\n\n // media stored inside other atrule should not bubble over it\n // backpup media bubbling information\n mediaPathBackup = context.mediaPath;\n mediaBlocksBackup = context.mediaBlocks;\n // deleted media bubbling information\n context.mediaPath = [];\n context.mediaBlocks = [];\n\n if (value) {\n value = value.eval(context);\n }\n if (rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n rules = [rules[0].eval(context)];\n rules[0].root = true;\n }\n // restore media bubbling information\n context.mediaPath = mediaPathBackup;\n context.mediaBlocks = mediaBlocksBackup;\n\n return new AtRule(this.name, value, rules,\n this.getIndex(), this.fileInfo(), this.debugInfo, this.isRooted, this.visibilityInfo());\n },\n\n variable(name) {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.variable.call(this.rules[0], name);\n }\n },\n\n find() {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.find.apply(this.rules[0], arguments);\n }\n },\n\n rulesets() {\n if (this.rules) {\n // assuming that there is only one rule at this point - that is how parser constructs the rule\n return Ruleset.prototype.rulesets.apply(this.rules[0]);\n }\n },\n\n outputRuleset(context, output, rules) {\n const ruleCnt = rules.length;\n let i;\n context.tabLevel = (context.tabLevel | 0) + 1;\n\n // Compressed\n if (context.compress) {\n output.add('{');\n for (i = 0; i < ruleCnt; i++) {\n rules[i].genCSS(context, output);\n }\n output.add('}');\n context.tabLevel--;\n return;\n }\n\n // Non-compressed\n const tabSetStr = `\\n${Array(context.tabLevel).join(' ')}`, tabRuleStr = `${tabSetStr} `;\n if (!ruleCnt) {\n output.add(` {${tabSetStr}}`);\n } else {\n output.add(` {${tabRuleStr}`);\n rules[0].genCSS(context, output);\n for (i = 1; i < ruleCnt; i++) {\n output.add(tabRuleStr);\n rules[i].genCSS(context, output);\n }\n output.add(`${tabSetStr}}`);\n }\n\n context.tabLevel--;\n }\n});\n\nexport default AtRule;\n","import Node from './node';\nimport contexts from '../contexts';\nimport * as utils from '../utils';\n\nconst DetachedRuleset = function(ruleset, frames) {\n this.ruleset = ruleset;\n this.frames = frames;\n this.setParent(this.ruleset, this);\n};\n\nDetachedRuleset.prototype = Object.assign(new Node(), {\n type: 'DetachedRuleset',\n evalFirst: true,\n\n accept(visitor) {\n this.ruleset = visitor.visit(this.ruleset);\n },\n\n eval(context) {\n const frames = this.frames || utils.copyArray(context.frames);\n return new DetachedRuleset(this.ruleset, frames);\n },\n\n callEval(context) {\n return this.ruleset.eval(this.frames ? new contexts.Eval(context, this.frames.concat(context.frames)) : context);\n }\n});\n\nexport default DetachedRuleset;\n","import Node from './node';\nimport unitConversions from '../data/unit-conversions';\nimport * as utils from '../utils';\n\nconst Unit = function(numerator, denominator, backupUnit) {\n this.numerator = numerator ? utils.copyArray(numerator).sort() : [];\n this.denominator = denominator ? utils.copyArray(denominator).sort() : [];\n if (backupUnit) {\n this.backupUnit = backupUnit;\n } else if (numerator && numerator.length) {\n this.backupUnit = numerator[0];\n }\n};\n\nUnit.prototype = Object.assign(new Node(), {\n type: 'Unit',\n\n clone() {\n return new Unit(utils.copyArray(this.numerator), utils.copyArray(this.denominator), this.backupUnit);\n },\n\n genCSS(context, output) {\n // Dimension checks the unit is singular and throws an error if in strict math mode.\n const strictUnits = context && context.strictUnits;\n if (this.numerator.length === 1) {\n output.add(this.numerator[0]); // the ideal situation\n } else if (!strictUnits && this.backupUnit) {\n output.add(this.backupUnit);\n } else if (!strictUnits && this.denominator.length) {\n output.add(this.denominator[0]);\n }\n },\n\n toString() {\n let i, returnStr = this.numerator.join('*');\n for (i = 0; i < this.denominator.length; i++) {\n returnStr += `/${this.denominator[i]}`;\n }\n return returnStr;\n },\n\n compare(other) {\n return this.is(other.toString()) ? 0 : undefined;\n },\n\n is(unitString) {\n return this.toString().toUpperCase() === unitString.toUpperCase();\n },\n\n isLength() {\n return RegExp('^(px|em|ex|ch|rem|in|cm|mm|pc|pt|ex|vw|vh|vmin|vmax)$', 'gi').test(this.toCSS());\n },\n\n isEmpty() {\n return this.numerator.length === 0 && this.denominator.length === 0;\n },\n\n isSingular() {\n return this.numerator.length <= 1 && this.denominator.length === 0;\n },\n\n map(callback) {\n let i;\n\n for (i = 0; i < this.numerator.length; i++) {\n this.numerator[i] = callback(this.numerator[i], false);\n }\n\n for (i = 0; i < this.denominator.length; i++) {\n this.denominator[i] = callback(this.denominator[i], true);\n }\n },\n\n usedUnits() {\n let group;\n const result = {};\n let mapUnit;\n let groupName;\n\n mapUnit = function (atomicUnit) {\n /* jshint loopfunc:true */\n if (group.hasOwnProperty(atomicUnit) && !result[groupName]) {\n result[groupName] = atomicUnit;\n }\n\n return atomicUnit;\n };\n\n for (groupName in unitConversions) {\n if (unitConversions.hasOwnProperty(groupName)) {\n group = unitConversions[groupName];\n\n this.map(mapUnit);\n }\n }\n\n return result;\n },\n\n cancel() {\n const counter = {};\n let atomicUnit;\n let i;\n\n for (i = 0; i < this.numerator.length; i++) {\n atomicUnit = this.numerator[i];\n counter[atomicUnit] = (counter[atomicUnit] || 0) + 1;\n }\n\n for (i = 0; i < this.denominator.length; i++) {\n atomicUnit = this.denominator[i];\n counter[atomicUnit] = (counter[atomicUnit] || 0) - 1;\n }\n\n this.numerator = [];\n this.denominator = [];\n\n for (atomicUnit in counter) {\n if (counter.hasOwnProperty(atomicUnit)) {\n const count = counter[atomicUnit];\n\n if (count > 0) {\n for (i = 0; i < count; i++) {\n this.numerator.push(atomicUnit);\n }\n } else if (count < 0) {\n for (i = 0; i < -count; i++) {\n this.denominator.push(atomicUnit);\n }\n }\n }\n }\n\n this.numerator.sort();\n this.denominator.sort();\n }\n});\n\nexport default Unit;\n","import Node from './node';\nimport unitConversions from '../data/unit-conversions';\nimport Unit from './unit';\nimport Color from './color';\n\n//\n// A number with a unit\n//\nconst Dimension = function(value, unit) {\n this.value = parseFloat(value);\n if (isNaN(this.value)) {\n throw new Error('Dimension is not a number.');\n }\n this.unit = (unit && unit instanceof Unit) ? unit :\n new Unit(unit ? [unit] : undefined);\n this.setParent(this.unit, this);\n};\n\nDimension.prototype = Object.assign(new Node(), {\n type: 'Dimension',\n\n accept(visitor) {\n this.unit = visitor.visit(this.unit);\n },\n\n eval(context) {\n return this;\n },\n\n toColor() {\n return new Color([this.value, this.value, this.value]);\n },\n\n genCSS(context, output) {\n if ((context && context.strictUnits) && !this.unit.isSingular()) {\n throw new Error(`Multiple units in dimension. Correct the units or use the unit function. Bad unit: ${this.unit.toString()}`);\n }\n\n const value = this.fround(context, this.value);\n let strValue = String(value);\n\n if (value !== 0 && value < 0.000001 && value > -0.000001) {\n // would be output 1e-6 etc.\n strValue = value.toFixed(20).replace(/0+$/, '');\n }\n\n if (context && context.compress) {\n // Zero values doesn't need a unit\n if (value === 0 && this.unit.isLength()) {\n output.add(strValue);\n return;\n }\n\n // Float values doesn't need a leading zero\n if (value > 0 && value < 1) {\n strValue = (strValue).substr(1);\n }\n }\n\n output.add(strValue);\n this.unit.genCSS(context, output);\n },\n\n // In an operation between two Dimensions,\n // we default to the first Dimension's unit,\n // so `1px + 2` will yield `3px`.\n operate(context, op, other) {\n /* jshint noempty:false */\n let value = this._operate(context, op, this.value, other.value), unit = this.unit.clone();\n\n if (op === '+' || op === '-') {\n if (unit.numerator.length === 0 && unit.denominator.length === 0) {\n unit = other.unit.clone();\n if (this.unit.backupUnit) {\n unit.backupUnit = this.unit.backupUnit;\n }\n } else if (other.unit.numerator.length === 0 && unit.denominator.length === 0) {\n // do nothing\n } else {\n other = other.convertTo(this.unit.usedUnits());\n\n if (context.strictUnits && other.unit.toString() !== unit.toString()) {\n throw new Error(`Incompatible units. Change the units or use the unit function. `\n + `Bad units: '${unit.toString()}' and '${other.unit.toString()}'.`);\n }\n\n value = this._operate(context, op, this.value, other.value);\n }\n } else if (op === '*') {\n unit.numerator = unit.numerator.concat(other.unit.numerator).sort();\n unit.denominator = unit.denominator.concat(other.unit.denominator).sort();\n unit.cancel();\n } else if (op === '/') {\n unit.numerator = unit.numerator.concat(other.unit.denominator).sort();\n unit.denominator = unit.denominator.concat(other.unit.numerator).sort();\n unit.cancel();\n }\n return new Dimension(value, unit);\n },\n\n compare(other) {\n let a, b;\n\n if (!(other instanceof Dimension)) {\n return undefined;\n }\n\n if (this.unit.isEmpty() || other.unit.isEmpty()) {\n a = this;\n b = other;\n } else {\n a = this.unify();\n b = other.unify();\n if (a.unit.compare(b.unit) !== 0) {\n return undefined;\n }\n }\n\n return Node.numericCompare(a.value, b.value);\n },\n\n unify() {\n return this.convertTo({ length: 'px', duration: 's', angle: 'rad' });\n },\n\n convertTo(conversions) {\n let value = this.value;\n const unit = this.unit.clone();\n let i;\n let groupName;\n let group;\n let targetUnit;\n let derivedConversions = {};\n let applyUnit;\n\n if (typeof conversions === 'string') {\n for (i in unitConversions) {\n if (unitConversions[i].hasOwnProperty(conversions)) {\n derivedConversions = {};\n derivedConversions[i] = conversions;\n }\n }\n conversions = derivedConversions;\n }\n applyUnit = function (atomicUnit, denominator) {\n /* jshint loopfunc:true */\n if (group.hasOwnProperty(atomicUnit)) {\n if (denominator) {\n value = value / (group[atomicUnit] / group[targetUnit]);\n } else {\n value = value * (group[atomicUnit] / group[targetUnit]);\n }\n\n return targetUnit;\n }\n\n return atomicUnit;\n };\n\n for (groupName in conversions) {\n if (conversions.hasOwnProperty(groupName)) {\n targetUnit = conversions[groupName];\n group = unitConversions[groupName];\n\n unit.map(applyUnit);\n }\n }\n\n unit.cancel();\n\n return new Dimension(value, unit);\n }\n});\n\nexport default Dimension;\n","import Node from './node';\nimport Color from './color';\nimport Dimension from './dimension';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\n\nconst Operation = function(op, operands, isSpaced) {\n this.op = op.trim();\n this.operands = operands;\n this.isSpaced = isSpaced;\n};\n\nOperation.prototype = Object.assign(new Node(), {\n type: 'Operation',\n\n accept(visitor) {\n this.operands = visitor.visitArray(this.operands);\n },\n\n eval(context) {\n let a = this.operands[0].eval(context), b = this.operands[1].eval(context), op;\n\n if (context.isMathOn(this.op)) {\n op = this.op === './' ? '/' : this.op;\n if (a instanceof Dimension && b instanceof Color) {\n a = a.toColor();\n }\n if (b instanceof Dimension && a instanceof Color) {\n b = b.toColor();\n }\n if (!a.operate) {\n if (a instanceof Operation && a.op === '/' && context.math === MATH.PARENS_DIVISION) {\n return new Operation(this.op, [a, b], this.isSpaced);\n }\n throw { type: 'Operation',\n message: 'Operation on an invalid type' };\n }\n\n return a.operate(context, op, b);\n } else {\n return new Operation(this.op, [a, b], this.isSpaced);\n }\n },\n\n genCSS(context, output) {\n this.operands[0].genCSS(context, output);\n if (this.isSpaced) {\n output.add(' ');\n }\n output.add(this.op);\n if (this.isSpaced) {\n output.add(' ');\n }\n this.operands[1].genCSS(context, output);\n }\n});\n\nexport default Operation;\n","import Node from './node';\nimport Paren from './paren';\nimport Comment from './comment';\nimport Dimension from './dimension';\nimport * as Constants from '../constants';\nconst MATH = Constants.Math;\n\nconst Expression = function(value, noSpacing) {\n this.value = value;\n this.noSpacing = noSpacing;\n if (!value) {\n throw new Error('Expression requires an array parameter');\n }\n};\n\nExpression.prototype = Object.assign(new Node(), {\n type: 'Expression',\n\n accept(visitor) {\n this.value = visitor.visitArray(this.value);\n },\n\n eval(context) {\n let returnValue;\n const mathOn = context.isMathOn();\n const inParenthesis = this.parens;\n\n let doubleParen = false;\n if (inParenthesis) {\n context.inParenthesis();\n }\n if (this.value.length > 1) {\n returnValue = new Expression(this.value.map(function (e) {\n if (!e.eval) {\n return e;\n }\n return e.eval(context);\n }), this.noSpacing);\n } else if (this.value.length === 1) {\n if (this.value[0].parens && !this.value[0].parensInOp && !context.inCalc) {\n doubleParen = true;\n }\n returnValue = this.value[0].eval(context);\n } else {\n returnValue = this;\n }\n if (inParenthesis) {\n context.outOfParenthesis();\n }\n if (this.parens && this.parensInOp && !mathOn && !doubleParen \n && (!(returnValue instanceof Dimension))) {\n returnValue = new Paren(returnValue);\n }\n return returnValue;\n },\n\n genCSS(context, output) {\n for (let i = 0; i < this.value.length; i++) {\n this.value[i].genCSS(context, output);\n if (!this.noSpacing && i + 1 < this.value.length) {\n output.add(' ');\n }\n }\n },\n\n throwAwayComments() {\n this.value = this.value.filter(function(v) {\n return !(v instanceof Comment);\n });\n }\n});\n\nexport default Expression;\n","import Expression from '../tree/expression';\n\nclass functionCaller {\n constructor(name, context, index, currentFileInfo) {\n this.name = name.toLowerCase();\n this.index = index;\n this.context = context;\n this.currentFileInfo = currentFileInfo;\n\n this.func = context.frames[0].functionRegistry.get(this.name);\n }\n\n isValid() {\n return Boolean(this.func);\n }\n\n call(args) {\n if (!(Array.isArray(args))) {\n args = [args];\n }\n const evalArgs = this.func.evalArgs;\n if (evalArgs !== false) {\n args = args.map(a => a.eval(this.context));\n }\n const commentFilter = item => !(item.type === 'Comment');\n\n // This code is terrible and should be replaced as per this issue...\n // https://github.com/less/less.js/issues/2477\n args = args\n .filter(commentFilter)\n .map(item => {\n if (item.type === 'Expression') {\n const subNodes = item.value.filter(commentFilter);\n if (subNodes.length === 1) {\n return subNodes[0];\n } else {\n return new Expression(subNodes);\n }\n }\n return item;\n });\n\n if (evalArgs === false) {\n return this.func(this.context, ...args);\n }\n\n return this.func(...args);\n }\n}\n\nexport default functionCaller;\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport function __createBinding(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n result.default = mod;\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to get private field on non-instance\");\r\n }\r\n return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to set private field on non-instance\");\r\n }\r\n privateMap.set(receiver, value);\r\n return value;\r\n}\r\n","import Node from './node';\nimport Anonymous from './anonymous';\nimport FunctionCaller from '../functions/function-caller';\n\n//\n// A function call node.\n//\nconst Call = function(name, args, index, currentFileInfo) {\n this.name = name;\n this.args = args;\n this.calc = name === 'calc';\n this._index = index;\n this._fileInfo = currentFileInfo;\n}\n\nCall.prototype = Object.assign(new Node(), {\n type: 'Call',\n\n accept(visitor) {\n if (this.args) {\n this.args = visitor.visitArray(this.args);\n }\n },\n\n //\n // When evaluating a function call,\n // we either find the function in the functionRegistry,\n // in which case we call it, passing the evaluated arguments,\n // if this returns null or we cannot find the function, we\n // simply print it out as it appeared originally [2].\n //\n // The reason why we evaluate the arguments, is in the case where\n // we try to pass a variable to a function, like: `saturate(@color)`.\n // The function should receive the value, not the variable.\n //\n eval(context) {\n /**\n * Turn off math for calc(), and switch back on for evaluating nested functions\n */\n const currentMathContext = context.mathOn;\n context.mathOn = !this.calc;\n if (this.calc || context.inCalc) {\n context.enterCalc();\n }\n\n const exitCalc = () => {\n if (this.calc || context.inCalc) {\n context.exitCalc();\n }\n context.mathOn = currentMathContext;\n };\n\n let result;\n const funcCaller = new FunctionCaller(this.name, context, this.getIndex(), this.fileInfo());\n\n if (funcCaller.isValid()) {\n try {\n result = funcCaller.call(this.args);\n exitCalc();\n } catch (e) {\n if (e.hasOwnProperty('line') && e.hasOwnProperty('column')) {\n throw e;\n }\n throw { \n type: e.type || 'Runtime',\n message: `Error evaluating function \\`${this.name}\\`${e.message ? `: ${e.message}` : ''}`,\n index: this.getIndex(), \n filename: this.fileInfo().filename,\n line: e.lineNumber,\n column: e.columnNumber\n };\n }\n }\n\n if (result !== null && result !== undefined) {\n // Results that that are not nodes are cast as Anonymous nodes\n // Falsy values or booleans are returned as empty nodes\n if (!(result instanceof Node)) {\n if (!result || result === true) {\n result = new Anonymous(null); \n }\n else {\n result = new Anonymous(result.toString()); \n }\n \n }\n result._index = this._index;\n result._fileInfo = this._fileInfo;\n return result;\n }\n\n const args = this.args.map(a => a.eval(context));\n exitCalc();\n\n return new Call(this.name, args, this.getIndex(), this.fileInfo());\n },\n\n genCSS(context, output) {\n output.add(`${this.name}(`, this.fileInfo(), this.getIndex());\n\n for (let i = 0; i < this.args.length; i++) {\n this.args[i].genCSS(context, output);\n if (i + 1 < this.args.length) {\n output.add(', ');\n }\n }\n\n output.add(')');\n }\n});\n\nexport default Call;\n","import Node from './node';\nimport Call from './call';\n\nconst Variable = function(name, index, currentFileInfo) {\n this.name = name;\n this._index = index;\n this._fileInfo = currentFileInfo;\n};\n\nVariable.prototype = Object.assign(new Node(), {\n type: 'Variable',\n\n eval(context) {\n let variable, name = this.name;\n\n if (name.indexOf('@@') === 0) {\n name = `@${new Variable(name.slice(1), this.getIndex(), this.fileInfo()).eval(context).value}`;\n }\n\n if (this.evaluating) {\n throw { type: 'Name',\n message: `Recursive variable definition for ${name}`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n this.evaluating = true;\n\n variable = this.find(context.frames, function (frame) {\n const v = frame.variable(name);\n if (v) {\n if (v.important) {\n const importantScope = context.importantScope[context.importantScope.length - 1];\n importantScope.important = v.important;\n }\n // If in calc, wrap vars in a function call to cascade evaluate args first\n if (context.inCalc) {\n return (new Call('_SELF', [v.value])).eval(context);\n }\n else {\n return v.value.eval(context);\n }\n }\n });\n if (variable) {\n this.evaluating = false;\n return variable;\n } else {\n throw { type: 'Name',\n message: `variable ${name} is undefined`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n },\n\n find(obj, fun) {\n for (let i = 0, r; i < obj.length; i++) {\n r = fun.call(obj, obj[i]);\n if (r) { return r; }\n }\n return null;\n }\n});\n\nexport default Variable;\n","import Node from './node';\nimport Declaration from './declaration';\n\nconst Property = function(name, index, currentFileInfo) {\n this.name = name;\n this._index = index;\n this._fileInfo = currentFileInfo;\n};\n\nProperty.prototype = Object.assign(new Node(), {\n type: 'Property',\n\n eval(context) {\n let property;\n const name = this.name;\n // TODO: shorten this reference\n const mergeRules = context.pluginManager.less.visitors.ToCSSVisitor.prototype._mergeRules;\n\n if (this.evaluating) {\n throw { type: 'Name',\n message: `Recursive property reference for ${name}`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n this.evaluating = true;\n\n property = this.find(context.frames, function (frame) {\n let v;\n const vArr = frame.property(name);\n if (vArr) {\n for (let i = 0; i < vArr.length; i++) {\n v = vArr[i];\n\n vArr[i] = new Declaration(v.name,\n v.value,\n v.important,\n v.merge,\n v.index,\n v.currentFileInfo,\n v.inline,\n v.variable\n );\n }\n mergeRules(vArr);\n\n v = vArr[vArr.length - 1];\n if (v.important) {\n const importantScope = context.importantScope[context.importantScope.length - 1];\n importantScope.important = v.important;\n }\n v = v.value.eval(context);\n return v;\n }\n });\n if (property) {\n this.evaluating = false;\n return property;\n } else {\n throw { type: 'Name',\n message: `Property '${name}' is undefined`,\n filename: this.currentFileInfo.filename,\n index: this.index };\n }\n },\n\n find(obj, fun) {\n for (let i = 0, r; i < obj.length; i++) {\n r = fun.call(obj, obj[i]);\n if (r) { return r; }\n }\n return null;\n }\n});\n\nexport default Property;\n","import Node from './node';\n\nconst Attribute = function(key, op, value) {\n this.key = key;\n this.op = op;\n this.value = value;\n}\n\nAttribute.prototype = Object.assign(new Node(), {\n type: 'Attribute',\n\n eval(context) {\n return new Attribute(this.key.eval ? this.key.eval(context) : this.key,\n this.op, (this.value && this.value.eval) ? this.value.eval(context) : this.value);\n },\n\n genCSS(context, output) {\n output.add(this.toCSS(context));\n },\n\n toCSS(context) {\n let value = this.key.toCSS ? this.key.toCSS(context) : this.key;\n\n if (this.op) {\n value += this.op;\n value += (this.value.toCSS ? this.value.toCSS(context) : this.value);\n }\n\n return `[${value}]`;\n }\n});\n\nexport default Attribute;\n","import Node from './node';\nimport Variable from './variable';\nimport Property from './property';\n\n\nconst Quoted = function(str, content, escaped, index, currentFileInfo) {\n this.escaped = (escaped == null) ? true : escaped;\n this.value = content || '';\n this.quote = str.charAt(0);\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.variableRegex = /@\\{([\\w-]+)\\}/g;\n this.propRegex = /\\$\\{([\\w-]+)\\}/g;\n this.allowRoot = escaped;\n};\n\nQuoted.prototype = Object.assign(new Node(), {\n type: 'Quoted',\n\n genCSS(context, output) {\n if (!this.escaped) {\n output.add(this.quote, this.fileInfo(), this.getIndex());\n }\n output.add(this.value);\n if (!this.escaped) {\n output.add(this.quote);\n }\n },\n\n containsVariables() {\n return this.value.match(this.variableRegex);\n },\n\n eval(context) {\n const that = this;\n let value = this.value;\n const variableReplacement = function (_, name) {\n const v = new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context, true);\n return (v instanceof Quoted) ? v.value : v.toCSS();\n };\n const propertyReplacement = function (_, name) {\n const v = new Property(`$${name}`, that.getIndex(), that.fileInfo()).eval(context, true);\n return (v instanceof Quoted) ? v.value : v.toCSS();\n };\n function iterativeReplace(value, regexp, replacementFnc) {\n let evaluatedValue = value;\n do {\n value = evaluatedValue.toString();\n evaluatedValue = value.replace(regexp, replacementFnc);\n } while (value !== evaluatedValue);\n return evaluatedValue;\n }\n value = iterativeReplace(value, this.variableRegex, variableReplacement);\n value = iterativeReplace(value, this.propRegex, propertyReplacement);\n return new Quoted(this.quote + value + this.quote, value, this.escaped, this.getIndex(), this.fileInfo());\n },\n\n compare(other) {\n // when comparing quoted strings allow the quote to differ\n if (other.type === 'Quoted' && !this.escaped && !other.escaped) {\n return Node.numericCompare(this.value, other.value);\n } else {\n return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined;\n }\n }\n});\n\nexport default Quoted;\n","import Node from './node';\n\nfunction escapePath(path) {\n return path.replace(/[\\(\\)'\"\\s]/g, function(match) { return `\\\\${match}`; });\n}\n\nconst URL = function(val, index, currentFileInfo, isEvald) {\n this.value = val;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.isEvald = isEvald;\n};\n\nURL.prototype = Object.assign(new Node(), {\n type: 'Url',\n\n accept(visitor) {\n this.value = visitor.visit(this.value);\n },\n\n genCSS(context, output) {\n output.add('url(');\n this.value.genCSS(context, output);\n output.add(')');\n },\n\n eval(context) {\n const val = this.value.eval(context);\n let rootpath;\n\n if (!this.isEvald) {\n // Add the rootpath if the URL requires a rewrite\n rootpath = this.fileInfo() && this.fileInfo().rootpath;\n if (typeof rootpath === 'string' &&\n typeof val.value === 'string' &&\n context.pathRequiresRewrite(val.value)) {\n if (!val.quote) {\n rootpath = escapePath(rootpath);\n }\n val.value = context.rewritePath(val.value, rootpath);\n } else {\n val.value = context.normalizePath(val.value);\n }\n\n // Add url args if enabled\n if (context.urlArgs) {\n if (!val.value.match(/^\\s*data:/)) {\n const delimiter = val.value.indexOf('?') === -1 ? '?' : '&';\n const urlArgs = delimiter + context.urlArgs;\n if (val.value.indexOf('#') !== -1) {\n val.value = val.value.replace('#', `${urlArgs}#`);\n } else {\n val.value += urlArgs;\n }\n }\n }\n }\n\n return new URL(val, this.getIndex(), this.fileInfo(), true);\n }\n});\n\nexport default URL;\n","import Ruleset from './ruleset';\nimport Value from './value';\nimport Selector from './selector';\nimport Anonymous from './anonymous';\nimport Expression from './expression';\nimport AtRule from './atrule';\nimport * as utils from '../utils';\n\nconst Media = function(value, features, index, currentFileInfo, visibilityInfo) {\n this._index = index;\n this._fileInfo = currentFileInfo;\n\n const selectors = (new Selector([], null, null, this._index, this._fileInfo)).createEmptySelectors();\n\n this.features = new Value(features);\n this.rules = [new Ruleset(selectors, value)];\n this.rules[0].allowImports = true;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n this.setParent(selectors, this);\n this.setParent(this.features, this);\n this.setParent(this.rules, this);\n};\n\nMedia.prototype = Object.assign(new AtRule(), {\n type: 'Media',\n\n isRulesetLike() {\n return true;\n },\n\n accept(visitor) {\n if (this.features) {\n this.features = visitor.visit(this.features);\n }\n if (this.rules) {\n this.rules = visitor.visitArray(this.rules);\n }\n },\n\n genCSS(context, output) {\n output.add('@media ', this._fileInfo, this._index);\n this.features.genCSS(context, output);\n this.outputRuleset(context, output, this.rules);\n },\n\n eval(context) {\n if (!context.mediaBlocks) {\n context.mediaBlocks = [];\n context.mediaPath = [];\n }\n\n const media = new Media(null, [], this._index, this._fileInfo, this.visibilityInfo());\n if (this.debugInfo) {\n this.rules[0].debugInfo = this.debugInfo;\n media.debugInfo = this.debugInfo;\n }\n \n media.features = this.features.eval(context);\n\n context.mediaPath.push(media);\n context.mediaBlocks.push(media);\n\n this.rules[0].functionRegistry = context.frames[0].functionRegistry.inherit();\n context.frames.unshift(this.rules[0]);\n media.rules = [this.rules[0].eval(context)];\n context.frames.shift();\n\n context.mediaPath.pop();\n\n return context.mediaPath.length === 0 ? media.evalTop(context) :\n media.evalNested(context);\n },\n\n evalTop(context) {\n let result = this;\n\n // Render all dependent Media blocks.\n if (context.mediaBlocks.length > 1) {\n const selectors = (new Selector([], null, null, this.getIndex(), this.fileInfo())).createEmptySelectors();\n result = new Ruleset(selectors, context.mediaBlocks);\n result.multiMedia = true;\n result.copyVisibilityInfo(this.visibilityInfo());\n this.setParent(result, this);\n }\n\n delete context.mediaBlocks;\n delete context.mediaPath;\n\n return result;\n },\n\n evalNested(context) {\n let i;\n let value;\n const path = context.mediaPath.concat([this]);\n\n // Extract the media-query conditions separated with `,` (OR).\n for (i = 0; i < path.length; i++) {\n value = path[i].features instanceof Value ?\n path[i].features.value : path[i].features;\n path[i] = Array.isArray(value) ? value : [value];\n }\n\n // Trace all permutations to generate the resulting media-query.\n //\n // (a, b and c) with nested (d, e) ->\n // a and d\n // a and e\n // b and c and d\n // b and c and e\n this.features = new Value(this.permute(path).map(path => {\n path = path.map(fragment => fragment.toCSS ? fragment : new Anonymous(fragment));\n\n for (i = path.length - 1; i > 0; i--) {\n path.splice(i, 0, new Anonymous('and'));\n }\n\n return new Expression(path);\n }));\n this.setParent(this.features, this);\n\n // Fake a tree-node that doesn't output anything.\n return new Ruleset([], []);\n },\n\n permute(arr) {\n if (arr.length === 0) {\n return [];\n } else if (arr.length === 1) {\n return arr[0];\n } else {\n const result = [];\n const rest = this.permute(arr.slice(1));\n for (let i = 0; i < rest.length; i++) {\n for (let j = 0; j < arr[0].length; j++) {\n result.push([arr[0][j]].concat(rest[i]));\n }\n }\n return result;\n }\n },\n\n bubbleSelectors(selectors) {\n if (!selectors) {\n return;\n }\n this.rules = [new Ruleset(utils.copyArray(selectors), [this.rules[0]])];\n this.setParent(this.rules, this);\n }\n});\n\nexport default Media;\n","import Node from './node';\nimport Media from './media';\nimport URL from './url';\nimport Quoted from './quoted';\nimport Ruleset from './ruleset';\nimport Anonymous from './anonymous';\nimport * as utils from '../utils';\nimport LessError from '../less-error';\n\n//\n// CSS @import node\n//\n// The general strategy here is that we don't want to wait\n// for the parsing to be completed, before we start importing\n// the file. That's because in the context of a browser,\n// most of the time will be spent waiting for the server to respond.\n//\n// On creation, we push the import path to our import queue, though\n// `import,push`, we also pass it a callback, which it'll call once\n// the file has been fetched, and parsed.\n//\nconst Import = function(path, features, options, index, currentFileInfo, visibilityInfo) {\n this.options = options;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.path = path;\n this.features = features;\n this.allowRoot = true;\n\n if (this.options.less !== undefined || this.options.inline) {\n this.css = !this.options.less || this.options.inline;\n } else {\n const pathValue = this.getPath();\n if (pathValue && /[#\\.\\&\\?]css([\\?;].*)?$/.test(pathValue)) {\n this.css = true;\n }\n }\n this.copyVisibilityInfo(visibilityInfo);\n this.setParent(this.features, this);\n this.setParent(this.path, this);\n};\n\nImport.prototype = Object.assign(new Node(), {\n type: 'Import',\n\n accept(visitor) {\n if (this.features) {\n this.features = visitor.visit(this.features);\n }\n this.path = visitor.visit(this.path);\n if (!this.options.isPlugin && !this.options.inline && this.root) {\n this.root = visitor.visit(this.root);\n }\n },\n\n genCSS(context, output) {\n if (this.css && this.path._fileInfo.reference === undefined) {\n output.add('@import ', this._fileInfo, this._index);\n this.path.genCSS(context, output);\n if (this.features) {\n output.add(' ');\n this.features.genCSS(context, output);\n }\n output.add(';');\n }\n },\n\n getPath() {\n return (this.path instanceof URL) ?\n this.path.value.value : this.path.value;\n },\n\n isVariableImport() {\n let path = this.path;\n if (path instanceof URL) {\n path = path.value;\n }\n if (path instanceof Quoted) {\n return path.containsVariables();\n }\n\n return true;\n },\n\n evalForImport(context) {\n let path = this.path;\n\n if (path instanceof URL) {\n path = path.value;\n }\n\n return new Import(path.eval(context), this.features, this.options, this._index, this._fileInfo, this.visibilityInfo());\n },\n\n evalPath(context) {\n const path = this.path.eval(context);\n const fileInfo = this._fileInfo;\n\n if (!(path instanceof URL)) {\n // Add the rootpath if the URL requires a rewrite\n const pathValue = path.value;\n if (fileInfo &&\n pathValue &&\n context.pathRequiresRewrite(pathValue)) {\n path.value = context.rewritePath(pathValue, fileInfo.rootpath);\n } else {\n path.value = context.normalizePath(path.value);\n }\n }\n\n return path;\n },\n\n eval(context) {\n const result = this.doEval(context);\n if (this.options.reference || this.blocksVisibility()) {\n if (result.length || result.length === 0) {\n result.forEach(function (node) {\n node.addVisibilityBlock();\n }\n );\n } else {\n result.addVisibilityBlock();\n }\n }\n return result;\n },\n\n doEval(context) {\n let ruleset;\n let registry;\n const features = this.features && this.features.eval(context);\n\n if (this.options.isPlugin) {\n if (this.root && this.root.eval) {\n try {\n this.root.eval(context);\n }\n catch (e) {\n e.message = 'Plugin error during evaluation';\n throw new LessError(e, this.root.imports, this.root.filename);\n }\n }\n registry = context.frames[0] && context.frames[0].functionRegistry;\n if ( registry && this.root && this.root.functions ) {\n registry.addMultiple( this.root.functions );\n }\n\n return [];\n }\n\n if (this.skip) {\n if (typeof this.skip === 'function') {\n this.skip = this.skip();\n }\n if (this.skip) {\n return [];\n }\n }\n if (this.options.inline) {\n const contents = new Anonymous(this.root, 0,\n {\n filename: this.importedFilename,\n reference: this.path._fileInfo && this.path._fileInfo.reference\n }, true, true);\n\n return this.features ? new Media([contents], this.features.value) : [contents];\n } else if (this.css) {\n const newImport = new Import(this.evalPath(context), features, this.options, this._index);\n if (!newImport.css && this.error) {\n throw this.error;\n }\n return newImport;\n } else if (this.root) {\n ruleset = new Ruleset(null, utils.copyArray(this.root.rules));\n ruleset.evalImports(context);\n\n return this.features ? new Media(ruleset.rules, this.features.value) : ruleset.rules;\n } else {\n return [];\n }\n }\n});\n\nexport default Import;\n","import Node from './node';\nimport Variable from './variable';\n\nconst JsEvalNode = function() {};\n\nJsEvalNode.prototype = Object.assign(new Node(), {\n evaluateJavaScript(expression, context) {\n let result;\n const that = this;\n const evalContext = {};\n\n if (!context.javascriptEnabled) {\n throw { message: 'Inline JavaScript is not enabled. Is it set in your options?',\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n expression = expression.replace(/@\\{([\\w-]+)\\}/g, function (_, name) {\n return that.jsify(new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context));\n });\n\n try {\n expression = new Function(`return (${expression})`);\n } catch (e) {\n throw { message: `JavaScript evaluation error: ${e.message} from \\`${expression}\\`` ,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n\n const variables = context.frames[0].variables();\n for (const k in variables) {\n if (variables.hasOwnProperty(k)) {\n /* jshint loopfunc:true */\n evalContext[k.slice(1)] = {\n value: variables[k].value,\n toJS: function () {\n return this.value.eval(context).toCSS();\n }\n };\n }\n }\n\n try {\n result = expression.call(evalContext);\n } catch (e) {\n throw { message: `JavaScript evaluation error: '${e.name}: ${e.message.replace(/[\"]/g, '\\'')}'` ,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n return result;\n },\n\n jsify(obj) {\n if (Array.isArray(obj.value) && (obj.value.length > 1)) {\n return `[${obj.value.map(function (v) { return v.toCSS(); }).join(', ')}]`;\n } else {\n return obj.toCSS();\n }\n }\n});\n\nexport default JsEvalNode;\n","import JsEvalNode from './js-eval-node';\nimport Dimension from './dimension';\nimport Quoted from './quoted';\nimport Anonymous from './anonymous';\n\nconst JavaScript = function(string, escaped, index, currentFileInfo) {\n this.escaped = escaped;\n this.expression = string;\n this._index = index;\n this._fileInfo = currentFileInfo;\n}\n\nJavaScript.prototype = Object.assign(new JsEvalNode(), {\n type: 'JavaScript',\n\n eval(context) {\n const result = this.evaluateJavaScript(this.expression, context);\n const type = typeof result;\n\n if (type === 'number' && !isNaN(result)) {\n return new Dimension(result);\n } else if (type === 'string') {\n return new Quoted(`\"${result}\"`, result, this.escaped, this._index);\n } else if (Array.isArray(result)) {\n return new Anonymous(result.join(', '));\n } else {\n return new Anonymous(result);\n }\n }\n});\n\nexport default JavaScript;\n","import Node from './node';\n\nconst Assignment = function(key, val) {\n this.key = key;\n this.value = val;\n}\n\nAssignment.prototype = Object.assign(new Node(), {\n type: 'Assignment',\n\n accept(visitor) {\n this.value = visitor.visit(this.value);\n },\n\n eval(context) {\n if (this.value.eval) {\n return new Assignment(this.key, this.value.eval(context));\n }\n return this;\n },\n\n genCSS(context, output) {\n output.add(`${this.key}=`);\n if (this.value.genCSS) {\n this.value.genCSS(context, output);\n } else {\n output.add(this.value);\n }\n }\n});\n\nexport default Assignment;\n","import Node from './node';\n\nconst Condition = function(op, l, r, i, negate) {\n this.op = op.trim();\n this.lvalue = l;\n this.rvalue = r;\n this._index = i;\n this.negate = negate;\n};\n\nCondition.prototype = Object.assign(new Node(), {\n type: 'Condition',\n\n accept(visitor) {\n this.lvalue = visitor.visit(this.lvalue);\n this.rvalue = visitor.visit(this.rvalue);\n },\n\n eval(context) {\n const result = (function (op, a, b) {\n switch (op) {\n case 'and': return a && b;\n case 'or': return a || b;\n default:\n switch (Node.compare(a, b)) {\n case -1:\n return op === '<' || op === '=<' || op === '<=';\n case 0:\n return op === '=' || op === '>=' || op === '=<' || op === '<=';\n case 1:\n return op === '>' || op === '>=';\n default:\n return false;\n }\n }\n })(this.op, this.lvalue.eval(context), this.rvalue.eval(context));\n\n return this.negate ? !result : result;\n }\n});\n\nexport default Condition;\n","import Node from './node';\n\nconst UnicodeDescriptor = function(value) {\n this.value = value;\n}\n\nUnicodeDescriptor.prototype = Object.assign(new Node(), {\n type: 'UnicodeDescriptor'\n})\n\nexport default UnicodeDescriptor;\n","import Node from './node';\nimport Operation from './operation';\nimport Dimension from './dimension';\n\nconst Negative = function(node) {\n this.value = node;\n};\n\nNegative.prototype = Object.assign(new Node(), {\n type: 'Negative',\n\n genCSS(context, output) {\n output.add('-');\n this.value.genCSS(context, output);\n },\n\n eval(context) {\n if (context.isMathOn()) {\n return (new Operation('*', [new Dimension(-1), this.value])).eval(context);\n }\n return new Negative(this.value.eval(context));\n }\n});\n\nexport default Negative;\n","import Node from './node';\nimport Selector from './selector';\n\nconst Extend = function(selector, option, index, currentFileInfo, visibilityInfo) {\n this.selector = selector;\n this.option = option;\n this.object_id = Extend.next_id++;\n this.parent_ids = [this.object_id];\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n\n switch (option) {\n case 'all':\n this.allowBefore = true;\n this.allowAfter = true;\n break;\n default:\n this.allowBefore = false;\n this.allowAfter = false;\n break;\n }\n this.setParent(this.selector, this);\n};\n\nExtend.prototype = Object.assign(new Node(), {\n type: 'Extend',\n\n accept(visitor) {\n this.selector = visitor.visit(this.selector);\n },\n\n eval(context) {\n return new Extend(this.selector.eval(context), this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n },\n\n clone(context) {\n return new Extend(this.selector, this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo());\n },\n\n // it concatenates (joins) all selectors in selector array\n findSelfSelectors(selectors) {\n let selfElements = [], i, selectorElements;\n\n for (i = 0; i < selectors.length; i++) {\n selectorElements = selectors[i].elements;\n // duplicate the logic in genCSS function inside the selector node.\n // future TODO - move both logics into the selector joiner visitor\n if (i > 0 && selectorElements.length && selectorElements[0].combinator.value === '') {\n selectorElements[0].combinator.value = ' ';\n }\n selfElements = selfElements.concat(selectors[i].elements);\n }\n\n this.selfSelectors = [new Selector(selfElements)];\n this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo());\n }\n});\n\nExtend.next_id = 0;\nexport default Extend;\n","import Node from './node';\nimport Variable from './variable';\nimport Ruleset from './ruleset';\nimport DetachedRuleset from './detached-ruleset';\nimport LessError from '../less-error';\n\nconst VariableCall = function(variable, index, currentFileInfo) {\n this.variable = variable;\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.allowRoot = true;\n};\n\nVariableCall.prototype = Object.assign(new Node(), {\n type: 'VariableCall',\n\n eval(context) {\n let rules;\n let detachedRuleset = new Variable(this.variable, this.getIndex(), this.fileInfo()).eval(context);\n const error = new LessError({message: `Could not evaluate variable call ${this.variable}`});\n\n if (!detachedRuleset.ruleset) {\n if (detachedRuleset.rules) {\n rules = detachedRuleset;\n }\n else if (Array.isArray(detachedRuleset)) {\n rules = new Ruleset('', detachedRuleset);\n }\n else if (Array.isArray(detachedRuleset.value)) {\n rules = new Ruleset('', detachedRuleset.value);\n }\n else {\n throw error;\n }\n detachedRuleset = new DetachedRuleset(rules);\n }\n\n if (detachedRuleset.ruleset) {\n return detachedRuleset.callEval(context);\n }\n throw error;\n }\n});\n\nexport default VariableCall;\n","import Node from './node';\nimport Variable from './variable';\nimport Ruleset from './ruleset';\nimport Selector from './selector';\n\nconst NamespaceValue = function(ruleCall, lookups, index, fileInfo) {\n this.value = ruleCall;\n this.lookups = lookups;\n this._index = index;\n this._fileInfo = fileInfo;\n};\n\nNamespaceValue.prototype = Object.assign(new Node(), {\n type: 'NamespaceValue',\n\n eval(context) {\n let i, j, name, rules = this.value.eval(context);\n \n for (i = 0; i < this.lookups.length; i++) {\n name = this.lookups[i];\n\n /**\n * Eval'd DRs return rulesets.\n * Eval'd mixins return rules, so let's make a ruleset if we need it.\n * We need to do this because of late parsing of values\n */\n if (Array.isArray(rules)) {\n rules = new Ruleset([new Selector()], rules);\n }\n\n if (name === '') {\n rules = rules.lastDeclaration();\n }\n else if (name.charAt(0) === '@') {\n if (name.charAt(1) === '@') {\n name = `@${new Variable(name.substr(1)).eval(context).value}`;\n }\n if (rules.variables) {\n rules = rules.variable(name);\n }\n \n if (!rules) {\n throw { type: 'Name',\n message: `variable ${name} not found`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n }\n else {\n if (name.substring(0, 2) === '$@') {\n name = `$${new Variable(name.substr(1)).eval(context).value}`;\n }\n else {\n name = name.charAt(0) === '$' ? name : `$${name}`;\n }\n if (rules.properties) {\n rules = rules.property(name);\n }\n \n if (!rules) {\n throw { type: 'Name',\n message: `property \"${name.substr(1)}\" not found`,\n filename: this.fileInfo().filename,\n index: this.getIndex() };\n }\n // Properties are an array of values, since a ruleset can have multiple props.\n // We pick the last one (the \"cascaded\" value)\n rules = rules[rules.length - 1];\n }\n\n if (rules.value) {\n rules = rules.eval(context).value;\n }\n if (rules.ruleset) {\n rules = rules.ruleset.eval(context);\n }\n }\n return rules;\n }\n});\n\nexport default NamespaceValue;\n","import Selector from './selector';\nimport Element from './element';\nimport Ruleset from './ruleset';\nimport Declaration from './declaration';\nimport DetachedRuleset from './detached-ruleset';\nimport Expression from './expression';\nimport contexts from '../contexts';\nimport * as utils from '../utils';\n\nconst Definition = function(name, params, rules, condition, variadic, frames, visibilityInfo) {\n this.name = name || 'anonymous mixin';\n this.selectors = [new Selector([new Element(null, name, false, this._index, this._fileInfo)])];\n this.params = params;\n this.condition = condition;\n this.variadic = variadic;\n this.arity = params.length;\n this.rules = rules;\n this._lookups = {};\n const optionalParameters = [];\n this.required = params.reduce(function (count, p) {\n if (!p.name || (p.name && !p.value)) {\n return count + 1;\n }\n else {\n optionalParameters.push(p.name);\n return count;\n }\n }, 0);\n this.optionalParameters = optionalParameters;\n this.frames = frames;\n this.copyVisibilityInfo(visibilityInfo);\n this.allowRoot = true;\n}\n\nDefinition.prototype = Object.assign(new Ruleset(), {\n type: 'MixinDefinition',\n evalFirst: true,\n\n accept(visitor) {\n if (this.params && this.params.length) {\n this.params = visitor.visitArray(this.params);\n }\n this.rules = visitor.visitArray(this.rules);\n if (this.condition) {\n this.condition = visitor.visit(this.condition);\n }\n },\n\n evalParams(context, mixinEnv, args, evaldArguments) {\n /* jshint boss:true */\n const frame = new Ruleset(null, null);\n\n let varargs;\n let arg;\n const params = utils.copyArray(this.params);\n let i;\n let j;\n let val;\n let name;\n let isNamedFound;\n let argIndex;\n let argsLength = 0;\n\n if (mixinEnv.frames && mixinEnv.frames[0] && mixinEnv.frames[0].functionRegistry) {\n frame.functionRegistry = mixinEnv.frames[0].functionRegistry.inherit();\n }\n mixinEnv = new contexts.Eval(mixinEnv, [frame].concat(mixinEnv.frames));\n\n if (args) {\n args = utils.copyArray(args);\n argsLength = args.length;\n\n for (i = 0; i < argsLength; i++) {\n arg = args[i];\n if (name = (arg && arg.name)) {\n isNamedFound = false;\n for (j = 0; j < params.length; j++) {\n if (!evaldArguments[j] && name === params[j].name) {\n evaldArguments[j] = arg.value.eval(context);\n frame.prependRule(new Declaration(name, arg.value.eval(context)));\n isNamedFound = true;\n break;\n }\n }\n if (isNamedFound) {\n args.splice(i, 1);\n i--;\n continue;\n } else {\n throw { type: 'Runtime', message: `Named argument for ${this.name} ${args[i].name} not found` };\n }\n }\n }\n }\n argIndex = 0;\n for (i = 0; i < params.length; i++) {\n if (evaldArguments[i]) { continue; }\n\n arg = args && args[argIndex];\n\n if (name = params[i].name) {\n if (params[i].variadic) {\n varargs = [];\n for (j = argIndex; j < argsLength; j++) {\n varargs.push(args[j].value.eval(context));\n }\n frame.prependRule(new Declaration(name, new Expression(varargs).eval(context)));\n } else {\n val = arg && arg.value;\n if (val) {\n // This was a mixin call, pass in a detached ruleset of it's eval'd rules\n if (Array.isArray(val)) {\n val = new DetachedRuleset(new Ruleset('', val));\n }\n else {\n val = val.eval(context);\n }\n } else if (params[i].value) {\n val = params[i].value.eval(mixinEnv);\n frame.resetCache();\n } else {\n throw { type: 'Runtime', message: `wrong number of arguments for ${this.name} (${argsLength} for ${this.arity})` };\n }\n\n frame.prependRule(new Declaration(name, val));\n evaldArguments[i] = val;\n }\n }\n\n if (params[i].variadic && args) {\n for (j = argIndex; j < argsLength; j++) {\n evaldArguments[j] = args[j].value.eval(context);\n }\n }\n argIndex++;\n }\n\n return frame;\n },\n\n makeImportant() {\n const rules = !this.rules ? this.rules : this.rules.map(function (r) {\n if (r.makeImportant) {\n return r.makeImportant(true);\n } else {\n return r;\n }\n });\n const result = new Definition(this.name, this.params, rules, this.condition, this.variadic, this.frames);\n return result;\n },\n\n eval(context) {\n return new Definition(this.name, this.params, this.rules, this.condition, this.variadic, this.frames || utils.copyArray(context.frames));\n },\n\n evalCall(context, args, important) {\n const _arguments = [];\n const mixinFrames = this.frames ? this.frames.concat(context.frames) : context.frames;\n const frame = this.evalParams(context, new contexts.Eval(context, mixinFrames), args, _arguments);\n let rules;\n let ruleset;\n\n frame.prependRule(new Declaration('@arguments', new Expression(_arguments).eval(context)));\n\n rules = utils.copyArray(this.rules);\n\n ruleset = new Ruleset(null, rules);\n ruleset.originalRuleset = this;\n ruleset = ruleset.eval(new contexts.Eval(context, [this, frame].concat(mixinFrames)));\n if (important) {\n ruleset = ruleset.makeImportant();\n }\n return ruleset;\n },\n\n matchCondition(args, context) {\n if (this.condition && !this.condition.eval(\n new contexts.Eval(context,\n [this.evalParams(context, /* the parameter variables */\n new contexts.Eval(context, this.frames ? this.frames.concat(context.frames) : context.frames), args, [])]\n .concat(this.frames || []) // the parent namespace/mixin frames\n .concat(context.frames)))) { // the current environment frames\n return false;\n }\n return true;\n },\n\n matchArgs(args, context) {\n const allArgsCnt = (args && args.length) || 0;\n let len;\n const optionalParameters = this.optionalParameters;\n const requiredArgsCnt = !args ? 0 : args.reduce(function (count, p) {\n if (optionalParameters.indexOf(p.name) < 0) {\n return count + 1;\n } else {\n return count;\n }\n }, 0);\n\n if (!this.variadic) {\n if (requiredArgsCnt < this.required) {\n return false;\n }\n if (allArgsCnt > this.params.length) {\n return false;\n }\n } else {\n if (requiredArgsCnt < (this.required - 1)) {\n return false;\n }\n }\n\n // check patterns\n len = Math.min(requiredArgsCnt, this.arity);\n\n for (let i = 0; i < len; i++) {\n if (!this.params[i].name && !this.params[i].variadic) {\n if (args[i].value.eval(context).toCSS() != this.params[i].value.eval(context).toCSS()) {\n return false;\n }\n }\n }\n return true;\n }\n});\n\nexport default Definition;\n","import Node from './node';\nimport Selector from './selector';\nimport MixinDefinition from './mixin-definition';\nimport defaultFunc from '../functions/default';\n\nconst MixinCall = function(elements, args, index, currentFileInfo, important) {\n this.selector = new Selector(elements);\n this.arguments = args || [];\n this._index = index;\n this._fileInfo = currentFileInfo;\n this.important = important;\n this.allowRoot = true;\n this.setParent(this.selector, this);\n};\n\nMixinCall.prototype = Object.assign(new Node(), {\n type: 'MixinCall',\n\n accept(visitor) {\n if (this.selector) {\n this.selector = visitor.visit(this.selector);\n }\n if (this.arguments.length) {\n this.arguments = visitor.visitArray(this.arguments);\n }\n },\n\n eval(context) {\n let mixins;\n let mixin;\n let mixinPath;\n const args = [];\n let arg;\n let argValue;\n const rules = [];\n let match = false;\n let i;\n let m;\n let f;\n let isRecursive;\n let isOneFound;\n const candidates = [];\n let candidate;\n const conditionResult = [];\n let defaultResult;\n const defFalseEitherCase = -1;\n const defNone = 0;\n const defTrue = 1;\n const defFalse = 2;\n let count;\n let originalRuleset;\n let noArgumentsFilter;\n\n this.selector = this.selector.eval(context);\n\n function calcDefGroup(mixin, mixinPath) {\n let f, p, namespace;\n\n for (f = 0; f < 2; f++) {\n conditionResult[f] = true;\n defaultFunc.value(f);\n for (p = 0; p < mixinPath.length && conditionResult[f]; p++) {\n namespace = mixinPath[p];\n if (namespace.matchCondition) {\n conditionResult[f] = conditionResult[f] && namespace.matchCondition(null, context);\n }\n }\n if (mixin.matchCondition) {\n conditionResult[f] = conditionResult[f] && mixin.matchCondition(args, context);\n }\n }\n if (conditionResult[0] || conditionResult[1]) {\n if (conditionResult[0] != conditionResult[1]) {\n return conditionResult[1] ?\n defTrue : defFalse;\n }\n\n return defNone;\n }\n return defFalseEitherCase;\n }\n\n for (i = 0; i < this.arguments.length; i++) {\n arg = this.arguments[i];\n argValue = arg.value.eval(context);\n if (arg.expand && Array.isArray(argValue.value)) {\n argValue = argValue.value;\n for (m = 0; m < argValue.length; m++) {\n args.push({value: argValue[m]});\n }\n } else {\n args.push({name: arg.name, value: argValue});\n }\n }\n\n noArgumentsFilter = function(rule) {return rule.matchArgs(null, context);};\n\n for (i = 0; i < context.frames.length; i++) {\n if ((mixins = context.frames[i].find(this.selector, null, noArgumentsFilter)).length > 0) {\n isOneFound = true;\n\n // To make `default()` function independent of definition order we have two \"subpasses\" here.\n // At first we evaluate each guard *twice* (with `default() == true` and `default() == false`),\n // and build candidate list with corresponding flags. Then, when we know all possible matches,\n // we make a final decision.\n\n for (m = 0; m < mixins.length; m++) {\n mixin = mixins[m].rule;\n mixinPath = mixins[m].path;\n isRecursive = false;\n for (f = 0; f < context.frames.length; f++) {\n if ((!(mixin instanceof MixinDefinition)) && mixin === (context.frames[f].originalRuleset || context.frames[f])) {\n isRecursive = true;\n break;\n }\n }\n if (isRecursive) {\n continue;\n }\n\n if (mixin.matchArgs(args, context)) {\n candidate = {mixin, group: calcDefGroup(mixin, mixinPath)};\n\n if (candidate.group !== defFalseEitherCase) {\n candidates.push(candidate);\n }\n\n match = true;\n }\n }\n\n defaultFunc.reset();\n\n count = [0, 0, 0];\n for (m = 0; m < candidates.length; m++) {\n count[candidates[m].group]++;\n }\n\n if (count[defNone] > 0) {\n defaultResult = defFalse;\n } else {\n defaultResult = defTrue;\n if ((count[defTrue] + count[defFalse]) > 1) {\n throw { type: 'Runtime',\n message: `Ambiguous use of \\`default()\\` found when matching for \\`${this.format(args)}\\``,\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n }\n\n for (m = 0; m < candidates.length; m++) {\n candidate = candidates[m].group;\n if ((candidate === defNone) || (candidate === defaultResult)) {\n try {\n mixin = candidates[m].mixin;\n if (!(mixin instanceof MixinDefinition)) {\n originalRuleset = mixin.originalRuleset || mixin;\n mixin = new MixinDefinition('', [], mixin.rules, null, false, null, originalRuleset.visibilityInfo());\n mixin.originalRuleset = originalRuleset;\n }\n const newRules = mixin.evalCall(context, args, this.important).rules;\n this._setVisibilityToReplacement(newRules);\n Array.prototype.push.apply(rules, newRules);\n } catch (e) {\n throw { message: e.message, index: this.getIndex(), filename: this.fileInfo().filename, stack: e.stack };\n }\n }\n }\n\n if (match) {\n return rules;\n }\n }\n }\n if (isOneFound) {\n throw { type: 'Runtime',\n message: `No matching definition was found for \\`${this.format(args)}\\``,\n index: this.getIndex(), filename: this.fileInfo().filename };\n } else {\n throw { type: 'Name',\n message: `${this.selector.toCSS().trim()} is undefined`,\n index: this.getIndex(), filename: this.fileInfo().filename };\n }\n },\n\n _setVisibilityToReplacement(replacement) {\n let i, rule;\n if (this.blocksVisibility()) {\n for (i = 0; i < replacement.length; i++) {\n rule = replacement[i];\n rule.addVisibilityBlock();\n }\n }\n },\n\n format(args) {\n return `${this.selector.toCSS().trim()}(${args ? args.map(function (a) {\n let argValue = '';\n if (a.name) {\n argValue += `${a.name}:`;\n }\n if (a.value.toCSS) {\n argValue += a.value.toCSS();\n } else {\n argValue += '???';\n }\n return argValue;\n }).join(', ') : ''})`;\n }\n});\n\nexport default MixinCall;\n","import Node from './node';\nimport Color from './color';\nimport AtRule from './atrule';\nimport DetachedRuleset from './detached-ruleset';\nimport Operation from './operation';\nimport Dimension from './dimension';\nimport Unit from './unit';\nimport Keyword from './keyword';\nimport Variable from './variable';\nimport Property from './property';\nimport Ruleset from './ruleset';\nimport Element from './element';\nimport Attribute from './attribute';\nimport Combinator from './combinator';\nimport Selector from './selector';\nimport Quoted from './quoted';\nimport Expression from './expression';\nimport Declaration from './declaration';\nimport Call from './call';\nimport URL from './url';\nimport Import from './import';\nimport Comment from './comment';\nimport Anonymous from './anonymous';\nimport Value from './value';\nimport JavaScript from './javascript';\nimport Assignment from './assignment';\nimport Condition from './condition';\nimport Paren from './paren';\nimport Media from './media';\nimport UnicodeDescriptor from './unicode-descriptor';\nimport Negative from './negative';\nimport Extend from './extend';\nimport VariableCall from './variable-call';\nimport NamespaceValue from './namespace-value';\n\n// mixins\nimport MixinCall from './mixin-call';\nimport MixinDefinition from './mixin-definition';\n\nexport default {\n Node, Color, AtRule, DetachedRuleset, Operation,\n Dimension, Unit, Keyword, Variable, Property,\n Ruleset, Element, Attribute, Combinator, Selector,\n Quoted, Expression, Declaration, Call, URL, Import,\n Comment, Anonymous, Value, JavaScript, Assignment,\n Condition, Paren, Media, UnicodeDescriptor, Negative,\n Extend, VariableCall, NamespaceValue,\n mixin: {\n Call: MixinCall,\n Definition: MixinDefinition\n }\n};","class AbstractFileManager {\n getPath(filename) {\n let j = filename.lastIndexOf('?');\n if (j > 0) {\n filename = filename.slice(0, j);\n }\n j = filename.lastIndexOf('/');\n if (j < 0) {\n j = filename.lastIndexOf('\\\\');\n }\n if (j < 0) {\n return '';\n }\n return filename.slice(0, j + 1);\n }\n\n tryAppendExtension(path, ext) {\n return /(\\.[a-z]*$)|([\\?;].*)$/.test(path) ? path : path + ext;\n }\n\n tryAppendLessExtension(path) {\n return this.tryAppendExtension(path, '.less');\n }\n\n supportsSync() {\n return false;\n }\n\n alwaysMakePathsAbsolute() {\n return false;\n }\n\n isPathAbsolute(filename) {\n return (/^(?:[a-z-]+:|\\/|\\\\|#)/i).test(filename);\n }\n\n // TODO: pull out / replace?\n join(basePath, laterPath) {\n if (!basePath) {\n return laterPath;\n }\n return basePath + laterPath;\n }\n\n pathDiff(url, baseUrl) {\n // diff between two paths to create a relative path\n\n const urlParts = this.extractUrlParts(url);\n\n const baseUrlParts = this.extractUrlParts(baseUrl);\n let i;\n let max;\n let urlDirectories;\n let baseUrlDirectories;\n let diff = '';\n if (urlParts.hostPart !== baseUrlParts.hostPart) {\n return '';\n }\n max = Math.max(baseUrlParts.directories.length, urlParts.directories.length);\n for (i = 0; i < max; i++) {\n if (baseUrlParts.directories[i] !== urlParts.directories[i]) { break; }\n }\n baseUrlDirectories = baseUrlParts.directories.slice(i);\n urlDirectories = urlParts.directories.slice(i);\n for (i = 0; i < baseUrlDirectories.length - 1; i++) {\n diff += '../';\n }\n for (i = 0; i < urlDirectories.length - 1; i++) {\n diff += `${urlDirectories[i]}/`;\n }\n return diff;\n }\n\n // helper function, not part of API\n extractUrlParts(url, baseUrl) {\n // urlParts[1] = protocol://hostname/ OR /\n // urlParts[2] = / if path relative to host base\n // urlParts[3] = directories\n // urlParts[4] = filename\n // urlParts[5] = parameters\n\n const urlPartsRegex = /^((?:[a-z-]+:)?\\/{2}(?:[^\\/\\?#]*\\/)|([\\/\\\\]))?((?:[^\\/\\\\\\?#]*[\\/\\\\])*)([^\\/\\\\\\?#]*)([#\\?].*)?$/i;\n\n const urlParts = url.match(urlPartsRegex);\n const returner = {};\n let rawDirectories = [];\n const directories = [];\n let i;\n let baseUrlParts;\n\n if (!urlParts) {\n throw new Error(`Could not parse sheet href - '${url}'`);\n }\n\n // Stylesheets in IE don't always return the full path\n if (baseUrl && (!urlParts[1] || urlParts[2])) {\n baseUrlParts = baseUrl.match(urlPartsRegex);\n if (!baseUrlParts) {\n throw new Error(`Could not parse page url - '${baseUrl}'`);\n }\n urlParts[1] = urlParts[1] || baseUrlParts[1] || '';\n if (!urlParts[2]) {\n urlParts[3] = baseUrlParts[3] + urlParts[3];\n }\n }\n\n if (urlParts[3]) {\n rawDirectories = urlParts[3].replace(/\\\\/g, '/').split('/');\n\n // collapse '..' and skip '.'\n for (i = 0; i < rawDirectories.length; i++) {\n\n if (rawDirectories[i] === '..') {\n directories.pop();\n }\n else if (rawDirectories[i] !== '.') {\n directories.push(rawDirectories[i]);\n }\n \n }\n }\n\n returner.hostPart = urlParts[1];\n returner.directories = directories;\n returner.rawPath = (urlParts[1] || '') + rawDirectories.join('/');\n returner.path = (urlParts[1] || '') + directories.join('/');\n returner.filename = urlParts[4];\n returner.fileUrl = returner.path + (urlParts[4] || '');\n returner.url = returner.fileUrl + (urlParts[5] || '');\n return returner;\n }\n}\n\nexport default AbstractFileManager;\n","import functionRegistry from '../functions/function-registry';\nimport LessError from '../less-error';\n\nclass AbstractPluginLoader {\n constructor() {\n // Implemented by Node.js plugin loader\n this.require = function() {\n return null;\n }\n }\n\n evalPlugin(contents, context, imports, pluginOptions, fileInfo) {\n\n let loader, registry, pluginObj, localModule, pluginManager, filename, result;\n\n pluginManager = context.pluginManager;\n\n if (fileInfo) {\n if (typeof fileInfo === 'string') {\n filename = fileInfo;\n }\n else {\n filename = fileInfo.filename;\n }\n }\n const shortname = (new this.less.FileManager()).extractUrlParts(filename).filename;\n\n if (filename) {\n pluginObj = pluginManager.get(filename);\n\n if (pluginObj) {\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n if (result) {\n return result;\n }\n try {\n if (pluginObj.use) {\n pluginObj.use.call(this.context, pluginObj);\n }\n }\n catch (e) {\n e.message = e.message || 'Error during @plugin call';\n return new LessError(e, imports, filename);\n }\n return pluginObj;\n }\n }\n localModule = {\n exports: {},\n pluginManager,\n fileInfo\n };\n registry = functionRegistry.create();\n\n const registerPlugin = function(obj) {\n pluginObj = obj;\n };\n\n try {\n loader = new Function('module', 'require', 'registerPlugin', 'functions', 'tree', 'less', 'fileInfo', contents);\n loader(localModule, this.require(filename), registerPlugin, registry, this.less.tree, this.less, fileInfo);\n }\n catch (e) {\n return new LessError(e, imports, filename);\n }\n\n if (!pluginObj) {\n pluginObj = localModule.exports;\n }\n pluginObj = this.validatePlugin(pluginObj, filename, shortname);\n\n if (pluginObj instanceof LessError) {\n return pluginObj;\n }\n\n if (pluginObj) {\n pluginObj.imports = imports;\n pluginObj.filename = filename;\n\n // For < 3.x (or unspecified minVersion) - setOptions() before install()\n if (!pluginObj.minVersion || this.compareVersion('3.0.0', pluginObj.minVersion) < 0) {\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n\n if (result) {\n return result;\n }\n }\n\n // Run on first load\n pluginManager.addPlugin(pluginObj, fileInfo.filename, registry);\n pluginObj.functions = registry.getLocalFunctions();\n\n // Need to call setOptions again because the pluginObj might have functions\n result = this.trySetOptions(pluginObj, filename, shortname, pluginOptions);\n if (result) {\n return result;\n }\n\n // Run every @plugin call\n try {\n if (pluginObj.use) {\n pluginObj.use.call(this.context, pluginObj);\n }\n }\n catch (e) {\n e.message = e.message || 'Error during @plugin call';\n return new LessError(e, imports, filename);\n }\n\n }\n else {\n return new LessError({ message: 'Not a valid plugin' }, imports, filename);\n }\n\n return pluginObj;\n\n }\n\n trySetOptions(plugin, filename, name, options) {\n if (options && !plugin.setOptions) {\n return new LessError({\n message: `Options have been provided but the plugin ${name} does not support any options.`\n });\n }\n try {\n plugin.setOptions && plugin.setOptions(options);\n }\n catch (e) {\n return new LessError(e);\n }\n }\n\n validatePlugin(plugin, filename, name) {\n if (plugin) {\n // support plugins being a function\n // so that the plugin can be more usable programmatically\n if (typeof plugin === 'function') {\n plugin = new plugin();\n }\n\n if (plugin.minVersion) {\n if (this.compareVersion(plugin.minVersion, this.less.version) < 0) {\n return new LessError({\n message: `Plugin ${name} requires version ${this.versionToString(plugin.minVersion)}`\n });\n }\n }\n return plugin;\n }\n return null;\n }\n\n compareVersion(aVersion, bVersion) {\n if (typeof aVersion === 'string') {\n aVersion = aVersion.match(/^(\\d+)\\.?(\\d+)?\\.?(\\d+)?/);\n aVersion.shift();\n }\n for (let i = 0; i < aVersion.length; i++) {\n if (aVersion[i] !== bVersion[i]) {\n return parseInt(aVersion[i]) > parseInt(bVersion[i]) ? -1 : 1;\n }\n }\n return 0;\n }\n\n versionToString(version) {\n let versionString = '';\n for (let i = 0; i < version.length; i++) {\n versionString += (versionString ? '.' : '') + version[i];\n }\n return versionString;\n }\n\n printUsage(plugins) {\n for (let i = 0; i < plugins.length; i++) {\n const plugin = plugins[i];\n if (plugin.printUsage) {\n plugin.printUsage();\n }\n }\n }\n}\n\nexport default AbstractPluginLoader;\n\n","import tree from '../tree';\n\nconst _visitArgs = { visitDeeper: true };\nlet _hasIndexed = false;\n\nfunction _noop(node) {\n return node;\n}\n\nfunction indexNodeTypes(parent, ticker) {\n // add .typeIndex to tree node types for lookup table\n let key, child;\n for (key in parent) { \n /* eslint guard-for-in: 0 */\n child = parent[key];\n switch (typeof child) {\n case 'function':\n // ignore bound functions directly on tree which do not have a prototype\n // or aren't nodes\n if (child.prototype && child.prototype.type) {\n child.prototype.typeIndex = ticker++;\n }\n break;\n case 'object':\n ticker = indexNodeTypes(child, ticker);\n break;\n \n }\n }\n return ticker;\n}\n\nclass Visitor {\n constructor(implementation) {\n this._implementation = implementation;\n this._visitInCache = {};\n this._visitOutCache = {};\n\n if (!_hasIndexed) {\n indexNodeTypes(tree, 1);\n _hasIndexed = true;\n }\n }\n\n visit(node) {\n if (!node) {\n return node;\n }\n\n const nodeTypeIndex = node.typeIndex;\n if (!nodeTypeIndex) {\n // MixinCall args aren't a node type?\n if (node.value && node.value.typeIndex) {\n this.visit(node.value);\n }\n return node;\n }\n\n const impl = this._implementation;\n let func = this._visitInCache[nodeTypeIndex];\n let funcOut = this._visitOutCache[nodeTypeIndex];\n const visitArgs = _visitArgs;\n let fnName;\n\n visitArgs.visitDeeper = true;\n\n if (!func) {\n fnName = `visit${node.type}`;\n func = impl[fnName] || _noop;\n funcOut = impl[`${fnName}Out`] || _noop;\n this._visitInCache[nodeTypeIndex] = func;\n this._visitOutCache[nodeTypeIndex] = funcOut;\n }\n\n if (func !== _noop) {\n const newNode = func.call(impl, node, visitArgs);\n if (node && impl.isReplacing) {\n node = newNode;\n }\n }\n\n if (visitArgs.visitDeeper && node) {\n if (node.length) {\n for (let i = 0, cnt = node.length; i < cnt; i++) {\n if (node[i].accept) {\n node[i].accept(this);\n }\n }\n } else if (node.accept) {\n node.accept(this);\n }\n }\n\n if (funcOut != _noop) {\n funcOut.call(impl, node);\n }\n\n return node;\n }\n\n visitArray(nodes, nonReplacing) {\n if (!nodes) {\n return nodes;\n }\n\n const cnt = nodes.length;\n let i;\n\n // Non-replacing\n if (nonReplacing || !this._implementation.isReplacing) {\n for (i = 0; i < cnt; i++) {\n this.visit(nodes[i]);\n }\n return nodes;\n }\n\n // Replacing\n const out = [];\n for (i = 0; i < cnt; i++) {\n const evald = this.visit(nodes[i]);\n if (evald === undefined) { continue; }\n if (!evald.splice) {\n out.push(evald);\n } else if (evald.length) {\n this.flatten(evald, out);\n }\n }\n return out;\n }\n\n flatten(arr, out) {\n if (!out) {\n out = [];\n }\n\n let cnt, i, item, nestedCnt, j, nestedItem;\n\n for (i = 0, cnt = arr.length; i < cnt; i++) {\n item = arr[i];\n if (item === undefined) {\n continue;\n }\n if (!item.splice) {\n out.push(item);\n continue;\n }\n\n for (j = 0, nestedCnt = item.length; j < nestedCnt; j++) {\n nestedItem = item[j];\n if (nestedItem === undefined) {\n continue;\n }\n if (!nestedItem.splice) {\n out.push(nestedItem);\n } else if (nestedItem.length) {\n this.flatten(nestedItem, out);\n }\n }\n }\n\n return out;\n }\n}\n\nexport default Visitor;\n","class ImportSequencer {\n constructor(onSequencerEmpty) {\n this.imports = [];\n this.variableImports = [];\n this._onSequencerEmpty = onSequencerEmpty;\n this._currentDepth = 0;\n }\n\n addImport(callback) {\n const importSequencer = this,\n importItem = {\n callback,\n args: null,\n isReady: false\n };\n this.imports.push(importItem);\n return function() {\n importItem.args = Array.prototype.slice.call(arguments, 0);\n importItem.isReady = true;\n importSequencer.tryRun();\n };\n }\n\n addVariableImport(callback) {\n this.variableImports.push(callback);\n }\n\n tryRun() {\n this._currentDepth++;\n try {\n while (true) {\n while (this.imports.length > 0) {\n const importItem = this.imports[0];\n if (!importItem.isReady) {\n return;\n }\n this.imports = this.imports.slice(1);\n importItem.callback.apply(null, importItem.args);\n }\n if (this.variableImports.length === 0) {\n break;\n }\n const variableImport = this.variableImports[0];\n this.variableImports = this.variableImports.slice(1);\n variableImport();\n }\n } finally {\n this._currentDepth--;\n }\n if (this._currentDepth === 0 && this._onSequencerEmpty) {\n this._onSequencerEmpty();\n }\n }\n}\n\nexport default ImportSequencer;\n","import contexts from '../contexts';\nimport Visitor from './visitor';\nimport ImportSequencer from './import-sequencer';\nimport * as utils from '../utils';\n\nconst ImportVisitor = function(importer, finish) {\n\n this._visitor = new Visitor(this);\n this._importer = importer;\n this._finish = finish;\n this.context = new contexts.Eval();\n this.importCount = 0;\n this.onceFileDetectionMap = {};\n this.recursionDetector = {};\n this._sequencer = new ImportSequencer(this._onSequencerEmpty.bind(this));\n};\n\nImportVisitor.prototype = {\n isReplacing: false,\n run: function (root) {\n try {\n // process the contents\n this._visitor.visit(root);\n }\n catch (e) {\n this.error = e;\n }\n\n this.isFinished = true;\n this._sequencer.tryRun();\n },\n _onSequencerEmpty: function() {\n if (!this.isFinished) {\n return;\n }\n this._finish(this.error);\n },\n visitImport: function (importNode, visitArgs) {\n const inlineCSS = importNode.options.inline;\n\n if (!importNode.css || inlineCSS) {\n\n const context = new contexts.Eval(this.context, utils.copyArray(this.context.frames));\n const importParent = context.frames[0];\n\n this.importCount++;\n if (importNode.isVariableImport()) {\n this._sequencer.addVariableImport(this.processImportNode.bind(this, importNode, context, importParent));\n } else {\n this.processImportNode(importNode, context, importParent);\n }\n }\n visitArgs.visitDeeper = false;\n },\n processImportNode: function(importNode, context, importParent) {\n let evaldImportNode;\n const inlineCSS = importNode.options.inline;\n\n try {\n evaldImportNode = importNode.evalForImport(context);\n } catch (e) {\n if (!e.filename) { e.index = importNode.getIndex(); e.filename = importNode.fileInfo().filename; }\n // attempt to eval properly and treat as css\n importNode.css = true;\n // if that fails, this error will be thrown\n importNode.error = e;\n }\n\n if (evaldImportNode && (!evaldImportNode.css || inlineCSS)) {\n\n if (evaldImportNode.options.multiple) {\n context.importMultiple = true;\n }\n\n // try appending if we haven't determined if it is css or not\n const tryAppendLessExtension = evaldImportNode.css === undefined;\n\n for (let i = 0; i < importParent.rules.length; i++) {\n if (importParent.rules[i] === importNode) {\n importParent.rules[i] = evaldImportNode;\n break;\n }\n }\n\n const onImported = this.onImported.bind(this, evaldImportNode, context), sequencedOnImported = this._sequencer.addImport(onImported);\n\n this._importer.push(evaldImportNode.getPath(), tryAppendLessExtension, evaldImportNode.fileInfo(),\n evaldImportNode.options, sequencedOnImported);\n } else {\n this.importCount--;\n if (this.isFinished) {\n this._sequencer.tryRun();\n }\n }\n },\n onImported: function (importNode, context, e, root, importedAtRoot, fullPath) {\n if (e) {\n if (!e.filename) {\n e.index = importNode.getIndex(); e.filename = importNode.fileInfo().filename;\n }\n this.error = e;\n }\n\n const importVisitor = this,\n inlineCSS = importNode.options.inline,\n isPlugin = importNode.options.isPlugin,\n isOptional = importNode.options.optional,\n duplicateImport = importedAtRoot || fullPath in importVisitor.recursionDetector;\n\n if (!context.importMultiple) {\n if (duplicateImport) {\n importNode.skip = true;\n } else {\n importNode.skip = function() {\n if (fullPath in importVisitor.onceFileDetectionMap) {\n return true;\n }\n importVisitor.onceFileDetectionMap[fullPath] = true;\n return false;\n };\n }\n }\n\n if (!fullPath && isOptional) {\n importNode.skip = true;\n }\n\n if (root) {\n importNode.root = root;\n importNode.importedFilename = fullPath;\n\n if (!inlineCSS && !isPlugin && (context.importMultiple || !duplicateImport)) {\n importVisitor.recursionDetector[fullPath] = true;\n\n const oldContext = this.context;\n this.context = context;\n try {\n this._visitor.visit(root);\n } catch (e) {\n this.error = e;\n }\n this.context = oldContext;\n }\n }\n\n importVisitor.importCount--;\n\n if (importVisitor.isFinished) {\n importVisitor._sequencer.tryRun();\n }\n },\n visitDeclaration: function (declNode, visitArgs) {\n if (declNode.value.type === 'DetachedRuleset') {\n this.context.frames.unshift(declNode);\n } else {\n visitArgs.visitDeeper = false;\n }\n },\n visitDeclarationOut: function(declNode) {\n if (declNode.value.type === 'DetachedRuleset') {\n this.context.frames.shift();\n }\n },\n visitAtRule: function (atRuleNode, visitArgs) {\n this.context.frames.unshift(atRuleNode);\n },\n visitAtRuleOut: function (atRuleNode) {\n this.context.frames.shift();\n },\n visitMixinDefinition: function (mixinDefinitionNode, visitArgs) {\n this.context.frames.unshift(mixinDefinitionNode);\n },\n visitMixinDefinitionOut: function (mixinDefinitionNode) {\n this.context.frames.shift();\n },\n visitRuleset: function (rulesetNode, visitArgs) {\n this.context.frames.unshift(rulesetNode);\n },\n visitRulesetOut: function (rulesetNode) {\n this.context.frames.shift();\n },\n visitMedia: function (mediaNode, visitArgs) {\n this.context.frames.unshift(mediaNode.rules[0]);\n },\n visitMediaOut: function (mediaNode) {\n this.context.frames.shift();\n }\n};\nexport default ImportVisitor;\n","class SetTreeVisibilityVisitor {\n constructor(visible) {\n this.visible = visible;\n }\n\n run(root) {\n this.visit(root);\n }\n\n visitArray(nodes) {\n if (!nodes) {\n return nodes;\n }\n\n const cnt = nodes.length;\n let i;\n for (i = 0; i < cnt; i++) {\n this.visit(nodes[i]);\n }\n return nodes;\n }\n\n visit(node) {\n if (!node) {\n return node;\n }\n if (node.constructor === Array) {\n return this.visitArray(node);\n }\n\n if (!node.blocksVisibility || node.blocksVisibility()) {\n return node;\n }\n if (this.visible) {\n node.ensureVisibility();\n } else {\n node.ensureInvisibility();\n }\n\n node.accept(this);\n return node;\n }\n}\n\nexport default SetTreeVisibilityVisitor;","import tree from '../tree';\nimport Visitor from './visitor';\nimport logger from '../logger';\nimport * as utils from '../utils';\n\n/* jshint loopfunc:true */\n\nclass ExtendFinderVisitor {\n constructor() {\n this._visitor = new Visitor(this);\n this.contexts = [];\n this.allExtendsStack = [[]];\n }\n\n run(root) {\n root = this._visitor.visit(root);\n root.allExtends = this.allExtendsStack[0];\n return root;\n }\n\n visitDeclaration(declNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n if (rulesetNode.root) {\n return;\n }\n\n let i;\n let j;\n let extend;\n const allSelectorsExtendList = [];\n let extendList;\n\n // get &:extend(.a); rules which apply to all selectors in this ruleset\n const rules = rulesetNode.rules, ruleCnt = rules ? rules.length : 0;\n for (i = 0; i < ruleCnt; i++) {\n if (rulesetNode.rules[i] instanceof tree.Extend) {\n allSelectorsExtendList.push(rules[i]);\n rulesetNode.extendOnEveryPath = true;\n }\n }\n\n // now find every selector and apply the extends that apply to all extends\n // and the ones which apply to an individual extend\n const paths = rulesetNode.paths;\n for (i = 0; i < paths.length; i++) {\n const selectorPath = paths[i], selector = selectorPath[selectorPath.length - 1], selExtendList = selector.extendList;\n\n extendList = selExtendList ? utils.copyArray(selExtendList).concat(allSelectorsExtendList)\n : allSelectorsExtendList;\n\n if (extendList) {\n extendList = extendList.map(function(allSelectorsExtend) {\n return allSelectorsExtend.clone();\n });\n }\n\n for (j = 0; j < extendList.length; j++) {\n this.foundExtends = true;\n extend = extendList[j];\n extend.findSelfSelectors(selectorPath);\n extend.ruleset = rulesetNode;\n if (j === 0) { extend.firstExtendOnThisSelectorPath = true; }\n this.allExtendsStack[this.allExtendsStack.length - 1].push(extend);\n }\n }\n\n this.contexts.push(rulesetNode.selectors);\n }\n\n visitRulesetOut(rulesetNode) {\n if (!rulesetNode.root) {\n this.contexts.length = this.contexts.length - 1;\n }\n }\n\n visitMedia(mediaNode, visitArgs) {\n mediaNode.allExtends = [];\n this.allExtendsStack.push(mediaNode.allExtends);\n }\n\n visitMediaOut(mediaNode) {\n this.allExtendsStack.length = this.allExtendsStack.length - 1;\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n atRuleNode.allExtends = [];\n this.allExtendsStack.push(atRuleNode.allExtends);\n }\n\n visitAtRuleOut(atRuleNode) {\n this.allExtendsStack.length = this.allExtendsStack.length - 1;\n }\n}\n\nclass ProcessExtendsVisitor {\n constructor() {\n this._visitor = new Visitor(this);\n }\n\n run(root) {\n const extendFinder = new ExtendFinderVisitor();\n this.extendIndices = {};\n extendFinder.run(root);\n if (!extendFinder.foundExtends) { return root; }\n root.allExtends = root.allExtends.concat(this.doExtendChaining(root.allExtends, root.allExtends));\n this.allExtendsStack = [root.allExtends];\n const newRoot = this._visitor.visit(root);\n this.checkExtendsForNonMatched(root.allExtends);\n return newRoot;\n }\n\n checkExtendsForNonMatched(extendList) {\n const indices = this.extendIndices;\n extendList.filter(function(extend) {\n return !extend.hasFoundMatches && extend.parent_ids.length == 1;\n }).forEach(function(extend) {\n let selector = '_unknown_';\n try {\n selector = extend.selector.toCSS({});\n }\n catch (_) {}\n\n if (!indices[`${extend.index} ${selector}`]) {\n indices[`${extend.index} ${selector}`] = true;\n logger.warn(`extend '${selector}' has no matches`);\n }\n });\n }\n\n doExtendChaining(extendsList, extendsListTarget, iterationCount) {\n //\n // chaining is different from normal extension.. if we extend an extend then we are not just copying, altering\n // and pasting the selector we would do normally, but we are also adding an extend with the same target selector\n // this means this new extend can then go and alter other extends\n //\n // this method deals with all the chaining work - without it, extend is flat and doesn't work on other extend selectors\n // this is also the most expensive.. and a match on one selector can cause an extension of a selector we had already\n // processed if we look at each selector at a time, as is done in visitRuleset\n\n let extendIndex;\n\n let targetExtendIndex;\n let matches;\n const extendsToAdd = [];\n let newSelector;\n const extendVisitor = this;\n let selectorPath;\n let extend;\n let targetExtend;\n let newExtend;\n\n iterationCount = iterationCount || 0;\n\n // loop through comparing every extend with every target extend.\n // a target extend is the one on the ruleset we are looking at copy/edit/pasting in place\n // e.g. .a:extend(.b) {} and .b:extend(.c) {} then the first extend extends the second one\n // and the second is the target.\n // the separation into two lists allows us to process a subset of chains with a bigger set, as is the\n // case when processing media queries\n for (extendIndex = 0; extendIndex < extendsList.length; extendIndex++) {\n for (targetExtendIndex = 0; targetExtendIndex < extendsListTarget.length; targetExtendIndex++) {\n\n extend = extendsList[extendIndex];\n targetExtend = extendsListTarget[targetExtendIndex];\n\n // look for circular references\n if ( extend.parent_ids.indexOf( targetExtend.object_id ) >= 0 ) { continue; }\n\n // find a match in the target extends self selector (the bit before :extend)\n selectorPath = [targetExtend.selfSelectors[0]];\n matches = extendVisitor.findMatch(extend, selectorPath);\n\n if (matches.length) {\n extend.hasFoundMatches = true;\n\n // we found a match, so for each self selector..\n extend.selfSelectors.forEach(function(selfSelector) {\n const info = targetExtend.visibilityInfo();\n\n // process the extend as usual\n newSelector = extendVisitor.extendSelector(matches, selectorPath, selfSelector, extend.isVisible());\n\n // but now we create a new extend from it\n newExtend = new(tree.Extend)(targetExtend.selector, targetExtend.option, 0, targetExtend.fileInfo(), info);\n newExtend.selfSelectors = newSelector;\n\n // add the extend onto the list of extends for that selector\n newSelector[newSelector.length - 1].extendList = [newExtend];\n\n // record that we need to add it.\n extendsToAdd.push(newExtend);\n newExtend.ruleset = targetExtend.ruleset;\n\n // remember its parents for circular references\n newExtend.parent_ids = newExtend.parent_ids.concat(targetExtend.parent_ids, extend.parent_ids);\n\n // only process the selector once.. if we have :extend(.a,.b) then multiple\n // extends will look at the same selector path, so when extending\n // we know that any others will be duplicates in terms of what is added to the css\n if (targetExtend.firstExtendOnThisSelectorPath) {\n newExtend.firstExtendOnThisSelectorPath = true;\n targetExtend.ruleset.paths.push(newSelector);\n }\n });\n }\n }\n }\n\n if (extendsToAdd.length) {\n // try to detect circular references to stop a stack overflow.\n // may no longer be needed.\n this.extendChainCount++;\n if (iterationCount > 100) {\n let selectorOne = '{unable to calculate}';\n let selectorTwo = '{unable to calculate}';\n try {\n selectorOne = extendsToAdd[0].selfSelectors[0].toCSS();\n selectorTwo = extendsToAdd[0].selector.toCSS();\n }\n catch (e) {}\n throw { message: `extend circular reference detected. One of the circular extends is currently:${selectorOne}:extend(${selectorTwo})`};\n }\n\n // now process the new extends on the existing rules so that we can handle a extending b extending c extending\n // d extending e...\n return extendsToAdd.concat(extendVisitor.doExtendChaining(extendsToAdd, extendsListTarget, iterationCount + 1));\n } else {\n return extendsToAdd;\n }\n }\n\n visitDeclaration(ruleNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitSelector(selectorNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n if (rulesetNode.root) {\n return;\n }\n let matches;\n let pathIndex;\n let extendIndex;\n const allExtends = this.allExtendsStack[this.allExtendsStack.length - 1];\n const selectorsToAdd = [];\n const extendVisitor = this;\n let selectorPath;\n\n // look at each selector path in the ruleset, find any extend matches and then copy, find and replace\n\n for (extendIndex = 0; extendIndex < allExtends.length; extendIndex++) {\n for (pathIndex = 0; pathIndex < rulesetNode.paths.length; pathIndex++) {\n selectorPath = rulesetNode.paths[pathIndex];\n\n // extending extends happens initially, before the main pass\n if (rulesetNode.extendOnEveryPath) { continue; }\n const extendList = selectorPath[selectorPath.length - 1].extendList;\n if (extendList && extendList.length) { continue; }\n\n matches = this.findMatch(allExtends[extendIndex], selectorPath);\n\n if (matches.length) {\n allExtends[extendIndex].hasFoundMatches = true;\n\n allExtends[extendIndex].selfSelectors.forEach(function(selfSelector) {\n let extendedSelectors;\n extendedSelectors = extendVisitor.extendSelector(matches, selectorPath, selfSelector, allExtends[extendIndex].isVisible());\n selectorsToAdd.push(extendedSelectors);\n });\n }\n }\n }\n rulesetNode.paths = rulesetNode.paths.concat(selectorsToAdd);\n }\n\n findMatch(extend, haystackSelectorPath) {\n //\n // look through the haystack selector path to try and find the needle - extend.selector\n // returns an array of selector matches that can then be replaced\n //\n let haystackSelectorIndex;\n\n let hackstackSelector;\n let hackstackElementIndex;\n let haystackElement;\n let targetCombinator;\n let i;\n const extendVisitor = this;\n const needleElements = extend.selector.elements;\n const potentialMatches = [];\n let potentialMatch;\n const matches = [];\n\n // loop through the haystack elements\n for (haystackSelectorIndex = 0; haystackSelectorIndex < haystackSelectorPath.length; haystackSelectorIndex++) {\n hackstackSelector = haystackSelectorPath[haystackSelectorIndex];\n\n for (hackstackElementIndex = 0; hackstackElementIndex < hackstackSelector.elements.length; hackstackElementIndex++) {\n\n haystackElement = hackstackSelector.elements[hackstackElementIndex];\n\n // if we allow elements before our match we can add a potential match every time. otherwise only at the first element.\n if (extend.allowBefore || (haystackSelectorIndex === 0 && hackstackElementIndex === 0)) {\n potentialMatches.push({pathIndex: haystackSelectorIndex, index: hackstackElementIndex, matched: 0,\n initialCombinator: haystackElement.combinator});\n }\n\n for (i = 0; i < potentialMatches.length; i++) {\n potentialMatch = potentialMatches[i];\n\n // selectors add \" \" onto the first element. When we use & it joins the selectors together, but if we don't\n // then each selector in haystackSelectorPath has a space before it added in the toCSS phase. so we need to\n // work out what the resulting combinator will be\n targetCombinator = haystackElement.combinator.value;\n if (targetCombinator === '' && hackstackElementIndex === 0) {\n targetCombinator = ' ';\n }\n\n // if we don't match, null our match to indicate failure\n if (!extendVisitor.isElementValuesEqual(needleElements[potentialMatch.matched].value, haystackElement.value) ||\n (potentialMatch.matched > 0 && needleElements[potentialMatch.matched].combinator.value !== targetCombinator)) {\n potentialMatch = null;\n } else {\n potentialMatch.matched++;\n }\n\n // if we are still valid and have finished, test whether we have elements after and whether these are allowed\n if (potentialMatch) {\n potentialMatch.finished = potentialMatch.matched === needleElements.length;\n if (potentialMatch.finished &&\n (!extend.allowAfter &&\n (hackstackElementIndex + 1 < hackstackSelector.elements.length || haystackSelectorIndex + 1 < haystackSelectorPath.length))) {\n potentialMatch = null;\n }\n }\n // if null we remove, if not, we are still valid, so either push as a valid match or continue\n if (potentialMatch) {\n if (potentialMatch.finished) {\n potentialMatch.length = needleElements.length;\n potentialMatch.endPathIndex = haystackSelectorIndex;\n potentialMatch.endPathElementIndex = hackstackElementIndex + 1; // index after end of match\n potentialMatches.length = 0; // we don't allow matches to overlap, so start matching again\n matches.push(potentialMatch);\n }\n } else {\n potentialMatches.splice(i, 1);\n i--;\n }\n }\n }\n }\n return matches;\n }\n\n isElementValuesEqual(elementValue1, elementValue2) {\n if (typeof elementValue1 === 'string' || typeof elementValue2 === 'string') {\n return elementValue1 === elementValue2;\n }\n if (elementValue1 instanceof tree.Attribute) {\n if (elementValue1.op !== elementValue2.op || elementValue1.key !== elementValue2.key) {\n return false;\n }\n if (!elementValue1.value || !elementValue2.value) {\n if (elementValue1.value || elementValue2.value) {\n return false;\n }\n return true;\n }\n elementValue1 = elementValue1.value.value || elementValue1.value;\n elementValue2 = elementValue2.value.value || elementValue2.value;\n return elementValue1 === elementValue2;\n }\n elementValue1 = elementValue1.value;\n elementValue2 = elementValue2.value;\n if (elementValue1 instanceof tree.Selector) {\n if (!(elementValue2 instanceof tree.Selector) || elementValue1.elements.length !== elementValue2.elements.length) {\n return false;\n }\n for (let i = 0; i < elementValue1.elements.length; i++) {\n if (elementValue1.elements[i].combinator.value !== elementValue2.elements[i].combinator.value) {\n if (i !== 0 || (elementValue1.elements[i].combinator.value || ' ') !== (elementValue2.elements[i].combinator.value || ' ')) {\n return false;\n }\n }\n if (!this.isElementValuesEqual(elementValue1.elements[i].value, elementValue2.elements[i].value)) {\n return false;\n }\n }\n return true;\n }\n return false;\n }\n\n extendSelector(matches, selectorPath, replacementSelector, isVisible) {\n\n // for a set of matches, replace each match with the replacement selector\n\n let currentSelectorPathIndex = 0, currentSelectorPathElementIndex = 0, path = [], matchIndex, selector, firstElement, match, newElements;\n\n for (matchIndex = 0; matchIndex < matches.length; matchIndex++) {\n match = matches[matchIndex];\n selector = selectorPath[match.pathIndex];\n firstElement = new tree.Element(\n match.initialCombinator,\n replacementSelector.elements[0].value,\n replacementSelector.elements[0].isVariable,\n replacementSelector.elements[0].getIndex(),\n replacementSelector.elements[0].fileInfo()\n );\n\n if (match.pathIndex > currentSelectorPathIndex && currentSelectorPathElementIndex > 0) {\n path[path.length - 1].elements = path[path.length - 1]\n .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex));\n currentSelectorPathElementIndex = 0;\n currentSelectorPathIndex++;\n }\n\n newElements = selector.elements\n .slice(currentSelectorPathElementIndex, match.index)\n .concat([firstElement])\n .concat(replacementSelector.elements.slice(1));\n\n if (currentSelectorPathIndex === match.pathIndex && matchIndex > 0) {\n path[path.length - 1].elements =\n path[path.length - 1].elements.concat(newElements);\n } else {\n path = path.concat(selectorPath.slice(currentSelectorPathIndex, match.pathIndex));\n\n path.push(new tree.Selector(\n newElements\n ));\n }\n currentSelectorPathIndex = match.endPathIndex;\n currentSelectorPathElementIndex = match.endPathElementIndex;\n if (currentSelectorPathElementIndex >= selectorPath[currentSelectorPathIndex].elements.length) {\n currentSelectorPathElementIndex = 0;\n currentSelectorPathIndex++;\n }\n }\n\n if (currentSelectorPathIndex < selectorPath.length && currentSelectorPathElementIndex > 0) {\n path[path.length - 1].elements = path[path.length - 1]\n .elements.concat(selectorPath[currentSelectorPathIndex].elements.slice(currentSelectorPathElementIndex));\n currentSelectorPathIndex++;\n }\n\n path = path.concat(selectorPath.slice(currentSelectorPathIndex, selectorPath.length));\n path = path.map(function (currentValue) {\n // we can re-use elements here, because the visibility property matters only for selectors\n const derived = currentValue.createDerived(currentValue.elements);\n if (isVisible) {\n derived.ensureVisibility();\n } else {\n derived.ensureInvisibility();\n }\n return derived;\n });\n return path;\n }\n\n visitMedia(mediaNode, visitArgs) {\n let newAllExtends = mediaNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]);\n newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, mediaNode.allExtends));\n this.allExtendsStack.push(newAllExtends);\n }\n\n visitMediaOut(mediaNode) {\n const lastIndex = this.allExtendsStack.length - 1;\n this.allExtendsStack.length = lastIndex;\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n let newAllExtends = atRuleNode.allExtends.concat(this.allExtendsStack[this.allExtendsStack.length - 1]);\n newAllExtends = newAllExtends.concat(this.doExtendChaining(newAllExtends, atRuleNode.allExtends));\n this.allExtendsStack.push(newAllExtends);\n }\n\n visitAtRuleOut(atRuleNode) {\n const lastIndex = this.allExtendsStack.length - 1;\n this.allExtendsStack.length = lastIndex;\n }\n}\n\nexport default ProcessExtendsVisitor;\n","import Visitor from './visitor';\n\nclass JoinSelectorVisitor {\n constructor() {\n this.contexts = [[]];\n this._visitor = new Visitor(this);\n }\n\n run(root) {\n return this._visitor.visit(root);\n }\n\n visitDeclaration(declNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitMixinDefinition(mixinDefinitionNode, visitArgs) {\n visitArgs.visitDeeper = false;\n }\n\n visitRuleset(rulesetNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n const paths = [];\n let selectors;\n\n this.contexts.push(paths);\n\n if (!rulesetNode.root) {\n selectors = rulesetNode.selectors;\n if (selectors) {\n selectors = selectors.filter(function(selector) { return selector.getIsOutput(); });\n rulesetNode.selectors = selectors.length ? selectors : (selectors = null);\n if (selectors) { rulesetNode.joinSelectors(paths, context, selectors); }\n }\n if (!selectors) { rulesetNode.rules = null; }\n rulesetNode.paths = paths;\n }\n }\n\n visitRulesetOut(rulesetNode) {\n this.contexts.length = this.contexts.length - 1;\n }\n\n visitMedia(mediaNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n mediaNode.rules[0].root = (context.length === 0 || context[0].multiMedia);\n }\n\n visitAtRule(atRuleNode, visitArgs) {\n const context = this.contexts[this.contexts.length - 1];\n if (atRuleNode.rules && atRuleNode.rules.length) {\n atRuleNode.rules[0].root = (atRuleNode.isRooted || context.length === 0 || null);\n }\n }\n}\n\nexport default JoinSelectorVisitor;\n","import tree from '../tree';\nimport Visitor from './visitor';\n\nclass CSSVisitorUtils {\n constructor(context) {\n this._visitor = new Visitor(this);\n this._context = context;\n }\n\n containsSilentNonBlockedChild(bodyRules) {\n let rule;\n if (!bodyRules) {\n return false;\n }\n for (let r = 0; r < bodyRules.length; r++) {\n rule = bodyRules[r];\n if (rule.isSilent && rule.isSilent(this._context) && !rule.blocksVisibility()) {\n // the atrule contains something that was referenced (likely by extend)\n // therefore it needs to be shown in output too\n return true;\n }\n }\n return false;\n }\n\n keepOnlyVisibleChilds(owner) {\n if (owner && owner.rules) {\n owner.rules = owner.rules.filter(thing => thing.isVisible());\n }\n }\n\n isEmpty(owner) {\n return (owner && owner.rules) \n ? (owner.rules.length === 0) : true;\n }\n\n hasVisibleSelector(rulesetNode) {\n return (rulesetNode && rulesetNode.paths)\n ? (rulesetNode.paths.length > 0) : false;\n }\n\n resolveVisibility(node, originalRules) {\n if (!node.blocksVisibility()) {\n if (this.isEmpty(node) && !this.containsSilentNonBlockedChild(originalRules)) {\n return ;\n }\n\n return node;\n }\n\n const compiledRulesBody = node.rules[0];\n this.keepOnlyVisibleChilds(compiledRulesBody);\n\n if (this.isEmpty(compiledRulesBody)) {\n return ;\n }\n\n node.ensureVisibility();\n node.removeVisibilityBlock();\n\n return node;\n }\n\n isVisibleRuleset(rulesetNode) {\n if (rulesetNode.firstRoot) {\n return true;\n }\n\n if (this.isEmpty(rulesetNode)) {\n return false;\n }\n\n if (!rulesetNode.root && !this.hasVisibleSelector(rulesetNode)) {\n return false;\n }\n\n return true;\n }\n}\n\nconst ToCSSVisitor = function(context) {\n this._visitor = new Visitor(this);\n this._context = context;\n this.utils = new CSSVisitorUtils(context);\n};\n\nToCSSVisitor.prototype = {\n isReplacing: true,\n run: function (root) {\n return this._visitor.visit(root);\n },\n\n visitDeclaration: function (declNode, visitArgs) {\n if (declNode.blocksVisibility() || declNode.variable) {\n return;\n }\n return declNode;\n },\n\n visitMixinDefinition: function (mixinNode, visitArgs) {\n // mixin definitions do not get eval'd - this means they keep state\n // so we have to clear that state here so it isn't used if toCSS is called twice\n mixinNode.frames = [];\n },\n\n visitExtend: function (extendNode, visitArgs) {\n },\n\n visitComment: function (commentNode, visitArgs) {\n if (commentNode.blocksVisibility() || commentNode.isSilent(this._context)) {\n return;\n }\n return commentNode;\n },\n\n visitMedia: function(mediaNode, visitArgs) {\n const originalRules = mediaNode.rules[0].rules;\n mediaNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n\n return this.utils.resolveVisibility(mediaNode, originalRules);\n },\n\n visitImport: function (importNode, visitArgs) {\n if (importNode.blocksVisibility()) {\n return ;\n }\n return importNode;\n },\n\n visitAtRule: function(atRuleNode, visitArgs) {\n if (atRuleNode.rules && atRuleNode.rules.length) {\n return this.visitAtRuleWithBody(atRuleNode, visitArgs);\n } else {\n return this.visitAtRuleWithoutBody(atRuleNode, visitArgs);\n }\n },\n\n visitAnonymous: function(anonymousNode, visitArgs) {\n if (!anonymousNode.blocksVisibility()) {\n anonymousNode.accept(this._visitor);\n return anonymousNode;\n }\n },\n\n visitAtRuleWithBody: function(atRuleNode, visitArgs) {\n // if there is only one nested ruleset and that one has no path, then it is\n // just fake ruleset\n function hasFakeRuleset(atRuleNode) {\n const bodyRules = atRuleNode.rules;\n return bodyRules.length === 1 && (!bodyRules[0].paths || bodyRules[0].paths.length === 0);\n }\n function getBodyRules(atRuleNode) {\n const nodeRules = atRuleNode.rules;\n if (hasFakeRuleset(atRuleNode)) {\n return nodeRules[0].rules;\n }\n\n return nodeRules;\n }\n // it is still true that it is only one ruleset in array\n // this is last such moment\n // process childs\n const originalRules = getBodyRules(atRuleNode);\n atRuleNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n\n if (!this.utils.isEmpty(atRuleNode)) {\n this._mergeRules(atRuleNode.rules[0].rules);\n }\n\n return this.utils.resolveVisibility(atRuleNode, originalRules);\n },\n\n visitAtRuleWithoutBody: function(atRuleNode, visitArgs) {\n if (atRuleNode.blocksVisibility()) {\n return;\n }\n\n if (atRuleNode.name === '@charset') {\n // Only output the debug info together with subsequent @charset definitions\n // a comment (or @media statement) before the actual @charset atrule would\n // be considered illegal css as it has to be on the first line\n if (this.charset) {\n if (atRuleNode.debugInfo) {\n const comment = new tree.Comment(`/* ${atRuleNode.toCSS(this._context).replace(/\\n/g, '')} */\\n`);\n comment.debugInfo = atRuleNode.debugInfo;\n return this._visitor.visit(comment);\n }\n return;\n }\n this.charset = true;\n }\n\n return atRuleNode;\n },\n\n checkValidNodes: function(rules, isRoot) {\n if (!rules) {\n return;\n }\n\n for (let i = 0; i < rules.length; i++) {\n const ruleNode = rules[i];\n if (isRoot && ruleNode instanceof tree.Declaration && !ruleNode.variable) {\n throw { message: 'Properties must be inside selector blocks. They cannot be in the root',\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n if (ruleNode instanceof tree.Call) {\n throw { message: `Function '${ruleNode.name}' did not return a root node`,\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n if (ruleNode.type && !ruleNode.allowRoot) {\n throw { message: `${ruleNode.type} node returned by a function is not valid here`,\n index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename};\n }\n }\n },\n\n visitRuleset: function (rulesetNode, visitArgs) {\n // at this point rulesets are nested into each other\n let rule;\n\n const rulesets = [];\n\n this.checkValidNodes(rulesetNode.rules, rulesetNode.firstRoot);\n\n if (!rulesetNode.root) {\n // remove invisible paths\n this._compileRulesetPaths(rulesetNode);\n\n // remove rulesets from this ruleset body and compile them separately\n const nodeRules = rulesetNode.rules;\n\n let nodeRuleCnt = nodeRules ? nodeRules.length : 0;\n for (let i = 0; i < nodeRuleCnt; ) {\n rule = nodeRules[i];\n if (rule && rule.rules) {\n // visit because we are moving them out from being a child\n rulesets.push(this._visitor.visit(rule));\n nodeRules.splice(i, 1);\n nodeRuleCnt--;\n continue;\n }\n i++;\n }\n // accept the visitor to remove rules and refactor itself\n // then we can decide nogw whether we want it or not\n // compile body\n if (nodeRuleCnt > 0) {\n rulesetNode.accept(this._visitor);\n } else {\n rulesetNode.rules = null;\n }\n visitArgs.visitDeeper = false;\n } else { // if (! rulesetNode.root) {\n rulesetNode.accept(this._visitor);\n visitArgs.visitDeeper = false;\n }\n\n if (rulesetNode.rules) {\n this._mergeRules(rulesetNode.rules);\n this._removeDuplicateRules(rulesetNode.rules);\n }\n\n // now decide whether we keep the ruleset\n if (this.utils.isVisibleRuleset(rulesetNode)) {\n rulesetNode.ensureVisibility();\n rulesets.splice(0, 0, rulesetNode);\n }\n\n if (rulesets.length === 1) {\n return rulesets[0];\n }\n return rulesets;\n },\n\n _compileRulesetPaths: function(rulesetNode) {\n if (rulesetNode.paths) {\n rulesetNode.paths = rulesetNode.paths\n .filter(p => {\n let i;\n if (p[0].elements[0].combinator.value === ' ') {\n p[0].elements[0].combinator = new(tree.Combinator)('');\n }\n for (i = 0; i < p.length; i++) {\n if (p[i].isVisible() && p[i].getIsOutput()) {\n return true;\n }\n }\n return false;\n });\n }\n },\n\n _removeDuplicateRules: function(rules) {\n if (!rules) { return; }\n\n // remove duplicates\n const ruleCache = {};\n\n let ruleList;\n let rule;\n let i;\n\n for (i = rules.length - 1; i >= 0 ; i--) {\n rule = rules[i];\n if (rule instanceof tree.Declaration) {\n if (!ruleCache[rule.name]) {\n ruleCache[rule.name] = rule;\n } else {\n ruleList = ruleCache[rule.name];\n if (ruleList instanceof tree.Declaration) {\n ruleList = ruleCache[rule.name] = [ruleCache[rule.name].toCSS(this._context)];\n }\n const ruleCSS = rule.toCSS(this._context);\n if (ruleList.indexOf(ruleCSS) !== -1) {\n rules.splice(i, 1);\n } else {\n ruleList.push(ruleCSS);\n }\n }\n }\n }\n },\n\n _mergeRules: function(rules) {\n if (!rules) {\n return; \n }\n\n const groups = {};\n const groupsArr = [];\n\n for (let i = 0; i < rules.length; i++) {\n const rule = rules[i];\n if (rule.merge) {\n const key = rule.name;\n groups[key] ? rules.splice(i--, 1) : \n groupsArr.push(groups[key] = []);\n groups[key].push(rule);\n }\n }\n\n groupsArr.forEach(group => {\n if (group.length > 0) {\n const result = group[0];\n let space = [];\n const comma = [new tree.Expression(space)];\n group.forEach(rule => {\n if ((rule.merge === '+') && (space.length > 0)) {\n comma.push(new tree.Expression(space = []));\n }\n space.push(rule.value);\n result.important = result.important || rule.important;\n });\n result.value = new tree.Value(comma);\n }\n });\n }\n};\n\nexport default ToCSSVisitor;\n","import Visitor from './visitor';\nimport ImportVisitor from './import-visitor';\nimport MarkVisibleSelectorsVisitor from './set-tree-visibility-visitor';\nimport ExtendVisitor from './extend-visitor';\nimport JoinSelectorVisitor from './join-selector-visitor';\nimport ToCSSVisitor from './to-css-visitor';\n\nexport default {\n Visitor,\n ImportVisitor,\n MarkVisibleSelectorsVisitor,\n ExtendVisitor,\n JoinSelectorVisitor,\n ToCSSVisitor\n};\n","import chunker from './chunker';\n\nexport default () => {\n let // Less input string\n input;\n\n let // current chunk\n j;\n\n const // holds state for backtracking\n saveStack = [];\n\n let // furthest index the parser has gone to\n furthest;\n\n let // if this is furthest we got to, this is the probably cause\n furthestPossibleErrorMessage;\n\n let // chunkified input\n chunks;\n\n let // current chunk\n current;\n\n let // index of current chunk, in `input`\n currentPos;\n\n const parserInput = {};\n const CHARCODE_SPACE = 32;\n const CHARCODE_TAB = 9;\n const CHARCODE_LF = 10;\n const CHARCODE_CR = 13;\n const CHARCODE_PLUS = 43;\n const CHARCODE_COMMA = 44;\n const CHARCODE_FORWARD_SLASH = 47;\n const CHARCODE_9 = 57;\n\n function skipWhitespace(length) {\n const oldi = parserInput.i;\n const oldj = j;\n const curr = parserInput.i - currentPos;\n const endIndex = parserInput.i + current.length - curr;\n const mem = (parserInput.i += length);\n const inp = input;\n let c;\n let nextChar;\n let comment;\n\n for (; parserInput.i < endIndex; parserInput.i++) {\n c = inp.charCodeAt(parserInput.i);\n\n if (parserInput.autoCommentAbsorb && c === CHARCODE_FORWARD_SLASH) {\n nextChar = inp.charAt(parserInput.i + 1);\n if (nextChar === '/') {\n comment = {index: parserInput.i, isLineComment: true};\n let nextNewLine = inp.indexOf('\\n', parserInput.i + 2);\n if (nextNewLine < 0) {\n nextNewLine = endIndex;\n }\n parserInput.i = nextNewLine;\n comment.text = inp.substr(comment.index, parserInput.i - comment.index);\n parserInput.commentStore.push(comment);\n continue;\n } else if (nextChar === '*') {\n const nextStarSlash = inp.indexOf('*/', parserInput.i + 2);\n if (nextStarSlash >= 0) {\n comment = {\n index: parserInput.i,\n text: inp.substr(parserInput.i, nextStarSlash + 2 - parserInput.i),\n isLineComment: false\n };\n parserInput.i += comment.text.length - 1;\n parserInput.commentStore.push(comment);\n continue;\n }\n }\n break;\n }\n\n if ((c !== CHARCODE_SPACE) && (c !== CHARCODE_LF) && (c !== CHARCODE_TAB) && (c !== CHARCODE_CR)) {\n break;\n }\n }\n\n current = current.slice(length + parserInput.i - mem + curr);\n currentPos = parserInput.i;\n\n if (!current.length) {\n if (j < chunks.length - 1) {\n current = chunks[++j];\n skipWhitespace(0); // skip space at the beginning of a chunk\n return true; // things changed\n }\n parserInput.finished = true;\n }\n\n return oldi !== parserInput.i || oldj !== j;\n }\n\n parserInput.save = () => {\n currentPos = parserInput.i;\n saveStack.push( { current, i: parserInput.i, j });\n };\n parserInput.restore = possibleErrorMessage => {\n\n if (parserInput.i > furthest || (parserInput.i === furthest && possibleErrorMessage && !furthestPossibleErrorMessage)) {\n furthest = parserInput.i;\n furthestPossibleErrorMessage = possibleErrorMessage;\n }\n const state = saveStack.pop();\n current = state.current;\n currentPos = parserInput.i = state.i;\n j = state.j;\n };\n parserInput.forget = () => {\n saveStack.pop();\n };\n parserInput.isWhitespace = offset => {\n const pos = parserInput.i + (offset || 0);\n const code = input.charCodeAt(pos);\n return (code === CHARCODE_SPACE || code === CHARCODE_CR || code === CHARCODE_TAB || code === CHARCODE_LF);\n };\n\n // Specialization of $(tok)\n parserInput.$re = tok => {\n if (parserInput.i > currentPos) {\n current = current.slice(parserInput.i - currentPos);\n currentPos = parserInput.i;\n }\n\n const m = tok.exec(current);\n if (!m) {\n return null;\n }\n\n skipWhitespace(m[0].length);\n if (typeof m === 'string') {\n return m;\n }\n\n return m.length === 1 ? m[0] : m;\n };\n\n parserInput.$char = tok => {\n if (input.charAt(parserInput.i) !== tok) {\n return null;\n }\n skipWhitespace(1);\n return tok;\n };\n\n parserInput.$str = tok => {\n const tokLength = tok.length;\n\n // https://jsperf.com/string-startswith/21\n for (let i = 0; i < tokLength; i++) {\n if (input.charAt(parserInput.i + i) !== tok.charAt(i)) {\n return null;\n }\n }\n\n skipWhitespace(tokLength);\n return tok;\n };\n\n parserInput.$quoted = loc => {\n const pos = loc || parserInput.i;\n const startChar = input.charAt(pos);\n\n if (startChar !== '\\'' && startChar !== '\"') {\n return;\n }\n const length = input.length;\n const currentPosition = pos;\n\n for (let i = 1; i + currentPosition < length; i++) {\n const nextChar = input.charAt(i + currentPosition);\n switch (nextChar) {\n case '\\\\':\n i++;\n continue;\n case '\\r':\n case '\\n':\n break;\n case startChar:\n const str = input.substr(currentPosition, i + 1);\n if (!loc && loc !== 0) {\n skipWhitespace(i + 1);\n return str\n }\n return [startChar, str];\n default:\n }\n }\n return null;\n };\n\n /**\n * Permissive parsing. Ignores everything except matching {} [] () and quotes\n * until matching token (outside of blocks)\n */\n parserInput.$parseUntil = tok => {\n let quote = '';\n let returnVal = null;\n let inComment = false;\n let blockDepth = 0;\n const blockStack = [];\n const parseGroups = [];\n const length = input.length;\n const startPos = parserInput.i;\n let lastPos = parserInput.i;\n let i = parserInput.i;\n let loop = true;\n let testChar;\n\n if (typeof tok === 'string') {\n testChar = char => char === tok\n } else {\n testChar = char => tok.test(char)\n }\n\n do {\n let prevChar;\n let nextChar = input.charAt(i);\n if (blockDepth === 0 && testChar(nextChar)) {\n returnVal = input.substr(lastPos, i - lastPos);\n if (returnVal) {\n parseGroups.push(returnVal);\n }\n else {\n parseGroups.push(' ');\n }\n returnVal = parseGroups;\n skipWhitespace(i - startPos);\n loop = false\n } else {\n if (inComment) {\n if (nextChar === '*' && \n input.charAt(i + 1) === '/') {\n i++;\n blockDepth--;\n inComment = false;\n }\n i++;\n continue;\n }\n switch (nextChar) {\n case '\\\\':\n i++;\n nextChar = input.charAt(i);\n parseGroups.push(input.substr(lastPos, i - lastPos + 1));\n lastPos = i + 1;\n break;\n case '/':\n if (input.charAt(i + 1) === '*') {\n i++;\n inComment = true;\n blockDepth++;\n }\n break;\n case '\\'':\n case '\"':\n quote = parserInput.$quoted(i);\n if (quote) {\n parseGroups.push(input.substr(lastPos, i - lastPos), quote);\n i += quote[1].length - 1;\n lastPos = i + 1;\n }\n else {\n skipWhitespace(i - startPos);\n returnVal = nextChar;\n loop = false;\n }\n break;\n case '{':\n blockStack.push('}');\n blockDepth++;\n break;\n case '(':\n blockStack.push(')');\n blockDepth++;\n break;\n case '[':\n blockStack.push(']');\n blockDepth++;\n break;\n case '}':\n case ')':\n case ']':\n const expected = blockStack.pop();\n if (nextChar === expected) {\n blockDepth--;\n } else {\n // move the parser to the error and return expected\n skipWhitespace(i - startPos);\n returnVal = expected;\n loop = false;\n }\n }\n i++;\n if (i > length) {\n loop = false;\n }\n }\n prevChar = nextChar;\n } while (loop);\n\n return returnVal ? returnVal : null;\n }\n\n parserInput.autoCommentAbsorb = true;\n parserInput.commentStore = [];\n parserInput.finished = false;\n\n // Same as $(), but don't change the state of the parser,\n // just return the match.\n parserInput.peek = tok => {\n if (typeof tok === 'string') {\n // https://jsperf.com/string-startswith/21\n for (let i = 0; i < tok.length; i++) {\n if (input.charAt(parserInput.i + i) !== tok.charAt(i)) {\n return false;\n }\n }\n return true;\n } else {\n return tok.test(current);\n }\n };\n\n // Specialization of peek()\n // TODO remove or change some currentChar calls to peekChar\n parserInput.peekChar = tok => input.charAt(parserInput.i) === tok;\n\n parserInput.currentChar = () => input.charAt(parserInput.i);\n\n parserInput.prevChar = () => input.charAt(parserInput.i - 1);\n\n parserInput.getInput = () => input;\n\n parserInput.peekNotNumeric = () => {\n const c = input.charCodeAt(parserInput.i);\n // Is the first char of the dimension 0-9, '.', '+' or '-'\n return (c > CHARCODE_9 || c < CHARCODE_PLUS) || c === CHARCODE_FORWARD_SLASH || c === CHARCODE_COMMA;\n };\n\n parserInput.start = (str, chunkInput, failFunction) => {\n input = str;\n parserInput.i = j = currentPos = furthest = 0;\n\n // chunking apparently makes things quicker (but my tests indicate\n // it might actually make things slower in node at least)\n // and it is a non-perfect parse - it can't recognise\n // unquoted urls, meaning it can't distinguish comments\n // meaning comments with quotes or {}() in them get 'counted'\n // and then lead to parse errors.\n // In addition if the chunking chunks in the wrong place we might\n // not be able to parse a parser statement in one go\n // this is officially deprecated but can be switched on via an option\n // in the case it causes too much performance issues.\n if (chunkInput) {\n chunks = chunker(str, failFunction);\n } else {\n chunks = [str];\n }\n\n current = chunks[0];\n\n skipWhitespace(0);\n };\n\n parserInput.end = () => {\n let message;\n const isFinished = parserInput.i >= input.length;\n\n if (parserInput.i < furthest) {\n message = furthestPossibleErrorMessage;\n parserInput.i = furthest;\n }\n return {\n isFinished,\n furthest: parserInput.i,\n furthestPossibleErrorMessage: message,\n furthestReachedEnd: parserInput.i >= input.length - 1,\n furthestChar: input[parserInput.i]\n };\n };\n\n return parserInput;\n};\n","// Split the input into chunks.\nexport default function (input, fail) {\n const len = input.length;\n let level = 0;\n let parenLevel = 0;\n let lastOpening;\n let lastOpeningParen;\n let lastMultiComment;\n let lastMultiCommentEndBrace;\n const chunks = [];\n let emitFrom = 0;\n let chunkerCurrentIndex;\n let currentChunkStartIndex;\n let cc;\n let cc2;\n let matched;\n\n function emitChunk(force) {\n const len = chunkerCurrentIndex - emitFrom;\n if (((len < 512) && !force) || !len) {\n return;\n }\n chunks.push(input.slice(emitFrom, chunkerCurrentIndex + 1));\n emitFrom = chunkerCurrentIndex + 1;\n }\n\n for (chunkerCurrentIndex = 0; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc = input.charCodeAt(chunkerCurrentIndex);\n if (((cc >= 97) && (cc <= 122)) || (cc < 34)) {\n // a-z or whitespace\n continue;\n }\n\n switch (cc) {\n case 40: // (\n parenLevel++;\n lastOpeningParen = chunkerCurrentIndex;\n continue;\n case 41: // )\n if (--parenLevel < 0) {\n return fail('missing opening `(`', chunkerCurrentIndex);\n }\n continue;\n case 59: // ;\n if (!parenLevel) { emitChunk(); }\n continue;\n case 123: // {\n level++;\n lastOpening = chunkerCurrentIndex;\n continue;\n case 125: // }\n if (--level < 0) {\n return fail('missing opening `{`', chunkerCurrentIndex);\n }\n if (!level && !parenLevel) { emitChunk(); }\n continue;\n case 92: // \\\n if (chunkerCurrentIndex < len - 1) { chunkerCurrentIndex++; continue; }\n return fail('unescaped `\\\\`', chunkerCurrentIndex);\n case 34:\n case 39:\n case 96: // \", ' and `\n matched = 0;\n currentChunkStartIndex = chunkerCurrentIndex;\n for (chunkerCurrentIndex = chunkerCurrentIndex + 1; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if (cc2 > 96) { continue; }\n if (cc2 == cc) { matched = 1; break; }\n if (cc2 == 92) { // \\\n if (chunkerCurrentIndex == len - 1) {\n return fail('unescaped `\\\\`', chunkerCurrentIndex);\n }\n chunkerCurrentIndex++;\n }\n }\n if (matched) { continue; }\n return fail(`unmatched \\`${String.fromCharCode(cc)}\\``, currentChunkStartIndex);\n case 47: // /, check for comment\n if (parenLevel || (chunkerCurrentIndex == len - 1)) { continue; }\n cc2 = input.charCodeAt(chunkerCurrentIndex + 1);\n if (cc2 == 47) {\n // //, find lnfeed\n for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if ((cc2 <= 13) && ((cc2 == 10) || (cc2 == 13))) { break; }\n }\n } else if (cc2 == 42) {\n // /*, find */\n lastMultiComment = currentChunkStartIndex = chunkerCurrentIndex;\n for (chunkerCurrentIndex = chunkerCurrentIndex + 2; chunkerCurrentIndex < len - 1; chunkerCurrentIndex++) {\n cc2 = input.charCodeAt(chunkerCurrentIndex);\n if (cc2 == 125) { lastMultiCommentEndBrace = chunkerCurrentIndex; }\n if (cc2 != 42) { continue; }\n if (input.charCodeAt(chunkerCurrentIndex + 1) == 47) { break; }\n }\n if (chunkerCurrentIndex == len - 1) {\n return fail('missing closing `*/`', currentChunkStartIndex);\n }\n chunkerCurrentIndex++;\n }\n continue;\n case 42: // *, check for unmatched */\n if ((chunkerCurrentIndex < len - 1) && (input.charCodeAt(chunkerCurrentIndex + 1) == 47)) {\n return fail('unmatched `/*`', chunkerCurrentIndex);\n }\n continue;\n }\n }\n\n if (level !== 0) {\n if ((lastMultiComment > lastOpening) && (lastMultiCommentEndBrace > lastMultiComment)) {\n return fail('missing closing `}` or `*/`', lastOpening);\n } else {\n return fail('missing closing `}`', lastOpening);\n }\n } else if (parenLevel !== 0) {\n return fail('missing closing `)`', lastOpeningParen);\n }\n\n emitChunk(true);\n return chunks;\n};\n","import LessError from '../less-error';\nimport tree from '../tree';\nimport visitors from '../visitors';\nimport getParserInput from './parser-input';\nimport * as utils from '../utils';\nimport functionRegistry from '../functions/function-registry';\n\n//\n// less.js - parser\n//\n// A relatively straight-forward predictive parser.\n// There is no tokenization/lexing stage, the input is parsed\n// in one sweep.\n//\n// To make the parser fast enough to run in the browser, several\n// optimization had to be made:\n//\n// - Matching and slicing on a huge input is often cause of slowdowns.\n// The solution is to chunkify the input into smaller strings.\n// The chunks are stored in the `chunks` var,\n// `j` holds the current chunk index, and `currentPos` holds\n// the index of the current chunk in relation to `input`.\n// This gives us an almost 4x speed-up.\n//\n// - In many cases, we don't need to match individual tokens;\n// for example, if a value doesn't hold any variables, operations\n// or dynamic references, the parser can effectively 'skip' it,\n// treating it as a literal.\n// An example would be '1px solid #000' - which evaluates to itself,\n// we don't need to know what the individual components are.\n// The drawback, of course is that you don't get the benefits of\n// syntax-checking on the CSS. This gives us a 50% speed-up in the parser,\n// and a smaller speed-up in the code-gen.\n//\n//\n// Token matching is done with the `$` function, which either takes\n// a terminal string or regexp, or a non-terminal function to call.\n// It also takes care of moving all the indices forwards.\n//\n\nconst Parser = function Parser(context, imports, fileInfo) {\n let parsers;\n const parserInput = getParserInput();\n\n function error(msg, type) {\n throw new LessError(\n {\n index: parserInput.i,\n filename: fileInfo.filename,\n type: type || 'Syntax',\n message: msg\n },\n imports\n );\n }\n\n function expect(arg, msg) {\n // some older browsers return typeof 'function' for RegExp\n const result = (arg instanceof Function) ? arg.call(parsers) : parserInput.$re(arg);\n if (result) {\n return result;\n }\n \n error(msg || (typeof arg === 'string'\n ? `expected '${arg}' got '${parserInput.currentChar()}'`\n : 'unexpected token'));\n }\n\n // Specialization of expect()\n function expectChar(arg, msg) {\n if (parserInput.$char(arg)) {\n return arg;\n }\n error(msg || `expected '${arg}' got '${parserInput.currentChar()}'`);\n }\n\n function getDebugInfo(index) {\n const filename = fileInfo.filename;\n\n return {\n lineNumber: utils.getLocation(index, parserInput.getInput()).line + 1,\n fileName: filename\n };\n }\n\n /**\n * Used after initial parsing to create nodes on the fly\n * \n * @param {String} str - string to parse \n * @param {Array} parseList - array of parsers to run input through e.g. [\"value\", \"important\"]\n * @param {Number} currentIndex - start number to begin indexing\n * @param {Object} fileInfo - fileInfo to attach to created nodes\n */\n function parseNode(str, parseList, currentIndex, fileInfo, callback) {\n let result;\n const returnNodes = [];\n const parser = parserInput;\n\n try {\n parser.start(str, false, function fail(msg, index) {\n callback({\n message: msg,\n index: index + currentIndex\n });\n });\n for (let x = 0, p, i; (p = parseList[x]); x++) {\n i = parser.i;\n result = parsers[p]();\n if (result) {\n try {\n result._index = i + currentIndex;\n result._fileInfo = fileInfo;\n } catch (e) {}\n returnNodes.push(result);\n }\n else {\n returnNodes.push(null);\n }\n }\n\n const endInfo = parser.end();\n if (endInfo.isFinished) {\n callback(null, returnNodes);\n }\n else {\n callback(true, null);\n }\n } catch (e) {\n throw new LessError({\n index: e.index + currentIndex,\n message: e.message\n }, imports, fileInfo.filename);\n }\n }\n\n //\n // The Parser\n //\n return {\n parserInput,\n imports,\n fileInfo,\n parseNode,\n //\n // Parse an input string into an abstract syntax tree,\n // @param str A string containing 'less' markup\n // @param callback call `callback` when done.\n // @param [additionalData] An optional map which can contains vars - a map (key, value) of variables to apply\n //\n parse: function (str, callback, additionalData) {\n let root;\n let error = null;\n let globalVars;\n let modifyVars;\n let ignored;\n let preText = '';\n\n globalVars = (additionalData && additionalData.globalVars) ? `${Parser.serializeVars(additionalData.globalVars)}\\n` : '';\n modifyVars = (additionalData && additionalData.modifyVars) ? `\\n${Parser.serializeVars(additionalData.modifyVars)}` : '';\n\n if (context.pluginManager) {\n const preProcessors = context.pluginManager.getPreProcessors();\n for (let i = 0; i < preProcessors.length; i++) {\n str = preProcessors[i].process(str, { context, imports, fileInfo });\n }\n }\n\n if (globalVars || (additionalData && additionalData.banner)) {\n preText = ((additionalData && additionalData.banner) ? additionalData.banner : '') + globalVars;\n ignored = imports.contentsIgnoredChars;\n ignored[fileInfo.filename] = ignored[fileInfo.filename] || 0;\n ignored[fileInfo.filename] += preText.length;\n }\n\n str = str.replace(/\\r\\n?/g, '\\n');\n // Remove potential UTF Byte Order Mark\n str = preText + str.replace(/^\\uFEFF/, '') + modifyVars;\n imports.contents[fileInfo.filename] = str;\n\n // Start with the primary rule.\n // The whole syntax tree is held under a Ruleset node,\n // with the `root` property set to true, so no `{}` are\n // output. The callback is called when the input is parsed.\n try {\n parserInput.start(str, context.chunkInput, function fail(msg, index) {\n throw new LessError({\n index,\n type: 'Parse',\n message: msg,\n filename: fileInfo.filename\n }, imports);\n });\n\n tree.Node.prototype.parse = this;\n root = new tree.Ruleset(null, this.parsers.primary());\n tree.Node.prototype.rootNode = root;\n root.root = true;\n root.firstRoot = true;\n root.functionRegistry = functionRegistry.inherit();\n \n } catch (e) {\n return callback(new LessError(e, imports, fileInfo.filename));\n }\n\n // If `i` is smaller than the `input.length - 1`,\n // it means the parser wasn't able to parse the whole\n // string, so we've got a parsing error.\n //\n // We try to extract a \\n delimited string,\n // showing the line where the parse error occurred.\n // We split it up into two parts (the part which parsed,\n // and the part which didn't), so we can color them differently.\n const endInfo = parserInput.end();\n if (!endInfo.isFinished) {\n\n let message = endInfo.furthestPossibleErrorMessage;\n\n if (!message) {\n message = 'Unrecognised input';\n if (endInfo.furthestChar === '}') {\n message += '. Possibly missing opening \\'{\\'';\n } else if (endInfo.furthestChar === ')') {\n message += '. Possibly missing opening \\'(\\'';\n } else if (endInfo.furthestReachedEnd) {\n message += '. Possibly missing something';\n }\n }\n\n error = new LessError({\n type: 'Parse',\n message,\n index: endInfo.furthest,\n filename: fileInfo.filename\n }, imports);\n }\n\n const finish = e => {\n e = error || e || imports.error;\n\n if (e) {\n if (!(e instanceof LessError)) {\n e = new LessError(e, imports, fileInfo.filename);\n }\n\n return callback(e);\n }\n else {\n return callback(null, root);\n }\n };\n\n if (context.processImports !== false) {\n new visitors.ImportVisitor(imports, finish)\n .run(root);\n } else {\n return finish();\n }\n },\n\n //\n // Here in, the parsing rules/functions\n //\n // The basic structure of the syntax tree generated is as follows:\n //\n // Ruleset -> Declaration -> Value -> Expression -> Entity\n //\n // Here's some Less code:\n //\n // .class {\n // color: #fff;\n // border: 1px solid #000;\n // width: @w + 4px;\n // > .child {...}\n // }\n //\n // And here's what the parse tree might look like:\n //\n // Ruleset (Selector '.class', [\n // Declaration (\"color\", Value ([Expression [Color #fff]]))\n // Declaration (\"border\", Value ([Expression [Dimension 1px][Keyword \"solid\"][Color #000]]))\n // Declaration (\"width\", Value ([Expression [Operation \" + \" [Variable \"@w\"][Dimension 4px]]]))\n // Ruleset (Selector [Element '>', '.child'], [...])\n // ])\n //\n // In general, most rules will try to parse a token with the `$re()` function, and if the return\n // value is truly, will return a new node, of the relevant type. Sometimes, we need to check\n // first, before parsing, that's when we use `peek()`.\n //\n parsers: parsers = {\n //\n // The `primary` rule is the *entry* and *exit* point of the parser.\n // The rules here can appear at any level of the parse tree.\n //\n // The recursive nature of the grammar is an interplay between the `block`\n // rule, which represents `{ ... }`, the `ruleset` rule, and this `primary` rule,\n // as represented by this simplified grammar:\n //\n // primary → (ruleset | declaration)+\n // ruleset → selector+ block\n // block → '{' primary '}'\n //\n // Only at one point is the primary rule not called from the\n // block rule: at the root level.\n //\n primary: function () {\n const mixin = this.mixin;\n let root = [];\n let node;\n\n while (true) {\n while (true) {\n node = this.comment();\n if (!node) { break; }\n root.push(node);\n }\n // always process comments before deciding if finished\n if (parserInput.finished) {\n break;\n }\n if (parserInput.peek('}')) {\n break;\n }\n\n node = this.extendRule();\n if (node) {\n root = root.concat(node);\n continue;\n }\n\n node = mixin.definition() || this.declaration() || mixin.call(false, false) || \n this.ruleset() || this.variableCall() || this.entities.call() || this.atrule();\n if (node) {\n root.push(node);\n } else {\n let foundSemiColon = false;\n while (parserInput.$char(';')) {\n foundSemiColon = true;\n }\n if (!foundSemiColon) {\n break;\n }\n }\n }\n\n return root;\n },\n\n // comments are collected by the main parsing mechanism and then assigned to nodes\n // where the current structure allows it\n comment: function () {\n if (parserInput.commentStore.length) {\n const comment = parserInput.commentStore.shift();\n return new(tree.Comment)(comment.text, comment.isLineComment, comment.index, fileInfo);\n }\n },\n\n //\n // Entities are tokens which can be found inside an Expression\n //\n entities: {\n mixinLookup: function() {\n return parsers.mixin.call(true, true);\n },\n //\n // A string, which supports escaping \" and '\n //\n // \"milky way\" 'he\\'s the one!'\n //\n quoted: function (forceEscaped) {\n let str;\n const index = parserInput.i;\n let isEscaped = false;\n\n parserInput.save();\n if (parserInput.$char('~')) {\n isEscaped = true;\n } else if (forceEscaped) {\n parserInput.restore();\n return;\n }\n\n str = parserInput.$quoted();\n if (!str) {\n parserInput.restore();\n return;\n }\n parserInput.forget();\n\n return new(tree.Quoted)(str.charAt(0), str.substr(1, str.length - 2), isEscaped, index, fileInfo);\n },\n\n //\n // A catch-all word, such as:\n //\n // black border-collapse\n //\n keyword: function () {\n const k = parserInput.$char('%') || parserInput.$re(/^\\[?(?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+\\]?/);\n if (k) {\n return tree.Color.fromKeyword(k) || new(tree.Keyword)(k);\n }\n },\n\n //\n // A function call\n //\n // rgb(255, 0, 255)\n //\n // The arguments are parsed with the `entities.arguments` parser.\n //\n call: function () {\n let name;\n let args;\n let func;\n const index = parserInput.i;\n\n // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18\n if (parserInput.peek(/^url\\(/i)) {\n return;\n }\n\n parserInput.save();\n\n name = parserInput.$re(/^([\\w-]+|%|~|progid:[\\w\\.]+)\\(/);\n if (!name) {\n parserInput.forget(); \n return;\n }\n\n name = name[1];\n func = this.customFuncCall(name);\n if (func) {\n args = func.parse();\n if (args && func.stop) {\n parserInput.forget();\n return args;\n }\n }\n\n args = this.arguments(args);\n\n if (!parserInput.$char(')')) {\n parserInput.restore('Could not parse call arguments or missing \\')\\'');\n return;\n }\n\n parserInput.forget();\n\n return new(tree.Call)(name, args, index, fileInfo);\n },\n \n //\n // Parsing rules for functions with non-standard args, e.g.:\n //\n // boolean(not(2 > 1))\n //\n // This is a quick prototype, to be modified/improved when\n // more custom-parsed funcs come (e.g. `selector(...)`)\n //\n\n customFuncCall: function (name) {\n /* Ideally the table is to be moved out of here for faster perf.,\n but it's quite tricky since it relies on all these `parsers`\n and `expect` available only here */\n return {\n alpha: f(parsers.ieAlpha, true),\n boolean: f(condition),\n 'if': f(condition)\n }[name.toLowerCase()];\n\n function f(parse, stop) {\n return {\n parse, // parsing function\n stop // when true - stop after parse() and return its result, \n // otherwise continue for plain args\n };\n }\n \n function condition() {\n return [expect(parsers.condition, 'expected condition')];\n }\n },\n\n arguments: function (prevArgs) {\n let argsComma = prevArgs || [];\n const argsSemiColon = [];\n let isSemiColonSeparated;\n let value;\n\n parserInput.save();\n\n while (true) {\n if (prevArgs) {\n prevArgs = false;\n } else {\n value = parsers.detachedRuleset() || this.assignment() || parsers.expression();\n if (!value) {\n break;\n }\n\n if (value.value && value.value.length == 1) {\n value = value.value[0];\n }\n\n argsComma.push(value);\n }\n\n if (parserInput.$char(',')) {\n continue;\n }\n\n if (parserInput.$char(';') || isSemiColonSeparated) {\n isSemiColonSeparated = true;\n value = (argsComma.length < 1) ? argsComma[0]\n : new tree.Value(argsComma);\n argsSemiColon.push(value);\n argsComma = [];\n }\n }\n\n parserInput.forget();\n return isSemiColonSeparated ? argsSemiColon : argsComma;\n },\n literal: function () {\n return this.dimension() ||\n this.color() ||\n this.quoted() ||\n this.unicodeDescriptor();\n },\n\n // Assignments are argument entities for calls.\n // They are present in ie filter properties as shown below.\n //\n // filter: progid:DXImageTransform.Microsoft.Alpha( *opacity=50* )\n //\n\n assignment: function () {\n let key;\n let value;\n parserInput.save();\n key = parserInput.$re(/^\\w+(?=\\s?=)/i);\n if (!key) {\n parserInput.restore();\n return;\n }\n if (!parserInput.$char('=')) {\n parserInput.restore();\n return;\n }\n value = parsers.entity();\n if (value) {\n parserInput.forget();\n return new(tree.Assignment)(key, value);\n } else {\n parserInput.restore();\n }\n },\n\n //\n // Parse url() tokens\n //\n // We use a specific rule for urls, because they don't really behave like\n // standard function calls. The difference is that the argument doesn't have\n // to be enclosed within a string, so it can't be parsed as an Expression.\n //\n url: function () {\n let value;\n const index = parserInput.i;\n\n parserInput.autoCommentAbsorb = false;\n\n if (!parserInput.$str('url(')) {\n parserInput.autoCommentAbsorb = true;\n return;\n }\n\n value = this.quoted() || this.variable() || this.property() ||\n parserInput.$re(/^(?:(?:\\\\[\\(\\)'\"])|[^\\(\\)'\"])+/) || '';\n\n parserInput.autoCommentAbsorb = true;\n\n expectChar(')');\n\n return new(tree.URL)((value.value != null || \n value instanceof tree.Variable || \n value instanceof tree.Property) ?\n value : new(tree.Anonymous)(value, index), index, fileInfo);\n },\n\n //\n // A Variable entity, such as `@fink`, in\n //\n // width: @fink + 2px\n //\n // We use a different parser for variable definitions,\n // see `parsers.variable`.\n //\n variable: function () {\n let ch;\n let name;\n const index = parserInput.i;\n\n parserInput.save();\n if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^@@?[\\w-]+/))) {\n ch = parserInput.currentChar();\n if (ch === '(' || ch === '[' && !parserInput.prevChar().match(/^\\s/)) {\n // this may be a VariableCall lookup\n const result = parsers.variableCall(name);\n if (result) {\n parserInput.forget();\n return result;\n }\n }\n parserInput.forget();\n return new(tree.Variable)(name, index, fileInfo);\n }\n parserInput.restore();\n },\n\n // A variable entity using the protective {} e.g. @{var}\n variableCurly: function () {\n let curly;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '@' && (curly = parserInput.$re(/^@\\{([\\w-]+)\\}/))) {\n return new(tree.Variable)(`@${curly[1]}`, index, fileInfo);\n }\n },\n //\n // A Property accessor, such as `$color`, in\n //\n // background-color: $color\n //\n property: function () {\n let name;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '$' && (name = parserInput.$re(/^\\$[\\w-]+/))) {\n return new(tree.Property)(name, index, fileInfo);\n }\n },\n\n // A property entity useing the protective {} e.g. ${prop}\n propertyCurly: function () {\n let curly;\n const index = parserInput.i;\n\n if (parserInput.currentChar() === '$' && (curly = parserInput.$re(/^\\$\\{([\\w-]+)\\}/))) {\n return new(tree.Property)(`$${curly[1]}`, index, fileInfo);\n }\n },\n //\n // A Hexadecimal color\n //\n // #4F3C2F\n //\n // `rgb` and `hsl` colors are parsed through the `entities.call` parser.\n //\n color: function () {\n let rgb;\n parserInput.save();\n\n if (parserInput.currentChar() === '#' && (rgb = parserInput.$re(/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})([\\w.#\\[])?/))) {\n if (!rgb[2]) {\n parserInput.forget();\n return new(tree.Color)(rgb[1], undefined, rgb[0]);\n } \n }\n parserInput.restore();\n },\n\n colorKeyword: function () {\n parserInput.save();\n const autoCommentAbsorb = parserInput.autoCommentAbsorb;\n parserInput.autoCommentAbsorb = false;\n const k = parserInput.$re(/^[_A-Za-z-][_A-Za-z0-9-]+/);\n parserInput.autoCommentAbsorb = autoCommentAbsorb;\n if (!k) {\n parserInput.forget();\n return;\n }\n parserInput.restore();\n const color = tree.Color.fromKeyword(k);\n if (color) {\n parserInput.$str(k);\n return color;\n }\n },\n\n //\n // A Dimension, that is, a number and a unit\n //\n // 0.5em 95%\n //\n dimension: function () {\n if (parserInput.peekNotNumeric()) {\n return;\n }\n\n const value = parserInput.$re(/^([+-]?\\d*\\.?\\d+)(%|[a-z_]+)?/i);\n if (value) {\n return new(tree.Dimension)(value[1], value[2]);\n }\n },\n\n //\n // A unicode descriptor, as is used in unicode-range\n //\n // U+0?? or U+00A1-00A9\n //\n unicodeDescriptor: function () {\n let ud;\n\n ud = parserInput.$re(/^U\\+[0-9a-fA-F?]+(\\-[0-9a-fA-F?]+)?/);\n if (ud) {\n return new(tree.UnicodeDescriptor)(ud[0]);\n }\n },\n\n //\n // JavaScript code to be evaluated\n //\n // `window.location.href`\n //\n javascript: function () {\n let js;\n const index = parserInput.i;\n\n parserInput.save();\n\n const escape = parserInput.$char('~');\n const jsQuote = parserInput.$char('`');\n\n if (!jsQuote) {\n parserInput.restore();\n return;\n }\n\n js = parserInput.$re(/^[^`]*`/);\n if (js) {\n parserInput.forget();\n return new(tree.JavaScript)(js.substr(0, js.length - 1), Boolean(escape), index, fileInfo);\n }\n parserInput.restore('invalid javascript definition');\n }\n },\n\n //\n // The variable part of a variable definition. Used in the `rule` parser\n //\n // @fink:\n //\n variable: function () {\n let name;\n\n if (parserInput.currentChar() === '@' && (name = parserInput.$re(/^(@[\\w-]+)\\s*:/))) { return name[1]; }\n },\n\n //\n // Call a variable value to retrieve a detached ruleset\n // or a value from a detached ruleset's rules.\n //\n // @fink();\n // @fink;\n // color: @fink[@color];\n //\n variableCall: function (parsedName) {\n let lookups;\n const i = parserInput.i;\n const inValue = !!parsedName;\n let name = parsedName;\n\n parserInput.save();\n\n if (name || (parserInput.currentChar() === '@'\n && (name = parserInput.$re(/^(@[\\w-]+)(\\(\\s*\\))?/)))) {\n\n lookups = this.mixin.ruleLookups();\n\n if (!lookups && ((inValue && parserInput.$str('()') !== '()') || (name[2] !== '()'))) {\n parserInput.restore('Missing \\'[...]\\' lookup in variable call');\n return;\n }\n\n if (!inValue) {\n name = name[1];\n }\n\n const call = new tree.VariableCall(name, i, fileInfo);\n if (!inValue && parsers.end()) {\n parserInput.forget();\n return call;\n }\n else {\n parserInput.forget();\n return new tree.NamespaceValue(call, lookups, i, fileInfo);\n }\n }\n\n parserInput.restore();\n },\n\n //\n // extend syntax - used to extend selectors\n //\n extend: function(isRule) {\n let elements;\n let e;\n const index = parserInput.i;\n let option;\n let extendList;\n let extend;\n\n if (!parserInput.$str(isRule ? '&:extend(' : ':extend(')) {\n return;\n }\n\n do {\n option = null;\n elements = null;\n while (!(option = parserInput.$re(/^(all)(?=\\s*(\\)|,))/))) {\n e = this.element();\n if (!e) {\n break;\n }\n if (elements) {\n elements.push(e);\n } else {\n elements = [ e ];\n }\n }\n\n option = option && option[1];\n if (!elements) {\n error('Missing target selector for :extend().');\n }\n extend = new(tree.Extend)(new(tree.Selector)(elements), option, index, fileInfo);\n if (extendList) {\n extendList.push(extend);\n } else {\n extendList = [ extend ];\n }\n } while (parserInput.$char(','));\n\n expect(/^\\)/);\n\n if (isRule) {\n expect(/^;/);\n }\n\n return extendList;\n },\n\n //\n // extendRule - used in a rule to extend all the parent selectors\n //\n extendRule: function() {\n return this.extend(true);\n },\n\n //\n // Mixins\n //\n mixin: {\n //\n // A Mixin call, with an optional argument list\n //\n // #mixins > .square(#fff);\n // #mixins.square(#fff);\n // .rounded(4px, black);\n // .button;\n //\n // We can lookup / return a value using the lookup syntax:\n //\n // color: #mixin.square(#fff)[@color];\n //\n // The `while` loop is there because mixins can be\n // namespaced, but we only support the child and descendant\n // selector for now.\n //\n call: function (inValue, getLookup) {\n const s = parserInput.currentChar();\n let important = false;\n let lookups;\n const index = parserInput.i;\n let elements;\n let args;\n let hasParens;\n\n if (s !== '.' && s !== '#') { return; }\n\n parserInput.save(); // stop us absorbing part of an invalid selector\n\n elements = this.elements();\n\n if (elements) {\n if (parserInput.$char('(')) {\n args = this.args(true).args;\n expectChar(')');\n hasParens = true;\n }\n\n if (getLookup !== false) {\n lookups = this.ruleLookups();\n }\n if (getLookup === true && !lookups) {\n parserInput.restore();\n return;\n }\n\n if (!lookups && !hasParens) {\n // This isn't a valid mixin call\n parserInput.restore('Unrecognized input. Possibly missing \\'(\\' in mixin call.');\n return;\n }\n\n if (!inValue && parsers.important()) {\n important = true;\n }\n\n if (inValue || parsers.end()) {\n parserInput.forget();\n const mixin = new(tree.mixin.Call)(elements, args, index, fileInfo, !lookups && important);\n if (lookups) {\n return new tree.NamespaceValue(mixin, lookups);\n }\n else {\n return mixin;\n }\n }\n }\n\n parserInput.restore();\n },\n /**\n * Matching elements for mixins\n * (Start with . or # and can have > )\n */\n elements: function() {\n let elements;\n let e;\n let c;\n let elem;\n let elemIndex;\n const re = /^[#.](?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/;\n while (true) {\n elemIndex = parserInput.i;\n e = parserInput.$re(re);\n \n if (!e) {\n break;\n }\n elem = new(tree.Element)(c, e, false, elemIndex, fileInfo);\n if (elements) {\n elements.push(elem);\n } else {\n elements = [ elem ];\n }\n c = parserInput.$char('>');\n }\n return elements;\n },\n args: function (isCall) {\n const entities = parsers.entities;\n const returner = { args:null, variadic: false };\n let expressions = [];\n const argsSemiColon = [];\n const argsComma = [];\n let isSemiColonSeparated;\n let expressionContainsNamed;\n let name;\n let nameLoop;\n let value;\n let arg;\n let expand;\n let hasSep = true;\n\n parserInput.save();\n\n while (true) {\n if (isCall) {\n arg = parsers.detachedRuleset() || parsers.expression();\n } else {\n parserInput.commentStore.length = 0;\n if (parserInput.$str('...')) {\n returner.variadic = true;\n if (parserInput.$char(';') && !isSemiColonSeparated) {\n isSemiColonSeparated = true;\n }\n (isSemiColonSeparated ? argsSemiColon : argsComma)\n .push({ variadic: true });\n break;\n }\n arg = entities.variable() || entities.property() || entities.literal() || entities.keyword() || this.call(true);\n }\n\n if (!arg || !hasSep) {\n break;\n }\n\n nameLoop = null;\n if (arg.throwAwayComments) {\n arg.throwAwayComments();\n }\n value = arg;\n let val = null;\n\n if (isCall) {\n // Variable\n if (arg.value && arg.value.length == 1) {\n val = arg.value[0];\n }\n } else {\n val = arg;\n }\n\n if (val && (val instanceof tree.Variable || val instanceof tree.Property)) {\n if (parserInput.$char(':')) {\n if (expressions.length > 0) {\n if (isSemiColonSeparated) {\n error('Cannot mix ; and , as delimiter types');\n }\n expressionContainsNamed = true;\n }\n\n value = parsers.detachedRuleset() || parsers.expression();\n\n if (!value) {\n if (isCall) {\n error('could not understand value for named argument');\n } else {\n parserInput.restore();\n returner.args = [];\n return returner;\n }\n }\n nameLoop = (name = val.name);\n } else if (parserInput.$str('...')) {\n if (!isCall) {\n returner.variadic = true;\n if (parserInput.$char(';') && !isSemiColonSeparated) {\n isSemiColonSeparated = true;\n }\n (isSemiColonSeparated ? argsSemiColon : argsComma)\n .push({ name: arg.name, variadic: true });\n break;\n } else {\n expand = true;\n }\n } else if (!isCall) {\n name = nameLoop = val.name;\n value = null;\n }\n }\n\n if (value) {\n expressions.push(value);\n }\n\n argsComma.push({ name:nameLoop, value, expand });\n\n if (parserInput.$char(',')) {\n hasSep = true;\n continue;\n }\n hasSep = parserInput.$char(';') === ';';\n\n if (hasSep || isSemiColonSeparated) {\n\n if (expressionContainsNamed) {\n error('Cannot mix ; and , as delimiter types');\n }\n\n isSemiColonSeparated = true;\n\n if (expressions.length > 1) {\n value = new(tree.Value)(expressions);\n }\n argsSemiColon.push({ name, value, expand });\n\n name = null;\n expressions = [];\n expressionContainsNamed = false;\n }\n }\n\n parserInput.forget();\n returner.args = isSemiColonSeparated ? argsSemiColon : argsComma;\n return returner;\n },\n //\n // A Mixin definition, with a list of parameters\n //\n // .rounded (@radius: 2px, @color) {\n // ...\n // }\n //\n // Until we have a finer grained state-machine, we have to\n // do a look-ahead, to make sure we don't have a mixin call.\n // See the `rule` function for more information.\n //\n // We start by matching `.rounded (`, and then proceed on to\n // the argument list, which has optional default values.\n // We store the parameters in `params`, with a `value` key,\n // if there is a value, such as in the case of `@radius`.\n //\n // Once we've got our params list, and a closing `)`, we parse\n // the `{...}` block.\n //\n definition: function () {\n let name;\n let params = [];\n let match;\n let ruleset;\n let cond;\n let variadic = false;\n if ((parserInput.currentChar() !== '.' && parserInput.currentChar() !== '#') ||\n parserInput.peek(/^[^{]*\\}/)) {\n return;\n }\n\n parserInput.save();\n\n match = parserInput.$re(/^([#.](?:[\\w-]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+)\\s*\\(/);\n if (match) {\n name = match[1];\n\n const argInfo = this.args(false);\n params = argInfo.args;\n variadic = argInfo.variadic;\n\n // .mixincall(\"@{a}\");\n // looks a bit like a mixin definition..\n // also\n // .mixincall(@a: {rule: set;});\n // so we have to be nice and restore\n if (!parserInput.$char(')')) {\n parserInput.restore('Missing closing \\')\\'');\n return;\n }\n\n parserInput.commentStore.length = 0;\n\n if (parserInput.$str('when')) { // Guard\n cond = expect(parsers.conditions, 'expected condition');\n }\n\n ruleset = parsers.block();\n\n if (ruleset) {\n parserInput.forget();\n return new(tree.mixin.Definition)(name, params, ruleset, cond, variadic);\n } else {\n parserInput.restore();\n }\n } else {\n parserInput.restore();\n }\n },\n \n ruleLookups: function() {\n let rule;\n let args;\n const lookups = [];\n\n if (parserInput.currentChar() !== '[') { \n return;\n }\n\n while (true) {\n parserInput.save();\n args = null;\n rule = this.lookupValue();\n if (!rule && rule !== '') {\n parserInput.restore();\n break;\n }\n lookups.push(rule);\n parserInput.forget();\n }\n if (lookups.length > 0) {\n return lookups;\n }\n },\n \n lookupValue: function() {\n parserInput.save();\n \n if (!parserInput.$char('[')) { \n parserInput.restore();\n return;\n }\n \n const name = parserInput.$re(/^(?:[@$]{0,2})[_a-zA-Z0-9-]*/);\n \n if (!parserInput.$char(']')) {\n parserInput.restore();\n return;\n } \n\n if (name || name === '') {\n parserInput.forget();\n return name;\n }\n \n parserInput.restore();\n }\n },\n //\n // Entities are the smallest recognized token,\n // and can be found inside a rule's value.\n //\n entity: function () {\n const entities = this.entities;\n\n return this.comment() || entities.literal() || entities.variable() || entities.url() ||\n entities.property() || entities.call() || entities.keyword() || this.mixin.call(true) ||\n entities.javascript();\n },\n\n //\n // A Declaration terminator. Note that we use `peek()` to check for '}',\n // because the `block` rule will be expecting it, but we still need to make sure\n // it's there, if ';' was omitted.\n //\n end: function () {\n return parserInput.$char(';') || parserInput.peek('}');\n },\n\n //\n // IE's alpha function\n //\n // alpha(opacity=88)\n //\n ieAlpha: function () {\n let value;\n\n // http://jsperf.com/case-insensitive-regex-vs-strtolower-then-regex/18\n if (!parserInput.$re(/^opacity=/i)) { return; }\n value = parserInput.$re(/^\\d+/);\n if (!value) {\n value = expect(parsers.entities.variable, 'Could not parse alpha');\n value = `@{${value.name.slice(1)}}`;\n }\n expectChar(')');\n return new tree.Quoted('', `alpha(opacity=${value})`);\n },\n\n //\n // A Selector Element\n //\n // div\n // + h1\n // #socks\n // input[type=\"text\"]\n //\n // Elements are the building blocks for Selectors,\n // they are made out of a `Combinator` (see combinator rule),\n // and an element name, such as a tag a class, or `*`.\n //\n element: function () {\n let e;\n let c;\n let v;\n const index = parserInput.i;\n\n c = this.combinator();\n\n e = parserInput.$re(/^(?:\\d+\\.\\d+|\\d+)%/) ||\n parserInput.$re(/^(?:[.#]?|:*)(?:[\\w-]|[^\\x00-\\x9f]|\\\\(?:[A-Fa-f0-9]{1,6} ?|[^A-Fa-f0-9]))+/) ||\n parserInput.$char('*') || parserInput.$char('&') || this.attribute() ||\n parserInput.$re(/^\\([^&()@]+\\)/) || parserInput.$re(/^[\\.#:](?=@)/) ||\n this.entities.variableCurly();\n\n if (!e) {\n parserInput.save();\n if (parserInput.$char('(')) {\n if ((v = this.selector(false)) && parserInput.$char(')')) {\n e = new(tree.Paren)(v);\n parserInput.forget();\n } else {\n parserInput.restore('Missing closing \\')\\'');\n }\n } else {\n parserInput.forget();\n }\n }\n\n if (e) { return new(tree.Element)(c, e, e instanceof tree.Variable, index, fileInfo); }\n },\n\n //\n // Combinators combine elements together, in a Selector.\n //\n // Because our parser isn't white-space sensitive, special care\n // has to be taken, when parsing the descendant combinator, ` `,\n // as it's an empty space. We have to check the previous character\n // in the input, to see if it's a ` ` character. More info on how\n // we deal with this in *combinator.js*.\n //\n combinator: function () {\n let c = parserInput.currentChar();\n\n if (c === '/') {\n parserInput.save();\n const slashedCombinator = parserInput.$re(/^\\/[a-z]+\\//i);\n if (slashedCombinator) {\n parserInput.forget();\n return new(tree.Combinator)(slashedCombinator);\n }\n parserInput.restore();\n }\n\n if (c === '>' || c === '+' || c === '~' || c === '|' || c === '^') {\n parserInput.i++;\n if (c === '^' && parserInput.currentChar() === '^') {\n c = '^^';\n parserInput.i++;\n }\n while (parserInput.isWhitespace()) { parserInput.i++; }\n return new(tree.Combinator)(c);\n } else if (parserInput.isWhitespace(-1)) {\n return new(tree.Combinator)(' ');\n } else {\n return new(tree.Combinator)(null);\n }\n },\n //\n // A CSS Selector\n // with less extensions e.g. the ability to extend and guard\n //\n // .class > div + h1\n // li a:hover\n //\n // Selectors are made out of one or more Elements, see above.\n //\n selector: function (isLess) {\n const index = parserInput.i;\n let elements;\n let extendList;\n let c;\n let e;\n let allExtends;\n let when;\n let condition;\n isLess = isLess !== false;\n while ((isLess && (extendList = this.extend())) || (isLess && (when = parserInput.$str('when'))) || (e = this.element())) {\n if (when) {\n condition = expect(this.conditions, 'expected condition');\n } else if (condition) {\n error('CSS guard can only be used at the end of selector');\n } else if (extendList) {\n if (allExtends) {\n allExtends = allExtends.concat(extendList);\n } else {\n allExtends = extendList;\n }\n } else {\n if (allExtends) { error('Extend can only be used at the end of selector'); }\n c = parserInput.currentChar();\n if (elements) {\n elements.push(e);\n } else {\n elements = [ e ];\n }\n e = null;\n }\n if (c === '{' || c === '}' || c === ';' || c === ',' || c === ')') {\n break;\n }\n }\n\n if (elements) { return new(tree.Selector)(elements, allExtends, condition, index, fileInfo); }\n if (allExtends) { error('Extend must be used to extend a selector, it cannot be used on its own'); }\n },\n selectors: function () {\n let s;\n let selectors;\n while (true) {\n s = this.selector();\n if (!s) {\n break;\n }\n if (selectors) {\n selectors.push(s);\n } else {\n selectors = [ s ];\n }\n parserInput.commentStore.length = 0;\n if (s.condition && selectors.length > 1) {\n error(\"Guards are only currently allowed on a single selector.\");\n }\n if (!parserInput.$char(',')) { break; }\n if (s.condition) {\n error(\"Guards are only currently allowed on a single selector.\");\n }\n parserInput.commentStore.length = 0;\n }\n return selectors;\n },\n attribute: function () {\n if (!parserInput.$char('[')) { return; }\n\n const entities = this.entities;\n let key;\n let val;\n let op;\n\n if (!(key = entities.variableCurly())) {\n key = expect(/^(?:[_A-Za-z0-9-\\*]*\\|)?(?:[_A-Za-z0-9-]|\\\\.)+/);\n }\n\n op = parserInput.$re(/^[|~*$^]?=/);\n if (op) {\n val = entities.quoted() || parserInput.$re(/^[0-9]+%/) || parserInput.$re(/^[\\w-]+/) || entities.variableCurly();\n }\n\n expectChar(']');\n\n return new(tree.Attribute)(key, op, val);\n },\n\n //\n // The `block` rule is used by `ruleset` and `mixin.definition`.\n // It's a wrapper around the `primary` rule, with added `{}`.\n //\n block: function () {\n let content;\n if (parserInput.$char('{') && (content = this.primary()) && parserInput.$char('}')) {\n return content;\n }\n },\n\n blockRuleset: function() {\n let block = this.block();\n\n if (block) {\n block = new tree.Ruleset(null, block);\n }\n return block;\n },\n\n detachedRuleset: function() {\n let argInfo;\n let params;\n let variadic;\n\n parserInput.save();\n if (parserInput.$re(/^[.#]\\(/)) {\n /**\n * DR args currently only implemented for each() function, and not \n * yet settable as `@dr: #(@arg) {}`\n * This should be done when DRs are merged with mixins.\n * See: https://github.com/less/less-meta/issues/16\n */\n argInfo = this.mixin.args(false);\n params = argInfo.args;\n variadic = argInfo.variadic;\n if (!parserInput.$char(')')) {\n parserInput.restore();\n return;\n }\n }\n const blockRuleset = this.blockRuleset();\n if (blockRuleset) {\n parserInput.forget();\n if (params) {\n return new tree.mixin.Definition(null, params, blockRuleset, null, variadic);\n }\n return new tree.DetachedRuleset(blockRuleset);\n }\n parserInput.restore();\n },\n\n //\n // div, .class, body > p {...}\n //\n ruleset: function () {\n let selectors;\n let rules;\n let debugInfo;\n\n parserInput.save();\n\n if (context.dumpLineNumbers) {\n debugInfo = getDebugInfo(parserInput.i);\n }\n\n selectors = this.selectors();\n\n if (selectors && (rules = this.block())) {\n parserInput.forget();\n const ruleset = new(tree.Ruleset)(selectors, rules, context.strictImports);\n if (context.dumpLineNumbers) {\n ruleset.debugInfo = debugInfo;\n }\n return ruleset;\n } else {\n parserInput.restore();\n }\n },\n declaration: function () {\n let name;\n let value;\n const index = parserInput.i;\n let hasDR;\n const c = parserInput.currentChar();\n let important;\n let merge;\n let isVariable;\n\n if (c === '.' || c === '#' || c === '&' || c === ':') { return; }\n\n parserInput.save();\n\n name = this.variable() || this.ruleProperty();\n if (name) {\n isVariable = typeof name === 'string';\n\n if (isVariable) {\n value = this.detachedRuleset();\n if (value) {\n hasDR = true;\n }\n }\n\n parserInput.commentStore.length = 0;\n if (!value) {\n // a name returned by this.ruleProperty() is always an array of the form:\n // [string-1, ..., string-n, \"\"] or [string-1, ..., string-n, \"+\"]\n // where each item is a tree.Keyword or tree.Variable\n merge = !isVariable && name.length > 1 && name.pop().value;\n\n // Custom property values get permissive parsing\n if (name[0].value && name[0].value.slice(0, 2) === '--') {\n value = this.permissiveValue();\n }\n // Try to store values as anonymous\n // If we need the value later we'll re-parse it in ruleset.parseValue\n else {\n value = this.anonymousValue();\n }\n if (value) {\n parserInput.forget();\n // anonymous values absorb the end ';' which is required for them to work\n return new(tree.Declaration)(name, value, false, merge, index, fileInfo);\n }\n\n if (!value) {\n value = this.value();\n }\n\n if (value) {\n important = this.important();\n } else if (isVariable) {\n // As a last resort, try permissiveValue\n value = this.permissiveValue();\n }\n }\n\n if (value && (this.end() || hasDR)) {\n parserInput.forget();\n return new(tree.Declaration)(name, value, important, merge, index, fileInfo);\n }\n else {\n parserInput.restore();\n }\n } else {\n parserInput.restore();\n }\n },\n anonymousValue: function () {\n const index = parserInput.i;\n const match = parserInput.$re(/^([^.#@\\$+\\/'\"*`(;{}-]*);/);\n if (match) {\n return new(tree.Anonymous)(match[1], index);\n }\n },\n /**\n * Used for custom properties, at-rules, and variables (as fallback)\n * Parses almost anything inside of {} [] () \"\" blocks\n * until it reaches outer-most tokens.\n * \n * First, it will try to parse comments and entities to reach\n * the end. This is mostly like the Expression parser except no\n * math is allowed.\n */\n permissiveValue: function (untilTokens) {\n let i;\n let e;\n let done;\n let value;\n const tok = untilTokens || ';';\n const index = parserInput.i;\n const result = [];\n\n function testCurrentChar() {\n const char = parserInput.currentChar();\n if (typeof tok === 'string') {\n return char === tok;\n } else {\n return tok.test(char);\n }\n }\n if (testCurrentChar()) {\n return;\n }\n value = [];\n do {\n e = this.comment();\n if (e) {\n value.push(e);\n continue;\n }\n e = this.entity();\n if (e) {\n value.push(e);\n }\n } while (e);\n\n done = testCurrentChar();\n\n if (value.length > 0) {\n value = new(tree.Expression)(value);\n if (done) {\n return value;\n }\n else {\n result.push(value);\n }\n // Preserve space before $parseUntil as it will not\n if (parserInput.prevChar() === ' ') {\n result.push(new tree.Anonymous(' ', index));\n }\n }\n parserInput.save();\n\n value = parserInput.$parseUntil(tok);\n\n if (value) {\n if (typeof value === 'string') {\n error(`Expected '${value}'`, 'Parse');\n }\n if (value.length === 1 && value[0] === ' ') {\n parserInput.forget();\n return new tree.Anonymous('', index);\n }\n let item;\n for (i = 0; i < value.length; i++) {\n item = value[i];\n if (Array.isArray(item)) {\n // Treat actual quotes as normal quoted values\n result.push(new tree.Quoted(item[0], item[1], true, index, fileInfo));\n }\n else {\n if (i === value.length - 1) {\n item = item.trim();\n }\n // Treat like quoted values, but replace vars like unquoted expressions\n const quote = new tree.Quoted('\\'', item, true, index, fileInfo);\n quote.variableRegex = /@([\\w-]+)/g;\n quote.propRegex = /\\$([\\w-]+)/g;\n result.push(quote);\n }\n }\n parserInput.forget();\n return new tree.Expression(result, true);\n }\n parserInput.restore();\n },\n\n //\n // An @import atrule\n //\n // @import \"lib\";\n //\n // Depending on our environment, importing is done differently:\n // In the browser, it's an XHR request, in Node, it would be a\n // file-system operation. The function used for importing is\n // stored in `import`, which we pass to the Import constructor.\n //\n 'import': function () {\n let path;\n let features;\n const index = parserInput.i;\n\n const dir = parserInput.$re(/^@import?\\s+/);\n\n if (dir) {\n const options = (dir ? this.importOptions() : null) || {};\n\n if ((path = this.entities.quoted() || this.entities.url())) {\n features = this.mediaFeatures();\n\n if (!parserInput.$char(';')) {\n parserInput.i = index;\n error('missing semi-colon or unrecognised media features on import');\n }\n features = features && new(tree.Value)(features);\n return new(tree.Import)(path, features, options, index, fileInfo);\n }\n else {\n parserInput.i = index;\n error('malformed import statement');\n }\n }\n },\n\n importOptions: function() {\n let o;\n const options = {};\n let optionName;\n let value;\n\n // list of options, surrounded by parens\n if (!parserInput.$char('(')) { return null; }\n do {\n o = this.importOption();\n if (o) {\n optionName = o;\n value = true;\n switch (optionName) {\n case 'css':\n optionName = 'less';\n value = false;\n break;\n case 'once':\n optionName = 'multiple';\n value = false;\n break;\n }\n options[optionName] = value;\n if (!parserInput.$char(',')) { break; }\n }\n } while (o);\n expectChar(')');\n return options;\n },\n\n importOption: function() {\n const opt = parserInput.$re(/^(less|css|multiple|once|inline|reference|optional)/);\n if (opt) {\n return opt[1];\n }\n },\n\n mediaFeature: function () {\n const entities = this.entities;\n const nodes = [];\n let e;\n let p;\n parserInput.save();\n do {\n e = entities.keyword() || entities.variable() || entities.mixinLookup();\n if (e) {\n nodes.push(e);\n } else if (parserInput.$char('(')) {\n p = this.property();\n e = this.value();\n if (parserInput.$char(')')) {\n if (p && e) {\n nodes.push(new(tree.Paren)(new(tree.Declaration)(p, e, null, null, parserInput.i, fileInfo, true)));\n } else if (e) {\n nodes.push(new(tree.Paren)(e));\n } else {\n error('badly formed media feature definition');\n }\n } else {\n error('Missing closing \\')\\'', 'Parse');\n }\n }\n } while (e);\n\n parserInput.forget();\n if (nodes.length > 0) {\n return new(tree.Expression)(nodes);\n }\n },\n\n mediaFeatures: function () {\n const entities = this.entities;\n const features = [];\n let e;\n do {\n e = this.mediaFeature();\n if (e) {\n features.push(e);\n if (!parserInput.$char(',')) { break; }\n } else {\n e = entities.variable() || entities.mixinLookup();\n if (e) {\n features.push(e);\n if (!parserInput.$char(',')) { break; }\n }\n }\n } while (e);\n\n return features.length > 0 ? features : null;\n },\n\n media: function () {\n let features;\n let rules;\n let media;\n let debugInfo;\n const index = parserInput.i;\n\n if (context.dumpLineNumbers) {\n debugInfo = getDebugInfo(index);\n }\n\n parserInput.save();\n\n if (parserInput.$str('@media')) {\n features = this.mediaFeatures();\n\n rules = this.block();\n\n if (!rules) {\n error('media definitions require block statements after any features');\n }\n\n parserInput.forget();\n\n media = new(tree.Media)(rules, features, index, fileInfo);\n if (context.dumpLineNumbers) {\n media.debugInfo = debugInfo;\n }\n\n return media;\n }\n\n parserInput.restore();\n },\n\n //\n\n // A @plugin directive, used to import plugins dynamically.\n //\n // @plugin (args) \"lib\";\n //\n plugin: function () {\n let path;\n let args;\n let options;\n const index = parserInput.i;\n const dir = parserInput.$re(/^@plugin?\\s+/);\n\n if (dir) {\n args = this.pluginArgs();\n\n if (args) {\n options = {\n pluginArgs: args,\n isPlugin: true\n };\n }\n else {\n options = { isPlugin: true };\n }\n\n if ((path = this.entities.quoted() || this.entities.url())) {\n\n if (!parserInput.$char(';')) {\n parserInput.i = index;\n error('missing semi-colon on @plugin');\n }\n return new(tree.Import)(path, null, options, index, fileInfo);\n }\n else {\n parserInput.i = index;\n error('malformed @plugin statement');\n }\n }\n },\n\n pluginArgs: function() {\n // list of options, surrounded by parens\n parserInput.save();\n if (!parserInput.$char('(')) {\n parserInput.restore();\n return null;\n }\n const args = parserInput.$re(/^\\s*([^\\);]+)\\)\\s*/);\n if (args[1]) {\n parserInput.forget();\n return args[1].trim();\n }\n else { \n parserInput.restore();\n return null;\n }\n },\n\n //\n // A CSS AtRule\n //\n // @charset \"utf-8\";\n //\n atrule: function () {\n const index = parserInput.i;\n let name;\n let value;\n let rules;\n let nonVendorSpecificName;\n let hasIdentifier;\n let hasExpression;\n let hasUnknown;\n let hasBlock = true;\n let isRooted = true;\n\n if (parserInput.currentChar() !== '@') { return; }\n\n value = this['import']() || this.plugin() || this.media();\n if (value) {\n return value;\n }\n\n parserInput.save();\n\n name = parserInput.$re(/^@[a-z-]+/);\n\n if (!name) { return; }\n\n nonVendorSpecificName = name;\n if (name.charAt(1) == '-' && name.indexOf('-', 2) > 0) {\n nonVendorSpecificName = `@${name.slice(name.indexOf('-', 2) + 1)}`;\n }\n\n switch (nonVendorSpecificName) {\n case '@charset':\n hasIdentifier = true;\n hasBlock = false;\n break;\n case '@namespace':\n hasExpression = true;\n hasBlock = false;\n break;\n case '@keyframes':\n case '@counter-style':\n hasIdentifier = true;\n break;\n case '@document':\n case '@supports':\n hasUnknown = true;\n isRooted = false;\n break;\n default:\n hasUnknown = true;\n break;\n }\n\n parserInput.commentStore.length = 0;\n\n if (hasIdentifier) {\n value = this.entity();\n if (!value) {\n error(`expected ${name} identifier`);\n }\n } else if (hasExpression) {\n value = this.expression();\n if (!value) {\n error(`expected ${name} expression`);\n }\n } else if (hasUnknown) {\n value = this.permissiveValue(/^[{;]/);\n hasBlock = (parserInput.currentChar() === '{');\n if (!value) {\n if (!hasBlock && parserInput.currentChar() !== ';') {\n error(`${name} rule is missing block or ending semi-colon`);\n }\n }\n else if (!value.value) {\n value = null;\n }\n }\n\n if (hasBlock) {\n rules = this.blockRuleset();\n }\n\n if (rules || (!hasBlock && value && parserInput.$char(';'))) {\n parserInput.forget();\n return new(tree.AtRule)(name, value, rules, index, fileInfo,\n context.dumpLineNumbers ? getDebugInfo(index) : null,\n isRooted\n );\n }\n\n parserInput.restore('at-rule options not recognised');\n },\n\n //\n // A Value is a comma-delimited list of Expressions\n //\n // font-family: Baskerville, Georgia, serif;\n //\n // In a Rule, a Value represents everything after the `:`,\n // and before the `;`.\n //\n value: function () {\n let e;\n const expressions = [];\n const index = parserInput.i;\n\n do {\n e = this.expression();\n if (e) {\n expressions.push(e);\n if (!parserInput.$char(',')) { break; }\n }\n } while (e);\n\n if (expressions.length > 0) {\n return new(tree.Value)(expressions, index);\n }\n },\n important: function () {\n if (parserInput.currentChar() === '!') {\n return parserInput.$re(/^! *important/);\n }\n },\n sub: function () {\n let a;\n let e;\n\n parserInput.save();\n if (parserInput.$char('(')) {\n a = this.addition();\n if (a && parserInput.$char(')')) {\n parserInput.forget();\n e = new(tree.Expression)([a]);\n e.parens = true;\n return e;\n }\n parserInput.restore('Expected \\')\\'');\n return;\n }\n parserInput.restore();\n },\n multiplication: function () {\n let m;\n let a;\n let op;\n let operation;\n let isSpaced;\n m = this.operand();\n if (m) {\n isSpaced = parserInput.isWhitespace(-1);\n while (true) {\n if (parserInput.peek(/^\\/[*\\/]/)) {\n break;\n }\n\n parserInput.save();\n\n op = parserInput.$char('/') || parserInput.$char('*') || parserInput.$str('./');\n\n if (!op) { parserInput.forget(); break; }\n\n a = this.operand();\n\n if (!a) { parserInput.restore(); break; }\n parserInput.forget();\n\n m.parensInOp = true;\n a.parensInOp = true;\n operation = new(tree.Operation)(op, [operation || m, a], isSpaced);\n isSpaced = parserInput.isWhitespace(-1);\n }\n return operation || m;\n }\n },\n addition: function () {\n let m;\n let a;\n let op;\n let operation;\n let isSpaced;\n m = this.multiplication();\n if (m) {\n isSpaced = parserInput.isWhitespace(-1);\n while (true) {\n op = parserInput.$re(/^[-+]\\s+/) || (!isSpaced && (parserInput.$char('+') || parserInput.$char('-')));\n if (!op) {\n break;\n }\n a = this.multiplication();\n if (!a) {\n break;\n }\n\n m.parensInOp = true;\n a.parensInOp = true;\n operation = new(tree.Operation)(op, [operation || m, a], isSpaced);\n isSpaced = parserInput.isWhitespace(-1);\n }\n return operation || m;\n }\n },\n conditions: function () {\n let a;\n let b;\n const index = parserInput.i;\n let condition;\n\n a = this.condition(true);\n if (a) {\n while (true) {\n if (!parserInput.peek(/^,\\s*(not\\s*)?\\(/) || !parserInput.$char(',')) {\n break;\n }\n b = this.condition(true);\n if (!b) {\n break;\n }\n condition = new(tree.Condition)('or', condition || a, b, index);\n }\n return condition || a;\n }\n },\n condition: function (needsParens) {\n let result;\n let logical;\n let next;\n function or() {\n return parserInput.$str('or');\n }\n\n result = this.conditionAnd(needsParens);\n if (!result) {\n return ;\n }\n logical = or();\n if (logical) {\n next = this.condition(needsParens);\n if (next) {\n result = new(tree.Condition)(logical, result, next);\n } else {\n return ;\n }\n }\n return result;\n },\n conditionAnd: function (needsParens) {\n let result;\n let logical;\n let next;\n const self = this;\n function insideCondition() {\n const cond = self.negatedCondition(needsParens) || self.parenthesisCondition(needsParens);\n if (!cond && !needsParens) {\n return self.atomicCondition(needsParens);\n }\n return cond;\n }\n function and() {\n return parserInput.$str('and');\n }\n\n result = insideCondition();\n if (!result) {\n return ;\n }\n logical = and();\n if (logical) {\n next = this.conditionAnd(needsParens);\n if (next) {\n result = new(tree.Condition)(logical, result, next);\n } else {\n return ;\n }\n }\n return result;\n },\n negatedCondition: function (needsParens) {\n if (parserInput.$str('not')) {\n const result = this.parenthesisCondition(needsParens);\n if (result) {\n result.negate = !result.negate;\n }\n return result;\n }\n },\n parenthesisCondition: function (needsParens) {\n function tryConditionFollowedByParenthesis(me) {\n let body;\n parserInput.save();\n body = me.condition(needsParens);\n if (!body) {\n parserInput.restore();\n return ;\n }\n if (!parserInput.$char(')')) {\n parserInput.restore();\n return ;\n }\n parserInput.forget();\n return body;\n }\n\n let body;\n parserInput.save();\n if (!parserInput.$str('(')) {\n parserInput.restore();\n return ;\n }\n body = tryConditionFollowedByParenthesis(this);\n if (body) {\n parserInput.forget();\n return body;\n }\n\n body = this.atomicCondition(needsParens);\n if (!body) {\n parserInput.restore();\n return ;\n }\n if (!parserInput.$char(')')) {\n parserInput.restore(`expected ')' got '${parserInput.currentChar()}'`);\n return ;\n }\n parserInput.forget();\n return body;\n },\n atomicCondition: function (needsParens) {\n const entities = this.entities;\n const index = parserInput.i;\n let a;\n let b;\n let c;\n let op;\n\n function cond() {\n return this.addition() || entities.keyword() || entities.quoted() || entities.mixinLookup();\n }\n cond = cond.bind(this);\n\n a = cond();\n if (a) {\n if (parserInput.$char('>')) {\n if (parserInput.$char('=')) {\n op = '>=';\n } else {\n op = '>';\n }\n } else\n if (parserInput.$char('<')) {\n if (parserInput.$char('=')) {\n op = '<=';\n } else {\n op = '<';\n }\n } else\n if (parserInput.$char('=')) {\n if (parserInput.$char('>')) {\n op = '=>';\n } else if (parserInput.$char('<')) {\n op = '=<';\n } else {\n op = '=';\n }\n }\n if (op) {\n b = cond();\n if (b) {\n c = new(tree.Condition)(op, a, b, index, false);\n } else {\n error('expected expression');\n }\n } else {\n c = new(tree.Condition)('=', a, new(tree.Keyword)('true'), index, false);\n }\n return c;\n }\n },\n\n //\n // An operand is anything that can be part of an operation,\n // such as a Color, or a Variable\n //\n operand: function () {\n const entities = this.entities;\n let negate;\n\n if (parserInput.peek(/^-[@\\$\\(]/)) {\n negate = parserInput.$char('-');\n }\n\n let o = this.sub() || entities.dimension() ||\n entities.color() || entities.variable() ||\n entities.property() || entities.call() ||\n entities.quoted(true) || entities.colorKeyword() ||\n entities.mixinLookup();\n\n if (negate) {\n o.parensInOp = true;\n o = new(tree.Negative)(o);\n }\n\n return o;\n },\n\n //\n // Expressions either represent mathematical operations,\n // or white-space delimited Entities.\n //\n // 1px solid black\n // @var * 2\n //\n expression: function () {\n const entities = [];\n let e;\n let delim;\n const index = parserInput.i;\n\n do {\n e = this.comment();\n if (e) {\n entities.push(e);\n continue;\n }\n e = this.addition() || this.entity();\n\n if (e instanceof tree.Comment) {\n e = null;\n }\n\n if (e) {\n entities.push(e);\n // operations do not allow keyword \"/\" dimension (e.g. small/20px) so we support that here\n if (!parserInput.peek(/^\\/[\\/*]/)) {\n delim = parserInput.$char('/');\n if (delim) {\n entities.push(new(tree.Anonymous)(delim, index));\n }\n }\n }\n } while (e);\n if (entities.length > 0) {\n return new(tree.Expression)(entities);\n }\n },\n property: function () {\n const name = parserInput.$re(/^(\\*?-?[_a-zA-Z0-9-]+)\\s*:/);\n if (name) {\n return name[1];\n }\n },\n ruleProperty: function () {\n let name = [];\n const index = [];\n let s;\n let k;\n\n parserInput.save();\n\n const simpleProperty = parserInput.$re(/^([_a-zA-Z0-9-]+)\\s*:/);\n if (simpleProperty) {\n name = [new(tree.Keyword)(simpleProperty[1])];\n parserInput.forget();\n return name;\n }\n\n function match(re) {\n const i = parserInput.i;\n const chunk = parserInput.$re(re);\n if (chunk) {\n index.push(i);\n return name.push(chunk[1]);\n }\n }\n\n match(/^(\\*?)/);\n while (true) {\n if (!match(/^((?:[\\w-]+)|(?:[@\\$]\\{[\\w-]+\\}))/)) {\n break;\n }\n }\n\n if ((name.length > 1) && match(/^((?:\\+_|\\+)?)\\s*:/)) {\n parserInput.forget();\n\n // at last, we have the complete match now. move forward,\n // convert name particles to tree objects and return:\n if (name[0] === '') {\n name.shift();\n index.shift();\n }\n for (k = 0; k < name.length; k++) {\n s = name[k];\n name[k] = (s.charAt(0) !== '@' && s.charAt(0) !== '$') ?\n new(tree.Keyword)(s) :\n (s.charAt(0) === '@' ?\n new(tree.Variable)(`@${s.slice(2, -1)}`, index[k], fileInfo) :\n new(tree.Property)(`$${s.slice(2, -1)}`, index[k], fileInfo));\n }\n return name;\n }\n parserInput.restore();\n }\n }\n };\n};\nParser.serializeVars = vars => {\n let s = '';\n\n for (const name in vars) {\n if (Object.hasOwnProperty.call(vars, name)) {\n const value = vars[name];\n s += `${((name[0] === '@') ? '' : '@') + name}: ${value}${(String(value).slice(-1) === ';') ? '' : ';'}`;\n }\n }\n\n return s;\n};\n\nexport default Parser;\n","import Anonymous from '../tree/anonymous';\nimport Keyword from '../tree/keyword';\n\nfunction boolean(condition) {\n return condition ? Keyword.True : Keyword.False;\n}\n\n/**\n * Functions with evalArgs set to false are sent context\n * as the first argument.\n */\nfunction If(context, condition, trueValue, falseValue) {\n return condition.eval(context) ? trueValue.eval(context)\n : (falseValue ? falseValue.eval(context) : new Anonymous);\n}\nIf.evalArgs = false;\n\nfunction isdefined(context, variable) {\n try {\n variable.eval(context);\n return Keyword.True;\n } catch (e) {\n return Keyword.False;\n }\n}\n\nisdefined.evalArgs = false;\n\nexport default { isdefined, boolean, 'if': If };\n","import Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nimport Expression from '../tree/expression';\nimport Operation from '../tree/operation';\nlet colorFunctions;\n\nfunction clamp(val) {\n return Math.min(1, Math.max(0, val));\n}\nfunction hsla(origColor, hsl) {\n const color = colorFunctions.hsla(hsl.h, hsl.s, hsl.l, hsl.a);\n if (color) {\n if (origColor.value && \n /^(rgb|hsl)/.test(origColor.value)) {\n color.value = origColor.value;\n } else {\n color.value = 'rgb';\n }\n return color;\n }\n}\nfunction toHSL(color) {\n if (color.toHSL) {\n return color.toHSL();\n } else {\n throw new Error('Argument cannot be evaluated to a color');\n }\n}\n\nfunction toHSV(color) {\n if (color.toHSV) {\n return color.toHSV();\n } else {\n throw new Error('Argument cannot be evaluated to a color');\n }\n}\n\nfunction number(n) {\n if (n instanceof Dimension) {\n return parseFloat(n.unit.is('%') ? n.value / 100 : n.value);\n } else if (typeof n === 'number') {\n return n;\n } else {\n throw {\n type: 'Argument',\n message: 'color functions take numbers as parameters'\n };\n }\n}\nfunction scaled(n, size) {\n if (n instanceof Dimension && n.unit.is('%')) {\n return parseFloat(n.value * size / 100);\n } else {\n return number(n);\n }\n}\ncolorFunctions = {\n rgb: function (r, g, b) {\n let a = 1\n /**\n * Comma-less syntax\n * e.g. rgb(0 128 255 / 50%)\n */\n if (r instanceof Expression) {\n const val = r.value\n r = val[0]\n g = val[1]\n b = val[2]\n /** \n * @todo - should this be normalized in\n * function caller? Or parsed differently?\n */\n if (b instanceof Operation) {\n const op = b\n b = op.operands[0]\n a = op.operands[1]\n }\n }\n const color = colorFunctions.rgba(r, g, b, a);\n if (color) {\n color.value = 'rgb';\n return color;\n }\n },\n rgba: function (r, g, b, a) {\n try {\n if (r instanceof Color) {\n if (g) {\n a = number(g);\n } else {\n a = r.alpha;\n }\n return new Color(r.rgb, a, 'rgba');\n }\n const rgb = [r, g, b].map(c => scaled(c, 255));\n a = number(a);\n return new Color(rgb, a, 'rgba');\n }\n catch (e) {}\n },\n hsl: function (h, s, l) {\n let a = 1\n if (h instanceof Expression) {\n const val = h.value\n h = val[0]\n s = val[1]\n l = val[2]\n\n if (l instanceof Operation) {\n const op = l\n l = op.operands[0]\n a = op.operands[1]\n }\n }\n const color = colorFunctions.hsla(h, s, l, a);\n if (color) {\n color.value = 'hsl';\n return color;\n }\n },\n hsla: function (h, s, l, a) {\n try {\n if (h instanceof Color) {\n if (s) {\n a = number(s);\n } else {\n a = h.alpha;\n }\n return new Color(h.rgb, a, 'hsla');\n }\n\n let m1;\n let m2;\n\n function hue(h) {\n h = h < 0 ? h + 1 : (h > 1 ? h - 1 : h);\n if (h * 6 < 1) {\n return m1 + (m2 - m1) * h * 6;\n }\n else if (h * 2 < 1) {\n return m2;\n }\n else if (h * 3 < 2) {\n return m1 + (m2 - m1) * (2 / 3 - h) * 6;\n }\n else {\n return m1;\n }\n }\n\n h = (number(h) % 360) / 360;\n s = clamp(number(s));l = clamp(number(l));a = clamp(number(a));\n\n m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n m1 = l * 2 - m2;\n\n const rgb = [\n hue(h + 1 / 3) * 255,\n hue(h) * 255,\n hue(h - 1 / 3) * 255\n ];\n a = number(a);\n return new Color(rgb, a, 'hsla');\n }\n catch (e) {}\n },\n\n hsv: function(h, s, v) {\n return colorFunctions.hsva(h, s, v, 1.0);\n },\n\n hsva: function(h, s, v, a) {\n h = ((number(h) % 360) / 360) * 360;\n s = number(s);v = number(v);a = number(a);\n\n let i;\n let f;\n i = Math.floor((h / 60) % 6);\n f = (h / 60) - i;\n\n const vs = [v,\n v * (1 - s),\n v * (1 - f * s),\n v * (1 - (1 - f) * s)];\n const perm = [[0, 3, 1],\n [2, 0, 1],\n [1, 0, 3],\n [1, 2, 0],\n [3, 1, 0],\n [0, 1, 2]];\n\n return colorFunctions.rgba(vs[perm[i][0]] * 255,\n vs[perm[i][1]] * 255,\n vs[perm[i][2]] * 255,\n a);\n },\n\n hue: function (color) {\n return new Dimension(toHSL(color).h);\n },\n saturation: function (color) {\n return new Dimension(toHSL(color).s * 100, '%');\n },\n lightness: function (color) {\n return new Dimension(toHSL(color).l * 100, '%');\n },\n hsvhue: function(color) {\n return new Dimension(toHSV(color).h);\n },\n hsvsaturation: function (color) {\n return new Dimension(toHSV(color).s * 100, '%');\n },\n hsvvalue: function (color) {\n return new Dimension(toHSV(color).v * 100, '%');\n },\n red: function (color) {\n return new Dimension(color.rgb[0]);\n },\n green: function (color) {\n return new Dimension(color.rgb[1]);\n },\n blue: function (color) {\n return new Dimension(color.rgb[2]);\n },\n alpha: function (color) {\n return new Dimension(toHSL(color).a);\n },\n luma: function (color) {\n return new Dimension(color.luma() * color.alpha * 100, '%');\n },\n luminance: function (color) {\n const luminance =\n (0.2126 * color.rgb[0] / 255) +\n (0.7152 * color.rgb[1] / 255) +\n (0.0722 * color.rgb[2] / 255);\n\n return new Dimension(luminance * color.alpha * 100, '%');\n },\n saturate: function (color, amount, method) {\n // filter: saturate(3.2);\n // should be kept as is, so check for color\n if (!color.rgb) {\n return null;\n }\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.s += hsl.s * amount.value / 100;\n }\n else {\n hsl.s += amount.value / 100;\n }\n hsl.s = clamp(hsl.s);\n return hsla(color, hsl);\n },\n desaturate: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.s -= hsl.s * amount.value / 100;\n }\n else {\n hsl.s -= amount.value / 100;\n }\n hsl.s = clamp(hsl.s);\n return hsla(color, hsl);\n },\n lighten: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.l += hsl.l * amount.value / 100;\n }\n else {\n hsl.l += amount.value / 100;\n }\n hsl.l = clamp(hsl.l);\n return hsla(color, hsl);\n },\n darken: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.l -= hsl.l * amount.value / 100;\n }\n else {\n hsl.l -= amount.value / 100;\n }\n hsl.l = clamp(hsl.l);\n return hsla(color, hsl);\n },\n fadein: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.a += hsl.a * amount.value / 100;\n }\n else {\n hsl.a += amount.value / 100;\n }\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n fadeout: function (color, amount, method) {\n const hsl = toHSL(color);\n\n if (typeof method !== 'undefined' && method.value === 'relative') {\n hsl.a -= hsl.a * amount.value / 100;\n }\n else {\n hsl.a -= amount.value / 100;\n }\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n fade: function (color, amount) {\n const hsl = toHSL(color);\n\n hsl.a = amount.value / 100;\n hsl.a = clamp(hsl.a);\n return hsla(color, hsl);\n },\n spin: function (color, amount) {\n const hsl = toHSL(color);\n const hue = (hsl.h + amount.value) % 360;\n\n hsl.h = hue < 0 ? 360 + hue : hue;\n\n return hsla(color, hsl);\n },\n //\n // Copyright (c) 2006-2009 Hampton Catlin, Natalie Weizenbaum, and Chris Eppstein\n // http://sass-lang.com\n //\n mix: function (color1, color2, weight) {\n if (!weight) {\n weight = new Dimension(50);\n }\n const p = weight.value / 100.0;\n const w = p * 2 - 1;\n const a = toHSL(color1).a - toHSL(color2).a;\n\n const w1 = (((w * a == -1) ? w : (w + a) / (1 + w * a)) + 1) / 2.0;\n const w2 = 1 - w1;\n\n const rgb = [color1.rgb[0] * w1 + color2.rgb[0] * w2,\n color1.rgb[1] * w1 + color2.rgb[1] * w2,\n color1.rgb[2] * w1 + color2.rgb[2] * w2];\n\n const alpha = color1.alpha * p + color2.alpha * (1 - p);\n\n return new Color(rgb, alpha);\n },\n greyscale: function (color) {\n return colorFunctions.desaturate(color, new Dimension(100));\n },\n contrast: function (color, dark, light, threshold) {\n // filter: contrast(3.2);\n // should be kept as is, so check for color\n if (!color.rgb) {\n return null;\n }\n if (typeof light === 'undefined') {\n light = colorFunctions.rgba(255, 255, 255, 1.0);\n }\n if (typeof dark === 'undefined') {\n dark = colorFunctions.rgba(0, 0, 0, 1.0);\n }\n // Figure out which is actually light and dark:\n if (dark.luma() > light.luma()) {\n const t = light;\n light = dark;\n dark = t;\n }\n if (typeof threshold === 'undefined') {\n threshold = 0.43;\n } else {\n threshold = number(threshold);\n }\n if (color.luma() < threshold) {\n return light;\n } else {\n return dark;\n }\n },\n // Changes made in 2.7.0 - Reverted in 3.0.0\n // contrast: function (color, color1, color2, threshold) {\n // // Return which of `color1` and `color2` has the greatest contrast with `color`\n // // according to the standard WCAG contrast ratio calculation.\n // // http://www.w3.org/TR/WCAG20/#contrast-ratiodef\n // // The threshold param is no longer used, in line with SASS.\n // // filter: contrast(3.2);\n // // should be kept as is, so check for color\n // if (!color.rgb) {\n // return null;\n // }\n // if (typeof color1 === 'undefined') {\n // color1 = colorFunctions.rgba(0, 0, 0, 1.0);\n // }\n // if (typeof color2 === 'undefined') {\n // color2 = colorFunctions.rgba(255, 255, 255, 1.0);\n // }\n // var contrast1, contrast2;\n // var luma = color.luma();\n // var luma1 = color1.luma();\n // var luma2 = color2.luma();\n // // Calculate contrast ratios for each color\n // if (luma > luma1) {\n // contrast1 = (luma + 0.05) / (luma1 + 0.05);\n // } else {\n // contrast1 = (luma1 + 0.05) / (luma + 0.05);\n // }\n // if (luma > luma2) {\n // contrast2 = (luma + 0.05) / (luma2 + 0.05);\n // } else {\n // contrast2 = (luma2 + 0.05) / (luma + 0.05);\n // }\n // if (contrast1 > contrast2) {\n // return color1;\n // } else {\n // return color2;\n // }\n // },\n argb: function (color) {\n return new Anonymous(color.toARGB());\n },\n color: function(c) {\n if ((c instanceof Quoted) &&\n (/^#([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3,4})$/i.test(c.value))) {\n const val = c.value.slice(1);\n return new Color(val, undefined, `#${val}`);\n }\n if ((c instanceof Color) || (c = Color.fromKeyword(c.value))) {\n c.value = undefined;\n return c;\n }\n throw {\n type: 'Argument',\n message: 'argument must be a color keyword or 3|4|6|8 digit hex e.g. #FFF'\n };\n },\n tint: function(color, amount) {\n return colorFunctions.mix(colorFunctions.rgb(255, 255, 255), color, amount);\n },\n shade: function(color, amount) {\n return colorFunctions.mix(colorFunctions.rgb(0, 0, 0), color, amount);\n }\n};\n\nexport default colorFunctions;\n","import Color from '../tree/color';\n\n// Color Blending\n// ref: http://www.w3.org/TR/compositing-1\n\nfunction colorBlend(mode, color1, color2) {\n const ab = color1.alpha; // result\n\n let // backdrop\n cb;\n\n const as = color2.alpha;\n\n let // source\n cs;\n\n let ar;\n let cr;\n const r = [];\n\n ar = as + ab * (1 - as);\n for (let i = 0; i < 3; i++) {\n cb = color1.rgb[i] / 255;\n cs = color2.rgb[i] / 255;\n cr = mode(cb, cs);\n if (ar) {\n cr = (as * cs + ab * (cb -\n as * (cb + cs - cr))) / ar;\n }\n r[i] = cr * 255;\n }\n\n return new Color(r, ar);\n}\n\nconst colorBlendModeFunctions = {\n multiply: function(cb, cs) {\n return cb * cs;\n },\n screen: function(cb, cs) {\n return cb + cs - cb * cs;\n },\n overlay: function(cb, cs) {\n cb *= 2;\n return (cb <= 1) ?\n colorBlendModeFunctions.multiply(cb, cs) :\n colorBlendModeFunctions.screen(cb - 1, cs);\n },\n softlight: function(cb, cs) {\n let d = 1;\n let e = cb;\n if (cs > 0.5) {\n e = 1;\n d = (cb > 0.25) ? Math.sqrt(cb)\n : ((16 * cb - 12) * cb + 4) * cb;\n }\n return cb - (1 - 2 * cs) * e * (d - cb);\n },\n hardlight: function(cb, cs) {\n return colorBlendModeFunctions.overlay(cs, cb);\n },\n difference: function(cb, cs) {\n return Math.abs(cb - cs);\n },\n exclusion: function(cb, cs) {\n return cb + cs - 2 * cb * cs;\n },\n\n // non-w3c functions:\n average: function(cb, cs) {\n return (cb + cs) / 2;\n },\n negation: function(cb, cs) {\n return 1 - Math.abs(cb + cs - 1);\n }\n};\n\nfor (const f in colorBlendModeFunctions) {\n if (colorBlendModeFunctions.hasOwnProperty(f)) {\n colorBlend[f] = colorBlend.bind(null, colorBlendModeFunctions[f]);\n }\n}\n\nexport default colorBlend;\n","import Comment from '../tree/comment';\nimport Node from '../tree/node';\nimport Dimension from '../tree/dimension';\nimport Declaration from '../tree/declaration';\nimport Expression from '../tree/expression';\nimport Ruleset from '../tree/ruleset';\nimport Selector from '../tree/selector';\nimport Element from '../tree/element';\nimport Quote from '../tree/quoted';\nimport Value from '../tree/value';\n\nconst getItemsFromNode = node => {\n // handle non-array values as an array of length 1\n // return 'undefined' if index is invalid\n const items = Array.isArray(node.value) ?\n node.value : Array(node);\n\n return items;\n};\n\nexport default {\n _SELF: function(n) {\n return n;\n },\n '~': function(...expr) {\n if (expr.length === 1) {\n return expr[0];\n }\n return new Value(expr);\n },\n extract: function(values, index) {\n // (1-based index)\n index = index.value - 1;\n\n return getItemsFromNode(values)[index];\n },\n length: function(values) {\n return new Dimension(getItemsFromNode(values).length);\n },\n /**\n * Creates a Less list of incremental values.\n * Modeled after Lodash's range function, also exists natively in PHP\n * \n * @param {Dimension} [start=1]\n * @param {Dimension} end - e.g. 10 or 10px - unit is added to output\n * @param {Dimension} [step=1] \n */\n range: function(start, end, step) {\n let from;\n let to;\n let stepValue = 1;\n const list = [];\n if (end) {\n to = end;\n from = start.value;\n if (step) {\n stepValue = step.value;\n }\n }\n else {\n from = 1;\n to = start;\n }\n\n for (let i = from; i <= to.value; i += stepValue) {\n list.push(new Dimension(i, to.unit));\n }\n\n return new Expression(list);\n },\n each: function(list, rs) {\n const rules = [];\n let newRules;\n let iterator;\n\n const tryEval = val => {\n if (val instanceof Node) {\n return val.eval(this.context);\n }\n return val;\n };\n\n if (list.value && !(list instanceof Quote)) {\n if (Array.isArray(list.value)) {\n iterator = list.value.map(tryEval);\n } else {\n iterator = [tryEval(list.value)];\n }\n } else if (list.ruleset) {\n iterator = tryEval(list.ruleset).rules;\n } else if (list.rules) {\n iterator = list.rules.map(tryEval);\n } else if (Array.isArray(list)) {\n iterator = list.map(tryEval);\n } else {\n iterator = [tryEval(list)];\n }\n\n let valueName = '@value';\n let keyName = '@key';\n let indexName = '@index';\n\n if (rs.params) {\n valueName = rs.params[0] && rs.params[0].name;\n keyName = rs.params[1] && rs.params[1].name;\n indexName = rs.params[2] && rs.params[2].name;\n rs = rs.rules;\n } else {\n rs = rs.ruleset;\n }\n\n for (let i = 0; i < iterator.length; i++) {\n let key;\n let value;\n const item = iterator[i];\n if (item instanceof Declaration) {\n key = typeof item.name === 'string' ? item.name : item.name[0].value;\n value = item.value;\n } else {\n key = new Dimension(i + 1);\n value = item;\n }\n\n if (item instanceof Comment) {\n continue;\n }\n\n newRules = rs.rules.slice(0);\n if (valueName) {\n newRules.push(new Declaration(valueName,\n value,\n false, false, this.index, this.currentFileInfo));\n }\n if (indexName) {\n newRules.push(new Declaration(indexName,\n new Dimension(i + 1),\n false, false, this.index, this.currentFileInfo));\n }\n if (keyName) {\n newRules.push(new Declaration(keyName,\n key,\n false, false, this.index, this.currentFileInfo));\n }\n\n rules.push(new Ruleset([ new(Selector)([ new Element(\"\", '&') ]) ],\n newRules,\n rs.strictImports,\n rs.visibilityInfo()\n ));\n }\n\n return new Ruleset([ new(Selector)([ new Element(\"\", '&') ]) ],\n rules,\n rs.strictImports,\n rs.visibilityInfo()\n ).eval(this.context);\n }\n};\n","import Dimension from '../tree/dimension';\n\nconst MathHelper = (fn, unit, n) => {\n if (!(n instanceof Dimension)) {\n throw { type: 'Argument', message: 'argument must be a number' };\n }\n if (unit == null) {\n unit = n.unit;\n } else {\n n = n.unify();\n }\n return new Dimension(fn(parseFloat(n.value)), unit);\n};\n\nexport default MathHelper;","import mathHelper from './math-helper.js';\n\nconst mathFunctions = {\n // name, unit\n ceil: null,\n floor: null,\n sqrt: null,\n abs: null,\n tan: '',\n sin: '',\n cos: '',\n atan: 'rad',\n asin: 'rad',\n acos: 'rad'\n};\n\nfor (const f in mathFunctions) {\n if (mathFunctions.hasOwnProperty(f)) {\n mathFunctions[f] = mathHelper.bind(null, Math[f], mathFunctions[f]);\n }\n}\n\nmathFunctions.round = (n, f) => {\n const fraction = typeof f === 'undefined' ? 0 : f.value;\n return mathHelper(num => num.toFixed(fraction), null, n);\n};\n\nexport default mathFunctions;\n","import Dimension from '../tree/dimension';\nimport Anonymous from '../tree/anonymous';\nimport mathHelper from './math-helper.js';\n\nconst minMax = function (isMin, args) {\n args = Array.prototype.slice.call(args);\n switch (args.length) {\n case 0: throw { type: 'Argument', message: 'one or more arguments required' };\n }\n let i; // key is the unit.toString() for unified Dimension values,\n let j;\n let current;\n let currentUnified;\n let referenceUnified;\n let unit;\n let unitStatic;\n let unitClone;\n\n const // elems only contains original argument values.\n order = [];\n\n const values = {};\n // value is the index into the order array.\n for (i = 0; i < args.length; i++) {\n current = args[i];\n if (!(current instanceof Dimension)) {\n if (Array.isArray(args[i].value)) {\n Array.prototype.push.apply(args, Array.prototype.slice.call(args[i].value));\n }\n continue;\n }\n currentUnified = current.unit.toString() === '' && unitClone !== undefined ? new Dimension(current.value, unitClone).unify() : current.unify();\n unit = currentUnified.unit.toString() === '' && unitStatic !== undefined ? unitStatic : currentUnified.unit.toString();\n unitStatic = unit !== '' && unitStatic === undefined || unit !== '' && order[0].unify().unit.toString() === '' ? unit : unitStatic;\n unitClone = unit !== '' && unitClone === undefined ? current.unit.toString() : unitClone;\n j = values[''] !== undefined && unit !== '' && unit === unitStatic ? values[''] : values[unit];\n if (j === undefined) {\n if (unitStatic !== undefined && unit !== unitStatic) {\n throw { type: 'Argument', message: 'incompatible types' };\n }\n values[unit] = order.length;\n order.push(current);\n continue;\n }\n referenceUnified = order[j].unit.toString() === '' && unitClone !== undefined ? new Dimension(order[j].value, unitClone).unify() : order[j].unify();\n if ( isMin && currentUnified.value < referenceUnified.value ||\n !isMin && currentUnified.value > referenceUnified.value) {\n order[j] = current;\n }\n }\n if (order.length == 1) {\n return order[0];\n }\n args = order.map(function (a) { return a.toCSS(this.context); }).join(this.context.compress ? ',' : ', ');\n return new Anonymous(`${isMin ? 'min' : 'max'}(${args})`);\n};\n\nexport default {\n min: function(...args) {\n try {\n return minMax(true, args);\n } catch (e) {}\n },\n max: function(...args) {\n try {\n return minMax(false, args);\n } catch (e) {}\n },\n convert: function (val, unit) {\n return val.convertTo(unit.value);\n },\n pi: function () {\n return new Dimension(Math.PI);\n },\n mod: function(a, b) {\n return new Dimension(a.value % b.value, a.unit);\n },\n pow: function(x, y) {\n if (typeof x === 'number' && typeof y === 'number') {\n x = new Dimension(x);\n y = new Dimension(y);\n } else if (!(x instanceof Dimension) || !(y instanceof Dimension)) {\n throw { type: 'Argument', message: 'arguments must be numbers' };\n }\n\n return new Dimension(Math.pow(x.value, y.value), x.unit);\n },\n percentage: function (n) {\n const result = mathHelper(num => num * 100, '%', n);\n\n return result;\n }\n};\n","import Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nimport JavaScript from '../tree/javascript';\n\nexport default {\n e: function (str) {\n return new Quoted('\"', str instanceof JavaScript ? str.evaluated : str.value, true);\n },\n escape: function (str) {\n return new Anonymous(\n encodeURI(str.value).replace(/=/g, '%3D').replace(/:/g, '%3A').replace(/#/g, '%23').replace(/;/g, '%3B')\n .replace(/\\(/g, '%28').replace(/\\)/g, '%29'));\n },\n replace: function (string, pattern, replacement, flags) {\n let result = string.value;\n replacement = (replacement.type === 'Quoted') ?\n replacement.value : replacement.toCSS();\n result = result.replace(new RegExp(pattern.value, flags ? flags.value : ''), replacement);\n return new Quoted(string.quote || '', result, string.escaped);\n },\n '%': function (string /* arg, arg, ... */) {\n const args = Array.prototype.slice.call(arguments, 1);\n let result = string.value;\n\n for (let i = 0; i < args.length; i++) {\n /* jshint loopfunc:true */\n result = result.replace(/%[sda]/i, token => {\n const value = ((args[i].type === 'Quoted') &&\n token.match(/s/i)) ? args[i].value : args[i].toCSS();\n return token.match(/[A-Z]$/) ? encodeURIComponent(value) : value;\n });\n }\n result = result.replace(/%%/g, '%');\n return new Quoted(string.quote || '', result, string.escaped);\n }\n};\n","import Keyword from '../tree/keyword';\nimport DetachedRuleset from '../tree/detached-ruleset';\nimport Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Quoted from '../tree/quoted';\nimport Anonymous from '../tree/anonymous';\nimport URL from '../tree/url';\nimport Operation from '../tree/operation';\n\nconst isa = (n, Type) => (n instanceof Type) ? Keyword.True : Keyword.False;\nconst isunit = (n, unit) => {\n if (unit === undefined) {\n throw { type: 'Argument', message: 'missing the required second argument to isunit.' };\n }\n unit = typeof unit.value === 'string' ? unit.value : unit;\n if (typeof unit !== 'string') {\n throw { type: 'Argument', message: 'Second argument to isunit should be a unit or a string.' };\n }\n return (n instanceof Dimension) && n.unit.is(unit) ? Keyword.True : Keyword.False;\n};\n\nexport default {\n isruleset: function (n) {\n return isa(n, DetachedRuleset);\n },\n iscolor: function (n) {\n return isa(n, Color);\n },\n isnumber: function (n) {\n return isa(n, Dimension);\n },\n isstring: function (n) {\n return isa(n, Quoted);\n },\n iskeyword: function (n) {\n return isa(n, Keyword);\n },\n isurl: function (n) {\n return isa(n, URL);\n },\n ispixel: function (n) {\n return isunit(n, 'px');\n },\n ispercentage: function (n) {\n return isunit(n, '%');\n },\n isem: function (n) {\n return isunit(n, 'em');\n },\n isunit,\n unit: function (val, unit) {\n if (!(val instanceof Dimension)) {\n throw { type: 'Argument',\n message: `the first argument to unit must be a number${val instanceof Operation ? '. Have you forgotten parenthesis?' : ''}` };\n }\n if (unit) {\n if (unit instanceof Keyword) {\n unit = unit.value;\n } else {\n unit = unit.toCSS();\n }\n } else {\n unit = '';\n }\n return new Dimension(val.value, unit);\n },\n 'get-unit': function (n) {\n return new Anonymous(n.unit);\n }\n};\n","import functionRegistry from './function-registry';\nimport functionCaller from './function-caller';\n\nimport boolean from './boolean';\nimport defaultFunc from './default';\nimport color from './color';\nimport colorBlending from './color-blending';\nimport dataUri from './data-uri';\nimport list from './list';\nimport math from './math';\nimport number from './number';\nimport string from './string';\nimport svg from './svg';\nimport types from './types';\n\nexport default environment => {\n const functions = { functionRegistry, functionCaller };\n\n // register functions\n functionRegistry.addMultiple(boolean);\n functionRegistry.add('default', defaultFunc.eval.bind(defaultFunc));\n functionRegistry.addMultiple(color);\n functionRegistry.addMultiple(colorBlending);\n functionRegistry.addMultiple(dataUri(environment));\n functionRegistry.addMultiple(list);\n functionRegistry.addMultiple(math);\n functionRegistry.addMultiple(number);\n functionRegistry.addMultiple(string);\n functionRegistry.addMultiple(svg(environment));\n functionRegistry.addMultiple(types);\n\n return functions;\n};\n","import Quoted from '../tree/quoted';\nimport URL from '../tree/url';\nimport * as utils from '../utils';\nimport logger from '../logger';\n\nexport default environment => {\n \n const fallback = (functionThis, node) => new URL(node, functionThis.index, functionThis.currentFileInfo).eval(functionThis.context); \n\n return { 'data-uri': function(mimetypeNode, filePathNode) {\n\n if (!filePathNode) {\n filePathNode = mimetypeNode;\n mimetypeNode = null;\n }\n\n let mimetype = mimetypeNode && mimetypeNode.value;\n let filePath = filePathNode.value;\n const currentFileInfo = this.currentFileInfo;\n const currentDirectory = currentFileInfo.rewriteUrls ?\n currentFileInfo.currentDirectory : currentFileInfo.entryPath;\n\n const fragmentStart = filePath.indexOf('#');\n let fragment = '';\n if (fragmentStart !== -1) {\n fragment = filePath.slice(fragmentStart);\n filePath = filePath.slice(0, fragmentStart);\n }\n const context = utils.clone(this.context);\n context.rawBuffer = true;\n\n const fileManager = environment.getFileManager(filePath, currentDirectory, context, environment, true);\n\n if (!fileManager) {\n return fallback(this, filePathNode);\n }\n\n let useBase64 = false;\n\n // detect the mimetype if not given\n if (!mimetypeNode) {\n\n mimetype = environment.mimeLookup(filePath);\n\n if (mimetype === 'image/svg+xml') {\n useBase64 = false;\n } else {\n // use base 64 unless it's an ASCII or UTF-8 format\n const charset = environment.charsetLookup(mimetype);\n useBase64 = ['US-ASCII', 'UTF-8'].indexOf(charset) < 0;\n }\n if (useBase64) { mimetype += ';base64'; }\n }\n else {\n useBase64 = /;base64$/.test(mimetype);\n }\n\n const fileSync = fileManager.loadFileSync(filePath, currentDirectory, context, environment);\n if (!fileSync.contents) {\n logger.warn(`Skipped data-uri embedding of ${filePath} because file not found`);\n return fallback(this, filePathNode || mimetypeNode);\n }\n let buf = fileSync.contents;\n if (useBase64 && !environment.encodeBase64) {\n return fallback(this, filePathNode);\n }\n\n buf = useBase64 ? environment.encodeBase64(buf) : encodeURIComponent(buf);\n\n const uri = `data:${mimetype},${buf}${fragment}`;\n\n return new URL(new Quoted(`\"${uri}\"`, uri, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo);\n }};\n};\n","import Dimension from '../tree/dimension';\nimport Color from '../tree/color';\nimport Expression from '../tree/expression';\nimport Quoted from '../tree/quoted';\nimport URL from '../tree/url';\n\nexport default environment => {\n return { 'svg-gradient': function(direction) {\n let stops;\n let gradientDirectionSvg;\n let gradientType = 'linear';\n let rectangleDimension = 'x=\"0\" y=\"0\" width=\"1\" height=\"1\"';\n const renderEnv = {compress: false};\n let returner;\n const directionValue = direction.toCSS(renderEnv);\n let i;\n let color;\n let position;\n let positionValue;\n let alpha;\n\n function throwArgumentDescriptor() {\n throw { type: 'Argument',\n message: 'svg-gradient expects direction, start_color [start_position], [color position,]...,' +\n ' end_color [end_position] or direction, color list' };\n }\n\n if (arguments.length == 2) {\n if (arguments[1].value.length < 2) {\n throwArgumentDescriptor();\n }\n stops = arguments[1].value;\n } else if (arguments.length < 3) {\n throwArgumentDescriptor();\n } else {\n stops = Array.prototype.slice.call(arguments, 1);\n }\n\n switch (directionValue) {\n case 'to bottom':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"0%\" y2=\"100%\"';\n break;\n case 'to right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"100%\" y2=\"0%\"';\n break;\n case 'to bottom right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"0%\" x2=\"100%\" y2=\"100%\"';\n break;\n case 'to top right':\n gradientDirectionSvg = 'x1=\"0%\" y1=\"100%\" x2=\"100%\" y2=\"0%\"';\n break;\n case 'ellipse':\n case 'ellipse at center':\n gradientType = 'radial';\n gradientDirectionSvg = 'cx=\"50%\" cy=\"50%\" r=\"75%\"';\n rectangleDimension = 'x=\"-50\" y=\"-50\" width=\"101\" height=\"101\"';\n break;\n default:\n throw { type: 'Argument', message: 'svg-gradient direction must be \\'to bottom\\', \\'to right\\',' +\n ' \\'to bottom right\\', \\'to top right\\' or \\'ellipse at center\\'' };\n }\n returner = `<${gradientType}Gradient id=\"g\" ${gradientDirectionSvg}>`;\n\n for (i = 0; i < stops.length; i += 1) {\n if (stops[i] instanceof Expression) {\n color = stops[i].value[0];\n position = stops[i].value[1];\n } else {\n color = stops[i];\n position = undefined;\n }\n\n if (!(color instanceof Color) || (!((i === 0 || i + 1 === stops.length) && position === undefined) && !(position instanceof Dimension))) {\n throwArgumentDescriptor();\n }\n positionValue = position ? position.toCSS(renderEnv) : i === 0 ? '0%' : '100%';\n alpha = color.alpha;\n returner += ``;\n }\n returner += ``;\n\n returner = encodeURIComponent(returner);\n\n returner = `data:image/svg+xml,${returner}`;\n return new URL(new Quoted(`'${returner}'`, returner, false, this.index, this.currentFileInfo), this.index, this.currentFileInfo);\n }};\n};\n","import contexts from './contexts';\nimport visitor from './visitors';\nimport tree from './tree';\n\nexport default function(root, options) {\n options = options || {};\n let evaldRoot;\n let variables = options.variables;\n const evalEnv = new contexts.Eval(options);\n\n //\n // Allows setting variables with a hash, so:\n //\n // `{ color: new tree.Color('#f01') }` will become:\n //\n // new tree.Declaration('@color',\n // new tree.Value([\n // new tree.Expression([\n // new tree.Color('#f01')\n // ])\n // ])\n // )\n //\n if (typeof variables === 'object' && !Array.isArray(variables)) {\n variables = Object.keys(variables).map(function (k) {\n let value = variables[k];\n\n if (!(value instanceof tree.Value)) {\n if (!(value instanceof tree.Expression)) {\n value = new tree.Expression([value]);\n }\n value = new tree.Value([value]);\n }\n return new tree.Declaration(`@${k}`, value, false, null, 0);\n });\n evalEnv.frames = [new tree.Ruleset(null, variables)];\n }\n\n const visitors = [\n new visitor.JoinSelectorVisitor(),\n new visitor.MarkVisibleSelectorsVisitor(true),\n new visitor.ExtendVisitor(),\n new visitor.ToCSSVisitor({compress: Boolean(options.compress)})\n ];\n\n const preEvalVisitors = [];\n let v;\n let visitorIterator;\n\n /**\n * first() / get() allows visitors to be added while visiting\n * \n * @todo Add scoping for visitors just like functions for @plugin; right now they're global\n */\n if (options.pluginManager) {\n visitorIterator = options.pluginManager.visitor();\n for (var i = 0; i < 2; i++) {\n visitorIterator.first();\n while ((v = visitorIterator.get())) {\n if (v.isPreEvalVisitor) {\n if (i === 0 || preEvalVisitors.indexOf(v) === -1) {\n preEvalVisitors.push(v);\n v.run(root);\n }\n }\n else {\n if (i === 0 || visitors.indexOf(v) === -1) {\n if (v.isPreVisitor) {\n visitors.unshift(v);\n }\n else {\n visitors.push(v);\n }\n }\n }\n }\n }\n }\n\n evaldRoot = root.eval(evalEnv);\n\n for (var i = 0; i < visitors.length; i++) {\n visitors[i].run(evaldRoot);\n }\n\n // Run any remaining visitors added after eval pass\n if (options.pluginManager) {\n visitorIterator.first();\n while ((v = visitorIterator.get())) {\n if (visitors.indexOf(v) === -1 && preEvalVisitors.indexOf(v) === -1) {\n v.run(evaldRoot);\n }\n }\n }\n\n return evaldRoot;\n};\n","/**\n * Plugin Manager\n */\nclass PluginManager {\n constructor(less) {\n this.less = less;\n this.visitors = [];\n this.preProcessors = [];\n this.postProcessors = [];\n this.installedPlugins = [];\n this.fileManagers = [];\n this.iterator = -1;\n this.pluginCache = {};\n this.Loader = new less.PluginLoader(less);\n }\n\n /**\n * Adds all the plugins in the array\n * @param {Array} plugins\n */\n addPlugins(plugins) {\n if (plugins) {\n for (let i = 0; i < plugins.length; i++) {\n this.addPlugin(plugins[i]);\n }\n }\n }\n\n /**\n *\n * @param plugin\n * @param {String} filename\n */\n addPlugin(plugin, filename, functionRegistry) {\n this.installedPlugins.push(plugin);\n if (filename) {\n this.pluginCache[filename] = plugin;\n }\n if (plugin.install) {\n plugin.install(this.less, this, functionRegistry || this.less.functions.functionRegistry);\n }\n }\n\n /**\n *\n * @param filename\n */\n get(filename) {\n return this.pluginCache[filename];\n }\n\n /**\n * Adds a visitor. The visitor object has options on itself to determine\n * when it should run.\n * @param visitor\n */\n addVisitor(visitor) {\n this.visitors.push(visitor);\n }\n\n /**\n * Adds a pre processor object\n * @param {object} preProcessor\n * @param {number} priority - guidelines 1 = before import, 1000 = import, 2000 = after import\n */\n addPreProcessor(preProcessor, priority) {\n let indexToInsertAt;\n for (indexToInsertAt = 0; indexToInsertAt < this.preProcessors.length; indexToInsertAt++) {\n if (this.preProcessors[indexToInsertAt].priority >= priority) {\n break;\n }\n }\n this.preProcessors.splice(indexToInsertAt, 0, {preProcessor, priority});\n }\n\n /**\n * Adds a post processor object\n * @param {object} postProcessor\n * @param {number} priority - guidelines 1 = before compression, 1000 = compression, 2000 = after compression\n */\n addPostProcessor(postProcessor, priority) {\n let indexToInsertAt;\n for (indexToInsertAt = 0; indexToInsertAt < this.postProcessors.length; indexToInsertAt++) {\n if (this.postProcessors[indexToInsertAt].priority >= priority) {\n break;\n }\n }\n this.postProcessors.splice(indexToInsertAt, 0, {postProcessor, priority});\n }\n\n /**\n *\n * @param manager\n */\n addFileManager(manager) {\n this.fileManagers.push(manager);\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getPreProcessors() {\n const preProcessors = [];\n for (let i = 0; i < this.preProcessors.length; i++) {\n preProcessors.push(this.preProcessors[i].preProcessor);\n }\n return preProcessors;\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getPostProcessors() {\n const postProcessors = [];\n for (let i = 0; i < this.postProcessors.length; i++) {\n postProcessors.push(this.postProcessors[i].postProcessor);\n }\n return postProcessors;\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getVisitors() {\n return this.visitors;\n }\n\n visitor() {\n const self = this;\n return {\n first: function() {\n self.iterator = -1;\n return self.visitors[self.iterator];\n },\n get: function() {\n self.iterator += 1;\n return self.visitors[self.iterator];\n }\n };\n }\n\n /**\n *\n * @returns {Array}\n * @private\n */\n getFileManagers() {\n return this.fileManagers;\n }\n}\n\nlet pm;\n\nconst PluginManagerFactory = function(less, newFactory) {\n if (newFactory || !pm) {\n pm = new PluginManager(less);\n }\n return pm;\n};\n\n//\nexport default PluginManagerFactory;\n","'use strict';\n\nfunction parseNodeVersion(version) {\n var match = version.match(/^v(\\d{1,2})\\.(\\d{1,2})\\.(\\d{1,2})(?:-([0-9A-Za-z-.]+))?(?:\\+([0-9A-Za-z-.]+))?$/); // eslint-disable-line max-len\n if (!match) {\n throw new Error('Unable to parse: ' + version);\n }\n\n var res = {\n major: parseInt(match[1], 10),\n minor: parseInt(match[2], 10),\n patch: parseInt(match[3], 10),\n pre: match[4] || '',\n build: match[5] || '',\n };\n\n return res;\n}\n\nmodule.exports = parseNodeVersion;\n","/* global window, XMLHttpRequest */\n\nimport AbstractFileManager from '../less/environment/abstract-file-manager.js';\n\nlet options;\nlet logger;\nlet fileCache = {};\n\n// TODOS - move log somewhere. pathDiff and doing something similar in node. use pathDiff in the other browser file for the initial load\nconst FileManager = function() {}\nFileManager.prototype = Object.assign(new AbstractFileManager(), {\n alwaysMakePathsAbsolute() {\n return true;\n },\n\n join(basePath, laterPath) {\n if (!basePath) {\n return laterPath;\n }\n return this.extractUrlParts(laterPath, basePath).path;\n },\n\n doXHR(url, type, callback, errback) {\n const xhr = new XMLHttpRequest();\n const async = options.isFileProtocol ? options.fileAsync : true;\n\n if (typeof xhr.overrideMimeType === 'function') {\n xhr.overrideMimeType('text/css');\n }\n logger.debug(`XHR: Getting '${url}'`);\n xhr.open('GET', url, async);\n xhr.setRequestHeader('Accept', type || 'text/x-less, text/css; q=0.9, */*; q=0.5');\n xhr.send(null);\n\n function handleResponse(xhr, callback, errback) {\n if (xhr.status >= 200 && xhr.status < 300) {\n callback(xhr.responseText,\n xhr.getResponseHeader('Last-Modified'));\n } else if (typeof errback === 'function') {\n errback(xhr.status, url);\n }\n }\n\n if (options.isFileProtocol && !options.fileAsync) {\n if (xhr.status === 0 || (xhr.status >= 200 && xhr.status < 300)) {\n callback(xhr.responseText);\n } else {\n errback(xhr.status, url);\n }\n } else if (async) {\n xhr.onreadystatechange = () => {\n if (xhr.readyState == 4) {\n handleResponse(xhr, callback, errback);\n }\n };\n } else {\n handleResponse(xhr, callback, errback);\n }\n },\n\n supports() {\n return true;\n },\n\n clearFileCache() {\n fileCache = {};\n },\n\n loadFile(filename, currentDirectory, options, environment) {\n // TODO: Add prefix support like less-node?\n // What about multiple paths?\n\n if (currentDirectory && !this.isPathAbsolute(filename)) {\n filename = currentDirectory + filename;\n }\n\n filename = options.ext ? this.tryAppendExtension(filename, options.ext) : filename;\n\n options = options || {};\n\n // sheet may be set to the stylesheet for the initial load or a collection of properties including\n // some context variables for imports\n const hrefParts = this.extractUrlParts(filename, window.location.href);\n const href = hrefParts.url;\n const self = this;\n \n return new Promise((resolve, reject) => {\n if (options.useFileCache && fileCache[href]) {\n try {\n const lessText = fileCache[href];\n return resolve({ contents: lessText, filename: href, webInfo: { lastModified: new Date() }});\n } catch (e) {\n return reject({ filename: href, message: `Error loading file ${href} error was ${e.message}` });\n }\n }\n\n self.doXHR(href, options.mime, function doXHRCallback(data, lastModified) {\n // per file cache\n fileCache[href] = data;\n\n // Use remote copy (re-parse)\n resolve({ contents: data, filename: href, webInfo: { lastModified }});\n }, function doXHRError(status, url) {\n reject({ type: 'File', message: `'${url}' wasn't found (${status})`, href });\n });\n });\n }\n});\n\nexport default (opts, log) => {\n options = opts;\n logger = log;\n return FileManager;\n}\n","import Environment from './environment/environment';\nimport data from './data';\nimport tree from './tree';\nimport AbstractFileManager from './environment/abstract-file-manager';\nimport AbstractPluginLoader from './environment/abstract-plugin-loader';\nimport visitors from './visitors';\nimport Parser from './parser/parser';\nimport functions from './functions';\nimport contexts from './contexts';\nimport LessError from './less-error';\nimport transformTree from './transform-tree';\nimport * as utils from './utils';\nimport PluginManager from './plugin-manager';\nimport logger from './logger';\nimport SourceMapOutput from './source-map-output';\nimport SourceMapBuilder from './source-map-builder';\nimport ParseTree from './parse-tree';\nimport ImportManager from './import-manager';\nimport Parse from './parse';\nimport Render from './render';\nimport { version } from '../../package.json';\nimport parseVersion from 'parse-node-version';\n\nexport default function(environment, fileManagers) {\n let sourceMapOutput, sourceMapBuilder, parseTree, importManager;\n\n environment = new Environment(environment, fileManagers);\n sourceMapOutput = SourceMapOutput(environment);\n sourceMapBuilder = SourceMapBuilder(sourceMapOutput, environment);\n parseTree = ParseTree(sourceMapBuilder);\n importManager = ImportManager(environment);\n\n const render = Render(environment, parseTree, importManager);\n const parse = Parse(environment, parseTree, importManager);\n\n const v = parseVersion(version);\n const initial = {\n version: [v.major, v.minor, v.patch],\n data,\n tree,\n Environment,\n AbstractFileManager,\n AbstractPluginLoader,\n environment,\n visitors,\n Parser,\n functions: functions(environment),\n contexts,\n SourceMapOutput: sourceMapOutput,\n SourceMapBuilder: sourceMapBuilder,\n ParseTree: parseTree,\n ImportManager: importManager,\n render,\n parse,\n LessError,\n transformTree,\n utils,\n PluginManager,\n logger\n };\n\n // Create a public API\n\n const ctor = function(t) {\n return function() {\n const obj = Object.create(t.prototype);\n t.apply(obj, Array.prototype.slice.call(arguments, 0));\n return obj;\n };\n };\n let t;\n const api = Object.create(initial);\n for (const n in initial.tree) {\n /* eslint guard-for-in: 0 */\n t = initial.tree[n];\n if (typeof t === 'function') {\n api[n.toLowerCase()] = ctor(t);\n }\n else {\n api[n] = Object.create(null);\n for (const o in t) {\n /* eslint guard-for-in: 0 */\n api[n][o.toLowerCase()] = ctor(t[o]);\n }\n }\n }\n\n /**\n * Some of the functions assume a `this` context of the API object,\n * which causes it to fail when wrapped for ES6 imports.\n * \n * An assumed `this` should be removed in the future.\n */\n initial.parse = initial.parse.bind(api);\n initial.render = initial.render.bind(api);\n\n return api;\n};\n","import LessError from './less-error';\nimport transformTree from './transform-tree';\nimport logger from './logger';\n\nexport default function(SourceMapBuilder) {\n class ParseTree {\n constructor(root, imports) {\n this.root = root;\n this.imports = imports;\n }\n\n toCSS(options) {\n let evaldRoot;\n const result = {};\n let sourceMapBuilder;\n try {\n evaldRoot = transformTree(this.root, options);\n } catch (e) {\n throw new LessError(e, this.imports);\n }\n\n try {\n const compress = Boolean(options.compress);\n if (compress) {\n logger.warn('The compress option has been deprecated. ' + \n 'We recommend you use a dedicated css minifier, for instance see less-plugin-clean-css.');\n }\n\n const toCSSOptions = {\n compress,\n dumpLineNumbers: options.dumpLineNumbers,\n strictUnits: Boolean(options.strictUnits),\n numPrecision: 8};\n\n if (options.sourceMap) {\n sourceMapBuilder = new SourceMapBuilder(options.sourceMap);\n result.css = sourceMapBuilder.toCSS(evaldRoot, toCSSOptions, this.imports);\n } else {\n result.css = evaldRoot.toCSS(toCSSOptions);\n }\n } catch (e) {\n throw new LessError(e, this.imports);\n }\n\n if (options.pluginManager) {\n const postProcessors = options.pluginManager.getPostProcessors();\n for (let i = 0; i < postProcessors.length; i++) {\n result.css = postProcessors[i].process(result.css, { sourceMap: sourceMapBuilder, options, imports: this.imports });\n }\n }\n if (options.sourceMap) {\n result.map = sourceMapBuilder.getExternalSourceMap();\n }\n\n result.imports = [];\n for (const file in this.imports.files) {\n if (this.imports.files.hasOwnProperty(file) && file !== this.imports.rootFilename) {\n result.imports.push(file);\n }\n }\n return result;\n }\n }\n\n return ParseTree;\n};\n","export default function (SourceMapOutput, environment) {\n class SourceMapBuilder {\n constructor(options) {\n this.options = options;\n }\n\n toCSS(rootNode, options, imports) {\n const sourceMapOutput = new SourceMapOutput(\n {\n contentsIgnoredCharsMap: imports.contentsIgnoredChars,\n rootNode,\n contentsMap: imports.contents,\n sourceMapFilename: this.options.sourceMapFilename,\n sourceMapURL: this.options.sourceMapURL,\n outputFilename: this.options.sourceMapOutputFilename,\n sourceMapBasepath: this.options.sourceMapBasepath,\n sourceMapRootpath: this.options.sourceMapRootpath,\n outputSourceFiles: this.options.outputSourceFiles,\n sourceMapGenerator: this.options.sourceMapGenerator,\n sourceMapFileInline: this.options.sourceMapFileInline, \n disableSourcemapAnnotation: this.options.disableSourcemapAnnotation\n });\n\n const css = sourceMapOutput.toCSS(options);\n this.sourceMap = sourceMapOutput.sourceMap;\n this.sourceMapURL = sourceMapOutput.sourceMapURL;\n if (this.options.sourceMapInputFilename) {\n this.sourceMapInputFilename = sourceMapOutput.normalizeFilename(this.options.sourceMapInputFilename);\n }\n if (this.options.sourceMapBasepath !== undefined && this.sourceMapURL !== undefined) {\n this.sourceMapURL = sourceMapOutput.removeBasepath(this.sourceMapURL);\n }\n return css + this.getCSSAppendage();\n }\n\n getCSSAppendage() {\n\n let sourceMapURL = this.sourceMapURL;\n if (this.options.sourceMapFileInline) {\n if (this.sourceMap === undefined) {\n return '';\n }\n sourceMapURL = `data:application/json;base64,${environment.encodeBase64(this.sourceMap)}`;\n }\n\n if (this.options.disableSourcemapAnnotation) {\n return '';\n }\n\n if (sourceMapURL) {\n return `/*# sourceMappingURL=${sourceMapURL} */`;\n }\n return '';\n }\n\n getExternalSourceMap() {\n return this.sourceMap;\n }\n\n setExternalSourceMap(sourceMap) {\n this.sourceMap = sourceMap;\n }\n\n isInline() {\n return this.options.sourceMapFileInline;\n }\n\n getSourceMapURL() {\n return this.sourceMapURL;\n }\n\n getOutputFilename() {\n return this.options.sourceMapOutputFilename;\n }\n\n getInputFilename() {\n return this.sourceMapInputFilename;\n }\n }\n\n return SourceMapBuilder;\n};\n","export default function (environment) {\n class SourceMapOutput {\n constructor(options) {\n this._css = [];\n this._rootNode = options.rootNode;\n this._contentsMap = options.contentsMap;\n this._contentsIgnoredCharsMap = options.contentsIgnoredCharsMap;\n if (options.sourceMapFilename) {\n this._sourceMapFilename = options.sourceMapFilename.replace(/\\\\/g, '/');\n }\n this._outputFilename = options.outputFilename;\n this.sourceMapURL = options.sourceMapURL;\n if (options.sourceMapBasepath) {\n this._sourceMapBasepath = options.sourceMapBasepath.replace(/\\\\/g, '/');\n }\n if (options.sourceMapRootpath) {\n this._sourceMapRootpath = options.sourceMapRootpath.replace(/\\\\/g, '/');\n if (this._sourceMapRootpath.charAt(this._sourceMapRootpath.length - 1) !== '/') {\n this._sourceMapRootpath += '/';\n }\n } else {\n this._sourceMapRootpath = '';\n }\n this._outputSourceFiles = options.outputSourceFiles;\n this._sourceMapGeneratorConstructor = environment.getSourceMapGenerator();\n\n this._lineNumber = 0;\n this._column = 0;\n }\n\n removeBasepath(path) {\n if (this._sourceMapBasepath && path.indexOf(this._sourceMapBasepath) === 0) {\n path = path.substring(this._sourceMapBasepath.length);\n if (path.charAt(0) === '\\\\' || path.charAt(0) === '/') {\n path = path.substring(1);\n }\n }\n\n return path;\n }\n\n normalizeFilename(filename) {\n filename = filename.replace(/\\\\/g, '/');\n filename = this.removeBasepath(filename);\n return (this._sourceMapRootpath || '') + filename;\n }\n\n add(chunk, fileInfo, index, mapLines) {\n\n // ignore adding empty strings\n if (!chunk) {\n return;\n }\n\n let lines, sourceLines, columns, sourceColumns, i;\n\n if (fileInfo && fileInfo.filename) {\n let inputSource = this._contentsMap[fileInfo.filename];\n\n // remove vars/banner added to the top of the file\n if (this._contentsIgnoredCharsMap[fileInfo.filename]) {\n // adjust the index\n index -= this._contentsIgnoredCharsMap[fileInfo.filename];\n if (index < 0) { index = 0; }\n // adjust the source\n inputSource = inputSource.slice(this._contentsIgnoredCharsMap[fileInfo.filename]);\n }\n\n /** \n * ignore empty content, or failsafe\n * if contents map is incorrect\n */\n if (inputSource === undefined) {\n this._css.push(chunk);\n return;\n }\n\n inputSource = inputSource.substring(0, index);\n sourceLines = inputSource.split('\\n');\n sourceColumns = sourceLines[sourceLines.length - 1];\n }\n\n lines = chunk.split('\\n');\n columns = lines[lines.length - 1];\n\n if (fileInfo && fileInfo.filename) {\n if (!mapLines) {\n this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + 1, column: this._column},\n original: { line: sourceLines.length, column: sourceColumns.length},\n source: this.normalizeFilename(fileInfo.filename)});\n } else {\n for (i = 0; i < lines.length; i++) {\n this._sourceMapGenerator.addMapping({ generated: { line: this._lineNumber + i + 1, column: i === 0 ? this._column : 0},\n original: { line: sourceLines.length + i, column: i === 0 ? sourceColumns.length : 0},\n source: this.normalizeFilename(fileInfo.filename)});\n }\n }\n }\n\n if (lines.length === 1) {\n this._column += columns.length;\n } else {\n this._lineNumber += lines.length - 1;\n this._column = columns.length;\n }\n\n this._css.push(chunk);\n }\n\n isEmpty() {\n return this._css.length === 0;\n }\n\n toCSS(context) {\n this._sourceMapGenerator = new this._sourceMapGeneratorConstructor({ file: this._outputFilename, sourceRoot: null });\n\n if (this._outputSourceFiles) {\n for (const filename in this._contentsMap) {\n if (this._contentsMap.hasOwnProperty(filename)) {\n let source = this._contentsMap[filename];\n if (this._contentsIgnoredCharsMap[filename]) {\n source = source.slice(this._contentsIgnoredCharsMap[filename]);\n }\n this._sourceMapGenerator.setSourceContent(this.normalizeFilename(filename), source);\n }\n }\n }\n\n this._rootNode.genCSS(context, this);\n\n if (this._css.length > 0) {\n let sourceMapURL;\n const sourceMapContent = JSON.stringify(this._sourceMapGenerator.toJSON());\n\n if (this.sourceMapURL) {\n sourceMapURL = this.sourceMapURL;\n } else if (this._sourceMapFilename) {\n sourceMapURL = this._sourceMapFilename;\n }\n this.sourceMapURL = sourceMapURL;\n\n this.sourceMap = sourceMapContent;\n }\n\n return this._css.join('');\n }\n }\n\n return SourceMapOutput;\n};\n","import contexts from './contexts';\nimport Parser from './parser/parser';\nimport LessError from './less-error';\nimport * as utils from './utils';\nimport logger from './logger';\n\nexport default function(environment) {\n // FileInfo = {\n // 'rewriteUrls' - option - whether to adjust URL's to be relative\n // 'filename' - full resolved filename of current file\n // 'rootpath' - path to append to normal URLs for this node\n // 'currentDirectory' - path to the current file, absolute\n // 'rootFilename' - filename of the base file\n // 'entryPath' - absolute path to the entry file\n // 'reference' - whether the file should not be output and only output parts that are referenced\n\n class ImportManager {\n constructor(less, context, rootFileInfo) {\n this.less = less;\n this.rootFilename = rootFileInfo.filename;\n this.paths = context.paths || []; // Search paths, when importing\n this.contents = {}; // map - filename to contents of all the files\n this.contentsIgnoredChars = {}; // map - filename to lines at the beginning of each file to ignore\n this.mime = context.mime;\n this.error = null;\n this.context = context;\n // Deprecated? Unused outside of here, could be useful.\n this.queue = []; // Files which haven't been imported yet\n this.files = {}; // Holds the imported parse trees.\n }\n\n /**\n * Add an import to be imported\n * @param path - the raw path\n * @param tryAppendExtension - whether to try appending a file extension (.less or .js if the path has no extension)\n * @param currentFileInfo - the current file info (used for instance to work out relative paths)\n * @param importOptions - import options\n * @param callback - callback for when it is imported\n */\n push(path, tryAppendExtension, currentFileInfo, importOptions, callback) {\n const importManager = this, pluginLoader = this.context.pluginManager.Loader;\n\n this.queue.push(path);\n\n const fileParsedFunc = function (e, root, fullPath) {\n importManager.queue.splice(importManager.queue.indexOf(path), 1); // Remove the path from the queue\n\n const importedEqualsRoot = fullPath === importManager.rootFilename;\n if (importOptions.optional && e) {\n callback(null, {rules:[]}, false, null);\n logger.info(`The file ${fullPath} was skipped because it was not found and the import was marked optional.`);\n }\n else {\n // Inline imports aren't cached here.\n // If we start to cache them, please make sure they won't conflict with non-inline imports of the\n // same name as they used to do before this comment and the condition below have been added.\n if (!importManager.files[fullPath] && !importOptions.inline) {\n importManager.files[fullPath] = { root, options: importOptions };\n }\n if (e && !importManager.error) { importManager.error = e; }\n callback(e, root, importedEqualsRoot, fullPath);\n }\n };\n\n const newFileInfo = {\n rewriteUrls: this.context.rewriteUrls,\n entryPath: currentFileInfo.entryPath,\n rootpath: currentFileInfo.rootpath,\n rootFilename: currentFileInfo.rootFilename\n };\n\n const fileManager = environment.getFileManager(path, currentFileInfo.currentDirectory, this.context, environment);\n\n if (!fileManager) {\n fileParsedFunc({ message: `Could not find a file-manager for ${path}` });\n return;\n }\n\n const loadFileCallback = function(loadedFile) {\n let plugin;\n const resolvedFilename = loadedFile.filename;\n const contents = loadedFile.contents.replace(/^\\uFEFF/, '');\n\n // Pass on an updated rootpath if path of imported file is relative and file\n // is in a (sub|sup) directory\n //\n // Examples:\n // - If path of imported file is 'module/nav/nav.less' and rootpath is 'less/',\n // then rootpath should become 'less/module/nav/'\n // - If path of imported file is '../mixins.less' and rootpath is 'less/',\n // then rootpath should become 'less/../'\n newFileInfo.currentDirectory = fileManager.getPath(resolvedFilename);\n if (newFileInfo.rewriteUrls) {\n newFileInfo.rootpath = fileManager.join(\n (importManager.context.rootpath || ''),\n fileManager.pathDiff(newFileInfo.currentDirectory, newFileInfo.entryPath));\n\n if (!fileManager.isPathAbsolute(newFileInfo.rootpath) && fileManager.alwaysMakePathsAbsolute()) {\n newFileInfo.rootpath = fileManager.join(newFileInfo.entryPath, newFileInfo.rootpath);\n }\n }\n newFileInfo.filename = resolvedFilename;\n\n const newEnv = new contexts.Parse(importManager.context);\n\n newEnv.processImports = false;\n importManager.contents[resolvedFilename] = contents;\n\n if (currentFileInfo.reference || importOptions.reference) {\n newFileInfo.reference = true;\n }\n\n if (importOptions.isPlugin) {\n plugin = pluginLoader.evalPlugin(contents, newEnv, importManager, importOptions.pluginArgs, newFileInfo);\n if (plugin instanceof LessError) {\n fileParsedFunc(plugin, null, resolvedFilename);\n }\n else {\n fileParsedFunc(null, plugin, resolvedFilename);\n }\n } else if (importOptions.inline) {\n fileParsedFunc(null, contents, resolvedFilename);\n } else {\n // import (multiple) parse trees apparently get altered and can't be cached.\n // TODO: investigate why this is\n if (importManager.files[resolvedFilename]\n && !importManager.files[resolvedFilename].options.multiple\n && !importOptions.multiple) {\n\n fileParsedFunc(null, importManager.files[resolvedFilename].root, resolvedFilename);\n }\n else {\n new Parser(newEnv, importManager, newFileInfo).parse(contents, function (e, root) {\n fileParsedFunc(e, root, resolvedFilename);\n });\n }\n }\n };\n let loadedFile;\n let promise;\n const context = utils.clone(this.context);\n\n if (tryAppendExtension) {\n context.ext = importOptions.isPlugin ? '.js' : '.less';\n }\n\n if (importOptions.isPlugin) {\n context.mime = 'application/javascript';\n\n if (context.syncImport) {\n loadedFile = pluginLoader.loadPluginSync(path, currentFileInfo.currentDirectory, context, environment, fileManager);\n } else {\n promise = pluginLoader.loadPlugin(path, currentFileInfo.currentDirectory, context, environment, fileManager);\n }\n }\n else {\n if (context.syncImport) {\n loadedFile = fileManager.loadFileSync(path, currentFileInfo.currentDirectory, context, environment);\n } else {\n promise = fileManager.loadFile(path, currentFileInfo.currentDirectory, context, environment,\n (err, loadedFile) => {\n if (err) {\n fileParsedFunc(err);\n } else {\n loadFileCallback(loadedFile);\n }\n });\n }\n }\n if (loadedFile) {\n if (!loadedFile.filename) {\n fileParsedFunc(loadedFile);\n } else {\n loadFileCallback(loadedFile);\n }\n } else if (promise) {\n promise.then(loadFileCallback, fileParsedFunc);\n }\n }\n }\n\n return ImportManager;\n};\n","import * as utils from './utils';\n\nexport default function(environment, ParseTree, ImportManager) {\n const render = function (input, options, callback) {\n if (typeof options === 'function') {\n callback = options;\n options = utils.copyOptions(this.options, {});\n }\n else {\n options = utils.copyOptions(this.options, options || {});\n }\n\n if (!callback) {\n const self = this;\n return new Promise(function (resolve, reject) {\n render.call(self, input, options, function(err, output) {\n if (err) {\n reject(err);\n } else {\n resolve(output);\n }\n });\n });\n } else {\n this.parse(input, options, function(err, root, imports, options) {\n if (err) { return callback(err); }\n\n let result;\n try {\n const parseTree = new ParseTree(root, imports);\n result = parseTree.toCSS(options);\n }\n catch (err) { return callback(err); }\n\n callback(null, result);\n });\n }\n };\n\n return render;\n};\n","import contexts from './contexts';\nimport Parser from './parser/parser';\nimport PluginManager from './plugin-manager';\nimport LessError from './less-error';\nimport * as utils from './utils';\n\nexport default function(environment, ParseTree, ImportManager) {\n const parse = function (input, options, callback) {\n\n if (typeof options === 'function') {\n callback = options;\n options = utils.copyOptions(this.options, {});\n }\n else {\n options = utils.copyOptions(this.options, options || {});\n }\n\n if (!callback) {\n const self = this;\n return new Promise(function (resolve, reject) {\n parse.call(self, input, options, function(err, output) {\n if (err) {\n reject(err);\n } else {\n resolve(output);\n }\n });\n });\n } else {\n let context;\n let rootFileInfo;\n const pluginManager = new PluginManager(this, !options.reUsePluginManager);\n\n options.pluginManager = pluginManager;\n\n context = new contexts.Parse(options);\n\n if (options.rootFileInfo) {\n rootFileInfo = options.rootFileInfo;\n } else {\n const filename = options.filename || 'input';\n const entryPath = filename.replace(/[^\\/\\\\]*$/, '');\n rootFileInfo = {\n filename,\n rewriteUrls: context.rewriteUrls,\n rootpath: context.rootpath || '',\n currentDirectory: entryPath,\n entryPath,\n rootFilename: filename\n };\n // add in a missing trailing slash\n if (rootFileInfo.rootpath && rootFileInfo.rootpath.slice(-1) !== '/') {\n rootFileInfo.rootpath += '/';\n }\n }\n\n const imports = new ImportManager(this, context, rootFileInfo);\n this.importManager = imports;\n\n // TODO: allow the plugins to be just a list of paths or names\n // Do an async plugin queue like lessc\n\n if (options.plugins) {\n options.plugins.forEach(function(plugin) {\n let evalResult, contents;\n if (plugin.fileContent) {\n contents = plugin.fileContent.replace(/^\\uFEFF/, '');\n evalResult = pluginManager.Loader.evalPlugin(contents, context, imports, plugin.options, plugin.filename);\n if (evalResult instanceof LessError) {\n return callback(evalResult);\n }\n }\n else {\n pluginManager.addPlugin(plugin);\n }\n });\n }\n\n new Parser(context, imports, rootFileInfo)\n .parse(input, function (e, root) {\n if (e) { return callback(e); }\n callback(null, root, imports, options);\n }, options);\n }\n };\n return parse;\n};\n","// TODO: Add tests for browser @plugin\n/* global window */\n\nimport AbstractPluginLoader from '../less/environment/abstract-plugin-loader.js';\n\n/**\n * Browser Plugin Loader\n */\nconst PluginLoader = function(less) {\n this.less = less;\n // Should we shim this.require for browser? Probably not?\n};\n\nPluginLoader.prototype = Object.assign(new AbstractPluginLoader(), {\n loadPlugin(filename, basePath, context, environment, fileManager) {\n return new Promise((fulfill, reject) => {\n fileManager.loadFile(filename, basePath, context, environment)\n .then(fulfill).catch(reject);\n });\n }\n});\n\nexport default PluginLoader;\n\n","import * as utils from './utils';\nimport browser from './browser';\n\nexport default (window, less, options) => {\n\n function errorHTML(e, rootHref) {\n const id = `less-error-message:${utils.extractId(rootHref || '')}`;\n const template = '
  • {content}
  • ';\n const elem = window.document.createElement('div');\n let timer;\n let content;\n const errors = [];\n const filename = e.filename || rootHref;\n const filenameNoPath = filename.match(/([^\\/]+(\\?.*)?)$/)[1];\n\n elem.id = id;\n elem.className = 'less-error-message';\n\n content = `

    ${e.type || 'Syntax'}Error: ${e.message || 'There is an error in your .less file'}` + \n `

    in ${filenameNoPath} `;\n\n const errorline = (e, i, classname) => {\n if (e.extract[i] !== undefined) {\n errors.push(template.replace(/\\{line\\}/, (parseInt(e.line, 10) || 0) + (i - 1))\n .replace(/\\{class\\}/, classname)\n .replace(/\\{content\\}/, e.extract[i]));\n }\n };\n\n if (e.line) {\n errorline(e, 0, '');\n errorline(e, 1, 'line');\n errorline(e, 2, '');\n content += `on line ${e.line}, column ${e.column + 1}:

      ${errors.join('')}
    `;\n }\n if (e.stack && (e.extract || options.logLevel >= 4)) {\n content += `
    Stack Trace
    ${e.stack.split('\\n').slice(1).join('
    ')}`;\n }\n elem.innerHTML = content;\n\n // CSS for error messages\n browser.createCSS(window.document, [\n '.less-error-message ul, .less-error-message li {',\n 'list-style-type: none;',\n 'margin-right: 15px;',\n 'padding: 4px 0;',\n 'margin: 0;',\n '}',\n '.less-error-message label {',\n 'font-size: 12px;',\n 'margin-right: 15px;',\n 'padding: 4px 0;',\n 'color: #cc7777;',\n '}',\n '.less-error-message pre {',\n 'color: #dd6666;',\n 'padding: 4px 0;',\n 'margin: 0;',\n 'display: inline-block;',\n '}',\n '.less-error-message pre.line {',\n 'color: #ff0000;',\n '}',\n '.less-error-message h3 {',\n 'font-size: 20px;',\n 'font-weight: bold;',\n 'padding: 15px 0 5px 0;',\n 'margin: 0;',\n '}',\n '.less-error-message a {',\n 'color: #10a',\n '}',\n '.less-error-message .error {',\n 'color: red;',\n 'font-weight: bold;',\n 'padding-bottom: 2px;',\n 'border-bottom: 1px dashed red;',\n '}'\n ].join('\\n'), { title: 'error-message' });\n\n elem.style.cssText = [\n 'font-family: Arial, sans-serif',\n 'border: 1px solid #e00',\n 'background-color: #eee',\n 'border-radius: 5px',\n '-webkit-border-radius: 5px',\n '-moz-border-radius: 5px',\n 'color: #e00',\n 'padding: 15px',\n 'margin-bottom: 15px'\n ].join(';');\n\n if (options.env === 'development') {\n timer = setInterval(() => {\n const document = window.document;\n const body = document.body;\n if (body) {\n if (document.getElementById(id)) {\n body.replaceChild(elem, document.getElementById(id));\n } else {\n body.insertBefore(elem, body.firstChild);\n }\n clearInterval(timer);\n }\n }, 10);\n }\n }\n\n function removeErrorHTML(path) {\n const node = window.document.getElementById(`less-error-message:${utils.extractId(path)}`);\n if (node) {\n node.parentNode.removeChild(node);\n }\n }\n\n function removeErrorConsole(path) {\n // no action\n }\n\n function removeError(path) {\n if (!options.errorReporting || options.errorReporting === 'html') {\n removeErrorHTML(path);\n } else if (options.errorReporting === 'console') {\n removeErrorConsole(path);\n } else if (typeof options.errorReporting === 'function') {\n options.errorReporting('remove', path);\n }\n }\n\n function errorConsole(e, rootHref) {\n const template = '{line} {content}';\n const filename = e.filename || rootHref;\n const errors = [];\n let content = `${e.type || 'Syntax'}Error: ${e.message || 'There is an error in your .less file'} in ${filename}`;\n\n const errorline = (e, i, classname) => {\n if (e.extract[i] !== undefined) {\n errors.push(template.replace(/\\{line\\}/, (parseInt(e.line, 10) || 0) + (i - 1))\n .replace(/\\{class\\}/, classname)\n .replace(/\\{content\\}/, e.extract[i]));\n }\n };\n\n if (e.line) {\n errorline(e, 0, '');\n errorline(e, 1, 'line');\n errorline(e, 2, '');\n content += ` on line ${e.line}, column ${e.column + 1}:\\n${errors.join('\\n')}`;\n }\n if (e.stack && (e.extract || options.logLevel >= 4)) {\n content += `\\nStack Trace\\n${e.stack}`;\n }\n less.logger.error(content);\n }\n\n function error(e, rootHref) {\n if (!options.errorReporting || options.errorReporting === 'html') {\n errorHTML(e, rootHref);\n } else if (options.errorReporting === 'console') {\n errorConsole(e, rootHref);\n } else if (typeof options.errorReporting === 'function') {\n options.errorReporting('add', e, rootHref);\n }\n }\n\n return {\n add: error,\n remove: removeError\n };\n};\n","/**\n * Kicks off less and compiles any stylesheets\n * used in the browser distributed version of less\n * to kick-start less using the browser api\n */\n/* global window, document */\n\nimport defaultOptions from '../less/default-options';\nimport addDefaultOptions from './add-default-options';\nimport root from './index';\n\nconst options = defaultOptions();\n\nif (window.less) {\n for (const key in window.less) {\n if (window.less.hasOwnProperty(key)) {\n options[key] = window.less[key];\n }\n }\n}\naddDefaultOptions(window, options);\n\noptions.plugins = options.plugins || [];\n\nif (window.LESS_PLUGINS) {\n options.plugins = options.plugins.concat(window.LESS_PLUGINS);\n}\n\nconst less = root(window, options);\nexport default less;\n\nwindow.less = less;\n\nlet css;\nlet head;\nlet style;\n\n// Always restore page visibility\nfunction resolveOrReject(data) {\n if (data.filename) {\n console.warn(data);\n }\n if (!options.async) {\n head.removeChild(style);\n }\n}\n\nif (options.onReady) {\n if (/!watch/.test(window.location.hash)) {\n less.watch();\n }\n // Simulate synchronous stylesheet loading by hiding page rendering\n if (!options.async) {\n css = 'body { display: none !important }';\n head = document.head || document.getElementsByTagName('head')[0];\n style = document.createElement('style');\n\n style.type = 'text/css';\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n\n head.appendChild(style);\n }\n less.registerStylesheetsImmediately();\n less.pageLoadFinished = less.refresh(less.env === 'development').then(resolveOrReject, resolveOrReject);\n}\n","// Export a new default each time\nexport default function() {\n return {\n /* Inline Javascript - @plugin still allowed */\n javascriptEnabled: false,\n\n /* Outputs a makefile import dependency list to stdout. */\n depends: false,\n\n /* (DEPRECATED) Compress using less built-in compression. \n * This does an okay job but does not utilise all the tricks of \n * dedicated css compression. */\n compress: false,\n\n /* Runs the less parser and just reports errors without any output. */\n lint: false,\n\n /* Sets available include paths.\n * If the file in an @import rule does not exist at that exact location, \n * less will look for it at the location(s) passed to this option. \n * You might use this for instance to specify a path to a library which \n * you want to be referenced simply and relatively in the less files. */\n paths: [],\n\n /* color output in the terminal */\n color: true,\n\n /* The strictImports controls whether the compiler will allow an @import inside of either \n * @media blocks or (a later addition) other selector blocks.\n * See: https://github.com/less/less.js/issues/656 */\n strictImports: false,\n\n /* Allow Imports from Insecure HTTPS Hosts */\n insecure: false,\n\n /* Allows you to add a path to every generated import and url in your css. \n * This does not affect less import statements that are processed, just ones \n * that are left in the output css. */\n rootpath: '',\n\n /* By default URLs are kept as-is, so if you import a file in a sub-directory \n * that references an image, exactly the same URL will be output in the css. \n * This option allows you to re-write URL's in imported files so that the \n * URL is always relative to the base imported file */\n rewriteUrls: false,\n\n /* How to process math \n * 0 always - eagerly try to solve all operations\n * 1 parens-division - require parens for division \"/\"\n * 2 parens | strict - require parens for all operations\n * 3 strict-legacy - legacy strict behavior (super-strict)\n */\n math: 1,\n\n /* Without this option, less attempts to guess at the output unit when it does maths. */\n strictUnits: false,\n\n /* Effectively the declaration is put at the top of your base Less file, \n * meaning it can be used but it also can be overridden if this variable \n * is defined in the file. */\n globalVars: null,\n\n /* As opposed to the global variable option, this puts the declaration at the\n * end of your base file, meaning it will override anything defined in your Less file. */\n modifyVars: null,\n\n /* This option allows you to specify a argument to go on to every URL. */\n urlArgs: ''\n }\n};","import {addDataAttr} from './utils';\nimport browser from './browser';\n\nexport default (window, options) => {\n\n // use options from the current script tag data attribues\n addDataAttr(options, browser.currentScript(window));\n\n if (options.isFileProtocol === undefined) {\n options.isFileProtocol = /^(file|(chrome|safari)(-extension)?|resource|qrc|app):/.test(window.location.protocol);\n }\n\n // Load styles asynchronously (default: false)\n //\n // This is set to `false` by default, so that the body\n // doesn't start loading before the stylesheets are parsed.\n // Setting this to `true` can result in flickering.\n //\n options.async = options.async || false;\n options.fileAsync = options.fileAsync || false;\n\n // Interval between watch polls\n options.poll = options.poll || (options.isFileProtocol ? 1000 : 1500);\n\n options.env = options.env || (window.location.hostname == '127.0.0.1' ||\n window.location.hostname == '0.0.0.0' ||\n window.location.hostname == 'localhost' ||\n (window.location.port &&\n window.location.port.length > 0) ||\n options.isFileProtocol ? 'development'\n : 'production');\n\n const dumpLineNumbers = /!dumpLineNumbers:(comments|mediaquery|all)/.exec(window.location.hash);\n if (dumpLineNumbers) {\n options.dumpLineNumbers = dumpLineNumbers[1];\n }\n\n if (options.useFileCache === undefined) {\n options.useFileCache = true;\n }\n\n if (options.onReady === undefined) {\n options.onReady = true;\n }\n\n if (options.relativeUrls) {\n options.rewriteUrls = 'all';\n }\n};\n","//\n// index.js\n// Should expose the additional browser functions on to the less object\n//\nimport {addDataAttr} from './utils';\nimport lessRoot from '../less';\nimport browser from './browser';\nimport FM from './file-manager';\nimport PluginLoader from './plugin-loader';\nimport LogListener from './log-listener';\nimport ErrorReporting from './error-reporting';\nimport Cache from './cache';\nimport ImageSize from './image-size';\n\nexport default (window, options) => {\n const document = window.document;\n const less = lessRoot();\n\n less.options = options;\n const environment = less.environment;\n const FileManager = FM(options, less.logger);\n const fileManager = new FileManager();\n environment.addFileManager(fileManager);\n less.FileManager = FileManager;\n less.PluginLoader = PluginLoader;\n\n LogListener(less, options);\n const errors = ErrorReporting(window, less, options);\n const cache = less.cache = options.cache || Cache(window, options, less.logger);\n ImageSize(less.environment);\n\n // Setup user functions - Deprecate?\n if (options.functions) {\n less.functions.functionRegistry.addMultiple(options.functions);\n }\n\n const typePattern = /^text\\/(x-)?less$/;\n\n function clone(obj) {\n const cloned = {};\n for (const prop in obj) {\n if (obj.hasOwnProperty(prop)) {\n cloned[prop] = obj[prop];\n }\n }\n return cloned;\n }\n\n // only really needed for phantom\n function bind(func, thisArg) {\n const curryArgs = Array.prototype.slice.call(arguments, 2);\n return function() {\n const args = curryArgs.concat(Array.prototype.slice.call(arguments, 0));\n return func.apply(thisArg, args);\n };\n }\n\n function loadStyles(modifyVars) {\n const styles = document.getElementsByTagName('style');\n let style;\n\n for (let i = 0; i < styles.length; i++) {\n style = styles[i];\n if (style.type.match(typePattern)) {\n const instanceOptions = clone(options);\n instanceOptions.modifyVars = modifyVars;\n const lessText = style.innerHTML || '';\n instanceOptions.filename = document.location.href.replace(/#.*$/, '');\n\n /* jshint loopfunc:true */\n // use closure to store current style\n less.render(lessText, instanceOptions,\n bind((style, e, result) => {\n if (e) {\n errors.add(e, 'inline');\n } else {\n style.type = 'text/css';\n if (style.styleSheet) {\n style.styleSheet.cssText = result.css;\n } else {\n style.innerHTML = result.css;\n }\n }\n }, null, style));\n }\n }\n }\n\n function loadStyleSheet(sheet, callback, reload, remaining, modifyVars) {\n\n const instanceOptions = clone(options);\n addDataAttr(instanceOptions, sheet);\n instanceOptions.mime = sheet.type;\n\n if (modifyVars) {\n instanceOptions.modifyVars = modifyVars;\n }\n\n function loadInitialFileCallback(loadedFile) {\n const data = loadedFile.contents;\n const path = loadedFile.filename;\n const webInfo = loadedFile.webInfo;\n\n const newFileInfo = {\n currentDirectory: fileManager.getPath(path),\n filename: path,\n rootFilename: path,\n rewriteUrls: instanceOptions.rewriteUrls\n };\n\n newFileInfo.entryPath = newFileInfo.currentDirectory;\n newFileInfo.rootpath = instanceOptions.rootpath || newFileInfo.currentDirectory;\n\n if (webInfo) {\n webInfo.remaining = remaining;\n\n const css = cache.getCSS(path, webInfo, instanceOptions.modifyVars);\n if (!reload && css) {\n webInfo.local = true;\n callback(null, css, data, sheet, webInfo, path);\n return;\n }\n\n }\n\n // TODO add tests around how this behaves when reloading\n errors.remove(path);\n\n instanceOptions.rootFileInfo = newFileInfo;\n less.render(data, instanceOptions, (e, result) => {\n if (e) {\n e.href = path;\n callback(e);\n } else {\n cache.setCSS(sheet.href, webInfo.lastModified, instanceOptions.modifyVars, result.css);\n callback(null, result.css, data, sheet, webInfo, path);\n }\n });\n }\n\n fileManager.loadFile(sheet.href, null, instanceOptions, environment)\n .then(loadedFile => {\n loadInitialFileCallback(loadedFile);\n }).catch(err => {\n console.log(err);\n callback(err);\n });\n\n }\n\n function loadStyleSheets(callback, reload, modifyVars) {\n for (let i = 0; i < less.sheets.length; i++) {\n loadStyleSheet(less.sheets[i], callback, reload, less.sheets.length - (i + 1), modifyVars);\n }\n }\n\n function initRunningMode() {\n if (less.env === 'development') {\n less.watchTimer = setInterval(() => {\n if (less.watchMode) {\n fileManager.clearFileCache();\n loadStyleSheets((e, css, _, sheet, webInfo) => {\n if (e) {\n errors.add(e, e.href || sheet.href);\n } else if (css) {\n browser.createCSS(window.document, css, sheet);\n }\n });\n }\n }, options.poll);\n }\n }\n\n //\n // Watch mode\n //\n less.watch = function () {\n if (!less.watchMode ) {\n less.env = 'development';\n initRunningMode();\n }\n this.watchMode = true;\n return true;\n };\n\n less.unwatch = function () {clearInterval(less.watchTimer); this.watchMode = false; return false; };\n\n //\n // Synchronously get all tags with the 'rel' attribute set to\n // \"stylesheet/less\".\n //\n less.registerStylesheetsImmediately = () => {\n const links = document.getElementsByTagName('link');\n less.sheets = [];\n\n for (let i = 0; i < links.length; i++) {\n if (links[i].rel === 'stylesheet/less' || (links[i].rel.match(/stylesheet/) &&\n (links[i].type.match(typePattern)))) {\n less.sheets.push(links[i]);\n }\n }\n };\n\n //\n // Asynchronously get all tags with the 'rel' attribute set to\n // \"stylesheet/less\", returning a Promise.\n //\n less.registerStylesheets = () => new Promise((resolve, reject) => {\n less.registerStylesheetsImmediately();\n resolve();\n });\n\n //\n // With this function, it's possible to alter variables and re-render\n // CSS without reloading less-files\n //\n less.modifyVars = record => less.refresh(true, record, false);\n\n less.refresh = (reload, modifyVars, clearFileCache) => {\n if ((reload || clearFileCache) && clearFileCache !== false) {\n fileManager.clearFileCache();\n }\n return new Promise((resolve, reject) => {\n let startTime;\n let endTime;\n let totalMilliseconds;\n let remainingSheets;\n startTime = endTime = new Date();\n\n // Set counter for remaining unprocessed sheets\n remainingSheets = less.sheets.length;\n\n if (remainingSheets === 0) {\n\n endTime = new Date();\n totalMilliseconds = endTime - startTime;\n less.logger.info('Less has finished and no sheets were loaded.');\n resolve({\n startTime,\n endTime,\n totalMilliseconds,\n sheets: less.sheets.length\n });\n\n } else {\n // Relies on less.sheets array, callback seems to be guaranteed to be called for every element of the array\n loadStyleSheets((e, css, _, sheet, webInfo) => {\n if (e) {\n errors.add(e, e.href || sheet.href);\n reject(e);\n return;\n }\n if (webInfo.local) {\n less.logger.info(`Loading ${sheet.href} from cache.`);\n } else {\n less.logger.info(`Rendered ${sheet.href} successfully.`);\n }\n browser.createCSS(window.document, css, sheet);\n less.logger.info(`CSS for ${sheet.href} generated in ${new Date() - endTime}ms`);\n\n // Count completed sheet\n remainingSheets--;\n\n // Check if the last remaining sheet was processed and then call the promise\n if (remainingSheets === 0) {\n totalMilliseconds = new Date() - startTime;\n less.logger.info(`Less has finished. CSS generated in ${totalMilliseconds}ms`);\n resolve({\n startTime,\n endTime,\n totalMilliseconds,\n sheets: less.sheets.length\n });\n }\n endTime = new Date();\n }, reload, modifyVars);\n }\n\n loadStyles(modifyVars);\n });\n };\n\n less.refreshStyles = loadStyles;\n return less;\n};\n","export default (less, options) => {\n const logLevel_debug = 4;\n const logLevel_info = 3;\n const logLevel_warn = 2;\n const logLevel_error = 1;\n\n // The amount of logging in the javascript console.\n // 3 - Debug, information and errors\n // 2 - Information and errors\n // 1 - Errors\n // 0 - None\n // Defaults to 2\n options.logLevel = typeof options.logLevel !== 'undefined' ? options.logLevel : (options.env === 'development' ? logLevel_info : logLevel_error);\n\n if (!options.loggers) {\n options.loggers = [{\n debug: function(msg) {\n if (options.logLevel >= logLevel_debug) {\n console.log(msg);\n }\n },\n info: function(msg) {\n if (options.logLevel >= logLevel_info) {\n console.log(msg);\n }\n },\n warn: function(msg) {\n if (options.logLevel >= logLevel_warn) {\n console.warn(msg);\n }\n },\n error: function(msg) {\n if (options.logLevel >= logLevel_error) {\n console.error(msg);\n }\n }\n }];\n }\n for (let i = 0; i < options.loggers.length; i++) {\n less.logger.addListener(options.loggers[i]);\n }\n};\n","// Cache system is a bit outdated and could do with work\n\nexport default (window, options, logger) => {\n let cache = null;\n if (options.env !== 'development') {\n try {\n cache = (typeof window.localStorage === 'undefined') ? null : window.localStorage;\n } catch (_) {}\n }\n return {\n setCSS: function(path, lastModified, modifyVars, styles) {\n if (cache) {\n logger.info(`saving ${path} to cache.`);\n try {\n cache.setItem(path, styles);\n cache.setItem(`${path}:timestamp`, lastModified);\n if (modifyVars) {\n cache.setItem(`${path}:vars`, JSON.stringify(modifyVars));\n }\n } catch (e) {\n // TODO - could do with adding more robust error handling\n logger.error(`failed to save \"${path}\" to local storage for caching.`);\n }\n }\n },\n getCSS: function(path, webInfo, modifyVars) {\n const css = cache && cache.getItem(path);\n const timestamp = cache && cache.getItem(`${path}:timestamp`);\n let vars = cache && cache.getItem(`${path}:vars`);\n\n modifyVars = modifyVars || {};\n vars = vars || \"{}\"; // if not set, treat as the JSON representation of an empty object\n\n if (timestamp && webInfo.lastModified &&\n (new Date(webInfo.lastModified).valueOf() ===\n new Date(timestamp).valueOf()) &&\n JSON.stringify(modifyVars) === vars) {\n // Use local copy\n return css;\n }\n }\n };\n};\n","\nimport functionRegistry from './../less/functions/function-registry';\n\nexport default () => {\n function imageSize() {\n throw {\n type: 'Runtime',\n message: 'Image size functions are not supported in browser version of less'\n };\n }\n\n const imageFunctions = {\n 'image-size': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n },\n 'image-width': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n },\n 'image-height': function(filePathNode) {\n imageSize(this, filePathNode);\n return -1;\n }\n };\n\n functionRegistry.addMultiple(imageFunctions);\n};\n"],"names":["extractId","href","replace","addDataAttr","options","tag","opt","dataset","hasOwnProperty","JSON","parse","_","document","styles","sheet","id","title","utils.extractId","oldStyleNode","getElementById","keepOldStyleNode","styleNode","createElement","setAttribute","media","styleSheet","appendChild","createTextNode","childNodes","length","firstChild","nodeValue","head","getElementsByTagName","nextEl","nextSibling","parentNode","insertBefore","removeChild","cssText","e","Error","window","scripts","currentScript","error","msg","this","_fireEvent","warn","info","debug","addListener","listener","_listeners","push","removeListener","i","splice","type","logFunction","externalEnvironment","fileManagers","requiredFunctions","functions","concat","propName","environmentFunc","bind","Environment","filename","currentDirectory","environment","isSync","logger","pluginManager","getFileManagers","fileManager","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgrey","darkgreen","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","grey","green","greenyellow","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgrey","lightgreen","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","m","cm","mm","in","px","pt","pc","duration","s","ms","angle","rad","Math","PI","deg","grad","turn","colors","unitConversions","parent","visibilityBlocks","undefined","nodeVisible","rootNode","parsed","self","Object","defineProperty","get","fileInfo","getIndex","Node","nodes","set","node","Array","isArray","forEach","_index","_fileInfo","context","strs","genCSS","add","chunk","index","isEmpty","join","output","value","visitor","visit","op","a","b","precision","numPrecision","Number","toFixed","compare","Color","rgb","originalForm","match","map","c","parseInt","alpha","split","clamp","v","max","min","toHex","round","toString","prototype","assign","luma","r","g","pow","toCSS","doNotCompress","color","colorFunction","compress","args","fround","indexOf","toHSL","h","l","toRGB","splitcolor","operate","other","_operate","d","toHSV","toARGB","x","fromKeyword","keyword","key","toLowerCase","slice","Paren","eval","_noSpaceCombinators"," ","|","Combinator","emptyOrWhitespace","trim","spaceOrEmpty","Element","combinator","isVariable","currentFileInfo","visibilityInfo","copyVisibilityInfo","setParent","accept","clone","firstSelector","charAt","ALWAYS","PARENS_DIVISION","PARENS","RewriteUrls","getType","payload","call","copy","target","constructor","getPrototypeOf","il","arguments","k","j","jl","__spreadArrays","getOwnPropertyNames","getOwnPropertySymbols","reduce","carry","props","includes","newVal","originalObject","includeNonenumerable","propType","propertyIsEnumerable","enumerable","writable","configurable","assignProp","nonenumerable","getLocation","inputStream","n","line","column","copyArray","arr","obj","cloned","prop","defaults","obj1","obj2","newObj","_defaults","defaults_1","copyOptions","opts","strictMath","math","Constants.Math","relativeUrls","rewriteUrls","Constants.RewriteUrls","flattenArray","result","length_1","anonymousFunc","LessError","fileContentMap","currentFilename","message","stack","input","contents","loc","utils.getLocation","col","callLine","lines","found","func","Function","lineAdjust","callExtract","extract","create","F","stylize","str","errorTxt","substr","Selector","elements","extendList","condition","evaldCondition","getElements","mixinElements_","visitArray","createDerived","newSelector","mediaEmpty","els","parseNode","err","imports","createEmptySelectors","el","sels","olen","len","mixinElements","shift","isJustParentSelector","extend","getIsOutput","Value","Keyword","True","False","Anonymous","mapLines","rulesetLike","allowRoot","isRulesetLike","Boolean","MATH","Declaration","name","important","merge","inline","variable","lastRule","prevMath","evaldValue","mathBypass","evalName","importantScope","importantResult","pop","makeImportant","ctx","lineSeparator","dumpLineNumbers","debugInfo","asComment","asMediaQuery","lineNumber","fileName","filenameWithProtocol","test","Comment","isLineComment","getDebugInfo","isSilent","isCompressed","contexts","copyFromOriginal","original","destination","propertiesToCopy","parseCopyProperties","Parse","paths","evalCopyProperties","isPathRelative","path","isPathLocalRelative","Eval","frames","enterCalc","calcStack","inCalc","exitCalc","inParenthesis","parensStack","outOfParenthesis","mathOn","isMathOn","pathRequiresRewrite","rewritePath","rootpath","newPath","normalizePath","segment","segments","reverse","makeRegistry","base","_data","addMultiple","keys","_this","getLocalFunctions","inherit","defaultFunc","value_","error_","reset","Ruleset","selectors","rules","strictImports","_lookups","_variables","_properties","isRuleset","selCnt","selector","hasVariable","hasOnePassingSelector","toParseSelectors","utils.flattenArray","rule","subRule","utils.copyArray","ruleset","originalRuleset","root","firstRoot","allowImports","functionRegistry","globalFunctionRegistry","ctxFrames","unshift","ctxSelectors","evalImports","rsRules","evalFirst","mediaBlockCount","mediaBlocks","filter","apply","resetCache","bubbleSelectors","importRules","matchArgs","matchCondition","lastSelector","_rulesets","variables","hash","vars","name_1","properties","name_2","decl","parseValue","property","lastDeclaration","toParse","transformDeclaration","nodes_1","rulesets","filtRules","prependRule","find","foundMixins","ruleNodes","tabLevel","sep","tabRuleStr","tabSetStr","charsetNodeIndex","importNodeIndex","isCharset","pathCnt","pathSubCnt","currentLastRule","isVisible","joinSelectors","joinSelector","createParenthesis","elementsToPak","originalElement","replacementParen","insideParent","createSelector","containedElement","element","addReplacementIntoPath","beginningPath","addPath","replacedElement","originalSelector","newSelectorPath","newJoinedSelector","parentEl","restOfPath","addAllReplacementsIntoPath","addPaths","mergeElementsOnToSelectors","sel","deriveSelector","deriveFrom","newPaths","replaceParentSelector","inSelector","currentElements","newSelectors","selectorsMultiplied","maybeSelector","hadParentSelector","nestedSelector","replaced","nestedPaths","replacedNewSelectors","concatenated","AtRule","isRooted","outputRuleset","mediaPathBackup","mediaBlocksBackup","mediaPath","ruleCnt","DetachedRuleset","callEval","Unit","numerator","denominator","backupUnit","sort","strictUnits","returnStr","is","unitString","toUpperCase","isLength","RegExp","isSingular","callback","usedUnits","group","mapUnit","groupName","atomicUnit","cancel","counter","count","Dimension","unit","parseFloat","isNaN","toColor","strValue","String","convertTo","unify","numericCompare","conversions","targetUnit","applyUnit","derivedConversions","Operation","operands","isSpaced","Expression","noSpacing","returnValue","parens","doubleParen","parensInOp","throwAwayComments","functionCaller","evalArgs","commentFilter","item","subNodes","Call","calc","currentMathContext","funcCaller","FunctionCaller","isValid","columnNumber","Variable","evaluating","frame","fun","Property","mergeRules","less","visitors","ToCSSVisitor","_mergeRules","vArr","Attribute","Quoted","content","escaped","quote","variableRegex","propRegex","containsVariables","that","iterativeReplace","regexp","replacementFnc","evaluatedValue","URL","val","isEvald","urlArgs","Media","features","evalTop","evalNested","multiMedia","permute","fragment","rest","Import","css","pathValue","getPath","isPlugin","reference","isVariableImport","evalForImport","evalPath","doEval","blocksVisibility","addVisibilityBlock","registry","skip","importedFilename","newImport","JsEvalNode","evaluateJavaScript","expression","evalContext","javascriptEnabled","jsify","toJS","JavaScript","string","Assignment","Condition","negate","lvalue","rvalue","UnicodeDescriptor","Negative","Extend","option","object_id","next_id","parent_ids","allowBefore","allowAfter","findSelfSelectors","selectorElements","selfElements","selfSelectors","VariableCall","detachedRuleset","NamespaceValue","ruleCall","lookups","substring","Definition","params","variadic","arity","optionalParameters","required","p","evalParams","mixinEnv","evaldArguments","varargs","arg","isNamedFound","argIndex","argsLength","evalCall","_arguments","mixinFrames","allArgsCnt","requiredArgsCnt","MixinCall","mixins","mixin","mixinPath","argValue","f","isRecursive","isOneFound","candidate","defaultResult","noArgumentsFilter","candidates","conditionResult","calcDefGroup","namespace","expand","MixinDefinition","format","newRules","_setVisibilityToReplacement","replacement","AbstractFileManager","lastIndexOf","ext","tryAppendExtension","basePath","laterPath","url","baseUrl","urlDirectories","baseUrlDirectories","urlParts","extractUrlParts","baseUrlParts","diff","hostPart","directories","urlPartsRegex","returner","rawDirectories","rawPath","fileUrl","require","AbstractPluginLoader","pluginOptions","pluginObj","localModule","shortname","FileManager","trySetOptions","use","exports","loader","tree","validatePlugin","minVersion","compareVersion","addPlugin","plugin","setOptions","version","versionToString","aVersion","bVersion","versionString","plugins","printUsage","_visitArgs","visitDeeper","_hasIndexed","_noop","implementation","_implementation","_visitInCache","_visitOutCache","indexNodeTypes","ticker","child","typeIndex","Visitor","nodeTypeIndex","fnName","impl","funcOut","visitArgs","newNode","isReplacing","cnt","nonReplacing","out","evald","flatten","nestedCnt","nestedItem","onSequencerEmpty","variableImports","_onSequencerEmpty","_currentDepth","ImportSequencer","importSequencer","importItem","isReady","tryRun","variableImport","ImportVisitor","importer","finish","_visitor","_importer","_finish","importCount","onceFileDetectionMap","recursionDetector","_sequencer","run","isFinished","visitImport","importNode","inlineCSS","importParent","addVariableImport","processImportNode","evaldImportNode","multiple","importMultiple","tryAppendLessExtension","onImported","sequencedOnImported","addImport","importedAtRoot","fullPath","importVisitor","isOptional","optional","duplicateImport","oldContext","visitDeclaration","declNode","visitDeclarationOut","visitAtRule","atRuleNode","visitAtRuleOut","visitMixinDefinition","mixinDefinitionNode","visitMixinDefinitionOut","visitRuleset","rulesetNode","visitRulesetOut","visitMedia","mediaNode","visitMediaOut","visible","SetTreeVisibilityVisitor","ensureVisibility","ensureInvisibility","allExtendsStack","ExtendFinderVisitor","allExtends","allSelectorsExtendList","extendOnEveryPath","selectorPath","selExtendList","allSelectorsExtend","foundExtends","firstExtendOnThisSelectorPath","ProcessExtendsVisitor","extendFinder","extendIndices","doExtendChaining","newRoot","checkExtendsForNonMatched","indices","hasFoundMatches","extendsList","extendsListTarget","iterationCount","extendIndex","targetExtendIndex","matches","targetExtend","newExtend","extendsToAdd","extendVisitor","findMatch","selfSelector","extendSelector","extendChainCount","selectorOne","selectorTwo","ruleNode","selectorNode","pathIndex","selectorsToAdd","extendedSelectors","haystackSelectorPath","haystackSelectorIndex","hackstackSelector","hackstackElementIndex","haystackElement","targetCombinator","potentialMatch","needleElements","potentialMatches","matched","initialCombinator","isElementValuesEqual","finished","endPathIndex","endPathElementIndex","elementValue1","elementValue2","replacementSelector","matchIndex","firstElement","newElements","currentSelectorPathIndex","currentSelectorPathElementIndex","currentValue","derived","newAllExtends","lastIndex","JoinSelectorVisitor","_context","CSSVisitorUtils","bodyRules","owner","thing","originalRules","containsSilentNonBlockedChild","compiledRulesBody","keepOnlyVisibleChilds","removeVisibilityBlock","hasVisibleSelector","utils","mixinNode","visitExtend","extendNode","visitComment","commentNode","resolveVisibility","visitAtRuleWithBody","visitAtRuleWithoutBody","visitAnonymous","anonymousNode","nodeRules","hasFakeRuleset","getBodyRules","charset","comment","checkValidNodes","isRoot","_compileRulesetPaths","nodeRuleCnt","_removeDuplicateRules","isVisibleRuleset","ruleList","ruleCache","ruleCSS","groups","groupsArr","result_1","space_1","comma_1","MarkVisibleSelectorsVisitor","ExtendVisitor","furthest","furthestPossibleErrorMessage","chunks","current","currentPos","saveStack","parserInput","skipWhitespace","nextChar","oldi","oldj","curr","endIndex","mem","inp","charCodeAt","autoCommentAbsorb","nextNewLine","text","commentStore","nextStarSlash","save","restore","possibleErrorMessage","state","forget","isWhitespace","offset","pos","code","$re","tok","exec","$char","$str","tokLength","$quoted","startChar","currentPosition","$parseUntil","testChar","returnVal","inComment","blockDepth","blockStack","parseGroups","startPos","lastPos","loop","char","expected","peek","peekChar","currentChar","prevChar","getInput","peekNotNumeric","start","chunkInput","failFunction","fail","lastOpening","lastOpeningParen","lastMultiComment","lastMultiCommentEndBrace","chunkerCurrentIndex","currentChunkStartIndex","cc","cc2","level","parenLevel","emitFrom","emitChunk","force","fromCharCode","chunker","end","furthestReachedEnd","furthestChar","Parser","parsers","getParserInput","expect","expectChar","parseList","currentIndex","returnNodes","parser","additionalData","globalVars","modifyVars","ignored","preText","serializeVars","preProcessors","getPreProcessors","process","banner","contentsIgnoredChars","primary","endInfo","processImports","extendRule","definition","declaration","variableCall","entities","atrule","foundSemiColon","mixinLookup","quoted","forceEscaped","isEscaped","customFuncCall","stop","ieAlpha","boolean","if","prevArgs","isSemiColonSeparated","argsComma","argsSemiColon","assignment","literal","dimension","unicodeDescriptor","entity","ch","variableCurly","curly","propertyCurly","colorKeyword","ud","javascript","js","escape","parsedName","inValue","ruleLookups","isRule","getLookup","hasParens","elem","elemIndex","re","isCall","expressionContainsNamed","nameLoop","expressions","hasSep","cond","argInfo","conditions","block","lookupValue","attribute","slashedCombinator","isLess","when","blockRuleset","hasDR","ruleProperty","permissiveValue","anonymousValue","untilTokens","done","testCurrentChar","import","dir","importOptions","mediaFeatures","o","optionName","importOption","mediaFeature","pluginArgs","nonVendorSpecificName","hasIdentifier","hasExpression","hasUnknown","hasBlock","sub","addition","multiplication","operation","operand","needsParens","logical","next","conditionAnd","negatedCondition","parenthesisCondition","atomicCondition","body","me","tryConditionFollowedByParenthesis","delim","simpleProperty","If","trueValue","falseValue","isdefined","colorFunctions","hsla","origColor","hsl","number","rgba","size","m1_1","m2_1","hue","hsv","hsva","vs","floor","perm","saturation","lightness","hsvhue","hsvsaturation","hsvvalue","luminance","saturate","amount","method","desaturate","lighten","darken","fadein","fadeout","fade","spin","mix","color1","color2","weight","w","w1","w2","greyscale","contrast","dark","light","threshold","t","argb","tint","shade","colorBlend","mode","cb","cs","ar","cr","ab","as","colorBlendModeFunctions","multiply","screen","overlay","softlight","sqrt","hardlight","difference","abs","exclusion","average","negation","getItemsFromNode","_SELF","~","_i","expr","values","range","step","from","to","stepValue","list","each","rs","iterator","tryEval","Quote","valueName","keyName","indexName","MathHelper","fn","mathFunctions","ceil","sin","cos","atan","asin","acos","mathHelper","fraction","num","minMax","isMin","currentUnified","referenceUnified","unitStatic","unitClone","order","convert","pi","mod","y","percentage","evaluated","encodeURI","pattern","flags","%","token","encodeURIComponent","isa","Type","isunit","isruleset","iscolor","isnumber","isstring","iskeyword","isurl","ispixel","ispercentage","isem","get-unit","colorBlending","fallback","functionThis","data-uri","mimetypeNode","filePathNode","mimetype","filePath","entryPath","fragmentStart","utils.clone","rawBuffer","getFileManager","useBase64","mimeLookup","charsetLookup","fileSync","loadFileSync","buf","encodeBase64","uri","dataUri","svg-gradient","direction","stops","gradientDirectionSvg","position","positionValue","gradientType","rectangleDimension","renderEnv","directionValue","throwArgumentDescriptor","types","evaldRoot","evalEnv","visitorIterator","preEvalVisitors","first","isPreEvalVisitor","isPreVisitor","pm","postProcessors","installedPlugins","pluginCache","Loader","PluginLoader","PluginManager","install","preProcessor","priority","indexToInsertAt","postProcessor","manager","PluginManagerFactory","newFactory","major","minor","patch","pre","build","sourceMapOutput","sourceMapBuilder","parseTree","importManager","SourceMapBuilder","ParseTree","transformTree","toCSSOptions","sourceMap","getPostProcessors","file","getExternalSourceMap","files","rootFilename","SourceMapOutput","contentsIgnoredCharsMap","contentsMap","sourceMapFilename","sourceMapURL","outputFilename","sourceMapOutputFilename","sourceMapBasepath","sourceMapRootpath","outputSourceFiles","sourceMapGenerator","sourceMapFileInline","disableSourcemapAnnotation","sourceMapInputFilename","normalizeFilename","removeBasepath","getCSSAppendage","_css","_rootNode","_contentsMap","_contentsIgnoredCharsMap","_sourceMapFilename","_outputFilename","_sourceMapBasepath","_sourceMapRootpath","_outputSourceFiles","_sourceMapGeneratorConstructor","getSourceMapGenerator","_lineNumber","_column","sourceLines","columns","sourceColumns","inputSource","_sourceMapGenerator","addMapping","generated","source","sourceRoot","setSourceContent","sourceMapContent","stringify","toJSON","rootFileInfo","mime","queue","ImportManager","pluginLoader","fileParsedFunc","importedEqualsRoot","newFileInfo","loadedFile","promise","loadFileCallback","resolvedFilename","pathDiff","isPathAbsolute","alwaysMakePathsAbsolute","newEnv","evalPlugin","syncImport","loadPluginSync","loadPlugin","loadFile","then","render","utils.copyOptions","self_1","Promise","resolve","reject","Render","context_1","pluginManager_1","reUsePluginManager","imports_1","evalResult","fileContent","parseVersion","initial","data","ctor","api","fileCache","doXHR","errback","xhr","XMLHttpRequest","async","isFileProtocol","fileAsync","handleResponse","status","responseText","getResponseHeader","overrideMimeType","open","setRequestHeader","send","onreadystatechange","readyState","supports","clearFileCache","location","useFileCache","lessText","webInfo","lastModified","Date","log","fulfill","catch","rootHref","errorReporting","errors","errorline","classname","logLevel","errorConsole","timer","filenameNoPath","className","innerHTML","browser","style","env","setInterval","replaceChild","clearInterval","errorHTML","remove","removeErrorHTML","depends","lint","insecure","protocol","poll","hostname","port","onReady","addDefaultOptions","LESS_PLUGINS","lessRoot","FM","addFileManager","loggers","console","LogListener","ErrorReporting","cache","localStorage","setCSS","setItem","getCSS","getItem","timestamp","valueOf","Cache","imageSize","imageFunctions","image-size","image-width","image-height","ImageSize","typePattern","thisArg","curryArgs","loadStyles","instanceOptions","loadStyleSheet","reload","remaining","local","loadInitialFileCallback","loadStyleSheets","sheets","watch","watchMode","watchTimer","unwatch","registerStylesheetsImmediately","links","rel","registerStylesheets","record","refresh","startTime","endTime","totalMilliseconds","remainingSheets","refreshStyles","resolveOrReject","pageLoadFinished"],"mappings":";;;;;;;;;oMACgBA,EAAUC,GACtB,OAAOA,EAAKC,QAAQ,sBAAuB,IACtCA,QAAQ,uBAAwB,IAChCA,QAAQ,MAAO,IACfA,QAAQ,eAAgB,IACxBA,QAAQ,aAAc,KACtBA,QAAQ,MAAO,cAGRC,EAAYC,EAASC,GACjC,IAAK,IAAMC,KAAOD,EAAIE,QAClB,GAAIF,EAAIE,QAAQC,eAAeF,GAC3B,GAAY,QAARA,GAAyB,oBAARA,GAAqC,aAARA,GAA8B,mBAARA,EACpEF,EAAQE,GAAOD,EAAIE,QAAQD,QAE3B,IACIF,EAAQE,GAAOG,KAAKC,MAAML,EAAIE,QAAQD,IAE1C,MAAOK,WChBR,SAAUC,EAAUC,EAAQC,GAEnC,IAAMb,EAAOa,EAAMb,MAAQ,GAGrBc,EAAK,SAAQD,EAAME,OAASC,EAAgBhB,IAG5CiB,EAAeN,EAASO,eAAeJ,GACzCK,GAAmB,EAGjBC,EAAYT,EAASU,cAAc,SACzCD,EAAUE,aAAa,OAAQ,YAC3BT,EAAMU,OACNH,EAAUE,aAAa,QAAST,EAAMU,OAE1CH,EAAUN,GAAKA,EAEVM,EAAUI,aACXJ,EAAUK,YAAYd,EAASe,eAAed,IAG9CO,EAAqC,OAAjBF,GAAyBA,EAAaU,WAAWC,OAAS,GAAKR,EAAUO,WAAWC,OAAS,GAC7GX,EAAaY,WAAWC,YAAcV,EAAUS,WAAWC,WAGnE,IAAMC,EAAOpB,EAASqB,qBAAqB,QAAQ,GAInD,GAAqB,OAAjBf,IAA8C,IAArBE,EAA4B,CACrD,IAAMc,EAASpB,GAASA,EAAMqB,aAAe,KACzCD,EACAA,EAAOE,WAAWC,aAAahB,EAAWa,GAE1CF,EAAKN,YAAYL,GAUzB,GAPIH,IAAqC,IAArBE,GAChBF,EAAakB,WAAWE,YAAYpB,GAMpCG,EAAUI,WACV,IACIJ,EAAUI,WAAWc,QAAU1B,EACjC,MAAO2B,GACL,MAAM,IAAIC,MAAM,6CAIb,SAASC,GACpB,IAEUC,EAFJ/B,EAAW8B,EAAO9B,SACxB,OAAOA,EAASgC,gBACND,EAAU/B,EAASqB,qBAAqB,WAC/BU,EAAQd,OAAS,MC7D7B,CACXgB,MAAO,SAASC,GACZC,KAAKC,WAAW,QAASF,IAE7BG,KAAM,SAASH,GACXC,KAAKC,WAAW,OAAQF,IAE5BI,KAAM,SAASJ,GACXC,KAAKC,WAAW,OAAQF,IAE5BK,MAAO,SAASL,GACZC,KAAKC,WAAW,QAASF,IAE7BM,YAAa,SAASC,GAClBN,KAAKO,WAAWC,KAAKF,IAEzBG,eAAgB,SAASH,GACrB,IAAK,IAAII,EAAI,EAAGA,EAAIV,KAAKO,WAAWzB,OAAQ4B,IACxC,GAAIV,KAAKO,WAAWG,KAAOJ,EAEvB,YADAN,KAAKO,WAAWI,OAAOD,EAAG,IAKtCT,WAAY,SAASW,EAAMb,GACvB,IAAK,IAAIW,EAAI,EAAGA,EAAIV,KAAKO,WAAWzB,OAAQ4B,IAAK,CAC7C,IAAMG,EAAcb,KAAKO,WAAWG,GAAGE,GACnCC,GACAA,EAAYd,KAIxBQ,WAAY,iBCxBZ,WAAYO,EAAqBC,GAC7Bf,KAAKe,aAAeA,GAAgB,GACpCD,EAAsBA,GAAuB,GAM7C,IAJA,IACME,EAAoB,GACpBC,EAAYD,EAAkBE,OAFV,CAAC,eAAgB,aAAc,gBAAiB,0BAIjER,EAAI,EAAGA,EAAIO,EAAUnC,OAAQ4B,IAAK,CACvC,IAAMS,EAAWF,EAAUP,GACrBU,EAAkBN,EAAoBK,GACxCC,EACApB,KAAKmB,GAAYC,EAAgBC,KAAKP,GAC/BJ,EAAIM,EAAkBlC,QAC7BkB,KAAKE,KAAK,8CAA8CiB,IAkCxE,OA7BIG,2BAAA,SAAeC,EAAUC,EAAkBnE,EAASoE,EAAaC,GAExDH,GACDI,EAAOzB,KAAK,kFAEQ,MAApBsB,GACAG,EAAOzB,KAAK,qFAGhB,IAAIa,EAAef,KAAKe,aACpB1D,EAAQuE,gBACRb,EAAe,GAAGG,OAAOH,GAAcG,OAAO7D,EAAQuE,cAAcC,oBAExE,IAAK,IAAInB,EAAIK,EAAajC,OAAS,EAAG4B,GAAK,EAAIA,IAAK,CAChD,IAAMoB,EAAcf,EAAaL,GACjC,GAAIoB,EAAYJ,EAAS,eAAiB,YAAYH,EAAUC,EAAkBnE,EAASoE,GACvF,OAAOK,EAGf,OAAO,MAGXR,2BAAA,SAAeQ,GACX9B,KAAKe,aAAaP,KAAKsB,IAG3BR,8BAAA,WACItB,KAAKe,aAAe,WCtDb,CACXgB,UAAY,UACZC,aAAe,UACfC,KAAO,UACPC,WAAa,UACbC,MAAQ,UACRC,MAAQ,UACRC,OAAS,UACTC,MAAQ,UACRC,eAAiB,UACjBC,KAAO,UACPC,WAAa,UACbC,MAAQ,UACRC,UAAY,UACZC,UAAY,UACZC,WAAa,UACbC,UAAY,UACZC,MAAQ,UACRC,eAAiB,UACjBC,SAAW,UACXC,QAAU,UACVC,KAAO,UACPC,SAAW,UACXC,SAAW,UACXC,cAAgB,UAChBC,SAAW,UACXC,SAAW,UACXC,UAAY,UACZC,UAAY,UACZC,YAAc,UACdC,eAAiB,UACjBC,WAAa,UACbC,WAAa,UACbC,QAAU,UACVC,WAAa,UACbC,aAAe,UACfC,cAAgB,UAChBC,cAAgB,UAChBC,cAAgB,UAChBC,cAAgB,UAChBC,WAAa,UACbC,SAAW,UACXC,YAAc,UACdC,QAAU,UACVC,QAAU,UACVC,WAAa,UACbC,UAAY,UACZC,YAAc,UACdC,YAAc,UACdC,QAAU,UACVC,UAAY,UACZC,WAAa,UACbC,KAAO,UACPC,UAAY,UACZC,KAAO,UACPC,KAAO,UACPC,MAAQ,UACRC,YAAc,UACdC,SAAW,UACXC,QAAU,UACVC,UAAY,UACZC,OAAS,UACTC,MAAQ,UACRC,MAAQ,UACRC,SAAW,UACXC,cAAgB,UAChBC,UAAY,UACZC,aAAe,UACfC,UAAY,UACZC,WAAa,UACbC,UAAY,UACZC,qBAAuB,UACvBC,UAAY,UACZC,UAAY,UACZC,WAAa,UACbC,UAAY,UACZC,YAAc,UACdC,cAAgB,UAChBC,aAAe,UACfC,eAAiB,UACjBC,eAAiB,UACjBC,eAAiB,UACjBC,YAAc,UACdC,KAAO,UACPC,UAAY,UACZC,MAAQ,UACRC,QAAU,UACVC,OAAS,UACTC,iBAAmB,UACnBC,WAAa,UACbC,aAAe,UACfC,aAAe,UACfC,eAAiB,UACjBC,gBAAkB,UAClBC,kBAAoB,UACpBC,gBAAkB,UAClBC,gBAAkB,UAClBC,aAAe,UACfC,UAAY,UACZC,UAAY,UACZC,SAAW,UACXC,YAAc,UACdC,KAAO,UACPC,QAAU,UACVC,MAAQ,UACRC,UAAY,UACZC,OAAS,UACTC,UAAY,UACZC,OAAS,UACTC,cAAgB,UAChBC,UAAY,UACZC,cAAgB,UAChBC,cAAgB,UAChBC,WAAa,UACbC,UAAY,UACZC,KAAO,UACPC,KAAO,UACPC,KAAO,UACPC,WAAa,UACbC,OAAS,UACTC,cAAgB,UAChBC,IAAM,UACNC,UAAY,UACZC,UAAY,UACZC,YAAc,UACdC,OAAS,UACTC,WAAa,UACbC,SAAW,UACXC,SAAW,UACXC,OAAS,UACTC,OAAS,UACTC,QAAU,UACVC,UAAY,UACZC,UAAY,UACZC,UAAY,UACZC,KAAO,UACPC,YAAc,UACdC,UAAY,UACZC,IAAM,UACNC,KAAO,UACPC,QAAU,UACVC,OAAS,UACTC,UAAY,UACZC,OAAS,UACTC,MAAQ,UACRC,MAAQ,UACRC,WAAa,UACbC,OAAS,UACTC,YAAc,aCpJH,CACXpM,OAAQ,CACJqM,EAAK,EACLC,GAAM,IACNC,GAAM,KACNC,GAAM,MACNC,GAAM,MAAS,GACfC,GAAM,MAAS,GACfC,GAAM,MAAS,GAAK,IAExBC,SAAU,CACNC,EAAK,EACLC,GAAM,MAEVC,MAAO,CACHC,IAAO,GAAK,EAAIC,KAAKC,IACrBC,IAAO,EAAI,IACXC,KAAQ,EAAI,IACZC,KAAQ,MCfD,CAAEC,SAAQC,gCCIrB,aACIrM,KAAKsM,OAAS,KACdtM,KAAKuM,sBAAmBC,EACxBxM,KAAKyM,iBAAcD,EACnBxM,KAAK0M,SAAW,KAChB1M,KAAK2M,OAAS,KAEd,IAAMC,EAAO5M,KACb6M,OAAOC,eAAe9M,KAAM,kBAAmB,CAC3C+M,IAAK,WAAa,OAAOH,EAAKI,cAElCH,OAAOC,eAAe9M,KAAM,QAAS,CACjC+M,IAAK,WAAa,OAAOH,EAAKK,cAmK1C,OA9JIC,sBAAA,SAAUC,EAAOb,GACb,SAASc,EAAIC,GACLA,GAAQA,aAAgBH,IACxBG,EAAKf,OAASA,GAGlBgB,MAAMC,QAAQJ,GACdA,EAAMK,QAAQJ,GAGdA,EAAID,IAIZD,qBAAA,WACI,OAAOlN,KAAKyN,QAAWzN,KAAKsM,QAAUtM,KAAKsM,OAAOW,YAAe,GAGrEC,qBAAA,WACI,OAAOlN,KAAK0N,WAAc1N,KAAKsM,QAAUtM,KAAKsM,OAAOU,YAAe,IAGxEE,0BAAA,WAAkB,OAAO,GAEzBA,kBAAA,SAAMS,GACF,IAAMC,EAAO,GASb,OARA5N,KAAK6N,OAAOF,EAAS,CACjBG,IAAK,SAASC,EAAOf,EAAUgB,GAC3BJ,EAAKpN,KAAKuN,IAEdE,QAAS,WACL,OAAuB,IAAhBL,EAAK9O,UAGb8O,EAAKM,KAAK,KAGrBhB,mBAAA,SAAOS,EAASQ,GACZA,EAAOL,IAAI9N,KAAKoO,QAGpBlB,mBAAA,SAAOmB,GACHrO,KAAKoO,MAAQC,EAAQC,MAAMtO,KAAKoO,QAGpClB,iBAAA,WAAS,OAAOlN,MAEhBkN,qBAAA,SAASS,EAASY,EAAIC,EAAGC,GACrB,OAAQF,GACJ,IAAK,IAAK,OAAOC,EAAIC,EACrB,IAAK,IAAK,OAAOD,EAAIC,EACrB,IAAK,IAAK,OAAOD,EAAIC,EACrB,IAAK,IAAK,OAAOD,EAAIC,IAI7BvB,mBAAA,SAAOS,EAASS,GACZ,IAAMM,EAAYf,GAAWA,EAAQgB,aAErC,OAAO,EAAcC,QAAQR,EAAQ,OAAOS,QAAQH,IAAcN,GAG/DlB,UAAP,SAAesB,EAAGC,GAOd,GAAKD,EAAS,SAGG,WAAXC,EAAE7N,MAAgC,cAAX6N,EAAE7N,KAC3B,OAAO4N,EAAEM,QAAQL,GACd,GAAIA,EAAEK,QACT,OAAQL,EAAEK,QAAQN,GACf,GAAIA,EAAE5N,OAAS6N,EAAE7N,KAAjB,CAMP,GAFA4N,EAAIA,EAAEJ,MACNK,EAAIA,EAAEL,OACDd,MAAMC,QAAQiB,GACf,OAAOA,IAAMC,EAAI,OAAIjC,EAEzB,GAAIgC,EAAE1P,SAAW2P,EAAE3P,OAAnB,CAGA,IAAK,IAAI4B,EAAI,EAAGA,EAAI8N,EAAE1P,OAAQ4B,IAC1B,GAAiC,IAA7BwM,EAAK4B,QAAQN,EAAE9N,GAAI+N,EAAE/N,IACrB,OAGR,OAAO,KAGJwM,iBAAP,SAAsBsB,EAAGC,GACrB,OAAOD,EAAMC,GAAK,EACZD,IAAMC,EAAK,EACPD,EAAMC,EAAK,OAAIjC,GAI7BU,6BAAA,WAII,OAH6B,MAAzBlN,KAAKuM,mBACLvM,KAAKuM,iBAAmB,GAEK,IAA1BvM,KAAKuM,kBAGhBW,+BAAA,WACiC,MAAzBlN,KAAKuM,mBACLvM,KAAKuM,iBAAmB,GAE5BvM,KAAKuM,iBAAmBvM,KAAKuM,iBAAmB,GAGpDW,kCAAA,WACiC,MAAzBlN,KAAKuM,mBACLvM,KAAKuM,iBAAmB,GAE5BvM,KAAKuM,iBAAmBvM,KAAKuM,iBAAmB,GAKpDW,6BAAA,WACIlN,KAAKyM,aAAc,GAKvBS,+BAAA,WACIlN,KAAKyM,aAAc,GAOvBS,sBAAA,WACI,OAAOlN,KAAKyM,aAGhBS,2BAAA,WACI,MAAO,CACHX,iBAAkBvM,KAAKuM,iBACvBE,YAAazM,KAAKyM,cAI1BS,+BAAA,SAAmB/M,GACVA,IAGLH,KAAKuM,iBAAmBpM,EAAKoM,iBAC7BvM,KAAKyM,YAActM,EAAKsM,mBC9K1BsC,EAAQ,SAASC,EAAKR,EAAGS,GAC3B,IAAMrC,EAAO5M,KAOTsN,MAAMC,QAAQyB,GACdhP,KAAKgP,IAAMA,EACJA,EAAIlQ,QAAU,GACrBkB,KAAKgP,IAAM,GACXA,EAAIE,MAAM,SAASC,KAAI,SAAUC,EAAG1O,GAC5BA,EAAI,EACJkM,EAAKoC,IAAIxO,KAAK6O,SAASD,EAAG,KAE1BxC,EAAK0C,MAASD,SAASD,EAAG,IAAO,SAIzCpP,KAAKgP,IAAM,GACXA,EAAIO,MAAM,IAAIJ,KAAI,SAAUC,EAAG1O,GACvBA,EAAI,EACJkM,EAAKoC,IAAIxO,KAAK6O,SAASD,EAAIA,EAAG,KAE9BxC,EAAK0C,MAASD,SAASD,EAAIA,EAAG,IAAO,QAIjDpP,KAAKsP,MAAQtP,KAAKsP,QAAuB,iBAANd,EAAiBA,EAAI,QAC5B,IAAjBS,IACPjP,KAAKoO,MAAQa,IA8LrB,SAASO,EAAMC,EAAGC,GACd,OAAO3D,KAAK4D,IAAI5D,KAAK2D,IAAID,EAAG,GAAIC,GAGpC,SAASE,EAAMH,GACX,MAAO,IAAIA,EAAEN,KAAI,SAAUC,GAEvB,QADAA,EAAII,EAAMzD,KAAK8D,MAAMT,GAAI,MACb,GAAK,IAAM,IAAMA,EAAEU,SAAS,OACzC5B,KAAK,IAlMZa,EAAMgB,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACxCtM,KAAM,QAENqP,gBACI,IAAIC,EAAIlQ,KAAKgP,IAAI,GAAK,IAAKmB,EAAInQ,KAAKgP,IAAI,GAAK,IAAKP,EAAIzO,KAAKgP,IAAI,GAAK,IAMpE,MAAO,OAJPkB,EAAKA,GAAK,OAAWA,EAAI,MAAQnE,KAAKqE,KAAMF,EAAI,MAAS,MAAQ,MAI7C,OAHpBC,EAAKA,GAAK,OAAWA,EAAI,MAAQpE,KAAKqE,KAAMD,EAAI,MAAS,MAAQ,MAGhC,OAFjC1B,EAAKA,GAAK,OAAWA,EAAI,MAAQ1C,KAAKqE,KAAM3B,EAAI,MAAS,MAAQ,OAKrEZ,gBAAOF,EAASQ,GACZA,EAAOL,IAAI9N,KAAKqQ,MAAM1C,KAG1B0C,eAAM1C,EAAS2C,GACX,IACIC,EACAjB,EACAkB,EAHEC,EAAW9C,GAAWA,EAAQ8C,WAAaH,EAI7CI,EAAO,GAOX,GAFApB,EAAQtP,KAAK2Q,OAAOhD,EAAS3N,KAAKsP,OAE9BtP,KAAKoO,MACL,GAAkC,IAA9BpO,KAAKoO,MAAMwC,QAAQ,OACftB,EAAQ,IACRkB,EAAgB,YAEjB,CAAA,GAAkC,IAA9BxQ,KAAKoO,MAAMwC,QAAQ,OAO1B,OAAO5Q,KAAKoO,MALRoC,EADAlB,EAAQ,EACQ,OAEA,WAMpBA,EAAQ,IACRkB,EAAgB,QAIxB,OAAQA,GACJ,IAAK,OACDE,EAAO1Q,KAAKgP,IAAIG,KAAI,SAAUC,GAC1B,OAAOI,EAAMzD,KAAK8D,MAAMT,GAAI,QAC7BlO,OAAOsO,EAAMF,EAAO,IACvB,MACJ,IAAK,OACDoB,EAAKlQ,KAAKgP,EAAMF,EAAO,IAC3B,IAAK,MACDiB,EAAQvQ,KAAK6Q,QACbH,EAAO,CACH1Q,KAAK2Q,OAAOhD,EAAS4C,EAAMO,GACxB9Q,KAAK2Q,OAAOhD,EAAmB,IAAV4C,EAAM5E,OAC3B3L,KAAK2Q,OAAOhD,EAAmB,IAAV4C,EAAMQ,QAChC7P,OAAOwP,GAGjB,GAAIF,EAEA,OAAUA,MAAiBE,EAAKxC,KAAK,KAAIuC,EAAW,GAAK,UAK7D,GAFAF,EAAQvQ,KAAKgR,QAETP,EAAU,CACV,IAAMQ,EAAaV,EAAMhB,MAAM,IAG3B0B,EAAW,KAAOA,EAAW,IAAMA,EAAW,KAAOA,EAAW,IAAMA,EAAW,KAAOA,EAAW,KACnGV,EAAQ,IAAIU,EAAW,GAAKA,EAAW,GAAKA,EAAW,IAI/D,OAAOV,GASXW,iBAAQvD,EAASY,EAAI4C,GAGjB,IAFA,IAAMnC,EAAM,IAAI1B,MAAM,GAChBgC,EAAQtP,KAAKsP,OAAS,EAAI6B,EAAM7B,OAAS6B,EAAM7B,MAC5CF,EAAI,EAAGA,EAAI,EAAGA,IACnBJ,EAAII,GAAKpP,KAAKoR,SAASzD,EAASY,EAAIvO,KAAKgP,IAAII,GAAI+B,EAAMnC,IAAII,IAE/D,OAAO,IAAIL,EAAMC,EAAKM,IAG1B0B,iBACI,OAAOpB,EAAM5P,KAAKgP,MAGtB6B,iBACI,IAGIC,EACAnF,EAJEuE,EAAIlQ,KAAKgP,IAAI,GAAK,IAAKmB,EAAInQ,KAAKgP,IAAI,GAAK,IAAKP,EAAIzO,KAAKgP,IAAI,GAAK,IAAKR,EAAIxO,KAAKsP,MAE9EI,EAAM3D,KAAK2D,IAAIQ,EAAGC,EAAG1B,GAAIkB,EAAM5D,KAAK4D,IAAIO,EAAGC,EAAG1B,GAG9CsC,GAAKrB,EAAMC,GAAO,EAClB0B,EAAI3B,EAAMC,EAEhB,GAAID,IAAQC,EACRmB,EAAInF,EAAI,MACL,CAGH,OAFAA,EAAIoF,EAAI,GAAMM,GAAK,EAAI3B,EAAMC,GAAO0B,GAAK3B,EAAMC,GAEvCD,GACJ,KAAKQ,EAAGY,GAAKX,EAAI1B,GAAK4C,GAAKlB,EAAI1B,EAAI,EAAI,GAAI,MAC3C,KAAK0B,EAAGW,GAAKrC,EAAIyB,GAAKmB,EAAI,EAAiB,MAC3C,KAAK5C,EAAGqC,GAAKZ,EAAIC,GAAKkB,EAAI,EAE9BP,GAAK,EAET,MAAO,CAAEA,EAAO,IAAJA,EAASnF,IAAGoF,IAAGvC,MAI/B8C,iBACI,IAGIR,EACAnF,EAJEuE,EAAIlQ,KAAKgP,IAAI,GAAK,IAAKmB,EAAInQ,KAAKgP,IAAI,GAAK,IAAKP,EAAIzO,KAAKgP,IAAI,GAAK,IAAKR,EAAIxO,KAAKsP,MAE9EI,EAAM3D,KAAK2D,IAAIQ,EAAGC,EAAG1B,GAAIkB,EAAM5D,KAAK4D,IAAIO,EAAGC,EAAG1B,GAG9CgB,EAAIC,EAEJ2B,EAAI3B,EAAMC,EAOhB,GALIhE,EADQ,IAAR+D,EACI,EAEA2B,EAAI3B,EAGRA,IAAQC,EACRmB,EAAI,MACD,CACH,OAAQpB,GACJ,KAAKQ,EAAGY,GAAKX,EAAI1B,GAAK4C,GAAKlB,EAAI1B,EAAI,EAAI,GAAI,MAC3C,KAAK0B,EAAGW,GAAKrC,EAAIyB,GAAKmB,EAAI,EAAG,MAC7B,KAAK5C,EAAGqC,GAAKZ,EAAIC,GAAKkB,EAAI,EAE9BP,GAAK,EAET,MAAO,CAAEA,EAAO,IAAJA,EAASnF,IAAG8D,IAAGjB,MAG/B+C,kBACI,OAAO3B,EAAM,CAAc,IAAb5P,KAAKsP,OAAapO,OAAOlB,KAAKgP,OAGhDF,iBAAQ0C,GACJ,OAAQA,EAAExC,KACNwC,EAAExC,IAAI,KAAOhP,KAAKgP,IAAI,IACtBwC,EAAExC,IAAI,KAAOhP,KAAKgP,IAAI,IACtBwC,EAAExC,IAAI,KAAOhP,KAAKgP,IAAI,IACtBwC,EAAElC,QAAWtP,KAAKsP,MAAS,OAAI9C,KAI3CuC,EAAM0C,YAAc,SAASC,GACzB,IAAItC,EACEuC,EAAMD,EAAQE,cAQpB,GAPIxF,EAAO3O,eAAekU,GACtBvC,EAAI,IAAIL,EAAM3C,EAAOuF,GAAKE,MAAM,IAEnB,gBAARF,IACLvC,EAAI,IAAIL,EAAM,CAAC,EAAG,EAAG,GAAI,IAGzBK,EAEA,OADAA,EAAEhB,MAAQsD,EACHtC,GC7Nf,IAAM0C,EAAQ,SAASzE,GACnBrN,KAAKoO,MAAQf,GAGjByE,EAAM/B,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACxCtM,KAAM,QAENiN,gBAAOF,EAASQ,GACZA,EAAOL,IAAI,KACX9N,KAAKoO,MAAMP,OAAOF,EAASQ,GAC3BA,EAAOL,IAAI,MAGfiE,cAAKpE,GACD,OAAO,IAAImE,EAAM9R,KAAKoO,MAAM2D,KAAKpE,OCfzC,IAAMqE,EAAsB,CACxB,IAAI,EACJC,KAAK,EACLC,KAAK,GAGHC,EAAa,SAAS/D,GACV,MAAVA,GACApO,KAAKoO,MAAQ,IACbpO,KAAKoS,mBAAoB,IAEzBpS,KAAKoO,MAAQA,EAAQA,EAAMiE,OAAS,GACpCrS,KAAKoS,kBAAmC,KAAfpS,KAAKoO,QAItC+D,EAAWpC,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC7CtM,KAAM,aAENiN,gBAAOF,EAASQ,GACZ,IAAMmE,EAAgB3E,EAAQ8C,UAAYuB,EAAoBhS,KAAKoO,OAAU,GAAK,IAClFD,EAAOL,IAAIwE,EAAetS,KAAKoO,MAAQkE,MClB/C,IAAMC,EAAU,SAASC,EAAYpE,EAAOqE,EAAYzE,EAAO0E,EAAiBC,GAC5E3S,KAAKwS,WAAaA,aAAsBL,EACpCK,EAAa,IAAIL,EAAWK,GAG5BxS,KAAKoO,MADY,iBAAVA,EACMA,EAAMiE,OACZjE,GAGM,GAEjBpO,KAAKyS,WAAaA,EAClBzS,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAK4S,mBAAmBD,GACxB3S,KAAK6S,UAAU7S,KAAKwS,WAAYxS,OAGpCuS,EAAQxC,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC1CtM,KAAM,UAENkS,gBAAOzE,GACH,IAAMD,EAAQpO,KAAKoO,MACnBpO,KAAKwS,WAAanE,EAAQC,MAAMtO,KAAKwS,YAChB,iBAAVpE,IACPpO,KAAKoO,MAAQC,EAAQC,MAAMF,KAInC2D,cAAKpE,GACD,OAAO,IAAI4E,EAAQvS,KAAKwS,WACpBxS,KAAKoO,MAAM2D,KAAO/R,KAAKoO,MAAM2D,KAAKpE,GAAW3N,KAAKoO,MAClDpO,KAAKyS,WACLzS,KAAKiN,WACLjN,KAAKgN,WAAYhN,KAAK2S,mBAG9BI,iBACI,OAAO,IAAIR,EAAQvS,KAAKwS,WACpBxS,KAAKoO,MACLpO,KAAKyS,WACLzS,KAAKiN,WACLjN,KAAKgN,WAAYhN,KAAK2S,mBAG9B9E,gBAAOF,EAASQ,GACZA,EAAOL,IAAI9N,KAAKqQ,MAAM1C,GAAU3N,KAAKgN,WAAYhN,KAAKiN,aAG1DoD,eAAM1C,GACFA,EAAUA,GAAW,GACrB,IAAIS,EAAQpO,KAAKoO,MACX4E,EAAgBrF,EAAQqF,cAQ9B,OAPI5E,aAAiB0D,IAGjBnE,EAAQqF,eAAgB,GAE5B5E,EAAQA,EAAMiC,MAAQjC,EAAMiC,MAAM1C,GAAWS,EAC7CT,EAAQqF,cAAgBA,EACV,KAAV5E,GAAoD,MAApCpO,KAAKwS,WAAWpE,MAAM6E,OAAO,GACtC,GAEAjT,KAAKwS,WAAWnC,MAAM1C,GAAWS,KClE7C,IAAMrC,EAAO,CAChBmH,OAAQ,EACRC,gBAAiB,EACjBC,OAAQ,GAICC,EACJ,EADIA,EAEF,EAFEA,EAGJ,ECLT,SAASC,EAAQC,GACb,OAAO1G,OAAOkD,UAAUD,SAAS0D,KAAKD,GAAS1B,MAAM,GAAI,GAqF7D,SAAStE,EAAQgG,GACb,MAA4B,UAArBD,EAAQC,GC3CnB,SAASE,EAAKC,EAAQrW,GAElB,YADgB,IAAZA,IAAsBA,EAAU,IAChCkQ,EAAQmG,GACDA,EAAOvE,KAAI,SAAUzO,GAAK,OAAO+S,EAAK/S,EAAGrD,MDnB3B,WAArBiW,EADeC,ECqBAG,IDlBZH,EAAQI,cAAgB9G,QAAUA,OAAO+G,eAAeL,KAAa1G,OAAOkD,UCmBxE2D,EAtCf,WACI,IAAK,IAAI/H,EAAI,EAAGjL,EAAI,EAAGmT,EAAKC,UAAUhV,OAAQ4B,EAAImT,EAAInT,IAAKiL,GAAKmI,UAAUpT,GAAG5B,OACxE,IAAIoR,EAAI5C,MAAM3B,GAAIoI,EAAI,EAA3B,IAA8BrT,EAAI,EAAGA,EAAImT,EAAInT,IACzC,IAAK,IAAI8N,EAAIsF,UAAUpT,GAAIsT,EAAI,EAAGC,EAAKzF,EAAE1P,OAAQkV,EAAIC,EAAID,IAAKD,IAC1D7D,EAAE6D,GAAKvF,EAAEwF,GACjB,OAAO9D,EAoCAgE,CAFKrH,OAAOsH,oBAAoBT,GACzB7G,OAAOuH,sBAAsBV,IACLW,QAAO,SAAUC,EAAO3C,GAC1D,OAAIpE,EAAQlQ,EAAQkX,SAAWlX,EAAQkX,MAAMC,SAAS7C,IAlC9D,SAAoB2C,EAAO3C,EAAK8C,EAAQC,EAAgBC,GACpD,IAAIC,EAAW,GAAGC,qBAAqBrB,KAAKkB,EAAgB/C,GACtD,aACA,gBACW,eAAbiD,IACAN,EAAM3C,GAAO8C,GACbE,GAAqC,kBAAbC,GACxB/H,OAAOC,eAAewH,EAAO3C,EAAK,CAC9BvD,MAAOqG,EACPK,YAAY,EACZC,UAAU,EACVC,cAAc,IA4BlBC,CAAWX,EAAO3C,EADL8B,EADHC,EAAO/B,GACMtU,GACQqW,EAAQrW,EAAQ6X,eAJpCZ,IAMZ,IDjCP,IAAuBf,WE7BP4B,EAAYnH,EAAOoH,GAK/B,IAJA,IAAIC,EAAIrH,EAAQ,EACZsH,EAAO,KACPC,GAAU,IAELF,GAAK,GAA+B,OAA1BD,EAAYnC,OAAOoC,IAClCE,IAOJ,MAJqB,iBAAVvH,IACPsH,GAAQF,EAAYvD,MAAM,EAAG7D,GAAOkB,MAAM,QAAU,IAAIpQ,QAGrD,CACHwW,OACAC,mBAIQC,EAAUC,GACtB,IAAI/U,EACE5B,EAAS2W,EAAI3W,OACb2U,EAAO,IAAInG,MAAMxO,GAEvB,IAAK4B,EAAI,EAAGA,EAAI5B,EAAQ4B,IACpB+S,EAAK/S,GAAK+U,EAAI/U,GAElB,OAAO+S,WAGKV,EAAM2C,GAClB,IAAMC,EAAS,GACf,IAAK,IAAMC,KAAQF,EACXA,EAAIjY,eAAemY,KACnBD,EAAOC,GAAQF,EAAIE,IAG3B,OAAOD,WAGKE,EAASC,EAAMC,GAC3B,IAAIC,EAASD,GAAQ,GACrB,IAAKA,EAAKE,UAAW,CACjBD,EAAS,GACT,IAAME,EAAWzC,EAAKqC,GACtBE,EAAOC,UAAYC,EACnB,IAAMP,EAASI,EAAOtC,EAAKsC,GAAQ,GACnClJ,OAAOmD,OAAOgG,EAAQE,EAAUP,GAEpC,OAAOK,WAGKG,EAAYL,EAAMC,GAC9B,GAAIA,GAAQA,EAAKE,UACb,OAAOF,EAEX,IAAMK,EAAOP,EAASC,EAAMC,GAQ5B,GAPIK,EAAKC,aACLD,EAAKE,KAAOC,EAAenD,QAG3BgD,EAAKI,eACLJ,EAAKK,YAAcC,GAEE,iBAAdN,EAAKE,KACZ,OAAQF,EAAKE,KAAK1E,eACd,IAAK,SACDwE,EAAKE,KAAOC,EAAerD,OAC3B,MACJ,IAAK,kBACDkD,EAAKE,KAAOC,EAAepD,gBAC3B,MACJ,IAAK,SACL,IAAK,SACDiD,EAAKE,KAAOC,EAAenD,OAC3B,MACJ,QACIgD,EAAKE,KAAOC,EAAenD,OAGvC,GAAgC,iBAArBgD,EAAKK,YACZ,OAAQL,EAAKK,YAAY7E,eACrB,IAAK,MACDwE,EAAKK,YAAcC,EACnB,MACJ,IAAK,QACDN,EAAKK,YAAcC,EACnB,MACJ,IAAK,MACDN,EAAKK,YAAcC,EAI/B,OAAON,WAYKO,EAAalB,EAAKmB,gBAAAA,MAC9B,IAAK,IAAIlW,EAAI,EAAGmW,EAASpB,EAAI3W,OAAQ4B,EAAImW,EAAQnW,IAAK,CAClD,IAAM0N,EAAQqH,EAAI/U,GACd4M,MAAMC,QAAQa,GACduI,EAAavI,EAAOwI,QAENpK,IAAV4B,GACAwI,EAAOpW,KAAK4N,GAIxB,OAAOwI,gHApBWd,EAAMC,GACxB,IAAK,IAAMH,KAAQG,EACXA,EAAKtY,eAAemY,KACpBE,EAAKF,GAAQG,EAAKH,IAG1B,OAAOE,oBCxGLgB,EAAgB,qCAwBhBC,EAAY,SAAStX,EAAGuX,EAAgBC,GAC1CvX,MAAM8T,KAAKxT,MAEX,IAAMuB,EAAW9B,EAAE8B,UAAY0V,EAK/B,GAHAjX,KAAKkX,QAAUzX,EAAEyX,QACjBlX,KAAKmX,MAAQ1X,EAAE0X,MAEXH,GAAkBzV,EAAU,CAC5B,IAAM6V,EAAQJ,EAAeK,SAAS9V,GAChC+V,EAAMC,EAAkB9X,EAAEuO,MAAOoJ,GACnC9B,EAAOgC,EAAIhC,KACTkC,EAAOF,EAAI/B,OACXkC,EAAWhY,EAAE+T,MAAQ+D,EAAkB9X,EAAE+T,KAAM4D,GAAO9B,KACtDoC,EAAQN,EAAQA,EAAM7H,MAAM,MAAQ,GAQ1C,GANAvP,KAAKY,KAAOnB,EAAEmB,MAAQ,SACtBZ,KAAKuB,SAAWA,EAChBvB,KAAKgO,MAAQvO,EAAEuO,MACfhO,KAAKsV,KAAuB,iBAATA,EAAoBA,EAAO,EAAI,KAClDtV,KAAKuV,OAASiC,GAETxX,KAAKsV,MAAQtV,KAAKmX,MAAO,CAC1B,IAAMQ,EAAQ3X,KAAKmX,MAAMjI,MAAM4H,GASzBc,EAAO,IAAIC,SAAS,IAAK,qBAC3BC,EAAa,EACjB,IACIF,IACF,MAAOnY,GACL,IAAMyP,EAAQzP,EAAE0X,MAAMjI,MAAM4H,GAE5BgB,EAAa,GADTxC,EAAOjG,SAASH,EAAM,KAI1ByI,IACIA,EAAM,KACN3X,KAAKsV,KAAOjG,SAASsI,EAAM,IAAMG,GAEjCH,EAAM,KACN3X,KAAKuV,OAASlG,SAASsI,EAAM,MAKzC3X,KAAKyX,SAAWA,EAAW,EAC3BzX,KAAK+X,YAAcL,EAAMD,GAEzBzX,KAAKgY,QAAU,CACXN,EAAM1X,KAAKsV,KAAO,GAClBoC,EAAM1X,KAAKsV,KAAO,GAClBoC,EAAM1X,KAAKsV,SAMvB,QAA6B,IAAlBzI,OAAOoL,OAAwB,CACtC,IAAMC,EAAI,aACVA,EAAEnI,UAAYrQ,MAAMqQ,UACpBgH,EAAUhH,UAAY,IAAImI,OAE1BnB,EAAUhH,UAAYlD,OAAOoL,OAAOvY,MAAMqQ,WAG9CgH,EAAUhH,UAAU4D,YAAcoD,EASlCA,EAAUhH,UAAUD,SAAW,SAASzS,GACpCA,EAAUA,GAAW,GAErB,IAAI6Z,EAAU,GACRc,EAAUhY,KAAKgY,SAAW,GAC5BlY,EAAQ,GACRqY,EAAU,SAAUC,GAAO,OAAOA,GACtC,GAAI/a,EAAQ8a,QAAS,CACjB,IAAMvX,SAAcvD,EAAQ8a,QAC5B,GAAa,aAATvX,EACA,MAAMlB,MAAM,+CAA+CkB,OAE/DuX,EAAU9a,EAAQ8a,QAGtB,GAAkB,OAAdnY,KAAKsV,KAAe,CAKpB,GAJ0B,iBAAf0C,EAAQ,IACflY,EAAMU,KAAK2X,EAAWnY,KAAKsV,KAAO,MAAK0C,EAAQ,GAAM,SAG/B,iBAAfA,EAAQ,GAAiB,CAChC,IAAIK,EAAcrY,KAAKsV,SACnB0C,EAAQ,KACRK,GAAYL,EAAQ,GAAGnG,MAAM,EAAG7R,KAAKuV,QACjC4C,EAAQA,EAAQA,EAAQH,EAAQ,GAAGM,OAAOtY,KAAKuV,OAAQ,GAAI,QACvDyC,EAAQ,GAAGnG,MAAM7R,KAAKuV,OAAS,GAAI,OAAQ,YAEvDzV,EAAMU,KAAK6X,GAGW,iBAAfL,EAAQ,IACflY,EAAMU,KAAK2X,EAAWnY,KAAKsV,KAAO,MAAK0C,EAAQ,GAAM,SAEzDlY,EAAWA,EAAMoO,KAAK,MAAQiK,EAAQ,GAAI,cAkB9C,OAfAjB,GAAWiB,EAAWnY,KAAKY,eAAcZ,KAAKkX,QAAW,OACrDlX,KAAKuB,WACL2V,GAAWiB,EAAQ,OAAQ,OAASnY,KAAKuB,UAEzCvB,KAAKsV,OACL4B,GAAWiB,EAAQ,YAAYnY,KAAKsV,kBAAgBtV,KAAKuV,OAAS,OAAM,SAG5E2B,GAAW,KAAKpX,EAEZE,KAAKyX,WACLP,GAAciB,EAAQ,QAAS,QAAUnY,KAAKuB,UAAY,SAC1D2V,GAAciB,EAAQnY,KAAKyX,SAAU,YAAWzX,KAAK+X,kBAGlDb,GC1JX,IAAMqB,EAAW,SAASC,EAAUC,EAAYC,EAAW1K,EAAO0E,EAAiBC,GAC/E3S,KAAKyY,WAAaA,EAClBzY,KAAK0Y,UAAYA,EACjB1Y,KAAK2Y,gBAAkBD,EACvB1Y,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAKwY,SAAWxY,KAAK4Y,YAAYJ,GACjCxY,KAAK6Y,oBAAiBrM,EACtBxM,KAAK4S,mBAAmBD,GACxB3S,KAAK6S,UAAU7S,KAAKwY,SAAUxY,OAGlCuY,EAASxI,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC3CtM,KAAM,WAENkS,gBAAOzE,GACCrO,KAAKwY,WACLxY,KAAKwY,SAAWnK,EAAQyK,WAAW9Y,KAAKwY,WAExCxY,KAAKyY,aACLzY,KAAKyY,WAAapK,EAAQyK,WAAW9Y,KAAKyY,aAE1CzY,KAAK0Y,YACL1Y,KAAK0Y,UAAYrK,EAAQC,MAAMtO,KAAK0Y,aAI5CK,uBAAcP,EAAUC,EAAYE,GAChCH,EAAWxY,KAAK4Y,YAAYJ,GAC5B,IAAMQ,EAAc,IAAIT,EAASC,EAAUC,GAAczY,KAAKyY,WAC1D,KAAMzY,KAAKiN,WAAYjN,KAAKgN,WAAYhN,KAAK2S,kBAGjD,OAFAqG,EAAYL,eAAoC,MAAlBA,EAA0BA,EAAiB3Y,KAAK2Y,eAC9EK,EAAYC,WAAajZ,KAAKiZ,WACvBD,GAGXJ,qBAAYM,GACR,OAAKA,GAGc,iBAARA,GACPlZ,KAAKrC,MAAMwb,UACPD,EACA,CAAC,YACDlZ,KAAKyN,OACLzN,KAAK0N,WACL,SAAS0L,EAAKxC,GACV,GAAIwC,EACA,MAAM,IAAIrC,EAAU,CAChB/I,MAAOoL,EAAIpL,MACXkJ,QAASkC,EAAIlC,SACdlX,KAAKrC,MAAM0b,QAASrZ,KAAK0N,UAAUnM,UAE1C2X,EAAMtC,EAAO,GAAG4B,YAGrBU,GAlBI,CAAC,IAAI3G,EAAQ,GAAI,KAAK,EAAOvS,KAAKyN,OAAQzN,KAAK0N,aAqB9D4L,gCACI,IAAMC,EAAK,IAAIhH,EAAQ,GAAI,KAAK,EAAOvS,KAAKyN,OAAQzN,KAAK0N,WAAY8L,EAAO,CAAC,IAAIjB,EAAS,CAACgB,GAAK,KAAM,KAAMvZ,KAAKyN,OAAQzN,KAAK0N,YAE9H,OADA8L,EAAK,GAAGP,YAAa,EACdO,GAGXtK,eAAMiC,GACF,IAEIsI,EACA/Y,EAHE8X,EAAWxY,KAAKwY,SAChBkB,EAAMlB,EAAS1Z,OAMrB,GAAa,KADb2a,GADAtI,EAAQA,EAAMwI,iBACD7a,SACK4a,EAAMD,EACpB,OAAO,EAEP,IAAK/Y,EAAI,EAAGA,EAAI+Y,EAAM/Y,IAClB,GAAI8X,EAAS9X,GAAG0N,QAAU+C,EAAMzQ,GAC5B,OAAO,EAKnB,OAAO+Y,GAGXE,yBACI,GAAI3Z,KAAK6Y,eACL,OAAO7Y,KAAK6Y,eAGhB,IAAIL,EAAWxY,KAAKwY,SAASrJ,KAAK,SAASM,GACvC,OAAOA,EAAE+C,WAAWpE,OAASqB,EAAErB,MAAMA,OAASqB,EAAErB,UACjDF,KAAK,IAAIgB,MAAM,+BAUlB,OARIsJ,EACoB,MAAhBA,EAAS,IACTA,EAASoB,QAGbpB,EAAW,GAGPxY,KAAK6Y,eAAiBL,GAGlCqB,gCACI,OAAQ7Z,KAAKiZ,YACgB,IAAzBjZ,KAAKwY,SAAS1Z,QACa,MAA3BkB,KAAKwY,SAAS,GAAGpK,QACsB,MAAtCpO,KAAKwY,SAAS,GAAGhG,WAAWpE,OAAuD,KAAtCpO,KAAKwY,SAAS,GAAGhG,WAAWpE,QAGlF2D,cAAKpE,GACD,IAAMgL,EAAiB3Y,KAAK0Y,WAAa1Y,KAAK0Y,UAAU3G,KAAKpE,GACzD6K,EAAWxY,KAAKwY,SAChBC,EAAazY,KAAKyY,WAKtB,OAHAD,EAAWA,GAAYA,EAASrJ,KAAI,SAAU1P,GAAK,OAAOA,EAAEsS,KAAKpE,MACjE8K,EAAaA,GAAcA,EAAWtJ,KAAI,SAAS2K,GAAU,OAAOA,EAAO/H,KAAKpE,MAEzE3N,KAAK+Y,cAAcP,EAAUC,EAAYE,IAGpD9K,gBAAOF,EAASQ,GACZ,IAAIzN,EAIJ,IAHMiN,GAAYA,EAAQqF,eAAwD,KAAtChT,KAAKwY,SAAS,GAAGhG,WAAWpE,OACpED,EAAOL,IAAI,IAAK9N,KAAKgN,WAAYhN,KAAKiN,YAErCvM,EAAI,EAAGA,EAAIV,KAAKwY,SAAS1Z,OAAQ4B,IACxBV,KAAKwY,SAAS9X,GAChBmN,OAAOF,EAASQ,IAIhC4L,uBACI,OAAO/Z,KAAK2Y,kBC1IpB,IAAMqB,EAAQ,SAAS5L,GACnB,IAAKA,EACD,MAAM,IAAI1O,MAAM,oCAEf4N,MAAMC,QAAQa,GAIfpO,KAAKoO,MAAQA,EAHbpO,KAAKoO,MAAQ,CAAEA,IAOvB4L,EAAMjK,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACxCtM,KAAM,QAENkS,gBAAOzE,GACCrO,KAAKoO,QACLpO,KAAKoO,MAAQC,EAAQyK,WAAW9Y,KAAKoO,SAI7C2D,cAAKpE,GACD,OAA0B,IAAtB3N,KAAKoO,MAAMtP,OACJkB,KAAKoO,MAAM,GAAG2D,KAAKpE,GAEnB,IAAIqM,EAAMha,KAAKoO,MAAMe,KAAI,SAAUM,GACtC,OAAOA,EAAEsC,KAAKpE,QAK1BE,gBAAOF,EAASQ,GACZ,IAAIzN,EACJ,IAAKA,EAAI,EAAGA,EAAIV,KAAKoO,MAAMtP,OAAQ4B,IAC/BV,KAAKoO,MAAM1N,GAAGmN,OAAOF,EAASQ,GAC1BzN,EAAI,EAAIV,KAAKoO,MAAMtP,QACnBqP,EAAOL,IAAKH,GAAWA,EAAQ8C,SAAY,IAAM,SCpCjE,IAAMwJ,EAAU,SAAS7L,GACrBpO,KAAKoO,MAAQA,GAGjB6L,EAAQlK,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC1CtM,KAAM,UAENiN,gBAAOF,EAASQ,GACZ,GAAmB,MAAfnO,KAAKoO,MAAiB,KAAM,CAAExN,KAAM,SAAUsW,QAAS,4BAC3D/I,EAAOL,IAAI9N,KAAKoO,UAIxB6L,EAAQC,KAAO,IAAID,EAAQ,QAC3BA,EAAQE,MAAQ,IAAIF,EAAQ,SCd5B,IAAMG,EAAY,SAAShM,EAAOJ,EAAO0E,EAAiB2H,EAAUC,EAAa3H,GAC7E3S,KAAKoO,MAAQA,EACbpO,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAKqa,SAAWA,EAChBra,KAAKsa,iBAAsC,IAAhBA,GAAuCA,EAClEta,KAAKua,WAAY,EACjBva,KAAK4S,mBAAmBD,IAG5ByH,EAAUrK,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC5CtM,KAAM,YACNmR,gBACI,OAAO,IAAIqI,EAAUpa,KAAKoO,MAAOpO,KAAKyN,OAAQzN,KAAK0N,UAAW1N,KAAKqa,SAAUra,KAAKsa,YAAata,KAAK2S,mBAExG7D,iBAAQqC,GACJ,OAAOA,EAAMd,OAASrQ,KAAKqQ,UAAYc,EAAMd,QAAU,OAAI7D,GAE/DgO,yBACI,OAAOxa,KAAKsa,aAEhBzM,gBAAOF,EAASQ,GACZnO,KAAKyM,YAAcgO,QAAQza,KAAKoO,OAC5BpO,KAAKyM,aACL0B,EAAOL,IAAI9N,KAAKoO,MAAOpO,KAAK0N,UAAW1N,KAAKyN,OAAQzN,KAAKqa,aCrBrE,IAAMK,EAAOnE,EAab,IAAMoE,EAAc,SAASC,EAAMxM,EAAOyM,EAAWC,EAAO9M,EAAO0E,EAAiBqI,EAAQC,GACxFhb,KAAK4a,KAAOA,EACZ5a,KAAKoO,MAASA,aAAiBlB,EAAQkB,EAAQ,IAAI4L,EAAM,CAAC5L,EAAQ,IAAIgM,EAAUhM,GAAS,OACzFpO,KAAK6a,UAAYA,EAAY,IAAIA,EAAUxI,OAAW,GACtDrS,KAAK8a,MAAQA,EACb9a,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAK+a,OAASA,IAAU,EACxB/a,KAAKgb,cAAyBxO,IAAbwO,EAA0BA,EACpCJ,EAAK3H,QAA8B,MAAnB2H,EAAK3H,OAAO,GACnCjT,KAAKua,WAAY,EACjBva,KAAK6S,UAAU7S,KAAKoO,MAAOpO,OAG/B2a,EAAY5K,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC9CtM,KAAM,cAENiN,gBAAOF,EAASQ,GACZA,EAAOL,IAAI9N,KAAK4a,MAAQjN,EAAQ8C,SAAW,IAAM,MAAOzQ,KAAKgN,WAAYhN,KAAKiN,YAC9E,IACIjN,KAAKoO,MAAMP,OAAOF,EAASQ,GAE/B,MAAO1O,GAGH,MAFAA,EAAEuO,MAAQhO,KAAKyN,OACfhO,EAAE8B,SAAWvB,KAAK0N,UAAUnM,SACtB9B,EAEV0O,EAAOL,IAAI9N,KAAK6a,WAAc7a,KAAK+a,QAAWpN,EAAQsN,UAAYtN,EAAQ8C,SAAa,GAAK,KAAMzQ,KAAK0N,UAAW1N,KAAKyN,SAG3HsE,cAAKpE,GACD,IAAwBuN,EAA4BC,EAAhDC,GAAa,EAAiBR,EAAO5a,KAAK4a,KAAkBI,EAAWhb,KAAKgb,SAC5D,iBAATJ,IAGPA,EAAwB,IAAhBA,EAAK9b,QAAkB8b,EAAK,aAAcX,EAC9CW,EAAK,GAAGxM,MA/CxB,SAAkBT,EAASiN,GACvB,IACIla,EADA0N,EAAQ,GAENiH,EAAIuF,EAAK9b,OACTqP,EAAS,CAACL,IAAK,SAAUnC,GAAIyC,GAASzC,IAC5C,IAAKjL,EAAI,EAAGA,EAAI2U,EAAG3U,IACfka,EAAKla,GAAGqR,KAAKpE,GAASE,OAAOF,EAASQ,GAE1C,OAAOC,EAuCqBiN,CAAS1N,EAASiN,GACtCI,GAAW,GAIF,SAATJ,GAAmBjN,EAAQ2I,OAASoE,EAAKxH,SACzCkI,GAAa,EACbF,EAAWvN,EAAQ2I,KACnB3I,EAAQ2I,KAAOoE,EAAKvH,iBAExB,IAII,GAHAxF,EAAQ2N,eAAe9a,KAAK,IAC5B2a,EAAanb,KAAKoO,MAAM2D,KAAKpE,IAExB3N,KAAKgb,UAAgC,oBAApBG,EAAWva,KAC7B,KAAM,CAAEsW,QAAS,8CACblJ,MAAOhO,KAAKiN,WAAY1L,SAAUvB,KAAKgN,WAAWzL,UAE1D,IAAIsZ,EAAY7a,KAAK6a,UACfU,EAAkB5N,EAAQ2N,eAAeE,MAK/C,OAJKX,GAAaU,EAAgBV,YAC9BA,EAAYU,EAAgBV,WAGzB,IAAIF,EAAYC,EACnBO,EACAN,EACA7a,KAAK8a,MACL9a,KAAKiN,WAAYjN,KAAKgN,WAAYhN,KAAK+a,OACvCC,GAER,MAAOvb,GAKH,KAJuB,iBAAZA,EAAEuO,QACTvO,EAAEuO,MAAQhO,KAAKiN,WACfxN,EAAE8B,SAAWvB,KAAKgN,WAAWzL,UAE3B9B,UAGF2b,IACAzN,EAAQ2I,KAAO4E,KAK3BO,yBACI,OAAO,IAAId,EAAY3a,KAAK4a,KACxB5a,KAAKoO,MACL,aACApO,KAAK8a,MACL9a,KAAKiN,WAAYjN,KAAKgN,WAAYhN,KAAK+a,WCxGnD,iBACI,WAAYpN,EAAS+N,EAAKC,GACtB,IAAI/E,EAAS,GACb,GAAIjJ,EAAQiO,kBAAoBjO,EAAQ8C,SACpC,OAAQ9C,EAAQiO,iBACZ,IAAK,WACDhF,EAASiF,EAAUC,UAAUJ,GAC7B,MACJ,IAAK,aACD9E,EAASiF,EAAUE,aAAaL,GAChC,MACJ,IAAK,MACD9E,EAASiF,EAAUC,UAAUJ,IAAQC,GAAiB,IAAME,EAAUE,aAAaL,GAI/F,OAAO9E,EAmBf,OAhBWiF,YAAP,SAAiBH,GACb,MAAO,WAAWA,EAAIG,UAAUG,gBAAeN,EAAIG,UAAUI,kBAG1DJ,eAAP,SAAoBH,GAChB,IAAIQ,EAAuBR,EAAIG,UAAUI,SAIzC,MAHK,gBAAgBE,KAAKD,KACtBA,EAAuB,UAAUA,GAE9B,gDAAgDA,EAAqB/e,QAAQ,eAAe,SAAUqR,GAIzG,MAHS,MAALA,IACAA,EAAI,KAED,KAAKA,iCACckN,EAAIG,UAAUG,wBC9B9CI,EAAU,SAAShO,EAAOiO,EAAerO,EAAO0E,GAClD1S,KAAKoO,MAAQA,EACbpO,KAAKqc,cAAgBA,EACrBrc,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAKua,WAAY,GAGrB6B,EAAQrM,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC1CtM,KAAM,UAENiN,gBAAOF,EAASQ,GACRnO,KAAK6b,WACL1N,EAAOL,IAAIwO,EAAa3O,EAAS3N,MAAOA,KAAKgN,WAAYhN,KAAKiN,YAElEkB,EAAOL,IAAI9N,KAAKoO,QAGpBmO,kBAAS5O,GACL,IAAM6O,EAAe7O,EAAQ8C,UAA8B,MAAlBzQ,KAAKoO,MAAM,GACpD,OAAOpO,KAAKqc,eAAiBG,KCvBrC,IAAMC,EAAW,GAIXC,EAAmB,SAA0BC,EAAUC,EAAaC,GACtE,GAAKF,EAEL,IAAK,IAAIjc,EAAI,EAAGA,EAAImc,EAAiB/d,OAAQ4B,IACrCic,EAASlf,eAAeof,EAAiBnc,MACzCkc,EAAYC,EAAiBnc,IAAMic,EAASE,EAAiBnc,MAQnEoc,EAAsB,CAExB,QACA,cACA,WACA,gBACA,WACA,kBACA,WACA,aACA,aACA,OACA,eAEA,iBAEA,iBAGJL,EAASM,MAAQ,SAAS1f,GACtBqf,EAAiBrf,EAAS2C,KAAM8c,GAEN,iBAAf9c,KAAKgd,QAAsBhd,KAAKgd,MAAQ,CAAChd,KAAKgd,SAG7D,IAAMC,EAAqB,CACvB,QACA,WACA,OACA,cACA,YACA,iBACA,UACA,oBACA,gBACA,iBACA,eAsGJ,SAASC,EAAeC,GACpB,OAAQ,sBAAsBhB,KAAKgB,GAGvC,SAASC,EAAoBD,GACzB,MAA0B,MAAnBA,EAAKlK,OAAO,GAxGvBwJ,EAASY,KAAO,SAAShgB,EAASigB,GAC9BZ,EAAiBrf,EAAS2C,KAAMid,GAEN,iBAAfjd,KAAKgd,QAAsBhd,KAAKgd,MAAQ,CAAChd,KAAKgd,QAEzDhd,KAAKsd,OAASA,GAAU,GACxBtd,KAAKsb,eAAiBtb,KAAKsb,gBAAkB,IAGjDmB,EAASY,KAAKtN,UAAUwN,UAAY,WAC3Bvd,KAAKwd,YACNxd,KAAKwd,UAAY,IAErBxd,KAAKwd,UAAUhd,MAAK,GACpBR,KAAKyd,QAAS,GAGlBhB,EAASY,KAAKtN,UAAU2N,SAAW,WAC/B1d,KAAKwd,UAAUhC,MACVxb,KAAKwd,UAAU1e,SAChBkB,KAAKyd,QAAS,IAItBhB,EAASY,KAAKtN,UAAU4N,cAAgB,WAC/B3d,KAAK4d,cACN5d,KAAK4d,YAAc,IAEvB5d,KAAK4d,YAAYpd,MAAK,IAG1Bic,EAASY,KAAKtN,UAAU8N,iBAAmB,WACvC7d,KAAK4d,YAAYpC,OAGrBiB,EAASY,KAAKtN,UAAU0N,QAAS,EACjChB,EAASY,KAAKtN,UAAU+N,QAAS,EACjCrB,EAASY,KAAKtN,UAAUgO,SAAW,SAAUxP,GACzC,QAAKvO,KAAK8d,YAGC,MAAPvP,GAAcvO,KAAKsW,OAASC,EAAerD,QAAYlT,KAAK4d,aAAgB5d,KAAK4d,YAAY9e,YAG7FkB,KAAKsW,KAAOC,EAAepD,kBACpBnT,KAAK4d,aAAe5d,KAAK4d,YAAY9e,UAKpD2d,EAASY,KAAKtN,UAAUiO,oBAAsB,SAAUb,GAGpD,OAFmBnd,KAAKyW,cAAgBC,EAA8B0G,EAAsBF,GAE1EC,IAGtBV,EAASY,KAAKtN,UAAUkO,YAAc,SAAUd,EAAMe,GAClD,IAAIC,EAaJ,OAXAD,EAAWA,GAAY,GACvBC,EAAUne,KAAKoe,cAAcF,EAAWf,GAIpCC,EAAoBD,IACpBD,EAAegB,KACkB,IAAjCd,EAAoBe,KACpBA,EAAU,KAAKA,GAGZA,GAGX1B,EAASY,KAAKtN,UAAUqO,cAAgB,SAAUjB,GAC9C,IACIkB,EADEC,EAAWnB,EAAK5N,MAAM,KAAKgP,UAIjC,IADApB,EAAO,GACoB,IAApBmB,EAASxf,QAEZ,OADAuf,EAAUC,EAAS9C,OAEf,IAAK,IACD,MACJ,IAAK,KACoB,IAAhB2B,EAAKre,QAA4C,OAA1Bqe,EAAKA,EAAKre,OAAS,GAC3Cqe,EAAK3c,KAAM6d,GAEXlB,EAAK3B,MAET,MACJ,QACI2B,EAAK3c,KAAK6d,GAKtB,OAAOlB,EAAKjP,KAAK,YCxJrB,SAASsQ,EAAcC,GACnB,MAAO,CACHC,MAAO,GACP5Q,IAAK,SAAS8M,EAAMhD,GAGhBgD,EAAOA,EAAKhJ,cAER5R,KAAK0e,MAAMjhB,eAAemd,GAG9B5a,KAAK0e,MAAM9D,GAAQhD,GAEvB+G,YAAa,SAAS1d,GAAT,WACT4L,OAAO+R,KAAK3d,GAAWuM,SACnB,SAAAoN,GACIiE,EAAK/Q,IAAI8M,EAAM3Z,EAAU2Z,QAGrC7N,IAAK,SAAS6N,GACV,OAAO5a,KAAK0e,MAAM9D,IAAW6D,GAAQA,EAAK1R,IAAK6N,IAEnDkE,kBAAmB,WACf,OAAO9e,KAAK0e,OAEhBK,QAAS,WACL,OAAOP,EAAcxe,OAEzBiY,OAAQ,SAASwG,GACb,OAAOD,EAAaC,KAKjBD,CAAc,MChCvBQ,EAAc,CAChBjN,KAAM,WACF,IAAMtC,EAAIzP,KAAKif,OACTxf,EAAIO,KAAKkf,OACf,GAAIzf,EACA,MAAMA,EAEV,GAAS,MAALgQ,EACA,OAAOA,EAAIwK,EAAQC,KAAOD,EAAQE,OAG1C/L,MAAO,SAAUqB,GACbzP,KAAKif,OAASxP,GAElB3P,MAAO,SAAUL,GACbO,KAAKkf,OAASzf,GAElB0f,MAAO,WACHnf,KAAKif,OAASjf,KAAKkf,OAAS,OCN9BE,EAAU,SAASC,EAAWC,EAAOC,EAAe5M,GACtD3S,KAAKqf,UAAYA,EACjBrf,KAAKsf,MAAQA,EACbtf,KAAKwf,SAAW,GAChBxf,KAAKyf,WAAa,KAClBzf,KAAK0f,YAAc,KACnB1f,KAAKuf,cAAgBA,EACrBvf,KAAK4S,mBAAmBD,GACxB3S,KAAKua,WAAY,EAEjBva,KAAK6S,UAAU7S,KAAKqf,UAAWrf,MAC/BA,KAAK6S,UAAU7S,KAAKsf,MAAOtf,OAG/Bof,EAAQrP,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC1CtM,KAAM,UACN+e,WAAW,EAEXnF,yBAAkB,OAAO,GAEzB1H,gBAAOzE,GACCrO,KAAKgd,MACLhd,KAAKgd,MAAQ3O,EAAQyK,WAAW9Y,KAAKgd,OAAO,GACrChd,KAAKqf,YACZrf,KAAKqf,UAAYhR,EAAQyK,WAAW9Y,KAAKqf,YAEzCrf,KAAKsf,OAAStf,KAAKsf,MAAMxgB,SACzBkB,KAAKsf,MAAQjR,EAAQyK,WAAW9Y,KAAKsf,SAI7CvN,cAAKpE,GAED,IAAI0R,EACAO,EACAC,EACAnf,EACAof,EACAC,GAAwB,EAE5B,GAAI/f,KAAKqf,YAAcO,EAAS5f,KAAKqf,UAAUvgB,QAAS,CAOpD,IANAugB,EAAY,IAAI/R,MAAMsS,GACtBZ,EAAYlf,MAAM,CACdc,KAAM,SACNsW,QAAS,6DAGRxW,EAAI,EAAGA,EAAIkf,EAAQlf,IAAK,CACzBmf,EAAW7f,KAAKqf,UAAU3e,GAAGqR,KAAKpE,GAClC,IAAK,IAAIqG,EAAI,EAAGA,EAAI6L,EAASrH,SAAS1Z,OAAQkV,IAC1C,GAAI6L,EAASrH,SAASxE,GAAGvB,WAAY,CACjCqN,GAAc,EACd,MAGRT,EAAU3e,GAAKmf,EACXA,EAASlH,iBACToH,GAAwB,GAIhC,GAAID,EAAa,CACb,IAAME,EAAmB,IAAI1S,MAAMsS,GACnC,IAAKlf,EAAI,EAAGA,EAAIkf,EAAQlf,IACpBmf,EAAWR,EAAU3e,GACrBsf,EAAiBtf,GAAKmf,EAASxP,MAAM1C,GAEzC3N,KAAKrC,MAAMwb,UACP6G,EAAiB9R,KAAK,KACtB,CAAC,aACDmR,EAAU,GAAGpS,WACboS,EAAU,GAAGrS,YACb,SAASoM,EAAKxC,GACNA,IACAyI,EAAYY,EAAmBrJ,OAK/CoI,EAAYG,aAEZY,GAAwB,EAG5B,IAEIG,EACAC,EAHAb,EAAQtf,KAAKsf,MAAQc,EAAgBpgB,KAAKsf,OAAS,KACjDe,EAAU,IAAIjB,EAAQC,EAAWC,EAAOtf,KAAKuf,cAAevf,KAAK2S,kBAIvE0N,EAAQC,gBAAkBtgB,KAC1BqgB,EAAQE,KAAOvgB,KAAKugB,KACpBF,EAAQG,UAAYxgB,KAAKwgB,UACzBH,EAAQI,aAAezgB,KAAKygB,aAExBzgB,KAAK6b,YACLwE,EAAQxE,UAAY7b,KAAK6b,WAGxBkE,IACDT,EAAMxgB,OAAS,GAKnBuhB,EAAQK,iBAAoB,SAAUpD,GAIlC,IAHA,IAEI3F,EAFAjX,EAAI,EACF2U,EAAIiI,EAAOxe,OAET4B,IAAM2U,IAAM3U,EAEhB,GADAiX,EAAQ2F,EAAQ5c,GAAIggB,iBACL,OAAO/I,EAE1B,OAAOgJ,EARgB,CASzBhT,EAAQ2P,QAASyB,UAGnB,IAAM6B,EAAYjT,EAAQ2P,OAC1BsD,EAAUC,QAAQR,GAGlB,IAAIS,EAAenT,EAAQ0R,UACtByB,IACDnT,EAAQ0R,UAAYyB,EAAe,IAEvCA,EAAaD,QAAQ7gB,KAAKqf,YAGtBgB,EAAQE,MAAQF,EAAQI,eAAiBJ,EAAQd,gBACjDc,EAAQU,YAAYpT,GAKxB,IAAMqT,EAAUX,EAAQf,MACxB,IAAK5e,EAAI,EAAIwf,EAAOc,EAAQtgB,GAAKA,IACzBwf,EAAKe,YACLD,EAAQtgB,GAAKwf,EAAKnO,KAAKpE,IAI/B,IAAMuT,EAAmBvT,EAAQwT,aAAexT,EAAQwT,YAAYriB,QAAW,EAG/E,IAAK4B,EAAI,EAAIwf,EAAOc,EAAQtgB,GAAKA,IACX,cAAdwf,EAAKtf,MAEL0e,EAAQY,EAAKnO,KAAKpE,GAASyT,QAAO,SAASlR,GACvC,QAAKA,aAAayK,GAAgBzK,EAAE8K,YAIvBqF,EAAQrF,SAAS9K,EAAE0K,SAIpCoG,EAAQrgB,OAAO0gB,MAAML,EAAS,CAACtgB,EAAG,GAAGQ,OAAOoe,IAC5C5e,GAAK4e,EAAMxgB,OAAS,EACpBuhB,EAAQiB,cACc,iBAAfpB,EAAKtf,OAEZ0e,EAAQY,EAAKnO,KAAKpE,GAAS2R,MAAM8B,QAAO,SAASlR,GAC7C,QAAKA,aAAayK,GAAgBzK,EAAE8K,aAMxCgG,EAAQrgB,OAAO0gB,MAAML,EAAS,CAACtgB,EAAG,GAAGQ,OAAOoe,IAC5C5e,GAAK4e,EAAMxgB,OAAS,EACpBuhB,EAAQiB,cAKhB,IAAK5gB,EAAI,EAAIwf,EAAOc,EAAQtgB,GAAKA,IACxBwf,EAAKe,YACND,EAAQtgB,GAAKwf,EAAOA,EAAKnO,KAAOmO,EAAKnO,KAAKpE,GAAWuS,GAK7D,IAAKxf,EAAI,EAAIwf,EAAOc,EAAQtgB,GAAKA,IAE7B,GAAIwf,aAAgBd,GAAWc,EAAKb,WAAuC,IAA1Ba,EAAKb,UAAUvgB,QAExDohB,EAAKb,UAAU,IAAMa,EAAKb,UAAU,GAAGxF,uBAAwB,CAC/DmH,EAAQrgB,OAAOD,IAAK,GAEpB,IAASsT,EAAI,EAAImM,EAAUD,EAAKZ,MAAMtL,GAAKA,IACnCmM,aAAmBjT,IACnBiT,EAAQvN,mBAAmBsN,EAAKvN,kBAC1BwN,aAAmBxF,GAAiBwF,EAAQnF,UAC9CgG,EAAQrgB,SAASD,EAAG,EAAGyf,IAY/C,GAHAS,EAAUhH,QACVkH,EAAalH,QAETjM,EAAQwT,YACR,IAAKzgB,EAAIwgB,EAAiBxgB,EAAIiN,EAAQwT,YAAYriB,OAAQ4B,IACtDiN,EAAQwT,YAAYzgB,GAAG6gB,gBAAgBlC,GAI/C,OAAOgB,GAGXU,qBAAYpT,GACR,IACIjN,EACA8gB,EAFElC,EAAQtf,KAAKsf,MAGnB,GAAKA,EAEL,IAAK5e,EAAI,EAAGA,EAAI4e,EAAMxgB,OAAQ4B,IACJ,WAAlB4e,EAAM5e,GAAGE,QACT4gB,EAAclC,EAAM5e,GAAGqR,KAAKpE,MACR6T,EAAY1iB,QAAiC,IAAvB0iB,EAAY1iB,SAClDwgB,EAAM3e,OAAO0gB,MAAM/B,EAAO,CAAC5e,EAAG,GAAGQ,OAAOsgB,IACxC9gB,GAAK8gB,EAAY1iB,OAAS,GAE1BwgB,EAAM3e,OAAOD,EAAG,EAAG8gB,GAEvBxhB,KAAKshB,eAKjB7F,yBASI,OARe,IAAI2D,EAAQpf,KAAKqf,UAAWrf,KAAKsf,MAAMnQ,KAAI,SAAUe,GAChE,OAAIA,EAAEuL,cACKvL,EAAEuL,gBAEFvL,KAEXlQ,KAAKuf,cAAevf,KAAK2S,mBAKjC8O,mBAAU/Q,GACN,OAAQA,GAAwB,IAAhBA,EAAK5R,QAIzB4iB,wBAAehR,EAAM/C,GACjB,IAAMgU,EAAe3hB,KAAKqf,UAAUrf,KAAKqf,UAAUvgB,OAAS,GAC5D,QAAK6iB,EAAahJ,kBAGdgJ,EAAajJ,YACZiJ,EAAajJ,UAAU3G,KACpB,IAAI0K,EAASY,KAAK1P,EACdA,EAAQ2P,WAMxBgE,sBACIthB,KAAK4hB,UAAY,KACjB5hB,KAAKyf,WAAa,KAClBzf,KAAK0f,YAAc,KACnB1f,KAAKwf,SAAW,IAGpBqC,qBAoBI,OAnBK7hB,KAAKyf,aACNzf,KAAKyf,WAAczf,KAAKsf,MAAatf,KAAKsf,MAAMjL,QAAO,SAAUyN,EAAM5R,GAOnE,GANIA,aAAayK,IAA8B,IAAfzK,EAAE8K,WAC9B8G,EAAK5R,EAAE0K,MAAQ1K,GAKJ,WAAXA,EAAEtP,MAAqBsP,EAAEqQ,MAAQrQ,EAAEqQ,KAAKsB,UAAW,CACnD,IAAME,EAAO7R,EAAEqQ,KAAKsB,YACpB,IAAK,IAAMG,KAAQD,EACXA,EAAKtkB,eAAeukB,KACpBF,EAAKE,GAAQ9R,EAAEqQ,KAAKvF,SAASgH,IAIzC,OAAOF,IACR,IAhB6B,IAkB7B9hB,KAAKyf,YAGhBwC,sBAiBI,OAhBKjiB,KAAK0f,cACN1f,KAAK0f,YAAe1f,KAAKsf,MAAatf,KAAKsf,MAAMjL,QAAO,SAAUyN,EAAM5R,GACpE,GAAIA,aAAayK,IAA8B,IAAfzK,EAAE8K,SAAmB,CACjD,IAAMkH,EAA0B,IAAlBhS,EAAE0K,KAAK9b,QAAkBoR,EAAE0K,KAAK,aAAcX,EACxD/J,EAAE0K,KAAK,GAAGxM,MAAQ8B,EAAE0K,KAEnBkH,EAAK,IAAII,GAIVJ,EAAK,IAAII,GAAQ1hB,KAAK0P,GAHtB4R,EAAK,IAAII,GAAU,CAAEhS,GAM7B,OAAO4R,IACR,IAb8B,IAe9B9hB,KAAK0f,aAGhB1E,kBAASJ,GACL,IAAMuH,EAAOniB,KAAK6hB,YAAYjH,GAC9B,GAAIuH,EACA,OAAOniB,KAAKoiB,WAAWD,IAI/BE,kBAASzH,GACL,IAAMuH,EAAOniB,KAAKiiB,aAAarH,GAC/B,GAAIuH,EACA,OAAOniB,KAAKoiB,WAAWD,IAI/BG,2BACI,IAAK,IAAI5hB,EAAIV,KAAKsf,MAAMxgB,OAAQ4B,EAAI,EAAGA,IAAK,CACxC,IAAMyhB,EAAOniB,KAAKsf,MAAM5e,EAAI,GAC5B,GAAIyhB,aAAgBxH,EAChB,OAAO3a,KAAKoiB,WAAWD,KAKnCC,oBAAWG,GACP,IAAM3V,EAAO5M,KACb,SAASwiB,EAAqBL,GAC1B,OAAIA,EAAK/T,iBAAiBgM,IAAc+H,EAAKxV,QACT,iBAArBwV,EAAK/T,MAAMA,MAClBpO,KAAKrC,MAAMwb,UACPgJ,EAAK/T,MAAMA,MACX,CAAC,QAAS,aACV+T,EAAK/T,MAAMnB,WACXkV,EAAKnV,YACL,SAASoM,EAAKxC,GACNwC,IACA+I,EAAKxV,QAAS,GAEdiK,IACAuL,EAAK/T,MAAQwI,EAAO,GACpBuL,EAAKtH,UAAYjE,EAAO,IAAM,GAC9BuL,EAAKxV,QAAS,MAI1BwV,EAAKxV,QAAS,EAGXwV,GAGAA,EAGf,GAAK7U,MAAMC,QAAQgV,GAGd,CACD,IAAME,EAAQ,GAId,OAHAF,EAAQ/U,SAAQ,SAAS6H,GACrBoN,EAAMjiB,KAAKgiB,EAAqBhP,KAAK5G,EAAMyI,OAExCoN,EAPP,OAAOD,EAAqBhP,KAAK5G,EAAM2V,IAW/CG,oBACI,IAAK1iB,KAAKsf,MAAS,MAAO,GAE1B,IAEI5e,EACAwf,EAHEyC,EAAY,GACZrD,EAAQtf,KAAKsf,MAInB,IAAK5e,EAAI,EAAIwf,EAAOZ,EAAM5e,GAAKA,IACvBwf,EAAKP,WACLgD,EAAUniB,KAAK0f,GAIvB,OAAOyC,GAGXC,qBAAY1C,GACR,IAAMZ,EAAQtf,KAAKsf,MACfA,EACAA,EAAMuB,QAAQX,GAEdlgB,KAAKsf,MAAQ,CAAEY,GAEnBlgB,KAAK6S,UAAUqN,EAAMlgB,OAGzB6iB,cAAKhD,EAAUjT,EAAMwU,GACjBxU,EAAOA,GAAQ5M,KACf,IACIkP,EACA4T,EAFExD,EAAQ,GAGR3N,EAAMkO,EAASxP,QAErB,OAAIsB,KAAO3R,KAAKwf,SAAmBxf,KAAKwf,SAAS7N,IAEjD3R,KAAK0iB,WAAWlV,SAAQ,SAAU0S,GAC9B,GAAIA,IAAStT,EACT,IAAK,IAAIoH,EAAI,EAAGA,EAAIkM,EAAKb,UAAUvgB,OAAQkV,IAEvC,GADA9E,EAAQ2Q,EAAS3Q,MAAMgR,EAAKb,UAAUrL,IAC3B,CACP,GAAI6L,EAASrH,SAAS1Z,OAASoQ,GAC3B,IAAKkS,GAAUA,EAAOlB,GAAO,CACzB4C,EAAc5C,EAAK2C,KAAK,IAAItK,EAASsH,EAASrH,SAAS3G,MAAM3C,IAAStC,EAAMwU,GAC5E,IAAK,IAAI1gB,EAAI,EAAGA,EAAIoiB,EAAYhkB,SAAU4B,EACtCoiB,EAAYpiB,GAAGyc,KAAK3c,KAAK0f,GAE7B5S,MAAMyC,UAAUvP,KAAK6gB,MAAM/B,EAAOwD,SAGtCxD,EAAM9e,KAAK,CAAE0f,OAAM/C,KAAM,KAE7B,UAKhBnd,KAAKwf,SAAS7N,GAAO2N,EACdA,IAGXzR,gBAAOF,EAASQ,GACZ,IAAIzN,EACAsT,EAKA6H,EAEAqE,EACA/C,EANA4F,EAAY,GAQhBpV,EAAQqV,SAAYrV,EAAQqV,UAAY,EAEnChjB,KAAKugB,MACN5S,EAAQqV,WAGZ,IAEIC,EAFEC,EAAavV,EAAQ8C,SAAW,GAAKnD,MAAMK,EAAQqV,SAAW,GAAG9U,KAAK,MACtEiV,EAAYxV,EAAQ8C,SAAW,GAAKnD,MAAMK,EAAQqV,UAAU9U,KAAK,MAGnEkV,EAAmB,EACnBC,EAAkB,EACtB,IAAK3iB,EAAI,EAAIwf,EAAOlgB,KAAKsf,MAAM5e,GAAKA,IAC5Bwf,aAAgB9D,GACZiH,IAAoB3iB,GACpB2iB,IAEJN,EAAUviB,KAAK0f,IACRA,EAAKoD,WAAapD,EAAKoD,aAC9BP,EAAUpiB,OAAOyiB,EAAkB,EAAGlD,GACtCkD,IACAC,KACqB,WAAdnD,EAAKtf,MACZmiB,EAAUpiB,OAAO0iB,EAAiB,EAAGnD,GACrCmD,KAEAN,EAAUviB,KAAK0f,GAOvB,GAJA6C,EAtCyB,GAsCI7hB,OAAO6hB,IAI/B/iB,KAAKugB,KAAM,EACZ1E,EAAYS,EAAa3O,EAAS3N,KAAMmjB,MAGpChV,EAAOL,IAAI+N,GACX1N,EAAOL,IAAIqV,IAGf,IAAMnG,EAAQhd,KAAKgd,MACbuG,EAAUvG,EAAMle,OAClB0kB,SAIJ,IAFAP,EAAMtV,EAAQ8C,SAAW,IAAO,MAAM0S,EAEjCziB,EAAI,EAAGA,EAAI6iB,EAAS7iB,IAErB,GAAM8iB,GADNrG,EAAOH,EAAMtc,IACW5B,OAOxB,IANI4B,EAAI,GAAKyN,EAAOL,IAAImV,GAExBtV,EAAQqF,eAAgB,EACxBmK,EAAK,GAAGtP,OAAOF,EAASQ,GAExBR,EAAQqF,eAAgB,EACnBgB,EAAI,EAAGA,EAAIwP,EAAYxP,IACxBmJ,EAAKnJ,GAAGnG,OAAOF,EAASQ,GAIhCA,EAAOL,KAAKH,EAAQ8C,SAAW,IAAM,QAAUyS,GAInD,IAAKxiB,EAAI,EAAIwf,EAAO6C,EAAUriB,GAAKA,IAAK,CAEhCA,EAAI,IAAMqiB,EAAUjkB,SACpB6O,EAAQsN,UAAW,GAGvB,IAAMwI,EAAkB9V,EAAQsN,SAC5BiF,EAAK1F,cAAc0F,KACnBvS,EAAQsN,UAAW,GAGnBiF,EAAKrS,OACLqS,EAAKrS,OAAOF,EAASQ,GACd+R,EAAK9R,OACZD,EAAOL,IAAIoS,EAAK9R,MAAM0B,YAG1BnC,EAAQsN,SAAWwI,GAEd9V,EAAQsN,UAAYiF,EAAKwD,YAC1BvV,EAAOL,IAAIH,EAAQ8C,SAAW,GAAM,KAAKyS,GAEzCvV,EAAQsN,UAAW,EAItBjb,KAAKugB,OACNpS,EAAOL,IAAKH,EAAQ8C,SAAW,IAAM,KAAK0S,OAC1CxV,EAAQqV,YAGP7U,EAAOF,WAAcN,EAAQ8C,WAAYzQ,KAAKwgB,WAC/CrS,EAAOL,IAAI,OAInB6V,uBAAc3G,EAAOrP,EAAS0R,GAC1B,IAAK,IAAI1T,EAAI,EAAGA,EAAI0T,EAAUvgB,OAAQ6M,IAClC3L,KAAK4jB,aAAa5G,EAAOrP,EAAS0R,EAAU1T,KAIpDiY,sBAAa5G,EAAOrP,EAASkS,GAEzB,SAASgE,EAAkBC,EAAeC,GACtC,IAAIC,EAAkBhQ,EACtB,GAA6B,IAAzB8P,EAAchlB,OACdklB,EAAmB,IAAIlS,EAAMgS,EAAc,QACxC,CACH,IAAMG,EAAe,IAAI3W,MAAMwW,EAAchlB,QAC7C,IAAKkV,EAAI,EAAGA,EAAI8P,EAAchlB,OAAQkV,IAClCiQ,EAAajQ,GAAK,IAAIzB,EAClB,KACAuR,EAAc9P,GACd+P,EAAgBtR,WAChBsR,EAAgBtW,OAChBsW,EAAgBrW,WAGxBsW,EAAmB,IAAIlS,EAAM,IAAIyG,EAAS0L,IAE9C,OAAOD,EAGX,SAASE,EAAeC,EAAkBJ,GACtC,IAAIK,EAGJ,OAFAA,EAAU,IAAI7R,EAAQ,KAAM4R,EAAkBJ,EAAgBtR,WAAYsR,EAAgBtW,OAAQsW,EAAgBrW,WACvG,IAAI6K,EAAS,CAAC6L,IAO7B,SAASC,EAAuBC,EAAeC,EAASC,EAAiBC,GACrE,IAAIC,EAAiB/C,EAAcgD,EAenC,GAbAD,EAAkB,GAIdJ,EAAcxlB,OAAS,GAEvB6iB,GADA+C,EAAkBtE,EAAgBkE,IACH9I,MAC/BmJ,EAAoBF,EAAiB1L,cAAcqH,EAAgBuB,EAAanJ,YAGhFmM,EAAoBF,EAAiB1L,cAAc,IAGnDwL,EAAQzlB,OAAS,EAAG,CAMpB,IAAI0T,EAAagS,EAAgBhS,WAE3BoS,EAAWL,EAAQ,GAAG/L,SAAS,GACjChG,EAAWJ,oBAAsBwS,EAASpS,WAAWJ,oBACrDI,EAAaoS,EAASpS,YAG1BmS,EAAkBnM,SAAShY,KAAK,IAAI+R,EAChCC,EACAoS,EAASxW,MACToW,EAAgB/R,WAChB+R,EAAgB/W,OAChB+W,EAAgB9W,YAEpBiX,EAAkBnM,SAAWmM,EAAkBnM,SAAStX,OAAOqjB,EAAQ,GAAG/L,SAAS3G,MAAM,IAS7F,GAL0C,IAAtC8S,EAAkBnM,SAAS1Z,QAC3B4lB,EAAgBlkB,KAAKmkB,GAIrBJ,EAAQzlB,OAAS,EAAG,CACpB,IAAI+lB,EAAaN,EAAQ1S,MAAM,GAC/BgT,EAAaA,EAAW1V,KAAI,SAAU0Q,GAClC,OAAOA,EAAS9G,cAAc8G,EAASrH,SAAU,OAErDkM,EAAkBA,EAAgBxjB,OAAO2jB,GAE7C,OAAOH,EAMX,SAASI,EAA4BR,EAAeS,EAAUP,EAAiBC,EAAkB7N,GAC7F,IAAI5C,EACJ,IAAKA,EAAI,EAAGA,EAAIsQ,EAAcxlB,OAAQkV,IAAK,CACvC,IAAM0Q,EAAkBL,EAAuBC,EAActQ,GAAI+Q,EAAUP,EAAiBC,GAC5F7N,EAAOpW,KAAKkkB,GAEhB,OAAO9N,EAGX,SAASoO,EAA2BxM,EAAU6G,GAC1C,IAAI3e,EAAGukB,EAEP,GAAwB,IAApBzM,EAAS1Z,OAGb,GAAyB,IAArBugB,EAAUvgB,OAKd,IAAK4B,EAAI,EAAIukB,EAAM5F,EAAU3e,GAAKA,IAE1BukB,EAAInmB,OAAS,EACbmmB,EAAIA,EAAInmB,OAAS,GAAKmmB,EAAIA,EAAInmB,OAAS,GAAGia,cAAckM,EAAIA,EAAInmB,OAAS,GAAG0Z,SAAStX,OAAOsX,IAG5FyM,EAAIzkB,KAAK,IAAI+X,EAASC,SAV1B6G,EAAU7e,KAAK,CAAE,IAAI+X,EAASC,KAsItC,SAAS0M,EAAevS,EAAgBwS,GACpC,IAAMnM,EAAcmM,EAAWpM,cAAcoM,EAAW3M,SAAU2M,EAAW1M,WAAY0M,EAAWxM,gBAEpG,OADAK,EAAYpG,mBAAmBD,GACxBqG,EAIX,IAAItY,EAAG0kB,EAKP,IAhIA,SAASC,EAAsBrI,EAAOrP,EAAS2X,GAW3C,IAAI5kB,EAAGsT,EAAGD,EAAGwR,EAAiBC,EAAcC,EAAqBR,EAAK1L,EAA+Bza,EAAQ6iB,EACjFyC,EACpBsB,EAFkEC,GAAoB,EAwB9F,IARAJ,EAAkB,GAIlBC,EAAe,CACX,IAGC9kB,EAAI,EAAI6Y,EAAK+L,EAAW9M,SAAS9X,GAAKA,IAEvC,GAAiB,MAAb6Y,EAAGnL,MAAe,CAClB,IAAMwX,GAzBNF,OAAAA,GADoBtB,EA0BsB7K,GAxBhCnL,iBAAiB0D,IAI/B4T,EAAgBtB,EAAQhW,MAAMA,iBACCmK,EAIxBmN,EARI,MAwBP,GAAsB,MAAlBE,EAAwB,CAGxBZ,EAA2BO,EAAiBC,GAE5C,IACIK,EADEC,EAAc,GAEdC,EAAuB,GAI7B,IAHAF,EAAWR,EAAsBS,EAAanY,EAASiY,GACvDD,EAAoBA,GAAqBE,EAEpC9R,EAAI,EAAGA,EAAI+R,EAAYhnB,OAAQiV,IAAK,CAErC+Q,EAA2BU,EAAc,CADbtB,EAAeL,EAAkBiC,EAAY/R,GAAIwF,GAAKA,IAClBA,EAAI+L,EAAYS,GAEpFP,EAAeO,EACfR,EAAkB,QAElBA,EAAgB/kB,KAAK+Y,OAGtB,CAUH,IATAoM,GAAoB,EAEpBF,EAAsB,GAItBT,EAA2BO,EAAiBC,GAGvCxR,EAAI,EAAGA,EAAIwR,EAAa1mB,OAAQkV,IAIjC,GAHAiR,EAAMO,EAAaxR,GAGI,IAAnBrG,EAAQ7O,OAGJmmB,EAAInmB,OAAS,GACbmmB,EAAI,GAAGzM,SAAShY,KAAK,IAAI+R,EAAQgH,EAAG/G,WAAY,GAAI+G,EAAG9G,WAAY8G,EAAG9L,OAAQ8L,EAAG7L,YAErF+X,EAAoBjlB,KAAKykB,QAIzB,IAAKlR,EAAI,EAAGA,EAAIpG,EAAQ7O,OAAQiV,IAAK,CAGjC,IAAM2Q,EAAkBL,EAAuBY,EAAKtX,EAAQoG,GAAIwF,EAAI+L,GAEpEG,EAAoBjlB,KAAKkkB,GAMrCc,EAAeC,EACfF,EAAkB,GAQ1B,IAFAP,EAA2BO,EAAiBC,GAEvC9kB,EAAI,EAAGA,EAAI8kB,EAAa1mB,OAAQ4B,KACjC5B,EAAS0mB,EAAa9kB,GAAG5B,QACZ,IACTke,EAAMxc,KAAKglB,EAAa9kB,IACxBihB,EAAe6D,EAAa9kB,GAAG5B,EAAS,GACxC0mB,EAAa9kB,GAAG5B,EAAS,GAAK6iB,EAAa5I,cAAc4I,EAAanJ,SAAU8M,EAAW7M,aAInG,OAAOkN,EAaSN,CADpBD,EAAW,GACyCzX,EAASkS,GAGzD,GAAIlS,EAAQ7O,OAAS,EAEjB,IADAsmB,EAAW,GACN1kB,EAAI,EAAGA,EAAIiN,EAAQ7O,OAAQ4B,IAAK,CAEjC,IAAMslB,EAAerY,EAAQjN,GAAGyO,IAAI+V,EAAe7jB,KAAKrB,KAAM6f,EAASlN,mBAEvEqT,EAAaxlB,KAAKqf,GAClBuF,EAAS5kB,KAAKwlB,QAIlBZ,EAAW,CAAC,CAACvF,IAIrB,IAAKnf,EAAI,EAAGA,EAAI0kB,EAAStmB,OAAQ4B,IAC7Bsc,EAAMxc,KAAK4kB,EAAS1kB,OCr0BhC,IAAMulB,EAAS,SACXrL,EACAxM,EACAkR,EACAtR,EACA0E,EACAmJ,EACAqK,EACAvT,GAEA,IAAIjS,EAIJ,GAFAV,KAAK4a,KAAQA,EACb5a,KAAKoO,MAASA,aAAiBlB,EAAQkB,EAASA,EAAQ,IAAIgM,EAAUhM,GAASA,EAC3EkR,EAAO,CAOP,IANIhS,MAAMC,QAAQ+R,GACdtf,KAAKsf,MAAQA,GAEbtf,KAAKsf,MAAQ,CAACA,GACdtf,KAAKsf,MAAM,GAAGD,UAAY,IAAK9G,EAAS,GAAI,KAAM,KAAMvK,EAAO0E,GAAkB4G,wBAEhF5Y,EAAI,EAAGA,EAAIV,KAAKsf,MAAMxgB,OAAQ4B,IAC/BV,KAAKsf,MAAM5e,GAAG+f,cAAe,EAEjCzgB,KAAK6S,UAAU7S,KAAKsf,MAAOtf,MAE/BA,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAK6b,UAAYA,EACjB7b,KAAKkmB,SAAWA,IAAY,EAC5BlmB,KAAK4S,mBAAmBD,GACxB3S,KAAKua,WAAY,GAGrB0L,EAAOlW,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACzCtM,KAAM,SACNkS,gBAAOzE,GACH,IAAMD,EAAQpO,KAAKoO,MAAOkR,EAAQtf,KAAKsf,MACnCA,IACAtf,KAAKsf,MAAQjR,EAAQyK,WAAWwG,IAEhClR,IACApO,KAAKoO,MAAQC,EAAQC,MAAMF,KAInCoM,yBACI,OAAOxa,KAAKsf,QAAUtf,KAAKsjB,aAG/BA,qBACI,MAAO,aAAetjB,KAAK4a,MAG/B/M,gBAAOF,EAASQ,GACZ,IAAMC,EAAQpO,KAAKoO,MAAOkR,EAAQtf,KAAKsf,MACvCnR,EAAOL,IAAI9N,KAAK4a,KAAM5a,KAAKgN,WAAYhN,KAAKiN,YACxCmB,IACAD,EAAOL,IAAI,KACXM,EAAMP,OAAOF,EAASQ,IAEtBmR,EACAtf,KAAKmmB,cAAcxY,EAASQ,EAAQmR,GAEpCnR,EAAOL,IAAI,MAInBiE,cAAKpE,GACD,IAAIyY,EAAiBC,EAAmBjY,EAAQpO,KAAKoO,MAAOkR,EAAQtf,KAAKsf,MAsBzE,OAlBA8G,EAAkBzY,EAAQ2Y,UAC1BD,EAAoB1Y,EAAQwT,YAE5BxT,EAAQ2Y,UAAY,GACpB3Y,EAAQwT,YAAc,GAElB/S,IACAA,EAAQA,EAAM2D,KAAKpE,IAEnB2R,KAEAA,EAAQ,CAACA,EAAM,GAAGvN,KAAKpE,KACjB,GAAG4S,MAAO,GAGpB5S,EAAQ2Y,UAAYF,EACpBzY,EAAQwT,YAAckF,EAEf,IAAIJ,EAAOjmB,KAAK4a,KAAMxM,EAAOkR,EAChCtf,KAAKiN,WAAYjN,KAAKgN,WAAYhN,KAAK6b,UAAW7b,KAAKkmB,SAAUlmB,KAAK2S,mBAG9EqI,kBAASJ,GACL,GAAI5a,KAAKsf,MAEL,OAAOF,EAAQrP,UAAUiL,SAASxH,KAAKxT,KAAKsf,MAAM,GAAI1E,IAI9DiI,gBACI,GAAI7iB,KAAKsf,MAEL,OAAOF,EAAQrP,UAAU8S,KAAKxB,MAAMrhB,KAAKsf,MAAM,GAAIxL,YAI3D4O,oBACI,GAAI1iB,KAAKsf,MAEL,OAAOF,EAAQrP,UAAU2S,SAASrB,MAAMrhB,KAAKsf,MAAM,KAI3D6G,uBAAcxY,EAASQ,EAAQmR,GAC3B,IACI5e,EADE6lB,EAAUjH,EAAMxgB,OAKtB,GAHA6O,EAAQqV,SAAoC,GAAL,EAAnBrV,EAAQqV,UAGxBrV,EAAQ8C,SAAU,CAElB,IADAtC,EAAOL,IAAI,KACNpN,EAAI,EAAGA,EAAI6lB,EAAS7lB,IACrB4e,EAAM5e,GAAGmN,OAAOF,EAASQ,GAI7B,OAFAA,EAAOL,IAAI,UACXH,EAAQqV,WAKZ,IAAMG,EAAY,KAAK7V,MAAMK,EAAQqV,UAAU9U,KAAK,MAASgV,EAAgBC,OAC7E,GAAKoD,EAEE,CAGH,IAFApY,EAAOL,IAAI,KAAKoV,GAChB5D,EAAM,GAAGzR,OAAOF,EAASQ,GACpBzN,EAAI,EAAGA,EAAI6lB,EAAS7lB,IACrByN,EAAOL,IAAIoV,GACX5D,EAAM5e,GAAGmN,OAAOF,EAASQ,GAE7BA,EAAOL,IAAOqV,YARdhV,EAAOL,IAAI,KAAKqV,OAWpBxV,EAAQqV,cCnJhB,IAAMwD,EAAkB,SAASnG,EAAS/C,GACtCtd,KAAKqgB,QAAUA,EACfrgB,KAAKsd,OAASA,EACdtd,KAAK6S,UAAU7S,KAAKqgB,QAASrgB,OAGjCwmB,EAAgBzW,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAClDtM,KAAM,kBACNqgB,WAAW,EAEXnO,gBAAOzE,GACHrO,KAAKqgB,QAAUhS,EAAQC,MAAMtO,KAAKqgB,UAGtCtO,cAAKpE,GACD,IAAM2P,EAAStd,KAAKsd,QAAU8C,EAAgBzS,EAAQ2P,QACtD,OAAO,IAAIkJ,EAAgBxmB,KAAKqgB,QAAS/C,IAG7CmJ,kBAAS9Y,GACL,OAAO3N,KAAKqgB,QAAQtO,KAAK/R,KAAKsd,OAAS,IAAIb,EAASY,KAAK1P,EAAS3N,KAAKsd,OAAOpc,OAAOyM,EAAQ2P,SAAW3P,MCpBhH,IAAM+Y,EAAO,SAASC,EAAWC,EAAaC,GAC1C7mB,KAAK2mB,UAAYA,EAAYvG,EAAgBuG,GAAWG,OAAS,GACjE9mB,KAAK4mB,YAAcA,EAAcxG,EAAgBwG,GAAaE,OAAS,GACnED,EACA7mB,KAAK6mB,WAAaA,EACXF,GAAaA,EAAU7nB,SAC9BkB,KAAK6mB,WAAaF,EAAU,KAIpCD,EAAK3W,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACvCtM,KAAM,OAENmS,iBACI,OAAO,IAAI2T,EAAKtG,EAAgBpgB,KAAK2mB,WAAYvG,EAAgBpgB,KAAK4mB,aAAc5mB,KAAK6mB,aAG7FhZ,gBAAOF,EAASQ,GAEZ,IAAM4Y,EAAcpZ,GAAWA,EAAQoZ,YACT,IAA1B/mB,KAAK2mB,UAAU7nB,OACfqP,EAAOL,IAAI9N,KAAK2mB,UAAU,KAClBI,GAAe/mB,KAAK6mB,WAC5B1Y,EAAOL,IAAI9N,KAAK6mB,aACRE,GAAe/mB,KAAK4mB,YAAY9nB,QACxCqP,EAAOL,IAAI9N,KAAK4mB,YAAY,KAIpC9W,oBACI,IAAIpP,EAAGsmB,EAAYhnB,KAAK2mB,UAAUzY,KAAK,KACvC,IAAKxN,EAAI,EAAGA,EAAIV,KAAK4mB,YAAY9nB,OAAQ4B,IACrCsmB,GAAa,IAAIhnB,KAAK4mB,YAAYlmB,GAEtC,OAAOsmB,GAGXlY,iBAAQqC,GACJ,OAAOnR,KAAKinB,GAAG9V,EAAMrB,YAAc,OAAItD,GAG3Cya,YAAGC,GACC,OAAOlnB,KAAK8P,WAAWqX,gBAAkBD,EAAWC,eAGxDC,oBACI,OAAOC,OAAO,wDAAyD,MAAMlL,KAAKnc,KAAKqQ,UAG3FpC,mBACI,OAAiC,IAA1BjO,KAAK2mB,UAAU7nB,QAA4C,IAA5BkB,KAAK4mB,YAAY9nB,QAG3DwoB,sBACI,OAAOtnB,KAAK2mB,UAAU7nB,QAAU,GAAiC,IAA5BkB,KAAK4mB,YAAY9nB,QAG1DqQ,aAAIoY,GACA,IAAI7mB,EAEJ,IAAKA,EAAI,EAAGA,EAAIV,KAAK2mB,UAAU7nB,OAAQ4B,IACnCV,KAAK2mB,UAAUjmB,GAAK6mB,EAASvnB,KAAK2mB,UAAUjmB,IAAI,GAGpD,IAAKA,EAAI,EAAGA,EAAIV,KAAK4mB,YAAY9nB,OAAQ4B,IACrCV,KAAK4mB,YAAYlmB,GAAK6mB,EAASvnB,KAAK4mB,YAAYlmB,IAAI,IAI5D8mB,qBACI,IAAIC,EAEAC,EACAC,EAFE/Q,EAAS,GAaf,IAAK+Q,KATLD,EAAU,SAAUE,GAMhB,OAJIH,EAAMhqB,eAAemqB,KAAgBhR,EAAO+Q,KAC5C/Q,EAAO+Q,GAAaC,GAGjBA,GAGOvb,EACVA,EAAgB5O,eAAekqB,KAC/BF,EAAQpb,EAAgBsb,GAExB3nB,KAAKmP,IAAIuY,IAIjB,OAAO9Q,GAGXiR,kBACI,IACID,EACAlnB,EAFEonB,EAAU,GAIhB,IAAKpnB,EAAI,EAAGA,EAAIV,KAAK2mB,UAAU7nB,OAAQ4B,IAEnConB,EADAF,EAAa5nB,KAAK2mB,UAAUjmB,KACLonB,EAAQF,IAAe,GAAK,EAGvD,IAAKlnB,EAAI,EAAGA,EAAIV,KAAK4mB,YAAY9nB,OAAQ4B,IAErConB,EADAF,EAAa5nB,KAAK4mB,YAAYlmB,KACPonB,EAAQF,IAAe,GAAK,EAMvD,IAAKA,KAHL5nB,KAAK2mB,UAAY,GACjB3mB,KAAK4mB,YAAc,GAEAkB,EACf,GAAIA,EAAQrqB,eAAemqB,GAAa,CACpC,IAAMG,EAAQD,EAAQF,GAEtB,GAAIG,EAAQ,EACR,IAAKrnB,EAAI,EAAGA,EAAIqnB,EAAOrnB,IACnBV,KAAK2mB,UAAUnmB,KAAKonB,QAErB,GAAIG,EAAQ,EACf,IAAKrnB,EAAI,EAAGA,GAAKqnB,EAAOrnB,IACpBV,KAAK4mB,YAAYpmB,KAAKonB,GAMtC5nB,KAAK2mB,UAAUG,OACf9mB,KAAK4mB,YAAYE,UC9HzB,IAAMkB,GAAY,SAAS5Z,EAAO6Z,GAE9B,GADAjoB,KAAKoO,MAAQ8Z,WAAW9Z,GACpB+Z,MAAMnoB,KAAKoO,OACX,MAAM,IAAI1O,MAAM,8BAEpBM,KAAKioB,KAAQA,GAAQA,aAAgBvB,EAAQuB,EACzC,IAAIvB,EAAKuB,EAAO,CAACA,QAAQzb,GAC7BxM,KAAK6S,UAAU7S,KAAKioB,KAAMjoB,OAG9BgoB,GAAUjY,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC5CtM,KAAM,YAENkS,gBAAOzE,GACHrO,KAAKioB,KAAO5Z,EAAQC,MAAMtO,KAAKioB,OAGnClW,cAAKpE,GACD,OAAO3N,MAGXooB,mBACI,OAAO,IAAIrZ,EAAM,CAAC/O,KAAKoO,MAAOpO,KAAKoO,MAAOpO,KAAKoO,SAGnDP,gBAAOF,EAASQ,GACZ,GAAKR,GAAWA,EAAQoZ,cAAiB/mB,KAAKioB,KAAKX,aAC/C,MAAM,IAAI5nB,MAAM,sFAAsFM,KAAKioB,KAAKnY,YAGpH,IAAM1B,EAAQpO,KAAK2Q,OAAOhD,EAAS3N,KAAKoO,OACpCia,EAAWC,OAAOla,GAOtB,GALc,IAAVA,GAAeA,EAAQ,MAAYA,GAAS,OAE5Cia,EAAWja,EAAMS,QAAQ,IAAI1R,QAAQ,MAAO,KAG5CwQ,GAAWA,EAAQ8C,SAAU,CAE7B,GAAc,IAAVrC,GAAepO,KAAKioB,KAAKb,WAEzB,YADAjZ,EAAOL,IAAIua,GAKXja,EAAQ,GAAKA,EAAQ,IACrBia,EAAW,EAAW/P,OAAO,IAIrCnK,EAAOL,IAAIua,GACXroB,KAAKioB,KAAKpa,OAAOF,EAASQ,IAM9B+C,iBAAQvD,EAASY,EAAI4C,GAEjB,IAAI/C,EAAQpO,KAAKoR,SAASzD,EAASY,EAAIvO,KAAKoO,MAAO+C,EAAM/C,OAAQ6Z,EAAOjoB,KAAKioB,KAAKlV,QAElF,GAAW,MAAPxE,GAAqB,MAAPA,EACd,GAA8B,IAA1B0Z,EAAKtB,UAAU7nB,QAA4C,IAA5BmpB,EAAKrB,YAAY9nB,OAChDmpB,EAAO9W,EAAM8W,KAAKlV,QACd/S,KAAKioB,KAAKpB,aACVoB,EAAKpB,WAAa7mB,KAAKioB,KAAKpB,iBAE7B,GAAoC,IAAhC1V,EAAM8W,KAAKtB,UAAU7nB,QAA4C,IAA5BmpB,EAAKrB,YAAY9nB,YAE1D,CAGH,GAFAqS,EAAQA,EAAMoX,UAAUvoB,KAAKioB,KAAKT,aAE9B7Z,EAAQoZ,aAAe5V,EAAM8W,KAAKnY,aAAemY,EAAKnY,WACtD,MAAM,IAAIpQ,MAAM,8EACKuoB,EAAKnY,qBAAoBqB,EAAM8W,KAAKnY,iBAG7D1B,EAAQpO,KAAKoR,SAASzD,EAASY,EAAIvO,KAAKoO,MAAO+C,EAAM/C,WAE3C,MAAPG,GACP0Z,EAAKtB,UAAYsB,EAAKtB,UAAUzlB,OAAOiQ,EAAM8W,KAAKtB,WAAWG,OAC7DmB,EAAKrB,YAAcqB,EAAKrB,YAAY1lB,OAAOiQ,EAAM8W,KAAKrB,aAAaE,OACnEmB,EAAKJ,UACS,MAAPtZ,IACP0Z,EAAKtB,UAAYsB,EAAKtB,UAAUzlB,OAAOiQ,EAAM8W,KAAKrB,aAAaE,OAC/DmB,EAAKrB,YAAcqB,EAAKrB,YAAY1lB,OAAOiQ,EAAM8W,KAAKtB,WAAWG,OACjEmB,EAAKJ,UAET,OAAO,IAAIG,GAAU5Z,EAAO6Z,IAGhCnZ,iBAAQqC,GACJ,IAAI3C,EAAGC,EAEP,GAAM0C,aAAiB6W,GAAvB,CAIA,GAAIhoB,KAAKioB,KAAKha,WAAakD,EAAM8W,KAAKha,UAClCO,EAAIxO,KACJyO,EAAI0C,OAIJ,GAFA3C,EAAIxO,KAAKwoB,QACT/Z,EAAI0C,EAAMqX,QACqB,IAA3Bha,EAAEyZ,KAAKnZ,QAAQL,EAAEwZ,MACjB,OAIR,OAAO/a,EAAKub,eAAeja,EAAEJ,MAAOK,EAAEL,SAG1Coa,iBACI,OAAOxoB,KAAKuoB,UAAU,CAAEzpB,OAAQ,KAAM4M,SAAU,IAAKG,MAAO,SAGhE0c,mBAAUG,GACN,IAEIhoB,EACAinB,EACAF,EACAkB,EAEAC,EAPAxa,EAAQpO,KAAKoO,MACX6Z,EAAOjoB,KAAKioB,KAAKlV,QAKnB8V,EAAqB,GAGzB,GAA2B,iBAAhBH,EAA0B,CACjC,IAAKhoB,KAAK2L,EACFA,EAAgB3L,GAAGjD,eAAeirB,MAClCG,EAAqB,IACFnoB,GAAKgoB,GAGhCA,EAAcG,EAiBlB,IAAKlB,KAfLiB,EAAY,SAAUhB,EAAYhB,GAE9B,OAAIa,EAAMhqB,eAAemqB,IACjBhB,EACAxY,GAAiBqZ,EAAMG,GAAcH,EAAMkB,GAE3Cva,GAAiBqZ,EAAMG,GAAcH,EAAMkB,GAGxCA,GAGJf,GAGOc,EACVA,EAAYjrB,eAAekqB,KAC3BgB,EAAaD,EAAYf,GACzBF,EAAQpb,EAAgBsb,GAExBM,EAAK9Y,IAAIyZ,IAMjB,OAFAX,EAAKJ,SAEE,IAAIG,GAAU5Z,EAAO6Z,MCtKpC,IAAMvN,GAAOnE,EAGPuS,GAAY,SAASva,EAAIwa,EAAUC,GACrChpB,KAAKuO,GAAKA,EAAG8D,OACbrS,KAAK+oB,SAAWA,EAChB/oB,KAAKgpB,SAAWA,GAGpBF,GAAU/Y,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC5CtM,KAAM,YAENkS,gBAAOzE,GACHrO,KAAK+oB,SAAW1a,EAAQyK,WAAW9Y,KAAK+oB,WAG5ChX,cAAKpE,GACD,IAA4EY,EAAxEC,EAAIxO,KAAK+oB,SAAS,GAAGhX,KAAKpE,GAAUc,EAAIzO,KAAK+oB,SAAS,GAAGhX,KAAKpE,GAElE,GAAIA,EAAQoQ,SAAS/d,KAAKuO,IAAK,CAQ3B,GAPAA,EAAiB,OAAZvO,KAAKuO,GAAc,IAAMvO,KAAKuO,GAC/BC,aAAawZ,IAAavZ,aAAaM,IACvCP,EAAIA,EAAE4Z,WAEN3Z,aAAauZ,IAAaxZ,aAAaO,IACvCN,EAAIA,EAAE2Z,YAEL5Z,EAAE0C,QAAS,CACZ,GAAI1C,aAAasa,IAAsB,MAATta,EAAED,IAAcZ,EAAQ2I,OAASoE,GAAKvH,gBAChE,OAAO,IAAI2V,GAAU9oB,KAAKuO,GAAI,CAACC,EAAGC,GAAIzO,KAAKgpB,UAE/C,KAAM,CAAEpoB,KAAM,YACVsW,QAAS,gCAGjB,OAAO1I,EAAE0C,QAAQvD,EAASY,EAAIE,GAE9B,OAAO,IAAIqa,GAAU9oB,KAAKuO,GAAI,CAACC,EAAGC,GAAIzO,KAAKgpB,WAInDnb,gBAAOF,EAASQ,GACZnO,KAAK+oB,SAAS,GAAGlb,OAAOF,EAASQ,GAC7BnO,KAAKgpB,UACL7a,EAAOL,IAAI,KAEfK,EAAOL,IAAI9N,KAAKuO,IACZvO,KAAKgpB,UACL7a,EAAOL,IAAI,KAEf9N,KAAK+oB,SAAS,GAAGlb,OAAOF,EAASQ,MC/CzC,IAAM8a,GAAa,SAAS7a,EAAO8a,GAG/B,GAFAlpB,KAAKoO,MAAQA,EACbpO,KAAKkpB,UAAYA,GACZ9a,EACD,MAAM,IAAI1O,MAAM,2CAIxBupB,GAAWlZ,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC7CtM,KAAM,aAENkS,gBAAOzE,GACHrO,KAAKoO,MAAQC,EAAQyK,WAAW9Y,KAAKoO,QAGzC2D,cAAKpE,GACD,IAAIwb,EACErL,EAASnQ,EAAQoQ,WACjBJ,EAAgB3d,KAAKopB,OAEvBC,GAAc,EA0BlB,OAzBI1L,GACAhQ,EAAQgQ,gBAER3d,KAAKoO,MAAMtP,OAAS,EACpBqqB,EAAc,IAAIF,GAAWjpB,KAAKoO,MAAMe,KAAI,SAAU1P,GAClD,OAAKA,EAAEsS,KAGAtS,EAAEsS,KAAKpE,GAFHlO,KAGXO,KAAKkpB,WACoB,IAAtBlpB,KAAKoO,MAAMtP,SACdkB,KAAKoO,MAAM,GAAGgb,QAAWppB,KAAKoO,MAAM,GAAGkb,YAAe3b,EAAQ8P,SAC9D4L,GAAc,GAElBF,EAAcnpB,KAAKoO,MAAM,GAAG2D,KAAKpE,IAEjCwb,EAAcnpB,KAEd2d,GACAhQ,EAAQkQ,oBAER7d,KAAKopB,SAAUppB,KAAKspB,YAAexL,GAAWuL,GACxCF,aAAuBnB,KAC7BmB,EAAc,IAAIrX,EAAMqX,IAErBA,GAGXtb,gBAAOF,EAASQ,GACZ,IAAK,IAAIzN,EAAI,EAAGA,EAAIV,KAAKoO,MAAMtP,OAAQ4B,IACnCV,KAAKoO,MAAM1N,GAAGmN,OAAOF,EAASQ,IACzBnO,KAAKkpB,WAAaxoB,EAAI,EAAIV,KAAKoO,MAAMtP,QACtCqP,EAAOL,IAAI,MAKvByb,6BACIvpB,KAAKoO,MAAQpO,KAAKoO,MAAMgT,QAAO,SAAS3R,GACpC,QAASA,aAAa2M,SCjElC,kBACI,WAAYxB,EAAMjN,EAASK,EAAO0E,GAC9B1S,KAAK4a,KAAOA,EAAKhJ,cACjB5R,KAAKgO,MAAQA,EACbhO,KAAK2N,QAAUA,EACf3N,KAAK0S,gBAAkBA,EAEvB1S,KAAK4X,KAAOjK,EAAQ2P,OAAO,GAAGoD,iBAAiB3T,IAAI/M,KAAK4a,MAuChE,OApCI4O,oBAAA,WACI,OAAO/O,QAAQza,KAAK4X,OAGxB4R,iBAAA,SAAK9Y,GAAL,WACUpD,MAAMC,QAAQmD,KAChBA,EAAO,CAACA,IAEZ,IAAM+Y,EAAWzpB,KAAK4X,KAAK6R,UACV,IAAbA,IACA/Y,EAAOA,EAAKvB,KAAI,SAAAX,GAAK,OAAAA,EAAEuD,KAAK8M,EAAKlR,aAErC,IAAM+b,EAAgB,SAAAC,GAAQ,QAAgB,YAAdA,EAAK/oB,OAkBrC,OAdA8P,EAAOA,EACF0Q,OAAOsI,GACPva,KAAI,SAAAwa,GACD,GAAkB,eAAdA,EAAK/oB,KAAuB,CAC5B,IAAMgpB,EAAWD,EAAKvb,MAAMgT,OAAOsI,GACnC,OAAwB,IAApBE,EAAS9qB,OACF8qB,EAAS,GAET,IAAIX,GAAWW,GAG9B,OAAOD,MAGE,IAAbF,EACOzpB,KAAK4X,WAAL5X,gBC2Gf,IAAK,IAAI2L,EAAI,EAAGjL,EAAI,EAAGmT,EAAKC,UAAUhV,OAAQ4B,EAAImT,EAAInT,IAAKiL,GAAKmI,UAAUpT,GAAG5B,OACxE,IAAIoR,EAAI5C,MAAM3B,GAAIoI,EAAI,EAA3B,IAA8BrT,EAAI,EAAGA,EAAImT,EAAInT,IACzC,IAAK,IAAI8N,EAAIsF,UAAUpT,GAAIsT,EAAI,EAAGC,EAAKzF,EAAE1P,OAAQkV,EAAIC,EAAID,IAAKD,IAC1D7D,EAAE6D,GAAKvF,EAAEwF,GACjB,OAAO9D,ID/GkBlQ,KAAK2N,SAAY+C,IAG/B1Q,KAAK4X,WAAL5X,KAAa0Q,SEvCtBmZ,GAAO,SAASjP,EAAMlK,EAAM1C,EAAO0E,GACrC1S,KAAK4a,KAAOA,EACZ5a,KAAK0Q,KAAOA,EACZ1Q,KAAK8pB,KAAgB,SAATlP,EACZ5a,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,GAGrBmX,GAAK9Z,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACvCtM,KAAM,OAENkS,gBAAOzE,GACCrO,KAAK0Q,OACL1Q,KAAK0Q,KAAOrC,EAAQyK,WAAW9Y,KAAK0Q,QAe5CqB,cAAKpE,GAAL,WAIUoc,EAAqBpc,EAAQmQ,OACnCnQ,EAAQmQ,QAAU9d,KAAK8pB,MACnB9pB,KAAK8pB,MAAQnc,EAAQ8P,SACrB9P,EAAQ4P,YAGZ,IAOI3G,EAPE8G,EAAW,YACTmB,EAAKiL,MAAQnc,EAAQ8P,SACrB9P,EAAQ+P,WAEZ/P,EAAQmQ,OAASiM,GAIfC,EAAa,IAAIC,GAAejqB,KAAK4a,KAAMjN,EAAS3N,KAAKiN,WAAYjN,KAAKgN,YAEhF,GAAIgd,EAAWE,UACX,IACItT,EAASoT,EAAWxW,KAAKxT,KAAK0Q,MAC9BgN,IACF,MAAOje,GACL,GAAIA,EAAEhC,eAAe,SAAWgC,EAAEhC,eAAe,UAC7C,MAAMgC,EAEV,KAAM,CACFmB,KAAMnB,EAAEmB,MAAQ,UAChBsW,QAAS,8BAA+BlX,KAAK4a,UAASnb,EAAEyX,QAAU,KAAKzX,EAAEyX,QAAY,IACrFlJ,MAAOhO,KAAKiN,WACZ1L,SAAUvB,KAAKgN,WAAWzL,SAC1B+T,KAAM7V,EAAEuc,WACRzG,OAAQ9V,EAAE0qB,cAKtB,GAAIvT,MAAAA,EAcA,OAXMA,aAAkB1J,IAKhB0J,EAAS,IAAIwD,EAJZxD,IAAqB,IAAXA,EAIYA,EAAO9G,WAHP,OAO/B8G,EAAOnJ,OAASzN,KAAKyN,OACrBmJ,EAAOlJ,UAAY1N,KAAK0N,UACjBkJ,EAGX,IAAMlG,EAAO1Q,KAAK0Q,KAAKvB,KAAI,SAAAX,GAAK,OAAAA,EAAEuD,KAAKpE,MAGvC,OAFA+P,IAEO,IAAImM,GAAK7pB,KAAK4a,KAAMlK,EAAM1Q,KAAKiN,WAAYjN,KAAKgN,aAG3Da,gBAAOF,EAASQ,GACZA,EAAOL,IAAO9N,KAAK4a,SAAS5a,KAAKgN,WAAYhN,KAAKiN,YAElD,IAAK,IAAIvM,EAAI,EAAGA,EAAIV,KAAK0Q,KAAK5R,OAAQ4B,IAClCV,KAAK0Q,KAAKhQ,GAAGmN,OAAOF,EAASQ,GACzBzN,EAAI,EAAIV,KAAK0Q,KAAK5R,QAClBqP,EAAOL,IAAI,MAInBK,EAAOL,IAAI,QCxGnB,IAAMsc,GAAW,SAASxP,EAAM5M,EAAO0E,GACnC1S,KAAK4a,KAAOA,EACZ5a,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,GAGrB0X,GAASra,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC3CtM,KAAM,WAENmR,cAAKpE,GACD,IAAIqN,EAAUJ,EAAO5a,KAAK4a,KAM1B,GAJ2B,IAAvBA,EAAKhK,QAAQ,QACbgK,EAAO,IAAI,IAAIwP,GAASxP,EAAK/I,MAAM,GAAI7R,KAAKiN,WAAYjN,KAAKgN,YAAY+E,KAAKpE,GAASS,OAGvFpO,KAAKqqB,WACL,KAAM,CAAEzpB,KAAM,OACVsW,QAAS,qCAAqC0D,EAC9CrZ,SAAUvB,KAAKgN,WAAWzL,SAC1ByM,MAAOhO,KAAKiN,YAqBpB,GAlBAjN,KAAKqqB,YAAa,EAElBrP,EAAWhb,KAAK6iB,KAAKlV,EAAQ2P,QAAQ,SAAUgN,GAC3C,IAAM7a,EAAI6a,EAAMtP,SAASJ,GACzB,GAAInL,EAAG,CACH,GAAIA,EAAEoL,UACqBlN,EAAQ2N,eAAe3N,EAAQ2N,eAAexc,OAAS,GAC/D+b,UAAYpL,EAAEoL,UAGjC,OAAIlN,EAAQ8P,OACD,IAAKoM,GAAK,QAAS,CAACpa,EAAErB,QAAS2D,KAAKpE,GAGpC8B,EAAErB,MAAM2D,KAAKpE,OAM5B,OADA3N,KAAKqqB,YAAa,EACXrP,EAEP,KAAM,CAAEpa,KAAM,OACVsW,QAAS,YAAY0D,kBACrBrZ,SAAUvB,KAAKgN,WAAWzL,SAC1ByM,MAAOhO,KAAKiN,aAIxB4V,cAAKnN,EAAK6U,GACN,IAAK,IAAI7pB,EAAI,EAAGwP,SAAGxP,EAAIgV,EAAI5W,OAAQ4B,IAE/B,GADAwP,EAAIqa,EAAI/W,KAAKkC,EAAKA,EAAIhV,IACb,OAAOwP,EAEpB,OAAO,QCzDf,IAAMsa,GAAW,SAAS5P,EAAM5M,EAAO0E,GACnC1S,KAAK4a,KAAOA,EACZ5a,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,GAGrB8X,GAASza,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC3CtM,KAAM,WAENmR,cAAKpE,GACD,IAAI0U,EACEzH,EAAO5a,KAAK4a,KAEZ6P,EAAa9c,EAAQ/L,cAAc8oB,KAAKC,SAASC,aAAa7a,UAAU8a,YAE9E,GAAI7qB,KAAKqqB,WACL,KAAM,CAAEzpB,KAAM,OACVsW,QAAS,oCAAoC0D,EAC7CrZ,SAAUvB,KAAKgN,WAAWzL,SAC1ByM,MAAOhO,KAAKiN,YAiCpB,GA9BAjN,KAAKqqB,YAAa,EAElBhI,EAAWriB,KAAK6iB,KAAKlV,EAAQ2P,QAAQ,SAAUgN,GAC3C,IAAI7a,EACEqb,EAAOR,EAAMjI,SAASzH,GAC5B,GAAIkQ,EAAM,CACN,IAAK,IAAIpqB,EAAI,EAAGA,EAAIoqB,EAAKhsB,OAAQ4B,IAC7B+O,EAAIqb,EAAKpqB,GAEToqB,EAAKpqB,GAAK,IAAIia,EAAYlL,EAAEmL,KACxBnL,EAAErB,MACFqB,EAAEoL,UACFpL,EAAEqL,MACFrL,EAAEzB,MACFyB,EAAEiD,gBACFjD,EAAEsL,OACFtL,EAAEuL,UAMV,GAHAyP,EAAWK,IAEXrb,EAAIqb,EAAKA,EAAKhsB,OAAS,IACjB+b,UACqBlN,EAAQ2N,eAAe3N,EAAQ2N,eAAexc,OAAS,GAC/D+b,UAAYpL,EAAEoL,UAGjC,OADApL,EAAIA,EAAErB,MAAM2D,KAAKpE,OAMrB,OADA3N,KAAKqqB,YAAa,EACXhI,EAEP,KAAM,CAAEzhB,KAAM,OACVsW,QAAS,aAAa0D,mBACtBrZ,SAAUvB,KAAK0S,gBAAgBnR,SAC/ByM,MAAOhO,KAAKgO,QAIxB6U,cAAKnN,EAAK6U,GACN,IAAK,IAAI7pB,EAAI,EAAGwP,SAAGxP,EAAIgV,EAAI5W,OAAQ4B,IAE/B,GADAwP,EAAIqa,EAAI/W,KAAKkC,EAAKA,EAAIhV,IACb,OAAOwP,EAEpB,OAAO,QCrEf,IAAM6a,GAAY,SAASpZ,EAAKpD,EAAIH,GAChCpO,KAAK2R,IAAMA,EACX3R,KAAKuO,GAAKA,EACVvO,KAAKoO,MAAQA,GAGjB2c,GAAUhb,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC5CtM,KAAM,YAENmR,cAAKpE,GACD,OAAO,IAAIod,GAAU/qB,KAAK2R,IAAII,KAAO/R,KAAK2R,IAAII,KAAKpE,GAAW3N,KAAK2R,IAC/D3R,KAAKuO,GAAKvO,KAAKoO,OAASpO,KAAKoO,MAAM2D,KAAQ/R,KAAKoO,MAAM2D,KAAKpE,GAAW3N,KAAKoO,QAGnFP,gBAAOF,EAASQ,GACZA,EAAOL,IAAI9N,KAAKqQ,MAAM1C,KAG1B0C,eAAM1C,GACF,IAAIS,EAAQpO,KAAK2R,IAAItB,MAAQrQ,KAAK2R,IAAItB,MAAM1C,GAAW3N,KAAK2R,IAO5D,OALI3R,KAAKuO,KACLH,GAASpO,KAAKuO,GACdH,GAAUpO,KAAKoO,MAAMiC,MAAQrQ,KAAKoO,MAAMiC,MAAM1C,GAAW3N,KAAKoO,OAG3D,IAAIA,SCvBnB,IAAM4c,GAAS,SAAS5S,EAAK6S,EAASC,EAASld,EAAO0E,GAClD1S,KAAKkrB,QAAsB,MAAXA,GAA0BA,EAC1ClrB,KAAKoO,MAAQ6c,GAAW,GACxBjrB,KAAKmrB,MAAQ/S,EAAInF,OAAO,GACxBjT,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAKorB,cAAgB,iBACrBprB,KAAKqrB,UAAY,kBACjBrrB,KAAKua,UAAY2Q,GAGrBF,GAAOjb,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACzCtM,KAAM,SAENiN,gBAAOF,EAASQ,GACPnO,KAAKkrB,SACN/c,EAAOL,IAAI9N,KAAKmrB,MAAOnrB,KAAKgN,WAAYhN,KAAKiN,YAEjDkB,EAAOL,IAAI9N,KAAKoO,OACXpO,KAAKkrB,SACN/c,EAAOL,IAAI9N,KAAKmrB,QAIxBG,6BACI,OAAOtrB,KAAKoO,MAAMc,MAAMlP,KAAKorB,gBAGjCrZ,cAAKpE,GACD,IAAM4d,EAAOvrB,KACToO,EAAQpO,KAAKoO,MASjB,SAASod,EAAiBpd,EAAOqd,EAAQC,GACrC,IAAIC,EAAiBvd,EACrB,GACIA,EAAQud,EAAe7b,WACvB6b,EAAiBvd,EAAMjR,QAAQsuB,EAAQC,SAClCtd,IAAUud,GACnB,OAAOA,EAIX,OAFAvd,EAAQod,EAAiBpd,EAAOpO,KAAKorB,eAhBT,SAAUxtB,EAAGgd,GACrC,IAAMnL,EAAI,IAAI2a,GAAS,IAAIxP,EAAQ2Q,EAAKte,WAAYse,EAAKve,YAAY+E,KAAKpE,GAAS,GACnF,OAAQ8B,aAAaub,GAAUvb,EAAErB,MAAQqB,EAAEY,WAe/CjC,EAAQod,EAAiBpd,EAAOpO,KAAKqrB,WAbT,SAAUztB,EAAGgd,GACrC,IAAMnL,EAAI,IAAI+a,GAAS,IAAI5P,EAAQ2Q,EAAKte,WAAYse,EAAKve,YAAY+E,KAAKpE,GAAS,GACnF,OAAQ8B,aAAaub,GAAUvb,EAAErB,MAAQqB,EAAEY,WAYxC,IAAI2a,GAAOhrB,KAAKmrB,MAAQ/c,EAAQpO,KAAKmrB,MAAO/c,EAAOpO,KAAKkrB,QAASlrB,KAAKiN,WAAYjN,KAAKgN,aAGlG8B,iBAAQqC,GAEJ,MAAmB,WAAfA,EAAMvQ,MAAsBZ,KAAKkrB,SAAY/Z,EAAM+Z,QAG5C/Z,EAAMd,OAASrQ,KAAKqQ,UAAYc,EAAMd,QAAU,OAAI7D,EAFpDU,EAAKub,eAAezoB,KAAKoO,MAAO+C,EAAM/C,UCtDzD,IAAMwd,GAAM,SAASC,EAAK7d,EAAO0E,EAAiBoZ,GAC9C9rB,KAAKoO,MAAQyd,EACb7rB,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAK8rB,QAAUA,GAGnBF,GAAI7b,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACtCtM,KAAM,MAENkS,gBAAOzE,GACHrO,KAAKoO,MAAQC,EAAQC,MAAMtO,KAAKoO,QAGpCP,gBAAOF,EAASQ,GACZA,EAAOL,IAAI,QACX9N,KAAKoO,MAAMP,OAAOF,EAASQ,GAC3BA,EAAOL,IAAI,MAGfiE,cAAKpE,GACD,IACIuQ,EADE2N,EAAM7rB,KAAKoO,MAAM2D,KAAKpE,GAG5B,IAAK3N,KAAK8rB,UAGkB,iBADxB5N,EAAWle,KAAKgN,YAAchN,KAAKgN,WAAWkR,WAErB,iBAAd2N,EAAIzd,OACXT,EAAQqQ,oBAAoB6N,EAAIzd,QAC3Byd,EAAIV,QACLjN,EAAsBA,EAlC1B/gB,QAAQ,eAAe,SAAS+R,GAAS,MAAO,KAAKA,MAoCrD2c,EAAIzd,MAAQT,EAAQsQ,YAAY4N,EAAIzd,MAAO8P,IAE3C2N,EAAIzd,MAAQT,EAAQyQ,cAAcyN,EAAIzd,OAItCT,EAAQoe,UACHF,EAAIzd,MAAMc,MAAM,cAAc,CAC/B,IACM6c,IADwC,IAA5BF,EAAIzd,MAAMwC,QAAQ,KAAc,IAAM,KAC5BjD,EAAQoe,SACJ,IAA5BF,EAAIzd,MAAMwC,QAAQ,KAClBib,EAAIzd,MAAQyd,EAAIzd,MAAMjR,QAAQ,IAAQ4uB,OAEtCF,EAAIzd,OAAS2d,EAM7B,OAAO,IAAIH,GAAIC,EAAK7rB,KAAKiN,WAAYjN,KAAKgN,YAAY,MClD9D,IAAMgf,GAAQ,SAAS5d,EAAO6d,EAAUje,EAAO0E,EAAiBC,GAC5D3S,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EAEjB,IAAM2M,EAAY,IAAK9G,EAAS,GAAI,KAAM,KAAMvY,KAAKyN,OAAQzN,KAAK0N,WAAY4L,uBAE9EtZ,KAAKisB,SAAW,IAAIjS,EAAMiS,GAC1BjsB,KAAKsf,MAAQ,CAAC,IAAIF,EAAQC,EAAWjR,IACrCpO,KAAKsf,MAAM,GAAGmB,cAAe,EAC7BzgB,KAAK4S,mBAAmBD,GACxB3S,KAAKua,WAAY,EACjBva,KAAK6S,UAAUwM,EAAWrf,MAC1BA,KAAK6S,UAAU7S,KAAKisB,SAAUjsB,MAC9BA,KAAK6S,UAAU7S,KAAKsf,MAAOtf,OAG/BgsB,GAAMjc,UAAYlD,OAAOmD,OAAO,IAAIiW,EAAU,CAC1CrlB,KAAM,QAEN4Z,yBACI,OAAO,GAGX1H,gBAAOzE,GACCrO,KAAKisB,WACLjsB,KAAKisB,SAAW5d,EAAQC,MAAMtO,KAAKisB,WAEnCjsB,KAAKsf,QACLtf,KAAKsf,MAAQjR,EAAQyK,WAAW9Y,KAAKsf,SAI7CzR,gBAAOF,EAASQ,GACZA,EAAOL,IAAI,UAAW9N,KAAK0N,UAAW1N,KAAKyN,QAC3CzN,KAAKisB,SAASpe,OAAOF,EAASQ,GAC9BnO,KAAKmmB,cAAcxY,EAASQ,EAAQnO,KAAKsf,QAG7CvN,cAAKpE,GACIA,EAAQwT,cACTxT,EAAQwT,YAAc,GACtBxT,EAAQ2Y,UAAY,IAGxB,IAAM7nB,EAAQ,IAAIutB,GAAM,KAAM,GAAIhsB,KAAKyN,OAAQzN,KAAK0N,UAAW1N,KAAK2S,kBAkBpE,OAjBI3S,KAAK6b,YACL7b,KAAKsf,MAAM,GAAGzD,UAAY7b,KAAK6b,UAC/Bpd,EAAMod,UAAY7b,KAAK6b,WAG3Bpd,EAAMwtB,SAAWjsB,KAAKisB,SAASla,KAAKpE,GAEpCA,EAAQ2Y,UAAU9lB,KAAK/B,GACvBkP,EAAQwT,YAAY3gB,KAAK/B,GAEzBuB,KAAKsf,MAAM,GAAGoB,iBAAmB/S,EAAQ2P,OAAO,GAAGoD,iBAAiB3B,UACpEpR,EAAQ2P,OAAOuD,QAAQ7gB,KAAKsf,MAAM,IAClC7gB,EAAM6gB,MAAQ,CAACtf,KAAKsf,MAAM,GAAGvN,KAAKpE,IAClCA,EAAQ2P,OAAO1D,QAEfjM,EAAQ2Y,UAAU9K,MAEkB,IAA7B7N,EAAQ2Y,UAAUxnB,OAAeL,EAAMytB,QAAQve,GAClDlP,EAAM0tB,WAAWxe,IAGzBue,iBAAQve,GACJ,IAAIiJ,EAAS5W,KAGb,GAAI2N,EAAQwT,YAAYriB,OAAS,EAAG,CAChC,IAAMugB,EAAY,IAAK9G,EAAS,GAAI,KAAM,KAAMvY,KAAKiN,WAAYjN,KAAKgN,YAAasM,wBACnF1C,EAAS,IAAIwI,EAAQC,EAAW1R,EAAQwT,cACjCiL,YAAa,EACpBxV,EAAOhE,mBAAmB5S,KAAK2S,kBAC/B3S,KAAK6S,UAAU+D,EAAQ5W,MAM3B,cAHO2N,EAAQwT,mBACRxT,EAAQ2Y,UAER1P,GAGXuV,oBAAWxe,GACP,IAAIjN,EACA0N,EACE+O,EAAOxP,EAAQ2Y,UAAUplB,OAAO,CAAClB,OAGvC,IAAKU,EAAI,EAAGA,EAAIyc,EAAKre,OAAQ4B,IACzB0N,EAAQ+O,EAAKzc,GAAGurB,oBAAoBjS,EAChCmD,EAAKzc,GAAGurB,SAAS7d,MAAQ+O,EAAKzc,GAAGurB,SACrC9O,EAAKzc,GAAK4M,MAAMC,QAAQa,GAASA,EAAQ,CAACA,GAsB9C,OAZApO,KAAKisB,SAAW,IAAIjS,EAAMha,KAAKqsB,QAAQlP,GAAMhO,KAAI,SAAAgO,GAG7C,IAFAA,EAAOA,EAAKhO,KAAI,SAAAmd,GAAY,OAAAA,EAASjc,MAAQic,EAAW,IAAIlS,EAAUkS,MAEjE5rB,EAAIyc,EAAKre,OAAS,EAAG4B,EAAI,EAAGA,IAC7Byc,EAAKxc,OAAOD,EAAG,EAAG,IAAI0Z,EAAU,QAGpC,OAAO,IAAI6O,GAAW9L,OAE1Bnd,KAAK6S,UAAU7S,KAAKisB,SAAUjsB,MAGvB,IAAIof,EAAQ,GAAI,KAG3BiN,iBAAQ5W,GACJ,GAAmB,IAAfA,EAAI3W,OACJ,MAAO,GACJ,GAAmB,IAAf2W,EAAI3W,OACX,OAAO2W,EAAI,GAIX,IAFA,IAAMmB,EAAS,GACT2V,EAAOvsB,KAAKqsB,QAAQ5W,EAAI5D,MAAM,IAC3BnR,EAAI,EAAGA,EAAI6rB,EAAKztB,OAAQ4B,IAC7B,IAAK,IAAIsT,EAAI,EAAGA,EAAIyB,EAAI,GAAG3W,OAAQkV,IAC/B4C,EAAOpW,KAAK,CAACiV,EAAI,GAAGzB,IAAI9S,OAAOqrB,EAAK7rB,KAG5C,OAAOkW,GAIf2K,yBAAgBlC,GACPA,IAGLrf,KAAKsf,MAAQ,CAAC,IAAIF,EAAQgB,EAAgBf,GAAY,CAACrf,KAAKsf,MAAM,MAClEtf,KAAK6S,UAAU7S,KAAKsf,MAAOtf,UC/HnC,IAAMwsB,GAAS,SAASrP,EAAM8O,EAAU5uB,EAAS2Q,EAAO0E,EAAiBC,GAQrE,GAPA3S,KAAK3C,QAAUA,EACf2C,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAKmd,KAAOA,EACZnd,KAAKisB,SAAWA,EAChBjsB,KAAKua,WAAY,OAES/N,IAAtBxM,KAAK3C,QAAQqtB,MAAsB1qB,KAAK3C,QAAQ0d,OAChD/a,KAAKysB,KAAOzsB,KAAK3C,QAAQqtB,MAAQ1qB,KAAK3C,QAAQ0d,WAC3C,CACH,IAAM2R,EAAY1sB,KAAK2sB,UACnBD,GAAa,0BAA0BvQ,KAAKuQ,KAC5C1sB,KAAKysB,KAAM,GAGnBzsB,KAAK4S,mBAAmBD,GACxB3S,KAAK6S,UAAU7S,KAAKisB,SAAUjsB,MAC9BA,KAAK6S,UAAU7S,KAAKmd,KAAMnd,OAG9BwsB,GAAOzc,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACzCtM,KAAM,SAENkS,gBAAOzE,GACCrO,KAAKisB,WACLjsB,KAAKisB,SAAW5d,EAAQC,MAAMtO,KAAKisB,WAEvCjsB,KAAKmd,KAAO9O,EAAQC,MAAMtO,KAAKmd,MAC1Bnd,KAAK3C,QAAQuvB,UAAa5sB,KAAK3C,QAAQ0d,SAAU/a,KAAKugB,OACvDvgB,KAAKugB,KAAOlS,EAAQC,MAAMtO,KAAKugB,QAIvC1S,gBAAOF,EAASQ,GACRnO,KAAKysB,UAAyCjgB,IAAlCxM,KAAKmd,KAAKzP,UAAUmf,YAChC1e,EAAOL,IAAI,WAAY9N,KAAK0N,UAAW1N,KAAKyN,QAC5CzN,KAAKmd,KAAKtP,OAAOF,EAASQ,GACtBnO,KAAKisB,WACL9d,EAAOL,IAAI,KACX9N,KAAKisB,SAASpe,OAAOF,EAASQ,IAElCA,EAAOL,IAAI,OAInB6e,mBACI,OAAQ3sB,KAAKmd,gBAAgByO,GACzB5rB,KAAKmd,KAAK/O,MAAMA,MAAQpO,KAAKmd,KAAK/O,OAG1C0e,4BACI,IAAI3P,EAAOnd,KAAKmd,KAIhB,OAHIA,aAAgByO,KAChBzO,EAAOA,EAAK/O,SAEZ+O,aAAgB6N,KACT7N,EAAKmO,qBAMpByB,uBAAcpf,GACV,IAAIwP,EAAOnd,KAAKmd,KAMhB,OAJIA,aAAgByO,KAChBzO,EAAOA,EAAK/O,OAGT,IAAIoe,GAAOrP,EAAKpL,KAAKpE,GAAU3N,KAAKisB,SAAUjsB,KAAK3C,QAAS2C,KAAKyN,OAAQzN,KAAK0N,UAAW1N,KAAK2S,mBAGzGqa,kBAASrf,GACL,IAAMwP,EAAOnd,KAAKmd,KAAKpL,KAAKpE,GACtBX,EAAWhN,KAAK0N,UAEtB,KAAMyP,aAAgByO,IAAM,CAExB,IAAMc,EAAYvP,EAAK/O,MACnBpB,GACA0f,GACA/e,EAAQqQ,oBAAoB0O,GAC5BvP,EAAK/O,MAAQT,EAAQsQ,YAAYyO,EAAW1f,EAASkR,UAErDf,EAAK/O,MAAQT,EAAQyQ,cAAcjB,EAAK/O,OAIhD,OAAO+O,GAGXpL,cAAKpE,GACD,IAAMiJ,EAAS5W,KAAKitB,OAAOtf,GAW3B,OAVI3N,KAAK3C,QAAQwvB,WAAa7sB,KAAKktB,sBAC3BtW,EAAO9X,QAA4B,IAAlB8X,EAAO9X,OACxB8X,EAAOpJ,SAAQ,SAAUH,GACrBA,EAAK8f,wBAITvW,EAAOuW,sBAGRvW,GAGXqW,gBAAOtf,GACH,IAAI0S,EACA+M,EACEnB,EAAWjsB,KAAKisB,UAAYjsB,KAAKisB,SAASla,KAAKpE,GAErD,GAAI3N,KAAK3C,QAAQuvB,SAAU,CACvB,GAAI5sB,KAAKugB,MAAQvgB,KAAKugB,KAAKxO,KACvB,IACI/R,KAAKugB,KAAKxO,KAAKpE,GAEnB,MAAOlO,GAEH,MADAA,EAAEyX,QAAU,iCACN,IAAIH,EAAUtX,EAAGO,KAAKugB,KAAKlH,QAASrZ,KAAKugB,KAAKhf,UAQ5D,OALA6rB,EAAWzf,EAAQ2P,OAAO,IAAM3P,EAAQ2P,OAAO,GAAGoD,mBACjC1gB,KAAKugB,MAAQvgB,KAAKugB,KAAKtf,WACpCmsB,EAASzO,YAAa3e,KAAKugB,KAAKtf,WAG7B,GAGX,GAAIjB,KAAKqtB,OACoB,mBAAdrtB,KAAKqtB,OACZrtB,KAAKqtB,KAAOrtB,KAAKqtB,QAEjBrtB,KAAKqtB,MACL,MAAO,GAGf,GAAIrtB,KAAK3C,QAAQ0d,OAAQ,CACrB,IAAM1D,EAAW,IAAI+C,EAAUpa,KAAKugB,KAAM,EACtC,CACIhf,SAAUvB,KAAKstB,iBACfT,UAAW7sB,KAAKmd,KAAKzP,WAAa1N,KAAKmd,KAAKzP,UAAUmf,YACvD,GAAM,GAEb,OAAO7sB,KAAKisB,SAAW,IAAID,GAAM,CAAC3U,GAAWrX,KAAKisB,SAAS7d,OAAS,CAACiJ,GAClE,GAAIrX,KAAKysB,IAAK,CACjB,IAAMc,EAAY,IAAIf,GAAOxsB,KAAKgtB,SAASrf,GAAUse,EAAUjsB,KAAK3C,QAAS2C,KAAKyN,QAClF,IAAK8f,EAAUd,KAAOzsB,KAAKF,MACvB,MAAME,KAAKF,MAEf,OAAOytB,EACJ,OAAIvtB,KAAKugB,OACZF,EAAU,IAAIjB,EAAQ,KAAMgB,EAAgBpgB,KAAKugB,KAAKjB,SAC9CyB,YAAYpT,GAEb3N,KAAKisB,SAAW,IAAID,GAAM3L,EAAQf,MAAOtf,KAAKisB,SAAS7d,OAASiS,EAAQf,OAExE,MChLnB,IAAMkO,GAAa,aAEnBA,GAAWzd,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC7CugB,4BAAmBC,EAAY/f,GAC3B,IAAIiJ,EACE2U,EAAOvrB,KACP2tB,EAAc,GAEpB,IAAKhgB,EAAQigB,kBACT,KAAM,CAAE1W,QAAS,+DACb3V,SAAUvB,KAAKgN,WAAWzL,SAC1ByM,MAAOhO,KAAKiN,YAGpBygB,EAAaA,EAAWvwB,QAAQ,kBAAkB,SAAUS,EAAGgd,GAC3D,OAAO2Q,EAAKsC,MAAM,IAAIzD,GAAS,IAAIxP,EAAQ2Q,EAAKte,WAAYse,EAAKve,YAAY+E,KAAKpE,OAGtF,IACI+f,EAAa,IAAI7V,SAAS,WAAW6V,OACvC,MAAOjuB,GACL,KAAM,CAAEyX,QAAS,gCAAgCzX,EAAEyX,kBAAkBwW,MACjEnsB,SAAUvB,KAAKgN,WAAWzL,SAC1ByM,MAAOhO,KAAKiN,YAGpB,IAAM4U,EAAYlU,EAAQ2P,OAAO,GAAGuE,YACpC,IAAK,IAAM9N,KAAK8N,EACRA,EAAUpkB,eAAesW,KAEzB4Z,EAAY5Z,EAAElC,MAAM,IAAM,CACtBzD,MAAOyT,EAAU9N,GAAG3F,MACpB0f,KAAM,WACF,OAAO9tB,KAAKoO,MAAM2D,KAAKpE,GAAS0C,WAMhD,IACIuG,EAAS8W,EAAWla,KAAKma,GAC3B,MAAOluB,GACL,KAAM,CAAEyX,QAAS,iCAAiCzX,EAAEmb,UAASnb,EAAEyX,QAAQ/Z,QAAQ,OAAQ,SACnFoE,SAAUvB,KAAKgN,WAAWzL,SAC1ByM,MAAOhO,KAAKiN,YAEpB,OAAO2J,GAGXiX,eAAMnY,GACF,OAAIpI,MAAMC,QAAQmI,EAAItH,QAAWsH,EAAItH,MAAMtP,OAAS,EACzC,IAAI4W,EAAItH,MAAMe,KAAI,SAAUM,GAAK,OAAOA,EAAEY,WAAYnC,KAAK,UAE3DwH,EAAIrF,WCnDvB,IAAM0d,GAAa,SAASC,EAAQ9C,EAASld,EAAO0E,GAChD1S,KAAKkrB,QAAUA,EACflrB,KAAK0tB,WAAaM,EAClBhuB,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,GAGrBqb,GAAWhe,UAAYlD,OAAOmD,OAAO,IAAIwd,GAAc,CACnD5sB,KAAM,aAENmR,cAAKpE,GACD,IAAMiJ,EAAS5W,KAAKytB,mBAAmBztB,KAAK0tB,WAAY/f,GAClD/M,SAAcgW,EAEpB,MAAa,WAAThW,GAAsBunB,MAAMvR,GAEZ,WAAThW,EACA,IAAIoqB,GAAO,IAAIpU,MAAWA,EAAQ5W,KAAKkrB,QAASlrB,KAAKyN,QACrDH,MAAMC,QAAQqJ,GACd,IAAIwD,EAAUxD,EAAO1I,KAAK,OAE1B,IAAIkM,EAAUxD,GANd,IAAIoR,GAAUpR,MClBjC,IAAMqX,GAAa,SAAStc,EAAKka,GAC7B7rB,KAAK2R,IAAMA,EACX3R,KAAKoO,MAAQyd,GAGjBoC,GAAWle,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC7CtM,KAAM,aAENkS,gBAAOzE,GACHrO,KAAKoO,MAAQC,EAAQC,MAAMtO,KAAKoO,QAGpC2D,cAAKpE,GACD,OAAI3N,KAAKoO,MAAM2D,KACJ,IAAIkc,GAAWjuB,KAAK2R,IAAK3R,KAAKoO,MAAM2D,KAAKpE,IAE7C3N,MAGX6N,gBAAOF,EAASQ,GACZA,EAAOL,IAAO9N,KAAK2R,SACf3R,KAAKoO,MAAMP,OACX7N,KAAKoO,MAAMP,OAAOF,EAASQ,GAE3BA,EAAOL,IAAI9N,KAAKoO,UCxB5B,IAAM8f,GAAY,SAAS3f,EAAIwC,EAAGb,EAAGxP,EAAGytB,GACpCnuB,KAAKuO,GAAKA,EAAG8D,OACbrS,KAAKouB,OAASrd,EACd/Q,KAAKquB,OAASne,EACdlQ,KAAKyN,OAAS/M,EACdV,KAAKmuB,OAASA,GAGlBD,GAAUne,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC5CtM,KAAM,YAENkS,gBAAOzE,GACHrO,KAAKouB,OAAS/f,EAAQC,MAAMtO,KAAKouB,QACjCpuB,KAAKquB,OAAShgB,EAAQC,MAAMtO,KAAKquB,SAGrCtc,cAAKpE,GACD,IAAMiJ,EAAS,SAAWrI,EAAIC,EAAGC,GAC7B,OAAQF,GACJ,IAAK,MAAO,OAAOC,GAAKC,EACxB,IAAK,KAAO,OAAOD,GAAKC,EACxB,QACI,OAAQvB,EAAK4B,QAAQN,EAAGC,IACpB,KAAM,EACF,MAAc,MAAPF,GAAqB,OAAPA,GAAsB,OAAPA,EACxC,KAAK,EACD,MAAc,MAAPA,GAAqB,OAAPA,GAAsB,OAAPA,GAAsB,OAAPA,EACvD,KAAK,EACD,MAAc,MAAPA,GAAqB,OAAPA,EACzB,QACI,OAAO,IAbZ,CAgBZvO,KAAKuO,GAAIvO,KAAKouB,OAAOrc,KAAKpE,GAAU3N,KAAKquB,OAAOtc,KAAKpE,IAExD,OAAO3N,KAAKmuB,QAAUvX,EAASA,KCnCvC,IAAM0X,GAAoB,SAASlgB,GAC/BpO,KAAKoO,MAAQA,GAGjBkgB,GAAkBve,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACpDtM,KAAM,sBCHV,IAAM2tB,GAAW,SAASlhB,GACtBrN,KAAKoO,MAAQf,GAGjBkhB,GAASxe,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC3CtM,KAAM,WAENiN,gBAAOF,EAASQ,GACZA,EAAOL,IAAI,KACX9N,KAAKoO,MAAMP,OAAOF,EAASQ,IAG/B4D,cAAKpE,GACD,OAAIA,EAAQoQ,WACD,IAAK+K,GAAU,IAAK,CAAC,IAAId,IAAW,GAAIhoB,KAAKoO,QAAS2D,KAAKpE,GAE/D,IAAI4gB,GAASvuB,KAAKoO,MAAM2D,KAAKpE,OCjB5C,IAAM6gB,GAAS,SAAS3O,EAAU4O,EAAQzgB,EAAO0E,EAAiBC,GAU9D,OATA3S,KAAK6f,SAAWA,EAChB7f,KAAKyuB,OAASA,EACdzuB,KAAK0uB,UAAYF,GAAOG,UACxB3uB,KAAK4uB,WAAa,CAAC5uB,KAAK0uB,WACxB1uB,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAK4S,mBAAmBD,GACxB3S,KAAKua,WAAY,EAETkU,GACJ,IAAK,MACDzuB,KAAK6uB,aAAc,EACnB7uB,KAAK8uB,YAAa,EAClB,MACJ,QACI9uB,KAAK6uB,aAAc,EACnB7uB,KAAK8uB,YAAa,EAG1B9uB,KAAK6S,UAAU7S,KAAK6f,SAAU7f,OAGlCwuB,GAAOze,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACzCtM,KAAM,SAENkS,gBAAOzE,GACHrO,KAAK6f,SAAWxR,EAAQC,MAAMtO,KAAK6f,WAGvC9N,cAAKpE,GACD,OAAO,IAAI6gB,GAAOxuB,KAAK6f,SAAS9N,KAAKpE,GAAU3N,KAAKyuB,OAAQzuB,KAAKiN,WAAYjN,KAAKgN,WAAYhN,KAAK2S,mBAGvGI,eAAMpF,GACF,OAAO,IAAI6gB,GAAOxuB,KAAK6f,SAAU7f,KAAKyuB,OAAQzuB,KAAKiN,WAAYjN,KAAKgN,WAAYhN,KAAK2S,mBAIzFoc,2BAAkB1P,GACd,IAAuB3e,EAAGsuB,EAAtBC,EAAe,GAEnB,IAAKvuB,EAAI,EAAGA,EAAI2e,EAAUvgB,OAAQ4B,IAC9BsuB,EAAmB3P,EAAU3e,GAAG8X,SAG5B9X,EAAI,GAAKsuB,EAAiBlwB,QAAmD,KAAzCkwB,EAAiB,GAAGxc,WAAWpE,QACnE4gB,EAAiB,GAAGxc,WAAWpE,MAAQ,KAE3C6gB,EAAeA,EAAa/tB,OAAOme,EAAU3e,GAAG8X,UAGpDxY,KAAKkvB,cAAgB,CAAC,IAAI3W,EAAS0W,IACnCjvB,KAAKkvB,cAAc,GAAGtc,mBAAmB5S,KAAK2S,qBAItD6b,GAAOG,QAAU,ECtDjB,IAAMQ,GAAe,SAASnU,EAAUhN,EAAO0E,GAC3C1S,KAAKgb,SAAWA,EAChBhb,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAKua,WAAY,GAGrB4U,GAAapf,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC/CtM,KAAM,eAENmR,cAAKpE,GACD,IAAI2R,EACA8P,EAAkB,IAAIhF,GAASpqB,KAAKgb,SAAUhb,KAAKiN,WAAYjN,KAAKgN,YAAY+E,KAAKpE,GACnF7N,EAAQ,IAAIiX,EAAU,CAACG,QAAS,oCAAoClX,KAAKgb,WAE/E,IAAKoU,EAAgB/O,QAAS,CAC1B,GAAI+O,EAAgB9P,MAChBA,EAAQ8P,OAEP,GAAI9hB,MAAMC,QAAQ6hB,GACnB9P,EAAQ,IAAIF,EAAQ,GAAIgQ,OAEvB,CAAA,IAAI9hB,MAAMC,QAAQ6hB,EAAgBhhB,OAInC,MAAMtO,EAHNwf,EAAQ,IAAIF,EAAQ,GAAIgQ,EAAgBhhB,OAK5CghB,EAAkB,IAAI5I,EAAgBlH,GAG1C,GAAI8P,EAAgB/O,QAChB,OAAO+O,EAAgB3I,SAAS9Y,GAEpC,MAAM7N,KCnCd,IAAMuvB,GAAiB,SAASC,EAAUC,EAASvhB,EAAOhB,GACtDhN,KAAKoO,MAAQkhB,EACbtvB,KAAKuvB,QAAUA,EACfvvB,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYV,GAGrBqiB,GAAetf,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CACjDtM,KAAM,iBAENmR,cAAKpE,GACD,IAAIjN,EAAMka,EAAM0E,EAAQtf,KAAKoO,MAAM2D,KAAKpE,GAExC,IAAKjN,EAAI,EAAGA,EAAIV,KAAKuvB,QAAQzwB,OAAQ4B,IAAK,CAYtC,GAXAka,EAAO5a,KAAKuvB,QAAQ7uB,GAOhB4M,MAAMC,QAAQ+R,KACdA,EAAQ,IAAIF,EAAQ,CAAC,IAAI7G,GAAa+G,IAG7B,KAAT1E,EACA0E,EAAQA,EAAMgD,uBAEb,GAAuB,MAAnB1H,EAAK3H,OAAO,IAQjB,GAPuB,MAAnB2H,EAAK3H,OAAO,KACZ2H,EAAO,IAAI,IAAIwP,GAASxP,EAAKtC,OAAO,IAAIvG,KAAKpE,GAASS,OAEtDkR,EAAMuC,YACNvC,EAAQA,EAAMtE,SAASJ,KAGtB0E,EACD,KAAM,CAAE1e,KAAM,OACVsW,QAAS,YAAY0D,eACrBrZ,SAAUvB,KAAKgN,WAAWzL,SAC1ByM,MAAOhO,KAAKiN,gBAGnB,CAWD,GATI2N,EADyB,OAAzBA,EAAK4U,UAAU,EAAG,GACX,IAAI,IAAIpF,GAASxP,EAAKtC,OAAO,IAAIvG,KAAKpE,GAASS,MAG5B,MAAnBwM,EAAK3H,OAAO,GAAa2H,EAAO,IAAIA,EAE3C0E,EAAM2C,aACN3C,EAAQA,EAAM+C,SAASzH,KAGtB0E,EACD,KAAM,CAAE1e,KAAM,OACVsW,QAAS,aAAa0D,EAAKtC,OAAO,iBAClC/W,SAAUvB,KAAKgN,WAAWzL,SAC1ByM,MAAOhO,KAAKiN,YAIpBqS,EAAQA,EAAMA,EAAMxgB,OAAS,GAG7BwgB,EAAMlR,QACNkR,EAAQA,EAAMvN,KAAKpE,GAASS,OAE5BkR,EAAMe,UACNf,EAAQA,EAAMe,QAAQtO,KAAKpE,IAGnC,OAAO2R,KCpEf,IAAMmQ,GAAa,SAAS7U,EAAM8U,EAAQpQ,EAAO5G,EAAWiX,EAAUrS,EAAQ3K,GAC1E3S,KAAK4a,KAAOA,GAAQ,kBACpB5a,KAAKqf,UAAY,CAAC,IAAI9G,EAAS,CAAC,IAAIhG,EAAQ,KAAMqI,GAAM,EAAO5a,KAAKyN,OAAQzN,KAAK0N,cACjF1N,KAAK0vB,OAASA,EACd1vB,KAAK0Y,UAAYA,EACjB1Y,KAAK2vB,SAAWA,EAChB3vB,KAAK4vB,MAAQF,EAAO5wB,OACpBkB,KAAKsf,MAAQA,EACbtf,KAAKwf,SAAW,GAChB,IAAMqQ,EAAqB,GAC3B7vB,KAAK8vB,SAAWJ,EAAOrb,QAAO,SAAU0T,EAAOgI,GAC3C,OAAKA,EAAEnV,MAASmV,EAAEnV,OAASmV,EAAE3hB,MAClB2Z,EAAQ,GAGf8H,EAAmBrvB,KAAKuvB,EAAEnV,MACnBmN,KAEZ,GACH/nB,KAAK6vB,mBAAqBA,EAC1B7vB,KAAKsd,OAASA,EACdtd,KAAK4S,mBAAmBD,GACxB3S,KAAKua,WAAY,GAGrBkV,GAAW1f,UAAYlD,OAAOmD,OAAO,IAAIoP,EAAW,CAChDxe,KAAM,kBACNqgB,WAAW,EAEXnO,gBAAOzE,GACCrO,KAAK0vB,QAAU1vB,KAAK0vB,OAAO5wB,SAC3BkB,KAAK0vB,OAASrhB,EAAQyK,WAAW9Y,KAAK0vB,SAE1C1vB,KAAKsf,MAAQjR,EAAQyK,WAAW9Y,KAAKsf,OACjCtf,KAAK0Y,YACL1Y,KAAK0Y,UAAYrK,EAAQC,MAAMtO,KAAK0Y,aAI5CsX,oBAAWriB,EAASsiB,EAAUvf,EAAMwf,GAEhC,IAEIC,EACAC,EAEA1vB,EACAsT,EACA6X,EACAjR,EACAyV,EACAC,EAVEhG,EAAQ,IAAIlL,EAAQ,KAAM,MAI1BsQ,EAAStP,EAAgBpgB,KAAK0vB,QAOhCa,EAAa,EAOjB,GALIN,EAAS3S,QAAU2S,EAAS3S,OAAO,IAAM2S,EAAS3S,OAAO,GAAGoD,mBAC5D4J,EAAM5J,iBAAmBuP,EAAS3S,OAAO,GAAGoD,iBAAiB3B,WAEjEkR,EAAW,IAAIxT,EAASY,KAAK4S,EAAU,CAAC3F,GAAOppB,OAAO+uB,EAAS3S,SAE3D5M,EAIA,IAFA6f,GADA7f,EAAO0P,EAAgB1P,IACL5R,OAEb4B,EAAI,EAAGA,EAAI6vB,EAAY7vB,IAExB,GAAIka,GADJwV,EAAM1f,EAAKhQ,KACQ0vB,EAAIxV,KAAO,CAE1B,IADAyV,GAAe,EACVrc,EAAI,EAAGA,EAAI0b,EAAO5wB,OAAQkV,IAC3B,IAAKkc,EAAelc,IAAM4G,IAAS8U,EAAO1b,GAAG4G,KAAM,CAC/CsV,EAAelc,GAAKoc,EAAIhiB,MAAM2D,KAAKpE,GACnC2c,EAAM1H,YAAY,IAAIjI,EAAYC,EAAMwV,EAAIhiB,MAAM2D,KAAKpE,KACvD0iB,GAAe,EACf,MAGR,GAAIA,EAAc,CACd3f,EAAK/P,OAAOD,EAAG,GACfA,IACA,SAEA,KAAM,CAAEE,KAAM,UAAWsW,QAAS,sBAAsBlX,KAAK4a,SAAQlK,EAAKhQ,GAAGka,mBAM7F,IADA0V,EAAW,EACN5vB,EAAI,EAAGA,EAAIgvB,EAAO5wB,OAAQ4B,IAC3B,IAAIwvB,EAAexvB,GAAnB,CAIA,GAFA0vB,EAAM1f,GAAQA,EAAK4f,GAEf1V,EAAO8U,EAAOhvB,GAAGka,KACjB,GAAI8U,EAAOhvB,GAAGivB,SAAU,CAEpB,IADAQ,EAAU,GACLnc,EAAIsc,EAAUtc,EAAIuc,EAAYvc,IAC/Bmc,EAAQ3vB,KAAKkQ,EAAKsD,GAAG5F,MAAM2D,KAAKpE,IAEpC2c,EAAM1H,YAAY,IAAIjI,EAAYC,EAAM,IAAIqO,GAAWkH,GAASpe,KAAKpE,SAClE,CAEH,GADAke,EAAMuE,GAAOA,EAAIhiB,MAITyd,EADAve,MAAMC,QAAQse,GACR,IAAIrF,EAAgB,IAAIpH,EAAQ,GAAIyM,IAGpCA,EAAI9Z,KAAKpE,OAEhB,CAAA,IAAI+hB,EAAOhvB,GAAG0N,MAIjB,KAAM,CAAExN,KAAM,UAAWsW,QAAS,iCAAiClX,KAAK4a,UAAS2V,UAAkBvwB,KAAK4vB,WAHxG/D,EAAM6D,EAAOhvB,GAAG0N,MAAM2D,KAAKke,GAC3B3F,EAAMhJ,aAKVgJ,EAAM1H,YAAY,IAAIjI,EAAYC,EAAMiR,IACxCqE,EAAexvB,GAAKmrB,EAI5B,GAAI6D,EAAOhvB,GAAGivB,UAAYjf,EACtB,IAAKsD,EAAIsc,EAAUtc,EAAIuc,EAAYvc,IAC/Bkc,EAAelc,GAAKtD,EAAKsD,GAAG5F,MAAM2D,KAAKpE,GAG/C2iB,IAGJ,OAAOhG,GAGX7O,yBACI,IAAM6D,EAAStf,KAAKsf,MAAqBtf,KAAKsf,MAAMnQ,KAAI,SAAUe,GAC9D,OAAIA,EAAEuL,cACKvL,EAAEuL,eAAc,GAEhBvL,KAJalQ,KAAKsf,MAQjC,OADe,IAAImQ,GAAWzvB,KAAK4a,KAAM5a,KAAK0vB,OAAQpQ,EAAOtf,KAAK0Y,UAAW1Y,KAAK2vB,SAAU3vB,KAAKsd,SAIrGvL,cAAKpE,GACD,OAAO,IAAI8hB,GAAWzvB,KAAK4a,KAAM5a,KAAK0vB,OAAQ1vB,KAAKsf,MAAOtf,KAAK0Y,UAAW1Y,KAAK2vB,SAAU3vB,KAAKsd,QAAU8C,EAAgBzS,EAAQ2P,UAGpIkT,kBAAS7iB,EAAS+C,EAAMmK,GACpB,IAGIyE,EACAe,EAJEoQ,EAAa,GACbC,EAAc1wB,KAAKsd,OAAStd,KAAKsd,OAAOpc,OAAOyM,EAAQ2P,QAAU3P,EAAQ2P,OACzEgN,EAAQtqB,KAAKgwB,WAAWriB,EAAS,IAAI8O,EAASY,KAAK1P,EAAS+iB,GAAchgB,EAAM+f,GActF,OAVAnG,EAAM1H,YAAY,IAAIjI,EAAY,aAAc,IAAIsO,GAAWwH,GAAY1e,KAAKpE,KAEhF2R,EAAQc,EAAgBpgB,KAAKsf,QAE7Be,EAAU,IAAIjB,EAAQ,KAAME,IACpBgB,gBAAkBtgB,KAC1BqgB,EAAUA,EAAQtO,KAAK,IAAI0K,EAASY,KAAK1P,EAAS,CAAC3N,KAAMsqB,GAAOppB,OAAOwvB,KACnE7V,IACAwF,EAAUA,EAAQ5E,iBAEf4E,GAGXqB,wBAAehR,EAAM/C,GACjB,QAAI3N,KAAK0Y,YAAc1Y,KAAK0Y,UAAU3G,KAClC,IAAI0K,EAASY,KAAK1P,EACd,CAAC3N,KAAKgwB,WAAWriB,EACb,IAAI8O,EAASY,KAAK1P,EAAS3N,KAAKsd,OAAStd,KAAKsd,OAAOpc,OAAOyM,EAAQ2P,QAAU3P,EAAQ2P,QAAS5M,EAAM,KACpGxP,OAAOlB,KAAKsd,QAAU,IACtBpc,OAAOyM,EAAQ2P,YAMhCmE,mBAAU/Q,EAAM/C,GACZ,IACI+L,EADEiX,EAAcjgB,GAAQA,EAAK5R,QAAW,EAEtC+wB,EAAqB7vB,KAAK6vB,mBAC1Be,EAAmBlgB,EAAWA,EAAK2D,QAAO,SAAU0T,EAAOgI,GAC7D,OAAIF,EAAmBjf,QAAQmf,EAAEnV,MAAQ,EAC9BmN,EAAQ,EAERA,IAEZ,GAN6B,EAQhC,GAAK/nB,KAAK2vB,UAQN,GAAIiB,EAAmB5wB,KAAK8vB,SAAW,EACnC,OAAO,MATK,CAChB,GAAIc,EAAkB5wB,KAAK8vB,SACvB,OAAO,EAEX,GAAIa,EAAa3wB,KAAK0vB,OAAO5wB,OACzB,OAAO,EASf4a,EAAM3N,KAAK4D,IAAIihB,EAAiB5wB,KAAK4vB,OAErC,IAAK,IAAIlvB,EAAI,EAAGA,EAAIgZ,EAAKhZ,IACrB,IAAKV,KAAK0vB,OAAOhvB,GAAGka,OAAS5a,KAAK0vB,OAAOhvB,GAAGivB,UACpCjf,EAAKhQ,GAAG0N,MAAM2D,KAAKpE,GAAS0C,SAAWrQ,KAAK0vB,OAAOhvB,GAAG0N,MAAM2D,KAAKpE,GAAS0C,QAC1E,OAAO,EAInB,OAAO,KC1Nf,IAAMwgB,GAAY,SAASrY,EAAU9H,EAAM1C,EAAO0E,EAAiBmI,GAC/D7a,KAAK6f,SAAW,IAAItH,EAASC,GAC7BxY,KAAK8T,UAAYpD,GAAQ,GACzB1Q,KAAKyN,OAASO,EACdhO,KAAK0N,UAAYgF,EACjB1S,KAAK6a,UAAYA,EACjB7a,KAAKua,WAAY,EACjBva,KAAK6S,UAAU7S,KAAK6f,SAAU7f,OAGlC6wB,GAAU9gB,UAAYlD,OAAOmD,OAAO,IAAI9C,EAAQ,CAC5CtM,KAAM,YAENkS,gBAAOzE,GACCrO,KAAK6f,WACL7f,KAAK6f,SAAWxR,EAAQC,MAAMtO,KAAK6f,WAEnC7f,KAAK8T,UAAUhV,SACfkB,KAAK8T,UAAYzF,EAAQyK,WAAW9Y,KAAK8T,aAIjD/B,cAAKpE,GACD,IAAImjB,EACAC,EACAC,EAEAZ,EACAa,EAGAvwB,EACAyK,EACA+lB,EACAC,EACAC,EAEAC,EAEAC,EAKAvJ,EACAzH,EACAiR,EApBE7gB,EAAO,GAGP4O,EAAQ,GACVpQ,GAAQ,EAMNsiB,EAAa,GAEbC,EAAkB,GAYxB,SAASC,EAAaX,EAAOC,GACzB,IAAIE,EAAGnB,EAAG4B,EAEV,IAAKT,EAAI,EAAGA,EAAI,EAAGA,IAAK,CAGpB,IAFAO,EAAgBP,IAAK,EACrBlS,EAAY5Q,MAAM8iB,GACbnB,EAAI,EAAGA,EAAIiB,EAAUlyB,QAAU2yB,EAAgBP,GAAInB,KACpD4B,EAAYX,EAAUjB,IACRrO,iBACV+P,EAAgBP,GAAKO,EAAgBP,IAAMS,EAAUjQ,eAAe,KAAM/T,IAG9EojB,EAAMrP,iBACN+P,EAAgBP,GAAKO,EAAgBP,IAAMH,EAAMrP,eAAehR,EAAM/C,IAG9E,OAAI8jB,EAAgB,IAAMA,EAAgB,GAClCA,EAAgB,IAAMA,EAAgB,GAC/BA,EAAgB,GA1BnB,EACC,EAFD,GADW,EAqC3B,IA7BAzxB,KAAK6f,SAAW7f,KAAK6f,SAAS9N,KAAKpE,GA6B9BjN,EAAI,EAAGA,EAAIV,KAAK8T,UAAUhV,OAAQ4B,IAGnC,GADAuwB,GADAb,EAAMpwB,KAAK8T,UAAUpT,IACN0N,MAAM2D,KAAKpE,GACtByiB,EAAIwB,QAAUtkB,MAAMC,QAAQ0jB,EAAS7iB,OAErC,IADA6iB,EAAWA,EAAS7iB,MACfjD,EAAI,EAAGA,EAAI8lB,EAASnyB,OAAQqM,IAC7BuF,EAAKlQ,KAAK,CAAC4N,MAAO6iB,EAAS9lB,UAG/BuF,EAAKlQ,KAAK,CAACoa,KAAMwV,EAAIxV,KAAMxM,MAAO6iB,IAM1C,IAFAM,EAAoB,SAASrR,GAAO,OAAOA,EAAKuB,UAAU,KAAM9T,IAE3DjN,EAAI,EAAGA,EAAIiN,EAAQ2P,OAAOxe,OAAQ4B,IACnC,IAAKowB,EAASnjB,EAAQ2P,OAAO5c,GAAGmiB,KAAK7iB,KAAK6f,SAAU,KAAM0R,IAAoBzyB,OAAS,EAAG,CAQtF,IAPAsyB,GAAa,EAORjmB,EAAI,EAAGA,EAAI2lB,EAAOhyB,OAAQqM,IAAK,CAIhC,IAHA4lB,EAAQD,EAAO3lB,GAAG+U,KAClB8Q,EAAYF,EAAO3lB,GAAGgS,KACtBgU,GAAc,EACTD,EAAI,EAAGA,EAAIvjB,EAAQ2P,OAAOxe,OAAQoyB,IACnC,KAAOH,aAAiBc,KAAqBd,KAAWpjB,EAAQ2P,OAAO4T,GAAG5Q,iBAAmB3S,EAAQ2P,OAAO4T,IAAK,CAC7GC,GAAc,EACd,MAGJA,GAIAJ,EAAMtP,UAAU/Q,EAAM/C,MA3EX,KA4EX0jB,EAAY,CAACN,QAAOtJ,MAAOiK,EAAaX,EAAOC,KAEjCvJ,OACV+J,EAAWhxB,KAAK6wB,GAGpBniB,GAAQ,GAOhB,IAHA8P,EAAYG,QAEZ4I,EAAQ,CAAC,EAAG,EAAG,GACV5c,EAAI,EAAGA,EAAIqmB,EAAW1yB,OAAQqM,IAC/B4c,EAAMyJ,EAAWrmB,GAAGsc,SAGxB,GAAIM,EA5FI,GA4Fa,EACjBuJ,EA3FK,OA8FL,GADAA,EA9FI,EA+FCvJ,EA/FD,GA+FkBA,EA9FjB,GA8FoC,EACrC,KAAM,CAAEnnB,KAAM,UACVsW,QAAS,yDAA4DlX,KAAK8xB,OAAOphB,OACjF1C,MAAOhO,KAAKiN,WAAY1L,SAAUvB,KAAKgN,WAAWzL,UAI9D,IAAK4J,EAAI,EAAGA,EAAIqmB,EAAW1yB,OAAQqM,IAE/B,GAzGI,KAwGJkmB,EAAYG,EAAWrmB,GAAGsc,QACM4J,IAAcC,EAC1C,KACIP,EAAQS,EAAWrmB,GAAG4lB,iBACCc,KACnBvR,EAAkByQ,EAAMzQ,iBAAmByQ,GAC3CA,EAAQ,IAAIc,GAAgB,GAAI,GAAId,EAAMzR,MAAO,MAAM,EAAO,KAAMgB,EAAgB3N,mBAC9E2N,gBAAkBA,GAE5B,IAAMyR,EAAWhB,EAAMP,SAAS7iB,EAAS+C,EAAM1Q,KAAK6a,WAAWyE,MAC/Dtf,KAAKgyB,4BAA4BD,GACjCzkB,MAAMyC,UAAUvP,KAAK6gB,MAAM/B,EAAOyS,GACpC,MAAOtyB,GACL,KAAM,CAAEyX,QAASzX,EAAEyX,QAASlJ,MAAOhO,KAAKiN,WAAY1L,SAAUvB,KAAKgN,WAAWzL,SAAU4V,MAAO1X,EAAE0X,OAK7G,GAAIjI,EACA,OAAOoQ,EAInB,MAAI8R,EACM,CAAExwB,KAAS,UACbsW,QAAS,yCAA0ClX,KAAK8xB,OAAOphB,OAC/D1C,MAAShO,KAAKiN,WAAY1L,SAAUvB,KAAKgN,WAAWzL,UAElD,CAAEX,KAAS,OACbsW,QAAYlX,KAAK6f,SAASxP,QAAQgC,uBAClCrE,MAAShO,KAAKiN,WAAY1L,SAAUvB,KAAKgN,WAAWzL,WAIhEywB,qCAA4BC,GACxB,IAAIvxB,EACJ,GAAIV,KAAKktB,mBACL,IAAKxsB,EAAI,EAAGA,EAAIuxB,EAAYnzB,OAAQ4B,IACzBuxB,EAAYvxB,GACdysB,sBAKjB2E,gBAAOphB,GACH,OAAU1Q,KAAK6f,SAASxP,QAAQgC,YAAU3B,EAAOA,EAAKvB,KAAI,SAAUX,GAChE,IAAIyiB,EAAW,GASf,OARIziB,EAAEoM,OACFqW,GAAeziB,EAAEoM,UAEjBpM,EAAEJ,MAAMiC,MACR4gB,GAAYziB,EAAEJ,MAAMiC,QAEpB4gB,GAAY,MAETA,KACR/iB,KAAK,MAAQ,kBCvKT,CACXhB,OAAM6B,QAAOkX,SAAQO,kBAAiBsC,aACtCd,aAAWtB,OAAMzM,UAASmQ,YAAUI,YACpCpL,UAAS7M,UAASwY,aAAW5Y,aAAYoG,WACzCyS,UAAQ/B,cAAYtO,cAAakP,QAAM+B,OAAKY,UAC5CpQ,UAAShC,YAAWJ,QAAO+T,cAAYE,cACvCC,aAAWpc,QAAOka,SAAOsC,qBAAmBC,YAC5CC,UAAQW,gBAAcE,kBACtB0B,MAAO,CACHlH,KAAMgH,GACNpB,WAAYoC,mBCjDpB,cAmIA,OAlIIK,oBAAA,SAAQ3wB,GACJ,IAAIyS,EAAIzS,EAAS4wB,YAAY,KAQ7B,OAPIne,EAAI,IACJzS,EAAWA,EAASsQ,MAAM,EAAGmC,KAEjCA,EAAIzS,EAAS4wB,YAAY,MACjB,IACJne,EAAIzS,EAAS4wB,YAAY,OAEzBne,EAAI,EACG,GAEJzS,EAASsQ,MAAM,EAAGmC,EAAI,IAGjCke,+BAAA,SAAmB/U,EAAMiV,GACrB,MAAO,yBAAyBjW,KAAKgB,GAAQA,EAAOA,EAAOiV,GAG/DF,mCAAA,SAAuB/U,GACnB,OAAOnd,KAAKqyB,mBAAmBlV,EAAM,UAGzC+U,yBAAA,WACI,OAAO,GAGXA,oCAAA,WACI,OAAO,GAGXA,2BAAA,SAAe3wB,GACX,MAAO,yBAA2B4a,KAAK5a,IAI3C2wB,iBAAA,SAAKI,EAAUC,GACX,OAAKD,EAGEA,EAAWC,EAFPA,GAKfL,qBAAA,SAASM,EAAKC,GAGV,IAGI/xB,EACAgP,EACAgjB,EACAC,EANEC,EAAW5yB,KAAK6yB,gBAAgBL,GAEhCM,EAAe9yB,KAAK6yB,gBAAgBJ,GAKtCM,EAAO,GACX,GAAIH,EAASI,WAAaF,EAAaE,SACnC,MAAO,GAGX,IADAtjB,EAAM3D,KAAK2D,IAAIojB,EAAaG,YAAYn0B,OAAQ8zB,EAASK,YAAYn0B,QAChE4B,EAAI,EAAGA,EAAIgP,GACRojB,EAAaG,YAAYvyB,KAAOkyB,EAASK,YAAYvyB,GADxCA,KAKrB,IAFAiyB,EAAqBG,EAAaG,YAAYphB,MAAMnR,GACpDgyB,EAAiBE,EAASK,YAAYphB,MAAMnR,GACvCA,EAAI,EAAGA,EAAIiyB,EAAmB7zB,OAAS,EAAG4B,IAC3CqyB,GAAQ,MAEZ,IAAKryB,EAAI,EAAGA,EAAIgyB,EAAe5zB,OAAS,EAAG4B,IACvCqyB,GAAWL,EAAehyB,OAE9B,OAAOqyB,GAIXb,4BAAA,SAAgBM,EAAKC,GAOjB,IAMI/xB,EACAoyB,EAPEI,EAAgB,kGAEhBN,EAAWJ,EAAItjB,MAAMgkB,GACrBC,EAAW,GACbC,EAAiB,GACfH,EAAc,GAIpB,IAAKL,EACD,MAAM,IAAIlzB,MAAM,iCAAiC8yB,OAIrD,GAAIC,KAAaG,EAAS,IAAMA,EAAS,IAAK,CAE1C,KADAE,EAAeL,EAAQvjB,MAAMgkB,IAEzB,MAAM,IAAIxzB,MAAM,+BAA+B+yB,OAEnDG,EAAS,GAAKA,EAAS,IAAME,EAAa,IAAM,GAC3CF,EAAS,KACVA,EAAS,GAAKE,EAAa,GAAKF,EAAS,IAIjD,GAAIA,EAAS,GAIT,IAHAQ,EAAiBR,EAAS,GAAGz1B,QAAQ,MAAO,KAAKoS,MAAM,KAGlD7O,EAAI,EAAGA,EAAI0yB,EAAet0B,OAAQ4B,IAET,OAAtB0yB,EAAe1yB,GACfuyB,EAAYzX,MAEe,MAAtB4X,EAAe1yB,IACpBuyB,EAAYzyB,KAAK4yB,EAAe1yB,IAa5C,OAPAyyB,EAASH,SAAWJ,EAAS,GAC7BO,EAASF,YAAcA,EACvBE,EAASE,SAAWT,EAAS,IAAM,IAAMQ,EAAellB,KAAK,KAC7DilB,EAAShW,MAAQyV,EAAS,IAAM,IAAMK,EAAY/kB,KAAK,KACvDilB,EAAS5xB,SAAWqxB,EAAS,GAC7BO,EAASG,QAAUH,EAAShW,MAAQyV,EAAS,IAAM,IACnDO,EAASX,IAAMW,EAASG,SAAWV,EAAS,IAAM,IAC3CO,sBC7HX,aAEInzB,KAAKuzB,QAAU,WACX,OAAO,MA8KnB,OA1KIC,uBAAA,SAAWnc,EAAU1J,EAAS0L,EAASoa,EAAezmB,GAElD,IAAYogB,EAAUsG,EAAWC,EAAa/xB,EAAeL,EAAUqV,EAEvEhV,EAAgB+L,EAAQ/L,cAEpBoL,IAEIzL,EADoB,iBAAbyL,EACIA,EAGAA,EAASzL,UAG5B,IAAMqyB,GAAY,IAAK5zB,KAAK0qB,KAAKmJ,aAAehB,gBAAgBtxB,GAAUA,SAE1E,GAAIA,IACAmyB,EAAY9xB,EAAcmL,IAAIxL,IAEf,CAEX,GADAqV,EAAS5W,KAAK8zB,cAAcJ,EAAWnyB,EAAUqyB,EAAWH,GAExD,OAAO7c,EAEX,IACQ8c,EAAUK,KACVL,EAAUK,IAAIvgB,KAAKxT,KAAK2N,QAAS+lB,GAGzC,MAAOj0B,GAEH,OADAA,EAAEyX,QAAUzX,EAAEyX,SAAW,4BAClB,IAAIH,EAAUtX,EAAG4Z,EAAS9X,GAErC,OAAOmyB,EAGfC,EAAc,CACVK,QAAS,GACTpyB,gBACAoL,YAEJogB,EAAW1M,EAAiBzI,SAM5B,IACa,IAAIJ,SAAS,SAAU,UAAW,iBAAkB,YAAa,OAAQ,OAAQ,WAAYR,EACtG4c,CAAON,EAAa3zB,KAAKuzB,QAAQhyB,IANd,SAASmU,GAC5Bge,EAAYhe,IAKgD0X,EAAUptB,KAAK0qB,KAAKwJ,KAAMl0B,KAAK0qB,KAAM1d,GAErG,MAAOvN,GACH,OAAO,IAAIsX,EAAUtX,EAAG4Z,EAAS9X,GAQrC,GALKmyB,IACDA,EAAYC,EAAYK,UAE5BN,EAAY1zB,KAAKm0B,eAAeT,EAAWnyB,EAAUqyB,cAE5B7c,EACrB,OAAO2c,EAGX,IAAIA,EAoCA,OAAO,IAAI3c,EAAU,CAAEG,QAAS,sBAAwBmC,EAAS9X,GA/BjE,GAJAmyB,EAAUra,QAAUA,EACpBqa,EAAUnyB,SAAWA,IAGhBmyB,EAAUU,YAAcp0B,KAAKq0B,eAAe,QAASX,EAAUU,YAAc,KAC9Exd,EAAS5W,KAAK8zB,cAAcJ,EAAWnyB,EAAUqyB,EAAWH,IAGxD,OAAO7c,EAUf,GALAhV,EAAc0yB,UAAUZ,EAAW1mB,EAASzL,SAAU6rB,GACtDsG,EAAUzyB,UAAYmsB,EAAStO,oBAG/BlI,EAAS5W,KAAK8zB,cAAcJ,EAAWnyB,EAAUqyB,EAAWH,GAExD,OAAO7c,EAIX,IACQ8c,EAAUK,KACVL,EAAUK,IAAIvgB,KAAKxT,KAAK2N,QAAS+lB,GAGzC,MAAOj0B,GAEH,OADAA,EAAEyX,QAAUzX,EAAEyX,SAAW,4BAClB,IAAIH,EAAUtX,EAAG4Z,EAAS9X,GAQzC,OAAOmyB,GAIXF,0BAAA,SAAce,EAAQhzB,EAAUqZ,EAAMvd,GAClC,GAAIA,IAAYk3B,EAAOC,WACnB,OAAO,IAAIzd,EAAU,CACjBG,QAAS,6CAA6C0D,qCAG9D,IACI2Z,EAAOC,YAAcD,EAAOC,WAAWn3B,GAE3C,MAAOoC,GACH,OAAO,IAAIsX,EAAUtX,KAI7B+zB,2BAAA,SAAee,EAAQhzB,EAAUqZ,GAC7B,OAAI2Z,GAGsB,mBAAXA,IACPA,EAAS,IAAIA,GAGbA,EAAOH,YACHp0B,KAAKq0B,eAAeE,EAAOH,WAAYp0B,KAAK0qB,KAAK+J,SAAW,EACrD,IAAI1d,EAAU,CACjBG,QAAS,UAAU0D,uBAAyB5a,KAAK00B,gBAAgBH,EAAOH,cAI7EG,GAEJ,MAGXf,2BAAA,SAAemB,EAAUC,GACG,iBAAbD,IACPA,EAAWA,EAASzlB,MAAM,6BACjB0K,QAEb,IAAK,IAAIlZ,EAAI,EAAGA,EAAIi0B,EAAS71B,OAAQ4B,IACjC,GAAIi0B,EAASj0B,KAAOk0B,EAASl0B,GACzB,OAAO2O,SAASslB,EAASj0B,IAAM2O,SAASulB,EAASl0B,KAAO,EAAI,EAGpE,OAAO,GAGX8yB,4BAAA,SAAgBiB,GAEZ,IADA,IAAII,EAAgB,GACXn0B,EAAI,EAAGA,EAAI+zB,EAAQ31B,OAAQ4B,IAChCm0B,IAAkBA,EAAgB,IAAM,IAAMJ,EAAQ/zB,GAE1D,OAAOm0B,GAGXrB,uBAAA,SAAWsB,GACP,IAAK,IAAIp0B,EAAI,EAAGA,EAAIo0B,EAAQh2B,OAAQ4B,IAAK,CACrC,IAAM6zB,EAASO,EAAQp0B,GACnB6zB,EAAOQ,YACPR,EAAOQ,oBC/KjBC,GAAa,CAAEC,aAAa,GAC9BC,IAAc,EAElB,SAASC,GAAM9nB,GACX,OAAOA,EA0BX,kBACI,WAAY+nB,GACRp1B,KAAKq1B,gBAAkBD,EACvBp1B,KAAKs1B,cAAgB,GACrBt1B,KAAKu1B,eAAiB,GAEjBL,MA7Bb,SAASM,EAAelpB,EAAQmpB,GAE5B,IAAI9jB,EAAK+jB,EACT,IAAK/jB,KAAOrF,EAGR,cADAopB,EAAQppB,EAAOqF,KAEX,IAAK,WAGG+jB,EAAM3lB,WAAa2lB,EAAM3lB,UAAUnP,OACnC80B,EAAM3lB,UAAU4lB,UAAYF,KAEhC,MACJ,IAAK,SACDA,EAASD,EAAeE,EAAOD,GAK3C,OAAOA,EAUCD,CAAetB,GAAM,GACrBgB,IAAc,GA0H1B,OAtHIU,kBAAA,SAAMvoB,GACF,IAAKA,EACD,OAAOA,EAGX,IAAMwoB,EAAgBxoB,EAAKsoB,UAC3B,IAAKE,EAKD,OAHIxoB,EAAKe,OAASf,EAAKe,MAAMunB,WACzB31B,KAAKsO,MAAMjB,EAAKe,OAEbf,EAGX,IAIIyoB,EAJEC,EAAO/1B,KAAKq1B,gBACdzd,EAAO5X,KAAKs1B,cAAcO,GAC1BG,EAAUh2B,KAAKu1B,eAAeM,GAC5BI,EAAYjB,GAalB,GAVAiB,EAAUhB,aAAc,EAEnBrd,IAEDA,EAAOme,EADPD,EAAS,QAAQzoB,EAAKzM,OACCu0B,GACvBa,EAAUD,EAAQD,UAAgBX,GAClCn1B,KAAKs1B,cAAcO,GAAiBje,EACpC5X,KAAKu1B,eAAeM,GAAiBG,GAGrCpe,IAASud,GAAO,CAChB,IAAMe,EAAUte,EAAKpE,KAAKuiB,EAAM1oB,EAAM4oB,GAClC5oB,GAAQ0oB,EAAKI,cACb9oB,EAAO6oB,GAIf,GAAID,EAAUhB,aAAe5nB,EACzB,GAAIA,EAAKvO,OACL,IAAK,IAAI4B,EAAI,EAAG01B,EAAM/oB,EAAKvO,OAAQ4B,EAAI01B,EAAK11B,IACpC2M,EAAK3M,GAAGoS,QACRzF,EAAK3M,GAAGoS,OAAO9S,WAGhBqN,EAAKyF,QACZzF,EAAKyF,OAAO9S,MAQpB,OAJIg2B,GAAWb,IACXa,EAAQxiB,KAAKuiB,EAAM1oB,GAGhBA,GAGXuoB,uBAAA,SAAWzoB,EAAOkpB,GACd,IAAKlpB,EACD,OAAOA,EAGX,IACIzM,EADE01B,EAAMjpB,EAAMrO,OAIlB,GAAIu3B,IAAiBr2B,KAAKq1B,gBAAgBc,YAAa,CACnD,IAAKz1B,EAAI,EAAGA,EAAI01B,EAAK11B,IACjBV,KAAKsO,MAAMnB,EAAMzM,IAErB,OAAOyM,EAIX,IAAMmpB,EAAM,GACZ,IAAK51B,EAAI,EAAGA,EAAI01B,EAAK11B,IAAK,CACtB,IAAM61B,EAAQv2B,KAAKsO,MAAMnB,EAAMzM,SACjB8L,IAAV+pB,IACCA,EAAM51B,OAEA41B,EAAMz3B,QACbkB,KAAKw2B,QAAQD,EAAOD,GAFpBA,EAAI91B,KAAK+1B,IAKjB,OAAOD,GAGXV,oBAAA,SAAQngB,EAAK6gB,GAKT,IAAIF,EAAK11B,EAAGipB,EAAM8M,EAAWziB,EAAG0iB,EAEhC,IANKJ,IACDA,EAAM,IAKL51B,EAAI,EAAG01B,EAAM3gB,EAAI3W,OAAQ4B,EAAI01B,EAAK11B,IAEnC,QAAa8L,KADbmd,EAAOlU,EAAI/U,IAIX,GAAKipB,EAAKhpB,OAKV,IAAKqT,EAAI,EAAGyiB,EAAY9M,EAAK7qB,OAAQkV,EAAIyiB,EAAWziB,SAE7BxH,KADnBkqB,EAAa/M,EAAK3V,MAIb0iB,EAAW/1B,OAEL+1B,EAAW53B,QAClBkB,KAAKw2B,QAAQE,EAAYJ,GAFzBA,EAAI91B,KAAKk2B,SAVbJ,EAAI91B,KAAKmpB,GAiBjB,OAAO2M,sBC/JX,WAAYK,GACR32B,KAAKqZ,QAAU,GACfrZ,KAAK42B,gBAAkB,GACvB52B,KAAK62B,kBAAoBF,EACzB32B,KAAK82B,cAAgB,EAgD7B,OA7CIC,sBAAA,SAAUxP,GACN,IAAMyP,EAAkBh3B,KACpBi3B,EAAa,CACT1P,WACA7W,KAAM,KACNwmB,SAAS,GAGjB,OADAl3B,KAAKqZ,QAAQ7Y,KAAKy2B,GACX,WACHA,EAAWvmB,KAAOpD,MAAMyC,UAAU8B,MAAM2B,KAAKM,UAAW,GACxDmjB,EAAWC,SAAU,EACrBF,EAAgBG,WAIxBJ,8BAAA,SAAkBxP,GACdvnB,KAAK42B,gBAAgBp2B,KAAK+mB,IAG9BwP,mBAAA,WACI/2B,KAAK82B,gBACL,IACI,OAAa,CACT,KAAO92B,KAAKqZ,QAAQva,OAAS,GAAG,CAC5B,IAAMm4B,EAAaj3B,KAAKqZ,QAAQ,GAChC,IAAK4d,EAAWC,QACZ,OAEJl3B,KAAKqZ,QAAUrZ,KAAKqZ,QAAQxH,MAAM,GAClColB,EAAW1P,SAASlG,MAAM,KAAM4V,EAAWvmB,MAE/C,GAAoC,IAAhC1Q,KAAK42B,gBAAgB93B,OACrB,MAEJ,IAAMs4B,EAAiBp3B,KAAK42B,gBAAgB,GAC5C52B,KAAK42B,gBAAkB52B,KAAK42B,gBAAgB/kB,MAAM,GAClDulB,aAGJp3B,KAAK82B,gBAEkB,IAAvB92B,KAAK82B,eAAuB92B,KAAK62B,mBACjC72B,KAAK62B,0BC7CXQ,GAAgB,SAASC,EAAUC,GAErCv3B,KAAKw3B,SAAW,IAAI5B,GAAQ51B,MAC5BA,KAAKy3B,UAAYH,EACjBt3B,KAAK03B,QAAUH,EACfv3B,KAAK2N,QAAU,IAAI8O,EAASY,KAC5Brd,KAAK23B,YAAc,EACnB33B,KAAK43B,qBAAuB,GAC5B53B,KAAK63B,kBAAoB,GACzB73B,KAAK83B,WAAa,IAAIf,GAAgB/2B,KAAK62B,kBAAkBx1B,KAAKrB,QAGtEq3B,GAActnB,UAAY,CACtBomB,aAAa,EACb4B,IAAK,SAAUxX,GACX,IAEIvgB,KAAKw3B,SAASlpB,MAAMiS,GAExB,MAAO9gB,GACHO,KAAKF,MAAQL,EAGjBO,KAAKg4B,YAAa,EAClBh4B,KAAK83B,WAAWX,UAEpBN,kBAAmB,WACV72B,KAAKg4B,YAGVh4B,KAAK03B,QAAQ13B,KAAKF,QAEtBm4B,YAAa,SAAUC,EAAYjC,GAC/B,IAAMkC,EAAYD,EAAW76B,QAAQ0d,OAErC,IAAKmd,EAAWzL,KAAO0L,EAAW,CAE9B,IAAMxqB,EAAU,IAAI8O,EAASY,KAAKrd,KAAK2N,QAASyS,EAAgBpgB,KAAK2N,QAAQ2P,SACvE8a,EAAezqB,EAAQ2P,OAAO,GAEpCtd,KAAK23B,cACDO,EAAWpL,mBACX9sB,KAAK83B,WAAWO,kBAAkBr4B,KAAKs4B,kBAAkBj3B,KAAKrB,KAAMk4B,EAAYvqB,EAASyqB,IAEzFp4B,KAAKs4B,kBAAkBJ,EAAYvqB,EAASyqB,GAGpDnC,EAAUhB,aAAc,GAE5BqD,kBAAmB,SAASJ,EAAYvqB,EAASyqB,GAC7C,IAAIG,EACEJ,EAAYD,EAAW76B,QAAQ0d,OAErC,IACIwd,EAAkBL,EAAWnL,cAAcpf,GAC7C,MAAOlO,GACAA,EAAE8B,WAAY9B,EAAEuO,MAAQkqB,EAAWjrB,WAAYxN,EAAE8B,SAAW22B,EAAWlrB,WAAWzL,UAEvF22B,EAAWzL,KAAM,EAEjByL,EAAWp4B,MAAQL,EAGvB,IAAI84B,GAAqBA,EAAgB9L,MAAO0L,EAqB5Cn4B,KAAK23B,cACD33B,KAAKg4B,YACLh4B,KAAK83B,WAAWX,aAvBoC,CAEpDoB,EAAgBl7B,QAAQm7B,WACxB7qB,EAAQ8qB,gBAAiB,GAM7B,IAFA,IAAMC,OAAiDlsB,IAAxB+rB,EAAgB9L,IAEtC/rB,EAAI,EAAGA,EAAI03B,EAAa9Y,MAAMxgB,OAAQ4B,IAC3C,GAAI03B,EAAa9Y,MAAM5e,KAAOw3B,EAAY,CACtCE,EAAa9Y,MAAM5e,GAAK63B,EACxB,MAIR,IAAMI,EAAa34B,KAAK24B,WAAWt3B,KAAKrB,KAAMu4B,EAAiB5qB,GAAUirB,EAAsB54B,KAAK83B,WAAWe,UAAUF,GAEzH34B,KAAKy3B,UAAUj3B,KAAK+3B,EAAgB5L,UAAW+L,EAAwBH,EAAgBvrB,WACnFurB,EAAgBl7B,QAASu7B,KAQrCD,WAAY,SAAUT,EAAYvqB,EAASlO,EAAG8gB,EAAMuY,EAAgBC,GAC5Dt5B,IACKA,EAAE8B,WACH9B,EAAEuO,MAAQkqB,EAAWjrB,WAAYxN,EAAE8B,SAAW22B,EAAWlrB,WAAWzL,UAExEvB,KAAKF,MAAQL,GAGjB,IAAMu5B,EAAgBh5B,KAClBm4B,EAAYD,EAAW76B,QAAQ0d,OAC/B6R,EAAWsL,EAAW76B,QAAQuvB,SAC9BqM,EAAaf,EAAW76B,QAAQ67B,SAChCC,EAAkBL,GAAkBC,KAAYC,EAAcnB,kBAoBlE,GAlBKlqB,EAAQ8qB,iBAELP,EAAW7K,OADX8L,GAGkB,WACd,OAAIJ,KAAYC,EAAcpB,uBAG9BoB,EAAcpB,qBAAqBmB,IAAY,GACxC,MAKdA,GAAYE,IACbf,EAAW7K,MAAO,GAGlB9M,IACA2X,EAAW3X,KAAOA,EAClB2X,EAAW5K,iBAAmByL,GAEzBZ,IAAcvL,IAAajf,EAAQ8qB,iBAAmBU,IAAkB,CACzEH,EAAcnB,kBAAkBkB,IAAY,EAE5C,IAAMK,EAAap5B,KAAK2N,QACxB3N,KAAK2N,QAAUA,EACf,IACI3N,KAAKw3B,SAASlpB,MAAMiS,GACtB,MAAO9gB,GACLO,KAAKF,MAAQL,EAEjBO,KAAK2N,QAAUyrB,EAIvBJ,EAAcrB,cAEVqB,EAAchB,YACdgB,EAAclB,WAAWX,UAGjCkC,iBAAkB,SAAUC,EAAUrD,GACN,oBAAxBqD,EAASlrB,MAAMxN,KACfZ,KAAK2N,QAAQ2P,OAAOuD,QAAQyY,GAE5BrD,EAAUhB,aAAc,GAGhCsE,oBAAqB,SAASD,GACE,oBAAxBA,EAASlrB,MAAMxN,MACfZ,KAAK2N,QAAQ2P,OAAO1D,SAG5B4f,YAAa,SAAUC,EAAYxD,GAC/Bj2B,KAAK2N,QAAQ2P,OAAOuD,QAAQ4Y,IAEhCC,eAAgB,SAAUD,GACtBz5B,KAAK2N,QAAQ2P,OAAO1D,SAExB+f,qBAAsB,SAAUC,EAAqB3D,GACjDj2B,KAAK2N,QAAQ2P,OAAOuD,QAAQ+Y,IAEhCC,wBAAyB,SAAUD,GAC/B55B,KAAK2N,QAAQ2P,OAAO1D,SAExBkgB,aAAc,SAAUC,EAAa9D,GACjCj2B,KAAK2N,QAAQ2P,OAAOuD,QAAQkZ,IAEhCC,gBAAiB,SAAUD,GACvB/5B,KAAK2N,QAAQ2P,OAAO1D,SAExBqgB,WAAY,SAAUC,EAAWjE,GAC7Bj2B,KAAK2N,QAAQ2P,OAAOuD,QAAQqZ,EAAU5a,MAAM,KAEhD6a,cAAe,SAAUD,GACrBl6B,KAAK2N,QAAQ2P,OAAO1D,UCzL5B,kBACI,WAAYwgB,GACRp6B,KAAKo6B,QAAUA,EAwCvB,OArCIC,gBAAA,SAAI9Z,GACAvgB,KAAKsO,MAAMiS,IAGf8Z,uBAAA,SAAWltB,GACP,IAAKA,EACD,OAAOA,EAGX,IACIzM,EADE01B,EAAMjpB,EAAMrO,OAElB,IAAK4B,EAAI,EAAGA,EAAI01B,EAAK11B,IACjBV,KAAKsO,MAAMnB,EAAMzM,IAErB,OAAOyM,GAGXktB,kBAAA,SAAMhtB,GACF,OAAKA,EAGDA,EAAKsG,cAAgBrG,MACdtN,KAAK8Y,WAAWzL,KAGtBA,EAAK6f,kBAAoB7f,EAAK6f,qBAG/BltB,KAAKo6B,QACL/sB,EAAKitB,mBAELjtB,EAAKktB,qBAGTltB,EAAKyF,OAAO9S,OARDqN,GAPAA,sBChBf,aACIrN,KAAKw3B,SAAW,IAAI5B,GAAQ51B,MAC5BA,KAAKyc,SAAW,GAChBzc,KAAKw6B,gBAAkB,CAAC,IAwFhC,OArFIC,gBAAA,SAAIla,GAGA,OAFAA,EAAOvgB,KAAKw3B,SAASlpB,MAAMiS,IACtBma,WAAa16B,KAAKw6B,gBAAgB,GAChCja,GAGXka,6BAAA,SAAiBnB,EAAUrD,GACvBA,EAAUhB,aAAc,GAG5BwF,iCAAA,SAAqBb,EAAqB3D,GACtCA,EAAUhB,aAAc,GAG5BwF,yBAAA,SAAaV,EAAa9D,GACtB,IAAI8D,EAAYxZ,KAAhB,CAIA,IAAI7f,EACAsT,EACA8F,EAEArB,EADEkiB,EAAyB,GAIzBrb,EAAQya,EAAYza,MAAOiH,EAAUjH,EAAQA,EAAMxgB,OAAS,EAClE,IAAK4B,EAAI,EAAGA,EAAI6lB,EAAS7lB,IACjBq5B,EAAYza,MAAM5e,aAAcwzB,GAAK1F,SACrCmM,EAAuBn6B,KAAK8e,EAAM5e,IAClCq5B,EAAYa,mBAAoB,GAMxC,IAAM5d,EAAQ+c,EAAY/c,MAC1B,IAAKtc,EAAI,EAAGA,EAAIsc,EAAMle,OAAQ4B,IAAK,CAC/B,IAAMm6B,EAAe7d,EAAMtc,GAAsDo6B,EAAvCD,EAAaA,EAAa/7B,OAAS,GAA6B2Z,WAW1G,KATAA,EAAaqiB,EAAgB1a,EAAgB0a,GAAe55B,OAAOy5B,GAC7DA,KAGFliB,EAAaA,EAAWtJ,KAAI,SAAS4rB,GACjC,OAAOA,EAAmBhoB,YAI7BiB,EAAI,EAAGA,EAAIyE,EAAW3Z,OAAQkV,IAC/BhU,KAAKg7B,cAAe,GACpBlhB,EAASrB,EAAWzE,IACb+a,kBAAkB8L,GACzB/gB,EAAOuG,QAAU0Z,EACP,IAAN/lB,IAAW8F,EAAOmhB,+BAAgC,GACtDj7B,KAAKw6B,gBAAgBx6B,KAAKw6B,gBAAgB17B,OAAS,GAAG0B,KAAKsZ,GAInE9Z,KAAKyc,SAASjc,KAAKu5B,EAAY1a,aAGnCob,4BAAA,SAAgBV,GACPA,EAAYxZ,OACbvgB,KAAKyc,SAAS3d,OAASkB,KAAKyc,SAAS3d,OAAS,IAItD27B,uBAAA,SAAWP,EAAWjE,GAClBiE,EAAUQ,WAAa,GACvB16B,KAAKw6B,gBAAgBh6B,KAAK05B,EAAUQ,aAGxCD,0BAAA,SAAcP,GACVl6B,KAAKw6B,gBAAgB17B,OAASkB,KAAKw6B,gBAAgB17B,OAAS,GAGhE27B,wBAAA,SAAYhB,EAAYxD,GACpBwD,EAAWiB,WAAa,GACxB16B,KAAKw6B,gBAAgBh6B,KAAKi5B,EAAWiB,aAGzCD,2BAAA,SAAehB,GACXz5B,KAAKw6B,gBAAgB17B,OAASkB,KAAKw6B,gBAAgB17B,OAAS,sBAKhE,aACIkB,KAAKw3B,SAAW,IAAI5B,GAAQ51B,MAwYpC,OArYIk7B,gBAAA,SAAI3a,GACA,IAAM4a,EAAe,IAAIV,GAGzB,GAFAz6B,KAAKo7B,cAAgB,GACrBD,EAAapD,IAAIxX,IACZ4a,EAAaH,aAAgB,OAAOza,EACzCA,EAAKma,WAAana,EAAKma,WAAWx5B,OAAOlB,KAAKq7B,iBAAiB9a,EAAKma,WAAYna,EAAKma,aACrF16B,KAAKw6B,gBAAkB,CAACja,EAAKma,YAC7B,IAAMY,EAAUt7B,KAAKw3B,SAASlpB,MAAMiS,GAEpC,OADAvgB,KAAKu7B,0BAA0Bhb,EAAKma,YAC7BY,GAGXJ,sCAAA,SAA0BziB,GACtB,IAAM+iB,EAAUx7B,KAAKo7B,cACrB3iB,EAAW2I,QAAO,SAAStH,GACvB,OAAQA,EAAO2hB,iBAA+C,GAA5B3hB,EAAO8U,WAAW9vB,UACrD0O,SAAQ,SAASsM,GAChB,IAAI+F,EAAW,YACf,IACIA,EAAW/F,EAAO+F,SAASxP,MAAM,IAErC,MAAOzS,IAEF49B,EAAW1hB,EAAO9L,UAAS6R,KAC5B2b,EAAW1hB,EAAO9L,UAAS6R,IAAc,EACzCle,EAAOzB,KAAK,WAAW2f,2BAKnCqb,6BAAA,SAAiBQ,EAAaC,EAAmBC,GAU7C,IAAIC,EAEAC,EACAC,EAEA/iB,EAEA6hB,EACA/gB,EACAkiB,EACAC,EANEC,EAAe,GAEfC,EAAgBn8B,KActB,IARA47B,EAAiBA,GAAkB,EAQ9BC,EAAc,EAAGA,EAAcH,EAAY58B,OAAQ+8B,IACpD,IAAKC,EAAoB,EAAGA,EAAoBH,EAAkB78B,OAAQg9B,IAEtEhiB,EAAS4hB,EAAYG,GACrBG,EAAeL,EAAkBG,GAG5BhiB,EAAO8U,WAAWhe,QAASorB,EAAatN,YAAe,IAG5DmM,EAAe,CAACmB,EAAa9M,cAAc,KAC3C6M,EAAUI,EAAcC,UAAUtiB,EAAQ+gB,IAE9B/7B,SACRgb,EAAO2hB,iBAAkB,EAGzB3hB,EAAOoV,cAAc1hB,SAAQ,SAAS6uB,GAClC,IAAMl8B,EAAO67B,EAAarpB,iBAG1BqG,EAAcmjB,EAAcG,eAAeP,EAASlB,EAAcwB,EAAcviB,EAAO4J,cAGvFuY,EAAY,IAAI/H,GAAW,OAAE8H,EAAanc,SAAUmc,EAAavN,OAAQ,EAAGuN,EAAahvB,WAAY7M,IAC3F+uB,cAAgBlW,EAG1BA,EAAYA,EAAYla,OAAS,GAAG2Z,WAAa,CAACwjB,GAGlDC,EAAa17B,KAAKy7B,GAClBA,EAAU5b,QAAU2b,EAAa3b,QAGjC4b,EAAUrN,WAAaqN,EAAUrN,WAAW1tB,OAAO86B,EAAapN,WAAY9U,EAAO8U,YAK/EoN,EAAaf,gCACbgB,EAAUhB,+BAAgC,EAC1Ce,EAAa3b,QAAQrD,MAAMxc,KAAKwY,SAOpD,GAAIkjB,EAAap9B,OAAQ,CAIrB,GADAkB,KAAKu8B,mBACDX,EAAiB,IAAK,CACtB,IAAIY,EAAc,wBACdC,EAAc,wBAClB,IACID,EAAcN,EAAa,GAAGhN,cAAc,GAAG7e,QAC/CosB,EAAcP,EAAa,GAAGrc,SAASxP,QAE3C,MAAO5Q,IACP,KAAM,CAAEyX,QAAS,gFAAgFslB,aAAsBC,OAK3H,OAAOP,EAAah7B,OAAOi7B,EAAcd,iBAAiBa,EAAcP,EAAmBC,EAAiB,IAE5G,OAAOM,GAIfhB,6BAAA,SAAiBwB,EAAUzG,GACvBA,EAAUhB,aAAc,GAG5BiG,iCAAA,SAAqBtB,EAAqB3D,GACtCA,EAAUhB,aAAc,GAG5BiG,0BAAA,SAAcyB,EAAc1G,GACxBA,EAAUhB,aAAc,GAG5BiG,yBAAA,SAAanB,EAAa9D,GACtB,IAAI8D,EAAYxZ,KAAhB,CAGA,IAAIwb,EACAa,EACAf,EAIAhB,EAHEH,EAAa16B,KAAKw6B,gBAAgBx6B,KAAKw6B,gBAAgB17B,OAAS,GAChE+9B,EAAiB,GACjBV,EAAgBn8B,KAKtB,IAAK67B,EAAc,EAAGA,EAAcnB,EAAW57B,OAAQ+8B,IACnD,IAAKe,EAAY,EAAGA,EAAY7C,EAAY/c,MAAMle,OAAQ89B,IAItD,GAHA/B,EAAed,EAAY/c,MAAM4f,IAG7B7C,EAAYa,kBAAhB,CACA,IAAMniB,EAAaoiB,EAAaA,EAAa/7B,OAAS,GAAG2Z,WACrDA,GAAcA,EAAW3Z,SAE7Bi9B,EAAU/7B,KAAKo8B,UAAU1B,EAAWmB,GAAchB,IAEtC/7B,SACR47B,EAAWmB,GAAaJ,iBAAkB,EAE1Cf,EAAWmB,GAAa3M,cAAc1hB,SAAQ,SAAS6uB,GACnD,IAAIS,EACJA,EAAoBX,EAAcG,eAAeP,EAASlB,EAAcwB,EAAc3B,EAAWmB,GAAanY,aAC9GmZ,EAAer8B,KAAKs8B,OAKpC/C,EAAY/c,MAAQ+c,EAAY/c,MAAM9b,OAAO27B,KAGjD3B,sBAAA,SAAUphB,EAAQijB,GAKd,IAAIC,EAEAC,EACAC,EACAC,EACAC,EACA18B,EAIA28B,EAFEC,EAAiBxjB,EAAO+F,SAASrH,SACjC+kB,EAAmB,GAEnBxB,EAAU,GAGhB,IAAKiB,EAAwB,EAAGA,EAAwBD,EAAqBj+B,OAAQk+B,IAGjF,IAFAC,EAAoBF,EAAqBC,GAEpCE,EAAwB,EAAGA,EAAwBD,EAAkBzkB,SAAS1Z,OAAQo+B,IAUvF,IARAC,EAAkBF,EAAkBzkB,SAAS0kB,IAGzCpjB,EAAO+U,aAA0C,IAA1BmO,GAAyD,IAA1BE,IACtDK,EAAiB/8B,KAAK,CAACo8B,UAAWI,EAAuBhvB,MAAOkvB,EAAuBM,QAAS,EAC5FC,kBAAmBN,EAAgB3qB,aAGtC9R,EAAI,EAAGA,EAAI68B,EAAiBz+B,OAAQ4B,IACrC28B,EAAiBE,EAAiB78B,GAMT,MADzB08B,EAAmBD,EAAgB3qB,WAAWpE,QACW,IAA1B8uB,IAC3BE,EAAmB,MA5Bbp9B,KAgCS09B,qBAAqBJ,EAAeD,EAAeG,SAASpvB,MAAO+uB,EAAgB/uB,QACjGivB,EAAeG,QAAU,GAAKF,EAAeD,EAAeG,SAAShrB,WAAWpE,QAAUgvB,EAC3FC,EAAiB,KAEjBA,EAAeG,UAIfH,IACAA,EAAeM,SAAWN,EAAeG,UAAYF,EAAex+B,OAChEu+B,EAAeM,WACb7jB,EAAOgV,aACJoO,EAAwB,EAAID,EAAkBzkB,SAAS1Z,QAAUk+B,EAAwB,EAAID,EAAqBj+B,UACvHu+B,EAAiB,OAIrBA,EACIA,EAAeM,WACfN,EAAev+B,OAASw+B,EAAex+B,OACvCu+B,EAAeO,aAAeZ,EAC9BK,EAAeQ,oBAAsBX,EAAwB,EAC7DK,EAAiBz+B,OAAS,EAC1Bi9B,EAAQv7B,KAAK68B,KAGjBE,EAAiB58B,OAAOD,EAAG,GAC3BA,KAKhB,OAAOq7B,GAGXb,iCAAA,SAAqB4C,EAAeC,GAChC,GAA6B,iBAAlBD,GAAuD,iBAAlBC,EAC5C,OAAOD,IAAkBC,EAE7B,GAAID,aAAyB5J,GAAKnJ,UAC9B,OAAI+S,EAAcvvB,KAAOwvB,EAAcxvB,IAAMuvB,EAAcnsB,MAAQosB,EAAcpsB,MAG5EmsB,EAAc1vB,OAAU2vB,EAAc3vB,OAM3C0vB,EAAgBA,EAAc1vB,MAAMA,OAAS0vB,EAAc1vB,UAC3D2vB,EAAgBA,EAAc3vB,MAAMA,OAAS2vB,EAAc3vB,QANnD0vB,EAAc1vB,QAAS2vB,EAAc3vB,OAWjD,GAFA0vB,EAAgBA,EAAc1vB,MAC9B2vB,EAAgBA,EAAc3vB,MAC1B0vB,aAAyB5J,GAAK3b,SAAU,CACxC,KAAMwlB,aAAyB7J,GAAK3b,WAAaulB,EAActlB,SAAS1Z,SAAWi/B,EAAcvlB,SAAS1Z,OACtG,OAAO,EAEX,IAAK,IAAI4B,EAAI,EAAGA,EAAKo9B,EAActlB,SAAS1Z,OAAQ4B,IAAK,CACrD,GAAIo9B,EAActlB,SAAS9X,GAAG8R,WAAWpE,QAAU2vB,EAAcvlB,SAAS9X,GAAG8R,WAAWpE,QAC1E,IAAN1N,IAAYo9B,EAActlB,SAAS9X,GAAG8R,WAAWpE,OAAS,QAAU2vB,EAAcvlB,SAAS9X,GAAG8R,WAAWpE,OAAS,MAClH,OAAO,EAGf,IAAKpO,KAAK09B,qBAAqBI,EAActlB,SAAS9X,GAAG0N,MAAO2vB,EAAcvlB,SAAS9X,GAAG0N,OACtF,OAAO,EAGf,OAAO,EAEX,OAAO,GAGX8sB,2BAAA,SAAea,EAASlB,EAAcmD,EAAqBta,GAIvD,IAAkFua,EAAYpe,EAAUqe,EAAchvB,EAAOivB,EAAzHC,EAA2B,EAAGC,EAAkC,EAAGlhB,EAAO,GAE9E,IAAK8gB,EAAa,EAAGA,EAAalC,EAAQj9B,OAAQm/B,IAE9Cpe,EAAWgb,GADX3rB,EAAQ6sB,EAAQkC,IACcrB,WAC9BsB,EAAe,IAAIhK,GAAK3hB,QACpBrD,EAAMuuB,kBACNO,EAAoBxlB,SAAS,GAAGpK,MAChC4vB,EAAoBxlB,SAAS,GAAG/F,WAChCurB,EAAoBxlB,SAAS,GAAGvL,WAChC+wB,EAAoBxlB,SAAS,GAAGxL,YAGhCkC,EAAM0tB,UAAYwB,GAA4BC,EAAkC,IAChFlhB,EAAKA,EAAKre,OAAS,GAAG0Z,SAAW2E,EAAKA,EAAKre,OAAS,GAC/C0Z,SAAStX,OAAO25B,EAAauD,GAA0B5lB,SAAS3G,MAAMwsB,IAC3EA,EAAkC,EAClCD,KAGJD,EAActe,EAASrH,SAClB3G,MAAMwsB,EAAiCnvB,EAAMlB,OAC7C9M,OAAO,CAACg9B,IACRh9B,OAAO88B,EAAoBxlB,SAAS3G,MAAM,IAE3CusB,IAA6BlvB,EAAM0tB,WAAaqB,EAAa,EAC7D9gB,EAAKA,EAAKre,OAAS,GAAG0Z,SAClB2E,EAAKA,EAAKre,OAAS,GAAG0Z,SAAStX,OAAOi9B,IAE1ChhB,EAAOA,EAAKjc,OAAO25B,EAAahpB,MAAMusB,EAA0BlvB,EAAM0tB,aAEjEp8B,KAAK,IAAI0zB,GAAK3b,SACf4lB,IAGRC,EAA2BlvB,EAAM0uB,cACjCS,EAAkCnvB,EAAM2uB,sBACDhD,EAAauD,GAA0B5lB,SAAS1Z,SACnFu/B,EAAkC,EAClCD,KAqBR,OAjBIA,EAA2BvD,EAAa/7B,QAAUu/B,EAAkC,IACpFlhB,EAAKA,EAAKre,OAAS,GAAG0Z,SAAW2E,EAAKA,EAAKre,OAAS,GAC/C0Z,SAAStX,OAAO25B,EAAauD,GAA0B5lB,SAAS3G,MAAMwsB,IAC3ED,KAIJjhB,GADAA,EAAOA,EAAKjc,OAAO25B,EAAahpB,MAAMusB,EAA0BvD,EAAa/7B,UACjEqQ,KAAI,SAAUmvB,GAEtB,IAAMC,EAAUD,EAAavlB,cAAculB,EAAa9lB,UAMxD,OALIkL,EACA6a,EAAQjE,mBAERiE,EAAQhE,qBAELgE,MAKfrD,uBAAA,SAAWhB,EAAWjE,GAClB,IAAIuI,EAAgBtE,EAAUQ,WAAWx5B,OAAOlB,KAAKw6B,gBAAgBx6B,KAAKw6B,gBAAgB17B,OAAS,IACnG0/B,EAAgBA,EAAct9B,OAAOlB,KAAKq7B,iBAAiBmD,EAAetE,EAAUQ,aACpF16B,KAAKw6B,gBAAgBh6B,KAAKg+B,IAG9BtD,0BAAA,SAAchB,GACV,IAAMuE,EAAYz+B,KAAKw6B,gBAAgB17B,OAAS,EAChDkB,KAAKw6B,gBAAgB17B,OAAS2/B,GAGlCvD,wBAAA,SAAYzB,EAAYxD,GACpB,IAAIuI,EAAgB/E,EAAWiB,WAAWx5B,OAAOlB,KAAKw6B,gBAAgBx6B,KAAKw6B,gBAAgB17B,OAAS,IACpG0/B,EAAgBA,EAAct9B,OAAOlB,KAAKq7B,iBAAiBmD,EAAe/E,EAAWiB,aACrF16B,KAAKw6B,gBAAgBh6B,KAAKg+B,IAG9BtD,2BAAA,SAAezB,GACX,IAAMgF,EAAYz+B,KAAKw6B,gBAAgB17B,OAAS,EAChDkB,KAAKw6B,gBAAgB17B,OAAS2/B,sBC1elC,aACIz+B,KAAKyc,SAAW,CAAC,IACjBzc,KAAKw3B,SAAW,IAAI5B,GAAQ51B,MAiDpC,OA9CI0+B,gBAAA,SAAIne,GACA,OAAOvgB,KAAKw3B,SAASlpB,MAAMiS,IAG/Bme,6BAAA,SAAiBpF,EAAUrD,GACvBA,EAAUhB,aAAc,GAG5ByJ,iCAAA,SAAqB9E,EAAqB3D,GACtCA,EAAUhB,aAAc,GAG5ByJ,yBAAA,SAAa3E,EAAa9D,GACtB,IAEI5W,EAFE1R,EAAU3N,KAAKyc,SAASzc,KAAKyc,SAAS3d,OAAS,GAC/Cke,EAAQ,GAGdhd,KAAKyc,SAASjc,KAAKwc,GAEd+c,EAAYxZ,QACblB,EAAY0a,EAAY1a,aAEpBA,EAAYA,EAAU+B,QAAO,SAASvB,GAAY,OAAOA,EAAS9F,iBAClEggB,EAAY1a,UAAYA,EAAUvgB,OAASugB,EAAaA,EAAY,KAChEA,GAAa0a,EAAYpW,cAAc3G,EAAOrP,EAAS0R,IAE1DA,IAAa0a,EAAYza,MAAQ,MACtCya,EAAY/c,MAAQA,IAI5B0hB,4BAAA,SAAgB3E,GACZ/5B,KAAKyc,SAAS3d,OAASkB,KAAKyc,SAAS3d,OAAS,GAGlD4/B,uBAAA,SAAWxE,EAAWjE,GAClB,IAAMtoB,EAAU3N,KAAKyc,SAASzc,KAAKyc,SAAS3d,OAAS,GACrDo7B,EAAU5a,MAAM,GAAGiB,KAA2B,IAAnB5S,EAAQ7O,QAAgB6O,EAAQ,GAAGye,YAGlEsS,wBAAA,SAAYjF,EAAYxD,GACpB,IAAMtoB,EAAU3N,KAAKyc,SAASzc,KAAKyc,SAAS3d,OAAS,GACjD26B,EAAWna,OAASma,EAAWna,MAAMxgB,SACrC26B,EAAWna,MAAM,GAAGiB,KAAQkZ,EAAWvT,UAA+B,IAAnBvY,EAAQ7O,QAAgB,0BC/CnF,WAAY6O,GACR3N,KAAKw3B,SAAW,IAAI5B,GAAQ51B,MAC5BA,KAAK2+B,SAAWhxB,EAwExB,OArEIixB,0CAAA,SAA8BC,GAC1B,IAAI3e,EACJ,IAAK2e,EACD,OAAO,EAEX,IAAK,IAAI3uB,EAAI,EAAGA,EAAI2uB,EAAU//B,OAAQoR,IAElC,IADAgQ,EAAO2e,EAAU3uB,IACRqM,UAAY2D,EAAK3D,SAASvc,KAAK2+B,YAAcze,EAAKgN,mBAGvD,OAAO,EAGf,OAAO,GAGX0R,kCAAA,SAAsBE,GACdA,GAASA,EAAMxf,QACfwf,EAAMxf,MAAQwf,EAAMxf,MAAM8B,QAAO,SAAA2d,GAAS,OAAAA,EAAMrb,iBAIxDkb,oBAAA,SAAQE,GACJ,OAAQA,IAASA,EAAMxf,OACO,IAAvBwf,EAAMxf,MAAMxgB,QAGvB8/B,+BAAA,SAAmB7E,GACf,SAAQA,IAAeA,EAAY/c,QAC5B+c,EAAY/c,MAAMle,OAAS,GAGtC8/B,8BAAA,SAAkBvxB,EAAM2xB,GACpB,IAAK3xB,EAAK6f,mBAAoB,CAC1B,GAAIltB,KAAKiO,QAAQZ,KAAUrN,KAAKi/B,8BAA8BD,GAC1D,OAGJ,OAAO3xB,EAGX,IAAM6xB,EAAoB7xB,EAAKiS,MAAM,GAGrC,GAFAtf,KAAKm/B,sBAAsBD,IAEvBl/B,KAAKiO,QAAQixB,GAOjB,OAHA7xB,EAAKitB,mBACLjtB,EAAK+xB,wBAEE/xB,GAGXuxB,6BAAA,SAAiB7E,GACb,QAAIA,EAAYvZ,YAIZxgB,KAAKiO,QAAQ8rB,OAIZA,EAAYxZ,OAASvgB,KAAKq/B,mBAAmBtF,UAQpDnP,GAAe,SAASjd,GAC1B3N,KAAKw3B,SAAW,IAAI5B,GAAQ51B,MAC5BA,KAAK2+B,SAAWhxB,EAChB3N,KAAKs/B,MAAQ,IAAIV,GAAgBjxB,IAGrCid,GAAa7a,UAAY,CACrBomB,aAAa,EACb4B,IAAK,SAAUxX,GACX,OAAOvgB,KAAKw3B,SAASlpB,MAAMiS,IAG/B8Y,iBAAkB,SAAUC,EAAUrD,GAClC,IAAIqD,EAASpM,qBAAsBoM,EAASte,SAG5C,OAAOse,GAGXK,qBAAsB,SAAU4F,EAAWtJ,GAGvCsJ,EAAUjiB,OAAS,IAGvBkiB,YAAa,SAAUC,EAAYxJ,KAGnCyJ,aAAc,SAAUC,EAAa1J,GACjC,IAAI0J,EAAYzS,qBAAsByS,EAAYpjB,SAASvc,KAAK2+B,UAGhE,OAAOgB,GAGX1F,WAAY,SAASC,EAAWjE,GAC5B,IAAM+I,EAAgB9E,EAAU5a,MAAM,GAAGA,MAIzC,OAHA4a,EAAUpnB,OAAO9S,KAAKw3B,UACtBvB,EAAUhB,aAAc,EAEjBj1B,KAAKs/B,MAAMM,kBAAkB1F,EAAW8E,IAGnD/G,YAAa,SAAUC,EAAYjC,GAC/B,IAAIiC,EAAWhL,mBAGf,OAAOgL,GAGXsB,YAAa,SAASC,EAAYxD,GAC9B,OAAIwD,EAAWna,OAASma,EAAWna,MAAMxgB,OAC9BkB,KAAK6/B,oBAAoBpG,EAAYxD,GAErCj2B,KAAK8/B,uBAAuBrG,EAAYxD,IAIvD8J,eAAgB,SAASC,EAAe/J,GACpC,IAAK+J,EAAc9S,mBAEf,OADA8S,EAAcltB,OAAO9S,KAAKw3B,UACnBwI,GAIfH,oBAAqB,SAASpG,EAAYxD,GAkBtC,IAAM+I,EAXN,SAAsBvF,GAClB,IAAMwG,EAAYxG,EAAWna,MAC7B,OANJ,SAAwBma,GACpB,IAAMoF,EAAYpF,EAAWna,MAC7B,OAA4B,IAArBuf,EAAU//B,UAAkB+/B,EAAU,GAAG7hB,OAAuC,IAA9B6hB,EAAU,GAAG7hB,MAAMle,QAIxEohC,CAAezG,GACRwG,EAAU,GAAG3gB,MAGjB2gB,EAKWE,CAAa1G,GAQnC,OAPAA,EAAW3mB,OAAO9S,KAAKw3B,UACvBvB,EAAUhB,aAAc,EAEnBj1B,KAAKs/B,MAAMrxB,QAAQwrB,IACpBz5B,KAAK6qB,YAAY4O,EAAWna,MAAM,GAAGA,OAGlCtf,KAAKs/B,MAAMM,kBAAkBnG,EAAYuF,IAGpDc,uBAAwB,SAASrG,EAAYxD,GACzC,IAAIwD,EAAWvM,mBAAf,CAIA,GAAwB,aAApBuM,EAAW7e,KAAqB,CAIhC,GAAI5a,KAAKogC,QAAS,CACd,GAAI3G,EAAW5d,UAAW,CACtB,IAAMwkB,EAAU,IAAInM,GAAK9X,QAAQ,MAAMqd,EAAWppB,MAAMrQ,KAAK2+B,UAAUxhC,QAAQ,MAAO,aAEtF,OADAkjC,EAAQxkB,UAAY4d,EAAW5d,UACxB7b,KAAKw3B,SAASlpB,MAAM+xB,GAE/B,OAEJrgC,KAAKogC,SAAU,EAGnB,OAAO3G,IAGX6G,gBAAiB,SAAShhB,EAAOihB,GAC7B,GAAKjhB,EAIL,IAAK,IAAI5e,EAAI,EAAGA,EAAI4e,EAAMxgB,OAAQ4B,IAAK,CACnC,IAAMg8B,EAAWpd,EAAM5e,GACvB,GAAI6/B,GAAU7D,aAAoBxI,GAAKvZ,cAAgB+hB,EAAS1hB,SAC5D,KAAM,CAAE9D,QAAS,wEACblJ,MAAO0uB,EAASzvB,WAAY1L,SAAUm7B,EAAS1vB,YAAc0vB,EAAS1vB,WAAWzL,UAEzF,GAAIm7B,aAAoBxI,GAAKrK,KACzB,KAAM,CAAE3S,QAAS,aAAawlB,EAAS9hB,oCACnC5M,MAAO0uB,EAASzvB,WAAY1L,SAAUm7B,EAAS1vB,YAAc0vB,EAAS1vB,WAAWzL,UAEzF,GAAIm7B,EAAS97B,OAAS87B,EAASniB,UAC3B,KAAM,CAAErD,QAAYwlB,EAAS97B,sDACzBoN,MAAO0uB,EAASzvB,WAAY1L,SAAUm7B,EAAS1vB,YAAc0vB,EAAS1vB,WAAWzL,YAKjGu4B,aAAc,SAAUC,EAAa9D,GAEjC,IAAI/V,EAEEwC,EAAW,GAIjB,GAFA1iB,KAAKsgC,gBAAgBvG,EAAYza,MAAOya,EAAYvZ,WAE/CuZ,EAAYxZ,KA6BbwZ,EAAYjnB,OAAO9S,KAAKw3B,UACxBvB,EAAUhB,aAAc,MA9BL,CAEnBj1B,KAAKwgC,qBAAqBzG,GAM1B,IAHA,IAAMkG,EAAYlG,EAAYza,MAE1BmhB,EAAcR,EAAYA,EAAUnhC,OAAS,EACxC4B,EAAI,EAAGA,EAAI+/B,IAChBvgB,EAAO+f,EAAUv/B,KACLwf,EAAKZ,OAEboD,EAASliB,KAAKR,KAAKw3B,SAASlpB,MAAM4R,IAClC+f,EAAUt/B,OAAOD,EAAG,GACpB+/B,KAGJ//B,IAKA+/B,EAAc,EACd1G,EAAYjnB,OAAO9S,KAAKw3B,UAExBuC,EAAYza,MAAQ,KAExB2W,EAAUhB,aAAc,EAiB5B,OAXI8E,EAAYza,QACZtf,KAAK6qB,YAAYkP,EAAYza,OAC7Btf,KAAK0gC,sBAAsB3G,EAAYza,QAIvCtf,KAAKs/B,MAAMqB,iBAAiB5G,KAC5BA,EAAYO,mBACZ5X,EAAS/hB,OAAO,EAAG,EAAGo5B,IAGF,IAApBrX,EAAS5jB,OACF4jB,EAAS,GAEbA,GAGX8d,qBAAsB,SAASzG,GACvBA,EAAY/c,QACZ+c,EAAY/c,MAAQ+c,EAAY/c,MAC3BoE,QAAO,SAAA2O,GACJ,IAAIrvB,EAIJ,IAH0C,MAAtCqvB,EAAE,GAAGvX,SAAS,GAAGhG,WAAWpE,QAC5B2hB,EAAE,GAAGvX,SAAS,GAAGhG,WAAa,IAAI0hB,GAAe,WAAE,KAElDxzB,EAAI,EAAGA,EAAIqvB,EAAEjxB,OAAQ4B,IACtB,GAAIqvB,EAAErvB,GAAGgjB,aAAeqM,EAAErvB,GAAGqZ,cACzB,OAAO,EAGf,OAAO,OAKvB2mB,sBAAuB,SAASphB,GAC5B,GAAKA,EAAL,CAGA,IAEIshB,EACA1gB,EACAxf,EAJEmgC,EAAY,GAMlB,IAAKngC,EAAI4e,EAAMxgB,OAAS,EAAG4B,GAAK,EAAIA,IAEhC,IADAwf,EAAOZ,EAAM5e,cACOwzB,GAAKvZ,YACrB,GAAKkmB,EAAU3gB,EAAKtF,MAEb,EACHgmB,EAAWC,EAAU3gB,EAAKtF,iBACFsZ,GAAKvZ,cACzBimB,EAAWC,EAAU3gB,EAAKtF,MAAQ,CAACimB,EAAU3gB,EAAKtF,MAAMvK,MAAMrQ,KAAK2+B,YAEvE,IAAMmC,EAAU5gB,EAAK7P,MAAMrQ,KAAK2+B,WACG,IAA/BiC,EAAShwB,QAAQkwB,GACjBxhB,EAAM3e,OAAOD,EAAG,GAEhBkgC,EAASpgC,KAAKsgC,QAVlBD,EAAU3gB,EAAKtF,MAAQsF,IAiBvC2K,YAAa,SAASvL,GAClB,GAAKA,EAAL,CAOA,IAHA,IAAMyhB,EAAY,GACZC,EAAY,GAETtgC,EAAI,EAAGA,EAAI4e,EAAMxgB,OAAQ4B,IAAK,CACnC,IAAMwf,EAAOZ,EAAM5e,GACnB,GAAIwf,EAAKpF,MAAO,CACZ,IAAMnJ,EAAMuO,EAAKtF,KACjBmmB,EAAOpvB,GAAO2N,EAAM3e,OAAOD,IAAK,GAC5BsgC,EAAUxgC,KAAKugC,EAAOpvB,GAAO,IACjCovB,EAAOpvB,GAAKnR,KAAK0f,IAIzB8gB,EAAUxzB,SAAQ,SAAAia,GACd,GAAIA,EAAM3oB,OAAS,EAAG,CAClB,IAAMmiC,EAASxZ,EAAM,GACjByZ,EAAS,GACPC,EAAS,CAAC,IAAIjN,GAAKjL,WAAWiY,IACpCzZ,EAAMja,SAAQ,SAAA0S,GACU,MAAfA,EAAKpF,OAAmBomB,EAAMpiC,OAAS,GACxCqiC,EAAM3gC,KAAK,IAAI0zB,GAAKjL,WAAWiY,EAAQ,KAE3CA,EAAM1gC,KAAK0f,EAAK9R,OAChB6yB,EAAOpmB,UAAYomB,EAAOpmB,WAAaqF,EAAKrF,aAEhDomB,EAAO7yB,MAAQ,IAAI8lB,GAAKla,MAAMmnB,iBC7V/B,CACXvL,WACAyB,iBACA+J,+BACAC,iBACA3C,uBACA9T,mCCVA,IACIxT,EAGApD,EAMAstB,EAGAC,EAGAC,EAGAC,EAGAC,EAfAC,EAAY,GAiBVC,EAAc,GAUpB,SAASC,EAAe/iC,GAWpB,IAVA,IAMIsQ,EACA0yB,EACAzB,EARE0B,EAAOH,EAAYlhC,EACnBshC,EAAOhuB,EACPiuB,EAAOL,EAAYlhC,EAAIghC,EACvBQ,EAAWN,EAAYlhC,EAAI+gC,EAAQ3iC,OAASmjC,EAC5CE,EAAOP,EAAYlhC,GAAK5B,EACxBsjC,EAAMhrB,EAKLwqB,EAAYlhC,EAAIwhC,EAAUN,EAAYlhC,IAAK,CAG9C,GAFA0O,EAAIgzB,EAAIC,WAAWT,EAAYlhC,GAE3BkhC,EAAYU,mBAjBO,KAiBclzB,EAA8B,CAE/D,GAAiB,OADjB0yB,EAAWM,EAAInvB,OAAO2uB,EAAYlhC,EAAI,IAChB,CAClB2/B,EAAU,CAACryB,MAAO4zB,EAAYlhC,EAAG2b,eAAe,GAChD,IAAIkmB,EAAcH,EAAIxxB,QAAQ,KAAMgxB,EAAYlhC,EAAI,GAChD6hC,EAAc,IACdA,EAAcL,GAElBN,EAAYlhC,EAAI6hC,EAChBlC,EAAQmC,KAAOJ,EAAI9pB,OAAO+nB,EAAQryB,MAAO4zB,EAAYlhC,EAAI2/B,EAAQryB,OACjE4zB,EAAYa,aAAajiC,KAAK6/B,GAC9B,SACG,GAAiB,MAAbyB,EAAkB,CACzB,IAAMY,EAAgBN,EAAIxxB,QAAQ,KAAMgxB,EAAYlhC,EAAI,GACxD,GAAIgiC,GAAiB,EAAG,CACpBrC,EAAU,CACNryB,MAAO4zB,EAAYlhC,EACnB8hC,KAAMJ,EAAI9pB,OAAOspB,EAAYlhC,EAAGgiC,EAAgB,EAAId,EAAYlhC,GAChE2b,eAAe,GAEnBulB,EAAYlhC,GAAK2/B,EAAQmC,KAAK1jC,OAAS,EACvC8iC,EAAYa,aAAajiC,KAAK6/B,GAC9B,UAGR,MAGJ,GAnDe,KAmDVjxB,GAjDO,KAiDmBA,GAlDlB,IAkDyCA,GAhD1C,KAgDkEA,EAC1E,MAOR,GAHAqyB,EAAUA,EAAQ5vB,MAAM/S,EAAS8iC,EAAYlhC,EAAIyhC,EAAMF,GACvDP,EAAaE,EAAYlhC,GAEpB+gC,EAAQ3iC,OAAQ,CACjB,GAAIkV,EAAIwtB,EAAO1iC,OAAS,EAGpB,OAFA2iC,EAAUD,IAASxtB,GACnB6tB,EAAe,IACR,EAEXD,EAAYjE,UAAW,EAG3B,OAAOoE,IAASH,EAAYlhC,GAAKshC,IAAShuB,EAoS9C,OAjSA4tB,EAAYe,KAAO,WACfjB,EAAaE,EAAYlhC,EACzBihC,EAAUnhC,KAAM,CAAEihC,UAAS/gC,EAAGkhC,EAAYlhC,EAAGsT,OAEjD4tB,EAAYgB,QAAU,SAAAC,IAEdjB,EAAYlhC,EAAI4gC,GAAaM,EAAYlhC,IAAM4gC,GAAYuB,IAAyBtB,KACpFD,EAAWM,EAAYlhC,EACvB6gC,EAA+BsB,GAEnC,IAAMC,EAAQnB,EAAUnmB,MACxBimB,EAAUqB,EAAMrB,QAChBC,EAAaE,EAAYlhC,EAAIoiC,EAAMpiC,EACnCsT,EAAI8uB,EAAM9uB,GAEd4tB,EAAYmB,OAAS,WACjBpB,EAAUnmB,OAEdomB,EAAYoB,aAAe,SAAAC,GACvB,IAAMC,EAAMtB,EAAYlhC,GAAKuiC,GAAU,GACjCE,EAAO/rB,EAAMirB,WAAWa,GAC9B,OA5FmB,KA4FXC,GAzFQ,KAyFmBA,GA3FlB,IA2F0CA,GA1F3C,KA0FoEA,GAIxFvB,EAAYwB,IAAM,SAAAC,GACVzB,EAAYlhC,EAAIghC,IAChBD,EAAUA,EAAQ5vB,MAAM+vB,EAAYlhC,EAAIghC,GACxCA,EAAaE,EAAYlhC,GAG7B,IAAMyK,EAAIk4B,EAAIC,KAAK7B,GACnB,OAAKt2B,GAIL02B,EAAe12B,EAAE,GAAGrM,QACH,iBAANqM,EACAA,EAGS,IAAbA,EAAErM,OAAeqM,EAAE,GAAKA,GARpB,MAWfy2B,EAAY2B,MAAQ,SAAAF,GAChB,OAAIjsB,EAAMnE,OAAO2uB,EAAYlhC,KAAO2iC,EACzB,MAEXxB,EAAe,GACRwB,IAGXzB,EAAY4B,KAAO,SAAAH,GAIf,IAHA,IAAMI,EAAYJ,EAAIvkC,OAGb4B,EAAI,EAAGA,EAAI+iC,EAAW/iC,IAC3B,GAAI0W,EAAMnE,OAAO2uB,EAAYlhC,EAAIA,KAAO2iC,EAAIpwB,OAAOvS,GAC/C,OAAO,KAKf,OADAmhC,EAAe4B,GACRJ,GAGXzB,EAAY8B,QAAU,SAAApsB,GAClB,IAAM4rB,EAAM5rB,GAAOsqB,EAAYlhC,EACzBijC,EAAYvsB,EAAMnE,OAAOiwB,GAE/B,GAAkB,MAAdS,GAAoC,MAAdA,EAA1B,CAMA,IAHA,IAAM7kC,EAASsY,EAAMtY,OACf8kC,EAAkBV,EAEfxiC,EAAI,EAAGA,EAAIkjC,EAAkB9kC,EAAQ4B,IAAK,CAE/C,OADiB0W,EAAMnE,OAAOvS,EAAIkjC,IAE9B,IAAK,KACDljC,IACA,SACJ,IAAK,KACL,IAAK,KACD,MACJ,KAAKijC,EACD,IAAMvrB,EAAMhB,EAAMkB,OAAOsrB,EAAiBljC,EAAI,GAC9C,OAAK4W,GAAe,IAARA,EAIL,CAACqsB,EAAWvrB,IAHfypB,EAAenhC,EAAI,GACZ0X,IAMvB,OAAO,OAOXwpB,EAAYiC,YAAc,SAAAR,GACtB,IAWIS,EAXA3Y,EAAQ,GACR4Y,EAAY,KACZC,GAAY,EACZC,EAAa,EACXC,EAAa,GACbC,EAAc,GACdrlC,EAASsY,EAAMtY,OACfslC,EAAWxC,EAAYlhC,EACzB2jC,EAAUzC,EAAYlhC,EACtBA,EAAIkhC,EAAYlhC,EAChB4jC,GAAO,EAIPR,EADe,iBAART,EACI,SAAAkB,GAAQ,OAAAA,IAASlB,GAEjB,SAAAkB,GAAQ,OAAAlB,EAAIlnB,KAAKooB,IAGhC,EAAG,CAEC,IAAIzC,EAAW1qB,EAAMnE,OAAOvS,GAC5B,GAAmB,IAAfujC,GAAoBH,EAAShC,IAC7BiC,EAAY3sB,EAAMkB,OAAO+rB,EAAS3jC,EAAI2jC,IAElCF,EAAY3jC,KAAKujC,GAGjBI,EAAY3jC,KAAK,KAErBujC,EAAYI,EACZtC,EAAenhC,EAAI0jC,GACnBE,GAAO,MACJ,CACH,GAAIN,EAAW,CACM,MAAblC,GACwB,MAAxB1qB,EAAMnE,OAAOvS,EAAI,KACjBA,IACAujC,IACAD,GAAY,GAEhBtjC,IACA,SAEJ,OAAQohC,GACJ,IAAK,KACDphC,IACAohC,EAAW1qB,EAAMnE,OAAOvS,GACxByjC,EAAY3jC,KAAK4W,EAAMkB,OAAO+rB,EAAS3jC,EAAI2jC,EAAU,IACrDA,EAAU3jC,EAAI,EACd,MACJ,IAAK,IAC2B,MAAxB0W,EAAMnE,OAAOvS,EAAI,KACjBA,IACAsjC,GAAY,EACZC,KAEJ,MACJ,IAAK,IACL,IAAK,KACD9Y,EAAQyW,EAAY8B,QAAQhjC,KAExByjC,EAAY3jC,KAAK4W,EAAMkB,OAAO+rB,EAAS3jC,EAAI2jC,GAAUlZ,GAErDkZ,GADA3jC,GAAKyqB,EAAM,GAAGrsB,OAAS,GACT,IAGd+iC,EAAenhC,EAAI0jC,GACnBL,EAAYjC,EACZwC,GAAO,GAEX,MACJ,IAAK,IACDJ,EAAW1jC,KAAK,KAChByjC,IACA,MACJ,IAAK,IACDC,EAAW1jC,KAAK,KAChByjC,IACA,MACJ,IAAK,IACDC,EAAW1jC,KAAK,KAChByjC,IACA,MACJ,IAAK,IACL,IAAK,IACL,IAAK,IACD,IAAMO,EAAWN,EAAW1oB,MACxBsmB,IAAa0C,EACbP,KAGApC,EAAenhC,EAAI0jC,GACnBL,EAAYS,EACZF,GAAO,KAGnB5jC,EACQ5B,IACJwlC,GAAO,UAIVA,GAET,OAAOP,GAAwB,MAGnCnC,EAAYU,mBAAoB,EAChCV,EAAYa,aAAe,GAC3Bb,EAAYjE,UAAW,EAIvBiE,EAAY6C,KAAO,SAAApB,GACf,GAAmB,iBAARA,EAAkB,CAEzB,IAAK,IAAI3iC,EAAI,EAAGA,EAAI2iC,EAAIvkC,OAAQ4B,IAC5B,GAAI0W,EAAMnE,OAAO2uB,EAAYlhC,EAAIA,KAAO2iC,EAAIpwB,OAAOvS,GAC/C,OAAO,EAGf,OAAO,EAEP,OAAO2iC,EAAIlnB,KAAKslB,IAMxBG,EAAY8C,SAAW,SAAArB,GAAO,OAAAjsB,EAAMnE,OAAO2uB,EAAYlhC,KAAO2iC,GAE9DzB,EAAY+C,YAAc,WAAM,OAAAvtB,EAAMnE,OAAO2uB,EAAYlhC,IAEzDkhC,EAAYgD,SAAW,WAAM,OAAAxtB,EAAMnE,OAAO2uB,EAAYlhC,EAAI,IAE1DkhC,EAAYiD,SAAW,WAAM,OAAAztB,GAE7BwqB,EAAYkD,eAAiB,WACzB,IAAM11B,EAAIgI,EAAMirB,WAAWT,EAAYlhC,GAEvC,OAAQ0O,EApTO,IAoTWA,EAvTR,IAES,KAqTqBA,GAtT7B,KAsT6DA,GAGpFwyB,EAAYmD,MAAQ,SAAC3sB,EAAK4sB,EAAYC,GAClC7tB,EAAQgB,EACRwpB,EAAYlhC,EAAIsT,EAAI0tB,EAAaJ,EAAW,EAaxCE,EADAwD,WCvWa5tB,EAAO8tB,GAC5B,IAGIC,EACAC,EACAC,EACAC,EAGAC,EACAC,EACAC,EACAC,EACAlI,EAbE9jB,EAAMtC,EAAMtY,OACd6mC,EAAQ,EACRC,EAAa,EAKXpE,EAAS,GACXqE,EAAW,EAOf,SAASC,EAAUC,GACf,IAAMrsB,EAAM6rB,EAAsBM,EAC5BnsB,EAAM,MAASqsB,IAAWrsB,IAGhC8nB,EAAOhhC,KAAK4W,EAAMvF,MAAMg0B,EAAUN,EAAsB,IACxDM,EAAWN,EAAsB,GAGrC,IAAKA,EAAsB,EAAGA,EAAsB7rB,EAAK6rB,IAErD,MADAE,EAAKruB,EAAMirB,WAAWkD,KACV,IAAQE,GAAM,KAAUA,EAAK,IAKzC,OAAQA,GACJ,KAAK,GACDG,IACAR,EAAmBG,EACnB,SACJ,KAAK,GACD,KAAMK,EAAa,EACf,OAAOV,EAAK,sBAAuBK,GAEvC,SACJ,KAAK,GACIK,GAAcE,IACnB,SACJ,KAAK,IACDH,IACAR,EAAcI,EACd,SACJ,KAAK,IACD,KAAMI,EAAQ,EACV,OAAOT,EAAK,sBAAuBK,GAElCI,GAAUC,GAAcE,IAC7B,SACJ,KAAK,GACD,GAAIP,EAAsB7rB,EAAM,EAAG,CAAE6rB,IAAuB,SAC5D,OAAOL,EAAK,iBAAkBK,GAClC,KAAK,GACL,KAAK,GACL,KAAK,GAGD,IAFA/H,EAAU,EACVgI,EAAyBD,EACpBA,GAA4C,EAAGA,EAAsB7rB,EAAK6rB,IAE3E,MADAG,EAAMtuB,EAAMirB,WAAWkD,IACb,IAAV,CACA,GAAIG,GAAOD,EAAI,CAAEjI,EAAU,EAAG,MAC9B,GAAW,IAAPkI,EAAW,CACX,GAAIH,GAAuB7rB,EAAM,EAC7B,OAAOwrB,EAAK,iBAAkBK,GAElCA,KAGR,GAAI/H,EAAW,SACf,OAAO0H,EAAK,cAAe5c,OAAO0d,aAAaP,OAASD,GAC5D,KAAK,GACD,GAAII,GAAeL,GAAuB7rB,EAAM,EAAM,SAEtD,GAAW,KADXgsB,EAAMtuB,EAAMirB,WAAWkD,EAAsB,IAGzC,IAAKA,GAA4C,EAAGA,EAAsB7rB,OACtEgsB,EAAMtuB,EAAMirB,WAAWkD,KACX,KAAgB,IAAPG,GAAsB,IAAPA,GAFuCH,UAI5E,GAAW,IAAPG,EAAW,CAGlB,IADAL,EAAmBG,EAAyBD,EACvCA,GAA4C,EAAGA,EAAsB7rB,EAAM,IAEjE,MADXgsB,EAAMtuB,EAAMirB,WAAWkD,MACLD,EAA2BC,GAClC,IAAPG,GAC6C,IAA7CtuB,EAAMirB,WAAWkD,EAAsB,IAJoCA,KAMnF,GAAIA,GAAuB7rB,EAAM,EAC7B,OAAOwrB,EAAK,uBAAwBM,GAExCD,IAEJ,SACJ,KAAK,GACD,GAAKA,EAAsB7rB,EAAM,GAAoD,IAA7CtC,EAAMirB,WAAWkD,EAAsB,GAC3E,OAAOL,EAAK,iBAAkBK,GAElC,SAIZ,OAAc,IAAVI,EAEWT,EADNG,EAAmBF,GAAiBG,EAA2BD,EACpD,8BAEA,sBAF+BF,GAIzB,IAAfS,EACAV,EAAK,sBAAuBE,IAGvCU,GAAU,GACHtE,GDiPUyE,CAAQ7tB,EAAK6sB,GAEb,CAAC7sB,GAGdqpB,EAAUD,EAAO,GAEjBK,EAAe,IAGnBD,EAAYsE,IAAM,WACd,IAAIhvB,EACE8gB,EAAa4J,EAAYlhC,GAAK0W,EAAMtY,OAM1C,OAJI8iC,EAAYlhC,EAAI4gC,IAChBpqB,EAAUqqB,EACVK,EAAYlhC,EAAI4gC,GAEb,CACHtJ,aACAsJ,SAAUM,EAAYlhC,EACtB6gC,6BAA8BrqB,EAC9BivB,mBAAoBvE,EAAYlhC,GAAK0W,EAAMtY,OAAS,EACpDsnC,aAAchvB,EAAMwqB,EAAYlhC,KAIjCkhC,GE5VLyE,GAAS,SAASA,EAAO14B,EAAS0L,EAASrM,GAC7C,IAAIs5B,EACE1E,EAAc2E,KAEpB,SAASzmC,EAAMC,EAAKa,GAChB,MAAM,IAAImW,EACN,CACI/I,MAAO4zB,EAAYlhC,EACnBa,SAAUyL,EAASzL,SACnBX,KAAMA,GAAQ,SACdsW,QAASnX,GAEbsZ,GAIR,SAASmtB,EAAOpW,EAAKrwB,GAEjB,IAAM6W,EAAUwZ,aAAevY,SAAYuY,EAAI5c,KAAK8yB,GAAW1E,EAAYwB,IAAIhT,GAC/E,GAAIxZ,EACA,OAAOA,EAGX9W,EAAMC,IAAuB,iBAARqwB,EACf,aAAaA,YAAawR,EAAY+C,kBACtC,qBAIV,SAAS8B,EAAWrW,EAAKrwB,GACrB,GAAI6hC,EAAY2B,MAAMnT,GAClB,OAAOA,EAEXtwB,EAAMC,GAAO,aAAaqwB,YAAawR,EAAY+C,mBAGvD,SAASroB,EAAatO,GAClB,IAAMzM,EAAWyL,EAASzL,SAE1B,MAAO,CACHya,WAAYzE,EAAkBvJ,EAAO4zB,EAAYiD,YAAYvvB,KAAO,EACpE2G,SAAU1a,GAyDlB,MAAO,CACHqgC,cACAvoB,UACArM,WACAmM,UAjDJ,SAAmBf,EAAKsuB,EAAWC,EAAc35B,EAAUua,GACvD,IAAI3Q,EACEgwB,EAAc,GACdC,EAASjF,EAEf,IACIiF,EAAO9B,MAAM3sB,GAAK,GAAO,SAAcrY,EAAKiO,GACxCuZ,EAAS,CACLrQ,QAASnX,EACTiO,MAAOA,EAAQ24B,OAGvB,IAAK,IAAIn1B,EAAI,EAAGue,SAAGrvB,SAAIqvB,EAAI2W,EAAUl1B,GAAKA,IAGtC,GAFA9Q,EAAImmC,EAAOnmC,EACXkW,EAAS0vB,EAAQvW,KACL,CACR,IACInZ,EAAOnJ,OAAS/M,EAAIimC,EACpB/vB,EAAOlJ,UAAYV,EACrB,MAAOvN,IACTmnC,EAAYpmC,KAAKoW,QAGjBgwB,EAAYpmC,KAAK,MAITqmC,EAAOX,MACXlO,WACRzQ,EAAS,KAAMqf,GAGfrf,GAAS,EAAM,MAErB,MAAO9nB,GACL,MAAM,IAAIsX,EAAU,CAChB/I,MAAOvO,EAAEuO,MAAQ24B,EACjBzvB,QAASzX,EAAEyX,SACZmC,EAASrM,EAASzL,YAkBzB5D,MAAO,SAAUya,EAAKmP,EAAUuf,GAC5B,IAAIvmB,EAEAwmB,EACAC,EACAC,EAHAnnC,EAAQ,KAIRonC,EAAU,GAKd,GAHAH,EAAcD,GAAkBA,EAAeC,WAAiBV,EAAOc,cAAcL,EAAeC,iBAAkB,GACtHC,EAAcF,GAAkBA,EAAeE,WAAc,KAAKX,EAAOc,cAAcL,EAAeE,YAAgB,GAElHr5B,EAAQ/L,cAER,IADA,IAAMwlC,EAAgBz5B,EAAQ/L,cAAcylC,mBACnC3mC,EAAI,EAAGA,EAAI0mC,EAActoC,OAAQ4B,IACtC0X,EAAMgvB,EAAc1mC,GAAG4mC,QAAQlvB,EAAK,CAAEzK,UAAS0L,UAASrM,cAI5D+5B,GAAeD,GAAkBA,EAAeS,UAChDL,GAAYJ,GAAkBA,EAAeS,OAAUT,EAAeS,OAAS,IAAMR,GACrFE,EAAU5tB,EAAQmuB,sBACVx6B,EAASzL,UAAY0lC,EAAQj6B,EAASzL,WAAa,EAC3D0lC,EAAQj6B,EAASzL,WAAa2lC,EAAQpoC,QAK1CsZ,EAAM8uB,GAFN9uB,EAAMA,EAAIjb,QAAQ,SAAU,OAERA,QAAQ,UAAW,IAAM6pC,EAC7C3tB,EAAQhC,SAASrK,EAASzL,UAAY6W,EAMtC,IACIwpB,EAAYmD,MAAM3sB,EAAKzK,EAAQq3B,YAAY,SAAcjlC,EAAKiO,GAC1D,MAAM,IAAI+I,EAAU,CAChB/I,QACApN,KAAM,QACNsW,QAASnX,EACTwB,SAAUyL,EAASzL,UACpB8X,MAGP6a,GAAKhnB,KAAK6C,UAAUpS,MAAQqC,KAC5BugB,EAAO,IAAI2T,GAAK9U,QAAQ,KAAMpf,KAAKsmC,QAAQmB,WAC3CvT,GAAKhnB,KAAK6C,UAAUrD,SAAW6T,EAC/BA,EAAKA,MAAO,EACZA,EAAKC,WAAY,EACjBD,EAAKG,iBAAmBA,EAAiB3B,UAE3C,MAAOtf,GACL,OAAO8nB,EAAS,IAAIxQ,EAAUtX,EAAG4Z,EAASrM,EAASzL,WAWvD,IAAMmmC,EAAU9F,EAAYsE,MAC5B,IAAKwB,EAAQ1P,WAAY,CAErB,IAAI9gB,EAAUwwB,EAAQnG,6BAEjBrqB,IACDA,EAAU,qBACmB,MAAzBwwB,EAAQtB,aACRlvB,GAAW,iCACqB,MAAzBwwB,EAAQtB,aACflvB,GAAW,iCACJwwB,EAAQvB,qBACfjvB,GAAW,iCAInBpX,EAAQ,IAAIiX,EAAU,CAClBnW,KAAM,QACNsW,UACAlJ,MAAO05B,EAAQpG,SACf//B,SAAUyL,EAASzL,UACpB8X,GAGP,IAAMke,EAAS,SAAA93B,GAGX,OAFAA,EAAIK,GAASL,GAAK4Z,EAAQvZ,QAGhBL,aAAasX,IACftX,EAAI,IAAIsX,EAAUtX,EAAG4Z,EAASrM,EAASzL,WAGpCgmB,EAAS9nB,IAGT8nB,EAAS,KAAMhH,IAI9B,IAA+B,IAA3B5S,EAAQg6B,eAIR,OAAOpQ,IAHP,IAAI5M,GAAS0M,cAAche,EAASke,GAC/BQ,IAAIxX,IAmCjB+lB,QAASA,EAAU,CAgBfmB,QAAS,WAKL,IAJA,IAEIp6B,EAFE0jB,EAAQ/wB,KAAK+wB,MACfxQ,EAAO,KAGE,CACT,KACIlT,EAAOrN,KAAKqgC,WAEZ9f,EAAK/f,KAAK6M,GAGd,GAAIu0B,EAAYjE,SACZ,MAEJ,GAAIiE,EAAY6C,KAAK,KACjB,MAIJ,GADAp3B,EAAOrN,KAAK4nC,aAERrnB,EAAOA,EAAKrf,OAAOmM,QAMvB,GAFAA,EAAO0jB,EAAM8W,cAAgB7nC,KAAK8nC,eAAiB/W,EAAMvd,MAAK,GAAO,IACjExT,KAAKqgB,WAAargB,KAAK+nC,gBAAkB/nC,KAAKgoC,SAASx0B,QAAUxT,KAAKioC,SAEtE1nB,EAAK/f,KAAK6M,OACP,CAEH,IADA,IAAI66B,GAAiB,EACdtG,EAAY2B,MAAM,MACrB2E,GAAiB,EAErB,IAAKA,EACD,OAKZ,OAAO3nB,GAKX8f,QAAS,WACL,GAAIuB,EAAYa,aAAa3jC,OAAQ,CACjC,IAAMuhC,EAAUuB,EAAYa,aAAa7oB,QACzC,OAAO,IAAIsa,GAAY,QAAEmM,EAAQmC,KAAMnC,EAAQhkB,cAAegkB,EAAQryB,MAAOhB,KAOrFg7B,SAAU,CACNG,YAAa,WACT,OAAO7B,EAAQvV,MAAMvd,MAAK,GAAM,IAOpC40B,OAAQ,SAAUC,GACd,IAAIjwB,EACEpK,EAAQ4zB,EAAYlhC,EACtB4nC,GAAY,EAGhB,GADA1G,EAAYe,OACRf,EAAY2B,MAAM,KAClB+E,GAAY,OACT,GAAID,EAEP,YADAzG,EAAYgB,UAKhB,GADAxqB,EAAMwpB,EAAY8B,UAOlB,OAFA9B,EAAYmB,SAEL,IAAI7O,GAAW,OAAE9b,EAAInF,OAAO,GAAImF,EAAIE,OAAO,EAAGF,EAAItZ,OAAS,GAAIwpC,EAAWt6B,EAAOhB,GALpF40B,EAAYgB,WAapBlxB,QAAS,WACL,IAAMqC,EAAI6tB,EAAY2B,MAAM,MAAQ3B,EAAYwB,IAAI,2DACpD,GAAIrvB,EACA,OAAOmgB,GAAKnlB,MAAM0C,YAAYsC,IAAM,IAAImgB,GAAY,QAAEngB,IAW9DP,KAAM,WACF,IAAIoH,EACAlK,EACAkH,EACE5J,EAAQ4zB,EAAYlhC,EAG1B,IAAIkhC,EAAY6C,KAAK,WAOrB,GAHA7C,EAAYe,OAEZ/nB,EAAOgnB,EAAYwB,IAAI,kCACvB,CAOA,GAFAxoB,EAAOA,EAAK,IACZhD,EAAO5X,KAAKuoC,eAAe3tB,MAEvBlK,EAAOkH,EAAKja,UACAia,EAAK4wB,KAEb,OADA5G,EAAYmB,SACLryB,EAMf,GAFAA,EAAO1Q,KAAK8T,UAAUpD,GAEjBkxB,EAAY2B,MAAM,KAOvB,OAFA3B,EAAYmB,SAEL,IAAI7O,GAAS,KAAEtZ,EAAMlK,EAAM1C,EAAOhB,GANrC40B,EAAYgB,QAAQ,sDAjBpBhB,EAAYmB,UAmCpBwF,eAAgB,SAAU3tB,GAItB,MAAO,CACHtL,MAAS4hB,EAAEoV,EAAQmC,SAAS,GAC5BC,QAASxX,EAAExY,GACXiwB,GAASzX,EAAExY,IACbkC,EAAKhJ,eAEP,SAASsf,EAAEvzB,EAAO6qC,GACd,MAAO,CACH7qC,QACA6qC,QAKR,SAAS9vB,IACL,MAAO,CAAC8tB,EAAOF,EAAQ5tB,UAAW,yBAI1C5E,UAAW,SAAU80B,GACjB,IAEIC,EACAz6B,EAHA06B,EAAYF,GAAY,GACtBG,EAAgB,GAMtB,IAFAnH,EAAYe,SAEC,CACT,GAAIiG,EACAA,GAAW,MACR,CAEH,KADAx6B,EAAQk4B,EAAQlX,mBAAqBpvB,KAAKgpC,cAAgB1C,EAAQ5Y,cAE9D,MAGAtf,EAAMA,OAA+B,GAAtBA,EAAMA,MAAMtP,SAC3BsP,EAAQA,EAAMA,MAAM,IAGxB06B,EAAUtoC,KAAK4N,GAGfwzB,EAAY2B,MAAM,OAIlB3B,EAAY2B,MAAM,MAAQsF,KAC1BA,GAAuB,EACvBz6B,EAAS06B,EAAUhqC,OAAS,EAAKgqC,EAAU,GACrC,IAAI5U,GAAKla,MAAM8uB,GACrBC,EAAcvoC,KAAK4N,GACnB06B,EAAY,IAKpB,OADAlH,EAAYmB,SACL8F,EAAuBE,EAAgBD,GAElDG,QAAS,WACL,OAAOjpC,KAAKkpC,aACLlpC,KAAKuQ,SACLvQ,KAAKooC,UACLpoC,KAAKmpC,qBAShBH,WAAY,WACR,IAAIr3B,EACAvD,EAGJ,GAFAwzB,EAAYe,OACZhxB,EAAMiwB,EAAYwB,IAAI,iBAKtB,GAAKxB,EAAY2B,MAAM,KAAvB,CAKA,GADAn1B,EAAQk4B,EAAQ8C,SAGZ,OADAxH,EAAYmB,SACL,IAAI7O,GAAe,WAAEviB,EAAKvD,GAEjCwzB,EAAYgB,eARZhB,EAAYgB,eAJZhB,EAAYgB,WAuBpBpQ,IAAK,WACD,IAAIpkB,EACEJ,EAAQ4zB,EAAYlhC,EAI1B,GAFAkhC,EAAYU,mBAAoB,EAE3BV,EAAY4B,KAAK,QAYtB,OAPAp1B,EAAQpO,KAAKooC,UAAYpoC,KAAKgb,YAAchb,KAAKqiB,YACzCuf,EAAYwB,IAAI,mCAAqC,GAE7DxB,EAAYU,mBAAoB,EAEhCmE,EAAW,KAEJ,IAAIvS,GAAQ,IAAkB,MAAf9lB,EAAMA,OACxBA,aAAiB8lB,GAAK9J,UACtBhc,aAAiB8lB,GAAK1J,SACtBpc,EAAQ,IAAI8lB,GAAc,UAAE9lB,EAAOJ,GAAQA,EAAOhB,GAdlD40B,EAAYU,mBAAoB,GAyBxCtnB,SAAU,WACN,IAAIquB,EACAzuB,EACE5M,EAAQ4zB,EAAYlhC,EAG1B,GADAkhC,EAAYe,OACsB,MAA9Bf,EAAY+C,gBAA0B/pB,EAAOgnB,EAAYwB,IAAI,eAAgB,CAE7E,GAAW,OADXiG,EAAKzH,EAAY+C,gBACQ,MAAP0E,IAAezH,EAAYgD,WAAW11B,MAAM,OAAQ,CAElE,IAAM0H,EAAS0vB,EAAQyB,aAAantB,GACpC,GAAIhE,EAEA,OADAgrB,EAAYmB,SACLnsB,EAIf,OADAgrB,EAAYmB,SACL,IAAI7O,GAAa,SAAEtZ,EAAM5M,EAAOhB,GAE3C40B,EAAYgB,WAIhB0G,cAAe,WACX,IAAIC,EACEv7B,EAAQ4zB,EAAYlhC,EAE1B,GAAkC,MAA9BkhC,EAAY+C,gBAA0B4E,EAAQ3H,EAAYwB,IAAI,mBAC9D,OAAO,IAAIlP,GAAa,SAAE,IAAIqV,EAAM,GAAMv7B,EAAOhB,IAQzDqV,SAAU,WACN,IAAIzH,EACE5M,EAAQ4zB,EAAYlhC,EAE1B,GAAkC,MAA9BkhC,EAAY+C,gBAA0B/pB,EAAOgnB,EAAYwB,IAAI,cAC7D,OAAO,IAAIlP,GAAa,SAAEtZ,EAAM5M,EAAOhB,IAK/Cw8B,cAAe,WACX,IAAID,EACEv7B,EAAQ4zB,EAAYlhC,EAE1B,GAAkC,MAA9BkhC,EAAY+C,gBAA0B4E,EAAQ3H,EAAYwB,IAAI,oBAC9D,OAAO,IAAIlP,GAAa,SAAE,IAAIqV,EAAM,GAAMv7B,EAAOhB,IAUzDuD,MAAO,WACH,IAAIvB,EAGJ,GAFA4yB,EAAYe,OAEsB,MAA9Bf,EAAY+C,gBAA0B31B,EAAM4yB,EAAYwB,IAAI,oEACvDp0B,EAAI,GAEL,OADA4yB,EAAYmB,SACL,IAAI7O,GAAU,MAAEllB,EAAI,QAAIxC,EAAWwC,EAAI,IAGtD4yB,EAAYgB,WAGhB6G,aAAc,WACV7H,EAAYe,OACZ,IAAML,EAAoBV,EAAYU,kBACtCV,EAAYU,mBAAoB,EAChC,IAAMvuB,EAAI6tB,EAAYwB,IAAI,6BAE1B,GADAxB,EAAYU,kBAAoBA,EAC3BvuB,EAAL,CAIA6tB,EAAYgB,UACZ,IAAMryB,EAAQ2jB,GAAKnlB,MAAM0C,YAAYsC,GACrC,OAAIxD,GACAqxB,EAAY4B,KAAKzvB,GACVxD,QAFX,EALIqxB,EAAYmB,UAgBpBmG,UAAW,WACP,IAAItH,EAAYkD,iBAAhB,CAIA,IAAM12B,EAAQwzB,EAAYwB,IAAI,kCAC9B,OAAIh1B,EACO,IAAI8lB,GAAc,UAAE9lB,EAAM,GAAIA,EAAM,SAD/C,IAUJ+6B,kBAAmB,WACf,IAAIO,EAGJ,GADAA,EAAK9H,EAAYwB,IAAI,uCAEjB,OAAO,IAAIlP,GAAsB,kBAAEwV,EAAG,KAS9CC,WAAY,WACR,IAAIC,EACE57B,EAAQ4zB,EAAYlhC,EAE1BkhC,EAAYe,OAEZ,IAAMkH,EAASjI,EAAY2B,MAAM,KAGjC,GAFgB3B,EAAY2B,MAAM,KAElC,CAMA,GADAqG,EAAKhI,EAAYwB,IAAI,WAGjB,OADAxB,EAAYmB,SACL,IAAI7O,GAAe,WAAE0V,EAAGtxB,OAAO,EAAGsxB,EAAG9qC,OAAS,GAAI2b,QAAQovB,GAAS77B,EAAOhB,GAErF40B,EAAYgB,QAAQ,sCAThBhB,EAAYgB,YAkBxB5nB,SAAU,WACN,IAAIJ,EAEJ,GAAkC,MAA9BgnB,EAAY+C,gBAA0B/pB,EAAOgnB,EAAYwB,IAAI,mBAAsB,OAAOxoB,EAAK,IAWvGmtB,aAAc,SAAU+B,GACpB,IAAIva,EACE7uB,EAAIkhC,EAAYlhC,EAChBqpC,IAAYD,EACdlvB,EAAOkvB,EAIX,GAFAlI,EAAYe,OAER/nB,GAAuC,MAA9BgnB,EAAY+C,gBACjB/pB,EAAOgnB,EAAYwB,IAAI,yBAA2B,CAItD,KAFA7T,EAAUvvB,KAAK+wB,MAAMiZ,iBAEHD,GAAsC,OAA3BnI,EAAY4B,KAAK,OAAgC,OAAZ5oB,EAAK,IAEnE,YADAgnB,EAAYgB,QAAQ,2CAInBmH,IACDnvB,EAAOA,EAAK,IAGhB,IAAMpH,EAAO,IAAI0gB,GAAK/E,aAAavU,EAAMla,EAAGsM,GAC5C,OAAK+8B,GAAWzD,EAAQJ,OACpBtE,EAAYmB,SACLvvB,IAGPouB,EAAYmB,SACL,IAAI7O,GAAK7E,eAAe7b,EAAM+b,EAAS7uB,EAAGsM,IAIzD40B,EAAYgB,WAMhB9oB,OAAQ,SAASmwB,GACb,IAAIzxB,EACA/Y,EAEAgvB,EACAhW,EACAqB,EAHE9L,EAAQ4zB,EAAYlhC,EAK1B,GAAKkhC,EAAY4B,KAAKyG,EAAS,YAAc,YAA7C,CAIA,EAAG,CAGC,IAFAxb,EAAS,KACTjW,EAAW,OACFiW,EAASmT,EAAYwB,IAAI,0BAC9B3jC,EAAIO,KAAKokB,YAIL5L,EACAA,EAAShY,KAAKf,GAEd+Y,EAAW,CAAE/Y,GAIrBgvB,EAASA,GAAUA,EAAO,GACrBjW,GACD1Y,EAAM,0CAEVga,EAAS,IAAIoa,GAAW,OAAE,IAAIA,GAAa,SAAE1b,GAAWiW,EAAQzgB,EAAOhB,GACnEyL,EACAA,EAAWjY,KAAKsZ,GAEhBrB,EAAa,CAAEqB,SAEd8nB,EAAY2B,MAAM,MAQ3B,OANAiD,EAAO,OAEHyD,GACAzD,EAAO,MAGJ/tB,IAMXmvB,WAAY,WACR,OAAO5nC,KAAK8Z,QAAO,IAMvBiX,MAAO,CAiBHvd,KAAM,SAAUu2B,EAASG,GACrB,IAEI3a,EAEA/W,EACA9H,EACAy5B,EANEx+B,EAAIi2B,EAAY+C,cAClB9pB,GAAY,EAEV7M,EAAQ4zB,EAAYlhC,EAK1B,GAAU,MAANiL,GAAmB,MAANA,EAAjB,CAMA,GAJAi2B,EAAYe,OAEZnqB,EAAWxY,KAAKwY,WAEF,CAUV,GATIopB,EAAY2B,MAAM,OAClB7yB,EAAO1Q,KAAK0Q,MAAK,GAAMA,KACvB+1B,EAAW,KACX0D,GAAY,IAGE,IAAdD,IACA3a,EAAUvvB,KAAKgqC,gBAED,IAAdE,IAAuB3a,EAEvB,YADAqS,EAAYgB,UAIhB,IAAKrT,IAAY4a,EAGb,YADAvI,EAAYgB,QAAQ,2DAQxB,IAJKmH,GAAWzD,EAAQzrB,cACpBA,GAAY,GAGZkvB,GAAWzD,EAAQJ,MAAO,CAC1BtE,EAAYmB,SACZ,IAAMhS,EAAQ,IAAImD,GAAKnD,MAAU,KAAEvY,EAAU9H,EAAM1C,EAAOhB,GAAWuiB,GAAW1U,GAChF,OAAI0U,EACO,IAAI2E,GAAK7E,eAAe0B,EAAOxB,GAG/BwB,GAKnB6Q,EAAYgB,YAMhBpqB,SAAU,WAON,IANA,IAAIA,EACA/Y,EACA2P,EACAg7B,EACAC,EACEC,EAAK,wDAEPD,EAAYzI,EAAYlhC,EACxBjB,EAAImiC,EAAYwB,IAAIkH,IAKpBF,EAAO,IAAIlW,GAAY,QAAE9kB,EAAG3P,GAAG,EAAO4qC,EAAWr9B,GAC7CwL,EACAA,EAAShY,KAAK4pC,GAEd5xB,EAAW,CAAE4xB,GAEjBh7B,EAAIwyB,EAAY2B,MAAM,KAE1B,OAAO/qB,GAEX9H,KAAM,SAAU65B,GACZ,IAKI1B,EACA2B,EACA5vB,EACA6vB,EACAr8B,EACAgiB,EACAwB,EAXEoW,EAAW1B,EAAQ0B,SACnB7U,EAAW,CAAEziB,KAAK,KAAMif,UAAU,GACpC+a,EAAc,GACZ3B,EAAgB,GAChBD,EAAY,GAQd6B,GAAS,EAIb,IAFA/I,EAAYe,SAEC,CACT,GAAI4H,EACAna,EAAMkW,EAAQlX,mBAAqBkX,EAAQ5Y,iBACxC,CAEH,GADAkU,EAAYa,aAAa3jC,OAAS,EAC9B8iC,EAAY4B,KAAK,OAAQ,CACzBrQ,EAASxD,UAAW,EAChBiS,EAAY2B,MAAM,OAASsF,IAC3BA,GAAuB,IAE1BA,EAAuBE,EAAgBD,GACnCtoC,KAAK,CAAEmvB,UAAU,IACtB,MAEJS,EAAM4X,EAAShtB,YAAcgtB,EAAS3lB,YAAc2lB,EAASiB,WAAajB,EAASt2B,WAAa1R,KAAKwT,MAAK,GAG9G,IAAK4c,IAAQua,EACT,MAGJF,EAAW,KACPra,EAAI7G,mBACJ6G,EAAI7G,oBAERnb,EAAQgiB,EACR,IAAIvE,EAAM,KAWV,GATI0e,EAEIna,EAAIhiB,OAA6B,GAApBgiB,EAAIhiB,MAAMtP,SACvB+sB,EAAMuE,EAAIhiB,MAAM,IAGpByd,EAAMuE,EAGNvE,IAAQA,aAAeqI,GAAK9J,UAAYyB,aAAeqI,GAAK1J,UAC5D,GAAIoX,EAAY2B,MAAM,KAAM,CAUxB,GATImH,EAAY5rC,OAAS,IACjB+pC,GACA/oC,EAAM,yCAEV0qC,GAA0B,KAG9Bp8B,EAAQk4B,EAAQlX,mBAAqBkX,EAAQ5Y,cAEjC,CACR,IAAI6c,EAKA,OAFA3I,EAAYgB,UACZzP,EAASziB,KAAO,GACTyiB,EAJPrzB,EAAM,iDAOd2qC,EAAY7vB,EAAOiR,EAAIjR,UACpB,GAAIgnB,EAAY4B,KAAK,OAAQ,CAChC,IAAK+G,EAAQ,CACTpX,EAASxD,UAAW,EAChBiS,EAAY2B,MAAM,OAASsF,IAC3BA,GAAuB,IAE1BA,EAAuBE,EAAgBD,GACnCtoC,KAAK,CAAEoa,KAAMwV,EAAIxV,KAAM+U,UAAU,IACtC,MAEAiC,GAAS,OAEL2Y,IACR3vB,EAAO6vB,EAAW5e,EAAIjR,KACtBxM,EAAQ,MAIZA,GACAs8B,EAAYlqC,KAAK4N,GAGrB06B,EAAUtoC,KAAK,CAAEoa,KAAK6vB,EAAUr8B,QAAOwjB,WAEnCgQ,EAAY2B,MAAM,KAClBoH,GAAS,IAGbA,EAAoC,MAA3B/I,EAAY2B,MAAM,OAEbsF,KAEN2B,GACA1qC,EAAM,yCAGV+oC,GAAuB,EAEnB6B,EAAY5rC,OAAS,IACrBsP,EAAQ,IAAI8lB,GAAU,MAAEwW,IAE5B3B,EAAcvoC,KAAK,CAAEoa,OAAMxM,QAAOwjB,WAElChX,EAAO,KACP8vB,EAAc,GACdF,GAA0B,GAMlC,OAFA5I,EAAYmB,SACZ5P,EAASziB,KAAOm4B,EAAuBE,EAAgBD,EAChD3V,GAqBX0U,WAAY,WACR,IAAIjtB,EAEA1L,EACAmR,EACAuqB,EAHAlb,EAAS,GAITC,GAAW,EACf,KAAmC,MAA9BiS,EAAY+C,eAAuD,MAA9B/C,EAAY+C,eAClD/C,EAAY6C,KAAK,aAOrB,GAHA7C,EAAYe,OAEZzzB,EAAQ0yB,EAAYwB,IAAI,gEACb,CACPxoB,EAAO1L,EAAM,GAEb,IAAM27B,EAAU7qC,KAAK0Q,MAAK,GAS1B,GARAgf,EAASmb,EAAQn6B,KACjBif,EAAWkb,EAAQlb,UAOdiS,EAAY2B,MAAM,KAEnB,YADA3B,EAAYgB,QAAQ,uBAYxB,GARAhB,EAAYa,aAAa3jC,OAAS,EAE9B8iC,EAAY4B,KAAK,UACjBoH,EAAOpE,EAAOF,EAAQwE,WAAY,uBAGtCzqB,EAAUimB,EAAQyE,QAId,OADAnJ,EAAYmB,SACL,IAAI7O,GAAKnD,MAAgB,WAAEnW,EAAM8U,EAAQrP,EAASuqB,EAAMjb,GAE/DiS,EAAYgB,eAGhBhB,EAAYgB,WAIpBoH,YAAa,WACT,IAAI9pB,EAEEqP,EAAU,GAEhB,GAAkC,MAA9BqS,EAAY+C,cAAhB,CAIA,OAAa,CAIT,GAHA/C,EAAYe,SAEZziB,EAAOlgB,KAAKgrC,gBACU,KAAT9qB,EAAa,CACtB0hB,EAAYgB,UACZ,MAEJrT,EAAQ/uB,KAAK0f,GACb0hB,EAAYmB,SAEhB,OAAIxT,EAAQzwB,OAAS,EACVywB,OADX,IAKJyb,YAAa,WAGT,GAFApJ,EAAYe,OAEPf,EAAY2B,MAAM,KAAvB,CAKA,IAAM3oB,EAAOgnB,EAAYwB,IAAI,gCAE7B,GAAKxB,EAAY2B,MAAM,KAKvB,OAAI3oB,GAAiB,KAATA,GACRgnB,EAAYmB,SACLnoB,QAGXgnB,EAAYgB,UATRhB,EAAYgB,eAPZhB,EAAYgB,YAuBxBwG,OAAQ,WACJ,IAAMpB,EAAWhoC,KAAKgoC,SAEtB,OAAOhoC,KAAKqgC,WAAa2H,EAASiB,WAAajB,EAAShtB,YAAcgtB,EAASxV,OAC3EwV,EAAS3lB,YAAc2lB,EAASx0B,QAAUw0B,EAASt2B,WAAa1R,KAAK+wB,MAAMvd,MAAK,IAChFw0B,EAAS2B,cAQjBzD,IAAK,WACD,OAAOtE,EAAY2B,MAAM,MAAQ3B,EAAY6C,KAAK,MAQtDgE,QAAS,WACL,IAAIr6B,EAGJ,GAAKwzB,EAAYwB,IAAI,cAOrB,OANAh1B,EAAQwzB,EAAYwB,IAAI,WAGpBh1B,EAAQ,MADRA,EAAQo4B,EAAOF,EAAQ0B,SAAShtB,SAAU,0BACvBJ,KAAK/I,MAAM,QAElC40B,EAAW,KACJ,IAAIvS,GAAKlJ,OAAO,GAAI,iBAAiB5c,QAehDgW,QAAS,WACL,IAAI3kB,EACA2P,EACAK,EACEzB,EAAQ4zB,EAAYlhC,EAwB1B,GAtBA0O,EAAIpP,KAAKwS,cAET/S,EAAImiC,EAAYwB,IAAI,uBAChBxB,EAAYwB,IAAI,+EAChBxB,EAAY2B,MAAM,MAAQ3B,EAAY2B,MAAM,MAAQvjC,KAAKirC,aACzDrJ,EAAYwB,IAAI,kBAAqBxB,EAAYwB,IAAI,iBACrDpjC,KAAKgoC,SAASsB,mBAGd1H,EAAYe,OACRf,EAAY2B,MAAM,MACb9zB,EAAIzP,KAAK6f,UAAS,KAAW+hB,EAAY2B,MAAM,MAChD9jC,EAAI,IAAIy0B,GAAU,MAAEzkB,GACpBmyB,EAAYmB,UAEZnB,EAAYgB,QAAQ,uBAGxBhB,EAAYmB,UAIhBtjC,EAAK,OAAO,IAAIy0B,GAAY,QAAE9kB,EAAG3P,EAAGA,aAAay0B,GAAK9J,SAAUpc,EAAOhB,IAY/EwF,WAAY,WACR,IAAIpD,EAAIwyB,EAAY+C,cAEpB,GAAU,MAANv1B,EAAW,CACXwyB,EAAYe,OACZ,IAAMuI,EAAoBtJ,EAAYwB,IAAI,gBAC1C,GAAI8H,EAEA,OADAtJ,EAAYmB,SACL,IAAI7O,GAAe,WAAEgX,GAEhCtJ,EAAYgB,UAGhB,GAAU,MAANxzB,GAAmB,MAANA,GAAmB,MAANA,GAAmB,MAANA,GAAmB,MAANA,EAAW,CAM/D,IALAwyB,EAAYlhC,IACF,MAAN0O,GAA2C,MAA9BwyB,EAAY+C,gBACzBv1B,EAAI,KACJwyB,EAAYlhC,KAETkhC,EAAYoB,gBAAkBpB,EAAYlhC,IACjD,OAAO,IAAIwzB,GAAe,WAAE9kB,GACzB,OAAIwyB,EAAYoB,cAAc,GAC1B,IAAI9O,GAAe,WAAE,KAErB,IAAIA,GAAe,WAAE,OAYpCrU,SAAU,SAAUsrB,GAChB,IACI3yB,EACAC,EACArJ,EACA3P,EACAi7B,EACA0Q,EACA1yB,EAPE1K,EAAQ4zB,EAAYlhC,EAS1B,IADAyqC,GAAoB,IAAXA,GACDA,IAAW1yB,EAAazY,KAAK8Z,WAAeqxB,IAAWC,EAAOxJ,EAAY4B,KAAK,WAAc/jC,EAAIO,KAAKokB,cACtGgnB,EACA1yB,EAAY8tB,EAAOxmC,KAAK8qC,WAAY,sBAC7BpyB,EACP5Y,EAAM,qDACC2Y,EAEHiiB,EADAA,EACaA,EAAWx5B,OAAOuX,GAElBA,GAGbiiB,GAAc56B,EAAM,kDACxBsP,EAAIwyB,EAAY+C,cACZnsB,EACAA,EAAShY,KAAKf,GAEd+Y,EAAW,CAAE/Y,GAEjBA,EAAI,MAEE,MAAN2P,GAAmB,MAANA,GAAmB,MAANA,GAAmB,MAANA,GAAmB,MAANA,KAK5D,GAAIoJ,EAAY,OAAO,IAAI0b,GAAa,SAAE1b,EAAUkiB,EAAYhiB,EAAW1K,EAAOhB,GAC9E0tB,GAAc56B,EAAM,2EAE5Buf,UAAW,WAGP,IAFA,IAAI1T,EACA0T,GAEA1T,EAAI3L,KAAK6f,cAILR,EACAA,EAAU7e,KAAKmL,GAEf0T,EAAY,CAAE1T,GAElBi2B,EAAYa,aAAa3jC,OAAS,EAC9B6M,EAAE+M,WAAa2G,EAAUvgB,OAAS,GAClCgB,EAAM,2DAEL8hC,EAAY2B,MAAM,OACnB53B,EAAE+M,WACF5Y,EAAM,2DAEV8hC,EAAYa,aAAa3jC,OAAS,EAEtC,OAAOugB,GAEX4rB,UAAW,WACP,GAAKrJ,EAAY2B,MAAM,KAAvB,CAEA,IACI5xB,EACAka,EACAtd,EAHEy5B,EAAWhoC,KAAKgoC,SAgBtB,OAXMr2B,EAAMq2B,EAASsB,mBACjB33B,EAAM60B,EAAO,oDAGjBj4B,EAAKqzB,EAAYwB,IAAI,iBAEjBvX,EAAMmc,EAASI,UAAYxG,EAAYwB,IAAI,aAAexB,EAAYwB,IAAI,YAAc4E,EAASsB,iBAGrG7C,EAAW,KAEJ,IAAIvS,GAAc,UAAEviB,EAAKpD,EAAIsd,KAOxCkf,MAAO,WACH,IAAI9f,EACJ,GAAI2W,EAAY2B,MAAM,OAAStY,EAAUjrB,KAAKynC,YAAc7F,EAAY2B,MAAM,KAC1E,OAAOtY,GAIfogB,aAAc,WACV,IAAIN,EAAQ/qC,KAAK+qC,QAKjB,OAHIA,IACAA,EAAQ,IAAI7W,GAAK9U,QAAQ,KAAM2rB,IAE5BA,GAGX3b,gBAAiB,WACb,IAAIyb,EACAnb,EACAC,EAGJ,GADAiS,EAAYe,QACRf,EAAYwB,IAAI,aAQhB1T,GADAmb,EAAU7qC,KAAK+wB,MAAMrgB,MAAK,IACTA,KACjBif,EAAWkb,EAAQlb,SACdiS,EAAY2B,MAAM,MAV3B,CAeA,IAAM8H,EAAerrC,KAAKqrC,eAC1B,GAAIA,EAEA,OADAzJ,EAAYmB,SACRrT,EACO,IAAIwE,GAAKnD,MAAMtB,WAAW,KAAMC,EAAQ2b,EAAc,KAAM1b,GAEhE,IAAIuE,GAAK1N,gBAAgB6kB,GAEpCzJ,EAAYgB,eAZJhB,EAAYgB,WAkBxBviB,QAAS,WACL,IAAIhB,EACAC,EACAzD,EAUJ,GARA+lB,EAAYe,OAERh1B,EAAQiO,kBACRC,EAAYS,EAAaslB,EAAYlhC,KAGzC2e,EAAYrf,KAAKqf,eAECC,EAAQtf,KAAK+qC,SAAU,CACrCnJ,EAAYmB,SACZ,IAAM1iB,EAAU,IAAI6T,GAAY,QAAE7U,EAAWC,EAAO3R,EAAQ4R,eAI5D,OAHI5R,EAAQiO,kBACRyE,EAAQxE,UAAYA,GAEjBwE,EAEPuhB,EAAYgB,WAGpBkF,YAAa,WACT,IAAIltB,EACAxM,EAEAk9B,EAEAzwB,EACAC,EACArI,EALEzE,EAAQ4zB,EAAYlhC,EAEpB0O,EAAIwyB,EAAY+C,cAKtB,GAAU,MAANv1B,GAAmB,MAANA,GAAmB,MAANA,GAAmB,MAANA,EAK3C,GAHAwyB,EAAYe,OAEZ/nB,EAAO5a,KAAKgb,YAAchb,KAAKurC,eACrB,CAWN,IAVA94B,EAA6B,iBAATmI,KAGhBxM,EAAQpO,KAAKovB,qBAETkc,GAAQ,GAIhB1J,EAAYa,aAAa3jC,OAAS,GAC7BsP,EAAO,CAeR,GAXA0M,GAASrI,GAAcmI,EAAK9b,OAAS,GAAK8b,EAAKY,MAAMpN,MAIjDA,EADAwM,EAAK,GAAGxM,OAAuC,OAA9BwM,EAAK,GAAGxM,MAAMyD,MAAM,EAAG,GAChC7R,KAAKwrC,kBAKLxrC,KAAKyrC,iBAKb,OAFA7J,EAAYmB,SAEL,IAAI7O,GAAgB,YAAEtZ,EAAMxM,GAAO,EAAO0M,EAAO9M,EAAOhB,GAG9DoB,IACDA,EAAQpO,KAAKoO,SAGbA,EACAyM,EAAY7a,KAAK6a,YACVpI,IAEPrE,EAAQpO,KAAKwrC,mBAIrB,GAAIp9B,IAAUpO,KAAKkmC,OAASoF,GAExB,OADA1J,EAAYmB,SACL,IAAI7O,GAAgB,YAAEtZ,EAAMxM,EAAOyM,EAAWC,EAAO9M,EAAOhB,GAGnE40B,EAAYgB,eAGhBhB,EAAYgB,WAGpB6I,eAAgB,WACZ,IAAMz9B,EAAQ4zB,EAAYlhC,EACpBwO,EAAQ0yB,EAAYwB,IAAI,6BAC9B,GAAIl0B,EACA,OAAO,IAAIglB,GAAc,UAAEhlB,EAAM,GAAIlB,IAY7Cw9B,gBAAiB,SAAUE,GACvB,IAAIhrC,EACAjB,EACAksC,EACAv9B,EACEi1B,EAAMqI,GAAe,IACrB19B,EAAQ4zB,EAAYlhC,EACpBkW,EAAS,GAEf,SAASg1B,IACL,IAAMrH,EAAO3C,EAAY+C,cACzB,MAAmB,iBAARtB,EACAkB,IAASlB,EAETA,EAAIlnB,KAAKooB,GAGxB,IAAIqH,IAAJ,CAGAx9B,EAAQ,GACR,KACI3O,EAAIO,KAAKqgC,aAKT5gC,EAAIO,KAAKopC,YAHLh7B,EAAM5N,KAAKf,SAOVA,GAIT,GAFAksC,EAAOC,IAEHx9B,EAAMtP,OAAS,EAAG,CAElB,GADAsP,EAAQ,IAAI8lB,GAAe,WAAE9lB,GACzBu9B,EACA,OAAOv9B,EAGPwI,EAAOpW,KAAK4N,GAGe,MAA3BwzB,EAAYgD,YACZhuB,EAAOpW,KAAK,IAAI0zB,GAAK9Z,UAAU,IAAKpM,IAO5C,GAJA4zB,EAAYe,OAEZv0B,EAAQwzB,EAAYiC,YAAYR,GAErB,CAIP,GAHqB,iBAAVj1B,GACPtO,EAAM,aAAasO,MAAU,SAEZ,IAAjBA,EAAMtP,QAA6B,MAAbsP,EAAM,GAE5B,OADAwzB,EAAYmB,SACL,IAAI7O,GAAK9Z,UAAU,GAAIpM,GAElC,IAAI2b,SACJ,IAAKjpB,EAAI,EAAGA,EAAI0N,EAAMtP,OAAQ4B,IAE1B,GADAipB,EAAOvb,EAAM1N,GACT4M,MAAMC,QAAQoc,GAEd/S,EAAOpW,KAAK,IAAI0zB,GAAKlJ,OAAOrB,EAAK,GAAIA,EAAK,IAAI,EAAM3b,EAAOhB,QAE1D,CACGtM,IAAM0N,EAAMtP,OAAS,IACrB6qB,EAAOA,EAAKtX,QAGhB,IAAM8Y,EAAQ,IAAI+I,GAAKlJ,OAAO,IAAMrB,GAAM,EAAM3b,EAAOhB,GACvDme,EAAMC,cAAgB,aACtBD,EAAME,UAAY,cAClBzU,EAAOpW,KAAK2qB,GAIpB,OADAyW,EAAYmB,SACL,IAAI7O,GAAKjL,WAAWrS,GAAQ,GAEvCgrB,EAAYgB,YAahBiJ,OAAU,WACN,IAAI1uB,EACA8O,EACEje,EAAQ4zB,EAAYlhC,EAEpBorC,EAAMlK,EAAYwB,IAAI,gBAE5B,GAAI0I,EAAK,CACL,IAAMzuC,GAAWyuC,EAAM9rC,KAAK+rC,gBAAkB,OAAS,GAEvD,GAAK5uB,EAAOnd,KAAKgoC,SAASI,UAAYpoC,KAAKgoC,SAASxV,MAQhD,OAPAvG,EAAWjsB,KAAKgsC,gBAEXpK,EAAY2B,MAAM,OACnB3B,EAAYlhC,EAAIsN,EAChBlO,EAAM,gEAEVmsB,EAAWA,GAAY,IAAIiI,GAAU,MAAEjI,GAChC,IAAIiI,GAAW,OAAE/W,EAAM8O,EAAU5uB,EAAS2Q,EAAOhB,GAGxD40B,EAAYlhC,EAAIsN,EAChBlO,EAAM,gCAKlBisC,cAAe,WACX,IAAIE,EAEAC,EACA99B,EAFE/Q,EAAU,GAKhB,IAAKukC,EAAY2B,MAAM,KAAQ,OAAO,KACtC,GAEI,GADA0I,EAAIjsC,KAAKmsC,eACF,CAGH,OADA/9B,GAAQ,EADR89B,EAAaD,GAGT,IAAK,MACDC,EAAa,OACb99B,GAAQ,EACR,MACJ,IAAK,OACD89B,EAAa,WACb99B,GAAQ,EAIhB,GADA/Q,EAAQ6uC,GAAc99B,GACjBwzB,EAAY2B,MAAM,KAAQ,aAE9B0I,GAET,OADAxF,EAAW,KACJppC,GAGX8uC,aAAc,WACV,IAAM5uC,EAAMqkC,EAAYwB,IAAI,uDAC5B,GAAI7lC,EACA,OAAOA,EAAI,IAInB6uC,aAAc,WACV,IAEI3sC,EACAswB,EAHEiY,EAAWhoC,KAAKgoC,SAChB76B,EAAQ,GAGdy0B,EAAYe,OACZ,IACIljC,EAAIuoC,EAASt2B,WAAas2B,EAAShtB,YAAcgtB,EAASG,eAEtDh7B,EAAM3M,KAAKf,GACJmiC,EAAY2B,MAAM,OACzBxT,EAAI/vB,KAAKqiB,WACT5iB,EAAIO,KAAKoO,QACLwzB,EAAY2B,MAAM,KACdxT,GAAKtwB,EACL0N,EAAM3M,KAAK,IAAI0zB,GAAU,MAAE,IAAIA,GAAgB,YAAEnE,EAAGtwB,EAAG,KAAM,KAAMmiC,EAAYlhC,EAAGsM,GAAU,KACrFvN,EACP0N,EAAM3M,KAAK,IAAI0zB,GAAU,MAAEz0B,IAE3BK,EAAM,yCAGVA,EAAM,sBAAyB,gBAGlCL,GAGT,GADAmiC,EAAYmB,SACR51B,EAAMrO,OAAS,EACf,OAAO,IAAIo1B,GAAe,WAAE/mB,IAIpC6+B,cAAe,WACX,IAEIvsC,EAFEuoC,EAAWhoC,KAAKgoC,SAChB/b,EAAW,GAEjB,GAEI,GADAxsB,EAAIO,KAAKosC,gBAGL,GADAngB,EAASzrB,KAAKf,IACTmiC,EAAY2B,MAAM,KAAQ,WAG/B,IADA9jC,EAAIuoC,EAAShtB,YAAcgtB,EAASG,iBAEhClc,EAASzrB,KAAKf,IACTmiC,EAAY2B,MAAM,MAAQ,YAGlC9jC,GAET,OAAOwsB,EAASntB,OAAS,EAAImtB,EAAW,MAG5CxtB,MAAO,WACH,IAAIwtB,EACA3M,EACA7gB,EACAod,EACE7N,EAAQ4zB,EAAYlhC,EAQ1B,GANIiN,EAAQiO,kBACRC,EAAYS,EAAatO,IAG7B4zB,EAAYe,OAERf,EAAY4B,KAAK,UAgBjB,OAfAvX,EAAWjsB,KAAKgsC,iBAEhB1sB,EAAQtf,KAAK+qC,UAGTjrC,EAAM,iEAGV8hC,EAAYmB,SAEZtkC,EAAQ,IAAIy1B,GAAU,MAAE5U,EAAO2M,EAAUje,EAAOhB,GAC5CW,EAAQiO,kBACRnd,EAAMod,UAAYA,GAGfpd,EAGXmjC,EAAYgB,WAShBrO,OAAQ,WACJ,IAAIpX,EACAzM,EACArT,EACE2Q,EAAQ4zB,EAAYlhC,EAG1B,GAFckhC,EAAYwB,IAAI,gBAErB,CAaL,GATI/lC,GAHJqT,EAAO1Q,KAAKqsC,cAGE,CACNA,WAAY37B,EACZkc,UAAU,GAIJ,CAAEA,UAAU,GAGrBzP,EAAOnd,KAAKgoC,SAASI,UAAYpoC,KAAKgoC,SAASxV,MAMhD,OAJKoP,EAAY2B,MAAM,OACnB3B,EAAYlhC,EAAIsN,EAChBlO,EAAM,kCAEH,IAAIo0B,GAAW,OAAE/W,EAAM,KAAM9f,EAAS2Q,EAAOhB,GAGpD40B,EAAYlhC,EAAIsN,EAChBlO,EAAM,iCAKlBusC,WAAY,WAGR,GADAzK,EAAYe,QACPf,EAAY2B,MAAM,KAEnB,OADA3B,EAAYgB,UACL,KAEX,IAAMlyB,EAAOkxB,EAAYwB,IAAI,sBAC7B,OAAI1yB,EAAK,IACLkxB,EAAYmB,SACLryB,EAAK,GAAG2B,SAGfuvB,EAAYgB,UACL,OASfqF,OAAQ,WACJ,IACIrtB,EACAxM,EACAkR,EACAgtB,EACAC,EACAC,EACAC,EAPEz+B,EAAQ4zB,EAAYlhC,EAQtBgsC,GAAW,EACXxmB,GAAW,EAEf,GAAkC,MAA9B0b,EAAY+C,cAAhB,CAGA,GADAv2B,EAAQpO,KAAa,UAAOA,KAAKu0B,UAAYv0B,KAAKvB,QAE9C,OAAO2P,EAOX,GAJAwzB,EAAYe,OAEZ/nB,EAAOgnB,EAAYwB,IAAI,aAEvB,CAOA,OALAkJ,EAAwB1xB,EACF,KAAlBA,EAAK3H,OAAO,IAAa2H,EAAKhK,QAAQ,IAAK,GAAK,IAChD07B,EAAwB,IAAI1xB,EAAK/I,MAAM+I,EAAKhK,QAAQ,IAAK,GAAK,IAG1D07B,GACJ,IAAK,WACDC,GAAgB,EAChBG,GAAW,EACX,MACJ,IAAK,aACDF,GAAgB,EAChBE,GAAW,EACX,MACJ,IAAK,aACL,IAAK,iBACDH,GAAgB,EAChB,MACJ,IAAK,YACL,IAAK,YACDE,GAAa,EACbvmB,GAAW,EACX,MACJ,QACIumB,GAAa,EAiCrB,GA7BA7K,EAAYa,aAAa3jC,OAAS,EAE9BytC,GACAn+B,EAAQpO,KAAKopC,WAETtpC,EAAM,YAAY8a,iBAEf4xB,GACPp+B,EAAQpO,KAAK0tB,eAET5tB,EAAM,YAAY8a,iBAEf6xB,IACPr+B,EAAQpO,KAAKwrC,gBAAgB,SAC7BkB,EAA0C,MAA9B9K,EAAY+C,cACnBv2B,EAKKA,EAAMA,QACZA,EAAQ,MALHs+B,GAA0C,MAA9B9K,EAAY+C,eACzB7kC,EAAS8a,kDAQjB8xB,IACAptB,EAAQtf,KAAKqrC,gBAGb/rB,IAAWotB,GAAYt+B,GAASwzB,EAAY2B,MAAM,KAElD,OADA3B,EAAYmB,SACL,IAAI7O,GAAW,OAAEtZ,EAAMxM,EAAOkR,EAAOtR,EAAOhB,EAC/CW,EAAQiO,gBAAkBU,EAAatO,GAAS,KAChDkY,GAIR0b,EAAYgB,QAAQ,qCAWxBx0B,MAAO,WACH,IAAI3O,EACEirC,EAAc,GACd18B,EAAQ4zB,EAAYlhC,EAE1B,GAEI,IADAjB,EAAIO,KAAK0tB,gBAELgd,EAAYlqC,KAAKf,IACZmiC,EAAY2B,MAAM,MAAQ,YAE9B9jC,GAET,GAAIirC,EAAY5rC,OAAS,EACrB,OAAO,IAAIo1B,GAAU,MAAEwW,EAAa18B,IAG5C6M,UAAW,WACP,GAAkC,MAA9B+mB,EAAY+C,cACZ,OAAO/C,EAAYwB,IAAI,kBAG/BuJ,IAAK,WACD,IAAIn+B,EACA/O,EAGJ,GADAmiC,EAAYe,OACRf,EAAY2B,MAAM,KAElB,OADA/0B,EAAIxO,KAAK4sC,aACAhL,EAAY2B,MAAM,MACvB3B,EAAYmB,UACZtjC,EAAI,IAAIy0B,GAAe,WAAE,CAAC1lB,KACxB4a,QAAS,EACJ3pB,QAEXmiC,EAAYgB,QAAQ,gBAGxBhB,EAAYgB,WAEhBiK,eAAgB,WACZ,IAAI1hC,EACAqD,EACAD,EACAu+B,EACA9jB,EAEJ,GADA7d,EAAInL,KAAK+sC,UACF,CAEH,IADA/jB,EAAW4Y,EAAYoB,cAAc,IAE7BpB,EAAY6C,KAAK,aADZ,CAST,GAJA7C,EAAYe,SAEZp0B,EAAKqzB,EAAY2B,MAAM,MAAQ3B,EAAY2B,MAAM,MAAQ3B,EAAY4B,KAAK,OAEjE,CAAE5B,EAAYmB,SAAU,MAIjC,KAFAv0B,EAAIxO,KAAK+sC,WAED,CAAEnL,EAAYgB,UAAW,MACjChB,EAAYmB,SAEZ53B,EAAEme,YAAa,EACf9a,EAAE8a,YAAa,EACfwjB,EAAY,IAAI5Y,GAAc,UAAE3lB,EAAI,CAACu+B,GAAa3hC,EAAGqD,GAAIwa,GACzDA,EAAW4Y,EAAYoB,cAAc,GAEzC,OAAO8J,GAAa3hC,IAG5ByhC,SAAU,WACN,IAAIzhC,EACAqD,EACAD,EACAu+B,EACA9jB,EAEJ,GADA7d,EAAInL,KAAK6sC,iBACF,CAEH,IADA7jB,EAAW4Y,EAAYoB,cAAc,IAEjCz0B,EAAKqzB,EAAYwB,IAAI,cAAiBpa,IAAa4Y,EAAY2B,MAAM,MAAQ3B,EAAY2B,MAAM,SAI/F/0B,EAAIxO,KAAK6sC,mBAKT1hC,EAAEme,YAAa,EACf9a,EAAE8a,YAAa,EACfwjB,EAAY,IAAI5Y,GAAc,UAAE3lB,EAAI,CAACu+B,GAAa3hC,EAAGqD,GAAIwa,GACzDA,EAAW4Y,EAAYoB,cAAc,GAEzC,OAAO8J,GAAa3hC,IAG5B2/B,WAAY,WACR,IAAIt8B,EACAC,EAEAiK,EADE1K,EAAQ4zB,EAAYlhC,EAI1B,GADA8N,EAAIxO,KAAK0Y,WAAU,GACZ,CACH,KACSkpB,EAAY6C,KAAK,qBAAwB7C,EAAY2B,MAAM,OAGhE90B,EAAIzO,KAAK0Y,WAAU,KAInBA,EAAY,IAAIwb,GAAc,UAAE,KAAMxb,GAAalK,EAAGC,EAAGT,GAE7D,OAAO0K,GAAalK,IAG5BkK,UAAW,SAAUs0B,GACjB,IAAIp2B,EACAq2B,EACAC,EAMJ,GADAt2B,EAAS5W,KAAKmtC,aAAaH,GAC3B,CAIA,GADAC,EAPWrL,EAAY4B,KAAK,MAQf,CAET,KADA0J,EAAOltC,KAAK0Y,UAAUs0B,IAIlB,OAFAp2B,EAAS,IAAIsd,GAAc,UAAE+Y,EAASr2B,EAAQs2B,GAKtD,OAAOt2B,IAEXu2B,aAAc,SAAUH,GACpB,IAAIp2B,EACAq2B,EACAC,EAGMtC,EAFJh+B,EAAO5M,KAab,GADA4W,GAVUg0B,EAAOh+B,EAAKwgC,iBAAiBJ,IAAgBpgC,EAAKygC,qBAAqBL,KAC/DA,EAGPpC,EAFIh+B,EAAK0gC,gBAAgBN,GASpC,CAIA,GADAC,EAPWrL,EAAY4B,KAAK,OAQf,CAET,KADA0J,EAAOltC,KAAKmtC,aAAaH,IAIrB,OAFAp2B,EAAS,IAAIsd,GAAc,UAAE+Y,EAASr2B,EAAQs2B,GAKtD,OAAOt2B,IAEXw2B,iBAAkB,SAAUJ,GACxB,GAAIpL,EAAY4B,KAAK,OAAQ,CACzB,IAAM5sB,EAAS5W,KAAKqtC,qBAAqBL,GAIzC,OAHIp2B,IACAA,EAAOuX,QAAUvX,EAAOuX,QAErBvX,IAGfy2B,qBAAsB,SAAUL,GAiB5B,IAAIO,EAEJ,GADA3L,EAAYe,OACPf,EAAY4B,KAAK,KAAtB,CAKA,GADA+J,EAtBA,SAA2CC,GACvC,IAAID,EAGJ,GAFA3L,EAAYe,OACZ4K,EAAOC,EAAG90B,UAAUs0B,GACpB,CAIA,GAAKpL,EAAY2B,MAAM,KAKvB,OADA3B,EAAYmB,SACLwK,EAJH3L,EAAYgB,eAJZhB,EAAYgB,UAiBb6K,CAAkCztC,MAGrC,OADA4hC,EAAYmB,SACLwK,EAIX,GADAA,EAAOvtC,KAAKstC,gBAAgBN,GAC5B,CAIA,GAAKpL,EAAY2B,MAAM,KAKvB,OADA3B,EAAYmB,SACLwK,EAJH3L,EAAYgB,QAAQ,qBAAqBhB,EAAY+C,wBAJrD/C,EAAYgB,eAXZhB,EAAYgB,WAqBpB0K,gBAAiB,SAAUN,GACvB,IAEIx+B,EACAC,EACAW,EACAb,EALEy5B,EAAWhoC,KAAKgoC,SAChBh6B,EAAQ4zB,EAAYlhC,EAM1B,SAASkqC,IACL,OAAO5qC,KAAK4sC,YAAc5E,EAASt2B,WAAas2B,EAASI,UAAYJ,EAASG,cAKlF,GADA35B,GAFAo8B,EAAOA,EAAKvpC,KAAKrB,SAqCb,OAjCI4hC,EAAY2B,MAAM,KAEdh1B,EADAqzB,EAAY2B,MAAM,KACb,KAEA,IAGT3B,EAAY2B,MAAM,KAEdh1B,EADAqzB,EAAY2B,MAAM,KACb,KAEA,IAGT3B,EAAY2B,MAAM,OAEdh1B,EADAqzB,EAAY2B,MAAM,KACb,KACE3B,EAAY2B,MAAM,KACpB,KAEA,KAGTh1B,GACAE,EAAIm8B,KAEAx7B,EAAI,IAAI8kB,GAAc,UAAE3lB,EAAIC,EAAGC,EAAGT,GAAO,GAEzClO,EAAM,uBAGVsP,EAAI,IAAI8kB,GAAc,UAAE,IAAK1lB,EAAG,IAAI0lB,GAAY,QAAE,QAASlmB,GAAO,GAE/DoB,GAQf29B,QAAS,WACL,IACI5e,EADE6Z,EAAWhoC,KAAKgoC,SAGlBpG,EAAY6C,KAAK,eACjBtW,EAASyT,EAAY2B,MAAM,MAG/B,IAAI0I,EAAIjsC,KAAK2sC,OAAS3E,EAASkB,aACvBlB,EAASz3B,SAAWy3B,EAAShtB,YAC7BgtB,EAAS3lB,YAAc2lB,EAASx0B,QAChCw0B,EAASI,QAAO,IAASJ,EAASyB,gBAClCzB,EAASG,cAOjB,OALIha,IACA8d,EAAE3iB,YAAa,EACf2iB,EAAI,IAAI/X,GAAa,SAAE+X,IAGpBA,GAUXve,WAAY,WACR,IACIjuB,EACAiuC,EAFE1F,EAAW,GAGXh6B,EAAQ4zB,EAAYlhC,EAE1B,IACIjB,EAAIO,KAAKqgC,WAEL2H,EAASxnC,KAAKf,KAGlBA,EAAIO,KAAK4sC,YAAc5sC,KAAKopC,oBAEXlV,GAAK9X,UAClB3c,EAAI,MAGJA,IACAuoC,EAASxnC,KAAKf,GAETmiC,EAAY6C,KAAK,cAClBiJ,EAAQ9L,EAAY2B,MAAM,OAEtByE,EAASxnC,KAAK,IAAI0zB,GAAc,UAAEwZ,EAAO1/B,YAIhDvO,GACT,GAAIuoC,EAASlpC,OAAS,EAClB,OAAO,IAAIo1B,GAAe,WAAE8T,IAGpC3lB,SAAU,WACN,IAAMzH,EAAOgnB,EAAYwB,IAAI,8BAC7B,GAAIxoB,EACA,OAAOA,EAAK,IAGpB2wB,aAAc,WACV,IAEI5/B,EACAoI,EAHA6G,EAAO,GACL5M,EAAQ,GAId4zB,EAAYe,OAEZ,IAAMgL,EAAiB/L,EAAYwB,IAAI,yBACvC,GAAIuK,EAGA,OAFA/yB,EAAO,CAAC,IAAIsZ,GAAY,QAAEyZ,EAAe,KACzC/L,EAAYmB,SACLnoB,EAGX,SAAS1L,EAAMo7B,GACX,IAAM5pC,EAAIkhC,EAAYlhC,EAChBqN,EAAQ6zB,EAAYwB,IAAIkH,GAC9B,GAAIv8B,EAEA,OADAC,EAAMxN,KAAKE,GACJka,EAAKpa,KAAKuN,EAAM,IAK/B,IADAmB,EAAM,UAEGA,EAAM,uCAKf,GAAK0L,EAAK9b,OAAS,GAAMoQ,EAAM,sBAAuB,CASlD,IARA0yB,EAAYmB,SAII,KAAZnoB,EAAK,KACLA,EAAKhB,QACL5L,EAAM4L,SAEL7F,EAAI,EAAGA,EAAI6G,EAAK9b,OAAQiV,IACzBpI,EAAIiP,EAAK7G,GACT6G,EAAK7G,GAAsB,MAAhBpI,EAAEsH,OAAO,IAA8B,MAAhBtH,EAAEsH,OAAO,GACvC,IAAIihB,GAAY,QAAEvoB,GACD,MAAhBA,EAAEsH,OAAO,GACN,IAAIihB,GAAa,SAAE,IAAIvoB,EAAEkG,MAAM,GAAI,GAAM7D,EAAM+F,GAAI/G,GACnD,IAAIknB,GAAa,SAAE,IAAIvoB,EAAEkG,MAAM,GAAI,GAAM7D,EAAM+F,GAAI/G,GAE/D,OAAO4N,EAEXgnB,EAAYgB,cCp1E5B,SAASgL,GAAGjgC,EAAS+K,EAAWm1B,EAAWC,GACvC,OAAOp1B,EAAU3G,KAAKpE,GAAWkgC,EAAU97B,KAAKpE,GACzCmgC,EAAaA,EAAW/7B,KAAKpE,GAAW,IAAIyM,EAIvD,SAAS2zB,GAAUpgC,EAASqN,GACxB,IAEI,OADAA,EAASjJ,KAAKpE,GACPsM,EAAQC,KACjB,MAAOza,GACL,OAAOwa,EAAQE,OD80EvBksB,GAAOc,cAAgB,SAAAplB,GACnB,IAAIpW,EAAI,GAER,IAAK,IAAMqW,KAAQD,EACf,GAAIlV,OAAOpP,eAAe+V,KAAKuO,EAAMC,GAAO,CACxC,IAAM5T,EAAQ2T,EAAKC,GACnBrW,IAAsB,MAAZqW,EAAK,GAAc,GAAK,KAAOA,OAAS5T,GAAqC,MAA5Bka,OAAOla,GAAOyD,OAAO,GAAc,GAAK,KAI3G,OAAOlG,GC/1EXiiC,GAAGnkB,UAAW,EAWdskB,GAAUtkB,UAAW,MCpBjBukB,MDsBW,CAAED,aAAWrF,QAzB5B,SAAiBhwB,GACb,OAAOA,EAAYuB,EAAQC,KAAOD,EAAQE,OAwBTwuB,GAAMiF,ICpB3C,SAASp+B,GAAMqc,GACX,OAAO9f,KAAK4D,IAAI,EAAG5D,KAAK2D,IAAI,EAAGmc,IAEnC,SAASoiB,GAAKC,EAAWC,GACrB,IAAM59B,EAAQy9B,GAAeC,KAAKE,EAAIr9B,EAAGq9B,EAAIxiC,EAAGwiC,EAAIp9B,EAAGo9B,EAAI3/B,GAC3D,GAAI+B,EAOA,OANI29B,EAAU9/B,OACV,aAAa+N,KAAK+xB,EAAU9/B,OAC5BmC,EAAMnC,MAAQ8/B,EAAU9/B,MAExBmC,EAAMnC,MAAQ,MAEXmC,EAGf,SAASM,GAAMN,GACX,GAAIA,EAAMM,MACN,OAAON,EAAMM,QAEb,MAAM,IAAInR,MAAM,2CAIxB,SAAS4R,GAAMf,GACX,GAAIA,EAAMe,MACN,OAAOf,EAAMe,QAEb,MAAM,IAAI5R,MAAM,2CAIxB,SAAS0uC,GAAO/4B,GACZ,GAAIA,aAAa2S,GACb,OAAOE,WAAW7S,EAAE4S,KAAKhB,GAAG,KAAO5R,EAAEjH,MAAQ,IAAMiH,EAAEjH,OAClD,GAAiB,iBAANiH,EACd,OAAOA,EAEP,KAAM,CACFzU,KAAM,WACNsW,QAAS,qDAWrB82B,GAAiB,CACbh/B,IAAK,SAAUkB,EAAGC,EAAG1B,GACjB,IAAID,EAAI,EAKR,GAAI0B,aAAa+Y,GAAY,CACzB,IAAM4C,EAAM3b,EAAE9B,MAQd,GAPA8B,EAAI2b,EAAI,GACR1b,EAAI0b,EAAI,IACRpd,EAAIod,EAAI,cAKS/C,GAAW,CACxB,IAAMva,EAAKE,EACXA,EAAIF,EAAGwa,SAAS,GAChBva,EAAID,EAAGwa,SAAS,IAGxB,IAAMxY,EAAQy9B,GAAeK,KAAKn+B,EAAGC,EAAG1B,EAAGD,GAC3C,GAAI+B,EAEA,OADAA,EAAMnC,MAAQ,MACPmC,GAGf89B,KAAM,SAAUn+B,EAAGC,EAAG1B,EAAGD,GACrB,IACI,GAAI0B,aAAanB,EAMb,OAJIP,EADA2B,EACIi+B,GAAOj+B,GAEPD,EAAEZ,MAEH,IAAIP,EAAMmB,EAAElB,IAAKR,EAAG,QAE/B,IAAMQ,EAAM,CAACkB,EAAGC,EAAG1B,GAAGU,KAAI,SAAAC,GAAK,OA7CxBk/B,EA6CkC,KA7CrCj5B,EA6CkCjG,aA5C7B4Y,IAAa3S,EAAE4S,KAAKhB,GAAG,KAC7BiB,WAAW7S,EAAEjH,MAAQkgC,EAAO,KAE5BF,GAAO/4B,GAJtB,IAAgBA,EAAGi5B,KA+CP,OADA9/B,EAAI4/B,GAAO5/B,GACJ,IAAIO,EAAMC,EAAKR,EAAG,QAE7B,MAAO/O,MAEX0uC,IAAK,SAAUr9B,EAAGnF,EAAGoF,GACjB,IAAIvC,EAAI,EACR,GAAIsC,aAAamY,GAAY,CACzB,IAAM4C,EAAM/a,EAAE1C,MAKd,GAJA0C,EAAI+a,EAAI,GACRlgB,EAAIkgB,EAAI,IACR9a,EAAI8a,EAAI,cAES/C,GAAW,CACxB,IAAMva,EAAKwC,EACXA,EAAIxC,EAAGwa,SAAS,GAChBva,EAAID,EAAGwa,SAAS,IAGxB,IAAMxY,EAAQy9B,GAAeC,KAAKn9B,EAAGnF,EAAGoF,EAAGvC,GAC3C,GAAI+B,EAEA,OADAA,EAAMnC,MAAQ,MACPmC,GAGf09B,KAAM,SAAUn9B,EAAGnF,EAAGoF,EAAGvC,GACrB,IACI,GAAIsC,aAAa/B,EAMb,OAJIP,EADA7C,EACIyiC,GAAOziC,GAEPmF,EAAExB,MAEH,IAAIP,EAAM+B,EAAE9B,IAAKR,EAAG,QAG/B,IAAI+/B,EACAC,EAEJ,SAASC,EAAI39B,GAET,OAAQ,GADRA,EAAIA,EAAI,EAAIA,EAAI,EAAKA,EAAI,EAAIA,EAAI,EAAIA,GACzB,EACDy9B,GAAMC,EAAKD,GAAMz9B,EAAI,EAEnB,EAAJA,EAAQ,EACN09B,EAEE,EAAJ19B,EAAQ,EACNy9B,GAAMC,EAAKD,IAAO,EAAI,EAAIz9B,GAAK,EAG/By9B,EAIfz9B,EAAKs9B,GAAOt9B,GAAK,IAAO,IACxBnF,EAAI6D,GAAM4+B,GAAOziC,IAAIoF,EAAIvB,GAAM4+B,GAAOr9B,IAAIvC,EAAIgB,GAAM4+B,GAAO5/B,IAG3D+/B,EAAS,EAAJx9B,GADLy9B,EAAKz9B,GAAK,GAAMA,GAAKpF,EAAI,GAAKoF,EAAIpF,EAAIoF,EAAIpF,GAG1C,IAAMqD,EAAM,CACS,IAAjBy/B,EAAI39B,EAAI,EAAI,GACG,IAAf29B,EAAI39B,GACa,IAAjB29B,EAAI39B,EAAI,EAAI,IAGhB,OADAtC,EAAI4/B,GAAO5/B,GACJ,IAAIO,EAAMC,EAAKR,EAAG,QAE7B,MAAO/O,MAGXivC,IAAK,SAAS59B,EAAGnF,EAAG8D,GAChB,OAAOu+B,GAAeW,KAAK79B,EAAGnF,EAAG8D,EAAG,IAGxCk/B,KAAM,SAAS79B,EAAGnF,EAAG8D,EAAGjB,GAIpB,IAAI9N,EACAwwB,EAJJpgB,EAAMs9B,GAAOt9B,GAAK,IAAO,IAAO,IAChCnF,EAAIyiC,GAAOziC,GAAG8D,EAAI2+B,GAAO3+B,GAAGjB,EAAI4/B,GAAO5/B,GAOvC,IAAMogC,EAAK,CAACn/B,EACRA,GAAK,EAAI9D,GACT8D,GAAK,GAJTyhB,EAAKpgB,EAAI,IADTpQ,EAAIqL,KAAK8iC,MAAO/9B,EAAI,GAAM,KAKTnF,GACb8D,GAAK,GAAK,EAAIyhB,GAAKvlB,IACjBmjC,EAAO,CAAC,CAAC,EAAG,EAAG,GACjB,CAAC,EAAG,EAAG,GACP,CAAC,EAAG,EAAG,GACP,CAAC,EAAG,EAAG,GACP,CAAC,EAAG,EAAG,GACP,CAAC,EAAG,EAAG,IAEX,OAAOd,GAAeK,KAAsB,IAAjBO,EAAGE,EAAKpuC,GAAG,IACjB,IAAjBkuC,EAAGE,EAAKpuC,GAAG,IACM,IAAjBkuC,EAAGE,EAAKpuC,GAAG,IACX8N,IAGRigC,IAAK,SAAUl+B,GACX,OAAO,IAAIyX,GAAUnX,GAAMN,GAAOO,IAEtCi+B,WAAY,SAAUx+B,GAClB,OAAO,IAAIyX,GAA2B,IAAjBnX,GAAMN,GAAO5E,EAAS,MAE/CqjC,UAAW,SAAUz+B,GACjB,OAAO,IAAIyX,GAA2B,IAAjBnX,GAAMN,GAAOQ,EAAS,MAE/Ck+B,OAAQ,SAAS1+B,GACb,OAAO,IAAIyX,GAAU1W,GAAMf,GAAOO,IAEtCo+B,cAAe,SAAU3+B,GACrB,OAAO,IAAIyX,GAA2B,IAAjB1W,GAAMf,GAAO5E,EAAS,MAE/CwjC,SAAU,SAAU5+B,GAChB,OAAO,IAAIyX,GAA2B,IAAjB1W,GAAMf,GAAOd,EAAS,MAE/ClG,IAAK,SAAUgH,GACX,OAAO,IAAIyX,GAAUzX,EAAMvB,IAAI,KAEnC1J,MAAO,SAAUiL,GACb,OAAO,IAAIyX,GAAUzX,EAAMvB,IAAI,KAEnCxM,KAAM,SAAU+N,GACZ,OAAO,IAAIyX,GAAUzX,EAAMvB,IAAI,KAEnCM,MAAO,SAAUiB,GACb,OAAO,IAAIyX,GAAUnX,GAAMN,GAAO/B,IAEtCyB,KAAM,SAAUM,GACZ,OAAO,IAAIyX,GAAUzX,EAAMN,OAASM,EAAMjB,MAAQ,IAAK,MAE3D8/B,UAAW,SAAU7+B,GACjB,IAAM6+B,EACD,MAAS7+B,EAAMvB,IAAI,GAAK,IACpB,MAASuB,EAAMvB,IAAI,GAAK,IACxB,MAASuB,EAAMvB,IAAI,GAAK,IAEjC,OAAO,IAAIgZ,GAAUonB,EAAY7+B,EAAMjB,MAAQ,IAAK,MAExD+/B,SAAU,SAAU9+B,EAAO++B,EAAQC,GAG/B,IAAKh/B,EAAMvB,IACP,OAAO,KAEX,IAAMm/B,EAAMt9B,GAAMN,GASlB,YAPsB,IAAXg/B,GAA2C,aAAjBA,EAAOnhC,MACxC+/B,EAAIxiC,GAAMwiC,EAAIxiC,EAAI2jC,EAAOlhC,MAAQ,IAGjC+/B,EAAIxiC,GAAK2jC,EAAOlhC,MAAQ,IAE5B+/B,EAAIxiC,EAAI6D,GAAM2+B,EAAIxiC,GACXsiC,GAAK19B,EAAO49B,IAEvBqB,WAAY,SAAUj/B,EAAO++B,EAAQC,GACjC,IAAMpB,EAAMt9B,GAAMN,GASlB,YAPsB,IAAXg/B,GAA2C,aAAjBA,EAAOnhC,MACxC+/B,EAAIxiC,GAAMwiC,EAAIxiC,EAAI2jC,EAAOlhC,MAAQ,IAGjC+/B,EAAIxiC,GAAK2jC,EAAOlhC,MAAQ,IAE5B+/B,EAAIxiC,EAAI6D,GAAM2+B,EAAIxiC,GACXsiC,GAAK19B,EAAO49B,IAEvBsB,QAAS,SAAUl/B,EAAO++B,EAAQC,GAC9B,IAAMpB,EAAMt9B,GAAMN,GASlB,YAPsB,IAAXg/B,GAA2C,aAAjBA,EAAOnhC,MACxC+/B,EAAIp9B,GAAMo9B,EAAIp9B,EAAIu+B,EAAOlhC,MAAQ,IAGjC+/B,EAAIp9B,GAAKu+B,EAAOlhC,MAAQ,IAE5B+/B,EAAIp9B,EAAIvB,GAAM2+B,EAAIp9B,GACXk9B,GAAK19B,EAAO49B,IAEvBuB,OAAQ,SAAUn/B,EAAO++B,EAAQC,GAC7B,IAAMpB,EAAMt9B,GAAMN,GASlB,YAPsB,IAAXg/B,GAA2C,aAAjBA,EAAOnhC,MACxC+/B,EAAIp9B,GAAMo9B,EAAIp9B,EAAIu+B,EAAOlhC,MAAQ,IAGjC+/B,EAAIp9B,GAAKu+B,EAAOlhC,MAAQ,IAE5B+/B,EAAIp9B,EAAIvB,GAAM2+B,EAAIp9B,GACXk9B,GAAK19B,EAAO49B,IAEvBwB,OAAQ,SAAUp/B,EAAO++B,EAAQC,GAC7B,IAAMpB,EAAMt9B,GAAMN,GASlB,YAPsB,IAAXg/B,GAA2C,aAAjBA,EAAOnhC,MACxC+/B,EAAI3/B,GAAM2/B,EAAI3/B,EAAI8gC,EAAOlhC,MAAQ,IAGjC+/B,EAAI3/B,GAAK8gC,EAAOlhC,MAAQ,IAE5B+/B,EAAI3/B,EAAIgB,GAAM2+B,EAAI3/B,GACXy/B,GAAK19B,EAAO49B,IAEvByB,QAAS,SAAUr/B,EAAO++B,EAAQC,GAC9B,IAAMpB,EAAMt9B,GAAMN,GASlB,YAPsB,IAAXg/B,GAA2C,aAAjBA,EAAOnhC,MACxC+/B,EAAI3/B,GAAM2/B,EAAI3/B,EAAI8gC,EAAOlhC,MAAQ,IAGjC+/B,EAAI3/B,GAAK8gC,EAAOlhC,MAAQ,IAE5B+/B,EAAI3/B,EAAIgB,GAAM2+B,EAAI3/B,GACXy/B,GAAK19B,EAAO49B,IAEvB0B,KAAM,SAAUt/B,EAAO++B,GACnB,IAAMnB,EAAMt9B,GAAMN,GAIlB,OAFA49B,EAAI3/B,EAAI8gC,EAAOlhC,MAAQ,IACvB+/B,EAAI3/B,EAAIgB,GAAM2+B,EAAI3/B,GACXy/B,GAAK19B,EAAO49B,IAEvB2B,KAAM,SAAUv/B,EAAO++B,GACnB,IAAMnB,EAAMt9B,GAAMN,GACZk+B,GAAON,EAAIr9B,EAAIw+B,EAAOlhC,OAAS,IAIrC,OAFA+/B,EAAIr9B,EAAI29B,EAAM,EAAI,IAAMA,EAAMA,EAEvBR,GAAK19B,EAAO49B,IAMvB4B,IAAK,SAAUC,EAAQC,EAAQC,GACtBA,IACDA,EAAS,IAAIloB,GAAU,KAE3B,IAAM+H,EAAImgB,EAAO9hC,MAAQ,IACnB+hC,EAAQ,EAAJpgB,EAAQ,EACZvhB,EAAIqC,GAAMm/B,GAAQxhC,EAAIqC,GAAMo/B,GAAQzhC,EAEpC4hC,IAAQD,EAAI3hC,IAAM,EAAK2hC,GAAKA,EAAI3hC,IAAM,EAAI2hC,EAAI3hC,IAAM,GAAK,EACzD6hC,EAAK,EAAID,EAETphC,EAAM,CAACghC,EAAOhhC,IAAI,GAAKohC,EAAKH,EAAOjhC,IAAI,GAAKqhC,EAC9CL,EAAOhhC,IAAI,GAAKohC,EAAKH,EAAOjhC,IAAI,GAAKqhC,EACrCL,EAAOhhC,IAAI,GAAKohC,EAAKH,EAAOjhC,IAAI,GAAKqhC,GAEnC/gC,EAAQ0gC,EAAO1gC,MAAQygB,EAAIkgB,EAAO3gC,OAAS,EAAIygB,GAErD,OAAO,IAAIhhB,EAAMC,EAAKM,IAE1BghC,UAAW,SAAU//B,GACjB,OAAOy9B,GAAewB,WAAWj/B,EAAO,IAAIyX,GAAU,OAE1DuoB,SAAU,SAAUhgC,EAAOigC,EAAMC,EAAOC,GAGpC,IAAKngC,EAAMvB,IACP,OAAO,KASX,QAPqB,IAAVyhC,IACPA,EAAQzC,GAAeK,KAAK,IAAK,IAAK,IAAK,SAE3B,IAATmC,IACPA,EAAOxC,GAAeK,KAAK,EAAG,EAAG,EAAG,IAGpCmC,EAAKvgC,OAASwgC,EAAMxgC,OAAQ,CAC5B,IAAM0gC,EAAIF,EACVA,EAAQD,EACRA,EAAOG,EAOX,OAJID,OADqB,IAAdA,EACK,IAEAtC,GAAOsC,GAEnBngC,EAAMN,OAASygC,EACRD,EAEAD,GAyCfI,KAAM,SAAUrgC,GACZ,OAAO,IAAI6J,EAAU7J,EAAMgB,WAE/BhB,MAAO,SAASnB,GACZ,GAAKA,aAAa4b,IACb,uDAAuD7O,KAAK/M,EAAEhB,OAAS,CACxE,IAAMyd,EAAMzc,EAAEhB,MAAMyD,MAAM,GAC1B,OAAO,IAAI9C,EAAM8c,OAAKrf,EAAW,IAAIqf,GAEzC,GAAKzc,aAAaL,IAAWK,EAAIL,EAAM0C,YAAYrC,EAAEhB,QAEjD,OADAgB,EAAEhB,WAAQ5B,EACH4C,EAEX,KAAM,CACFxO,KAAS,WACTsW,QAAS,oEAGjB25B,KAAM,SAAStgC,EAAO++B,GAClB,OAAOtB,GAAe+B,IAAI/B,GAAeh/B,IAAI,IAAK,IAAK,KAAMuB,EAAO++B,IAExEwB,MAAO,SAASvgC,EAAO++B,GACnB,OAAOtB,GAAe+B,IAAI/B,GAAeh/B,IAAI,EAAG,EAAG,GAAIuB,EAAO++B,KC1btE,SAASyB,GAAWC,EAAMhB,EAAQC,GAC9B,IAGIgB,EAKAC,EAEAC,EACAC,EAXEC,EAAKrB,EAAO1gC,MAKZgiC,EAAKrB,EAAO3gC,MAOZY,EAAI,GAEVihC,EAAKG,EAAKD,GAAM,EAAIC,GACpB,IAAK,IAAI5wC,EAAI,EAAGA,EAAI,EAAGA,IAGnB0wC,EAAKJ,EAFLC,EAAKjB,EAAOhhC,IAAItO,GAAK,IACrBwwC,EAAKjB,EAAOjhC,IAAItO,GAAK,KAEjBywC,IACAC,GAAME,EAAKJ,EAAKG,GAAMJ,EAChBK,GAAML,EAAKC,EAAKE,KAAQD,GAElCjhC,EAAExP,GAAU,IAAL0wC,EAGX,OAAO,IAAIriC,EAAMmB,EAAGihC,GAGxB,IAAMI,GAA0B,CAC5BC,SAAU,SAASP,EAAIC,GACnB,OAAOD,EAAKC,GAEhBO,OAAQ,SAASR,EAAIC,GACjB,OAAOD,EAAKC,EAAKD,EAAKC,GAE1BQ,QAAS,SAAST,EAAIC,GAElB,OADAD,GAAM,IACQ,EACVM,GAAwBC,SAASP,EAAIC,GACrCK,GAAwBE,OAAOR,EAAK,EAAGC,IAE/CS,UAAW,SAASV,EAAIC,GACpB,IAAI7/B,EAAI,EACJ5R,EAAIwxC,EAMR,OALIC,EAAK,KACLzxC,EAAI,EACJ4R,EAAK4/B,EAAK,IAAQllC,KAAK6lC,KAAKX,KACpB,GAAKA,EAAK,IAAMA,EAAK,GAAKA,GAE/BA,GAAM,EAAI,EAAIC,GAAMzxC,GAAK4R,EAAI4/B,IAExCY,UAAW,SAASZ,EAAIC,GACpB,OAAOK,GAAwBG,QAAQR,EAAID,IAE/Ca,WAAY,SAASb,EAAIC,GACrB,OAAOnlC,KAAKgmC,IAAId,EAAKC,IAEzBc,UAAW,SAASf,EAAIC,GACpB,OAAOD,EAAKC,EAAK,EAAID,EAAKC,GAI9Be,QAAS,SAAShB,EAAIC,GAClB,OAAQD,EAAKC,GAAM,GAEvBgB,SAAU,SAASjB,EAAIC,GACnB,OAAO,EAAInlC,KAAKgmC,IAAId,EAAKC,EAAK,KAItC,IAAK,IAAMhgB,MAAKqgB,GACRA,GAAwB9zC,eAAeyzB,MACvC6f,GAAW7f,IAAK6f,GAAW1vC,KAAK,KAAMkwC,GAAwBrgB,UCpEhEihB,GAAmB,SAAA9kC,GAMrB,OAHcC,MAAMC,QAAQF,EAAKe,OAC7Bf,EAAKe,MAAQd,MAAMD,OAKZ,CACX+kC,MAAO,SAAS/8B,GACZ,OAAOA,GAEXg9B,IAAK,eAAS,aAAAC,mBAAAA,IAAAC,kBACV,OAAoB,IAAhBA,EAAKzzC,OACEyzC,EAAK,GAET,IAAIv4B,EAAMu4B,IAErBv6B,QAAS,SAASw6B,EAAQxkC,GAItB,OAFAA,EAAQA,EAAMI,MAAQ,EAEf+jC,GAAiBK,GAAQxkC,IAEpClP,OAAQ,SAAS0zC,GACb,OAAO,IAAIxqB,GAAUmqB,GAAiBK,GAAQ1zC,SAUlD2zC,MAAO,SAAS1N,EAAOmB,EAAKwM,GACxB,IAAIC,EACAC,EACAC,EAAY,EACVC,EAAO,GACT5M,GACA0M,EAAK1M,EACLyM,EAAO5N,EAAM32B,MACTskC,IACAG,EAAYH,EAAKtkC,SAIrBukC,EAAO,EACPC,EAAK7N,GAGT,IAAK,IAAIrkC,EAAIiyC,EAAMjyC,GAAKkyC,EAAGxkC,MAAO1N,GAAKmyC,EACnCC,EAAKtyC,KAAK,IAAIwnB,GAAUtnB,EAAGkyC,EAAG3qB,OAGlC,OAAO,IAAIgB,GAAW6pB,IAE1BC,KAAM,SAASD,EAAME,GAAf,IAEEjhB,EACAkhB,SAFE3zB,EAAQ,GAIR4zB,EAAU,SAAArnB,GACZ,OAAIA,aAAe3e,EACR2e,EAAI9Z,KAAK8M,EAAKlR,SAElBke,GAUPonB,GAPAH,EAAK1kC,OAAW0kC,aAAgBK,GAMzBL,EAAKzyB,QACD6yB,EAAQJ,EAAKzyB,SAASf,MAC1BwzB,EAAKxzB,MACDwzB,EAAKxzB,MAAMnQ,IAAI+jC,GACnB5lC,MAAMC,QAAQulC,GACVA,EAAK3jC,IAAI+jC,GAET,CAACA,EAAQJ,IAZhBxlC,MAAMC,QAAQulC,EAAK1kC,OACR0kC,EAAK1kC,MAAMe,IAAI+jC,GAEf,CAACA,EAAQJ,EAAK1kC,QAYjC,IAAIglC,EAAY,SACZC,EAAU,OACVC,EAAY,SAEZN,EAAGtjB,QACH0jB,EAAYJ,EAAGtjB,OAAO,IAAMsjB,EAAGtjB,OAAO,GAAG9U,KACzCy4B,EAAUL,EAAGtjB,OAAO,IAAMsjB,EAAGtjB,OAAO,GAAG9U,KACvC04B,EAAYN,EAAGtjB,OAAO,IAAMsjB,EAAGtjB,OAAO,GAAG9U,KACzCo4B,EAAKA,EAAG1zB,OAER0zB,EAAKA,EAAG3yB,QAGZ,IAAK,IAAI3f,EAAI,EAAGA,EAAIuyC,EAASn0C,OAAQ4B,IAAK,CACtC,IAAIiR,SACAvD,SACEub,EAAOspB,EAASvyC,GAClBipB,aAAgBhP,GAChBhJ,EAA2B,iBAAdgY,EAAK/O,KAAoB+O,EAAK/O,KAAO+O,EAAK/O,KAAK,GAAGxM,MAC/DA,EAAQub,EAAKvb,QAEbuD,EAAM,IAAIqW,GAAUtnB,EAAI,GACxB0N,EAAQub,GAGRA,aAAgBvN,IAIpB2V,EAAWihB,EAAG1zB,MAAMzN,MAAM,GACtBuhC,GACArhB,EAASvxB,KAAK,IAAIma,EAAYy4B,EAC1BhlC,GACA,GAAO,EAAOpO,KAAKgO,MAAOhO,KAAK0S,kBAEnC4gC,GACAvhB,EAASvxB,KAAK,IAAIma,EAAY24B,EAC1B,IAAItrB,GAAUtnB,EAAI,IAClB,GAAO,EAAOV,KAAKgO,MAAOhO,KAAK0S,kBAEnC2gC,GACAthB,EAASvxB,KAAK,IAAIma,EAAY04B,EAC1B1hC,GACA,GAAO,EAAO3R,KAAKgO,MAAOhO,KAAK0S,kBAGvC4M,EAAM9e,KAAK,IAAI4e,EAAQ,CAAE,MAAc,CAAE,IAAI7M,EAAQ,GAAI,QACrDwf,EACAihB,EAAGzzB,cACHyzB,EAAGrgC,oBAIX,OAAO,IAAIyM,EAAQ,CAAE,MAAc,CAAE,IAAI7M,EAAQ,GAAI,QACjD+M,EACA0zB,EAAGzzB,cACHyzB,EAAGrgC,kBACLZ,KAAK/R,KAAK2N,WCzJd4lC,GAAa,SAACC,EAAIvrB,EAAM5S,GAC1B,KAAMA,aAAa2S,IACf,KAAM,CAAEpnB,KAAM,WAAYsW,QAAS,6BAOvC,OALY,MAAR+Q,EACAA,EAAO5S,EAAE4S,KAET5S,EAAIA,EAAEmT,QAEH,IAAIR,GAAUwrB,EAAGtrB,WAAW7S,EAAEjH,QAAS6Z,ICT5CwrB,GAAgB,CAElBC,KAAO,KACP7E,MAAO,KACP+C,KAAO,KACPG,IAAO,KACPvnC,IAAO,GACPmpC,IAAO,GACPC,IAAO,GACPC,KAAO,MACPC,KAAO,MACPC,KAAO,OAGX,IAAK,IAAM7iB,MAAKuiB,GACRA,GAAch2C,eAAeyzB,MAC7BuiB,GAAcviB,IAAK8iB,GAAW3yC,KAAK,KAAM0K,KAAKmlB,IAAIuiB,GAAcviB,MAIxEuiB,GAAc5jC,MAAQ,SAACwF,EAAG6b,GACtB,IAAM+iB,OAAwB,IAAN/iB,EAAoB,EAAIA,EAAE9iB,MAClD,OAAO4lC,IAAW,SAAAE,GAAO,OAAAA,EAAIrlC,QAAQolC,KAAW,KAAM5+B,ICpB1D,IAAM8+B,GAAS,SAAUC,EAAO1jC,GAE5B,QADAA,EAAOpD,MAAMyC,UAAU8B,MAAM2B,KAAK9C,IACrB5R,QACT,KAAK,EAAG,KAAM,CAAE8B,KAAM,WAAYsW,QAAS,kCAE/C,IAAIxW,EACAsT,EACAytB,EACA4S,EACAC,EACArsB,EACAssB,EACAC,EAGAC,EAAS,GAEPjC,EAAS,GAEf,IAAK9xC,EAAI,EAAGA,EAAIgQ,EAAK5R,OAAQ4B,IAEzB,IADA+gC,EAAU/wB,EAAKhQ,cACUsnB,GAWzB,GAHAusB,EAAsB,MADtBtsB,EAA0C,MAD1CosB,EAA6C,KAA5B5S,EAAQxZ,KAAKnY,iBAAmCtD,IAAdgoC,EAA0B,IAAIxsB,GAAUyZ,EAAQrzB,MAAOomC,GAAWhsB,QAAUiZ,EAAQjZ,SACjHP,KAAKnY,iBAAoCtD,IAAf+nC,EAA2BA,EAAaF,EAAepsB,KAAKnY,kBACjEtD,IAAf+nC,GAAqC,KAATtsB,GAAoD,KAArCwsB,EAAM,GAAGjsB,QAAQP,KAAKnY,WAAoBmY,EAAOssB,EACxHC,EAAqB,KAATvsB,QAA6Bzb,IAAdgoC,EAA0B/S,EAAQxZ,KAAKnY,WAAa0kC,OAErEhoC,KADVwH,OAAmBxH,IAAfgmC,EAAO,KAA8B,KAATvqB,GAAeA,IAASssB,EAAa/B,EAAO,IAAMA,EAAOvqB,IASzFqsB,EAAgD,KAA7BG,EAAMzgC,GAAGiU,KAAKnY,iBAAmCtD,IAAdgoC,EAA0B,IAAIxsB,GAAUysB,EAAMzgC,GAAG5F,MAAOomC,GAAWhsB,QAAUisB,EAAMzgC,GAAGwU,SACvI4rB,GAASC,EAAejmC,MAAQkmC,EAAiBlmC,QACjDgmC,GAASC,EAAejmC,MAAQkmC,EAAiBlmC,SAClDqmC,EAAMzgC,GAAKytB,OAXf,CACI,QAAmBj1B,IAAf+nC,GAA4BtsB,IAASssB,EACrC,KAAM,CAAE3zC,KAAM,WAAYsW,QAAS,sBAEvCs7B,EAAOvqB,GAAQwsB,EAAM31C,OACrB21C,EAAMj0C,KAAKihC,QAfPn0B,MAAMC,QAAQmD,EAAKhQ,GAAG0N,QACtBd,MAAMyC,UAAUvP,KAAK6gB,MAAM3Q,EAAMpD,MAAMyC,UAAU8B,MAAM2B,KAAK9C,EAAKhQ,GAAG0N,QAuBhF,OAAoB,GAAhBqmC,EAAM31C,OACC21C,EAAM,IAEjB/jC,EAAO+jC,EAAMtlC,KAAI,SAAUX,GAAK,OAAOA,EAAE6B,MAAMrQ,KAAK2N,YAAaO,KAAKlO,KAAK2N,QAAQ8C,SAAW,IAAM,MAC7F,IAAI2J,GAAag6B,EAAQ,MAAQ,WAAS1jC,YAGtC,CACXf,IAAK,eAAS,aAAA2iC,mBAAAA,IAAA5hC,kBACV,IACI,OAAOyjC,IAAO,EAAMzjC,GACtB,MAAOjR,MAEbiQ,IAAK,eAAS,aAAA4iC,mBAAAA,IAAA5hC,kBACV,IACI,OAAOyjC,IAAO,EAAOzjC,GACvB,MAAOjR,MAEbi1C,QAAS,SAAU7oB,EAAK5D,GACpB,OAAO4D,EAAItD,UAAUN,EAAK7Z,QAE9BumC,GAAI,WACA,OAAO,IAAI3sB,GAAUjc,KAAKC,KAE9B4oC,IAAK,SAASpmC,EAAGC,GACb,OAAO,IAAIuZ,GAAUxZ,EAAEJ,MAAQK,EAAEL,MAAOI,EAAEyZ,OAE9C7X,IAAK,SAASoB,EAAGqjC,GACb,GAAiB,iBAANrjC,GAA+B,iBAANqjC,EAChCrjC,EAAI,IAAIwW,GAAUxW,GAClBqjC,EAAI,IAAI7sB,GAAU6sB,QACf,KAAMrjC,aAAawW,IAAgB6sB,aAAa7sB,IACnD,KAAM,CAAEpnB,KAAM,WAAYsW,QAAS,6BAGvC,OAAO,IAAI8Q,GAAUjc,KAAKqE,IAAIoB,EAAEpD,MAAOymC,EAAEzmC,OAAQoD,EAAEyW,OAEvD6sB,WAAY,SAAUz/B,GAGlB,OAFe2+B,IAAW,SAAAE,GAAO,OAAM,IAANA,IAAW,IAAK7+B,QCpF1C,CACX5V,EAAG,SAAU2Y,GACT,OAAO,IAAI4S,GAAO,IAAK5S,aAAe2V,GAAa3V,EAAI28B,UAAY38B,EAAIhK,OAAO,IAElFy7B,OAAQ,SAAUzxB,GACd,OAAO,IAAIgC,EACP46B,UAAU58B,EAAIhK,OAAOjR,QAAQ,KAAM,OAAOA,QAAQ,KAAM,OAAOA,QAAQ,KAAM,OAAOA,QAAQ,KAAM,OAC7FA,QAAQ,MAAO,OAAOA,QAAQ,MAAO,SAElDA,QAAS,SAAU6wB,EAAQinB,EAAShjB,EAAaijB,GAC7C,IAAIt+B,EAASoX,EAAO5f,MAIpB,OAHA6jB,EAAoC,WAArBA,EAAYrxB,KACvBqxB,EAAY7jB,MAAQ6jB,EAAY5hB,QACpCuG,EAASA,EAAOzZ,QAAQ,IAAIkqB,OAAO4tB,EAAQ7mC,MAAO8mC,EAAQA,EAAM9mC,MAAQ,IAAK6jB,GACtE,IAAIjH,GAAOgD,EAAO7C,OAAS,GAAIvU,EAAQoX,EAAO9C,UAEzDiqB,IAAK,SAAUnnB,GAIX,IAHA,IAAMtd,EAAOpD,MAAMyC,UAAU8B,MAAM2B,KAAKM,UAAW,GAC/C8C,EAASoX,EAAO5f,iBAEX1N,GAELkW,EAASA,EAAOzZ,QAAQ,WAAW,SAAAi4C,GAC/B,IAAMhnC,EAA2B,WAAjBsC,EAAKhQ,GAAGE,MACpBw0C,EAAMlmC,MAAM,MAASwB,EAAKhQ,GAAG0N,MAAQsC,EAAKhQ,GAAG2P,QACjD,OAAO+kC,EAAMlmC,MAAM,UAAYmmC,mBAAmBjnC,GAASA,MAL1D1N,EAAI,EAAGA,EAAIgQ,EAAK5R,OAAQ4B,MAAxBA,GAST,OADAkW,EAASA,EAAOzZ,QAAQ,MAAO,KACxB,IAAI6tB,GAAOgD,EAAO7C,OAAS,GAAIvU,EAAQoX,EAAO9C,WCxBvDoqB,GAAM,SAACjgC,EAAGkgC,GAAS,OAAClgC,aAAakgC,EAAQt7B,EAAQC,KAAOD,EAAQE,OAChEq7B,GAAS,SAACngC,EAAG4S,GACf,QAAazb,IAATyb,EACA,KAAM,CAAErnB,KAAM,WAAYsW,QAAS,mDAGvC,GAAoB,iBADpB+Q,EAA6B,iBAAfA,EAAK7Z,MAAqB6Z,EAAK7Z,MAAQ6Z,GAEjD,KAAM,CAAErnB,KAAM,WAAYsW,QAAS,2DAEvC,OAAQ7B,aAAa2S,IAAc3S,EAAE4S,KAAKhB,GAAGgB,GAAQhO,EAAQC,KAAOD,EAAQE,UAGjE,CACXs7B,UAAW,SAAUpgC,GACjB,OAAOigC,GAAIjgC,EAAGmR,IAElBkvB,QAAS,SAAUrgC,GACf,OAAOigC,GAAIjgC,EAAGtG,IAElB4mC,SAAU,SAAUtgC,GAChB,OAAOigC,GAAIjgC,EAAG2S,KAElB4tB,SAAU,SAAUvgC,GAChB,OAAOigC,GAAIjgC,EAAG2V,KAElB6qB,UAAW,SAAUxgC,GACjB,OAAOigC,GAAIjgC,EAAG4E,IAElB67B,MAAO,SAAUzgC,GACb,OAAOigC,GAAIjgC,EAAGuW,KAElBmqB,QAAS,SAAU1gC,GACf,OAAOmgC,GAAOngC,EAAG,OAErB2gC,aAAc,SAAU3gC,GACpB,OAAOmgC,GAAOngC,EAAG,MAErB4gC,KAAM,SAAU5gC,GACZ,OAAOmgC,GAAOngC,EAAG,OAErBmgC,UACAvtB,KAAM,SAAU4D,EAAK5D,GACjB,KAAM4D,aAAe7D,IACjB,KAAM,CAAEpnB,KAAM,WACVsW,QAAS,+CAA8C2U,aAAe/C,GAAY,oCAAsC,KAWhI,OAPQb,EAFJA,EACIA,aAAgBhO,EACTgO,EAAK7Z,MAEL6Z,EAAK5X,QAGT,GAEJ,IAAI2X,GAAU6D,EAAIzd,MAAO6Z,IAEpCiuB,WAAY,SAAU7gC,GAClB,OAAO,IAAI+E,EAAU/E,EAAE4S,oBCpDhBxmB,GACX,IAAMR,EAAY,CAAEyf,mBAAkB8I,mBAetC,OAZA9I,EAAiB/B,YAAY+pB,IAC7BhoB,EAAiB5S,IAAI,UAAWkR,EAAYjN,KAAK1Q,KAAK2d,IACtD0B,EAAiB/B,YAAYpO,IAC7BmQ,EAAiB/B,YAAYw3B,IAC7Bz1B,EAAiB/B,qBClBNld,GAEX,IAAM20C,EAAW,SAACC,EAAchpC,GAAS,OAAA,IAAIue,GAAIve,EAAMgpC,EAAaroC,MAAOqoC,EAAa3jC,iBAAiBX,KAAKskC,EAAa1oC,UAE3H,MAAO,CAAE2oC,WAAY,SAASC,EAAcC,GAEnCA,IACDA,EAAeD,EACfA,EAAe,MAGnB,IAAIE,EAAWF,GAAgBA,EAAanoC,MACxCsoC,EAAWF,EAAapoC,MACtBsE,EAAkB1S,KAAK0S,gBACvBlR,EAAmBkR,EAAgB+D,YACrC/D,EAAgBlR,iBAAmBkR,EAAgBikC,UAEjDC,EAAgBF,EAAS9lC,QAAQ,KACnC0b,EAAW,IACQ,IAAnBsqB,IACAtqB,EAAWoqB,EAAS7kC,MAAM+kC,GAC1BF,EAAWA,EAAS7kC,MAAM,EAAG+kC,IAEjC,IAAMjpC,EAAUkpC,EAAY72C,KAAK2N,SACjCA,EAAQmpC,WAAY,EAEpB,IAAMh1C,EAAcL,EAAYs1C,eAAeL,EAAUl1C,EAAkBmM,EAASlM,GAAa,GAEjG,IAAKK,EACD,OAAOs0C,EAASp2C,KAAMw2C,GAG1B,IAAIQ,GAAY,EAGhB,GAAKT,EAcDS,EAAY,WAAW76B,KAAKs6B,OAdb,CAIf,GAAiB,mBAFjBA,EAAWh1C,EAAYw1C,WAAWP,IAG9BM,GAAY,MACT,CAEH,IAAM5W,EAAU3+B,EAAYy1C,cAAcT,GAC1CO,EAAY,CAAC,WAAY,SAASpmC,QAAQwvB,GAAW,EAErD4W,IAAaP,GAAY,WAMjC,IAAMU,EAAWr1C,EAAYs1C,aAAaV,EAAUl1C,EAAkBmM,EAASlM,GAC/E,IAAK01C,EAAS9/B,SAEV,OADA1V,EAAOzB,KAAK,iCAAiCw2C,6BACtCN,EAASp2C,KAAMw2C,GAAgBD,GAE1C,IAAIc,EAAMF,EAAS9/B,SACnB,GAAI2/B,IAAcv1C,EAAY61C,aAC1B,OAAOlB,EAASp2C,KAAMw2C,GAK1B,IAAMe,EAAM,QAAQd,OAFpBY,EAAML,EAAYv1C,EAAY61C,aAAaD,GAAOhC,mBAAmBgC,IAE/B/qB,EAEtC,OAAO,IAAIV,GAAI,IAAIZ,GAAO,IAAIusB,MAAQA,GAAK,EAAOv3C,KAAKgO,MAAOhO,KAAK0S,iBAAkB1S,KAAKgO,MAAOhO,KAAK0S,mBDhD7E8kC,CAAQ/1C,IACrCif,EAAiB/B,YAAYm0B,IAC7BpyB,EAAiB/B,YAAYrI,IAC7BoK,EAAiB/B,YAAYyvB,IAC7B1tB,EAAiB/B,YAAYqP,IAC7BtN,EAAiB/B,YErBV,CAAE84B,eAAgB,SAASC,GAC9B,IAAIC,EACAC,EAIAzkB,EAEAzyB,EACA6P,EACAsnC,EACAC,EACAxoC,EATAyoC,EAAe,SACfC,EAAqB,mCACnBC,EAAY,CAACxnC,UAAU,GAEvBynC,EAAiBR,EAAUrnC,MAAM4nC,GAOvC,SAASE,IACL,KAAM,CAAEv3C,KAAM,WACVsW,QAAS,yIAejB,OAXwB,GAApBpD,UAAUhV,QACNgV,UAAU,GAAG1F,MAAMtP,OAAS,GAC5Bq5C,IAEJR,EAAQ7jC,UAAU,GAAG1F,OACd0F,UAAUhV,OAAS,EAC1Bq5C,IAEAR,EAAQrqC,MAAMyC,UAAU8B,MAAM2B,KAAKM,UAAW,GAG1CokC,GACJ,IAAK,YACDN,EAAuB,oCACvB,MACJ,IAAK,WACDA,EAAuB,oCACvB,MACJ,IAAK,kBACDA,EAAuB,sCACvB,MACJ,IAAK,eACDA,EAAuB,sCACvB,MACJ,IAAK,UACL,IAAK,oBACDG,EAAe,SACfH,EAAuB,4BACvBI,EAAqB,2CACrB,MACJ,QACI,KAAM,CAAEp3C,KAAM,WAAYsW,QAAS,oHAK3C,IAFAic,EAAW,8DAA8D4kB,qBAA+BH,MAEnGl3C,EAAI,EAAGA,EAAIi3C,EAAM74C,OAAQ4B,GAAK,EAC3Bi3C,EAAMj3C,aAAcuoB,IACpB1Y,EAAQonC,EAAMj3C,GAAG0N,MAAM,GACvBypC,EAAWF,EAAMj3C,GAAG0N,MAAM,KAE1BmC,EAAQonC,EAAMj3C,GACdm3C,OAAWrrC,GAGT+D,aAAiBxB,KAAoB,IAANrO,GAAWA,EAAI,IAAMi3C,EAAM74C,cAAwB0N,IAAbqrC,GAA6BA,aAAoB7vB,KACxHmwB,IAEJL,EAAgBD,EAAWA,EAASxnC,MAAM4nC,GAAmB,IAANv3C,EAAU,KAAO,OACxE4O,EAAQiB,EAAMjB,MACd6jB,GAAY,iBAAiB2kB,mBAA8BvnC,EAAMS,aAAW1B,EAAQ,EAAI,kBAAkBA,MAAW,SAOzH,OALA6jB,GAAY,KAAK4kB,oBAA8BC,6BAE/C7kB,EAAWkiB,mBAAmBliB,GAGvB,IAAIvH,GAAI,IAAIZ,GAAO,KAD1BmI,EAAW,sBAAsBA,OACUA,GAAU,EAAOnzB,KAAKgO,MAAOhO,KAAK0S,iBAAkB1S,KAAKgO,MAAOhO,KAAK0S,oBFvDpHgO,EAAiB/B,YAAYy5B,IAEtBn3C,eG3Basf,EAAMljB,GAE1B,IAAIg7C,EACAx2B,GAFJxkB,EAAUA,GAAW,IAEGwkB,UAClBy2B,EAAU,IAAI77B,EAASY,KAAKhgB,GAeT,iBAAdwkB,GAA2BvU,MAAMC,QAAQsU,KAChDA,EAAYhV,OAAO+R,KAAKiD,GAAW1S,KAAI,SAAU4E,GAC7C,IAAI3F,EAAQyT,EAAU9N,GAQtB,OANM3F,aAAiB8lB,GAAKla,QAClB5L,aAAiB8lB,GAAKjL,aACxB7a,EAAQ,IAAI8lB,GAAKjL,WAAW,CAAC7a,KAEjCA,EAAQ,IAAI8lB,GAAKla,MAAM,CAAC5L,KAErB,IAAI8lB,GAAKvZ,YAAY,IAAI5G,EAAK3F,GAAO,EAAO,KAAM,MAE7DkqC,EAAQh7B,OAAS,CAAC,IAAI4W,GAAK9U,QAAQ,KAAMyC,KAG7C,IAQIpS,EACA8oC,EATE5tB,EAAW,CACb,IAAItc,GAAQqwB,oBACZ,IAAIrwB,GAAQ+yB,6BAA4B,GACxC,IAAI/yB,GAAQgzB,cACZ,IAAIhzB,GAAQuc,aAAa,CAACna,SAAUgK,QAAQpd,EAAQoT,aAGlD+nC,EAAkB,GASxB,GAAIn7C,EAAQuE,cAAe,CACvB22C,EAAkBl7C,EAAQuE,cAAcyM,UACxC,IAAK,IAAI3N,EAAI,EAAGA,EAAI,EAAGA,IAEnB,IADA63C,EAAgBE,QACRhpC,EAAI8oC,EAAgBxrC,OACpB0C,EAAEipC,iBACQ,IAANh4C,IAA2C,IAAhC83C,EAAgB5nC,QAAQnB,KACnC+oC,EAAgBh4C,KAAKiP,GACrBA,EAAEsoB,IAAIxX,IAIA,IAAN7f,IAAoC,IAAzBiqB,EAAS/Z,QAAQnB,KACxBA,EAAEkpC,aACFhuB,EAAS9J,QAAQpR,GAGjBkb,EAASnqB,KAAKiP,IAQtC4oC,EAAY93B,EAAKxO,KAAKumC,GAEtB,IAAS53C,EAAI,EAAGA,EAAIiqB,EAAS7rB,OAAQ4B,IACjCiqB,EAASjqB,GAAGq3B,IAAIsgB,GAIpB,GAAIh7C,EAAQuE,cAER,IADA22C,EAAgBE,QACRhpC,EAAI8oC,EAAgBxrC,QACK,IAAzB4d,EAAS/Z,QAAQnB,KAA6C,IAAhC+oC,EAAgB5nC,QAAQnB,IACtDA,EAAEsoB,IAAIsgB,GAKlB,OAAOA,EC5FX,IA0JIO,iBAzJA,WAAYluB,GACR1qB,KAAK0qB,KAAOA,EACZ1qB,KAAK2qB,SAAW,GAChB3qB,KAAKonC,cAAgB,GACrBpnC,KAAK64C,eAAiB,GACtB74C,KAAK84C,iBAAmB,GACxB94C,KAAKe,aAAe,GACpBf,KAAKizC,UAAY,EACjBjzC,KAAK+4C,YAAc,GACnB/4C,KAAKg5C,OAAS,IAAItuB,EAAKuuB,aAAavuB,GA8I5C,OAvIIwuB,uBAAA,SAAWpkB,GACP,GAAIA,EACA,IAAK,IAAIp0B,EAAI,EAAGA,EAAIo0B,EAAQh2B,OAAQ4B,IAChCV,KAAKs0B,UAAUQ,EAAQp0B,KAUnCw4C,sBAAA,SAAU3kB,EAAQhzB,EAAUmf,GACxB1gB,KAAK84C,iBAAiBt4C,KAAK+zB,GACvBhzB,IACAvB,KAAK+4C,YAAYx3C,GAAYgzB,GAE7BA,EAAO4kB,SACP5kB,EAAO4kB,QAAQn5C,KAAK0qB,KAAM1qB,KAAM0gB,GAAoB1gB,KAAK0qB,KAAKzpB,UAAUyf,mBAQhFw4B,gBAAA,SAAI33C,GACA,OAAOvB,KAAK+4C,YAAYx3C,IAQ5B23C,uBAAA,SAAW7qC,GACPrO,KAAK2qB,SAASnqB,KAAK6N,IAQvB6qC,4BAAA,SAAgBE,EAAcC,GAC1B,IAAIC,EACJ,IAAKA,EAAkB,EAAGA,EAAkBt5C,KAAKonC,cAActoC,UACvDkB,KAAKonC,cAAckS,GAAiBD,UAAYA,GADeC,KAKvEt5C,KAAKonC,cAAczmC,OAAO24C,EAAiB,EAAG,CAACF,eAAcC,cAQjEH,6BAAA,SAAiBK,EAAeF,GAC5B,IAAIC,EACJ,IAAKA,EAAkB,EAAGA,EAAkBt5C,KAAK64C,eAAe/5C,UACxDkB,KAAK64C,eAAeS,GAAiBD,UAAYA,GADeC,KAKxEt5C,KAAK64C,eAAel4C,OAAO24C,EAAiB,EAAG,CAACC,gBAAeF,cAOnEH,2BAAA,SAAeM,GACXx5C,KAAKe,aAAaP,KAAKg5C,IAQ3BN,6BAAA,WAEI,IADA,IAAM9R,EAAgB,GACb1mC,EAAI,EAAGA,EAAIV,KAAKonC,cAActoC,OAAQ4B,IAC3C0mC,EAAc5mC,KAAKR,KAAKonC,cAAc1mC,GAAG04C,cAE7C,OAAOhS,GAQX8R,8BAAA,WAEI,IADA,IAAML,EAAiB,GACdn4C,EAAI,EAAGA,EAAIV,KAAK64C,eAAe/5C,OAAQ4B,IAC5Cm4C,EAAer4C,KAAKR,KAAK64C,eAAen4C,GAAG64C,eAE/C,OAAOV,GAQXK,wBAAA,WACI,OAAOl5C,KAAK2qB,UAGhBuuB,oBAAA,WACI,IAAMtsC,EAAO5M,KACb,MAAO,CACHy4C,MAAO,WAEH,OADA7rC,EAAKqmC,UAAY,EACVrmC,EAAK+d,SAAS/d,EAAKqmC,WAE9BlmC,IAAK,WAED,OADAH,EAAKqmC,UAAY,EACVrmC,EAAK+d,SAAS/d,EAAKqmC,aAUtCiG,4BAAA,WACI,OAAOl5C,KAAKe,mBAMd04C,GAAuB,SAAS/uB,EAAMgvB,GAIxC,OAHIA,GAAed,KACfA,GAAK,IAAIM,GAAcxuB,IAEpBkuB,IChJX,ICfIv7C,GACAsE,MDHJ,SAA0B8yB,GACxB,IAAIvlB,EAAQulB,EAAQvlB,MAAM,mFAC1B,IAAKA,EACH,MAAM,IAAIxP,MAAM,oBAAsB+0B,GAWxC,MARU,CACRklB,MAAOtqC,SAASH,EAAM,GAAI,IAC1B0qC,MAAOvqC,SAASH,EAAM,GAAI,IAC1B2qC,MAAOxqC,SAASH,EAAM,GAAI,IAC1B4qC,IAAK5qC,EAAM,IAAM,GACjB6qC,MAAO7qC,EAAM,IAAM,iBEUCzN,EAAaV,GACjC,IAAIi5C,EAAiBC,EAAkBC,EAAWC,EAKlDD,WCzBoBE,GA4DpB,kBA1DI,WAAY75B,EAAMlH,GACdrZ,KAAKugB,KAAOA,EACZvgB,KAAKqZ,QAAUA,EAsDvB,OAnDIghC,kBAAA,SAAMh9C,GACF,IAAIg7C,EAEA4B,EADErjC,EAAS,GAEf,IACIyhC,EAAYiC,GAAct6C,KAAKugB,KAAMljB,GACvC,MAAOoC,GACL,MAAM,IAAIsX,EAAUtX,EAAGO,KAAKqZ,SAGhC,IACI,IAAM5I,EAAWgK,QAAQpd,EAAQoT,UAC7BA,GACA9O,EAAOzB,KAAK,mIAIhB,IAAMq6C,EAAe,CACjB9pC,WACAmL,gBAAiBve,EAAQue,gBACzBmL,YAAatM,QAAQpd,EAAQ0pB,aAC7BpY,aAAc,GAEdtR,EAAQm9C,WACRP,EAAmB,IAAIG,EAAiB/8C,EAAQm9C,WAChD5jC,EAAO6V,IAAMwtB,EAAiB5pC,MAAMgoC,EAAWkC,EAAcv6C,KAAKqZ,UAElEzC,EAAO6V,IAAM4rB,EAAUhoC,MAAMkqC,GAEnC,MAAO96C,GACL,MAAM,IAAIsX,EAAUtX,EAAGO,KAAKqZ,SAGhC,GAAIhc,EAAQuE,cAER,IADA,IAAMi3C,EAAiBx7C,EAAQuE,cAAc64C,oBACpC/5C,EAAI,EAAGA,EAAIm4C,EAAe/5C,OAAQ4B,IACvCkW,EAAO6V,IAAMosB,EAAen4C,GAAG4mC,QAAQ1wB,EAAO6V,IAAK,CAAE+tB,UAAWP,EAAkB58C,UAASgc,QAASrZ,KAAKqZ,UAQjH,IAAK,IAAMqhC,KALPr9C,EAAQm9C,YACR5jC,EAAOzH,IAAM8qC,EAAiBU,wBAGlC/jC,EAAOyC,QAAU,GACErZ,KAAKqZ,QAAQuhC,MACxB56C,KAAKqZ,QAAQuhC,MAAMn9C,eAAei9C,IAASA,IAAS16C,KAAKqZ,QAAQwhC,cACjEjkC,EAAOyC,QAAQ7Y,KAAKk6C,GAG5B,OAAO9jC,QD/BHyjC,CADZJ,WE5BqBa,EAAiBr5C,GAgFtC,kBA9EI,WAAYpE,GACR2C,KAAK3C,QAAUA,EA2EvB,OAxEI+8C,kBAAA,SAAM1tC,EAAUrP,EAASgc,GACrB,IAAM2gC,EAAkB,IAAIc,EACxB,CACIC,wBAAyB1hC,EAAQmuB,qBACjC96B,WACAsuC,YAAa3hC,EAAQhC,SACrB4jC,kBAAmBj7C,KAAK3C,QAAQ49C,kBAChCC,aAAcl7C,KAAK3C,QAAQ69C,aAC3BC,eAAgBn7C,KAAK3C,QAAQ+9C,wBAC7BC,kBAAmBr7C,KAAK3C,QAAQg+C,kBAChCC,kBAAmBt7C,KAAK3C,QAAQi+C,kBAChCC,kBAAmBv7C,KAAK3C,QAAQk+C,kBAChCC,mBAAoBx7C,KAAK3C,QAAQm+C,mBACjCC,oBAAqBz7C,KAAK3C,QAAQo+C,oBAClCC,2BAA4B17C,KAAK3C,QAAQq+C,6BAG3CjvB,EAAMutB,EAAgB3pC,MAAMhT,GASlC,OARA2C,KAAKw6C,UAAYR,EAAgBQ,UACjCx6C,KAAKk7C,aAAelB,EAAgBkB,aAChCl7C,KAAK3C,QAAQs+C,yBACb37C,KAAK27C,uBAAyB3B,EAAgB4B,kBAAkB57C,KAAK3C,QAAQs+C,8BAE1CnvC,IAAnCxM,KAAK3C,QAAQg+C,wBAAyD7uC,IAAtBxM,KAAKk7C,eACrDl7C,KAAKk7C,aAAelB,EAAgB6B,eAAe77C,KAAKk7C,eAErDzuB,EAAMzsB,KAAK87C,mBAGtB1B,4BAAA,WAEI,IAAIc,EAAel7C,KAAKk7C,aACxB,GAAIl7C,KAAK3C,QAAQo+C,oBAAqB,CAClC,QAAuBjvC,IAAnBxM,KAAKw6C,UACL,MAAO,GAEXU,EAAe,gCAAgCz5C,EAAY61C,aAAat3C,KAAKw6C,WAGjF,OAAIx6C,KAAK3C,QAAQq+C,2BACN,GAGPR,EACO,wBAAwBA,QAE5B,IAGXd,iCAAA,WACI,OAAOp6C,KAAKw6C,WAGhBJ,iCAAA,SAAqBI,GACjBx6C,KAAKw6C,UAAYA,GAGrBJ,qBAAA,WACI,OAAOp6C,KAAK3C,QAAQo+C,qBAGxBrB,4BAAA,WACI,OAAOp6C,KAAKk7C,cAGhBd,8BAAA,WACI,OAAOp6C,KAAK3C,QAAQ+9C,yBAGxBhB,6BAAA,WACI,OAAOp6C,KAAK27C,6BFhDDvB,CADnBJ,WG3BqBv4C,GAoJrB,kBAlJI,WAAYpE,GACR2C,KAAK+7C,KAAO,GACZ/7C,KAAKg8C,UAAY3+C,EAAQqP,SACzB1M,KAAKi8C,aAAe5+C,EAAQ29C,YAC5Bh7C,KAAKk8C,yBAA2B7+C,EAAQ09C,wBACpC19C,EAAQ49C,oBACRj7C,KAAKm8C,mBAAqB9+C,EAAQ49C,kBAAkB99C,QAAQ,MAAO,MAEvE6C,KAAKo8C,gBAAkB/+C,EAAQ89C,eAC/Bn7C,KAAKk7C,aAAe79C,EAAQ69C,aACxB79C,EAAQg+C,oBACRr7C,KAAKq8C,mBAAqBh/C,EAAQg+C,kBAAkBl+C,QAAQ,MAAO,MAEnEE,EAAQi+C,mBACRt7C,KAAKs8C,mBAAqBj/C,EAAQi+C,kBAAkBn+C,QAAQ,MAAO,KACQ,MAAvE6C,KAAKs8C,mBAAmBrpC,OAAOjT,KAAKs8C,mBAAmBx9C,OAAS,KAChEkB,KAAKs8C,oBAAsB,MAG/Bt8C,KAAKs8C,mBAAqB,GAE9Bt8C,KAAKu8C,mBAAqBl/C,EAAQk+C,kBAClCv7C,KAAKw8C,+BAAiC/6C,EAAYg7C,wBAElDz8C,KAAK08C,YAAc,EACnB18C,KAAK28C,QAAU,EAuHvB,OApHI7B,2BAAA,SAAe39B,GAQX,OAPInd,KAAKq8C,oBAAgE,IAA1Cl/B,EAAKvM,QAAQ5Q,KAAKq8C,sBAEtB,QADvBl/B,EAAOA,EAAKqS,UAAUxvB,KAAKq8C,mBAAmBv9C,SACrCmU,OAAO,IAAkC,MAAnBkK,EAAKlK,OAAO,KACvCkK,EAAOA,EAAKqS,UAAU,KAIvBrS,GAGX29B,8BAAA,SAAkBv5C,GAGd,OAFAA,EAAWA,EAASpE,QAAQ,MAAO,KACnCoE,EAAWvB,KAAK67C,eAAet6C,IACvBvB,KAAKs8C,oBAAsB,IAAM/6C,GAG7Cu5C,gBAAA,SAAI/sC,EAAOf,EAAUgB,EAAOqM,GAGxB,GAAKtM,EAAL,CAIA,IAAI2J,EAAOklC,EAAaC,EAASC,EAAep8C,EAEhD,GAAIsM,GAAYA,EAASzL,SAAU,CAC/B,IAAIw7C,EAAc/8C,KAAKi8C,aAAajvC,EAASzL,UAe7C,GAZIvB,KAAKk8C,yBAAyBlvC,EAASzL,aAEvCyM,GAAShO,KAAKk8C,yBAAyBlvC,EAASzL,WACpC,IAAKyM,EAAQ,GAEzB+uC,EAAcA,EAAYlrC,MAAM7R,KAAKk8C,yBAAyBlvC,EAASzL,iBAOvDiL,IAAhBuwC,EAEA,YADA/8C,KAAK+7C,KAAKv7C,KAAKuN,GAMnB+uC,GADAF,GADAG,EAAcA,EAAYvtB,UAAU,EAAGxhB,IACbuB,MAAM,OACJqtC,EAAY99C,OAAS,GAMrD,GAFA+9C,GADAnlC,EAAQ3J,EAAMwB,MAAM,OACJmI,EAAM5Y,OAAS,GAE3BkO,GAAYA,EAASzL,SACrB,GAAK8Y,EAKD,IAAK3Z,EAAI,EAAGA,EAAIgX,EAAM5Y,OAAQ4B,IAC1BV,KAAKg9C,oBAAoBC,WAAW,CAAEC,UAAW,CAAE5nC,KAAMtV,KAAK08C,YAAch8C,EAAI,EAAG6U,OAAc,IAAN7U,EAAUV,KAAK28C,QAAU,GAChHhgC,SAAU,CAAErH,KAAMsnC,EAAY99C,OAAS4B,EAAG6U,OAAc,IAAN7U,EAAUo8C,EAAch+C,OAAS,GACnFq+C,OAAQn9C,KAAK47C,kBAAkB5uC,EAASzL,iBAPhDvB,KAAKg9C,oBAAoBC,WAAW,CAAEC,UAAW,CAAE5nC,KAAMtV,KAAK08C,YAAc,EAAGnnC,OAAQvV,KAAK28C,SACxFhgC,SAAU,CAAErH,KAAMsnC,EAAY99C,OAAQyW,OAAQunC,EAAch+C,QAC5Dq+C,OAAQn9C,KAAK47C,kBAAkB5uC,EAASzL,YAU/B,IAAjBmW,EAAM5Y,OACNkB,KAAK28C,SAAWE,EAAQ/9C,QAExBkB,KAAK08C,aAAehlC,EAAM5Y,OAAS,EACnCkB,KAAK28C,QAAUE,EAAQ/9C,QAG3BkB,KAAK+7C,KAAKv7C,KAAKuN,KAGnB+sC,oBAAA,WACI,OAA4B,IAArB96C,KAAK+7C,KAAKj9C,QAGrBg8C,kBAAA,SAAMntC,GAGF,GAFA3N,KAAKg9C,oBAAsB,IAAIh9C,KAAKw8C,+BAA+B,CAAE9B,KAAM16C,KAAKo8C,gBAAiBgB,WAAY,OAEzGp9C,KAAKu8C,mBACL,IAAK,IAAMh7C,KAAYvB,KAAKi8C,aACxB,GAAIj8C,KAAKi8C,aAAax+C,eAAe8D,GAAW,CAC5C,IAAI47C,EAASn9C,KAAKi8C,aAAa16C,GAC3BvB,KAAKk8C,yBAAyB36C,KAC9B47C,EAASA,EAAOtrC,MAAM7R,KAAKk8C,yBAAyB36C,KAExDvB,KAAKg9C,oBAAoBK,iBAAiBr9C,KAAK47C,kBAAkBr6C,GAAW47C,GAOxF,GAFAn9C,KAAKg8C,UAAUnuC,OAAOF,EAAS3N,MAE3BA,KAAK+7C,KAAKj9C,OAAS,EAAG,CACtB,IAAIo8C,SACEoC,EAAmB5/C,KAAK6/C,UAAUv9C,KAAKg9C,oBAAoBQ,UAE7Dx9C,KAAKk7C,aACLA,EAAel7C,KAAKk7C,aACbl7C,KAAKm8C,qBACZjB,EAAel7C,KAAKm8C,oBAExBn8C,KAAKk7C,aAAeA,EAEpBl7C,KAAKw6C,UAAY8C,EAGrB,OAAOt9C,KAAK+7C,KAAK7tC,KAAK,UHrHZ4sC,CADlBr5C,EAAc,IAAIH,EAAYG,EAAaV,IAEUU,IAErD04C,WIxBoB14C,GA+KpB,kBApKI,WAAYipB,EAAM/c,EAAS8vC,GACvBz9C,KAAK0qB,KAAOA,EACZ1qB,KAAK66C,aAAe4C,EAAal8C,SACjCvB,KAAKgd,MAAQrP,EAAQqP,OAAS,GAC9Bhd,KAAKqX,SAAW,GAChBrX,KAAKwnC,qBAAuB,GAC5BxnC,KAAK09C,KAAO/vC,EAAQ+vC,KACpB19C,KAAKF,MAAQ,KACbE,KAAK2N,QAAUA,EAEf3N,KAAK29C,MAAQ,GACb39C,KAAK46C,MAAQ,GAuJrB,OA5IIgD,iBAAA,SAAKzgC,EAAMkV,EAAoB3f,EAAiBq5B,EAAexkB,GAC3D,IAAM4yB,EAAgBn6C,KAAM69C,EAAe79C,KAAK2N,QAAQ/L,cAAco3C,OAEtEh5C,KAAK29C,MAAMn9C,KAAK2c,GAEhB,IAAM2gC,EAAiB,SAAUr+C,EAAG8gB,EAAMwY,GACtCohB,EAAcwD,MAAMh9C,OAAOw5C,EAAcwD,MAAM/sC,QAAQuM,GAAO,GAE9D,IAAM4gC,EAAqBhlB,IAAaohB,EAAcU,aAClD9O,EAAc7S,UAAYz5B,GAC1B8nB,EAAS,KAAM,CAACjI,MAAM,KAAK,EAAO,MAClC3d,EAAOxB,KAAK,YAAY44B,iFAMnBohB,EAAcS,MAAM7hB,IAAcgT,EAAchxB,SACjDo/B,EAAcS,MAAM7hB,GAAY,CAAExY,OAAMljB,QAAS0uC,IAEjDtsC,IAAM06C,EAAcr6C,QAASq6C,EAAcr6C,MAAQL,GACvD8nB,EAAS9nB,EAAG8gB,EAAMw9B,EAAoBhlB,KAIxCilB,EAAc,CAChBvnC,YAAazW,KAAK2N,QAAQ8I,YAC1BkgC,UAAWjkC,EAAgBikC,UAC3Bz4B,SAAUxL,EAAgBwL,SAC1B28B,aAAcnoC,EAAgBmoC,cAG5B/4C,EAAcL,EAAYs1C,eAAe55B,EAAMzK,EAAgBlR,iBAAkBxB,KAAK2N,QAASlM,GAErG,GAAKK,EAAL,CAKA,IA4DIm8C,EACAC,EA7DEC,EAAmB,SAASF,GAC9B,IAAI1pB,EACE6pB,EAAmBH,EAAW18C,SAC9B8V,EAAW4mC,EAAW5mC,SAASla,QAAQ,UAAW,IAUxD6gD,EAAYx8C,iBAAmBM,EAAY6qB,QAAQyxB,GAC/CJ,EAAYvnC,cACZunC,EAAY9/B,SAAWpc,EAAYoM,KAC9BisC,EAAcxsC,QAAQuQ,UAAY,GACnCpc,EAAYu8C,SAASL,EAAYx8C,iBAAkBw8C,EAAYrH,aAE9D70C,EAAYw8C,eAAeN,EAAY9/B,WAAapc,EAAYy8C,4BACjEP,EAAY9/B,SAAWpc,EAAYoM,KAAK8vC,EAAYrH,UAAWqH,EAAY9/B,YAGnF8/B,EAAYz8C,SAAW68C,EAEvB,IAAMI,EAAS,IAAI/hC,EAASM,MAAMo9B,EAAcxsC,SAEhD6wC,EAAO7W,gBAAiB,EACxBwS,EAAc9iC,SAAS+mC,GAAoB/mC,GAEvC3E,EAAgBma,WAAakf,EAAclf,aAC3CmxB,EAAYnxB,WAAY,GAGxBkf,EAAcnf,UACd2H,EAASspB,EAAaY,WAAWpnC,EAAUmnC,EAAQrE,EAAepO,EAAcM,WAAY2R,cACtEjnC,EAClB+mC,EAAevpB,EAAQ,KAAM6pB,GAG7BN,EAAe,KAAMvpB,EAAQ6pB,GAE1BrS,EAAchxB,OACrB+iC,EAAe,KAAMzmC,EAAU+mC,IAI3BjE,EAAcS,MAAMwD,IAChBjE,EAAcS,MAAMwD,GAAkB/gD,QAAQm7B,UAC9CuT,EAAcvT,SAKlB,IAAI6N,GAAOmY,EAAQrE,EAAe6D,GAAargD,MAAM0Z,GAAU,SAAU5X,EAAG8gB,GACxEu9B,EAAer+C,EAAG8gB,EAAM69B,MAJ5BN,EAAe,KAAM3D,EAAcS,MAAMwD,GAAkB79B,KAAM69B,IAWvEzwC,EAAUkpC,EAAY72C,KAAK2N,SAE7B0kB,IACA1kB,EAAQykB,IAAM2Z,EAAcnf,SAAW,MAAQ,SAG/Cmf,EAAcnf,UACdjf,EAAQ+vC,KAAO,yBAEX/vC,EAAQ+wC,WACRT,EAAaJ,EAAac,eAAexhC,EAAMzK,EAAgBlR,iBAAkBmM,EAASlM,EAAaK,GAEvGo8C,EAAUL,EAAae,WAAWzhC,EAAMzK,EAAgBlR,iBAAkBmM,EAASlM,EAAaK,IAIhG6L,EAAQ+wC,WACRT,EAAan8C,EAAYs1C,aAAaj6B,EAAMzK,EAAgBlR,iBAAkBmM,EAASlM,GAEvFy8C,EAAUp8C,EAAY+8C,SAAS1hC,EAAMzK,EAAgBlR,iBAAkBmM,EAASlM,GAC5E,SAAC2X,EAAK6kC,GACE7kC,EACA0kC,EAAe1kC,GAEf+kC,EAAiBF,MAKjCA,EACKA,EAAW18C,SAGZ48C,EAAiBF,GAFjBH,EAAeG,GAIZC,GACPA,EAAQY,KAAKX,EAAkBL,QAtG/BA,EAAe,CAAE5mC,QAAS,qCAAqCiG,UJ5C3DygC,CAAcn8C,GAE9B,IAsCIkvC,EAtCEoO,WK9Bct9C,EAAa44C,EAAWuD,GAC5C,IAAMmB,EAAS,SAAU3nC,EAAO/Z,EAASkqB,GASrC,GARuB,mBAAZlqB,GACPkqB,EAAWlqB,EACXA,EAAU2hD,EAAkBh/C,KAAK3C,QAAS,KAG1CA,EAAU2hD,EAAkBh/C,KAAK3C,QAASA,GAAW,KAGpDkqB,EAAU,CACX,IAAM03B,EAAOj/C,KACb,OAAO,IAAIk/C,SAAQ,SAAUC,EAASC,GAClCL,EAAOvrC,KAAKyrC,EAAM7nC,EAAO/Z,GAAS,SAAS+b,EAAKjL,GACxCiL,EACAgmC,EAAOhmC,GAEP+lC,EAAQhxC,SAKpBnO,KAAKrC,MAAMyZ,EAAO/Z,GAAS,SAAS+b,EAAKmH,EAAMlH,EAAShc,GACpD,GAAI+b,EAAO,OAAOmO,EAASnO,GAE3B,IAAIxC,EACJ,IAEIA,EADkB,IAAIyjC,EAAU95B,EAAMlH,GACnBhJ,MAAMhT,GAE7B,MAAO+b,GAAO,OAAOmO,EAASnO,GAE9BmO,EAAS,KAAM3Q,OAK3B,OAAOmoC,ELPQM,CAAO59C,EAAay4C,GAC7Bv8C,WM3Bc8D,EAAa44C,EAAWuD,GAC5C,IAAMjgD,EAAQ,SAAUyZ,EAAO/Z,EAASkqB,GAUpC,GARuB,mBAAZlqB,GACPkqB,EAAWlqB,EACXA,EAAU2hD,EAAkBh/C,KAAK3C,QAAS,KAG1CA,EAAU2hD,EAAkBh/C,KAAK3C,QAASA,GAAW,KAGpDkqB,EAAU,CACX,IAAM03B,EAAOj/C,KACb,OAAO,IAAIk/C,SAAQ,SAAUC,EAASC,GAClCzhD,EAAM6V,KAAKyrC,EAAM7nC,EAAO/Z,GAAS,SAAS+b,EAAKjL,GACvCiL,EACAgmC,EAAOhmC,GAEP+lC,EAAQhxC,SAKpB,IAAImxC,EACA7B,SACE8B,EAAgB,IAAIrG,GAAcl5C,MAAO3C,EAAQmiD,oBAMvD,GAJAniD,EAAQuE,cAAgB29C,EAExBD,EAAU,IAAI7iC,EAASM,MAAM1f,GAEzBA,EAAQogD,aACRA,EAAepgD,EAAQogD,iBACpB,CACH,IAAMl8C,EAAWlE,EAAQkE,UAAY,QAC/Bo1C,EAAYp1C,EAASpE,QAAQ,YAAa,KAChDsgD,EAAe,CACXl8C,WACAkV,YAAa6oC,EAAQ7oC,YACrByH,SAAUohC,EAAQphC,UAAY,GAC9B1c,iBAAkBm1C,EAClBA,YACAkE,aAAct5C,IAGD2c,UAAgD,MAApCu/B,EAAav/B,SAASrM,OAAO,KACtD4rC,EAAav/B,UAAY,KAIjC,IAAMuhC,EAAU,IAAI7B,EAAc59C,KAAMs/C,EAAS7B,GACjDz9C,KAAKm6C,cAAgBsF,EAKjBpiD,EAAQy3B,SACRz3B,EAAQy3B,QAAQtnB,SAAQ,SAAS+mB,GAC7B,IAAImrB,EAAYroC,EAChB,GAAIkd,EAAOorB,aAGP,GAFAtoC,EAAWkd,EAAOorB,YAAYxiD,QAAQ,UAAW,KACjDuiD,EAAaH,EAAcvG,OAAOyF,WAAWpnC,EAAUioC,EAASG,EAASlrB,EAAOl3B,QAASk3B,EAAOhzB,qBACtEwV,EACtB,OAAOwQ,EAASm4B,QAIpBH,EAAcjrB,UAAUC,MAKpC,IAAI8R,GAAOiZ,EAASG,EAAShC,GACxB9/C,MAAMyZ,GAAO,SAAU3X,EAAG8gB,GACvB,GAAI9gB,EAAK,OAAO8nB,EAAS9nB,GACzB8nB,EAAS,KAAMhH,EAAMk/B,EAASpiD,KAC/BA,IAGf,OAAOM,ENpDOof,CAAMtb,EAAay4C,EAAWC,GAEtC1qC,EAAImwC,YACJC,EAAU,CACZprB,QAAS,CAAChlB,EAAEkqC,MAAOlqC,EAAEmqC,MAAOnqC,EAAEoqC,OAC9BiG,OACA5rB,QACA5yB,cACA4wB,uBACAsB,wBACA/xB,cACAkpB,YACA0b,UACAplC,UAAWA,GAAUQ,GACrBgb,WACAq+B,gBAAiBd,EACjBI,iBAAkBH,EAClBI,UAAWH,EACX0D,cAAezD,EACf4E,SACAphD,QACAoZ,YACAujC,iBACAhb,QACA4Z,iBACAv3C,UAKEo+C,EAAO,SAASpP,GAClB,OAAO,WACH,IAAMj7B,EAAM7I,OAAOoL,OAAO04B,EAAE5gC,WAE5B,OADA4gC,EAAEtvB,MAAM3L,EAAKpI,MAAMyC,UAAU8B,MAAM2B,KAAKM,UAAW,IAC5C4B,IAITsqC,EAAMnzC,OAAOoL,OAAO4nC,GAC1B,IAAK,IAAMxqC,KAAKwqC,EAAQ3rB,KAGpB,GAAiB,mBADjByc,EAAIkP,EAAQ3rB,KAAK7e,IAEb2qC,EAAI3qC,EAAEzD,eAAiBmuC,EAAKpP,QAI5B,IAAK,IAAM1E,KADX+T,EAAI3qC,GAAKxI,OAAOoL,OAAO,MACP04B,EAEZqP,EAAI3qC,GAAG42B,EAAEr6B,eAAiBmuC,EAAKpP,EAAE1E,IAc7C,OAHA4T,EAAQliD,MAAQkiD,EAAQliD,MAAM0D,KAAK2+C,GACnCH,EAAQd,OAASc,EAAQd,OAAO19C,KAAK2+C,GAE9BA,ED1FX,IAAIC,GAAY,GAGVpsB,GAAc,aACpBA,GAAY9jB,UAAYlD,OAAOmD,OAAO,IAAIkiB,GAAuB,CAC7DqsB,mCACI,OAAO,GAGXrwC,cAAKokB,EAAUC,GACX,OAAKD,EAGEtyB,KAAK6yB,gBAAgBN,EAAWD,GAAUnV,KAFtCoV,GAKf2tB,eAAM1tB,EAAK5xB,EAAM2mB,EAAU44B,GACvB,IAAMC,EAAM,IAAIC,eACVC,GAAQjjD,GAAQkjD,gBAAiBljD,GAAQmjD,UAU/C,SAASC,EAAeL,EAAK74B,EAAU44B,GAC/BC,EAAIM,QAAU,KAAON,EAAIM,OAAS,IAClCn5B,EAAS64B,EAAIO,aACTP,EAAIQ,kBAAkB,kBACA,mBAAZT,GACdA,EAAQC,EAAIM,OAAQluB,GAbQ,mBAAzB4tB,EAAIS,kBACXT,EAAIS,iBAAiB,YAEzBl/C,GAAOvB,MAAM,iBAAiBoyB,OAC9B4tB,EAAIU,KAAK,MAAOtuB,EAAK8tB,GACrBF,EAAIW,iBAAiB,SAAUngD,GAAQ,4CACvCw/C,EAAIY,KAAK,MAWL3jD,GAAQkjD,iBAAmBljD,GAAQmjD,UAChB,IAAfJ,EAAIM,QAAiBN,EAAIM,QAAU,KAAON,EAAIM,OAAS,IACvDn5B,EAAS64B,EAAIO,cAEbR,EAAQC,EAAIM,OAAQluB,GAEjB8tB,EACPF,EAAIa,mBAAqB,WACC,GAAlBb,EAAIc,YACJT,EAAeL,EAAK74B,EAAU44B,IAItCM,EAAeL,EAAK74B,EAAU44B,IAItCgB,oBACI,OAAO,GAGXC,0BACInB,GAAY,IAGhBpB,kBAASt9C,EAAUC,EAAkBnE,EAASoE,GAItCD,IAAqBxB,KAAKs+C,eAAe/8C,KACzCA,EAAWC,EAAmBD,GAGlCA,EAAWlE,EAAQ+0B,IAAMpyB,KAAKqyB,mBAAmB9wB,EAAUlE,EAAQ+0B,KAAO7wB,EAE1ElE,EAAUA,GAAW,GAIrB,IACMH,EADY8C,KAAK6yB,gBAAgBtxB,EAAU5B,OAAO0hD,SAASnkD,MACrCs1B,IACtB5lB,EAAY5M,KAElB,OAAO,IAAIk/C,SAAQ,SAACC,EAASC,GACzB,GAAI/hD,EAAQikD,cAAgBrB,GAAU/iD,GAClC,IACI,IAAMqkD,EAAWtB,GAAU/iD,GAC3B,OAAOiiD,EAAQ,CAAE9nC,SAAUkqC,EAAUhgD,SAAUrE,EAAMskD,QAAS,CAAEC,aAAc,IAAIC,QACpF,MAAOjiD,GACL,OAAO2/C,EAAO,CAAE79C,SAAUrE,EAAMga,QAAS,sBAAsBha,gBAAkBuC,EAAEyX,UAI3FtK,EAAKszC,MAAMhjD,EAAMG,EAAQqgD,MAAM,SAAuBoC,EAAM2B,GAExDxB,GAAU/iD,GAAQ4iD,EAGlBX,EAAQ,CAAE9nC,SAAUyoC,EAAMv+C,SAAUrE,EAAMskD,QAAS,CAAEC,qBACtD,SAAoBf,EAAQluB,GAC3B4sB,EAAO,CAAEx+C,KAAM,OAAQsW,QAAS,IAAIsb,qBAAsBkuB,MAAWxjD,kCAMrEkZ,EAAMurC,GAGlB,OAFAtkD,GAAU+Y,EACVzU,GAASggD,EACF9tB,IQxGLolB,GAAe,SAASvuB,GAC1B1qB,KAAK0qB,KAAOA,GAIhBuuB,GAAalpC,UAAYlD,OAAOmD,OAAO,IAAIwjB,GAAwB,CAC/DorB,oBAAWr9C,EAAU+wB,EAAU3kB,EAASlM,EAAaK,GACjD,OAAO,IAAIo9C,SAAQ,SAAC0C,EAASxC,GACzBt9C,EAAY+8C,SAASt9C,EAAU+wB,EAAU3kB,EAASlM,GAC7Cq9C,KAAK8C,GAASC,MAAMzC,yBCdrBz/C,EAAQ+qB,EAAMrtB,GAkK1B,MAAO,CACHyQ,IAXJ,SAAerO,EAAGqiD,GACTzkD,EAAQ0kD,gBAA6C,SAA3B1kD,EAAQ0kD,eAED,YAA3B1kD,EAAQ0kD,eA7BvB,SAAsBtiD,EAAGqiD,GACrB,IACMvgD,EAAW9B,EAAE8B,UAAYugD,EACzBE,EAAS,GACX/2B,GAAaxrB,EAAEmB,MAAQ,qBAAkBnB,EAAEyX,SAAW,+CAA6C3V,EAEjG0gD,EAAY,SAACxiD,EAAGiB,EAAGwhD,QACA11C,IAAjB/M,EAAEuY,QAAQtX,IACVshD,EAAOxhD,KAPE,mBAOYrD,QAAQ,YAAakS,SAAS5P,EAAE6V,KAAM,KAAO,IAAM5U,EAAI,IACvEvD,QAAQ,YAAa+kD,GACrB/kD,QAAQ,cAAesC,EAAEuY,QAAQtX,MAI1CjB,EAAE6V,OACF2sC,EAAUxiD,EAAG,EAAG,IAChBwiD,EAAUxiD,EAAG,EAAG,QAChBwiD,EAAUxiD,EAAG,EAAG,IAChBwrB,GAAW,YAAYxrB,EAAE6V,kBAAgB7V,EAAE8V,OAAS,SAAOysC,EAAO9zC,KAAK,OAEvEzO,EAAE0X,QAAU1X,EAAEuY,SAAW3a,EAAQ8kD,UAAY,KAC7Cl3B,GAAW,kBAAkBxrB,EAAE0X,OAEnCuT,EAAK/oB,OAAO7B,MAAMmrB,GAOdm3B,CAAa3iD,EAAGqiD,GACyB,mBAA3BzkD,EAAQ0kD,gBACtB1kD,EAAQ0kD,eAAe,MAAOtiD,EAAGqiD,GA5JzC,SAAmBriD,EAAGqiD,GAClB,IAGIO,EACAp3B,EAJEjtB,EAAK,sBAAsBE,EAAgB4jD,GAAY,IAEvD1X,EAAOzqC,EAAO9B,SAASU,cAAc,OAGrCyjD,EAAS,GACTzgD,EAAW9B,EAAE8B,UAAYugD,EACzBQ,EAAiB/gD,EAAS2N,MAAM,oBAAoB,GAE1Dk7B,EAAKpsC,GAAYA,EACjBosC,EAAKmY,UAAY,qBAEjBt3B,EAAU,QAAOxrB,EAAEmB,MAAQ,qBAAkBnB,EAAEyX,SAAW,wCACtD,uBAAuB3V,OAAa+gD,UAExC,IAAML,EAAY,SAACxiD,EAAGiB,EAAGwhD,QACA11C,IAAjB/M,EAAEuY,QAAQtX,IACVshD,EAAOxhD,KAhBE,qEAgBYrD,QAAQ,YAAakS,SAAS5P,EAAE6V,KAAM,KAAO,IAAM5U,EAAI,IACvEvD,QAAQ,YAAa+kD,GACrB/kD,QAAQ,cAAesC,EAAEuY,QAAQtX,MAI1CjB,EAAE6V,OACF2sC,EAAUxiD,EAAG,EAAG,IAChBwiD,EAAUxiD,EAAG,EAAG,QAChBwiD,EAAUxiD,EAAG,EAAG,IAChBwrB,GAAW,WAAWxrB,EAAE6V,kBAAgB7V,EAAE8V,OAAS,eAAaysC,EAAO9zC,KAAK,aAE5EzO,EAAE0X,QAAU1X,EAAEuY,SAAW3a,EAAQ8kD,UAAY,KAC7Cl3B,GAAW,0BAA0BxrB,EAAE0X,MAAM5H,MAAM,MAAMsC,MAAM,GAAG3D,KAAK,UAE3Ek8B,EAAKoY,UAAYv3B,EAGjBw3B,EAAkB9iD,EAAO9B,SAAU,CAC/B,mDACA,yBACA,sBACA,kBACA,aACA,IACA,8BACA,mBACA,sBACA,kBACA,kBACA,IACA,4BACA,kBACA,kBACA,aACA,yBACA,IACA,iCACA,kBACA,IACA,2BACA,mBACA,qBACA,yBACA,aACA,IACA,0BACA,cACA,IACA,+BACA,cACA,qBACA,uBACA,iCACA,KACFqQ,KAAK,MAAO,CAAEjQ,MAAO,kBAEvBmsC,EAAKsY,MAAMljD,QAAU,CACjB,iCACA,yBACA,yBACA,qBACA,6BACA,0BACA,cACA,gBACA,uBACF0O,KAAK,KAEa,gBAAhB7Q,EAAQslD,MACRN,EAAQO,aAAY,WAChB,IAAM/kD,EAAW8B,EAAO9B,SAClB0vC,EAAO1vC,EAAS0vC,KAClBA,IACI1vC,EAASO,eAAeJ,GACxBuvC,EAAKsV,aAAazY,EAAMvsC,EAASO,eAAeJ,IAEhDuvC,EAAKjuC,aAAa8qC,EAAMmD,EAAKxuC,YAEjC+jD,cAAcT,MAEnB,KAqDHU,CAAUtjD,EAAGqiD,IAUjBkB,OAhDJ,SAAqB7lC,GACZ9f,EAAQ0kD,gBAA6C,SAA3B1kD,EAAQ0kD,eAED,YAA3B1kD,EAAQ0kD,gBAE0B,mBAA3B1kD,EAAQ0kD,gBACtB1kD,EAAQ0kD,eAAe,SAAU5kC,GAjBzC,SAAyBA,GACrB,IAAM9P,EAAO1N,EAAO9B,SAASO,eAAe,sBAAsBF,EAAgBif,IAC9E9P,GACAA,EAAKhO,WAAWE,YAAY8N,GAU5B41C,CAAgB9lC,MC9GtB9f,GCTK,CAEHuwB,mBAAmB,EAGnBs1B,SAAS,EAKTzyC,UAAU,EAGV0yC,MAAM,EAONnmC,MAAO,GAGPzM,OAAO,EAKPgP,eAAe,EAGf6jC,UAAU,EAKVllC,SAAU,GAMVzH,aAAa,EAQbH,KAAM,EAGNyQ,aAAa,EAKbggB,WAAY,KAIZC,WAAY,KAGZjb,QAAS,IDtDjB,GAAIpsB,OAAO+qB,KACP,IAAK,IAAM/Y,MAAOhS,OAAO+qB,KACjB/qB,OAAO+qB,KAAKjtB,eAAekU,MAC3BtU,GAAQsU,IAAOhS,OAAO+qB,KAAK/Y,eEbvBhS,EAAQtC,GAGpBD,EAAYC,EAASolD,EAAsB9iD,SAEZ6M,IAA3BnP,EAAQkjD,iBACRljD,EAAQkjD,eAAiB,yDAAyDpkC,KAAKxc,EAAO0hD,SAASgC,WAS3GhmD,EAAQijD,MAAQjjD,EAAQijD,QAAS,EACjCjjD,EAAQmjD,UAAYnjD,EAAQmjD,YAAa,EAGzCnjD,EAAQimD,KAAOjmD,EAAQimD,OAASjmD,EAAQkjD,eAAiB,IAAO,MAEhEljD,EAAQslD,IAAMtlD,EAAQslD,MAAoC,aAA5BhjD,EAAO0hD,SAASkC,UACd,WAA5B5jD,EAAO0hD,SAASkC,UACY,aAA5B5jD,EAAO0hD,SAASkC,UACf5jD,EAAO0hD,SAASmC,MACb7jD,EAAO0hD,SAASmC,KAAK1kD,OAAS,GAClCzB,EAAQkjD,eAAmC,cACzC,cAEN,IAAM3kC,EAAkB,6CAA6C0nB,KAAK3jC,EAAO0hD,SAASv/B,MACtFlG,IACAve,EAAQue,gBAAkBA,EAAgB,SAGjBpP,IAAzBnP,EAAQikD,eACRjkD,EAAQikD,cAAe,QAGH90C,IAApBnP,EAAQomD,UACRpmD,EAAQomD,SAAU,GAGlBpmD,EAAQmZ,eACRnZ,EAAQoZ,YAAc,OF1B9BitC,CAAkB/jD,OAAQtC,OAElBy3B,QAAUz3B,GAAQy3B,SAAW,GAEjCn1B,OAAOgkD,eACPtmD,GAAQy3B,QAAUz3B,GAAQy3B,QAAQ5zB,OAAOvB,OAAOgkD,eAGpD,IAKIl3B,GACAxtB,GACAyjD,GAPEh4B,YGdU/qB,EAAQtC,GACpB,IAAMQ,EAAW8B,EAAO9B,SAClB6sB,EAAOk5B,KAEbl5B,EAAKrtB,QAAUA,EACf,IAAMoE,EAAcipB,EAAKjpB,YACnBoyB,EAAcgwB,GAAGxmD,EAASqtB,EAAK/oB,QAC/BG,EAAc,IAAI+xB,EACxBpyB,EAAYqiD,eAAehiD,GAC3B4oB,EAAKmJ,YAAcA,EACnBnJ,EAAKuuB,aAAeA,YCxBRvuB,EAAMrtB,GAYlBA,EAAQ8kD,cAAuC,IAArB9kD,EAAQ8kD,SAA2B9kD,EAAQ8kD,SAA4B,gBAAhB9kD,EAAQslD,IAVnE,EAEC,EAUlBtlD,EAAQ0mD,UACT1mD,EAAQ0mD,QAAU,CAAC,CACf3jD,MAAO,SAASL,GACR1C,EAAQ8kD,UAhBD,GAiBP6B,QAAQrC,IAAI5hD,IAGpBI,KAAM,SAASJ,GACP1C,EAAQ8kD,UApBF,GAqBN6B,QAAQrC,IAAI5hD,IAGpBG,KAAM,SAASH,GACP1C,EAAQ8kD,UAxBF,GAyBN6B,QAAQ9jD,KAAKH,IAGrBD,MAAO,SAASC,GACR1C,EAAQ8kD,UA5BD,GA6BP6B,QAAQlkD,MAAMC,OAK9B,IAAK,IAAIW,EAAI,EAAGA,EAAIrD,EAAQ0mD,QAAQjlD,OAAQ4B,IACxCgqB,EAAK/oB,OAAOtB,YAAYhD,EAAQ0mD,QAAQrjD,IDb5CujD,CAAYv5B,EAAMrtB,GAClB,IAAM2kD,EAASkC,GAAevkD,EAAQ+qB,EAAMrtB,GACtC8mD,EAAQz5B,EAAKy5B,MAAQ9mD,EAAQ8mD,gBE1BvBxkD,EAAQtC,EAASsE,GAC7B,IAAIwiD,EAAQ,KACZ,GAAoB,gBAAhB9mD,EAAQslD,IACR,IACIwB,OAAwC,IAAxBxkD,EAAOykD,aAAgC,KAAOzkD,EAAOykD,aACvE,MAAOxmD,IAEb,MAAO,CACHymD,OAAQ,SAASlnC,EAAMskC,EAAcza,EAAYlpC,GAC7C,GAAIqmD,EAAO,CACPxiD,EAAOxB,KAAK,UAAUgd,gBACtB,IACIgnC,EAAMG,QAAQnnC,EAAMrf,GACpBqmD,EAAMG,QAAWnnC,eAAkBskC,GAC/Bza,GACAmd,EAAMG,QAAWnnC,UAAazf,KAAK6/C,UAAUvW,IAEnD,MAAOvnC,GAELkC,EAAO7B,MAAM,mBAAmBqd,wCAI5ConC,OAAQ,SAASpnC,EAAMqkC,EAASxa,GAC5B,IAAMva,EAAY03B,GAASA,EAAMK,QAAQrnC,GACnCsnC,EAAYN,GAASA,EAAMK,QAAWrnC,gBACxC4E,EAAYoiC,GAASA,EAAMK,QAAWrnC,WAK1C,GAHA6pB,EAAaA,GAAc,GAC3BjlB,EAAOA,GAAQ,KAEX0iC,GAAajD,EAAQC,cACpB,IAAIC,KAAKF,EAAQC,cAAciD,YAC5B,IAAIhD,KAAK+C,GAAWC,WACxBhnD,KAAK6/C,UAAUvW,KAAgBjlB,EAE/B,OAAO0K,IFVyBk4B,CAAMhlD,EAAQtC,EAASqtB,EAAK/oB,oBGxBxE,SAASijD,IACL,KAAM,CACFhkD,KAAM,UACNsW,QAAS,qEAIjB,IAAM2tC,EAAiB,CACnBC,aAAc,SAAStO,GAEnB,OADAoO,KACQ,GAEZG,cAAe,SAASvO,GAEpB,OADAoO,KACQ,GAEZI,eAAgB,SAASxO,GAErB,OADAoO,KACQ,IAIhBlkC,EAAiB/B,YAAYkmC,GHG7BI,CAAUv6B,EAAKjpB,aAGXpE,EAAQ4D,WACRypB,EAAKzpB,UAAUyf,iBAAiB/B,YAAYthB,EAAQ4D,WAGxD,IAAMikD,EAAc,oBAEpB,SAASnyC,EAAM2C,GACX,IAAMC,EAAS,GACf,IAAK,IAAMC,KAAQF,EACXA,EAAIjY,eAAemY,KACnBD,EAAOC,GAAQF,EAAIE,IAG3B,OAAOD,EAIX,SAAStU,EAAKuW,EAAMutC,GAChB,IAAMC,EAAY93C,MAAMyC,UAAU8B,MAAM2B,KAAKM,UAAW,GACxD,OAAO,WACH,IAAMpD,EAAO00C,EAAUlkD,OAAOoM,MAAMyC,UAAU8B,MAAM2B,KAAKM,UAAW,IACpE,OAAO8D,EAAKyJ,MAAM8jC,EAASz0C,IAInC,SAAS20C,EAAWre,GAIhB,IAHA,IACI0b,EADE5kD,EAASD,EAASqB,qBAAqB,SAGpCwB,EAAI,EAAGA,EAAI5C,EAAOgB,OAAQ4B,IAE/B,IADAgiD,EAAQ5kD,EAAO4C,IACLE,KAAKsO,MAAMg2C,GAAc,CAC/B,IAAMI,EAAkBvyC,EAAM1V,GAC9BioD,EAAgBte,WAAaA,EAC7B,IAAMua,EAAWmB,EAAMF,WAAa,GACpC8C,EAAgB/jD,SAAW1D,EAASwjD,SAASnkD,KAAKC,QAAQ,OAAQ,IAIlEutB,EAAKq0B,OAAOwC,EAAU+D,EAClBjkD,GAAK,SAACqhD,EAAOjjD,EAAGmX,GACRnX,EACAuiD,EAAOl0C,IAAIrO,EAAG,WAEdijD,EAAM9hD,KAAO,WACT8hD,EAAMhkD,WACNgkD,EAAMhkD,WAAWc,QAAUoX,EAAO6V,IAElCi2B,EAAMF,UAAY5rC,EAAO6V,OAGlC,KAAMi2B,KAKzB,SAAS6C,EAAexnD,EAAOwpB,EAAUi+B,EAAQC,EAAWze,GAExD,IAAMse,EAAkBvyC,EAAM1V,GAC9BD,EAAYkoD,EAAiBvnD,GAC7BunD,EAAgB5H,KAAO3/C,EAAM6C,KAEzBomC,IACAse,EAAgBte,WAAaA,GA6CjCllC,EAAY+8C,SAAS9gD,EAAMb,KAAM,KAAMooD,EAAiB7jD,GACnDq9C,MAAK,SAAAb,IA3CV,SAAiCA,GAC7B,IAAM6B,EAAO7B,EAAW5mC,SAClB8F,EAAO8gC,EAAW18C,SAClBigD,EAAUvD,EAAWuD,QAErBxD,EAAc,CAChBx8C,iBAAkBM,EAAY6qB,QAAQxP,GACtC5b,SAAU4b,EACV09B,aAAc19B,EACd1G,YAAa6uC,EAAgB7uC,aAMjC,GAHAunC,EAAYrH,UAAYqH,EAAYx8C,iBACpCw8C,EAAY9/B,SAAWonC,EAAgBpnC,UAAY8/B,EAAYx8C,iBAE3DggD,EAAS,CACTA,EAAQiE,UAAYA,EAEpB,IAAMh5B,EAAM03B,EAAMI,OAAOpnC,EAAMqkC,EAAS8D,EAAgBte,YACxD,IAAKwe,GAAU/4B,EAGX,OAFA+0B,EAAQkE,OAAQ,OAChBn+B,EAAS,KAAMkF,EAAKqzB,EAAM/hD,EAAOyjD,EAASrkC,GAOlD6kC,EAAOgB,OAAO7lC,GAEdmoC,EAAgB7H,aAAeO,EAC/BtzB,EAAKq0B,OAAOe,EAAMwF,GAAiB,SAAC7lD,EAAGmX,GAC/BnX,GACAA,EAAEvC,KAAOigB,EACToK,EAAS9nB,KAET0kD,EAAME,OAAOtmD,EAAMb,KAAMskD,EAAQC,aAAc6D,EAAgBte,WAAYpwB,EAAO6V,KAClFlF,EAAS,KAAM3Q,EAAO6V,IAAKqzB,EAAM/hD,EAAOyjD,EAASrkC,OAOrDwoC,CAAwB1H,MACzB4D,OAAM,SAAAzoC,GACL4qC,QAAQrC,IAAIvoC,GACZmO,EAASnO,MAKrB,SAASwsC,EAAgBr+B,EAAUi+B,EAAQxe,GACvC,IAAK,IAAItmC,EAAI,EAAGA,EAAIgqB,EAAKm7B,OAAO/mD,OAAQ4B,IACpC6kD,EAAe76B,EAAKm7B,OAAOnlD,GAAI6mB,EAAUi+B,EAAQ96B,EAAKm7B,OAAO/mD,QAAU4B,EAAI,GAAIsmC,GAmIvF,OA3GAtc,EAAKo7B,MAAU,WAMX,OALKp7B,EAAKq7B,YACNr7B,EAAKi4B,IAAM,cArBE,gBAAbj4B,EAAKi4B,MACLj4B,EAAKs7B,WAAapD,aAAY,WACtBl4B,EAAKq7B,YACLjkD,EAAYs/C,iBACZwE,GAAgB,SAACnmD,EAAGgtB,EAAK7uB,EAAGG,EAAOyjD,GAC3B/hD,EACAuiD,EAAOl0C,IAAIrO,EAAGA,EAAEvC,MAAQa,EAAMb,MACvBuvB,GACPg2B,EAAkB9iD,EAAO9B,SAAU4uB,EAAK1uB,SAIrDV,EAAQimD,QAYftjD,KAAK+lD,WAAY,GACV,GAGXr7B,EAAKu7B,QAAU,WAAqE,OAAxDnD,cAAcp4B,EAAKs7B,YAAahmD,KAAK+lD,WAAY,GAAc,GAM3Fr7B,EAAKw7B,+BAAiC,WAClC,IAAMC,EAAQtoD,EAASqB,qBAAqB,QAC5CwrB,EAAKm7B,OAAS,GAEd,IAAK,IAAInlD,EAAI,EAAGA,EAAIylD,EAAMrnD,OAAQ4B,KACT,oBAAjBylD,EAAMzlD,GAAG0lD,KAA8BD,EAAMzlD,GAAG0lD,IAAIl3C,MAAM,eACzDi3C,EAAMzlD,GAAGE,KAAKsO,MAAMg2C,KACrBx6B,EAAKm7B,OAAOrlD,KAAK2lD,EAAMzlD,KASnCgqB,EAAK27B,oBAAsB,WAAM,OAAA,IAAInH,SAAQ,SAACC,EAASC,GACnD10B,EAAKw7B,iCACL/G,QAOJz0B,EAAKsc,WAAa,SAAAsf,GAAU,OAAA57B,EAAK67B,SAAQ,EAAMD,GAAQ,IAEvD57B,EAAK67B,QAAU,SAACf,EAAQxe,EAAYoa,GAIhC,OAHKoE,GAAUpE,KAAsC,IAAnBA,GAC9Bt/C,EAAYs/C,iBAET,IAAIlC,SAAQ,SAACC,EAASC,GACzB,IAAIoH,EACAC,EACAC,EACAC,EACJH,EAAYC,EAAU,IAAI/E,KAKF,KAFxBiF,EAAkBj8B,EAAKm7B,OAAO/mD,SAI1B2nD,EAAU,IAAI/E,KACdgF,EAAoBD,EAAUD,EAC9B97B,EAAK/oB,OAAOxB,KAAK,gDACjBg/C,EAAQ,CACJqH,YACAC,UACAC,oBACAb,OAAQn7B,EAAKm7B,OAAO/mD,UAKxB8mD,GAAgB,SAACnmD,EAAGgtB,EAAK7uB,EAAGG,EAAOyjD,GAC/B,GAAI/hD,EAGA,OAFAuiD,EAAOl0C,IAAIrO,EAAGA,EAAEvC,MAAQa,EAAMb,WAC9BkiD,EAAO3/C,GAGP+hD,EAAQkE,MACRh7B,EAAK/oB,OAAOxB,KAAK,WAAWpC,EAAMb,qBAElCwtB,EAAK/oB,OAAOxB,KAAK,YAAYpC,EAAMb,uBAEvCulD,EAAkB9iD,EAAO9B,SAAU4uB,EAAK1uB,GACxC2sB,EAAK/oB,OAAOxB,KAAK,WAAWpC,EAAMb,uBAAqB,IAAIwkD,KAAS+E,SAM5C,MAHxBE,IAIID,EAAoB,IAAIhF,KAAS8E,EACjC97B,EAAK/oB,OAAOxB,KAAK,uCAAuCumD,QACxDvH,EAAQ,CACJqH,YACAC,UACAC,oBACAb,OAAQn7B,EAAKm7B,OAAO/mD,UAG5B2nD,EAAU,IAAI/E,OACf8D,EAAQxe,GAGfqe,EAAWre,OAInBtc,EAAKk8B,cAAgBvB,EACd36B,EH/PEnK,CAAK5gB,OAAQtC,IAU1B,SAASwpD,GAAgB/G,GACjBA,EAAKv+C,UACLyiD,QAAQ9jD,KAAK4/C,GAEZziD,GAAQijD,OACTrhD,GAAKM,YAAYmjD,WAZzB/iD,OAAO+qB,KAAOA,GAgBVrtB,GAAQomD,UACJ,SAAStnC,KAAKxc,OAAO0hD,SAASv/B,OAC9B4I,GAAKo7B,QAGJzoD,GAAQijD,QACT7zB,GAAM,oCACNxtB,GAAOpB,SAASoB,MAAQpB,SAASqB,qBAAqB,QAAQ,IAC9DwjD,GAAQ7kD,SAASU,cAAc,UAEzBqC,KAAO,WACT8hD,GAAMhkD,WACNgkD,GAAMhkD,WAAWc,QAAUitB,GAE3Bi2B,GAAM/jD,YAAYd,SAASe,eAAe6tB,KAG9CxtB,GAAKN,YAAY+jD,KAErBh4B,GAAKw7B,iCACLx7B,GAAKo8B,iBAAmBp8B,GAAK67B,QAAqB,gBAAb77B,GAAKi4B,KAAuB7D,KAAK+H,GAAiBA"} \ No newline at end of file diff --git a/packages/less/package-lock.json b/packages/less/package-lock.json index 0fed10716..cfd7e22a4 100644 --- a/packages/less/package-lock.json +++ b/packages/less/package-lock.json @@ -1,6 +1,6 @@ { "name": "less", - "version": "3.13.0", + "version": "4.0.0", "lockfileVersion": 1, "requires": true, "dependencies": { @@ -98,6 +98,40 @@ "fastq": "^1.6.0" } }, + "@rollup/plugin-json": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/@rollup/plugin-json/-/plugin-json-4.1.0.tgz", + "integrity": "sha512-yfLbTdNS6amI/2OpmbiBoW12vngr5NW2jCJVZSBEz+H5KfUJZ2M7sDjk0U6GOOdCWFVScShte29o9NezJ53TPw==", + "dev": true, + "requires": { + "@rollup/pluginutils": "^3.0.8" + } + }, + "@rollup/pluginutils": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz", + "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==", + "dev": true, + "requires": { + "@types/estree": "0.0.39", + "estree-walker": "^1.0.1", + "picomatch": "^2.2.2" + }, + "dependencies": { + "@types/estree": { + "version": "0.0.39", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", + "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", + "dev": true + }, + "estree-walker": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz", + "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg==", + "dev": true + } + } + }, "@types/color-name": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", @@ -4306,6 +4340,11 @@ "integrity": "sha1-VjRtR0nXjyNDDKDHE4UK75GqNh0=", "dev": true }, + "parse-node-version": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parse-node-version/-/parse-node-version-1.0.1.tgz", + "integrity": "sha512-3YHlOa/JgH6Mnpr05jP9eDG254US9ek25LyIxZlDItp2iJtwyaXQb57lBYLdT3MowkUFYEV2XXNAYIPlESvJlA==" + }, "parse-passwd": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/parse-passwd/-/parse-passwd-1.0.0.tgz", diff --git a/packages/less/package.json b/packages/less/package.json index 34dfb4e1e..dffd6d776 100644 --- a/packages/less/package.json +++ b/packages/less/package.json @@ -1,6 +1,6 @@ { "name": "less", - "version": "3.13.1", + "version": "4.0.0", "description": "Leaner CSS", "homepage": "http://lesscss.org", "author": { @@ -54,8 +54,9 @@ "source-map": "~0.6.0" }, "devDependencies": { - "@less/test-data": "^3.13.0", - "@less/test-import-module": "^3.13.0", + "@less/test-data": "^4.0.0", + "@less/test-import-module": "^4.0.0", + "@rollup/plugin-json": "^4.1.0", "@typescript-eslint/eslint-plugin": "^3.3.0", "@typescript-eslint/parser": "^3.3.0", "benny": "^3.6.12", @@ -128,6 +129,7 @@ "sourcearchive": "https://github.com/less/less.js/archive/v", "dependencies": { "copy-anything": "^2.0.1", + "parse-node-version": "^1.0.1", "tslib": "^1.10.0" } } diff --git a/packages/less/src/less-browser/file-manager.js b/packages/less/src/less-browser/file-manager.js index 6a74aee99..fa8a8ea92 100644 --- a/packages/less/src/less-browser/file-manager.js +++ b/packages/less/src/less-browser/file-manager.js @@ -7,17 +7,18 @@ let logger; let fileCache = {}; // TODOS - move log somewhere. pathDiff and doing something similar in node. use pathDiff in the other browser file for the initial load -class FileManager extends AbstractFileManager { +const FileManager = function() {} +FileManager.prototype = Object.assign(new AbstractFileManager(), { alwaysMakePathsAbsolute() { return true; - } + }, join(basePath, laterPath) { if (!basePath) { return laterPath; } return this.extractUrlParts(laterPath, basePath).path; - } + }, doXHR(url, type, callback, errback) { const xhr = new XMLHttpRequest(); @@ -55,15 +56,15 @@ class FileManager extends AbstractFileManager { } else { handleResponse(xhr, callback, errback); } - } + }, supports() { return true; - } + }, clearFileCache() { fileCache = {}; - } + }, loadFile(filename, currentDirectory, options, environment) { // TODO: Add prefix support like less-node? @@ -104,7 +105,7 @@ class FileManager extends AbstractFileManager { }); }); } -} +}); export default (opts, log) => { options = opts; diff --git a/packages/less/src/less-browser/plugin-loader.js b/packages/less/src/less-browser/plugin-loader.js index 2ae1d7e75..be9a03dc2 100644 --- a/packages/less/src/less-browser/plugin-loader.js +++ b/packages/less/src/less-browser/plugin-loader.js @@ -6,21 +6,19 @@ import AbstractPluginLoader from '../less/environment/abstract-plugin-loader.js' /** * Browser Plugin Loader */ -class PluginLoader extends AbstractPluginLoader { - constructor(less) { - super(); - - this.less = less; - // Should we shim this.require for browser? Probably not? - } +const PluginLoader = function(less) { + this.less = less; + // Should we shim this.require for browser? Probably not? +}; +PluginLoader.prototype = Object.assign(new AbstractPluginLoader(), { loadPlugin(filename, basePath, context, environment, fileManager) { return new Promise((fulfill, reject) => { fileManager.loadFile(filename, basePath, context, environment) .then(fulfill).catch(reject); }); } -} +}); export default PluginLoader; diff --git a/packages/less/src/less-node/file-manager.js b/packages/less/src/less-node/file-manager.js index 4b9235a91..874f886b0 100644 --- a/packages/less/src/less-node/file-manager.js +++ b/packages/less/src/less-node/file-manager.js @@ -2,14 +2,15 @@ import path from 'path'; import fs from './fs'; import AbstractFileManager from '../less/environment/abstract-file-manager.js'; -class FileManager extends AbstractFileManager { +const FileManager = function() {} +FileManager.prototype = Object.assign(new AbstractFileManager(), { supports() { return true; - } + }, supportsSync() { return true; - } + }, loadFile(filename, currentDirectory, options, environment, callback) { let fullFilename; @@ -26,7 +27,7 @@ class FileManager extends AbstractFileManager { const paths = isAbsoluteFilename ? [''] : [currentDirectory]; - if (options.paths) { paths.push(...options.paths); } + if (options.paths) { paths.push.apply(paths, options.paths); } if (!isAbsoluteFilename && paths.indexOf('.') === -1) { paths.push('.'); } @@ -101,7 +102,7 @@ class FileManager extends AbstractFileManager { fullFilename = extFilename; } } - + const readFileArgs = [fullFilename]; if (!options.rawBuffer) { readFileArgs.push('utf-8'); @@ -121,11 +122,12 @@ class FileManager extends AbstractFileManager { if (e) { filenamesTried.push(isNodeModule ? npmPrefix + fullFilename : fullFilename); return tryPrefix(j + 1); - } + } fulfill({ contents: data, filename: fullFilename}); }); fs.readFile.apply(this, readFileArgs); } + } else { tryPathIndex(i + 1); @@ -136,12 +138,12 @@ class FileManager extends AbstractFileManager { } }(0)); } - } + }, loadFileSync(filename, currentDirectory, options, environment) { options.syncImport = true; return this.loadFile(filename, currentDirectory, options, environment); } -} +}); -export default FileManager; \ No newline at end of file +export default FileManager; diff --git a/packages/less/src/less-node/index.js b/packages/less/src/less-node/index.js index ae08a8952..fec503988 100644 --- a/packages/less/src/less-node/index.js +++ b/packages/less/src/less-node/index.js @@ -2,26 +2,22 @@ import environment from './environment'; import FileManager from './file-manager'; import UrlFileManager from './url-file-manager'; import createFromEnvironment from '../less'; -import lesscHelper from './lessc-helper'; -import PluginLoader from './plugin-loader'; -import fs from './fs'; -import defaultOptions from '../less/default-options'; -import imageSize from './image-size'; - const less = createFromEnvironment(environment, [new FileManager(), new UrlFileManager()]); +import lesscHelper from './lessc-helper'; +import path from 'path'; // allow people to create less with their own environment less.createFromEnvironment = createFromEnvironment; less.lesscHelper = lesscHelper; -less.PluginLoader = PluginLoader; -less.fs = fs; +less.PluginLoader = require('./plugin-loader').default; +less.fs = require('./fs').default; less.FileManager = FileManager; less.UrlFileManager = UrlFileManager; // Set up options -less.options = defaultOptions(); +less.options = require('../less/default-options').default(); // provide image-size functionality -imageSize(less.environment); +require('./image-size').default(less.environment); export default less; diff --git a/packages/less/src/less-node/plugin-loader.js b/packages/less/src/less-node/plugin-loader.js index e55218192..e9be545b7 100644 --- a/packages/less/src/less-node/plugin-loader.js +++ b/packages/less/src/less-node/plugin-loader.js @@ -4,25 +4,23 @@ import AbstractPluginLoader from '../less/environment/abstract-plugin-loader.js' /** * Node Plugin Loader */ -class PluginLoader extends AbstractPluginLoader { - constructor(less) { - super(); - - this.less = less; - this.require = prefix => { - prefix = path.dirname(prefix); - return id => { - const str = id.substr(0, 2); - if (str === '..' || str === './') { - return require(path.join(prefix, id)); - } - else { - return require(id); - } - }; +const PluginLoader = function(less) { + this.less = less; + this.require = prefix => { + prefix = path.dirname(prefix); + return id => { + const str = id.substr(0, 2); + if (str === '..' || str === './') { + return require(path.join(prefix, id)); + } + else { + return require(id); + } }; - } + }; +}; +PluginLoader.prototype = Object.assign(new AbstractPluginLoader(), { loadPlugin(filename, basePath, context, environment, fileManager) { const prefix = filename.slice(0, 1); const explicit = prefix === '.' || prefix === '/' || filename.slice(-3).toLowerCase() === '.js'; @@ -49,13 +47,13 @@ class PluginLoader extends AbstractPluginLoader { reject(err); }); }); - } + }, loadPluginSync(filename, basePath, context, environment, fileManager) { context.syncImport = true; return this.loadPlugin(filename, basePath, context, environment, fileManager); } -} +}); export default PluginLoader; diff --git a/packages/less/src/less-node/url-file-manager.js b/packages/less/src/less-node/url-file-manager.js index 733d78c86..728bc7afa 100644 --- a/packages/less/src/less-node/url-file-manager.js +++ b/packages/less/src/less-node/url-file-manager.js @@ -4,10 +4,11 @@ let request; import AbstractFileManager from '../less/environment/abstract-file-manager.js'; import logger from '../less/logger'; -class UrlFileManager extends AbstractFileManager { +const UrlFileManager = function() {} +UrlFileManager.prototype = Object.assign(new AbstractFileManager(), { supports(filename, currentDirectory, options, environment) { return isUrlRe.test( filename ) || isUrlRe.test(currentDirectory); - } + }, loadFile(filename, currentDirectory, options, environment) { return new Promise((fulfill, reject) => { @@ -41,6 +42,6 @@ class UrlFileManager extends AbstractFileManager { }); }); } -} +}); export default UrlFileManager; diff --git a/packages/less/src/less/constants.js b/packages/less/src/less/constants.js index 3c57c7ec6..d095fc246 100644 --- a/packages/less/src/less/constants.js +++ b/packages/less/src/less/constants.js @@ -2,8 +2,8 @@ export const Math = { ALWAYS: 0, PARENS_DIVISION: 1, - PARENS: 2, - STRICT_LEGACY: 3 + PARENS: 2 + // removed - STRICT_LEGACY: 3 }; export const RewriteUrls = { diff --git a/packages/less/src/less/contexts.js b/packages/less/src/less/contexts.js index 803b8c6c9..e76658833 100644 --- a/packages/less/src/less/contexts.js +++ b/packages/less/src/less/contexts.js @@ -54,111 +54,111 @@ const evalCopyProperties = [ 'rewriteUrls' // option - whether to adjust URL's to be relative ]; -function isPathRelative(path) { - return !/^(?:[a-z-]+:|\/|#)/i.test(path); -} +contexts.Eval = function(options, frames) { + copyFromOriginal(options, this, evalCopyProperties); -function isPathLocalRelative(path) { - return path.charAt(0) === '.'; -} + if (typeof this.paths === 'string') { this.paths = [this.paths]; } -contexts.Eval = class { - constructor(options, frames) { - copyFromOriginal(options, this, evalCopyProperties); + this.frames = frames || []; + this.importantScope = this.importantScope || []; +}; - if (typeof this.paths === 'string') { this.paths = [this.paths]; } +contexts.Eval.prototype.enterCalc = function () { + if (!this.calcStack) { + this.calcStack = []; + } + this.calcStack.push(true); + this.inCalc = true; +}; - this.frames = frames || []; - this.importantScope = this.importantScope || []; +contexts.Eval.prototype.exitCalc = function () { + this.calcStack.pop(); + if (!this.calcStack.length) { this.inCalc = false; - this.mathOn = true; } +}; - enterCalc() { - if (!this.calcStack) { - this.calcStack = []; - } - this.calcStack.push(true); - this.inCalc = true; +contexts.Eval.prototype.inParenthesis = function () { + if (!this.parensStack) { + this.parensStack = []; } + this.parensStack.push(true); +}; - exitCalc() { - this.calcStack.pop(); - if (!this.calcStack.length) { - this.inCalc = false; - } +contexts.Eval.prototype.outOfParenthesis = function () { + this.parensStack.pop(); +}; + +contexts.Eval.prototype.inCalc = false; +contexts.Eval.prototype.mathOn = true; +contexts.Eval.prototype.isMathOn = function (op) { + if (!this.mathOn) { + return false; + } + if (op === '/' && this.math !== Constants.Math.ALWAYS && (!this.parensStack || !this.parensStack.length)) { + return false; } + if (this.math > Constants.Math.PARENS_DIVISION) { + return this.parensStack && this.parensStack.length; + } + return true; +}; - inParenthesis() { - if (!this.parensStack) { - this.parensStack = []; - } - this.parensStack.push(true); - }; +contexts.Eval.prototype.pathRequiresRewrite = function (path) { + const isRelative = this.rewriteUrls === Constants.RewriteUrls.LOCAL ? isPathLocalRelative : isPathRelative; - outOfParenthesis() { - this.parensStack.pop(); - }; + return isRelative(path); +}; - isMathOn(op) { - if (!this.mathOn) { - return false; - } - if (op === '/' && this.math !== Constants.Math.ALWAYS && (!this.parensStack || !this.parensStack.length)) { - return false; - } - if (this.math > Constants.Math.PARENS_DIVISION) { - return this.parensStack && this.parensStack.length; - } - return true; - } +contexts.Eval.prototype.rewritePath = function (path, rootpath) { + let newPath; - pathRequiresRewrite(path) { - const isRelative = this.rewriteUrls === Constants.RewriteUrls.LOCAL ? isPathLocalRelative : isPathRelative; + rootpath = rootpath || ''; + newPath = this.normalizePath(rootpath + path); - return isRelative(path); + // If a path was explicit relative and the rootpath was not an absolute path + // we must ensure that the new path is also explicit relative. + if (isPathLocalRelative(path) && + isPathRelative(rootpath) && + isPathLocalRelative(newPath) === false) { + newPath = `./${newPath}`; } - rewritePath(path, rootpath) { - let newPath; - - rootpath = rootpath || ''; - newPath = this.normalizePath(rootpath + path); + return newPath; +}; - // If a path was explicit relative and the rootpath was not an absolute path - // we must ensure that the new path is also explicit relative. - if (isPathLocalRelative(path) && - isPathRelative(rootpath) && - isPathLocalRelative(newPath) === false) { - newPath = `./${newPath}`; +contexts.Eval.prototype.normalizePath = function (path) { + const segments = path.split('/').reverse(); + let segment; + + path = []; + while (segments.length !== 0) { + segment = segments.pop(); + switch ( segment ) { + case '.': + break; + case '..': + if ((path.length === 0) || (path[path.length - 1] === '..')) { + path.push( segment ); + } else { + path.pop(); + } + break; + default: + path.push(segment); + break; } - - return newPath; } - normalizePath(path) { - const segments = path.split('/').reverse(); - let segment; - - path = []; - while (segments.length !== 0) { - segment = segments.pop(); - switch ( segment ) { - case '.': - break; - case '..': - if ((path.length === 0) || (path[path.length - 1] === '..')) { - path.push( segment ); - } else { - path.pop(); - } - break; - default: - path.push(segment); - break; - } - } + return path.join('/'); +}; - return path.join('/'); - } +function isPathRelative(path) { + return !/^(?:[a-z-]+:|\/|#)/i.test(path); } + +function isPathLocalRelative(path) { + return path.charAt(0) === '.'; +} + +// todo - do the same for the toCSS ? diff --git a/packages/less/src/less/default-options.js b/packages/less/src/less/default-options.js index a87b84333..839762f0e 100644 --- a/packages/less/src/less/default-options.js +++ b/packages/less/src/less/default-options.js @@ -1,68 +1,70 @@ // Export a new default each time -export default () => ({ - /* Inline Javascript - @plugin still allowed */ - javascriptEnabled: false, +export default function() { + return { + /* Inline Javascript - @plugin still allowed */ + javascriptEnabled: false, - /* Outputs a makefile import dependency list to stdout. */ - depends: false, + /* Outputs a makefile import dependency list to stdout. */ + depends: false, - /* (DEPRECATED) Compress using less built-in compression. - * This does an okay job but does not utilise all the tricks of - * dedicated css compression. */ - compress: false, + /* (DEPRECATED) Compress using less built-in compression. + * This does an okay job but does not utilise all the tricks of + * dedicated css compression. */ + compress: false, - /* Runs the less parser and just reports errors without any output. */ - lint: false, + /* Runs the less parser and just reports errors without any output. */ + lint: false, - /* Sets available include paths. - * If the file in an @import rule does not exist at that exact location, - * less will look for it at the location(s) passed to this option. - * You might use this for instance to specify a path to a library which - * you want to be referenced simply and relatively in the less files. */ - paths: [], + /* Sets available include paths. + * If the file in an @import rule does not exist at that exact location, + * less will look for it at the location(s) passed to this option. + * You might use this for instance to specify a path to a library which + * you want to be referenced simply and relatively in the less files. */ + paths: [], - /* color output in the terminal */ - color: true, + /* color output in the terminal */ + color: true, - /* The strictImports controls whether the compiler will allow an @import inside of either - * @media blocks or (a later addition) other selector blocks. - * See: https://github.com/less/less.js/issues/656 */ - strictImports: false, + /* The strictImports controls whether the compiler will allow an @import inside of either + * @media blocks or (a later addition) other selector blocks. + * See: https://github.com/less/less.js/issues/656 */ + strictImports: false, - /* Allow Imports from Insecure HTTPS Hosts */ - insecure: false, + /* Allow Imports from Insecure HTTPS Hosts */ + insecure: false, - /* Allows you to add a path to every generated import and url in your css. - * This does not affect less import statements that are processed, just ones - * that are left in the output css. */ - rootpath: '', + /* Allows you to add a path to every generated import and url in your css. + * This does not affect less import statements that are processed, just ones + * that are left in the output css. */ + rootpath: '', - /* By default URLs are kept as-is, so if you import a file in a sub-directory - * that references an image, exactly the same URL will be output in the css. - * This option allows you to re-write URL's in imported files so that the - * URL is always relative to the base imported file */ - rewriteUrls: false, + /* By default URLs are kept as-is, so if you import a file in a sub-directory + * that references an image, exactly the same URL will be output in the css. + * This option allows you to re-write URL's in imported files so that the + * URL is always relative to the base imported file */ + rewriteUrls: false, - /* How to process math - * 0 always - eagerly try to solve all operations - * 1 parens-division - require parens for division "/" - * 2 parens | strict - require parens for all operations - * 3 strict-legacy - legacy strict behavior (super-strict) - */ - math: 0, + /* How to process math + * 0 always - eagerly try to solve all operations + * 1 parens-division - require parens for division "/" + * 2 parens | strict - require parens for all operations + * 3 strict-legacy - legacy strict behavior (super-strict) + */ + math: 1, - /* Without this option, less attempts to guess at the output unit when it does maths. */ - strictUnits: false, + /* Without this option, less attempts to guess at the output unit when it does maths. */ + strictUnits: false, - /* Effectively the declaration is put at the top of your base Less file, - * meaning it can be used but it also can be overridden if this variable - * is defined in the file. */ - globalVars: null, + /* Effectively the declaration is put at the top of your base Less file, + * meaning it can be used but it also can be overridden if this variable + * is defined in the file. */ + globalVars: null, - /* As opposed to the global variable option, this puts the declaration at the - * end of your base file, meaning it will override anything defined in your Less file. */ - modifyVars: null, + /* As opposed to the global variable option, this puts the declaration at the + * end of your base file, meaning it will override anything defined in your Less file. */ + modifyVars: null, - /* This option allows you to specify a argument to go on to every URL. */ - urlArgs: '' -}); \ No newline at end of file + /* This option allows you to specify a argument to go on to every URL. */ + urlArgs: '' + } +}; \ No newline at end of file diff --git a/packages/less/src/less/environment/abstract-file-manager.js b/packages/less/src/less/environment/abstract-file-manager.js index 873e21d8e..03ca08613 100644 --- a/packages/less/src/less/environment/abstract-file-manager.js +++ b/packages/less/src/less/environment/abstract-file-manager.js @@ -20,28 +20,34 @@ class AbstractFileManager { tryAppendLessExtension(path) { return this.tryAppendExtension(path, '.less'); - }; + } - supportsSync() { return false; } + supportsSync() { + return false; + } - alwaysMakePathsAbsolute() { return false; } + alwaysMakePathsAbsolute() { + return false; + } isPathAbsolute(filename) { return (/^(?:[a-z-]+:|\/|\\|#)/i).test(filename); } + // TODO: pull out / replace? join(basePath, laterPath) { if (!basePath) { return laterPath; } return basePath + laterPath; - }; + } pathDiff(url, baseUrl) { // diff between two paths to create a relative path + const urlParts = this.extractUrlParts(url); - const baseUrlParts = this.extractUrlParts(baseUrl); + const baseUrlParts = this.extractUrlParts(baseUrl); let i; let max; let urlDirectories; @@ -63,7 +69,8 @@ class AbstractFileManager { diff += `${urlDirectories[i]}/`; } return diff; - }; + } + // helper function, not part of API extractUrlParts(url, baseUrl) { // urlParts[1] = protocol://hostname/ OR / @@ -121,7 +128,7 @@ class AbstractFileManager { returner.fileUrl = returner.path + (urlParts[4] || ''); returner.url = returner.fileUrl + (urlParts[5] || ''); return returner; - }; + } } -export default AbstractFileManager; \ No newline at end of file +export default AbstractFileManager; diff --git a/packages/less/src/less/environment/abstract-plugin-loader.js b/packages/less/src/less/environment/abstract-plugin-loader.js index 50caeb4bb..917c24baa 100644 --- a/packages/less/src/less/environment/abstract-plugin-loader.js +++ b/packages/less/src/less/environment/abstract-plugin-loader.js @@ -4,17 +4,14 @@ import LessError from '../less-error'; class AbstractPluginLoader { constructor() { // Implemented by Node.js plugin loader - this.require = () => null + this.require = function() { + return null; + } } evalPlugin(contents, context, imports, pluginOptions, fileInfo) { - let loader; - let registry; - let pluginObj; - let localModule; - let pluginManager; - let filename; - let result; + + let loader, registry, pluginObj, localModule, pluginManager, filename, result; pluginManager = context.pluginManager; @@ -55,7 +52,7 @@ class AbstractPluginLoader { }; registry = functionRegistry.create(); - const registerPlugin = obj => { + const registerPlugin = function(obj) { pluginObj = obj; }; @@ -116,6 +113,7 @@ class AbstractPluginLoader { } return pluginObj; + } trySetOptions(plugin, filename, name, options) { diff --git a/packages/less/src/less/environment/environment.js b/packages/less/src/less/environment/environment.js index 340c8e14b..39de0d315 100644 --- a/packages/less/src/less/environment/environment.js +++ b/packages/less/src/less/environment/environment.js @@ -5,7 +5,7 @@ import logger from '../logger'; -class environment { +class Environment { constructor(externalEnvironment, fileManagers) { this.fileManagers = fileManagers || []; externalEnvironment = externalEnvironment || {}; @@ -56,4 +56,4 @@ class environment { } } -export default environment; +export default Environment; diff --git a/packages/less/src/less/functions/boolean.js b/packages/less/src/less/functions/boolean.js index 981fce8c8..e483bbb23 100644 --- a/packages/less/src/less/functions/boolean.js +++ b/packages/less/src/less/functions/boolean.js @@ -13,6 +13,17 @@ function If(context, condition, trueValue, falseValue) { return condition.eval(context) ? trueValue.eval(context) : (falseValue ? falseValue.eval(context) : new Anonymous); } -If.evalArgs = false +If.evalArgs = false; -export default { boolean, 'if': If }; +function isdefined(context, variable) { + try { + variable.eval(context); + return Keyword.True; + } catch (e) { + return Keyword.False; + } +} + +isdefined.evalArgs = false; + +export default { isdefined, boolean, 'if': If }; diff --git a/packages/less/src/less/functions/color.js b/packages/less/src/less/functions/color.js index ba0e0baf6..f070e1690 100644 --- a/packages/less/src/less/functions/color.js +++ b/packages/less/src/less/functions/color.js @@ -2,6 +2,8 @@ import Dimension from '../tree/dimension'; import Color from '../tree/color'; import Quoted from '../tree/quoted'; import Anonymous from '../tree/anonymous'; +import Expression from '../tree/expression'; +import Operation from '../tree/operation'; let colorFunctions; function clamp(val) { @@ -56,7 +58,27 @@ function scaled(n, size) { } colorFunctions = { rgb: function (r, g, b) { - const color = colorFunctions.rgba(r, g, b, 1.0); + let a = 1 + /** + * Comma-less syntax + * e.g. rgb(0 128 255 / 50%) + */ + if (r instanceof Expression) { + const val = r.value + r = val[0] + g = val[1] + b = val[2] + /** + * @todo - should this be normalized in + * function caller? Or parsed differently? + */ + if (b instanceof Operation) { + const op = b + b = op.operands[0] + a = op.operands[1] + } + } + const color = colorFunctions.rgba(r, g, b, a); if (color) { color.value = 'rgb'; return color; @@ -79,7 +101,20 @@ colorFunctions = { catch (e) {} }, hsl: function (h, s, l) { - const color = colorFunctions.hsla(h, s, l, 1.0); + let a = 1 + if (h instanceof Expression) { + const val = h.value + h = val[0] + s = val[1] + l = val[2] + + if (l instanceof Operation) { + const op = l + l = op.operands[0] + a = op.operands[1] + } + } + const color = colorFunctions.hsla(h, s, l, a); if (color) { color.value = 'hsl'; return color; diff --git a/packages/less/src/less/functions/function-caller.js b/packages/less/src/less/functions/function-caller.js index 346ab82e4..109923f25 100644 --- a/packages/less/src/less/functions/function-caller.js +++ b/packages/less/src/less/functions/function-caller.js @@ -15,36 +15,30 @@ class functionCaller { } call(args) { + if (!(Array.isArray(args))) { + args = [args]; + } const evalArgs = this.func.evalArgs; if (evalArgs !== false) { args = args.map(a => a.eval(this.context)); } + const commentFilter = item => !(item.type === 'Comment'); + // This code is terrible and should be replaced as per this issue... // https://github.com/less/less.js/issues/2477 - if (Array.isArray(args)) { - args = args.filter(item => { - if (item.type === 'Comment') { - return false; - } - return true; - }) - .map(item => { - if (item.type === 'Expression') { - const subNodes = item.value.filter(item => { - if (item.type === 'Comment') { - return false; - } - return true; - }); - if (subNodes.length === 1) { - return subNodes[0]; - } else { - return new Expression(subNodes); - } + args = args + .filter(commentFilter) + .map(item => { + if (item.type === 'Expression') { + const subNodes = item.value.filter(commentFilter); + if (subNodes.length === 1) { + return subNodes[0]; + } else { + return new Expression(subNodes); } - return item; - }); - } + } + return item; + }); if (evalArgs === false) { return this.func(this.context, ...args); diff --git a/packages/less/src/less/functions/list.js b/packages/less/src/less/functions/list.js index 1463a5232..98a4c72c9 100644 --- a/packages/less/src/less/functions/list.js +++ b/packages/less/src/less/functions/list.js @@ -7,6 +7,7 @@ import Ruleset from '../tree/ruleset'; import Selector from '../tree/selector'; import Element from '../tree/element'; import Quote from '../tree/quoted'; +import Value from '../tree/value'; const getItemsFromNode = node => { // handle non-array values as an array of length 1 @@ -21,6 +22,12 @@ export default { _SELF: function(n) { return n; }, + '~': function(...expr) { + if (expr.length === 1) { + return expr[0]; + } + return new Value(expr); + }, extract: function(values, index) { // (1-based index) index = index.value - 1; diff --git a/packages/less/src/less/functions/number.js b/packages/less/src/less/functions/number.js index 2575c9288..f01689472 100644 --- a/packages/less/src/less/functions/number.js +++ b/packages/less/src/less/functions/number.js @@ -57,10 +57,14 @@ const minMax = function (isMin, args) { export default { min: function(...args) { - return minMax(true, args); + try { + return minMax(true, args); + } catch (e) {} }, max: function(...args) { - return minMax(false, args); + try { + return minMax(false, args); + } catch (e) {} }, convert: function (val, unit) { return val.convertTo(unit.value); diff --git a/packages/less/src/less/index.js b/packages/less/src/less/index.js index bb7005466..4873f0b31 100644 --- a/packages/less/src/less/index.js +++ b/packages/less/src/less/index.js @@ -1,48 +1,41 @@ +import Environment from './environment/environment'; import data from './data'; import tree from './tree'; -import Environment from './environment/environment'; import AbstractFileManager from './environment/abstract-file-manager'; import AbstractPluginLoader from './environment/abstract-plugin-loader'; import visitors from './visitors'; import Parser from './parser/parser'; -import Functions from './functions'; +import functions from './functions'; import contexts from './contexts'; -import sourceMapOutput from './source-map-output'; -import sourceMapBuilder from './source-map-builder'; -import parseTree from './parse-tree'; -import importManager from './import-manager'; -import Render from './render'; -import Parse from './parse'; import LessError from './less-error'; import transformTree from './transform-tree'; import * as utils from './utils'; import PluginManager from './plugin-manager'; import logger from './logger'; +import SourceMapOutput from './source-map-output'; +import SourceMapBuilder from './source-map-builder'; +import ParseTree from './parse-tree'; +import ImportManager from './import-manager'; +import Parse from './parse'; +import Render from './render'; +import { version } from '../../package.json'; +import parseVersion from 'parse-node-version'; + +export default function(environment, fileManagers) { + let sourceMapOutput, sourceMapBuilder, parseTree, importManager; -export default (environment, fileManagers) => { - /** - * @todo - * This original code could be improved quite a bit. - * Many classes / modules currently add side-effects / mutations to passed in objects, - * which makes it hard to refactor and reason about. - */ environment = new Environment(environment, fileManagers); + sourceMapOutput = SourceMapOutput(environment); + sourceMapBuilder = SourceMapBuilder(sourceMapOutput, environment); + parseTree = ParseTree(sourceMapBuilder); + importManager = ImportManager(environment); - const SourceMapOutput = sourceMapOutput(environment); - const SourceMapBuilder = sourceMapBuilder(SourceMapOutput, environment); - const ParseTree = parseTree(SourceMapBuilder); - const ImportManager = importManager(environment); - const render = Render(environment, ParseTree, ImportManager); - const parse = Parse(environment, ParseTree, ImportManager); - const functions = Functions(environment); + const render = Render(environment, parseTree, importManager); + const parse = Parse(environment, parseTree, importManager); - /** - * @todo - * This root properties / methods need to be organized. - * It's not clear what should / must be public and why. - */ + const v = parseVersion(`v${version}`); const initial = { - version: [3, 13, 1], + version: [v.major, v.minor, v.patch], data, tree, Environment, @@ -51,12 +44,12 @@ export default (environment, fileManagers) => { environment, visitors, Parser, - functions, + functions: functions(environment), contexts, - SourceMapOutput, - SourceMapBuilder, - ParseTree, - ImportManager, + SourceMapOutput: sourceMapOutput, + SourceMapBuilder: sourceMapBuilder, + ParseTree: parseTree, + ImportManager: importManager, render, parse, LessError, @@ -67,10 +60,14 @@ export default (environment, fileManagers) => { }; // Create a public API - const ctor = t => function (...args) { - return new t(...args); - }; + const ctor = function(t) { + return function() { + const obj = Object.create(t.prototype); + t.apply(obj, Array.prototype.slice.call(arguments, 0)); + return obj; + }; + }; let t; const api = Object.create(initial); for (const n in initial.tree) { diff --git a/packages/less/src/less/less-error.js b/packages/less/src/less/less-error.js index e4100c82e..9bd1aeb5a 100644 --- a/packages/less/src/less/less-error.js +++ b/packages/less/src/less/less-error.js @@ -24,7 +24,7 @@ const anonymousFunc = /(|Function):(\d+):(\d+)/; * @param {Object} fileContentMap - An object with file contents in 'contents' property (like importManager) @todo - move to fileManager? * @param {string} [currentFilename] */ -const LessError = function LessError(e, fileContentMap, currentFilename) { +const LessError = function(e, fileContentMap, currentFilename) { Error.call(this); const filename = e.filename || currentFilename; @@ -35,7 +35,7 @@ const LessError = function LessError(e, fileContentMap, currentFilename) { if (fileContentMap && filename) { const input = fileContentMap.contents[filename]; const loc = utils.getLocation(e.index, input); - const line = loc.line; + var line = loc.line; const col = loc.column; const callLine = e.call && utils.getLocation(e.call, input).line; const lines = input ? input.split('\n') : ''; @@ -62,7 +62,7 @@ const LessError = function LessError(e, fileContentMap, currentFilename) { func(); } catch (e) { const match = e.stack.match(anonymousFunc); - const line = parseInt(match[2]); + var line = parseInt(match[2]); lineAdjust = 1 - line; } @@ -89,7 +89,7 @@ const LessError = function LessError(e, fileContentMap, currentFilename) { }; if (typeof Object.create === 'undefined') { - const F = () => {}; + const F = function () {}; F.prototype = Error.prototype; LessError.prototype = new F(); } else { @@ -105,11 +105,13 @@ LessError.prototype.constructor = LessError; * @param {Object} options * @returns {string} */ -LessError.prototype.toString = function(options = {}) { +LessError.prototype.toString = function(options) { + options = options || {}; + let message = ''; const extract = this.extract || []; let error = []; - let stylize = str => str; + let stylize = function (str) { return str; }; if (options.stylize) { const type = typeof options.stylize; if (type !== 'function') { diff --git a/packages/less/src/less/parse-tree.js b/packages/less/src/less/parse-tree.js index 462de6fd5..44f7deece 100644 --- a/packages/less/src/less/parse-tree.js +++ b/packages/less/src/less/parse-tree.js @@ -2,7 +2,7 @@ import LessError from './less-error'; import transformTree from './transform-tree'; import logger from './logger'; -export default SourceMapBuilder => { +export default function(SourceMapBuilder) { class ParseTree { constructor(root, imports) { this.root = root; diff --git a/packages/less/src/less/parse.js b/packages/less/src/less/parse.js index ec70cb318..931c9a91c 100644 --- a/packages/less/src/less/parse.js +++ b/packages/less/src/less/parse.js @@ -4,7 +4,7 @@ import PluginManager from './plugin-manager'; import LessError from './less-error'; import * as utils from './utils'; -export default (environment, ParseTree, ImportManager) => { +export default function(environment, ParseTree, ImportManager) { const parse = function (input, options, callback) { if (typeof options === 'function') { @@ -17,8 +17,8 @@ export default (environment, ParseTree, ImportManager) => { if (!callback) { const self = this; - return new Promise((resolve, reject) => { - parse.call(self, input, options, (err, output) => { + return new Promise(function (resolve, reject) { + parse.call(self, input, options, function(err, output) { if (err) { reject(err); } else { @@ -61,9 +61,8 @@ export default (environment, ParseTree, ImportManager) => { // Do an async plugin queue like lessc if (options.plugins) { - options.plugins.forEach(plugin => { - let evalResult; - let contents; + options.plugins.forEach(function(plugin) { + let evalResult, contents; if (plugin.fileContent) { contents = plugin.fileContent.replace(/^\uFEFF/, ''); evalResult = pluginManager.Loader.evalPlugin(contents, context, imports, plugin.options, plugin.filename); @@ -78,7 +77,7 @@ export default (environment, ParseTree, ImportManager) => { } new Parser(context, imports, rootFileInfo) - .parse(input, (e, root) => { + .parse(input, function (e, root) { if (e) { return callback(e); } callback(null, root, imports, options); }, options); diff --git a/packages/less/src/less/parser/chunker.js b/packages/less/src/less/parser/chunker.js index 9c35f3f5a..8dae722f6 100644 --- a/packages/less/src/less/parser/chunker.js +++ b/packages/less/src/less/parser/chunker.js @@ -1,5 +1,5 @@ // Split the input into chunks. -export default (input, fail) => { +export default function (input, fail) { const len = input.length; let level = 0; let parenLevel = 0; diff --git a/packages/less/src/less/parser/parser.js b/packages/less/src/less/parser/parser.js index 3f3ea563f..6b8ab9a80 100644 --- a/packages/less/src/less/parser/parser.js +++ b/packages/less/src/less/parser/parser.js @@ -421,7 +421,7 @@ const Parser = function Parser(context, imports, fileInfo) { parserInput.save(); - name = parserInput.$re(/^([\w-]+|%|progid:[\w\.]+)\(/); + name = parserInput.$re(/^([\w-]+|%|~|progid:[\w\.]+)\(/); if (!name) { parserInput.forget(); return; @@ -908,9 +908,9 @@ const Parser = function Parser(context, imports, fileInfo) { return; } - if (inValue && !lookups && !hasParens) { - // This isn't a valid in-value mixin call - parserInput.restore(); + if (!lookups && !hasParens) { + // This isn't a valid mixin call + parserInput.restore('Unrecognized input. Possibly missing \'(\' in mixin call.'); return; } diff --git a/packages/less/src/less/plugin-manager.js b/packages/less/src/less/plugin-manager.js index 977b1c5ee..48002fbcd 100644 --- a/packages/less/src/less/plugin-manager.js +++ b/packages/less/src/less/plugin-manager.js @@ -157,7 +157,7 @@ class PluginManager { let pm; -function PluginManagerFactory(less, newFactory) { +const PluginManagerFactory = function(less, newFactory) { if (newFactory || !pm) { pm = new PluginManager(less); } diff --git a/packages/less/src/less/render.js b/packages/less/src/less/render.js index b03276635..9920d2fd1 100644 --- a/packages/less/src/less/render.js +++ b/packages/less/src/less/render.js @@ -1,6 +1,6 @@ import * as utils from './utils'; -export default (environment, ParseTree, ImportManager) => { +export default function(environment, ParseTree, ImportManager) { const render = function (input, options, callback) { if (typeof options === 'function') { callback = options; @@ -12,8 +12,8 @@ export default (environment, ParseTree, ImportManager) => { if (!callback) { const self = this; - return new Promise((resolve, reject) => { - render.call(self, input, options, (err, output) => { + return new Promise(function (resolve, reject) { + render.call(self, input, options, function(err, output) { if (err) { reject(err); } else { @@ -22,7 +22,7 @@ export default (environment, ParseTree, ImportManager) => { }); }); } else { - this.parse(input, options, (err, root, imports, options) => { + this.parse(input, options, function(err, root, imports, options) { if (err) { return callback(err); } let result; diff --git a/packages/less/src/less/source-map-builder.js b/packages/less/src/less/source-map-builder.js index 853ff538c..53a6860a5 100644 --- a/packages/less/src/less/source-map-builder.js +++ b/packages/less/src/less/source-map-builder.js @@ -1,4 +1,4 @@ -export default (SourceMapOutput, environment) => { +export default function (SourceMapOutput, environment) { class SourceMapBuilder { constructor(options) { this.options = options; diff --git a/packages/less/src/less/source-map-output.js b/packages/less/src/less/source-map-output.js index 9bb014c5c..1878d6f76 100644 --- a/packages/less/src/less/source-map-output.js +++ b/packages/less/src/less/source-map-output.js @@ -1,4 +1,4 @@ -export default environment => { +export default function (environment) { class SourceMapOutput { constructor(options) { this._css = []; @@ -46,16 +46,13 @@ export default environment => { } add(chunk, fileInfo, index, mapLines) { + // ignore adding empty strings if (!chunk) { return; } - let lines; - let sourceLines; - let columns; - let sourceColumns; - let i; + let lines, sourceLines, columns, sourceColumns, i; if (fileInfo && fileInfo.filename) { let inputSource = this._contentsMap[fileInfo.filename]; diff --git a/packages/less/src/less/transform-tree.js b/packages/less/src/less/transform-tree.js index 79eee5064..92479b73c 100644 --- a/packages/less/src/less/transform-tree.js +++ b/packages/less/src/less/transform-tree.js @@ -2,7 +2,8 @@ import contexts from './contexts'; import visitor from './visitors'; import tree from './tree'; -export default (root, options = {}) => { +export default function(root, options) { + options = options || {}; let evaldRoot; let variables = options.variables; const evalEnv = new contexts.Eval(options); @@ -21,7 +22,7 @@ export default (root, options = {}) => { // ) // if (typeof variables === 'object' && !Array.isArray(variables)) { - variables = Object.keys(variables).map(k => { + variables = Object.keys(variables).map(function (k) { let value = variables[k]; if (!(value instanceof tree.Value)) { diff --git a/packages/less/src/less/tree/anonymous.js b/packages/less/src/less/tree/anonymous.js index 1b96e92f4..9c40a9526 100644 --- a/packages/less/src/less/tree/anonymous.js +++ b/packages/less/src/less/tree/anonymous.js @@ -1,5 +1,4 @@ import Node from './node'; -import { extend } from './util'; const Anonymous = function(value, index, currentFileInfo, mapLines, rulesetLike, visibilityInfo) { this.value = value; @@ -11,26 +10,23 @@ const Anonymous = function(value, index, currentFileInfo, mapLines, rulesetLike, this.copyVisibilityInfo(visibilityInfo); } -Anonymous.prototype = new Node(); - -Anonymous.prototype.eval = function() { - return new Anonymous(this.value, this._index, this._fileInfo, this.mapLines, this.rulesetLike, this.visibilityInfo()); -}; - -Anonymous.prototype.compare = function(other) { - return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; -}; - -Anonymous.prototype.isRulesetLike = function() { - return this.rulesetLike; -}; - -Anonymous.prototype.genCSS = function(context, output) { - this.nodeVisible = Boolean(this.value); - if (this.nodeVisible) { - output.add(this.value, this._fileInfo, this._index, this.mapLines); +Anonymous.prototype = Object.assign(new Node(), { + type: 'Anonymous', + eval() { + return new Anonymous(this.value, this._index, this._fileInfo, this.mapLines, this.rulesetLike, this.visibilityInfo()); + }, + compare(other) { + return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; + }, + isRulesetLike() { + return this.rulesetLike; + }, + genCSS(context, output) { + this.nodeVisible = Boolean(this.value); + if (this.nodeVisible) { + output.add(this.value, this._fileInfo, this._index, this.mapLines); + } } -}; +}) -Anonymous.prototype.type = 'Anonymous'; export default Anonymous; diff --git a/packages/less/src/less/tree/assignment.js b/packages/less/src/less/tree/assignment.js index f2a4e19cc..564d9220d 100644 --- a/packages/less/src/less/tree/assignment.js +++ b/packages/less/src/less/tree/assignment.js @@ -3,29 +3,30 @@ import Node from './node'; const Assignment = function(key, val) { this.key = key; this.value = val; -}; +} -Assignment.prototype = new Node(); +Assignment.prototype = Object.assign(new Node(), { + type: 'Assignment', -Assignment.prototype.accept = function(visitor) { - this.value = visitor.visit(this.value); -}; + accept(visitor) { + this.value = visitor.visit(this.value); + }, -Assignment.prototype.eval = function(context) { - if (this.value.eval) { - return new Assignment(this.key, this.value.eval(context)); - } - return this; -}; + eval(context) { + if (this.value.eval) { + return new Assignment(this.key, this.value.eval(context)); + } + return this; + }, -Assignment.prototype.genCSS = function(context, output) { - output.add(`${this.key}=`); - if (this.value.genCSS) { - this.value.genCSS(context, output); - } else { - output.add(this.value); + genCSS(context, output) { + output.add(`${this.key}=`); + if (this.value.genCSS) { + this.value.genCSS(context, output); + } else { + output.add(this.value); + } } -}; +}); -Assignment.prototype.type = 'Assignment'; export default Assignment; diff --git a/packages/less/src/less/tree/atrule.js b/packages/less/src/less/tree/atrule.js index a21650d5a..9b5a07aa0 100644 --- a/packages/less/src/less/tree/atrule.js +++ b/packages/less/src/less/tree/atrule.js @@ -35,129 +35,122 @@ const AtRule = function( this.isRooted = isRooted || false; this.copyVisibilityInfo(visibilityInfo); this.allowRoot = true; -}; - -AtRule.prototype = new Node(); +} + +AtRule.prototype = Object.assign(new Node(), { + type: 'AtRule', + accept(visitor) { + const value = this.value, rules = this.rules; + if (rules) { + this.rules = visitor.visitArray(rules); + } + if (value) { + this.value = visitor.visit(value); + } + }, + + isRulesetLike() { + return this.rules || !this.isCharset(); + }, + + isCharset() { + return '@charset' === this.name; + }, + + genCSS(context, output) { + const value = this.value, rules = this.rules; + output.add(this.name, this.fileInfo(), this.getIndex()); + if (value) { + output.add(' '); + value.genCSS(context, output); + } + if (rules) { + this.outputRuleset(context, output, rules); + } else { + output.add(';'); + } + }, -AtRule.prototype.accept = function(visitor) { - const value = this.value; - const rules = this.rules; - if (rules) { - this.rules = visitor.visitArray(rules); - } - if (value) { - this.value = visitor.visit(value); - } -}; - -AtRule.prototype.isRulesetLike = function() { - return this.rules || !this.isCharset(); -}; - -AtRule.prototype.isCharset = function() { - return '@charset' === this.name; -}; - -AtRule.prototype.genCSS = function(context, output) { - const value = this.value; - const rules = this.rules; - output.add(this.name, this.fileInfo(), this.getIndex()); - if (value) { - output.add(' '); - value.genCSS(context, output); - } - if (rules) { - this.outputRuleset(context, output, rules); - } else { - output.add(';'); - } -}; - -AtRule.prototype.eval = function(context) { - let mediaPathBackup; - let mediaBlocksBackup; - let value = this.value; - let rules = this.rules; - - // media stored inside other atrule should not bubble over it - // backpup media bubbling information - mediaPathBackup = context.mediaPath; - mediaBlocksBackup = context.mediaBlocks; - // deleted media bubbling information - context.mediaPath = []; - context.mediaBlocks = []; - - if (value) { - value = value.eval(context); - } - if (rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - rules = [rules[0].eval(context)]; - rules[0].root = true; - } - // restore media bubbling information - context.mediaPath = mediaPathBackup; - context.mediaBlocks = mediaBlocksBackup; - - return new AtRule(this.name, value, rules, - this.getIndex(), this.fileInfo(), this.debugInfo, this.isRooted, this.visibilityInfo()); -}; - -AtRule.prototype.variable = function(name) { - if (this.rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - return Ruleset.prototype.variable.call(this.rules[0], name); - } -}; + eval(context) { + let mediaPathBackup, mediaBlocksBackup, value = this.value, rules = this.rules; -AtRule.prototype.find = function(...args) { - if (this.rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - return Ruleset.prototype.find.apply(this.rules[0], args); - } -}; + // media stored inside other atrule should not bubble over it + // backpup media bubbling information + mediaPathBackup = context.mediaPath; + mediaBlocksBackup = context.mediaBlocks; + // deleted media bubbling information + context.mediaPath = []; + context.mediaBlocks = []; -AtRule.prototype.rulesets = function() { - if (this.rules) { - // assuming that there is only one rule at this point - that is how parser constructs the rule - return Ruleset.prototype.rulesets.apply(this.rules[0]); - } -}; + if (value) { + value = value.eval(context); + } + if (rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + rules = [rules[0].eval(context)]; + rules[0].root = true; + } + // restore media bubbling information + context.mediaPath = mediaPathBackup; + context.mediaBlocks = mediaBlocksBackup; + + return new AtRule(this.name, value, rules, + this.getIndex(), this.fileInfo(), this.debugInfo, this.isRooted, this.visibilityInfo()); + }, + + variable(name) { + if (this.rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + return Ruleset.prototype.variable.call(this.rules[0], name); + } + }, -AtRule.prototype.outputRuleset = function(context, output, rules) { - const ruleCnt = rules.length; - let i; - context.tabLevel = (context.tabLevel | 0) + 1; + find() { + if (this.rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + return Ruleset.prototype.find.apply(this.rules[0], arguments); + } + }, - // Compressed - if (context.compress) { - output.add('{'); - for (i = 0; i < ruleCnt; i++) { - rules[i].genCSS(context, output); + rulesets() { + if (this.rules) { + // assuming that there is only one rule at this point - that is how parser constructs the rule + return Ruleset.prototype.rulesets.apply(this.rules[0]); + } + }, + + outputRuleset(context, output, rules) { + const ruleCnt = rules.length; + let i; + context.tabLevel = (context.tabLevel | 0) + 1; + + // Compressed + if (context.compress) { + output.add('{'); + for (i = 0; i < ruleCnt; i++) { + rules[i].genCSS(context, output); + } + output.add('}'); + context.tabLevel--; + return; } - output.add('}'); - context.tabLevel--; - return; - } - // Non-compressed - const tabSetStr = `\n${Array(context.tabLevel).join(' ')}`; - - const tabRuleStr = `${tabSetStr} `; - if (!ruleCnt) { - output.add(` {${tabSetStr}}`); - } else { - output.add(` {${tabRuleStr}`); - rules[0].genCSS(context, output); - for (i = 1; i < ruleCnt; i++) { - output.add(tabRuleStr); - rules[i].genCSS(context, output); + // Non-compressed + const tabSetStr = `\n${Array(context.tabLevel).join(' ')}`, tabRuleStr = `${tabSetStr} `; + if (!ruleCnt) { + output.add(` {${tabSetStr}}`); + } else { + output.add(` {${tabRuleStr}`); + rules[0].genCSS(context, output); + for (i = 1; i < ruleCnt; i++) { + output.add(tabRuleStr); + rules[i].genCSS(context, output); + } + output.add(`${tabSetStr}}`); } - output.add(`${tabSetStr}}`); - } - context.tabLevel--; -}; + context.tabLevel--; + } +}); -AtRule.prototype.type = 'AtRule'; export default AtRule; diff --git a/packages/less/src/less/tree/attribute.js b/packages/less/src/less/tree/attribute.js index f94b08375..cc78b4b22 100644 --- a/packages/less/src/less/tree/attribute.js +++ b/packages/less/src/less/tree/attribute.js @@ -4,29 +4,30 @@ const Attribute = function(key, op, value) { this.key = key; this.op = op; this.value = value; -}; +} -Attribute.prototype = new Node(); +Attribute.prototype = Object.assign(new Node(), { + type: 'Attribute', -Attribute.prototype.eval = function(context) { - return new Attribute(this.key.eval ? this.key.eval(context) : this.key, - this.op, (this.value && this.value.eval) ? this.value.eval(context) : this.value); -}; + eval(context) { + return new Attribute(this.key.eval ? this.key.eval(context) : this.key, + this.op, (this.value && this.value.eval) ? this.value.eval(context) : this.value); + }, -Attribute.prototype.genCSS = function(context, output) { - output.add(this.toCSS(context)); -}; + genCSS(context, output) { + output.add(this.toCSS(context)); + }, -Attribute.prototype.toCSS = function(context) { - let value = this.key.toCSS ? this.key.toCSS(context) : this.key; + toCSS(context) { + let value = this.key.toCSS ? this.key.toCSS(context) : this.key; - if (this.op) { - value += this.op; - value += (this.value.toCSS ? this.value.toCSS(context) : this.value); - } + if (this.op) { + value += this.op; + value += (this.value.toCSS ? this.value.toCSS(context) : this.value); + } - return `[${value}]`; -}; + return `[${value}]`; + } +}); -Attribute.prototype.type = 'Attribute'; export default Attribute; diff --git a/packages/less/src/less/tree/call.js b/packages/less/src/less/tree/call.js index 36e25683a..61ed0173c 100644 --- a/packages/less/src/less/tree/call.js +++ b/packages/less/src/less/tree/call.js @@ -13,61 +13,63 @@ const Call = function(name, args, index, currentFileInfo) { this._fileInfo = currentFileInfo; } -Call.prototype = new Node(); +Call.prototype = Object.assign(new Node(), { + type: 'Call', -Call.prototype.accept = function(visitor) { - if (this.args) { - this.args = visitor.visitArray(this.args); - } -}; - -// -// When evaluating a function call, -// we either find the function in the functionRegistry, -// in which case we call it, passing the evaluated arguments, -// if this returns null or we cannot find the function, we -// simply print it out as it appeared originally [2]. -// -// The reason why we evaluate the arguments, is in the case where -// we try to pass a variable to a function, like: `saturate(@color)`. -// The function should receive the value, not the variable. -// -Call.prototype.eval = function(context) { - /** - * Turn off math for calc(), and switch back on for evaluating nested functions - */ - const currentMathContext = context.mathOn; - context.mathOn = !this.calc; - if (this.calc || context.inCalc) { - context.enterCalc(); - } + accept(visitor) { + if (this.args) { + this.args = visitor.visitArray(this.args); + } + }, - const exitCalc = () => { + // + // When evaluating a function call, + // we either find the function in the functionRegistry, + // in which case we call it, passing the evaluated arguments, + // if this returns null or we cannot find the function, we + // simply print it out as it appeared originally [2]. + // + // The reason why we evaluate the arguments, is in the case where + // we try to pass a variable to a function, like: `saturate(@color)`. + // The function should receive the value, not the variable. + // + eval(context) { + /** + * Turn off math for calc(), and switch back on for evaluating nested functions + */ + const currentMathContext = context.mathOn; + context.mathOn = !this.calc; if (this.calc || context.inCalc) { - context.exitCalc(); + context.enterCalc(); } - context.mathOn = currentMathContext; - }; - let result; - const funcCaller = new FunctionCaller(this.name, context, this.getIndex(), this.fileInfo()); + const exitCalc = () => { + if (this.calc || context.inCalc) { + context.exitCalc(); + } + context.mathOn = currentMathContext; + }; + + let result; + const funcCaller = new FunctionCaller(this.name, context, this.getIndex(), this.fileInfo()); - if (funcCaller.isValid()) { - try { - result = funcCaller.call(this.args); - exitCalc(); - } catch (e) { - if (e.hasOwnProperty('line') && e.hasOwnProperty('column')) { - throw e + if (funcCaller.isValid()) { + try { + result = funcCaller.call(this.args); + exitCalc(); + } catch (e) { + if (e.hasOwnProperty('line') && e.hasOwnProperty('column')) { + throw e; + } + throw { + type: e.type || 'Runtime', + message: `Error evaluating function \`${this.name}\`${e.message ? `: ${e.message}` : ''}`, + index: this.getIndex(), + filename: this.fileInfo().filename, + line: e.lineNumber, + column: e.columnNumber + }; } - throw { - type: e.type || 'Runtime', - message: `error evaluating function \`${this.name}\`${e.message ? `: ${e.message}` : ''}`, - index: this.getIndex(), - filename: this.fileInfo().filename, - line: e.lineNumber, - column: e.columnNumber - }; } if (result !== null && result !== undefined) { @@ -86,26 +88,25 @@ Call.prototype.eval = function(context) { result._fileInfo = this._fileInfo; return result; } - } - const args = this.args.map(a => a.eval(context)); - exitCalc(); + const args = this.args.map(a => a.eval(context)); + exitCalc(); - return new Call(this.name, args, this.getIndex(), this.fileInfo()); -}; + return new Call(this.name, args, this.getIndex(), this.fileInfo()); + }, -Call.prototype.genCSS = function(context, output) { - output.add(`${this.name}(`, this.fileInfo(), this.getIndex()); + genCSS(context, output) { + output.add(`${this.name}(`, this.fileInfo(), this.getIndex()); - for (let i = 0; i < this.args.length; i++) { - this.args[i].genCSS(context, output); - if (i + 1 < this.args.length) { - output.add(', '); + for (let i = 0; i < this.args.length; i++) { + this.args[i].genCSS(context, output); + if (i + 1 < this.args.length) { + output.add(', '); + } } - } - output.add(')'); -}; + output.add(')'); + } +}); -Call.prototype.type = 'Call'; export default Call; diff --git a/packages/less/src/less/tree/color.js b/packages/less/src/less/tree/color.js index 89cda98c8..df068a59f 100644 --- a/packages/less/src/less/tree/color.js +++ b/packages/less/src/less/tree/color.js @@ -16,7 +16,7 @@ const Color = function(rgb, a, originalForm) { this.rgb = rgb; } else if (rgb.length >= 6) { this.rgb = []; - rgb.match(/.{2}/g).map((c, i) => { + rgb.match(/.{2}/g).map(function (c, i) { if (i < 3) { self.rgb.push(parseInt(c, 16)); } else { @@ -25,7 +25,7 @@ const Color = function(rgb, a, originalForm) { }); } else { this.rgb = []; - rgb.split('').map((c, i) => { + rgb.split('').map(function (c, i) { if (i < 3) { self.rgb.push(parseInt(c + c, 16)); } else { @@ -37,196 +37,179 @@ const Color = function(rgb, a, originalForm) { if (typeof originalForm !== 'undefined') { this.value = originalForm; } -}; - -Color.prototype = new Node(); - -Color.prototype.luma = function() { - let r = this.rgb[0] / 255; - let g = this.rgb[1] / 255; - let b = this.rgb[2] / 255; - - r = (r <= 0.03928) ? r / 12.92 : Math.pow(((r + 0.055) / 1.055), 2.4); - g = (g <= 0.03928) ? g / 12.92 : Math.pow(((g + 0.055) / 1.055), 2.4); - b = (b <= 0.03928) ? b / 12.92 : Math.pow(((b + 0.055) / 1.055), 2.4); - - return 0.2126 * r + 0.7152 * g + 0.0722 * b; -}; - -Color.prototype.genCSS = function(context, output) { - output.add(this.toCSS(context)); -}; - -Color.prototype.toCSS = function(context, doNotCompress) { - const compress = context && context.compress && !doNotCompress; - let color; - let alpha; - let colorFunction; - let args = []; - - // `value` is set if this color was originally - // converted from a named color string so we need - // to respect this and try to output named color too. - alpha = this.fround(context, this.alpha); +} - if (this.value) { - if (this.value.indexOf('rgb') === 0) { - if (alpha < 1) { - colorFunction = 'rgba'; - } - } else if (this.value.indexOf('hsl') === 0) { - if (alpha < 1) { - colorFunction = 'hsla'; +Color.prototype = Object.assign(new Node(), { + type: 'Color', + + luma() { + let r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255; + + r = (r <= 0.03928) ? r / 12.92 : Math.pow(((r + 0.055) / 1.055), 2.4); + g = (g <= 0.03928) ? g / 12.92 : Math.pow(((g + 0.055) / 1.055), 2.4); + b = (b <= 0.03928) ? b / 12.92 : Math.pow(((b + 0.055) / 1.055), 2.4); + + return 0.2126 * r + 0.7152 * g + 0.0722 * b; + }, + + genCSS(context, output) { + output.add(this.toCSS(context)); + }, + + toCSS(context, doNotCompress) { + const compress = context && context.compress && !doNotCompress; + let color; + let alpha; + let colorFunction; + let args = []; + + // `value` is set if this color was originally + // converted from a named color string so we need + // to respect this and try to output named color too. + alpha = this.fround(context, this.alpha); + + if (this.value) { + if (this.value.indexOf('rgb') === 0) { + if (alpha < 1) { + colorFunction = 'rgba'; + } + } else if (this.value.indexOf('hsl') === 0) { + if (alpha < 1) { + colorFunction = 'hsla'; + } else { + colorFunction = 'hsl'; + } } else { - colorFunction = 'hsl'; + return this.value; } } else { - return this.value; - } - } else { - if (alpha < 1) { - colorFunction = 'rgba'; + if (alpha < 1) { + colorFunction = 'rgba'; + } } - } - switch (colorFunction) { - case 'rgba': - args = this.rgb.map(c => clamp(Math.round(c), 255)).concat(clamp(alpha, 1)); - break; - case 'hsla': - args.push(clamp(alpha, 1)); - case 'hsl': - color = this.toHSL(); - args = [ - this.fround(context, color.h), - `${this.fround(context, color.s * 100)}%`, - `${this.fround(context, color.l * 100)}%` - ].concat(args); - } + switch (colorFunction) { + case 'rgba': + args = this.rgb.map(function (c) { + return clamp(Math.round(c), 255); + }).concat(clamp(alpha, 1)); + break; + case 'hsla': + args.push(clamp(alpha, 1)); + case 'hsl': + color = this.toHSL(); + args = [ + this.fround(context, color.h), + `${this.fround(context, color.s * 100)}%`, + `${this.fround(context, color.l * 100)}%` + ].concat(args); + } - if (colorFunction) { - // Values are capped between `0` and `255`, rounded and zero-padded. - return `${colorFunction}(${args.join(`,${compress ? '' : ' '}`)})`; - } + if (colorFunction) { + // Values are capped between `0` and `255`, rounded and zero-padded. + return `${colorFunction}(${args.join(`,${compress ? '' : ' '}`)})`; + } - color = this.toRGB(); + color = this.toRGB(); - if (compress) { - const splitcolor = color.split(''); + if (compress) { + const splitcolor = color.split(''); - // Convert color to short format - if (splitcolor[1] === splitcolor[2] && splitcolor[3] === splitcolor[4] && splitcolor[5] === splitcolor[6]) { - color = `#${splitcolor[1]}${splitcolor[3]}${splitcolor[5]}`; + // Convert color to short format + if (splitcolor[1] === splitcolor[2] && splitcolor[3] === splitcolor[4] && splitcolor[5] === splitcolor[6]) { + color = `#${splitcolor[1]}${splitcolor[3]}${splitcolor[5]}`; + } } - } - return color; -}; + return color; + }, -// -// Operations have to be done per-channel, if not, -// channels will spill onto each other. Once we have -// our result, in the form of an integer triplet, -// we create a new Color node to hold the result. -// -Color.prototype.operate = function(context, op, other) { - const rgb = new Array(3); - const alpha = this.alpha * (1 - other.alpha) + other.alpha; - for (let c = 0; c < 3; c++) { - rgb[c] = this._operate(context, op, this.rgb[c], other.rgb[c]); - } - return new Color(rgb, alpha); -}; + // + // Operations have to be done per-channel, if not, + // channels will spill onto each other. Once we have + // our result, in the form of an integer triplet, + // we create a new Color node to hold the result. + // + operate(context, op, other) { + const rgb = new Array(3); + const alpha = this.alpha * (1 - other.alpha) + other.alpha; + for (let c = 0; c < 3; c++) { + rgb[c] = this._operate(context, op, this.rgb[c], other.rgb[c]); + } + return new Color(rgb, alpha); + }, -Color.prototype.toRGB = function() { - return toHex(this.rgb); -}; + toRGB() { + return toHex(this.rgb); + }, -Color.prototype.toHSL = function() { - const r = this.rgb[0] / 255; - const g = this.rgb[1] / 255; - const b = this.rgb[2] / 255; - const a = this.alpha; - const max = Math.max(r, g, b); - const min = Math.min(r, g, b); - let h; - let s; - const l = (max + min) / 2; - const d = max - min; - - if (max === min) { - h = s = 0; - } else { - s = l > 0.5 ? d / (2 - max - min) : d / (max + min); + toHSL() { + const r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255, a = this.alpha; - switch (max) { - case r: h = (g - b) / d + (g < b ? 6 : 0); break; - case g: h = (b - r) / d + 2; break; - case b: h = (r - g) / d + 4; break; - } - h /= 6; - } - return { h: h * 360, s, l, a }; -}; + const max = Math.max(r, g, b), min = Math.min(r, g, b); + let h; + let s; + const l = (max + min) / 2; + const d = max - min; -// Adapted from http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript -Color.prototype.toHSV = function() { - const r = this.rgb[0] / 255; - const g = this.rgb[1] / 255; - const b = this.rgb[2] / 255; - const a = this.alpha; - const max = Math.max(r, g, b); - const min = Math.min(r, g, b); - let h; - let s; - const v = max; - - const d = max - min; - if (max === 0) { - s = 0; - } else { - s = d / max; - } + if (max === min) { + h = s = 0; + } else { + s = l > 0.5 ? d / (2 - max - min) : d / (max + min); - if (max === min) { - h = 0; - } else { - switch (max) { - case r: h = (g - b) / d + (g < b ? 6 : 0); break; - case g: h = (b - r) / d + 2; break; - case b: h = (r - g) / d + 4; break; + switch (max) { + case r: h = (g - b) / d + (g < b ? 6 : 0); break; + case g: h = (b - r) / d + 2; break; + case b: h = (r - g) / d + 4; break; + } + h /= 6; } - h /= 6; - } - return { h: h * 360, s, v, a }; -}; + return { h: h * 360, s, l, a }; + }, -Color.prototype.toARGB = function() { - return toHex([this.alpha * 255].concat(this.rgb)); -}; - -Color.prototype.compare = function(x) { - return (x.rgb && - x.rgb[0] === this.rgb[0] && - x.rgb[1] === this.rgb[1] && - x.rgb[2] === this.rgb[2] && - x.alpha === this.alpha) ? 0 : undefined; -}; + // Adapted from http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript + toHSV() { + const r = this.rgb[0] / 255, g = this.rgb[1] / 255, b = this.rgb[2] / 255, a = this.alpha; -Color.prototype.type = 'Color'; + const max = Math.max(r, g, b), min = Math.min(r, g, b); + let h; + let s; + const v = max; -function clamp(v, max) { - return Math.min(Math.max(v, 0), max); -} + const d = max - min; + if (max === 0) { + s = 0; + } else { + s = d / max; + } -function toHex(v) { - return `#${v.map(c => { - c = clamp(Math.round(c), 255); - return (c < 16 ? '0' : '') + c.toString(16); - }).join('')}`; -} + if (max === min) { + h = 0; + } else { + switch (max) { + case r: h = (g - b) / d + (g < b ? 6 : 0); break; + case g: h = (b - r) / d + 2; break; + case b: h = (r - g) / d + 4; break; + } + h /= 6; + } + return { h: h * 360, s, v, a }; + }, + + toARGB() { + return toHex([this.alpha * 255].concat(this.rgb)); + }, + + compare(x) { + return (x.rgb && + x.rgb[0] === this.rgb[0] && + x.rgb[1] === this.rgb[1] && + x.rgb[2] === this.rgb[2] && + x.alpha === this.alpha) ? 0 : undefined; + } +}); -Color.fromKeyword = keyword => { +Color.fromKeyword = function(keyword) { let c; const key = keyword.toLowerCase(); if (colors.hasOwnProperty(key)) { @@ -242,4 +225,15 @@ Color.fromKeyword = keyword => { } }; +function clamp(v, max) { + return Math.min(Math.max(v, 0), max); +} + +function toHex(v) { + return `#${v.map(function (c) { + c = clamp(Math.round(c), 255); + return (c < 16 ? '0' : '') + c.toString(16); + }).join('')}`; +} + export default Color; diff --git a/packages/less/src/less/tree/combinator.js b/packages/less/src/less/tree/combinator.js index c6625c168..a98347699 100644 --- a/packages/less/src/less/tree/combinator.js +++ b/packages/less/src/less/tree/combinator.js @@ -13,15 +13,15 @@ const Combinator = function(value) { this.value = value ? value.trim() : ''; this.emptyOrWhitespace = this.value === ''; } -}; - -Combinator.prototype = new Node(); +} -Combinator.prototype.genCSS = function(context, output) { - const spaceOrEmpty = (context.compress || _noSpaceCombinators[this.value]) ? '' : ' '; - output.add(spaceOrEmpty + this.value + spaceOrEmpty); -}; +Combinator.prototype = Object.assign(new Node(), { + type: 'Combinator', -Combinator.prototype.type = 'Combinator'; + genCSS(context, output) { + const spaceOrEmpty = (context.compress || _noSpaceCombinators[this.value]) ? '' : ' '; + output.add(spaceOrEmpty + this.value + spaceOrEmpty); + } +}); export default Combinator; diff --git a/packages/less/src/less/tree/comment.js b/packages/less/src/less/tree/comment.js index 80e6b76ad..ce18c4e58 100644 --- a/packages/less/src/less/tree/comment.js +++ b/packages/less/src/less/tree/comment.js @@ -7,21 +7,22 @@ const Comment = function(value, isLineComment, index, currentFileInfo) { this._index = index; this._fileInfo = currentFileInfo; this.allowRoot = true; -}; +} -Comment.prototype = new Node(); +Comment.prototype = Object.assign(new Node(), { + type: 'Comment', -Comment.prototype.genCSS = function(context, output) { - if (this.debugInfo) { - output.add(getDebugInfo(context, this), this.fileInfo(), this.getIndex()); - } - output.add(this.value); -}; + genCSS(context, output) { + if (this.debugInfo) { + output.add(getDebugInfo(context, this), this.fileInfo(), this.getIndex()); + } + output.add(this.value); + }, -Comment.prototype.isSilent = function(context) { - const isCompressed = context.compress && this.value[2] !== '!'; - return this.isLineComment || isCompressed; -}; + isSilent(context) { + const isCompressed = context.compress && this.value[2] !== '!'; + return this.isLineComment || isCompressed; + } +}); -Comment.prototype.type = 'Comment'; export default Comment; diff --git a/packages/less/src/less/tree/condition.js b/packages/less/src/less/tree/condition.js index b4208d074..4ae3beb43 100644 --- a/packages/less/src/less/tree/condition.js +++ b/packages/less/src/less/tree/condition.js @@ -8,34 +8,35 @@ const Condition = function(op, l, r, i, negate) { this.negate = negate; }; -Condition.prototype = new Node(); +Condition.prototype = Object.assign(new Node(), { + type: 'Condition', -Condition.prototype.accept = function(visitor) { - this.lvalue = visitor.visit(this.lvalue); - this.rvalue = visitor.visit(this.rvalue); -} + accept(visitor) { + this.lvalue = visitor.visit(this.lvalue); + this.rvalue = visitor.visit(this.rvalue); + }, -Condition.prototype.eval = function(context) { - const result = ((op, a, b) => { - switch (op) { - case 'and': return a && b; - case 'or': return a || b; - default: - switch (Node.compare(a, b)) { - case -1: - return op === '<' || op === '=<' || op === '<='; - case 0: - return op === '=' || op === '>=' || op === '=<' || op === '<='; - case 1: - return op === '>' || op === '>='; - default: - return false; - } - } - })(this.op, this.lvalue.eval(context), this.rvalue.eval(context)); + eval(context) { + const result = (function (op, a, b) { + switch (op) { + case 'and': return a && b; + case 'or': return a || b; + default: + switch (Node.compare(a, b)) { + case -1: + return op === '<' || op === '=<' || op === '<='; + case 0: + return op === '=' || op === '>=' || op === '=<' || op === '<='; + case 1: + return op === '>' || op === '>='; + default: + return false; + } + } + })(this.op, this.lvalue.eval(context), this.rvalue.eval(context)); - return this.negate ? !result : result; -}; + return this.negate ? !result : result; + } +}); -Condition.prototype.type = 'Condition'; export default Condition; diff --git a/packages/less/src/less/tree/debug-info.js b/packages/less/src/less/tree/debug-info.js index 71424c8dd..e23472190 100644 --- a/packages/less/src/less/tree/debug-info.js +++ b/packages/less/src/less/tree/debug-info.js @@ -1,35 +1,38 @@ -const debugInfo = (context, ctx, lineSeparator) => { - let result = ''; - if (context.dumpLineNumbers && !context.compress) { - switch (context.dumpLineNumbers) { - case 'comments': - result = debugInfo.asComment(ctx); - break; - case 'mediaquery': - result = debugInfo.asMediaQuery(ctx); - break; - case 'all': - result = debugInfo.asComment(ctx) + (lineSeparator || '') + debugInfo.asMediaQuery(ctx); - break; +class debugInfo { + constructor(context, ctx, lineSeparator) { + let result = ''; + if (context.dumpLineNumbers && !context.compress) { + switch (context.dumpLineNumbers) { + case 'comments': + result = debugInfo.asComment(ctx); + break; + case 'mediaquery': + result = debugInfo.asMediaQuery(ctx); + break; + case 'all': + result = debugInfo.asComment(ctx) + (lineSeparator || '') + debugInfo.asMediaQuery(ctx); + break; + } } + return result; } - return result; -}; -debugInfo.asComment = ctx => ctx.debugInfo ? `/* line ${ctx.debugInfo.lineNumber}, ${ctx.debugInfo.fileName} */\n` : ''; - -debugInfo.asMediaQuery = ctx => { - if (!ctx.debugInfo) { return ''; } - let filenameWithProtocol = ctx.debugInfo.fileName; - if (!/^[a-z]+:\/\//i.test(filenameWithProtocol)) { - filenameWithProtocol = `file://${filenameWithProtocol}`; + static asComment(ctx) { + return `/* line ${ctx.debugInfo.lineNumber}, ${ctx.debugInfo.fileName} */\n`; } - return `@media -sass-debug-info{filename{font-family:${filenameWithProtocol.replace(/([.:\/\\])/g, a => { - if (a == '\\') { - a = '\/'; + + static asMediaQuery(ctx) { + let filenameWithProtocol = ctx.debugInfo.fileName; + if (!/^[a-z]+:\/\//i.test(filenameWithProtocol)) { + filenameWithProtocol = `file://${filenameWithProtocol}`; } - return `\\${a}`; - })}}line{font-family:\\00003${ctx.debugInfo.lineNumber}}}\n`; -}; + return `@media -sass-debug-info{filename{font-family:${filenameWithProtocol.replace(/([.:\/\\])/g, function (a) { + if (a == '\\') { + a = '\/'; + } + return `\\${a}`; + })}}line{font-family:\\00003${ctx.debugInfo.lineNumber}}}\n`; + } +} export default debugInfo; diff --git a/packages/less/src/less/tree/declaration.js b/packages/less/src/less/tree/declaration.js index e6d1c79fa..9291f495e 100644 --- a/packages/less/src/less/tree/declaration.js +++ b/packages/less/src/less/tree/declaration.js @@ -5,6 +5,16 @@ import Anonymous from './anonymous'; import * as Constants from '../constants'; const MATH = Constants.Math; +function evalName(context, name) { + let value = ''; + let i; + const n = name.length; + const output = {add: function (s) {value += s;}}; + for (i = 0; i < n; i++) { + name[i].eval(context).genCSS(context, output); + } + return value; +} const Declaration = function(name, value, important, merge, index, currentFileInfo, inline, variable) { this.name = name; @@ -20,94 +30,80 @@ const Declaration = function(name, value, important, merge, index, currentFileIn this.setParent(this.value, this); }; -Declaration.prototype = new Node(); +Declaration.prototype = Object.assign(new Node(), { + type: 'Declaration', -Declaration.prototype.genCSS = function(context, output) { - output.add(this.name + (context.compress ? ':' : ': '), this.fileInfo(), this.getIndex()); - try { - this.value.genCSS(context, output); - } - catch (e) { - e.index = this._index; - e.filename = this._fileInfo.filename; - throw e; - } - output.add(this.important + ((this.inline || (context.lastRule && context.compress)) ? '' : ';'), this._fileInfo, this._index); -} - -Declaration.prototype.eval = function(context) { - let mathBypass = false; - let prevMath; - let name = this.name; - let evaldValue; - let variable = this.variable; - if (typeof name !== 'string') { - // expand 'primitive' name directly to get - // things faster (~10% for benchmark.less): - name = (name.length === 1) && (name[0] instanceof Keyword) ? - name[0].value : evalName(context, name); - variable = false; // never treat expanded interpolation as new variable name - } - - // @todo remove when parens-division is default - if (name === 'font' && context.math === MATH.ALWAYS) { - mathBypass = true; - prevMath = context.math; - context.math = MATH.PARENS_DIVISION; - } - try { - context.importantScope.push({}); - evaldValue = this.value.eval(context); - - if (!this.variable && evaldValue.type === 'DetachedRuleset') { - throw { message: 'Rulesets cannot be evaluated on a property.', - index: this.getIndex(), filename: this.fileInfo().filename }; + genCSS(context, output) { + output.add(this.name + (context.compress ? ':' : ': '), this.fileInfo(), this.getIndex()); + try { + this.value.genCSS(context, output); } - let important = this.important; - const importantResult = context.importantScope.pop(); - if (!important && importantResult.important) { - important = importantResult.important; + catch (e) { + e.index = this._index; + e.filename = this._fileInfo.filename; + throw e; } + output.add(this.important + ((this.inline || (context.lastRule && context.compress)) ? '' : ';'), this._fileInfo, this._index); + }, - return new Declaration(name, - evaldValue, - important, - this.merge, - this.getIndex(), this.fileInfo(), this.inline, - variable); - } - catch (e) { - if (typeof e.index !== 'number') { - e.index = this.getIndex(); - e.filename = this.fileInfo().filename; + eval(context) { + let mathBypass = false, prevMath, name = this.name, evaldValue, variable = this.variable; + if (typeof name !== 'string') { + // expand 'primitive' name directly to get + // things faster (~10% for benchmark.less): + name = (name.length === 1) && (name[0] instanceof Keyword) ? + name[0].value : evalName(context, name); + variable = false; // never treat expanded interpolation as new variable name } - throw e; - } - finally { - if (mathBypass) { - context.math = prevMath; + + // @todo remove when parens-division is default + if (name === 'font' && context.math === MATH.ALWAYS) { + mathBypass = true; + prevMath = context.math; + context.math = MATH.PARENS_DIVISION; } - } -}; + try { + context.importantScope.push({}); + evaldValue = this.value.eval(context); -Declaration.prototype.makeImportant = function() { - return new Declaration(this.name, - this.value, - '!important', - this.merge, - this.getIndex(), this.fileInfo(), this.inline); -}; + if (!this.variable && evaldValue.type === 'DetachedRuleset') { + throw { message: 'Rulesets cannot be evaluated on a property.', + index: this.getIndex(), filename: this.fileInfo().filename }; + } + let important = this.important; + const importantResult = context.importantScope.pop(); + if (!important && importantResult.important) { + important = importantResult.important; + } -function evalName(context, name) { - let value = ''; - let i; - const n = name.length; - const output = {add: function (s) {value += s;}}; - for (i = 0; i < n; i++) { - name[i].eval(context).genCSS(context, output); + return new Declaration(name, + evaldValue, + important, + this.merge, + this.getIndex(), this.fileInfo(), this.inline, + variable); + } + catch (e) { + if (typeof e.index !== 'number') { + e.index = this.getIndex(); + e.filename = this.fileInfo().filename; + } + throw e; + } + finally { + if (mathBypass) { + context.math = prevMath; + } + } + }, + + makeImportant() { + return new Declaration(this.name, + this.value, + '!important', + this.merge, + this.getIndex(), this.fileInfo(), this.inline); } - return value; -} +}); -Declaration.prototype.type = 'Declaration'; export default Declaration; \ No newline at end of file diff --git a/packages/less/src/less/tree/detached-ruleset.js b/packages/less/src/less/tree/detached-ruleset.js index cd399a19e..de5d91535 100644 --- a/packages/less/src/less/tree/detached-ruleset.js +++ b/packages/less/src/less/tree/detached-ruleset.js @@ -8,21 +8,22 @@ const DetachedRuleset = function(ruleset, frames) { this.setParent(this.ruleset, this); }; -DetachedRuleset.prototype = new Node(); +DetachedRuleset.prototype = Object.assign(new Node(), { + type: 'DetachedRuleset', + evalFirst: true, -DetachedRuleset.prototype.accept = function(visitor) { - this.ruleset = visitor.visit(this.ruleset); -}; + accept(visitor) { + this.ruleset = visitor.visit(this.ruleset); + }, -DetachedRuleset.prototype.eval = function(context) { - const frames = this.frames || utils.copyArray(context.frames); - return new DetachedRuleset(this.ruleset, frames); -}; + eval(context) { + const frames = this.frames || utils.copyArray(context.frames); + return new DetachedRuleset(this.ruleset, frames); + }, -DetachedRuleset.prototype.callEval = function(context) { - return this.ruleset.eval(this.frames ? new contexts.Eval(context, this.frames.concat(context.frames)) : context); -}; + callEval(context) { + return this.ruleset.eval(this.frames ? new contexts.Eval(context, this.frames.concat(context.frames)) : context); + } +}); -DetachedRuleset.prototype.type = 'DetachedRuleset'; -DetachedRuleset.prototype.evalFirst = true; export default DetachedRuleset; diff --git a/packages/less/src/less/tree/dimension.js b/packages/less/src/less/tree/dimension.js index 40eae04c6..80e4a0607 100644 --- a/packages/less/src/less/tree/dimension.js +++ b/packages/less/src/less/tree/dimension.js @@ -16,162 +16,160 @@ const Dimension = function(value, unit) { this.setParent(this.unit, this); }; -Dimension.prototype = new Node(); +Dimension.prototype = Object.assign(new Node(), { + type: 'Dimension', -Dimension.prototype.accept = function(visitor) { - this.unit = visitor.visit(this.unit); -}; - -Dimension.prototype.eval = function(context) { - return this; -}; - -Dimension.prototype.toColor = function() { - return new Color([this.value, this.value, this.value]); -}; + accept(visitor) { + this.unit = visitor.visit(this.unit); + }, -Dimension.prototype.genCSS = function(context, output) { - if ((context && context.strictUnits) && !this.unit.isSingular()) { - throw new Error(`Multiple units in dimension. Correct the units or use the unit function. Bad unit: ${this.unit.toString()}`); - } - - const value = this.fround(context, this.value); - let strValue = String(value); + eval(context) { + return this; + }, - if (value !== 0 && value < 0.000001 && value > -0.000001) { - // would be output 1e-6 etc. - strValue = value.toFixed(20).replace(/0+$/, ''); - } - - if (context && context.compress) { - // Zero values doesn't need a unit - if (value === 0 && this.unit.isLength()) { - output.add(strValue); - return; - } + toColor() { + return new Color([this.value, this.value, this.value]); + }, - // Float values doesn't need a leading zero - if (value > 0 && value < 1) { - strValue = (strValue).substr(1); + genCSS(context, output) { + if ((context && context.strictUnits) && !this.unit.isSingular()) { + throw new Error(`Multiple units in dimension. Correct the units or use the unit function. Bad unit: ${this.unit.toString()}`); } - } - - output.add(strValue); - this.unit.genCSS(context, output); -}; -// In an operation between two Dimensions, -// we default to the first Dimension's unit, -// so `1px + 2` will yield `3px`. -Dimension.prototype.operate = function(context, op, other) { - /* jshint noempty:false */ - let value = this._operate(context, op, this.value, other.value); + const value = this.fround(context, this.value); + let strValue = String(value); - let unit = this.unit.clone(); + if (value !== 0 && value < 0.000001 && value > -0.000001) { + // would be output 1e-6 etc. + strValue = value.toFixed(20).replace(/0+$/, ''); + } - if (op === '+' || op === '-') { - if (unit.numerator.length === 0 && unit.denominator.length === 0) { - unit = other.unit.clone(); - if (this.unit.backupUnit) { - unit.backupUnit = this.unit.backupUnit; + if (context && context.compress) { + // Zero values doesn't need a unit + if (value === 0 && this.unit.isLength()) { + output.add(strValue); + return; } - } else if (other.unit.numerator.length === 0 && unit.denominator.length === 0) { - // do nothing - } else { - other = other.convertTo(this.unit.usedUnits()); - if (context.strictUnits && other.unit.toString() !== unit.toString()) { - throw new Error(`Incompatible units. Change the units or use the unit function. ` + - `Bad units: '${unit.toString()}' and '${other.unit.toString()}'.`); + // Float values doesn't need a leading zero + if (value > 0 && value < 1) { + strValue = (strValue).substr(1); } - - value = this._operate(context, op, this.value, other.value); } - } else if (op === '*') { - unit.numerator = unit.numerator.concat(other.unit.numerator).sort(); - unit.denominator = unit.denominator.concat(other.unit.denominator).sort(); - unit.cancel(); - } else if (op === '/') { - unit.numerator = unit.numerator.concat(other.unit.denominator).sort(); - unit.denominator = unit.denominator.concat(other.unit.numerator).sort(); - unit.cancel(); - } - return new Dimension(value, unit); -}; -Dimension.prototype.compare = function(other) { - let a; - let b; + output.add(strValue); + this.unit.genCSS(context, output); + }, + + // In an operation between two Dimensions, + // we default to the first Dimension's unit, + // so `1px + 2` will yield `3px`. + operate(context, op, other) { + /* jshint noempty:false */ + let value = this._operate(context, op, this.value, other.value), unit = this.unit.clone(); + + if (op === '+' || op === '-') { + if (unit.numerator.length === 0 && unit.denominator.length === 0) { + unit = other.unit.clone(); + if (this.unit.backupUnit) { + unit.backupUnit = this.unit.backupUnit; + } + } else if (other.unit.numerator.length === 0 && unit.denominator.length === 0) { + // do nothing + } else { + other = other.convertTo(this.unit.usedUnits()); - if (!(other instanceof Dimension)) { - return undefined; - } + if (context.strictUnits && other.unit.toString() !== unit.toString()) { + throw new Error(`Incompatible units. Change the units or use the unit function. ` + + `Bad units: '${unit.toString()}' and '${other.unit.toString()}'.`); + } - if (this.unit.isEmpty() || other.unit.isEmpty()) { - a = this; - b = other; - } else { - a = this.unify(); - b = other.unify(); - if (a.unit.compare(b.unit) !== 0) { - return undefined; + value = this._operate(context, op, this.value, other.value); + } + } else if (op === '*') { + unit.numerator = unit.numerator.concat(other.unit.numerator).sort(); + unit.denominator = unit.denominator.concat(other.unit.denominator).sort(); + unit.cancel(); + } else if (op === '/') { + unit.numerator = unit.numerator.concat(other.unit.denominator).sort(); + unit.denominator = unit.denominator.concat(other.unit.numerator).sort(); + unit.cancel(); } - } + return new Dimension(value, unit); + }, - return Node.numericCompare(a.value, b.value); -}; + compare(other) { + let a, b; -Dimension.prototype.unify = function() { - return this.convertTo({ length: 'px', duration: 's', angle: 'rad' }); -}; + if (!(other instanceof Dimension)) { + return undefined; + } -Dimension.prototype.convertTo = function(conversions) { - let value = this.value; - const unit = this.unit.clone(); - let i; - let groupName; - let group; - let targetUnit; - let derivedConversions = {}; - let applyUnit; - - if (typeof conversions === 'string') { - for (i in unitConversions) { - if (unitConversions[i].hasOwnProperty(conversions)) { - derivedConversions = {}; - derivedConversions[i] = conversions; + if (this.unit.isEmpty() || other.unit.isEmpty()) { + a = this; + b = other; + } else { + a = this.unify(); + b = other.unify(); + if (a.unit.compare(b.unit) !== 0) { + return undefined; } } - conversions = derivedConversions; - } - applyUnit = (atomicUnit, denominator) => { - /* jshint loopfunc:true */ - if (group.hasOwnProperty(atomicUnit)) { - if (denominator) { - value = value / (group[atomicUnit] / group[targetUnit]); - } else { - value = value * (group[atomicUnit] / group[targetUnit]); - } - return targetUnit; + return Node.numericCompare(a.value, b.value); + }, + + unify() { + return this.convertTo({ length: 'px', duration: 's', angle: 'rad' }); + }, + + convertTo(conversions) { + let value = this.value; + const unit = this.unit.clone(); + let i; + let groupName; + let group; + let targetUnit; + let derivedConversions = {}; + let applyUnit; + + if (typeof conversions === 'string') { + for (i in unitConversions) { + if (unitConversions[i].hasOwnProperty(conversions)) { + derivedConversions = {}; + derivedConversions[i] = conversions; + } + } + conversions = derivedConversions; } + applyUnit = function (atomicUnit, denominator) { + /* jshint loopfunc:true */ + if (group.hasOwnProperty(atomicUnit)) { + if (denominator) { + value = value / (group[atomicUnit] / group[targetUnit]); + } else { + value = value * (group[atomicUnit] / group[targetUnit]); + } + + return targetUnit; + } - return atomicUnit; - }; + return atomicUnit; + }; - for (groupName in conversions) { - if (conversions.hasOwnProperty(groupName)) { - targetUnit = conversions[groupName]; - group = unitConversions[groupName]; + for (groupName in conversions) { + if (conversions.hasOwnProperty(groupName)) { + targetUnit = conversions[groupName]; + group = unitConversions[groupName]; - unit.map(applyUnit); + unit.map(applyUnit); + } } - } - unit.cancel(); + unit.cancel(); - return new Dimension(value, unit); -}; + return new Dimension(value, unit); + } +}); -Dimension.prototype.type = 'Dimension'; export default Dimension; diff --git a/packages/less/src/less/tree/element.js b/packages/less/src/less/tree/element.js index 552e4d467..4331fbc44 100644 --- a/packages/less/src/less/tree/element.js +++ b/packages/less/src/less/tree/element.js @@ -18,54 +18,56 @@ const Element = function(combinator, value, isVariable, index, currentFileInfo, this._fileInfo = currentFileInfo; this.copyVisibilityInfo(visibilityInfo); this.setParent(this.combinator, this); -}; +} -Element.prototype = new Node(); +Element.prototype = Object.assign(new Node(), { + type: 'Element', -Element.prototype.accept = function(visitor) { - const value = this.value; - this.combinator = visitor.visit(this.combinator); - if (typeof value === 'object') { - this.value = visitor.visit(value); - } -}; + accept(visitor) { + const value = this.value; + this.combinator = visitor.visit(this.combinator); + if (typeof value === 'object') { + this.value = visitor.visit(value); + } + }, -Element.prototype.eval = function(context) { - return new Element(this.combinator, - this.value.eval ? this.value.eval(context) : this.value, - this.isVariable, - this.getIndex(), - this.fileInfo(), this.visibilityInfo()); -}; + eval(context) { + return new Element(this.combinator, + this.value.eval ? this.value.eval(context) : this.value, + this.isVariable, + this.getIndex(), + this.fileInfo(), this.visibilityInfo()); + }, -Element.prototype.clone = function() { - return new Element(this.combinator, - this.value, - this.isVariable, - this.getIndex(), - this.fileInfo(), this.visibilityInfo()); -}; + clone() { + return new Element(this.combinator, + this.value, + this.isVariable, + this.getIndex(), + this.fileInfo(), this.visibilityInfo()); + }, -Element.prototype.genCSS = function(context, output) { - output.add(this.toCSS(context), this.fileInfo(), this.getIndex()); -}; + genCSS(context, output) { + output.add(this.toCSS(context), this.fileInfo(), this.getIndex()); + }, -Element.prototype.toCSS = function(context = {}) { - let value = this.value; - const firstSelector = context.firstSelector; - if (value instanceof Paren) { - // selector in parens should not be affected by outer selector - // flags (breaks only interpolated selectors - see #1973) - context.firstSelector = true; - } - value = value.toCSS ? value.toCSS(context) : value; - context.firstSelector = firstSelector; - if (value === '' && this.combinator.value.charAt(0) === '&') { - return ''; - } else { - return this.combinator.toCSS(context) + value; + toCSS(context) { + context = context || {}; + let value = this.value; + const firstSelector = context.firstSelector; + if (value instanceof Paren) { + // selector in parens should not be affected by outer selector + // flags (breaks only interpolated selectors - see #1973) + context.firstSelector = true; + } + value = value.toCSS ? value.toCSS(context) : value; + context.firstSelector = firstSelector; + if (value === '' && this.combinator.value.charAt(0) === '&') { + return ''; + } else { + return this.combinator.toCSS(context) + value; + } } -}; +}); -Element.prototype.type = 'Element'; export default Element; diff --git a/packages/less/src/less/tree/expression.js b/packages/less/src/less/tree/expression.js index c0d38a0a2..bbbacc80f 100644 --- a/packages/less/src/less/tree/expression.js +++ b/packages/less/src/less/tree/expression.js @@ -13,60 +13,61 @@ const Expression = function(value, noSpacing) { } }; -Expression.prototype = new Node(); +Expression.prototype = Object.assign(new Node(), { + type: 'Expression', -Expression.prototype.accept = function(visitor) { - this.value = visitor.visitArray(this.value); -}; - -Expression.prototype.eval = function(context) { - let returnValue; - const mathOn = context.isMathOn(); + accept(visitor) { + this.value = visitor.visitArray(this.value); + }, - const inParenthesis = this.parens && - (context.math !== MATH.STRICT_LEGACY || !this.parensInOp); + eval(context) { + let returnValue; + const mathOn = context.isMathOn(); + const inParenthesis = this.parens; - let doubleParen = false; - if (inParenthesis) { - context.inParenthesis(); - } - if (this.value.length > 1) { - returnValue = new Expression(this.value.map(e => { - if (!e.eval) { - return e; + let doubleParen = false; + if (inParenthesis) { + context.inParenthesis(); + } + if (this.value.length > 1) { + returnValue = new Expression(this.value.map(function (e) { + if (!e.eval) { + return e; + } + return e.eval(context); + }), this.noSpacing); + } else if (this.value.length === 1) { + if (this.value[0].parens && !this.value[0].parensInOp && !context.inCalc) { + doubleParen = true; } - return e.eval(context); - }), this.noSpacing); - } else if (this.value.length === 1) { - if (this.value[0].parens && !this.value[0].parensInOp && !context.inCalc) { - doubleParen = true; + returnValue = this.value[0].eval(context); + } else { + returnValue = this; } - returnValue = this.value[0].eval(context); - } else { - returnValue = this; - } - if (inParenthesis) { - context.outOfParenthesis(); - } - if (this.parens && this.parensInOp && !mathOn && !doubleParen - && (!(returnValue instanceof Dimension))) { - returnValue = new Paren(returnValue); - } - return returnValue; -}; + if (inParenthesis) { + context.outOfParenthesis(); + } + if (this.parens && this.parensInOp && !mathOn && !doubleParen + && (!(returnValue instanceof Dimension))) { + returnValue = new Paren(returnValue); + } + return returnValue; + }, -Expression.prototype.genCSS = function(context, output) { - for (let i = 0; i < this.value.length; i++) { - this.value[i].genCSS(context, output); - if (!this.noSpacing && i + 1 < this.value.length) { - output.add(' '); + genCSS(context, output) { + for (let i = 0; i < this.value.length; i++) { + this.value[i].genCSS(context, output); + if (!this.noSpacing && i + 1 < this.value.length) { + output.add(' '); + } } - } -}; + }, -Expression.prototype.throwAwayComments = function() { - this.value = this.value.filter(v => !(v instanceof Comment)); -}; + throwAwayComments() { + this.value = this.value.filter(function(v) { + return !(v instanceof Comment); + }); + } +}); -Expression.prototype.type = 'Expression'; export default Expression; diff --git a/packages/less/src/less/tree/extend.js b/packages/less/src/less/tree/extend.js index d2418bdd3..6e10246bf 100644 --- a/packages/less/src/less/tree/extend.js +++ b/packages/less/src/less/tree/extend.js @@ -24,43 +24,39 @@ const Extend = function(selector, option, index, currentFileInfo, visibilityInfo this.setParent(this.selector, this); }; -Extend.prototype = new Node(); - -Extend.prototype.accept = function(visitor) { - this.selector = visitor.visit(this.selector); -}; - -Extend.prototype.eval = function(context) { - return new Extend(this.selector.eval(context), this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); -}; - -Extend.prototype.clone = function(context) { - return new Extend(this.selector, this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); -}; - -// it concatenates (joins) all selectors in selector array -Extend.prototype.findSelfSelectors = function(selectors) { - let selfElements = []; - let i; - let selectorElements; - - for (i = 0; i < selectors.length; i++) { - selectorElements = selectors[i].elements; - // duplicate the logic in genCSS function inside the selector node. - // future TODO - move both logics into the selector joiner visitor - if (i > 0 && selectorElements.length && selectorElements[0].combinator.value === '') { - selectorElements[0].combinator.value = ' '; +Extend.prototype = Object.assign(new Node(), { + type: 'Extend', + + accept(visitor) { + this.selector = visitor.visit(this.selector); + }, + + eval(context) { + return new Extend(this.selector.eval(context), this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + }, + + clone(context) { + return new Extend(this.selector, this.option, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + }, + + // it concatenates (joins) all selectors in selector array + findSelfSelectors(selectors) { + let selfElements = [], i, selectorElements; + + for (i = 0; i < selectors.length; i++) { + selectorElements = selectors[i].elements; + // duplicate the logic in genCSS function inside the selector node. + // future TODO - move both logics into the selector joiner visitor + if (i > 0 && selectorElements.length && selectorElements[0].combinator.value === '') { + selectorElements[0].combinator.value = ' '; + } + selfElements = selfElements.concat(selectors[i].elements); } - selfElements = selfElements.concat(selectors[i].elements); - } - this.selfSelectors = [new Selector(selfElements)]; - this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo()); -}; + this.selfSelectors = [new Selector(selfElements)]; + this.selfSelectors[0].copyVisibilityInfo(this.visibilityInfo()); + } +}); -/** - * Used with the extend visitor - */ Extend.next_id = 0; -Extend.prototype.type = 'Extend'; export default Extend; diff --git a/packages/less/src/less/tree/import.js b/packages/less/src/less/tree/import.js index cf19cdabe..00cfc7037 100644 --- a/packages/less/src/less/tree/import.js +++ b/packages/less/src/less/tree/import.js @@ -38,147 +38,148 @@ const Import = function(path, features, options, index, currentFileInfo, visibil this.copyVisibilityInfo(visibilityInfo); this.setParent(this.features, this); this.setParent(this.path, this); -} - -Import.prototype = new Node(); - -Import.prototype.accept = function(visitor) { - if (this.features) { - this.features = visitor.visit(this.features); - } - this.path = visitor.visit(this.path); - if (!this.options.isPlugin && !this.options.inline && this.root) { - this.root = visitor.visit(this.root); - } }; -Import.prototype.genCSS = function(context, output) { - if (this.css && this.path._fileInfo.reference === undefined) { - output.add('@import ', this._fileInfo, this._index); - this.path.genCSS(context, output); +Import.prototype = Object.assign(new Node(), { + type: 'Import', + + accept(visitor) { if (this.features) { - output.add(' '); - this.features.genCSS(context, output); + this.features = visitor.visit(this.features); } - output.add(';'); - } -}; - -Import.prototype.getPath = function() { - return (this.path instanceof URL) ? - this.path.value.value : this.path.value; -}; - -Import.prototype.isVariableImport = function() { - let path = this.path; - if (path instanceof URL) { - path = path.value; - } - if (path instanceof Quoted) { - return path.containsVariables(); - } + this.path = visitor.visit(this.path); + if (!this.options.isPlugin && !this.options.inline && this.root) { + this.root = visitor.visit(this.root); + } + }, + + genCSS(context, output) { + if (this.css && this.path._fileInfo.reference === undefined) { + output.add('@import ', this._fileInfo, this._index); + this.path.genCSS(context, output); + if (this.features) { + output.add(' '); + this.features.genCSS(context, output); + } + output.add(';'); + } + }, - return true; -}; + getPath() { + return (this.path instanceof URL) ? + this.path.value.value : this.path.value; + }, -Import.prototype.evalForImport = function(context) { - let path = this.path; + isVariableImport() { + let path = this.path; + if (path instanceof URL) { + path = path.value; + } + if (path instanceof Quoted) { + return path.containsVariables(); + } - if (path instanceof URL) { - path = path.value; - } + return true; + }, - return new Import(path.eval(context), this.features, this.options, this._index, this._fileInfo, this.visibilityInfo()); -}; + evalForImport(context) { + let path = this.path; -Import.prototype.evalPath = function(context) { - const path = this.path.eval(context); - const fileInfo = this._fileInfo; - - if (!(path instanceof URL)) { - // Add the rootpath if the URL requires a rewrite - const pathValue = path.value; - if (fileInfo && - pathValue && - context.pathRequiresRewrite(pathValue)) { - path.value = context.rewritePath(pathValue, fileInfo.rootpath); - } else { - path.value = context.normalizePath(path.value); + if (path instanceof URL) { + path = path.value; } - } - return path; -}; + return new Import(path.eval(context), this.features, this.options, this._index, this._fileInfo, this.visibilityInfo()); + }, + + evalPath(context) { + const path = this.path.eval(context); + const fileInfo = this._fileInfo; + + if (!(path instanceof URL)) { + // Add the rootpath if the URL requires a rewrite + const pathValue = path.value; + if (fileInfo && + pathValue && + context.pathRequiresRewrite(pathValue)) { + path.value = context.rewritePath(pathValue, fileInfo.rootpath); + } else { + path.value = context.normalizePath(path.value); + } + } -Import.prototype.eval = function(context) { - const result = this.doEval(context); - if (this.options.reference || this.blocksVisibility()) { - if (result.length || result.length === 0) { - result.forEach(node => { - node.addVisibilityBlock(); + return path; + }, + + eval(context) { + const result = this.doEval(context); + if (this.options.reference || this.blocksVisibility()) { + if (result.length || result.length === 0) { + result.forEach(function (node) { + node.addVisibilityBlock(); + } + ); + } else { + result.addVisibilityBlock(); } - ); - } else { - result.addVisibilityBlock(); } - } - return result; -}; + return result; + }, + + doEval(context) { + let ruleset; + let registry; + const features = this.features && this.features.eval(context); + + if (this.options.isPlugin) { + if (this.root && this.root.eval) { + try { + this.root.eval(context); + } + catch (e) { + e.message = 'Plugin error during evaluation'; + throw new LessError(e, this.root.imports, this.root.filename); + } + } + registry = context.frames[0] && context.frames[0].functionRegistry; + if ( registry && this.root && this.root.functions ) { + registry.addMultiple( this.root.functions ); + } -Import.prototype.doEval = function(context) { - let ruleset; - let registry; - const features = this.features && this.features.eval(context); + return []; + } - if (this.options.isPlugin) { - if (this.root && this.root.eval) { - try { - this.root.eval(context); + if (this.skip) { + if (typeof this.skip === 'function') { + this.skip = this.skip(); } - catch (e) { - e.message = 'Plugin error during evaluation'; - throw new LessError(e, this.root.imports, this.root.filename); + if (this.skip) { + return []; } } - registry = context.frames[0] && context.frames[0].functionRegistry; - if ( registry && this.root && this.root.functions ) { - registry.addMultiple( this.root.functions ); - } - - return []; - } + if (this.options.inline) { + const contents = new Anonymous(this.root, 0, + { + filename: this.importedFilename, + reference: this.path._fileInfo && this.path._fileInfo.reference + }, true, true); + + return this.features ? new Media([contents], this.features.value) : [contents]; + } else if (this.css) { + const newImport = new Import(this.evalPath(context), features, this.options, this._index); + if (!newImport.css && this.error) { + throw this.error; + } + return newImport; + } else if (this.root) { + ruleset = new Ruleset(null, utils.copyArray(this.root.rules)); + ruleset.evalImports(context); - if (this.skip) { - if (typeof this.skip === 'function') { - this.skip = this.skip(); - } - if (this.skip) { + return this.features ? new Media(ruleset.rules, this.features.value) : ruleset.rules; + } else { return []; } } - if (this.options.inline) { - const contents = new Anonymous(this.root, 0, - { - filename: this.importedFilename, - reference: this.path._fileInfo && this.path._fileInfo.reference - }, true, true); - - return this.features ? new Media([contents], this.features.value) : [contents]; - } else if (this.css) { - const newImport = new Import(this.evalPath(context), features, this.options, this._index); - if (!newImport.css && this.error) { - throw this.error; - } - return newImport; - } else if (this.root) { - ruleset = new Ruleset(null, utils.copyArray(this.root.rules)); - ruleset.evalImports(context); - - return this.features ? new Media(ruleset.rules, this.features.value) : ruleset.rules; - } else { - return []; - } -}; +}); -Import.prototype.type = 'Import'; export default Import; diff --git a/packages/less/src/less/tree/javascript.js b/packages/less/src/less/tree/javascript.js index a5faf3411..ebdeeed88 100644 --- a/packages/less/src/less/tree/javascript.js +++ b/packages/less/src/less/tree/javascript.js @@ -8,24 +8,25 @@ const JavaScript = function(string, escaped, index, currentFileInfo) { this.expression = string; this._index = index; this._fileInfo = currentFileInfo; -}; +} -JavaScript.prototype = new JsEvalNode(); +JavaScript.prototype = Object.assign(new JsEvalNode(), { + type: 'JavaScript', -JavaScript.prototype.eval = function(context) { - const result = this.evaluateJavaScript(this.expression, context); - const type = typeof result; + eval(context) { + const result = this.evaluateJavaScript(this.expression, context); + const type = typeof result; - if (type === 'number' && !isNaN(result)) { - return new Dimension(result); - } else if (type === 'string') { - return new Quoted(`"${result}"`, result, this.escaped, this._index); - } else if (Array.isArray(result)) { - return new Anonymous(result.join(', ')); - } else { - return new Anonymous(result); + if (type === 'number' && !isNaN(result)) { + return new Dimension(result); + } else if (type === 'string') { + return new Quoted(`"${result}"`, result, this.escaped, this._index); + } else if (Array.isArray(result)) { + return new Anonymous(result.join(', ')); + } else { + return new Anonymous(result); + } } -}; +}); -JavaScript.prototype.type = 'JavaScript'; export default JavaScript; diff --git a/packages/less/src/less/tree/js-eval-node.js b/packages/less/src/less/tree/js-eval-node.js index a65d703d6..8874f5f18 100644 --- a/packages/less/src/less/tree/js-eval-node.js +++ b/packages/less/src/less/tree/js-eval-node.js @@ -3,58 +3,60 @@ import Variable from './variable'; const JsEvalNode = function() {}; -JsEvalNode.prototype = new Node(); - -JsEvalNode.prototype.evaluateJavaScript = function(expression, context) { - let result; - const that = this; - const evalContext = {}; - - if (!context.javascriptEnabled) { - throw { message: 'Inline JavaScript is not enabled. Is it set in your options?', - filename: this.fileInfo().filename, - index: this.getIndex() }; - } +JsEvalNode.prototype = Object.assign(new Node(), { + evaluateJavaScript(expression, context) { + let result; + const that = this; + const evalContext = {}; + + if (!context.javascriptEnabled) { + throw { message: 'Inline JavaScript is not enabled. Is it set in your options?', + filename: this.fileInfo().filename, + index: this.getIndex() }; + } - expression = expression.replace(/@\{([\w-]+)\}/g, (_, name) => that.jsify(new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context))); + expression = expression.replace(/@\{([\w-]+)\}/g, function (_, name) { + return that.jsify(new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context)); + }); - try { - expression = new Function(`return (${expression})`); - } catch (e) { - throw { message: `JavaScript evaluation error: ${e.message} from \`${expression}\`` , - filename: this.fileInfo().filename, - index: this.getIndex() }; - } + try { + expression = new Function(`return (${expression})`); + } catch (e) { + throw { message: `JavaScript evaluation error: ${e.message} from \`${expression}\`` , + filename: this.fileInfo().filename, + index: this.getIndex() }; + } - const variables = context.frames[0].variables(); - for (const k in variables) { - if (variables.hasOwnProperty(k)) { - /* jshint loopfunc:true */ - evalContext[k.slice(1)] = { - value: variables[k].value, - toJS: function () { - return this.value.eval(context).toCSS(); - } - }; + const variables = context.frames[0].variables(); + for (const k in variables) { + if (variables.hasOwnProperty(k)) { + /* jshint loopfunc:true */ + evalContext[k.slice(1)] = { + value: variables[k].value, + toJS: function () { + return this.value.eval(context).toCSS(); + } + }; + } } - } - try { - result = expression.call(evalContext); - } catch (e) { - throw { message: `JavaScript evaluation error: '${e.name}: ${e.message.replace(/["]/g, '\'')}'` , - filename: this.fileInfo().filename, - index: this.getIndex() }; - } - return result; -}; - -JsEvalNode.prototype.jsify = function(obj) { - if (Array.isArray(obj.value) && (obj.value.length > 1)) { - return `[${obj.value.map(v => v.toCSS()).join(', ')}]`; - } else { - return obj.toCSS(); + try { + result = expression.call(evalContext); + } catch (e) { + throw { message: `JavaScript evaluation error: '${e.name}: ${e.message.replace(/["]/g, '\'')}'` , + filename: this.fileInfo().filename, + index: this.getIndex() }; + } + return result; + }, + + jsify(obj) { + if (Array.isArray(obj.value) && (obj.value.length > 1)) { + return `[${obj.value.map(function (v) { return v.toCSS(); }).join(', ')}]`; + } else { + return obj.toCSS(); + } } -}; +}); export default JsEvalNode; diff --git a/packages/less/src/less/tree/keyword.js b/packages/less/src/less/tree/keyword.js index cc5825329..d3b3704e8 100644 --- a/packages/less/src/less/tree/keyword.js +++ b/packages/less/src/less/tree/keyword.js @@ -4,14 +4,14 @@ const Keyword = function(value) { this.value = value; }; -Keyword.prototype = new Node(); +Keyword.prototype = Object.assign(new Node(), { + type: 'Keyword', -Keyword.prototype.genCSS = function(context, output) { - if (this.value === '%') { throw { type: 'Syntax', message: 'Invalid % without number' }; } - output.add(this.value); -}; - -Keyword.prototype.type = 'Keyword'; + genCSS(context, output) { + if (this.value === '%') { throw { type: 'Syntax', message: 'Invalid % without number' }; } + output.add(this.value); + } +}); Keyword.True = new Keyword('true'); Keyword.False = new Keyword('false'); diff --git a/packages/less/src/less/tree/media.js b/packages/less/src/less/tree/media.js index 7a0b1f5a4..fd5c4f7c7 100644 --- a/packages/less/src/less/tree/media.js +++ b/packages/less/src/less/tree/media.js @@ -20,133 +20,134 @@ const Media = function(value, features, index, currentFileInfo, visibilityInfo) this.setParent(selectors, this); this.setParent(this.features, this); this.setParent(this.rules, this); -} - -Media.prototype = new AtRule(); - -Media.prototype.isRulesetLike = function() { - return true; -}; - -Media.prototype.accept = function(visitor) { - if (this.features) { - this.features = visitor.visit(this.features); - } - if (this.rules) { - this.rules = visitor.visitArray(this.rules); - } -}; - -Media.prototype.genCSS = function(context, output) { - output.add('@media ', this._fileInfo, this._index); - this.features.genCSS(context, output); - this.outputRuleset(context, output, this.rules); }; -Media.prototype.eval = function(context) { - if (!context.mediaBlocks) { - context.mediaBlocks = []; - context.mediaPath = []; - } +Media.prototype = Object.assign(new AtRule(), { + type: 'Media', - const media = new Media(null, [], this._index, this._fileInfo, this.visibilityInfo()); - if (this.debugInfo) { - this.rules[0].debugInfo = this.debugInfo; - media.debugInfo = this.debugInfo; - } - - media.features = this.features.eval(context); + isRulesetLike() { + return true; + }, - context.mediaPath.push(media); - context.mediaBlocks.push(media); + accept(visitor) { + if (this.features) { + this.features = visitor.visit(this.features); + } + if (this.rules) { + this.rules = visitor.visitArray(this.rules); + } + }, + + genCSS(context, output) { + output.add('@media ', this._fileInfo, this._index); + this.features.genCSS(context, output); + this.outputRuleset(context, output, this.rules); + }, + + eval(context) { + if (!context.mediaBlocks) { + context.mediaBlocks = []; + context.mediaPath = []; + } - this.rules[0].functionRegistry = context.frames[0].functionRegistry.inherit(); - context.frames.unshift(this.rules[0]); - media.rules = [this.rules[0].eval(context)]; - context.frames.shift(); + const media = new Media(null, [], this._index, this._fileInfo, this.visibilityInfo()); + if (this.debugInfo) { + this.rules[0].debugInfo = this.debugInfo; + media.debugInfo = this.debugInfo; + } + + media.features = this.features.eval(context); - context.mediaPath.pop(); + context.mediaPath.push(media); + context.mediaBlocks.push(media); - return context.mediaPath.length === 0 ? media.evalTop(context) : - media.evalNested(context); -}; + this.rules[0].functionRegistry = context.frames[0].functionRegistry.inherit(); + context.frames.unshift(this.rules[0]); + media.rules = [this.rules[0].eval(context)]; + context.frames.shift(); -Media.prototype.evalTop = function(context) { - let result = this; + context.mediaPath.pop(); - // Render all dependent Media blocks. - if (context.mediaBlocks.length > 1) { - const selectors = (new Selector([], null, null, this.getIndex(), this.fileInfo())).createEmptySelectors(); - result = new Ruleset(selectors, context.mediaBlocks); - result.multiMedia = true; - result.copyVisibilityInfo(this.visibilityInfo()); - this.setParent(result, this); - } + return context.mediaPath.length === 0 ? media.evalTop(context) : + media.evalNested(context); + }, - delete context.mediaBlocks; - delete context.mediaPath; + evalTop(context) { + let result = this; - return result; -}; - -Media.prototype.evalNested = function(context) { - let i; - let value; - const path = context.mediaPath.concat([this]); + // Render all dependent Media blocks. + if (context.mediaBlocks.length > 1) { + const selectors = (new Selector([], null, null, this.getIndex(), this.fileInfo())).createEmptySelectors(); + result = new Ruleset(selectors, context.mediaBlocks); + result.multiMedia = true; + result.copyVisibilityInfo(this.visibilityInfo()); + this.setParent(result, this); + } - // Extract the media-query conditions separated with `,` (OR). - for (i = 0; i < path.length; i++) { - value = path[i].features instanceof Value ? - path[i].features.value : path[i].features; - path[i] = Array.isArray(value) ? value : [value]; - } + delete context.mediaBlocks; + delete context.mediaPath; - // Trace all permutations to generate the resulting media-query. - // - // (a, b and c) with nested (d, e) -> - // a and d - // a and e - // b and c and d - // b and c and e - this.features = new Value(this.permute(path).map(path => { - path = path.map(fragment => fragment.toCSS ? fragment : new Anonymous(fragment)); - - for (i = path.length - 1; i > 0; i--) { - path.splice(i, 0, new Anonymous('and')); + return result; + }, + + evalNested(context) { + let i; + let value; + const path = context.mediaPath.concat([this]); + + // Extract the media-query conditions separated with `,` (OR). + for (i = 0; i < path.length; i++) { + value = path[i].features instanceof Value ? + path[i].features.value : path[i].features; + path[i] = Array.isArray(value) ? value : [value]; } - return new Expression(path); - })); - this.setParent(this.features, this); - - // Fake a tree-node that doesn't output anything. - return new Ruleset([], []); -}; + // Trace all permutations to generate the resulting media-query. + // + // (a, b and c) with nested (d, e) -> + // a and d + // a and e + // b and c and d + // b and c and e + this.features = new Value(this.permute(path).map(path => { + path = path.map(fragment => fragment.toCSS ? fragment : new Anonymous(fragment)); + + for (i = path.length - 1; i > 0; i--) { + path.splice(i, 0, new Anonymous('and')); + } -Media.prototype.permute = function(arr) { - if (arr.length === 0) { - return []; - } else if (arr.length === 1) { - return arr[0]; - } else { - const result = []; - const rest = this.permute(arr.slice(1)); - for (let i = 0; i < rest.length; i++) { - for (let j = 0; j < arr[0].length; j++) { - result.push([arr[0][j]].concat(rest[i])); + return new Expression(path); + })); + this.setParent(this.features, this); + + // Fake a tree-node that doesn't output anything. + return new Ruleset([], []); + }, + + permute(arr) { + if (arr.length === 0) { + return []; + } else if (arr.length === 1) { + return arr[0]; + } else { + const result = []; + const rest = this.permute(arr.slice(1)); + for (let i = 0; i < rest.length; i++) { + for (let j = 0; j < arr[0].length; j++) { + result.push([arr[0][j]].concat(rest[i])); + } } + return result; } - return result; - } -}; + }, -Media.prototype.bubbleSelectors = function(selectors) { - if (!selectors) { - return; + bubbleSelectors(selectors) { + if (!selectors) { + return; + } + this.rules = [new Ruleset(utils.copyArray(selectors), [this.rules[0]])]; + this.setParent(this.rules, this); } - this.rules = [new Ruleset(utils.copyArray(selectors), [this.rules[0]])]; - this.setParent(this.rules, this); -}; +}); -Media.prototype.type = 'Media'; export default Media; diff --git a/packages/less/src/less/tree/mixin-call.js b/packages/less/src/less/tree/mixin-call.js index e8550f356..36e6b41ff 100644 --- a/packages/less/src/less/tree/mixin-call.js +++ b/packages/less/src/less/tree/mixin-call.js @@ -13,201 +13,199 @@ const MixinCall = function(elements, args, index, currentFileInfo, important) { this.setParent(this.selector, this); }; -MixinCall.prototype = new Node(); +MixinCall.prototype = Object.assign(new Node(), { + type: 'MixinCall', -MixinCall.prototype.accept = function(visitor) { - if (this.selector) { - this.selector = visitor.visit(this.selector); - } - if (this.arguments.length) { - this.arguments = visitor.visitArray(this.arguments); - } -}; - -MixinCall.prototype.eval = function(context) { - let mixins; - let mixin; - let mixinPath; - const args = []; - let arg; - let argValue; - const rules = []; - let match = false; - let i; - let m; - let f; - let isRecursive; - let isOneFound; - const candidates = []; - let candidate; - const conditionResult = []; - let defaultResult; - const defFalseEitherCase = -1; - const defNone = 0; - const defTrue = 1; - const defFalse = 2; - let count; - let originalRuleset; - let noArgumentsFilter; - - this.selector = this.selector.eval(context); - - function calcDefGroup(mixin, mixinPath) { + accept(visitor) { + if (this.selector) { + this.selector = visitor.visit(this.selector); + } + if (this.arguments.length) { + this.arguments = visitor.visitArray(this.arguments); + } + }, + + eval(context) { + let mixins; + let mixin; + let mixinPath; + const args = []; + let arg; + let argValue; + const rules = []; + let match = false; + let i; + let m; let f; - let p; - let namespace; - - for (f = 0; f < 2; f++) { - conditionResult[f] = true; - defaultFunc.value(f); - for (p = 0; p < mixinPath.length && conditionResult[f]; p++) { - namespace = mixinPath[p]; - if (namespace.matchCondition) { - conditionResult[f] = conditionResult[f] && namespace.matchCondition(null, context); + let isRecursive; + let isOneFound; + const candidates = []; + let candidate; + const conditionResult = []; + let defaultResult; + const defFalseEitherCase = -1; + const defNone = 0; + const defTrue = 1; + const defFalse = 2; + let count; + let originalRuleset; + let noArgumentsFilter; + + this.selector = this.selector.eval(context); + + function calcDefGroup(mixin, mixinPath) { + let f, p, namespace; + + for (f = 0; f < 2; f++) { + conditionResult[f] = true; + defaultFunc.value(f); + for (p = 0; p < mixinPath.length && conditionResult[f]; p++) { + namespace = mixinPath[p]; + if (namespace.matchCondition) { + conditionResult[f] = conditionResult[f] && namespace.matchCondition(null, context); + } + } + if (mixin.matchCondition) { + conditionResult[f] = conditionResult[f] && mixin.matchCondition(args, context); } } - if (mixin.matchCondition) { - conditionResult[f] = conditionResult[f] && mixin.matchCondition(args, context); + if (conditionResult[0] || conditionResult[1]) { + if (conditionResult[0] != conditionResult[1]) { + return conditionResult[1] ? + defTrue : defFalse; + } + + return defNone; } + return defFalseEitherCase; } - if (conditionResult[0] || conditionResult[1]) { - if (conditionResult[0] != conditionResult[1]) { - return conditionResult[1] ? - defTrue : defFalse; - } - return defNone; - } - return defFalseEitherCase; - } - - for (i = 0; i < this.arguments.length; i++) { - arg = this.arguments[i]; - argValue = arg.value.eval(context); - if (arg.expand && Array.isArray(argValue.value)) { - argValue = argValue.value; - for (m = 0; m < argValue.length; m++) { - args.push({value: argValue[m]}); + for (i = 0; i < this.arguments.length; i++) { + arg = this.arguments[i]; + argValue = arg.value.eval(context); + if (arg.expand && Array.isArray(argValue.value)) { + argValue = argValue.value; + for (m = 0; m < argValue.length; m++) { + args.push({value: argValue[m]}); + } + } else { + args.push({name: arg.name, value: argValue}); } - } else { - args.push({name: arg.name, value: argValue}); } - } - noArgumentsFilter = rule => rule.matchArgs(null, context); - - for (i = 0; i < context.frames.length; i++) { - if ((mixins = context.frames[i].find(this.selector, null, noArgumentsFilter)).length > 0) { - isOneFound = true; - - // To make `default()` function independent of definition order we have two "subpasses" here. - // At first we evaluate each guard *twice* (with `default() == true` and `default() == false`), - // and build candidate list with corresponding flags. Then, when we know all possible matches, - // we make a final decision. - - for (m = 0; m < mixins.length; m++) { - mixin = mixins[m].rule; - mixinPath = mixins[m].path; - isRecursive = false; - for (f = 0; f < context.frames.length; f++) { - if ((!(mixin instanceof MixinDefinition)) && mixin === (context.frames[f].originalRuleset || context.frames[f])) { - isRecursive = true; - break; + noArgumentsFilter = function(rule) {return rule.matchArgs(null, context);}; + + for (i = 0; i < context.frames.length; i++) { + if ((mixins = context.frames[i].find(this.selector, null, noArgumentsFilter)).length > 0) { + isOneFound = true; + + // To make `default()` function independent of definition order we have two "subpasses" here. + // At first we evaluate each guard *twice* (with `default() == true` and `default() == false`), + // and build candidate list with corresponding flags. Then, when we know all possible matches, + // we make a final decision. + + for (m = 0; m < mixins.length; m++) { + mixin = mixins[m].rule; + mixinPath = mixins[m].path; + isRecursive = false; + for (f = 0; f < context.frames.length; f++) { + if ((!(mixin instanceof MixinDefinition)) && mixin === (context.frames[f].originalRuleset || context.frames[f])) { + isRecursive = true; + break; + } + } + if (isRecursive) { + continue; } - } - if (isRecursive) { - continue; - } - if (mixin.matchArgs(args, context)) { - candidate = {mixin, group: calcDefGroup(mixin, mixinPath)}; + if (mixin.matchArgs(args, context)) { + candidate = {mixin, group: calcDefGroup(mixin, mixinPath)}; - if (candidate.group !== defFalseEitherCase) { - candidates.push(candidate); - } + if (candidate.group !== defFalseEitherCase) { + candidates.push(candidate); + } - match = true; + match = true; + } } - } - defaultFunc.reset(); + defaultFunc.reset(); - count = [0, 0, 0]; - for (m = 0; m < candidates.length; m++) { - count[candidates[m].group]++; - } + count = [0, 0, 0]; + for (m = 0; m < candidates.length; m++) { + count[candidates[m].group]++; + } - if (count[defNone] > 0) { - defaultResult = defFalse; - } else { - defaultResult = defTrue; - if ((count[defTrue] + count[defFalse]) > 1) { - throw { type: 'Runtime', - message: `Ambiguous use of \`default()\` found when matching for \`${this.format(args)}\``, - index: this.getIndex(), filename: this.fileInfo().filename }; + if (count[defNone] > 0) { + defaultResult = defFalse; + } else { + defaultResult = defTrue; + if ((count[defTrue] + count[defFalse]) > 1) { + throw { type: 'Runtime', + message: `Ambiguous use of \`default()\` found when matching for \`${this.format(args)}\``, + index: this.getIndex(), filename: this.fileInfo().filename }; + } } - } - for (m = 0; m < candidates.length; m++) { - candidate = candidates[m].group; - if ((candidate === defNone) || (candidate === defaultResult)) { - try { - mixin = candidates[m].mixin; - if (!(mixin instanceof MixinDefinition)) { - originalRuleset = mixin.originalRuleset || mixin; - mixin = new MixinDefinition('', [], mixin.rules, null, false, null, originalRuleset.visibilityInfo()); - mixin.originalRuleset = originalRuleset; + for (m = 0; m < candidates.length; m++) { + candidate = candidates[m].group; + if ((candidate === defNone) || (candidate === defaultResult)) { + try { + mixin = candidates[m].mixin; + if (!(mixin instanceof MixinDefinition)) { + originalRuleset = mixin.originalRuleset || mixin; + mixin = new MixinDefinition('', [], mixin.rules, null, false, null, originalRuleset.visibilityInfo()); + mixin.originalRuleset = originalRuleset; + } + const newRules = mixin.evalCall(context, args, this.important).rules; + this._setVisibilityToReplacement(newRules); + Array.prototype.push.apply(rules, newRules); + } catch (e) { + throw { message: e.message, index: this.getIndex(), filename: this.fileInfo().filename, stack: e.stack }; } - const newRules = mixin.evalCall(context, args, this.important).rules; - this._setVisibilityToReplacement(newRules); - Array.prototype.push.apply(rules, newRules); - } catch (e) { - throw { message: e.message, index: this.getIndex(), filename: this.fileInfo().filename, stack: e.stack }; } } - } - if (match) { - return rules; + if (match) { + return rules; + } } } - } - if (isOneFound) { - throw { type: 'Runtime', - message: `No matching definition was found for \`${this.format(args)}\``, - index: this.getIndex(), filename: this.fileInfo().filename }; - } else { - throw { type: 'Name', - message: `${this.selector.toCSS().trim()} is undefined`, - index: this.getIndex(), filename: this.fileInfo().filename }; - } -}; - -MixinCall.prototype._setVisibilityToReplacement = function(replacement) { - let i; - let rule; - if (this.blocksVisibility()) { - for (i = 0; i < replacement.length; i++) { - rule = replacement[i]; - rule.addVisibilityBlock(); - } - } -}; - -MixinCall.prototype.format = function(args) { - return `${this.selector.toCSS().trim()}(${args ? args.map(a => { - let argValue = ''; - if (a.name) { - argValue += `${a.name}:`; - } - if (a.value.toCSS) { - argValue += a.value.toCSS(); + if (isOneFound) { + throw { type: 'Runtime', + message: `No matching definition was found for \`${this.format(args)}\``, + index: this.getIndex(), filename: this.fileInfo().filename }; } else { - argValue += '???'; + throw { type: 'Name', + message: `${this.selector.toCSS().trim()} is undefined`, + index: this.getIndex(), filename: this.fileInfo().filename }; } - return argValue; - }).join(', ') : ''})`; -}; + }, + + _setVisibilityToReplacement(replacement) { + let i, rule; + if (this.blocksVisibility()) { + for (i = 0; i < replacement.length; i++) { + rule = replacement[i]; + rule.addVisibilityBlock(); + } + } + }, + + format(args) { + return `${this.selector.toCSS().trim()}(${args ? args.map(function (a) { + let argValue = ''; + if (a.name) { + argValue += `${a.name}:`; + } + if (a.value.toCSS) { + argValue += a.value.toCSS(); + } else { + argValue += '???'; + } + return argValue; + }).join(', ') : ''})`; + } +}); -MixinCall.prototype.type = 'MixinCall'; export default MixinCall; diff --git a/packages/less/src/less/tree/mixin-definition.js b/packages/less/src/less/tree/mixin-definition.js index b35aeecc9..eb22c44b0 100644 --- a/packages/less/src/less/tree/mixin-definition.js +++ b/packages/less/src/less/tree/mixin-definition.js @@ -17,7 +17,7 @@ const Definition = function(name, params, rules, condition, variadic, frames, vi this.rules = rules; this._lookups = {}; const optionalParameters = []; - this.required = params.reduce((count, p) => { + this.required = params.reduce(function (count, p) { if (!p.name || (p.name && !p.value)) { return count + 1; } @@ -30,198 +30,199 @@ const Definition = function(name, params, rules, condition, variadic, frames, vi this.frames = frames; this.copyVisibilityInfo(visibilityInfo); this.allowRoot = true; -}; +} -Definition.prototype = new Ruleset(); +Definition.prototype = Object.assign(new Ruleset(), { + type: 'MixinDefinition', + evalFirst: true, -Definition.prototype.accept = function(visitor) { - if (this.params && this.params.length) { - this.params = visitor.visitArray(this.params); - } - this.rules = visitor.visitArray(this.rules); - if (this.condition) { - this.condition = visitor.visit(this.condition); - } -}; - -Definition.prototype.evalParams = function(context, mixinEnv, args, evaldArguments) { - /* jshint boss:true */ - const frame = new Ruleset(null, null); - - let varargs; - let arg; - const params = utils.copyArray(this.params); - let i; - let j; - let val; - let name; - let isNamedFound; - let argIndex; - let argsLength = 0; - - if (mixinEnv.frames && mixinEnv.frames[0] && mixinEnv.frames[0].functionRegistry) { - frame.functionRegistry = mixinEnv.frames[0].functionRegistry.inherit(); - } - mixinEnv = new contexts.Eval(mixinEnv, [frame].concat(mixinEnv.frames)); - - if (args) { - args = utils.copyArray(args); - argsLength = args.length; - - for (i = 0; i < argsLength; i++) { - arg = args[i]; - if (name = (arg && arg.name)) { - isNamedFound = false; - for (j = 0; j < params.length; j++) { - if (!evaldArguments[j] && name === params[j].name) { - evaldArguments[j] = arg.value.eval(context); - frame.prependRule(new Declaration(name, arg.value.eval(context))); - isNamedFound = true; - break; + accept(visitor) { + if (this.params && this.params.length) { + this.params = visitor.visitArray(this.params); + } + this.rules = visitor.visitArray(this.rules); + if (this.condition) { + this.condition = visitor.visit(this.condition); + } + }, + + evalParams(context, mixinEnv, args, evaldArguments) { + /* jshint boss:true */ + const frame = new Ruleset(null, null); + + let varargs; + let arg; + const params = utils.copyArray(this.params); + let i; + let j; + let val; + let name; + let isNamedFound; + let argIndex; + let argsLength = 0; + + if (mixinEnv.frames && mixinEnv.frames[0] && mixinEnv.frames[0].functionRegistry) { + frame.functionRegistry = mixinEnv.frames[0].functionRegistry.inherit(); + } + mixinEnv = new contexts.Eval(mixinEnv, [frame].concat(mixinEnv.frames)); + + if (args) { + args = utils.copyArray(args); + argsLength = args.length; + + for (i = 0; i < argsLength; i++) { + arg = args[i]; + if (name = (arg && arg.name)) { + isNamedFound = false; + for (j = 0; j < params.length; j++) { + if (!evaldArguments[j] && name === params[j].name) { + evaldArguments[j] = arg.value.eval(context); + frame.prependRule(new Declaration(name, arg.value.eval(context))); + isNamedFound = true; + break; + } + } + if (isNamedFound) { + args.splice(i, 1); + i--; + continue; + } else { + throw { type: 'Runtime', message: `Named argument for ${this.name} ${args[i].name} not found` }; } - } - if (isNamedFound) { - args.splice(i, 1); - i--; - continue; - } else { - throw { type: 'Runtime', message: `Named argument for ${this.name} ${args[i].name} not found` }; } } } - } - argIndex = 0; - for (i = 0; i < params.length; i++) { - if (evaldArguments[i]) { continue; } + argIndex = 0; + for (i = 0; i < params.length; i++) { + if (evaldArguments[i]) { continue; } - arg = args && args[argIndex]; + arg = args && args[argIndex]; - if (name = params[i].name) { - if (params[i].variadic) { - varargs = []; - for (j = argIndex; j < argsLength; j++) { - varargs.push(args[j].value.eval(context)); - } - frame.prependRule(new Declaration(name, new Expression(varargs).eval(context))); - } else { - val = arg && arg.value; - if (val) { - // This was a mixin call, pass in a detached ruleset of it's eval'd rules - if (Array.isArray(val)) { - val = new DetachedRuleset(new Ruleset('', val)); - } - else { - val = val.eval(context); + if (name = params[i].name) { + if (params[i].variadic) { + varargs = []; + for (j = argIndex; j < argsLength; j++) { + varargs.push(args[j].value.eval(context)); } - } else if (params[i].value) { - val = params[i].value.eval(mixinEnv); - frame.resetCache(); + frame.prependRule(new Declaration(name, new Expression(varargs).eval(context))); } else { - throw { type: 'Runtime', message: `wrong number of arguments for ${this.name} (${argsLength} for ${this.arity})` }; - } + val = arg && arg.value; + if (val) { + // This was a mixin call, pass in a detached ruleset of it's eval'd rules + if (Array.isArray(val)) { + val = new DetachedRuleset(new Ruleset('', val)); + } + else { + val = val.eval(context); + } + } else if (params[i].value) { + val = params[i].value.eval(mixinEnv); + frame.resetCache(); + } else { + throw { type: 'Runtime', message: `wrong number of arguments for ${this.name} (${argsLength} for ${this.arity})` }; + } - frame.prependRule(new Declaration(name, val)); - evaldArguments[i] = val; + frame.prependRule(new Declaration(name, val)); + evaldArguments[i] = val; + } } - } - if (params[i].variadic && args) { - for (j = argIndex; j < argsLength; j++) { - evaldArguments[j] = args[j].value.eval(context); + if (params[i].variadic && args) { + for (j = argIndex; j < argsLength; j++) { + evaldArguments[j] = args[j].value.eval(context); + } } + argIndex++; } - argIndex++; - } - return frame; -}; - -Definition.prototype.makeImportant = function() { - const rules = !this.rules ? this.rules : this.rules.map(r => { - if (r.makeImportant) { - return r.makeImportant(true); - } else { - return r; - } - }); - const result = new Definition(this.name, this.params, rules, this.condition, this.variadic, this.frames); - return result; -}; - -Definition.prototype.eval = function(context) { - return new Definition(this.name, this.params, this.rules, this.condition, this.variadic, this.frames || utils.copyArray(context.frames)); -}; - -Definition.prototype.evalCall = function(context, args, important) { - const _arguments = []; - const mixinFrames = this.frames ? this.frames.concat(context.frames) : context.frames; - const frame = this.evalParams(context, new contexts.Eval(context, mixinFrames), args, _arguments); - let rules; - let ruleset; - - frame.prependRule(new Declaration('@arguments', new Expression(_arguments).eval(context))); - - rules = utils.copyArray(this.rules); - - ruleset = new Ruleset(null, rules); - ruleset.originalRuleset = this; - ruleset = ruleset.eval(new contexts.Eval(context, [this, frame].concat(mixinFrames))); - if (important) { - ruleset = ruleset.makeImportant(); - } - return ruleset; -}; - -Definition.prototype.matchCondition = function(args, context) { - if (this.condition && !this.condition.eval( - new contexts.Eval(context, - [this.evalParams(context, /* the parameter variables */ - new contexts.Eval(context, this.frames ? this.frames.concat(context.frames) : context.frames), args, [])] - .concat(this.frames || []) // the parent namespace/mixin frames - .concat(context.frames)))) { // the current environment frames - return false; - } - return true; -}; - -Definition.prototype.matchArgs = function(args, context) { - const allArgsCnt = (args && args.length) || 0; - let len; - const optionalParameters = this.optionalParameters; - const requiredArgsCnt = !args ? 0 : args.reduce((count, p) => { - if (optionalParameters.indexOf(p.name) < 0) { - return count + 1; - } else { - return count; - } - }, 0); + return frame; + }, - if (!this.variadic) { - if (requiredArgsCnt < this.required) { - return false; + makeImportant() { + const rules = !this.rules ? this.rules : this.rules.map(function (r) { + if (r.makeImportant) { + return r.makeImportant(true); + } else { + return r; + } + }); + const result = new Definition(this.name, this.params, rules, this.condition, this.variadic, this.frames); + return result; + }, + + eval(context) { + return new Definition(this.name, this.params, this.rules, this.condition, this.variadic, this.frames || utils.copyArray(context.frames)); + }, + + evalCall(context, args, important) { + const _arguments = []; + const mixinFrames = this.frames ? this.frames.concat(context.frames) : context.frames; + const frame = this.evalParams(context, new contexts.Eval(context, mixinFrames), args, _arguments); + let rules; + let ruleset; + + frame.prependRule(new Declaration('@arguments', new Expression(_arguments).eval(context))); + + rules = utils.copyArray(this.rules); + + ruleset = new Ruleset(null, rules); + ruleset.originalRuleset = this; + ruleset = ruleset.eval(new contexts.Eval(context, [this, frame].concat(mixinFrames))); + if (important) { + ruleset = ruleset.makeImportant(); } - if (allArgsCnt > this.params.length) { + return ruleset; + }, + + matchCondition(args, context) { + if (this.condition && !this.condition.eval( + new contexts.Eval(context, + [this.evalParams(context, /* the parameter variables */ + new contexts.Eval(context, this.frames ? this.frames.concat(context.frames) : context.frames), args, [])] + .concat(this.frames || []) // the parent namespace/mixin frames + .concat(context.frames)))) { // the current environment frames return false; } - } else { - if (requiredArgsCnt < (this.required - 1)) { - return false; + return true; + }, + + matchArgs(args, context) { + const allArgsCnt = (args && args.length) || 0; + let len; + const optionalParameters = this.optionalParameters; + const requiredArgsCnt = !args ? 0 : args.reduce(function (count, p) { + if (optionalParameters.indexOf(p.name) < 0) { + return count + 1; + } else { + return count; + } + }, 0); + + if (!this.variadic) { + if (requiredArgsCnt < this.required) { + return false; + } + if (allArgsCnt > this.params.length) { + return false; + } + } else { + if (requiredArgsCnt < (this.required - 1)) { + return false; + } } - } - // check patterns - len = Math.min(requiredArgsCnt, this.arity); + // check patterns + len = Math.min(requiredArgsCnt, this.arity); - for (let i = 0; i < len; i++) { - if (!this.params[i].name && !this.params[i].variadic) { - if (args[i].value.eval(context).toCSS() != this.params[i].value.eval(context).toCSS()) { - return false; + for (let i = 0; i < len; i++) { + if (!this.params[i].name && !this.params[i].variadic) { + if (args[i].value.eval(context).toCSS() != this.params[i].value.eval(context).toCSS()) { + return false; + } } } + return true; } - return true; -}; +}); -Definition.prototype.type = 'MixinDefinition'; -Definition.prototype.evalFirst = true; export default Definition; diff --git a/packages/less/src/less/tree/namespace-value.js b/packages/less/src/less/tree/namespace-value.js index 7f00c3027..adbd9ea36 100644 --- a/packages/less/src/less/tree/namespace-value.js +++ b/packages/less/src/less/tree/namespace-value.js @@ -8,77 +8,75 @@ const NamespaceValue = function(ruleCall, lookups, index, fileInfo) { this.lookups = lookups; this._index = index; this._fileInfo = fileInfo; -} - -NamespaceValue.prototype = new Node(); - -NamespaceValue.prototype.eval = function(context) { - let i; - let j; - let name; - let rules = this.value.eval(context); +}; - for (i = 0; i < this.lookups.length; i++) { - name = this.lookups[i]; +NamespaceValue.prototype = Object.assign(new Node(), { + type: 'NamespaceValue', - /** - * Eval'd DRs return rulesets. - * Eval'd mixins return rules, so let's make a ruleset if we need it. - * We need to do this because of late parsing of values - */ - if (Array.isArray(rules)) { - rules = new Ruleset([new Selector()], rules); - } + eval(context) { + let i, j, name, rules = this.value.eval(context); + + for (i = 0; i < this.lookups.length; i++) { + name = this.lookups[i]; - if (name === '') { - rules = rules.lastDeclaration(); - } - else if (name.charAt(0) === '@') { - if (name.charAt(1) === '@') { - name = `@${new Variable(name.substr(1)).eval(context).value}`; + /** + * Eval'd DRs return rulesets. + * Eval'd mixins return rules, so let's make a ruleset if we need it. + * We need to do this because of late parsing of values + */ + if (Array.isArray(rules)) { + rules = new Ruleset([new Selector()], rules); } - if (rules.variables) { - rules = rules.variable(name); + + if (name === '') { + rules = rules.lastDeclaration(); } - - if (!rules) { - throw { type: 'Name', - message: `variable ${name} not found`, - filename: this.fileInfo().filename, - index: this.getIndex() }; - } - } - else { - if (name.substring(0, 2) === '$@') { - name = `$${new Variable(name.substr(1)).eval(context).value}`; + else if (name.charAt(0) === '@') { + if (name.charAt(1) === '@') { + name = `@${new Variable(name.substr(1)).eval(context).value}`; + } + if (rules.variables) { + rules = rules.variable(name); + } + + if (!rules) { + throw { type: 'Name', + message: `variable ${name} not found`, + filename: this.fileInfo().filename, + index: this.getIndex() }; + } } else { - name = name.charAt(0) === '$' ? name : `$${name}`; + if (name.substring(0, 2) === '$@') { + name = `$${new Variable(name.substr(1)).eval(context).value}`; + } + else { + name = name.charAt(0) === '$' ? name : `$${name}`; + } + if (rules.properties) { + rules = rules.property(name); + } + + if (!rules) { + throw { type: 'Name', + message: `property "${name.substr(1)}" not found`, + filename: this.fileInfo().filename, + index: this.getIndex() }; + } + // Properties are an array of values, since a ruleset can have multiple props. + // We pick the last one (the "cascaded" value) + rules = rules[rules.length - 1]; } - if (rules.properties) { - rules = rules.property(name); + + if (rules.value) { + rules = rules.eval(context).value; } - - if (!rules) { - throw { type: 'Name', - message: `property "${name.substr(1)}" not found`, - filename: this.fileInfo().filename, - index: this.getIndex() }; + if (rules.ruleset) { + rules = rules.ruleset.eval(context); } - // Properties are an array of values, since a ruleset can have multiple props. - // We pick the last one (the "cascaded" value) - rules = rules[rules.length - 1]; - } - - if (rules.value) { - rules = rules.eval(context).value; - } - if (rules.ruleset) { - rules = rules.ruleset.eval(context); } + return rules; } - return rules; -}; +}); -NamespaceValue.prototype.type = 'NamespaceValue'; export default NamespaceValue; diff --git a/packages/less/src/less/tree/negative.js b/packages/less/src/less/tree/negative.js index 5ed0d9c70..7e1bcf1b2 100644 --- a/packages/less/src/less/tree/negative.js +++ b/packages/less/src/less/tree/negative.js @@ -4,21 +4,22 @@ import Dimension from './dimension'; const Negative = function(node) { this.value = node; -} +}; -Negative.prototype = new Node(); +Negative.prototype = Object.assign(new Node(), { + type: 'Negative', -Negative.prototype.genCSS = function(context, output) { - output.add('-'); - this.value.genCSS(context, output); -}; + genCSS(context, output) { + output.add('-'); + this.value.genCSS(context, output); + }, -Negative.prototype.eval = function(context) { - if (context.isMathOn()) { - return (new Operation('*', [new Dimension(-1), this.value])).eval(context); + eval(context) { + if (context.isMathOn()) { + return (new Operation('*', [new Dimension(-1), this.value])).eval(context); + } + return new Negative(this.value.eval(context)); } - return new Negative(this.value.eval(context)); -}; +}); -Negative.prototype.type = 'Negative'; export default Negative; diff --git a/packages/less/src/less/tree/node.js b/packages/less/src/less/tree/node.js index f7e17b9dc..dcfd17bf3 100644 --- a/packages/less/src/less/tree/node.js +++ b/packages/less/src/less/tree/node.js @@ -44,9 +44,7 @@ class Node { return this._fileInfo || (this.parent && this.parent.fileInfo()) || {}; } - isRulesetLike() { - return false; - } + isRulesetLike() { return false; } toCSS(context) { const strs = []; @@ -86,6 +84,46 @@ class Node { return (precision) ? Number((value + 2e-16).toFixed(precision)) : value; } + static compare(a, b) { + /* returns: + -1: a < b + 0: a = b + 1: a > b + and *any* other value for a != b (e.g. undefined, NaN, -2 etc.) */ + + if ((a.compare) && + // for "symmetric results" force toCSS-based comparison + // of Quoted or Anonymous if either value is one of those + !(b.type === 'Quoted' || b.type === 'Anonymous')) { + return a.compare(b); + } else if (b.compare) { + return -b.compare(a); + } else if (a.type !== b.type) { + return undefined; + } + + a = a.value; + b = b.value; + if (!Array.isArray(a)) { + return a === b ? 0 : undefined; + } + if (a.length !== b.length) { + return undefined; + } + for (let i = 0; i < a.length; i++) { + if (Node.compare(a[i], b[i]) !== 0) { + return undefined; + } + } + return 0; + } + + static numericCompare(a, b) { + return a < b ? -1 + : a === b ? 0 + : a > b ? 1 : undefined; + } + // Returns true if this node represents root of ast imported by reference blocksVisibility() { if (this.visibilityBlocks == null) { @@ -144,41 +182,4 @@ class Node { } } -Node.compare = (a, b) => { - /* returns: - -1: a < b - 0: a = b - 1: a > b - and *any* other value for a != b (e.g. undefined, NaN, -2 etc.) */ - - if ((a.compare) && - // for "symmetric results" force toCSS-based comparison - // of Quoted or Anonymous if either value is one of those - !(b.type === 'Quoted' || b.type === 'Anonymous')) { - return a.compare(b); - } else if (b.compare) { - return -b.compare(a); - } else if (a.type !== b.type) { - return undefined; - } - - a = a.value; - b = b.value; - if (!Array.isArray(a)) { - return a === b ? 0 : undefined; - } - if (a.length !== b.length) { - return undefined; - } - for (let i = 0; i < a.length; i++) { - if (Node.compare(a[i], b[i]) !== 0) { - return undefined; - } - } - return 0; -}; - -Node.numericCompare = (a, b) => a < b ? -1 - : a === b ? 0 - : a > b ? 1 : undefined; export default Node; diff --git a/packages/less/src/less/tree/operation.js b/packages/less/src/less/tree/operation.js index a21423d91..225da1ac0 100644 --- a/packages/less/src/less/tree/operation.js +++ b/packages/less/src/less/tree/operation.js @@ -4,56 +4,56 @@ import Dimension from './dimension'; import * as Constants from '../constants'; const MATH = Constants.Math; + const Operation = function(op, operands, isSpaced) { this.op = op.trim(); this.operands = operands; this.isSpaced = isSpaced; }; -Operation.prototype = new Node(); +Operation.prototype = Object.assign(new Node(), { + type: 'Operation', -Operation.prototype.accept = function(visitor) { - this.operands = visitor.visitArray(this.operands); -} + accept(visitor) { + this.operands = visitor.visitArray(this.operands); + }, -Operation.prototype.eval = function(context) { - let a = this.operands[0].eval(context); - let b = this.operands[1].eval(context); - let op; + eval(context) { + let a = this.operands[0].eval(context), b = this.operands[1].eval(context), op; - if (context.isMathOn(this.op)) { - op = this.op === './' ? '/' : this.op; - if (a instanceof Dimension && b instanceof Color) { - a = a.toColor(); - } - if (b instanceof Dimension && a instanceof Color) { - b = b.toColor(); - } - if (!a.operate) { - if (a instanceof Operation && a.op === '/' && context.math === MATH.PARENS_DIVISION) { - return new Operation(this.op, [a, b], this.isSpaced); + if (context.isMathOn(this.op)) { + op = this.op === './' ? '/' : this.op; + if (a instanceof Dimension && b instanceof Color) { + a = a.toColor(); + } + if (b instanceof Dimension && a instanceof Color) { + b = b.toColor(); + } + if (!a.operate) { + if (a instanceof Operation && a.op === '/' && context.math === MATH.PARENS_DIVISION) { + return new Operation(this.op, [a, b], this.isSpaced); + } + throw { type: 'Operation', + message: 'Operation on an invalid type' }; } - throw { type: 'Operation', - message: 'Operation on an invalid type' }; - } - return a.operate(context, op, b); - } else { - return new Operation(this.op, [a, b], this.isSpaced); - } -}; + return a.operate(context, op, b); + } else { + return new Operation(this.op, [a, b], this.isSpaced); + } + }, -Operation.prototype.genCSS = function(context, output) { - this.operands[0].genCSS(context, output); - if (this.isSpaced) { - output.add(' '); - } - output.add(this.op); - if (this.isSpaced) { - output.add(' '); + genCSS(context, output) { + this.operands[0].genCSS(context, output); + if (this.isSpaced) { + output.add(' '); + } + output.add(this.op); + if (this.isSpaced) { + output.add(' '); + } + this.operands[1].genCSS(context, output); } - this.operands[1].genCSS(context, output); -}; +}); -Operation.prototype.type = 'Operation'; export default Operation; diff --git a/packages/less/src/less/tree/paren.js b/packages/less/src/less/tree/paren.js index b71f4c49d..6e0d889a9 100644 --- a/packages/less/src/less/tree/paren.js +++ b/packages/less/src/less/tree/paren.js @@ -4,17 +4,18 @@ const Paren = function(node) { this.value = node; }; -Paren.prototype = new Node(); +Paren.prototype = Object.assign(new Node(), { + type: 'Paren', -Paren.prototype.genCSS = function(context, output) { - output.add('('); - this.value.genCSS(context, output); - output.add(')'); -} + genCSS(context, output) { + output.add('('); + this.value.genCSS(context, output); + output.add(')'); + }, -Paren.prototype.eval = function(context) { - return new Paren(this.value.eval(context)); -}; + eval(context) { + return new Paren(this.value.eval(context)); + } +}); -Paren.prototype.type = 'Paren'; export default Paren; diff --git a/packages/less/src/less/tree/property.js b/packages/less/src/less/tree/property.js index e1d194916..d3b34fce7 100644 --- a/packages/less/src/less/tree/property.js +++ b/packages/less/src/less/tree/property.js @@ -7,69 +7,70 @@ const Property = function(name, index, currentFileInfo) { this._fileInfo = currentFileInfo; }; -Property.prototype = new Node(); +Property.prototype = Object.assign(new Node(), { + type: 'Property', -Property.prototype.eval = function(context) { - let property; - const name = this.name; - // TODO: shorten this reference - const mergeRules = context.pluginManager.less.visitors.ToCSSVisitor.prototype._mergeRules; + eval(context) { + let property; + const name = this.name; + // TODO: shorten this reference + const mergeRules = context.pluginManager.less.visitors.ToCSSVisitor.prototype._mergeRules; - if (this.evaluating) { - throw { type: 'Name', - message: `Recursive property reference for ${name}`, - filename: this.fileInfo().filename, - index: this.getIndex() }; - } + if (this.evaluating) { + throw { type: 'Name', + message: `Recursive property reference for ${name}`, + filename: this.fileInfo().filename, + index: this.getIndex() }; + } - this.evaluating = true; + this.evaluating = true; - property = this.find(context.frames, frame => { - let v; - const vArr = frame.property(name); - if (vArr) { - for (let i = 0; i < vArr.length; i++) { - v = vArr[i]; + property = this.find(context.frames, function (frame) { + let v; + const vArr = frame.property(name); + if (vArr) { + for (let i = 0; i < vArr.length; i++) { + v = vArr[i]; - vArr[i] = new Declaration(v.name, - v.value, - v.important, - v.merge, - v.index, - v.currentFileInfo, - v.inline, - v.variable - ); - } - mergeRules(vArr); + vArr[i] = new Declaration(v.name, + v.value, + v.important, + v.merge, + v.index, + v.currentFileInfo, + v.inline, + v.variable + ); + } + mergeRules(vArr); - v = vArr[vArr.length - 1]; - if (v.important) { - const importantScope = context.importantScope[context.importantScope.length - 1]; - importantScope.important = v.important; + v = vArr[vArr.length - 1]; + if (v.important) { + const importantScope = context.importantScope[context.importantScope.length - 1]; + importantScope.important = v.important; + } + v = v.value.eval(context); + return v; } - v = v.value.eval(context); - return v; + }); + if (property) { + this.evaluating = false; + return property; + } else { + throw { type: 'Name', + message: `Property '${name}' is undefined`, + filename: this.currentFileInfo.filename, + index: this.index }; } - }); - if (property) { - this.evaluating = false; - return property; - } else { - throw { type: 'Name', - message: `Property '${name}' is undefined`, - filename: this.currentFileInfo.filename, - index: this.index }; - } -}; + }, -Property.prototype.find = function(obj, fun) { - for (let i = 0, r; i < obj.length; i++) { - r = fun.call(obj, obj[i]); - if (r) { return r; } + find(obj, fun) { + for (let i = 0, r; i < obj.length; i++) { + r = fun.call(obj, obj[i]); + if (r) { return r; } + } + return null; } - return null; -}; +}); -Property.prototype.type = 'Property'; export default Property; diff --git a/packages/less/src/less/tree/quoted.js b/packages/less/src/less/tree/quoted.js index cb44a9211..d73c40ca6 100644 --- a/packages/less/src/less/tree/quoted.js +++ b/packages/less/src/less/tree/quoted.js @@ -2,6 +2,7 @@ import Node from './node'; import Variable from './variable'; import Property from './property'; + const Quoted = function(str, content, escaped, index, currentFileInfo) { this.escaped = (escaped == null) ? true : escaped; this.value = content || ''; @@ -13,55 +14,55 @@ const Quoted = function(str, content, escaped, index, currentFileInfo) { this.allowRoot = escaped; }; -Quoted.prototype = new Node(); +Quoted.prototype = Object.assign(new Node(), { + type: 'Quoted', -Quoted.prototype.genCSS = function(context, output) { - if (!this.escaped) { - output.add(this.quote, this.fileInfo(), this.getIndex()); - } - output.add(this.value); - if (!this.escaped) { - output.add(this.quote); - } -}; + genCSS(context, output) { + if (!this.escaped) { + output.add(this.quote, this.fileInfo(), this.getIndex()); + } + output.add(this.value); + if (!this.escaped) { + output.add(this.quote); + } + }, -Quoted.prototype.containsVariables = function() { - return this.value.match(this.variableRegex); -}; + containsVariables() { + return this.value.match(this.variableRegex); + }, -Quoted.prototype.eval = function(context) { - const that = this; - let value = this.value; - const variableReplacement = (_, name) => { - const v = new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context, true); - return (v instanceof Quoted) ? v.value : v.toCSS(); - }; - const propertyReplacement = (_, name) => { - const v = new Property(`$${name}`, that.getIndex(), that.fileInfo()).eval(context, true); - return (v instanceof Quoted) ? v.value : v.toCSS(); - }; - function iterativeReplace(value, regexp, replacementFnc) { - let evaluatedValue = value; - do { - value = evaluatedValue.toString(); - evaluatedValue = value.replace(regexp, replacementFnc); - } while (value !== evaluatedValue); - return evaluatedValue; - } - value = iterativeReplace(value, this.variableRegex, variableReplacement); - value = iterativeReplace(value, this.propRegex, propertyReplacement); - - return new Quoted(this.quote + value + this.quote, value, this.escaped, this.getIndex(), this.fileInfo()); -}; + eval(context) { + const that = this; + let value = this.value; + const variableReplacement = function (_, name) { + const v = new Variable(`@${name}`, that.getIndex(), that.fileInfo()).eval(context, true); + return (v instanceof Quoted) ? v.value : v.toCSS(); + }; + const propertyReplacement = function (_, name) { + const v = new Property(`$${name}`, that.getIndex(), that.fileInfo()).eval(context, true); + return (v instanceof Quoted) ? v.value : v.toCSS(); + }; + function iterativeReplace(value, regexp, replacementFnc) { + let evaluatedValue = value; + do { + value = evaluatedValue.toString(); + evaluatedValue = value.replace(regexp, replacementFnc); + } while (value !== evaluatedValue); + return evaluatedValue; + } + value = iterativeReplace(value, this.variableRegex, variableReplacement); + value = iterativeReplace(value, this.propRegex, propertyReplacement); + return new Quoted(this.quote + value + this.quote, value, this.escaped, this.getIndex(), this.fileInfo()); + }, -Quoted.prototype.compare = function(other) { - // when comparing quoted strings allow the quote to differ - if (other.type === 'Quoted' && !this.escaped && !other.escaped) { - return Node.numericCompare(this.value, other.value); - } else { - return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; + compare(other) { + // when comparing quoted strings allow the quote to differ + if (other.type === 'Quoted' && !this.escaped && !other.escaped) { + return Node.numericCompare(this.value, other.value); + } else { + return other.toCSS && this.toCSS() === other.toCSS() ? 0 : undefined; + } } -}; +}); -Quoted.prototype.type = 'Quoted'; export default Quoted; diff --git a/packages/less/src/less/tree/ruleset.js b/packages/less/src/less/tree/ruleset.js index 4d5934b69..22f68b75c 100644 --- a/packages/less/src/less/tree/ruleset.js +++ b/packages/less/src/less/tree/ruleset.js @@ -26,839 +26,824 @@ const Ruleset = function(selectors, rules, strictImports, visibilityInfo) { this.setParent(this.rules, this); } -Ruleset.prototype = new Node(); +Ruleset.prototype = Object.assign(new Node(), { + type: 'Ruleset', + isRuleset: true, -Ruleset.prototype.isRulesetLike = function() { - return true; -}; + isRulesetLike() { return true; }, -Ruleset.prototype.accept = function(visitor) { - if (this.paths) { - this.paths = visitor.visitArray(this.paths, true); - } else if (this.selectors) { - this.selectors = visitor.visitArray(this.selectors); - } - if (this.rules && this.rules.length) { - this.rules = visitor.visitArray(this.rules); - } -}; - -Ruleset.prototype.eval = function(context) { - const that = this; - let selectors; - let selCnt; - let selector; - let i; - let hasVariable; - let hasOnePassingSelector = false; - - if (this.selectors && (selCnt = this.selectors.length)) { - selectors = new Array(selCnt); - defaultFunc.error({ - type: 'Syntax', - message: 'it is currently only allowed in parametric mixin guards,' - }); + accept(visitor) { + if (this.paths) { + this.paths = visitor.visitArray(this.paths, true); + } else if (this.selectors) { + this.selectors = visitor.visitArray(this.selectors); + } + if (this.rules && this.rules.length) { + this.rules = visitor.visitArray(this.rules); + } + }, + + eval(context) { + const that = this; + let selectors; + let selCnt; + let selector; + let i; + let hasVariable; + let hasOnePassingSelector = false; + + if (this.selectors && (selCnt = this.selectors.length)) { + selectors = new Array(selCnt); + defaultFunc.error({ + type: 'Syntax', + message: 'it is currently only allowed in parametric mixin guards,' + }); - for (i = 0; i < selCnt; i++) { - selector = this.selectors[i].eval(context); - for (var j = 0; j < selector.elements.length; j++) { - if (selector.elements[j].isVariable) { - hasVariable = true; - break; + for (i = 0; i < selCnt; i++) { + selector = this.selectors[i].eval(context); + for (var j = 0; j < selector.elements.length; j++) { + if (selector.elements[j].isVariable) { + hasVariable = true; + break; + } + } + selectors[i] = selector; + if (selector.evaldCondition) { + hasOnePassingSelector = true; } } - selectors[i] = selector; - if (selector.evaldCondition) { - hasOnePassingSelector = true; + + if (hasVariable) { + const toParseSelectors = new Array(selCnt); + for (i = 0; i < selCnt; i++) { + selector = selectors[i]; + toParseSelectors[i] = selector.toCSS(context); + } + this.parse.parseNode( + toParseSelectors.join(','), + ["selectors"], + selectors[0].getIndex(), + selectors[0].fileInfo(), + function(err, result) { + if (result) { + selectors = utils.flattenArray(result); + } + }); } - } - if (hasVariable) { - const toParseSelectors = new Array(selCnt); - for (i = 0; i < selCnt; i++) { - selector = selectors[i]; - toParseSelectors[i] = selector.toCSS(context); - } - this.parse.parseNode( - toParseSelectors.join(','), - ["selectors"], - selectors[0].getIndex(), - selectors[0].fileInfo(), - (err, result) => { - if (result) { - selectors = utils.flattenArray(result); - } - }); + defaultFunc.reset(); + } else { + hasOnePassingSelector = true; } - defaultFunc.reset(); - } else { - hasOnePassingSelector = true; - } - - let rules = this.rules ? utils.copyArray(this.rules) : null; - const ruleset = new Ruleset(selectors, rules, this.strictImports, this.visibilityInfo()); - let rule; - let subRule; + let rules = this.rules ? utils.copyArray(this.rules) : null; + const ruleset = new Ruleset(selectors, rules, this.strictImports, this.visibilityInfo()); + let rule; + let subRule; - ruleset.originalRuleset = this; - ruleset.root = this.root; - ruleset.firstRoot = this.firstRoot; - ruleset.allowImports = this.allowImports; + ruleset.originalRuleset = this; + ruleset.root = this.root; + ruleset.firstRoot = this.firstRoot; + ruleset.allowImports = this.allowImports; - if (this.debugInfo) { - ruleset.debugInfo = this.debugInfo; - } + if (this.debugInfo) { + ruleset.debugInfo = this.debugInfo; + } - if (!hasOnePassingSelector) { - rules.length = 0; - } + if (!hasOnePassingSelector) { + rules.length = 0; + } - // inherit a function registry from the frames stack when possible; - // otherwise from the global registry - ruleset.functionRegistry = (frames => { - let i = 0; - const n = frames.length; - let found; - for ( ; i !== n ; ++i ) { - found = frames[ i ].functionRegistry; - if ( found ) { return found; } - } - return globalFunctionRegistry; - })(context.frames).inherit(); - - // push the current ruleset to the frames stack - const ctxFrames = context.frames; - ctxFrames.unshift(ruleset); - - // currrent selectors - let ctxSelectors = context.selectors; - if (!ctxSelectors) { - context.selectors = ctxSelectors = []; - } - ctxSelectors.unshift(this.selectors); + // inherit a function registry from the frames stack when possible; + // otherwise from the global registry + ruleset.functionRegistry = (function (frames) { + let i = 0; + const n = frames.length; + let found; + for ( ; i !== n ; ++i ) { + found = frames[ i ].functionRegistry; + if ( found ) { return found; } + } + return globalFunctionRegistry; + }(context.frames)).inherit(); - // Evaluate imports - if (ruleset.root || ruleset.allowImports || !ruleset.strictImports) { - ruleset.evalImports(context); - } + // push the current ruleset to the frames stack + const ctxFrames = context.frames; + ctxFrames.unshift(ruleset); - // Store the frames around mixin definitions, - // so they can be evaluated like closures when the time comes. - const rsRules = ruleset.rules; - for (i = 0; (rule = rsRules[i]); i++) { - if (rule.evalFirst) { - rsRules[i] = rule.eval(context); + // currrent selectors + let ctxSelectors = context.selectors; + if (!ctxSelectors) { + context.selectors = ctxSelectors = []; } - } + ctxSelectors.unshift(this.selectors); - const mediaBlockCount = (context.mediaBlocks && context.mediaBlocks.length) || 0; - - // Evaluate mixin calls. - for (i = 0; (rule = rsRules[i]); i++) { - if (rule.type === 'MixinCall') { - /* jshint loopfunc:true */ - rules = rule.eval(context).filter(r => { - if ((r instanceof Declaration) && r.variable) { - // do not pollute the scope if the variable is - // already there. consider returning false here - // but we need a way to "return" variable from mixins - return !(ruleset.variable(r.name)); - } - return true; - }); - rsRules.splice(...[i, 1].concat(rules)); - i += rules.length - 1; - ruleset.resetCache(); - } else if (rule.type === 'VariableCall') { - /* jshint loopfunc:true */ - rules = rule.eval(context).rules.filter(r => { - if ((r instanceof Declaration) && r.variable) { - // do not pollute the scope at all - return false; - } - return true; - }); - rsRules.splice(...[i, 1].concat(rules)); - i += rules.length - 1; - ruleset.resetCache(); + // Evaluate imports + if (ruleset.root || ruleset.allowImports || !ruleset.strictImports) { + ruleset.evalImports(context); } - } - // Evaluate everything else - for (i = 0; (rule = rsRules[i]); i++) { - if (!rule.evalFirst) { - rsRules[i] = rule = rule.eval ? rule.eval(context) : rule; + // Store the frames around mixin definitions, + // so they can be evaluated like closures when the time comes. + const rsRules = ruleset.rules; + for (i = 0; (rule = rsRules[i]); i++) { + if (rule.evalFirst) { + rsRules[i] = rule.eval(context); + } } - } - // Evaluate everything else - for (i = 0; (rule = rsRules[i]); i++) { - // for rulesets, check if it is a css guard and can be removed - if (rule instanceof Ruleset && rule.selectors && rule.selectors.length === 1) { - // check if it can be folded in (e.g. & where) - if (rule.selectors[0] && rule.selectors[0].isJustParentSelector()) { - rsRules.splice(i--, 1); - - for (var j = 0; (subRule = rule.rules[j]); j++) { - if (subRule instanceof Node) { - subRule.copyVisibilityInfo(rule.visibilityInfo()); - if (!(subRule instanceof Declaration) || !subRule.variable) { - rsRules.splice(++i, 0, subRule); - } + const mediaBlockCount = (context.mediaBlocks && context.mediaBlocks.length) || 0; + + // Evaluate mixin calls. + for (i = 0; (rule = rsRules[i]); i++) { + if (rule.type === 'MixinCall') { + /* jshint loopfunc:true */ + rules = rule.eval(context).filter(function(r) { + if ((r instanceof Declaration) && r.variable) { + // do not pollute the scope if the variable is + // already there. consider returning false here + // but we need a way to "return" variable from mixins + return !(ruleset.variable(r.name)); } - } + return true; + }); + rsRules.splice.apply(rsRules, [i, 1].concat(rules)); + i += rules.length - 1; + ruleset.resetCache(); + } else if (rule.type === 'VariableCall') { + /* jshint loopfunc:true */ + rules = rule.eval(context).rules.filter(function(r) { + if ((r instanceof Declaration) && r.variable) { + // do not pollute the scope at all + return false; + } + return true; + }); + rsRules.splice.apply(rsRules, [i, 1].concat(rules)); + i += rules.length - 1; + ruleset.resetCache(); } } - } - - // Pop the stack - ctxFrames.shift(); - ctxSelectors.shift(); - if (context.mediaBlocks) { - for (i = mediaBlockCount; i < context.mediaBlocks.length; i++) { - context.mediaBlocks[i].bubbleSelectors(selectors); + // Evaluate everything else + for (i = 0; (rule = rsRules[i]); i++) { + if (!rule.evalFirst) { + rsRules[i] = rule = rule.eval ? rule.eval(context) : rule; + } } - } - return ruleset; -}; - -Ruleset.prototype.evalImports = function(context) { - const rules = this.rules; - let i; - let importRules; - if (!rules) { return; } - - for (i = 0; i < rules.length; i++) { - if (rules[i].type === 'Import') { - importRules = rules[i].eval(context); - if (importRules && (importRules.length || importRules.length === 0)) { - rules.splice(...[i, 1].concat(importRules)); - i += importRules.length - 1; - } else { - rules.splice(i, 1, importRules); + // Evaluate everything else + for (i = 0; (rule = rsRules[i]); i++) { + // for rulesets, check if it is a css guard and can be removed + if (rule instanceof Ruleset && rule.selectors && rule.selectors.length === 1) { + // check if it can be folded in (e.g. & where) + if (rule.selectors[0] && rule.selectors[0].isJustParentSelector()) { + rsRules.splice(i--, 1); + + for (var j = 0; (subRule = rule.rules[j]); j++) { + if (subRule instanceof Node) { + subRule.copyVisibilityInfo(rule.visibilityInfo()); + if (!(subRule instanceof Declaration) || !subRule.variable) { + rsRules.splice(++i, 0, subRule); + } + } + } + } } - this.resetCache(); } - } -}; -Ruleset.prototype.makeImportant = function() { - const result = new Ruleset(this.selectors, this.rules.map(r => { - if (r.makeImportant) { - return r.makeImportant(); - } else { - return r; + // Pop the stack + ctxFrames.shift(); + ctxSelectors.shift(); + + if (context.mediaBlocks) { + for (i = mediaBlockCount; i < context.mediaBlocks.length; i++) { + context.mediaBlocks[i].bubbleSelectors(selectors); + } } - }), this.strictImports, this.visibilityInfo()); - return result; -}; + return ruleset; + }, -Ruleset.prototype.matchArgs = function(args) { - return !args || args.length === 0; -}; + evalImports(context) { + const rules = this.rules; + let i; + let importRules; + if (!rules) { return; } + + for (i = 0; i < rules.length; i++) { + if (rules[i].type === 'Import') { + importRules = rules[i].eval(context); + if (importRules && (importRules.length || importRules.length === 0)) { + rules.splice.apply(rules, [i, 1].concat(importRules)); + i += importRules.length - 1; + } else { + rules.splice(i, 1, importRules); + } + this.resetCache(); + } + } + }, -// lets you call a css selector with a guard -Ruleset.prototype.matchCondition = function(args, context) { - const lastSelector = this.selectors[this.selectors.length - 1]; - if (!lastSelector.evaldCondition) { - return false; - } - if (lastSelector.condition && - !lastSelector.condition.eval( - new contexts.Eval(context, - context.frames))) { - return false; - } - return true; -}; + makeImportant() { + const result = new Ruleset(this.selectors, this.rules.map(function (r) { + if (r.makeImportant) { + return r.makeImportant(); + } else { + return r; + } + }), this.strictImports, this.visibilityInfo()); -Ruleset.prototype.resetCache = function() { - this._rulesets = null; - this._variables = null; - this._properties = null; - this._lookups = {}; -}; - -Ruleset.prototype.variables = function() { - if (!this._variables) { - this._variables = !this.rules ? {} : this.rules.reduce((hash, r) => { - if (r instanceof Declaration && r.variable === true) { - hash[r.name] = r; - } - // when evaluating variables in an import statement, imports have not been eval'd - // so we need to go inside import statements. - // guard against root being a string (in the case of inlined less) - if (r.type === 'Import' && r.root && r.root.variables) { - const vars = r.root.variables(); - for (const name in vars) { - if (vars.hasOwnProperty(name)) { - hash[name] = r.root.variable(name); - } + return result; + }, + + matchArgs(args) { + return !args || args.length === 0; + }, + + // lets you call a css selector with a guard + matchCondition(args, context) { + const lastSelector = this.selectors[this.selectors.length - 1]; + if (!lastSelector.evaldCondition) { + return false; + } + if (lastSelector.condition && + !lastSelector.condition.eval( + new contexts.Eval(context, + context.frames))) { + return false; + } + return true; + }, + + resetCache() { + this._rulesets = null; + this._variables = null; + this._properties = null; + this._lookups = {}; + }, + + variables() { + if (!this._variables) { + this._variables = !this.rules ? {} : this.rules.reduce(function (hash, r) { + if (r instanceof Declaration && r.variable === true) { + hash[r.name] = r; } - } - return hash; - }, {}); - } - return this._variables; -}; - -Ruleset.prototype.properties = function() { - if (!this._properties) { - this._properties = !this.rules ? {} : this.rules.reduce((hash, r) => { - if (r instanceof Declaration && r.variable !== true) { - const name = (r.name.length === 1) && (r.name[0] instanceof Keyword) ? - r.name[0].value : r.name; - // Properties don't overwrite as they can merge - if (!hash[`$${name}`]) { - hash[`$${name}`] = [ r ]; + // when evaluating variables in an import statement, imports have not been eval'd + // so we need to go inside import statements. + // guard against root being a string (in the case of inlined less) + if (r.type === 'Import' && r.root && r.root.variables) { + const vars = r.root.variables(); + for (const name in vars) { + if (vars.hasOwnProperty(name)) { + hash[name] = r.root.variable(name); + } + } } - else { - hash[`$${name}`].push(r); + return hash; + }, {}); + } + return this._variables; + }, + + properties() { + if (!this._properties) { + this._properties = !this.rules ? {} : this.rules.reduce(function (hash, r) { + if (r instanceof Declaration && r.variable !== true) { + const name = (r.name.length === 1) && (r.name[0] instanceof Keyword) ? + r.name[0].value : r.name; + // Properties don't overwrite as they can merge + if (!hash[`$${name}`]) { + hash[`$${name}`] = [ r ]; + } + else { + hash[`$${name}`].push(r); + } } - } - return hash; - }, {}); - } - return this._properties; -}; - -Ruleset.prototype.variable = function(name) { - const decl = this.variables()[name]; - if (decl) { - return this.parseValue(decl); - } -}; + return hash; + }, {}); + } + return this._properties; + }, -Ruleset.prototype.property = function(name) { - const decl = this.properties()[name]; - if (decl) { - return this.parseValue(decl); - } -}; + variable(name) { + const decl = this.variables()[name]; + if (decl) { + return this.parseValue(decl); + } + }, -Ruleset.prototype.lastDeclaration = function() { - for (let i = this.rules.length; i > 0; i--) { - const decl = this.rules[i - 1]; - if (decl instanceof Declaration) { + property(name) { + const decl = this.properties()[name]; + if (decl) { return this.parseValue(decl); } - } -}; + }, -Ruleset.prototype.parseValue = function(toParse) { - const self = this; - function transformDeclaration(decl) { - if (decl.value instanceof Anonymous && !decl.parsed) { - if (typeof decl.value.value === 'string') { - this.parse.parseNode( - decl.value.value, - ['value', 'important'], - decl.value.getIndex(), - decl.fileInfo(), - (err, result) => { - if (err) { - decl.parsed = true; - } - if (result) { - decl.value = result[0]; - decl.important = result[1] || ''; - decl.parsed = true; - } - }); - } else { - decl.parsed = true; + lastDeclaration() { + for (let i = this.rules.length; i > 0; i--) { + const decl = this.rules[i - 1]; + if (decl instanceof Declaration) { + return this.parseValue(decl); } + } + }, + + parseValue(toParse) { + const self = this; + function transformDeclaration(decl) { + if (decl.value instanceof Anonymous && !decl.parsed) { + if (typeof decl.value.value === 'string') { + this.parse.parseNode( + decl.value.value, + ['value', 'important'], + decl.value.getIndex(), + decl.fileInfo(), + function(err, result) { + if (err) { + decl.parsed = true; + } + if (result) { + decl.value = result[0]; + decl.important = result[1] || ''; + decl.parsed = true; + } + }); + } else { + decl.parsed = true; + } - return decl; + return decl; + } + else { + return decl; + } + } + if (!Array.isArray(toParse)) { + return transformDeclaration.call(self, toParse); } else { - return decl; + const nodes = []; + toParse.forEach(function(n) { + nodes.push(transformDeclaration.call(self, n)); + }); + return nodes; } - } - if (!Array.isArray(toParse)) { - return transformDeclaration.call(self, toParse); - } - else { - const nodes = []; - toParse.forEach(n => { - nodes.push(transformDeclaration.call(self, n)); - }); - return nodes; - } -}; + }, -Ruleset.prototype.rulesets = function() { - if (!this.rules) { return []; } + rulesets() { + if (!this.rules) { return []; } - const filtRules = []; - const rules = this.rules; - let i; - let rule; + const filtRules = []; + const rules = this.rules; + let i; + let rule; - for (i = 0; (rule = rules[i]); i++) { - if (rule.isRuleset) { - filtRules.push(rule); + for (i = 0; (rule = rules[i]); i++) { + if (rule.isRuleset) { + filtRules.push(rule); + } } - } - return filtRules; -}; + return filtRules; + }, -Ruleset.prototype.prependRule = function(rule) { - const rules = this.rules; - if (rules) { - rules.unshift(rule); - } else { - this.rules = [ rule ]; - } - this.setParent(rule, this); -}; - -Ruleset.prototype.find = function(selector, self = this, filter) { - const rules = []; - let match; - let foundMixins; - const key = selector.toCSS(); - - if (key in this._lookups) { return this._lookups[key]; } - - this.rulesets().forEach(rule => { - if (rule !== self) { - for (let j = 0; j < rule.selectors.length; j++) { - match = selector.match(rule.selectors[j]); - if (match) { - if (selector.elements.length > match) { - if (!filter || filter(rule)) { - foundMixins = rule.find(new Selector(selector.elements.slice(match)), self, filter); - for (let i = 0; i < foundMixins.length; ++i) { - foundMixins[i].path.push(rule); + prependRule(rule) { + const rules = this.rules; + if (rules) { + rules.unshift(rule); + } else { + this.rules = [ rule ]; + } + this.setParent(rule, this); + }, + + find(selector, self, filter) { + self = self || this; + const rules = []; + let match; + let foundMixins; + const key = selector.toCSS(); + + if (key in this._lookups) { return this._lookups[key]; } + + this.rulesets().forEach(function (rule) { + if (rule !== self) { + for (let j = 0; j < rule.selectors.length; j++) { + match = selector.match(rule.selectors[j]); + if (match) { + if (selector.elements.length > match) { + if (!filter || filter(rule)) { + foundMixins = rule.find(new Selector(selector.elements.slice(match)), self, filter); + for (let i = 0; i < foundMixins.length; ++i) { + foundMixins[i].path.push(rule); + } + Array.prototype.push.apply(rules, foundMixins); } - Array.prototype.push.apply(rules, foundMixins); + } else { + rules.push({ rule, path: []}); } - } else { - rules.push({ rule, path: []}); + break; } - break; } } - } - }); - this._lookups[key] = rules; - return rules; -}; + }); + this._lookups[key] = rules; + return rules; + }, -Ruleset.prototype.genCSS = function(context, output) { - let i; - let j; - const charsetRuleNodes = []; - let ruleNodes = []; + genCSS(context, output) { + let i; + let j; + const charsetRuleNodes = []; + let ruleNodes = []; - let // Line number debugging - debugInfo; + let // Line number debugging + debugInfo; - let rule; - let path; + let rule; + let path; - context.tabLevel = (context.tabLevel || 0); + context.tabLevel = (context.tabLevel || 0); - if (!this.root) { - context.tabLevel++; - } + if (!this.root) { + context.tabLevel++; + } - const tabRuleStr = context.compress ? '' : Array(context.tabLevel + 1).join(' '); - const tabSetStr = context.compress ? '' : Array(context.tabLevel).join(' '); - let sep; + const tabRuleStr = context.compress ? '' : Array(context.tabLevel + 1).join(' '); + const tabSetStr = context.compress ? '' : Array(context.tabLevel).join(' '); + let sep; - let charsetNodeIndex = 0; - let importNodeIndex = 0; - for (i = 0; (rule = this.rules[i]); i++) { - if (rule instanceof Comment) { - if (importNodeIndex === i) { + let charsetNodeIndex = 0; + let importNodeIndex = 0; + for (i = 0; (rule = this.rules[i]); i++) { + if (rule instanceof Comment) { + if (importNodeIndex === i) { + importNodeIndex++; + } + ruleNodes.push(rule); + } else if (rule.isCharset && rule.isCharset()) { + ruleNodes.splice(charsetNodeIndex, 0, rule); + charsetNodeIndex++; + importNodeIndex++; + } else if (rule.type === 'Import') { + ruleNodes.splice(importNodeIndex, 0, rule); importNodeIndex++; + } else { + ruleNodes.push(rule); } - ruleNodes.push(rule); - } else if (rule.isCharset && rule.isCharset()) { - ruleNodes.splice(charsetNodeIndex, 0, rule); - charsetNodeIndex++; - importNodeIndex++; - } else if (rule.type === 'Import') { - ruleNodes.splice(importNodeIndex, 0, rule); - importNodeIndex++; - } else { - ruleNodes.push(rule); } - } - ruleNodes = charsetRuleNodes.concat(ruleNodes); + ruleNodes = charsetRuleNodes.concat(ruleNodes); - // If this is the root node, we don't render - // a selector, or {}. - if (!this.root) { - debugInfo = getDebugInfo(context, this, tabSetStr); + // If this is the root node, we don't render + // a selector, or {}. + if (!this.root) { + debugInfo = getDebugInfo(context, this, tabSetStr); - if (debugInfo) { - output.add(debugInfo); - output.add(tabSetStr); - } + if (debugInfo) { + output.add(debugInfo); + output.add(tabSetStr); + } - const paths = this.paths; - const pathCnt = paths.length; - let pathSubCnt; + const paths = this.paths; + const pathCnt = paths.length; + let pathSubCnt; - sep = context.compress ? ',' : (`,\n${tabSetStr}`); + sep = context.compress ? ',' : (`,\n${tabSetStr}`); - for (i = 0; i < pathCnt; i++) { - path = paths[i]; - if (!(pathSubCnt = path.length)) { continue; } - if (i > 0) { output.add(sep); } + for (i = 0; i < pathCnt; i++) { + path = paths[i]; + if (!(pathSubCnt = path.length)) { continue; } + if (i > 0) { output.add(sep); } - context.firstSelector = true; - path[0].genCSS(context, output); + context.firstSelector = true; + path[0].genCSS(context, output); - context.firstSelector = false; - for (j = 1; j < pathSubCnt; j++) { - path[j].genCSS(context, output); + context.firstSelector = false; + for (j = 1; j < pathSubCnt; j++) { + path[j].genCSS(context, output); + } } + + output.add((context.compress ? '{' : ' {\n') + tabRuleStr); } - output.add((context.compress ? '{' : ' {\n') + tabRuleStr); - } + // Compile rules and rulesets + for (i = 0; (rule = ruleNodes[i]); i++) { - // Compile rules and rulesets - for (i = 0; (rule = ruleNodes[i]); i++) { + if (i + 1 === ruleNodes.length) { + context.lastRule = true; + } - if (i + 1 === ruleNodes.length) { - context.lastRule = true; - } + const currentLastRule = context.lastRule; + if (rule.isRulesetLike(rule)) { + context.lastRule = false; + } - const currentLastRule = context.lastRule; - if (rule.isRulesetLike(rule)) { - context.lastRule = false; - } + if (rule.genCSS) { + rule.genCSS(context, output); + } else if (rule.value) { + output.add(rule.value.toString()); + } + + context.lastRule = currentLastRule; - if (rule.genCSS) { - rule.genCSS(context, output); - } else if (rule.value) { - output.add(rule.value.toString()); + if (!context.lastRule && rule.isVisible()) { + output.add(context.compress ? '' : (`\n${tabRuleStr}`)); + } else { + context.lastRule = false; + } } - context.lastRule = currentLastRule; + if (!this.root) { + output.add((context.compress ? '}' : `\n${tabSetStr}}`)); + context.tabLevel--; + } - if (!context.lastRule && rule.isVisible()) { - output.add(context.compress ? '' : (`\n${tabRuleStr}`)); - } else { - context.lastRule = false; + if (!output.isEmpty() && !context.compress && this.firstRoot) { + output.add('\n'); } - } + }, - if (!this.root) { - output.add((context.compress ? '}' : `\n${tabSetStr}}`)); - context.tabLevel--; - } + joinSelectors(paths, context, selectors) { + for (let s = 0; s < selectors.length; s++) { + this.joinSelector(paths, context, selectors[s]); + } + }, - if (!output.isEmpty() && !context.compress && this.firstRoot) { - output.add('\n'); - } -}; + joinSelector(paths, context, selector) { -Ruleset.prototype.joinSelectors = function(paths, context, selectors) { - for (let s = 0; s < selectors.length; s++) { - this.joinSelector(paths, context, selectors[s]); - } -}; + function createParenthesis(elementsToPak, originalElement) { + let replacementParen, j; + if (elementsToPak.length === 0) { + replacementParen = new Paren(elementsToPak[0]); + } else { + const insideParent = new Array(elementsToPak.length); + for (j = 0; j < elementsToPak.length; j++) { + insideParent[j] = new Element( + null, + elementsToPak[j], + originalElement.isVariable, + originalElement._index, + originalElement._fileInfo + ); + } + replacementParen = new Paren(new Selector(insideParent)); + } + return replacementParen; + } + + function createSelector(containedElement, originalElement) { + let element, selector; + element = new Element(null, containedElement, originalElement.isVariable, originalElement._index, originalElement._fileInfo); + selector = new Selector([element]); + return selector; + } + + // joins selector path from `beginningPath` with selector path in `addPath` + // `replacedElement` contains element that is being replaced by `addPath` + // returns concatenated path + function addReplacementIntoPath(beginningPath, addPath, replacedElement, originalSelector) { + let newSelectorPath, lastSelector, newJoinedSelector; + // our new selector path + newSelectorPath = []; + + // construct the joined selector - if & is the first thing this will be empty, + // if not newJoinedSelector will be the last set of elements in the selector + if (beginningPath.length > 0) { + newSelectorPath = utils.copyArray(beginningPath); + lastSelector = newSelectorPath.pop(); + newJoinedSelector = originalSelector.createDerived(utils.copyArray(lastSelector.elements)); + } + else { + newJoinedSelector = originalSelector.createDerived([]); + } -Ruleset.prototype.joinSelector = function(paths, context, selector) { - function createParenthesis(elementsToPak, originalElement) { - let replacementParen; - let j; - if (elementsToPak.length === 0) { - replacementParen = new Paren(elementsToPak[0]); - } else { - const insideParent = new Array(elementsToPak.length); - for (j = 0; j < elementsToPak.length; j++) { - insideParent[j] = new Element( - null, - elementsToPak[j], - originalElement.isVariable, - originalElement._index, - originalElement._fileInfo - ); - } - replacementParen = new Paren(new Selector(insideParent)); - } - return replacementParen; - } + if (addPath.length > 0) { + // /deep/ is a CSS4 selector - (removed, so should deprecate) + // that is valid without anything in front of it + // so if the & does not have a combinator that is "" or " " then + // and there is a combinator on the parent, then grab that. + // this also allows + a { & .b { .a & { ... though not sure why you would want to do that + let combinator = replacedElement.combinator; + + const parentEl = addPath[0].elements[0]; + if (combinator.emptyOrWhitespace && !parentEl.combinator.emptyOrWhitespace) { + combinator = parentEl.combinator; + } + // join the elements so far with the first part of the parent + newJoinedSelector.elements.push(new Element( + combinator, + parentEl.value, + replacedElement.isVariable, + replacedElement._index, + replacedElement._fileInfo + )); + newJoinedSelector.elements = newJoinedSelector.elements.concat(addPath[0].elements.slice(1)); + } - function createSelector(containedElement, originalElement) { - let element; - let selector; - element = new Element(null, containedElement, originalElement.isVariable, originalElement._index, originalElement._fileInfo); - selector = new Selector([element]); - return selector; - } + // now add the joined selector - but only if it is not empty + if (newJoinedSelector.elements.length !== 0) { + newSelectorPath.push(newJoinedSelector); + } - // joins selector path from `beginningPath` with selector path in `addPath` - // `replacedElement` contains element that is being replaced by `addPath` - // returns concatenated path - function addReplacementIntoPath(beginningPath, addPath, replacedElement, originalSelector) { - let newSelectorPath; - let lastSelector; - let newJoinedSelector; - // our new selector path - newSelectorPath = []; - - // construct the joined selector - if & is the first thing this will be empty, - // if not newJoinedSelector will be the last set of elements in the selector - if (beginningPath.length > 0) { - newSelectorPath = utils.copyArray(beginningPath); - lastSelector = newSelectorPath.pop(); - newJoinedSelector = originalSelector.createDerived(utils.copyArray(lastSelector.elements)); - } - else { - newJoinedSelector = originalSelector.createDerived([]); + // put together the parent selectors after the join (e.g. the rest of the parent) + if (addPath.length > 1) { + let restOfPath = addPath.slice(1); + restOfPath = restOfPath.map(function (selector) { + return selector.createDerived(selector.elements, []); + }); + newSelectorPath = newSelectorPath.concat(restOfPath); + } + return newSelectorPath; } - if (addPath.length > 0) { - // /deep/ is a CSS4 selector - (removed, so should deprecate) - // that is valid without anything in front of it - // so if the & does not have a combinator that is "" or " " then - // and there is a combinator on the parent, then grab that. - // this also allows + a { & .b { .a & { ... though not sure why you would want to do that - let combinator = replacedElement.combinator; - - const parentEl = addPath[0].elements[0]; - if (combinator.emptyOrWhitespace && !parentEl.combinator.emptyOrWhitespace) { - combinator = parentEl.combinator; + // joins selector path from `beginningPath` with every selector path in `addPaths` array + // `replacedElement` contains element that is being replaced by `addPath` + // returns array with all concatenated paths + function addAllReplacementsIntoPath( beginningPath, addPaths, replacedElement, originalSelector, result) { + let j; + for (j = 0; j < beginningPath.length; j++) { + const newSelectorPath = addReplacementIntoPath(beginningPath[j], addPaths, replacedElement, originalSelector); + result.push(newSelectorPath); } - // join the elements so far with the first part of the parent - newJoinedSelector.elements.push(new Element( - combinator, - parentEl.value, - replacedElement.isVariable, - replacedElement._index, - replacedElement._fileInfo - )); - newJoinedSelector.elements = newJoinedSelector.elements.concat(addPath[0].elements.slice(1)); + return result; } - // now add the joined selector - but only if it is not empty - if (newJoinedSelector.elements.length !== 0) { - newSelectorPath.push(newJoinedSelector); - } + function mergeElementsOnToSelectors(elements, selectors) { + let i, sel; - // put together the parent selectors after the join (e.g. the rest of the parent) - if (addPath.length > 1) { - let restOfPath = addPath.slice(1); - restOfPath = restOfPath.map(selector => selector.createDerived(selector.elements, [])); - newSelectorPath = newSelectorPath.concat(restOfPath); - } - return newSelectorPath; - } + if (elements.length === 0) { + return ; + } + if (selectors.length === 0) { + selectors.push([ new Selector(elements) ]); + return; + } - // joins selector path from `beginningPath` with every selector path in `addPaths` array - // `replacedElement` contains element that is being replaced by `addPath` - // returns array with all concatenated paths - function addAllReplacementsIntoPath( beginningPath, addPaths, replacedElement, originalSelector, result) { - let j; - for (j = 0; j < beginningPath.length; j++) { - const newSelectorPath = addReplacementIntoPath(beginningPath[j], addPaths, replacedElement, originalSelector); - result.push(newSelectorPath); + for (i = 0; (sel = selectors[i]); i++) { + // if the previous thing in sel is a parent this needs to join on to it + if (sel.length > 0) { + sel[sel.length - 1] = sel[sel.length - 1].createDerived(sel[sel.length - 1].elements.concat(elements)); + } + else { + sel.push(new Selector(elements)); + } + } } - return result; - } - function mergeElementsOnToSelectors(elements, selectors) { - let i; - let sel; + // replace all parent selectors inside `inSelector` by content of `context` array + // resulting selectors are returned inside `paths` array + // returns true if `inSelector` contained at least one parent selector + function replaceParentSelector(paths, context, inSelector) { + // The paths are [[Selector]] + // The first list is a list of comma separated selectors + // The inner list is a list of inheritance separated selectors + // e.g. + // .a, .b { + // .c { + // } + // } + // == [[.a] [.c]] [[.b] [.c]] + // + let i, j, k, currentElements, newSelectors, selectorsMultiplied, sel, el, hadParentSelector = false, length, lastSelector; + function findNestedSelector(element) { + let maybeSelector; + if (!(element.value instanceof Paren)) { + return null; + } - if (elements.length === 0) { - return ; - } - if (selectors.length === 0) { - selectors.push([ new Selector(elements) ]); - return; - } + maybeSelector = element.value.value; + if (!(maybeSelector instanceof Selector)) { + return null; + } - for (i = 0; (sel = selectors[i]); i++) { - // if the previous thing in sel is a parent this needs to join on to it - if (sel.length > 0) { - sel[sel.length - 1] = sel[sel.length - 1].createDerived(sel[sel.length - 1].elements.concat(elements)); + return maybeSelector; } - else { - sel.push(new Selector(elements)); - } - } - } - // replace all parent selectors inside `inSelector` by content of `context` array - // resulting selectors are returned inside `paths` array - // returns true if `inSelector` contained at least one parent selector - function replaceParentSelector(paths, context, inSelector) { - // The paths are [[Selector]] - // The first list is a list of comma separated selectors - // The inner list is a list of inheritance separated selectors - // e.g. - // .a, .b { - // .c { - // } - // } - // == [[.a] [.c]] [[.b] [.c]] - // - let i; + // the elements from the current selector so far + currentElements = []; + // the current list of new selectors to add to the path. + // We will build it up. We initiate it with one empty selector as we "multiply" the new selectors + // by the parents + newSelectors = [ + [] + ]; + + for (i = 0; (el = inSelector.elements[i]); i++) { + // non parent reference elements just get added + if (el.value !== '&') { + const nestedSelector = findNestedSelector(el); + if (nestedSelector != null) { + // merge the current list of non parent selector elements + // on to the current list of selectors to add + mergeElementsOnToSelectors(currentElements, newSelectors); + + const nestedPaths = []; + let replaced; + const replacedNewSelectors = []; + replaced = replaceParentSelector(nestedPaths, context, nestedSelector); + hadParentSelector = hadParentSelector || replaced; + // the nestedPaths array should have only one member - replaceParentSelector does not multiply selectors + for (k = 0; k < nestedPaths.length; k++) { + const replacementSelector = createSelector(createParenthesis(nestedPaths[k], el), el); + addAllReplacementsIntoPath(newSelectors, [replacementSelector], el, inSelector, replacedNewSelectors); + } + newSelectors = replacedNewSelectors; + currentElements = []; + } else { + currentElements.push(el); + } + + } else { + hadParentSelector = true; + // the new list of selectors to add + selectorsMultiplied = []; - let j; - let k; - let currentElements; - let newSelectors; - let selectorsMultiplied; - let sel; - let el; - let hadParentSelector = false; - let length; - let lastSelector; - function findNestedSelector(element) { - let maybeSelector; - if (!(element.value instanceof Paren)) { - return null; - } - - maybeSelector = element.value.value; - if (!(maybeSelector instanceof Selector)) { - return null; - } - - return maybeSelector; - } - - // the elements from the current selector so far - currentElements = []; - // the current list of new selectors to add to the path. - // We will build it up. We initiate it with one empty selector as we "multiply" the new selectors - // by the parents - newSelectors = [ - [] - ]; - - for (i = 0; (el = inSelector.elements[i]); i++) { - // non parent reference elements just get added - if (el.value !== '&') { - const nestedSelector = findNestedSelector(el); - if (nestedSelector != null) { // merge the current list of non parent selector elements // on to the current list of selectors to add mergeElementsOnToSelectors(currentElements, newSelectors); - const nestedPaths = []; - let replaced; - const replacedNewSelectors = []; - replaced = replaceParentSelector(nestedPaths, context, nestedSelector); - hadParentSelector = hadParentSelector || replaced; - // the nestedPaths array should have only one member - replaceParentSelector does not multiply selectors - for (k = 0; k < nestedPaths.length; k++) { - const replacementSelector = createSelector(createParenthesis(nestedPaths[k], el), el); - addAllReplacementsIntoPath(newSelectors, [replacementSelector], el, inSelector, replacedNewSelectors); - } - newSelectors = replacedNewSelectors; - currentElements = []; - } else { - currentElements.push(el); - } - - } else { - hadParentSelector = true; - // the new list of selectors to add - selectorsMultiplied = []; - - // merge the current list of non parent selector elements - // on to the current list of selectors to add - mergeElementsOnToSelectors(currentElements, newSelectors); - - // loop through our current selectors - for (j = 0; j < newSelectors.length; j++) { - sel = newSelectors[j]; - // if we don't have any parent paths, the & might be in a mixin so that it can be used - // whether there are parents or not - if (context.length === 0) { - // the combinator used on el should now be applied to the next element instead so that - // it is not lost - if (sel.length > 0) { - sel[0].elements.push(new Element(el.combinator, '', el.isVariable, el._index, el._fileInfo)); + // loop through our current selectors + for (j = 0; j < newSelectors.length; j++) { + sel = newSelectors[j]; + // if we don't have any parent paths, the & might be in a mixin so that it can be used + // whether there are parents or not + if (context.length === 0) { + // the combinator used on el should now be applied to the next element instead so that + // it is not lost + if (sel.length > 0) { + sel[0].elements.push(new Element(el.combinator, '', el.isVariable, el._index, el._fileInfo)); + } + selectorsMultiplied.push(sel); } - selectorsMultiplied.push(sel); - } - else { - // and the parent selectors - for (k = 0; k < context.length; k++) { - // We need to put the current selectors - // then join the last selector's elements on to the parents selectors - const newSelectorPath = addReplacementIntoPath(sel, context[k], el, inSelector); - // add that to our new set of selectors - selectorsMultiplied.push(newSelectorPath); + else { + // and the parent selectors + for (k = 0; k < context.length; k++) { + // We need to put the current selectors + // then join the last selector's elements on to the parents selectors + const newSelectorPath = addReplacementIntoPath(sel, context[k], el, inSelector); + // add that to our new set of selectors + selectorsMultiplied.push(newSelectorPath); + } } } - } - // our new selectors has been multiplied, so reset the state - newSelectors = selectorsMultiplied; - currentElements = []; + // our new selectors has been multiplied, so reset the state + newSelectors = selectorsMultiplied; + currentElements = []; + } } - } - // if we have any elements left over (e.g. .a& .b == .b) - // add them on to all the current selectors - mergeElementsOnToSelectors(currentElements, newSelectors); + // if we have any elements left over (e.g. .a& .b == .b) + // add them on to all the current selectors + mergeElementsOnToSelectors(currentElements, newSelectors); - for (i = 0; i < newSelectors.length; i++) { - length = newSelectors[i].length; - if (length > 0) { - paths.push(newSelectors[i]); - lastSelector = newSelectors[i][length - 1]; - newSelectors[i][length - 1] = lastSelector.createDerived(lastSelector.elements, inSelector.extendList); + for (i = 0; i < newSelectors.length; i++) { + length = newSelectors[i].length; + if (length > 0) { + paths.push(newSelectors[i]); + lastSelector = newSelectors[i][length - 1]; + newSelectors[i][length - 1] = lastSelector.createDerived(lastSelector.elements, inSelector.extendList); + } } - } - - return hadParentSelector; - } - function deriveSelector(visibilityInfo, deriveFrom) { - const newSelector = deriveFrom.createDerived(deriveFrom.elements, deriveFrom.extendList, deriveFrom.evaldCondition); - newSelector.copyVisibilityInfo(visibilityInfo); - return newSelector; - } + return hadParentSelector; + } - // joinSelector code follows - let i; + function deriveSelector(visibilityInfo, deriveFrom) { + const newSelector = deriveFrom.createDerived(deriveFrom.elements, deriveFrom.extendList, deriveFrom.evaldCondition); + newSelector.copyVisibilityInfo(visibilityInfo); + return newSelector; + } - let newPaths; - let hadParentSelector; + // joinSelector code follows + let i, newPaths, hadParentSelector; - newPaths = []; - hadParentSelector = replaceParentSelector(newPaths, context, selector); + newPaths = []; + hadParentSelector = replaceParentSelector(newPaths, context, selector); - if (!hadParentSelector) { - if (context.length > 0) { - newPaths = []; - for (i = 0; i < context.length; i++) { + if (!hadParentSelector) { + if (context.length > 0) { + newPaths = []; + for (i = 0; i < context.length; i++) { - const concatenated = context[i].map(deriveSelector.bind(this, selector.visibilityInfo())); + const concatenated = context[i].map(deriveSelector.bind(this, selector.visibilityInfo())); - concatenated.push(selector); - newPaths.push(concatenated); + concatenated.push(selector); + newPaths.push(concatenated); + } + } + else { + newPaths = [[selector]]; } } - else { - newPaths = [[selector]]; + + for (i = 0; i < newPaths.length; i++) { + paths.push(newPaths[i]); } - } - for (i = 0; i < newPaths.length; i++) { - paths.push(newPaths[i]); } -}; +}); -Ruleset.prototype.type = 'Ruleset'; -Ruleset.prototype.isRuleset = true; export default Ruleset; diff --git a/packages/less/src/less/tree/selector.js b/packages/less/src/less/tree/selector.js index e03458cb6..a198a7740 100644 --- a/packages/less/src/less/tree/selector.js +++ b/packages/less/src/less/tree/selector.js @@ -12,133 +12,134 @@ const Selector = function(elements, extendList, condition, index, currentFileInf this.mixinElements_ = undefined; this.copyVisibilityInfo(visibilityInfo); this.setParent(this.elements, this); -} - -Selector.prototype = new Node(); - -Selector.prototype.accept = function(visitor) { - if (this.elements) { - this.elements = visitor.visitArray(this.elements); - } - if (this.extendList) { - this.extendList = visitor.visitArray(this.extendList); - } - if (this.condition) { - this.condition = visitor.visit(this.condition); - } }; -Selector.prototype.createDerived = function(elements, extendList, evaldCondition) { - elements = this.getElements(elements); - const newSelector = new Selector(elements, extendList || this.extendList, - null, this.getIndex(), this.fileInfo(), this.visibilityInfo()); - newSelector.evaldCondition = (evaldCondition != null) ? evaldCondition : this.evaldCondition; - newSelector.mediaEmpty = this.mediaEmpty; - return newSelector; -}; +Selector.prototype = Object.assign(new Node(), { + type: 'Selector', -Selector.prototype.getElements = function(els) { - if (!els) { - return [new Element('', '&', false, this._index, this._fileInfo)]; - } - if (typeof els === 'string') { - this.parse.parseNode( - els, - ['selector'], - this._index, - this._fileInfo, - function(err, result) { - if (err) { - throw new LessError({ - index: err.index, - message: err.message - }, this.parse.imports, this._fileInfo.filename); + accept(visitor) { + if (this.elements) { + this.elements = visitor.visitArray(this.elements); + } + if (this.extendList) { + this.extendList = visitor.visitArray(this.extendList); + } + if (this.condition) { + this.condition = visitor.visit(this.condition); + } + }, + + createDerived(elements, extendList, evaldCondition) { + elements = this.getElements(elements); + const newSelector = new Selector(elements, extendList || this.extendList, + null, this.getIndex(), this.fileInfo(), this.visibilityInfo()); + newSelector.evaldCondition = (evaldCondition != null) ? evaldCondition : this.evaldCondition; + newSelector.mediaEmpty = this.mediaEmpty; + return newSelector; + }, + + getElements(els) { + if (!els) { + return [new Element('', '&', false, this._index, this._fileInfo)]; + } + if (typeof els === 'string') { + this.parse.parseNode( + els, + ['selector'], + this._index, + this._fileInfo, + function(err, result) { + if (err) { + throw new LessError({ + index: err.index, + message: err.message + }, this.parse.imports, this._fileInfo.filename); + } + els = result[0].elements; + }); + } + return els; + }, + + createEmptySelectors() { + const el = new Element('', '&', false, this._index, this._fileInfo), sels = [new Selector([el], null, null, this._index, this._fileInfo)]; + sels[0].mediaEmpty = true; + return sels; + }, + + match(other) { + const elements = this.elements; + const len = elements.length; + let olen; + let i; + + other = other.mixinElements(); + olen = other.length; + if (olen === 0 || len < olen) { + return 0; + } else { + for (i = 0; i < olen; i++) { + if (elements[i].value !== other[i]) { + return 0; } - els = result[0].elements; - }); - } - return els; -}; - -Selector.prototype.createEmptySelectors = function() { - const el = new Element('', '&', false, this._index, this._fileInfo); - const sels = [new Selector([el], null, null, this._index, this._fileInfo)]; - sels[0].mediaEmpty = true; - return sels; -}; - -Selector.prototype.match = function(other) { - const elements = this.elements; - const len = elements.length; - let olen; - let i; - - other = other.mixinElements(); - olen = other.length; - if (olen === 0 || len < olen) { - return 0; - } else { - for (i = 0; i < olen; i++) { - if (elements[i].value !== other[i]) { - return 0; } } - } - return olen; // return number of matched elements -}; + return olen; // return number of matched elements + }, -Selector.prototype.mixinElements = function() { - if (this.mixinElements_) { - return this.mixinElements_; - } + mixinElements() { + if (this.mixinElements_) { + return this.mixinElements_; + } - let elements = this.elements.map( v => v.combinator.value + (v.value.value || v.value)).join('').match(/[,&#\*\.\w-]([\w-]|(\\.))*/g); + let elements = this.elements.map( function(v) { + return v.combinator.value + (v.value.value || v.value); + }).join('').match(/[,&#\*\.\w-]([\w-]|(\\.))*/g); - if (elements) { - if (elements[0] === '&') { - elements.shift(); + if (elements) { + if (elements[0] === '&') { + elements.shift(); + } + } else { + elements = []; } - } else { - elements = []; - } - return (this.mixinElements_ = elements); -}; + return (this.mixinElements_ = elements); + }, -Selector.prototype.isJustParentSelector = function() { - return !this.mediaEmpty && - this.elements.length === 1 && - this.elements[0].value === '&' && - (this.elements[0].combinator.value === ' ' || this.elements[0].combinator.value === ''); -}; + isJustParentSelector() { + return !this.mediaEmpty && + this.elements.length === 1 && + this.elements[0].value === '&' && + (this.elements[0].combinator.value === ' ' || this.elements[0].combinator.value === ''); + }, -Selector.prototype.eval = function(context) { - const evaldCondition = this.condition && this.condition.eval(context); - let elements = this.elements; - let extendList = this.extendList; + eval(context) { + const evaldCondition = this.condition && this.condition.eval(context); + let elements = this.elements; + let extendList = this.extendList; - elements = elements && elements.map(e => e.eval(context)); - extendList = extendList && extendList.map(extend => extend.eval(context)); + elements = elements && elements.map(function (e) { return e.eval(context); }); + extendList = extendList && extendList.map(function(extend) { return extend.eval(context); }); - return this.createDerived(elements, extendList, evaldCondition); -}; + return this.createDerived(elements, extendList, evaldCondition); + }, -Selector.prototype.genCSS = function(context, output) { - let i; - let element; - if ((!context || !context.firstSelector) && this.elements[0].combinator.value === '') { - output.add(' ', this.fileInfo(), this.getIndex()); - } - for (i = 0; i < this.elements.length; i++) { - element = this.elements[i]; - element.genCSS(context, output); - } -}; + genCSS(context, output) { + let i, element; + if ((!context || !context.firstSelector) && this.elements[0].combinator.value === '') { + output.add(' ', this.fileInfo(), this.getIndex()); + } + for (i = 0; i < this.elements.length; i++) { + element = this.elements[i]; + element.genCSS(context, output); + } + }, -Selector.prototype.getIsOutput = function() { - return this.evaldCondition; -}; + getIsOutput() { + return this.evaldCondition; + } +}); -Selector.prototype.type = 'Selector'; export default Selector; diff --git a/packages/less/src/less/tree/unicode-descriptor.js b/packages/less/src/less/tree/unicode-descriptor.js index 67fa79e26..78a695065 100644 --- a/packages/less/src/less/tree/unicode-descriptor.js +++ b/packages/less/src/less/tree/unicode-descriptor.js @@ -4,7 +4,8 @@ const UnicodeDescriptor = function(value) { this.value = value; } -UnicodeDescriptor.prototype = new Node(); -UnicodeDescriptor.prototype.type = 'UnicodeDescriptor'; +UnicodeDescriptor.prototype = Object.assign(new Node(), { + type: 'UnicodeDescriptor' +}) export default UnicodeDescriptor; diff --git a/packages/less/src/less/tree/unit.js b/packages/less/src/less/tree/unit.js index 4207d0d10..3943ad2c6 100644 --- a/packages/less/src/less/tree/unit.js +++ b/packages/less/src/less/tree/unit.js @@ -12,128 +12,128 @@ const Unit = function(numerator, denominator, backupUnit) { } }; -Unit.prototype = new Node(); - -Unit.prototype.clone = function() { - return new Unit(utils.copyArray(this.numerator), utils.copyArray(this.denominator), this.backupUnit); -}; - -Unit.prototype.genCSS = function(context, output) { - // Dimension checks the unit is singular and throws an error if in strict math mode. - const strictUnits = context && context.strictUnits; - if (this.numerator.length === 1) { - output.add(this.numerator[0]); // the ideal situation - } else if (!strictUnits && this.backupUnit) { - output.add(this.backupUnit); - } else if (!strictUnits && this.denominator.length) { - output.add(this.denominator[0]); - } -}; - -Unit.prototype.toString = function() { - let i; - let returnStr = this.numerator.join('*'); - for (i = 0; i < this.denominator.length; i++) { - returnStr += `/${this.denominator[i]}`; - } - return returnStr; -}; - -Unit.prototype.compare = function(other) { - return this.is(other.toString()) ? 0 : undefined; -}; +Unit.prototype = Object.assign(new Node(), { + type: 'Unit', + + clone() { + return new Unit(utils.copyArray(this.numerator), utils.copyArray(this.denominator), this.backupUnit); + }, + + genCSS(context, output) { + // Dimension checks the unit is singular and throws an error if in strict math mode. + const strictUnits = context && context.strictUnits; + if (this.numerator.length === 1) { + output.add(this.numerator[0]); // the ideal situation + } else if (!strictUnits && this.backupUnit) { + output.add(this.backupUnit); + } else if (!strictUnits && this.denominator.length) { + output.add(this.denominator[0]); + } + }, -Unit.prototype.is = function(unitString) { - return this.toString().toUpperCase() === unitString.toUpperCase(); -}; + toString() { + let i, returnStr = this.numerator.join('*'); + for (i = 0; i < this.denominator.length; i++) { + returnStr += `/${this.denominator[i]}`; + } + return returnStr; + }, -Unit.prototype.isLength = function() { - return RegExp('^(px|em|ex|ch|rem|in|cm|mm|pc|pt|ex|vw|vh|vmin|vmax)$', 'gi').test(this.toCSS()); -}; + compare(other) { + return this.is(other.toString()) ? 0 : undefined; + }, -Unit.prototype.isEmpty = function() { - return this.numerator.length === 0 && this.denominator.length === 0; -}; + is(unitString) { + return this.toString().toUpperCase() === unitString.toUpperCase(); + }, -Unit.prototype.isSingular = function() { - return this.numerator.length <= 1 && this.denominator.length === 0; -}; + isLength() { + return RegExp('^(px|em|ex|ch|rem|in|cm|mm|pc|pt|ex|vw|vh|vmin|vmax)$', 'gi').test(this.toCSS()); + }, -Unit.prototype.map = function(callback) { - let i; + isEmpty() { + return this.numerator.length === 0 && this.denominator.length === 0; + }, - for (i = 0; i < this.numerator.length; i++) { - this.numerator[i] = callback(this.numerator[i], false); - } + isSingular() { + return this.numerator.length <= 1 && this.denominator.length === 0; + }, - for (i = 0; i < this.denominator.length; i++) { - this.denominator[i] = callback(this.denominator[i], true); - } -}; + map(callback) { + let i; -Unit.prototype.usedUnits = function() { - let group; - const result = {}; - let mapUnit; - let groupName; + for (i = 0; i < this.numerator.length; i++) { + this.numerator[i] = callback(this.numerator[i], false); + } - mapUnit = atomicUnit => { - /* jshint loopfunc:true */ - if (group.hasOwnProperty(atomicUnit) && !result[groupName]) { - result[groupName] = atomicUnit; + for (i = 0; i < this.denominator.length; i++) { + this.denominator[i] = callback(this.denominator[i], true); } + }, + + usedUnits() { + let group; + const result = {}; + let mapUnit; + let groupName; + + mapUnit = function (atomicUnit) { + /* jshint loopfunc:true */ + if (group.hasOwnProperty(atomicUnit) && !result[groupName]) { + result[groupName] = atomicUnit; + } - return atomicUnit; - }; + return atomicUnit; + }; - for (groupName in unitConversions) { - if (unitConversions.hasOwnProperty(groupName)) { - group = unitConversions[groupName]; + for (groupName in unitConversions) { + if (unitConversions.hasOwnProperty(groupName)) { + group = unitConversions[groupName]; - this.map(mapUnit); + this.map(mapUnit); + } } - } - - return result; -}; -Unit.prototype.cancel = function() { - const counter = {}; - let atomicUnit; - let i; + return result; + }, - for (i = 0; i < this.numerator.length; i++) { - atomicUnit = this.numerator[i]; - counter[atomicUnit] = (counter[atomicUnit] || 0) + 1; - } + cancel() { + const counter = {}; + let atomicUnit; + let i; - for (i = 0; i < this.denominator.length; i++) { - atomicUnit = this.denominator[i]; - counter[atomicUnit] = (counter[atomicUnit] || 0) - 1; - } - - this.numerator = []; - this.denominator = []; + for (i = 0; i < this.numerator.length; i++) { + atomicUnit = this.numerator[i]; + counter[atomicUnit] = (counter[atomicUnit] || 0) + 1; + } - for (atomicUnit in counter) { - if (counter.hasOwnProperty(atomicUnit)) { - const count = counter[atomicUnit]; + for (i = 0; i < this.denominator.length; i++) { + atomicUnit = this.denominator[i]; + counter[atomicUnit] = (counter[atomicUnit] || 0) - 1; + } - if (count > 0) { - for (i = 0; i < count; i++) { - this.numerator.push(atomicUnit); - } - } else if (count < 0) { - for (i = 0; i < -count; i++) { - this.denominator.push(atomicUnit); + this.numerator = []; + this.denominator = []; + + for (atomicUnit in counter) { + if (counter.hasOwnProperty(atomicUnit)) { + const count = counter[atomicUnit]; + + if (count > 0) { + for (i = 0; i < count; i++) { + this.numerator.push(atomicUnit); + } + } else if (count < 0) { + for (i = 0; i < -count; i++) { + this.denominator.push(atomicUnit); + } } } } - } - this.numerator.sort(); - this.denominator.sort(); -}; + this.numerator.sort(); + this.denominator.sort(); + } +}); -Unit.prototype.type = 'Unit'; export default Unit; diff --git a/packages/less/src/less/tree/url.js b/packages/less/src/less/tree/url.js index 3365b6502..f0f329cab 100644 --- a/packages/less/src/less/tree/url.js +++ b/packages/less/src/less/tree/url.js @@ -1,5 +1,9 @@ import Node from './node'; +function escapePath(path) { + return path.replace(/[\(\)'"\s]/g, function(match) { return `\\${match}`; }); +} + const URL = function(val, index, currentFileInfo, isEvald) { this.value = val; this._index = index; @@ -7,57 +11,53 @@ const URL = function(val, index, currentFileInfo, isEvald) { this.isEvald = isEvald; }; -URL.prototype = new Node(); - -URL.prototype.accept = function(visitor) { - this.value = visitor.visit(this.value); -}; - -URL.prototype.genCSS = function(context, output) { - output.add('url('); - this.value.genCSS(context, output); - output.add(')'); -}; - -URL.prototype.eval = function(context) { - const val = this.value.eval(context); - let rootpath; - - if (!this.isEvald) { - // Add the rootpath if the URL requires a rewrite - rootpath = this.fileInfo() && this.fileInfo().rootpath; - if (typeof rootpath === 'string' && - typeof val.value === 'string' && - context.pathRequiresRewrite(val.value)) { - if (!val.quote) { - rootpath = escapePath(rootpath); +URL.prototype = Object.assign(new Node(), { + type: 'Url', + + accept(visitor) { + this.value = visitor.visit(this.value); + }, + + genCSS(context, output) { + output.add('url('); + this.value.genCSS(context, output); + output.add(')'); + }, + + eval(context) { + const val = this.value.eval(context); + let rootpath; + + if (!this.isEvald) { + // Add the rootpath if the URL requires a rewrite + rootpath = this.fileInfo() && this.fileInfo().rootpath; + if (typeof rootpath === 'string' && + typeof val.value === 'string' && + context.pathRequiresRewrite(val.value)) { + if (!val.quote) { + rootpath = escapePath(rootpath); + } + val.value = context.rewritePath(val.value, rootpath); + } else { + val.value = context.normalizePath(val.value); } - val.value = context.rewritePath(val.value, rootpath); - } else { - val.value = context.normalizePath(val.value); - } - // Add url args if enabled - if (context.urlArgs) { - if (!val.value.match(/^\s*data:/)) { - const delimiter = val.value.indexOf('?') === -1 ? '?' : '&'; - const urlArgs = delimiter + context.urlArgs; - if (val.value.indexOf('#') !== -1) { - val.value = val.value.replace('#', `${urlArgs}#`); - } else { - val.value += urlArgs; + // Add url args if enabled + if (context.urlArgs) { + if (!val.value.match(/^\s*data:/)) { + const delimiter = val.value.indexOf('?') === -1 ? '?' : '&'; + const urlArgs = delimiter + context.urlArgs; + if (val.value.indexOf('#') !== -1) { + val.value = val.value.replace('#', `${urlArgs}#`); + } else { + val.value += urlArgs; + } } } } - } - - return new URL(val, this.getIndex(), this.fileInfo(), true); -}; -URL.prototype.type = 'Url'; - -function escapePath(path) { - return path.replace(/[\(\)'"\s]/g, match => `\\${match}`); -} + return new URL(val, this.getIndex(), this.fileInfo(), true); + } +}); export default URL; diff --git a/packages/less/src/less/tree/value.js b/packages/less/src/less/tree/value.js index a3a6bce5d..b1eb57a89 100644 --- a/packages/less/src/less/tree/value.js +++ b/packages/less/src/less/tree/value.js @@ -12,31 +12,34 @@ const Value = function(value) { } }; -Value.prototype = new Node(); +Value.prototype = Object.assign(new Node(), { + type: 'Value', -Value.prototype.accept = function(visitor) { - if (this.value) { - this.value = visitor.visitArray(this.value); - } -}; + accept(visitor) { + if (this.value) { + this.value = visitor.visitArray(this.value); + } + }, -Value.prototype.eval = function(context) { - if (this.value.length === 1) { - return this.value[0].eval(context); - } else { - return new Value(this.value.map(v => v.eval(context))); - } -}; + eval(context) { + if (this.value.length === 1) { + return this.value[0].eval(context); + } else { + return new Value(this.value.map(function (v) { + return v.eval(context); + })); + } + }, -Value.prototype.genCSS = function(context, output) { - let i; - for (i = 0; i < this.value.length; i++) { - this.value[i].genCSS(context, output); - if (i + 1 < this.value.length) { - output.add((context && context.compress) ? ',' : ', '); + genCSS(context, output) { + let i; + for (i = 0; i < this.value.length; i++) { + this.value[i].genCSS(context, output); + if (i + 1 < this.value.length) { + output.add((context && context.compress) ? ',' : ', '); + } } } -}; +}); -Value.prototype.type = 'Value'; export default Value; diff --git a/packages/less/src/less/tree/variable-call.js b/packages/less/src/less/tree/variable-call.js index 2c8fa68c3..9d1e8b941 100644 --- a/packages/less/src/less/tree/variable-call.js +++ b/packages/less/src/less/tree/variable-call.js @@ -11,34 +11,35 @@ const VariableCall = function(variable, index, currentFileInfo) { this.allowRoot = true; }; -VariableCall.prototype = new Node(); +VariableCall.prototype = Object.assign(new Node(), { + type: 'VariableCall', -VariableCall.prototype.eval = function(context) { - let rules; - let detachedRuleset = new Variable(this.variable, this.getIndex(), this.fileInfo()).eval(context); - const error = new LessError({message: `Could not evaluate variable call ${this.variable}`}); + eval(context) { + let rules; + let detachedRuleset = new Variable(this.variable, this.getIndex(), this.fileInfo()).eval(context); + const error = new LessError({message: `Could not evaluate variable call ${this.variable}`}); - if (!detachedRuleset.ruleset) { - if (detachedRuleset.rules) { - rules = detachedRuleset; + if (!detachedRuleset.ruleset) { + if (detachedRuleset.rules) { + rules = detachedRuleset; + } + else if (Array.isArray(detachedRuleset)) { + rules = new Ruleset('', detachedRuleset); + } + else if (Array.isArray(detachedRuleset.value)) { + rules = new Ruleset('', detachedRuleset.value); + } + else { + throw error; + } + detachedRuleset = new DetachedRuleset(rules); } - else if (Array.isArray(detachedRuleset)) { - rules = new Ruleset('', detachedRuleset); - } - else if (Array.isArray(detachedRuleset.value)) { - rules = new Ruleset('', detachedRuleset.value); - } - else { - throw error; - } - detachedRuleset = new DetachedRuleset(rules); - } - if (detachedRuleset.ruleset) { - return detachedRuleset.callEval(context); + if (detachedRuleset.ruleset) { + return detachedRuleset.callEval(context); + } + throw error; } - throw error; -}; +}); -VariableCall.prototype.type = 'VariableCall'; export default VariableCall; diff --git a/packages/less/src/less/tree/variable.js b/packages/less/src/less/tree/variable.js index 1db4df42d..a81e3ecef 100644 --- a/packages/less/src/less/tree/variable.js +++ b/packages/less/src/less/tree/variable.js @@ -7,59 +7,59 @@ const Variable = function(name, index, currentFileInfo) { this._fileInfo = currentFileInfo; }; -Variable.prototype = new Node(); +Variable.prototype = Object.assign(new Node(), { + type: 'Variable', -Variable.prototype.eval = function(context) { - let variable; - let name = this.name; + eval(context) { + let variable, name = this.name; - if (name.indexOf('@@') === 0) { - name = `@${new Variable(name.slice(1), this.getIndex(), this.fileInfo()).eval(context).value}`; - } + if (name.indexOf('@@') === 0) { + name = `@${new Variable(name.slice(1), this.getIndex(), this.fileInfo()).eval(context).value}`; + } - if (this.evaluating) { - throw { type: 'Name', - message: `Recursive variable definition for ${name}`, - filename: this.fileInfo().filename, - index: this.getIndex() }; - } + if (this.evaluating) { + throw { type: 'Name', + message: `Recursive variable definition for ${name}`, + filename: this.fileInfo().filename, + index: this.getIndex() }; + } - this.evaluating = true; + this.evaluating = true; - variable = this.find(context.frames, frame => { - const v = frame.variable(name); - if (v) { - if (v.important) { - const importantScope = context.importantScope[context.importantScope.length - 1]; - importantScope.important = v.important; - } - // If in calc, wrap vars in a function call to cascade evaluate args first - if (context.inCalc) { - return (new Call('_SELF', [v.value])).eval(context); - } - else { - return v.value.eval(context); + variable = this.find(context.frames, function (frame) { + const v = frame.variable(name); + if (v) { + if (v.important) { + const importantScope = context.importantScope[context.importantScope.length - 1]; + importantScope.important = v.important; + } + // If in calc, wrap vars in a function call to cascade evaluate args first + if (context.inCalc) { + return (new Call('_SELF', [v.value])).eval(context); + } + else { + return v.value.eval(context); + } } + }); + if (variable) { + this.evaluating = false; + return variable; + } else { + throw { type: 'Name', + message: `variable ${name} is undefined`, + filename: this.fileInfo().filename, + index: this.getIndex() }; } - }); - if (variable) { - this.evaluating = false; - return variable; - } else { - throw { type: 'Name', - message: `variable ${name} is undefined`, - filename: this.fileInfo().filename, - index: this.getIndex() }; - } -}; + }, -Variable.prototype.find = function(obj, fun) { - for (let i = 0, r; i < obj.length; i++) { - r = fun.call(obj, obj[i]); - if (r) { return r; } + find(obj, fun) { + for (let i = 0, r; i < obj.length; i++) { + r = fun.call(obj, obj[i]); + if (r) { return r; } + } + return null; } - return null; -}; +}); -Variable.prototype.type = 'Variable'; export default Variable; diff --git a/packages/less/src/less/utils.js b/packages/less/src/less/utils.js index 8f053e352..c0921b90d 100644 --- a/packages/less/src/less/utils.js +++ b/packages/less/src/less/utils.js @@ -60,7 +60,7 @@ export function copyOptions(obj1, obj2) { } const opts = defaults(obj1, obj2); if (opts.strictMath) { - opts.math = Constants.Math.STRICT_LEGACY; + opts.math = Constants.Math.PARENS; } // Back compat with changed relativeUrls option if (opts.relativeUrls) { @@ -78,8 +78,8 @@ export function copyOptions(obj1, obj2) { case 'parens': opts.math = Constants.Math.PARENS; break; - case 'strict-legacy': - opts.math = Constants.Math.STRICT_LEGACY; + default: + opts.math = Constants.Math.PARENS; } } if (typeof opts.rewriteUrls === 'string') { diff --git a/packages/less/src/less/visitors/extend-visitor.js b/packages/less/src/less/visitors/extend-visitor.js index f9e5b40c0..04a538f08 100644 --- a/packages/less/src/less/visitors/extend-visitor.js +++ b/packages/less/src/less/visitors/extend-visitor.js @@ -38,9 +38,7 @@ class ExtendFinderVisitor { let extendList; // get &:extend(.a); rules which apply to all selectors in this ruleset - const rules = rulesetNode.rules; - - const ruleCnt = rules ? rules.length : 0; + const rules = rulesetNode.rules, ruleCnt = rules ? rules.length : 0; for (i = 0; i < ruleCnt; i++) { if (rulesetNode.rules[i] instanceof tree.Extend) { allSelectorsExtendList.push(rules[i]); @@ -52,15 +50,15 @@ class ExtendFinderVisitor { // and the ones which apply to an individual extend const paths = rulesetNode.paths; for (i = 0; i < paths.length; i++) { - const selectorPath = paths[i]; - const selector = selectorPath[selectorPath.length - 1]; - const selExtendList = selector.extendList; + const selectorPath = paths[i], selector = selectorPath[selectorPath.length - 1], selExtendList = selector.extendList; extendList = selExtendList ? utils.copyArray(selExtendList).concat(allSelectorsExtendList) : allSelectorsExtendList; if (extendList) { - extendList = extendList.map(allSelectorsExtend => allSelectorsExtend.clone()); + extendList = extendList.map(function(allSelectorsExtend) { + return allSelectorsExtend.clone(); + }); } for (j = 0; j < extendList.length; j++) { @@ -120,7 +118,9 @@ class ProcessExtendsVisitor { checkExtendsForNonMatched(extendList) { const indices = this.extendIndices; - extendList.filter(extend => !extend.hasFoundMatches && extend.parent_ids.length == 1).forEach(extend => { + extendList.filter(function(extend) { + return !extend.hasFoundMatches && extend.parent_ids.length == 1; + }).forEach(function(extend) { let selector = '_unknown_'; try { selector = extend.selector.toCSS({}); @@ -181,7 +181,7 @@ class ProcessExtendsVisitor { extend.hasFoundMatches = true; // we found a match, so for each self selector.. - extend.selfSelectors.forEach(selfSelector => { + extend.selfSelectors.forEach(function(selfSelector) { const info = targetExtend.visibilityInfo(); // process the extend as usual @@ -276,7 +276,7 @@ class ProcessExtendsVisitor { if (matches.length) { allExtends[extendIndex].hasFoundMatches = true; - allExtends[extendIndex].selfSelectors.forEach(selfSelector => { + allExtends[extendIndex].selfSelectors.forEach(function(selfSelector) { let extendedSelectors; extendedSelectors = extendVisitor.extendSelector(matches, selectorPath, selfSelector, allExtends[extendIndex].isVisible()); selectorsToAdd.push(extendedSelectors); @@ -406,17 +406,10 @@ class ProcessExtendsVisitor { } extendSelector(matches, selectorPath, replacementSelector, isVisible) { - // for a set of matches, replace each match with the replacement selector - let currentSelectorPathIndex = 0; + // for a set of matches, replace each match with the replacement selector - let currentSelectorPathElementIndex = 0; - let path = []; - let matchIndex; - let selector; - let firstElement; - let match; - let newElements; + let currentSelectorPathIndex = 0, currentSelectorPathElementIndex = 0, path = [], matchIndex, selector, firstElement, match, newElements; for (matchIndex = 0; matchIndex < matches.length; matchIndex++) { match = matches[matchIndex]; @@ -466,7 +459,7 @@ class ProcessExtendsVisitor { } path = path.concat(selectorPath.slice(currentSelectorPathIndex, selectorPath.length)); - path = path.map(currentValue => { + path = path.map(function (currentValue) { // we can re-use elements here, because the visibility property matters only for selectors const derived = currentValue.createDerived(currentValue.elements); if (isVisible) { diff --git a/packages/less/src/less/visitors/import-sequencer.js b/packages/less/src/less/visitors/import-sequencer.js index b21f628b4..dc5d56430 100644 --- a/packages/less/src/less/visitors/import-sequencer.js +++ b/packages/less/src/less/visitors/import-sequencer.js @@ -7,17 +7,15 @@ class ImportSequencer { } addImport(callback) { - const importSequencer = this; - - const importItem = { - callback, - args: null, - isReady: false - }; - + const importSequencer = this, + importItem = { + callback, + args: null, + isReady: false + }; this.imports.push(importItem); - return function(...args) { - importItem.args = Array.prototype.slice.call(args, 0); + return function() { + importItem.args = Array.prototype.slice.call(arguments, 0); importItem.isReady = true; importSequencer.tryRun(); }; diff --git a/packages/less/src/less/visitors/import-visitor.js b/packages/less/src/less/visitors/import-visitor.js index a83cd4331..1f102d85f 100644 --- a/packages/less/src/less/visitors/import-visitor.js +++ b/packages/less/src/less/visitors/import-visitor.js @@ -67,6 +67,7 @@ ImportVisitor.prototype = { } if (evaldImportNode && (!evaldImportNode.css || inlineCSS)) { + if (evaldImportNode.options.multiple) { context.importMultiple = true; } @@ -81,8 +82,7 @@ ImportVisitor.prototype = { } } - const onImported = this.onImported.bind(this, evaldImportNode, context); - const sequencedOnImported = this._sequencer.addImport(onImported); + const onImported = this.onImported.bind(this, evaldImportNode, context), sequencedOnImported = this._sequencer.addImport(onImported); this._importer.push(evaldImportNode.getPath(), tryAppendLessExtension, evaldImportNode.fileInfo(), evaldImportNode.options, sequencedOnImported); @@ -101,17 +101,17 @@ ImportVisitor.prototype = { this.error = e; } - const importVisitor = this; - const inlineCSS = importNode.options.inline; - const isPlugin = importNode.options.isPlugin; - const isOptional = importNode.options.optional; - const duplicateImport = importedAtRoot || fullPath in importVisitor.recursionDetector; + const importVisitor = this, + inlineCSS = importNode.options.inline, + isPlugin = importNode.options.isPlugin, + isOptional = importNode.options.optional, + duplicateImport = importedAtRoot || fullPath in importVisitor.recursionDetector; if (!context.importMultiple) { if (duplicateImport) { importNode.skip = true; } else { - importNode.skip = () => { + importNode.skip = function() { if (fullPath in importVisitor.onceFileDetectionMap) { return true; } diff --git a/packages/less/src/less/visitors/join-selector-visitor.js b/packages/less/src/less/visitors/join-selector-visitor.js index d042ee3d0..6ec312709 100644 --- a/packages/less/src/less/visitors/join-selector-visitor.js +++ b/packages/less/src/less/visitors/join-selector-visitor.js @@ -28,7 +28,7 @@ class JoinSelectorVisitor { if (!rulesetNode.root) { selectors = rulesetNode.selectors; if (selectors) { - selectors = selectors.filter(selector => selector.getIsOutput()); + selectors = selectors.filter(function(selector) { return selector.getIsOutput(); }); rulesetNode.selectors = selectors.length ? selectors : (selectors = null); if (selectors) { rulesetNode.joinSelectors(paths, context, selectors); } } diff --git a/packages/less/src/less/visitors/to-css-visitor.js b/packages/less/src/less/visitors/to-css-visitor.js index 0761b4675..d49987ea7 100644 --- a/packages/less/src/less/visitors/to-css-visitor.js +++ b/packages/less/src/less/visitors/to-css-visitor.js @@ -207,7 +207,7 @@ ToCSSVisitor.prototype = { index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename}; } if (ruleNode instanceof tree.Call) { - throw { message: `Function '${ruleNode.name}' is undefined`, + throw { message: `Function '${ruleNode.name}' did not return a root node`, index: ruleNode.getIndex(), filename: ruleNode.fileInfo() && ruleNode.fileInfo().filename}; } if (ruleNode.type && !ruleNode.allowRoot) { diff --git a/packages/less/src/less/visitors/visitor.js b/packages/less/src/less/visitors/visitor.js index 6f6bc5b08..9db634f4f 100644 --- a/packages/less/src/less/visitors/visitor.js +++ b/packages/less/src/less/visitors/visitor.js @@ -1,4 +1,5 @@ import tree from '../tree'; + const _visitArgs = { visitDeeper: true }; let _hasIndexed = false; @@ -8,9 +9,7 @@ function _noop(node) { function indexNodeTypes(parent, ticker) { // add .typeIndex to tree node types for lookup table - let key; - - let child; + let key, child; for (key in parent) { /* eslint guard-for-in: 0 */ child = parent[key]; @@ -82,7 +81,7 @@ class Visitor { if (visitArgs.visitDeeper && node) { if (node.length) { - for (var i = 0, cnt = node.length; i < cnt; i++) { + for (let i = 0, cnt = node.length; i < cnt; i++) { if (node[i].accept) { node[i].accept(this); } @@ -134,12 +133,7 @@ class Visitor { out = []; } - let cnt; - let i; - let item; - let nestedCnt; - let j; - let nestedItem; + let cnt, i, item, nestedCnt, j, nestedItem; for (i = 0, cnt = arr.length; i < cnt; i++) { item = arr[i]; diff --git a/packages/less/test/browser/less/errors/image-height-error.txt b/packages/less/test/browser/less/errors/image-height-error.txt index b5493fcd3..c5116d0a2 100644 --- a/packages/less/test/browser/less/errors/image-height-error.txt +++ b/packages/less/test/browser/less/errors/image-height-error.txt @@ -1,4 +1,4 @@ -RuntimeError: error evaluating function `image-height`: Image size functions are not supported in browser version of less in image-height-error.less on line 2, column 11: +RuntimeError: Error evaluating function `image-height`: Image size functions are not supported in browser version of less in image-height-error.less on line 2, column 11: 1 .test-height{ 2 height: image-height("../data/image.jpg") 3 } \ No newline at end of file diff --git a/packages/less/test/browser/less/errors/image-size-error.txt b/packages/less/test/browser/less/errors/image-size-error.txt index fdb0f37ba..399be5137 100644 --- a/packages/less/test/browser/less/errors/image-size-error.txt +++ b/packages/less/test/browser/less/errors/image-size-error.txt @@ -1,4 +1,4 @@ -RuntimeError: error evaluating function `image-size`: Image size functions are not supported in browser version of less in image-size-error.less on line 2, column 9: +RuntimeError: Error evaluating function `image-size`: Image size functions are not supported in browser version of less in image-size-error.less on line 2, column 9: 1 .test-size{ 2 size: image-size("../data/image.jpg") 3 } \ No newline at end of file diff --git a/packages/less/test/browser/less/errors/image-width-error.txt b/packages/less/test/browser/less/errors/image-width-error.txt index 57d85f4a9..03d814a9b 100644 --- a/packages/less/test/browser/less/errors/image-width-error.txt +++ b/packages/less/test/browser/less/errors/image-width-error.txt @@ -1,4 +1,4 @@ -RuntimeError: error evaluating function `image-width`: Image size functions are not supported in browser version of less in image-width-error.less on line 2, column 10: +RuntimeError: Error evaluating function `image-width`: Image size functions are not supported in browser version of less in image-width-error.less on line 2, column 10: 1 .test-width{ 2 width: image-width("../data/image.jpg") 3 } \ No newline at end of file diff --git a/packages/less/test/index.js b/packages/less/test/index.js index 6dba330ed..0924725f6 100644 --- a/packages/less/test/index.js +++ b/packages/less/test/index.js @@ -13,15 +13,15 @@ var testMap = [ javascriptEnabled: true }, '_main/'], [{}, 'namespacing/'], - [{ - math: 'strict-legacy' - }, 'math/strict-legacy/'], [{ math: 'parens' }, 'math/strict/'], [{ math: 'parens-division' }, 'math/parens-division/'], + [{ + math: 'always' + }, 'math/always/'], // Use legacy strictMath: true here to demonstrate it still works [{strictMath: true, strictUnits: true, javascriptEnabled: true}, '../errors/eval/', lessTester.testErrors, null], @@ -39,8 +39,10 @@ var testMap = [ // TODO: Change this to rewriteUrls: false once the relativeUrls option is removed [{math: 'strict', relativeUrls: false, rootpath: 'folder (1)/'}, 'static-urls/'], [{math: 'strict', compress: true}, 'compression/'], - [{math: 0, strictUnits: true}, 'strict-units/'], - [{}, 'legacy/'], + + [{math: 0, strictUnits: true}, 'units/strict/'], + [{math: 0, strictUnits: false}, 'units/no-strict/'], + [{math: 'strict', strictUnits: true, sourceMap: true, globalVars: true }, 'sourcemaps/', lessTester.testSourcemap, null, null, function(filename, type, baseFolder) { @@ -74,8 +76,7 @@ var testMap = [ [{plugin: 'test/plugins/preprocess/'}, 'preProcessorPlugin/'], [{plugin: 'test/plugins/visitor/'}, 'visitorPlugin/'], [{plugin: 'test/plugins/filemanager/'}, 'filemanagerPlugin/'], - [{}, 'no-strict-math/'], - [{}, '3rd-party/'], + [{math: 0}, '3rd-party/'], [{ processImports: false }, 'process-imports/'] ]; testMap.forEach(function(args) { @@ -83,7 +84,7 @@ testMap.forEach(function(args) { }); lessTester.testSyncronous({syncImport: true}, '_main/import'); lessTester.testSyncronous({syncImport: true}, '_main/plugin'); -lessTester.testSyncronous({syncImport: true}, 'math/strict-legacy/css'); +lessTester.testSyncronous({syncImport: true}, 'math/strict/css'); lessTester.testNoOptions(); lessTester.testJSImport(); lessTester.finished(); diff --git a/packages/less/tsconfig.json b/packages/less/tsconfig.json index 2c571b1aa..a0a698c78 100644 --- a/packages/less/tsconfig.json +++ b/packages/less/tsconfig.json @@ -6,6 +6,7 @@ "sourceMap": true, "inlineSources": true, "esModuleInterop": true, + "importHelpers": true, "target": "ES5" }, "include": ["src/**/*"], diff --git a/packages/test-data/css/3rd-party/uikit.css b/packages/test-data/css/3rd-party/uikit.css deleted file mode 100644 index d3be4ea5a..000000000 --- a/packages/test-data/css/3rd-party/uikit.css +++ /dev/null @@ -1,8955 +0,0 @@ -/* ======================================================================== - Component: Base - ========================================================================== */ -/* - * 1. Normalize default `font-family` and set `font-size` to support `rem` units - * 2. Prevents iOS text size adjust after orientation change, without disabling user zoom - * 3. Style - */ -html { - /* 1 */ - font: normal 14px / 20px "Helvetica Neue", Helvetica, Arial, sans-serif; - /* 2 */ - -webkit-text-size-adjust: 100%; - -ms-text-size-adjust: 100%; - /* 3 */ - background: #fff; - color: #444; -} -/* - * Removes default margin. - */ -body { - margin: 0; -} -/* Links - ========================================================================== */ -/* - * Remove the gray background color from active links in IE 10. - */ -a { - background: transparent; -} -/* - * Improve readability of focused elements when they are also in an active/hover state. - */ -a:active, -a:hover { - outline: 0; -} -/* - * Style - */ -a, -.uk-link { - color: #07D; - text-decoration: none; - cursor: pointer; -} -a:hover, -.uk-link:hover { - color: #059; - text-decoration: underline; -} -/* Text-level semantics - ========================================================================== */ -/* - * Address styling not present in IE 8/9/10/11, Safari, and Chrome. - */ -abbr[title] { - border-bottom: 1px dotted; -} -/* - * Address style set to `bolder` in Firefox 4+, Safari, and Chrome. - */ -b, -strong { - font-weight: bold; -} -/* - * 1. Address odd `em`-unit font size rendering in all browsers. - * 2. Consolas has a better baseline in running text compared to `Courier` - */ -:not(pre) > code, -:not(pre) > kbd, -:not(pre) > samp { - /* 1 */ - font-size: 12px; - /* 2 */ - font-family: Consolas, monospace, serif; - /* 3 */ - color: #D05; - white-space: nowrap; -} -/* - * Emphasize - */ -em { - color: #D05; -} -/* - * Insert - */ -ins { - background: #ffa; - color: #444; - text-decoration: none; -} -/* - * Mark - * Note: Addresses styling not present in IE 8/9. - */ -mark { - background: #ffa; - color: #444; -} -/* - * Quote - */ -q { - font-style: italic; -} -/* - * Addresses inconsistent and variable font size in all browsers. - */ -small { - font-size: 80%; -} -/* - * Prevents `sub` and `sup` affecting `line-height` in all browsers. - */ -sub, -sup { - font-size: 75%; - line-height: 0; - position: relative; - vertical-align: baseline; -} -sup { - top: -0.5em; -} -sub { - bottom: -0.25em; -} -/* Embedded content - ========================================================================== */ -/* - * Remove the gap between embedded content and the bottom of their containers. - */ -audio, -canvas, -iframe, -img, -svg, -video { - vertical-align: middle; -} -/* - * Responsiveness - * 1. Sets a maximum width relative to the parent and auto scales the height - * 2. Corrects `max-width` behavior if padding and border are used - */ -audio, -canvas, -img, -svg, -video { - /* 1 */ - max-width: 100%; - height: auto; - /* 2 */ - box-sizing: border-box; -} -/* - * Preserve original dimensions - */ -.uk-img-preserve, -.uk-img-preserve audio, -.uk-img-preserve canvas, -.uk-img-preserve img, -.uk-img-preserve svg, -.uk-img-preserve video { - max-width: none; -} -/* - * Remove border when inside `a` element in IE 8/9/10. - */ -img { - border: 0; -} -/* - * Correct overflow not hidden in IE 9/10/11. - */ -svg:not(:root) { - overflow: hidden; -} -/* Block elements - ========================================================================== */ -/* - * Reset margin - */ -blockquote, -figure { - margin: 0; -} -/* - * Margins - */ -p, -ul, -ol, -dl, -blockquote, -pre, -address, -fieldset, -figure { - margin: 0 0 15px 0; -} -* + p, -* + ul, -* + ol, -* + dl, -* + blockquote, -* + pre, -* + address, -* + fieldset, -* + figure { - margin-top: 15px; -} -/* Headings - ========================================================================== */ -h1, -h2, -h3, -h4, -h5, -h6 { - margin: 0 0 15px 0; - font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; - font-weight: normal; - color: #444; - text-transform: none; -} -/* - * Margins - */ -* + h1, -* + h2, -* + h3, -* + h4, -* + h5, -* + h6 { - margin-top: 25px; -} -/* - * Sizes - */ -h1, -.uk-h1 { - font-size: 36px; - line-height: 42px; -} -h2, -.uk-h2 { - font-size: 24px; - line-height: 30px; -} -h3, -.uk-h3 { - font-size: 18px; - line-height: 24px; -} -h4, -.uk-h4 { - font-size: 16px; - line-height: 22px; -} -h5, -.uk-h5 { - font-size: 14px; - line-height: 20px; -} -h6, -.uk-h6 { - font-size: 12px; - line-height: 18px; -} -/* Lists - ========================================================================== */ -ul, -ol { - padding-left: 30px; -} -/* - * Reset margin for nested lists - */ -ul > li > ul, -ul > li > ol, -ol > li > ol, -ol > li > ul { - margin: 0; -} -/* Description lists - ========================================================================== */ -dt { - font-weight: bold; -} -dd { - margin-left: 0; -} -/* Horizontal rules - ========================================================================== */ -/* - * 1. Address differences between Firefox and other browsers. - * 2. Style - */ -hr { - /* 1 */ - box-sizing: content-box; - height: 0; - /* 2 */ - margin: 15px 0; - border: 0; - border-top: 1px solid #ddd; -} -/* Address - ========================================================================== */ -address { - font-style: normal; -} -/* Blockquotes - ========================================================================== */ -blockquote { - padding-left: 15px; - border-left: 5px solid #ddd; - font-size: 16px; - line-height: 22px; - font-style: italic; -} -/* Preformatted text - ========================================================================== */ -/* - * 1. Contain overflow in all browsers. - */ -pre { - padding: 10px; - background: #f5f5f5; - font: 12px / 18px Consolas, monospace, serif; - color: #444; - -moz-tab-size: 4; - tab-size: 4; - /* 1 */ - overflow: auto; -} -/* Selection pseudo-element - ========================================================================== */ -::-moz-selection { - background: #39f; - color: #fff; - text-shadow: none; -} -::selection { - background: #39f; - color: #fff; - text-shadow: none; -} -/* HTML5 elements - ========================================================================== */ -/* - * Correct `block` display not defined for any HTML5 element in IE 8/9. - * Correct `block` display not defined for `details` or `summary` in IE 10/11 and Firefox. - * Correct `block` display not defined for `main` in IE 11. - */ -article, -aside, -details, -figcaption, -figure, -footer, -header, -main, -nav, -section, -summary { - display: block; -} -/* - * Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera. - */ -progress { - vertical-align: baseline; -} -/* - * Prevent displaying `audio` without controls in Chrome, Safari and Opera - */ -audio:not([controls]) { - display: none; -} -/* - * Address `[hidden]` styling not present in IE 8/9/10. - * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22. - */ -[hidden], -template { - display: none; -} -/* Iframe - ========================================================================== */ -iframe { - border: 0; -} -/* Fix viewport for IE10 snap mode - ========================================================================== */ -@media screen and (max-width: 400px) { - @-ms-viewport { - width: device-width; - } -} -/* ======================================================================== - Component: Grid - ========================================================================== */ -/* - * 1. Makes grid more robust so that it can be used with other block elements like lists - */ -.uk-grid { - display: -ms-flexbox; - display: -webkit-flex; - display: flex; - -ms-flex-wrap: wrap; - -webkit-flex-wrap: wrap; - flex-wrap: wrap; - /* 1 */ - margin: 0; - padding: 0; - list-style: none; -} -/* - * DEPRECATED - * Micro clearfix - * Can't use `table` because it creates a 1px gap when it becomes a flex item, only in Webkit - */ -.uk-grid:before, -.uk-grid:after { - content: ""; - display: block; - overflow: hidden; -} -.uk-grid:after { - clear: both; -} -/* - * Grid cell - * 1. Space is allocated solely based on content dimensions - * 2. Makes grid more robust so that it can be used with other block elements - * 3. DEPRECATED Using `float` to support IE9 - */ -.uk-grid > * { - /* 1 */ - -ms-flex: none; - -webkit-flex: none; - flex: none; - /* 2 */ - margin: 0; - /* 3 */ - float: left; -} -/* - * Remove margin from the last-child - */ -.uk-grid > * > :last-child { - margin-bottom: 0; -} -/* Grid gutter - ========================================================================== */ -/* - * Default gutter - */ -/* Horizontal */ -.uk-grid { - margin-left: -25px; -} -.uk-grid > * { - padding-left: 25px; -} -/* Vertical */ -.uk-grid + .uk-grid, -.uk-grid-margin, -.uk-grid > * > .uk-panel + .uk-panel { - margin-top: 25px; -} -/* Large screen and bigger */ -@media (min-width: 1220px) { - /* Horizontal */ - .uk-grid { - margin-left: -35px; - } - .uk-grid > * { - padding-left: 35px; - } - /* Vertical */ - .uk-grid + .uk-grid, - .uk-grid-margin, - .uk-grid > * > .uk-panel + .uk-panel { - margin-top: 35px; - } -} -/* - * Collapse gutter - */ -/* Horizontal */ -.uk-grid-collapse { - margin-left: 0; -} -.uk-grid-collapse > * { - padding-left: 0; -} -/* Vertical */ -.uk-grid-collapse + .uk-grid-collapse, -.uk-grid-collapse > .uk-grid-margin, -.uk-grid-collapse > * > .uk-panel + .uk-panel { - margin-top: 0; -} -/* - * Small gutter - */ -/* Horizontal */ -.uk-grid-small { - margin-left: -10px; -} -.uk-grid-small > * { - padding-left: 10px; -} -/* Vertical */ -.uk-grid-small + .uk-grid-small, -.uk-grid-small > .uk-grid-margin, -.uk-grid-small > * > .uk-panel + .uk-panel { - margin-top: 10px; -} -/* - * Medium gutter - */ -/* Horizontal */ -.uk-grid-medium { - margin-left: -25px; -} -.uk-grid-medium > * { - padding-left: 25px; -} -/* Vertical */ -.uk-grid-medium + .uk-grid-medium, -.uk-grid-medium > .uk-grid-margin, -.uk-grid-medium > * > .uk-panel + .uk-panel { - margin-top: 25px; -} -/* - * Large gutter - */ -/* Large screen and bigger */ -@media (min-width: 960px) { - /* Horizontal */ - .uk-grid-large { - margin-left: -35px; - } - .uk-grid-large > * { - padding-left: 35px; - } - /* Vertical */ - .uk-grid-large + .uk-grid-large, - .uk-grid-large-margin, - .uk-grid-large > * > .uk-panel + .uk-panel { - margin-top: 35px; - } -} -/* Extra Large screens */ -@media (min-width: 1220px) { - /* Horizontal */ - .uk-grid-large { - margin-left: -50px; - } - .uk-grid-large > * { - padding-left: 50px; - } - /* Vertical */ - .uk-grid-large + .uk-grid-large, - .uk-grid-large-margin, - .uk-grid-large > * > .uk-panel + .uk-panel { - margin-top: 50px; - } -} -/* Modifier: `uk-grid-divider` - ========================================================================== */ -/* - * Horizontal divider - * Only works with the default gutter. Does not work with gutter collapse, small or large. - * Does not work with `uk-push-*`, `uk-pull-*` and not if the columns float into the next row. - */ -.uk-grid-divider:not(:empty) { - margin-left: -25px; - margin-right: -25px; -} -.uk-grid-divider > * { - padding-left: 25px; - padding-right: 25px; -} -.uk-grid-divider > [class*='uk-width-1-']:not(.uk-width-1-1):nth-child(n+2), -.uk-grid-divider > [class*='uk-width-2-']:nth-child(n+2), -.uk-grid-divider > [class*='uk-width-3-']:nth-child(n+2), -.uk-grid-divider > [class*='uk-width-4-']:nth-child(n+2), -.uk-grid-divider > [class*='uk-width-5-']:nth-child(n+2), -.uk-grid-divider > [class*='uk-width-6-']:nth-child(n+2), -.uk-grid-divider > [class*='uk-width-7-']:nth-child(n+2), -.uk-grid-divider > [class*='uk-width-8-']:nth-child(n+2), -.uk-grid-divider > [class*='uk-width-9-']:nth-child(n+2) { - border-left: 1px solid #ddd; -} -/* Tablet and bigger */ -@media (min-width: 768px) { - .uk-grid-divider > [class*='uk-width-medium-']:not(.uk-width-medium-1-1):nth-child(n+2) { - border-left: 1px solid #ddd; - } -} -/* Desktop and bigger */ -@media (min-width: 960px) { - .uk-grid-divider > [class*='uk-width-large-']:not(.uk-width-large-1-1):nth-child(n+2) { - border-left: 1px solid #ddd; - } -} -/* Large screen and bigger */ -@media (min-width: 1220px) { - /* - * Large gutter - */ - .uk-grid-divider:not(:empty) { - margin-left: -35px; - margin-right: -35px; - } - .uk-grid-divider > * { - padding-left: 35px; - padding-right: 35px; - } - .uk-grid-divider:empty { - margin-top: 35px; - margin-bottom: 35px; - } -} -/* - * Vertical divider - */ -.uk-grid-divider:empty { - margin-top: 25px; - margin-bottom: 25px; - border-top: 1px solid #ddd; -} -/* Match panels in grids - ========================================================================== */ -/* - * 1. Behave like a block element - */ -.uk-grid-match > * { - display: -ms-flexbox; - display: -webkit-flex; - display: flex; - /* 1 */ - -ms-flex-wrap: wrap; - -webkit-flex-wrap: wrap; - flex-wrap: wrap; -} -.uk-grid-match > * > * { - /* 1 */ - -ms-flex: none; - -webkit-flex: none; - flex: none; - box-sizing: border-box; - width: 100%; -} -/* Even grid cell widths - ========================================================================== */ -[class*='uk-grid-width'] > * { - box-sizing: border-box; - width: 100%; -} -.uk-grid-width-1-2 > * { - width: 50%; -} -.uk-grid-width-1-3 > * { - width: 33.333%; -} -.uk-grid-width-1-4 > * { - width: 25%; -} -.uk-grid-width-1-5 > * { - width: 20%; -} -.uk-grid-width-1-6 > * { - width: 16.666%; -} -.uk-grid-width-1-10 > * { - width: 10%; -} -.uk-grid-width-auto > * { - width: auto; -} -/* Phone landscape and bigger */ -@media (min-width: 480px) { - .uk-grid-width-small-1-1 > * { - width: 100%; - } - .uk-grid-width-small-1-2 > * { - width: 50%; - } - .uk-grid-width-small-1-3 > * { - width: 33.333%; - } - .uk-grid-width-small-1-4 > * { - width: 25%; - } - .uk-grid-width-small-1-5 > * { - width: 20%; - } - .uk-grid-width-small-1-6 > * { - width: 16.666%; - } - .uk-grid-width-small-1-10 > * { - width: 10%; - } -} -/* Tablet and bigger */ -@media (min-width: 768px) { - .uk-grid-width-medium-1-1 > * { - width: 100%; - } - .uk-grid-width-medium-1-2 > * { - width: 50%; - } - .uk-grid-width-medium-1-3 > * { - width: 33.333%; - } - .uk-grid-width-medium-1-4 > * { - width: 25%; - } - .uk-grid-width-medium-1-5 > * { - width: 20%; - } - .uk-grid-width-medium-1-6 > * { - width: 16.666%; - } - .uk-grid-width-medium-1-10 > * { - width: 10%; - } -} -/* Desktop and bigger */ -@media (min-width: 960px) { - .uk-grid-width-large-1-1 > * { - width: 100%; - } - .uk-grid-width-large-1-2 > * { - width: 50%; - } - .uk-grid-width-large-1-3 > * { - width: 33.333%; - } - .uk-grid-width-large-1-4 > * { - width: 25%; - } - .uk-grid-width-large-1-5 > * { - width: 20%; - } - .uk-grid-width-large-1-6 > * { - width: 16.666%; - } - .uk-grid-width-large-1-10 > * { - width: 10%; - } -} -/* Large screen and bigger */ -@media (min-width: 1220px) { - .uk-grid-width-xlarge-1-1 > * { - width: 100%; - } - .uk-grid-width-xlarge-1-2 > * { - width: 50%; - } - .uk-grid-width-xlarge-1-3 > * { - width: 33.333%; - } - .uk-grid-width-xlarge-1-4 > * { - width: 25%; - } - .uk-grid-width-xlarge-1-5 > * { - width: 20%; - } - .uk-grid-width-xlarge-1-6 > * { - width: 16.666%; - } - .uk-grid-width-xlarge-1-10 > * { - width: 10%; - } -} -/* Sub-objects: `uk-width-*` - ========================================================================== */ -[class*='uk-width'] { - box-sizing: border-box; - width: 100%; -} -/* - * Widths - */ -/* Whole */ -.uk-width-1-1 { - width: 100%; -} -/* Halves */ -.uk-width-1-2, -.uk-width-2-4, -.uk-width-3-6, -.uk-width-5-10 { - width: 50%; -} -/* Thirds */ -.uk-width-1-3, -.uk-width-2-6 { - width: 33.333%; -} -.uk-width-2-3, -.uk-width-4-6 { - width: 66.666%; -} -/* Quarters */ -.uk-width-1-4 { - width: 25%; -} -.uk-width-3-4 { - width: 75%; -} -/* Fifths */ -.uk-width-1-5, -.uk-width-2-10 { - width: 20%; -} -.uk-width-2-5, -.uk-width-4-10 { - width: 40%; -} -.uk-width-3-5, -.uk-width-6-10 { - width: 60%; -} -.uk-width-4-5, -.uk-width-8-10 { - width: 80%; -} -/* Sixths */ -.uk-width-1-6 { - width: 16.666%; -} -.uk-width-5-6 { - width: 83.333%; -} -/* Tenths */ -.uk-width-1-10 { - width: 10%; -} -.uk-width-3-10 { - width: 30%; -} -.uk-width-7-10 { - width: 70%; -} -.uk-width-9-10 { - width: 90%; -} -/* Phone landscape and bigger */ -@media (min-width: 480px) { - /* Whole */ - .uk-width-small-1-1 { - width: 100%; - } - /* Halves */ - .uk-width-small-1-2, - .uk-width-small-2-4, - .uk-width-small-3-6, - .uk-width-small-5-10 { - width: 50%; - } - /* Thirds */ - .uk-width-small-1-3, - .uk-width-small-2-6 { - width: 33.333%; - } - .uk-width-small-2-3, - .uk-width-small-4-6 { - width: 66.666%; - } - /* Quarters */ - .uk-width-small-1-4 { - width: 25%; - } - .uk-width-small-3-4 { - width: 75%; - } - /* Fifths */ - .uk-width-small-1-5, - .uk-width-small-2-10 { - width: 20%; - } - .uk-width-small-2-5, - .uk-width-small-4-10 { - width: 40%; - } - .uk-width-small-3-5, - .uk-width-small-6-10 { - width: 60%; - } - .uk-width-small-4-5, - .uk-width-small-8-10 { - width: 80%; - } - /* Sixths */ - .uk-width-small-1-6 { - width: 16.666%; - } - .uk-width-small-5-6 { - width: 83.333%; - } - /* Tenths */ - .uk-width-small-1-10 { - width: 10%; - } - .uk-width-small-3-10 { - width: 30%; - } - .uk-width-small-7-10 { - width: 70%; - } - .uk-width-small-9-10 { - width: 90%; - } -} -/* Tablet and bigger */ -@media (min-width: 768px) { - /* Whole */ - .uk-width-medium-1-1 { - width: 100%; - } - /* Halves */ - .uk-width-medium-1-2, - .uk-width-medium-2-4, - .uk-width-medium-3-6, - .uk-width-medium-5-10 { - width: 50%; - } - /* Thirds */ - .uk-width-medium-1-3, - .uk-width-medium-2-6 { - width: 33.333%; - } - .uk-width-medium-2-3, - .uk-width-medium-4-6 { - width: 66.666%; - } - /* Quarters */ - .uk-width-medium-1-4 { - width: 25%; - } - .uk-width-medium-3-4 { - width: 75%; - } - /* Fifths */ - .uk-width-medium-1-5, - .uk-width-medium-2-10 { - width: 20%; - } - .uk-width-medium-2-5, - .uk-width-medium-4-10 { - width: 40%; - } - .uk-width-medium-3-5, - .uk-width-medium-6-10 { - width: 60%; - } - .uk-width-medium-4-5, - .uk-width-medium-8-10 { - width: 80%; - } - /* Sixths */ - .uk-width-medium-1-6 { - width: 16.666%; - } - .uk-width-medium-5-6 { - width: 83.333%; - } - /* Tenths */ - .uk-width-medium-1-10 { - width: 10%; - } - .uk-width-medium-3-10 { - width: 30%; - } - .uk-width-medium-7-10 { - width: 70%; - } - .uk-width-medium-9-10 { - width: 90%; - } -} -/* Desktop and bigger */ -@media (min-width: 960px) { - /* Whole */ - .uk-width-large-1-1 { - width: 100%; - } - /* Halves */ - .uk-width-large-1-2, - .uk-width-large-2-4, - .uk-width-large-3-6, - .uk-width-large-5-10 { - width: 50%; - } - /* Thirds */ - .uk-width-large-1-3, - .uk-width-large-2-6 { - width: 33.333%; - } - .uk-width-large-2-3, - .uk-width-large-4-6 { - width: 66.666%; - } - /* Quarters */ - .uk-width-large-1-4 { - width: 25%; - } - .uk-width-large-3-4 { - width: 75%; - } - /* Fifths */ - .uk-width-large-1-5, - .uk-width-large-2-10 { - width: 20%; - } - .uk-width-large-2-5, - .uk-width-large-4-10 { - width: 40%; - } - .uk-width-large-3-5, - .uk-width-large-6-10 { - width: 60%; - } - .uk-width-large-4-5, - .uk-width-large-8-10 { - width: 80%; - } - /* Sixths */ - .uk-width-large-1-6 { - width: 16.666%; - } - .uk-width-large-5-6 { - width: 83.333%; - } - /* Tenths */ - .uk-width-large-1-10 { - width: 10%; - } - .uk-width-large-3-10 { - width: 30%; - } - .uk-width-large-7-10 { - width: 70%; - } - .uk-width-large-9-10 { - width: 90%; - } -} -/* Large screen and bigger */ -@media (min-width: 1220px) { - /* Whole */ - .uk-width-xlarge-1-1 { - width: 100%; - } - /* Halves */ - .uk-width-xlarge-1-2, - .uk-width-xlarge-2-4, - .uk-width-xlarge-3-6, - .uk-width-xlarge-5-10 { - width: 50%; - } - /* Thirds */ - .uk-width-xlarge-1-3, - .uk-width-xlarge-2-6 { - width: 33.333%; - } - .uk-width-xlarge-2-3, - .uk-width-xlarge-4-6 { - width: 66.666%; - } - /* Quarters */ - .uk-width-xlarge-1-4 { - width: 25%; - } - .uk-width-xlarge-3-4 { - width: 75%; - } - /* Fifths */ - .uk-width-xlarge-1-5, - .uk-width-xlarge-2-10 { - width: 20%; - } - .uk-width-xlarge-2-5, - .uk-width-xlarge-4-10 { - width: 40%; - } - .uk-width-xlarge-3-5, - .uk-width-xlarge-6-10 { - width: 60%; - } - .uk-width-xlarge-4-5, - .uk-width-xlarge-8-10 { - width: 80%; - } - /* Sixths */ - .uk-width-xlarge-1-6 { - width: 16.666%; - } - .uk-width-xlarge-5-6 { - width: 83.333%; - } - /* Tenths */ - .uk-width-xlarge-1-10 { - width: 10%; - } - .uk-width-xlarge-3-10 { - width: 30%; - } - .uk-width-xlarge-7-10 { - width: 70%; - } - .uk-width-xlarge-9-10 { - width: 90%; - } -} -/* Sub-object: `uk-push-*` and `uk-pull-*` - ========================================================================== */ -/* - * Source ordering - * Works only with `uk-width-medium-*` - */ -/* Tablet and bigger */ -@media (min-width: 768px) { - [class*='uk-push-'], - [class*='uk-pull-'] { - position: relative; - } - /* - * Push - */ - /* Halves */ - .uk-push-1-2, - .uk-push-2-4, - .uk-push-3-6, - .uk-push-5-10 { - left: 50%; - } - /* Thirds */ - .uk-push-1-3, - .uk-push-2-6 { - left: 33.333%; - } - .uk-push-2-3, - .uk-push-4-6 { - left: 66.666%; - } - /* Quarters */ - .uk-push-1-4 { - left: 25%; - } - .uk-push-3-4 { - left: 75%; - } - /* Fifths */ - .uk-push-1-5, - .uk-push-2-10 { - left: 20%; - } - .uk-push-2-5, - .uk-push-4-10 { - left: 40%; - } - .uk-push-3-5, - .uk-push-6-10 { - left: 60%; - } - .uk-push-4-5, - .uk-push-8-10 { - left: 80%; - } - /* Sixths */ - .uk-push-1-6 { - left: 16.666%; - } - .uk-push-5-6 { - left: 83.333%; - } - /* Tenths */ - .uk-push-1-10 { - left: 10%; - } - .uk-push-3-10 { - left: 30%; - } - .uk-push-7-10 { - left: 70%; - } - .uk-push-9-10 { - left: 90%; - } - /* - * Pull - */ - /* Halves */ - .uk-pull-1-2, - .uk-pull-2-4, - .uk-pull-3-6, - .uk-pull-5-10 { - left: -50%; - } - /* Thirds */ - .uk-pull-1-3, - .uk-pull-2-6 { - left: -33.333%; - } - .uk-pull-2-3, - .uk-pull-4-6 { - left: -66.666%; - } - /* Quarters */ - .uk-pull-1-4 { - left: -25%; - } - .uk-pull-3-4 { - left: -75%; - } - /* Fifths */ - .uk-pull-1-5, - .uk-pull-2-10 { - left: -20%; - } - .uk-pull-2-5, - .uk-pull-4-10 { - left: -40%; - } - .uk-pull-3-5, - .uk-pull-6-10 { - left: -60%; - } - .uk-pull-4-5, - .uk-pull-8-10 { - left: -80%; - } - /* Sixths */ - .uk-pull-1-6 { - left: -16.666%; - } - .uk-pull-5-6 { - left: -83.333%; - } - /* Tenths */ - .uk-pull-1-10 { - left: -10%; - } - .uk-pull-3-10 { - left: -30%; - } - .uk-pull-7-10 { - left: -70%; - } - .uk-pull-9-10 { - left: -90%; - } -} -/* ======================================================================== - Component: Panel - ========================================================================== */ -/* - * 1. Needed for `a` elements - * 2. Create position context for badges - */ -.uk-panel { - /* 1 */ - display: block; - /* 2 */ - position: relative; -} -/* - * Allow panels to be anchors - */ -.uk-panel, -.uk-panel:hover { - text-decoration: none; -} -/* - * Micro clearfix to make panels more robust - */ -.uk-panel:before, -.uk-panel:after { - content: ""; - display: table; -} -.uk-panel:after { - clear: both; -} -/* - * Remove margin from the last-child if not `uk-widget-title` - */ -.uk-panel > :not(.uk-panel-title):last-child { - margin-bottom: 0; -} -/* Sub-object: `uk-panel-title` - ========================================================================== */ -.uk-panel-title { - margin-top: 0; - margin-bottom: 15px; - font-size: 18px; - line-height: 24px; - font-weight: normal; - text-transform: none; - color: #444; -} -/* Sub-object: `uk-panel-badge` - ========================================================================== */ -.uk-panel-badge { - position: absolute; - top: 0; - right: 0; - z-index: 1; -} -/* Sub-object: `uk-panel-teaser` - ========================================================================== */ -.uk-panel-teaser { - margin-bottom: 15px; -} -/* Sub-object: `uk-panel-body` - ========================================================================== */ -.uk-panel-body { - padding: 15px; -} -/* Modifier: `uk-panel-box` - ========================================================================== */ -.uk-panel-box { - padding: 15px; - background: #f5f5f5; - color: #444; -} -.uk-panel-box-hover:hover { - color: #444; -} -.uk-panel-box .uk-panel-title { - color: #444; -} -.uk-panel-box .uk-panel-badge { - top: 10px; - right: 10px; -} -.uk-panel-box > .uk-panel-teaser { - margin-top: -15px; - margin-left: -15px; - margin-right: -15px; -} -/* - * Nav in panel - */ -.uk-panel-box > .uk-nav-side { - margin: 0 -15px; -} -/* - * Sub-modifier: `uk-panel-box-primary` - */ -.uk-panel-box-primary { - background-color: #ebf7fd; - color: #2d7091; -} -.uk-panel-box-primary-hover:hover { - color: #2d7091; -} -.uk-panel-box-primary .uk-panel-title { - color: #2d7091; -} -/* - * Sub-modifier: `uk-panel-box-secondary` - */ -.uk-panel-box-secondary { - background-color: #eee; - color: #444; -} -.uk-panel-box-secondary-hover:hover { - color: #444; -} -.uk-panel-box-secondary .uk-panel-title { - color: #444; -} -/* Modifier: `uk-panel-hover` - ========================================================================== */ -.uk-panel-hover { - padding: 15px; - color: #444; -} -.uk-panel-hover:hover { - background: #f5f5f5; - color: #444; -} -.uk-panel-hover .uk-panel-badge { - top: 10px; - right: 10px; -} -.uk-panel-hover > .uk-panel-teaser { - margin-top: -15px; - margin-left: -15px; - margin-right: -15px; -} -/* Modifier: `uk-panel-header` - ========================================================================== */ -.uk-panel-header .uk-panel-title { - padding-bottom: 10px; - border-bottom: 1px solid #ddd; - color: #444; -} -/* Modifier: `uk-panel-space` - ========================================================================== */ -.uk-panel-space { - padding: 30px; -} -.uk-panel-space .uk-panel-badge { - top: 30px; - right: 30px; -} -/* Modifier: `uk-panel-divider` - ========================================================================== */ -.uk-panel + .uk-panel-divider { - margin-top: 50px !important; -} -.uk-panel + .uk-panel-divider:before { - content: ""; - display: block; - position: absolute; - top: -25px; - left: 0; - right: 0; - border-top: 1px solid #ddd; -} -/* Large screen and bigger */ -@media (min-width: 1220px) { - .uk-panel + .uk-panel-divider { - margin-top: 70px !important; - } - .uk-panel + .uk-panel-divider:before { - top: -35px; - } -} -/* ======================================================================== - Component: Block - ========================================================================== */ -.uk-block { - position: relative; - box-sizing: border-box; - padding-top: 20px; - padding-bottom: 20px; -} -/* Phone landscape and bigger */ -@media (min-width: 768px) { - .uk-block { - padding-top: 50px; - padding-bottom: 50px; - } -} -/* - * Micro clearfix to make blocks more robust - */ -.uk-block:before, -.uk-block:after { - content: ""; - display: table; -} -.uk-block:after { - clear: both; -} -/* - * Remove margin from the last-child - */ -.uk-block > :last-child { - margin-bottom: 0; -} -/* Padding Modifier - ========================================================================== */ -/* - * Large padding - */ -.uk-block-large { - padding-top: 20px; - padding-bottom: 20px; -} -/* Tablets and bigger */ -@media (min-width: 768px) { - .uk-block-large { - padding-top: 50px; - padding-bottom: 50px; - } -} -/* Desktop and bigger */ -@media (min-width: 960px) { - .uk-block-large { - padding-top: 100px; - padding-bottom: 100px; - } -} -/* Color Modifier - ========================================================================== */ -/* - * Default - */ -.uk-block-default { - background: #fff; -} -/* - * Muted - */ -.uk-block-muted { - background: #f9f9f9; -} -/* - * Primary - */ -.uk-block-primary { - background: #00a8e6; -} -/* - * Secondary - */ -.uk-block-secondary { - background: #222; -} -/* ======================================================================== - Component: Article - ========================================================================== */ -/* - * Micro clearfix to make articles more robust - */ -.uk-article:before, -.uk-article:after { - content: ""; - display: table; -} -.uk-article:after { - clear: both; -} -/* - * Remove margin from the last-child - */ -.uk-article > :last-child { - margin-bottom: 0; -} -/* - * Vertical gutter for articles - */ -.uk-article + .uk-article { - margin-top: 25px; -} -/* Sub-object `uk-article-title` - ========================================================================== */ -.uk-article-title { - font-size: 36px; - line-height: 42px; - font-weight: normal; - text-transform: none; -} -.uk-article-title a { - color: inherit; - text-decoration: none; -} -/* Sub-object `uk-article-meta` - ========================================================================== */ -.uk-article-meta { - font-size: 12px; - line-height: 18px; - color: #999; -} -/* Sub-object `uk-article-lead` - ========================================================================== */ -.uk-article-lead { - color: #444; - font-size: 18px; - line-height: 24px; - font-weight: normal; -} -/* Sub-object `uk-article-divider` - ========================================================================== */ -.uk-article-divider { - margin-bottom: 25px; - border-color: #ddd; -} -* + .uk-article-divider { - margin-top: 25px; -} -/* ======================================================================== - Component: Comment - ========================================================================== */ -/* Sub-object `uk-comment-header` - ========================================================================== */ -.uk-comment-header { - margin-bottom: 15px; -} -/* - * Micro clearfix - */ -.uk-comment-header:before, -.uk-comment-header:after { - content: ""; - display: table; -} -.uk-comment-header:after { - clear: both; -} -/* Sub-object `uk-comment-avatar` - ========================================================================== */ -.uk-comment-avatar { - margin-right: 15px; - float: left; -} -/* Sub-object `uk-comment-title` - ========================================================================== */ -.uk-comment-title { - margin: 5px 0 0 0; - font-size: 16px; - line-height: 22px; -} -/* Sub-object `uk-comment-meta` - ========================================================================== */ -.uk-comment-meta { - margin: 2px 0 0 0; - font-size: 11px; - line-height: 16px; - color: #999; -} -/* Sub-object `uk-comment-body` - ========================================================================== */ -/* - * Remove margin from the last-child - */ -.uk-comment-body > :last-child { - margin-bottom: 0; -} -/* Sub-object `uk-comment-list` - ========================================================================== */ -.uk-comment-list { - padding: 0; - list-style: none; -} -.uk-comment-list .uk-comment + ul { - margin: 15px 0 0 0; - list-style: none; -} -.uk-comment-list > li:nth-child(n+2), -.uk-comment-list .uk-comment + ul > li:nth-child(n+2) { - margin-top: 15px; -} -/* Tablet and bigger */ -@media (min-width: 768px) { - .uk-comment-list .uk-comment + ul { - padding-left: 100px; - } -} -/* Modifier `uk-comment-primary` - ========================================================================== */ -/* ======================================================================== - Component: Cover - ========================================================================== */ -/* - * Background image always covers and centers its element - */ -.uk-cover-background { - background-position: 50% 50%; - background-size: cover; - background-repeat: no-repeat; -} -/* - * Emulates image cover, works with video and image elements - * 1. Parent container which clips resized object - * 2. Resizes the object to always covers its container - * 3. Reset the responsive image CSS - * 4. Center object - */ -/* 1 */ -.uk-cover { - overflow: hidden; -} -.uk-cover-object { - /* 2 */ - width: auto; - height: auto; - min-width: 100%; - min-height: 100%; - /* 3 */ - max-width: none; - /* 4 */ - position: relative; - left: 50%; - top: 50%; - -webkit-transform: translate(-50%, -50%); - transform: translate(-50%, -50%); -} -/* - * To center iframes use `data-uk-cover` JavaScript - */ -[data-uk-cover] { - position: relative; - left: 50%; - top: 50%; - -webkit-transform: translate(-50%, -50%); - transform: translate(-50%, -50%); -} -/* ======================================================================== - Component: Nav - ========================================================================== */ -.uk-nav, -.uk-nav ul { - margin: 0; - padding: 0; - list-style: none; -} -/* - * Items - */ -.uk-nav li > a { - display: block; - text-decoration: none; -} -.uk-nav > li > a { - padding: 5px 15px; -} -/* - * Nested items - */ -.uk-nav ul { - padding-left: 15px; -} -.uk-nav ul a { - padding: 2px 0; -} -/* - * Item subtitle - */ -.uk-nav li > a > div { - font-size: 12px; - line-height: 18px; -} -/* Sub-object: `uk-nav-header` - ========================================================================== */ -.uk-nav-header { - padding: 5px 15px; - text-transform: uppercase; - font-weight: bold; - font-size: 12px; -} -.uk-nav-header:not(:first-child) { - margin-top: 15px; -} -/* Sub-object: `uk-nav-divider` - ========================================================================== */ -.uk-nav-divider { - margin: 9px 15px; -} -/* Sub-object: `uk-nav-sub` - ========================================================================== */ -/* - * `ul` needed for higher specificity to override padding - */ -ul.uk-nav-sub { - padding: 5px 0 5px 15px; -} -/* Modifier: `uk-nav-parent-icon` - ========================================================================== */ -.uk-nav-parent-icon > .uk-parent > a:after { - content: "\f104"; - width: 20px; - margin-right: -10px; - float: right; - font-family: FontAwesome; - text-align: center; -} -.uk-nav-parent-icon > .uk-parent.uk-open > a:after { - content: "\f107"; -} -/* Modifier `uk-nav-side` - ========================================================================== */ -/* - * Items - */ -.uk-nav-side > li > a { - color: #444; -} -/* - * Hover - * 1. Apply hover style also to focus state - * 2. Remove default focus style - */ -.uk-nav-side > li > a:hover, -.uk-nav-side > li > a:focus { - background: rgba(0, 0, 0, 0.05); - color: #444; - /* 2 */ - outline: none; -} -/* Active */ -.uk-nav-side > li.uk-active > a { - background: #00a8e6; - color: #fff; -} -/* - * Sub-object: `uk-nav-header` - */ -.uk-nav-side .uk-nav-header { - color: #444; -} -/* - * Sub-object: `uk-nav-divider` - */ -.uk-nav-side .uk-nav-divider { - border-top: 1px solid #ddd; -} -/* - * Nested items - */ -.uk-nav-side ul a { - color: #07D; -} -.uk-nav-side ul a:hover { - color: #059; -} -/* Modifier `uk-nav-dropdown` - ========================================================================== */ -/* - * Items - */ -.uk-nav-dropdown > li > a { - color: #444; -} -/* - * Hover - * 1. Apply hover style also to focus state - * 2. Remove default focus style - */ -.uk-nav-dropdown > li > a:hover, -.uk-nav-dropdown > li > a:focus { - background: #00a8e6; - color: #fff; - /* 2 */ - outline: none; -} -/* - * Sub-object: `uk-nav-header` - */ -.uk-nav-dropdown .uk-nav-header { - color: #999; -} -/* - * Sub-object: `uk-nav-divider` - */ -.uk-nav-dropdown .uk-nav-divider { - border-top: 1px solid #ddd; -} -/* - * Nested items - */ -.uk-nav-dropdown ul a { - color: #07D; -} -.uk-nav-dropdown ul a:hover { - color: #059; -} -/* Modifier `uk-nav-navbar` - ========================================================================== */ -/* - * Items - */ -.uk-nav-navbar > li > a { - color: #444; -} -/* - * Hover - * 1. Apply hover style also to focus state - * 2. Remove default focus style - */ -.uk-nav-navbar > li > a:hover, -.uk-nav-navbar > li > a:focus { - background: #00a8e6; - color: #fff; - /* 2 */ - outline: none; -} -/* - * Sub-object: `uk-nav-header` - */ -.uk-nav-navbar .uk-nav-header { - color: #999; -} -/* - * Sub-object: `uk-nav-divider` - */ -.uk-nav-navbar .uk-nav-divider { - border-top: 1px solid #ddd; -} -/* - * Nested items - */ -.uk-nav-navbar ul a { - color: #07D; -} -.uk-nav-navbar ul a:hover { - color: #059; -} -/* Modifier `uk-nav-offcanvas` - ========================================================================== */ -/* - * Items - */ -.uk-nav-offcanvas > li > a { - color: #ccc; - padding: 10px 15px; -} -/* - * Hover - * No hover on touch devices because it behaves buggy in fixed offcanvas - * 1. Apply hover style also to focus state - * 2. Remove default focus style - */ -.uk-nav-offcanvas > .uk-open > a, -html:not(.uk-touch) .uk-nav-offcanvas > li > a:hover, -html:not(.uk-touch) .uk-nav-offcanvas > li > a:focus { - background: #404040; - color: #fff; - /* 2 */ - outline: none; -} -/* - * Active - * `html .uk-nav` needed for higher specificity to override hover - */ -html .uk-nav.uk-nav-offcanvas > li.uk-active > a { - background: #1a1a1a; - color: #fff; -} -/* - * Sub-object: `uk-nav-header` - */ -.uk-nav-offcanvas .uk-nav-header { - color: #777; -} -/* - * Sub-object: `uk-nav-divider` - */ -.uk-nav-offcanvas .uk-nav-divider { - border-top: 1px solid #1a1a1a; -} -/* - * Nested items - * No hover on touch devices because it behaves buggy in fixed offcanvas - */ -.uk-nav-offcanvas ul a { - color: #ccc; -} -html:not(.uk-touch) .uk-nav-offcanvas ul a:hover { - color: #fff; -} -/* ======================================================================== - Component: Navbar - ========================================================================== */ -.uk-navbar { - background: #eee; - color: #444; -} -/* - * Micro clearfix - */ -.uk-navbar:before, -.uk-navbar:after { - content: ""; - display: table; -} -.uk-navbar:after { - clear: both; -} -/* Sub-object: `uk-navbar-nav` - ========================================================================== */ -.uk-navbar-nav { - margin: 0; - padding: 0; - list-style: none; - float: left; -} -/* - * 1. Create position context for dropdowns - */ -.uk-navbar-nav > li { - float: left; - /* 1 */ - position: relative; -} -/* - * 1. Dimensions - * 2. Style - */ -.uk-navbar-nav > li > a { - display: block; - box-sizing: border-box; - text-decoration: none; - /* 1 */ - height: 40px; - padding: 0 15px; - line-height: 40px; - /* 2 */ - color: #444; - font-size: 14px; - font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; - font-weight: normal; -} -/* Appear not as link */ -.uk-navbar-nav > li > a[href='#'] { - cursor: text; -} -/* - * Hover - * 1. Apply hover style also to focus state - * 2. Also apply if dropdown is opened - * 3. Remove default focus style - */ -.uk-navbar-nav > li:hover > a, -.uk-navbar-nav > li > a:focus, -.uk-navbar-nav > li.uk-open > a { - background-color: #f5f5f5; - color: #444; - /* 3 */ - outline: none; -} -/* OnClick */ -.uk-navbar-nav > li > a:active { - background-color: #ddd; - color: #444; -} -/* Active */ -.uk-navbar-nav > li.uk-active > a { - background-color: #f5f5f5; - color: #444; -} -/* Sub-objects: `uk-navbar-nav-subtitle` - ========================================================================== */ -.uk-navbar-nav .uk-navbar-nav-subtitle { - line-height: 28px; -} -.uk-navbar-nav-subtitle > div { - margin-top: -6px; - font-size: 10px; - line-height: 12px; -} -/* Sub-objects: `uk-navbar-content`, `uk-navbar-brand`, `uk-navbar-toggle` - ========================================================================== */ -/* - * Imitate navbar items - */ -.uk-navbar-content, -.uk-navbar-brand, -.uk-navbar-toggle { - box-sizing: border-box; - display: block; - height: 40px; - padding: 0 15px; - float: left; -} -/* - * Helper to center all child elements vertically - */ -.uk-navbar-content:before, -.uk-navbar-brand:before, -.uk-navbar-toggle:before { - content: ''; - display: inline-block; - height: 100%; - vertical-align: middle; -} -/* Sub-objects: `uk-navbar-content` - ========================================================================== */ -/* - * Better sibling spacing - */ -.uk-navbar-content + .uk-navbar-content:not(.uk-navbar-center) { - padding-left: 0; -} -/* - * Link colors - */ -.uk-navbar-content > a:not([class]) { - color: #07D; -} -.uk-navbar-content > a:not([class]):hover { - color: #059; -} -/* Sub-objects: `uk-navbar-brand` - ========================================================================== */ -.uk-navbar-brand { - font-size: 18px; - color: #444; - text-decoration: none; -} -/* - * 1. Apply hover style also to focus state - * 2. Remove default focus style - */ -.uk-navbar-brand:hover, -.uk-navbar-brand:focus { - color: #444; - text-decoration: none; - /* 2 */ - outline: none; -} -/* Sub-object: `uk-navbar-toggle` - ========================================================================== */ -.uk-navbar-toggle { - font-size: 18px; - color: #444; - text-decoration: none; -} -/* - * 1. Apply hover style also to focus state - * 2. Remove default focus style - */ -.uk-navbar-toggle:hover, -.uk-navbar-toggle:focus { - color: #444; - text-decoration: none; - /* 2 */ - outline: none; -} -/* - * 1. Center icon vertically - */ -.uk-navbar-toggle:after { - content: "\f0c9"; - font-family: FontAwesome; - /* 1 */ - vertical-align: middle; -} -.uk-navbar-toggle-alt:after { - content: "\f002"; -} -/* Sub-object: `uk-navbar-center` - ========================================================================== */ -/* - * The element with this class needs to be last child in the navbar - * 1. This hack is needed because other float elements shift centered text - */ -.uk-navbar-center { - float: none; - text-align: center; - /* 1 */ - max-width: 50%; - margin-left: auto; - margin-right: auto; -} -/* Sub-object: `uk-navbar-flip` - ========================================================================== */ -.uk-navbar-flip { - float: right; -} -/* ======================================================================== - Component: Subnav - ========================================================================== */ -/* - * 1. Gutter - * 2. Remove default list style - */ -.uk-subnav { - display: -ms-flexbox; - display: -webkit-flex; - display: flex; - -ms-flex-wrap: wrap; - -webkit-flex-wrap: wrap; - flex-wrap: wrap; - /* 1 */ - margin-left: -10px; - margin-top: -10px; - /* 2 */ - padding: 0; - list-style: none; -} -/* - * 1. Space is allocated solely based on content dimensions - * 2. Horizontal gutter is using `padding` so `uk-width-*` classes can be applied - * 3. Create position context for dropdowns - */ -.uk-subnav > * { - /* 1 */ - -ms-flex: none; - -webkit-flex: none; - flex: none; - /* 2 */ - padding-left: 10px; - margin-top: 10px; - /* 3 */ - position: relative; -} -/* - * DEPRECATED IE9 Support - */ -.uk-subnav:before, -.uk-subnav:after { - content: ""; - display: block; - overflow: hidden; -} -.uk-subnav:after { - clear: both; -} -.uk-subnav > * { - float: left; -} -/* Items - ========================================================================== */ -.uk-subnav > * > * { - display: inline-block; - color: #444; -} -/* - * Hover - * 1. Apply hover style also to focus state - */ -.uk-subnav > * > :hover, -.uk-subnav > * > :focus { - color: #07D; - text-decoration: none; -} -/* - * Active - */ -.uk-subnav > .uk-active > * { - color: #07D; -} -/* Modifier: 'subnav-line' - ========================================================================== */ -.uk-subnav-line > :before { - content: ""; - display: inline-block; - height: 10px; - vertical-align: middle; -} -.uk-subnav-line > :nth-child(n+2):before { - margin-right: 10px; - border-left: 1px solid #ddd; -} -/* Modifier: 'subnav-pill' - ========================================================================== */ -.uk-subnav-pill > * > * { - padding: 3px 9px; -} -/* - * Hover - * 1. Apply hover style also to focus state - * 2. Remove default focus style - */ -.uk-subnav-pill > * > :hover, -.uk-subnav-pill > * > :focus { - background: #eee; - color: #444; - text-decoration: none; - /* 2 */ - outline: none; -} -/* - * Active - * `li` needed for higher specificity to override hover - */ -.uk-subnav-pill > .uk-active > * { - background: #00a8e6; - color: #fff; -} -/* Disabled state - ========================================================================== */ -.uk-subnav > .uk-disabled > * { - background: none; - color: #999; - text-decoration: none; - cursor: text; -} -/* ======================================================================== - Component: Breadcrumb - ========================================================================== */ -/* - * 1. Remove default list style - * 2. Remove whitespace between child elements when using `inline-block` - */ -.uk-breadcrumb { - /* 1 */ - padding: 0; - list-style: none; - /* 2 */ - font-size: 0.001px; -} -/* Items - ========================================================================== */ -/* - * Reset whitespace hack - */ -.uk-breadcrumb > li { - font-size: 1rem; - vertical-align: top; -} -.uk-breadcrumb > li, -.uk-breadcrumb > li > a, -.uk-breadcrumb > li > span { - display: inline-block; -} -.uk-breadcrumb > li:nth-child(n+2):before { - content: "/"; - display: inline-block; - margin: 0 8px; -} -/* - * Disabled - */ -.uk-breadcrumb > li:not(.uk-active) > span { - color: #999; -} -/* ======================================================================== - Component: Pagination - ========================================================================== */ -/* - * 1. Remove default list style - * 2. Center pagination by default - * 3. Remove whitespace between child elements when using `inline-block` - */ -.uk-pagination { - /* 1 */ - padding: 0; - list-style: none; - /* 2 */ - text-align: center; - /* 3 */ - font-size: 0.001px; -} -/* - * Micro clearfix - * Needed if `uk-pagination-previous` or `uk-pagination-next` sub-objects are used - */ -.uk-pagination:before, -.uk-pagination:after { - content: ""; - display: table; -} -.uk-pagination:after { - clear: both; -} -/* Items - ========================================================================== */ -/* - * 1. Reset whitespace hack - * 2. Remove the gap at the bottom of it container - */ -.uk-pagination > li { - display: inline-block; - /* 1 */ - font-size: 1rem; - /* 2 */ - vertical-align: top; -} -.uk-pagination > li:nth-child(n+2) { - margin-left: 5px; -} -/* - * 1. Makes pagination more robust against different box-sizing use - * 2. Reset text-align to center if alignment modifier is used - */ -.uk-pagination > li > a, -.uk-pagination > li > span { - display: inline-block; - min-width: 16px; - padding: 3px 5px; - line-height: 20px; - text-decoration: none; - /* 1 */ - box-sizing: content-box; - /* 2 */ - text-align: center; -} -/* - * Links - */ -.uk-pagination > li > a { - background: #eee; - color: #444; -} -/* - * Hover - * 1. Apply hover style also to focus state - * 2. Remove default focus style - */ -.uk-pagination > li > a:hover, -.uk-pagination > li > a:focus { - background-color: #f5f5f5; - color: #444; - /* 2 */ - outline: none; -} -/* OnClick */ -.uk-pagination > li > a:active { - background-color: #ddd; - color: #444; -} -/* - * Active - */ -.uk-pagination > .uk-active > span { - background: #00a8e6; - color: #fff; -} -/* - * Disabled - */ -.uk-pagination > .uk-disabled > span { - background-color: #f5f5f5; - color: #999; -} -/* Previous and next navigation - ========================================================================== */ -.uk-pagination-previous { - float: left; -} -.uk-pagination-next { - float: right; -} -/* Alignment modifiers - ========================================================================== */ -.uk-pagination-left { - text-align: left; -} -.uk-pagination-right { - text-align: right; -} -/* ======================================================================== - Component: Tab - ========================================================================== */ -.uk-tab { - margin: 0; - padding: 0; - list-style: none; - border-bottom: 1px solid #ddd; -} -/* - * Micro clearfix on the deepest container - */ -.uk-tab:before, -.uk-tab:after { - content: ""; - display: table; -} -.uk-tab:after { - clear: both; -} -/* - * Items - * 1. Create position context for dropdowns - */ -.uk-tab > li { - margin-bottom: -1px; - float: left; - /* 1 */ - position: relative; -} -.uk-tab > li > a { - display: block; - padding: 8px 12px 8px 12px; - border: 1px solid transparent; - border-bottom-width: 0; - color: #07D; - text-decoration: none; -} -.uk-tab > li:nth-child(n+2) > a { - margin-left: 5px; -} -/* - * Hover - * 1. Apply hover style also to focus state - * 2. Also apply if dropdown is opened - * 3. Remove default focus style - */ -.uk-tab > li > a:hover, -.uk-tab > li > a:focus, -.uk-tab > li.uk-open > a { - border-color: #f5f5f5; - background: #f5f5f5; - color: #059; - /* 2 */ - outline: none; -} -.uk-tab > li:not(.uk-active) > a:hover, -.uk-tab > li:not(.uk-active) > a:focus, -.uk-tab > li.uk-open:not(.uk-active) > a { - margin-bottom: 1px; - padding-bottom: 7px; -} -/* Active */ -.uk-tab > li.uk-active > a { - border-color: #ddd; - border-bottom-color: transparent; - background: #fff; - color: #444; -} -/* Disabled */ -.uk-tab > li.uk-disabled > a { - color: #999; - cursor: text; -} -.uk-tab > li.uk-disabled > a:hover, -.uk-tab > li.uk-disabled > a:focus, -.uk-tab > li.uk-disabled.uk-active > a { - background: none; - border-color: transparent; -} -/* Modifier: 'tab-flip' - ========================================================================== */ -.uk-tab-flip > li { - float: right; -} -.uk-tab-flip > li:nth-child(n+2) > a { - margin-left: 0; - margin-right: 5px; -} -/* Modifier: 'tab-responsive' - ========================================================================== */ -.uk-tab > li.uk-tab-responsive > a { - margin-left: 0; - margin-right: 0; -} -/* - * Icon - */ -.uk-tab-responsive > a:before { - content: "\f0c9\00a0"; - font-family: FontAwesome; -} -/* Modifier: 'tab-center' - ========================================================================== */ -.uk-tab-center { - border-bottom: 1px solid #ddd; -} -.uk-tab-center-bottom { - border-bottom: none; - border-top: 1px solid #ddd; -} -.uk-tab-center:before, -.uk-tab-center:after { - content: ""; - display: table; -} -.uk-tab-center:after { - clear: both; -} -/* - * 1. Using `right` to prevent vertical scrollbar caused by centering if to many tabs - */ -.uk-tab-center .uk-tab { - position: relative; - right: 50%; - border: none; - float: right; -} -.uk-tab-center .uk-tab > li { - position: relative; - right: -50%; -} -.uk-tab-center .uk-tab > li > a { - text-align: center; -} -/* Modifier: 'tab-bottom' - ========================================================================== */ -.uk-tab-bottom { - border-top: 1px solid #ddd; - border-bottom: none; -} -.uk-tab-bottom > li { - margin-top: -1px; - margin-bottom: 0; -} -.uk-tab-bottom > li > a { - padding-top: 8px; - padding-bottom: 8px; - border-bottom-width: 1px; - border-top-width: 0; -} -.uk-tab-bottom > li:not(.uk-active) > a:hover, -.uk-tab-bottom > li:not(.uk-active) > a:focus, -.uk-tab-bottom > li.uk-open:not(.uk-active) > a { - margin-bottom: 0; - margin-top: 1px; - padding-bottom: 8px; - padding-top: 7px; -} -.uk-tab-bottom > li.uk-active > a { - border-top-color: transparent; - border-bottom-color: #ddd; -} -/* Modifier: 'tab-grid' - ========================================================================== */ -/* - * 1. Create position context to prevent hidden border because of negative `z-index` - */ -.uk-tab-grid { - margin-left: -5px; - border-bottom: none; - /* 1 */ - position: relative; - z-index: 0; -} -.uk-tab-grid:before { - display: block; - position: absolute; - left: 5px; - right: 0; - bottom: -1px; - border-top: 1px solid #ddd; - /* 1 */ - z-index: -1; -} -.uk-tab-grid > li:first-child > a { - margin-left: 5px; -} -.uk-tab-grid > li > a { - text-align: center; -} -/* - * If `uk-tab-bottom` - */ -.uk-tab-grid.uk-tab-bottom { - border-top: none; -} -.uk-tab-grid.uk-tab-bottom:before { - top: -1px; - bottom: auto; -} -/* Modifier: 'tab-left', 'tab-right' - ========================================================================== */ -/* Tablet and bigger */ -@media (min-width: 768px) { - .uk-tab-left, - .uk-tab-right { - border-bottom: none; - } - .uk-tab-left > li, - .uk-tab-right > li { - margin-bottom: 0; - float: none; - } - .uk-tab-left > li > a, - .uk-tab-right > li > a { - padding-top: 8px; - padding-bottom: 8px; - } - .uk-tab-left > li:nth-child(n+2) > a, - .uk-tab-right > li:nth-child(n+2) > a { - margin-left: 0; - margin-top: 5px; - } - .uk-tab-left > li.uk-active > a, - .uk-tab-right > li.uk-active > a { - border-color: #ddd; - } - /* - * Modifier: 'tab-left' - */ - .uk-tab-left { - border-right: 1px solid #ddd; - } - .uk-tab-left > li { - margin-right: -1px; - } - .uk-tab-left > li > a { - border-bottom-width: 1px; - border-right-width: 0; - } - .uk-tab-left > li:not(.uk-active) > a:hover, - .uk-tab-left > li:not(.uk-active) > a:focus { - margin-bottom: 0; - margin-right: 1px; - padding-bottom: 8px; - padding-right: 11px; - } - .uk-tab-left > li.uk-active > a { - border-right-color: transparent; - } - /* - * Modifier: 'tab-right' - */ - .uk-tab-right { - border-left: 1px solid #ddd; - } - .uk-tab-right > li { - margin-left: -1px; - } - .uk-tab-right > li > a { - border-bottom-width: 1px; - border-left-width: 0; - } - .uk-tab-right > li:not(.uk-active) > a:hover, - .uk-tab-right > li:not(.uk-active) > a:focus { - margin-bottom: 0; - margin-left: 1px; - padding-bottom: 8px; - padding-left: 11px; - } - .uk-tab-right > li.uk-active > a { - border-left-color: transparent; - } -} -/* ======================================================================== - Component: Thumbnav - ========================================================================== */ -/* - * 1. Gutter - * 2. Remove default list style - */ -.uk-thumbnav { - display: -ms-flexbox; - display: -webkit-flex; - display: flex; - -ms-flex-wrap: wrap; - -webkit-flex-wrap: wrap; - flex-wrap: wrap; - /* 1 */ - margin-left: -10px; - margin-top: -10px; - /* 2 */ - padding: 0; - list-style: none; -} -/* - * 1. Space is allocated solely based on content dimensions - * 2. Horizontal gutter is using `padding` so `uk-width-*` classes can be applied - */ -.uk-thumbnav > * { - /* 1 */ - -ms-flex: none; - -webkit-flex: none; - flex: none; - /* 2 */ - padding-left: 10px; - margin-top: 10px; -} -/* - * DEPRECATED IE9 Support - */ -.uk-thumbnav:before, -.uk-thumbnav:after { - content: ""; - display: block; - overflow: hidden; -} -.uk-thumbnav:after { - clear: both; -} -.uk-thumbnav > * { - float: left; -} -/* Items - ========================================================================== */ -.uk-thumbnav > * > * { - display: block; - background: #fff; -} -.uk-thumbnav > * > * > img { - opacity: 0.7; - -webkit-transition: opacity 0.15s linear; - transition: opacity 0.15s linear; -} -/* - * Hover - */ -.uk-thumbnav > * > :hover > img, -.uk-thumbnav > * > :focus > img { - opacity: 1; -} -/* - * Active - */ -.uk-thumbnav > .uk-active > * > img { - opacity: 1; -} -/* ======================================================================== - Component: List - ========================================================================== */ -.uk-list { - padding: 0; - list-style: none; -} -/* - * Micro clearfix to make list more robust - */ -.uk-list > li:before, -.uk-list > li:after { - content: ""; - display: table; -} -.uk-list > li:after { - clear: both; -} -/* - * Remove margin from the last-child - */ -.uk-list > li > :last-child { - margin-bottom: 0; -} -/* - * Nested lists - */ -.uk-list ul { - margin: 0; - padding-left: 20px; - list-style: none; -} -/* Modifier: `uk-list-line` - ========================================================================== */ -.uk-list-line > li:nth-child(n+2) { - margin-top: 5px; - padding-top: 5px; - border-top: 1px solid #ddd; -} -/* Modifier: `uk-list-striped` - ========================================================================== */ -.uk-list-striped > li { - padding: 5px 5px; -} -.uk-list-striped > li:nth-of-type(odd) { - background: #f5f5f5; -} -/* Modifier: `uk-list-space` - ========================================================================== */ -.uk-list-space > li:nth-child(n+2) { - margin-top: 10px; -} -/* ======================================================================== - Component: Description list - ========================================================================== */ -/* Modifier: `uk-description-list-horizontal` - ========================================================================== */ -/* Tablet and bigger */ -@media (min-width: 768px) { - .uk-description-list-horizontal { - overflow: hidden; - } - .uk-description-list-horizontal > dt { - width: 160px; - float: left; - clear: both; - overflow: hidden; - text-overflow: ellipsis; - white-space: nowrap; - } - .uk-description-list-horizontal > dd { - margin-left: 180px; - } -} -/* Modifier: `uk-description-list-line` - ========================================================================== */ -.uk-description-list-line > dt { - font-weight: normal; -} -.uk-description-list-line > dt:nth-child(n+2) { - margin-top: 5px; - padding-top: 5px; - border-top: 1px solid #ddd; -} -.uk-description-list-line > dd { - color: #999; -} -/* ======================================================================== - Component: Table - ========================================================================== */ -/* - * 1. Remove most spacing between table cells. - * 2. Block element behavior - * 3. Style - */ -.uk-table { - /* 1 */ - border-collapse: collapse; - border-spacing: 0; - /* 2 */ - width: 100%; - /* 3 */ - margin-bottom: 15px; -} -/* - * Add margin if adjacent element - */ -* + .uk-table { - margin-top: 15px; -} -.uk-table th, -.uk-table td { - padding: 8px 8px; -} -/* - * Set alignment - */ -.uk-table th { - text-align: left; -} -.uk-table td { - vertical-align: top; -} -.uk-table thead th { - vertical-align: bottom; -} -/* - * Caption and footer - */ -.uk-table caption, -.uk-table tfoot { - font-size: 12px; - font-style: italic; -} -.uk-table caption { - text-align: left; - color: #999; -} -/* - * Active State - */ -.uk-table tbody tr.uk-active { - background: #EEE; -} -/* Sub-modifier: `uk-table-middle` - ========================================================================== */ -.uk-table-middle, -.uk-table-middle td { - vertical-align: middle !important; -} -/* Modifier: `uk-table-striped` - ========================================================================== */ -.uk-table-striped tbody tr:nth-of-type(odd) { - background: #f5f5f5; -} -/* Modifier: `uk-table-condensed` - ========================================================================== */ -.uk-table-condensed td { - padding: 4px 8px; -} -/* Modifier: `uk-table-hover` - ========================================================================== */ -.uk-table-hover tbody tr:hover { - background: #EEE; -} -/* ======================================================================== - Component: Form - ========================================================================== */ -/* - * 1. Define consistent box sizing. - * Default is `content-box` with following exceptions set to `border-box` - * `button`, `select`, `input[type="checkbox"]` and `input[type="radio"]` - * `input[type="search"]` in Chrome, Safari and Opera - * `input[type="color"]` in Firefox - * 2. Address margins set differently in Firefox/IE and Chrome/Safari/Opera. - * 3. Remove `border-radius` in iOS. - * 4. Correct `font` properties and `color` not being inherited. - */ -.uk-form input, -.uk-form select, -.uk-form textarea { - /* 1 */ - box-sizing: border-box; - /* 2 */ - margin: 0; - /* 3 */ - border-radius: 0; - /* 4 */ - font: inherit; - color: inherit; -} -/* - * Address inconsistent `text-transform` inheritance which is only inherit in Firefox - */ -.uk-form select { - text-transform: none; -} -/* - * 1. Correct `font` properties not being inherited. - * 2. Don't inherit the `font-weight` and use `bold` instead. - * NOTE: Both declarations don't work in Chrome, Safari and Opera. - */ -.uk-form optgroup { - /* 1 */ - font: inherit; - /* 2 */ - font-weight: bold; -} -/* - * Removes inner padding and border in Firefox 4+. - */ -.uk-form input::-moz-focus-inner { - border: 0; - padding: 0; -} -/* - * Removes excess padding in IE 8/9/10. - */ -.uk-form input[type="checkbox"], -.uk-form input[type="radio"] { - padding: 0; -} -/* - * Improves consistency of cursor style for clickable elements - */ -.uk-form input[type="checkbox"]:not(:disabled), -.uk-form input[type="radio"]:not(:disabled) { - cursor: pointer; -} -/* - * Remove default style in iOS. - */ -.uk-form textarea, -.uk-form input:not([type]), -.uk-form input[type="text"], -.uk-form input[type="password"], -.uk-form input[type="email"], -.uk-form input[type="url"], -.uk-form input[type="search"], -.uk-form input[type="tel"], -.uk-form input[type="number"], -.uk-form input[type="datetime"] { - -webkit-appearance: none; -} -/* - * Remove inner padding and search cancel button in Chrome, Safari and Opera on OS X. - */ -.uk-form input[type="search"]::-webkit-search-cancel-button, -.uk-form input[type="search"]::-webkit-search-decoration { - -webkit-appearance: none; -} -/* - * Fix the cursor style for Chrome's increment/decrement buttons. For certain - * `font-size` values of the `input`, it causes the cursor style of the - * decrement button to change from `default` to `text`. - */ -.uk-form input[type="number"]::-webkit-inner-spin-button, -.uk-form input[type="number"]::-webkit-outer-spin-button { - height: auto; -} -/* - * Define consistent border, margin, and padding. - */ -.uk-form fieldset { - border: none; - margin: 0; - padding: 0; -} -/* - * 1. Remove default vertical scrollbar in IE 8/9/10/11. - * 2. Improve readability and alignment in all browsers. - */ -.uk-form textarea { - /* 1 */ - overflow: auto; - /* 2 */ - vertical-align: top; -} -/* - * Removes placeholder transparency in Firefox. - */ -.uk-form ::-moz-placeholder { - opacity: 1; -} -/* - * Removes `box-shadow` for invalid controls in Firefox. - */ -.uk-form :invalid { - box-shadow: none; -} -/* - * Vertical alignment - */ -.uk-form input:not([type="radio"]):not([type="checkbox"]), -.uk-form select { - vertical-align: middle; -} -/* Style - ========================================================================== */ -/* - * Remove margin from the last-child - */ -.uk-form > :last-child { - margin-bottom: 0; -} -/* - * Controls - * Except for `range`, `radio`, `checkbox`, `file`, `submit`, `reset`, `button` and `image` - * 1. Must be `height` because `min-height` is not working in OSX - * 2. Responsiveness: Sets a maximum width relative to the parent to scale on narrower viewports - * 3. Vertical `padding` needed for `select` elements in Firefox - * 4. Style - */ -.uk-form select, -.uk-form textarea, -.uk-form input:not([type]), -.uk-form input[type="text"], -.uk-form input[type="password"], -.uk-form input[type="datetime"], -.uk-form input[type="datetime-local"], -.uk-form input[type="date"], -.uk-form input[type="month"], -.uk-form input[type="time"], -.uk-form input[type="week"], -.uk-form input[type="number"], -.uk-form input[type="email"], -.uk-form input[type="url"], -.uk-form input[type="search"], -.uk-form input[type="tel"], -.uk-form input[type="color"] { - /* 1 */ - height: 30px; - /* 2 */ - max-width: 100%; - /* 3 */ - padding: 4px 6px; - /* 4 */ - border: 1px solid #ddd; - background: #fff; - color: #444; - -webkit-transition: all 0.2s linear; - -webkit-transition-property: border, background, color, box-shadow, padding; - transition: all 0.2s linear; - transition-property: border, background, color, box-shadow, padding; -} -.uk-form select:focus, -.uk-form textarea:focus, -.uk-form input:not([type]):focus, -.uk-form input[type="text"]:focus, -.uk-form input[type="password"]:focus, -.uk-form input[type="datetime"]:focus, -.uk-form input[type="datetime-local"]:focus, -.uk-form input[type="date"]:focus, -.uk-form input[type="month"]:focus, -.uk-form input[type="time"]:focus, -.uk-form input[type="week"]:focus, -.uk-form input[type="number"]:focus, -.uk-form input[type="email"]:focus, -.uk-form input[type="url"]:focus, -.uk-form input[type="search"]:focus, -.uk-form input[type="tel"]:focus, -.uk-form input[type="color"]:focus { - border-color: #99baca; - outline: 0; - background: #f5fbfe; - color: #444; -} -.uk-form select:disabled, -.uk-form textarea:disabled, -.uk-form input:not([type]):disabled, -.uk-form input[type="text"]:disabled, -.uk-form input[type="password"]:disabled, -.uk-form input[type="datetime"]:disabled, -.uk-form input[type="datetime-local"]:disabled, -.uk-form input[type="date"]:disabled, -.uk-form input[type="month"]:disabled, -.uk-form input[type="time"]:disabled, -.uk-form input[type="week"]:disabled, -.uk-form input[type="number"]:disabled, -.uk-form input[type="email"]:disabled, -.uk-form input[type="url"]:disabled, -.uk-form input[type="search"]:disabled, -.uk-form input[type="tel"]:disabled, -.uk-form input[type="color"]:disabled { - border-color: #ddd; - background-color: #f5f5f5; - color: #999; -} -/* - * Placeholder - */ -.uk-form :-ms-input-placeholder { - color: #999 !important; -} -.uk-form ::-moz-placeholder { - color: #999; -} -.uk-form ::-webkit-input-placeholder { - color: #999; -} -.uk-form :disabled:-ms-input-placeholder { - color: #999 !important; -} -.uk-form :disabled::-moz-placeholder { - color: #999; -} -.uk-form :disabled::-webkit-input-placeholder { - color: #999; -} -/* - * Legend - * 1. Behave like block element - * 2. Correct `color` not being inherited in IE 8/9/10/11. - * 3. Remove padding - * 4. `margin-bottom` is not working in Safari and Opera. - * Using `padding` and :after instead to create the border - * 5. Style - */ -.uk-form legend { - /* 1 */ - width: 100%; - /* 2 */ - border: 0; - /* 3 */ - padding: 0; - /* 4 */ - padding-bottom: 15px; - /* 5 */ - font-size: 18px; - line-height: 30px; -} -/* - * 1. Fixes IE9 - */ -.uk-form legend:after { - content: ""; - display: block; - border-bottom: 1px solid #ddd; - /* 1 */ - width: 100%; -} -/* Size modifiers - * Higher specificity needed to override defaults - ========================================================================== */ -select.uk-form-small, -textarea.uk-form-small, -input[type].uk-form-small, -input:not([type]).uk-form-small { - height: 25px; - padding: 3px 3px; - font-size: 12px; -} -select.uk-form-large, -textarea.uk-form-large, -input[type].uk-form-large, -input:not([type]).uk-form-large { - height: 40px; - padding: 8px 6px; - font-size: 16px; -} -/* Reset height - * Must be after size modifiers - ========================================================================== */ -.uk-form textarea, -.uk-form select[multiple], -.uk-form select[size] { - height: auto; -} -/* Validation states - * Using !important to keep the selector simple - ========================================================================== */ -/* - * Error state - */ -.uk-form-danger { - border-color: #dc8d99 !important; - background: #fff7f8 !important; - color: #d85030 !important; -} -/* - * Success state - */ -.uk-form-success { - border-color: #8ec73b !important; - background: #fafff2 !important; - color: #659f13 !important; -} -/* Style modifiers - * Using !important to keep the selector simple - ========================================================================== */ -/* - * Blank form - */ -.uk-form-blank { - border-color: transparent !important; - border-style: dashed !important; - background: none !important; -} -.uk-form-blank:focus { - border-color: #ddd !important; -} -/* Size sub-modifiers - ========================================================================== */ -/* - * Fixed widths - * Different widths for mini sized `input` and `select` elements - */ -input.uk-form-width-mini { - width: 40px; -} -select.uk-form-width-mini { - width: 65px; -} -.uk-form-width-small { - width: 130px; -} -.uk-form-width-medium { - width: 200px; -} -.uk-form-width-large { - width: 500px; -} -/* Sub-objects: `uk-form-row` - * Groups labels and controls in rows - ========================================================================== */ -/* - * Micro clearfix - * Needed for `uk-form-horizontal` modifier - */ -.uk-form-row:before, -.uk-form-row:after { - content: ""; - display: table; -} -.uk-form-row:after { - clear: both; -} -/* - * Vertical gutter - */ -.uk-form-row + .uk-form-row { - margin-top: 15px; -} -/* Help text - * Sub-object: `uk-form-help-inline`, `uk-form-help-block` - ========================================================================== */ -.uk-form-help-inline { - display: inline-block; - margin: 0 0 0 10px; -} -.uk-form-help-block { - margin: 5px 0 0 0; -} -/* Controls content - * Sub-object: `uk-form-controls`, `uk-form-controls-condensed` - ========================================================================== */ -/* - * Remove margins - */ -.uk-form-controls > :first-child { - margin-top: 0; -} -.uk-form-controls > :last-child { - margin-bottom: 0; -} -/* - * Group controls and text into blocks with a small spacing between blocks - */ -.uk-form-controls-condensed { - margin: 5px 0; -} -/* Modifier: `uk-form-stacked` - * Requires sub-object: `uk-form-label` - ========================================================================== */ -.uk-form-stacked .uk-form-label { - display: block; - margin-bottom: 5px; - font-weight: bold; -} -/* Modifier: `uk-form-horizontal` - * Requires sub-objects: `uk-form-label`, `uk-form-controls` - ========================================================================== */ -/* Tablet portrait and smaller */ -@media (max-width: 959px) { - /* Behave like `uk-form-stacked` */ - .uk-form-horizontal .uk-form-label { - display: block; - margin-bottom: 5px; - font-weight: bold; - } -} -/* Desktop and bigger */ -@media (min-width: 960px) { - .uk-form-horizontal .uk-form-label { - width: 200px; - margin-top: 5px; - float: left; - } - .uk-form-horizontal .uk-form-controls { - margin-left: 215px; - } - /* Better vertical alignment if controls are checkboxes and radio buttons with text */ - .uk-form-horizontal .uk-form-controls-text { - padding-top: 5px; - } -} -/* Sub-object: `uk-form-icon` - ========================================================================== */ -/* - * 1. Container width fits its content - * 2. Create position context - * 3. Prevent `inline-block` consequences - */ -.uk-form-icon { - /* 1 */ - display: inline-block; - /* 2 */ - position: relative; - /* 3 */ - max-width: 100%; -} -/* - * 1. Make form element clickable through icon - */ -.uk-form-icon > [class*='uk-icon-'] { - position: absolute; - top: 50%; - width: 30px; - margin-top: -7px; - font-size: 14px; - color: #999; - text-align: center; - /* 1 */ - pointer-events: none; -} -.uk-form-icon:not(.uk-form-icon-flip) > input { - padding-left: 30px !important; -} -/* - * Sub-modifier: `uk-form-icon-flip` - */ -.uk-form-icon-flip > [class*='uk-icon-'] { - right: 0; -} -.uk-form-icon-flip > input { - padding-right: 30px !important; -} -/* ======================================================================== - Component: Button - ========================================================================== */ -/* - * Removes inner padding and border in Firefox 4+. - */ -.uk-button::-moz-focus-inner { - border: 0; - padding: 0; -} -/* - * 1. Correct inability to style clickable `input` types in iOS. - * 2. Remove margins in Chrome, Safari and Opera. - * 3. Remove borders for `button`. - * 4. Address `overflow` set to `hidden` in IE 8/9/10/11. - * 5. Correct `font` properties and `color` not being inherited for `button`. - * 6. Address inconsistent `text-transform` inheritance which is only inherit in Firefox and IE - * 7. Style - * 8. `line-height` is used to create a height - * 9. `min-height` is necessary for `input` elements in Firefox and Opera because `line-height` is not working. - * 10. Reset button group whitespace hack - * 11. Required for `a`. - */ -.uk-button { - /* 1 */ - -webkit-appearance: none; - /* 2 */ - margin: 0; - /* 3 */ - border: none; - /* 4 */ - overflow: visible; - /* 5 */ - font: inherit; - color: #444; - /* 6 */ - text-transform: none; - /* 7 */ - display: inline-block; - box-sizing: border-box; - padding: 0 12px; - background: #eee; - vertical-align: middle; - /* 8 */ - line-height: 30px; - /* 9 */ - min-height: 30px; - /* 10 */ - font-size: 1rem; - /* 11 */ - text-decoration: none; - text-align: center; -} -.uk-button:not(:disabled) { - cursor: pointer; -} -/* - * Hover - * 1. Apply hover style also to focus state - * 2. Remove default focus style - * 3. Required for `a` elements - */ -.uk-button:hover, -.uk-button:focus { - background-color: #f5f5f5; - color: #444; - /* 2 */ - outline: none; - /* 3 */ - text-decoration: none; -} -/* Active */ -.uk-button:active, -.uk-button.uk-active { - background-color: #ddd; - color: #444; -} -/* Color modifiers - ========================================================================== */ -/* - * Modifier: `uk-button-primary` - */ -.uk-button-primary { - background-color: #00a8e6; - color: #fff; -} -/* Hover */ -.uk-button-primary:hover, -.uk-button-primary:focus { - background-color: #35b3ee; - color: #fff; -} -/* Active */ -.uk-button-primary:active, -.uk-button-primary.uk-active { - background-color: #0091ca; - color: #fff; -} -/* - * Modifier: `uk-button-success` - */ -.uk-button-success { - background-color: #8cc14c; - color: #fff; -} -/* Hover */ -.uk-button-success:hover, -.uk-button-success:focus { - background-color: #8ec73b; - color: #fff; -} -/* Active */ -.uk-button-success:active, -.uk-button-success.uk-active { - background-color: #72ae41; - color: #fff; -} -/* - * Modifier: `uk-button-danger` - */ -.uk-button-danger { - background-color: #da314b; - color: #fff; -} -/* Hover */ -.uk-button-danger:hover, -.uk-button-danger:focus { - background-color: #e4354f; - color: #fff; -} -/* Active */ -.uk-button-danger:active, -.uk-button-danger.uk-active { - background-color: #c91032; - color: #fff; -} -/* Disabled state - * Overrides also the color modifiers - ========================================================================== */ -/* Equal for all button types */ -.uk-button:disabled { - background-color: #f5f5f5; - color: #999; -} -/* Modifier: `uk-button-link` - ========================================================================== */ -/* Reset */ -.uk-button-link, -.uk-button-link:hover, -.uk-button-link:focus, -.uk-button-link:active, -.uk-button-link.uk-active, -.uk-button-link:disabled { - border-color: transparent; - background: none; -} -/* Color */ -.uk-button-link { - color: #07D; -} -.uk-button-link:hover, -.uk-button-link:focus, -.uk-button-link:active, -.uk-button-link.uk-active { - color: #059; - text-decoration: underline; -} -.uk-button-link:disabled { - color: #999; -} -/* Focus */ -.uk-button-link:focus { - outline: 1px dotted; -} -/* Size modifiers - ========================================================================== */ -.uk-button-mini { - min-height: 20px; - padding: 0 6px; - line-height: 20px; - font-size: 11px; -} -.uk-button-small { - min-height: 25px; - padding: 0 10px; - line-height: 25px; - font-size: 12px; -} -.uk-button-large { - min-height: 40px; - padding: 0 15px; - line-height: 40px; - font-size: 16px; -} -/* Sub-object `uk-button-group` - ========================================================================== */ -/* - * 1. Behave like buttons - * 2. Create position context for dropdowns - * 3. Remove whitespace between child elements when using `inline-block` - * 4. Prevent buttons from wrapping - * 5. Remove whitespace between child elements when using `inline-block` - */ -.uk-button-group { - /* 1 */ - display: inline-block; - vertical-align: middle; - /* 2 */ - position: relative; - /* 3 */ - font-size: 0.001px; - /* 4 */ - white-space: nowrap; -} -.uk-button-group > * { - display: inline-block; -} -/* 5 */ -.uk-button-group .uk-button { - vertical-align: top; -} -/* Sub-object: `uk-button-dropdown` - ========================================================================== */ -/* - * 1. Behave like buttons - * 2. Create position context for dropdowns - */ -.uk-button-dropdown { - /* 1 */ - display: inline-block; - vertical-align: middle; - /* 2 */ - position: relative; -} -/* ======================================================================== - Component: Icon - ========================================================================== */ -@font-face { - font-family: 'FontAwesome'; - src: url("../fonts/fontawesome-webfont.woff2") format('woff2'), url("../fonts/fontawesome-webfont.woff") format("woff"), url("../fonts/fontawesome-webfont.ttf") format("truetype"); - font-weight: normal; - font-style: normal; -} -/* - * 1. Allow margin - * 2. Prevent inherit font style - * 4. Correct line-height - * 5. Better font rendering - * 6. Remove `text-decoration` for anchors - */ -[class*='uk-icon-'] { - font-family: FontAwesome; - /* 1 */ - display: inline-block; - /* 2 */ - font-weight: normal; - font-style: normal; - /* 4 */ - line-height: 1; - /* 5 */ - -webkit-font-smoothing: antialiased; - -moz-osx-font-smoothing: grayscale; -} -/* 6 */ -[class*='uk-icon-'], -[class*='uk-icon-']:hover, -[class*='uk-icon-']:focus { - text-decoration: none; -} -/* Size modifiers - ========================================================================== */ -.uk-icon-small { - font-size: 150%; - vertical-align: -10%; -} -.uk-icon-medium { - font-size: 200%; - vertical-align: -16%; -} -.uk-icon-large { - font-size: 250%; - vertical-align: -22%; -} -/* Modifier: `uk-icon-justify` - ========================================================================== */ -.uk-icon-justify { - width: 1em; - text-align: center; -} -/* Modifier: `uk-icon-spin` - ========================================================================== */ -.uk-icon-spin { - display: inline-block; - -webkit-animation: uk-rotate 2s infinite linear; - animation: uk-rotate 2s infinite linear; -} -/* Modifier: `uk-icon-hover` - ========================================================================== */ -.uk-icon-hover { - color: #999; -} -/* - * Hover - */ -.uk-icon-hover:hover { - color: #444; -} -/* Modifier: `uk-icon-button` - ========================================================================== */ -.uk-icon-button { - box-sizing: border-box; - display: inline-block; - width: 35px; - height: 35px; - border-radius: 100%; - background: #eee; - line-height: 35px; - color: #444; - font-size: 18px; - text-align: center; -} -/* - * Hover - * 1. Apply hover style also to focus state - * 2. Remove default focus style - */ -.uk-icon-button:hover, -.uk-icon-button:focus { - background-color: #f5f5f5; - color: #444; - /* 2 */ - outline: none; -} -/* Active */ -.uk-icon-button:active { - background-color: #ddd; - color: #444; -} -/* Icon mapping - ========================================================================== */ -.uk-icon-glass:before { - content: "\f000"; -} -.uk-icon-music:before { - content: "\f001"; -} -.uk-icon-search:before { - content: "\f002"; -} -.uk-icon-envelope-o:before { - content: "\f003"; -} -.uk-icon-heart:before { - content: "\f004"; -} -.uk-icon-star:before { - content: "\f005"; -} -.uk-icon-star-o:before { - content: "\f006"; -} -.uk-icon-user:before { - content: "\f007"; -} -.uk-icon-film:before { - content: "\f008"; -} -.uk-icon-th-large:before { - content: "\f009"; -} -.uk-icon-th:before { - content: "\f00a"; -} -.uk-icon-th-list:before { - content: "\f00b"; -} -.uk-icon-check:before { - content: "\f00c"; -} -.uk-icon-remove:before, -.uk-icon-close:before, -.uk-icon-times:before { - content: "\f00d"; -} -.uk-icon-search-plus:before { - content: "\f00e"; -} -.uk-icon-search-minus:before { - content: "\f010"; -} -.uk-icon-power-off:before { - content: "\f011"; -} -.uk-icon-signal:before { - content: "\f012"; -} -.uk-icon-gear:before, -.uk-icon-cog:before { - content: "\f013"; -} -.uk-icon-trash-o:before { - content: "\f014"; -} -.uk-icon-home:before { - content: "\f015"; -} -.uk-icon-file-o:before { - content: "\f016"; -} -.uk-icon-clock-o:before { - content: "\f017"; -} -.uk-icon-road:before { - content: "\f018"; -} -.uk-icon-download:before { - content: "\f019"; -} -.uk-icon-arrow-circle-o-down:before { - content: "\f01a"; -} -.uk-icon-arrow-circle-o-up:before { - content: "\f01b"; -} -.uk-icon-inbox:before { - content: "\f01c"; -} -.uk-icon-play-circle-o:before { - content: "\f01d"; -} -.uk-icon-rotate-right:before, -.uk-icon-repeat:before { - content: "\f01e"; -} -.uk-icon-refresh:before { - content: "\f021"; -} -.uk-icon-list-alt:before { - content: "\f022"; -} -.uk-icon-lock:before { - content: "\f023"; -} -.uk-icon-flag:before { - content: "\f024"; -} -.uk-icon-headphones:before { - content: "\f025"; -} -.uk-icon-volume-off:before { - content: "\f026"; -} -.uk-icon-volume-down:before { - content: "\f027"; -} -.uk-icon-volume-up:before { - content: "\f028"; -} -.uk-icon-qrcode:before { - content: "\f029"; -} -.uk-icon-barcode:before { - content: "\f02a"; -} -.uk-icon-tag:before { - content: "\f02b"; -} -.uk-icon-tags:before { - content: "\f02c"; -} -.uk-icon-book:before { - content: "\f02d"; -} -.uk-icon-bookmark:before { - content: "\f02e"; -} -.uk-icon-print:before { - content: "\f02f"; -} -.uk-icon-camera:before { - content: "\f030"; -} -.uk-icon-font:before { - content: "\f031"; -} -.uk-icon-bold:before { - content: "\f032"; -} -.uk-icon-italic:before { - content: "\f033"; -} -.uk-icon-text-height:before { - content: "\f034"; -} -.uk-icon-text-width:before { - content: "\f035"; -} -.uk-icon-align-left:before { - content: "\f036"; -} -.uk-icon-align-center:before { - content: "\f037"; -} -.uk-icon-align-right:before { - content: "\f038"; -} -.uk-icon-align-justify:before { - content: "\f039"; -} -.uk-icon-list:before { - content: "\f03a"; -} -.uk-icon-dedent:before, -.uk-icon-outdent:before { - content: "\f03b"; -} -.uk-icon-indent:before { - content: "\f03c"; -} -.uk-icon-video-camera:before { - content: "\f03d"; -} -.uk-icon-photo:before, -.uk-icon-image:before, -.uk-icon-picture-o:before { - content: "\f03e"; -} -.uk-icon-pencil:before { - content: "\f040"; -} -.uk-icon-map-marker:before { - content: "\f041"; -} -.uk-icon-adjust:before { - content: "\f042"; -} -.uk-icon-tint:before { - content: "\f043"; -} -.uk-icon-edit:before, -.uk-icon-pencil-square-o:before { - content: "\f044"; -} -.uk-icon-share-square-o:before { - content: "\f045"; -} -.uk-icon-check-square-o:before { - content: "\f046"; -} -.uk-icon-arrows:before { - content: "\f047"; -} -.uk-icon-step-backward:before { - content: "\f048"; -} -.uk-icon-fast-backward:before { - content: "\f049"; -} -.uk-icon-backward:before { - content: "\f04a"; -} -.uk-icon-play:before { - content: "\f04b"; -} -.uk-icon-pause:before { - content: "\f04c"; -} -.uk-icon-stop:before { - content: "\f04d"; -} -.uk-icon-forward:before { - content: "\f04e"; -} -.uk-icon-fast-forward:before { - content: "\f050"; -} -.uk-icon-step-forward:before { - content: "\f051"; -} -.uk-icon-eject:before { - content: "\f052"; -} -.uk-icon-chevron-left:before { - content: "\f053"; -} -.uk-icon-chevron-right:before { - content: "\f054"; -} -.uk-icon-plus-circle:before { - content: "\f055"; -} -.uk-icon-minus-circle:before { - content: "\f056"; -} -.uk-icon-times-circle:before { - content: "\f057"; -} -.uk-icon-check-circle:before { - content: "\f058"; -} -.uk-icon-question-circle:before { - content: "\f059"; -} -.uk-icon-info-circle:before { - content: "\f05a"; -} -.uk-icon-crosshairs:before { - content: "\f05b"; -} -.uk-icon-times-circle-o:before { - content: "\f05c"; -} -.uk-icon-check-circle-o:before { - content: "\f05d"; -} -.uk-icon-ban:before { - content: "\f05e"; -} -.uk-icon-arrow-left:before { - content: "\f060"; -} -.uk-icon-arrow-right:before { - content: "\f061"; -} -.uk-icon-arrow-up:before { - content: "\f062"; -} -.uk-icon-arrow-down:before { - content: "\f063"; -} -.uk-icon-mail-forward:before, -.uk-icon-share:before { - content: "\f064"; -} -.uk-icon-expand:before { - content: "\f065"; -} -.uk-icon-compress:before { - content: "\f066"; -} -.uk-icon-plus:before { - content: "\f067"; -} -.uk-icon-minus:before { - content: "\f068"; -} -.uk-icon-asterisk:before { - content: "\f069"; -} -.uk-icon-exclamation-circle:before { - content: "\f06a"; -} -.uk-icon-gift:before { - content: "\f06b"; -} -.uk-icon-leaf:before { - content: "\f06c"; -} -.uk-icon-fire:before { - content: "\f06d"; -} -.uk-icon-eye:before { - content: "\f06e"; -} -.uk-icon-eye-slash:before { - content: "\f070"; -} -.uk-icon-warning:before, -.uk-icon-exclamation-triangle:before { - content: "\f071"; -} -.uk-icon-plane:before { - content: "\f072"; -} -.uk-icon-calendar:before { - content: "\f073"; -} -.uk-icon-random:before { - content: "\f074"; -} -.uk-icon-comment:before { - content: "\f075"; -} -.uk-icon-magnet:before { - content: "\f076"; -} -.uk-icon-chevron-up:before { - content: "\f077"; -} -.uk-icon-chevron-down:before { - content: "\f078"; -} -.uk-icon-retweet:before { - content: "\f079"; -} -.uk-icon-shopping-cart:before { - content: "\f07a"; -} -.uk-icon-folder:before { - content: "\f07b"; -} -.uk-icon-folder-open:before { - content: "\f07c"; -} -.uk-icon-arrows-v:before { - content: "\f07d"; -} -.uk-icon-arrows-h:before { - content: "\f07e"; -} -.uk-icon-bar-chart-o:before, -.uk-icon-bar-chart:before { - content: "\f080"; -} -.uk-icon-twitter-square:before { - content: "\f081"; -} -.uk-icon-facebook-square:before { - content: "\f082"; -} -.uk-icon-camera-retro:before { - content: "\f083"; -} -.uk-icon-key:before { - content: "\f084"; -} -.uk-icon-gears:before, -.uk-icon-cogs:before { - content: "\f085"; -} -.uk-icon-comments:before { - content: "\f086"; -} -.uk-icon-thumbs-o-up:before { - content: "\f087"; -} -.uk-icon-thumbs-o-down:before { - content: "\f088"; -} -.uk-icon-star-half:before { - content: "\f089"; -} -.uk-icon-heart-o:before { - content: "\f08a"; -} -.uk-icon-sign-out:before { - content: "\f08b"; -} -.uk-icon-linkedin-square:before { - content: "\f08c"; -} -.uk-icon-thumb-tack:before { - content: "\f08d"; -} -.uk-icon-external-link:before { - content: "\f08e"; -} -.uk-icon-sign-in:before { - content: "\f090"; -} -.uk-icon-trophy:before { - content: "\f091"; -} -.uk-icon-github-square:before { - content: "\f092"; -} -.uk-icon-upload:before { - content: "\f093"; -} -.uk-icon-lemon-o:before { - content: "\f094"; -} -.uk-icon-phone:before { - content: "\f095"; -} -.uk-icon-square-o:before { - content: "\f096"; -} -.uk-icon-bookmark-o:before { - content: "\f097"; -} -.uk-icon-phone-square:before { - content: "\f098"; -} -.uk-icon-twitter:before { - content: "\f099"; -} -.uk-icon-facebook-f:before, -.uk-icon-facebook:before { - content: "\f09a"; -} -.uk-icon-github:before { - content: "\f09b"; -} -.uk-icon-unlock:before { - content: "\f09c"; -} -.uk-icon-credit-card:before { - content: "\f09d"; -} -.uk-icon-rss:before { - content: "\f09e"; -} -.uk-icon-hdd-o:before { - content: "\f0a0"; -} -.uk-icon-bullhorn:before { - content: "\f0a1"; -} -.uk-icon-bell:before { - content: "\f0f3"; -} -.uk-icon-certificate:before { - content: "\f0a3"; -} -.uk-icon-hand-o-right:before { - content: "\f0a4"; -} -.uk-icon-hand-o-left:before { - content: "\f0a5"; -} -.uk-icon-hand-o-up:before { - content: "\f0a6"; -} -.uk-icon-hand-o-down:before { - content: "\f0a7"; -} -.uk-icon-arrow-circle-left:before { - content: "\f0a8"; -} -.uk-icon-arrow-circle-right:before { - content: "\f0a9"; -} -.uk-icon-arrow-circle-up:before { - content: "\f0aa"; -} -.uk-icon-arrow-circle-down:before { - content: "\f0ab"; -} -.uk-icon-globe:before { - content: "\f0ac"; -} -.uk-icon-wrench:before { - content: "\f0ad"; -} -.uk-icon-tasks:before { - content: "\f0ae"; -} -.uk-icon-filter:before { - content: "\f0b0"; -} -.uk-icon-briefcase:before { - content: "\f0b1"; -} -.uk-icon-arrows-alt:before { - content: "\f0b2"; -} -.uk-icon-group:before, -.uk-icon-users:before { - content: "\f0c0"; -} -.uk-icon-chain:before, -.uk-icon-link:before { - content: "\f0c1"; -} -.uk-icon-cloud:before { - content: "\f0c2"; -} -.uk-icon-flask:before { - content: "\f0c3"; -} -.uk-icon-cut:before, -.uk-icon-scissors:before { - content: "\f0c4"; -} -.uk-icon-copy:before, -.uk-icon-files-o:before { - content: "\f0c5"; -} -.uk-icon-paperclip:before { - content: "\f0c6"; -} -.uk-icon-save:before, -.uk-icon-floppy-o:before { - content: "\f0c7"; -} -.uk-icon-square:before { - content: "\f0c8"; -} -.uk-icon-navicon:before, -.uk-icon-reorder:before, -.uk-icon-bars:before { - content: "\f0c9"; -} -.uk-icon-list-ul:before { - content: "\f0ca"; -} -.uk-icon-list-ol:before { - content: "\f0cb"; -} -.uk-icon-strikethrough:before { - content: "\f0cc"; -} -.uk-icon-underline:before { - content: "\f0cd"; -} -.uk-icon-table:before { - content: "\f0ce"; -} -.uk-icon-magic:before { - content: "\f0d0"; -} -.uk-icon-truck:before { - content: "\f0d1"; -} -.uk-icon-pinterest:before { - content: "\f0d2"; -} -.uk-icon-pinterest-square:before { - content: "\f0d3"; -} -.uk-icon-google-plus-square:before { - content: "\f0d4"; -} -.uk-icon-google-plus:before { - content: "\f0d5"; -} -.uk-icon-money:before { - content: "\f0d6"; -} -.uk-icon-caret-down:before { - content: "\f0d7"; -} -.uk-icon-caret-up:before { - content: "\f0d8"; -} -.uk-icon-caret-left:before { - content: "\f0d9"; -} -.uk-icon-caret-right:before { - content: "\f0da"; -} -.uk-icon-columns:before { - content: "\f0db"; -} -.uk-icon-unsorted:before, -.uk-icon-sort:before { - content: "\f0dc"; -} -.uk-icon-sort-down:before, -.uk-icon-sort-desc:before { - content: "\f0dd"; -} -.uk-icon-sort-up:before, -.uk-icon-sort-asc:before { - content: "\f0de"; -} -.uk-icon-envelope:before { - content: "\f0e0"; -} -.uk-icon-linkedin:before { - content: "\f0e1"; -} -.uk-icon-rotate-left:before, -.uk-icon-undo:before { - content: "\f0e2"; -} -.uk-icon-legal:before, -.uk-icon-gavel:before { - content: "\f0e3"; -} -.uk-icon-dashboard:before, -.uk-icon-tachometer:before { - content: "\f0e4"; -} -.uk-icon-comment-o:before { - content: "\f0e5"; -} -.uk-icon-comments-o:before { - content: "\f0e6"; -} -.uk-icon-flash:before, -.uk-icon-bolt:before { - content: "\f0e7"; -} -.uk-icon-sitemap:before { - content: "\f0e8"; -} -.uk-icon-umbrella:before { - content: "\f0e9"; -} -.uk-icon-paste:before, -.uk-icon-clipboard:before { - content: "\f0ea"; -} -.uk-icon-lightbulb-o:before { - content: "\f0eb"; -} -.uk-icon-exchange:before { - content: "\f0ec"; -} -.uk-icon-cloud-download:before { - content: "\f0ed"; -} -.uk-icon-cloud-upload:before { - content: "\f0ee"; -} -.uk-icon-user-md:before { - content: "\f0f0"; -} -.uk-icon-stethoscope:before { - content: "\f0f1"; -} -.uk-icon-suitcase:before { - content: "\f0f2"; -} -.uk-icon-bell-o:before { - content: "\f0a2"; -} -.uk-icon-coffee:before { - content: "\f0f4"; -} -.uk-icon-cutlery:before { - content: "\f0f5"; -} -.uk-icon-file-text-o:before { - content: "\f0f6"; -} -.uk-icon-building-o:before { - content: "\f0f7"; -} -.uk-icon-hospital-o:before { - content: "\f0f8"; -} -.uk-icon-ambulance:before { - content: "\f0f9"; -} -.uk-icon-medkit:before { - content: "\f0fa"; -} -.uk-icon-fighter-jet:before { - content: "\f0fb"; -} -.uk-icon-beer:before { - content: "\f0fc"; -} -.uk-icon-h-square:before { - content: "\f0fd"; -} -.uk-icon-plus-square:before { - content: "\f0fe"; -} -.uk-icon-angle-double-left:before { - content: "\f100"; -} -.uk-icon-angle-double-right:before { - content: "\f101"; -} -.uk-icon-angle-double-up:before { - content: "\f102"; -} -.uk-icon-angle-double-down:before { - content: "\f103"; -} -.uk-icon-angle-left:before { - content: "\f104"; -} -.uk-icon-angle-right:before { - content: "\f105"; -} -.uk-icon-angle-up:before { - content: "\f106"; -} -.uk-icon-angle-down:before { - content: "\f107"; -} -.uk-icon-desktop:before { - content: "\f108"; -} -.uk-icon-laptop:before { - content: "\f109"; -} -.uk-icon-tablet:before { - content: "\f10a"; -} -.uk-icon-mobile-phone:before, -.uk-icon-mobile:before { - content: "\f10b"; -} -.uk-icon-circle-o:before { - content: "\f10c"; -} -.uk-icon-quote-left:before { - content: "\f10d"; -} -.uk-icon-quote-right:before { - content: "\f10e"; -} -.uk-icon-spinner:before { - content: "\f110"; -} -.uk-icon-circle:before { - content: "\f111"; -} -.uk-icon-mail-reply:before, -.uk-icon-reply:before { - content: "\f112"; -} -.uk-icon-github-alt:before { - content: "\f113"; -} -.uk-icon-folder-o:before { - content: "\f114"; -} -.uk-icon-folder-open-o:before { - content: "\f115"; -} -.uk-icon-smile-o:before { - content: "\f118"; -} -.uk-icon-frown-o:before { - content: "\f119"; -} -.uk-icon-meh-o:before { - content: "\f11a"; -} -.uk-icon-gamepad:before { - content: "\f11b"; -} -.uk-icon-keyboard-o:before { - content: "\f11c"; -} -.uk-icon-flag-o:before { - content: "\f11d"; -} -.uk-icon-flag-checkered:before { - content: "\f11e"; -} -.uk-icon-terminal:before { - content: "\f120"; -} -.uk-icon-code:before { - content: "\f121"; -} -.uk-icon-mail-reply-all:before, -.uk-icon-reply-all:before { - content: "\f122"; -} -.uk-icon-star-half-empty:before, -.uk-icon-star-half-full:before, -.uk-icon-star-half-o:before { - content: "\f123"; -} -.uk-icon-location-arrow:before { - content: "\f124"; -} -.uk-icon-crop:before { - content: "\f125"; -} -.uk-icon-code-fork:before { - content: "\f126"; -} -.uk-icon-unlink:before, -.uk-icon-chain-broken:before { - content: "\f127"; -} -.uk-icon-question:before { - content: "\f128"; -} -.uk-icon-info:before { - content: "\f129"; -} -.uk-icon-exclamation:before { - content: "\f12a"; -} -.uk-icon-superscript:before { - content: "\f12b"; -} -.uk-icon-subscript:before { - content: "\f12c"; -} -.uk-icon-eraser:before { - content: "\f12d"; -} -.uk-icon-puzzle-piece:before { - content: "\f12e"; -} -.uk-icon-microphone:before { - content: "\f130"; -} -.uk-icon-microphone-slash:before { - content: "\f131"; -} -.uk-icon-shield:before { - content: "\f132"; -} -.uk-icon-calendar-o:before { - content: "\f133"; -} -.uk-icon-fire-extinguisher:before { - content: "\f134"; -} -.uk-icon-rocket:before { - content: "\f135"; -} -.uk-icon-maxcdn:before { - content: "\f136"; -} -.uk-icon-chevron-circle-left:before { - content: "\f137"; -} -.uk-icon-chevron-circle-right:before { - content: "\f138"; -} -.uk-icon-chevron-circle-up:before { - content: "\f139"; -} -.uk-icon-chevron-circle-down:before { - content: "\f13a"; -} -.uk-icon-html5:before { - content: "\f13b"; -} -.uk-icon-css3:before { - content: "\f13c"; -} -.uk-icon-anchor:before { - content: "\f13d"; -} -.uk-icon-unlock-alt:before { - content: "\f13e"; -} -.uk-icon-bullseye:before { - content: "\f140"; -} -.uk-icon-ellipsis-h:before { - content: "\f141"; -} -.uk-icon-ellipsis-v:before { - content: "\f142"; -} -.uk-icon-rss-square:before { - content: "\f143"; -} -.uk-icon-play-circle:before { - content: "\f144"; -} -.uk-icon-ticket:before { - content: "\f145"; -} -.uk-icon-minus-square:before { - content: "\f146"; -} -.uk-icon-minus-square-o:before { - content: "\f147"; -} -.uk-icon-level-up:before { - content: "\f148"; -} -.uk-icon-level-down:before { - content: "\f149"; -} -.uk-icon-check-square:before { - content: "\f14a"; -} -.uk-icon-pencil-square:before { - content: "\f14b"; -} -.uk-icon-external-link-square:before { - content: "\f14c"; -} -.uk-icon-share-square:before { - content: "\f14d"; -} -.uk-icon-compass:before { - content: "\f14e"; -} -.uk-icon-toggle-down:before, -.uk-icon-caret-square-o-down:before { - content: "\f150"; -} -.uk-icon-toggle-up:before, -.uk-icon-caret-square-o-up:before { - content: "\f151"; -} -.uk-icon-toggle-right:before, -.uk-icon-caret-square-o-right:before { - content: "\f152"; -} -.uk-icon-euro:before, -.uk-icon-eur:before { - content: "\f153"; -} -.uk-icon-gbp:before { - content: "\f154"; -} -.uk-icon-dollar:before, -.uk-icon-usd:before { - content: "\f155"; -} -.uk-icon-rupee:before, -.uk-icon-inr:before { - content: "\f156"; -} -.uk-icon-cny:before, -.uk-icon-rmb:before, -.uk-icon-yen:before, -.uk-icon-jpy:before { - content: "\f157"; -} -.uk-icon-ruble:before, -.uk-icon-rouble:before, -.uk-icon-rub:before { - content: "\f158"; -} -.uk-icon-won:before, -.uk-icon-krw:before { - content: "\f159"; -} -.uk-icon-bitcoin:before, -.uk-icon-btc:before { - content: "\f15a"; -} -.uk-icon-file:before { - content: "\f15b"; -} -.uk-icon-file-text:before { - content: "\f15c"; -} -.uk-icon-sort-alpha-asc:before { - content: "\f15d"; -} -.uk-icon-sort-alpha-desc:before { - content: "\f15e"; -} -.uk-icon-sort-amount-asc:before { - content: "\f160"; -} -.uk-icon-sort-amount-desc:before { - content: "\f161"; -} -.uk-icon-sort-numeric-asc:before { - content: "\f162"; -} -.uk-icon-sort-numeric-desc:before { - content: "\f163"; -} -.uk-icon-thumbs-up:before { - content: "\f164"; -} -.uk-icon-thumbs-down:before { - content: "\f165"; -} -.uk-icon-youtube-square:before { - content: "\f166"; -} -.uk-icon-youtube:before { - content: "\f167"; -} -.uk-icon-xing:before { - content: "\f168"; -} -.uk-icon-xing-square:before { - content: "\f169"; -} -.uk-icon-youtube-play:before { - content: "\f16a"; -} -.uk-icon-dropbox:before { - content: "\f16b"; -} -.uk-icon-stack-overflow:before { - content: "\f16c"; -} -.uk-icon-instagram:before { - content: "\f16d"; -} -.uk-icon-flickr:before { - content: "\f16e"; -} -.uk-icon-adn:before { - content: "\f170"; -} -.uk-icon-bitbucket:before { - content: "\f171"; -} -.uk-icon-bitbucket-square:before { - content: "\f172"; -} -.uk-icon-tumblr:before { - content: "\f173"; -} -.uk-icon-tumblr-square:before { - content: "\f174"; -} -.uk-icon-long-arrow-down:before { - content: "\f175"; -} -.uk-icon-long-arrow-up:before { - content: "\f176"; -} -.uk-icon-long-arrow-left:before { - content: "\f177"; -} -.uk-icon-long-arrow-right:before { - content: "\f178"; -} -.uk-icon-apple:before { - content: "\f179"; -} -.uk-icon-windows:before { - content: "\f17a"; -} -.uk-icon-android:before { - content: "\f17b"; -} -.uk-icon-linux:before { - content: "\f17c"; -} -.uk-icon-dribbble:before { - content: "\f17d"; -} -.uk-icon-skype:before { - content: "\f17e"; -} -.uk-icon-foursquare:before { - content: "\f180"; -} -.uk-icon-trello:before { - content: "\f181"; -} -.uk-icon-female:before { - content: "\f182"; -} -.uk-icon-male:before { - content: "\f183"; -} -.uk-icon-gittip:before, -.uk-icon-gratipay:before { - content: "\f184"; -} -.uk-icon-sun-o:before { - content: "\f185"; -} -.uk-icon-moon-o:before { - content: "\f186"; -} -.uk-icon-archive:before { - content: "\f187"; -} -.uk-icon-bug:before { - content: "\f188"; -} -.uk-icon-vk:before { - content: "\f189"; -} -.uk-icon-weibo:before { - content: "\f18a"; -} -.uk-icon-renren:before { - content: "\f18b"; -} -.uk-icon-pagelines:before { - content: "\f18c"; -} -.uk-icon-stack-exchange:before { - content: "\f18d"; -} -.uk-icon-arrow-circle-o-right:before { - content: "\f18e"; -} -.uk-icon-arrow-circle-o-left:before { - content: "\f190"; -} -.uk-icon-toggle-left:before, -.uk-icon-caret-square-o-left:before { - content: "\f191"; -} -.uk-icon-dot-circle-o:before { - content: "\f192"; -} -.uk-icon-wheelchair:before { - content: "\f193"; -} -.uk-icon-vimeo-square:before { - content: "\f194"; -} -.uk-icon-turkish-lira:before, -.uk-icon-try:before { - content: "\f195"; -} -.uk-icon-plus-square-o:before { - content: "\f196"; -} -.uk-icon-space-shuttle:before { - content: "\f197"; -} -.uk-icon-slack:before { - content: "\f198"; -} -.uk-icon-envelope-square:before { - content: "\f199"; -} -.uk-icon-wordpress:before { - content: "\f19a"; -} -.uk-icon-openid:before { - content: "\f19b"; -} -.uk-icon-institution:before, -.uk-icon-bank:before, -.uk-icon-university:before { - content: "\f19c"; -} -.uk-icon-mortar-board:before, -.uk-icon-graduation-cap:before { - content: "\f19d"; -} -.uk-icon-yahoo:before { - content: "\f19e"; -} -.uk-icon-google:before { - content: "\f1a0"; -} -.uk-icon-reddit:before { - content: "\f1a1"; -} -.uk-icon-reddit-square:before { - content: "\f1a2"; -} -.uk-icon-stumbleupon-circle:before { - content: "\f1a3"; -} -.uk-icon-stumbleupon:before { - content: "\f1a4"; -} -.uk-icon-delicious:before { - content: "\f1a5"; -} -.uk-icon-digg:before { - content: "\f1a6"; -} -.uk-icon-pied-piper:before { - content: "\f1a7"; -} -.uk-icon-pied-piper-alt:before { - content: "\f1a8"; -} -.uk-icon-drupal:before { - content: "\f1a9"; -} -.uk-icon-joomla:before { - content: "\f1aa"; -} -.uk-icon-language:before { - content: "\f1ab"; -} -.uk-icon-fax:before { - content: "\f1ac"; -} -.uk-icon-building:before { - content: "\f1ad"; -} -.uk-icon-child:before { - content: "\f1ae"; -} -.uk-icon-paw:before { - content: "\f1b0"; -} -.uk-icon-spoon:before { - content: "\f1b1"; -} -.uk-icon-cube:before { - content: "\f1b2"; -} -.uk-icon-cubes:before { - content: "\f1b3"; -} -.uk-icon-behance:before { - content: "\f1b4"; -} -.uk-icon-behance-square:before { - content: "\f1b5"; -} -.uk-icon-steam:before { - content: "\f1b6"; -} -.uk-icon-steam-square:before { - content: "\f1b7"; -} -.uk-icon-recycle:before { - content: "\f1b8"; -} -.uk-icon-automobile:before, -.uk-icon-car:before { - content: "\f1b9"; -} -.uk-icon-cab:before, -.uk-icon-taxi:before { - content: "\f1ba"; -} -.uk-icon-tree:before { - content: "\f1bb"; -} -.uk-icon-spotify:before { - content: "\f1bc"; -} -.uk-icon-deviantart:before { - content: "\f1bd"; -} -.uk-icon-soundcloud:before { - content: "\f1be"; -} -.uk-icon-database:before { - content: "\f1c0"; -} -.uk-icon-file-pdf-o:before { - content: "\f1c1"; -} -.uk-icon-file-word-o:before { - content: "\f1c2"; -} -.uk-icon-file-excel-o:before { - content: "\f1c3"; -} -.uk-icon-file-powerpoint-o:before { - content: "\f1c4"; -} -.uk-icon-file-photo-o:before, -.uk-icon-file-picture-o:before, -.uk-icon-file-image-o:before { - content: "\f1c5"; -} -.uk-icon-file-zip-o:before, -.uk-icon-file-archive-o:before { - content: "\f1c6"; -} -.uk-icon-file-sound-o:before, -.uk-icon-file-audio-o:before { - content: "\f1c7"; -} -.uk-icon-file-movie-o:before, -.uk-icon-file-video-o:before { - content: "\f1c8"; -} -.uk-icon-file-code-o:before { - content: "\f1c9"; -} -.uk-icon-vine:before { - content: "\f1ca"; -} -.uk-icon-codepen:before { - content: "\f1cb"; -} -.uk-icon-jsfiddle:before { - content: "\f1cc"; -} -.uk-icon-life-bouy:before, -.uk-icon-life-buoy:before, -.uk-icon-life-saver:before, -.uk-icon-support:before, -.uk-icon-life-ring:before { - content: "\f1cd"; -} -.uk-icon-circle-o-notch:before { - content: "\f1ce"; -} -.uk-icon-ra:before, -.uk-icon-rebel:before { - content: "\f1d0"; -} -.uk-icon-ge:before, -.uk-icon-empire:before { - content: "\f1d1"; -} -.uk-icon-git-square:before { - content: "\f1d2"; -} -.uk-icon-git:before { - content: "\f1d3"; -} -.uk-icon-hacker-news:before { - content: "\f1d4"; -} -.uk-icon-tencent-weibo:before { - content: "\f1d5"; -} -.uk-icon-qq:before { - content: "\f1d6"; -} -.uk-icon-wechat:before, -.uk-icon-weixin:before { - content: "\f1d7"; -} -.uk-icon-send:before, -.uk-icon-paper-plane:before { - content: "\f1d8"; -} -.uk-icon-send-o:before, -.uk-icon-paper-plane-o:before { - content: "\f1d9"; -} -.uk-icon-history:before { - content: "\f1da"; -} -.uk-icon-genderless:before, -.uk-icon-circle-thin:before { - content: "\f1db"; -} -.uk-icon-header:before { - content: "\f1dc"; -} -.uk-icon-paragraph:before { - content: "\f1dd"; -} -.uk-icon-sliders:before { - content: "\f1de"; -} -.uk-icon-share-alt:before { - content: "\f1e0"; -} -.uk-icon-share-alt-square:before { - content: "\f1e1"; -} -.uk-icon-bomb:before { - content: "\f1e2"; -} -.uk-icon-soccer-ball-o:before, -.uk-icon-futbol-o:before { - content: "\f1e3"; -} -.uk-icon-tty:before { - content: "\f1e4"; -} -.uk-icon-binoculars:before { - content: "\f1e5"; -} -.uk-icon-plug:before { - content: "\f1e6"; -} -.uk-icon-slideshare:before { - content: "\f1e7"; -} -.uk-icon-twitch:before { - content: "\f1e8"; -} -.uk-icon-yelp:before { - content: "\f1e9"; -} -.uk-icon-newspaper-o:before { - content: "\f1ea"; -} -.uk-icon-wifi:before { - content: "\f1eb"; -} -.uk-icon-calculator:before { - content: "\f1ec"; -} -.uk-icon-paypal:before { - content: "\f1ed"; -} -.uk-icon-google-wallet:before { - content: "\f1ee"; -} -.uk-icon-cc-visa:before { - content: "\f1f0"; -} -.uk-icon-cc-mastercard:before { - content: "\f1f1"; -} -.uk-icon-cc-discover:before { - content: "\f1f2"; -} -.uk-icon-cc-amex:before { - content: "\f1f3"; -} -.uk-icon-cc-paypal:before { - content: "\f1f4"; -} -.uk-icon-cc-stripe:before { - content: "\f1f5"; -} -.uk-icon-bell-slash:before { - content: "\f1f6"; -} -.uk-icon-bell-slash-o:before { - content: "\f1f7"; -} -.uk-icon-trash:before { - content: "\f1f8"; -} -.uk-icon-copyright:before { - content: "\f1f9"; -} -.uk-icon-at:before { - content: "\f1fa"; -} -.uk-icon-eyedropper:before { - content: "\f1fb"; -} -.uk-icon-paint-brush:before { - content: "\f1fc"; -} -.uk-icon-birthday-cake:before { - content: "\f1fd"; -} -.uk-icon-area-chart:before { - content: "\f1fe"; -} -.uk-icon-pie-chart:before { - content: "\f200"; -} -.uk-icon-line-chart:before { - content: "\f201"; -} -.uk-icon-lastfm:before { - content: "\f202"; -} -.uk-icon-lastfm-square:before { - content: "\f203"; -} -.uk-icon-toggle-off:before { - content: "\f204"; -} -.uk-icon-toggle-on:before { - content: "\f205"; -} -.uk-icon-bicycle:before { - content: "\f206"; -} -.uk-icon-bus:before { - content: "\f207"; -} -.uk-icon-ioxhost:before { - content: "\f208"; -} -.uk-icon-angellist:before { - content: "\f209"; -} -.uk-icon-cc:before { - content: "\f20a"; -} -.uk-icon-shekel:before, -.uk-icon-sheqel:before, -.uk-icon-ils:before { - content: "\f20b"; -} -.uk-icon-meanpath:before { - content: "\f20c"; -} -.uk-icon-buysellads:before { - content: "\f20d"; -} -.uk-icon-connectdevelop:before { - content: "\f20e"; -} -.uk-icon-dashcube:before { - content: "\f210"; -} -.uk-icon-forumbee:before { - content: "\f211"; -} -.uk-icon-leanpub:before { - content: "\f212"; -} -.uk-icon-sellsy:before { - content: "\f213"; -} -.uk-icon-shirtsinbulk:before { - content: "\f214"; -} -.uk-icon-simplybuilt:before { - content: "\f215"; -} -.uk-icon-skyatlas:before { - content: "\f216"; -} -.uk-icon-cart-plus:before { - content: "\f217"; -} -.uk-icon-cart-arrow-down:before { - content: "\f218"; -} -.uk-icon-diamond:before { - content: "\f219"; -} -.uk-icon-ship:before { - content: "\f21a"; -} -.uk-icon-user-secret:before { - content: "\f21b"; -} -.uk-icon-motorcycle:before { - content: "\f21c"; -} -.uk-icon-street-view:before { - content: "\f21d"; -} -.uk-icon-heartbeat:before { - content: "\f21e"; -} -.uk-icon-venus:before { - content: "\f221"; -} -.uk-icon-mars:before { - content: "\f222"; -} -.uk-icon-mercury:before { - content: "\f223"; -} -.uk-icon-transgender:before { - content: "\f224"; -} -.uk-icon-transgender-alt:before { - content: "\f225"; -} -.uk-icon-venus-double:before { - content: "\f226"; -} -.uk-icon-mars-double:before { - content: "\f227"; -} -.uk-icon-venus-mars:before { - content: "\f228"; -} -.uk-icon-mars-stroke:before { - content: "\f229"; -} -.uk-icon-mars-stroke-v:before { - content: "\f22a"; -} -.uk-icon-mars-stroke-h:before { - content: "\f22b"; -} -.uk-icon-neuter:before { - content: "\f22c"; -} -.uk-icon-facebook-official:before { - content: "\f230"; -} -.uk-icon-pinterest-p:before { - content: "\f231"; -} -.uk-icon-whatsapp:before { - content: "\f232"; -} -.uk-icon-server:before { - content: "\f233"; -} -.uk-icon-user-plus:before { - content: "\f234"; -} -.uk-icon-user-times:before { - content: "\f235"; -} -.uk-icon-hotel:before, -.uk-icon-bed:before { - content: "\f236"; -} -.uk-icon-viacoin:before { - content: "\f237"; -} -.uk-icon-train:before { - content: "\f238"; -} -.uk-icon-subway:before { - content: "\f239"; -} -.uk-icon-medium-logo:before { - content: "\f23a"; -} -.uk-icon-500px:before { - content: "\f26e"; -} -.uk-icon-amazon:before { - content: "\f270"; -} -.uk-icon-balance-scale:before { - content: "\f24e"; -} -.uk-icon-battery-empty:before, -.uk-icon-battery-0:before { - content: "\f244"; -} -.uk-icon-battery-quarter:before, -.uk-icon-battery-1:before { - content: "\f243"; -} -.uk-icon-battery-half:before, -.uk-icon-battery-2:before { - content: "\f242"; -} -.uk-icon-battery-three-quarters:before, -.uk-icon-battery-3:before { - content: "\f241"; -} -.uk-icon-battery-full:before, -.uk-icon-battery-4:before { - content: "\f240"; -} -.uk-icon-black-tie:before { - content: "\f27e"; -} -.uk-icon-calendar-check-o:before { - content: "\f274"; -} -.uk-icon-calendar-minus-o:before { - content: "\f272"; -} -.uk-icon-calendar-plus-o:before { - content: "\f271"; -} -.uk-icon-calendar-times-o:before { - content: "\f273"; -} -.uk-icon-cc-diners-club:before { - content: "\f24c"; -} -.uk-icon-cc-jcb:before { - content: "\f24b"; -} -.uk-icon-chrome:before { - content: "\f268"; -} -.uk-icon-clone:before { - content: "\f24d"; -} -.uk-icon-commenting:before { - content: "\f27a"; -} -.uk-icon-commenting-o:before { - content: "\f27b"; -} -.uk-icon-contao:before { - content: "\f26d"; -} -.uk-icon-creative-commons:before { - content: "\f25e"; -} -.uk-icon-expeditedssl:before { - content: "\f23e"; -} -.uk-icon-firefox:before { - content: "\f269"; -} -.uk-icon-fonticons:before { - content: "\f280"; -} -.uk-icon-get-pocket:before { - content: "\f265"; -} -.uk-icon-gg:before { - content: "\f260"; -} -.uk-icon-gg-circle:before { - content: "\f261"; -} -.uk-icon-hand-lizard-o:before { - content: "\f258"; -} -.uk-icon-hand-stop-o:before, -.uk-icon-hand-paper-o:before { - content: "\f256"; -} -.uk-icon-hand-peace-o:before { - content: "\f25b"; -} -.uk-icon-hand-pointer-o:before { - content: "\f25a"; -} -.uk-icon-hand-grab-o:before, -.uk-icon-hand-rock-o:before { - content: "\f255"; -} -.uk-icon-hand-scissors-o:before { - content: "\f257"; -} -.uk-icon-hand-spock-o:before { - content: "\f259"; -} -.uk-icon-hourglass:before { - content: "\f254"; -} -.uk-icon-hourglass-o:before { - content: "\f250"; -} -.uk-icon-hourglass-1:before, -.uk-icon-hourglass-start:before { - content: "\f251"; -} -.uk-icon-hourglass-2:before, -.uk-icon-hourglass-half:before { - content: "\f252"; -} -.uk-icon-hourglass-3:before, -.uk-icon-hourglass-end:before { - content: "\f253"; -} -.uk-icon-houzz:before { - content: "\f27c"; -} -.uk-icon-i-cursor:before { - content: "\f246"; -} -.uk-icon-industry:before { - content: "\f275"; -} -.uk-icon-internet-explorer:before { - content: "\f26b"; -} -.uk-icon-map:before { - content: "\f279"; -} -.uk-icon-map-o:before { - content: "\f278"; -} -.uk-icon-map-pin:before { - content: "\f276"; -} -.uk-icon-map-signs:before { - content: "\f277"; -} -.uk-icon-mouse-pointer:before { - content: "\f245"; -} -.uk-icon-object-group:before { - content: "\f247"; -} -.uk-icon-object-ungroup:before { - content: "\f248"; -} -.uk-icon-odnoklassniki:before { - content: "\f263"; -} -.uk-icon-odnoklassniki-square:before { - content: "\f264"; -} -.uk-icon-opencart:before { - content: "\f23d"; -} -.uk-icon-opera:before { - content: "\f26a"; -} -.uk-icon-optin-monster:before { - content: "\f23c"; -} -.uk-icon-registered:before { - content: "\f25d"; -} -.uk-icon-safari:before { - content: "\f267"; -} -.uk-icon-sticky-note:before { - content: "\f249"; -} -.uk-icon-sticky-note-o:before { - content: "\f24a"; -} -.uk-icon-tv:before, -.uk-icon-television:before { - content: "\f26c"; -} -.uk-icon-trademark:before { - content: "\f25c"; -} -.uk-icon-tripadvisor:before { - content: "\f262"; -} -.uk-icon-vimeo:before { - content: "\f27d"; -} -.uk-icon-wikipedia-w:before { - content: "\f266"; -} -.uk-icon-yc:before, -.uk-icon-y-combinator:before { - content: "\f23b"; -} -.uk-icon-yc-square:before, -.uk-icon-y-combinator-square:before { - content: "\f1d4"; -} -.uk-icon-bluetooth:before { - content: "\f293"; -} -.uk-icon-bluetooth-b:before { - content: "\f294"; -} -.uk-icon-codiepie:before { - content: "\f284"; -} -.uk-icon-credit-card-alt:before { - content: "\f283"; -} -.uk-icon-edge:before { - content: "\f282"; -} -.uk-icon-fort-awesome:before { - content: "\f286"; -} -.uk-icon-hashtag:before { - content: "\f292"; -} -.uk-icon-mixcloud:before { - content: "\f289"; -} -.uk-icon-modx:before { - content: "\f285"; -} -.uk-icon-pause-circle:before { - content: "\f28b"; -} -.uk-icon-pause-circle-o:before { - content: "\f28c"; -} -.uk-icon-percent:before { - content: "\f295"; -} -.uk-icon-product-hunt:before { - content: "\f288"; -} -.uk-icon-reddit-alien:before { - content: "\f281"; -} -.uk-icon-scribd:before { - content: "\f28a"; -} -.uk-icon-shopping-bag:before { - content: "\f290"; -} -.uk-icon-shopping-basket:before { - content: "\f291"; -} -.uk-icon-stop-circle:before { - content: "\f28d"; -} -.uk-icon-stop-circle-o:before { - content: "\f28e"; -} -.uk-icon-usb:before { - content: "\f287"; -} -.uk-icon-american-sign-language-interpreting:before, -.uk-icon-asl-interpreting:before { - content: "\f2a3"; -} -.uk-icon-assistive-listening-systems:before { - content: "\f2a2"; -} -.uk-icon-audio-description:before { - content: "\f29e"; -} -.uk-icon-blind:before { - content: "\f29d"; -} -.uk-icon-braille:before { - content: "\f2a1"; -} -.uk-icon-deaf:before, -.uk-icon-deafness:before { - content: "\f2a4"; -} -.uk-icon-envira:before { - content: "\f299"; -} -.uk-icon-font-awesome:before, -.uk-icon-fa:before { - content: "\f2b4"; -} -.uk-icon-first-order:before { - content: "\f2b0"; -} -.uk-icon-gitlab:before { - content: "\f296"; -} -.uk-icon-glide:before { - content: "\f2a5"; -} -.uk-icon-glide-g:before { - content: "\f2a6"; -} -.uk-icon-hard-of-hearing:before { - content: "\f2a4"; -} -.uk-icon-low-vision:before { - content: "\f2a8"; -} -.uk-icon-question-circle-o:before { - content: "\f29c"; -} -.uk-icon-sign-language:before, -.uk-icon-signing:before { - content: "\f2a7"; -} -.uk-icon-snapchat:before { - content: "\f2ab"; -} -.uk-icon-snapchat-ghost:before { - content: "\f2ac"; -} -.uk-icon-snapchat-square:before { - content: "\f2ad"; -} -.uk-icon-themeisle:before { - content: "\f2b2"; -} -.uk-icon-universal-access:before { - content: "\f29a"; -} -.uk-icon-viadeo:before { - content: "\f2a9"; -} -.uk-icon-viadeo-square:before { - content: "\f2aa"; -} -.uk-icon-volume-control-phone:before { - content: "\f2a0"; -} -.uk-icon-wheelchair-alt:before { - content: "\f29b"; -} -.uk-icon-wpbeginner:before { - content: "\f297"; -} -.uk-icon-wpforms:before { - content: "\f298"; -} -.uk-icon-yoast:before { - content: "\f2b1"; -} -.uk-icon-adress-book:before { - content: "\f2b9"; -} -.uk-icon-adress-book-o:before { - content: "\f2ba"; -} -.uk-icon-adress-card:before { - content: "\f2bb"; -} -.uk-icon-adress-card-o:before { - content: "\f2bc"; -} -.uk-icon-bandcamp:before { - content: "\f2d5"; -} -.uk-icon-bath:before { - content: "\f2cd"; -} -.uk-icon-bathub:before { - content: "\f2cd"; -} -.uk-icon-drivers-license:before { - content: "\f2c2"; -} -.uk-icon-drivers-license-o:before { - content: "\f2c3"; -} -.uk-icon-eercast:before { - content: "\f2da"; -} -.uk-icon-envelope-open:before { - content: "\f2b6"; -} -.uk-icon-envelope-open-o:before { - content: "\f2b7"; -} -.uk-icon-etsy:before { - content: "\f2d7"; -} -.uk-icon-free-code-camp:before { - content: "\f2c5"; -} -.uk-icon-grav:before { - content: "\f2d6"; -} -.uk-icon-handshake-o:before { - content: "\f2b5"; -} -.uk-icon-id-badge:before { - content: "\f2c1"; -} -.uk-icon-id-card:before { - content: "\f2c2"; -} -.uk-icon-id-card-o:before { - content: "\f2c3"; -} -.uk-icon-imdb:before { - content: "\f2d8"; -} -.uk-icon-linode:before { - content: "\f2b8"; -} -.uk-icon-meetup:before { - content: "\f2e0"; -} -.uk-icon-microchip:before { - content: "\f2db"; -} -.uk-icon-podcast:before { - content: "\f2ce"; -} -.uk-icon-quora:before { - content: "\f2c4"; -} -.uk-icon-ravelry:before { - content: "\f2d9"; -} -.uk-icon-s15:before { - content: "\f2cd"; -} -.uk-icon-shower:before { - content: "\f2cc"; -} -.uk-icon-snowflake-o:before { - content: "\f2dc"; -} -.uk-icon-superpowers:before { - content: "\f2dd"; -} -.uk-icon-telegram:before { - content: "\f2c6"; -} -.uk-icon-thermometer:before { - content: "\f2c7"; -} -.uk-icon-thermometer-0:before { - content: "\f2cb"; -} -.uk-icon-thermometer-1:before { - content: "\f2ca"; -} -.uk-icon-thermometer-2:before { - content: "\f2c9"; -} -.uk-icon-thermometer-3:before { - content: "\f2c8"; -} -.uk-icon-thermometer-4:before { - content: "\f2c7"; -} -.uk-icon-thermometer-empty:before { - content: "\f2cb"; -} -.uk-icon-thermometer-full:before { - content: "\f2c7"; -} -.uk-icon-thermometer-half:before { - content: "\f2c9"; -} -.uk-icon-thermometer-quarter:before { - content: "\f2ca"; -} -.uk-icon-thermometer-three-quarters:before { - content: "\f2c8"; -} -.uk-icon-times-rectangle:before { - content: "\f2d3"; -} -.uk-icon-times-rectangle-o:before { - content: "\f2d4"; -} -.uk-icon-user-circle:before { - content: "\f2bd"; -} -.uk-icon-user-circle-o:before { - content: "\f2be"; -} -.uk-icon-user-o:before { - content: "\f2c0"; -} -.uk-icon-vcard:before { - content: "\f2bb"; -} -.uk-icon-vcard-o:before { - content: "\f2bc"; -} -.uk-icon-widow-close:before { - content: "\f2d3"; -} -.uk-icon-widow-close-o:before { - content: "\f2d4"; -} -.uk-icon-window-maximize:before { - content: "\f2d0"; -} -.uk-icon-window-minimize:before { - content: "\f2d1"; -} -.uk-icon-window-restore:before { - content: "\f2d2"; -} -.uk-icon-wpexplorer:before { - content: "\f2de"; -} -/* ======================================================================== - Component: Close - ========================================================================== */ -/* - * Removes inner padding and border in Firefox 4+. - */ -.uk-close::-moz-focus-inner { - border: 0; - padding: 0; -} -/* - * 1. Correct inability to style clickable `input` types in iOS. - * 2. Remove margins in Chrome, Safari and Opera. - * 3. Remove borders for `button`. - * 4. Address `overflow` set to `hidden` in IE 8/9/10/11. - * 5. Correct `font` properties and `color` not being inherited for `button`. - * 6. Address inconsistent `text-transform` inheritance which is only inherit in Firefox and IE - * 7. Remove default `button` padding and background color - * 8. Style - */ -.uk-close { - /* 1 */ - -webkit-appearance: none; - /* 2 */ - margin: 0; - /* 3 */ - border: none; - /* 4 */ - overflow: visible; - /* 5 */ - font: inherit; - color: inherit; - /* 6 */ - text-transform: none; - /* 7. */ - padding: 0; - background: transparent; - /* 8 */ - display: inline-block; - box-sizing: content-box; - width: 20px; - line-height: 20px; - text-align: center; - vertical-align: middle; - opacity: 0.3; -} -/* Icon */ -.uk-close:after { - display: block; - content: "\f00d"; - font-family: FontAwesome; -} -/* - * Hover - * 1. Apply hover style also to focus state - * 2. Remove default focus style - * 3. Required for `a` elements - */ -.uk-close:hover, -.uk-close:focus { - opacity: 0.5; - /* 2 */ - outline: none; - /* 3 */ - color: inherit; - text-decoration: none; - cursor: pointer; -} -/* Modifier - ========================================================================== */ -.uk-close-alt { - padding: 2px; - border-radius: 50%; - background: #eee; - opacity: 1; -} -/* Hover */ -.uk-close-alt:hover, -.uk-close-alt:focus { - opacity: 1; -} -/* Icon */ -.uk-close-alt:after { - opacity: 0.5; -} -.uk-close-alt:hover:after, -.uk-close-alt:focus:after { - opacity: 0.8; -} -/* ======================================================================== - Component: Badge - ========================================================================== */ -.uk-badge { - display: inline-block; - padding: 0 5px; - background: #00a8e6; - font-size: 10px; - font-weight: bold; - line-height: 14px; - color: #fff; - text-align: center; - vertical-align: middle; - text-transform: none; -} -/* - * Keep color when badge is a link - */ -a.uk-badge:hover { - color: #fff; -} -/* Modifier: `uk-badge-notification`; - ========================================================================== */ -.uk-badge-notification { - box-sizing: border-box; - min-width: 18px; - border-radius: 500px; - font-size: 12px; - line-height: 18px; -} -/* Color modifier - ========================================================================== */ -/* - * Modifier: `uk-badge-success` - */ -.uk-badge-success { - background-color: #8cc14c; -} -/* - * Modifier: `uk-badge-warning` - */ -.uk-badge-warning { - background-color: #faa732; -} -/* - * Modifier: `uk-badge-danger` - */ -.uk-badge-danger { - background-color: #da314b; -} -/* ======================================================================== - Component: Alert - ========================================================================== */ -.uk-alert { - margin-bottom: 15px; - padding: 10px; - background: #ebf7fd; - color: #2d7091; -} -/* - * Add margin if adjacent element - */ -* + .uk-alert { - margin-top: 15px; -} -/* - * Remove margin from the last-child - */ -.uk-alert > :last-child { - margin-bottom: 0; -} -/* - * Keep color for headings if the default heading color is changed - */ -.uk-alert h1, -.uk-alert h2, -.uk-alert h3, -.uk-alert h4, -.uk-alert h5, -.uk-alert h6 { - color: inherit; -} -/* Close in alert - ========================================================================== */ -.uk-alert > .uk-close:first-child { - float: right; -} -/* - * Remove margin from adjacent element - */ -.uk-alert > .uk-close:first-child + * { - margin-top: 0; -} -/* Modifier: `uk-alert-success` - ========================================================================== */ -.uk-alert-success { - background: #f2fae3; - color: #659f13; -} -/* Modifier: `uk-alert-warning` - ========================================================================== */ -.uk-alert-warning { - background: #fffceb; - color: #e28327; -} -/* Modifier: `uk-alert-danger` - ========================================================================== */ -.uk-alert-danger { - background: #fff1f0; - color: #d85030; -} -/* Modifier: `uk-alert-large` - ========================================================================== */ -.uk-alert-large { - padding: 20px; -} -.uk-alert-large > .uk-close:first-child { - margin: -10px -10px 0 0; -} -/* ======================================================================== - Component: Thumbnail - ========================================================================== */ -/* - * 1. Container width fits its content - * 2. Responsive behavior - * 3. Corrects `max-width` behavior sed - * 4. Required for `figure` element - * 5. Style - */ -.uk-thumbnail { - /* 1 */ - display: inline-block; - /* 2 */ - max-width: 100%; - /* 3 */ - box-sizing: border-box; - /* 3 */ - margin: 0; - /* 4 */ - padding: 4px; - border: 1px solid #ddd; - background: #fff; -} -/* - * Hover state for `a` elements - * 1. Apply hover style also to focus state - * 2. Needed for caption - * 3. Remove default focus style - */ -a.uk-thumbnail:hover, -a.uk-thumbnail:focus { - border-color: #aaa; - background-color: #fff; - /* 2 */ - text-decoration: none; - /* 3 */ - outline: none; -} -/* Caption - ========================================================================== */ -.uk-thumbnail-caption { - padding-top: 4px; - text-align: center; - color: #444; -} -/* Sizes - ========================================================================== */ -.uk-thumbnail-mini { - width: 150px; -} -.uk-thumbnail-small { - width: 200px; -} -.uk-thumbnail-medium { - width: 300px; -} -.uk-thumbnail-large { - width: 400px; -} -.uk-thumbnail-expand, -.uk-thumbnail-expand > img { - width: 100%; -} -/* ======================================================================== - Component: Overlay - ========================================================================== */ -/* - * 1. Container width fits its content - * 2. Create position context - * 3. Set max-width for responsive images to prevent `inline-block` consequences - * 4. Remove the gap between the container and its child element - * 5. Needed for transitions and to fixed wrong scaling calculation for images in Chrome - * 6. Fixed `overflow: hidden` to be ignored with border-radius and CSS transforms in Webkit - * 7. Reset margin - */ -.uk-overlay { - /* 1 */ - display: inline-block; - /* 2 */ - position: relative; - /* 3 */ - max-width: 100%; - /* 4 */ - vertical-align: middle; - /* 5 */ - overflow: hidden; - /* 6 */ - -webkit-transform: translateZ(0); - /* 7 */ - margin: 0; -} -/* 6 for Safari */ -.uk-overlay.uk-border-circle { - -webkit-mask-image: -webkit-radial-gradient(circle, white 100%, black 100%); -} -/* - * Remove margin from content - */ -.uk-overlay > :first-child { - margin-bottom: 0; -} -/* Sub-object `uk-overlay-panel` - ========================================================================== */ -/* - * 1. Position cover - * 2. Style - */ -.uk-overlay-panel { - /* 1 */ - position: absolute; - top: 0; - bottom: 0; - left: 0; - right: 0; - /* 2 */ - padding: 20px; - color: #fff; -} -/* - * Remove margin from the last-child - */ -.uk-overlay-panel > :last-child, -.uk-overlay-panel.uk-flex > * > :last-child { - margin-bottom: 0; -} -/* - * Keep color for headings if the default heading color is changed - */ -.uk-overlay-panel h1, -.uk-overlay-panel h2, -.uk-overlay-panel h3, -.uk-overlay-panel h4, -.uk-overlay-panel h5, -.uk-overlay-panel h6 { - color: inherit; -} -.uk-overlay-panel a:not([class]) { - color: inherit; - text-decoration: underline; -} -.uk-overlay-panel a[class*='uk-icon-']:not(.uk-icon-button) { - color: inherit; -} -/* Sub-object `uk-overlay-hover` and `uk-overlay-active` - ========================================================================== */ -.uk-overlay-hover:not(:hover):not(.uk-hover) .uk-overlay-panel:not(.uk-ignore) { - opacity: 0; -} -.uk-overlay-active :not(.uk-active) > .uk-overlay-panel:not(.uk-ignore) { - opacity: 0; -} -/* Modifier `uk-overlay-background` - ========================================================================== */ -.uk-overlay-background { - background: rgba(0, 0, 0, 0.5); -} -/* Modifier `uk-overlay-image` - ========================================================================== */ -/* - * Reset panel - */ -.uk-overlay-image { - padding: 0; -} -/* Position modifiers - ========================================================================== */ -.uk-overlay-top { - bottom: auto; -} -.uk-overlay-bottom { - top: auto; -} -.uk-overlay-left { - right: auto; -} -.uk-overlay-right { - left: auto; -} -/* Sub-object `uk-overlay-icon` - ========================================================================== */ -.uk-overlay-icon:before { - content: "\f002"; - position: absolute; - top: 50%; - left: 50%; - width: 50px; - height: 50px; - margin-top: -25px; - margin-left: -25px; - font-size: 50px; - line-height: 1; - font-family: FontAwesome; - text-align: center; - color: #fff; -} -/* Transitions - ========================================================================== */ -.uk-overlay-fade, -.uk-overlay-scale, -.uk-overlay-spin, -.uk-overlay-grayscale, -.uk-overlay-blur, -[class*='uk-overlay-slide'] { - transition-duration: 0.3s; - transition-timing-function: ease-out; - transition-property: opacity, transform, filter; -} -.uk-overlay-active .uk-overlay-fade, -.uk-overlay-active .uk-overlay-scale, -.uk-overlay-active .uk-overlay-spin, -.uk-overlay-active [class*='uk-overlay-slide'] { - transition-duration: 0.8s; -} -/* - * Fade - */ -.uk-overlay-fade { - opacity: 0.7; -} -.uk-overlay-hover:hover .uk-overlay-fade, -.uk-overlay-hover.uk-hover .uk-overlay-fade, -.uk-overlay-active .uk-active > .uk-overlay-fade { - opacity: 1; -} -/* - * Scale - */ -.uk-overlay-scale { - -webkit-transform: scale(1); - transform: scale(1); -} -.uk-overlay-hover:hover .uk-overlay-scale, -.uk-overlay-hover.uk-hover .uk-overlay-scale, -.uk-overlay-active .uk-active > .uk-overlay-scale { - -webkit-transform: scale(1.1); - transform: scale(1.1); -} -/* - * Spin - */ -.uk-overlay-spin { - -webkit-transform: scale(1) rotate(0deg); - transform: scale(1) rotate(0deg); -} -.uk-overlay-hover:hover .uk-overlay-spin, -.uk-overlay-hover.uk-hover .uk-overlay-spin, -.uk-overlay-active .uk-active > .uk-overlay-spin { - -webkit-transform: scale(1.1) rotate(3deg); - transform: scale(1.1) rotate(3deg); -} -/* - * Grayscale - */ -.uk-overlay-grayscale { - -webkit-filter: grayscale(100%); - filter: grayscale(100%); -} -.uk-overlay-hover:hover .uk-overlay-grayscale, -.uk-overlay-hover.uk-hover .uk-overlay-grayscale, -.uk-overlay-active .uk-active > .uk-overlay-grayscale { - -webkit-filter: grayscale(0%); - filter: grayscale(0%); -} -/* - * Slide - */ -[class*='uk-overlay-slide'] { - opacity: 0; -} -/* Top */ -.uk-overlay-slide-top { - -webkit-transform: translateY(-100%); - transform: translateY(-100%); -} -/* Bottom */ -.uk-overlay-slide-bottom { - -webkit-transform: translateY(100%); - transform: translateY(100%); -} -/* Left */ -.uk-overlay-slide-left { - -webkit-transform: translateX(-100%); - transform: translateX(-100%); -} -/* Right */ -.uk-overlay-slide-right { - -webkit-transform: translateX(100%); - transform: translateX(100%); -} -/* Hover */ -.uk-overlay-hover:hover [class*='uk-overlay-slide'], -.uk-overlay-hover.uk-hover [class*='uk-overlay-slide'], -.uk-overlay-active .uk-active > [class*='uk-overlay-slide'] { - opacity: 1; - -webkit-transform: translateX(0) translateY(0); - transform: translateX(0) translateY(0); -} -/* DEPRECATED - * Sub-object `uk-overlay-area` - ========================================================================== */ -/* - * 1. Set position - * 2. Set style - * 3. Fade-in transition - */ -.uk-overlay-area { - /* 1 */ - position: absolute; - top: 0; - bottom: 0; - left: 0; - right: 0; - /* 2 */ - background: rgba(0, 0, 0, 0.3); - /* 3 */ - opacity: 0; - -webkit-transition: opacity 0.15s linear; - transition: opacity 0.15s linear; - -webkit-transform: translate3d(0, 0, 0); -} -/* - * Hover - * 1. `uk-hover` to support touch devices - * 2. Use optional `uk-overlay-toggle` to trigger the overlay earlier - */ -.uk-overlay:hover .uk-overlay-area, -.uk-overlay.uk-hover .uk-overlay-area, -.uk-overlay-toggle:hover .uk-overlay-area, -.uk-overlay-toggle.uk-hover .uk-overlay-area { - opacity: 1; -} -/* - * Icon - */ -.uk-overlay-area:empty:before { - content: "\f002"; - position: absolute; - top: 50%; - left: 50%; - width: 50px; - height: 50px; - margin-top: -25px; - margin-left: -25px; - font-size: 50px; - line-height: 1; - font-family: FontAwesome; - text-align: center; - color: #fff; -} -/* DEPRECATED - * Sub-object `uk-overlay-area-content` - ========================================================================== */ -/* - * Remove whitespace between child elements when using `inline-block` - * Needed for Firefox - */ -.uk-overlay-area:not(:empty) { - font-size: 0.001px; -} -/* - * 1. Needed for vertical alignment - */ -.uk-overlay-area:not(:empty):before { - content: ''; - display: inline-block; - height: 100%; - vertical-align: middle; -} -/* - * 1. Set vertical alignment - * 2. Reset whitespace hack - * 3. Set horizontal alignment - * 4. Set style - */ -.uk-overlay-area-content { - /* 1 */ - display: inline-block; - box-sizing: border-box; - width: 100%; - vertical-align: middle; - /* 2 */ - font-size: 1rem; - /* 3 */ - text-align: center; - /* 4 */ - padding: 0 15px; - color: #fff; -} -/* - * Remove margin from the last-child - */ -.uk-overlay-area-content > :last-child { - margin-bottom: 0; -} -/* - * Links in overlay area - */ -.uk-overlay-area-content a:not([class]), -.uk-overlay-area-content a:not([class]):hover { - color: inherit; -} -/* DEPRECATED - * Sub-object `uk-overlay-caption` - ========================================================================== */ -/* - * 1. Set position - * 2. Set style - * 3. Fade-in transition - */ -.uk-overlay-caption { - /* 1 */ - position: absolute; - bottom: 0; - left: 0; - right: 0; - /* 2 */ - padding: 15px; - background: rgba(0, 0, 0, 0.5); - color: #fff; - /* 3 */ - opacity: 0; - -webkit-transition: opacity 0.15s linear; - transition: opacity 0.15s linear; - -webkit-transform: translate3d(0, 0, 0); -} -/* - * Hover - * 1. `uk-hover` to support touch devices - * 2. Use optional `uk-overlay-toggle` to trigger the overlay earlier - */ -.uk-overlay:hover .uk-overlay-caption, -.uk-overlay.uk-hover .uk-overlay-caption, -.uk-overlay-toggle:hover .uk-overlay-caption, -.uk-overlay-toggle.uk-hover .uk-overlay-caption { - opacity: 1; -} -/* ======================================================================== - Component: Column - ========================================================================== */ -[class*='uk-column-'] { - -webkit-column-gap: 25px; - -moz-column-gap: 25px; - column-gap: 25px; -} -/* Width modifiers - ========================================================================== */ -.uk-column-1-2 { - -webkit-column-count: 2; - -moz-column-count: 2; - column-count: 2; -} -.uk-column-1-3 { - -webkit-column-count: 3; - -moz-column-count: 3; - column-count: 3; -} -.uk-column-1-4 { - -webkit-column-count: 4; - -moz-column-count: 4; - column-count: 4; -} -.uk-column-1-5 { - -webkit-column-count: 5; - -moz-column-count: 5; - column-count: 5; -} -.uk-column-1-6 { - -webkit-column-count: 6; - -moz-column-count: 6; - column-count: 6; -} -/* Phone landscape and bigger */ -@media (min-width: 480px) { - .uk-column-small-1-2 { - -webkit-column-count: 2; - -moz-column-count: 2; - column-count: 2; - } - .uk-column-small-1-3 { - -webkit-column-count: 3; - -moz-column-count: 3; - column-count: 3; - } - .uk-column-small-1-4 { - -webkit-column-count: 4; - -moz-column-count: 4; - column-count: 4; - } - .uk-column-small-1-5 { - -webkit-column-count: 5; - -moz-column-count: 5; - column-count: 5; - } - .uk-column-small-1-6 { - -webkit-column-count: 6; - -moz-column-count: 6; - column-count: 6; - } -} -/* Tablet and bigger */ -@media (min-width: 768px) { - .uk-column-medium-1-2 { - -webkit-column-count: 2; - -moz-column-count: 2; - column-count: 2; - } - .uk-column-medium-1-3 { - -webkit-column-count: 3; - -moz-column-count: 3; - column-count: 3; - } - .uk-column-medium-1-4 { - -webkit-column-count: 4; - -moz-column-count: 4; - column-count: 4; - } - .uk-column-medium-1-5 { - -webkit-column-count: 5; - -moz-column-count: 5; - column-count: 5; - } - .uk-column-medium-1-6 { - -webkit-column-count: 6; - -moz-column-count: 6; - column-count: 6; - } -} -/* Desktop and bigger */ -@media (min-width: 960px) { - .uk-column-large-1-2 { - -webkit-column-count: 2; - -moz-column-count: 2; - column-count: 2; - } - .uk-column-large-1-3 { - -webkit-column-count: 3; - -moz-column-count: 3; - column-count: 3; - } - .uk-column-large-1-4 { - -webkit-column-count: 4; - -moz-column-count: 4; - column-count: 4; - } - .uk-column-large-1-5 { - -webkit-column-count: 5; - -moz-column-count: 5; - column-count: 5; - } - .uk-column-large-1-6 { - -webkit-column-count: 6; - -moz-column-count: 6; - column-count: 6; - } -} -/* Large screen and bigger */ -@media (min-width: 1220px) { - .uk-column-xlarge-1-2 { - -webkit-column-count: 2; - -moz-column-count: 2; - column-count: 2; - } - .uk-column-xlarge-1-3 { - -webkit-column-count: 3; - -moz-column-count: 3; - column-count: 3; - } - .uk-column-xlarge-1-4 { - -webkit-column-count: 4; - -moz-column-count: 4; - column-count: 4; - } - .uk-column-xlarge-1-5 { - -webkit-column-count: 5; - -moz-column-count: 5; - column-count: 5; - } - .uk-column-xlarge-1-6 { - -webkit-column-count: 6; - -moz-column-count: 6; - column-count: 6; - } -} -/* ======================================================================== - Component: Animation - ========================================================================== */ -[class*='uk-animation-'] { - -webkit-animation-duration: 0.5s; - animation-duration: 0.5s; - -webkit-animation-timing-function: ease-out; - animation-timing-function: ease-out; - -webkit-animation-fill-mode: both; - animation-fill-mode: both; -} -/* Hide animated element if scrollspy is used */ -@media screen { - [data-uk-scrollspy*='uk-animation-']:not([data-uk-scrollspy*='target']) { - opacity: 0; - } -} -/* - * Fade - * Higher specificity (!important) needed because of reverse modifier - */ -.uk-animation-fade { - -webkit-animation-name: uk-fade; - animation-name: uk-fade; - -webkit-animation-duration: 0.8s; - animation-duration: 0.8s; - -webkit-animation-timing-function: linear !important; - animation-timing-function: linear !important; -} -/* - * Fade with scale - */ -.uk-animation-scale-up { - -webkit-animation-name: uk-fade-scale-02; - animation-name: uk-fade-scale-02; -} -.uk-animation-scale-down { - -webkit-animation-name: uk-fade-scale-18; - animation-name: uk-fade-scale-18; -} -/* - * Fade with slide - */ -.uk-animation-slide-top { - -webkit-animation-name: uk-fade-top; - animation-name: uk-fade-top; -} -.uk-animation-slide-bottom { - -webkit-animation-name: uk-fade-bottom; - animation-name: uk-fade-bottom; -} -.uk-animation-slide-left { - -webkit-animation-name: uk-fade-left; - animation-name: uk-fade-left; -} -.uk-animation-slide-right { - -webkit-animation-name: uk-fade-right; - animation-name: uk-fade-right; -} -/* - * Scale - */ -.uk-animation-scale { - -webkit-animation-name: uk-scale-12; - animation-name: uk-scale-12; -} -/* - * Shake - */ -.uk-animation-shake { - -webkit-animation-name: uk-shake; - animation-name: uk-shake; -} -/* Direction modifiers - ========================================================================== */ -.uk-animation-reverse { - -webkit-animation-direction: reverse; - animation-direction: reverse; - -webkit-animation-timing-function: ease-in; - animation-timing-function: ease-in; -} -/* Duration modifiers -========================================================================== */ -.uk-animation-15 { - -webkit-animation-duration: 15s; - animation-duration: 15s; -} -/* Origin modifiers -========================================================================== */ -.uk-animation-top-left { - -webkit-transform-origin: 0 0; - transform-origin: 0 0; -} -.uk-animation-top-center { - -webkit-transform-origin: 50% 0; - transform-origin: 50% 0; -} -.uk-animation-top-right { - -webkit-transform-origin: 100% 0; - transform-origin: 100% 0; -} -.uk-animation-middle-left { - -webkit-transform-origin: 0 50%; - transform-origin: 0 50%; -} -.uk-animation-middle-right { - -webkit-transform-origin: 100% 50%; - transform-origin: 100% 50%; -} -.uk-animation-bottom-left { - -webkit-transform-origin: 0 100%; - transform-origin: 0 100%; -} -.uk-animation-bottom-center { - -webkit-transform-origin: 50% 100%; - transform-origin: 50% 100%; -} -.uk-animation-bottom-right { - -webkit-transform-origin: 100% 100%; - transform-origin: 100% 100%; -} -/* Sub-object: `uk-animation-hover` -========================================================================== */ -/* - * Enable animation only on hover - * Note: Firefox also needs this because animations are not triggered when switching between display `hidden` and `block` - */ -.uk-animation-hover:not(:hover), -.uk-animation-hover:not(:hover) [class*='uk-animation-'], -.uk-touch .uk-animation-hover:not(.uk-hover), -.uk-touch .uk-animation-hover:not(.uk-hover) [class*='uk-animation-'] { - -webkit-animation-name: none; - animation-name: none; -} -/* Keyframes: Fade - * Used by dropdown, datepicker and slideshow component - ========================================================================== */ -@-webkit-keyframes uk-fade { - 0% { - opacity: 0; - } - 100% { - opacity: 1; - } -} -@keyframes uk-fade { - 0% { - opacity: 0; - } - 100% { - opacity: 1; - } -} -/* Keyframes: Fade with slide - ========================================================================== */ -/* - * Top - */ -@-webkit-keyframes uk-fade-top { - 0% { - opacity: 0; - -webkit-transform: translateY(-100%); - } - 100% { - opacity: 1; - -webkit-transform: translateY(0); - } -} -@keyframes uk-fade-top { - 0% { - opacity: 0; - transform: translateY(-100%); - } - 100% { - opacity: 1; - transform: translateY(0); - } -} -/* - * Bottom - */ -@-webkit-keyframes uk-fade-bottom { - 0% { - opacity: 0; - -webkit-transform: translateY(100%); - } - 100% { - opacity: 1; - -webkit-transform: translateY(0); - } -} -@keyframes uk-fade-bottom { - 0% { - opacity: 0; - transform: translateY(100%); - } - 100% { - opacity: 1; - transform: translateY(0); - } -} -/* - * Left - */ -@-webkit-keyframes uk-fade-left { - 0% { - opacity: 0; - -webkit-transform: translateX(-100%); - } - 100% { - opacity: 1; - -webkit-transform: translateX(0); - } -} -@keyframes uk-fade-left { - 0% { - opacity: 0; - transform: translateX(-100%); - } - 100% { - opacity: 1; - transform: translateX(0); - } -} -/* - * Right - */ -@-webkit-keyframes uk-fade-right { - 0% { - opacity: 0; - -webkit-transform: translateX(100%); - } - 100% { - opacity: 1; - -webkit-transform: translateX(0); - } -} -@keyframes uk-fade-right { - 0% { - opacity: 0; - transform: translateX(100%); - } - 100% { - opacity: 1; - transform: translateX(0); - } -} -/* Keyframes: Fade with scale - ========================================================================== */ -/* - * Scale by 0.2 - */ -@-webkit-keyframes uk-fade-scale-02 { - 0% { - opacity: 0; - -webkit-transform: scale(0.2); - } - 100% { - opacity: 1; - -webkit-transform: scale(1); - } -} -@keyframes uk-fade-scale-02 { - 0% { - opacity: 0; - transform: scale(0.2); - } - 100% { - opacity: 1; - transform: scale(1); - } -} -/* - * Scale by 1.5 - * Used by slideshow component - */ -@-webkit-keyframes uk-fade-scale-15 { - 0% { - opacity: 0; - -webkit-transform: scale(1.5); - } - 100% { - opacity: 1; - -webkit-transform: scale(1); - } -} -@keyframes uk-fade-scale-15 { - 0% { - opacity: 0; - transform: scale(1.5); - } - 100% { - opacity: 1; - transform: scale(1); - } -} -/* - * Scale by 1.8 - */ -@-webkit-keyframes uk-fade-scale-18 { - 0% { - opacity: 0; - -webkit-transform: scale(1.8); - } - 100% { - opacity: 1; - -webkit-transform: scale(1); - } -} -@keyframes uk-fade-scale-18 { - 0% { - opacity: 0; - transform: scale(1.8); - } - 100% { - opacity: 1; - transform: scale(1); - } -} -/* Keyframes: Slide - * Used by slideshow component - ========================================================================== */ -/* - * Left - */ -@-webkit-keyframes uk-slide-left { - 0% { - -webkit-transform: translateX(-100%); - } - 100% { - -webkit-transform: translateX(0); - } -} -@keyframes uk-slide-left { - 0% { - transform: translateX(-100%); - } - 100% { - transform: translateX(0); - } -} -/* - * Right - */ -@-webkit-keyframes uk-slide-right { - 0% { - -webkit-transform: translateX(100%); - } - 100% { - -webkit-transform: translateX(0); - } -} -@keyframes uk-slide-right { - 0% { - transform: translateX(100%); - } - 100% { - transform: translateX(0); - } -} -/* - * Left third - */ -@-webkit-keyframes uk-slide-left-33 { - 0% { - -webkit-transform: translateX(33%); - } - 100% { - -webkit-transform: translateX(0); - } -} -@keyframes uk-slide-left-33 { - 0% { - transform: translateX(33%); - } - 100% { - transform: translateX(0); - } -} -/* - * Right third - */ -@-webkit-keyframes uk-slide-right-33 { - 0% { - -webkit-transform: translateX(-33%); - } - 100% { - -webkit-transform: translateX(0); - } -} -@keyframes uk-slide-right-33 { - 0% { - transform: translateX(-33%); - } - 100% { - transform: translateX(0); - } -} -/* Keyframes: Scale - ========================================================================== */ -@-webkit-keyframes uk-scale-12 { - 0% { - -webkit-transform: scale(1.2); - } - 100% { - -webkit-transform: scale(1); - } -} -@keyframes uk-scale-12 { - 0% { - transform: scale(1.2); - } - 100% { - transform: scale(1); - } -} -/* Keyframes: Rotate - * Used by icon component - ========================================================================== */ -@-webkit-keyframes uk-rotate { - 0% { - -webkit-transform: rotate(0deg); - } - 100% { - -webkit-transform: rotate(359deg); - } -} -@keyframes uk-rotate { - 0% { - transform: rotate(0deg); - } - 100% { - transform: rotate(359deg); - } -} -/* Keyframes: Shake - ========================================================================== */ -@-webkit-keyframes uk-shake { - 0%, - 100% { - -webkit-transform: translateX(0); - } - 10% { - -webkit-transform: translateX(-9px); - } - 20% { - -webkit-transform: translateX(8px); - } - 30% { - -webkit-transform: translateX(-7px); - } - 40% { - -webkit-transform: translateX(6px); - } - 50% { - -webkit-transform: translateX(-5px); - } - 60% { - -webkit-transform: translateX(4px); - } - 70% { - -webkit-transform: translateX(-3px); - } - 80% { - -webkit-transform: translateX(2px); - } - 90% { - -webkit-transform: translateX(-1px); - } -} -@keyframes uk-shake { - 0%, - 100% { - transform: translateX(0); - } - 10% { - transform: translateX(-9px); - } - 20% { - transform: translateX(8px); - } - 30% { - transform: translateX(-7px); - } - 40% { - transform: translateX(6px); - } - 50% { - transform: translateX(-5px); - } - 60% { - transform: translateX(4px); - } - 70% { - transform: translateX(-3px); - } - 80% { - transform: translateX(2px); - } - 90% { - transform: translateX(-1px); - } -} -/* Keyframes: Fade with slide fixed - * Used by dropdown and search component - ========================================================================== */ -/* - * Top fixed - */ -@-webkit-keyframes uk-slide-top-fixed { - 0% { - opacity: 0; - -webkit-transform: translateY(-10px); - } - 100% { - opacity: 1; - -webkit-transform: translateY(0); - } -} -@keyframes uk-slide-top-fixed { - 0% { - opacity: 0; - transform: translateY(-10px); - } - 100% { - opacity: 1; - transform: translateY(0); - } -} -/* - * Bottom fixed - */ -@-webkit-keyframes uk-slide-bottom-fixed { - 0% { - opacity: 0; - -webkit-transform: translateY(10px); - } - 100% { - opacity: 1; - -webkit-transform: translateY(0); - } -} -@keyframes uk-slide-bottom-fixed { - 0% { - opacity: 0; - transform: translateY(10px); - } - 100% { - opacity: 1; - transform: translateY(0); - } -} -/* ======================================================================== - Component: Dropdown - ========================================================================== */ -/* - * 1. Hide by default - * 2. Set position - * 3. Box-sizing is needed for `uk-dropdown-justify` - * 4. Set width - */ -.uk-dropdown, -.uk-dropdown-blank { - /* 1 */ - display: none; - /* 2 */ - position: absolute; - z-index: 970; - /* 3 */ - box-sizing: border-box; - /* 4 */ - width: 200px; -} -/* - * Dropdown style - * 1. Reset button group whitespace hack - */ -.uk-dropdown { - padding: 15px; - background: #f5f5f5; - color: #444; - /* 1 */ - font-size: 1rem; - vertical-align: top; -} -/* Focus */ -.uk-dropdown:focus { - outline: none; -} -/* - * 1. Show dropdown - * 2. Set animation - * 3. Needed for scale animation - */ -.uk-open > .uk-dropdown, -.uk-open > .uk-dropdown-blank { - /* 1 */ - display: block; - /* 2 */ - -webkit-animation: uk-fade 0.2s ease-in-out; - animation: uk-fade 0.2s ease-in-out; - /* 3 */ - -webkit-transform-origin: 0 0; - transform-origin: 0 0; -} -/* Alignment modifiers - ========================================================================== */ -/* - * Modifier - */ -.uk-dropdown-top { - margin-top: -5px; -} -.uk-dropdown-bottom { - margin-top: 5px; -} -.uk-dropdown-left { - margin-left: -5px; -} -.uk-dropdown-right { - margin-left: 5px; -} -/* Nav in dropdown - ========================================================================== */ -.uk-dropdown .uk-nav { - margin: 0 -15px; -} -/* Grid and panel in dropdown - ========================================================================== */ -/* -* Vertical gutter -*/ -/* - * Grid - * Higher specificity to override large gutter - */ -.uk-grid .uk-dropdown-grid + .uk-dropdown-grid { - margin-top: 15px; -} -/* Panels */ -.uk-dropdown-grid > [class*='uk-width-'] > .uk-panel + .uk-panel { - margin-top: 15px; -} -/* Tablet and bigger */ -@media (min-width: 768px) { - /* - * Horizontal gutter - */ - .uk-dropdown:not(.uk-dropdown-stack) > .uk-dropdown-grid { - margin-left: -15px; - margin-right: -15px; - } - .uk-dropdown:not(.uk-dropdown-stack) > .uk-dropdown-grid > [class*='uk-width-'] { - padding-left: 15px; - padding-right: 15px; - } - /* - * Column divider - */ - .uk-dropdown:not(.uk-dropdown-stack) > .uk-dropdown-grid > [class*='uk-width-']:nth-child(n+2) { - border-left: 1px solid #ddd; - } - /* - * Width multiplier for dropdown columns - */ - .uk-dropdown-width-2:not(.uk-dropdown-stack) { - width: 400px; - } - .uk-dropdown-width-3:not(.uk-dropdown-stack) { - width: 600px; - } - .uk-dropdown-width-4:not(.uk-dropdown-stack) { - width: 800px; - } - .uk-dropdown-width-5:not(.uk-dropdown-stack) { - width: 1000px; - } -} -/* Phone landscape and smaller */ -@media (max-width: 767px) { - /* - * Stack columns and take full width - */ - .uk-dropdown-grid > [class*='uk-width-'] { - width: 100%; - } - /* - * Vertical gutter - */ - .uk-dropdown-grid > [class*='uk-width-']:nth-child(n+2) { - margin-top: 15px; - } -} -/* -* Stack grid columns -*/ -.uk-dropdown-stack > .uk-dropdown-grid > [class*='uk-width-'] { - width: 100%; -} -.uk-dropdown-stack > .uk-dropdown-grid > [class*='uk-width-']:nth-child(n+2) { - margin-top: 15px; -} -/* Modifier `uk-dropdown-small` - ========================================================================== */ -/* - * Set min-width and text expands dropdown if needed - */ -.uk-dropdown-small { - min-width: 150px; - width: auto; - padding: 5px; - white-space: nowrap; -} -/* - * Nav in dropdown - */ -.uk-dropdown-small .uk-nav { - margin: 0 -5px; -} -/* Modifier: `uk-dropdown-navbar` - ========================================================================== */ -.uk-dropdown-navbar { - margin-top: 0; - background: #f5f5f5; - color: #444; -} -.uk-open > .uk-dropdown-navbar { - -webkit-animation: uk-slide-top-fixed 0.2s ease-in-out; - animation: uk-slide-top-fixed 0.2s ease-in-out; -} -/* Modifier `uk-dropdown-scrollable` - ========================================================================== */ -/* - * Usefull for long lists - */ -.uk-dropdown-scrollable { - overflow-y: auto; - max-height: 200px; -} -/* Sub-object: `uk-dropdown-overlay` - ========================================================================== */ -/* ======================================================================== - Component: Modal - ========================================================================== */ -/* - * This is the modal overlay and modal dialog container - * 1. Hide by default - * 2. Set fixed position - * 3. Allow scrolling for the modal dialog - * 4. Mask the background page - * 5. Fade-in transition - * 6. Deactivate browser history navigation in IE11 - * 7. force hardware acceleration to prevent browser rendering hiccups - */ -.uk-modal { - /* 1 */ - display: none; - /* 2 */ - position: fixed; - top: 0; - right: 0; - bottom: 0; - left: 0; - z-index: 1010; - /* 3 */ - overflow-y: auto; - -webkit-overflow-scrolling: touch; - /* 4 */ - background: rgba(0, 0, 0, 0.6); - /* 5 */ - opacity: 0; - -webkit-transition: opacity 0.15s linear; - transition: opacity 0.15s linear; - /* 6 */ - touch-action: cross-slide-y pinch-zoom double-tap-zoom; - /* 7 */ - -webkit-transform: translateZ(0); - transform: translateZ(0); -} -/* - * Open state - */ -.uk-modal.uk-open { - opacity: 1; -} -/* - * Prevents duplicated scrollbar caused by 4. - */ -.uk-modal-page, -.uk-modal-page body { - overflow: hidden; -} -/* Sub-object: `uk-modal-dialog` - ========================================================================== */ -/* - * 1. Create position context for caption, spinner and close button - * 2. Set box sizing - * 3. Set style - * 4. Slide-in transition - */ -.uk-modal-dialog { - /* 1 */ - position: relative; - /* 2 */ - box-sizing: border-box; - margin: 50px auto; - padding: 20px; - width: 600px; - max-width: 100%; - max-width: calc(100% - 20px); - /* 3 */ - background: #fff; - /* 4 */ - opacity: 0; - -webkit-transform: translateY(-100px); - transform: translateY(-100px); - -webkit-transition: opacity 0.3s linear, -webkit-transform 0.3s ease-out; - transition: opacity 0.3s linear, transform 0.3s ease-out; -} -/* Phone landscape and smaller */ -@media (max-width: 767px) { - /* - * Fit in small screen - */ - .uk-modal-dialog { - width: auto; - margin: 10px auto; - } -} -/* - * Open state - */ -.uk-open .uk-modal-dialog { - /* 4 */ - opacity: 1; - -webkit-transform: translateY(0); - transform: translateY(0); -} -/* - * Remove margin from the last-child - */ -.uk-modal-dialog > :not([class*='uk-modal-']):last-child { - margin-bottom: 0; -} -/* Close in modal - ========================================================================== */ -.uk-modal-dialog > .uk-close:first-child { - margin: -10px -10px 0 0; - float: right; -} -/* - * Remove margin from adjacent element - */ -.uk-modal-dialog > .uk-close:first-child + :not([class*='uk-modal-']) { - margin-top: 0; -} -/* Modifier: `uk-modal-dialog-lightbox` - ========================================================================== */ -.uk-modal-dialog-lightbox { - margin: 15px auto; - padding: 0; - max-width: 95%; - max-width: calc(100% - 30px); - min-height: 50px; -} -/* - * Close button - */ -.uk-modal-dialog-lightbox > .uk-close:first-child { - position: absolute; - top: -12px; - right: -12px; - margin: 0; - float: none; -} -/* Phone landscape and smaller */ -@media (max-width: 767px) { - .uk-modal-dialog-lightbox > .uk-close:first-child { - top: -7px; - right: -7px; - } -} -/* Modifier: `uk-modal-dialog-blank` - ========================================================================== */ -.uk-modal-dialog-blank { - margin: 0; - padding: 0; - width: 100%; - max-width: 100%; - -webkit-transition: opacity 0.3s linear; - transition: opacity 0.3s linear; -} -/* -* Close button -*/ -.uk-modal-dialog-blank > .uk-close:first-child { - position: absolute; - top: 20px; - right: 20px; - z-index: 1; - margin: 0; - float: none; -} -/* Modifier: `uk-modal-dialog-large` - ========================================================================== */ -/* Tablet and bigger */ -@media (min-width: 768px) { - .uk-modal-dialog-large { - width: 930px; - } -} -/* Large screen and bigger */ -@media (min-width: 1220px) { - .uk-modal-dialog-large { - width: 1130px; - } -} -/* Sub-Object: `uk-modal-header` and `uk-modal-footer` - ========================================================================== */ -.uk-modal-header { - margin-bottom: 15px; -} -.uk-modal-footer { - margin-top: 15px; -} -/* - * Remove margin from the last-child - */ -.uk-modal-header > :last-child, -.uk-modal-footer > :last-child { - margin-bottom: 0; -} -/* Sub-Object: `uk-modal-caption` - ========================================================================== */ -.uk-modal-caption { - position: absolute; - left: 0; - right: 0; - bottom: -20px; - margin-bottom: -10px; - color: #fff; - text-align: center; - overflow: hidden; - text-overflow: ellipsis; - white-space: nowrap; -} -/* Sub-Object: `uk-modal-spinner` - ========================================================================== */ -.uk-modal-spinner { - position: absolute; - top: 50%; - left: 50%; - -webkit-transform: translate(-50%, -50%); - transform: translate(-50%, -50%); - font-size: 25px; - color: #ddd; -} -.uk-modal-spinner:after { - content: "\f110"; - display: block; - font-family: FontAwesome; - -webkit-animation: uk-rotate 2s infinite linear; - animation: uk-rotate 2s infinite linear; -} -/* ======================================================================== - Component: Off-canvas - ========================================================================== */ -/* - * This is the offcanvas overlay and bar container - * 1. Hide by default - * 2. Set fixed position - * 3. Deactivate browser touch actions in IE11 - * 4. Mask the background page - */ -.uk-offcanvas { - /* 1 */ - display: none; - /* 2 */ - position: fixed; - top: 0; - right: 0; - bottom: 0; - left: 0; - z-index: 1000; - /* 3 */ - touch-action: none; - /* 4 */ - background: rgba(0, 0, 0, 0.1); -} -.uk-offcanvas.uk-active { - display: block; -} -/* Sub-object `uk-offcanvas-page` - ========================================================================== */ -/* - * Prepares the whole HTML page to slide-out - * 1. Fix the main page and disallow scrolling - * 2. Side-out transition - * 3. Needed for the transition to work instead of just letting it pop to the side - */ -.uk-offcanvas-page { - /* 1 */ - position: fixed; - /* 2 */ - -webkit-transition: margin-left 0.3s ease-in-out; - transition: margin-left 0.3s ease-in-out; - /* 3 */ - margin-left: 0; -} -/* Sub-object `uk-offcanvas-bar` - ========================================================================== */ -/* - * This is the offcanvas bar - * 1. Set fixed position - * 2. Size and style - * 3. Allow scrolling - * 4. Side-out transition - * 5. Deactivate scroll chaining in IE11 - */ -.uk-offcanvas-bar { - /* 1 */ - position: fixed; - top: 0; - bottom: 0; - left: 0; - -webkit-transform: translateX(-100%); - transform: translateX(-100%); - z-index: 1001; - /* 2 */ - width: 270px; - max-width: 100%; - background: #333; - /* 3 */ - overflow-y: auto; - -webkit-overflow-scrolling: touch; - /* 4 */ - -webkit-transition: -webkit-transform 0.3s ease-in-out; - transition: transform 0.3s ease-in-out; - /* 5 */ - -ms-scroll-chaining: none; -} -.uk-offcanvas.uk-active .uk-offcanvas-bar.uk-offcanvas-bar-show { - -webkit-transform: translateX(0%); - transform: translateX(0%); -} -/* Modifier `uk-offcanvas-bar-flip` - ========================================================================== */ -.uk-offcanvas-bar-flip { - left: auto; - right: 0; - -webkit-transform: translateX(100%); - transform: translateX(100%); -} -/* Offcanvase modes - ========================================================================== */ -.uk-offcanvas-bar[mode='none'] { - -webkit-transition: none; - transition: none; -} -.uk-offcanvas-bar[mode='reveal'] { - -webkit-transform: translateX(0%); - transform: translateX(0%); - clip: rect(0, 0, 100vh, 0); - -webkit-transition: -webkit-transform 0.3s ease-in-out, clip 0.3s ease-in-out; - transition: transform 0.3s ease-in-out, clip 0.3s ease-in-out; -} -.uk-offcanvas-bar-flip[mode='reveal'] { - clip: none; - -webkit-transform: translateX(100%); - transform: translateX(100%); -} -.uk-offcanvas-bar-flip[mode='reveal'] > * { - -webkit-transform: translateX(-100%); - transform: translateX(-100%); - -webkit-transition: -webkit-transform 0.3s ease-in-out; - transition: transform 0.3s ease-in-out; -} -.uk-offcanvas.uk-active .uk-offcanvas-bar-flip[mode='reveal'].uk-offcanvas-bar-show > * { - -webkit-transform: translateX(0%); - transform: translateX(0%); -} -/* Panel in offcanvas - ========================================================================== */ -.uk-offcanvas .uk-panel { - margin: 20px 15px; - color: #777; -} -.uk-offcanvas .uk-panel-title { - color: #ccc; -} -.uk-offcanvas .uk-panel a:not([class]) { - color: #ccc; -} -.uk-offcanvas .uk-panel a:not([class]):hover { - color: #fff; -} -/* ======================================================================== - Component: Switcher - ========================================================================== */ -/* - * 1. Deactivate browser history navigation in IE11 - */ -.uk-switcher { - margin: 0; - padding: 0; - list-style: none; - /* 1 */ - touch-action: cross-slide-y pinch-zoom double-tap-zoom; -} -/* - * Items - */ -.uk-switcher > :not(.uk-active) { - display: none; -} -/* ======================================================================== - Component: Text - ========================================================================== */ -/* Size modifiers - ========================================================================== */ -.uk-text-small { - font-size: 11px; - line-height: 16px; -} -.uk-text-large { - font-size: 18px; - line-height: 24px; - font-weight: normal; -} -/* Weight modifiers - ========================================================================== */ -.uk-text-bold { - font-weight: bold; -} -/* Color modifiers - ========================================================================== */ -.uk-text-muted { - color: #999 !important; -} -.uk-text-primary { - color: #2d7091 !important; -} -.uk-text-success { - color: #659f13 !important; -} -.uk-text-warning { - color: #e28327 !important; -} -.uk-text-danger { - color: #d85030 !important; -} -.uk-text-contrast { - color: #fff !important; -} -/* Alignment modifiers - ========================================================================== */ -.uk-text-left { - text-align: left !important; -} -.uk-text-right { - text-align: right !important; -} -.uk-text-center { - text-align: center !important; -} -.uk-text-justify { - text-align: justify !important; -} -.uk-text-top { - vertical-align: top !important; -} -.uk-text-middle { - vertical-align: middle !important; -} -.uk-text-bottom { - vertical-align: bottom !important; -} -/* Only tablets portrait and smaller */ -@media (max-width: 959px) { - .uk-text-center-medium { - text-align: center !important; - } - .uk-text-left-medium { - text-align: left !important; - } -} -/* Phone landscape and smaller */ -@media (max-width: 767px) { - .uk-text-center-small { - text-align: center !important; - } - .uk-text-left-small { - text-align: left !important; - } -} -/* Wrap modifiers - ========================================================================== */ -/* - * Prevent text from wrapping onto multiple lines - */ -.uk-text-nowrap { - white-space: nowrap; -} -/* - * Prevent text from wrapping onto multiple lines, and truncate with an ellipsis - */ -.uk-text-truncate { - overflow: hidden; - text-overflow: ellipsis; - white-space: nowrap; -} -/* - * Break strings if their length exceeds the width of their container - */ -.uk-text-break { - word-wrap: break-word; - -webkit-hyphens: auto; - -ms-hyphens: auto; - -moz-hyphens: auto; - hyphens: auto; -} -/* Transform modifiers - ========================================================================== */ -.uk-text-capitalize { - text-transform: capitalize !important; -} -.uk-text-lowercase { - text-transform: lowercase !important; -} -.uk-text-uppercase { - text-transform: uppercase !important; -} -/* ======================================================================== - Component: Utility - ========================================================================== */ -/* Container - ========================================================================== */ -.uk-container { - box-sizing: border-box; - max-width: 980px; - padding: 0 25px; -} -/* Large screen and bigger */ -@media (min-width: 1220px) { - .uk-container { - max-width: 1200px; - padding: 0 35px; - } -} -/* - * Micro clearfix - */ -.uk-container:before, -.uk-container:after { - content: ""; - display: table; -} -.uk-container:after { - clear: both; -} -/* - * Center container - */ -.uk-container-center { - margin-left: auto; - margin-right: auto; -} -/* Clearing - ========================================================================== */ -/* - * Micro clearfix -* `table-cell` is used with `:before` because `table` creates a 1px gap when it becomes a flex item, only in Webkit - * `table` is used again with `:after` because `clear` only works with block elements. - * Note: `display: block` with `overflow: hidden` is currently not working in the latest Safari - */ -.uk-clearfix:before { - content: ""; - display: table-cell; -} -.uk-clearfix:after { - content: ""; - display: table; - clear: both; -} -/* - * Create a new block formatting context - */ -.uk-nbfc { - overflow: hidden; -} -.uk-nbfc-alt { - display: table-cell; - width: 10000px; -} -/* Alignment of block elements - ========================================================================== */ -/* - * Float blocks - * 1. Prevent content overflow on small devices - */ -.uk-float-left { - float: left; -} -.uk-float-right { - float: right; -} -/* 1 */ -[class*='uk-float-'] { - max-width: 100%; -} -/* Alignment of images and objects - ========================================================================== */ -/* - * Alignment - */ -[class*='uk-align-'] { - display: block; - margin-bottom: 15px; -} -.uk-align-left { - margin-right: 15px; - float: left; -} -.uk-align-right { - margin-left: 15px; - float: right; -} -/* Tablet and bigger */ -@media (min-width: 768px) { - .uk-align-medium-left { - margin-right: 15px; - float: left; - } - .uk-align-medium-right { - margin-left: 15px; - float: right; - } -} -.uk-align-center { - margin-left: auto; - margin-right: auto; -} -/* Vertical alignment - ========================================================================== */ -/* - * Remove whitespace between child elements when using `inline-block` - */ -.uk-vertical-align { - font-size: 0.001px; -} -/* - * The `uk-vertical-align` container needs a specific height - */ -.uk-vertical-align:before { - content: ''; - display: inline-block; - height: 100%; - vertical-align: middle; -} -/* - * Sub-object which can have any height - * 1. Reset whitespace hack - */ -.uk-vertical-align-middle, -.uk-vertical-align-bottom { - display: inline-block; - max-width: 100%; - /* 1 */ - font-size: 1rem; -} -.uk-vertical-align-middle { - vertical-align: middle; -} -.uk-vertical-align-bottom { - vertical-align: bottom; -} -/* Height - ========================================================================== */ -/* - * More robust if padding and border are used - */ -[class*='uk-height'] { - box-sizing: border-box; -} -/* - * Useful to extend the `html` and `body` element to the full height of the page. - */ -.uk-height-1-1 { - height: 100%; -} -/* - * Useful to create image teasers - */ -.uk-height-viewport { - height: 100vh; - min-height: 600px; -} -/* Responsive objects - * Note: Images are already responsive by default, see Base component - ========================================================================== */ -/* - * 1. Corrects `max-width` and `max-height` behavior if padding and border are used - */ -.uk-responsive-width, -.uk-responsive-height { - box-sizing: border-box; -} -/* - * Responsiveness: Sets a maximum width relative to the parent and auto scales the height - * `important` needed to override `uk-img-preserve img` - */ -.uk-responsive-width { - max-width: 100% !important; - height: auto; -} -/* - * Responsiveness: Sets a maximum height relative to the parent and auto scales the width - * Only works if the parent element has a fixed height. - */ -.uk-responsive-height { - max-height: 100%; - width: auto; -} -/* Margin - ========================================================================== */ -/* - * Create a block with the same margin of a paragraph - * Add margin if adjacent element - */ -.uk-margin { - margin-bottom: 15px; -} -* + .uk-margin { - margin-top: 15px; -} -.uk-margin-top { - margin-top: 15px !important; -} -.uk-margin-bottom { - margin-bottom: 15px !important; -} -.uk-margin-left { - margin-left: 15px !important; -} -.uk-margin-right { - margin-right: 15px !important; -} -/* - * Larger margins - */ -.uk-margin-large { - margin-bottom: 50px; -} -* + .uk-margin-large { - margin-top: 50px; -} -.uk-margin-large-top { - margin-top: 50px !important; -} -.uk-margin-large-bottom { - margin-bottom: 50px !important; -} -.uk-margin-large-left { - margin-left: 50px !important; -} -.uk-margin-large-right { - margin-right: 50px !important; -} -/* - * Smaller margins - */ -.uk-margin-small { - margin-bottom: 5px; -} -* + .uk-margin-small { - margin-top: 5px; -} -.uk-margin-small-top { - margin-top: 5px !important; -} -.uk-margin-small-bottom { - margin-bottom: 5px !important; -} -.uk-margin-small-left { - margin-left: 5px !important; -} -.uk-margin-small-right { - margin-right: 5px !important; -} -/* - * Remove margins - */ -.uk-margin-remove { - margin: 0 !important; -} -.uk-margin-top-remove { - margin-top: 0 !important; -} -.uk-margin-bottom-remove { - margin-bottom: 0 !important; -} -/* Padding - ========================================================================== */ -.uk-padding-remove { - padding: 0 !important; -} -.uk-padding-top-remove { - padding-top: 0 !important; -} -.uk-padding-bottom-remove { - padding-bottom: 0 !important; -} -.uk-padding-vertical-remove { - padding-top: 0 !important; - padding-bottom: 0 !important; -} -/* Border - ========================================================================== */ -.uk-border-circle { - border-radius: 50%; -} -.uk-border-rounded { - border-radius: 5px; -} -/* Headings - ========================================================================== */ -.uk-heading-large { - font-size: 36px; - line-height: 42px; -} -/* Tablet and bigger */ -@media (min-width: 768px) { - .uk-heading-large { - font-size: 52px; - line-height: 64px; - } -} -/* Link - ========================================================================== */ -/* - * Let links appear in default text color - */ -.uk-link-muted, -.uk-link-muted a { - color: #444; -} -.uk-link-muted:hover, -.uk-link-muted a:hover { - color: #444; -} -/* - * Reset link style - */ -.uk-link-reset, -.uk-link-reset a, -.uk-link-reset:hover, -.uk-link-reset a:hover, -.uk-link-reset:focus, -.uk-link-reset a:focus { - color: inherit; - text-decoration: none; -} -/* Scrollable - ========================================================================== */ -/* - * Enable scrolling for preformatted text - */ -.uk-scrollable-text { - height: 300px; - overflow-y: scroll; - -webkit-overflow-scrolling: touch; - resize: both; -} -/* - * Box with scrolling enabled - */ -.uk-scrollable-box { - box-sizing: border-box; - height: 170px; - padding: 10px; - border: 1px solid #ddd; - overflow: auto; - -webkit-overflow-scrolling: touch; - resize: both; -} -.uk-scrollable-box > :last-child { - margin-bottom: 0; -} -/* Overflow - ========================================================================== */ -.uk-overflow-hidden { - overflow: hidden; -} -/* - * Enable scrollbars if content is clipped - */ -.uk-overflow-container { - overflow: auto; - -webkit-overflow-scrolling: touch; -} -.uk-overflow-container > :last-child { - margin-bottom: 0; -} -/* Position - ========================================================================== */ -.uk-position-absolute, -[class*='uk-position-top'], -[class*='uk-position-bottom'] { - position: absolute !important; -} -/* Don't use `width: 100%` because it is wrong if the parent has padding. */ -.uk-position-top { - top: 0; - left: 0; - right: 0; -} -.uk-position-bottom { - bottom: 0; - left: 0; - right: 0; -} -.uk-position-top-left { - top: 0; - left: 0; -} -.uk-position-top-right { - top: 0; - right: 0; -} -.uk-position-bottom-left { - bottom: 0; - left: 0; -} -.uk-position-bottom-right { - bottom: 0; - right: 0; -} -/* - * Cover - */ -.uk-position-cover { - position: absolute; - top: 0; - bottom: 0; - left: 0; - right: 0; -} -/* - * Relative - */ -.uk-position-relative { - position: relative !important; -} -/* - * Z-index - */ -.uk-position-z-index { - z-index: 1; -} -/* Display - ========================================================================== */ -/* - * Display - * 1. Required if child is a responsive image - */ -.uk-display-block { - display: block !important; -} -.uk-display-inline { - display: inline !important; -} -.uk-display-inline-block { - display: inline-block !important; - /* 1 */ - max-width: 100%; -} -/* - * Visibility - * Avoids setting display to `block` so it works also with `inline-block` and `table` - */ -/* Desktop and bigger */ -@media (min-width: 960px) { - .uk-visible-small { - display: none !important; - } - .uk-visible-medium { - display: none !important; - } - .uk-hidden-large { - display: none !important; - } -} -/* Tablets portrait */ -@media (min-width: 768px) and (max-width: 959px) { - .uk-visible-small { - display: none !important; - } - .uk-visible-large { - display: none !important ; - } - .uk-hidden-medium { - display: none !important; - } -} -/* Phone landscape and smaller*/ -@media (max-width: 767px) { - .uk-visible-medium { - display: none !important; - } - .uk-visible-large { - display: none !important; - } - .uk-hidden-small { - display: none !important; - } -} -/* Remove from the flow and screen readers on any device */ -.uk-hidden { - display: none !important; - visibility: hidden !important; -} -/* It's hidden, but still affects layout */ -.uk-invisible { - visibility: hidden !important; -} -/* Show on hover */ -.uk-visible-hover:hover .uk-hidden, -.uk-visible-hover:hover .uk-invisible { - display: block !important; - visibility: visible !important; -} -.uk-visible-hover-inline:hover .uk-hidden, -.uk-visible-hover-inline:hover .uk-invisible { - display: inline-block !important; - visibility: visible !important; -} -/* Hide on touch */ -.uk-touch .uk-hidden-touch, -.uk-notouch .uk-hidden-notouch { - display: none !important; -} -/* ======================================================================== - Component: Flex - ========================================================================== */ -.uk-flex { - display: -ms-flexbox; - display: -webkit-flex; - display: flex; -} -.uk-flex-inline { - display: -ms-inline-flexbox; - display: -webkit-inline-flex; - display: inline-flex; -} -/* - * Fixes initial flex-shrink value in IE10 - */ -.uk-flex > *, -.uk-flex-inline > * { - -ms-flex-negative: 1; -} -/* Alignment - ========================================================================== */ -/* - * Vertical alignment - * Default value is `stretch` - */ -.uk-flex-top { - -ms-flex-align: start; - -webkit-align-items: flex-start; - align-items: flex-start; -} -.uk-flex-middle { - -ms-flex-align: center; - -webkit-align-items: center; - align-items: center; -} -.uk-flex-bottom { - -ms-flex-align: end; - -webkit-align-items: flex-end; - align-items: flex-end; -} -/* - * Horizontal alignment - * Default value is `flex-start` - */ -.uk-flex-center { - -ms-flex-pack: center; - -webkit-justify-content: center; - justify-content: center; -} -.uk-flex-right { - -ms-flex-pack: end; - -webkit-justify-content: flex-end; - justify-content: flex-end; -} -.uk-flex-space-between { - -ms-flex-pack: justify; - -webkit-justify-content: space-between; - justify-content: space-between; -} -.uk-flex-space-around { - -ms-flex-pack: distribute; - -webkit-justify-content: space-around; - justify-content: space-around; -} -/* Direction - ========================================================================== */ -.uk-flex-row-reverse { - -ms-flex-direction: row-reverse; - -webkit-flex-direction: row-reverse; - flex-direction: row-reverse; -} -.uk-flex-column { - -ms-flex-direction: column; - -webkit-flex-direction: column; - flex-direction: column; -} -.uk-flex-column-reverse { - -ms-flex-direction: column-reverse; - -webkit-flex-direction: column-reverse; - flex-direction: column-reverse; -} -/* Wrap - ========================================================================== */ -.uk-flex-nowrap { - -ms-flex-wrap: nowrap; - -webkit-flex-wrap: nowrap; - flex-wrap: nowrap; -} -.uk-flex-wrap { - -ms-flex-wrap: wrap; - -webkit-flex-wrap: wrap; - flex-wrap: wrap; -} -.uk-flex-wrap-reverse { - -ms-flex-wrap: wrap-reverse; - -webkit-flex-wrap: wrap-reverse; - flex-wrap: wrap-reverse; -} -/* - * Horizontal alignment - * Default value is `stretch` - */ -.uk-flex-wrap-top { - -ms-flex-line-pack: start; - -webkit-align-content: flex-start; - align-content: flex-start; -} -.uk-flex-wrap-middle { - -ms-flex-line-pack: center; - -webkit-align-content: center; - align-content: center; -} -.uk-flex-wrap-bottom { - -ms-flex-line-pack: end; - -webkit-align-content: flex-end; - align-content: flex-end; -} -.uk-flex-wrap-space-between { - -ms-flex-line-pack: justify; - -webkit-align-content: space-between; - align-content: space-between; -} -.uk-flex-wrap-space-around { - -ms-flex-line-pack: distribute; - -webkit-align-content: space-around; - align-content: space-around; -} -/* Item ordering - ========================================================================== */ -/* - * Default is 0 - */ -.uk-flex-order-first { - -ms-flex-order: -1; - -webkit-order: -1; - order: -1; -} -.uk-flex-order-last { - -ms-flex-order: 99; - -webkit-order: 99; - order: 99; -} -/* Phone landscape and bigger */ -@media (min-width: 480px) { - .uk-flex-order-first-small { - -ms-flex-order: -1; - -webkit-order: -1; - order: -1; - } - .uk-flex-order-last-small { - -ms-flex-order: 99; - -webkit-order: 99; - order: 99; - } -} -/* Tablet and bigger */ -@media (min-width: 768px) { - .uk-flex-order-first-medium { - -ms-flex-order: -1; - -webkit-order: -1; - order: -1; - } - .uk-flex-order-last-medium { - -ms-flex-order: 99; - -webkit-order: 99; - order: 99; - } -} -/* Desktop and bigger */ -@media (min-width: 960px) { - .uk-flex-order-first-large { - -ms-flex-order: -1; - -webkit-order: -1; - order: -1; - } - .uk-flex-order-last-large { - -ms-flex-order: 99; - -webkit-order: 99; - order: 99; - } -} -/* Large screen and bigger */ -@media (min-width: 1220px) { - .uk-flex-order-first-xlarge { - -ms-flex-order: -1; - -webkit-order: -1; - order: -1; - } - .uk-flex-order-last-xlarge { - -ms-flex-order: 99; - -webkit-order: 99; - order: 99; - } -} -/* Item dimensions - ========================================================================== */ -/* - * Initial: 0 1 auto - * Content dimensions, but shrinks - */ -/* - * No Flex: 0 0 auto - * Content dimensions - */ -.uk-flex-item-none { - -ms-flex: none; - -webkit-flex: none; - flex: none; -} -/* - * Relative Flex: 1 1 auto - * Space is allocated considering content - * 1. Fixes flex-shrink value in IE10 - */ -.uk-flex-item-auto { - -ms-flex: auto; - -webkit-flex: auto; - flex: auto; - /* 1 */ - -ms-flex-negative: 1; -} -/* - * Absolute Flex: 1 1 0% - * Space is allocated solely based on flex - */ -.uk-flex-item-1 { - -ms-flex: 1; - -webkit-flex: 1; - flex: 1; -} -/* ======================================================================== - Component: Contrast - ========================================================================== */ -.uk-contrast { - color: #fff; - /* Active */ -} -.uk-contrast a:not([class]), -.uk-contrast .uk-link { - color: rgba(255, 255, 255, 0.7); - text-decoration: none; -} -.uk-contrast a:not([class]):hover, -.uk-contrast .uk-link:hover { - color: #fff; - text-decoration: underline; -} -.uk-contrast :not(pre) > code, -.uk-contrast :not(pre) > kbd, -.uk-contrast :not(pre) > samp { - color: #fff; -} -.uk-contrast em { - color: #fff; -} -.uk-contrast h1, -.uk-contrast h2, -.uk-contrast h3, -.uk-contrast h4, -.uk-contrast h5, -.uk-contrast h6 { - color: #fff; -} -.uk-contrast hr { - border-top-color: rgba(255, 255, 255, 0.2); -} -.uk-contrast .uk-nav li > a, -.uk-contrast .uk-nav li > a:hover { - text-decoration: none; -} -.uk-contrast .uk-nav-side > li > a { - color: #fff; -} -.uk-contrast .uk-nav-side > li > a:hover, -.uk-contrast .uk-nav-side > li > a:focus { - background: rgba(255, 255, 255, 0.1); - color: #fff; -} -.uk-contrast .uk-nav-side > li.uk-active > a { - background: #fff; - color: #444; -} -.uk-contrast .uk-nav-side .uk-nav-header { - color: #fff; -} -.uk-contrast .uk-nav-side .uk-nav-divider { - border-top-color: rgba(255, 255, 255, 0.2); -} -.uk-contrast .uk-nav-side ul a { - color: rgba(255, 255, 255, 0.7); -} -.uk-contrast .uk-nav-side ul a:hover { - color: #fff; -} -.uk-contrast .uk-subnav > * > a { - color: rgba(255, 255, 255, 0.7); - text-decoration: none; -} -.uk-contrast .uk-subnav > * > a:hover, -.uk-contrast .uk-subnav > * > a:focus { - color: #fff; - text-decoration: none; -} -.uk-contrast .uk-subnav > .uk-active > a { - color: #fff; -} -.uk-contrast .uk-subnav-line > :nth-child(n+2):before { - border-left-color: rgba(255, 255, 255, 0.2); -} -.uk-contrast .uk-subnav-pill > * > a:hover, -.uk-contrast .uk-subnav-pill > * > a:focus { - background: rgba(255, 255, 255, 0.7); - color: #444; - text-decoration: none; -} -.uk-contrast .uk-subnav-pill > .uk-active > a { - background: #fff; - color: #444; -} -.uk-contrast .uk-tab { - border-bottom-color: rgba(255, 255, 255, 0.2); -} -.uk-contrast .uk-tab > li > a { - border-color: transparent; - color: rgba(255, 255, 255, 0.7); -} -.uk-contrast .uk-tab > li > a:hover, -.uk-contrast .uk-tab > li > a:focus, -.uk-contrast .uk-tab > li.uk-open > a { - border-color: rgba(255, 255, 255, 0.7); - background: rgba(255, 255, 255, 0.7); - color: #444; - text-decoration: none; -} -.uk-contrast .uk-tab > li.uk-active > a { - border-color: rgba(255, 255, 255, 0.2); - border-bottom-color: transparent; - background: #fff; - color: #444; -} -.uk-contrast .uk-tab-center { - border-bottom-color: rgba(255, 255, 255, 0.2); -} -.uk-contrast .uk-tab-grid:before { - border-top-color: rgba(255, 255, 255, 0.2); -} -.uk-contrast .uk-list-line > li:nth-child(n+2) { - border-top-color: rgba(255, 255, 255, 0.2); -} -.uk-contrast .uk-form select, -.uk-contrast .uk-form textarea, -.uk-contrast .uk-form input:not([type]), -.uk-contrast .uk-form input[type="text"], -.uk-contrast .uk-form input[type="password"], -.uk-contrast .uk-form input[type="datetime"], -.uk-contrast .uk-form input[type="datetime-local"], -.uk-contrast .uk-form input[type="date"], -.uk-contrast .uk-form input[type="month"], -.uk-contrast .uk-form input[type="time"], -.uk-contrast .uk-form input[type="week"], -.uk-contrast .uk-form input[type="number"], -.uk-contrast .uk-form input[type="email"], -.uk-contrast .uk-form input[type="url"], -.uk-contrast .uk-form input[type="search"], -.uk-contrast .uk-form input[type="tel"], -.uk-contrast .uk-form input[type="color"] { - border-color: rgba(255, 255, 255, 0.8); - background: rgba(255, 255, 255, 0.8); - color: #444; - background-clip: padding-box; -} -.uk-contrast .uk-form select:focus, -.uk-contrast .uk-form textarea:focus, -.uk-contrast .uk-form input:not([type]):focus, -.uk-contrast .uk-form input[type="text"]:focus, -.uk-contrast .uk-form input[type="password"]:focus, -.uk-contrast .uk-form input[type="datetime"]:focus, -.uk-contrast .uk-form input[type="datetime-local"]:focus, -.uk-contrast .uk-form input[type="date"]:focus, -.uk-contrast .uk-form input[type="month"]:focus, -.uk-contrast .uk-form input[type="time"]:focus, -.uk-contrast .uk-form input[type="week"]:focus, -.uk-contrast .uk-form input[type="number"]:focus, -.uk-contrast .uk-form input[type="email"]:focus, -.uk-contrast .uk-form input[type="url"]:focus, -.uk-contrast .uk-form input[type="search"]:focus, -.uk-contrast .uk-form input[type="tel"]:focus, -.uk-contrast .uk-form input[type="color"]:focus { - border-color: #fff; - background: #fff; - color: #444; -} -.uk-contrast .uk-form :-ms-input-placeholder { - color: rgba(68, 68, 68, 0.7) !important; -} -.uk-contrast .uk-form ::-moz-placeholder { - color: rgba(68, 68, 68, 0.7); -} -.uk-contrast .uk-form ::-webkit-input-placeholder { - color: rgba(68, 68, 68, 0.7); -} -.uk-contrast .uk-button { - color: #444; - background: #fff; -} -.uk-contrast .uk-button:hover, -.uk-contrast .uk-button:focus { - background-color: rgba(255, 255, 255, 0.8); - color: #444; -} -.uk-contrast .uk-button:active, -.uk-contrast .uk-button.uk-active { - background-color: rgba(255, 255, 255, 0.7); - color: #444; -} -.uk-contrast .uk-button-primary { - background-color: #00a8e6; - color: #fff; -} -.uk-contrast .uk-button-primary:hover, -.uk-contrast .uk-button-primary:focus { - background-color: #35b3ee; - color: #fff; -} -.uk-contrast .uk-button-primary:active, -.uk-contrast .uk-button-primary.uk-active { - background-color: #0091ca; - color: #fff; -} -.uk-contrast .uk-icon-hover { - color: rgba(255, 255, 255, 0.7); -} -.uk-contrast .uk-icon-hover:hover { - color: #fff; -} -.uk-contrast .uk-icon-button { - background: #fff; - color: #444; -} -.uk-contrast .uk-icon-button:hover, -.uk-contrast .uk-icon-button:focus { - background-color: rgba(255, 255, 255, 0.8); - color: #444; -} -.uk-contrast .uk-icon-button:active { - background-color: rgba(255, 255, 255, 0.7); - color: #444; -} -.uk-contrast .uk-text-muted { - color: rgba(255, 255, 255, 0.6) !important; -} -.uk-contrast .uk-text-primary { - color: #2d7091 !important; -} -/* ======================================================================== - Component: Print - ========================================================================== */ -@media print { - *, - *:before, - *:after { - background: transparent !important; - color: black !important; - box-shadow: none !important; - text-shadow: none !important; - } - a, - a:visited { - text-decoration: underline; - } - pre, - blockquote { - border: 1px solid #999; - page-break-inside: avoid; - } - thead { - display: table-header-group; - } - tr, - img { - page-break-inside: avoid; - } - img { - max-width: 100% !important; - } - @page { - margin: 0.5cm; - } - p, - h2, - h3 { - orphans: 3; - widows: 3; - } - h2, - h3 { - page-break-after: avoid; - } -} diff --git a/packages/test-data/css/_main/colors2.css b/packages/test-data/css/_main/colors2.css new file mode 100644 index 000000000..e23287f26 --- /dev/null +++ b/packages/test-data/css/_main/colors2.css @@ -0,0 +1,6 @@ +foo { + color: #0080ff; + color: rgba(0, 128, 255, 0.5); + color: hsl(198, 28%, 50%); + color: hsla(198, 28%, 50%, 0.5); +} diff --git a/packages/test-data/css/_main/functions.css b/packages/test-data/css/_main/functions.css index 99323620e..56ab9ea02 100644 --- a/packages/test-data/css/_main/functions.css +++ b/packages/test-data/css/_main/functions.css @@ -111,6 +111,7 @@ min: 3mm; max: 3; max: 5em; + max-native: max(10vw, 100px); percentage: 20%; color-quoted-digit: #dda0dd; color-quoted-keyword: #dda0dd; @@ -139,6 +140,8 @@ mixt: rgba(255, 0, 0, 0.5); } #built-in .is-a { + rules-defined: true; + foo-defined: false; ruleset: true; color: true; color1: true; @@ -232,3 +235,12 @@ html { color: green; color: purple; } +.paren-escapes { + list-1: 1, 2, 3; + length-1: 3; + item-1: 4; + item-2: 5; + item-3: 6; + list-2: 1, 2, 3; + list-3: 7, 8, 9; +} diff --git a/packages/test-data/css/_main/import-remote.css b/packages/test-data/css/_main/import-remote.css index 23ef8dbcc..e32befca0 100644 --- a/packages/test-data/css/_main/import-remote.css +++ b/packages/test-data/css/_main/import-remote.css @@ -1,3 +1,3 @@ .test { - color: blue; + color: 42; } diff --git a/packages/test-data/css/no-strict-math/mixins-guards.css b/packages/test-data/css/math/always/mixins-guards.css similarity index 100% rename from packages/test-data/css/no-strict-math/mixins-guards.css rename to packages/test-data/css/math/always/mixins-guards.css diff --git a/packages/test-data/css/no-strict-math/no-sm-operations.css b/packages/test-data/css/math/always/no-sm-operations.css similarity index 100% rename from packages/test-data/css/no-strict-math/no-sm-operations.css rename to packages/test-data/css/math/always/no-sm-operations.css diff --git a/packages/test-data/css/math/parens-division/mixins-args.css b/packages/test-data/css/math/parens-division/mixins-args.css index ca82850f1..82407441e 100644 --- a/packages/test-data/css/math/parens-division/mixins-args.css +++ b/packages/test-data/css/math/parens-division/mixins-args.css @@ -16,11 +16,6 @@ height: 49%; depth: 49%; } -.no-parens { - width: 5px; - height: 49%; - depth: 49%; -} .no-args { width: 5px; height: 49%; diff --git a/packages/test-data/css/math/strict-legacy/css.css b/packages/test-data/css/math/strict-legacy/css.css deleted file mode 100644 index 633640781..000000000 --- a/packages/test-data/css/math/strict-legacy/css.css +++ /dev/null @@ -1,95 +0,0 @@ -@charset "utf-8"; -div { - color: black; -} -div { - width: 99%; -} -* { - min-width: 45em; -} -h1, -h2 > a > p, -h3 { - color: none; -} -div.class { - color: blue; -} -div#id { - color: green; -} -.class#id { - color: purple; -} -.one.two.three { - color: grey; -} -@media print { - * { - font-size: 3em; - } -} -@media screen { - * { - font-size: 10px; - } -} -@font-face { - font-family: 'Garamond Pro'; -} -a:hover, -a:link { - color: #999; -} -p, -p:first-child { - text-transform: none; -} -q:lang(no) { - quotes: none; -} -p + h1 { - font-size: 2.2em; -} -#shorthands { - border: 1px solid #000; - font: 12px/16px Arial; - font: 100%/16px Arial; - margin: 1px 0; - padding: 0 auto; -} -#more-shorthands { - margin: 0; - padding: 1px 0 2px 0; - font: normal small / 20px 'Trebuchet MS', Verdana, sans-serif; - font: 0/0 a; - border-radius: 5px / 10px; -} -.misc { - -moz-border-radius: 2px; - display: -moz-inline-stack; - width: 0.1em; - background-color: #009998; - background: -webkit-gradient(linear, left top, left bottom, from(red), to(blue)); - margin: ; - filter: alpha(opacity=100); - width: auto\9; -} -.misc .nested-multiple { - multiple-semi-colons: yes; -} -#important { - color: red !important; - width: 100%!important; - height: 20px ! important; -} -@font-face { - font-family: font-a; -} -@font-face { - font-family: font-b; -} -.æøå { - margin: 0; -} diff --git a/packages/test-data/css/math/strict-legacy/media-math.css b/packages/test-data/css/math/strict-legacy/media-math.css deleted file mode 100644 index 1d2452a0a..000000000 --- a/packages/test-data/css/math/strict-legacy/media-math.css +++ /dev/null @@ -1,10 +0,0 @@ -@media (min-width: 16 + 1) { - .foo { - bar: 1; - } -} -@media (min-width: 16 / 9) { - .foo { - bar: 1; - } -} diff --git a/packages/test-data/css/math/strict-legacy/mixins-args.css b/packages/test-data/css/math/strict-legacy/mixins-args.css deleted file mode 100644 index f5d37b20f..000000000 --- a/packages/test-data/css/math/strict-legacy/mixins-args.css +++ /dev/null @@ -1,163 +0,0 @@ -#hidden { - color: transparent; -} -#hidden1 { - color: transparent; -} -.two-args { - color: blue; - width: 10px; - height: 99%; - border: 2px dotted black; -} -.one-arg { - width: 15px; - height: 49%; -} -.no-parens { - width: 5px; - height: 49%; -} -.no-args { - width: 5px; - height: 49%; -} -.var-args { - width: 45; - height: 17%; -} -.multi-mix { - width: 10px; - height: 29%; - margin: 4; - padding: 5; -} -body { - padding: 30px; - color: #f00; -} -.scope-mix { - width: 8; -} -.content { - width: 600px; -} -.content .column { - margin: 600px; -} -#same-var-name { - radius: 5px; -} -#var-inside { - width: 10px; -} -.arguments { - border: 1px solid black; - width: 1px; -} -.arguments2 { - border: 0px; - width: 0px; -} -.arguments3 { - border: 0px; - width: 0px; -} -.arguments4 { - border: 0 1 2 3 4; - rest: 1 2 3 4; - width: 0; -} -.edge-case { - border: "{"; - width: "{"; -} -.slash-vs-math { - border-radius: 2px/5px; - border-radius: 5px/10px; - border-radius: 6px; -} -.comma-vs-semi-colon { - one: a; - two: b, c; - one: d, e; - two: f; - one: g; - one: h; - one: i; - one: j; - one: k; - two: l; - one: m, n; - one: o, p; - two: q; - one: r, s; - two: t; -} -#named-conflict { - four: a, 11, 12, 13; - four: a, 21, 22, 23; -} -.test-rule-mixin-default-arg { - defaults: 1px 1px 1px; - defaults: 2px 2px 2px; -} -.selector { - margin: 2, 2, 2, 2; -} -.selector2 { - margin: 2, 2, 2, 2; -} -.selector3 { - margin: 4; -} -mixins-args-expand-op-1 { - m3: 1, 2, 3; -} -mixins-args-expand-op-2 { - m3: 4, 5, 6; -} -mixins-args-expand-op-3a { - m3: a, b, c; -} -mixins-args-expand-op-3b { - m4: 0, a, b, c; -} -mixins-args-expand-op-3c { - m4: a, b, c, 4; -} -mixins-args-expand-op-4a { - m3: a, b, c, d; -} -mixins-args-expand-op-4b { - m4: 0, a, b, c, d; -} -mixins-args-expand-op-4c { - m4: a, b, c, d, 4; -} -mixins-args-expand-op-5a { - m3: 1, 2, 3; -} -mixins-args-expand-op-5b { - m4: 0, 1, 2, 3; -} -mixins-args-expand-op-5c { - m4: 1, 2, 3, 4; -} -mixins-args-expand-op-6 { - m4: 0, 1, 2, 3; -} -mixins-args-expand-op-7 { - m4: 0, 1, 2, 3; -} -mixins-args-expand-op-8 { - m4: 1, 1.5, 2, 3; -} -mixins-args-expand-op-9 { - aa: 4 5 6 1 2 3 and again 4 5 6; - a4: and; - a8: 5; -} -#test-mixin-matching-when-default-2645 { - height: 20px; -} diff --git a/packages/test-data/css/math/strict-legacy/parens.css b/packages/test-data/css/math/strict-legacy/parens.css deleted file mode 100644 index 89fe108a3..000000000 --- a/packages/test-data/css/math/strict-legacy/parens.css +++ /dev/null @@ -1,40 +0,0 @@ -.parens { - border: 2px solid black; - margin: 1px 3px 16 3; - width: 36; - padding: 2px 36px; -} -.in-function { - value: 2 + 1; -} -.more-parens { - padding: 8 4 4 4px; - width-all: 96; - width-first: 16 * 6; - width-keep: (4 * 4) * 6; - height: calc(100% + (25vh - 20px)); - height-keep: (7 * 7) + (8 * 8); - height-all: 113; - height-parts: 49 + 64; - margin-keep: (4 * (5 + 5) / 2) - (4 * 2); - margin-parts: 20 - 8; - margin-all: 12; - border-radius-keep: 4px * (1 + 1) / 4 + 3px; - border-radius-parts: 8px / 7px; - border-radius-all: 5px; -} -.negative { - neg-var: -1; - neg-var-paren: -1; -} -.nested-parens { - width: 2 * (4 * (2 + (1 + 6))) - 1; - height: ((2 + 3) * (2 + 3) / (9 - 4)) + 1; -} -.mixed-units { - margin: 2px 4em 1 5pc; - padding: 6px 1em 2px 2; -} -.test-rule-false-negatives { - a: (; -} diff --git a/packages/test-data/css/math/strict/mixins-args.css b/packages/test-data/css/math/strict/mixins-args.css index 138ce0ae3..78ce9a85d 100644 --- a/packages/test-data/css/math/strict/mixins-args.css +++ b/packages/test-data/css/math/strict/mixins-args.css @@ -16,11 +16,6 @@ height: 49%; depth: 50% - 1%; } -.no-parens { - width: 5px; - height: 49%; - depth: 50% - 1%; -} .no-args { width: 5px; height: 49%; diff --git a/packages/test-data/css/legacy/legacy.css b/packages/test-data/css/units/no-strict/no-strict.css similarity index 100% rename from packages/test-data/css/legacy/legacy.css rename to packages/test-data/css/units/no-strict/no-strict.css diff --git a/packages/test-data/css/strict-units/strict-units.css b/packages/test-data/css/units/strict/strict-units.css similarity index 100% rename from packages/test-data/css/strict-units/strict-units.css rename to packages/test-data/css/units/strict/strict-units.css diff --git a/packages/test-data/errors/eval/color-func-invalid-color-2.txt b/packages/test-data/errors/eval/color-func-invalid-color-2.txt index 39dd5887c..4f5701761 100644 --- a/packages/test-data/errors/eval/color-func-invalid-color-2.txt +++ b/packages/test-data/errors/eval/color-func-invalid-color-2.txt @@ -1,3 +1,3 @@ -RuntimeError: error evaluating function `darken`: Argument cannot be evaluated to a color in {path}color-func-invalid-color-2.less on line 2, column 14: +RuntimeError: Error evaluating function `darken`: Argument cannot be evaluated to a color in {path}color-func-invalid-color-2.less on line 2, column 14: 1 // https://github.com/less/less.js/issues/3338 2 @base-color: darken(var(--baseColor, red), 50%); diff --git a/packages/test-data/errors/eval/color-func-invalid-color.txt b/packages/test-data/errors/eval/color-func-invalid-color.txt index c96013034..a5a7a112a 100644 --- a/packages/test-data/errors/eval/color-func-invalid-color.txt +++ b/packages/test-data/errors/eval/color-func-invalid-color.txt @@ -1,4 +1,4 @@ -ArgumentError: error evaluating function `color`: argument must be a color keyword or 3|4|6|8 digit hex e.g. #FFF in {path}color-func-invalid-color.less on line 2, column 10: +ArgumentError: Error evaluating function `color`: argument must be a color keyword or 3|4|6|8 digit hex e.g. #FFF in {path}color-func-invalid-color.less on line 2, column 10: 1 .test-rule { 2 color: color("NOT A COLOR"); 3 } diff --git a/packages/test-data/errors/eval/css-guard-default-func.txt b/packages/test-data/errors/eval/css-guard-default-func.txt index 022f5222e..4b101d81a 100644 --- a/packages/test-data/errors/eval/css-guard-default-func.txt +++ b/packages/test-data/errors/eval/css-guard-default-func.txt @@ -1,4 +1,4 @@ -SyntaxError: error evaluating function `default`: it is currently only allowed in parametric mixin guards, in {path}css-guard-default-func.less on line 2, column 16: +SyntaxError: Error evaluating function `default`: it is currently only allowed in parametric mixin guards, in {path}css-guard-default-func.less on line 2, column 16: 1 2 selector when (default()) { 3 color: red; diff --git a/packages/test-data/errors/eval/functions-1.txt b/packages/test-data/errors/eval/functions-1.txt index d029986ee..66696123d 100644 --- a/packages/test-data/errors/eval/functions-1.txt +++ b/packages/test-data/errors/eval/functions-1.txt @@ -1,3 +1,3 @@ -SyntaxError: Function 'test-undefined' is undefined in {path}functions-1.less on line 2, column 1: +SyntaxError: Function 'test-undefined' did not return a root node in {path}functions-1.less on line 2, column 1: 1 @plugin "../../plugin/plugin-tree-nodes"; 2 test-undefined(); diff --git a/packages/test-data/errors/eval/functions-4-call.txt b/packages/test-data/errors/eval/functions-4-call.txt index 3d57bc0f2..4144723f9 100644 --- a/packages/test-data/errors/eval/functions-4-call.txt +++ b/packages/test-data/errors/eval/functions-4-call.txt @@ -1,3 +1,3 @@ -SyntaxError: Function 'foo' is undefined in {path}functions-4-call.less on line 2, column 1: +SyntaxError: Function 'foo' did not return a root node in {path}functions-4-call.less on line 2, column 1: 1 @plugin "../../plugin/plugin-tree-nodes"; 2 test-call(); diff --git a/packages/test-data/errors/eval/mixin-not-visible-in-scope-1.less b/packages/test-data/errors/eval/mixin-not-visible-in-scope-1.less index 2842613ef..4ba2e3a49 100644 --- a/packages/test-data/errors/eval/mixin-not-visible-in-scope-1.less +++ b/packages/test-data/errors/eval/mixin-not-visible-in-scope-1.less @@ -4,6 +4,6 @@ } & { - .b {.a} // was Err. before 1.6.2 + .b {.a()} // was Err. before 1.6.2 } } \ No newline at end of file diff --git a/packages/test-data/errors/eval/mixin-not-visible-in-scope-1.txt b/packages/test-data/errors/eval/mixin-not-visible-in-scope-1.txt index 15e64dc20..1d8b96cef 100644 --- a/packages/test-data/errors/eval/mixin-not-visible-in-scope-1.txt +++ b/packages/test-data/errors/eval/mixin-not-visible-in-scope-1.txt @@ -1,4 +1,4 @@ NameError: .a is undefined in {path}mixin-not-visible-in-scope-1.less on line 7, column 13: 6 & { -7 .b {.a} // was Err. before 1.6.2 +7 .b {.a()} // was Err. before 1.6.2 8 } diff --git a/packages/test-data/errors/eval/percentage-non-number-argument.txt b/packages/test-data/errors/eval/percentage-non-number-argument.txt index f01a1e546..c96dfca79 100644 --- a/packages/test-data/errors/eval/percentage-non-number-argument.txt +++ b/packages/test-data/errors/eval/percentage-non-number-argument.txt @@ -1,4 +1,4 @@ -ArgumentError: error evaluating function `percentage`: argument must be a number in {path}percentage-non-number-argument.less on line 2, column 15: +ArgumentError: Error evaluating function `percentage`: argument must be a number in {path}percentage-non-number-argument.less on line 2, column 15: 1 div { 2 percentage: percentage(16/17); 3 } diff --git a/packages/test-data/errors/eval/recursive-variable.txt b/packages/test-data/errors/eval/recursive-variable.txt index b8bd6fdd9..9e7e22542 100644 --- a/packages/test-data/errors/eval/recursive-variable.txt +++ b/packages/test-data/errors/eval/recursive-variable.txt @@ -1,2 +1,2 @@ -NameError: error evaluating function `darken`: Recursive variable definition for @bodyColor in {path}recursive-variable.less on line 1, column 13: +NameError: Error evaluating function `darken`: Recursive variable definition for @bodyColor in {path}recursive-variable.less on line 1, column 13: 1 @bodyColor: darken(@bodyColor, 30%); diff --git a/packages/test-data/errors/eval/root-func-undefined-1.txt b/packages/test-data/errors/eval/root-func-undefined-1.txt index a07480e61..563725a27 100644 --- a/packages/test-data/errors/eval/root-func-undefined-1.txt +++ b/packages/test-data/errors/eval/root-func-undefined-1.txt @@ -1,2 +1,2 @@ -SyntaxError: Function 'func' is undefined in {path}root-func-undefined-1.less on line 1, column 1: +SyntaxError: Function 'func' did not return a root node in {path}root-func-undefined-1.less on line 1, column 1: 1 func(); diff --git a/packages/test-data/errors/eval/root-func-undefined-2.txt b/packages/test-data/errors/eval/root-func-undefined-2.txt index 4c88b97d9..d553673ef 100644 --- a/packages/test-data/errors/eval/root-func-undefined-2.txt +++ b/packages/test-data/errors/eval/root-func-undefined-2.txt @@ -1,3 +1,3 @@ -SyntaxError: Function 'test-undefined' is undefined in {path}root-func-undefined-2.less on line 2, column 1: +SyntaxError: Function 'test-undefined' did not return a root node in {path}root-func-undefined-2.less on line 2, column 1: 1 @plugin "../../plugin/plugin-tree-nodes.js"; 2 test-undefined(); diff --git a/packages/test-data/errors/eval/svg-gradient1.txt b/packages/test-data/errors/eval/svg-gradient1.txt index ec662fe60..65ed9af7c 100644 --- a/packages/test-data/errors/eval/svg-gradient1.txt +++ b/packages/test-data/errors/eval/svg-gradient1.txt @@ -1,4 +1,4 @@ -ArgumentError: error evaluating function `svg-gradient`: svg-gradient direction must be 'to bottom', 'to right', 'to bottom right', 'to top right' or 'ellipse at center' in {path}svg-gradient1.less on line 2, column 6: +ArgumentError: Error evaluating function `svg-gradient`: svg-gradient direction must be 'to bottom', 'to right', 'to bottom right', 'to top right' or 'ellipse at center' in {path}svg-gradient1.less on line 2, column 6: 1 .a { 2 a: svg-gradient(horizontal, black, white); 3 } diff --git a/packages/test-data/errors/eval/svg-gradient2.txt b/packages/test-data/errors/eval/svg-gradient2.txt index 1f2e1bfc9..45548cbc3 100644 --- a/packages/test-data/errors/eval/svg-gradient2.txt +++ b/packages/test-data/errors/eval/svg-gradient2.txt @@ -1,4 +1,4 @@ -ArgumentError: error evaluating function `svg-gradient`: svg-gradient expects direction, start_color [start_position], [color position,]..., end_color [end_position] or direction, color list in {path}svg-gradient2.less on line 2, column 6: +ArgumentError: Error evaluating function `svg-gradient`: svg-gradient expects direction, start_color [start_position], [color position,]..., end_color [end_position] or direction, color list in {path}svg-gradient2.less on line 2, column 6: 1 .a { 2 a: svg-gradient(to bottom, black, orange, 45%, white); 3 } diff --git a/packages/test-data/errors/eval/svg-gradient3.txt b/packages/test-data/errors/eval/svg-gradient3.txt index f77a353ac..9a19a74f9 100644 --- a/packages/test-data/errors/eval/svg-gradient3.txt +++ b/packages/test-data/errors/eval/svg-gradient3.txt @@ -1,4 +1,4 @@ -ArgumentError: error evaluating function `svg-gradient`: svg-gradient direction must be 'to bottom', 'to right', 'to bottom right', 'to top right' or 'ellipse at center' in {path}svg-gradient3.less on line 2, column 6: +ArgumentError: Error evaluating function `svg-gradient`: svg-gradient direction must be 'to bottom', 'to right', 'to bottom right', 'to top right' or 'ellipse at center' in {path}svg-gradient3.less on line 2, column 6: 1 .a { 2 a: svg-gradient(black, orange); 3 } diff --git a/packages/test-data/errors/eval/svg-gradient4.txt b/packages/test-data/errors/eval/svg-gradient4.txt index c0d41e94f..102d03c8c 100644 --- a/packages/test-data/errors/eval/svg-gradient4.txt +++ b/packages/test-data/errors/eval/svg-gradient4.txt @@ -1,4 +1,4 @@ -ArgumentError: error evaluating function `svg-gradient`: svg-gradient direction must be 'to bottom', 'to right', 'to bottom right', 'to top right' or 'ellipse at center' in {path}svg-gradient4.less on line 2, column 6: +ArgumentError: Error evaluating function `svg-gradient`: svg-gradient direction must be 'to bottom', 'to right', 'to bottom right', 'to top right' or 'ellipse at center' in {path}svg-gradient4.less on line 2, column 6: 1 .a { 2 a: svg-gradient(horizontal, @colors); 3 } diff --git a/packages/test-data/errors/eval/svg-gradient5.txt b/packages/test-data/errors/eval/svg-gradient5.txt index 41f8f46f2..9a501ddc9 100644 --- a/packages/test-data/errors/eval/svg-gradient5.txt +++ b/packages/test-data/errors/eval/svg-gradient5.txt @@ -1,4 +1,4 @@ -ArgumentError: error evaluating function `svg-gradient`: svg-gradient expects direction, start_color [start_position], [color position,]..., end_color [end_position] or direction, color list in {path}svg-gradient5.less on line 2, column 6: +ArgumentError: Error evaluating function `svg-gradient`: svg-gradient expects direction, start_color [start_position], [color position,]..., end_color [end_position] or direction, color list in {path}svg-gradient5.less on line 2, column 6: 1 .a { 2 a: svg-gradient(to bottom, @colors); 3 } diff --git a/packages/test-data/errors/eval/svg-gradient6.txt b/packages/test-data/errors/eval/svg-gradient6.txt index 2ce85cf6b..8743cb1da 100644 --- a/packages/test-data/errors/eval/svg-gradient6.txt +++ b/packages/test-data/errors/eval/svg-gradient6.txt @@ -1,4 +1,4 @@ -ArgumentError: error evaluating function `svg-gradient`: svg-gradient direction must be 'to bottom', 'to right', 'to bottom right', 'to top right' or 'ellipse at center' in {path}svg-gradient6.less on line 2, column 6: +ArgumentError: Error evaluating function `svg-gradient`: svg-gradient direction must be 'to bottom', 'to right', 'to bottom right', 'to top right' or 'ellipse at center' in {path}svg-gradient6.less on line 2, column 6: 1 .a { 2 a: svg-gradient(black, @colors); 3 } diff --git a/packages/test-data/errors/eval/unit-function.txt b/packages/test-data/errors/eval/unit-function.txt index baf90f422..e680324bc 100644 --- a/packages/test-data/errors/eval/unit-function.txt +++ b/packages/test-data/errors/eval/unit-function.txt @@ -1,4 +1,4 @@ -ArgumentError: error evaluating function `unit`: the first argument to unit must be a number. Have you forgotten parenthesis? in {path}unit-function.less on line 2, column 14: +ArgumentError: Error evaluating function `unit`: the first argument to unit must be a number. Have you forgotten parenthesis? in {path}unit-function.less on line 2, column 14: 1 .a { 2 font-size: unit(80/16,rem); 3 } diff --git a/packages/test-data/less/3rd-party/uikit.less b/packages/test-data/less/3rd-party/uikit.less deleted file mode 100644 index b8ac9a70a..000000000 --- a/packages/test-data/less/3rd-party/uikit.less +++ /dev/null @@ -1 +0,0 @@ -@import "uikit/src/less/uikit"; \ No newline at end of file diff --git a/packages/test-data/less/_main/colors2.less b/packages/test-data/less/_main/colors2.less new file mode 100644 index 000000000..12837736a --- /dev/null +++ b/packages/test-data/less/_main/colors2.less @@ -0,0 +1,6 @@ +foo { + color: rgb(0 128 255); + color: rgb(0 128 255 / 50%); + color: hsl(198deg 28% 50%); + color: hsl(198deg 28% 50% / 50%); +} \ No newline at end of file diff --git a/packages/test-data/less/_main/css-escapes.less b/packages/test-data/less/_main/css-escapes.less index a132f39f4..cf42940e7 100644 --- a/packages/test-data/less/_main/css-escapes.less +++ b/packages/test-data/less/_main/css-escapes.less @@ -14,7 +14,7 @@ strong { color: @ugly; - .mixin\!tUp; + .mixin\!tUp(); } } diff --git a/packages/test-data/less/_main/directives-bubling.less b/packages/test-data/less/_main/directives-bubling.less index be3523869..8217ecc36 100644 --- a/packages/test-data/less/_main/directives-bubling.less +++ b/packages/test-data/less/_main/directives-bubling.less @@ -122,7 +122,7 @@ } html { - .nestedSupportsMixin; + .nestedSupportsMixin(); } // selectors should not propagate into all directive types diff --git a/packages/test-data/less/_main/extract-and-length.less b/packages/test-data/less/_main/extract-and-length.less index d064bdb9d..8de68d1e8 100644 --- a/packages/test-data/less/_main/extract-and-length.less +++ b/packages/test-data/less/_main/extract-and-length.less @@ -5,12 +5,12 @@ .a(@i: length(@cols)) when (@i > 0) { @divider: e(extract(@cols, @i)); } -.a; +.a(); .b(@j: 1) when (@j < length(@cols)) { @divider: e(extract(@cols, @j)); } -.b; +.b(); // simple array/list: diff --git a/packages/test-data/less/_main/functions.less b/packages/test-data/less/_main/functions.less index f6db3b41c..bad7b5cdb 100644 --- a/packages/test-data/less/_main/functions.less +++ b/packages/test-data/less/_main/functions.less @@ -118,6 +118,7 @@ min: min(1cm, 3mm); max: max(1, 3); max: max(3em, 1em, 2em, 5em); + max-native: max(10vw, 100px); percentage: percentage((10px / 50)); color-quoted-digit: color("#dda0dd"); color-quoted-keyword: color("plum"); @@ -152,6 +153,8 @@ @rules: { color: red; }; + rules-defined: isdefined(@rules); + foo-defined: isdefined(@foo); ruleset: isruleset(@rules); color: iscolor(#ddd); color1: iscolor(red); @@ -282,3 +285,17 @@ html { }); @falsey(); } + +.paren-escapes { + list-1: ~(1, 2, 3); + length-1: length($list-1); + each(~(1 2 3); { + item-@{value}: @value + 3; + }) + + .mixin(@list-1; @list-2) { + list-2: @list-1; + list-3: @list-2; + } + .mixin($list-1, ~(7; 8; 9)); +} diff --git a/packages/test-data/less/_main/import-remote.less b/packages/test-data/less/_main/import-remote.less index 6e2a947cf..b7f1b6350 100644 --- a/packages/test-data/less/_main/import-remote.less +++ b/packages/test-data/less/_main/import-remote.less @@ -1,8 +1,8 @@ // https://github.com/less/less.js/issues/3541 @import (reference) url(https://cdn.jsdelivr.net/npm/@less/test-data/less/_main/selectors.less); -@import (reference) url("https://cdn.jsdelivr.net/npm/@less/test-data/less/_main/scope.less"); +@import (reference) url("https://cdn.jsdelivr.net/npm/@less/test-data/less/_main/media.less"); @import (reference) url("https://cdn.jsdelivr.net/npm/@less/test-data/less/_main/empty.less?arg"); .test { - color: @x; + color: @var; } \ No newline at end of file diff --git a/packages/test-data/less/_main/import.less b/packages/test-data/less/_main/import.less index 2b0d19ed5..e7d175692 100644 --- a/packages/test-data/less/_main/import.less +++ b/packages/test-data/less/_main/import.less @@ -9,7 +9,7 @@ @import url("//ha.com/file.css") (min-width:@var); #import-test { - .mixin; + .mixin(); width: 10px; height: (@a + 10%); value: pi-anon(); diff --git a/packages/test-data/less/_main/import/import-and-relative-paths-test.less b/packages/test-data/less/_main/import/import-and-relative-paths-test.less index d6256c6b8..6d8286b55 100644 --- a/packages/test-data/less/_main/import/import-and-relative-paths-test.less +++ b/packages/test-data/less/_main/import/import-and-relative-paths-test.less @@ -12,6 +12,6 @@ } #imported-relative-path { - .unquoted-relative-path-bg; - .quoted-relative-path-border-image; + .unquoted-relative-path-bg(); + .quoted-relative-path-border-image(); } \ No newline at end of file diff --git a/packages/test-data/less/_main/mixins-closure.less b/packages/test-data/less/_main/mixins-closure.less index 26c8b6e90..d60378f9b 100644 --- a/packages/test-data/less/_main/mixins-closure.less +++ b/packages/test-data/less/_main/mixins-closure.less @@ -6,12 +6,12 @@ } .class { - .scope > .mixin; + .scope > .mixin(); } .overwrite { @var: 0px; - .scope > .mixin; + .scope > .mixin(); } .nested { @@ -21,6 +21,6 @@ } .class { @var: 10px; - .mixin; + .mixin(); } } diff --git a/packages/test-data/less/_main/mixins-guards.less b/packages/test-data/less/_main/mixins-guards.less index 338ece786..6a88f52cd 100644 --- a/packages/test-data/less/_main/mixins-guards.less +++ b/packages/test-data/less/_main/mixins-guards.less @@ -60,7 +60,7 @@ .default (@a: inherit) when (@a = inherit) { content: default; } -.default1 { .default } +.default1 { .default() } // true & false keywords .test-rule (@a) when (@a) { @@ -94,7 +94,7 @@ .bool () when not (true) and not (true) { content: not true and not true } .bool () when not (false) and (false), not (false) { content: not false and false, not false } -.bool1 { .bool } +.bool1 { .bool() } .equality-unit-test(@num) when (@num = 1%) { test: fail; diff --git a/packages/test-data/less/_main/mixins-important.less b/packages/test-data/less/_main/mixins-important.less index ecdb29234..0733db6af 100644 --- a/packages/test-data/less/_main/mixins-important.less +++ b/packages/test-data/less/_main/mixins-important.less @@ -20,7 +20,7 @@ .mixin(3); .mixin(4) !important; .mixin(5); - .mixin !important; + .mixin() !important; .mixin(9); } .size(@aaa: auto) { diff --git a/packages/test-data/less/_main/mixins-interpolated.less b/packages/test-data/less/_main/mixins-interpolated.less index b79fa89a6..4be88c991 100644 --- a/packages/test-data/less/_main/mixins-interpolated.less +++ b/packages/test-data/less/_main/mixins-interpolated.less @@ -25,9 +25,9 @@ } mi-test-a { - .123; - .foo; - #foo; + .123(); + .foo(); + #foo(); } .b .bb { @@ -39,7 +39,7 @@ mi-test-a { } mi-test-b { - .b.bb.foo-xxx.yyy-foo#foo.foo.bbb; + .b.bb.foo-xxx.yyy-foo#foo.foo.bbb(); } @c1: @a1; @@ -55,9 +55,9 @@ mi-test-b { } mi-test-c { - &-1 {#foo-foo;} - &-2 {#foo-foo > .bar;} - &-3 {#foo-foo > .bar.baz;} + &-1 {#foo-foo();} + &-2 {#foo-foo > .bar();} + &-3 {#foo-foo > .bar.baz();} } .Person(@name, @gender_) { diff --git a/packages/test-data/less/_main/mixins.less b/packages/test-data/less/_main/mixins.less index 7ffa9dacc..b887c860d 100644 --- a/packages/test-data/less/_main/mixins.less +++ b/packages/test-data/less/_main/mixins.less @@ -21,30 +21,30 @@ } #container { color: black; - .mixin; - .mixout; - #theme > .mixin; + .mixin(); + .mixout(); + #theme > .mixin(); } #header { .milk { color: inherit; - .mixin; - #theme > .mixin; + .mixin(); + #theme > .mixin(); } #cookie { .chips { - #namespace .borders; + #namespace .borders(); .calories { - #container; + #container(); } } - .borders; + .borders(); } } -.secure-zone { #namespace .biohazard .man; } +.secure-zone { #namespace .biohazard .man(); } .direct { - #namespace > .borders; + #namespace > .borders(); } .bo, .bar { @@ -71,11 +71,11 @@ } } .extended { - .bo; - .jo.ki; - .amp.support; - .amp.support.higher; - .amp.support.deeper; + .bo(); + .jo.ki(); + .amp.support(); + .amp.support.higher(); + .amp.support.deeper(); } .do .re .mi .fa { .sol .la { @@ -85,10 +85,10 @@ } } .mutli-selector-parents { - .do.re.mi.fa.sol.la.si; + .do.re.mi.fa.sol.la.si(); } .foo .bar { - .bar; + .bar(); } .has_parents() { & .underParents { diff --git a/packages/test-data/less/_main/scope.less b/packages/test-data/less/_main/scope.less index 13d01a170..5cdcc74bc 100644 --- a/packages/test-data/less/_main/scope.less +++ b/packages/test-data/less/_main/scope.less @@ -9,7 +9,7 @@ @mix: blue; .tiny-scope { color: @mix; // #989 - .mixin; + .mixin(); } .scope1 { @@ -57,7 +57,7 @@ } .importRuleset(); .testImported { - .imported; + .imported(); } @parameterDefault: 'top level'; diff --git a/packages/test-data/less/_main/urls.less b/packages/test-data/less/_main/urls.less index 244488bfc..73de12b63 100644 --- a/packages/test-data/less/_main/urls.less +++ b/packages/test-data/less/_main/urls.less @@ -39,8 +39,8 @@ @import "import/import-and-relative-paths-test"; #relative-url-import { - .unquoted-relative-path-bg; - .quoted-relative-path-border-image; + .unquoted-relative-path-bg(); + .quoted-relative-path-border-image(); } #data-uri { diff --git a/packages/test-data/less/no-strict-math/mixins-guards.less b/packages/test-data/less/math/always/mixins-guards.less similarity index 100% rename from packages/test-data/less/no-strict-math/mixins-guards.less rename to packages/test-data/less/math/always/mixins-guards.less diff --git a/packages/test-data/less/no-strict-math/no-sm-operations.less b/packages/test-data/less/math/always/no-sm-operations.less similarity index 100% rename from packages/test-data/less/no-strict-math/no-sm-operations.less rename to packages/test-data/less/math/always/no-sm-operations.less diff --git a/packages/test-data/less/math/parens-division/mixins-args.less b/packages/test-data/less/math/parens-division/mixins-args.less index fe006de9e..d4749ac1f 100644 --- a/packages/test-data/less/math/parens-division/mixins-args.less +++ b/packages/test-data/less/math/parens-division/mixins-args.less @@ -19,7 +19,7 @@ } #hidden { - .hidden; + .hidden(); } #hidden1 { @@ -36,10 +36,6 @@ .mixin(3px); } -.no-parens { - .mixin; -} - .no-args { .mixin(); } @@ -98,7 +94,7 @@ body { @var: 10px; width: @var; } -#var-inside { .var-inside; } +#var-inside { .var-inside(); } .mixin-arguments (@width: 0px, ...) { border: @arguments; @@ -112,7 +108,7 @@ body { .mixin-arguments(); } .arguments3 { - .mixin-arguments; + .mixin-arguments(); } .mixin-arguments2 (@width, @rest...) { diff --git a/packages/test-data/less/math/strict-legacy/css.less b/packages/test-data/less/math/strict-legacy/css.less deleted file mode 100644 index 0cdebae89..000000000 --- a/packages/test-data/less/math/strict-legacy/css.less +++ /dev/null @@ -1,108 +0,0 @@ -@charset "utf-8"; -div { color: black; } -div { width: 99%; } - -* { - min-width: 45em; -} - -h1, h2 > a > p, h3 { - color: none; -} - -div.class { - color: blue; -} - -div#id { - color: green; -} - -.class#id { - color: purple; -} - -.one.two.three { - color: grey; -} - -@media print { - * { - font-size: 3em; - } -} - -@media screen { - * { - font-size: 10px; - } -} - -@font-face { - font-family: 'Garamond Pro'; -} - -a:hover, a:link { - color: #999; -} - -p, p:first-child { - text-transform: none; -} - -q:lang(no) { - quotes: none; -} - -p + h1 { - font-size: +2.2em; -} - -#shorthands { - border: 1px solid #000; - font: 12px/16px Arial; - font: 100%/16px Arial; - margin: 1px 0; - padding: 0 auto; -} - -#more-shorthands { - margin: 0; - padding: 1px 0 2px 0; - font: normal small/20px 'Trebuchet MS', Verdana, sans-serif; - font: 0/0 a; - border-radius: 5px / 10px; -} - -.misc { - -moz-border-radius: 2px; - display: -moz-inline-stack; - width: .1em; - background-color: #009998; - background: -webkit-gradient(linear, left top, left bottom, from(red), to(blue)); - margin: ; - .nested-multiple { - multiple-semi-colons: yes;;;;;; - }; - filter: alpha(opacity=100); - width: auto\9; -} - -#important { - color: red !important; - width: 100%!important; - height: 20px ! important; -} - -.def-font(@name) { - @font-face { - font-family: @name - } -} - -.def-font(font-a); -.def-font(font-b); - -.æøå { - margin: 0; -} diff --git a/packages/test-data/less/math/strict-legacy/media-math.less b/packages/test-data/less/math/strict-legacy/media-math.less deleted file mode 100644 index b3df9118e..000000000 --- a/packages/test-data/less/math/strict-legacy/media-math.less +++ /dev/null @@ -1,9 +0,0 @@ -@var: 16; - -@media (min-width: @var + 1) { - .foo { bar: 1; } -} - -@media (min-width: @var / 9) { - .foo { bar: 1; } -} \ No newline at end of file diff --git a/packages/test-data/less/math/strict-legacy/mixins-args.less b/packages/test-data/less/math/strict-legacy/mixins-args.less deleted file mode 100644 index 1bc868a59..000000000 --- a/packages/test-data/less/math/strict-legacy/mixins-args.less +++ /dev/null @@ -1,263 +0,0 @@ -.mixin (@a: 1px, @b: 50%) { - width: (@a * 5); - height: (@b - 1%); -} - -.mixina (@style, @width, @color: black) { - border: @width @style @color; -} - -.mixiny -(@a: 0, @b: 0) { - margin: @a; - padding: @b; -} - -.hidden() { - color: transparent; // asd -} - -#hidden { - .hidden; -} - -#hidden1 { - .hidden(); -} - -.two-args { - color: blue; - .mixin(2px, 100%); - .mixina(dotted, 2px); -} - -.one-arg { - .mixin(3px); -} - -.no-parens { - .mixin; -} - -.no-args { - .mixin(); -} - -.var-args { - @var: 9; - .mixin(@var, (@var * 2)); -} - -.multi-mix { - .mixin(2px, 30%); - .mixiny(4, 5); -} - -.maxa(@arg1: 10, @arg2: #f00) { - padding: (@arg1 * 2px); - color: @arg2; -} - -body { - .maxa(15); -} - -@glob: 5; -.global-mixin(@a:2) { - width: (@glob + @a); -} - -.scope-mix { - .global-mixin(3); -} - -.nested-ruleset (@width: 200px) { - width: @width; - .column { margin: @width; } -} -.content { - .nested-ruleset(600px); -} - -// - -.same-var-name2(@radius) { - radius: @radius; -} -.same-var-name(@radius) { - .same-var-name2(@radius); -} -#same-var-name { - .same-var-name(5px); -} - -// - -.var-inside () { - @var: 10px; - width: @var; -} -#var-inside { .var-inside; } - -.mixin-arguments (@width: 0px, ...) { - border: @arguments; - width: @width; -} - -.arguments { - .mixin-arguments(1px, solid, black); -} -.arguments2 { - .mixin-arguments(); -} -.arguments3 { - .mixin-arguments; -} - -.mixin-arguments2 (@width, @rest...) { - border: @arguments; - rest: @rest; - width: @width; -} -.arguments4 { - .mixin-arguments2(0, 1, 2, 3, 4); -} - -// Edge cases - -.edge-case { - .mixin-arguments("{"); -} - -// Division vs. Literal Slash -.border-radius(@r: 2px/5px) { - border-radius: @r; -} -.slash-vs-math { - .border-radius(); - .border-radius(5px/10px); - .border-radius((3px * 2)); -} -// semi-colon vs comma for delimiting - -.mixin-takes-one(@a) { - one: @a; -} - -.mixin-takes-two(@a; @b) { - one: @a; - two: @b; -} - -.comma-vs-semi-colon { - .mixin-takes-two(@a : a; @b : b, c); - .mixin-takes-two(@a : d, e; @b : f); - .mixin-takes-one(@a: g); - .mixin-takes-one(@a : h;); - .mixin-takes-one(i); - .mixin-takes-one(j;); - .mixin-takes-two(k, l); - .mixin-takes-one(m, n;); - .mixin-takes-two(o, p; q); - .mixin-takes-two(r, s; t;); -} - -.mixin-conflict(@a:defA, @b:defB, @c:defC) { - three: @a, @b, @c; -} - -.mixin-conflict(@a:defA, @b:defB, @c:defC, @d:defD) { - four: @a, @b, @c, @d; -} - -#named-conflict { - .mixin-conflict(11, 12, 13, @a:a); - .mixin-conflict(@a:a, 21, 22, 23); -} -@a: 3px; -.mixin-default-arg(@a: 1px, @b: @a, @c: @b) { - defaults: 1px 1px 1px; - defaults: 2px 2px 2px; -} - -.test-rule-mixin-default-arg { - .mixin-default-arg(); - .mixin-default-arg(2px); -} - -.mixin-comma-default1(@color; @padding; @margin: 2, 2, 2, 2) { - margin: @margin; -} -.selector { - .mixin-comma-default1(#33acfe; 4); -} -.mixin-comma-default2(@margin: 2, 2, 2, 2;) { - margin: @margin; -} -.selector2 { - .mixin-comma-default2(); -} -.mixin-comma-default3(@margin: 2, 2, 2, 2) { - margin: @margin; -} -.selector3 { - .mixin-comma-default3(4,2,2,2); -} - -.test-rule-calling-one-arg-mixin(@a) { -} - -.test-rule-calling-one-arg-mixin(@a, @b, @rest...) { -} - -div { - .test-rule-calling-one-arg-mixin(1); -} - -mixins-args-expand-op- { - @x: 1, 2, 3; - @y: 4 5 6; - - &1 {.m3(@x...)} - &2 {.m3(@y...)} - &3 {.wr(a, b, c)} - &4 {.wr(a; b; c, d)} - &5 {.wr(@x...)} - &6 {.m4(0; @x...)} - &7 {.m4(@x..., @a: 0)} - &8 {.m4(@b: 1.5; @x...)} - &9 {.aa(@y, @x..., and again, @y...)} - - .m3(@a, @b, @c) { - m3: @a, @b, @c; - } - - .m4(@a, @b, @c, @d) { - m4: @a, @b, @c, @d; - } - - .wr(@a...) { - &a {.m3(@a...)} - &b {.m4(0, @a...)} - &c {.m4(@a..., 4)} - } - - .aa(@a...) { - aa: @a; - a4: extract(@a, 5); - a8: extract(@a, 8); - } -} -#test-mixin-matching-when-default-2645 { - .mixin(@height) { - height: @height; - } - - .mixin(@width, @height: 10px) { - width: @width; - - .mixin(@height: @height); - } - - .mixin(@height: 20px); -} \ No newline at end of file diff --git a/packages/test-data/less/math/strict-legacy/parens.less b/packages/test-data/less/math/strict-legacy/parens.less deleted file mode 100644 index 4520119fc..000000000 --- a/packages/test-data/less/math/strict-legacy/parens.less +++ /dev/null @@ -1,50 +0,0 @@ -.parens { - @var: 1px; - border: (@var * 2) solid black; - margin: (@var * 1) (@var + 2) (4 * 4) 3; - width: (6 * 6); - padding: 2px (6 * 6px); -} - -.in-function { - value: min((1 + 1)) + 1; -} - -.more-parens { - @var: (2 * 2); - padding: (2 * @var) 4 4 (@var * 1px); - width-all: ((@var * @var) * 6); - width-first: ((@var * @var)) * 6; - width-keep: (@var * @var) * 6; - height: calc(100% + (25vh - 20px)); - height-keep: (7 * 7) + (8 * 8); - height-all: ((7 * 7) + (8 * 8)); - height-parts: ((7 * 7)) + ((8 * 8)); - margin-keep: (4 * (5 + 5) / 2) - (@var * 2); - margin-parts: ((4 * (5 + 5) / 2)) - ((@var * 2)); - margin-all: ((4 * (5 + 5) / 2) + (-(@var * 2))); - border-radius-keep: 4px * (1 + 1) / @var + 3px; - border-radius-parts: ((4px * (1 + 1))) / ((@var + 3px)); - border-radius-all: (4px * (1 + 1) / @var + 3px); - // margin: (6 * 6)px; -} - -.negative { - @var: 1; - neg-var: -@var; // -1 ? - neg-var-paren: -(@var); // -(1) ? -} - -.nested-parens { - width: 2 * (4 * (2 + (1 + 6))) - 1; - height: ((2 + 3) * (2 + 3) / (9 - 4)) + 1; -} - -.mixed-units { - margin: 2px 4em 1 5pc; - padding: (2px + 4px) 1em 2px 2; -} - -.test-rule-false-negatives { - a: ~"("; -} diff --git a/packages/test-data/less/math/strict/mixins-args.less b/packages/test-data/less/math/strict/mixins-args.less index fe006de9e..d4749ac1f 100644 --- a/packages/test-data/less/math/strict/mixins-args.less +++ b/packages/test-data/less/math/strict/mixins-args.less @@ -19,7 +19,7 @@ } #hidden { - .hidden; + .hidden(); } #hidden1 { @@ -36,10 +36,6 @@ .mixin(3px); } -.no-parens { - .mixin; -} - .no-args { .mixin(); } @@ -98,7 +94,7 @@ body { @var: 10px; width: @var; } -#var-inside { .var-inside; } +#var-inside { .var-inside(); } .mixin-arguments (@width: 0px, ...) { border: @arguments; @@ -112,7 +108,7 @@ body { .mixin-arguments(); } .arguments3 { - .mixin-arguments; + .mixin-arguments(); } .mixin-arguments2 (@width, @rest...) { diff --git a/packages/test-data/less/namespacing/namespacing-3.less b/packages/test-data/less/namespacing/namespacing-3.less index f184f6904..84e7f091f 100644 --- a/packages/test-data/less/namespacing/namespacing-3.less +++ b/packages/test-data/less/namespacing/namespacing-3.less @@ -34,7 +34,7 @@ ten: 10px; } .cell { - margin: @margins[zero] @margins[ten]/2 !important; + margin: @margins[zero] (@margins[ten]/2) !important; } .mixin(@color: black; @margin: 10px; @padding: 20px) { diff --git a/packages/test-data/less/namespacing/namespacing-4.less b/packages/test-data/less/namespacing/namespacing-4.less index cbd32a277..bf003a621 100644 --- a/packages/test-data/less/namespacing/namespacing-4.less +++ b/packages/test-data/less/namespacing/namespacing-4.less @@ -26,7 +26,7 @@ } .foo { - .colors() { #library.core.colors; } + .colors() { #library.core.colors(); } width: .alias[@a]; background: .colors[primary]; color: .colors[foreground]; diff --git a/packages/test-data/less/legacy/legacy.less b/packages/test-data/less/units/no-strict/no-strict.less similarity index 100% rename from packages/test-data/less/legacy/legacy.less rename to packages/test-data/less/units/no-strict/no-strict.less diff --git a/packages/test-data/less/strict-units/strict-units.less b/packages/test-data/less/units/strict/strict-units.less similarity index 100% rename from packages/test-data/less/strict-units/strict-units.less rename to packages/test-data/less/units/strict/strict-units.less diff --git a/packages/test-data/package.json b/packages/test-data/package.json index 4f2416e00..f73d282ed 100644 --- a/packages/test-data/package.json +++ b/packages/test-data/package.json @@ -3,7 +3,7 @@ "publishConfig": { "access": "public" }, - "version": "3.13.0", + "version": "4.0.0", "description": "Less files and CSS results", "author": { "name": "Alexis Sellier", diff --git a/packages/test-import-module/package.json b/packages/test-import-module/package.json index 05db58e95..1d002a5dc 100644 --- a/packages/test-import-module/package.json +++ b/packages/test-import-module/package.json @@ -1,7 +1,7 @@ { "name": "@less/test-import-module", "private": true, - "version": "3.13.0", + "version": "4.0.0", "description": "Less files to be included in node_modules directory for testing import from node_modules", "author": { "name": "Alexis Sellier",