aboutsummaryrefslogtreecommitdiff
path: root/node_modules/autoprefixer/node_modules/postcss
diff options
context:
space:
mode:
Diffstat (limited to 'node_modules/autoprefixer/node_modules/postcss')
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/CHANGELOG.md617
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/LICENSE20
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/README.md459
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/docs/api/assets/scripts.min.js8
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/docs/api/assets/styles.min.css1
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/docs/api/index.html22531
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/docs/architecture.md156
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/docs/guidelines/plugin.md195
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/docs/guidelines/runner.md143
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/docs/source-maps.md74
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/docs/syntax.md231
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/at-rule.js129
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/comment.js57
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/container.js869
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/css-syntax-error.js300
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/declaration.js98
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/input.js216
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/lazy-result.js444
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/list.js93
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/map-generator.js354
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/node.js608
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/parse.js40
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/parser.js611
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/postcss.d.ts1277
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/postcss.js285
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/previous-map.js161
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/processor.js263
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/result.js215
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/root.js129
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/rule.js118
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/stringifier.js364
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/stringify.js18
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/terminal-highlight.js84
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/tokenize.js295
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/vendor.js53
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/warn-once.js17
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/lib/warning.js133
-rw-r--r--node_modules/autoprefixer/node_modules/postcss/package.json82
38 files changed, 31748 insertions, 0 deletions
diff --git a/node_modules/autoprefixer/node_modules/postcss/CHANGELOG.md b/node_modules/autoprefixer/node_modules/postcss/CHANGELOG.md
new file mode 100644
index 0000000..f9589f8
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/CHANGELOG.md
@@ -0,0 +1,617 @@
+# Change Log
+This project adheres to [Semantic Versioning](http://semver.org/).
+
+## 7.0.18
+* Fix TypeScript type definitions (by Jan Buschtöns).
+
+## 7.0.17
+* Fix TypeScript type definitions (by Bob Matcuk and Jan Buschtöns).
+
+## 7.0.16
+* Revert Custom Properties fix until PostCSS 8.0.
+
+## 7.0.15
+* Fix Custom Properties support (by Ivan Solovev).
+
+## 7.0.14
+* Fix tokenizer for `postcss-less` (by Matt Lyons).
+
+## 7.0.13
+* Fix parsing regression in 7.0.12 for comments between property and value.
+
+## 7.0.12
+* Fix parsing broken CSS with two words in declaration property.
+
+## 7.0.11
+* Fix source maps on declaration semicolon (by Niklas Mischkulnig).
+
+## 7.0.10
+* Fix source maps (by Niklas Mischkulnig).
+
+## 7.0.9
+* Increase stringifing performance for non-raws AST.
+
+## 7.0.8
+* Fix TypeScript definitions (by Ankur Oberoi).
+* Use `support-colors` 6.0.
+
+## 7.0.7
+* Extend `Error` in `CssSyntaxError`.
+
+## 7.0.6
+* Fix parsing files with BOM (by Veniamin Krol).
+
+## 7.0.5
+* Reduce npm package size (by Gilad Peleg).
+
+## 7.0.4
+* Fix safe parser regression.
+
+## 7.0.3
+* Fix tokenizer extendability (by Andrew Powell).
+* Reduce npm package size.
+
+## 7.0.2
+* Fix warning text (by Rui Pedro M Lima).
+
+## 7.0.1
+* Fix JSDoc (by Steven Lambert).
+
+## 7.0 “President Amy”
+* Remove Node.js 9 and Node.js 4 support.
+* Remove IE and “dead” browsers support for client-side Babel transpiling.
+* Add CSS position on error happened inside `walk()` (by Nikhil Gaba).
+* Add `LazyResult#finally` (by Igor Kamyshev).
+* Add warning on calling PostCSS without plugins and syntax options.
+* Reduce client-side size.
+
+## 6.0.23
+* Fix parsing nested at-rules without semicolon, params, and spaces.
+* Fix docs (by Kevin Schiffer and Pat Cavit).
+
+## 6.0.22
+* Fix `Node#prev` and `Node#next` on missed parent.
+
+## 6.0.21
+* Rename Chinese docs to fix `yarnpkg.com` issue.
+
+## 6.0.20
+* Better error message on `null` as input CSS.
+
+## 6.0.19
+* Fix TypeScript definitions for source maps (by Oleh Kuchuk).
+* Fix `source` field in TypeScript definitions (by Sylvain Pollet-Villard).
+
+## 6.0.18
+* Use primitive object in TypeScript definitions (by Sylvain Pollet-Villard).
+
+## 6.0.17
+* Fix parsing comment in selector between word tokens (by Oleh Kuchuk).
+
+## 6.0.16
+* Fix warning text (by Michael Keller).
+
+## 6.0.15
+* Add warning about missed `from` option on `process().then()` call.
+* Add IE 10 support.
+
+## 6.0.14
+* Fix TypeScript definitions (by Jed Mao).
+
+## 6.0.13
+* Fix TypeScript definitions for case of multiple PostCSS versions
+ in `node_modules` (by Chris Eppstein).
+* Use `source-map` 0.6.
+
+## 6.0.12
+* Don’t copy `*` hack to declaration indent.
+
+## 6.0.11
+* Add upper case `!IMPORTANT` support.
+
+## 6.0.10
+* Reduce PostCSS size in webpack bundle.
+
+## 6.0.9
+* Improve error message for plugin with old PostCSS (by Igor Adamenko).
+
+## 6.0.8
+* Fix Node.js 4.2.2 support.
+
+## 6.0.7
+* Fix base64 decoding for old Node.js and browser.
+
+## 6.0.6
+* Fix `end` position in at-rule without semicolon (by Oleh Kuchuk).
+
+## 6.0.5
+* Move Babel config from `package.json` for `node_modules` compiling cases.
+
+## 6.0.4
+* Fix parsing `;;` after rules.
+* Use Chalk 2.0.
+
+## 6.0.3
+* Fix escape sequences parsing (by Oleh Kuchuk).
+* Added ability to force disable colors with an environment variable.
+* Improved color detection of some terminal apps.
+
+## 6.0.2
+* Keep `raws.before` on moving `Root` children to new `Root`.
+
+## 6.0.1
+* Fix parser extensibility to use it in Safe Parser.
+
+## 6.0 “Marquis Orias”
+* Remove node.js 0.12 support.
+* Remove deprecated method from PostCSS 4.
+* Insert methods remove child from previous parent, instead of closing.
+* Insert methods and cloning doesn’t clean `raws` anymore.
+* Methods `moveTo`, `moveAfter`, `moveBefore` were deprecated.
+* Options was changed in `Plugin#process(css, processOptions, pluginOptions)`.
+* Add stream parser to reduce memory usage (by Oleh Kuchuk).
+* Add `before()`/`after()` shortcuts for `node.parent.insertBefore(node, x)`.
+* Add `Rule#raws.ownSemicolon` for semicolon after templates for `@apply`.
+* Use `babel-preset-env` to compile npm package.
+* Remove `js-base64` from dependencies (by Roman Dvornov).
+* Fix error message on single `:` in CSS.
+* Move tests to Jest.
+* Clean up test (by Gabriel Kalani).
+
+## 5.2.18
+* Fix TypeScript definitions for case of multiple PostCSS versions
+ in `node_modules` (by Chris Eppstein).
+
+## 5.2.17
+* Add `postcss-sass` suggestion to syntax error on `.sass` input.
+
+## 5.2.16
+* Better error on wrong argument in node constructor.
+
+## 5.2.15
+* Fix TypeScript definitions (by bumbleblym).
+
+## 5.2.14
+* Fix browser bundle building in webpack (by janschoenherr).
+
+## 5.2.13
+* Do not add comment to important raws.
+* Fix JSDoc (by Dmitry Semigradsky).
+
+## 5.2.12
+* Fix typo in deprecation message (by Garet McKinley).
+
+## 5.2.11
+* Fix TypeScript definitions (by Jed Mao).
+
+## 5.2.10
+* Fix TypeScript definitions (by Jed Mao).
+
+## 5.2.9
+* Update TypeScript definitions (by Jed Mao).
+
+## 5.2.8
+* Fix error message (by Ben Briggs).
+
+## 5.2.7
+* Better error message on syntax object in plugins list.
+
+## 5.2.6
+* Fix `postcss.vendor` for values with spaces (by 刘祺).
+
+## 5.2.5
+* Better error message on unclosed string (by Ben Briggs).
+
+## 5.2.4
+* Improve terminal CSS syntax highlight (by Simon Lydell).
+
+## 5.2.3
+* Better color highlight in syntax error code frame.
+* Fix color highlight support in old systems.
+
+## 5.2.2
+* Update `Processor#version`.
+
+## 5.2.1
+* Fix source map path for CSS without `from` option (by Michele Locati).
+
+## 5.2 “Duke Vapula”
+* Add syntax highlight to code frame in syntax error (by Andrey Popp).
+* Use Babel code frame style and size in syntax error.
+* Add `[` and `]` tokens to parse `[attr=;] {}` correctly.
+* Add `ignoreErrors` options to tokenizer (by Andrey Popp).
+* Fix error position on tab indent (by Simon Lydell).
+
+## 5.1.2
+* Suggests SCSS/Less parsers on parse errors depends on file extension.
+
+## 5.1.1
+* Fix TypeScript definitions (by Efremov Alexey).
+
+## 5.1 “King and President Zagan”
+* Add URI in source map support (by Mark Finger).
+* Add `map.from` option (by Mark Finger).
+* Add `<no source>` mappings for nodes without source (by Bogdan Chadkin).
+* Add function value support to `map.prev` option (by Chris Montoro).
+* Add declaration value type check in shortcut creating (by 刘祺).
+* `Result#warn` now returns new created warning.
+* Don’t call plugin creator in `postcss.plugin` call.
+* Add source maps to PostCSS ES5 build.
+* Add JSDoc to PostCSS classes.
+* Clean npm package from unnecessary docs.
+
+## 5.0.21
+* Fix support with input source mao with `utf8` encoding name.
+
+## 5.0.20
+* Fix between raw value parsing (by David Clark).
+* Update TypeScript definitions (by Jed Mao).
+* Clean fake node.source after `append(string)`.
+
+## 5.0.19
+* Fix indent-based syntaxes support.
+
+## 5.0.18
+* Parse new lines according W3C CSS syntax specification.
+
+## 5.0.17
+* Fix options argument in `Node#warn` (by Ben Briggs).
+* Fix TypeScript definitions (by Jed Mao).
+
+## 5.0.16
+* Fix CSS syntax error position on unclosed quotes.
+
+## 5.0.15
+* Fix `Node#clone()` on `null` value somewhere in node.
+
+## 5.0.14
+* Allow to use PostCSS in webpack bundle without JSON loader.
+
+## 5.0.13
+* Fix `index` and `word` options in `Warning#toString` (by Bogdan Chadkin).
+* Fix input source content loading in errors.
+* Fix map options on using `LazyResult` as input CSS.
+* 100% test coverage.
+* Use Babel 6.
+
+## 5.0.12
+* Allow passing a previous map with no mappings (by Andreas Lind).
+
+## 5.0.11
+* Increase plugins performance by 1.5 times.
+
+## 5.0.10
+* Fix warning from nodes without source.
+
+## 5.0.9
+* Fix source map type detection (by @asan).
+
+## 5.0.8
+* Fixed a missed step in `5.0.7` that caused the module to be published as
+ ES6 code.
+
+## 5.0.7
+* PostCSS now requires that node 0.12 is installed via the engines property
+ in package.json (by Howard Zuo).
+
+## 5.0.6
+* Fix parsing nested at-rule without semicolon (by Matt Drake).
+* Trim `Declaration#value` (by Bogdan Chadkin).
+
+## 5.0.5
+* Fix multi-tokens property parsing (by Matt Drake).
+
+## 5.0.4
+* Fix start position in `Root#source`.
+* Fix source map annotation, when CSS uses `\r\n` (by Mohammad Younes).
+
+## 5.0.3
+* Fix `url()` parsing.
+* Fix using `selectors` in `Rule` constructor.
+* Add start source to `Root` node.
+
+## 5.0.2
+* Fix `remove(index)` to be compatible with 4.x plugin.
+
+## 5.0.1
+* Fix PostCSS 4.x plugins compatibility.
+* Fix type definition loading (by Jed Mao).
+
+## 5.0 “President Valac”
+* Remove `safe` option. Move Safe Parser to separate project.
+* `Node#toString` does not include `before` for root nodes.
+* Remove plugin returning `Root` API.
+* Remove Promise polyfill for node.js 0.10.
+* Deprecate `eachInside`, `eachDecl`, `eachRule`, `eachAtRule` and `eachComment`
+ in favor of `walk`, `walkDecls`, `walkRules`, `walkAtRules` and `walkComments`
+ (by Jed Mao).
+* Deprecate `Container#remove` and `Node#removeSelf`
+ in favor of `Container#removeChild` and `Node#remove` (by Ben Briggs).
+* Deprecate `Node#replace` in favor of `replaceWith` (by Ben Briggs).
+* Deprecate raw properties in favor of `Node#raws` object.
+* Deprecate `Node#style` in favor of `raw`.
+* Deprecate `CssSyntaxError#generated` in favor of `input`.
+* Deprecate `Node#cleanStyles` in favor of `cleanRaws`.
+* Deprecate `Root#prevMap` in favor of `Root.source.input.map`.
+* Add `syntax`, `parser` and `stringifier` options for Custom Syntaxes.
+* Add stringifier option to `Node#toString`.
+* Add `Result#content` alias for non-CSS syntaxes.
+* Add `plugin.process(css)` shortcut to every plugin function (by Ben Briggs).
+* Add multiple nodes support to insert methods (by Jonathan Neal).
+* Add `Node#warn` shortcut (by Ben Briggs).
+* Add `word` and `index` options to errors and warnings (by David Clark).
+* Add `line`, `column` properties to `Warning`.
+* Use `supports-color` library to detect color support in error output.
+* Add type definitions for TypeScript plugin developers (by Jed Mao).
+* `Rule#selectors` setter detects separators.
+* Add `postcss.stringify` method.
+* Throw descriptive errors for incorrectly formatted plugins.
+* Add docs to npm release.
+* Fix `url()` parsing.
+* Fix Windows support (by Jed Mao).
+
+## 4.1.16
+* Fix errors without stack trace.
+
+## 4.1.15
+* Allow asynchronous plugins to change processor plugins list (by Ben Briggs).
+
+## 4.1.14
+* Fix for plugins packs defined by `postcss.plugin`.
+
+## 4.1.13
+* Fix input inlined source maps with UTF-8 encoding.
+
+## 4.1.12
+* Update Promise polyfill.
+
+## 4.1.11
+* Fix error message on wrong plugin format.
+
+## 4.1.10
+* Fix Promise behavior on sync plugin errors.
+* Automatically fill `plugin` field in `CssSyntaxError`.
+* Fix warning message (by Ben Briggs).
+
+## 4.1.9
+* Speed up `node.clone()`.
+
+## 4.1.8
+* Accepts `Processor` instance in `postcss()` constructor too.
+
+## 4.1.7
+* Speed up `postcss.list` (by Bogdan Chadkin).
+
+## 4.1.6
+* Fix Promise behavior on parsing error.
+
+## 4.1.5
+* Parse at-words in declaration values.
+
+## 4.1.4
+* Fix Promise polyfill dependency (by Anton Yakushev and Matija Marohnić).
+
+## 4.1.3
+* Add Promise polyfill for node.js 0.10 and IE.
+
+## 4.1.2
+* List helpers can be accessed independently `var space = postcss.list.space`.
+
+## 4.1.1
+* Show deprecated message only once.
+
+## 4.1 “Marquis Andras”
+* Asynchronous plugin support.
+* Add warnings from plugins and `Result#messages`.
+* Add `postcss.plugin()` to create plugins with a standard API.
+* Insert nodes by CSS string.
+* Show version warning message on error from an outdated plugin.
+* Send `Result` instance to plugins as the second argument.
+* Add `CssSyntaxError#plugin`.
+* Add `CssSyntaxError#showSourceCode()`.
+* Add `postcss.list` and `postcss.vendor` aliases.
+* Add `Processor#version`.
+* Parse wrong closing bracket.
+* Parse `!important` statement with spaces and comments inside (by Ben Briggs).
+* Throw an error on declaration without `prop` or `value` (by Philip Peterson).
+* Fix source map mappings position.
+* Add indexed source map support.
+* Always set `error.generated`.
+* Clean all source map annotation comments.
+
+## 4.0.6
+* Remove `babel` from released package dependencies (by Andres Suarez).
+
+## 4.0.5
+* Fix error message on double colon in declaration.
+
+## 4.0.4
+* Fix indent detection in some rare cases.
+
+## 4.0.3
+* Faster API with 6to5 Loose mode.
+* Fix indexed source maps support.
+
+## 4.0.2
+* Do not copy IE hacks to code style.
+
+## 4.0.1
+* Add `source.input` to `Root` too.
+
+## 4.0 “Duke Flauros”
+* Rename `Container#childs` to `nodes`.
+* Rename `PostCSS#processors` to `plugins`.
+* Add `Node#replaceValues()` method.
+* Add `Node#moveTo()`, `moveBefore()` and `moveAfter()` methods.
+* Add `Node#cloneBefore()` and `cloneAfter()` shortcuts.
+* Add `Node#next()`, `prev()` and `root()` shortcuts.
+* Add `Node#replaceWith()` method.
+* Add `Node#error()` method.
+* Add `Container#removeAll()` method.
+* Add filter argument to `eachDecl()` and `eachAtRule()`.
+* Add `Node#source.input` and move `source.file` or `source.id` to `input`.
+* Change code indent, when node was moved.
+* Better fix code style on `Rule`, `AtRule` and `Comment` nodes changes.
+* Allow to create rules and at-rules by hash shortcut in append methods.
+* Add class name to CSS syntax error output.
+
+## 3.0.7
+* Fix IE filter parsing with multiple commands.
+* Safer way to consume PostCSS object as plugin (by Maxime Thirouin).
+
+## 3.0.6
+* Fix missing semicolon when comment comes after last declaration.
+* Fix Safe Mode declaration parsing on unclosed blocks.
+
+## 3.0.5
+* Fix parser to support difficult cases with backslash escape and brackets.
+* Add `CssSyntaxError#stack` (by Maxime Thirouin).
+
+## 3.0.4
+* Fix Safe Mode on unknown word before declaration.
+
+## 3.0.3
+* Increase tokenizer speed (by Roman Dvornov).
+
+## 3.0.2
+* Fix empty comment parsing.
+* Fix `Root#normalize` in some inserts.
+
+## 3.0.1
+* Fix Rhino JS runtime support.
+* Typo in deprecated warning (by Maxime Thirouin).
+
+## 3.0 “Marquis Andrealphus”
+* New parser, which become the fastest ever CSS parser written in JavaScript.
+* Parser can now parse declarations and rules in one parent (like in `@page`)
+ and nested declarations for plugins like `postcss-nested`.
+* Child nodes array is now in `childs` property, instead of `decls` and `rules`.
+* `map.inline` and `map.sourcesContent` options are now `true` by default.
+* Fix iterators (`each`, `insertAfter`) on children array changes.
+* Use previous source map to show origin source of CSS syntax error.
+* Use 6to5 ES6 compiler, instead of ES6 Transpiler.
+* Use code style for manually added rules from existing rules.
+* Use `from` option from previous source map `file` field.
+* Set `to` value to `from` if `to` option is missing.
+* Use better node source name when missing `from` option.
+* Show a syntax error when `;` is missed between declarations.
+* Allow to pass `PostCSS` instance or list of plugins to `use()` method.
+* Allow to pass `Result` instance to `process()` method.
+* Trim Unicode BOM on source maps parsing.
+* Parse at-rules without spaces like `@import"file"`.
+* Better previous `sourceMappingURL` annotation comment cleaning.
+* Do not remove previous `sourceMappingURL` comment on `map.annotation: false`.
+* Parse nameless at-rules in Safe Mode.
+* Fix source map generation for nodes without source.
+* Fix next child `before` if `Root` first child got removed.
+
+## 2.2.6
+* Fix map generation for nodes without source (by Josiah Savary).
+
+## 2.2.5
+* Fix source map with BOM marker support (by Mohammad Younes).
+* Fix source map paths (by Mohammad Younes).
+
+## 2.2.4
+* Fix `prepend()` on empty `Root`.
+
+## 2.2.3
+* Allow to use object shortcut in `use()` with functions like `autoprefixer`.
+
+## 2.2.2
+* Add shortcut to set processors in `use()` via object with `.postcss` property.
+
+## 2.2.1
+* Send `opts` from `Processor#process(css, opts)` to processors.
+
+## 2.2 “Marquis Cimeies”
+* Use GNU style syntax error messages.
+* Add `Node#replace` method.
+* Add `CssSyntaxError#reason` property.
+
+## 2.1.2
+* Fix UTF-8 support in inline source map.
+* Fix source map `sourcesContent` if there is no `from` and `to` options.
+
+## 2.1.1
+* Allow to miss `to` and `from` options for inline source maps.
+* Add `Node#source.id` if file name is unknown.
+* Better detect splitter between rules in CSS concatenation tools.
+* Automatically clone node in insert methods.
+
+## 2.1 “King Amdusias”
+* Change Traceur ES6 compiler to ES6 Transpiler.
+* Show broken CSS line in syntax error.
+
+## 2.0 “King Belial”
+* Project was rewritten from CoffeeScript to ES6.
+* Add Safe Mode to works with live input or with hacks from legacy code.
+* More safer parser to pass all hacks from Browserhacks.com.
+* Use real properties instead of magic getter/setter for raw properties.
+
+## 1.0 “Marquis Decarabia”
+* Save previous source map for each node to support CSS concatenation
+ with multiple previous maps.
+* Add `map.sourcesContent` option to add origin content to `sourcesContent`
+ inside map.
+* Allow to set different place of output map in annotation comment.
+* Allow to use arrays and `Root` in `Container#append` and same methods.
+* Add `Root#prevMap` with information about previous map.
+* Allow to use latest PostCSS from GitHub by npm.
+* `Result` now is lazy and it will generate output CSS only if you use `css`
+ or `map` property.
+* Use separated `map.prev` option to set previous map.
+* Rename `inlineMap` option to `map.inline`.
+* Rename `mapAnnotation` option to `map.annotation`.
+* `Result#map` now return `SourceMapGenerator` object, instead of string.
+* Run previous map autodetect only if input CSS contains annotation comment.
+* Add `map: 'inline'` shortcut for `map: { inline: true }` option.
+* `Node#source.file` now will contains absolute path.
+* Clean `Declaration#between` style on node clone.
+
+## 0.3.5
+* Allow to use `Root` or `Result` as first argument in `process()`.
+* Save parsed AST to `Result#root`.
+
+## 0.3.4
+* Better space symbol detect to read UTF-8 BOM correctly.
+
+## 0.3.3
+* Remove source map hacks by using new Mozilla’s `source-map` (by Simon Lydell).
+
+## 0.3.2
+* Add URI encoding support for inline source maps.
+
+## 0.3.1
+* Fix relative paths from previous source map.
+* Safer space split in `Rule#selectors` (by Simon Lydell).
+
+## 0.3 “Prince Seere”
+* Add `Comment` node for comments between declarations or rules.
+* Add source map annotation comment to output CSS.
+* Allow to inline source map to annotation comment by data:uri.
+* Fix source maps on Windows.
+* Fix source maps for subdirectory (by Dmitry Nikitenko and Simon Lydell).
+* Autodetect previous source map.
+* Add `first` and `last` shortcuts to container nodes.
+* Parse `!important` to separated property in `Declaration`.
+* Allow to break iteration by returning `false`.
+* Copy code style to new nodes.
+* Add `eachInside` method to recursively iterate all nodes.
+* Add `selectors` shortcut to get selectors array.
+* Add `toResult` method to `Rule` to simplify work with several input files.
+* Clean declaration’s `value`, rule’s `selector` and at-rule’s `params`
+ by storing spaces in `between` property.
+
+## 0.2 “Duke Dantalion”
+* Add source map support.
+* Add shortcuts to create nodes.
+* Method `process()` now returns object with `css` and `map` keys.
+* Origin CSS file option was renamed from `file` to `from`.
+* Rename `Node#remove()` method to `removeSelf()` to fix name conflict.
+* Node source was moved to `source` property with origin file
+ and node end position.
+* You can set own CSS generate function.
+
+## 0.1 “Count Andromalius”
+* Initial release.
diff --git a/node_modules/autoprefixer/node_modules/postcss/LICENSE b/node_modules/autoprefixer/node_modules/postcss/LICENSE
new file mode 100644
index 0000000..da057b4
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/LICENSE
@@ -0,0 +1,20 @@
+The MIT License (MIT)
+
+Copyright 2013 Andrey Sitnik <andrey@sitnik.ru>
+
+Permission is hereby granted, free of charge, to any person obtaining a copy of
+this software and associated documentation files (the "Software"), to deal in
+the Software without restriction, including without limitation the rights to
+use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
+the Software, and to permit persons to whom the Software is furnished to do so,
+subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
+FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
+COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
+IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
diff --git a/node_modules/autoprefixer/node_modules/postcss/README.md b/node_modules/autoprefixer/node_modules/postcss/README.md
new file mode 100644
index 0000000..229ba37
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/README.md
@@ -0,0 +1,459 @@
+# PostCSS [![Gitter][chat-img]][chat]
+
+<img align="right" width="95" height="95"
+ alt="Philosopher’s stone, logo of PostCSS"
+ src="http://postcss.github.io/postcss/logo.svg">
+
+[chat-img]: https://img.shields.io/badge/Gitter-Join_the_PostCSS_chat-brightgreen.svg
+[chat]: https://gitter.im/postcss/postcss
+
+PostCSS is a tool for transforming styles with JS plugins.
+These plugins can lint your CSS, support variables and mixins,
+transpile future CSS syntax, inline images, and more.
+
+PostCSS is used by industry leaders including Wikipedia, Twitter, Alibaba,
+and JetBrains. The [Autoprefixer] PostCSS plugin is one of the most popular
+CSS processors.
+
+PostCSS takes a CSS file and provides an API to analyze and modify its rules
+(by transforming them into an [Abstract Syntax Tree]).
+This API can then be used by [plugins] to do a lot of useful things,
+e.g. to find errors automatically insert vendor prefixes.
+
+**Support / Discussion:** [Gitter](https://gitter.im/postcss/postcss)<br>
+**Twitter account:** [@postcss](https://twitter.com/postcss)<br>
+**VK.com page:** [postcss](https://vk.com/postcss)<br>
+**中文翻译**: [`README-cn.md`](./README-cn.md)
+
+For PostCSS commercial support (consulting, improving the front-end culture
+of your company, PostCSS plugins), contact [Evil Martians]
+at <surrender@evilmartians.com>.
+
+[Abstract Syntax Tree]: https://en.wikipedia.org/wiki/Abstract_syntax_tree
+[Evil Martians]: https://evilmartians.com/?utm_source=postcss
+[Autoprefixer]: https://github.com/postcss/autoprefixer
+[plugins]: https://github.com/postcss/postcss#plugins
+
+<a href="https://evilmartians.com/?utm_source=postcss">
+ <img src="https://evilmartians.com/badges/sponsored-by-evil-martians.svg"
+ alt="Sponsored by Evil Martians" width="236" height="54">
+</a>
+
+## Plugins
+
+Currently, PostCSS has more than 200 plugins. You can find all of the plugins
+in the [plugins list] or in the [searchable catalog]. Below is a list
+of our favorite plugins — the best demonstrations of what can be built
+on top of PostCSS.
+
+If you have any new ideas, [PostCSS plugin development] is really easy.
+
+[searchable catalog]: http://postcss.parts
+[plugins list]: https://github.com/postcss/postcss/blob/master/docs/plugins.md
+
+### Solve Global CSS Problem
+
+* [`postcss-use`] allows you to explicitly set PostCSS plugins within CSS
+ and execute them only for the current file.
+* [`postcss-modules`] and [`react-css-modules`] automatically isolate
+ selectors within components.
+* [`postcss-autoreset`] is an alternative to using a global reset
+ that is better for isolatable components.
+* [`postcss-initial`] adds `all: initial` support, which resets
+ all inherited styles.
+* [`cq-prolyfill`] adds container query support, allowing styles that respond
+ to the width of the parent.
+
+### Use Future CSS, Today
+
+* [`autoprefixer`] adds vendor prefixes, using data from Can I Use.
+* [`postcss-preset-env`] allows you to use future CSS features today.
+
+### Better CSS Readability
+
+* [`precss`] contains plugins for Sass-like features, like variables, nesting,
+ and mixins.
+* [`postcss-sorting`] sorts the content of rules and at-rules.
+* [`postcss-utilities`] includes the most commonly used shortcuts and helpers.
+* [`short`] adds and extends numerous shorthand properties.
+
+### Images and Fonts
+
+* [`postcss-assets`] inserts image dimensions and inlines files.
+* [`postcss-sprites`] generates image sprites.
+* [`font-magician`] generates all the `@font-face` rules needed in CSS.
+* [`postcss-inline-svg`] allows you to inline SVG and customize its styles.
+* [`postcss-write-svg`] allows you to write simple SVG directly in your CSS.
+
+### Linters
+
+* [`stylelint`] is a modular stylesheet linter.
+* [`stylefmt`] is a tool that automatically formats CSS
+ according `stylelint` rules.
+* [`doiuse`] lints CSS for browser support, using data from Can I Use.
+* [`colorguard`] helps you maintain a consistent color palette.
+
+### Other
+
+* [`postcss-rtl`] combines both-directional (left-to-right and right-to-left) styles in one CSS file.
+* [`cssnano`] is a modular CSS minifier.
+* [`lost`] is a feature-rich `calc()` grid system.
+* [`rtlcss`] mirrors styles for right-to-left locales.
+
+[PostCSS plugin development]: https://github.com/postcss/postcss/blob/master/docs/writing-a-plugin.md
+[`postcss-inline-svg`]: https://github.com/TrySound/postcss-inline-svg
+[`postcss-preset-env`]: https://github.com/jonathantneal/postcss-preset-env
+[`react-css-modules`]: https://github.com/gajus/react-css-modules
+[`postcss-autoreset`]: https://github.com/maximkoretskiy/postcss-autoreset
+[`postcss-write-svg`]: https://github.com/jonathantneal/postcss-write-svg
+[`postcss-utilities`]: https://github.com/ismamz/postcss-utilities
+[`postcss-initial`]: https://github.com/maximkoretskiy/postcss-initial
+[`postcss-sprites`]: https://github.com/2createStudio/postcss-sprites
+[`postcss-modules`]: https://github.com/outpunk/postcss-modules
+[`postcss-sorting`]: https://github.com/hudochenkov/postcss-sorting
+[`postcss-assets`]: https://github.com/assetsjs/postcss-assets
+[`font-magician`]: https://github.com/jonathantneal/postcss-font-magician
+[`autoprefixer`]: https://github.com/postcss/autoprefixer
+[`cq-prolyfill`]: https://github.com/ausi/cq-prolyfill
+[`postcss-rtl`]: https://github.com/vkalinichev/postcss-rtl
+[`postcss-use`]: https://github.com/postcss/postcss-use
+[`css-modules`]: https://github.com/css-modules/css-modules
+[`colorguard`]: https://github.com/SlexAxton/css-colorguard
+[`stylelint`]: https://github.com/stylelint/stylelint
+[`stylefmt`]: https://github.com/morishitter/stylefmt
+[`cssnano`]: http://cssnano.co
+[`precss`]: https://github.com/jonathantneal/precss
+[`doiuse`]: https://github.com/anandthakker/doiuse
+[`rtlcss`]: https://github.com/MohammadYounes/rtlcss
+[`short`]: https://github.com/jonathantneal/postcss-short
+[`lost`]: https://github.com/peterramsing/lost
+
+## Syntaxes
+
+PostCSS can transform styles in any syntax, not just CSS.
+If there is not yet support for your favorite syntax,
+you can write a parser and/or stringifier to extend PostCSS.
+
+* [`sugarss`] is a indent-based syntax like Sass or Stylus.
+* [`postcss-syntax`] switch syntax automatically by file extensions.
+* [`postcss-html`] parsing styles in `<style>` tags of HTML-like files.
+* [`postcss-markdown`] parsing styles in code blocks of Markdown files.
+* [`postcss-jsx`] parsing CSS in template / object literals of source files.
+* [`postcss-styled`] parsing CSS in template literals of source files.
+* [`postcss-scss`] allows you to work with SCSS
+ *(but does not compile SCSS to CSS)*.
+* [`postcss-sass`] allows you to work with Sass
+ *(but does not compile Sass to CSS)*.
+* [`postcss-less`] allows you to work with Less
+ *(but does not compile LESS to CSS)*.
+* [`postcss-less-engine`] allows you to work with Less
+ *(and DOES compile LESS to CSS using true Less.js evaluation)*.
+* [`postcss-js`] allows you to write styles in JS or transform
+ React Inline Styles, Radium or JSS.
+* [`postcss-safe-parser`] finds and fixes CSS syntax errors.
+* [`midas`] converts a CSS string to highlighted HTML.
+
+[`postcss-less-engine`]: https://github.com/Crunch/postcss-less
+[`postcss-safe-parser`]: https://github.com/postcss/postcss-safe-parser
+[`postcss-syntax`]: https://github.com/gucong3000/postcss-syntax
+[`postcss-html`]: https://github.com/gucong3000/postcss-html
+[`postcss-markdown`]: https://github.com/gucong3000/postcss-markdown
+[`postcss-jsx`]: https://github.com/gucong3000/postcss-jsx
+[`postcss-styled`]: https://github.com/gucong3000/postcss-styled
+[`postcss-scss`]: https://github.com/postcss/postcss-scss
+[`postcss-sass`]: https://github.com/AleshaOleg/postcss-sass
+[`postcss-less`]: https://github.com/webschik/postcss-less
+[`postcss-js`]: https://github.com/postcss/postcss-js
+[`sugarss`]: https://github.com/postcss/sugarss
+[`midas`]: https://github.com/ben-eb/midas
+
+## Articles
+
+* [Some things you may think about PostCSS… and you might be wrong](http://julian.io/some-things-you-may-think-about-postcss-and-you-might-be-wrong)
+* [What PostCSS Really Is; What It Really Does](http://davidtheclark.com/its-time-for-everyone-to-learn-about-postcss)
+* [PostCSS Guides](http://webdesign.tutsplus.com/series/postcss-deep-dive--cms-889)
+
+More articles and videos you can find on [awesome-postcss](https://github.com/jjaderg/awesome-postcss) list.
+
+## Books
+
+* [Mastering PostCSS for Web Design](https://www.packtpub.com/web-development/mastering-postcss-web-design) by Alex Libby, Packt. (June 2016)
+
+## Usage
+
+You can start using PostCSS in just two steps:
+
+1. Find and add PostCSS extensions for your build tool.
+2. [Select plugins] and add them to your PostCSS process.
+
+[Select plugins]: http://postcss.parts
+
+### CSS-in-JS
+
+The best way to use PostCSS with CSS-in-JS is [`astroturf`].
+Add its loader to your `webpack.config.js`:
+
+```js
+module.exports = {
+ module: {
+ rules: [
+ {
+ test: /\.css$/,
+ use: ['style-loader', 'postcss-loader'],
+ },
+ {
+ test: /\.jsx?$/,
+ use: ['babel-loader', 'astroturf/loader'],
+ }
+ ]
+ }
+}
+```
+
+Then create `postcss.config.js`:
+
+```js
+module.exports = {
+ plugins: [
+ require('autoprefixer'),
+ require('postcss-nested')
+ ]
+}
+```
+
+[`astroturf`]: https://github.com/4Catalyzer/astroturf
+
+### Parcel
+
+[Parcel] has built-in PostCSS support. It already uses Autoprefixer
+and cssnano. If you want to change plugins, create `postcss.config.js`
+in project’s root:
+
+```js
+module.exports = {
+ plugins: [
+ require('autoprefixer'),
+ require('postcss-nested')
+ ]
+}
+```
+
+Parcel will even automatically install these plugins for you.
+
+> Please, be aware of [the several issues in Version 1](https://github.com/parcel-bundler/parcel/labels/CSS%20Preprocessing). Notice, [Version 2](https://github.com/parcel-bundler/parcel/projects/5) may resolve the issues via [issue #2157](https://github.com/parcel-bundler/parcel/issues/2157).
+
+[Parcel]: https://parceljs.org
+
+### Webpack
+
+Use [`postcss-loader`] in `webpack.config.js`:
+
+```js
+module.exports = {
+ module: {
+ rules: [
+ {
+ test: /\.css$/,
+ exclude: /node_modules/,
+ use: [
+ {
+ loader: 'style-loader',
+ },
+ {
+ loader: 'css-loader',
+ options: {
+ importLoaders: 1,
+ }
+ },
+ {
+ loader: 'postcss-loader'
+ }
+ ]
+ }
+ ]
+ }
+}
+```
+
+Then create `postcss.config.js`:
+
+```js
+module.exports = {
+ plugins: [
+ require('precss'),
+ require('autoprefixer')
+ ]
+}
+```
+
+[`postcss-loader`]: https://github.com/postcss/postcss-loader
+
+### Gulp
+
+Use [`gulp-postcss`] and [`gulp-sourcemaps`].
+
+```js
+gulp.task('css', () => {
+ const postcss = require('gulp-postcss')
+ const sourcemaps = require('gulp-sourcemaps')
+
+ return gulp.src('src/**/*.css')
+ .pipe( sourcemaps.init() )
+ .pipe( postcss([ require('precss'), require('autoprefixer') ]) )
+ .pipe( sourcemaps.write('.') )
+ .pipe( gulp.dest('build/') )
+})
+```
+
+[`gulp-sourcemaps`]: https://github.com/floridoo/gulp-sourcemaps
+[`gulp-postcss`]: https://github.com/postcss/gulp-postcss
+
+### npm run / CLI
+
+To use PostCSS from your command-line interface or with npm scripts
+there is [`postcss-cli`].
+
+```sh
+postcss --use autoprefixer -c options.json -o main.css css/*.css
+```
+
+[`postcss-cli`]: https://github.com/postcss/postcss-cli
+
+### Browser
+
+If you want to compile CSS string in browser (for instance, in live edit
+tools like CodePen), just use [Browserify] or [webpack]. They will pack
+PostCSS and plugins files into a single file.
+
+To apply PostCSS plugins to React Inline Styles, JSS, Radium
+and other [CSS-in-JS], you can use [`postcss-js`] and transforms style objects.
+
+```js
+var postcss = require('postcss-js')
+var prefixer = postcss.sync([ require('autoprefixer') ])
+
+prefixer({ display: 'flex' }) //=> { display: ['-webkit-box', '-webkit-flex', '-ms-flexbox', 'flex'] }
+```
+
+[`postcss-js`]: https://github.com/postcss/postcss-js
+[Browserify]: http://browserify.org/
+[CSS-in-JS]: https://github.com/MicheleBertoli/css-in-js
+[webpack]: https://webpack.github.io/
+
+### Runners
+
+* **Grunt**: [`grunt-postcss`](https://github.com/nDmitry/grunt-postcss)
+* **HTML**: [`posthtml-postcss`](https://github.com/posthtml/posthtml-postcss)
+* **Stylus**: [`poststylus`](https://github.com/seaneking/poststylus)
+* **Rollup**: [`rollup-plugin-postcss`](https://github.com/egoist/rollup-plugin-postcss)
+* **Brunch**: [`postcss-brunch`](https://github.com/brunch/postcss-brunch)
+* **Broccoli**: [`broccoli-postcss`](https://github.com/jeffjewiss/broccoli-postcss)
+* **Meteor**: [`postcss`](https://atmospherejs.com/juliancwirko/postcss)
+* **ENB**: [`enb-postcss`](https://github.com/awinogradov/enb-postcss)
+* **Taskr**: [`taskr-postcss`](https://github.com/lukeed/taskr/tree/master/packages/postcss)
+* **Start**: [`start-postcss`](https://github.com/start-runner/postcss)
+* **Connect/Express**: [`postcss-middleware`](https://github.com/jedmao/postcss-middleware)
+
+### JS API
+
+For other environments, you can use the JS API:
+
+```js
+const autoprefixer = require('autoprefixer')
+const postcss = require('postcss')
+const precss = require('precss')
+const fs = require('fs')
+
+fs.readFile('src/app.css', (err, css) => {
+ postcss([precss, autoprefixer])
+ .process(css, { from: 'src/app.css', to: 'dest/app.css' })
+ .then(result => {
+ fs.writeFile('dest/app.css', result.css, () => true)
+ if ( result.map ) {
+ fs.writeFile('dest/app.css.map', result.map, () => true)
+ }
+ })
+})
+```
+
+Read the [PostCSS API documentation] for more details about the JS API.
+
+All PostCSS runners should pass [PostCSS Runner Guidelines].
+
+[PostCSS Runner Guidelines]: https://github.com/postcss/postcss/blob/master/docs/guidelines/runner.md
+[PostCSS API documentation]: http://api.postcss.org/postcss.html
+
+### Options
+
+Most PostCSS runners accept two parameters:
+
+* An array of plugins.
+* An object of options.
+
+Common options:
+
+* `syntax`: an object providing a syntax parser and a stringifier.
+* `parser`: a special syntax parser (for example, [SCSS]).
+* `stringifier`: a special syntax output generator (for example, [Midas]).
+* `map`: [source map options].
+* `from`: the input file name (most runners set it automatically).
+* `to`: the output file name (most runners set it automatically).
+
+[source map options]: https://github.com/postcss/postcss/blob/master/docs/source-maps.md
+[Midas]: https://github.com/ben-eb/midas
+[SCSS]: https://github.com/postcss/postcss-scss
+
+### Treat Warnings as Errors
+
+In some situations it might be helpful to fail the build on any warning
+from PostCSS or one of its plugins. This guarantees that no warnings
+go unnoticed, and helps to avoid bugs. While there is no option to enable
+treating warnings as errors, it can easily be done
+by adding `postcss-fail-on-warn` plugin in the end of PostCSS plugins:
+
+```js
+module.exports = {
+ plugins: [
+ require('autoprefixer'),
+ require('postcss-fail-on-warn')
+ ]
+}
+```
+
+
+## Editors & IDE Integration
+
+### Atom
+
+* [`language-postcss`] adds PostCSS and [SugarSS] highlight.
+* [`source-preview-postcss`] previews your output CSS in a separate, live pane.
+
+[SugarSS]: https://github.com/postcss/sugarss
+
+### Sublime Text
+
+* [`Syntax-highlighting-for-PostCSS`] adds PostCSS highlight.
+
+[`Syntax-highlighting-for-PostCSS`]: https://github.com/hudochenkov/Syntax-highlighting-for-PostCSS
+[`source-preview-postcss`]: https://atom.io/packages/source-preview-postcss
+[`language-postcss`]: https://atom.io/packages/language-postcss
+
+### Vim
+
+* [`postcss.vim`] adds PostCSS highlight.
+
+[`postcss.vim`]: https://github.com/stephenway/postcss.vim
+
+### WebStorm
+
+WebStorm 2016.3 [has] built-in PostCSS support.
+
+[has]: https://blog.jetbrains.com/webstorm/2016/08/webstorm-2016-3-early-access-preview/
+
+
+## Security Contact
+
+To report a security vulnerability, please use the [Tidelift security contact].
+Tidelift will coordinate the fix and disclosure.
+
+[Tidelift security contact]: https://tidelift.com/security
diff --git a/node_modules/autoprefixer/node_modules/postcss/docs/api/assets/scripts.min.js b/node_modules/autoprefixer/node_modules/postcss/docs/api/assets/scripts.min.js
new file mode 100644
index 0000000..d22a9d5
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/docs/api/assets/scripts.min.js
@@ -0,0 +1,8 @@
+parcelRequire=function(e,r,t,n){var i,o="function"==typeof parcelRequire&&parcelRequire,u="function"==typeof require&&require;function f(t,n){if(!r[t]){if(!e[t]){var i="function"==typeof parcelRequire&&parcelRequire;if(!n&&i)return i(t,!0);if(o)return o(t,!0);if(u&&"string"==typeof t)return u(t);var c=new Error("Cannot find module '"+t+"'");throw c.code="MODULE_NOT_FOUND",c}p.resolve=function(r){return e[t][1][r]||r},p.cache={};var l=r[t]=new f.Module(t);e[t][0].call(l.exports,p,l,l.exports,this)}return r[t].exports;function p(e){return f(p.resolve(e))}}f.isParcelRequire=!0,f.Module=function(e){this.id=e,this.bundle=f,this.exports={}},f.modules=e,f.cache=r,f.parent=o,f.register=function(r,t){e[r]=[function(e,r){r.exports=t},{}]};for(var c=0;c<t.length;c++)try{f(t[c])}catch(e){i||(i=e)}if(t.length){var l=f(t[t.length-1]);"object"==typeof exports&&"undefined"!=typeof module?module.exports=l:"function"==typeof define&&define.amd?define(function(){return l}):n&&(this[n]=l)}if(parcelRequire=f,i)throw i;return f}({"SyYu":[function(require,module,exports) {
+var define;
+var A;!function(e,t){"use strict";"function"==typeof A&&A.amd?A([],t):"object"==typeof module&&module.exports?module.exports=t():(e.AnchorJS=t(),e.anchors=new e.AnchorJS)}(this,function(){"use strict";return function(A){function e(A){A.icon=A.hasOwnProperty("icon")?A.icon:"",A.visible=A.hasOwnProperty("visible")?A.visible:"hover",A.placement=A.hasOwnProperty("placement")?A.placement:"right",A.ariaLabel=A.hasOwnProperty("ariaLabel")?A.ariaLabel:"Anchor",A.class=A.hasOwnProperty("class")?A.class:"",A.base=A.hasOwnProperty("base")?A.base:"",A.truncate=A.hasOwnProperty("truncate")?Math.floor(A.truncate):64,A.titleText=A.hasOwnProperty("titleText")?A.titleText:""}function t(A){var e;if("string"==typeof A||A instanceof String)e=[].slice.call(document.querySelectorAll(A));else{if(!(Array.isArray(A)||A instanceof NodeList))throw new Error("The selector provided to AnchorJS was invalid.");e=[].slice.call(A)}return e}this.options=A||{},this.elements=[],e(this.options),this.isTouchDevice=function(){return!!("ontouchstart"in window||window.DocumentTouch&&document instanceof DocumentTouch)},this.add=function(A){var i,n,o,s,a,r,c,h,l,u,d,p,w=[];if(e(this.options),"touch"===(d=this.options.visible)&&(d=this.isTouchDevice()?"always":"hover"),A||(A="h2, h3, h4, h5, h6"),0===(i=t(A)).length)return this;for(function(){if(null===document.head.querySelector("style.anchorjs")){var A,e=document.createElement("style");e.className="anchorjs",e.appendChild(document.createTextNode("")),void 0===(A=document.head.querySelector('[rel="stylesheet"], style'))?document.head.appendChild(e):document.head.insertBefore(e,A),e.sheet.insertRule(" .anchorjs-link { opacity: 0; text-decoration: none; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }",e.sheet.cssRules.length),e.sheet.insertRule(" *:hover > .anchorjs-link, .anchorjs-link:focus { opacity: 1; }",e.sheet.cssRules.length),e.sheet.insertRule(" [data-anchorjs-icon]::after { content: attr(data-anchorjs-icon); }",e.sheet.cssRules.length),e.sheet.insertRule(' @font-face { font-family: "anchorjs-icons"; src: url(data:n/a;base64,AAEAAAALAIAAAwAwT1MvMg8yG2cAAAE4AAAAYGNtYXDp3gC3AAABpAAAAExnYXNwAAAAEAAAA9wAAAAIZ2x5ZlQCcfwAAAH4AAABCGhlYWQHFvHyAAAAvAAAADZoaGVhBnACFwAAAPQAAAAkaG10eASAADEAAAGYAAAADGxvY2EACACEAAAB8AAAAAhtYXhwAAYAVwAAARgAAAAgbmFtZQGOH9cAAAMAAAAAunBvc3QAAwAAAAADvAAAACAAAQAAAAEAAHzE2p9fDzz1AAkEAAAAAADRecUWAAAAANQA6R8AAAAAAoACwAAAAAgAAgAAAAAAAAABAAADwP/AAAACgAAA/9MCrQABAAAAAAAAAAAAAAAAAAAAAwABAAAAAwBVAAIAAAAAAAIAAAAAAAAAAAAAAAAAAAAAAAMCQAGQAAUAAAKZAswAAACPApkCzAAAAesAMwEJAAAAAAAAAAAAAAAAAAAAARAAAAAAAAAAAAAAAAAAAAAAQAAg//0DwP/AAEADwABAAAAAAQAAAAAAAAAAAAAAIAAAAAAAAAIAAAACgAAxAAAAAwAAAAMAAAAcAAEAAwAAABwAAwABAAAAHAAEADAAAAAIAAgAAgAAACDpy//9//8AAAAg6cv//f///+EWNwADAAEAAAAAAAAAAAAAAAAACACEAAEAAAAAAAAAAAAAAAAxAAACAAQARAKAAsAAKwBUAAABIiYnJjQ3NzY2MzIWFxYUBwcGIicmNDc3NjQnJiYjIgYHBwYUFxYUBwYGIwciJicmNDc3NjIXFhQHBwYUFxYWMzI2Nzc2NCcmNDc2MhcWFAcHBgYjARQGDAUtLXoWOR8fORYtLTgKGwoKCjgaGg0gEhIgDXoaGgkJBQwHdR85Fi0tOAobCgoKOBoaDSASEiANehoaCQkKGwotLXoWOR8BMwUFLYEuehYXFxYugC44CQkKGwo4GkoaDQ0NDXoaShoKGwoFBe8XFi6ALjgJCQobCjgaShoNDQ0NehpKGgobCgoKLYEuehYXAAAADACWAAEAAAAAAAEACAAAAAEAAAAAAAIAAwAIAAEAAAAAAAMACAAAAAEAAAAAAAQACAAAAAEAAAAAAAUAAQALAAEAAAAAAAYACAAAAAMAAQQJAAEAEAAMAAMAAQQJAAIABgAcAAMAAQQJAAMAEAAMAAMAAQQJAAQAEAAMAAMAAQQJAAUAAgAiAAMAAQQJAAYAEAAMYW5jaG9yanM0MDBAAGEAbgBjAGgAbwByAGoAcwA0ADAAMABAAAAAAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAH//wAP) format("truetype"); }',e.sheet.cssRules.length)}}(),n=document.querySelectorAll("[id]"),o=[].map.call(n,function(A){return A.id}),a=0;a<i.length;a++)if(this.hasAnchorJSLink(i[a]))w.push(a);else{if(i[a].hasAttribute("id"))s=i[a].getAttribute("id");else if(i[a].hasAttribute("data-anchor-id"))s=i[a].getAttribute("data-anchor-id");else{l=h=this.urlify(i[a].textContent),c=0;do{void 0!==r&&(l=h+"-"+c),r=o.indexOf(l),c+=1}while(-1!==r);r=void 0,o.push(l),i[a].setAttribute("id",l),s=l}s.replace(/-/g," "),(u=document.createElement("a")).className="anchorjs-link "+this.options.class,u.setAttribute("aria-label",this.options.ariaLabel),u.setAttribute("data-anchorjs-icon",this.options.icon),this.options.titleText&&(u.title=this.options.titleText),p=document.querySelector("base")?window.location.pathname+window.location.search:"",p=this.options.base||p,u.href=p+"#"+s,"always"===d&&(u.style.opacity="1"),""===this.options.icon&&(u.style.font="1em/1 anchorjs-icons","left"===this.options.placement&&(u.style.lineHeight="inherit")),"left"===this.options.placement?(u.style.position="absolute",u.style.marginLeft="-1em",u.style.paddingRight="0.5em",i[a].insertBefore(u,i[a].firstChild)):(u.style.paddingLeft="0.375em",i[a].appendChild(u))}for(a=0;a<w.length;a++)i.splice(w[a]-a,1);return this.elements=this.elements.concat(i),this},this.remove=function(A){for(var e,i,n=t(A),o=0;o<n.length;o++)(i=n[o].querySelector(".anchorjs-link"))&&(-1!==(e=this.elements.indexOf(n[o]))&&this.elements.splice(e,1),n[o].removeChild(i));return this},this.removeAll=function(){this.remove(this.elements)},this.urlify=function(A){return this.options.truncate||e(this.options),A.trim().replace(/\'/gi,"").replace(/[& +$,:;=?@"#{}|^~[`%!'<>\]\.\/\(\)\*\\\n\t\b\v]/g,"-").replace(/-{2,}/g,"-").substring(0,this.options.truncate).replace(/^-+|-+$/gm,"").toLowerCase()},this.hasAnchorJSLink=function(A){var e=A.firstChild&&(" "+A.firstChild.className+" ").indexOf(" anchorjs-link ")>-1,t=A.lastChild&&(" "+A.lastChild.className+" ").indexOf(" anchorjs-link ")>-1;return e||t||!1}}});
+},{}],"S+Fx":[function(require,module,exports) {
+var e=require("anchor-js"),t=new e;t.options.placement="left",t.add("h3");var n=document.getElementById("toc").getElementsByTagName("a");document.getElementById("filter-input").addEventListener("keyup",function(e){var t,s,i;if(13===e.keyCode)for(t=0;t<n.length;t++)if(!(s=n[t]).classList.contains("display-none"))return location.replace(s.firstChild.href),e.preventDefault();var a=function(){return!0},o=this.value.toLowerCase();for(o.match(/^\s*$/)||(a=function(e){var t=e.firstChild.innerHTML||e.textContent;return t&&-1!==t.toLowerCase().indexOf(o)}),t=0;t<n.length;t++)s=n[t],i=Array.from(s.getElementsByTagName("a")),a(s)||i.some(a)?s.classList.remove("display-none"):s.classList.add("display-none")});for(var s=document.getElementsByClassName("toggle-sibling"),i=0;i<s.length;i++)s[i].addEventListener("click",a);function a(){var e=this.nextElementSibling,t=this.getElementsByClassName("icon")[0],n="display-none";e.classList.contains(n)?(e.classList.remove(n),t.innerHTML="▾"):(e.classList.add(n),t.innerHTML="▸")}function o(e){if(e){var t=document.getElementById(e);t&&0===t.offsetHeight&&t.parentNode.parentNode.classList.contains("display-none")&&t.parentNode.parentNode.classList.remove("display-none")}}function r(e){if(e&&!history.state){var t=document.getElementById(e);t&&t.scrollIntoView()}}function l(){o(location.hash.substring(1)),r(location.hash.substring(1))}window.addEventListener("hashchange",l),l();for(var d=document.getElementsByClassName("pre-open"),c=0;c<d.length;c++)d[c].addEventListener("mousedown",u,!1);function u(){o(this.hash.substring(1))}function m(){history.replaceState({},document.title)}function f(e){e&&history.replaceState(e.state,document.title)}window.addEventListener("load",function(){setTimeout(function(){f(),m()},1)}),window.addEventListener("popstate",f);
+},{"anchor-js":"SyYu"}],"249i":[function(require,module,exports) {
+require("./site");
+},{"./site":"S+Fx"}]},{},["249i"], null) \ No newline at end of file
diff --git a/node_modules/autoprefixer/node_modules/postcss/docs/api/assets/styles.min.css b/node_modules/autoprefixer/node_modules/postcss/docs/api/assets/styles.min.css
new file mode 100644
index 0000000..9258853
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/docs/api/assets/styles.min.css
@@ -0,0 +1 @@
+body,button{margin:0}button,input,select,textarea{font-family:inherit;font-size:100%}img{max-width:100%}svg{max-height:100%}fieldset,input,select,textarea{font-size:1rem;margin-top:0;margin-bottom:.5rem}input[type=datetime-local],input[type=datetime],input[type=email],input[type=month],input[type=number],input[type=password],input[type=search],input[type=tel],input[type=text],input[type=time],input[type=url],input[type=week]{box-sizing:border-box;height:2.25rem;padding:.5rem;vertical-align:middle;-webkit-appearance:none}select{box-sizing:border-box;line-height:1.75;padding:.5rem}select:not([multiple]){height:2.25rem;vertical-align:middle}textarea{box-sizing:border-box;line-height:1.75;padding:.5rem}.fieldset-reset{padding:0;margin-left:0;margin-right:0;border:0}.fieldset-reset legend{padding:0}.button,button{font-size:inherit;font-weight:700;text-decoration:none;cursor:pointer;display:inline-block;box-sizing:border-box;line-height:1.125rem;padding:.4rem .6rem;margin:0;height:auto;border:1px solid transparent;vertical-align:middle;-webkit-appearance:none}::-moz-focus-inner{border:0;padding:0}.button:hover{text-decoration:none}table{border-collapse:separate;border-spacing:0;max-width:100%;width:100%}th{text-align:left;font-weight:700}td,th{padding:.25rem 1rem;line-height:inherit}th{vertical-align:bottom}td{vertical-align:top}body{line-height:1.5;font-size:100%}body,h1,h2,h3,h4,h5,h6{font-family:Helvetica Neue,Helvetica,sans-serif}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.25;margin-top:1em;margin-bottom:.5em}dl,ol,p,ul{font-size:1rem;margin-top:0;margin-bottom:1rem}ol,ul{padding-left:2rem}code,pre,samp{font-family:Consolas,Source Code Pro,monospace;font-size:inherit}pre{margin-top:0;margin-bottom:1rem;overflow-x:scroll;padding:1rem;background-color:rgba(0,0,0,.03125)}blockquote,hr{margin-top:2rem;margin-bottom:2rem}blockquote{margin-left:0;padding-left:1rem;padding-right:1rem}blockquote,blockquote p{font-size:1.25rem;font-style:italic}.h1,h1{font-size:2rem}.h2,h2{font-size:1.5rem}.h3,h3{font-size:1.25rem}.h4,h4{font-size:1rem}.h5,h5{font-size:.875rem}.h6,h6{font-size:.75rem}.list-reset{list-style:none;padding-left:0}.inline{display:inline}.block{display:block}.inline-block{display:inline-block}.overflow-hidden{overflow:hidden}.overflow-scroll{overflow:scroll}.overflow-auto{overflow:auto}.clearfix:after,.clearfix:before{content:" ";display:table}.clearfix:after{clear:both}.left{float:left}.right{float:right}.fit{max-width:100%}.half-width{width:50%}.full-width{width:100%}.bold{font-weight:700}.regular{font-weight:400}.italic{font-style:italic}.caps{text-transform:uppercase;letter-spacing:.2em}.left-align{text-align:left}.center{text-align:center}.right-align{text-align:right}.justify{text-align:justify}.nowrap{white-space:nowrap}.m0{margin:0}.mt0{margin-top:0}.mr0{margin-right:0}.mb0{margin-bottom:0}.ml0{margin-left:0}.m1{margin:.5rem}.mt1{margin-top:.5rem}.mr1{margin-right:.5rem}.mb1{margin-bottom:.5rem}.ml1{margin-left:.5rem}.m2{margin:1rem}.mt2{margin-top:1rem}.mr2{margin-right:1rem}.mb2{margin-bottom:1rem}.ml2{margin-left:1rem}.m3{margin:2rem}.mt3{margin-top:2rem}.mr3{margin-right:2rem}.mb3{margin-bottom:2rem}.ml3{margin-left:2rem}.m4{margin:4rem}.mt4{margin-top:4rem}.mr4{margin-right:4rem}.mb4{margin-bottom:4rem}.ml4{margin-left:4rem}.mxn1{margin-left:-.5rem;margin-right:-.5rem}.mxn2{margin-left:-1rem;margin-right:-1rem}.mxn3{margin-left:-2rem;margin-right:-2rem}.mxn4{margin-left:-4rem;margin-right:-4rem}.mx-auto{margin-left:auto;margin-right:auto}.p1{padding:.5rem}.py1{padding-top:.5rem;padding-bottom:.5rem}.px1{padding-left:.5rem;padding-right:.5rem}.p2{padding:1rem}.py2{padding-top:1rem;padding-bottom:1rem}.px2{padding-left:1rem;padding-right:1rem}.p3{padding:2rem}.py3{padding-top:2rem;padding-bottom:2rem}.px3{padding-left:2rem;padding-right:2rem}.p4{padding:4rem}.py4{padding-top:4rem;padding-bottom:4rem}.px4{padding-left:4rem;padding-right:4rem}.lg-show,.md-show,.sm-show{display:none!important}@media (min-width:40em){.sm-show{display:block!important}}@media (min-width:52em){.md-show{display:block!important}}@media (min-width:64em){.lg-show{display:block!important}}@media (min-width:40em){.sm-hide{display:none!important}}@media (min-width:52em){.md-hide{display:none!important}}@media (min-width:64em){.lg-hide{display:none!important}}.display-none{display:none!important}.hide{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.z1{z-index:1}.z2{z-index:2}.z3{z-index:3}.z4{z-index:4}.absolute-center{top:0;right:0;bottom:0;left:0;margin:auto;display:table}.button-small{padding:.25rem .5rem}.button-big{padding:1rem 1.25rem}.button-narrow{padding-left:.5rem;padding-right:.5rem}.container{max-width:64em;margin-left:auto;margin-right:auto}.col{float:left}.col,.col-right{box-sizing:border-box}.col-right{float:right}.col-1{width:8.33333%}.col-2{width:16.66667%}.col-3{width:25%}.col-4{width:33.33333%}.col-5{width:41.66667%}.col-6{width:50%}.col-7{width:58.33333%}.col-8{width:66.66667%}.col-9{width:75%}.col-10{width:83.33333%}.col-11{width:91.66667%}.col-12{width:100%}@media (min-width:40em){.sm-col{float:left;box-sizing:border-box}.sm-col-right{float:right;box-sizing:border-box}.sm-col-1{width:8.33333%}.sm-col-2{width:16.66667%}.sm-col-3{width:25%}.sm-col-4{width:33.33333%}.sm-col-5{width:41.66667%}.sm-col-6{width:50%}.sm-col-7{width:58.33333%}.sm-col-8{width:66.66667%}.sm-col-9{width:75%}.sm-col-10{width:83.33333%}.sm-col-11{width:91.66667%}.sm-col-12{width:100%}}@media (min-width:52em){.md-col{float:left;box-sizing:border-box}.md-col-right{float:right;box-sizing:border-box}.md-col-1{width:8.33333%}.md-col-2{width:16.66667%}.md-col-3{width:25%}.md-col-4{width:33.33333%}.md-col-5{width:41.66667%}.md-col-6{width:50%}.md-col-7{width:58.33333%}.md-col-8{width:66.66667%}.md-col-9{width:75%}.md-col-10{width:83.33333%}.md-col-11{width:91.66667%}.md-col-12{width:100%}}@media (min-width:64em){.lg-col{float:left;box-sizing:border-box}.lg-col-right{float:right;box-sizing:border-box}.lg-col-1{width:8.33333%}.lg-col-2{width:16.66667%}.lg-col-3{width:25%}.lg-col-4{width:33.33333%}.lg-col-5{width:41.66667%}.lg-col-6{width:50%}.lg-col-7{width:58.33333%}.lg-col-8{width:66.66667%}.lg-col-9{width:75%}.lg-col-10{width:83.33333%}.lg-col-11{width:91.66667%}.lg-col-12{width:100%}}.flex{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flex-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.flex-wrap{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.flex-center{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.flex-baseline{-webkit-box-align:baseline;-webkit-align-items:baseline;-ms-flex-align:baseline;align-items:baseline}.flex-stretch{-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.flex-start{-webkit-box-align:start;-webkit-align-items:flex-start;-ms-flex-align:start;align-items:flex-start}.flex-end{-webkit-box-align:end;-webkit-align-items:flex-end;-ms-flex-align:end;align-items:flex-end}.flex-first{-webkit-box-ordinal-group:0;-webkit-order:-1;-ms-flex-order:-1;order:-1}.flex-last{-webkit-box-ordinal-group:1025;-webkit-order:1024;-ms-flex-order:1024;order:1024}.flex-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.flex-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.flex-none{-webkit-box-flex:0;-webkit-flex:none;-ms-flex:none;flex:none}.flex>div{box-sizing:border-box}@media (min-width:40em){.sm-flex{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.sm-flex>div{box-sizing:border-box}}@media (min-width:52em){.md-flex{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.md-flex>div{box-sizing:border-box}}@media (min-width:64em){.lg-flex{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.lg-flex>div{box-sizing:border-box}}body{color:#222;background-color:#fff}a{color:#0074d9;text-decoration:none}a:hover{text-decoration:underline}hr{border:0;border-bottom:1px solid rgba(0,0,0,.125)}.button{color:#fff;background-color:#0074d9;border-radius:3px}.button:hover{box-shadow:inset 0 0 0 20rem rgba(0,0,0,.0625)}.button:focus{outline:none;border-color:rgba(0,0,0,.125);box-shadow:0 0 2px 1px rgba(0,0,0,.25)}.button.is-active,.button:active{box-shadow:inset 0 0 0 20rem rgba(0,0,0,.125),inset 0 3px 4px 0 rgba(0,0,0,.25),0 0 1px rgba(0,0,0,.125)}.button.is-disabled,.button:disabled{opacity:.5}.field-light{background-color:#fff;-webkit-transition:box-shadow .2s ease;transition:box-shadow .2s ease;border:1px solid rgba(0,0,0,.125);border-radius:3px}.field-light:focus{outline:none;border-color:#0074d9;box-shadow:0 0 2px rgba(0,116,217,.5)}.field-light:disabled{color:#aaa}.field-light:disabled,.field-light:read-only:not(select){background-color:rgba(0,0,0,.125)}.field-light:invalid{border-color:#ff4136}.field-light.is-success{border-color:#2ecc40}.field-light.is-warning{border-color:#ffdc00}.field-light.is-error{border-color:#ff4136}.checkbox-light,.radio-light{-webkit-transition:box-shadow .2s ease;transition:box-shadow .2s ease}.radio-light{border-radius:50%}.checkbox-light:focus,.radio-light:focus{outline:none;box-shadow:0 0 2px rgba(0,116,217,.5)}.field-dark{color:#fff;background-color:rgba(0,0,0,.25);border:1px solid rgba(0,0,0,.0625);border-radius:3px}.field-dark::-webkit-input-placeholder{color:hsla(0,0%,100%,.75)}.field-dark::-moz-placeholder{color:hsla(0,0%,100%,.75)}.field-dark:-ms-input-placeholder{color:hsla(0,0%,100%,.75)}.field-dark::placeholder{color:hsla(0,0%,100%,.75)}.field-dark:focus{outline:0;border:1px solid hsla(0,0%,100%,.5)}.field-dark:read-only:not(select){background-color:hsla(0,0%,100%,.25)}.field-dark:invalid{border-color:#ff4136}.field-dark.is-success{border-color:#2ecc40}.field-dark.is-warning{border-color:#ffdc00}.field-dark.is-error{border-color:#ff4136}input[type=range]{vertical-align:middle;background-color:transparent}.range-light{color:inherit;-webkit-appearance:none;padding-top:.5rem;padding-bottom:.5rem}.range-light::-webkit-slider-thumb{-webkit-appearance:none;position:relative;width:.5rem;height:1.25rem;border-radius:3px;background-color:currentcolor;cursor:pointer;margin-top:-.5rem}.range-light::-webkit-slider-thumb:before{content:"";display:block;position:absolute;top:-.5rem;left:-.875rem;width:2.25rem;height:2.25rem;opacity:0}.range-light::-moz-range-thumb{width:.5rem;height:1.25rem;border-radius:3px;border-color:transparent;border-width:0;background-color:currentcolor;cursor:pointer}.range-light::-webkit-slider-runnable-track{height:.25rem;cursor:pointer;border-radius:3px;background-color:rgba(0,0,0,.25)}.range-light::-moz-range-track{height:.25rem;cursor:pointer;border-radius:3px;background-color:rgba(0,0,0,.25)}.range-light:focus{outline:none}.range-light:focus::-webkit-slider-thumb{outline:none;border:0;box-shadow:0 0 1px 2px currentcolor}.range-light:focus::-moz-range-thumb{outline:none;border:0;box-shadow:0 0 1px 2px currentcolor}.progress{display:block;width:100%;height:.5625rem;margin:.5rem 0;background-color:rgba(0,0,0,.125);border:0;border-radius:10000px;overflow:hidden;-webkit-appearance:none;cursor:pointer}.progress::-webkit-progress-bar{-webkit-appearance:none;background-color:rgba(0,0,0,.125)}.progress::-webkit-progress-value{-webkit-appearance:none;background-color:currentColor}.progress::-moz-progress-bar{background-color:currentColor}.table-light td,.table-light th{border-bottom:1px solid rgba(0,0,0,.125)}.table-light tr:last-child td{border-bottom:0}.button-outline{position:relative;z-index:2;color:inherit;background-color:transparent;border-radius:3px;border:1px solid;-webkit-transition-duration:.1s;transition-duration:.1s;-webkit-transition-timing-function:ease-out;transition-timing-function:ease-out;-webkit-transition-property:box-shadow,background-color;transition-property:box-shadow,background-color}.button-outline:before{content:"";width:100%;height:100%;display:block;position:absolute;z-index:-1;top:-1px;left:-1px;border:1px solid transparent;background-color:currentcolor;border-radius:3px;-webkit-transition-duration:.1s;transition-duration:.1s;-webkit-transition-timing-function:ease-out;transition-timing-function:ease-out;-webkit-transition-property:opacity;transition-property:opacity;opacity:0}.button-outline:hover{box-shadow:none}.button-outline:hover:before{opacity:.125}.button-outline:focus{outline:none;border:1px solid;box-shadow:0 0 3px 1px}.button-outline.is-active,.button-outline:active{box-shadow:inset 0 1px 5px 0,0 0 1px}.button-outline.is-disabled,.button-outline:disabled{opacity:.5}.button-transparent{position:relative;z-index:2;color:inherit;background-color:transparent;border-radius:0;border:1px solid transparent}.button-transparent:before{content:"";width:100%;height:100%;display:block;position:absolute;z-index:-1;top:-1px;left:-1px;border:1px solid transparent;background-color:currentcolor;-webkit-transition-duration:.1s;transition-duration:.1s;-webkit-transition-timing-function:ease-out;transition-timing-function:ease-out;-webkit-transition-property:opacity;transition-property:opacity;opacity:0}.button-transparent:hover{box-shadow:none}.button-transparent:hover:before{opacity:.0625;opacity:.09375}.button-transparent:focus{outline:none;border-color:transparent;box-shadow:0 0 3px}.button-transparent.is-active:before,.button-transparent:active:before{opacity:.0625}.button-transparent.is-disabled,.button-transparent:disabled{opacity:.5}.bg-cover{background-size:cover}.bg-contain{background-size:contain}.bg-center{background-position:50%}.bg-top{background-position:top}.bg-right{background-position:100%}.bg-bottom{background-position:bottom}.bg-left{background-position:0}.border{border:1px solid rgba(0,0,0,.125)}.border-top{border-top:1px solid rgba(0,0,0,.125)}.border-right{border-right:1px solid rgba(0,0,0,.125)}.border-bottom{border-bottom:1px solid rgba(0,0,0,.125)}.border-left{border-left:1px solid rgba(0,0,0,.125)}.rounded{border-radius:3px}.circle{border-radius:50%}.rounded-top{border-radius:3px 3px 0 0}.rounded-right{border-radius:0 3px 3px 0}.rounded-bottom{border-radius:0 0 3px 3px}.rounded-left{border-radius:3px 0 0 3px}.not-rounded{border-radius:0}.black,.dark-gray{color:#222}.gray,.mid-gray{color:#aaa}.light-gray,.silver{color:#ddd}.white{color:#fff}.aqua{color:#7fdbff}.blue{color:#0074d9}.navy{color:#001f3f}.teal{color:#39cccc}.green{color:#2ecc40}.olive{color:#3d9970}.lime{color:#01ff70}.yellow{color:#ffdc00}.orange{color:#ff851b}.red{color:#ff4136}.fuchsia{color:#f012be}.purple{color:#b10dc9}.maroon{color:#85144b}.bg-black,.bg-dark-gray{background-color:#222}.bg-gray,.bg-mid-gray{background-color:#aaa}.bg-light-gray,.bg-silver{background-color:#ddd}.bg-white{background-color:#fff}.bg-aqua{background-color:#7fdbff}.bg-blue{background-color:#0074d9}.bg-navy{background-color:#001f3f}.bg-teal{background-color:#39cccc}.bg-green{background-color:#2ecc40}.bg-olive{background-color:#3d9970}.bg-lime{background-color:#01ff70}.bg-yellow{background-color:#ffdc00}.bg-orange{background-color:#ff851b}.bg-red{background-color:#ff4136}.bg-fuchsia{background-color:#f012be}.bg-purple{background-color:#b10dc9}.bg-maroon{background-color:#85144b}.bg-darken-0{background-color:rgba(0,0,0,.03125)}.bg-darken-1{background-color:rgba(0,0,0,.0625)}.bg-darken-2{background-color:rgba(0,0,0,.125)}.bg-darken-3{background-color:rgba(0,0,0,.25)}.bg-darken-4{background-color:rgba(0,0,0,.5)}.border-aqua{border-color:#7fdbff}.border-blue{border-color:#0074d9}.border-navy{border-color:#001f3f}.border-teal{border-color:#39cccc}.border-green{border-color:#2ecc40}.border-olive{border-color:#3d9970}.border-lime{border-color:#01ff70}.border-yellow{border-color:#ffdc00}.border-orange{border-color:#ff851b}.border-red{border-color:#ff4136}.border-fuchsia{border-color:#f012be}.border-purple{border-color:#b10dc9}.border-maroon{border-color:#85144b}.border-black{border-color:#222}.border-gray{border-color:#aaa}.border-silver{border-color:#ddd}.border-white{border-color:#fff}.border-darken-1{border-color:rgba(0,0,0,.0625)}.border-darken-2{border-color:rgba(0,0,0,.125)}.border-darken-3{border-color:rgba(0,0,0,.25)}.border-darken-4{border-color:rgba(0,0,0,.5)}.muted{opacity:.5}.hljs{color:#333;background:#f8f8f8;-webkit-text-size-adjust:none}.diff .hljs-header,.hljs-comment,.hljs-javadoc{color:#998;font-style:italic}.css .rule .hljs-keyword,.hljs-keyword,.hljs-request,.hljs-status,.hljs-subst,.hljs-winutils,.nginx .hljs-title{color:#1184ce}.hljs-dartdoc,.hljs-hexcolor,.hljs-number,.hljs-phpdoc,.hljs-string,.hljs-tag .hljs-value,.ruby .hljs-constant,.tex .hljs-formula{color:#ed225d}.hljs-id,.hljs-title,.scss .hljs-preprocessor{color:#900;font-weight:700}.hljs-list .hljs-keyword,.hljs-subst{font-weight:400}.hljs-class .hljs-title,.hljs-type,.tex .hljs-command,.vhdl .hljs-literal{color:#458;font-weight:700}.django .hljs-tag .hljs-keyword,.hljs-rules .hljs-property,.hljs-tag,.hljs-tag .hljs-title{color:navy;font-weight:400}.hljs-attribute,.hljs-variable,.lisp .hljs-body{color:teal}.hljs-regexp{color:#009926}.clojure .hljs-keyword,.hljs-prompt,.hljs-symbol,.lisp .hljs-keyword,.ruby .hljs-symbol .hljs-string,.scheme .hljs-keyword,.tex .hljs-special{color:#990073}.hljs-built_in{color:#0086b3}.hljs-cdata,.hljs-doctype,.hljs-pi,.hljs-pragma,.hljs-preprocessor,.hljs-shebang{color:#999;font-weight:700}.hljs-deletion{background:#fdd}.hljs-addition{background:#dfd}.diff .hljs-change{background:#0086b3}.hljs-chunk{color:#aaa}.hljs{display:block;overflow-x:auto;padding:.5em;background:#232323;color:#e6e1dc}.hljs-comment,.hljs-quote{color:#bc9458;font-style:italic}.hljs-keyword,.hljs-selector-tag{color:#c26230}.hljs-number,.hljs-regexp,.hljs-string,.hljs-template-variable,.hljs-variable{color:#a5c261}.hljs-subst{color:#519f50}.hljs-name,.hljs-tag{color:#e8bf6a}.hljs-type{color:#da4939}.hljs-attr,.hljs-built_in,.hljs-builtin-name,.hljs-bullet,.hljs-link,.hljs-symbol{color:#6d9cbe}.hljs-params{color:#d0d0ff}.hljs-attribute{color:#cda869}.hljs-meta{color:#9b859d}.hljs-section,.hljs-title{color:#ffc66d}.hljs-addition{background-color:#144212}.hljs-addition,.hljs-deletion{color:#e6e1dc;display:inline-block;width:100%}.hljs-deletion{background-color:#600}.hljs-selector-class{color:#9b703f}.hljs-selector-id{color:#8b98ab}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-link{text-decoration:underline}.documentation{font-family:system-ui,-apple-system,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;overflow-x:hidden}.documentation a{color:#298ee6}.documentation a.black{color:#052e52}.container-small{max-width:58rem;margin-left:auto;margin-right:auto}.font-smaller{font-size:80%}.dark a.quiet{color:#fff}.dark a{color:#d2d2d2}.fade{opacity:.5}.button-indent{padding:.25rem 1.5rem;font-size:90%}.section-indent{border-left:2px solid #eee}.force-inline *{display:inline}section:target{background:#fafafa}.documentation-sidebar a:active{background:#298ee6;color:#fff}.documentation h1,.documentation h2,.documentation h3,.documentation h4,.documentation h5,.documentation h6{font-family:inherit;font-weight:700}p{font-family:inherit;line-height:1.7rem;color:#464646}.documentation code,.documentation pre,.documentation samp{font-family:Consolas,Inconsolata,Source Code Pro,monospace}pre{border-radius:3px;word-break:break-word;white-space:pre-wrap;display:block}h4{font-size:.8rem}.quiet{color:#7d7d7d}.small{font-size:.9rem}td{word-break:break-word}th.small{font-size:.8rem}.strong{font-weight:700}li{margin-top:10px}.keyline-all{border:1px solid #7d7d7d}.keyline-light{border:1px solid #e0e0e0}.fill-light{background:#efefef}li>code,p>code,td>code>a{font-weight:700}.documentation pre{padding:1rem;background:#052e52;color:#e6e1dc;font-size:.9rem}.bg-midnight{background:#052e52}.dark-link a,.dark-link code{color:#052e52}table p,table td{font-size:.9rem;line-height:1.3rem}.documentation td,.documentation th,.input{padding:.5rem}.input{font-family:inherit;display:block;width:100%;height:2rem;margin-bottom:1rem;border:1px solid #ccc;font-size:.875rem;border-radius:3px;box-sizing:border-box} \ No newline at end of file
diff --git a/node_modules/autoprefixer/node_modules/postcss/docs/api/index.html b/node_modules/autoprefixer/node_modules/postcss/docs/api/index.html
new file mode 100644
index 0000000..8dfeb47
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/docs/api/index.html
@@ -0,0 +1,22531 @@
+<!doctype html>
+<html>
+<head>
+ <meta charset='utf-8' />
+ <title>postcss 7.0.17 | Documentation</title>
+ <meta name='description' content='Tool for transforming styles with JS plugins'>
+ <meta name='viewport' content='width=device-width,initial-scale=1'>
+ <link href='assets/styles.min.css' rel='stylesheet' />
+</head>
+
+<body class='documentation'>
+<div class='px2'>
+ <div class='clearfix md-flex lg-flex flex-stretch mxn2'>
+ <div class='documentation-sidebar relative top-0 bottom-0 right-0 px2 py2 col-3 md-show'>
+ <div class='font-smaller fixed col-3 top-0 bottom-0 left-0 overflow-auto fill-light dark-link'>
+ <div class='px2'>
+ <h3 class='mb0 no-anchor'><code>postcss</code></h3>
+ <div class='mb1'><code>7.0.17</code></div>
+ <input placeholder='Filter' id='filter-input' class='col12 block input' type='text' />
+ <div id="toc">
+
+
+
+ <a
+ href='#classes'
+ class="blockmt1 quiet rounded bold block h4 mt2 ">
+ <code>CLASSES</code>
+
+ </a>
+
+
+
+
+
+ <a
+ href='#atrule'
+ class="regular block toggle-sibling">
+ <code>AtRule</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#atruleappend'
+ class='button-indent regular block'>
+ <code>#append</code>
+ </a>
+
+ <a
+ href='#atruleeach'
+ class='button-indent regular block'>
+ <code>#each</code>
+ </a>
+
+ <a
+ href='#atruleevery'
+ class='button-indent regular block'>
+ <code>#every</code>
+ </a>
+
+ <a
+ href='#atrulefirst'
+ class='button-indent regular block'>
+ <code>#first</code>
+ </a>
+
+ <a
+ href='#atruleindex'
+ class='button-indent regular block'>
+ <code>#index</code>
+ </a>
+
+ <a
+ href='#atruleinsertafter'
+ class='button-indent regular block'>
+ <code>#insertAfter</code>
+ </a>
+
+ <a
+ href='#atruleinsertbefore'
+ class='button-indent regular block'>
+ <code>#insertBefore</code>
+ </a>
+
+ <a
+ href='#atrulelast'
+ class='button-indent regular block'>
+ <code>#last</code>
+ </a>
+
+ <a
+ href='#atruleprepend'
+ class='button-indent regular block'>
+ <code>#prepend</code>
+ </a>
+
+ <a
+ href='#atruleremoveall'
+ class='button-indent regular block'>
+ <code>#removeAll</code>
+ </a>
+
+ <a
+ href='#atruleremovechild'
+ class='button-indent regular block'>
+ <code>#removeChild</code>
+ </a>
+
+ <a
+ href='#atrulereplacevalues'
+ class='button-indent regular block'>
+ <code>#replaceValues</code>
+ </a>
+
+ <a
+ href='#atrulesome'
+ class='button-indent regular block'>
+ <code>#some</code>
+ </a>
+
+ <a
+ href='#atrulewalk'
+ class='button-indent regular block'>
+ <code>#walk</code>
+ </a>
+
+ <a
+ href='#atrulewalkatrules'
+ class='button-indent regular block'>
+ <code>#walkAtRules</code>
+ </a>
+
+ <a
+ href='#atrulewalkcomments'
+ class='button-indent regular block'>
+ <code>#walkComments</code>
+ </a>
+
+ <a
+ href='#atrulewalkdecls'
+ class='button-indent regular block'>
+ <code>#walkDecls</code>
+ </a>
+
+ <a
+ href='#atrulewalkrules'
+ class='button-indent regular block'>
+ <code>#walkRules</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#comment'
+ class="regular block toggle-sibling">
+ <code>Comment</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#commentafter'
+ class='button-indent regular block'>
+ <code>#after</code>
+ </a>
+
+ <a
+ href='#commentbefore'
+ class='button-indent regular block'>
+ <code>#before</code>
+ </a>
+
+ <a
+ href='#commentcleanraws'
+ class='button-indent regular block'>
+ <code>#cleanRaws</code>
+ </a>
+
+ <a
+ href='#commentclone'
+ class='button-indent regular block'>
+ <code>#clone</code>
+ </a>
+
+ <a
+ href='#commentcloneafter'
+ class='button-indent regular block'>
+ <code>#cloneAfter</code>
+ </a>
+
+ <a
+ href='#commentclonebefore'
+ class='button-indent regular block'>
+ <code>#cloneBefore</code>
+ </a>
+
+ <a
+ href='#commenterror'
+ class='button-indent regular block'>
+ <code>#error</code>
+ </a>
+
+ <a
+ href='#commentnext'
+ class='button-indent regular block'>
+ <code>#next</code>
+ </a>
+
+ <a
+ href='#commentprev'
+ class='button-indent regular block'>
+ <code>#prev</code>
+ </a>
+
+ <a
+ href='#commentraw'
+ class='button-indent regular block'>
+ <code>#raw</code>
+ </a>
+
+ <a
+ href='#commentremove'
+ class='button-indent regular block'>
+ <code>#remove</code>
+ </a>
+
+ <a
+ href='#commentreplacewith'
+ class='button-indent regular block'>
+ <code>#replaceWith</code>
+ </a>
+
+ <a
+ href='#commentroot'
+ class='button-indent regular block'>
+ <code>#root</code>
+ </a>
+
+ <a
+ href='#commenttostring'
+ class='button-indent regular block'>
+ <code>#toString</code>
+ </a>
+
+ <a
+ href='#commentwarn'
+ class='button-indent regular block'>
+ <code>#warn</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#container'
+ class="regular block toggle-sibling">
+ <code>Container</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#containerafter'
+ class='button-indent regular block'>
+ <code>#after</code>
+ </a>
+
+ <a
+ href='#containerappend'
+ class='button-indent regular block'>
+ <code>#append</code>
+ </a>
+
+ <a
+ href='#containerbefore'
+ class='button-indent regular block'>
+ <code>#before</code>
+ </a>
+
+ <a
+ href='#containercleanraws'
+ class='button-indent regular block'>
+ <code>#cleanRaws</code>
+ </a>
+
+ <a
+ href='#containerclone'
+ class='button-indent regular block'>
+ <code>#clone</code>
+ </a>
+
+ <a
+ href='#containercloneafter'
+ class='button-indent regular block'>
+ <code>#cloneAfter</code>
+ </a>
+
+ <a
+ href='#containerclonebefore'
+ class='button-indent regular block'>
+ <code>#cloneBefore</code>
+ </a>
+
+ <a
+ href='#containereach'
+ class='button-indent regular block'>
+ <code>#each</code>
+ </a>
+
+ <a
+ href='#containererror'
+ class='button-indent regular block'>
+ <code>#error</code>
+ </a>
+
+ <a
+ href='#containerevery'
+ class='button-indent regular block'>
+ <code>#every</code>
+ </a>
+
+ <a
+ href='#containerfirst'
+ class='button-indent regular block'>
+ <code>#first</code>
+ </a>
+
+ <a
+ href='#containerindex'
+ class='button-indent regular block'>
+ <code>#index</code>
+ </a>
+
+ <a
+ href='#containerinsertafter'
+ class='button-indent regular block'>
+ <code>#insertAfter</code>
+ </a>
+
+ <a
+ href='#containerinsertbefore'
+ class='button-indent regular block'>
+ <code>#insertBefore</code>
+ </a>
+
+ <a
+ href='#containerlast'
+ class='button-indent regular block'>
+ <code>#last</code>
+ </a>
+
+ <a
+ href='#containernext'
+ class='button-indent regular block'>
+ <code>#next</code>
+ </a>
+
+ <a
+ href='#containerprepend'
+ class='button-indent regular block'>
+ <code>#prepend</code>
+ </a>
+
+ <a
+ href='#containerprev'
+ class='button-indent regular block'>
+ <code>#prev</code>
+ </a>
+
+ <a
+ href='#containerraw'
+ class='button-indent regular block'>
+ <code>#raw</code>
+ </a>
+
+ <a
+ href='#containerremove'
+ class='button-indent regular block'>
+ <code>#remove</code>
+ </a>
+
+ <a
+ href='#containerremoveall'
+ class='button-indent regular block'>
+ <code>#removeAll</code>
+ </a>
+
+ <a
+ href='#containerremovechild'
+ class='button-indent regular block'>
+ <code>#removeChild</code>
+ </a>
+
+ <a
+ href='#containerreplacevalues'
+ class='button-indent regular block'>
+ <code>#replaceValues</code>
+ </a>
+
+ <a
+ href='#containerreplacewith'
+ class='button-indent regular block'>
+ <code>#replaceWith</code>
+ </a>
+
+ <a
+ href='#containerroot'
+ class='button-indent regular block'>
+ <code>#root</code>
+ </a>
+
+ <a
+ href='#containersome'
+ class='button-indent regular block'>
+ <code>#some</code>
+ </a>
+
+ <a
+ href='#containertostring'
+ class='button-indent regular block'>
+ <code>#toString</code>
+ </a>
+
+ <a
+ href='#containerwalk'
+ class='button-indent regular block'>
+ <code>#walk</code>
+ </a>
+
+ <a
+ href='#containerwalkatrules'
+ class='button-indent regular block'>
+ <code>#walkAtRules</code>
+ </a>
+
+ <a
+ href='#containerwalkcomments'
+ class='button-indent regular block'>
+ <code>#walkComments</code>
+ </a>
+
+ <a
+ href='#containerwalkdecls'
+ class='button-indent regular block'>
+ <code>#walkDecls</code>
+ </a>
+
+ <a
+ href='#containerwalkrules'
+ class='button-indent regular block'>
+ <code>#walkRules</code>
+ </a>
+
+ <a
+ href='#containerwarn'
+ class='button-indent regular block'>
+ <code>#warn</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#csssyntaxerror'
+ class="regular block toggle-sibling">
+ <code>CssSyntaxError</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#csssyntaxerrorname'
+ class='button-indent regular block'>
+ <code>#name</code>
+ </a>
+
+ <a
+ href='#csssyntaxerrorreason'
+ class='button-indent regular block'>
+ <code>#reason</code>
+ </a>
+
+ <a
+ href='#csssyntaxerrorfile'
+ class='button-indent regular block'>
+ <code>#file</code>
+ </a>
+
+ <a
+ href='#csssyntaxerrorsource'
+ class='button-indent regular block'>
+ <code>#source</code>
+ </a>
+
+ <a
+ href='#csssyntaxerrorplugin'
+ class='button-indent regular block'>
+ <code>#plugin</code>
+ </a>
+
+ <a
+ href='#csssyntaxerrorline'
+ class='button-indent regular block'>
+ <code>#line</code>
+ </a>
+
+ <a
+ href='#csssyntaxerrorcolumn'
+ class='button-indent regular block'>
+ <code>#column</code>
+ </a>
+
+ <a
+ href='#csssyntaxerrormessage'
+ class='button-indent regular block'>
+ <code>#message</code>
+ </a>
+
+ <a
+ href='#csssyntaxerrorshowsourcecode'
+ class='button-indent regular block'>
+ <code>#showSourceCode</code>
+ </a>
+
+ <a
+ href='#csssyntaxerrortostring'
+ class='button-indent regular block'>
+ <code>#toString</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#declaration'
+ class="regular block toggle-sibling">
+ <code>Declaration</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#declarationafter'
+ class='button-indent regular block'>
+ <code>#after</code>
+ </a>
+
+ <a
+ href='#declarationbefore'
+ class='button-indent regular block'>
+ <code>#before</code>
+ </a>
+
+ <a
+ href='#declarationcleanraws'
+ class='button-indent regular block'>
+ <code>#cleanRaws</code>
+ </a>
+
+ <a
+ href='#declarationclone'
+ class='button-indent regular block'>
+ <code>#clone</code>
+ </a>
+
+ <a
+ href='#declarationcloneafter'
+ class='button-indent regular block'>
+ <code>#cloneAfter</code>
+ </a>
+
+ <a
+ href='#declarationclonebefore'
+ class='button-indent regular block'>
+ <code>#cloneBefore</code>
+ </a>
+
+ <a
+ href='#declarationerror'
+ class='button-indent regular block'>
+ <code>#error</code>
+ </a>
+
+ <a
+ href='#declarationnext'
+ class='button-indent regular block'>
+ <code>#next</code>
+ </a>
+
+ <a
+ href='#declarationprev'
+ class='button-indent regular block'>
+ <code>#prev</code>
+ </a>
+
+ <a
+ href='#declarationraw'
+ class='button-indent regular block'>
+ <code>#raw</code>
+ </a>
+
+ <a
+ href='#declarationremove'
+ class='button-indent regular block'>
+ <code>#remove</code>
+ </a>
+
+ <a
+ href='#declarationreplacewith'
+ class='button-indent regular block'>
+ <code>#replaceWith</code>
+ </a>
+
+ <a
+ href='#declarationroot'
+ class='button-indent regular block'>
+ <code>#root</code>
+ </a>
+
+ <a
+ href='#declarationtostring'
+ class='button-indent regular block'>
+ <code>#toString</code>
+ </a>
+
+ <a
+ href='#declarationwarn'
+ class='button-indent regular block'>
+ <code>#warn</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#input'
+ class="regular block toggle-sibling">
+ <code>Input</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#inputcss'
+ class='button-indent regular block'>
+ <code>#css</code>
+ </a>
+
+ <a
+ href='#inputfile'
+ class='button-indent regular block'>
+ <code>#file</code>
+ </a>
+
+ <a
+ href='#inputmap'
+ class='button-indent regular block'>
+ <code>#map</code>
+ </a>
+
+ <a
+ href='#inputid'
+ class='button-indent regular block'>
+ <code>#id</code>
+ </a>
+
+ <a
+ href='#inputorigin'
+ class='button-indent regular block'>
+ <code>#origin</code>
+ </a>
+
+ <a
+ href='#inputfrom'
+ class='button-indent regular block'>
+ <code>#from</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#lazyresult'
+ class="regular block toggle-sibling">
+ <code>LazyResult</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#lazyresultprocessor'
+ class='button-indent regular block'>
+ <code>#processor</code>
+ </a>
+
+ <a
+ href='#lazyresultopts'
+ class='button-indent regular block'>
+ <code>#opts</code>
+ </a>
+
+ <a
+ href='#lazyresultcss'
+ class='button-indent regular block'>
+ <code>#css</code>
+ </a>
+
+ <a
+ href='#lazyresultcontent'
+ class='button-indent regular block'>
+ <code>#content</code>
+ </a>
+
+ <a
+ href='#lazyresultmap'
+ class='button-indent regular block'>
+ <code>#map</code>
+ </a>
+
+ <a
+ href='#lazyresultroot'
+ class='button-indent regular block'>
+ <code>#root</code>
+ </a>
+
+ <a
+ href='#lazyresultmessages'
+ class='button-indent regular block'>
+ <code>#messages</code>
+ </a>
+
+ <a
+ href='#lazyresultwarnings'
+ class='button-indent regular block'>
+ <code>#warnings</code>
+ </a>
+
+ <a
+ href='#lazyresulttostring'
+ class='button-indent regular block'>
+ <code>#toString</code>
+ </a>
+
+ <a
+ href='#lazyresultthen'
+ class='button-indent regular block'>
+ <code>#then</code>
+ </a>
+
+ <a
+ href='#lazyresultcatch'
+ class='button-indent regular block'>
+ <code>#catch</code>
+ </a>
+
+ <a
+ href='#lazyresultfinally'
+ class='button-indent regular block'>
+ <code>#finally</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#node'
+ class="regular block toggle-sibling">
+ <code>Node</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#nodeerror'
+ class='button-indent regular block'>
+ <code>#error</code>
+ </a>
+
+ <a
+ href='#nodewarn'
+ class='button-indent regular block'>
+ <code>#warn</code>
+ </a>
+
+ <a
+ href='#noderemove'
+ class='button-indent regular block'>
+ <code>#remove</code>
+ </a>
+
+ <a
+ href='#nodetostring'
+ class='button-indent regular block'>
+ <code>#toString</code>
+ </a>
+
+ <a
+ href='#nodeclone'
+ class='button-indent regular block'>
+ <code>#clone</code>
+ </a>
+
+ <a
+ href='#nodeclonebefore'
+ class='button-indent regular block'>
+ <code>#cloneBefore</code>
+ </a>
+
+ <a
+ href='#nodecloneafter'
+ class='button-indent regular block'>
+ <code>#cloneAfter</code>
+ </a>
+
+ <a
+ href='#nodereplacewith'
+ class='button-indent regular block'>
+ <code>#replaceWith</code>
+ </a>
+
+ <a
+ href='#nodenext'
+ class='button-indent regular block'>
+ <code>#next</code>
+ </a>
+
+ <a
+ href='#nodeprev'
+ class='button-indent regular block'>
+ <code>#prev</code>
+ </a>
+
+ <a
+ href='#nodebefore'
+ class='button-indent regular block'>
+ <code>#before</code>
+ </a>
+
+ <a
+ href='#nodeafter'
+ class='button-indent regular block'>
+ <code>#after</code>
+ </a>
+
+ <a
+ href='#noderaw'
+ class='button-indent regular block'>
+ <code>#raw</code>
+ </a>
+
+ <a
+ href='#noderoot'
+ class='button-indent regular block'>
+ <code>#root</code>
+ </a>
+
+ <a
+ href='#nodecleanraws'
+ class='button-indent regular block'>
+ <code>#cleanRaws</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#previousmap'
+ class="regular block toggle-sibling">
+ <code>PreviousMap</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#previousmapinline'
+ class='button-indent regular block'>
+ <code>#inline</code>
+ </a>
+
+ <a
+ href='#previousmapconsumer'
+ class='button-indent regular block'>
+ <code>#consumer</code>
+ </a>
+
+ <a
+ href='#previousmapwithcontent'
+ class='button-indent regular block'>
+ <code>#withContent</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#processor'
+ class="regular block toggle-sibling">
+ <code>Processor</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#processorversion'
+ class='button-indent regular block'>
+ <code>#version</code>
+ </a>
+
+ <a
+ href='#processorplugins'
+ class='button-indent regular block'>
+ <code>#plugins</code>
+ </a>
+
+ <a
+ href='#processoruse'
+ class='button-indent regular block'>
+ <code>#use</code>
+ </a>
+
+ <a
+ href='#processorprocess'
+ class='button-indent regular block'>
+ <code>#process</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#result'
+ class="regular block toggle-sibling">
+ <code>Result</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#resultprocessor'
+ class='button-indent regular block'>
+ <code>#processor</code>
+ </a>
+
+ <a
+ href='#resultmessages'
+ class='button-indent regular block'>
+ <code>#messages</code>
+ </a>
+
+ <a
+ href='#resultroot'
+ class='button-indent regular block'>
+ <code>#root</code>
+ </a>
+
+ <a
+ href='#resultopts'
+ class='button-indent regular block'>
+ <code>#opts</code>
+ </a>
+
+ <a
+ href='#resultcss'
+ class='button-indent regular block'>
+ <code>#css</code>
+ </a>
+
+ <a
+ href='#resultmap'
+ class='button-indent regular block'>
+ <code>#map</code>
+ </a>
+
+ <a
+ href='#resulttostring'
+ class='button-indent regular block'>
+ <code>#toString</code>
+ </a>
+
+ <a
+ href='#resultwarn'
+ class='button-indent regular block'>
+ <code>#warn</code>
+ </a>
+
+ <a
+ href='#resultwarnings'
+ class='button-indent regular block'>
+ <code>#warnings</code>
+ </a>
+
+ <a
+ href='#resultcontent'
+ class='button-indent regular block'>
+ <code>#content</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#root'
+ class="regular block toggle-sibling">
+ <code>Root</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#rootappend'
+ class='button-indent regular block'>
+ <code>#append</code>
+ </a>
+
+ <a
+ href='#rooteach'
+ class='button-indent regular block'>
+ <code>#each</code>
+ </a>
+
+ <a
+ href='#rootevery'
+ class='button-indent regular block'>
+ <code>#every</code>
+ </a>
+
+ <a
+ href='#rootfirst'
+ class='button-indent regular block'>
+ <code>#first</code>
+ </a>
+
+ <a
+ href='#rootindex'
+ class='button-indent regular block'>
+ <code>#index</code>
+ </a>
+
+ <a
+ href='#rootinsertafter'
+ class='button-indent regular block'>
+ <code>#insertAfter</code>
+ </a>
+
+ <a
+ href='#rootinsertbefore'
+ class='button-indent regular block'>
+ <code>#insertBefore</code>
+ </a>
+
+ <a
+ href='#rootlast'
+ class='button-indent regular block'>
+ <code>#last</code>
+ </a>
+
+ <a
+ href='#rootprepend'
+ class='button-indent regular block'>
+ <code>#prepend</code>
+ </a>
+
+ <a
+ href='#rootremoveall'
+ class='button-indent regular block'>
+ <code>#removeAll</code>
+ </a>
+
+ <a
+ href='#rootremovechild'
+ class='button-indent regular block'>
+ <code>#removeChild</code>
+ </a>
+
+ <a
+ href='#rootreplacevalues'
+ class='button-indent regular block'>
+ <code>#replaceValues</code>
+ </a>
+
+ <a
+ href='#rootwalk'
+ class='button-indent regular block'>
+ <code>#walk</code>
+ </a>
+
+ <a
+ href='#rootwalkatrules'
+ class='button-indent regular block'>
+ <code>#walkAtRules</code>
+ </a>
+
+ <a
+ href='#rootwalkcomments'
+ class='button-indent regular block'>
+ <code>#walkComments</code>
+ </a>
+
+ <a
+ href='#rootwalkrules'
+ class='button-indent regular block'>
+ <code>#walkRules</code>
+ </a>
+
+ <a
+ href='#rooton'
+ class='button-indent regular block'>
+ <code>#on</code>
+ </a>
+
+ <a
+ href='#rootsome'
+ class='button-indent regular block'>
+ <code>#some</code>
+ </a>
+
+ <a
+ href='#roottoresult'
+ class='button-indent regular block'>
+ <code>#toResult</code>
+ </a>
+
+ <a
+ href='#rootwalkdecls'
+ class='button-indent regular block'>
+ <code>#walkDecls</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#rule'
+ class="regular block toggle-sibling">
+ <code>Rule</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#ruleappend'
+ class='button-indent regular block'>
+ <code>#append</code>
+ </a>
+
+ <a
+ href='#ruleeach'
+ class='button-indent regular block'>
+ <code>#each</code>
+ </a>
+
+ <a
+ href='#ruleevery'
+ class='button-indent regular block'>
+ <code>#every</code>
+ </a>
+
+ <a
+ href='#rulefirst'
+ class='button-indent regular block'>
+ <code>#first</code>
+ </a>
+
+ <a
+ href='#ruleindex'
+ class='button-indent regular block'>
+ <code>#index</code>
+ </a>
+
+ <a
+ href='#ruleinsertafter'
+ class='button-indent regular block'>
+ <code>#insertAfter</code>
+ </a>
+
+ <a
+ href='#ruleinsertbefore'
+ class='button-indent regular block'>
+ <code>#insertBefore</code>
+ </a>
+
+ <a
+ href='#rulelast'
+ class='button-indent regular block'>
+ <code>#last</code>
+ </a>
+
+ <a
+ href='#ruleprepend'
+ class='button-indent regular block'>
+ <code>#prepend</code>
+ </a>
+
+ <a
+ href='#ruleremoveall'
+ class='button-indent regular block'>
+ <code>#removeAll</code>
+ </a>
+
+ <a
+ href='#ruleremovechild'
+ class='button-indent regular block'>
+ <code>#removeChild</code>
+ </a>
+
+ <a
+ href='#rulereplacevalues'
+ class='button-indent regular block'>
+ <code>#replaceValues</code>
+ </a>
+
+ <a
+ href='#ruleselectors'
+ class='button-indent regular block'>
+ <code>#selectors</code>
+ </a>
+
+ <a
+ href='#rulesome'
+ class='button-indent regular block'>
+ <code>#some</code>
+ </a>
+
+ <a
+ href='#rulewalk'
+ class='button-indent regular block'>
+ <code>#walk</code>
+ </a>
+
+ <a
+ href='#rulewalkatrules'
+ class='button-indent regular block'>
+ <code>#walkAtRules</code>
+ </a>
+
+ <a
+ href='#rulewalkcomments'
+ class='button-indent regular block'>
+ <code>#walkComments</code>
+ </a>
+
+ <a
+ href='#rulewalkdecls'
+ class='button-indent regular block'>
+ <code>#walkDecls</code>
+ </a>
+
+ <a
+ href='#rulewalkrules'
+ class='button-indent regular block'>
+ <code>#walkRules</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#warning'
+ class="regular block toggle-sibling">
+ <code>Warning</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+
+ <a
+ href='#warningtype'
+ class='button-indent regular block'>
+ <code>#type</code>
+ </a>
+
+ <a
+ href='#warningtext'
+ class='button-indent regular block'>
+ <code>#text</code>
+ </a>
+
+ <a
+ href='#warningline'
+ class='button-indent regular block'>
+ <code>#line</code>
+ </a>
+
+ <a
+ href='#warningcolumn'
+ class='button-indent regular block'>
+ <code>#column</code>
+ </a>
+
+ <a
+ href='#warningtostring'
+ class='button-indent regular block'>
+ <code>#toString</code>
+ </a>
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#namespaces'
+ class="blockmt1 quiet rounded bold block h4 mt2 ">
+ <code>NAMESPACES</code>
+
+ </a>
+
+
+
+
+
+ <a
+ href='#list'
+ class="regular block toggle-sibling">
+ <code>list</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+ <a
+ href='#listspace'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.space</code>
+ </a>
+
+ <a
+ href='#listcomma'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.comma</code>
+ </a>
+
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#postcss'
+ class="regular block toggle-sibling">
+ <code>postcss</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+ <a
+ href='#postcssplugin'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.plugin</code>
+ </a>
+
+ <a
+ href='#postcssstringify'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.stringify</code>
+ </a>
+
+ <a
+ href='#postcssparse'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.parse</code>
+ </a>
+
+ <a
+ href='#postcssvendor'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.vendor</code>
+ </a>
+
+ <a
+ href='#postcsslist'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.list</code>
+ </a>
+
+ <a
+ href='#postcsscomment'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.comment</code>
+ </a>
+
+ <a
+ href='#postcssatrule'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.atRule</code>
+ </a>
+
+ <a
+ href='#postcssdecl'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.decl</code>
+ </a>
+
+ <a
+ href='#postcssrule'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.rule</code>
+ </a>
+
+ <a
+ href='#postcssroot'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.root</code>
+ </a>
+
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#vendor'
+ class="regular block toggle-sibling">
+ <code>vendor</code>
+ <span class='icon'>▾</span>
+ </a>
+
+
+ <div class='toggle-target'>
+
+
+ <a
+ href='#vendorprefix'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.prefix</code>
+ </a>
+
+ <a
+ href='#vendorunprefixed'
+ class='button-indent px1 quiet regular rounded block'>
+ <code>.unprefixed</code>
+ </a>
+
+
+
+
+
+ </div>
+
+
+
+
+ <a
+ href='#global'
+ class="blockmt1 quiet rounded bold block h4 mt2 ">
+ <code>GLOBAL</code>
+
+ </a>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </div>
+ <div class='mt1 h6 quiet'>
+ <a href='https://documentation.js.org/reading-documentation.html'>Need help reading this?</a>
+ </div>
+ </div>
+
+ </div>
+ </div>
+ <div class='sm-col-12 md-col-9 lg-col-9 flex flex-column'>
+ <div class='flex-auto full-width'>
+
+
+ <div class='hide'>
+ <section class='py2 clearfix'>
+
+ <h2 id='classes' class='mt0'>
+ CLASSES
+ </h2>
+
+
+
+
+
+ </section>
+</div>
+
+
+
+ <section id='atrule'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+ <span class='font-smaller'>
+ Extends
+
+ <a href="#container">Container</a>
+
+ </span>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/at-rule.js#L23-L94'>
+ <span>lib/at-rule.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atrule'>
+ <code>
+ AtRule
+ <span class='gray'>(defaults)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Represents an at-rule.</p>
+<p>If it’s followed in the CSS by a {} block, this node will have
+a nodes property representing its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>defaults</code></td>
+ <td class='col-3 quiet'>
+ any
+
+ </td>
+ <td class='col-6'></td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'@charset "UTF-8"; @media print {}'</span>)
+
+<span class="hljs-keyword">const</span> charset = root.first
+charset.type <span class="hljs-comment">//=&gt; 'atrule'</span>
+charset.nodes <span class="hljs-comment">//=&gt; undefined</span>
+
+<span class="hljs-keyword">const</span> media = root.last
+media.nodes <span class="hljs-comment">//=&gt; []</span></code></pre>
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='atruleappend'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L370-L379'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atruleappend'>
+ <code>
+ append
+ <span class='gray'>(children)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts new nodes to the end of the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>children</code></td>
+ <td class='col-3 quiet'>
+ ...(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New nodes.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> decl1 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+<span class="hljs-keyword">const</span> decl2 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'background-color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'white'</span> })
+rule.append(decl1, decl2)
+
+root.append({ <span class="hljs-attr">name</span>: <span class="hljs-string">'charset'</span>, <span class="hljs-attr">params</span>: <span class="hljs-string">'"UTF-8"'</span> }) <span class="hljs-comment">// at-rule</span>
+root.append({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }) <span class="hljs-comment">// rule</span>
+rule.append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> }) <span class="hljs-comment">// declaration</span>
+rule.append({ <span class="hljs-attr">text</span>: <span class="hljs-string">'Comment'</span> }) <span class="hljs-comment">// comment</span>
+
+root.append(<span class="hljs-string">'a {}'</span>)
+root.first.append(<span class="hljs-string">'color: black; z-index: 1'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atruleeach'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L76-L102'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atruleeach'>
+ <code>
+ each
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Iterates through the container’s immediate children,
+calling <code>callback</code> for each child.</p>
+<p>Returning <code>false</code> in the callback will break iteration.</p>
+<p>This method only iterates through the container’s immediate children.
+If you need to recursively iterate through all the container’s descendant
+nodes, use <a href="#containerwalk">Container#walk</a>.</p>
+<p>Unlike the for <code>{}</code>-cycle or <code>Array#forEach</code> this iterator is safe
+if you are mutating the array of child nodes during iteration.
+PostCSS will adjust the current index to match the mutations.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a { color: black; z-index: 1 }'</span>)
+<span class="hljs-keyword">const</span> rule = root.first
+
+<span class="hljs-keyword">for</span> (<span class="hljs-keyword">const</span> decl <span class="hljs-keyword">of</span> rule.nodes) {
+ decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop })
+ <span class="hljs-comment">// Cycle will be infinite, because cloneBefore moves the current node</span>
+ <span class="hljs-comment">// to the next index</span>
+}
+
+rule.each(<span class="hljs-function"><span class="hljs-params">decl</span> =&gt;</span> {
+ decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop })
+ <span class="hljs-comment">// Will be executed only for color and z-index</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atruleevery'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L587-L589'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atruleevery'>
+ <code>
+ every
+ <span class='gray'>(condition)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns <code>true</code> if callback returns <code>true</code>
+for all of the container’s children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>condition</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childcondition">childCondition</a>
+
+ </td>
+ <td class='col-6'>Iterator returns true or false.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a></code>
+ :
+ <span class='force-inline'>Is every child pass condition.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> noPrefixes = rule.every(<span class="hljs-function"><span class="hljs-params">i</span> =&gt;</span> i.prop[<span class="hljs-number">0</span>] !== <span class="hljs-string">'-'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atrulefirst'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L631-L634'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atrulefirst'>
+ <code>
+ first
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The container’s first child.</p>
+
+
+ <p>
+ Type:
+ <a href="#node">Node</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.first === rules.nodes[<span class="hljs-number">0</span>]</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atruleindex'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L616-L621'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atruleindex'>
+ <code>
+ index
+ <span class='gray'>(child)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <code>child</code>’s index within the <a href="Container#nodes">Container#nodes</a> array.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>child</code></td>
+ <td class='col-3 quiet'>
+ <a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Child of the current container.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a></code>
+ :
+ <span class='force-inline'>Child index.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.index( rule.nodes[<span class="hljs-number">2</span>] ) <span class="hljs-comment">//=&gt; 2</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atruleinsertafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L462-L479'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atruleinsertafter'>
+ <code>
+ insertAfter
+ <span class='gray'>(exist, add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node after old node within the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>exist</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atruleinsertbefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L434-L452'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atruleinsertbefore'>
+ <code>
+ insertBefore
+ <span class='gray'>(exist, add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node before old node within the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>exist</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.insertBefore(decl, decl.clone({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop }))</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atrulelast'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L644-L647'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atrulelast'>
+ <code>
+ last
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The container’s last child.</p>
+
+
+ <p>
+ Type:
+ <a href="#node">Node</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.last === rule.nodes[rule.nodes.length - <span class="hljs-number">1</span>]</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atruleprepend'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L401-L414'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atruleprepend'>
+ <code>
+ prepend
+ <span class='gray'>(children)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts new nodes to the start of the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>children</code></td>
+ <td class='col-3 quiet'>
+ ...(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New nodes.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> decl1 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+<span class="hljs-keyword">const</span> decl2 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'background-color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'white'</span> })
+rule.prepend(decl1, decl2)
+
+root.append({ <span class="hljs-attr">name</span>: <span class="hljs-string">'charset'</span>, <span class="hljs-attr">params</span>: <span class="hljs-string">'"UTF-8"'</span> }) <span class="hljs-comment">// at-rule</span>
+root.append({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }) <span class="hljs-comment">// rule</span>
+rule.append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> }) <span class="hljs-comment">// declaration</span>
+rule.append({ <span class="hljs-attr">text</span>: <span class="hljs-string">'Comment'</span> }) <span class="hljs-comment">// comment</span>
+
+root.append(<span class="hljs-string">'a {}'</span>)
+root.first.append(<span class="hljs-string">'color: black; z-index: 1'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atruleremoveall'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L523-L530'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atruleremoveall'>
+ <code>
+ removeAll
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes all children from the container
+and cleans their parent properties.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.removeAll()
+rule.nodes.length <span class="hljs-comment">//=&gt; 0</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atruleremovechild'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L495-L511'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atruleremovechild'>
+ <code>
+ removeChild
+ <span class='gray'>(child)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes node from the container and cleans the parent properties
+from the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>child</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.nodes.length <span class="hljs-comment">//=&gt; 5</span>
+rule.removeChild(decl)
+rule.nodes.length <span class="hljs-comment">//=&gt; 4</span>
+decl.parent <span class="hljs-comment">//=&gt; undefined</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atrulereplacevalues'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L558-L574'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atrulereplacevalues'>
+ <code>
+ replaceValues
+ <span class='gray'>(pattern, opts, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Passes all declaration values within the container that match pattern
+through callback, replacing those values with the returned result
+of callback.</p>
+<p>This method is useful if you are using a custom unit or function
+and need to iterate through all values.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>pattern</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)
+
+ </td>
+ <td class='col-6'>Replace pattern.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+
+ </td>
+ <td class='col-6'>Options to speed up the search.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.props</td>
+ <td class="col-2 quiet">
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>>)
+
+ </td>
+ <td class='col-8'>An array of property names.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.fast</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>String that’s used to narrow down
+values and speed up the regexp search.
+</td>
+</tr>
+
+
+
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">function</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>)
+
+ </td>
+ <td class='col-6'>String to replace pattern or callback
+that returns a new value. The callback
+will receive the same arguments
+as those passed to a function parameter
+of
+<code>String#replace</code>
+.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.replaceValues(<span class="hljs-regexp">/\d+rem/</span>, { <span class="hljs-attr">fast</span>: <span class="hljs-string">'rem'</span> }, string =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-number">15</span> * <span class="hljs-built_in">parseInt</span>(string) + <span class="hljs-string">'px'</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atrulesome'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L602-L604'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atrulesome'>
+ <code>
+ some
+ <span class='gray'>(condition)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns <code>true</code> if callback returns <code>true</code> for (at least) one
+of the container’s children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>condition</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childcondition">childCondition</a>
+
+ </td>
+ <td class='col-6'>Iterator returns true or false.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a></code>
+ :
+ <span class='force-inline'>Is some child pass condition.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> hasPrefix = rule.some(<span class="hljs-function"><span class="hljs-params">i</span> =&gt;</span> i.prop[<span class="hljs-number">0</span>] === <span class="hljs-string">'-'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atrulewalk'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L123-L137'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atrulewalk'>
+ <code>
+ walk
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each node.</p>
+<p>Like container.each(), this method is safe to use
+if you are mutating arrays during iteration.</p>
+<p>If you only need to iterate through the container’s immediate children,
+use <a href="#containereach">Container#each</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walk(<span class="hljs-function"><span class="hljs-params">node</span> =&gt;</span> {
+ <span class="hljs-comment">// Traverses all descendant nodes.</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atrulewalkatrules'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L303-L324'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atrulewalkatrules'>
+ <code>
+ walkAtRules
+ <span class='gray'>(name?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each at-rule node.</p>
+<p>If you pass a filter, iteration will only happen over at-rules
+that have matching names.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>name</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter at-rules by name.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkAtRules(<span class="hljs-function"><span class="hljs-params">rule</span> =&gt;</span> {
+ <span class="hljs-keyword">if</span> (isOld(rule.name)) rule.remove()
+})
+
+<span class="hljs-keyword">let</span> first = <span class="hljs-literal">false</span>
+root.walkAtRules(<span class="hljs-string">'charset'</span>, rule =&gt; {
+ <span class="hljs-keyword">if</span> (!first) {
+ first = <span class="hljs-literal">true</span>
+ } <span class="hljs-keyword">else</span> {
+ rule.remove()
+ }
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atrulewalkcomments'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L342-L348'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atrulewalkcomments'>
+ <code>
+ walkComments
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each comment node.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkComments(<span class="hljs-function"><span class="hljs-params">comment</span> =&gt;</span> {
+ comment.remove()
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atrulewalkdecls'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L203-L224'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atrulewalkdecls'>
+ <code>
+ walkDecls
+ <span class='gray'>(prop?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each declaration node.</p>
+<p>If you pass a filter, iteration will only happen over declarations
+with matching properties.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>prop</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter declarations by property name.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkDecls(<span class="hljs-function"><span class="hljs-params">decl</span> =&gt;</span> {
+ checkPropertySupport(decl.prop)
+})
+
+root.walkDecls(<span class="hljs-string">'border-radius'</span>, decl =&gt; {
+ decl.remove()
+})
+
+root.walkDecls(<span class="hljs-regexp">/^background/</span>, decl =&gt; {
+ decl.value = takeFirstColorFromGradient(decl.value)
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='atrulewalkrules'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L249-L271'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#atrulewalkrules'>
+ <code>
+ walkRules
+ <span class='gray'>(selector?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each rule node.</p>
+<p>If you pass a filter, iteration will only happen over rules
+with matching selectors.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>selector</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter rules by selector.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> selectors = []
+root.walkRules(<span class="hljs-function"><span class="hljs-params">rule</span> =&gt;</span> {
+ selectors.push(rule.selector)
+})
+<span class="hljs-built_in">console</span>.log(<span class="hljs-string">`Your CSS uses <span class="hljs-subst">${ selectors.length }</span> selectors`</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='comment'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+ <span class='font-smaller'>
+ Extends
+
+ <a href="#node">Node</a>
+
+ </span>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/comment.js#L13-L37'>
+ <span>lib/comment.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#comment'>
+ <code>
+ Comment
+ <span class='gray'>(defaults)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Represents a comment between declarations or statements (rule and at-rules).</p>
+<p>Comments inside selectors, at-rule parameters, or declaration values
+will be stored in the <code>raws</code> properties explained above.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>defaults</code></td>
+ <td class='col-3 quiet'>
+ any
+
+ </td>
+ <td class='col-6'></td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='commentafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L312-L315'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentafter'>
+ <code>
+ after
+ <span class='gray'>(add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node after current node to current node’s parent.</p>
+<p>Just alias for <code>node.parent.insertAfter(node, add)</code>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.after(<span class="hljs-string">'color: black'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentbefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L295-L298'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentbefore'>
+ <code>
+ before
+ <span class='gray'>(add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node before current node to current node’s parent.</p>
+<p>Just alias for <code>node.parent.insertBefore(node, add)</code>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.before(<span class="hljs-string">'content: ""'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentcleanraws'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L392-L396'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentcleanraws'>
+ <code>
+ cleanRaws
+ <span class='gray'>(keepBetween?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Clear the code style properties for the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>keepBetween</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a>?
+
+ </td>
+ <td class='col-6'>Keep the raws.between symbols.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a></code>
+ :
+ <span class='force-inline'>
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>node.raws.before <span class="hljs-comment">//=&gt; ' '</span>
+node.cleanRaws()
+node.raws.before <span class="hljs-comment">//=&gt; undefined</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentclone'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L182-L188'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentclone'>
+ <code>
+ clone
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns an exact clone of the node.</p>
+<p>The resulting cloned node and its (cloned) children will retain
+code style properties.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>New properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Clone of the node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.raws.before <span class="hljs-comment">//=&gt; "\n "</span>
+<span class="hljs-keyword">const</span> cloned = decl.clone({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-moz-'</span> + decl.prop })
+cloned.raws.before <span class="hljs-comment">//=&gt; "\n "</span>
+cloned.toString() <span class="hljs-comment">//=&gt; -moz-transform: scale(0)</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentcloneafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L215-L219'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentcloneafter'>
+ <code>
+ cloneAfter
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Shortcut to clone the node and insert the resulting cloned node
+after the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>New properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>New node.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentclonebefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L201-L205'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentclonebefore'>
+ <code>
+ cloneBefore
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Shortcut to clone the node and insert the resulting cloned node
+before the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Mew properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>New node
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-moz-'</span> + decl.prop })</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commenterror'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L88-L94'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commenterror'>
+ <code>
+ error
+ <span class='gray'>(message, opts = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <code>CssSyntaxError</code> instance containing the original position
+of the node in the source, showing line and column numbers and also
+a small excerpt to facilitate debugging.</p>
+<p>If present, an input source map will be used to get the original position
+of the source, even from a previous compilation step
+(e.g., from Sass compilation).</p>
+<p>This method produces very useful error messages.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>message</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Error description.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Options.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.plugin</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>Plugin name that created this error.
+PostCSS will set it automatically.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.word</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>A word inside a node’s string that should
+be highlighted as the source of the error.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.index</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>An index inside a node’s string that should
+be highlighted as the source of the error.
+</td>
+</tr>
+
+
+
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#csssyntaxerror">CssSyntaxError</a></code>
+ :
+ <span class='force-inline'>Error object to throw it.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (!variables[name]) {
+ <span class="hljs-keyword">throw</span> decl.error(<span class="hljs-string">'Unknown variable '</span> + name, { <span class="hljs-attr">word</span>: name })
+ <span class="hljs-comment">// CssSyntaxError: postcss-vars:a.sass:4:3: Unknown variable $black</span>
+ <span class="hljs-comment">// color: $black</span>
+ <span class="hljs-comment">// a</span>
+ <span class="hljs-comment">// ^</span>
+ <span class="hljs-comment">// background: white</span>
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentnext'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L259-L263'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentnext'>
+ <code>
+ next
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns the next child of the node’s parent.
+Returns <code>undefined</code> if the current node is the last child.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Next node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (comment.text === <span class="hljs-string">'delete next'</span>) {
+ <span class="hljs-keyword">const</span> next = comment.next()
+ <span class="hljs-keyword">if</span> (next) {
+ next.remove()
+ }
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentprev'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L277-L281'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentprev'>
+ <code>
+ prev
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns the previous child of the node’s parent.
+Returns <code>undefined</code> if the current node is the first child.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Previous node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> annotation = decl.prev()
+<span class="hljs-keyword">if</span> (annotation.type === <span class="hljs-string">'comment'</span>) {
+ readAnnotation(annotation.text)
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentraw'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L361-L364'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentraw'>
+ <code>
+ raw
+ <span class='gray'>(prop, defaultType?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <a href="Node#raws">Node#raws</a> value. If the node is missing
+the code style property (because the node was manually built or cloned),
+PostCSS will try to autodetect the code style property by looking
+at other nodes in the tree.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>prop</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Name of code style property.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>defaultType</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>?
+
+ </td>
+ <td class='col-6'>Name of default value, it can be missed
+if the value is the same as prop.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>Code style value.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a { background: white }'</span>)
+root.nodes[<span class="hljs-number">0</span>].append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">1</span>].raws.before <span class="hljs-comment">//=&gt; undefined</span>
+root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">1</span>].raw(<span class="hljs-string">'before'</span>) <span class="hljs-comment">//=&gt; ' '</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentremove'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L138-L144'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentremove'>
+ <code>
+ remove
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes the node from its parent and cleans the parent properties
+from the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Node to make calls chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (decl.prop.match(<span class="hljs-regexp">/^-webkit-/</span>)) {
+ decl.remove()
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentreplacewith'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L233-L243'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentreplacewith'>
+ <code>
+ replaceWith
+ <span class='gray'>(nodes)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts node(s) before the current node and removes the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>nodes</code></td>
+ <td class='col-3 quiet'>
+ ...<a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Mode(s) to replace current one.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Current node to methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (atrule.name === <span class="hljs-string">'mixin'</span>) {
+ atrule.replaceWith(mixinRules[atrule.params])
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentroot'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L374-L378'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentroot'>
+ <code>
+ root
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Finds the Root instance of the node’s tree.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#root">Root</a></code>
+ :
+ <span class='force-inline'>Root parent.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">0</span>].root() === root</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commenttostring'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L157-L164'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commenttostring'>
+ <code>
+ toString
+ <span class='gray'>(stringifier = stringify)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a CSS string representing the node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>stringifier</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#stringifier">stringifier</a> | <a href="#syntax">syntax</a>)?
+
+ = <code>stringify</code>
+ </td>
+ <td class='col-6'>A syntax to use
+in string generation.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>CSS string of this node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.rule({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }).toString() <span class="hljs-comment">//=&gt; "a {}"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='commentwarn'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L121-L125'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#commentwarn'>
+ <code>
+ warn
+ <span class='gray'>(result, text, opts?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>This method is provided as a convenience wrapper for <a href="#resultwarn">Result#warn</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>result</code></td>
+ <td class='col-3 quiet'>
+ <a href="#result">Result</a>
+
+ </td>
+ <td class='col-6'>The
+<a href="#result">Result</a>
+ instance
+that will receive the warning.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>text</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Warning message.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ </td>
+ <td class='col-6'>Options
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.plugin</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>Plugin name that created this warning.
+PostCSS will set it automatically.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.word</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>A word inside a node’s string that should
+be highlighted as the source of the warning.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.index</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>An index inside a node’s string that should
+be highlighted as the source of the warning.
+</td>
+</tr>
+
+
+
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#warning">Warning</a></code>
+ :
+ <span class='force-inline'>Created warning object.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> plugin = postcss.plugin(<span class="hljs-string">'postcss-deprecated'</span>, () =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-function">(<span class="hljs-params">root, result</span>) =&gt;</span> {
+ root.walkDecls(<span class="hljs-string">'bad'</span>, decl =&gt; {
+ decl.warn(result, <span class="hljs-string">'Deprecated property bad'</span>)
+ })
+ }
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='container'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+ <span class='font-smaller'>
+ Extends
+
+ <a href="#node">Node</a>
+
+ </span>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L36-L708'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#container'>
+ <code>
+ Container
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The <a href="#root">Root</a>, <a href="#atrule">AtRule</a>, and <a href="#rule">Rule</a> container nodes
+inherit some common methods to help work with their children.</p>
+<p>Note that all containers can store any content. If you write a rule inside
+a rule, PostCSS will parse it.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='containerafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L312-L315'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerafter'>
+ <code>
+ after
+ <span class='gray'>(add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node after current node to current node’s parent.</p>
+<p>Just alias for <code>node.parent.insertAfter(node, add)</code>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.after(<span class="hljs-string">'color: black'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerappend'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L370-L379'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerappend'>
+ <code>
+ append
+ <span class='gray'>(children)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts new nodes to the end of the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>children</code></td>
+ <td class='col-3 quiet'>
+ ...(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New nodes.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> decl1 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+<span class="hljs-keyword">const</span> decl2 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'background-color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'white'</span> })
+rule.append(decl1, decl2)
+
+root.append({ <span class="hljs-attr">name</span>: <span class="hljs-string">'charset'</span>, <span class="hljs-attr">params</span>: <span class="hljs-string">'"UTF-8"'</span> }) <span class="hljs-comment">// at-rule</span>
+root.append({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }) <span class="hljs-comment">// rule</span>
+rule.append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> }) <span class="hljs-comment">// declaration</span>
+rule.append({ <span class="hljs-attr">text</span>: <span class="hljs-string">'Comment'</span> }) <span class="hljs-comment">// comment</span>
+
+root.append(<span class="hljs-string">'a {}'</span>)
+root.first.append(<span class="hljs-string">'color: black; z-index: 1'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerbefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L295-L298'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerbefore'>
+ <code>
+ before
+ <span class='gray'>(add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node before current node to current node’s parent.</p>
+<p>Just alias for <code>node.parent.insertBefore(node, add)</code>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.before(<span class="hljs-string">'content: ""'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containercleanraws'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L392-L396'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containercleanraws'>
+ <code>
+ cleanRaws
+ <span class='gray'>(keepBetween?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Clear the code style properties for the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>keepBetween</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a>?
+
+ </td>
+ <td class='col-6'>Keep the raws.between symbols.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a></code>
+ :
+ <span class='force-inline'>
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>node.raws.before <span class="hljs-comment">//=&gt; ' '</span>
+node.cleanRaws()
+node.raws.before <span class="hljs-comment">//=&gt; undefined</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerclone'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L182-L188'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerclone'>
+ <code>
+ clone
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns an exact clone of the node.</p>
+<p>The resulting cloned node and its (cloned) children will retain
+code style properties.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>New properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Clone of the node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.raws.before <span class="hljs-comment">//=&gt; "\n "</span>
+<span class="hljs-keyword">const</span> cloned = decl.clone({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-moz-'</span> + decl.prop })
+cloned.raws.before <span class="hljs-comment">//=&gt; "\n "</span>
+cloned.toString() <span class="hljs-comment">//=&gt; -moz-transform: scale(0)</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containercloneafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L215-L219'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containercloneafter'>
+ <code>
+ cloneAfter
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Shortcut to clone the node and insert the resulting cloned node
+after the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>New properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>New node.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerclonebefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L201-L205'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerclonebefore'>
+ <code>
+ cloneBefore
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Shortcut to clone the node and insert the resulting cloned node
+before the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Mew properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>New node
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-moz-'</span> + decl.prop })</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containereach'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L76-L102'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containereach'>
+ <code>
+ each
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Iterates through the container’s immediate children,
+calling <code>callback</code> for each child.</p>
+<p>Returning <code>false</code> in the callback will break iteration.</p>
+<p>This method only iterates through the container’s immediate children.
+If you need to recursively iterate through all the container’s descendant
+nodes, use <a href="#containerwalk">Container#walk</a>.</p>
+<p>Unlike the for <code>{}</code>-cycle or <code>Array#forEach</code> this iterator is safe
+if you are mutating the array of child nodes during iteration.
+PostCSS will adjust the current index to match the mutations.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a { color: black; z-index: 1 }'</span>)
+<span class="hljs-keyword">const</span> rule = root.first
+
+<span class="hljs-keyword">for</span> (<span class="hljs-keyword">const</span> decl <span class="hljs-keyword">of</span> rule.nodes) {
+ decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop })
+ <span class="hljs-comment">// Cycle will be infinite, because cloneBefore moves the current node</span>
+ <span class="hljs-comment">// to the next index</span>
+}
+
+rule.each(<span class="hljs-function"><span class="hljs-params">decl</span> =&gt;</span> {
+ decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop })
+ <span class="hljs-comment">// Will be executed only for color and z-index</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containererror'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L88-L94'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containererror'>
+ <code>
+ error
+ <span class='gray'>(message, opts = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <code>CssSyntaxError</code> instance containing the original position
+of the node in the source, showing line and column numbers and also
+a small excerpt to facilitate debugging.</p>
+<p>If present, an input source map will be used to get the original position
+of the source, even from a previous compilation step
+(e.g., from Sass compilation).</p>
+<p>This method produces very useful error messages.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>message</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Error description.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Options.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.plugin</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>Plugin name that created this error.
+PostCSS will set it automatically.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.word</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>A word inside a node’s string that should
+be highlighted as the source of the error.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.index</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>An index inside a node’s string that should
+be highlighted as the source of the error.
+</td>
+</tr>
+
+
+
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#csssyntaxerror">CssSyntaxError</a></code>
+ :
+ <span class='force-inline'>Error object to throw it.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (!variables[name]) {
+ <span class="hljs-keyword">throw</span> decl.error(<span class="hljs-string">'Unknown variable '</span> + name, { <span class="hljs-attr">word</span>: name })
+ <span class="hljs-comment">// CssSyntaxError: postcss-vars:a.sass:4:3: Unknown variable $black</span>
+ <span class="hljs-comment">// color: $black</span>
+ <span class="hljs-comment">// a</span>
+ <span class="hljs-comment">// ^</span>
+ <span class="hljs-comment">// background: white</span>
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerevery'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L587-L589'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerevery'>
+ <code>
+ every
+ <span class='gray'>(condition)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns <code>true</code> if callback returns <code>true</code>
+for all of the container’s children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>condition</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childcondition">childCondition</a>
+
+ </td>
+ <td class='col-6'>Iterator returns true or false.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a></code>
+ :
+ <span class='force-inline'>Is every child pass condition.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> noPrefixes = rule.every(<span class="hljs-function"><span class="hljs-params">i</span> =&gt;</span> i.prop[<span class="hljs-number">0</span>] !== <span class="hljs-string">'-'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerfirst'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L631-L634'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerfirst'>
+ <code>
+ first
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The container’s first child.</p>
+
+
+ <p>
+ Type:
+ <a href="#node">Node</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.first === rules.nodes[<span class="hljs-number">0</span>]</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerindex'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L616-L621'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerindex'>
+ <code>
+ index
+ <span class='gray'>(child)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <code>child</code>’s index within the <a href="Container#nodes">Container#nodes</a> array.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>child</code></td>
+ <td class='col-3 quiet'>
+ <a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Child of the current container.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a></code>
+ :
+ <span class='force-inline'>Child index.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.index( rule.nodes[<span class="hljs-number">2</span>] ) <span class="hljs-comment">//=&gt; 2</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerinsertafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L462-L479'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerinsertafter'>
+ <code>
+ insertAfter
+ <span class='gray'>(exist, add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node after old node within the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>exist</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerinsertbefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L434-L452'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerinsertbefore'>
+ <code>
+ insertBefore
+ <span class='gray'>(exist, add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node before old node within the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>exist</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.insertBefore(decl, decl.clone({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop }))</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerlast'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L644-L647'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerlast'>
+ <code>
+ last
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The container’s last child.</p>
+
+
+ <p>
+ Type:
+ <a href="#node">Node</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.last === rule.nodes[rule.nodes.length - <span class="hljs-number">1</span>]</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containernext'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L259-L263'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containernext'>
+ <code>
+ next
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns the next child of the node’s parent.
+Returns <code>undefined</code> if the current node is the last child.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Next node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (comment.text === <span class="hljs-string">'delete next'</span>) {
+ <span class="hljs-keyword">const</span> next = comment.next()
+ <span class="hljs-keyword">if</span> (next) {
+ next.remove()
+ }
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerprepend'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L401-L414'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerprepend'>
+ <code>
+ prepend
+ <span class='gray'>(children)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts new nodes to the start of the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>children</code></td>
+ <td class='col-3 quiet'>
+ ...(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New nodes.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> decl1 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+<span class="hljs-keyword">const</span> decl2 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'background-color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'white'</span> })
+rule.prepend(decl1, decl2)
+
+root.append({ <span class="hljs-attr">name</span>: <span class="hljs-string">'charset'</span>, <span class="hljs-attr">params</span>: <span class="hljs-string">'"UTF-8"'</span> }) <span class="hljs-comment">// at-rule</span>
+root.append({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }) <span class="hljs-comment">// rule</span>
+rule.append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> }) <span class="hljs-comment">// declaration</span>
+rule.append({ <span class="hljs-attr">text</span>: <span class="hljs-string">'Comment'</span> }) <span class="hljs-comment">// comment</span>
+
+root.append(<span class="hljs-string">'a {}'</span>)
+root.first.append(<span class="hljs-string">'color: black; z-index: 1'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerprev'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L277-L281'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerprev'>
+ <code>
+ prev
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns the previous child of the node’s parent.
+Returns <code>undefined</code> if the current node is the first child.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Previous node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> annotation = decl.prev()
+<span class="hljs-keyword">if</span> (annotation.type === <span class="hljs-string">'comment'</span>) {
+ readAnnotation(annotation.text)
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerraw'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L361-L364'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerraw'>
+ <code>
+ raw
+ <span class='gray'>(prop, defaultType?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <a href="Node#raws">Node#raws</a> value. If the node is missing
+the code style property (because the node was manually built or cloned),
+PostCSS will try to autodetect the code style property by looking
+at other nodes in the tree.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>prop</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Name of code style property.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>defaultType</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>?
+
+ </td>
+ <td class='col-6'>Name of default value, it can be missed
+if the value is the same as prop.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>Code style value.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a { background: white }'</span>)
+root.nodes[<span class="hljs-number">0</span>].append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">1</span>].raws.before <span class="hljs-comment">//=&gt; undefined</span>
+root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">1</span>].raw(<span class="hljs-string">'before'</span>) <span class="hljs-comment">//=&gt; ' '</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerremove'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L138-L144'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerremove'>
+ <code>
+ remove
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes the node from its parent and cleans the parent properties
+from the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Node to make calls chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (decl.prop.match(<span class="hljs-regexp">/^-webkit-/</span>)) {
+ decl.remove()
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerremoveall'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L523-L530'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerremoveall'>
+ <code>
+ removeAll
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes all children from the container
+and cleans their parent properties.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.removeAll()
+rule.nodes.length <span class="hljs-comment">//=&gt; 0</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerremovechild'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L495-L511'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerremovechild'>
+ <code>
+ removeChild
+ <span class='gray'>(child)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes node from the container and cleans the parent properties
+from the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>child</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.nodes.length <span class="hljs-comment">//=&gt; 5</span>
+rule.removeChild(decl)
+rule.nodes.length <span class="hljs-comment">//=&gt; 4</span>
+decl.parent <span class="hljs-comment">//=&gt; undefined</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerreplacevalues'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L558-L574'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerreplacevalues'>
+ <code>
+ replaceValues
+ <span class='gray'>(pattern, opts, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Passes all declaration values within the container that match pattern
+through callback, replacing those values with the returned result
+of callback.</p>
+<p>This method is useful if you are using a custom unit or function
+and need to iterate through all values.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>pattern</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)
+
+ </td>
+ <td class='col-6'>Replace pattern.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+
+ </td>
+ <td class='col-6'>Options to speed up the search.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.props</td>
+ <td class="col-2 quiet">
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>>)
+
+ </td>
+ <td class='col-8'>An array of property names.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.fast</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>String that’s used to narrow down
+values and speed up the regexp search.
+</td>
+</tr>
+
+
+
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">function</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>)
+
+ </td>
+ <td class='col-6'>String to replace pattern or callback
+that returns a new value. The callback
+will receive the same arguments
+as those passed to a function parameter
+of
+<code>String#replace</code>
+.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.replaceValues(<span class="hljs-regexp">/\d+rem/</span>, { <span class="hljs-attr">fast</span>: <span class="hljs-string">'rem'</span> }, string =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-number">15</span> * <span class="hljs-built_in">parseInt</span>(string) + <span class="hljs-string">'px'</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerreplacewith'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L233-L243'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerreplacewith'>
+ <code>
+ replaceWith
+ <span class='gray'>(nodes)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts node(s) before the current node and removes the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>nodes</code></td>
+ <td class='col-3 quiet'>
+ ...<a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Mode(s) to replace current one.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Current node to methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (atrule.name === <span class="hljs-string">'mixin'</span>) {
+ atrule.replaceWith(mixinRules[atrule.params])
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerroot'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L374-L378'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerroot'>
+ <code>
+ root
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Finds the Root instance of the node’s tree.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#root">Root</a></code>
+ :
+ <span class='force-inline'>Root parent.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">0</span>].root() === root</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containersome'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L602-L604'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containersome'>
+ <code>
+ some
+ <span class='gray'>(condition)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns <code>true</code> if callback returns <code>true</code> for (at least) one
+of the container’s children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>condition</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childcondition">childCondition</a>
+
+ </td>
+ <td class='col-6'>Iterator returns true or false.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a></code>
+ :
+ <span class='force-inline'>Is some child pass condition.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> hasPrefix = rule.some(<span class="hljs-function"><span class="hljs-params">i</span> =&gt;</span> i.prop[<span class="hljs-number">0</span>] === <span class="hljs-string">'-'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containertostring'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L157-L164'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containertostring'>
+ <code>
+ toString
+ <span class='gray'>(stringifier = stringify)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a CSS string representing the node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>stringifier</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#stringifier">stringifier</a> | <a href="#syntax">syntax</a>)?
+
+ = <code>stringify</code>
+ </td>
+ <td class='col-6'>A syntax to use
+in string generation.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>CSS string of this node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.rule({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }).toString() <span class="hljs-comment">//=&gt; "a {}"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerwalk'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L123-L137'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerwalk'>
+ <code>
+ walk
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each node.</p>
+<p>Like container.each(), this method is safe to use
+if you are mutating arrays during iteration.</p>
+<p>If you only need to iterate through the container’s immediate children,
+use <a href="#containereach">Container#each</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walk(<span class="hljs-function"><span class="hljs-params">node</span> =&gt;</span> {
+ <span class="hljs-comment">// Traverses all descendant nodes.</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerwalkatrules'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L303-L324'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerwalkatrules'>
+ <code>
+ walkAtRules
+ <span class='gray'>(name?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each at-rule node.</p>
+<p>If you pass a filter, iteration will only happen over at-rules
+that have matching names.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>name</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter at-rules by name.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkAtRules(<span class="hljs-function"><span class="hljs-params">rule</span> =&gt;</span> {
+ <span class="hljs-keyword">if</span> (isOld(rule.name)) rule.remove()
+})
+
+<span class="hljs-keyword">let</span> first = <span class="hljs-literal">false</span>
+root.walkAtRules(<span class="hljs-string">'charset'</span>, rule =&gt; {
+ <span class="hljs-keyword">if</span> (!first) {
+ first = <span class="hljs-literal">true</span>
+ } <span class="hljs-keyword">else</span> {
+ rule.remove()
+ }
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerwalkcomments'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L342-L348'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerwalkcomments'>
+ <code>
+ walkComments
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each comment node.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkComments(<span class="hljs-function"><span class="hljs-params">comment</span> =&gt;</span> {
+ comment.remove()
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerwalkdecls'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L203-L224'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerwalkdecls'>
+ <code>
+ walkDecls
+ <span class='gray'>(prop?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each declaration node.</p>
+<p>If you pass a filter, iteration will only happen over declarations
+with matching properties.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>prop</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter declarations by property name.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkDecls(<span class="hljs-function"><span class="hljs-params">decl</span> =&gt;</span> {
+ checkPropertySupport(decl.prop)
+})
+
+root.walkDecls(<span class="hljs-string">'border-radius'</span>, decl =&gt; {
+ decl.remove()
+})
+
+root.walkDecls(<span class="hljs-regexp">/^background/</span>, decl =&gt; {
+ decl.value = takeFirstColorFromGradient(decl.value)
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerwalkrules'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L249-L271'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerwalkrules'>
+ <code>
+ walkRules
+ <span class='gray'>(selector?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each rule node.</p>
+<p>If you pass a filter, iteration will only happen over rules
+with matching selectors.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>selector</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter rules by selector.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> selectors = []
+root.walkRules(<span class="hljs-function"><span class="hljs-params">rule</span> =&gt;</span> {
+ selectors.push(rule.selector)
+})
+<span class="hljs-built_in">console</span>.log(<span class="hljs-string">`Your CSS uses <span class="hljs-subst">${ selectors.length }</span> selectors`</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='containerwarn'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L121-L125'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#containerwarn'>
+ <code>
+ warn
+ <span class='gray'>(result, text, opts?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>This method is provided as a convenience wrapper for <a href="#resultwarn">Result#warn</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>result</code></td>
+ <td class='col-3 quiet'>
+ <a href="#result">Result</a>
+
+ </td>
+ <td class='col-6'>The
+<a href="#result">Result</a>
+ instance
+that will receive the warning.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>text</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Warning message.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ </td>
+ <td class='col-6'>Options
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.plugin</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>Plugin name that created this warning.
+PostCSS will set it automatically.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.word</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>A word inside a node’s string that should
+be highlighted as the source of the warning.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.index</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>An index inside a node’s string that should
+be highlighted as the source of the warning.
+</td>
+</tr>
+
+
+
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#warning">Warning</a></code>
+ :
+ <span class='force-inline'>Created warning object.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> plugin = postcss.plugin(<span class="hljs-string">'postcss-deprecated'</span>, () =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-function">(<span class="hljs-params">root, result</span>) =&gt;</span> {
+ root.walkDecls(<span class="hljs-string">'bad'</span>, decl =&gt; {
+ decl.warn(result, <span class="hljs-string">'Deprecated property bad'</span>)
+ })
+ }
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='csssyntaxerror'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+ <span class='font-smaller'>
+ Extends
+
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Error">Error</a>
+
+ </span>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/css-syntax-error.js#L33-L243'>
+ <span>lib/css-syntax-error.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#csssyntaxerror'>
+ <code>
+ CssSyntaxError
+ <span class='gray'>(message, line?, column?, source?, file?, plugin?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The CSS parser throws this error for broken CSS.</p>
+<p>Custom parsers can throw this error for broken custom syntax using
+the <a href="#nodeerror">Node#error</a> method.</p>
+<p>PostCSS will use the input source map to detect the original error location.
+If you wrote a Sass file, compiled it to CSS and then parsed it with PostCSS,
+PostCSS will show the original position in the Sass file.</p>
+<p>If you need the position in the PostCSS input
+(e.g., to debug the previous compiler), use <code>error.input.file</code>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>message</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Error message.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>line</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>?
+
+ </td>
+ <td class='col-6'>Source line of the error.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>column</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>?
+
+ </td>
+ <td class='col-6'>Source column of the error.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>source</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>?
+
+ </td>
+ <td class='col-6'>Source code of the broken file.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>file</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>?
+
+ </td>
+ <td class='col-6'>Absolute path to the broken file.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>plugin</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>?
+
+ </td>
+ <td class='col-6'>PostCSS plugin name, if error came from plugin.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-comment">// Catching and checking syntax error</span>
+<span class="hljs-keyword">try</span> {
+ postcss.parse(<span class="hljs-string">'a{'</span>)
+} <span class="hljs-keyword">catch</span> (error) {
+ <span class="hljs-keyword">if</span> (error.name === <span class="hljs-string">'CssSyntaxError'</span>) {
+ error <span class="hljs-comment">//=&gt; CssSyntaxError</span>
+ }
+}</code></pre>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-comment">// Raising error from plugin</span>
+<span class="hljs-keyword">throw</span> node.error(<span class="hljs-string">'Unknown variable'</span>, { <span class="hljs-attr">plugin</span>: <span class="hljs-string">'postcss-vars'</span> })</code></pre>
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='csssyntaxerrorname'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/css-syntax-error.js#L58-L58'>
+ <span>lib/css-syntax-error.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#csssyntaxerrorname'>
+ <code>
+ name
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Always equal to <code>'CssSyntaxError'</code>. You should always check error type
+by <code>error.name === 'CssSyntaxError'</code>
+instead of <code>error instanceof CssSyntaxError</code>,
+because npm could have several PostCSS versions.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (error.name === <span class="hljs-string">'CssSyntaxError'</span>) {
+ error <span class="hljs-comment">//=&gt; CssSyntaxError</span>
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='csssyntaxerrorreason'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/css-syntax-error.js#L67-L67'>
+ <span>lib/css-syntax-error.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#csssyntaxerrorreason'>
+ <code>
+ reason
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Error message.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>error.message <span class="hljs-comment">//=&gt; 'Unclosed block'</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='csssyntaxerrorfile'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/css-syntax-error.js#L79-L79'>
+ <span>lib/css-syntax-error.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#csssyntaxerrorfile'>
+ <code>
+ file
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Absolute path to the broken file.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>error.file <span class="hljs-comment">//=&gt; 'a.sass'</span>
+error.input.file <span class="hljs-comment">//=&gt; 'a.css'</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='csssyntaxerrorsource'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/css-syntax-error.js#L91-L91'>
+ <span>lib/css-syntax-error.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#csssyntaxerrorsource'>
+ <code>
+ source
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Source code of the broken file.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>error.source <span class="hljs-comment">//=&gt; 'a { b {} }'</span>
+error.input.column <span class="hljs-comment">//=&gt; 'a b { }'</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='csssyntaxerrorplugin'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/css-syntax-error.js#L102-L102'>
+ <span>lib/css-syntax-error.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#csssyntaxerrorplugin'>
+ <code>
+ plugin
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Plugin name, if error came from plugin.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>error.plugin <span class="hljs-comment">//=&gt; 'postcss-vars'</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='csssyntaxerrorline'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/css-syntax-error.js#L114-L114'>
+ <span>lib/css-syntax-error.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#csssyntaxerrorline'>
+ <code>
+ line
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Source line of the error.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>error.line <span class="hljs-comment">//=&gt; 2</span>
+error.input.line <span class="hljs-comment">//=&gt; 4</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='csssyntaxerrorcolumn'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/css-syntax-error.js#L124-L124'>
+ <span>lib/css-syntax-error.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#csssyntaxerrorcolumn'>
+ <code>
+ column
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Source column of the error.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>error.column <span class="hljs-comment">//=&gt; 1</span>
+error.input.column <span class="hljs-comment">//=&gt; 4</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='csssyntaxerrormessage'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/css-syntax-error.js#L144-L144'>
+ <span>lib/css-syntax-error.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#csssyntaxerrormessage'>
+ <code>
+ message
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Full error text in the GNU error format
+with plugin, file, line and column.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>error.message <span class="hljs-comment">//=&gt; 'a.css:1:1: Unclosed block'</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='csssyntaxerrorshowsourcecode'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/css-syntax-error.js#L173-L211'>
+ <span>lib/css-syntax-error.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#csssyntaxerrorshowsourcecode'>
+ <code>
+ showSourceCode
+ <span class='gray'>(color?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a few lines of CSS source that caused the error.</p>
+<p>If the CSS has an input source map without <code>sourceContent</code>,
+this method will return an empty string.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>color</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a>?
+
+ </td>
+ <td class='col-6'>Whether arrow will be colored red by terminal
+color codes. By default, PostCSS will detect
+color support by
+<code>process.stdout.isTTY</code>
+
+and
+<code>process.env.NODE_DISABLE_COLORS</code>
+.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>Few lines of CSS source that caused the error.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>error.showSourceCode() <span class="hljs-comment">//=&gt; " 4 | }</span>
+ <span class="hljs-comment">// 5 | a {</span>
+ <span class="hljs-comment">// &gt; 6 | bad</span>
+ <span class="hljs-comment">// | ^</span>
+ <span class="hljs-comment">// 7 | }</span>
+ <span class="hljs-comment">// 8 | b {"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='csssyntaxerrortostring'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/css-syntax-error.js#L223-L229'>
+ <span>lib/css-syntax-error.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#csssyntaxerrortostring'>
+ <code>
+ toString
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns error position, message and source code of the broken part.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>Error position, message and source code.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>error.toString() <span class="hljs-comment">//=&gt; "CssSyntaxError: app.css:1:1: Unclosed block</span>
+ <span class="hljs-comment">// &gt; 1 | a {</span>
+ <span class="hljs-comment">// | ^"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='declaration'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+ <span class='font-smaller'>
+ Extends
+
+ <a href="#node">Node</a>
+
+ </span>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/declaration.js#L16-L80'>
+ <span>lib/declaration.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declaration'>
+ <code>
+ Declaration
+ <span class='gray'>(defaults)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Represents a CSS declaration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>defaults</code></td>
+ <td class='col-3 quiet'>
+ any
+
+ </td>
+ <td class='col-6'></td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a { color: black }'</span>)
+<span class="hljs-keyword">const</span> decl = root.first.first
+decl.type <span class="hljs-comment">//=&gt; 'decl'</span>
+decl.toString() <span class="hljs-comment">//=&gt; ' color: black'</span></code></pre>
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='declarationafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L312-L315'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationafter'>
+ <code>
+ after
+ <span class='gray'>(add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node after current node to current node’s parent.</p>
+<p>Just alias for <code>node.parent.insertAfter(node, add)</code>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.after(<span class="hljs-string">'color: black'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationbefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L295-L298'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationbefore'>
+ <code>
+ before
+ <span class='gray'>(add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node before current node to current node’s parent.</p>
+<p>Just alias for <code>node.parent.insertBefore(node, add)</code>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.before(<span class="hljs-string">'content: ""'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationcleanraws'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L392-L396'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationcleanraws'>
+ <code>
+ cleanRaws
+ <span class='gray'>(keepBetween?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Clear the code style properties for the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>keepBetween</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a>?
+
+ </td>
+ <td class='col-6'>Keep the raws.between symbols.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a></code>
+ :
+ <span class='force-inline'>
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>node.raws.before <span class="hljs-comment">//=&gt; ' '</span>
+node.cleanRaws()
+node.raws.before <span class="hljs-comment">//=&gt; undefined</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationclone'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L182-L188'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationclone'>
+ <code>
+ clone
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns an exact clone of the node.</p>
+<p>The resulting cloned node and its (cloned) children will retain
+code style properties.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>New properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Clone of the node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.raws.before <span class="hljs-comment">//=&gt; "\n "</span>
+<span class="hljs-keyword">const</span> cloned = decl.clone({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-moz-'</span> + decl.prop })
+cloned.raws.before <span class="hljs-comment">//=&gt; "\n "</span>
+cloned.toString() <span class="hljs-comment">//=&gt; -moz-transform: scale(0)</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationcloneafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L215-L219'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationcloneafter'>
+ <code>
+ cloneAfter
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Shortcut to clone the node and insert the resulting cloned node
+after the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>New properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>New node.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationclonebefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L201-L205'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationclonebefore'>
+ <code>
+ cloneBefore
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Shortcut to clone the node and insert the resulting cloned node
+before the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Mew properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>New node
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-moz-'</span> + decl.prop })</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationerror'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L88-L94'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationerror'>
+ <code>
+ error
+ <span class='gray'>(message, opts = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <code>CssSyntaxError</code> instance containing the original position
+of the node in the source, showing line and column numbers and also
+a small excerpt to facilitate debugging.</p>
+<p>If present, an input source map will be used to get the original position
+of the source, even from a previous compilation step
+(e.g., from Sass compilation).</p>
+<p>This method produces very useful error messages.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>message</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Error description.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Options.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.plugin</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>Plugin name that created this error.
+PostCSS will set it automatically.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.word</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>A word inside a node’s string that should
+be highlighted as the source of the error.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.index</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>An index inside a node’s string that should
+be highlighted as the source of the error.
+</td>
+</tr>
+
+
+
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#csssyntaxerror">CssSyntaxError</a></code>
+ :
+ <span class='force-inline'>Error object to throw it.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (!variables[name]) {
+ <span class="hljs-keyword">throw</span> decl.error(<span class="hljs-string">'Unknown variable '</span> + name, { <span class="hljs-attr">word</span>: name })
+ <span class="hljs-comment">// CssSyntaxError: postcss-vars:a.sass:4:3: Unknown variable $black</span>
+ <span class="hljs-comment">// color: $black</span>
+ <span class="hljs-comment">// a</span>
+ <span class="hljs-comment">// ^</span>
+ <span class="hljs-comment">// background: white</span>
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationnext'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L259-L263'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationnext'>
+ <code>
+ next
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns the next child of the node’s parent.
+Returns <code>undefined</code> if the current node is the last child.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Next node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (comment.text === <span class="hljs-string">'delete next'</span>) {
+ <span class="hljs-keyword">const</span> next = comment.next()
+ <span class="hljs-keyword">if</span> (next) {
+ next.remove()
+ }
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationprev'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L277-L281'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationprev'>
+ <code>
+ prev
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns the previous child of the node’s parent.
+Returns <code>undefined</code> if the current node is the first child.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Previous node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> annotation = decl.prev()
+<span class="hljs-keyword">if</span> (annotation.type === <span class="hljs-string">'comment'</span>) {
+ readAnnotation(annotation.text)
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationraw'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L361-L364'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationraw'>
+ <code>
+ raw
+ <span class='gray'>(prop, defaultType?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <a href="Node#raws">Node#raws</a> value. If the node is missing
+the code style property (because the node was manually built or cloned),
+PostCSS will try to autodetect the code style property by looking
+at other nodes in the tree.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>prop</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Name of code style property.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>defaultType</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>?
+
+ </td>
+ <td class='col-6'>Name of default value, it can be missed
+if the value is the same as prop.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>Code style value.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a { background: white }'</span>)
+root.nodes[<span class="hljs-number">0</span>].append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">1</span>].raws.before <span class="hljs-comment">//=&gt; undefined</span>
+root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">1</span>].raw(<span class="hljs-string">'before'</span>) <span class="hljs-comment">//=&gt; ' '</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationremove'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L138-L144'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationremove'>
+ <code>
+ remove
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes the node from its parent and cleans the parent properties
+from the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Node to make calls chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (decl.prop.match(<span class="hljs-regexp">/^-webkit-/</span>)) {
+ decl.remove()
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationreplacewith'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L233-L243'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationreplacewith'>
+ <code>
+ replaceWith
+ <span class='gray'>(nodes)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts node(s) before the current node and removes the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>nodes</code></td>
+ <td class='col-3 quiet'>
+ ...<a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Mode(s) to replace current one.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Current node to methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (atrule.name === <span class="hljs-string">'mixin'</span>) {
+ atrule.replaceWith(mixinRules[atrule.params])
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationroot'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L374-L378'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationroot'>
+ <code>
+ root
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Finds the Root instance of the node’s tree.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#root">Root</a></code>
+ :
+ <span class='force-inline'>Root parent.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">0</span>].root() === root</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationtostring'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L157-L164'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationtostring'>
+ <code>
+ toString
+ <span class='gray'>(stringifier = stringify)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a CSS string representing the node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>stringifier</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#stringifier">stringifier</a> | <a href="#syntax">syntax</a>)?
+
+ = <code>stringify</code>
+ </td>
+ <td class='col-6'>A syntax to use
+in string generation.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>CSS string of this node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.rule({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }).toString() <span class="hljs-comment">//=&gt; "a {}"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='declarationwarn'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L121-L125'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#declarationwarn'>
+ <code>
+ warn
+ <span class='gray'>(result, text, opts?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>This method is provided as a convenience wrapper for <a href="#resultwarn">Result#warn</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>result</code></td>
+ <td class='col-3 quiet'>
+ <a href="#result">Result</a>
+
+ </td>
+ <td class='col-6'>The
+<a href="#result">Result</a>
+ instance
+that will receive the warning.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>text</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Warning message.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ </td>
+ <td class='col-6'>Options
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.plugin</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>Plugin name that created this warning.
+PostCSS will set it automatically.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.word</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>A word inside a node’s string that should
+be highlighted as the source of the warning.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.index</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>An index inside a node’s string that should
+be highlighted as the source of the warning.
+</td>
+</tr>
+
+
+
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#warning">Warning</a></code>
+ :
+ <span class='force-inline'>Created warning object.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> plugin = postcss.plugin(<span class="hljs-string">'postcss-deprecated'</span>, () =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-function">(<span class="hljs-params">root, result</span>) =&gt;</span> {
+ root.walkDecls(<span class="hljs-string">'bad'</span>, decl =&gt; {
+ decl.warn(result, <span class="hljs-string">'Deprecated property bad'</span>)
+ })
+ }
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='input'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/input.js#L15-L169'>
+ <span>lib/input.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#input'>
+ <code>
+ Input
+ <span class='gray'>(css, opts = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Represents the source CSS.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>css</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Input CSS source.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'><a href="#processorprocess">Processor#process</a>
+ options.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(css, { <span class="hljs-attr">from</span>: file })
+<span class="hljs-keyword">const</span> input = root.source.input</code></pre>
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='inputcss'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/input.js#L34-L34'>
+ <span>lib/input.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#inputcss'>
+ <code>
+ css
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Input CSS source</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> input = postcss.parse(<span class="hljs-string">'a{}'</span>, { <span class="hljs-attr">from</span>: file }).input
+input.css <span class="hljs-comment">//=&gt; "a{}"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='inputfile'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/input.js#L55-L55'>
+ <span>lib/input.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#inputfile'>
+ <code>
+ file
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The absolute path to the CSS source file defined
+with the <code>from</code> option.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(css, { <span class="hljs-attr">from</span>: <span class="hljs-string">'a.css'</span> })
+root.source.input.file <span class="hljs-comment">//=&gt; '/home/ai/a.css'</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='inputmap'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/input.js#L72-L72'>
+ <span>lib/input.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#inputmap'>
+ <code>
+ map
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The input source map passed from a compilation step before PostCSS
+(for example, from Sass compiler).</p>
+
+
+ <p>
+ Type:
+ <a href="#previousmap">PreviousMap</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.source.input.map.consumer().sources <span class="hljs-comment">//=&gt; ['a.sass']</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='inputid'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/input.js#L90-L90'>
+ <span>lib/input.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#inputid'>
+ <code>
+ id
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The unique ID of the CSS source. It will be created if <code>from</code> option
+is not provided (because PostCSS does not know the file path).</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(css)
+root.source.input.file <span class="hljs-comment">//=&gt; undefined</span>
+root.source.input.id <span class="hljs-comment">//=&gt; "&lt;input css 1&gt;"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='inputorigin'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/input.js#L127-L144'>
+ <span>lib/input.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#inputorigin'>
+ <code>
+ origin
+ <span class='gray'>(line, column)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Reads the input source map and returns a symbol position
+in the input source (e.g., in a Sass file that was compiled
+to CSS before being passed to PostCSS).</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>line</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-6'>Line in input CSS.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>column</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-6'>Column in input CSS.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#fileposition">filePosition</a></code>
+ :
+ <span class='force-inline'>Position in input source.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.source.input.origin(<span class="hljs-number">1</span>, <span class="hljs-number">1</span>) <span class="hljs-comment">//=&gt; { file: 'a.css', line: 3, column: 1 }</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='inputfrom'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/input.js#L166-L168'>
+ <span>lib/input.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#inputfrom'>
+ <code>
+ from
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The CSS source identifier. Contains <a href="#inputfile">Input#file</a> if the user
+set the <code>from</code> option, or <a href="#inputid">Input#id</a> if they did not.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(css, { <span class="hljs-attr">from</span>: <span class="hljs-string">'a.css'</span> })
+root.source.input.from <span class="hljs-comment">//=&gt; "/home/ai/a.css"</span>
+
+<span class="hljs-keyword">const</span> root = postcss.parse(css)
+root.source.input.from <span class="hljs-comment">//=&gt; "&lt;input css 1&gt;"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='lazyresult'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L26-L417'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresult'>
+ <code>
+ LazyResult
+ <span class='gray'>(processor, css, opts)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>A Promise proxy for the result of PostCSS transformations.</p>
+<p>A <code>LazyResult</code> instance is returned by <a href="#processorprocess">Processor#process</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>processor</code></td>
+ <td class='col-3 quiet'>
+ any
+
+ </td>
+ <td class='col-6'></td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>css</code></td>
+ <td class='col-3 quiet'>
+ any
+
+ </td>
+ <td class='col-6'></td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ any
+
+ </td>
+ <td class='col-6'></td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> lazy = postcss([autoprefixer]).process(css)</code></pre>
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='lazyresultprocessor'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L63-L65'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresultprocessor'>
+ <code>
+ processor
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <a href="#processor">Processor</a> instance, which will be used
+for CSS transformations.</p>
+
+
+ <p>
+ Type:
+ <a href="#processor">Processor</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='lazyresultopts'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L72-L74'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresultopts'>
+ <code>
+ opts
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Options from the <a href="#processorprocess">Processor#process</a> call.</p>
+
+
+ <p>
+ Type:
+ <a href="#processoptions">processOptions</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='lazyresultcss'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L88-L90'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresultcss'>
+ <code>
+ css
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Processes input CSS through synchronous plugins, converts <code>Root</code>
+to a CSS string and returns <a href="#resultcss">Result#css</a>.</p>
+<p>This property will only work with synchronous plugins.
+If the processor contains any asynchronous plugins
+it will throw an error. This is why this method is only
+for debug purpose, you should always use <a href="#lazyresultthen">LazyResult#then</a>.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='lazyresultcontent'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L104-L106'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresultcontent'>
+ <code>
+ content
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>An alias for the <code>css</code> property. Use it with syntaxes
+that generate non-CSS output.</p>
+<p>This property will only work with synchronous plugins.
+If the processor contains any asynchronous plugins
+it will throw an error. This is why this method is only
+for debug purpose, you should always use <a href="#lazyresultthen">LazyResult#then</a>.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='lazyresultmap'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L120-L122'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresultmap'>
+ <code>
+ map
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Processes input CSS through synchronous plugins
+and returns <a href="#resultmap">Result#map</a>.</p>
+<p>This property will only work with synchronous plugins.
+If the processor contains any asynchronous plugins
+it will throw an error. This is why this method is only
+for debug purpose, you should always use <a href="#lazyresultthen">LazyResult#then</a>.</p>
+
+
+ <p>
+ Type:
+ SourceMapGenerator
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='lazyresultroot'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L137-L139'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresultroot'>
+ <code>
+ root
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Processes input CSS through synchronous plugins
+and returns <a href="#resultroot">Result#root</a>.</p>
+<p>This property will only work with synchronous plugins. If the processor
+contains any asynchronous plugins it will throw an error.</p>
+<p>This is why this method is only for debug purpose,
+you should always use <a href="#lazyresultthen">LazyResult#then</a>.</p>
+
+
+ <p>
+ Type:
+ <a href="#root">Root</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='lazyresultmessages'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L154-L156'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresultmessages'>
+ <code>
+ messages
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Processes input CSS through synchronous plugins
+and returns <a href="#resultmessages">Result#messages</a>.</p>
+<p>This property will only work with synchronous plugins. If the processor
+contains any asynchronous plugins it will throw an error.</p>
+<p>This is why this method is only for debug purpose,
+you should always use <a href="#lazyresultthen">LazyResult#then</a>.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#message">Message</a>>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='lazyresultwarnings'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L164-L166'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresultwarnings'>
+ <code>
+ warnings
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Processes input CSS through synchronous plugins
+and calls <a href="Result#warnings()">Result#warnings()</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#warning">Warning</a>></code>
+ :
+ <span class='force-inline'>Warnings from plugins.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='lazyresulttostring'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L176-L178'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresulttostring'>
+ <code>
+ toString
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Alias for the <a href="#lazyresultcss">LazyResult#css</a> property.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>Output CSS.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>lazy + <span class="hljs-string">''</span> === lazy.css</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='lazyresultthen'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L198-L209'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresultthen'>
+ <code>
+ then
+ <span class='gray'>(onFulfilled, onRejected)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Processes input CSS through synchronous and asynchronous plugins
+and calls <code>onFulfilled</code> with a Result instance. If a plugin throws
+an error, the <code>onRejected</code> callback will be executed.</p>
+<p>It implements standard Promise API.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>onFulfilled</code></td>
+ <td class='col-3 quiet'>
+ <a href="#onfulfilled">onFulfilled</a>
+
+ </td>
+ <td class='col-6'>Callback will be executed
+when all plugins will finish work.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>onRejected</code></td>
+ <td class='col-3 quiet'>
+ <a href="#onrejected">onRejected</a>
+
+ </td>
+ <td class='col-6'>Callback will be executed on any error.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Promise">Promise</a></code>
+ :
+ <span class='force-inline'>Promise API to make queue.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss([autoprefixer]).process(css, { <span class="hljs-attr">from</span>: cssPath }).then(<span class="hljs-function"><span class="hljs-params">result</span> =&gt;</span> {
+ <span class="hljs-built_in">console</span>.log(result.css)
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='lazyresultcatch'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L228-L230'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresultcatch'>
+ <code>
+ catch
+ <span class='gray'>(onRejected)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Processes input CSS through synchronous and asynchronous plugins
+and calls onRejected for each error thrown in any plugin.</p>
+<p>It implements standard Promise API.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>onRejected</code></td>
+ <td class='col-3 quiet'>
+ <a href="#onrejected">onRejected</a>
+
+ </td>
+ <td class='col-6'>Callback will be executed on any error.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Promise">Promise</a></code>
+ :
+ <span class='force-inline'>Promise API to make queue.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss([autoprefixer]).process(css).then(<span class="hljs-function"><span class="hljs-params">result</span> =&gt;</span> {
+ <span class="hljs-built_in">console</span>.log(result.css)
+}).catch(<span class="hljs-function"><span class="hljs-params">error</span> =&gt;</span> {
+ <span class="hljs-built_in">console</span>.error(error)
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='lazyresultfinally'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L248-L250'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#lazyresultfinally'>
+ <code>
+ finally
+ <span class='gray'>(onFinally)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Processes input CSS through synchronous and asynchronous plugins
+and calls onFinally on any error or when all plugins will finish work.</p>
+<p>It implements standard Promise API.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>onFinally</code></td>
+ <td class='col-3 quiet'>
+ onFinally
+
+ </td>
+ <td class='col-6'>Callback will be executed on any error or
+when all plugins will finish work.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Promise">Promise</a></code>
+ :
+ <span class='force-inline'>Promise API to make queue.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss([autoprefixer]).process(css).finally(<span class="hljs-function"><span class="hljs-params">()</span> =&gt;</span> {
+ <span class="hljs-built_in">console</span>.log(<span class="hljs-string">'processing ended'</span>)
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='node'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L34-L514'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#node'>
+ <code>
+ Node
+ <span class='gray'>(defaults = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>All node classes inherit the following common methods.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>defaults</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Value for node properties.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='nodeerror'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L88-L94'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodeerror'>
+ <code>
+ error
+ <span class='gray'>(message, opts = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <code>CssSyntaxError</code> instance containing the original position
+of the node in the source, showing line and column numbers and also
+a small excerpt to facilitate debugging.</p>
+<p>If present, an input source map will be used to get the original position
+of the source, even from a previous compilation step
+(e.g., from Sass compilation).</p>
+<p>This method produces very useful error messages.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>message</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Error description.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Options.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.plugin</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>Plugin name that created this error.
+PostCSS will set it automatically.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.word</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>A word inside a node’s string that should
+be highlighted as the source of the error.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.index</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>An index inside a node’s string that should
+be highlighted as the source of the error.
+</td>
+</tr>
+
+
+
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#csssyntaxerror">CssSyntaxError</a></code>
+ :
+ <span class='force-inline'>Error object to throw it.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (!variables[name]) {
+ <span class="hljs-keyword">throw</span> decl.error(<span class="hljs-string">'Unknown variable '</span> + name, { <span class="hljs-attr">word</span>: name })
+ <span class="hljs-comment">// CssSyntaxError: postcss-vars:a.sass:4:3: Unknown variable $black</span>
+ <span class="hljs-comment">// color: $black</span>
+ <span class="hljs-comment">// a</span>
+ <span class="hljs-comment">// ^</span>
+ <span class="hljs-comment">// background: white</span>
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='nodewarn'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L121-L125'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodewarn'>
+ <code>
+ warn
+ <span class='gray'>(result, text, opts?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>This method is provided as a convenience wrapper for <a href="#resultwarn">Result#warn</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>result</code></td>
+ <td class='col-3 quiet'>
+ <a href="#result">Result</a>
+
+ </td>
+ <td class='col-6'>The
+<a href="#result">Result</a>
+ instance
+that will receive the warning.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>text</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Warning message.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ </td>
+ <td class='col-6'>Options
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.plugin</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>Plugin name that created this warning.
+PostCSS will set it automatically.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.word</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>A word inside a node’s string that should
+be highlighted as the source of the warning.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.index</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>An index inside a node’s string that should
+be highlighted as the source of the warning.
+</td>
+</tr>
+
+
+
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#warning">Warning</a></code>
+ :
+ <span class='force-inline'>Created warning object.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> plugin = postcss.plugin(<span class="hljs-string">'postcss-deprecated'</span>, () =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-function">(<span class="hljs-params">root, result</span>) =&gt;</span> {
+ root.walkDecls(<span class="hljs-string">'bad'</span>, decl =&gt; {
+ decl.warn(result, <span class="hljs-string">'Deprecated property bad'</span>)
+ })
+ }
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='noderemove'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L138-L144'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#noderemove'>
+ <code>
+ remove
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes the node from its parent and cleans the parent properties
+from the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Node to make calls chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (decl.prop.match(<span class="hljs-regexp">/^-webkit-/</span>)) {
+ decl.remove()
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='nodetostring'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L157-L164'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodetostring'>
+ <code>
+ toString
+ <span class='gray'>(stringifier = stringify)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a CSS string representing the node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>stringifier</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#stringifier">stringifier</a> | <a href="#syntax">syntax</a>)?
+
+ = <code>stringify</code>
+ </td>
+ <td class='col-6'>A syntax to use
+in string generation.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>CSS string of this node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.rule({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }).toString() <span class="hljs-comment">//=&gt; "a {}"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='nodeclone'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L182-L188'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodeclone'>
+ <code>
+ clone
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns an exact clone of the node.</p>
+<p>The resulting cloned node and its (cloned) children will retain
+code style properties.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>New properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Clone of the node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.raws.before <span class="hljs-comment">//=&gt; "\n "</span>
+<span class="hljs-keyword">const</span> cloned = decl.clone({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-moz-'</span> + decl.prop })
+cloned.raws.before <span class="hljs-comment">//=&gt; "\n "</span>
+cloned.toString() <span class="hljs-comment">//=&gt; -moz-transform: scale(0)</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='nodeclonebefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L201-L205'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodeclonebefore'>
+ <code>
+ cloneBefore
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Shortcut to clone the node and insert the resulting cloned node
+before the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Mew properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>New node
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-moz-'</span> + decl.prop })</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='nodecloneafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L215-L219'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodecloneafter'>
+ <code>
+ cloneAfter
+ <span class='gray'>(overrides = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Shortcut to clone the node and insert the resulting cloned node
+after the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>overrides</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>New properties to override in the clone.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>New node.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='nodereplacewith'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L233-L243'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodereplacewith'>
+ <code>
+ replaceWith
+ <span class='gray'>(nodes)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts node(s) before the current node and removes the current node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>nodes</code></td>
+ <td class='col-3 quiet'>
+ ...<a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Mode(s) to replace current one.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>Current node to methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (atrule.name === <span class="hljs-string">'mixin'</span>) {
+ atrule.replaceWith(mixinRules[atrule.params])
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='nodenext'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L259-L263'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodenext'>
+ <code>
+ next
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns the next child of the node’s parent.
+Returns <code>undefined</code> if the current node is the last child.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Next node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (comment.text === <span class="hljs-string">'delete next'</span>) {
+ <span class="hljs-keyword">const</span> next = comment.next()
+ <span class="hljs-keyword">if</span> (next) {
+ next.remove()
+ }
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='nodeprev'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L277-L281'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodeprev'>
+ <code>
+ prev
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns the previous child of the node’s parent.
+Returns <code>undefined</code> if the current node is the first child.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Previous node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> annotation = decl.prev()
+<span class="hljs-keyword">if</span> (annotation.type === <span class="hljs-string">'comment'</span>) {
+ readAnnotation(annotation.text)
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='nodebefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L295-L298'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodebefore'>
+ <code>
+ before
+ <span class='gray'>(add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node before current node to current node’s parent.</p>
+<p>Just alias for <code>node.parent.insertBefore(node, add)</code>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.before(<span class="hljs-string">'content: ""'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='nodeafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L312-L315'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodeafter'>
+ <code>
+ after
+ <span class='gray'>(add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node after current node to current node’s parent.</p>
+<p>Just alias for <code>node.parent.insertAfter(node, add)</code>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>decl.after(<span class="hljs-string">'color: black'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='noderaw'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L361-L364'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#noderaw'>
+ <code>
+ raw
+ <span class='gray'>(prop, defaultType?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <a href="Node#raws">Node#raws</a> value. If the node is missing
+the code style property (because the node was manually built or cloned),
+PostCSS will try to autodetect the code style property by looking
+at other nodes in the tree.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>prop</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Name of code style property.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>defaultType</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>?
+
+ </td>
+ <td class='col-6'>Name of default value, it can be missed
+if the value is the same as prop.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>Code style value.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a { background: white }'</span>)
+root.nodes[<span class="hljs-number">0</span>].append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">1</span>].raws.before <span class="hljs-comment">//=&gt; undefined</span>
+root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">1</span>].raw(<span class="hljs-string">'before'</span>) <span class="hljs-comment">//=&gt; ' '</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='noderoot'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L374-L378'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#noderoot'>
+ <code>
+ root
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Finds the Root instance of the node’s tree.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#root">Root</a></code>
+ :
+ <span class='force-inline'>Root parent.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.nodes[<span class="hljs-number">0</span>].nodes[<span class="hljs-number">0</span>].root() === root</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='nodecleanraws'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L392-L396'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#nodecleanraws'>
+ <code>
+ cleanRaws
+ <span class='gray'>(keepBetween?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Clear the code style properties for the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>keepBetween</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a>?
+
+ </td>
+ <td class='col-6'>Keep the raws.between symbols.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a></code>
+ :
+ <span class='force-inline'>
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>node.raws.before <span class="hljs-comment">//=&gt; ' '</span>
+node.cleanRaws()
+node.raws.before <span class="hljs-comment">//=&gt; undefined</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='previousmap'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/previous-map.js#L24-L140'>
+ <span>lib/previous-map.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#previousmap'>
+ <code>
+ PreviousMap
+ <span class='gray'>(css, opts?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Source map information from input CSS.
+For example, source map after Sass compiler.</p>
+<p>This class will automatically find source map in input CSS or in file system
+near input file (according <code>from</code> option).</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>css</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Input CSS source.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="#processoptions">processOptions</a>?
+
+ </td>
+ <td class='col-6'><a href="#processorprocess">Processor#process</a>
+ options.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(css, { <span class="hljs-attr">from</span>: <span class="hljs-string">'a.sass.css'</span> })
+root.input.map <span class="hljs-comment">//=&gt; PreviousMap</span></code></pre>
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='previousmapinline'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/previous-map.js#L36-L36'>
+ <span>lib/previous-map.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#previousmapinline'>
+ <code>
+ inline
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Was source map inlined by data-uri to input CSS.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='previousmapconsumer'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/previous-map.js#L52-L57'>
+ <span>lib/previous-map.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#previousmapconsumer'>
+ <code>
+ consumer
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Create a instance of <code>SourceMapGenerator</code> class
+from the <code>source-map</code> library to work with source map information.</p>
+<p>It is lazy method, so it will create object only on first call
+and then it will use cache.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>SourceMapGenerator</code>
+ :
+ <span class='force-inline'>Object with source map information.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='previousmapwithcontent'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/previous-map.js#L64-L67'>
+ <span>lib/previous-map.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#previousmapwithcontent'>
+ <code>
+ withContent
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Does source map contains <code>sourcesContent</code> with input source text.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a></code>
+ :
+ <span class='force-inline'>Is
+<code>sourcesContent</code>
+ present.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='processor'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L12-L135'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#processor'>
+ <code>
+ Processor
+ <span class='gray'>(plugins)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Contains plugins to process CSS. Create one <code>Processor</code> instance,
+initialize its plugins, and then use that instance on numerous CSS files.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>plugins</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;(<a href="#plugin">Plugin</a> | <a href="#pluginfunction">pluginFunction</a>)> | <a href="#processor">Processor</a>)
+
+ = <code>[]</code>
+ </td>
+ <td class='col-6'>PostCSS plugins.
+See
+<a href="#processoruse">Processor#use</a>
+ for plugin format.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> processor = postcss([autoprefixer, precss])
+processor.process(css1).then(<span class="hljs-function"><span class="hljs-params">result</span> =&gt;</span> <span class="hljs-built_in">console</span>.log(result.css))
+processor.process(css2).then(<span class="hljs-function"><span class="hljs-params">result</span> =&gt;</span> <span class="hljs-built_in">console</span>.log(result.css))</code></pre>
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='processorversion'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L28-L28'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#processorversion'>
+ <code>
+ version
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Current PostCSS version.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (result.processor.version.split(<span class="hljs-string">'.'</span>)[<span class="hljs-number">0</span>] !== <span class="hljs-string">'6'</span>) {
+ <span class="hljs-keyword">throw</span> <span class="hljs-keyword">new</span> <span class="hljs-built_in">Error</span>(<span class="hljs-string">'This plugin works only with PostCSS 6'</span>)
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='processorplugins'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L38-L38'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#processorplugins'>
+ <code>
+ plugins
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Plugins added to this processor.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#pluginfunction">pluginFunction</a>>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> processor = postcss([autoprefixer, precss])
+processor.plugins.length <span class="hljs-comment">//=&gt; 2</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='processoruse'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L70-L73'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#processoruse'>
+ <code>
+ use
+ <span class='gray'>(plugin)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Adds a plugin to be used as a CSS processor.</p>
+<p>PostCSS plugin can be in 4 formats:</p>
+<ul>
+<li>A plugin created by <a href="#postcssplugin">postcss.plugin</a> method.</li>
+<li>A function. PostCSS will pass the function a @{link Root}
+as the first argument and current <a href="#result">Result</a> instance
+as the second.</li>
+<li>An object with a <code>postcss</code> method. PostCSS will use that method
+as described in #2.</li>
+<li>Another <a href="#processor">Processor</a> instance. PostCSS will copy plugins
+from that instance into this one.</li>
+</ul>
+<p>Plugins can also be added by passing them as arguments when creating
+a <code>postcss</code> instance (see [<code>postcss(plugins)</code>]).</p>
+<p>Asynchronous plugins should return a <code>Promise</code> instance.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>plugin</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#plugin">Plugin</a> | <a href="#pluginfunction">pluginFunction</a> | <a href="#processor">Processor</a>)
+
+ </td>
+ <td class='col-6'>PostCSS plugin
+or
+<a href="#processor">Processor</a>
+
+with plugins.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>Processes</code>
+ :
+ <span class='force-inline'>Current processor to make methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> processor = postcss()
+ .use(autoprefixer)
+ .use(precss)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='processorprocess'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L97-L110'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#processorprocess'>
+ <code>
+ process
+ <span class='gray'>(css, opts = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Parses source CSS and returns a <a href="#lazyresult">LazyResult</a> Promise proxy.
+Because some plugins can be asynchronous it doesn’t make
+any transformations. Transformations will be applied
+in the <a href="#lazyresult">LazyResult</a> methods.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>css</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="#tostring">toString</a> | <a href="#result">Result</a>)
+
+ </td>
+ <td class='col-6'>String with input CSS or any object
+with a
+<code>toString()</code>
+ method,
+like a Buffer. Optionally, send
+a
+<a href="#result">Result</a>
+ instance
+and the processor will take
+the
+<a href="#root">Root</a>
+ from it.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="#processoptions">processOptions</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Options.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#lazyresult">LazyResult</a></code>
+ :
+ <span class='force-inline'>Promise proxy.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>processor.process(css, { <span class="hljs-attr">from</span>: <span class="hljs-string">'a.css'</span>, <span class="hljs-attr">to</span>: <span class="hljs-string">'a.out.css'</span> })
+ .then(<span class="hljs-function"><span class="hljs-params">result</span> =&gt;</span> {
+ <span class="hljs-built_in">console</span>.log(result.css)
+ })</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='result'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L17-L170'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#result'>
+ <code>
+ Result
+ <span class='gray'>(processor, root, opts)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Provides the result of the PostCSS transformations.</p>
+<p>A Result instance is returned by <a href="#lazyresultthen">LazyResult#then</a>
+or <a href="#roottoresult">Root#toResult</a> methods.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>processor</code></td>
+ <td class='col-3 quiet'>
+ <a href="#processor">Processor</a>
+
+ </td>
+ <td class='col-6'>Processor used for this transformation.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>root</code></td>
+ <td class='col-3 quiet'>
+ <a href="#root">Root</a>
+
+ </td>
+ <td class='col-6'>Root node after all transformations.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="#processoptions">processOptions</a>
+
+ </td>
+ <td class='col-6'>Options from the
+<a href="#processorprocess">Processor#process</a>
+
+or
+<a href="#roottoresult">Root#toResult</a>
+.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss([autoprefixer]).process(css).then(<span class="hljs-function"><span class="hljs-params">result</span> =&gt;</span> {
+ <span class="hljs-built_in">console</span>.log(result.css)
+})</code></pre>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> result2 = postcss.parse(css).toResult()</code></pre>
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='resultprocessor'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L37-L37'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#resultprocessor'>
+ <code>
+ processor
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The Processor instance used for this transformation.</p>
+
+
+ <p>
+ Type:
+ <a href="#processor">Processor</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">for</span> (<span class="hljs-keyword">const</span> plugin <span class="hljs-keyword">of</span> result.processor.plugins) {
+ <span class="hljs-keyword">if</span> (plugin.postcssPlugin === <span class="hljs-string">'postcss-bad'</span>) {
+ <span class="hljs-keyword">throw</span> <span class="hljs-string">'postcss-good is incompatible with postcss-bad'</span>
+ }
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='resultmessages'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L56-L56'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#resultmessages'>
+ <code>
+ messages
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Contains messages from plugins (e.g., warnings or custom messages).
+Each message should have type and plugin properties.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#message">Message</a>>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.plugin(<span class="hljs-string">'postcss-min-browser'</span>, () =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-function">(<span class="hljs-params">root, result</span>) =&gt;</span> {
+ <span class="hljs-keyword">const</span> browsers = detectMinBrowsersByCanIUse(root)
+ result.messages.push({
+ <span class="hljs-attr">type</span>: <span class="hljs-string">'min-browser'</span>,
+ <span class="hljs-attr">plugin</span>: <span class="hljs-string">'postcss-min-browser'</span>,
+ browsers
+ })
+ }
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='resultroot'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L65-L65'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#resultroot'>
+ <code>
+ root
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Root node after all transformations.</p>
+
+
+ <p>
+ Type:
+ <a href="#root">Root</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.toResult().root === root</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='resultopts'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L75-L75'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#resultopts'>
+ <code>
+ opts
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Options from the <a href="#processorprocess">Processor#process</a> or <a href="#roottoresult">Root#toResult</a> call
+that produced this Result instance.</p>
+
+
+ <p>
+ Type:
+ <a href="#processoptions">processOptions</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.toResult(opts).opts === opts</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='resultcss'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L84-L84'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#resultcss'>
+ <code>
+ css
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>A CSS string representing of <a href="#resultroot">Result#root</a>.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.parse(<span class="hljs-string">'a{}'</span>).toResult().css <span class="hljs-comment">//=&gt; "a{}"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='resultmap'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L99-L99'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#resultmap'>
+ <code>
+ map
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>An instance of <code>SourceMapGenerator</code> class from the <code>source-map</code> library,
+representing changes to the <a href="#resultroot">Result#root</a> instance.</p>
+
+
+ <p>
+ Type:
+ SourceMapGenerator
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>result.map.toJSON() <span class="hljs-comment">//=&gt; { version: 3, file: 'a.css', … }</span></code></pre>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (result.map) {
+ fs.writeFileSync(result.opts.to + <span class="hljs-string">'.map'</span>, result.map.toString())
+}</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='resulttostring'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L110-L112'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#resulttostring'>
+ <code>
+ toString
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns for @{link Result#css} content.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>String representing of
+<a href="#resultroot">Result#root</a>
+.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>result + <span class="hljs-string">''</span> === result.css</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='resultwarn'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L130-L141'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#resultwarn'>
+ <code>
+ warn
+ <span class='gray'>(text, opts = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Creates an instance of <a href="#warning">Warning</a> and adds it
+to <a href="#resultmessages">Result#messages</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>text</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Warning message.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">Object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Warning options.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.node</td>
+ <td class="col-2 quiet">
+ <a href="#node">Node</a>
+
+ </td>
+ <td class='col-8'>CSS node that caused the warning.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.word</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>Word in CSS source that caused the warning.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.index</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>Index in CSS node string that caused
+the warning.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.plugin</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>Name of the plugin that created
+this warning.
+<a href="#resultwarn">Result#warn</a>
+ fills
+this property automatically.
+</td>
+</tr>
+
+
+
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#warning">Warning</a></code>
+ :
+ <span class='force-inline'>Created warning.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='resultwarnings'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L154-L156'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#resultwarnings'>
+ <code>
+ warnings
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns warnings from plugins. Filters <a href="#warning">Warning</a> instances
+from <a href="#resultmessages">Result#messages</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#warning">Warning</a>></code>
+ :
+ <span class='force-inline'>Warnings from plugins.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>result.warnings().forEach(<span class="hljs-function"><span class="hljs-params">warn</span> =&gt;</span> {
+ <span class="hljs-built_in">console</span>.warn(warn.toString())
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='resultcontent'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L167-L169'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#resultcontent'>
+ <code>
+ content
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>An alias for the <a href="#resultcss">Result#css</a> property.
+Use it with syntaxes that generate non-CSS output.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>result.css === result.content</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='root'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+ <span class='font-smaller'>
+ Extends
+
+ <a href="#container">Container</a>
+
+ </span>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/root.js#L76-L181'>
+ <span>lib/root.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#root'>
+ <code>
+ Root
+ <span class='gray'>(defaults)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Represents a CSS file and contains all its parsed nodes.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>defaults</code></td>
+ <td class='col-3 quiet'>
+ any
+
+ </td>
+ <td class='col-6'></td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a{color:black} b{z-index:2}'</span>)
+root.type <span class="hljs-comment">//=&gt; 'root'</span>
+root.nodes.length <span class="hljs-comment">//=&gt; 2</span></code></pre>
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='rootappend'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L370-L379'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootappend'>
+ <code>
+ append
+ <span class='gray'>(children)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts new nodes to the end of the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>children</code></td>
+ <td class='col-3 quiet'>
+ ...(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New nodes.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> decl1 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+<span class="hljs-keyword">const</span> decl2 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'background-color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'white'</span> })
+rule.append(decl1, decl2)
+
+root.append({ <span class="hljs-attr">name</span>: <span class="hljs-string">'charset'</span>, <span class="hljs-attr">params</span>: <span class="hljs-string">'"UTF-8"'</span> }) <span class="hljs-comment">// at-rule</span>
+root.append({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }) <span class="hljs-comment">// rule</span>
+rule.append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> }) <span class="hljs-comment">// declaration</span>
+rule.append({ <span class="hljs-attr">text</span>: <span class="hljs-string">'Comment'</span> }) <span class="hljs-comment">// comment</span>
+
+root.append(<span class="hljs-string">'a {}'</span>)
+root.first.append(<span class="hljs-string">'color: black; z-index: 1'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rooteach'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L76-L102'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rooteach'>
+ <code>
+ each
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Iterates through the container’s immediate children,
+calling <code>callback</code> for each child.</p>
+<p>Returning <code>false</code> in the callback will break iteration.</p>
+<p>This method only iterates through the container’s immediate children.
+If you need to recursively iterate through all the container’s descendant
+nodes, use <a href="#containerwalk">Container#walk</a>.</p>
+<p>Unlike the for <code>{}</code>-cycle or <code>Array#forEach</code> this iterator is safe
+if you are mutating the array of child nodes during iteration.
+PostCSS will adjust the current index to match the mutations.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a { color: black; z-index: 1 }'</span>)
+<span class="hljs-keyword">const</span> rule = root.first
+
+<span class="hljs-keyword">for</span> (<span class="hljs-keyword">const</span> decl <span class="hljs-keyword">of</span> rule.nodes) {
+ decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop })
+ <span class="hljs-comment">// Cycle will be infinite, because cloneBefore moves the current node</span>
+ <span class="hljs-comment">// to the next index</span>
+}
+
+rule.each(<span class="hljs-function"><span class="hljs-params">decl</span> =&gt;</span> {
+ decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop })
+ <span class="hljs-comment">// Will be executed only for color and z-index</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootevery'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L587-L589'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootevery'>
+ <code>
+ every
+ <span class='gray'>(condition)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns <code>true</code> if callback returns <code>true</code>
+for all of the container’s children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>condition</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childcondition">childCondition</a>
+
+ </td>
+ <td class='col-6'>Iterator returns true or false.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a></code>
+ :
+ <span class='force-inline'>Is every child pass condition.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> noPrefixes = rule.every(<span class="hljs-function"><span class="hljs-params">i</span> =&gt;</span> i.prop[<span class="hljs-number">0</span>] !== <span class="hljs-string">'-'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootfirst'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L631-L634'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootfirst'>
+ <code>
+ first
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The container’s first child.</p>
+
+
+ <p>
+ Type:
+ <a href="#node">Node</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.first === rules.nodes[<span class="hljs-number">0</span>]</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootindex'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L616-L621'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootindex'>
+ <code>
+ index
+ <span class='gray'>(child)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <code>child</code>’s index within the <a href="Container#nodes">Container#nodes</a> array.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>child</code></td>
+ <td class='col-3 quiet'>
+ <a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Child of the current container.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a></code>
+ :
+ <span class='force-inline'>Child index.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.index( rule.nodes[<span class="hljs-number">2</span>] ) <span class="hljs-comment">//=&gt; 2</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootinsertafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L462-L479'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootinsertafter'>
+ <code>
+ insertAfter
+ <span class='gray'>(exist, add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node after old node within the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>exist</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootinsertbefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L434-L452'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootinsertbefore'>
+ <code>
+ insertBefore
+ <span class='gray'>(exist, add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node before old node within the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>exist</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.insertBefore(decl, decl.clone({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop }))</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootlast'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L644-L647'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootlast'>
+ <code>
+ last
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The container’s last child.</p>
+
+
+ <p>
+ Type:
+ <a href="#node">Node</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.last === rule.nodes[rule.nodes.length - <span class="hljs-number">1</span>]</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootprepend'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L401-L414'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootprepend'>
+ <code>
+ prepend
+ <span class='gray'>(children)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts new nodes to the start of the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>children</code></td>
+ <td class='col-3 quiet'>
+ ...(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New nodes.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> decl1 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+<span class="hljs-keyword">const</span> decl2 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'background-color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'white'</span> })
+rule.prepend(decl1, decl2)
+
+root.append({ <span class="hljs-attr">name</span>: <span class="hljs-string">'charset'</span>, <span class="hljs-attr">params</span>: <span class="hljs-string">'"UTF-8"'</span> }) <span class="hljs-comment">// at-rule</span>
+root.append({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }) <span class="hljs-comment">// rule</span>
+rule.append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> }) <span class="hljs-comment">// declaration</span>
+rule.append({ <span class="hljs-attr">text</span>: <span class="hljs-string">'Comment'</span> }) <span class="hljs-comment">// comment</span>
+
+root.append(<span class="hljs-string">'a {}'</span>)
+root.first.append(<span class="hljs-string">'color: black; z-index: 1'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootremoveall'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L523-L530'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootremoveall'>
+ <code>
+ removeAll
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes all children from the container
+and cleans their parent properties.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.removeAll()
+rule.nodes.length <span class="hljs-comment">//=&gt; 0</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootremovechild'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L495-L511'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootremovechild'>
+ <code>
+ removeChild
+ <span class='gray'>(child)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes node from the container and cleans the parent properties
+from the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>child</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.nodes.length <span class="hljs-comment">//=&gt; 5</span>
+rule.removeChild(decl)
+rule.nodes.length <span class="hljs-comment">//=&gt; 4</span>
+decl.parent <span class="hljs-comment">//=&gt; undefined</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootreplacevalues'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L558-L574'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootreplacevalues'>
+ <code>
+ replaceValues
+ <span class='gray'>(pattern, opts, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Passes all declaration values within the container that match pattern
+through callback, replacing those values with the returned result
+of callback.</p>
+<p>This method is useful if you are using a custom unit or function
+and need to iterate through all values.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>pattern</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)
+
+ </td>
+ <td class='col-6'>Replace pattern.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+
+ </td>
+ <td class='col-6'>Options to speed up the search.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.props</td>
+ <td class="col-2 quiet">
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>>)
+
+ </td>
+ <td class='col-8'>An array of property names.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.fast</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>String that’s used to narrow down
+values and speed up the regexp search.
+</td>
+</tr>
+
+
+
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">function</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>)
+
+ </td>
+ <td class='col-6'>String to replace pattern or callback
+that returns a new value. The callback
+will receive the same arguments
+as those passed to a function parameter
+of
+<code>String#replace</code>
+.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.replaceValues(<span class="hljs-regexp">/\d+rem/</span>, { <span class="hljs-attr">fast</span>: <span class="hljs-string">'rem'</span> }, string =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-number">15</span> * <span class="hljs-built_in">parseInt</span>(string) + <span class="hljs-string">'px'</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootwalk'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L123-L137'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootwalk'>
+ <code>
+ walk
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each node.</p>
+<p>Like container.each(), this method is safe to use
+if you are mutating arrays during iteration.</p>
+<p>If you only need to iterate through the container’s immediate children,
+use <a href="#containereach">Container#each</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walk(<span class="hljs-function"><span class="hljs-params">node</span> =&gt;</span> {
+ <span class="hljs-comment">// Traverses all descendant nodes.</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootwalkatrules'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L303-L324'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootwalkatrules'>
+ <code>
+ walkAtRules
+ <span class='gray'>(name?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each at-rule node.</p>
+<p>If you pass a filter, iteration will only happen over at-rules
+that have matching names.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>name</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter at-rules by name.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkAtRules(<span class="hljs-function"><span class="hljs-params">rule</span> =&gt;</span> {
+ <span class="hljs-keyword">if</span> (isOld(rule.name)) rule.remove()
+})
+
+<span class="hljs-keyword">let</span> first = <span class="hljs-literal">false</span>
+root.walkAtRules(<span class="hljs-string">'charset'</span>, rule =&gt; {
+ <span class="hljs-keyword">if</span> (!first) {
+ first = <span class="hljs-literal">true</span>
+ } <span class="hljs-keyword">else</span> {
+ rule.remove()
+ }
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootwalkcomments'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L342-L348'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootwalkcomments'>
+ <code>
+ walkComments
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each comment node.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkComments(<span class="hljs-function"><span class="hljs-params">comment</span> =&gt;</span> {
+ comment.remove()
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootwalkrules'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L249-L271'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootwalkrules'>
+ <code>
+ walkRules
+ <span class='gray'>(selector?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each rule node.</p>
+<p>If you pass a filter, iteration will only happen over rules
+with matching selectors.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>selector</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter rules by selector.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> selectors = []
+root.walkRules(<span class="hljs-function"><span class="hljs-params">rule</span> =&gt;</span> {
+ selectors.push(rule.selector)
+})
+<span class="hljs-built_in">console</span>.log(<span class="hljs-string">`Your CSS uses <span class="hljs-subst">${ selectors.length }</span> selectors`</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rooton'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/root.js#L160-L164'>
+ <span>lib/root.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rooton'>
+ <code>
+ on
+ <span class='gray'>(type?, callback?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The method registrations the plugins in postcss to their bypass with
+algorithm visitor. The plugin must subscribes to the type of the node.
+It can be "atrule", "rule", "decl", "comment". Example: "atrule" is
+"@media", "@keyframes"; "rule" is selector (class, id, tag); "decl" is
+property (color, border, etc.); "comment" is comment. The plugin will
+call on the type of the node to which it is subscribed. The plugin can
+be subscribed at the enter to node or at the exit from node. The plugin get
+node and index.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>type</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>?
+
+ </td>
+ <td class='col-6'>The type of the node ("atrule", "rule",
+"decl", "comment").
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">function</a>?
+
+ </td>
+ <td class='col-6'>Function receives node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a></code>
+ :
+ <span class='force-inline'>
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>css.on(<span class="hljs-string">"decl"</span>, (node, index) =&gt; {})
+<span class="hljs-comment">// is shorthand for</span>
+css.on(<span class="hljs-string">"decl.enter"</span>, (node, index) =&gt; {})
+
+css.on(<span class="hljs-string">"decl.exit"</span>, (node, index) =&gt; {})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootsome'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L602-L604'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootsome'>
+ <code>
+ some
+ <span class='gray'>(condition)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns <code>true</code> if callback returns <code>true</code> for (at least) one
+of the container’s children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>condition</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childcondition">childCondition</a>
+
+ </td>
+ <td class='col-6'>Iterator returns true or false.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a></code>
+ :
+ <span class='force-inline'>Is some child pass condition.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> hasPrefix = rule.some(<span class="hljs-function"><span class="hljs-params">i</span> =&gt;</span> i.prop[<span class="hljs-number">0</span>] === <span class="hljs-string">'-'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='roottoresult'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/root.js#L129-L135'>
+ <span>lib/root.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#roottoresult'>
+ <code>
+ toResult
+ <span class='gray'>(opts = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <a href="#result">Result</a> instance representing the root’s CSS.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="#processoptions">processOptions</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Options with only
+<code>to</code>
+ and
+<code>map</code>
+ keys.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#result">Result</a></code>
+ :
+ <span class='force-inline'>Result with current root’s CSS.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root1 = postcss.parse(css1, { <span class="hljs-attr">from</span>: <span class="hljs-string">'a.css'</span> })
+<span class="hljs-keyword">const</span> root2 = postcss.parse(css2, { <span class="hljs-attr">from</span>: <span class="hljs-string">'b.css'</span> })
+root1.append(root2)
+<span class="hljs-keyword">const</span> result = root1.toResult({ <span class="hljs-attr">to</span>: <span class="hljs-string">'all.css'</span>, <span class="hljs-attr">map</span>: <span class="hljs-literal">true</span> })</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rootwalkdecls'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L203-L224'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rootwalkdecls'>
+ <code>
+ walkDecls
+ <span class='gray'>(prop?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each declaration node.</p>
+<p>If you pass a filter, iteration will only happen over declarations
+with matching properties.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>prop</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter declarations by property name.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkDecls(<span class="hljs-function"><span class="hljs-params">decl</span> =&gt;</span> {
+ checkPropertySupport(decl.prop)
+})
+
+root.walkDecls(<span class="hljs-string">'border-radius'</span>, decl =&gt; {
+ decl.remove()
+})
+
+root.walkDecls(<span class="hljs-regexp">/^background/</span>, decl =&gt; {
+ decl.value = takeFirstColorFromGradient(decl.value)
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='rule'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+ <span class='font-smaller'>
+ Extends
+
+ <a href="#container">Container</a>
+
+ </span>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/rule.js#L17-L90'>
+ <span>lib/rule.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rule'>
+ <code>
+ Rule
+ <span class='gray'>(defaults)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Represents a CSS rule: a selector followed by a declaration block.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>defaults</code></td>
+ <td class='col-3 quiet'>
+ any
+
+ </td>
+ <td class='col-6'></td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a{}'</span>)
+<span class="hljs-keyword">const</span> rule = root.first
+rule.type <span class="hljs-comment">//=&gt; 'rule'</span>
+rule.toString() <span class="hljs-comment">//=&gt; 'a{}'</span></code></pre>
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='ruleappend'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L370-L379'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#ruleappend'>
+ <code>
+ append
+ <span class='gray'>(children)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts new nodes to the end of the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>children</code></td>
+ <td class='col-3 quiet'>
+ ...(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New nodes.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> decl1 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+<span class="hljs-keyword">const</span> decl2 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'background-color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'white'</span> })
+rule.append(decl1, decl2)
+
+root.append({ <span class="hljs-attr">name</span>: <span class="hljs-string">'charset'</span>, <span class="hljs-attr">params</span>: <span class="hljs-string">'"UTF-8"'</span> }) <span class="hljs-comment">// at-rule</span>
+root.append({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }) <span class="hljs-comment">// rule</span>
+rule.append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> }) <span class="hljs-comment">// declaration</span>
+rule.append({ <span class="hljs-attr">text</span>: <span class="hljs-string">'Comment'</span> }) <span class="hljs-comment">// comment</span>
+
+root.append(<span class="hljs-string">'a {}'</span>)
+root.first.append(<span class="hljs-string">'color: black; z-index: 1'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='ruleeach'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L76-L102'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#ruleeach'>
+ <code>
+ each
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Iterates through the container’s immediate children,
+calling <code>callback</code> for each child.</p>
+<p>Returning <code>false</code> in the callback will break iteration.</p>
+<p>This method only iterates through the container’s immediate children.
+If you need to recursively iterate through all the container’s descendant
+nodes, use <a href="#containerwalk">Container#walk</a>.</p>
+<p>Unlike the for <code>{}</code>-cycle or <code>Array#forEach</code> this iterator is safe
+if you are mutating the array of child nodes during iteration.
+PostCSS will adjust the current index to match the mutations.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a { color: black; z-index: 1 }'</span>)
+<span class="hljs-keyword">const</span> rule = root.first
+
+<span class="hljs-keyword">for</span> (<span class="hljs-keyword">const</span> decl <span class="hljs-keyword">of</span> rule.nodes) {
+ decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop })
+ <span class="hljs-comment">// Cycle will be infinite, because cloneBefore moves the current node</span>
+ <span class="hljs-comment">// to the next index</span>
+}
+
+rule.each(<span class="hljs-function"><span class="hljs-params">decl</span> =&gt;</span> {
+ decl.cloneBefore({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop })
+ <span class="hljs-comment">// Will be executed only for color and z-index</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='ruleevery'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L587-L589'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#ruleevery'>
+ <code>
+ every
+ <span class='gray'>(condition)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns <code>true</code> if callback returns <code>true</code>
+for all of the container’s children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>condition</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childcondition">childCondition</a>
+
+ </td>
+ <td class='col-6'>Iterator returns true or false.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a></code>
+ :
+ <span class='force-inline'>Is every child pass condition.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> noPrefixes = rule.every(<span class="hljs-function"><span class="hljs-params">i</span> =&gt;</span> i.prop[<span class="hljs-number">0</span>] !== <span class="hljs-string">'-'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rulefirst'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L631-L634'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rulefirst'>
+ <code>
+ first
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The container’s first child.</p>
+
+
+ <p>
+ Type:
+ <a href="#node">Node</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.first === rules.nodes[<span class="hljs-number">0</span>]</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='ruleindex'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L616-L621'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#ruleindex'>
+ <code>
+ index
+ <span class='gray'>(child)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a <code>child</code>’s index within the <a href="Container#nodes">Container#nodes</a> array.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>child</code></td>
+ <td class='col-3 quiet'>
+ <a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Child of the current container.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a></code>
+ :
+ <span class='force-inline'>Child index.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.index( rule.nodes[<span class="hljs-number">2</span>] ) <span class="hljs-comment">//=&gt; 2</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='ruleinsertafter'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L462-L479'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#ruleinsertafter'>
+ <code>
+ insertAfter
+ <span class='gray'>(exist, add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node after old node within the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>exist</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='ruleinsertbefore'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L434-L452'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#ruleinsertbefore'>
+ <code>
+ insertBefore
+ <span class='gray'>(exist, add)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Insert new node before old node within the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>exist</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>add</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.insertBefore(decl, decl.clone({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'-webkit-'</span> + decl.prop }))</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rulelast'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L644-L647'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rulelast'>
+ <code>
+ last
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The container’s last child.</p>
+
+
+ <p>
+ Type:
+ <a href="#node">Node</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.last === rule.nodes[rule.nodes.length - <span class="hljs-number">1</span>]</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='ruleprepend'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L401-L414'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#ruleprepend'>
+ <code>
+ prepend
+ <span class='gray'>(children)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Inserts new nodes to the start of the container.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>children</code></td>
+ <td class='col-3 quiet'>
+ ...(<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>)
+
+ </td>
+ <td class='col-6'>New nodes.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> decl1 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> })
+<span class="hljs-keyword">const</span> decl2 = postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'background-color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'white'</span> })
+rule.prepend(decl1, decl2)
+
+root.append({ <span class="hljs-attr">name</span>: <span class="hljs-string">'charset'</span>, <span class="hljs-attr">params</span>: <span class="hljs-string">'"UTF-8"'</span> }) <span class="hljs-comment">// at-rule</span>
+root.append({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }) <span class="hljs-comment">// rule</span>
+rule.append({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'black'</span> }) <span class="hljs-comment">// declaration</span>
+rule.append({ <span class="hljs-attr">text</span>: <span class="hljs-string">'Comment'</span> }) <span class="hljs-comment">// comment</span>
+
+root.append(<span class="hljs-string">'a {}'</span>)
+root.first.append(<span class="hljs-string">'color: black; z-index: 1'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='ruleremoveall'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L523-L530'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#ruleremoveall'>
+ <code>
+ removeAll
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes all children from the container
+and cleans their parent properties.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.removeAll()
+rule.nodes.length <span class="hljs-comment">//=&gt; 0</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='ruleremovechild'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L495-L511'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#ruleremovechild'>
+ <code>
+ removeChild
+ <span class='gray'>(child)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Removes node from the container and cleans the parent properties
+from the node and its children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>child</code></td>
+ <td class='col-3 quiet'>
+ (<a href="#node">Node</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>)
+
+ </td>
+ <td class='col-6'>Child or child’s index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>rule.nodes.length <span class="hljs-comment">//=&gt; 5</span>
+rule.removeChild(decl)
+rule.nodes.length <span class="hljs-comment">//=&gt; 4</span>
+decl.parent <span class="hljs-comment">//=&gt; undefined</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rulereplacevalues'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L558-L574'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rulereplacevalues'>
+ <code>
+ replaceValues
+ <span class='gray'>(pattern, opts, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Passes all declaration values within the container that match pattern
+through callback, replacing those values with the returned result
+of callback.</p>
+<p>This method is useful if you are using a custom unit or function
+and need to iterate through all values.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>pattern</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)
+
+ </td>
+ <td class='col-6'>Replace pattern.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+
+ </td>
+ <td class='col-6'>Options to speed up the search.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>opts.props</td>
+ <td class="col-2 quiet">
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>>)
+
+ </td>
+ <td class='col-8'>An array of property names.
+</td>
+</tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>opts.fast</td>
+ <td class="col-2 quiet">
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>String that’s used to narrow down
+values and speed up the regexp search.
+</td>
+</tr>
+
+
+
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">function</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>)
+
+ </td>
+ <td class='col-6'>String to replace pattern or callback
+that returns a new value. The callback
+will receive the same arguments
+as those passed to a function parameter
+of
+<code>String#replace</code>
+.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#node">Node</a></code>
+ :
+ <span class='force-inline'>This node for methods chain.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.replaceValues(<span class="hljs-regexp">/\d+rem/</span>, { <span class="hljs-attr">fast</span>: <span class="hljs-string">'rem'</span> }, string =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-number">15</span> * <span class="hljs-built_in">parseInt</span>(string) + <span class="hljs-string">'px'</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='ruleselectors'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/rule.js#L41-L43'>
+ <span>lib/rule.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#ruleselectors'>
+ <code>
+ selectors
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>An array containing the rule’s individual selectors.
+Groups of selectors are split at commas.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> root = postcss.parse(<span class="hljs-string">'a, b { }'</span>)
+<span class="hljs-keyword">const</span> rule = root.first
+
+rule.selector <span class="hljs-comment">//=&gt; 'a, b'</span>
+rule.selectors <span class="hljs-comment">//=&gt; ['a', 'b']</span>
+
+rule.selectors = [<span class="hljs-string">'a'</span>, <span class="hljs-string">'strong'</span>]
+rule.selector <span class="hljs-comment">//=&gt; 'a, strong'</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rulesome'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L602-L604'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rulesome'>
+ <code>
+ some
+ <span class='gray'>(condition)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns <code>true</code> if callback returns <code>true</code> for (at least) one
+of the container’s children.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>condition</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childcondition">childCondition</a>
+
+ </td>
+ <td class='col-6'>Iterator returns true or false.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a></code>
+ :
+ <span class='force-inline'>Is some child pass condition.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> hasPrefix = rule.some(<span class="hljs-function"><span class="hljs-params">i</span> =&gt;</span> i.prop[<span class="hljs-number">0</span>] === <span class="hljs-string">'-'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rulewalk'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L123-L137'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rulewalk'>
+ <code>
+ walk
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each node.</p>
+<p>Like container.each(), this method is safe to use
+if you are mutating arrays during iteration.</p>
+<p>If you only need to iterate through the container’s immediate children,
+use <a href="#containereach">Container#each</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walk(<span class="hljs-function"><span class="hljs-params">node</span> =&gt;</span> {
+ <span class="hljs-comment">// Traverses all descendant nodes.</span>
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rulewalkatrules'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L303-L324'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rulewalkatrules'>
+ <code>
+ walkAtRules
+ <span class='gray'>(name?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each at-rule node.</p>
+<p>If you pass a filter, iteration will only happen over at-rules
+that have matching names.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>name</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter at-rules by name.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkAtRules(<span class="hljs-function"><span class="hljs-params">rule</span> =&gt;</span> {
+ <span class="hljs-keyword">if</span> (isOld(rule.name)) rule.remove()
+})
+
+<span class="hljs-keyword">let</span> first = <span class="hljs-literal">false</span>
+root.walkAtRules(<span class="hljs-string">'charset'</span>, rule =&gt; {
+ <span class="hljs-keyword">if</span> (!first) {
+ first = <span class="hljs-literal">true</span>
+ } <span class="hljs-keyword">else</span> {
+ rule.remove()
+ }
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rulewalkcomments'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L342-L348'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rulewalkcomments'>
+ <code>
+ walkComments
+ <span class='gray'>(callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each comment node.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkComments(<span class="hljs-function"><span class="hljs-params">comment</span> =&gt;</span> {
+ comment.remove()
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rulewalkdecls'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L203-L224'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rulewalkdecls'>
+ <code>
+ walkDecls
+ <span class='gray'>(prop?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each declaration node.</p>
+<p>If you pass a filter, iteration will only happen over declarations
+with matching properties.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>prop</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter declarations by property name.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>root.walkDecls(<span class="hljs-function"><span class="hljs-params">decl</span> =&gt;</span> {
+ checkPropertySupport(decl.prop)
+})
+
+root.walkDecls(<span class="hljs-string">'border-radius'</span>, decl =&gt; {
+ decl.remove()
+})
+
+root.walkDecls(<span class="hljs-regexp">/^background/</span>, decl =&gt; {
+ decl.value = takeFirstColorFromGradient(decl.value)
+})</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='rulewalkrules'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L249-L271'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#rulewalkrules'>
+ <code>
+ walkRules
+ <span class='gray'>(selector?, callback)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Traverses the container’s descendant nodes, calling callback
+for each rule node.</p>
+<p>If you pass a filter, iteration will only happen over rules
+with matching selectors.</p>
+<p>Like <a href="#containereach">Container#each</a>, this method is safe
+to use if you are mutating arrays during iteration.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>selector</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/RegExp">RegExp</a>)?
+
+ </td>
+ <td class='col-6'>String or regular expression
+to filter rules by selector.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>callback</code></td>
+ <td class='col-3 quiet'>
+ <a href="#childiterator">childIterator</a>
+
+ </td>
+ <td class='col-6'>Iterator receives each node and index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>returns
+<code>false</code>
+ if iteration was broke.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> selectors = []
+root.walkRules(<span class="hljs-function"><span class="hljs-params">rule</span> =&gt;</span> {
+ selectors.push(rule.selector)
+})
+<span class="hljs-built_in">console</span>.log(<span class="hljs-string">`Your CSS uses <span class="hljs-subst">${ selectors.length }</span> selectors`</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='warning'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/warning.js#L9-L107'>
+ <span>lib/warning.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#warning'>
+ <code>
+ Warning
+ <span class='gray'>(text, opts = {})</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Represents a plugin’s warning. It can be created using <a href="#nodewarn">Node#warn</a>.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>text</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Warning message.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">Object</a>?
+
+ = <code>{}</code>
+ </td>
+ <td class='col-6'>Warning options.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">if</span> (decl.important) {
+ decl.warn(result, <span class="hljs-string">'Avoid !important'</span>, { <span class="hljs-attr">word</span>: <span class="hljs-string">'!important'</span> })
+}</code></pre>
+
+
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Instance Members</h4>
+ <div class="section-indent">
+
+ <section id='warningtype'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/warning.js#L31-L31'>
+ <span>lib/warning.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#warningtype'>
+ <code>
+ type
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Type to filter warnings from <a href="#resultmessages">Result#messages</a>.
+Always equal to <code>"warning"</code>.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> nonWarning = result.messages.filter(<span class="hljs-function"><span class="hljs-params">i</span> =&gt;</span> i.type !== <span class="hljs-string">'warning'</span>)</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='warningtext'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/warning.js#L40-L40'>
+ <span>lib/warning.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#warningtext'>
+ <code>
+ text
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>The warning message.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>warning.text <span class="hljs-comment">//=&gt; 'Try to avoid !important'</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='warningline'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/warning.js#L51-L51'>
+ <span>lib/warning.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#warningline'>
+ <code>
+ line
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Line in the input file with this warning’s source.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>warning.line <span class="hljs-comment">//=&gt; 5</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='warningcolumn'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/warning.js#L60-L60'>
+ <span>lib/warning.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#warningcolumn'>
+ <code>
+ column
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Column in the input file with this warning’s source.</p>
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>warning.column <span class="hljs-comment">//=&gt; 6</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='warningtostring'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/warning.js#L74-L88'>
+ <span>lib/warning.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#warningtostring'>
+ <code>
+ toString
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns a warning position and message.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>Warning position and message.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>warning.toString() <span class="hljs-comment">//=&gt; 'postcss-lint:a.css:10:14: Avoid !important'</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+</section>
+
+
+
+
+ <div class='hide'>
+ <section class='py2 clearfix'>
+
+ <h2 id='namespaces' class='mt0'>
+ NAMESPACES
+ </h2>
+
+
+
+
+
+ </section>
+</div>
+
+
+
+ <section id='list'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/list.js#L10-L87'>
+ <span>lib/list.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#list'>
+ <code>
+ list
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Contains helpers for safely splitting lists of CSS values,
+preserving parentheses and quotes.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> list = postcss.list</code></pre>
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Static Members</h4>
+ <div class="section-indent">
+
+ <section id='listspace'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/list.js#L66-L69'>
+ <span>lib/list.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#listspace'>
+ <code>
+ space
+ <span class='gray'>(string)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Safely splits space-separated values (such as those for <code>background</code>,
+<code>border-radius</code>, and other shorthand properties).</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>string</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Space-separated values.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>></code>
+ :
+ <span class='force-inline'>Split values.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.list.space(<span class="hljs-string">'1px calc(10% + 1px)'</span>) <span class="hljs-comment">//=&gt; ['1px', 'calc(10% + 1px)']</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='listcomma'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/list.js#L83-L85'>
+ <span>lib/list.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#listcomma'>
+ <code>
+ comma
+ <span class='gray'>(string)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Safely splits comma-separated values (such as those for <code>transition-*</code>
+and <code>background</code> properties).</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>string</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Comma-separated values.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>></code>
+ :
+ <span class='force-inline'>Split values.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.list.comma(<span class="hljs-string">'black, linear-gradient(white, black)'</span>)
+<span class="hljs-comment">//=&gt; ['black', 'linear-gradient(white, black)']</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='postcss'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/postcss.js#L30-L35'>
+ <span>lib/postcss.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#postcss'>
+ <code>
+ postcss
+ <span class='gray'>(plugins)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Create a new <a href="#processor">Processor</a> instance that will apply <code>plugins</code>
+as CSS processors.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>plugins</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;(<a href="#plugin">Plugin</a> | <a href="#pluginfunction">pluginFunction</a>)> | <a href="#processor">Processor</a>)
+
+ </td>
+ <td class='col-6'>PostCSS plugins.
+See
+<a href="#processoruse">Processor#use</a>
+ for plugin format.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#processor">Processor</a></code>
+ :
+ <span class='force-inline'>Processor to process multiple CSS.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">let</span> postcss = <span class="hljs-built_in">require</span>(<span class="hljs-string">'postcss'</span>)
+
+postcss(plugins).process(css, { <span class="hljs-keyword">from</span>, to }).then(<span class="hljs-function"><span class="hljs-params">result</span> =&gt;</span> {
+ <span class="hljs-built_in">console</span>.log(result.css)
+})</code></pre>
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Static Members</h4>
+ <div class="section-indent">
+
+ <section id='postcssplugin'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/postcss.js#L109-L130'>
+ <span>lib/postcss.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#postcssplugin'>
+ <code>
+ plugin
+ <span class='gray'>(name, initializer)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Creates a PostCSS plugin with a standard API.</p>
+<p>The newly-wrapped function will provide both the name and PostCSS
+version of the plugin.</p>
+<pre class='hljs'><span class="hljs-keyword">const</span> processor = postcss([replace])
+processor.plugins[<span class="hljs-number">0</span>].postcssPlugin <span class="hljs-comment">//=&gt; 'postcss-replace'</span>
+processor.plugins[<span class="hljs-number">0</span>].postcssVersion <span class="hljs-comment">//=&gt; '6.0.0'</span></pre>
+<p>The plugin function receives 2 arguments: <a href="#root">Root</a>
+and <a href="#result">Result</a> instance. The function should mutate the provided
+<code>Root</code> node. Alternatively, you can create a new <code>Root</code> node
+and override the <code>result.root</code> property.</p>
+<pre class='hljs'><span class="hljs-keyword">const</span> cleaner = postcss.plugin(<span class="hljs-string">'postcss-cleaner'</span>, () =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-function">(<span class="hljs-params">root, result</span>) =&gt;</span> {
+ result.root = postcss.root()
+ }
+})</pre>
+<p>As a convenience, plugins also expose a <code>process</code> method so that you can use
+them as standalone tools.</p>
+<pre class='hljs'>cleaner.process(css, processOpts, pluginOpts)
+<span class="hljs-comment">// This is equivalent to:</span>
+postcss([ cleaner(pluginOpts) ]).process(css, processOpts)</pre>
+<p>Asynchronous plugins should return a <code>Promise</code> instance.</p>
+<pre class='hljs'>postcss.plugin(<span class="hljs-string">'postcss-import'</span>, () =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-function">(<span class="hljs-params">root, result</span>) =&gt;</span> {
+ <span class="hljs-keyword">return</span> <span class="hljs-keyword">new</span> <span class="hljs-built_in">Promise</span>( <span class="hljs-function">(<span class="hljs-params">resolve, reject</span>) =&gt;</span> {
+ fs.readFile(<span class="hljs-string">'base.css'</span>, (base) =&gt; {
+ root.prepend(base)
+ resolve()
+ })
+ })
+ }
+})</pre>
+<p>Add warnings using the <a href="#nodewarn">Node#warn</a> method.
+Send data to other plugins using the <a href="#resultmessages">Result#messages</a> array.</p>
+<pre class='hljs'>postcss.plugin(<span class="hljs-string">'postcss-caniuse-test'</span>, () =&gt; {
+ <span class="hljs-keyword">return</span> <span class="hljs-function">(<span class="hljs-params">root, result</span>) =&gt;</span> {
+ root.walkDecls(<span class="hljs-function"><span class="hljs-params">decl</span> =&gt;</span> {
+ <span class="hljs-keyword">if</span> (!caniuse.support(decl.prop)) {
+ decl.warn(result, <span class="hljs-string">'Some browsers do not support '</span> + decl.prop)
+ }
+ })
+ }
+})</pre>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>name</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>PostCSS plugin name. Same as in
+<code>name</code>
+
+property in
+<code>package.json</code>
+. It will be saved
+in
+<code>plugin.postcssPlugin</code>
+ property.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>initializer</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">function</a>
+
+ </td>
+ <td class='col-6'>Will receive plugin options
+and should return
+<a href="#pluginfunction">pluginFunction</a>
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#plugin">Plugin</a></code>
+ :
+ <span class='force-inline'>PostCSS plugin.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='postcssstringify'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/postcss.js#L143-L143'>
+ <span>lib/postcss.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#postcssstringify'>
+ <code>
+ stringify
+ <span class='gray'>(node, builder)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Default function to convert a node tree into a CSS string.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>node</code></td>
+ <td class='col-3 quiet'>
+ <a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Start node for stringifing. Usually
+<a href="#root">Root</a>
+.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>builder</code></td>
+ <td class='col-3 quiet'>
+ <a href="#builder">builder</a>
+
+ </td>
+ <td class='col-6'>Function to concatenate CSS from node’s parts
+or generate string and source map.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>void</code>
+ :
+ <span class='force-inline'>
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='postcssparse'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/postcss.js#L163-L163'>
+ <span>lib/postcss.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#postcssparse'>
+ <code>
+ parse
+ <span class='gray'>(css, opts?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Parses source css and returns a new <a href="#root">Root</a> node,
+which contains the source CSS nodes.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>css</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="#tostring">toString</a>)
+
+ </td>
+ <td class='col-6'>String with input CSS or any object
+with toString() method, like a Buffer
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="#processoptions">processOptions</a>?
+
+ </td>
+ <td class='col-6'>Options with only
+<code>from</code>
+ and
+<code>map</code>
+ keys.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#root">Root</a></code>
+ :
+ <span class='force-inline'>PostCSS AST.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-comment">// Simple CSS concatenation with source map support</span>
+<span class="hljs-keyword">const</span> root1 = postcss.parse(css1, { <span class="hljs-attr">from</span>: file1 })
+<span class="hljs-keyword">const</span> root2 = postcss.parse(css2, { <span class="hljs-attr">from</span>: file2 })
+root1.append(root2).toResult().css</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='postcssvendor'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/postcss.js#L173-L173'>
+ <span>lib/postcss.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#postcssvendor'>
+ <code>
+ vendor
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Contains the <a href="#vendor">vendor</a> module.</p>
+
+
+ <p>
+ Type:
+ <a href="#vendor">vendor</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.vendor.unprefixed(<span class="hljs-string">'-moz-tab'</span>) <span class="hljs-comment">//=&gt; ['tab']</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='postcsslist'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/postcss.js#L183-L183'>
+ <span>lib/postcss.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#postcsslist'>
+ <code>
+ list
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Contains the <a href="#list">list</a> module.</p>
+
+
+ <p>
+ Type:
+ <a href="#list">list</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.list.space(<span class="hljs-string">'5px calc(10% + 5px)'</span>) <span class="hljs-comment">//=&gt; ['5px', 'calc(10% + 5px)']</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='postcsscomment'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/postcss.js#L195-L195'>
+ <span>lib/postcss.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#postcsscomment'>
+ <code>
+ comment
+ <span class='gray'>(defaults?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Creates a new <a href="#comment">Comment</a> node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>defaults</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ </td>
+ <td class='col-6'>Properties for the new node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#comment">Comment</a></code>
+ :
+ <span class='force-inline'>New comment node
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.comment({ <span class="hljs-attr">text</span>: <span class="hljs-string">'test'</span> })</code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='postcssatrule'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/postcss.js#L207-L207'>
+ <span>lib/postcss.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#postcssatrule'>
+ <code>
+ atRule
+ <span class='gray'>(defaults?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Creates a new <a href="#atrule">AtRule</a> node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>defaults</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ </td>
+ <td class='col-6'>Properties for the new node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#atrule">AtRule</a></code>
+ :
+ <span class='force-inline'>new at-rule node
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.atRule({ <span class="hljs-attr">name</span>: <span class="hljs-string">'charset'</span> }).toString() <span class="hljs-comment">//=&gt; "@charset"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='postcssdecl'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/postcss.js#L219-L219'>
+ <span>lib/postcss.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#postcssdecl'>
+ <code>
+ decl
+ <span class='gray'>(defaults?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Creates a new <a href="#declaration">Declaration</a> node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>defaults</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ </td>
+ <td class='col-6'>Properties for the new node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#declaration">Declaration</a></code>
+ :
+ <span class='force-inline'>new declaration node
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.decl({ <span class="hljs-attr">prop</span>: <span class="hljs-string">'color'</span>, <span class="hljs-attr">value</span>: <span class="hljs-string">'red'</span> }).toString() <span class="hljs-comment">//=&gt; "color: red"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='postcssrule'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/postcss.js#L231-L231'>
+ <span>lib/postcss.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#postcssrule'>
+ <code>
+ rule
+ <span class='gray'>(defaults?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Creates a new <a href="#rule">Rule</a> node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>defaults</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ </td>
+ <td class='col-6'>Properties for the new node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#rule">Rule</a></code>
+ :
+ <span class='force-inline'>new rule node
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.rule({ <span class="hljs-attr">selector</span>: <span class="hljs-string">'a'</span> }).toString() <span class="hljs-comment">//=&gt; "a {\n}"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='postcssroot'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/postcss.js#L243-L243'>
+ <span>lib/postcss.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#postcssroot'>
+ <code>
+ root
+ <span class='gray'>(defaults?)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Creates a new <a href="#root">Root</a> node.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>defaults</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>?
+
+ </td>
+ <td class='col-6'>Properties for the new node.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#root">Root</a></code>
+ :
+ <span class='force-inline'>new root node.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.root({ <span class="hljs-attr">after</span>: <span class="hljs-string">'\n'</span> }).toString() <span class="hljs-comment">//=&gt; "\n"</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='vendor'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/vendor.js#L9-L45'>
+ <span>lib/vendor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#vendor'>
+ <code>
+ vendor
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Contains helpers for working with vendor prefixes.</p>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code><span class="hljs-keyword">const</span> vendor = postcss.vendor</code></pre>
+
+
+
+
+ <h4 class='caps quiet mb2 mt3'>Static Members</h4>
+ <div class="section-indent">
+
+ <section id='vendorprefix'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/vendor.js#L22-L29'>
+ <span>lib/vendor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#vendorprefix'>
+ <code>
+ prefix
+ <span class='gray'>(prop)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns the vendor prefix extracted from an input string.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>prop</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>String with or without vendor prefix.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>vendor prefix or empty string
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.vendor.prefix(<span class="hljs-string">'-moz-tab-size'</span>) <span class="hljs-comment">//=&gt; '-moz-'</span>
+postcss.vendor.prefix(<span class="hljs-string">'tab-size'</span>) <span class="hljs-comment">//=&gt; ''</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+ <section id='vendorunprefixed'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/vendor.js#L41-L43'>
+ <span>lib/vendor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#vendorunprefixed'>
+ <code>
+ unprefixed
+ <span class='gray'>(prop)</span>
+ </code>
+ </a>
+ </h3>
+
+ <p>Returns the input string stripped of its vendor prefix.</p>
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>prop</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>String with or without vendor prefix.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a></code>
+ :
+ <span class='force-inline'>String name without vendor prefixes.
+</span>
+
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Examples</h4>
+
+
+ <pre class='p1 overflow-auto round fill-light'><code>postcss.vendor.unprefixed(<span class="hljs-string">'-moz-tab-size'</span>) <span class="hljs-comment">//=&gt; 'tab-size'</span></code></pre>
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+</div>
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <div class='hide'>
+ <section class='py2 clearfix'>
+
+ <h2 id='global' class='mt0'>
+ GLOBAL
+ </h2>
+
+
+
+
+
+ </section>
+</div>
+
+
+
+ <section id='message'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/result.js#L174-L178'>
+ <span>lib/result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#message'>
+ <code>
+ Message
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-2 small caps quiet'>property</th>
+ <th class='col-2 small caps quiet'>type</th>
+ <th class='col-8 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-2 strong'>type</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>: Message type.
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>plugin</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>: Source PostCSS plugin name.
+</td>
+ </tr>
+
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='plugin'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L183-L186'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#plugin'>
+ <code>
+ Plugin
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-2 small caps quiet'>property</th>
+ <th class='col-2 small caps quiet'>type</th>
+ <th class='col-8 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-2 strong'>postcss</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">function</a>
+
+ </td>
+ <td class='col-8'>: PostCSS plugin function.
+</td>
+ </tr>
+
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='builder'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L139-L144'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#builder'>
+ <code>
+ builder
+ <span class='gray'>(part, node, type?)</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">Function</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>part</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-6'>Part of generated CSS connected to this node.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>node</code></td>
+ <td class='col-3 quiet'>
+ <a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>AST node.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>type</code></td>
+ <td class='col-3 quiet'>
+ (<code>"start"</code> | <code>"end"</code>)?
+
+ </td>
+ <td class='col-6'>Node’s part type.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='childcondition'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L712-L718'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#childcondition'>
+ <code>
+ childCondition
+ <span class='gray'>(node, index, nodes)</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">Function</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>node</code></td>
+ <td class='col-3 quiet'>
+ <a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Container child.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>index</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-6'>Child index.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>nodes</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a>&#x3C;<a href="#node">Node</a>>
+
+ </td>
+ <td class='col-6'>All container children.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean">boolean</a></code>
+ :
+ <span class='force-inline'>
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='childiterator'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/container.js#L720-L725'>
+ <span>lib/container.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#childiterator'>
+ <code>
+ childIterator
+ <span class='gray'>(node, index)</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">Function</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>node</code></td>
+ <td class='col-3 quiet'>
+ <a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Container child.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>index</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-6'>Child index.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>(<code>false</code> | <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/undefined">undefined</a>)</code>
+ :
+ <span class='force-inline'>Returning
+<code>false</code>
+ will break iteration.
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='fileposition'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/input.js#L173-L178'>
+ <span>lib/input.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#fileposition'>
+ <code>
+ filePosition
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-2 small caps quiet'>property</th>
+ <th class='col-2 small caps quiet'>type</th>
+ <th class='col-8 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-2 strong'>file</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>: Path to file.
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>line</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>: Source line in file.
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>column</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>: Source column in file.
+</td>
+ </tr>
+
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='onfulfilled'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L421-L424'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#onfulfilled'>
+ <code>
+ onFulfilled
+ <span class='gray'>(result)</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">Function</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>result</code></td>
+ <td class='col-3 quiet'>
+ <a href="#result">Result</a>
+
+ </td>
+ <td class='col-6'></td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='onrejected'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/lazy-result.js#L426-L429'>
+ <span>lib/lazy-result.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#onrejected'>
+ <code>
+ onRejected
+ <span class='gray'>(error)</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">Function</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>error</code></td>
+ <td class='col-3 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Error">Error</a>
+
+ </td>
+ <td class='col-6'></td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='parser'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L146-L154'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#parser'>
+ <code>
+ parser
+ <span class='gray'>(css, opts?)</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">Function</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>css</code></td>
+ <td class='col-3 quiet'>
+ (<a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a> | <a href="#tostring">toString</a>)
+
+ </td>
+ <td class='col-6'>String with input CSS or any object
+with toString() method, like a Buffer.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>opts</code></td>
+ <td class='col-3 quiet'>
+ <a href="#processoptions">processOptions</a>?
+
+ </td>
+ <td class='col-6'>Options with only
+<code>from</code>
+ and
+<code>map</code>
+ keys.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code><a href="#root">Root</a></code>
+ :
+ <span class='force-inline'>PostCSS AST
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='pluginfunction'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L177-L181'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#pluginfunction'>
+ <code>
+ pluginFunction
+ <span class='gray'>(root, result)</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">Function</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>root</code></td>
+ <td class='col-3 quiet'>
+ <a href="#root">Root</a>
+
+ </td>
+ <td class='col-6'>Parsed input CSS.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>result</code></td>
+ <td class='col-3 quiet'>
+ <a href="#result">Result</a>
+
+ </td>
+ <td class='col-6'>Result to set warnings or check other plugins.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='position'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L518-L522'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#position'>
+ <code>
+ position
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-2 small caps quiet'>property</th>
+ <th class='col-2 small caps quiet'>type</th>
+ <th class='col-8 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-2 strong'>line</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>: Source line in file.
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>column</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number">number</a>
+
+ </td>
+ <td class='col-8'>: Source column in file.
+</td>
+ </tr>
+
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='processoptions'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L188-L219'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#processoptions'>
+ <code>
+ processOptions
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-2 small caps quiet'>property</th>
+ <th class='col-2 small caps quiet'>type</th>
+ <th class='col-8 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-2 strong'>from</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>: The path of the CSS source file.
+You should always set
+<code>from</code>
+,
+because it is used in source map
+generation and syntax error messages.
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>to</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String">string</a>
+
+ </td>
+ <td class='col-8'>: The path where you’ll put the output
+CSS file. You should always set
+<code>to</code>
+
+to generate correct source maps.
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>parser</td>
+ <td class='col-2 quiet'>
+ <a href="#parser">parser</a>
+
+ </td>
+ <td class='col-8'>: Function to generate AST by string.
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>stringifier</td>
+ <td class='col-2 quiet'>
+ <a href="#stringifier">stringifier</a>
+
+ </td>
+ <td class='col-8'>: Class to generate string by AST.
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>syntax</td>
+ <td class='col-2 quiet'>
+ <a href="#syntax">syntax</a>
+
+ </td>
+ <td class='col-8'>: Object with
+<code>parse</code>
+ and
+<code>stringify</code>
+.
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>map</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+
+ </td>
+ <td class='col-8'>: Source map options.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-2 strong'>map</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+
+ </td>
+ <td class='col-8'>: Source map options.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='source'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/node.js#L524-L529'>
+ <span>lib/node.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#source'>
+ <code>
+ source
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-2 small caps quiet'>property</th>
+ <th class='col-2 small caps quiet'>type</th>
+ <th class='col-8 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-2 strong'>input</td>
+ <td class='col-2 quiet'>
+ <a href="#input">Input</a>
+
+ </td>
+ <td class='col-8'>: <a href="#input">Input</a>
+ with input file
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>start</td>
+ <td class='col-2 quiet'>
+ <a href="#position">position</a>
+
+ </td>
+ <td class='col-8'>: The starting position of the node’s source.
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>end</td>
+ <td class='col-2 quiet'>
+ <a href="#position">position</a>
+
+ </td>
+ <td class='col-8'>: The ending position of the node’s source.
+</td>
+ </tr>
+
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='stringifier'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L156-L164'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#stringifier'>
+ <code>
+ stringifier
+ <span class='gray'>(node, builder)</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">Function</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-3 small caps quiet'>parameter</th>
+ <th class='col-3 small caps quiet'>type</th>
+ <th class='col-6 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-3 strong'><code>node</code></td>
+ <td class='col-3 quiet'>
+ <a href="#node">Node</a>
+
+ </td>
+ <td class='col-6'>Start node for stringifing. Usually
+<a href="#root">Root</a>
+.
+</td>
+ </tr>
+
+
+ <tr>
+ <td class='col-3 strong'><code>builder</code></td>
+ <td class='col-3 quiet'>
+ <a href="#builder">builder</a>
+
+ </td>
+ <td class='col-6'>Function to concatenate CSS from node’s parts
+or generate string and source map.
+</td>
+ </tr>
+
+
+ </table>
+
+
+
+
+
+
+ <h4 class='caps quiet mb1 mt3'>Returns</h4>
+ <code>void</code>
+ :
+ <span class='force-inline'>
+</span>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='syntax'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L166-L170'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#syntax'>
+ <code>
+ syntax
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-2 small caps quiet'>property</th>
+ <th class='col-2 small caps quiet'>type</th>
+ <th class='col-8 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-2 strong'>parse</td>
+ <td class='col-2 quiet'>
+ <a href="#parser">parser</a>
+
+ </td>
+ <td class='col-8'>: Function to generate AST by string.
+</td>
+ </tr>
+
+
+
+ <tr>
+ <td class='col-2 strong'>stringify</td>
+ <td class='col-2 quiet'>
+ <a href="#stringifier">stringifier</a>
+
+ </td>
+ <td class='col-8'>: Function to generate string by AST.
+</td>
+ </tr>
+
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+
+ <section id='tostring'class='mt2 mb2 px3 py1 keyline-top'>
+
+ <div class='right py2'>
+
+
+ <span class="px2"></span>
+ <a class='fr fill-darken0 round round pad1x quiet h5' href='https://git@github.com/:postcss/postcss/blob/ca2aebad42a24508d6de0a2a6a760fd18c5b8648/lib/processor.js#L172-L175'>
+ <span>lib/processor.js</span>
+ </a>
+
+ </div>
+
+ <h3 class='regular'>
+ <a class='black' href='#tostring'>
+ <code>
+ toString
+ <span class='gray'>()</span>
+ </code>
+ </a>
+ </h3>
+
+
+
+ <p>
+ Type:
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object">object</a>
+ </p>
+
+
+
+
+
+
+
+
+
+
+
+
+ <table class='table-light mt3 rounded keyline-all keyline-light overflow-hidden bg-cloudy-light'>
+ <thead class='fill-light'>
+ <th class='col-2 small caps quiet'>property</th>
+ <th class='col-2 small caps quiet'>type</th>
+ <th class='col-8 small caps quiet'>description</th>
+ </thead>
+
+ <tr>
+ <td class='col-2 strong'>toString</td>
+ <td class='col-2 quiet'>
+ <a href="https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function">function</a>
+
+ </td>
+ <td class='col-8'></td>
+ </tr>
+
+
+
+ </table>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</section>
+
+
+
+ </div>
+ </div>
+ </div>
+</div>
+<script src='assets/scripts.min.js'></script>
+</body>
+</html>
diff --git a/node_modules/autoprefixer/node_modules/postcss/docs/architecture.md b/node_modules/autoprefixer/node_modules/postcss/docs/architecture.md
new file mode 100644
index 0000000..266cd39
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/docs/architecture.md
@@ -0,0 +1,156 @@
+## PostCSS Architecture
+
+General overview of the PostCSS architecture.
+It can be useful for everyone who wishes to contribute to the core or develop a better understanding of the tool.
+
+**Table of Contents**
+
+- [Overview](#overview)
+- [Workflow](#workflow)
+- [Core Structures](#core-structures)
+ * [Tokenizer](#tokenizer--libtokenizees6-)
+ * [Parser](#parser--libparsees6-libparseres6-)
+ * [Processor](#processor--libprocessores6-)
+ * [Stringifier](#stringifier--libstringifyes6-libstringifieres6-)
+- [API](#api-reference)
+
+### Overview
+
+> This section describes ideas lying behind PostCSS
+
+Before diving deeper into the development of PostCSS let's briefly describe what is PostCSS and what is not.
+
+**PostCSS**
+
+- *is **NOT** a style preprocessor like `Sass` or `Less`.*
+
+ It does not define a custom syntax and semantics, it's not actually a language.
+ PostCSS works with CSS and can be easily integrated with the tools described above. That being said any valid CSS can be processed by PostCSS.
+
+- *is a tool for CSS syntax transformations*
+
+ It allows you to define custom CSS like syntax that could be understandable and transformed by plugins. That being said PostCSS is not strictly about CSS spec but about syntax definition manner of CSS. In such a way you can define custom syntax constructs like at-rule, that could be very helpful for tools build around PostCSS. PostCSS plays the role of a framework for building outstanding tools for CSS manipulations.
+
+- *is a big player in CSS ecosystem*
+
+ A Large amount of lovely tools like `Autoprefixer`, `Stylelint`, `CSSnano` were built on PostCSS ecosystem. There is a big chance that you already use it implicitly, just check your `node_modules` :smiley:
+
+### Workflow
+
+This is a high-level overview of the whole PostCSS workflow
+
+<img width="300" src="https://upload.wikimedia.org/wikipedia/commons/thumb/a/aa/PostCSS_scheme.svg/512px-PostCSS_scheme.svg.png" alt="workflow">
+
+As you can see from the diagram above, PostCSS architecture is pretty straightforward but some parts of it could be misunderstood.
+
+You can see a part called *Parser*, this construct will be described in details later on, just for now think about it as a structure that can understand your CSS like syntax and create an object representation of it.
+
+That being said, there are few ways to write a parser.
+
+ - *Write a single file with string to AST transformation*
+
+ This method is quite popular, for example, the [Rework analyzer](https://github.com/reworkcss/css/blob/master/lib/parse/index.js) was written in this style. But with a large code base, the code becomes hard to read and pretty slow.
+
+ - *Split it into lexical analysis/parsing steps (source string → tokens → AST)*
+
+ This is the way of how we do it in PostCSS and also the most popular one.
+ A lot of parsers like [`@babel/parser` (parser behind Babel)](https://github.com/babel/babel/tree/master/packages/babel-parser), [`CSSTree`](https://github.com/csstree/csstree) were written in such way.
+ The main reasons to separate tokenization from parsing steps are performance and abstracting complexity.
+
+Let think about why the second way is better for our needs.
+
+First of all, because string to tokens step takes more time than parsing step. We operate on large source string and process it char by char, this is why it is very inefficient operation in terms of performance and we should perform it only once.
+
+But from other side tokens to AST transformation is logically more complex so with such separation we could write very fast tokenizer (but from this comes sometimes hard to read code) and easy to read (but slow) parser.
+
+Summing it up splitting into two steps improve performance and code readability.
+
+So now let's look more closely on structures that play the main role in PostCSS workflow.
+
+### Core Structures
+
+ - #### Tokenizer ( [lib/tokenize.es6](https://github.com/postcss/postcss/blob/master/lib/tokenize.es6) )
+
+ Tokenizer (aka Lexer) plays important role in syntax analysis.
+
+ It accepts CSS string and returns a list of tokens.
+
+ Token is a simple structure that describes some part of syntax like `at-rule`, `comment` or `word`. It can also contain positional information for more descriptive errors.
+
+ For example, if we consider following CSS
+
+ ```css
+ .className { color: #FFF; }
+ ```
+
+ corresponding tokens from PostCSS will be
+ ```js
+ [
+ ["word", ".className", 1, 1, 1, 10]
+ ["space", " "]
+ ["{", "{", 1, 12]
+ ["space", " "]
+ ["word", "color", 1, 14, 1, 18]
+ [":", ":", 1, 19]
+ ["space", " "]
+ ["word", "#FFF" , 1, 21, 1, 23]
+ [";", ";", 1, 24]
+ ["space", " "]
+ ["}", "}", 1, 26]
+ ]
+ ```
+
+ As you can see from the example above a single token represented as a list and also `space` token doesn't have positional information.
+
+ Let's look more closely on single token like `word`. As it was said each token represented as a list and follow such pattern.
+
+ ```js
+ const token = [
+ // represents token type
+ 'word',
+
+ // represents matched word
+ '.className',
+
+ // This two numbers represent start position of token.
+ // It is optional value as we saw in the example above,
+ // tokens like `space` don't have such information.
+
+ // Here the first number is line number and the second one is corresponding column.
+ 1, 1,
+
+ // Next two numbers also optional and represent end position for multichar tokens like this one. Numbers follow same rule as was described above
+ 1, 10
+ ]
+ ```
+ There are many patterns how tokenization could be done, PostCSS motto is performance and simplicity. Tokenization is a complex computing operation and takes a large amount of syntax analysis time ( ~90% ), that why PostCSS' Tokenizer looks dirty but it was optimized for speed. Any high-level constructs like classes could dramatically slow down tokenizer.
+
+ PostCSS' Tokenizer uses some sort of streaming/chaining API where you expose [`nextToken()`](https://github.com/postcss/postcss/blob/master/lib/tokenize.es6#L48-L308) method to Parser. In this manner, we provide a clean interface for Parser and reduce memory usage by storing only a few tokens and not the whole list of tokens.
+
+- #### Parser ( [lib/parse.es6](https://github.com/postcss/postcss/blob/master/lib/parse.es6), [lib/parser.es6](https://github.com/postcss/postcss/blob/master/lib/parser.es6) )
+
+ Parser is the main structure responsible for [syntax analysis](https://en.wikipedia.org/wiki/Parsing) of incoming CSS. Parser produces a structure called [Abstract Syntax Tree (AST)](https://en.wikipedia.org/wiki/Abstract_syntax_tree) that could then be transformed by plugins later on.
+
+ Parser works in common with Tokenizer and operates over tokens, not source string, as it would be a very inefficient operation.
+
+ It uses mostly `nextToken` and `back` methods provided by Tokenizer for obtaining single or multiple tokens and then construct part of AST called `Node`.
+
+ There are multiple Node types that PostCSS could produce but all of them inherit from base Node [class](https://github.com/postcss/postcss/blob/master/lib/node.es6#L34).
+
+- #### Processor ( [lib/processor.es6](https://github.com/postcss/postcss/blob/master/lib/processor.es6) )
+
+ Processor is a very plain structure that initializes plugins and runs syntax transformations. Plugin is just a function registered with [postcss.plugin](https://github.com/postcss/postcss/blob/master/lib/postcss.es6#L109) call.
+
+ It exposes only a few public API methods. Description of them could be found on [api.postcss.org/Processor](http://api.postcss.org/Processor.html)
+
+- #### Stringifier ( [lib/stringify.es6](https://github.com/postcss/postcss/blob/master/lib/stringify.es6), [lib/stringifier.es6](https://github.com/postcss/postcss/blob/master/lib/stringifier.es6) )
+
+ Stringifier is a base class that translates modified AST to pure CSS string. Stringifier traverses AST starting from provided Node and generates a raw string representation of it calling corresponding methods.
+
+ The most essential method is [`Stringifier.stringify`](https://github.com/postcss/postcss/blob/master/lib/stringifier.es6#L25-L27)
+ that accepts initial Node and semicolon indicator.
+ You can learn more by checking [stringifier.es6](https://github.com/postcss/postcss/blob/master/lib/stringifier.es6)
+
+### API Reference
+
+More descriptive API documentation could be found [here](http://api.postcss.org/)
diff --git a/node_modules/autoprefixer/node_modules/postcss/docs/guidelines/plugin.md b/node_modules/autoprefixer/node_modules/postcss/docs/guidelines/plugin.md
new file mode 100644
index 0000000..52fdcf3
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/docs/guidelines/plugin.md
@@ -0,0 +1,195 @@
+# PostCSS Plugin Guidelines
+
+A PostCSS plugin is a function that receives and, usually,
+transforms a CSS AST from the PostCSS parser.
+
+The rules below are *mandatory* for all PostCSS plugins.
+
+See also [ClojureWerkz’s recommendations] for open source projects.
+
+[ClojureWerkz’s recommendations]: http://blog.clojurewerkz.org/blog/2013/04/20/how-to-make-your-open-source-project-really-awesome/
+
+## 1. API
+
+### 1.1 Clear name with `postcss-` prefix
+
+The plugin’s purpose should be clear just by reading its name.
+If you wrote a transpiler for CSS 4 Custom Media, `postcss-custom-media`
+would be a good name. If you wrote a plugin to support mixins,
+`postcss-mixins` would be a good name.
+
+The prefix `postcss-` shows that the plugin is part of the PostCSS ecosystem.
+
+This rule is not mandatory for plugins that can run as independent tools,
+without the user necessarily knowing that it is powered by
+PostCSS — for example, [RTLCSS] and [Autoprefixer].
+
+[Autoprefixer]: https://github.com/postcss/autoprefixer
+[RTLCSS]: https://rtlcss.com/
+
+### 1.2. Do one thing, and do it well
+
+Do not create multitool plugins. Several small, one-purpose plugins bundled into
+a plugin pack is usually a better solution.
+
+For example, [`postcss-preset-env`] contains many small plugins,
+one for each W3C specification. And [`cssnano`] contains a separate plugin
+for each of its optimization.
+
+[`postcss-preset-env`]: https://preset-env.cssdb.org/
+[`cssnano`]: https://github.com/ben-eb/cssnano
+
+### 1.3. Do not use mixins
+
+Preprocessors libraries like Compass provide an API with mixins.
+
+PostCSS plugins are different.
+A plugin cannot be just a set of mixins for [`postcss-mixins`].
+
+To achieve your goal, consider transforming valid CSS
+or using custom at-rules and custom properties.
+
+[`postcss-mixins`]: https://github.com/postcss/postcss-mixins
+
+### 1.4. Create plugin by `postcss.plugin`
+
+By wrapping your function in this method,
+you are hooking into a common plugin API:
+
+```js
+module.exports = postcss.plugin('plugin-name', opts => {
+ return (root, result) => {
+ // Plugin code
+ }
+})
+```
+
+## 2. Processing
+
+### 2.1. Plugin must be tested
+
+A CI service like [Travis] is also recommended for testing code in
+different environments. You should test in (at least) Node.js [active LTS](https://github.com/nodejs/LTS) and current stable version.
+
+[Travis]: https://travis-ci.org/
+
+### 2.2. Use asynchronous methods whenever possible
+
+For example, use `fs.writeFile` instead of `fs.writeFileSync`:
+
+```js
+postcss.plugin('plugin-sprite', opts => {
+ return (root, result) => {
+
+ return new Promise((resolve, reject) => {
+ const sprite = makeSprite()
+ fs.writeFile(opts.file, sprite, err => {
+ if (err) return reject(err)
+ resolve()
+ })
+ })
+
+ }
+})
+```
+
+### 2.3. Set `node.source` for new nodes
+
+Every node must have a relevant `source` so PostCSS can generate
+an accurate source map.
+
+So if you add a new declaration based on some existing declaration, you should
+clone the existing declaration in order to save that original `source`.
+
+```js
+if (needPrefix(decl.prop)) {
+ decl.cloneBefore({ prop: '-webkit-' + decl.prop })
+}
+```
+
+You can also set `source` directly, copying from some existing node:
+
+```js
+if (decl.prop === 'animation') {
+ const keyframe = createAnimationByName(decl.value)
+ keyframes.source = decl.source
+ decl.root().append(keyframes)
+}
+```
+
+### 2.4. Use only the public PostCSS API
+
+PostCSS plugins must not rely on undocumented properties or methods,
+which may be subject to change in any minor release. The public API
+is described in [API docs].
+
+[API docs]: http://api.postcss.org/
+
+## 3. Errors
+
+### 3.1. Use `node.error` on CSS relevant errors
+
+If you have an error because of input CSS (like an unknown name
+in a mixin plugin) you should use `node.error` to create an error
+that includes source position:
+
+```js
+if (typeof mixins[name] === 'undefined') {
+ throw decl.error('Unknown mixin ' + name, { plugin: 'postcss-mixins' })
+}
+```
+
+### 3.2. Use `result.warn` for warnings
+
+Do not print warnings with `console.log` or `console.warn`,
+because some PostCSS runner may not allow console output.
+
+```js
+if (outdated(decl.prop)) {
+ result.warn(decl.prop + ' is outdated', { node: decl })
+}
+```
+
+If CSS input is a source of the warning, the plugin must set the `node` option.
+
+## 4. Documentation
+
+### 4.1. Document your plugin in English
+
+PostCSS plugins must have their `README.md` wrote in English. Do not be afraid
+of your English skills, as the open source community will fix your errors.
+
+Of course, you are welcome to write documentation in other languages;
+just name them appropriately (e.g. `README.ja.md`).
+
+### 4.2. Include input and output examples
+
+The plugin's `README.md` must contain example input and output CSS.
+A clear example is the best way to describe how your plugin works.
+
+The first section of the `README.md` is a good place to put examples.
+See [postcss-opacity](https://github.com/iamvdo/postcss-opacity) for an example.
+
+Of course, this guideline does not apply if your plugin does not
+transform the CSS.
+
+### 4.3. Maintain a changelog
+
+PostCSS plugins must describe the changes of all their releases
+in a separate file, such as `CHANGELOG.md`, `History.md`, or [GitHub Releases].
+Visit [Keep A Changelog] for more information about how to write one of these.
+
+Of course, you should be using [SemVer].
+
+[Keep A Changelog]: http://keepachangelog.com/
+[GitHub Releases]: https://help.github.com/articles/creating-releases/
+[SemVer]: http://semver.org/
+
+### 4.4. Include `postcss-plugin` keyword in `package.json`
+
+PostCSS plugins written for npm must have the `postcss-plugin` keyword
+in their `package.json`. This special keyword will be useful for feedback about
+the PostCSS ecosystem.
+
+For packages not published to npm, this is not mandatory, but is recommended
+if the package format can contain keywords.
diff --git a/node_modules/autoprefixer/node_modules/postcss/docs/guidelines/runner.md b/node_modules/autoprefixer/node_modules/postcss/docs/guidelines/runner.md
new file mode 100644
index 0000000..24de712
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/docs/guidelines/runner.md
@@ -0,0 +1,143 @@
+# PostCSS Runner Guidelines
+
+A PostCSS runner is a tool that processes CSS through a user-defined list
+of plugins; for example, [`postcss-cli`] or [`gulp‑postcss`].
+These rules are mandatory for any such runners.
+
+For single-plugin tools, like [`gulp-autoprefixer`],
+these rules are not mandatory but are highly recommended.
+
+See also [ClojureWerkz’s recommendations] for open source projects.
+
+[ClojureWerkz’s recommendations]: http://blog.clojurewerkz.org/blog/2013/04/20/how-to-make-your-open-source-project-really-awesome/
+[`gulp-autoprefixer`]: https://github.com/sindresorhus/gulp-autoprefixer
+[`gulp‑postcss`]: https://github.com/w0rm/gulp-postcss
+[`postcss-cli`]: https://github.com/postcss/postcss-cli
+
+## 1. API
+
+### 1.1. Accept functions in plugin parameters
+
+If your runner uses a config file, it must be written in JavaScript, so that
+it can support plugins which accept a function, such as [`postcss-assets`]:
+
+```js
+module.exports = [
+ require('postcss-assets')({
+ cachebuster: function (file) {
+ return fs.statSync(file).mtime.getTime().toString(16)
+ }
+ })
+]
+```
+
+[`postcss-assets`]: https://github.com/borodean/postcss-assets
+
+## 2. Processing
+
+### 2.1. Set `from` and `to` processing options
+
+To ensure that PostCSS generates source maps and displays better syntax errors,
+runners must specify the `from` and `to` options. If your runner does not handle
+writing to disk (for example, a gulp transform), you should set both options
+to point to the same file:
+
+```js
+processor.process({ from: file.path, to: file.path })
+```
+
+### 2.2. Use only the asynchronous API
+
+PostCSS runners must use only the asynchronous API.
+The synchronous API is provided only for debugging, is slower,
+and can’t work with asynchronous plugins.
+
+```js
+processor.process(opts).then(result => {
+ // processing is finished
+});
+```
+
+### 2.3. Use only the public PostCSS API
+
+PostCSS runners must not rely on undocumented properties or methods,
+which may be subject to change in any minor release. The public API
+is described in [API docs].
+
+[API docs]: http://api.postcss.org/
+
+## 3. Output
+
+### 3.1. Don’t show JS stack for `CssSyntaxError`
+
+PostCSS runners must not show a stack trace for CSS syntax errors,
+as the runner can be used by developers who are not familiar with JavaScript.
+Instead, handle such errors gracefully:
+
+```js
+processor.process(opts).catch(error => {
+ if (error.name === 'CssSyntaxError') {
+ process.stderr.write(error.message + error.showSourceCode())
+ } else {
+ throw error
+ }
+})
+```
+
+### 3.2. Display `result.warnings()`
+
+PostCSS runners must output warnings from `result.warnings()`:
+
+```js
+result.warnings().forEach(warn => {
+ process.stderr.write(warn.toString())
+})
+```
+
+See also [postcss-log-warnings] and [postcss-messages] plugins.
+
+[postcss-log-warnings]: https://github.com/davidtheclark/postcss-log-warnings
+[postcss-messages]: https://github.com/postcss/postcss-messages
+
+### 3.3. Allow the user to write source maps to different files
+
+PostCSS by default will inline source maps in the generated file; however,
+PostCSS runners must provide an option to save the source map in a different
+file:
+
+```js
+if (result.map) {
+ fs.writeFile(opts.to + '.map', result.map.toString())
+}
+```
+
+## 4. Documentation
+
+### 4.1. Document your runner in English
+
+PostCSS runners must have their `README.md` wrote in English. Do not be afraid
+of your English skills, as the open source community will fix your errors.
+
+Of course, you are welcome to write documentation in other languages;
+just name them appropriately (e.g. `README.ja.md`).
+
+### 4.2. Maintain a changelog
+
+PostCSS runners must describe changes of all releases in a separate file,
+such as `ChangeLog.md`, `History.md`, or with [GitHub Releases].
+Visit [Keep A Changelog] for more information on how to write one of these.
+
+Of course, you should use [SemVer].
+
+[Keep A Changelog]: http://keepachangelog.com/
+[GitHub Releases]: https://help.github.com/articles/creating-releases/
+[SemVer]: http://semver.org/
+
+### 4.3. `postcss-runner` keyword in `package.json`
+
+PostCSS runners written for npm must have the `postcss-runner` keyword
+in their `package.json`. This special keyword will be useful for feedback about
+the PostCSS ecosystem.
+
+For packages not published to npm, this is not mandatory, but recommended
+if the package format is allowed to contain keywords.
diff --git a/node_modules/autoprefixer/node_modules/postcss/docs/source-maps.md b/node_modules/autoprefixer/node_modules/postcss/docs/source-maps.md
new file mode 100644
index 0000000..ce29755
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/docs/source-maps.md
@@ -0,0 +1,74 @@
+# PostCSS and Source Maps
+
+PostCSS has great [source maps] support. It can read and interpret maps
+from previous transformation steps, autodetect the format that you expect,
+and output both external and inline maps.
+
+To ensure that you generate an accurate source map, you must indicate the input
+and output CSS file paths — using the options `from` and `to`, respectively.
+
+To generate a new source map with the default options, simply set `map: true`.
+This will generate an inline source map that contains the source content.
+If you don’t want the map inlined, you can set `map.inline: false`.
+
+```js
+processor
+ .process(css, {
+ from: 'app.sass.css',
+ to: 'app.css',
+ map: { inline: false }
+ })
+ .then(result => {
+ result.map //=> '{ "version":3,
+ // "file":"app.css",
+ // "sources":["app.sass"],
+ // "mappings":"AAAA,KAAI" }'
+ })
+```
+
+If PostCSS finds source maps from a previous transformation,
+it will automatically update that source map with the same options.
+
+## Options
+
+If you want more control over source map generation, you can define the `map`
+option as an object with the following parameters:
+
+* `inline` boolean: indicates that the source map should be embedded
+ in the output CSS as a Base64-encoded comment. By default, it is `true`.
+ But if all previous maps are external, not inline, PostCSS will not embed
+ the map even if you do not set this option.
+
+ If you have an inline source map, the `result.map` property will be empty,
+ as the source map will be contained within the text of `result.css`.
+
+* `prev` string, object, boolean or function: source map content from
+ a previous processing step (for example, Sass compilation).
+ PostCSS will try to read the previous source map automatically
+ (based on comments within the source CSS), but you can use this option
+ to identify it manually. If desired, you can omit the previous map
+ with `prev: false`.
+
+* `sourcesContent` boolean: indicates that PostCSS should set the origin
+ content (for example, Sass source) of the source map. By default,
+ it is `true`. But if all previous maps do not contain sources content,
+ PostCSS will also leave it out even if you do not set this option.
+
+* `annotation` boolean or string: indicates that PostCSS should add annotation
+ comments to the CSS. By default, PostCSS will always add a comment with a path
+ to the source map. PostCSS will not add annotations to CSS files that
+ do not contain any comments.
+
+ By default, PostCSS presumes that you want to save the source map as
+ `opts.to + '.map'` and will use this path in the annotation comment.
+ A different path can be set by providing a string value for `annotation`.
+
+ If you have set `inline: true`, annotation cannot be disabled.
+
+* `from` string: by default, PostCSS will set the `sources` property of the map
+ to the value of the `from` option. If you want to override this behaviour, you
+ can use `map.from` to explicitly set the source map's `sources` property.
+ Path should be absolute or relative from generated file
+ (`to` option in `process()` method).
+
+[source maps]: http://www.html5rocks.com/en/tutorials/developertools/sourcemaps/
diff --git a/node_modules/autoprefixer/node_modules/postcss/docs/syntax.md b/node_modules/autoprefixer/node_modules/postcss/docs/syntax.md
new file mode 100644
index 0000000..b0e1a60
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/docs/syntax.md
@@ -0,0 +1,231 @@
+# How to Write Custom Syntax
+
+PostCSS can transform styles in any syntax, and is not limited to just CSS.
+By writing a custom syntax, you can transform styles in any desired format.
+
+Writing a custom syntax is much harder than writing a PostCSS plugin, but
+it is an awesome adventure.
+
+There are 3 types of PostCSS syntax packages:
+
+* **Parser** to parse input string to node’s tree.
+* **Stringifier** to generate output string by node’s tree.
+* **Syntax** contains both parser and stringifier.
+
+## Syntax
+
+A good example of a custom syntax is [SCSS]. Some users may want to transform
+SCSS sources with PostCSS plugins, for example if they need to add vendor
+prefixes or change the property order. So this syntax should output SCSS from
+an SCSS input.
+
+The syntax API is a very simple plain object, with `parse` & `stringify`
+functions:
+
+```js
+module.exports = {
+ parse: require('./parse'),
+ stringify: require('./stringify')
+}
+```
+
+[SCSS]: https://github.com/postcss/postcss-scss
+
+## Parser
+
+A good example of a parser is [Safe Parser], which parses malformed/broken CSS.
+Because there is no point to generate broken output, this package only provides
+a parser.
+
+The parser API is a function which receives a string & returns a [`Root`] node.
+The second argument is a function which receives an object with PostCSS options.
+
+```js
+const postcss = require('postcss')
+
+module.exports = function parse (css, opts) {
+ const root = postcss.root()
+ // Add other nodes to root
+ return root
+}
+```
+
+[Safe Parser]: https://github.com/postcss/postcss-safe-parser
+[`Root`]: http://api.postcss.org/Root.html
+
+### Main Theory
+
+There are many books about parsers; but do not worry because CSS syntax is
+very easy, and so the parser will be much simpler than a programming language
+parser.
+
+The default PostCSS parser contains two steps:
+
+1. [Tokenizer] which reads input string character by character and builds a
+ tokens array. For example, it joins space symbols to a `['space', '\n ']`
+ token, and detects strings to a `['string', '"\"{"']` token.
+2. [Parser] which reads the tokens array, creates node instances and
+ builds a tree.
+
+[Tokenizer]: https://github.com/postcss/postcss/blob/master/lib/tokenize.es6
+[Parser]: https://github.com/postcss/postcss/blob/master/lib/parser.es6
+
+### Performance
+
+Parsing input is often the most time consuming task in CSS processors. So it
+is very important to have a fast parser.
+
+The main rule of optimization is that there is no performance without a
+benchmark. You can look at [PostCSS benchmarks] to build your own.
+
+Of parsing tasks, the tokenize step will often take the most time, so its
+performance should be prioritized. Unfortunately, classes, functions and
+high level structures can slow down your tokenizer. Be ready to write dirty
+code with repeated statements. This is why it is difficult to extend the
+default [PostCSS tokenizer]; copy & paste will be a necessary evil.
+
+Second optimization is using character codes instead of strings.
+
+```js
+// Slow
+string[i] === '{'
+
+// Fast
+const OPEN_CURLY = 123 // `{'
+string.charCodeAt(i) === OPEN_CURLY
+```
+
+Third optimization is “fast jumps”. If you find open quotes, you can find
+next closing quote much faster by `indexOf`:
+
+```js
+// Simple jump
+next = string.indexOf('"', currentPosition + 1)
+
+// Jump by RegExp
+regexp.lastIndex = currentPosion + 1
+regexp.test(string)
+next = regexp.lastIndex
+```
+
+The parser can be a well written class. There is no need in copy-paste and
+hardcore optimization there. You can extend the default [PostCSS parser].
+
+[PostCSS benchmarks]: https://github.com/postcss/benchmark
+[PostCSS tokenizer]: https://github.com/postcss/postcss/blob/master/lib/tokenize.es6
+[PostCSS parser]: https://github.com/postcss/postcss/blob/master/lib/parser.es6
+
+### Node Source
+
+Every node should have `source` property to generate correct source map.
+This property contains `start` and `end` properties with `{ line, column }`,
+and `input` property with an [`Input`] instance.
+
+Your tokenizer should save the original position so that you can propagate
+the values to the parser, to ensure that the source map is correctly updated.
+
+[`Input`]: https://github.com/postcss/postcss/blob/master/lib/input.es6
+
+### Raw Values
+
+A good PostCSS parser should provide all information (including spaces symbols)
+to generate byte-to-byte equal output. It is not so difficult, but respectful
+for user input and allow integration smoke tests.
+
+A parser should save all additional symbols to `node.raws` object.
+It is an open structure for you, you can add additional keys.
+For example, [SCSS parser] saves comment types (`/* */` or `//`)
+in `node.raws.inline`.
+
+The default parser cleans CSS values from comments and spaces.
+It saves the original value with comments to `node.raws.value.raw` and uses it,
+if the node value was not changed.
+
+[SCSS parser]: https://github.com/postcss/postcss-scss
+
+### Tests
+
+Of course, all parsers in the PostCSS ecosystem must have tests.
+
+If your parser just extends CSS syntax (like [SCSS] or [Safe Parser]),
+you can use the [PostCSS Parser Tests]. It contains unit & integration tests.
+
+[PostCSS Parser Tests]: https://github.com/postcss/postcss-parser-tests
+
+## Stringifier
+
+A style guide generator is a good example of a stringifier. It generates output
+HTML which contains CSS components. For this use case, a parser isn't necessary,
+so the package should just contain a stringifier.
+
+The Stringifier API is little bit more complicated, than the parser API.
+PostCSS generates a source map, so a stringifier can’t just return a string.
+It must link every substring with its source node.
+
+A Stringifier is a function which receives [`Root`] node and builder callback.
+Then it calls builder with every node’s string and node instance.
+
+```js
+module.exports = function stringify (root, builder) {
+ // Some magic
+ const string = decl.prop + ':' + decl.value + ';'
+ builder(string, decl)
+ // Some science
+};
+```
+
+### Main Theory
+
+PostCSS [default stringifier] is just a class with a method for each node type
+and many methods to detect raw properties.
+
+In most cases it will be enough just to extend this class,
+like in [SCSS stringifier].
+
+[default stringifier]: https://github.com/postcss/postcss/blob/master/lib/stringifier.es6
+[SCSS stringifier]: https://github.com/postcss/postcss-scss/blob/master/lib/scss-stringifier.es6
+
+### Builder Function
+
+A builder function will be passed to `stringify` function as second argument.
+For example, the default PostCSS stringifier class saves it
+to `this.builder` property.
+
+Builder receives output substring and source node to append this substring
+to the final output.
+
+Some nodes contain other nodes in the middle. For example, a rule has a `{`
+at the beginning, many declarations inside and a closing `}`.
+
+For these cases, you should pass a third argument to builder function:
+`'start'` or `'end'` string:
+
+```js
+this.builder(rule.selector + '{', rule, 'start')
+// Stringify declarations inside
+this.builder('}', rule, 'end')
+```
+
+### Raw Values
+
+A good PostCSS custom syntax saves all symbols and provide byte-to-byte equal
+output if there were no changes.
+
+This is why every node has `node.raws` object to store space symbol, etc.
+
+Be careful, because sometimes these raw properties will not be present; some
+nodes may be built manually, or may lose their indentation when they are moved
+to another parent node.
+
+This is why the default stringifier has a `raw()` method to autodetect raw
+properties by other nodes. For example, it will look at other nodes to detect
+indent size and them multiply it with the current node depth.
+
+### Tests
+
+A stringifier must have tests too.
+
+You can use unit and integration test cases from [PostCSS Parser Tests].
+Just compare input CSS with CSS after your parser and stringifier.
+
+[PostCSS Parser Tests]: https://github.com/postcss/postcss-parser-tests
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/at-rule.js b/node_modules/autoprefixer/node_modules/postcss/lib/at-rule.js
new file mode 100644
index 0000000..619c04a
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/at-rule.js
@@ -0,0 +1,129 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _container = _interopRequireDefault(require("./container"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
+
+/**
+ * Represents an at-rule.
+ *
+ * If it’s followed in the CSS by a {} block, this node will have
+ * a nodes property representing its children.
+ *
+ * @extends Container
+ *
+ * @example
+ * const root = postcss.parse('@charset "UTF-8"; @media print {}')
+ *
+ * const charset = root.first
+ * charset.type //=> 'atrule'
+ * charset.nodes //=> undefined
+ *
+ * const media = root.last
+ * media.nodes //=> []
+ */
+var AtRule =
+/*#__PURE__*/
+function (_Container) {
+ _inheritsLoose(AtRule, _Container);
+
+ function AtRule(defaults) {
+ var _this;
+
+ _this = _Container.call(this, defaults) || this;
+ _this.type = 'atrule';
+ return _this;
+ }
+
+ var _proto = AtRule.prototype;
+
+ _proto.append = function append() {
+ var _Container$prototype$;
+
+ if (!this.nodes) this.nodes = [];
+
+ for (var _len = arguments.length, children = new Array(_len), _key = 0; _key < _len; _key++) {
+ children[_key] = arguments[_key];
+ }
+
+ return (_Container$prototype$ = _Container.prototype.append).call.apply(_Container$prototype$, [this].concat(children));
+ };
+
+ _proto.prepend = function prepend() {
+ var _Container$prototype$2;
+
+ if (!this.nodes) this.nodes = [];
+
+ for (var _len2 = arguments.length, children = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
+ children[_key2] = arguments[_key2];
+ }
+
+ return (_Container$prototype$2 = _Container.prototype.prepend).call.apply(_Container$prototype$2, [this].concat(children));
+ }
+ /**
+ * @memberof AtRule#
+ * @member {string} name The at-rule’s name immediately follows the `@`.
+ *
+ * @example
+ * const root = postcss.parse('@media print {}')
+ * media.name //=> 'media'
+ * const media = root.first
+ */
+
+ /**
+ * @memberof AtRule#
+ * @member {string} params The at-rule’s parameters, the values
+ * that follow the at-rule’s name but precede
+ * any {} block.
+ *
+ * @example
+ * const root = postcss.parse('@media print, screen {}')
+ * const media = root.first
+ * media.params //=> 'print, screen'
+ */
+
+ /**
+ * @memberof AtRule#
+ * @member {object} raws Information to generate byte-to-byte equal
+ * node string as it was in the origin input.
+ *
+ * Every parser saves its own properties,
+ * but the default CSS parser uses:
+ *
+ * * `before`: the space symbols before the node. It also stores `*`
+ * and `_` symbols before the declaration (IE hack).
+ * * `after`: the space symbols after the last child of the node
+ * to the end of the node.
+ * * `between`: the symbols between the property and value
+ * for declarations, selector and `{` for rules, or last parameter
+ * and `{` for at-rules.
+ * * `semicolon`: contains true if the last child has
+ * an (optional) semicolon.
+ * * `afterName`: the space between the at-rule name and its parameters.
+ *
+ * PostCSS cleans at-rule parameters from comments and extra spaces,
+ * but it stores origin content in raws properties.
+ * As such, if you don’t change a declaration’s value,
+ * PostCSS will use the raw value with comments.
+ *
+ * @example
+ * const root = postcss.parse(' @media\nprint {\n}')
+ * root.first.first.raws //=> { before: ' ',
+ * // between: ' ',
+ * // afterName: '\n',
+ * // after: '\n' }
+ */
+ ;
+
+ return AtRule;
+}(_container.default);
+
+var _default = AtRule;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImF0LXJ1bGUuZXM2Il0sIm5hbWVzIjpbIkF0UnVsZSIsImRlZmF1bHRzIiwidHlwZSIsImFwcGVuZCIsIm5vZGVzIiwiY2hpbGRyZW4iLCJwcmVwZW5kIiwiQ29udGFpbmVyIl0sIm1hcHBpbmdzIjoiOzs7OztBQUFBOzs7Ozs7QUFFQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBa0JNQSxNOzs7OztBQUNKLGtCQUFhQyxRQUFiLEVBQXVCO0FBQUE7O0FBQ3JCLGtDQUFNQSxRQUFOO0FBQ0EsVUFBS0MsSUFBTCxHQUFZLFFBQVo7QUFGcUI7QUFHdEI7Ozs7U0FFREMsTSxHQUFBLGtCQUFxQjtBQUFBOztBQUNuQixRQUFJLENBQUMsS0FBS0MsS0FBVixFQUFpQixLQUFLQSxLQUFMLEdBQWEsRUFBYjs7QUFERSxzQ0FBVkMsUUFBVTtBQUFWQSxNQUFBQSxRQUFVO0FBQUE7O0FBRW5CLHlEQUFhRixNQUFiLGtEQUF1QkUsUUFBdkI7QUFDRCxHOztTQUVEQyxPLEdBQUEsbUJBQXNCO0FBQUE7O0FBQ3BCLFFBQUksQ0FBQyxLQUFLRixLQUFWLEVBQWlCLEtBQUtBLEtBQUwsR0FBYSxFQUFiOztBQURHLHVDQUFWQyxRQUFVO0FBQVZBLE1BQUFBLFFBQVU7QUFBQTs7QUFFcEIsMERBQWFDLE9BQWIsbURBQXdCRCxRQUF4QjtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7QUFVQTs7Ozs7Ozs7Ozs7O0FBWUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7RUF0Q21CRSxrQjs7ZUF1RU5QLE0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQ29udGFpbmVyIGZyb20gJy4vY29udGFpbmVyJ1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYW4gYXQtcnVsZS5cbiAqXG4gKiBJZiBpdOKAmXMgZm9sbG93ZWQgaW4gdGhlIENTUyBieSBhIHt9IGJsb2NrLCB0aGlzIG5vZGUgd2lsbCBoYXZlXG4gKiBhIG5vZGVzIHByb3BlcnR5IHJlcHJlc2VudGluZyBpdHMgY2hpbGRyZW4uXG4gKlxuICogQGV4dGVuZHMgQ29udGFpbmVyXG4gKlxuICogQGV4YW1wbGVcbiAqIGNvbnN0IHJvb3QgPSBwb3N0Y3NzLnBhcnNlKCdAY2hhcnNldCBcIlVURi04XCI7IEBtZWRpYSBwcmludCB7fScpXG4gKlxuICogY29uc3QgY2hhcnNldCA9IHJvb3QuZmlyc3RcbiAqIGNoYXJzZXQudHlwZSAgLy89PiAnYXRydWxlJ1xuICogY2hhcnNldC5ub2RlcyAvLz0+IHVuZGVmaW5lZFxuICpcbiAqIGNvbnN0IG1lZGlhID0gcm9vdC5sYXN0XG4gKiBtZWRpYS5ub2RlcyAgIC8vPT4gW11cbiAqL1xuY2xhc3MgQXRSdWxlIGV4dGVuZHMgQ29udGFpbmVyIHtcbiAgY29uc3RydWN0b3IgKGRlZmF1bHRzKSB7XG4gICAgc3VwZXIoZGVmYXVsdHMpXG4gICAgdGhpcy50eXBlID0gJ2F0cnVsZSdcbiAgfVxuXG4gIGFwcGVuZCAoLi4uY2hpbGRyZW4pIHtcbiAgICBpZiAoIXRoaXMubm9kZXMpIHRoaXMubm9kZXMgPSBbXVxuICAgIHJldHVybiBzdXBlci5hcHBlbmQoLi4uY2hpbGRyZW4pXG4gIH1cblxuICBwcmVwZW5kICguLi5jaGlsZHJlbikge1xuICAgIGlmICghdGhpcy5ub2RlcykgdGhpcy5ub2RlcyA9IFtdXG4gICAgcmV0dXJuIHN1cGVyLnByZXBlbmQoLi4uY2hpbGRyZW4pXG4gIH1cblxuICAvKipcbiAgICogQG1lbWJlcm9mIEF0UnVsZSNcbiAgICogQG1lbWJlciB7c3RyaW5nfSBuYW1lIFRoZSBhdC1ydWxl4oCZcyBuYW1lIGltbWVkaWF0ZWx5IGZvbGxvd3MgdGhlIGBAYC5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgcm9vdCAgPSBwb3N0Y3NzLnBhcnNlKCdAbWVkaWEgcHJpbnQge30nKVxuICAgKiBtZWRpYS5uYW1lIC8vPT4gJ21lZGlhJ1xuICAgKiBjb25zdCBtZWRpYSA9IHJvb3QuZmlyc3RcbiAgICovXG5cbiAgLyoqXG4gICAqIEBtZW1iZXJvZiBBdFJ1bGUjXG4gICAqIEBtZW1iZXIge3N0cmluZ30gcGFyYW1zIFRoZSBhdC1ydWxl4oCZcyBwYXJhbWV0ZXJzLCB0aGUgdmFsdWVzXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgIHRoYXQgZm9sbG93IHRoZSBhdC1ydWxl4oCZcyBuYW1lIGJ1dCBwcmVjZWRlXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgIGFueSB7fSBibG9jay5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgcm9vdCAgPSBwb3N0Y3NzLnBhcnNlKCdAbWVkaWEgcHJpbnQsIHNjcmVlbiB7fScpXG4gICAqIGNvbnN0IG1lZGlhID0gcm9vdC5maXJzdFxuICAgKiBtZWRpYS5wYXJhbXMgLy89PiAncHJpbnQsIHNjcmVlbidcbiAgICovXG5cbiAgLyoqXG4gICAqIEBtZW1iZXJvZiBBdFJ1bGUjXG4gICAqIEBtZW1iZXIge29iamVjdH0gcmF3cyBJbmZvcm1hdGlvbiB0byBnZW5lcmF0ZSBieXRlLXRvLWJ5dGUgZXF1YWxcbiAgICogICAgICAgICAgICAgICAgICAgICAgICBub2RlIHN0cmluZyBhcyBpdCB3YXMgaW4gdGhlIG9yaWdpbiBpbnB1dC5cbiAgICpcbiAgICogRXZlcnkgcGFyc2VyIHNhdmVzIGl0cyBvd24gcHJvcGVydGllcyxcbiAgICogYnV0IHRoZSBkZWZhdWx0IENTUyBwYXJzZXIgdXNlczpcbiAgICpcbiAgICogKiBgYmVmb3JlYDogdGhlIHNwYWNlIHN5bWJvbHMgYmVmb3JlIHRoZSBub2RlLiBJdCBhbHNvIHN0b3JlcyBgKmBcbiAgICogICBhbmQgYF9gIHN5bWJvbHMgYmVmb3JlIHRoZSBkZWNsYXJhdGlvbiAoSUUgaGFjaykuXG4gICAqICogYGFmdGVyYDogdGhlIHNwYWNlIHN5bWJvbHMgYWZ0ZXIgdGhlIGxhc3QgY2hpbGQgb2YgdGhlIG5vZGVcbiAgICogICB0byB0aGUgZW5kIG9mIHRoZSBub2RlLlxuICAgKiAqIGBiZXR3ZWVuYDogdGhlIHN5bWJvbHMgYmV0d2VlbiB0aGUgcHJvcGVydHkgYW5kIHZhbHVlXG4gICAqICAgZm9yIGRlY2xhcmF0aW9ucywgc2VsZWN0b3IgYW5kIGB7YCBmb3IgcnVsZXMsIG9yIGxhc3QgcGFyYW1ldGVyXG4gICAqICAgYW5kIGB7YCBmb3IgYXQtcnVsZXMuXG4gICAqICogYHNlbWljb2xvbmA6IGNvbnRhaW5zIHRydWUgaWYgdGhlIGxhc3QgY2hpbGQgaGFzXG4gICAqICAgYW4gKG9wdGlvbmFsKSBzZW1pY29sb24uXG4gICAqICogYGFmdGVyTmFtZWA6IHRoZSBzcGFjZSBiZXR3ZWVuIHRoZSBhdC1ydWxlIG5hbWUgYW5kIGl0cyBwYXJhbWV0ZXJzLlxuICAgKlxuICAgKiBQb3N0Q1NTIGNsZWFucyBhdC1ydWxlIHBhcmFtZXRlcnMgZnJvbSBjb21tZW50cyBhbmQgZXh0cmEgc3BhY2VzLFxuICAgKiBidXQgaXQgc3RvcmVzIG9yaWdpbiBjb250ZW50IGluIHJhd3MgcHJvcGVydGllcy5cbiAgICogQXMgc3VjaCwgaWYgeW91IGRvbuKAmXQgY2hhbmdlIGEgZGVjbGFyYXRpb27igJlzIHZhbHVlLFxuICAgKiBQb3N0Q1NTIHdpbGwgdXNlIHRoZSByYXcgdmFsdWUgd2l0aCBjb21tZW50cy5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJyAgQG1lZGlhXFxucHJpbnQge1xcbn0nKVxuICAgKiByb290LmZpcnN0LmZpcnN0LnJhd3MgLy89PiB7IGJlZm9yZTogJyAgJyxcbiAgICogICAgICAgICAgICAgICAgICAgICAgIC8vICAgICBiZXR3ZWVuOiAnICcsXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAvLyAgICAgYWZ0ZXJOYW1lOiAnXFxuJyxcbiAgICogICAgICAgICAgICAgICAgICAgICAgIC8vICAgICBhZnRlcjogJ1xcbicgfVxuICAgKi9cbn1cblxuZXhwb3J0IGRlZmF1bHQgQXRSdWxlXG4iXSwiZmlsZSI6ImF0LXJ1bGUuanMifQ==
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/comment.js b/node_modules/autoprefixer/node_modules/postcss/lib/comment.js
new file mode 100644
index 0000000..c9db73e
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/comment.js
@@ -0,0 +1,57 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _node = _interopRequireDefault(require("./node"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
+
+/**
+ * Represents a comment between declarations or statements (rule and at-rules).
+ *
+ * Comments inside selectors, at-rule parameters, or declaration values
+ * will be stored in the `raws` properties explained above.
+ *
+ * @extends Node
+ */
+var Comment =
+/*#__PURE__*/
+function (_Node) {
+ _inheritsLoose(Comment, _Node);
+
+ function Comment(defaults) {
+ var _this;
+
+ _this = _Node.call(this, defaults) || this;
+ _this.type = 'comment';
+ return _this;
+ }
+ /**
+ * @memberof Comment#
+ * @member {string} text The comment’s text.
+ */
+
+ /**
+ * @memberof Comment#
+ * @member {object} raws Information to generate byte-to-byte equal
+ * node string as it was in the origin input.
+ *
+ * Every parser saves its own properties,
+ * but the default CSS parser uses:
+ *
+ * * `before`: the space symbols before the node.
+ * * `left`: the space symbols between `/*` and the comment’s text.
+ * * `right`: the space symbols between the comment’s text.
+ */
+
+
+ return Comment;
+}(_node.default);
+
+var _default = Comment;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbW1lbnQuZXM2Il0sIm5hbWVzIjpbIkNvbW1lbnQiLCJkZWZhdWx0cyIsInR5cGUiLCJOb2RlIl0sIm1hcHBpbmdzIjoiOzs7OztBQUFBOzs7Ozs7QUFFQTs7Ozs7Ozs7SUFRTUEsTzs7Ozs7QUFDSixtQkFBYUMsUUFBYixFQUF1QjtBQUFBOztBQUNyQiw2QkFBTUEsUUFBTjtBQUNBLFVBQUtDLElBQUwsR0FBWSxTQUFaO0FBRnFCO0FBR3RCO0FBRUQ7Ozs7O0FBS0E7Ozs7Ozs7Ozs7Ozs7OztFQVhvQkMsYTs7ZUF5QlBILE8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgTm9kZSBmcm9tICcuL25vZGUnXG5cbi8qKlxuICogUmVwcmVzZW50cyBhIGNvbW1lbnQgYmV0d2VlbiBkZWNsYXJhdGlvbnMgb3Igc3RhdGVtZW50cyAocnVsZSBhbmQgYXQtcnVsZXMpLlxuICpcbiAqIENvbW1lbnRzIGluc2lkZSBzZWxlY3RvcnMsIGF0LXJ1bGUgcGFyYW1ldGVycywgb3IgZGVjbGFyYXRpb24gdmFsdWVzXG4gKiB3aWxsIGJlIHN0b3JlZCBpbiB0aGUgYHJhd3NgIHByb3BlcnRpZXMgZXhwbGFpbmVkIGFib3ZlLlxuICpcbiAqIEBleHRlbmRzIE5vZGVcbiAqL1xuY2xhc3MgQ29tbWVudCBleHRlbmRzIE5vZGUge1xuICBjb25zdHJ1Y3RvciAoZGVmYXVsdHMpIHtcbiAgICBzdXBlcihkZWZhdWx0cylcbiAgICB0aGlzLnR5cGUgPSAnY29tbWVudCdcbiAgfVxuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgQ29tbWVudCNcbiAgICogQG1lbWJlciB7c3RyaW5nfSB0ZXh0IFRoZSBjb21tZW504oCZcyB0ZXh0LlxuICAgKi9cblxuICAvKipcbiAgICogQG1lbWJlcm9mIENvbW1lbnQjXG4gICAqIEBtZW1iZXIge29iamVjdH0gcmF3cyBJbmZvcm1hdGlvbiB0byBnZW5lcmF0ZSBieXRlLXRvLWJ5dGUgZXF1YWxcbiAgICogICAgICAgICAgICAgICAgICAgICAgIG5vZGUgc3RyaW5nIGFzIGl0IHdhcyBpbiB0aGUgb3JpZ2luIGlucHV0LlxuICAgKlxuICAgKiBFdmVyeSBwYXJzZXIgc2F2ZXMgaXRzIG93biBwcm9wZXJ0aWVzLFxuICAgKiBidXQgdGhlIGRlZmF1bHQgQ1NTIHBhcnNlciB1c2VzOlxuICAgKlxuICAgKiAqIGBiZWZvcmVgOiB0aGUgc3BhY2Ugc3ltYm9scyBiZWZvcmUgdGhlIG5vZGUuXG4gICAqICogYGxlZnRgOiB0aGUgc3BhY2Ugc3ltYm9scyBiZXR3ZWVuIGAvKmAgYW5kIHRoZSBjb21tZW504oCZcyB0ZXh0LlxuICAgKiAqIGByaWdodGA6IHRoZSBzcGFjZSBzeW1ib2xzIGJldHdlZW4gdGhlIGNvbW1lbnTigJlzIHRleHQuXG4gICAqL1xufVxuXG5leHBvcnQgZGVmYXVsdCBDb21tZW50XG4iXSwiZmlsZSI6ImNvbW1lbnQuanMifQ==
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/container.js b/node_modules/autoprefixer/node_modules/postcss/lib/container.js
new file mode 100644
index 0000000..b41c891
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/container.js
@@ -0,0 +1,869 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _declaration = _interopRequireDefault(require("./declaration"));
+
+var _comment = _interopRequireDefault(require("./comment"));
+
+var _node = _interopRequireDefault(require("./node"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
+
+function cleanSource(nodes) {
+ return nodes.map(function (i) {
+ if (i.nodes) i.nodes = cleanSource(i.nodes);
+ delete i.source;
+ return i;
+ });
+}
+/**
+ * The {@link Root}, {@link AtRule}, and {@link Rule} container nodes
+ * inherit some common methods to help work with their children.
+ *
+ * Note that all containers can store any content. If you write a rule inside
+ * a rule, PostCSS will parse it.
+ *
+ * @extends Node
+ * @abstract
+ */
+
+
+var Container =
+/*#__PURE__*/
+function (_Node) {
+ _inheritsLoose(Container, _Node);
+
+ function Container() {
+ return _Node.apply(this, arguments) || this;
+ }
+
+ var _proto = Container.prototype;
+
+ _proto.push = function push(child) {
+ child.parent = this;
+ this.nodes.push(child);
+ return this;
+ }
+ /**
+ * Iterates through the container’s immediate children,
+ * calling `callback` for each child.
+ *
+ * Returning `false` in the callback will break iteration.
+ *
+ * This method only iterates through the container’s immediate children.
+ * If you need to recursively iterate through all the container’s descendant
+ * nodes, use {@link Container#walk}.
+ *
+ * Unlike the for `{}`-cycle or `Array#forEach` this iterator is safe
+ * if you are mutating the array of child nodes during iteration.
+ * PostCSS will adjust the current index to match the mutations.
+ *
+ * @param {childIterator} callback Iterator receives each node and index.
+ *
+ * @return {false|undefined} Returns `false` if iteration was broke.
+ *
+ * @example
+ * const root = postcss.parse('a { color: black; z-index: 1 }')
+ * const rule = root.first
+ *
+ * for (const decl of rule.nodes) {
+ * decl.cloneBefore({ prop: '-webkit-' + decl.prop })
+ * // Cycle will be infinite, because cloneBefore moves the current node
+ * // to the next index
+ * }
+ *
+ * rule.each(decl => {
+ * decl.cloneBefore({ prop: '-webkit-' + decl.prop })
+ * // Will be executed only for color and z-index
+ * })
+ */
+ ;
+
+ _proto.each = function each(callback) {
+ if (!this.lastEach) this.lastEach = 0;
+ if (!this.indexes) this.indexes = {};
+ this.lastEach += 1;
+ var id = this.lastEach;
+ this.indexes[id] = 0;
+ if (!this.nodes) return undefined;
+ var index, result;
+
+ while (this.indexes[id] < this.nodes.length) {
+ index = this.indexes[id];
+ result = callback(this.nodes[index], index);
+ if (result === false) break;
+ this.indexes[id] += 1;
+ }
+
+ delete this.indexes[id];
+ return result;
+ }
+ /**
+ * Traverses the container’s descendant nodes, calling callback
+ * for each node.
+ *
+ * Like container.each(), this method is safe to use
+ * if you are mutating arrays during iteration.
+ *
+ * If you only need to iterate through the container’s immediate children,
+ * use {@link Container#each}.
+ *
+ * @param {childIterator} callback Iterator receives each node and index.
+ *
+ * @return {false|undefined} Returns `false` if iteration was broke.
+ *
+ * @example
+ * root.walk(node => {
+ * // Traverses all descendant nodes.
+ * })
+ */
+ ;
+
+ _proto.walk = function walk(callback) {
+ return this.each(function (child, i) {
+ var result;
+
+ try {
+ result = callback(child, i);
+ } catch (e) {
+ e.postcssNode = child;
+
+ if (e.stack && child.source && /\n\s{4}at /.test(e.stack)) {
+ var s = child.source;
+ e.stack = e.stack.replace(/\n\s{4}at /, "$&" + s.input.from + ":" + s.start.line + ":" + s.start.column + "$&");
+ }
+
+ throw e;
+ }
+
+ if (result !== false && child.walk) {
+ result = child.walk(callback);
+ }
+
+ return result;
+ });
+ }
+ /**
+ * Traverses the container’s descendant nodes, calling callback
+ * for each declaration node.
+ *
+ * If you pass a filter, iteration will only happen over declarations
+ * with matching properties.
+ *
+ * Like {@link Container#each}, this method is safe
+ * to use if you are mutating arrays during iteration.
+ *
+ * @param {string|RegExp} [prop] String or regular expression
+ * to filter declarations by property name.
+ * @param {childIterator} callback Iterator receives each node and index.
+ *
+ * @return {false|undefined} Returns `false` if iteration was broke.
+ *
+ * @example
+ * root.walkDecls(decl => {
+ * checkPropertySupport(decl.prop)
+ * })
+ *
+ * root.walkDecls('border-radius', decl => {
+ * decl.remove()
+ * })
+ *
+ * root.walkDecls(/^background/, decl => {
+ * decl.value = takeFirstColorFromGradient(decl.value)
+ * })
+ */
+ ;
+
+ _proto.walkDecls = function walkDecls(prop, callback) {
+ if (!callback) {
+ callback = prop;
+ return this.walk(function (child, i) {
+ if (child.type === 'decl') {
+ return callback(child, i);
+ }
+ });
+ }
+
+ if (prop instanceof RegExp) {
+ return this.walk(function (child, i) {
+ if (child.type === 'decl' && prop.test(child.prop)) {
+ return callback(child, i);
+ }
+ });
+ }
+
+ return this.walk(function (child, i) {
+ if (child.type === 'decl' && child.prop === prop) {
+ return callback(child, i);
+ }
+ });
+ }
+ /**
+ * Traverses the container’s descendant nodes, calling callback
+ * for each rule node.
+ *
+ * If you pass a filter, iteration will only happen over rules
+ * with matching selectors.
+ *
+ * Like {@link Container#each}, this method is safe
+ * to use if you are mutating arrays during iteration.
+ *
+ * @param {string|RegExp} [selector] String or regular expression
+ * to filter rules by selector.
+ * @param {childIterator} callback Iterator receives each node and index.
+ *
+ * @return {false|undefined} returns `false` if iteration was broke.
+ *
+ * @example
+ * const selectors = []
+ * root.walkRules(rule => {
+ * selectors.push(rule.selector)
+ * })
+ * console.log(`Your CSS uses ${ selectors.length } selectors`)
+ */
+ ;
+
+ _proto.walkRules = function walkRules(selector, callback) {
+ if (!callback) {
+ callback = selector;
+ return this.walk(function (child, i) {
+ if (child.type === 'rule') {
+ return callback(child, i);
+ }
+ });
+ }
+
+ if (selector instanceof RegExp) {
+ return this.walk(function (child, i) {
+ if (child.type === 'rule' && selector.test(child.selector)) {
+ return callback(child, i);
+ }
+ });
+ }
+
+ return this.walk(function (child, i) {
+ if (child.type === 'rule' && child.selector === selector) {
+ return callback(child, i);
+ }
+ });
+ }
+ /**
+ * Traverses the container’s descendant nodes, calling callback
+ * for each at-rule node.
+ *
+ * If you pass a filter, iteration will only happen over at-rules
+ * that have matching names.
+ *
+ * Like {@link Container#each}, this method is safe
+ * to use if you are mutating arrays during iteration.
+ *
+ * @param {string|RegExp} [name] String or regular expression
+ * to filter at-rules by name.
+ * @param {childIterator} callback Iterator receives each node and index.
+ *
+ * @return {false|undefined} Returns `false` if iteration was broke.
+ *
+ * @example
+ * root.walkAtRules(rule => {
+ * if (isOld(rule.name)) rule.remove()
+ * })
+ *
+ * let first = false
+ * root.walkAtRules('charset', rule => {
+ * if (!first) {
+ * first = true
+ * } else {
+ * rule.remove()
+ * }
+ * })
+ */
+ ;
+
+ _proto.walkAtRules = function walkAtRules(name, callback) {
+ if (!callback) {
+ callback = name;
+ return this.walk(function (child, i) {
+ if (child.type === 'atrule') {
+ return callback(child, i);
+ }
+ });
+ }
+
+ if (name instanceof RegExp) {
+ return this.walk(function (child, i) {
+ if (child.type === 'atrule' && name.test(child.name)) {
+ return callback(child, i);
+ }
+ });
+ }
+
+ return this.walk(function (child, i) {
+ if (child.type === 'atrule' && child.name === name) {
+ return callback(child, i);
+ }
+ });
+ }
+ /**
+ * Traverses the container’s descendant nodes, calling callback
+ * for each comment node.
+ *
+ * Like {@link Container#each}, this method is safe
+ * to use if you are mutating arrays during iteration.
+ *
+ * @param {childIterator} callback Iterator receives each node and index.
+ *
+ * @return {false|undefined} Returns `false` if iteration was broke.
+ *
+ * @example
+ * root.walkComments(comment => {
+ * comment.remove()
+ * })
+ */
+ ;
+
+ _proto.walkComments = function walkComments(callback) {
+ return this.walk(function (child, i) {
+ if (child.type === 'comment') {
+ return callback(child, i);
+ }
+ });
+ }
+ /**
+ * Inserts new nodes to the end of the container.
+ *
+ * @param {...(Node|object|string|Node[])} children New nodes.
+ *
+ * @return {Node} This node for methods chain.
+ *
+ * @example
+ * const decl1 = postcss.decl({ prop: 'color', value: 'black' })
+ * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' })
+ * rule.append(decl1, decl2)
+ *
+ * root.append({ name: 'charset', params: '"UTF-8"' }) // at-rule
+ * root.append({ selector: 'a' }) // rule
+ * rule.append({ prop: 'color', value: 'black' }) // declaration
+ * rule.append({ text: 'Comment' }) // comment
+ *
+ * root.append('a {}')
+ * root.first.append('color: black; z-index: 1')
+ */
+ ;
+
+ _proto.append = function append() {
+ for (var _len = arguments.length, children = new Array(_len), _key = 0; _key < _len; _key++) {
+ children[_key] = arguments[_key];
+ }
+
+ for (var _i = 0, _children = children; _i < _children.length; _i++) {
+ var child = _children[_i];
+ var nodes = this.normalize(child, this.last);
+
+ for (var _iterator = nodes, _isArray = Array.isArray(_iterator), _i2 = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
+ var _ref;
+
+ if (_isArray) {
+ if (_i2 >= _iterator.length) break;
+ _ref = _iterator[_i2++];
+ } else {
+ _i2 = _iterator.next();
+ if (_i2.done) break;
+ _ref = _i2.value;
+ }
+
+ var node = _ref;
+ this.nodes.push(node);
+ }
+ }
+
+ return this;
+ }
+ /**
+ * Inserts new nodes to the start of the container.
+ *
+ * @param {...(Node|object|string|Node[])} children New nodes.
+ *
+ * @return {Node} This node for methods chain.
+ *
+ * @example
+ * const decl1 = postcss.decl({ prop: 'color', value: 'black' })
+ * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' })
+ * rule.prepend(decl1, decl2)
+ *
+ * root.append({ name: 'charset', params: '"UTF-8"' }) // at-rule
+ * root.append({ selector: 'a' }) // rule
+ * rule.append({ prop: 'color', value: 'black' }) // declaration
+ * rule.append({ text: 'Comment' }) // comment
+ *
+ * root.append('a {}')
+ * root.first.append('color: black; z-index: 1')
+ */
+ ;
+
+ _proto.prepend = function prepend() {
+ for (var _len2 = arguments.length, children = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
+ children[_key2] = arguments[_key2];
+ }
+
+ children = children.reverse();
+
+ for (var _iterator2 = children, _isArray2 = Array.isArray(_iterator2), _i3 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {
+ var _ref2;
+
+ if (_isArray2) {
+ if (_i3 >= _iterator2.length) break;
+ _ref2 = _iterator2[_i3++];
+ } else {
+ _i3 = _iterator2.next();
+ if (_i3.done) break;
+ _ref2 = _i3.value;
+ }
+
+ var child = _ref2;
+ var nodes = this.normalize(child, this.first, 'prepend').reverse();
+
+ for (var _iterator3 = nodes, _isArray3 = Array.isArray(_iterator3), _i4 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {
+ var _ref3;
+
+ if (_isArray3) {
+ if (_i4 >= _iterator3.length) break;
+ _ref3 = _iterator3[_i4++];
+ } else {
+ _i4 = _iterator3.next();
+ if (_i4.done) break;
+ _ref3 = _i4.value;
+ }
+
+ var node = _ref3;
+ this.nodes.unshift(node);
+ }
+
+ for (var id in this.indexes) {
+ this.indexes[id] = this.indexes[id] + nodes.length;
+ }
+ }
+
+ return this;
+ };
+
+ _proto.cleanRaws = function cleanRaws(keepBetween) {
+ _Node.prototype.cleanRaws.call(this, keepBetween);
+
+ if (this.nodes) {
+ for (var _iterator4 = this.nodes, _isArray4 = Array.isArray(_iterator4), _i5 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {
+ var _ref4;
+
+ if (_isArray4) {
+ if (_i5 >= _iterator4.length) break;
+ _ref4 = _iterator4[_i5++];
+ } else {
+ _i5 = _iterator4.next();
+ if (_i5.done) break;
+ _ref4 = _i5.value;
+ }
+
+ var node = _ref4;
+ node.cleanRaws(keepBetween);
+ }
+ }
+ }
+ /**
+ * Insert new node before old node within the container.
+ *
+ * @param {Node|number} exist Child or child’s index.
+ * @param {Node|object|string|Node[]} add New node.
+ *
+ * @return {Node} This node for methods chain.
+ *
+ * @example
+ * rule.insertBefore(decl, decl.clone({ prop: '-webkit-' + decl.prop }))
+ */
+ ;
+
+ _proto.insertBefore = function insertBefore(exist, add) {
+ exist = this.index(exist);
+ var type = exist === 0 ? 'prepend' : false;
+ var nodes = this.normalize(add, this.nodes[exist], type).reverse();
+
+ for (var _iterator5 = nodes, _isArray5 = Array.isArray(_iterator5), _i6 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) {
+ var _ref5;
+
+ if (_isArray5) {
+ if (_i6 >= _iterator5.length) break;
+ _ref5 = _iterator5[_i6++];
+ } else {
+ _i6 = _iterator5.next();
+ if (_i6.done) break;
+ _ref5 = _i6.value;
+ }
+
+ var node = _ref5;
+ this.nodes.splice(exist, 0, node);
+ }
+
+ var index;
+
+ for (var id in this.indexes) {
+ index = this.indexes[id];
+
+ if (exist <= index) {
+ this.indexes[id] = index + nodes.length;
+ }
+ }
+
+ return this;
+ }
+ /**
+ * Insert new node after old node within the container.
+ *
+ * @param {Node|number} exist Child or child’s index.
+ * @param {Node|object|string|Node[]} add New node.
+ *
+ * @return {Node} This node for methods chain.
+ */
+ ;
+
+ _proto.insertAfter = function insertAfter(exist, add) {
+ exist = this.index(exist);
+ var nodes = this.normalize(add, this.nodes[exist]).reverse();
+
+ for (var _iterator6 = nodes, _isArray6 = Array.isArray(_iterator6), _i7 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) {
+ var _ref6;
+
+ if (_isArray6) {
+ if (_i7 >= _iterator6.length) break;
+ _ref6 = _iterator6[_i7++];
+ } else {
+ _i7 = _iterator6.next();
+ if (_i7.done) break;
+ _ref6 = _i7.value;
+ }
+
+ var node = _ref6;
+ this.nodes.splice(exist + 1, 0, node);
+ }
+
+ var index;
+
+ for (var id in this.indexes) {
+ index = this.indexes[id];
+
+ if (exist < index) {
+ this.indexes[id] = index + nodes.length;
+ }
+ }
+
+ return this;
+ }
+ /**
+ * Removes node from the container and cleans the parent properties
+ * from the node and its children.
+ *
+ * @param {Node|number} child Child or child’s index.
+ *
+ * @return {Node} This node for methods chain
+ *
+ * @example
+ * rule.nodes.length //=> 5
+ * rule.removeChild(decl)
+ * rule.nodes.length //=> 4
+ * decl.parent //=> undefined
+ */
+ ;
+
+ _proto.removeChild = function removeChild(child) {
+ child = this.index(child);
+ this.nodes[child].parent = undefined;
+ this.nodes.splice(child, 1);
+ var index;
+
+ for (var id in this.indexes) {
+ index = this.indexes[id];
+
+ if (index >= child) {
+ this.indexes[id] = index - 1;
+ }
+ }
+
+ return this;
+ }
+ /**
+ * Removes all children from the container
+ * and cleans their parent properties.
+ *
+ * @return {Node} This node for methods chain.
+ *
+ * @example
+ * rule.removeAll()
+ * rule.nodes.length //=> 0
+ */
+ ;
+
+ _proto.removeAll = function removeAll() {
+ for (var _iterator7 = this.nodes, _isArray7 = Array.isArray(_iterator7), _i8 = 0, _iterator7 = _isArray7 ? _iterator7 : _iterator7[Symbol.iterator]();;) {
+ var _ref7;
+
+ if (_isArray7) {
+ if (_i8 >= _iterator7.length) break;
+ _ref7 = _iterator7[_i8++];
+ } else {
+ _i8 = _iterator7.next();
+ if (_i8.done) break;
+ _ref7 = _i8.value;
+ }
+
+ var node = _ref7;
+ node.parent = undefined;
+ }
+
+ this.nodes = [];
+ return this;
+ }
+ /**
+ * Passes all declaration values within the container that match pattern
+ * through callback, replacing those values with the returned result
+ * of callback.
+ *
+ * This method is useful if you are using a custom unit or function
+ * and need to iterate through all values.
+ *
+ * @param {string|RegExp} pattern Replace pattern.
+ * @param {object} opts Options to speed up the search.
+ * @param {string|string[]} opts.props An array of property names.
+ * @param {string} opts.fast String that’s used to narrow down
+ * values and speed up the regexp search.
+ * @param {function|string} callback String to replace pattern or callback
+ * that returns a new value. The callback
+ * will receive the same arguments
+ * as those passed to a function parameter
+ * of `String#replace`.
+ *
+ * @return {Node} This node for methods chain.
+ *
+ * @example
+ * root.replaceValues(/\d+rem/, { fast: 'rem' }, string => {
+ * return 15 * parseInt(string) + 'px'
+ * })
+ */
+ ;
+
+ _proto.replaceValues = function replaceValues(pattern, opts, callback) {
+ if (!callback) {
+ callback = opts;
+ opts = {};
+ }
+
+ this.walkDecls(function (decl) {
+ if (opts.props && opts.props.indexOf(decl.prop) === -1) return;
+ if (opts.fast && decl.value.indexOf(opts.fast) === -1) return;
+ decl.value = decl.value.replace(pattern, callback);
+ });
+ return this;
+ }
+ /**
+ * Returns `true` if callback returns `true`
+ * for all of the container’s children.
+ *
+ * @param {childCondition} condition Iterator returns true or false.
+ *
+ * @return {boolean} Is every child pass condition.
+ *
+ * @example
+ * const noPrefixes = rule.every(i => i.prop[0] !== '-')
+ */
+ ;
+
+ _proto.every = function every(condition) {
+ return this.nodes.every(condition);
+ }
+ /**
+ * Returns `true` if callback returns `true` for (at least) one
+ * of the container’s children.
+ *
+ * @param {childCondition} condition Iterator returns true or false.
+ *
+ * @return {boolean} Is some child pass condition.
+ *
+ * @example
+ * const hasPrefix = rule.some(i => i.prop[0] === '-')
+ */
+ ;
+
+ _proto.some = function some(condition) {
+ return this.nodes.some(condition);
+ }
+ /**
+ * Returns a `child`’s index within the {@link Container#nodes} array.
+ *
+ * @param {Node} child Child of the current container.
+ *
+ * @return {number} Child index.
+ *
+ * @example
+ * rule.index( rule.nodes[2] ) //=> 2
+ */
+ ;
+
+ _proto.index = function index(child) {
+ if (typeof child === 'number') {
+ return child;
+ }
+
+ return this.nodes.indexOf(child);
+ }
+ /**
+ * The container’s first child.
+ *
+ * @type {Node}
+ *
+ * @example
+ * rule.first === rules.nodes[0]
+ */
+ ;
+
+ _proto.normalize = function normalize(nodes, sample) {
+ var _this = this;
+
+ if (typeof nodes === 'string') {
+ var parse = require('./parse');
+
+ nodes = cleanSource(parse(nodes).nodes);
+ } else if (Array.isArray(nodes)) {
+ nodes = nodes.slice(0);
+
+ for (var _iterator8 = nodes, _isArray8 = Array.isArray(_iterator8), _i9 = 0, _iterator8 = _isArray8 ? _iterator8 : _iterator8[Symbol.iterator]();;) {
+ var _ref8;
+
+ if (_isArray8) {
+ if (_i9 >= _iterator8.length) break;
+ _ref8 = _iterator8[_i9++];
+ } else {
+ _i9 = _iterator8.next();
+ if (_i9.done) break;
+ _ref8 = _i9.value;
+ }
+
+ var i = _ref8;
+ if (i.parent) i.parent.removeChild(i, 'ignore');
+ }
+ } else if (nodes.type === 'root') {
+ nodes = nodes.nodes.slice(0);
+
+ for (var _iterator9 = nodes, _isArray9 = Array.isArray(_iterator9), _i10 = 0, _iterator9 = _isArray9 ? _iterator9 : _iterator9[Symbol.iterator]();;) {
+ var _ref9;
+
+ if (_isArray9) {
+ if (_i10 >= _iterator9.length) break;
+ _ref9 = _iterator9[_i10++];
+ } else {
+ _i10 = _iterator9.next();
+ if (_i10.done) break;
+ _ref9 = _i10.value;
+ }
+
+ var _i11 = _ref9;
+ if (_i11.parent) _i11.parent.removeChild(_i11, 'ignore');
+ }
+ } else if (nodes.type) {
+ nodes = [nodes];
+ } else if (nodes.prop) {
+ if (typeof nodes.value === 'undefined') {
+ throw new Error('Value field is missed in node creation');
+ } else if (typeof nodes.value !== 'string') {
+ nodes.value = String(nodes.value);
+ }
+
+ nodes = [new _declaration.default(nodes)];
+ } else if (nodes.selector) {
+ var Rule = require('./rule');
+
+ nodes = [new Rule(nodes)];
+ } else if (nodes.name) {
+ var AtRule = require('./at-rule');
+
+ nodes = [new AtRule(nodes)];
+ } else if (nodes.text) {
+ nodes = [new _comment.default(nodes)];
+ } else {
+ throw new Error('Unknown node type in node creation');
+ }
+
+ var processed = nodes.map(function (i) {
+ if (i.parent) i.parent.removeChild(i);
+
+ if (typeof i.raws.before === 'undefined') {
+ if (sample && typeof sample.raws.before !== 'undefined') {
+ i.raws.before = sample.raws.before.replace(/[^\s]/g, '');
+ }
+ }
+
+ i.parent = _this;
+ return i;
+ });
+ return processed;
+ }
+ /**
+ * @memberof Container#
+ * @member {Node[]} nodes An array containing the container’s children.
+ *
+ * @example
+ * const root = postcss.parse('a { color: black }')
+ * root.nodes.length //=> 1
+ * root.nodes[0].selector //=> 'a'
+ * root.nodes[0].nodes[0].prop //=> 'color'
+ */
+ ;
+
+ _createClass(Container, [{
+ key: "first",
+ get: function get() {
+ if (!this.nodes) return undefined;
+ return this.nodes[0];
+ }
+ /**
+ * The container’s last child.
+ *
+ * @type {Node}
+ *
+ * @example
+ * rule.last === rule.nodes[rule.nodes.length - 1]
+ */
+
+ }, {
+ key: "last",
+ get: function get() {
+ if (!this.nodes) return undefined;
+ return this.nodes[this.nodes.length - 1];
+ }
+ }]);
+
+ return Container;
+}(_node.default);
+
+var _default = Container;
+/**
+ * @callback childCondition
+ * @param {Node} node Container child.
+ * @param {number} index Child index.
+ * @param {Node[]} nodes All container children.
+ * @return {boolean}
+ */
+
+/**
+ * @callback childIterator
+ * @param {Node} node Container child.
+ * @param {number} index Child index.
+ * @return {false|undefined} Returning `false` will break iteration.
+ */
+
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbnRhaW5lci5lczYiXSwibmFtZXMiOlsiY2xlYW5Tb3VyY2UiLCJub2RlcyIsIm1hcCIsImkiLCJzb3VyY2UiLCJDb250YWluZXIiLCJwdXNoIiwiY2hpbGQiLCJwYXJlbnQiLCJlYWNoIiwiY2FsbGJhY2siLCJsYXN0RWFjaCIsImluZGV4ZXMiLCJpZCIsInVuZGVmaW5lZCIsImluZGV4IiwicmVzdWx0IiwibGVuZ3RoIiwid2FsayIsImUiLCJwb3N0Y3NzTm9kZSIsInN0YWNrIiwidGVzdCIsInMiLCJyZXBsYWNlIiwiaW5wdXQiLCJmcm9tIiwic3RhcnQiLCJsaW5lIiwiY29sdW1uIiwid2Fsa0RlY2xzIiwicHJvcCIsInR5cGUiLCJSZWdFeHAiLCJ3YWxrUnVsZXMiLCJzZWxlY3RvciIsIndhbGtBdFJ1bGVzIiwibmFtZSIsIndhbGtDb21tZW50cyIsImFwcGVuZCIsImNoaWxkcmVuIiwibm9ybWFsaXplIiwibGFzdCIsIm5vZGUiLCJwcmVwZW5kIiwicmV2ZXJzZSIsImZpcnN0IiwidW5zaGlmdCIsImNsZWFuUmF3cyIsImtlZXBCZXR3ZWVuIiwiaW5zZXJ0QmVmb3JlIiwiZXhpc3QiLCJhZGQiLCJzcGxpY2UiLCJpbnNlcnRBZnRlciIsInJlbW92ZUNoaWxkIiwicmVtb3ZlQWxsIiwicmVwbGFjZVZhbHVlcyIsInBhdHRlcm4iLCJvcHRzIiwiZGVjbCIsInByb3BzIiwiaW5kZXhPZiIsImZhc3QiLCJ2YWx1ZSIsImV2ZXJ5IiwiY29uZGl0aW9uIiwic29tZSIsInNhbXBsZSIsInBhcnNlIiwicmVxdWlyZSIsIkFycmF5IiwiaXNBcnJheSIsInNsaWNlIiwiRXJyb3IiLCJTdHJpbmciLCJEZWNsYXJhdGlvbiIsIlJ1bGUiLCJBdFJ1bGUiLCJ0ZXh0IiwiQ29tbWVudCIsInByb2Nlc3NlZCIsInJhd3MiLCJiZWZvcmUiLCJOb2RlIl0sIm1hcHBpbmdzIjoiOzs7OztBQUFBOztBQUNBOztBQUNBOzs7Ozs7Ozs7O0FBRUEsU0FBU0EsV0FBVCxDQUFz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QVA7QUFDakIsYUFBTyxLQUFLYixLQUFMLENBQVcsQ0FBWCxDQUFQO0FBQ0Q7QUFFRDs7Ozs7Ozs7Ozs7d0JBUVk7QUFDVixVQUFJLENBQUMsS0FBS0EsS0FBVixFQUFpQixPQUFPYSxTQUFQO0FBQ2pCLGFBQU8sS0FBS2IsS0FBTCxDQUFXLEtBQUtBLEtBQUwsQ0FBV2dCLE1BQVgsR0FBb0IsQ0FBL0IsQ0FBUDtBQUNEOzs7O0VBaGpCcUJtRSxhOztlQSttQlQvRSxTO0FBRWY7Ozs7Ozs7O0FBUUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgRGVjbGFyYXRpb24gZnJvbSAnLi9kZWNsYXJhdGlvbidcbmltcG9ydCBDb21tZW50IGZyb20gJy4vY29tbWVudCdcbmltcG9ydCBOb2RlIGZyb20gJy4vbm9kZSdcblxuZnVuY3Rpb24gY2xlYW5Tb3VyY2UgKG5vZGVzKSB7XG4gIHJldHVybiBub2Rlcy5tYXAoaSA9PiB7XG4gICAgaWYgKGkubm9kZXMpIGkubm9kZXMgPSBjbGVhblNvdXJjZShpLm5vZGVzKVxuICAgIGRlbGV0ZSBpLnNvdXJjZVxuICAgIHJldHVybiBpXG4gIH0pXG59XG5cbi8qKlxuICogVGhlIHtAbGluayBSb290fSwge0BsaW5rIEF0UnVsZX0sIGFuZCB7QGxpbmsgUnVsZX0gY29udGFpbmVyIG5vZGVzXG4gKiBpbmhlcml0IHNvbWUgY29tbW9uIG1ldGhvZHMgdG8gaGVscCB3b3JrIHdpdGggdGhlaXIgY2hpbGRyZW4uXG4gKlxuICogTm90ZSB0aGF0IGFsbCBjb250YWluZXJzIGNhbiBzdG9yZSBhbnkgY29udGVudC4gSWYgeW91IHdyaXRlIGEgcnVsZSBpbnNpZGVcbiAqIGEgcnVsZSwgUG9zdENTUyB3aWxsIHBhcnNlIGl0LlxuICpcbiAqIEBleHRlbmRzIE5vZGVcbiAqIEBhYnN0cmFjdFxuICovXG5jbGFzcyBDb250YWluZXIgZXh0ZW5kcyBOb2RlIHtcbiAgcHVzaCAoY2hpbGQpIHtcbiAgICBjaGlsZC5wYXJlbnQgPSB0aGlzXG4gICAgdGhpcy5ub2Rlcy5wdXNoKGNoaWxkKVxuICAgIHJldHVybiB0aGlzXG4gIH1cblxuICAvKipcbiAgICogSXRlcmF0ZXMgdGhyb3VnaCB0aGUgY29udGFpbmVy4oCZcyBpbW1lZGlhdGUgY2hpbGRyZW4sXG4gICAqIGNhbGxpbmcgYGNhbGxiYWNrYCBmb3IgZWFjaCBjaGlsZC5cbiAgICpcbiAgICogUmV0dXJuaW5nIGBmYWxzZWAgaW4gdGhlIGNhbGxiYWNrIHdpbGwgYnJlYWsgaXRlcmF0aW9uLlxuICAgKlxuICAgKiBUaGlzIG1ldGhvZCBvbmx5IGl0ZXJhdGVzIHRocm91Z2ggdGhlIGNvbnRhaW5lcuKAmXMgaW1tZWRpYXRlIGNoaWxkcmVuLlxuICAgKiBJZiB5b3UgbmVlZCB0byByZWN1cnNpdmVseSBpdGVyYXRlIHRocm91Z2ggYWxsIHRoZSBjb250YWluZXLigJlzIGRlc2NlbmRhbnRcbiAgICogbm9kZXMsIHVzZSB7QGxpbmsgQ29udGFpbmVyI3dhbGt9LlxuICAgKlxuICAgKiBVbmxpa2UgdGhlIGZvciBge31gLWN5Y2xlIG9yIGBBcnJheSNmb3JFYWNoYCB0aGlzIGl0ZXJhdG9yIGlzIHNhZmVcbiAgICogaWYgeW91IGFyZSBtdXRhdGluZyB0aGUgYXJyYXkgb2YgY2hpbGQgbm9kZXMgZHVyaW5nIGl0ZXJhdGlvbi5cbiAgICogUG9zdENTUyB3aWxsIGFkanVzdCB0aGUgY3VycmVudCBpbmRleCB0byBtYXRjaCB0aGUgbXV0YXRpb25zLlxuICAgKlxuICAgKiBAcGFyYW0ge2NoaWxkSXRlcmF0b3J9IGNhbGxiYWNrIEl0ZXJhdG9yIHJlY2VpdmVzIGVhY2ggbm9kZSBhbmQgaW5kZXguXG4gICAqXG4gICAqIEByZXR1cm4ge2ZhbHNlfHVuZGVmaW5lZH0gUmV0dXJucyBgZmFsc2VgIGlmIGl0ZXJhdGlvbiB3YXMgYnJva2UuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGNvbnN0IHJvb3QgPSBwb3N0Y3NzLnBhcnNlKCdhIHsgY29sb3I6IGJsYWNrOyB6LWluZGV4OiAxIH0nKVxuICAgKiBjb25zdCBydWxlID0gcm9vdC5maXJzdFxuICAgKlxuICAgKiBmb3IgKGNvbnN0IGRlY2wgb2YgcnVsZS5ub2Rlcykge1xuICAgKiAgIGRlY2wuY2xvbmVCZWZvcmUoeyBwcm9wOiAnLXdlYmtpdC0nICsgZGVjbC5wcm9wIH0pXG4gICAqICAgLy8gQ3ljbGUgd2lsbCBiZSBpbmZpbml0ZSwgYmVjYXVzZSBjbG9uZUJlZm9yZSBtb3ZlcyB0aGUgY3VycmVudCBub2RlXG4gICAqICAgLy8gdG8gdGhlIG5leHQgaW5kZXhcbiAgICogfVxuICAgKlxuICAgKiBydWxlLmVhY2goZGVjbCA9PiB7XG4gICAqICAgZGVjbC5jbG9uZUJlZm9yZSh7IHByb3A6ICctd2Via2l0LScgKyBkZWNsLnByb3AgfSlcbiAgICogICAvLyBXaWxsIGJlIGV4ZWN1dGVkIG9ubHkgZm9yIGNvbG9yIGFuZCB6LWluZGV4XG4gICAqIH0pXG4gICAqL1xuICBlYWNoIChjYWxsYmFjaykge1xuICAgIGlmICghdGhpcy5sYXN0RWFjaCkgdGhpcy5sYXN0RWFjaCA9IDBcbiAgICBpZiAoIXRoaXMuaW5kZXhlcykgdGhpcy5pbmRleGVzID0geyB9XG5cbiAgICB0aGlzLmxhc3RFYWNoICs9IDFcbiAgICBsZXQgaWQgPSB0aGlzLmxhc3RFYWNoXG4gICAgdGhpcy5pbmRleGVzW2lkXSA9IDBcblxuICAgIGlmICghdGhpcy5ub2RlcykgcmV0dXJuIHVuZGVmaW5lZFxuXG4gICAgbGV0IGluZGV4LCByZXN1bHRcbiAgICB3aGlsZSAodGhpcy5pbmRleGVzW2lkXSA8IHRoaXMubm9kZXMubGVuZ3RoKSB7XG4gICAgICBpbmRleCA9IHRoaXMuaW5kZXhlc1tpZF1cbiAgICAgIHJlc3VsdCA9IGNhbGxiYWNrKHRoaXMubm9kZXNbaW5kZXhdLCBpbmRleClcbiAgICAgIGlmIChyZXN1bHQgPT09IGZhbHNlKSBicmVha1xuXG4gICAgICB0aGlzLmluZGV4ZXNbaWRdICs9IDFcbiAgICB9XG5cbiAgICBkZWxldGUgdGhpcy5pbmRleGVzW2lkXVxuXG4gICAgcmV0dXJuIHJlc3VsdFxuICB9XG5cbiAgLyoqXG4gICAqIFRyYXZlcnNlcyB0aGUgY29udGFpbmVy4oCZcyBkZXNjZW5kYW50IG5vZGVzLCBjYWxsaW5nIGNhbGxiYWNrXG4gICAqIGZvciBlYWNoIG5vZGUuXG4gICAqXG4gICAqIExpa2UgY29udGFpbmVyLmVhY2goKSwgdGhpcyBtZXRob2QgaXMgc2FmZSB0byB1c2VcbiAgICogaWYgeW91IGFyZSBtdXRhdGluZyBhcnJheXMgZHVyaW5nIGl0ZXJhdGlvbi5cbiAgICpcbiAgICogSWYgeW91IG9ubHkgbmVlZCB0byBpdGVyYXRlIHRocm91Z2ggdGhlIGNvbnRhaW5lcuKAmXMgaW1tZWRpYXRlIGNoaWxkcmVuLFxuICAgKiB1c2Uge0BsaW5rIENvbnRhaW5lciNlYWNofS5cbiAgICpcbiAgICogQHBhcmFtIHtjaGlsZEl0ZXJhdG9yfSBjYWxsYmFjayBJdGVyYXRvciByZWNlaXZlcyBlYWNoIG5vZGUgYW5kIGluZGV4LlxuICAgKlxuICAgKiBAcmV0dXJuIHtmYWxzZXx1bmRlZmluZWR9IFJldHVybnMgYGZhbHNlYCBpZiBpdGVyYXRpb24gd2FzIGJyb2tlLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiByb290LndhbGsobm9kZSA9PiB7XG4gICAqICAgLy8gVHJhdmVyc2VzIGFsbCBkZXNjZW5kYW50IG5vZGVzLlxuICAgKiB9KVxuICAgKi9cbiAgd2FsayAoY2FsbGJhY2spIHtcbiAgICByZXR1cm4gdGhpcy5lYWNoKChjaGlsZCwgaSkgPT4ge1xuICAgICAgbGV0IHJlc3VsdFxuICAgICAgdHJ5IHtcbiAgICAgICAgcmVzdWx0ID0gY2FsbGJhY2soY2hpbGQsIGkpXG4gICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIGUucG9zdGNzc05vZGUgPSBjaGlsZFxuICAgICAgICBpZiAoZS5zdGFjayAmJiBjaGlsZC5zb3VyY2UgJiYgL1xcblxcc3s0fWF0IC8udGVzdChlLnN0YWNrKSkge1xuICAgICAgICAgIGxldCBzID0gY2hpbGQuc291cmNlXG4gICAgICAgICAgZS5zdGFjayA9IGUuc3RhY2sucmVwbGFjZSgvXFxuXFxzezR9YXQgLyxcbiAgICAgICAgICAgIGAkJiR7IHMuaW5wdXQuZnJvbSB9OiR7IHMuc3RhcnQubGluZSB9OiR7IHMuc3RhcnQuY29sdW1uIH0kJmApXG4gICAgICAgIH1cbiAgICAgICAgdGhyb3cgZVxuICAgICAgfVxuICAgICAgaWYgKHJlc3VsdCAhPT0gZmFsc2UgJiYgY2hpbGQud2Fsaykge1xuICAgICAgICByZXN1bHQgPSBjaGlsZC53YWxrKGNhbGxiYWNrKVxuICAgICAgfVxuICAgICAgcmV0dXJuIHJlc3VsdFxuICAgIH0pXG4gIH1cblxuICAvKipcbiAgICogVHJhdmVyc2VzIHRoZSBjb250YWluZXLigJlzIGRlc2NlbmRhbnQgbm9kZXMsIGNhbGxpbmcgY2FsbGJhY2tcbiAgICogZm9yIGVhY2ggZGVjbGFyYXRpb24gbm9kZS5cbiAgICpcbiAgICogSWYgeW91IHBhc3MgYSBmaWx0ZXIsIGl0ZXJhdGlvbiB3aWxsIG9ubHkgaGFwcGVuIG92ZXIgZGVjbGFyYXRpb25zXG4gICAqIHdpdGggbWF0Y2hpbmcgcHJvcGVydGllcy5cbiAgICpcbiAgICogTGlrZSB7QGxpbmsgQ29udGFpbmVyI2VhY2h9LCB0aGlzIG1ldGhvZCBpcyBzYWZlXG4gICAqIHRvIHVzZSBpZiB5b3UgYXJlIG11dGF0aW5nIGFycmF5cyBkdXJpbmcgaXRlcmF0aW9uLlxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ3xSZWdFeHB9IFtwcm9wXSAgIFN0cmluZyBvciByZWd1bGFyIGV4cHJlc3Npb25cbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0byBmaWx0ZXIgZGVjbGFyYXRpb25zIGJ5IHByb3BlcnR5IG5hbWUuXG4gICAqIEBwYXJhbSB7Y2hpbGRJdGVyYXRvcn0gY2FsbGJhY2sgSXRlcmF0b3IgcmVjZWl2ZXMgZWFjaCBub2RlIGFuZCBpbmRleC5cbiAgICpcbiAgICogQHJldHVybiB7ZmFsc2V8dW5kZWZpbmVkfSBSZXR1cm5zIGBmYWxzZWAgaWYgaXRlcmF0aW9uIHdhcyBicm9rZS5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcm9vdC53YWxrRGVjbHMoZGVjbCA9PiB7XG4gICAqICAgY2hlY2tQcm9wZXJ0eVN1cHBvcnQoZGVjbC5wcm9wKVxuICAgKiB9KVxuICAgKlxuICAgKiByb290LndhbGtEZWNscygnYm9yZGVyLXJhZGl1cycsIGRlY2wgPT4ge1xuICAgKiAgIGRlY2wucmVtb3ZlKClcbiAgICogfSlcbiAgICpcbiAgICogcm9vdC53YWxrRGVjbHMoL15iYWNrZ3JvdW5kLywgZGVjbCA9PiB7XG4gICAqICAgZGVjbC52YWx1ZSA9IHRha2VGaXJzdENvbG9yRnJvbUdyYWRpZW50KGRlY2wudmFsdWUpXG4gICAqIH0pXG4gICAqL1xuICB3YWxrRGVjbHMgKHByb3AsIGNhbGxiYWNrKSB7XG4gICAgaWYgKCFjYWxsYmFjaykge1xuICAgICAgY2FsbGJhY2sgPSBwcm9wXG4gICAgICByZXR1cm4gdGhpcy53YWxrKChjaGlsZCwgaSkgPT4ge1xuICAgICAgICBpZiAoY2hpbGQudHlwZSA9PT0gJ2RlY2wnKSB7XG4gICAgICAgICAgcmV0dXJuIGNhbGxiYWNrKGNoaWxkLCBpKVxuICAgICAgICB9XG4gICAgICB9KVxuICAgIH1cbiAgICBpZiAocHJvcCBpbnN0YW5jZW9mIFJlZ0V4cCkge1xuICAgICAgcmV0dXJuIHRoaXMud2FsaygoY2hpbGQsIGkpID0+IHtcbiAgICAgICAgaWYgKGNoaWxkLnR5cGUgPT09ICdkZWNsJyAmJiBwcm9wLnRlc3QoY2hpbGQucHJvcCkpIHtcbiAgICAgICAgICByZXR1cm4gY2FsbGJhY2soY2hpbGQsIGkpXG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfVxuICAgIHJldHVybiB0aGlzLndhbGsoKGNoaWxkLCBpKSA9PiB7XG4gICAgICBpZiAoY2hpbGQudHlwZSA9PT0gJ2RlY2wnICYmIGNoaWxkLnByb3AgPT09IHByb3ApIHtcbiAgICAgICAgcmV0dXJuIGNhbGxiYWNrKGNoaWxkLCBpKVxuICAgICAgfVxuICAgIH0pXG4gIH1cblxuICAvKipcbiAgICogVHJhdmVyc2VzIHRoZSBjb250YWluZXLigJlzIGRlc2NlbmRhbnQgbm9kZXMsIGNhbGxpbmcgY2FsbGJhY2tcbiAgICogZm9yIGVhY2ggcnVsZSBub2RlLlxuICAgKlxuICAgKiBJZiB5b3UgcGFzcyBhIGZpbHRlciwgaXRlcmF0aW9uIHdpbGwgb25seSBoYXBwZW4gb3ZlciBydWxlc1xuICAgKiB3aXRoIG1hdGNoaW5nIHNlbGVjdG9ycy5cbiAgICpcbiAgICogTGlrZSB7QGxpbmsgQ29udGFpbmVyI2VhY2h9LCB0aGlzIG1ldGhvZCBpcyBzYWZlXG4gICAqIHRvIHVzZSBpZiB5b3UgYXJlIG11dGF0aW5nIGFycmF5cyBkdXJpbmcgaXRlcmF0aW9uLlxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ3xSZWdFeHB9IFtzZWxlY3Rvcl0gU3RyaW5nIG9yIHJlZ3VsYXIgZXhwcmVzc2lvblxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdG8gZmlsdGVyIHJ1bGVzIGJ5IHNlbGVjdG9yLlxuICAgKiBAcGFyYW0ge2NoaWxkSXRlcmF0b3J9IGNhbGxiYWNrICAgSXRlcmF0b3IgcmVjZWl2ZXMgZWFjaCBub2RlIGFuZCBpbmRleC5cbiAgICpcbiAgICogQHJldHVybiB7ZmFsc2V8dW5kZWZpbmVkfSByZXR1cm5zIGBmYWxzZWAgaWYgaXRlcmF0aW9uIHdhcyBicm9rZS5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgc2VsZWN0b3JzID0gW11cbiAgICogcm9vdC53YWxrUnVsZXMocnVsZSA9PiB7XG4gICAqICAgc2VsZWN0b3JzLnB1c2gocnVsZS5zZWxlY3RvcilcbiAgICogfSlcbiAgICogY29uc29sZS5sb2coYFlvdXIgQ1NTIHVzZXMgJHsgc2VsZWN0b3JzLmxlbmd0aCB9IHNlbGVjdG9yc2ApXG4gICAqL1xuICB3YWxrUnVsZXMgKHNlbGVjdG9yLCBjYWxsYmFjaykge1xuICAgIGlmICghY2FsbGJhY2spIHtcbiAgICAgIGNhbGxiYWNrID0gc2VsZWN0b3JcblxuICAgICAgcmV0dXJuIHRoaXMud2FsaygoY2hpbGQsIGkpID0+IHtcbiAgICAgICAgaWYgKGNoaWxkLnR5cGUgPT09ICdydWxlJykge1xuICAgICAgICAgIHJldHVybiBjYWxsYmFjayhjaGlsZCwgaSlcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICB9XG4gICAgaWYgKHNlbGVjdG9yIGluc3RhbmNlb2YgUmVnRXhwKSB7XG4gICAgICByZXR1cm4gdGhpcy53YWxrKChjaGlsZCwgaSkgPT4ge1xuICAgICAgICBpZiAoY2hpbGQudHlwZSA9PT0gJ3J1bGUnICYmIHNlbGVjdG9yLnRlc3QoY2hpbGQuc2VsZWN0b3IpKSB7XG4gICAgICAgICAgcmV0dXJuIGNhbGxiYWNrKGNoaWxkLCBpKVxuICAgICAgICB9XG4gICAgICB9KVxuICAgIH1cbiAgICByZXR1cm4gdGhpcy53YWxrKChjaGlsZCwgaSkgPT4ge1xuICAgICAgaWYgKGNoaWxkLnR5cGUgPT09ICdydWxlJyAmJiBjaGlsZC5zZWxlY3RvciA9PT0gc2VsZWN0b3IpIHtcbiAgICAgICAgcmV0dXJuIGNhbGxiYWNrKGNoaWxkLCBpKVxuICAgICAgfVxuICAgIH0pXG4gIH1cblxuICAvKipcbiAgICogVHJhdmVyc2VzIHRoZSBjb250YWluZXLigJlzIGRlc2NlbmRhbnQgbm9kZXMsIGNhbGxpbmcgY2FsbGJhY2tcbiAgICogZm9yIGVhY2ggYXQtcnVsZSBub2RlLlxuICAgKlxuICAgKiBJZiB5b3UgcGFzcyBhIGZpbHRlciwgaXRlcmF0aW9uIHdpbGwgb25seSBoYXBwZW4gb3ZlciBhdC1ydWxlc1xuICAgKiB0aGF0IGhhdmUgbWF0Y2hpbmcgbmFtZXMuXG4gICAqXG4gICAqIExpa2Uge0BsaW5rIENvbnRhaW5lciNlYWNofSwgdGhpcyBtZXRob2QgaXMgc2FmZVxuICAgKiB0byB1c2UgaWYgeW91IGFyZSBtdXRhdGluZyBhcnJheXMgZHVyaW5nIGl0ZXJhdGlvbi5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd8UmVnRXhwfSBbbmFtZV0gICBTdHJpbmcgb3IgcmVndWxhciBleHByZXNzaW9uXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdG8gZmlsdGVyIGF0LXJ1bGVzIGJ5IG5hbWUuXG4gICAqIEBwYXJhbSB7Y2hpbGRJdGVyYXRvcn0gY2FsbGJhY2sgSXRlcmF0b3IgcmVjZWl2ZXMgZWFjaCBub2RlIGFuZCBpbmRleC5cbiAgICpcbiAgICogQHJldHVybiB7ZmFsc2V8dW5kZWZpbmVkfSBSZXR1cm5zIGBmYWxzZWAgaWYgaXRlcmF0aW9uIHdhcyBicm9rZS5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcm9vdC53YWxrQXRSdWxlcyhydWxlID0+IHtcbiAgICogICBpZiAoaXNPbGQocnVsZS5uYW1lKSkgcnVsZS5yZW1vdmUoKVxuICAgKiB9KVxuICAgKlxuICAgKiBsZXQgZmlyc3QgPSBmYWxzZVxuICAgKiByb290LndhbGtBdFJ1bGVzKCdjaGFyc2V0JywgcnVsZSA9PiB7XG4gICAqICAgaWYgKCFmaXJzdCkge1xuICAgKiAgICAgZmlyc3QgPSB0cnVlXG4gICAqICAgfSBlbHNlIHtcbiAgICogICAgIHJ1bGUucmVtb3ZlKClcbiAgICogICB9XG4gICAqIH0pXG4gICAqL1xuICB3YWxrQXRSdWxlcyAobmFtZSwgY2FsbGJhY2spIHtcbiAgICBpZiAoIWNhbGxiYWNrKSB7XG4gICAgICBjYWxsYmFjayA9IG5hbWVcbiAgICAgIHJldHVybiB0aGlzLndhbGsoKGNoaWxkLCBpKSA9PiB7XG4gICAgICAgIGlmIChjaGlsZC50eXBlID09PSAnYXRydWxlJykge1xuICAgICAgICAgIHJldHVybiBjYWxsYmFjayhjaGlsZCwgaSlcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICB9XG4gICAgaWYgKG5hbWUgaW5zdGFuY2VvZiBSZWdFeHApIHtcbiAgICAgIHJldHVybiB0aGlzLndhbGsoKGNoaWxkLCBpKSA9PiB7XG4gICAgICAgIGlmIChjaGlsZC50eXBlID09PSAnYXRydWxlJyAmJiBuYW1lLnRlc3QoY2hpbGQubmFtZSkpIHtcbiAgICAgICAgICByZXR1cm4gY2FsbGJhY2soY2hpbGQsIGkpXG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfVxuICAgIHJldHVybiB0aGlzLndhbGsoKGNoaWxkLCBpKSA9PiB7XG4gICAgICBpZiAoY2hpbGQudHlwZSA9PT0gJ2F0cnVsZScgJiYgY2hpbGQubmFtZSA9PT0gbmFtZSkge1xuICAgICAgICByZXR1cm4gY2FsbGJhY2soY2hpbGQsIGkpXG4gICAgICB9XG4gICAgfSlcbiAgfVxuXG4gIC8qKlxuICAgKiBUcmF2ZXJzZXMgdGhlIGNvbnRhaW5lcuKAmXMgZGVzY2VuZGFudCBub2RlcywgY2FsbGluZyBjYWxsYmFja1xuICAgKiBmb3IgZWFjaCBjb21tZW50IG5vZGUuXG4gICAqXG4gICAqIExpa2Uge0BsaW5rIENvbnRhaW5lciNlYWNofSwgdGhpcyBtZXRob2QgaXMgc2FmZVxuICAgKiB0byB1c2UgaWYgeW91IGFyZSBtdXRhdGluZyBhcnJheXMgZHVyaW5nIGl0ZXJhdGlvbi5cbiAgICpcbiAgICogQHBhcmFtIHtjaGlsZEl0ZXJhdG9yfSBjYWxsYmFjayBJdGVyYXRvciByZWNlaXZlcyBlYWNoIG5vZGUgYW5kIGluZGV4LlxuICAgKlxuICAgKiBAcmV0dXJuIHtmYWxzZXx1bmRlZmluZWR9IFJldHVybnMgYGZhbHNlYCBpZiBpdGVyYXRpb24gd2FzIGJyb2tlLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiByb290LndhbGtDb21tZW50cyhjb21tZW50ID0+IHtcbiAgICogICBjb21tZW50LnJlbW92ZSgpXG4gICAqIH0pXG4gICAqL1xuICB3YWxrQ29tbWVudHMgKGNhbGxiYWNrKSB7XG4gICAgcmV0dXJuIHRoaXMud2FsaygoY2hpbGQsIGkpID0+IHtcbiAgICAgIGlmIChjaGlsZC50eXBlID09PSAnY29tbWVudCcpIHtcbiAgICAgICAgcmV0dXJuIGNhbGxiYWNrKGNoaWxkLCBpKVxuICAgICAgfVxuICAgIH0pXG4gIH1cblxuICAvKipcbiAgICogSW5zZXJ0cyBuZXcgbm9kZXMgdG8gdGhlIGVuZCBvZiB0aGUgY29udGFpbmVyLlxuICAgKlxuICAgKiBAcGFyYW0gey4uLihOb2RlfG9iamVjdHxzdHJpbmd8Tm9kZVtdKX0gY2hpbGRyZW4gTmV3IG5vZGVzLlxuICAgKlxuICAgKiBAcmV0dXJuIHtOb2RlfSBUaGlzIG5vZGUgZm9yIG1ldGhvZHMgY2hhaW4uXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGNvbnN0IGRlY2wxID0gcG9zdGNzcy5kZWNsKHsgcHJvcDogJ2NvbG9yJywgdmFsdWU6ICdibGFjaycgfSlcbiAgICogY29uc3QgZGVjbDIgPSBwb3N0Y3NzLmRlY2woeyBwcm9wOiAnYmFja2dyb3VuZC1jb2xvcicsIHZhbHVlOiAnd2hpdGUnIH0pXG4gICAqIHJ1bGUuYXBwZW5kKGRlY2wxLCBkZWNsMilcbiAgICpcbiAgICogcm9vdC5hcHBlbmQoeyBuYW1lOiAnY2hhcnNldCcsIHBhcmFtczogJ1wiVVRGLThcIicgfSkgIC8vIGF0LXJ1bGVcbiAgICogcm9vdC5hcHBlbmQoeyBzZWxlY3RvcjogJ2EnIH0pICAgICAgICAgICAgICAgICAgICAgICAvLyBydWxlXG4gICAqIHJ1bGUuYXBwZW5kKHsgcHJvcDogJ2NvbG9yJywgdmFsdWU6ICdibGFjaycgfSkgICAgICAgLy8gZGVjbGFyYXRpb25cbiAgICogcnVsZS5hcHBlbmQoeyB0ZXh0OiAnQ29tbWVudCcgfSkgICAgICAgICAgICAgICAgICAgICAvLyBjb21tZW50XG4gICAqXG4gICAqIHJvb3QuYXBwZW5kKCdhIHt9JylcbiAgICogcm9vdC5maXJzdC5hcHBlbmQoJ2NvbG9yOiBibGFjazsgei1pbmRleDogMScpXG4gICAqL1xuICBhcHBlbmQgKC4uLmNoaWxkcmVuKSB7XG4gICAgZm9yIChsZXQgY2hpbGQgb2YgY2hpbGRyZW4pIHtcbiAgICAgIGxldCBub2RlcyA9IHRoaXMubm9ybWFsaXplKGNoaWxkLCB0aGlzLmxhc3QpXG4gICAgICBmb3IgKGxldCBub2RlIG9mIG5vZGVzKSB0aGlzLm5vZGVzLnB1c2gobm9kZSlcbiAgICB9XG4gICAgcmV0dXJuIHRoaXNcbiAgfVxuXG4gIC8qKlxuICAgKiBJbnNlcnRzIG5ldyBub2RlcyB0byB0aGUgc3RhcnQgb2YgdGhlIGNvbnRhaW5lci5cbiAgICpcbiAgICogQHBhcmFtIHsuLi4oTm9kZXxvYmplY3R8c3RyaW5nfE5vZGVbXSl9IGNoaWxkcmVuIE5ldyBub2Rlcy5cbiAgICpcbiAgICogQHJldHVybiB7Tm9kZX0gVGhpcyBub2RlIGZvciBtZXRob2RzIGNoYWluLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBjb25zdCBkZWNsMSA9IHBvc3Rjc3MuZGVjbCh7IHByb3A6ICdjb2xvcicsIHZhbHVlOiAnYmxhY2snIH0pXG4gICAqIGNvbnN0IGRlY2wyID0gcG9zdGNzcy5kZWNsKHsgcHJvcDogJ2JhY2tncm91bmQtY29sb3InLCB2YWx1ZTogJ3doaXRlJyB9KVxuICAgKiBydWxlLnByZXBlbmQoZGVjbDEsIGRlY2wyKVxuICAgKlxuICAgKiByb290LmFwcGVuZCh7IG5hbWU6ICdjaGFyc2V0JywgcGFyYW1zOiAnXCJVVEYtOFwiJyB9KSAgLy8gYXQtcnVsZVxuICAgKiByb290LmFwcGVuZCh7IHNlbGVjdG9yOiAnYScgfSkgICAgICAgICAgICAgICAgICAgICAgIC8vIHJ1bGVcbiAgICogcnVsZS5hcHBlbmQoeyBwcm9wOiAnY29sb3InLCB2YWx1ZTogJ2JsYWNrJyB9KSAgICAgICAvLyBkZWNsYXJhdGlvblxuICAgKiBydWxlLmFwcGVuZCh7IHRleHQ6ICdDb21tZW50JyB9KSAgICAgICAgICAgICAgICAgICAgIC8vIGNvbW1lbnRcbiAgICpcbiAgICogcm9vdC5hcHBlbmQoJ2Ege30nKVxuICAgKiByb290LmZpcnN0LmFwcGVuZCgnY29sb3I6IGJsYWNrOyB6LWluZGV4OiAxJylcbiAgICovXG4gIHByZXBlbmQgKC4uLmNoaWxkcmVuKSB7XG4gICAgY2hpbGRyZW4gPSBjaGlsZHJlbi5yZXZlcnNlKClcbiAgICBmb3IgKGxldCBjaGlsZCBvZiBjaGlsZHJlbikge1xuICAgICAgbGV0IG5vZGVzID0gdGhpcy5ub3JtYWxpemUoY2hpbGQsIHRoaXMuZmlyc3QsICdwcmVwZW5kJykucmV2ZXJzZSgpXG4gICAgICBmb3IgKGxldCBub2RlIG9mIG5vZGVzKSB0aGlzLm5vZGVzLnVuc2hpZnQobm9kZSlcbiAgICAgIGZvciAobGV0IGlkIGluIHRoaXMuaW5kZXhlcykge1xuICAgICAgICB0aGlzLmluZGV4ZXNbaWRdID0gdGhpcy5pbmRleGVzW2lkXSArIG5vZGVzLmxlbmd0aFxuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdGhpc1xuICB9XG5cbiAgY2xlYW5SYXdzIChrZWVwQmV0d2Vlbikge1xuICAgIHN1cGVyLmNsZWFuUmF3cyhrZWVwQmV0d2VlbilcbiAgICBpZiAodGhpcy5ub2Rlcykge1xuICAgICAgZm9yIChsZXQgbm9kZSBvZiB0aGlzLm5vZGVzKSBub2RlLmNsZWFuUmF3cyhrZWVwQmV0d2VlbilcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogSW5zZXJ0IG5ldyBub2RlIGJlZm9yZSBvbGQgbm9kZSB3aXRoaW4gdGhlIGNvbnRhaW5lci5cbiAgICpcbiAgICogQHBhcmFtIHtOb2RlfG51bWJlcn0gZXhpc3QgICAgICAgICAgICAgQ2hpbGQgb3IgY2hpbGTigJlzIGluZGV4LlxuICAgKiBAcGFyYW0ge05vZGV8b2JqZWN0fHN0cmluZ3xOb2RlW119IGFkZCBOZXcgbm9kZS5cbiAgICpcbiAgICogQHJldHVybiB7Tm9kZX0gVGhpcyBub2RlIGZvciBtZXRob2RzIGNoYWluLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBydWxlLmluc2VydEJlZm9yZShkZWNsLCBkZWNsLmNsb25lKHsgcHJvcDogJy13ZWJraXQtJyArIGRlY2wucHJvcCB9KSlcbiAgICovXG4gIGluc2VydEJlZm9yZSAoZXhpc3QsIGFkZCkge1xuICAgIGV4aXN0ID0gdGhpcy5pbmRleChleGlzdClcblxuICAgIGxldCB0eXBlID0gZXhpc3QgPT09IDAgPyAncHJlcGVuZCcgOiBmYWxzZVxuICAgIGxldCBub2RlcyA9IHRoaXMubm9ybWFsaXplKGFkZCwgdGhpcy5ub2Rlc1tleGlzdF0sIHR5cGUpLnJldmVyc2UoKVxuICAgIGZvciAobGV0IG5vZGUgb2Ygbm9kZXMpIHRoaXMubm9kZXMuc3BsaWNlKGV4aXN0LCAwLCBub2RlKVxuXG4gICAgbGV0IGluZGV4XG4gICAgZm9yIChsZXQgaWQgaW4gdGhpcy5pbmRleGVzKSB7XG4gICAgICBpbmRleCA9IHRoaXMuaW5kZXhlc1tpZF1cbiAgICAgIGlmIChleGlzdCA8PSBpbmRleCkge1xuICAgICAgICB0aGlzLmluZGV4ZXNbaWRdID0gaW5kZXggKyBub2Rlcy5sZW5ndGhcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gdGhpc1xuICB9XG5cbiAgLyoqXG4gICAqIEluc2VydCBuZXcgbm9kZSBhZnRlciBvbGQgbm9kZSB3aXRoaW4gdGhlIGNvbnRhaW5lci5cbiAgICpcbiAgICogQHBhcmFtIHtOb2RlfG51bWJlcn0gZXhpc3QgICAgICAgICAgICAgQ2hpbGQgb3IgY2hpbGTigJlzIGluZGV4LlxuICAgKiBAcGFyYW0ge05vZGV8b2JqZWN0fHN0cmluZ3xOb2RlW119IGFkZCBOZXcgbm9kZS5cbiAgICpcbiAgICogQHJldHVybiB7Tm9kZX0gVGhpcyBub2RlIGZvciBtZXRob2RzIGNoYWluLlxuICAgKi9cbiAgaW5zZXJ0QWZ0ZXIgKGV4aXN0LCBhZGQpIHtcbiAgICBleGlzdCA9IHRoaXMuaW5kZXgoZXhpc3QpXG5cbiAgICBsZXQgbm9kZXMgPSB0aGlzLm5vcm1hbGl6ZShhZGQsIHRoaXMubm9kZXNbZXhpc3RdKS5yZXZlcnNlKClcbiAgICBmb3IgKGxldCBub2RlIG9mIG5vZGVzKSB0aGlzLm5vZGVzLnNwbGljZShleGlzdCArIDEsIDAsIG5vZGUpXG5cbiAgICBsZXQgaW5kZXhcbiAgICBmb3IgKGxldCBpZCBpbiB0aGlzLmluZGV4ZXMpIHtcbiAgICAgIGluZGV4ID0gdGhpcy5pbmRleGVzW2lkXVxuICAgICAgaWYgKGV4aXN0IDwgaW5kZXgpIHtcbiAgICAgICAgdGhpcy5pbmRleGVzW2lkXSA9IGluZGV4ICsgbm9kZXMubGVuZ3RoXG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXNcbiAgfVxuXG4gIC8qKlxuICAgKiBSZW1vdmVzIG5vZGUgZnJvbSB0aGUgY29udGFpbmVyIGFuZCBjbGVhbnMgdGhlIHBhcmVudCBwcm9wZXJ0aWVzXG4gICAqIGZyb20gdGhlIG5vZGUgYW5kIGl0cyBjaGlsZHJlbi5cbiAgICpcbiAgICogQHBhcmFtIHtOb2RlfG51bWJlcn0gY2hpbGQgQ2hpbGQgb3IgY2hpbGTigJlzIGluZGV4LlxuICAgKlxuICAgKiBAcmV0dXJuIHtOb2RlfSBUaGlzIG5vZGUgZm9yIG1ldGhvZHMgY2hhaW5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcnVsZS5ub2Rlcy5sZW5ndGggIC8vPT4gNVxuICAgKiBydWxlLnJlbW92ZUNoaWxkKGRlY2wpXG4gICAqIHJ1bGUubm9kZXMubGVuZ3RoICAvLz0+IDRcbiAgICogZGVjbC5wYXJlbnQgICAgICAgIC8vPT4gdW5kZWZpbmVkXG4gICAqL1xuICByZW1vdmVDaGlsZCAoY2hpbGQpIHtcbiAgICBjaGlsZCA9IHRoaXMuaW5kZXgoY2hpbGQpXG4gICAgdGhpcy5ub2Rlc1tjaGlsZF0ucGFyZW50ID0gdW5kZWZpbmVkXG4gICAgdGhpcy5ub2Rlcy5zcGxpY2UoY2hpbGQsIDEpXG5cbiAgICBsZXQgaW5kZXhcbiAgICBmb3IgKGxldCBpZCBpbiB0aGlzLmluZGV4ZXMpIHtcbiAgICAgIGluZGV4ID0gdGhpcy5pbmRleGVzW2lkXVxuICAgICAgaWYgKGluZGV4ID49IGNoaWxkKSB7XG4gICAgICAgIHRoaXMuaW5kZXhlc1tpZF0gPSBpbmRleCAtIDFcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gdGhpc1xuICB9XG5cbiAgLyoqXG4gICAqIFJlbW92ZXMgYWxsIGNoaWxkcmVuIGZyb20gdGhlIGNvbnRhaW5lclxuICAgKiBhbmQgY2xlYW5zIHRoZWlyIHBhcmVudCBwcm9wZXJ0aWVzLlxuICAgKlxuICAgKiBAcmV0dXJuIHtOb2RlfSBUaGlzIG5vZGUgZm9yIG1ldGhvZHMgY2hhaW4uXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIHJ1bGUucmVtb3ZlQWxsKClcbiAgICogcnVsZS5ub2Rlcy5sZW5ndGggLy89PiAwXG4gICAqL1xuICByZW1vdmVBbGwgKCkge1xuICAgIGZvciAobGV0IG5vZGUgb2YgdGhpcy5ub2Rlcykgbm9kZS5wYXJlbnQgPSB1bmRlZmluZWRcbiAgICB0aGlzLm5vZGVzID0gW11cbiAgICByZXR1cm4gdGhpc1xuICB9XG5cbiAgLyoqXG4gICAqIFBhc3NlcyBhbGwgZGVjbGFyYXRpb24gdmFsdWVzIHdpdGhpbiB0aGUgY29udGFpbmVyIHRoYXQgbWF0Y2ggcGF0dGVyblxuICAgKiB0aHJvdWdoIGNhbGxiYWNrLCByZXBsYWNpbmcgdGhvc2UgdmFsdWVzIHdpdGggdGhlIHJldHVybmVkIHJlc3VsdFxuICAgKiBvZiBjYWxsYmFjay5cbiAgICpcbiAgICogVGhpcyBtZXRob2QgaXMgdXNlZnVsIGlmIHlvdSBhcmUgdXNpbmcgYSBjdXN0b20gdW5pdCBvciBmdW5jdGlvblxuICAgKiBhbmQgbmVlZCB0byBpdGVyYXRlIHRocm91Z2ggYWxsIHZhbHVlcy5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd8UmVnRXhwfSBwYXR0ZXJuICAgICAgUmVwbGFjZSBwYXR0ZXJuLlxuICAgKiBAcGFyYW0ge29iamVjdH0gb3B0cyAgICAgICAgICAgICAgICBPcHRpb25zIHRvIHNwZWVkIHVwIHRoZSBzZWFyY2guXG4gICAqIEBwYXJhbSB7c3RyaW5nfHN0cmluZ1tdfSBvcHRzLnByb3BzIEFuIGFycmF5IG9mIHByb3BlcnR5IG5hbWVzLlxuICAgKiBAcGFyYW0ge3N0cmluZ30gb3B0cy5mYXN0ICAgICAgICAgICBTdHJpbmcgdGhhdOKAmXMgdXNlZCB0byBuYXJyb3cgZG93blxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZXMgYW5kIHNwZWVkIHVwIHRoZSByZWdleHAgc2VhcmNoLlxuICAgKiBAcGFyYW0ge2Z1bmN0aW9ufHN0cmluZ30gY2FsbGJhY2sgICBTdHJpbmcgdG8gcmVwbGFjZSBwYXR0ZXJuIG9yIGNhbGxiYWNrXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoYXQgcmV0dXJucyBhIG5ldyB2YWx1ZS4gVGhlIGNhbGxiYWNrXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHdpbGwgcmVjZWl2ZSB0aGUgc2FtZSBhcmd1bWVudHNcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYXMgdGhvc2UgcGFzc2VkIHRvIGEgZnVuY3Rpb24gcGFyYW1ldGVyXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG9mIGBTdHJpbmcjcmVwbGFjZWAuXG4gICAqXG4gICAqIEByZXR1cm4ge05vZGV9IFRoaXMgbm9kZSBmb3IgbWV0aG9kcyBjaGFpbi5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcm9vdC5yZXBsYWNlVmFsdWVzKC9cXGQrcmVtLywgeyBmYXN0OiAncmVtJyB9LCBzdHJpbmcgPT4ge1xuICAgKiAgIHJldHVybiAxNSAqIHBhcnNlSW50KHN0cmluZykgKyAncHgnXG4gICAqIH0pXG4gICAqL1xuICByZXBsYWNlVmFsdWVzIChwYXR0ZXJuLCBvcHRzLCBjYWxsYmFjaykge1xuICAgIGlmICghY2FsbGJhY2spIHtcbiAgICAgIGNhbGxiYWNrID0gb3B0c1xuICAgICAgb3B0cyA9IHsgfVxuICAgIH1cblxuICAgIHRoaXMud2Fsa0RlY2xzKGRlY2wgPT4ge1xuICAgICAgaWYgKG9wdHMucHJvcHMgJiYgb3B0cy5wcm9wcy5pbmRleE9mKGRlY2wucHJvcCkgPT09IC0xKSByZXR1cm5cbiAgICAgIGlmIChvcHRzLmZhc3QgJiYgZGVjbC52YWx1ZS5pbmRleE9mKG9wdHMuZmFzdCkgPT09IC0xKSByZXR1cm5cblxuICAgICAgZGVjbC52YWx1ZSA9IGRlY2wudmFsdWUucmVwbGFjZShwYXR0ZXJuLCBjYWxsYmFjaylcbiAgICB9KVxuXG4gICAgcmV0dXJuIHRoaXNcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGB0cnVlYCBpZiBjYWxsYmFjayByZXR1cm5zIGB0cnVlYFxuICAgKiBmb3IgYWxsIG9mIHRoZSBjb250YWluZXLigJlzIGNoaWxkcmVuLlxuICAgKlxuICAgKiBAcGFyYW0ge2NoaWxkQ29uZGl0aW9ufSBjb25kaXRpb24gSXRlcmF0b3IgcmV0dXJucyB0cnVlIG9yIGZhbHNlLlxuICAgKlxuICAgKiBAcmV0dXJuIHtib29sZWFufSBJcyBldmVyeSBjaGlsZCBwYXNzIGNvbmRpdGlvbi5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgbm9QcmVmaXhlcyA9IHJ1bGUuZXZlcnkoaSA9PiBpLnByb3BbMF0gIT09ICctJylcbiAgICovXG4gIGV2ZXJ5IChjb25kaXRpb24pIHtcbiAgICByZXR1cm4gdGhpcy5ub2Rlcy5ldmVyeShjb25kaXRpb24pXG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyBgdHJ1ZWAgaWYgY2FsbGJhY2sgcmV0dXJucyBgdHJ1ZWAgZm9yIChhdCBsZWFzdCkgb25lXG4gICAqIG9mIHRoZSBjb250YWluZXLigJlzIGNoaWxkcmVuLlxuICAgKlxuICAgKiBAcGFyYW0ge2NoaWxkQ29uZGl0aW9ufSBjb25kaXRpb24gSXRlcmF0b3IgcmV0dXJucyB0cnVlIG9yIGZhbHNlLlxuICAgKlxuICAgKiBAcmV0dXJuIHtib29sZWFufSBJcyBzb21lIGNoaWxkIHBhc3MgY29uZGl0aW9uLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBjb25zdCBoYXNQcmVmaXggPSBydWxlLnNvbWUoaSA9PiBpLnByb3BbMF0gPT09ICctJylcbiAgICovXG4gIHNvbWUgKGNvbmRpdGlvbikge1xuICAgIHJldHVybiB0aGlzLm5vZGVzLnNvbWUoY29uZGl0aW9uKVxuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgYSBgY2hpbGRg4oCZcyBpbmRleCB3aXRoaW4gdGhlIHtAbGluayBDb250YWluZXIjbm9kZXN9IGFycmF5LlxuICAgKlxuICAgKiBAcGFyYW0ge05vZGV9IGNoaWxkIENoaWxkIG9mIHRoZSBjdXJyZW50IGNvbnRhaW5lci5cbiAgICpcbiAgICogQHJldHVybiB7bnVtYmVyfSBDaGlsZCBpbmRleC5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcnVsZS5pbmRleCggcnVsZS5ub2Rlc1syXSApIC8vPT4gMlxuICAgKi9cbiAgaW5kZXggKGNoaWxkKSB7XG4gICAgaWYgKHR5cGVvZiBjaGlsZCA9PT0gJ251bWJlcicpIHtcbiAgICAgIHJldHVybiBjaGlsZFxuICAgIH1cbiAgICByZXR1cm4gdGhpcy5ub2Rlcy5pbmRleE9mKGNoaWxkKVxuICB9XG5cbiAgLyoqXG4gICAqIFRoZSBjb250YWluZXLigJlzIGZpcnN0IGNoaWxkLlxuICAgKlxuICAgKiBAdHlwZSB7Tm9kZX1cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcnVsZS5maXJzdCA9PT0gcnVsZXMubm9kZXNbMF1cbiAgICovXG4gIGdldCBmaXJzdCAoKSB7XG4gICAgaWYgKCF0aGlzLm5vZGVzKSByZXR1cm4gdW5kZWZpbmVkXG4gICAgcmV0dXJuIHRoaXMubm9kZXNbMF1cbiAgfVxuXG4gIC8qKlxuICAgKiBUaGUgY29udGFpbmVy4oCZcyBsYXN0IGNoaWxkLlxuICAgKlxuICAgKiBAdHlwZSB7Tm9kZX1cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcnVsZS5sYXN0ID09PSBydWxlLm5vZGVzW3J1bGUubm9kZXMubGVuZ3RoIC0gMV1cbiAgICovXG4gIGdldCBsYXN0ICgpIHtcbiAgICBpZiAoIXRoaXMubm9kZXMpIHJldHVybiB1bmRlZmluZWRcbiAgICByZXR1cm4gdGhpcy5ub2Rlc1t0aGlzLm5vZGVzLmxlbmd0aCAtIDFdXG4gIH1cblxuICBub3JtYWxpemUgKG5vZGVzLCBzYW1wbGUpIHtcbiAgICBpZiAodHlwZW9mIG5vZGVzID09PSAnc3RyaW5nJykge1xuICAgICAgbGV0IHBhcnNlID0gcmVxdWlyZSgnLi9wYXJzZScpXG4gICAgICBub2RlcyA9IGNsZWFuU291cmNlKHBhcnNlKG5vZGVzKS5ub2RlcylcbiAgICB9IGVsc2UgaWYgKEFycmF5LmlzQXJyYXkobm9kZXMpKSB7XG4gICAgICBub2RlcyA9IG5vZGVzLnNsaWNlKDApXG4gICAgICBmb3IgKGxldCBpIG9mIG5vZGVzKSB7XG4gICAgICAgIGlmIChpLnBhcmVudCkgaS5wYXJlbnQucmVtb3ZlQ2hpbGQoaSwgJ2lnbm9yZScpXG4gICAgICB9XG4gICAgfSBlbHNlIGlmIChub2Rlcy50eXBlID09PSAncm9vdCcpIHtcbiAgICAgIG5vZGVzID0gbm9kZXMubm9kZXMuc2xpY2UoMClcbiAgICAgIGZvciAobGV0IGkgb2Ygbm9kZXMpIHtcbiAgICAgICAgaWYgKGkucGFyZW50KSBpLnBhcmVudC5yZW1vdmVDaGlsZChpLCAnaWdub3JlJylcbiAgICAgIH1cbiAgICB9IGVsc2UgaWYgKG5vZGVzLnR5cGUpIHtcbiAgICAgIG5vZGVzID0gW25vZGVzXVxuICAgIH0gZWxzZSBpZiAobm9kZXMucHJvcCkge1xuICAgICAgaWYgKHR5cGVvZiBub2Rlcy52YWx1ZSA9PT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdWYWx1ZSBmaWVsZCBpcyBtaXNzZWQgaW4gbm9kZSBjcmVhdGlvbicpXG4gICAgICB9IGVsc2UgaWYgKHR5cGVvZiBub2Rlcy52YWx1ZSAhPT0gJ3N0cmluZycpIHtcbiAgICAgICAgbm9kZXMudmFsdWUgPSBTdHJpbmcobm9kZXMudmFsdWUpXG4gICAgICB9XG4gICAgICBub2RlcyA9IFtuZXcgRGVjbGFyYXRpb24obm9kZXMpXVxuICAgIH0gZWxzZSBpZiAobm9kZXMuc2VsZWN0b3IpIHtcbiAgICAgIGxldCBSdWxlID0gcmVxdWlyZSgnLi9ydWxlJylcbiAgICAgIG5vZGVzID0gW25ldyBSdWxlKG5vZGVzKV1cbiAgICB9IGVsc2UgaWYgKG5vZGVzLm5hbWUpIHtcbiAgICAgIGxldCBBdFJ1bGUgPSByZXF1aXJlKCcuL2F0LXJ1bGUnKVxuICAgICAgbm9kZXMgPSBbbmV3IEF0UnVsZShub2RlcyldXG4gICAgfSBlbHNlIGlmIChub2Rlcy50ZXh0KSB7XG4gICAgICBub2RlcyA9IFtuZXcgQ29tbWVudChub2RlcyldXG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignVW5rbm93biBub2RlIHR5cGUgaW4gbm9kZSBjcmVhdGlvbicpXG4gICAgfVxuXG4gICAgbGV0IHByb2Nlc3NlZCA9IG5vZGVzLm1hcChpID0+IHtcbiAgICAgIGlmIChpLnBhcmVudCkgaS5wYXJlbnQucmVtb3ZlQ2hpbGQoaSlcbiAgICAgIGlmICh0eXBlb2YgaS5yYXdzLmJlZm9yZSA9PT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgaWYgKHNhbXBsZSAmJiB0eXBlb2Ygc2FtcGxlLnJhd3MuYmVmb3JlICE9PSAndW5kZWZpbmVkJykge1xuICAgICAgICAgIGkucmF3cy5iZWZvcmUgPSBzYW1wbGUucmF3cy5iZWZvcmUucmVwbGFjZSgvW15cXHNdL2csICcnKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgICBpLnBhcmVudCA9IHRoaXNcbiAgICAgIHJldHVybiBpXG4gICAgfSlcblxuICAgIHJldHVybiBwcm9jZXNzZWRcbiAgfVxuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgQ29udGFpbmVyI1xuICAgKiBAbWVtYmVyIHtOb2RlW119IG5vZGVzIEFuIGFycmF5IGNvbnRhaW5pbmcgdGhlIGNvbnRhaW5lcuKAmXMgY2hpbGRyZW4uXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGNvbnN0IHJvb3QgPSBwb3N0Y3NzLnBhcnNlKCdhIHsgY29sb3I6IGJsYWNrIH0nKVxuICAgKiByb290Lm5vZGVzLmxlbmd0aCAgICAgICAgICAgLy89PiAxXG4gICAqIHJvb3Qubm9kZXNbMF0uc2VsZWN0b3IgICAgICAvLz0+ICdhJ1xuICAgKiByb290Lm5vZGVzWzBdLm5vZGVzWzBdLnByb3AgLy89PiAnY29sb3InXG4gICAqL1xufVxuXG5leHBvcnQgZGVmYXVsdCBDb250YWluZXJcblxuLyoqXG4gKiBAY2FsbGJhY2sgY2hpbGRDb25kaXRpb25cbiAqIEBwYXJhbSB7Tm9kZX0gbm9kZSAgICBDb250YWluZXIgY2hpbGQuXG4gKiBAcGFyYW0ge251bWJlcn0gaW5kZXggQ2hpbGQgaW5kZXguXG4gKiBAcGFyYW0ge05vZGVbXX0gbm9kZXMgQWxsIGNvbnRhaW5lciBjaGlsZHJlbi5cbiAqIEByZXR1cm4ge2Jvb2xlYW59XG4gKi9cblxuLyoqXG4gKiBAY2FsbGJhY2sgY2hpbGRJdGVyYXRvclxuICogQHBhcmFtIHtOb2RlfSBub2RlICAgIENvbnRhaW5lciBjaGlsZC5cbiAqIEBwYXJhbSB7bnVtYmVyfSBpbmRleCBDaGlsZCBpbmRleC5cbiAqIEByZXR1cm4ge2ZhbHNlfHVuZGVmaW5lZH0gUmV0dXJuaW5nIGBmYWxzZWAgd2lsbCBicmVhayBpdGVyYXRpb24uXG4gKi9cbiJdLCJmaWxlIjoiY29udGFpbmVyLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/css-syntax-error.js b/node_modules/autoprefixer/node_modules/postcss/lib/css-syntax-error.js
new file mode 100644
index 0000000..833e4ec
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/css-syntax-error.js
@@ -0,0 +1,300 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _supportsColor = _interopRequireDefault(require("supports-color"));
+
+var _chalk = _interopRequireDefault(require("chalk"));
+
+var _terminalHighlight = _interopRequireDefault(require("./terminal-highlight"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
+
+function _wrapNativeSuper(Class) { var _cache = typeof Map === "function" ? new Map() : undefined; _wrapNativeSuper = function _wrapNativeSuper(Class) { if (Class === null || !_isNativeFunction(Class)) return Class; if (typeof Class !== "function") { throw new TypeError("Super expression must either be null or a function"); } if (typeof _cache !== "undefined") { if (_cache.has(Class)) return _cache.get(Class); _cache.set(Class, Wrapper); } function Wrapper() { return _construct(Class, arguments, _getPrototypeOf(this).constructor); } Wrapper.prototype = Object.create(Class.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return _setPrototypeOf(Wrapper, Class); }; return _wrapNativeSuper(Class); }
+
+function isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }
+
+function _construct(Parent, args, Class) { if (isNativeReflectConstruct()) { _construct = Reflect.construct; } else { _construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) _setPrototypeOf(instance, Class.prototype); return instance; }; } return _construct.apply(null, arguments); }
+
+function _isNativeFunction(fn) { return Function.toString.call(fn).indexOf("[native code]") !== -1; }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+/**
+ * The CSS parser throws this error for broken CSS.
+ *
+ * Custom parsers can throw this error for broken custom syntax using
+ * the {@link Node#error} method.
+ *
+ * PostCSS will use the input source map to detect the original error location.
+ * If you wrote a Sass file, compiled it to CSS and then parsed it with PostCSS,
+ * PostCSS will show the original position in the Sass file.
+ *
+ * If you need the position in the PostCSS input
+ * (e.g., to debug the previous compiler), use `error.input.file`.
+ *
+ * @example
+ * // Catching and checking syntax error
+ * try {
+ * postcss.parse('a{')
+ * } catch (error) {
+ * if (error.name === 'CssSyntaxError') {
+ * error //=> CssSyntaxError
+ * }
+ * }
+ *
+ * @example
+ * // Raising error from plugin
+ * throw node.error('Unknown variable', { plugin: 'postcss-vars' })
+ */
+var CssSyntaxError =
+/*#__PURE__*/
+function (_Error) {
+ _inheritsLoose(CssSyntaxError, _Error);
+
+ /**
+ * @param {string} message Error message.
+ * @param {number} [line] Source line of the error.
+ * @param {number} [column] Source column of the error.
+ * @param {string} [source] Source code of the broken file.
+ * @param {string} [file] Absolute path to the broken file.
+ * @param {string} [plugin] PostCSS plugin name, if error came from plugin.
+ */
+ function CssSyntaxError(message, line, column, source, file, plugin) {
+ var _this;
+
+ _this = _Error.call(this, message) || this;
+ /**
+ * Always equal to `'CssSyntaxError'`. You should always check error type
+ * by `error.name === 'CssSyntaxError'`
+ * instead of `error instanceof CssSyntaxError`,
+ * because npm could have several PostCSS versions.
+ *
+ * @type {string}
+ *
+ * @example
+ * if (error.name === 'CssSyntaxError') {
+ * error //=> CssSyntaxError
+ * }
+ */
+
+ _this.name = 'CssSyntaxError';
+ /**
+ * Error message.
+ *
+ * @type {string}
+ *
+ * @example
+ * error.message //=> 'Unclosed block'
+ */
+
+ _this.reason = message;
+
+ if (file) {
+ /**
+ * Absolute path to the broken file.
+ *
+ * @type {string}
+ *
+ * @example
+ * error.file //=> 'a.sass'
+ * error.input.file //=> 'a.css'
+ */
+ _this.file = file;
+ }
+
+ if (source) {
+ /**
+ * Source code of the broken file.
+ *
+ * @type {string}
+ *
+ * @example
+ * error.source //=> 'a { b {} }'
+ * error.input.column //=> 'a b { }'
+ */
+ _this.source = source;
+ }
+
+ if (plugin) {
+ /**
+ * Plugin name, if error came from plugin.
+ *
+ * @type {string}
+ *
+ * @example
+ * error.plugin //=> 'postcss-vars'
+ */
+ _this.plugin = plugin;
+ }
+
+ if (typeof line !== 'undefined' && typeof column !== 'undefined') {
+ /**
+ * Source line of the error.
+ *
+ * @type {number}
+ *
+ * @example
+ * error.line //=> 2
+ * error.input.line //=> 4
+ */
+ _this.line = line;
+ /**
+ * Source column of the error.
+ *
+ * @type {number}
+ *
+ * @example
+ * error.column //=> 1
+ * error.input.column //=> 4
+ */
+
+ _this.column = column;
+ }
+
+ _this.setMessage();
+
+ if (Error.captureStackTrace) {
+ Error.captureStackTrace(_assertThisInitialized(_this), CssSyntaxError);
+ }
+
+ return _this;
+ }
+
+ var _proto = CssSyntaxError.prototype;
+
+ _proto.setMessage = function setMessage() {
+ /**
+ * Full error text in the GNU error format
+ * with plugin, file, line and column.
+ *
+ * @type {string}
+ *
+ * @example
+ * error.message //=> 'a.css:1:1: Unclosed block'
+ */
+ this.message = this.plugin ? this.plugin + ': ' : '';
+ this.message += this.file ? this.file : '<css input>';
+
+ if (typeof this.line !== 'undefined') {
+ this.message += ':' + this.line + ':' + this.column;
+ }
+
+ this.message += ': ' + this.reason;
+ }
+ /**
+ * Returns a few lines of CSS source that caused the error.
+ *
+ * If the CSS has an input source map without `sourceContent`,
+ * this method will return an empty string.
+ *
+ * @param {boolean} [color] Whether arrow will be colored red by terminal
+ * color codes. By default, PostCSS will detect
+ * color support by `process.stdout.isTTY`
+ * and `process.env.NODE_DISABLE_COLORS`.
+ *
+ * @example
+ * error.showSourceCode() //=> " 4 | }
+ * // 5 | a {
+ * // > 6 | bad
+ * // | ^
+ * // 7 | }
+ * // 8 | b {"
+ *
+ * @return {string} Few lines of CSS source that caused the error.
+ */
+ ;
+
+ _proto.showSourceCode = function showSourceCode(color) {
+ var _this2 = this;
+
+ if (!this.source) return '';
+ var css = this.source;
+
+ if (_terminalHighlight.default) {
+ if (typeof color === 'undefined') color = _supportsColor.default.stdout;
+ if (color) css = (0, _terminalHighlight.default)(css);
+ }
+
+ var lines = css.split(/\r?\n/);
+ var start = Math.max(this.line - 3, 0);
+ var end = Math.min(this.line + 2, lines.length);
+ var maxWidth = String(end).length;
+
+ function mark(text) {
+ if (color && _chalk.default.red) {
+ return _chalk.default.red.bold(text);
+ }
+
+ return text;
+ }
+
+ function aside(text) {
+ if (color && _chalk.default.gray) {
+ return _chalk.default.gray(text);
+ }
+
+ return text;
+ }
+
+ return lines.slice(start, end).map(function (line, index) {
+ var number = start + 1 + index;
+ var gutter = ' ' + (' ' + number).slice(-maxWidth) + ' | ';
+
+ if (number === _this2.line) {
+ var spacing = aside(gutter.replace(/\d/g, ' ')) + line.slice(0, _this2.column - 1).replace(/[^\t]/g, ' ');
+ return mark('>') + aside(gutter) + line + '\n ' + spacing + mark('^');
+ }
+
+ return ' ' + aside(gutter) + line;
+ }).join('\n');
+ }
+ /**
+ * Returns error position, message and source code of the broken part.
+ *
+ * @example
+ * error.toString() //=> "CssSyntaxError: app.css:1:1: Unclosed block
+ * // > 1 | a {
+ * // | ^"
+ *
+ * @return {string} Error position, message and source code.
+ */
+ ;
+
+ _proto.toString = function toString() {
+ var code = this.showSourceCode();
+
+ if (code) {
+ code = '\n\n' + code + '\n';
+ }
+
+ return this.name + ': ' + this.message + code;
+ }
+ /**
+ * @memberof CssSyntaxError#
+ * @member {Input} input Input object with PostCSS internal information
+ * about input file. If input has source map
+ * from previous tool, PostCSS will use origin
+ * (for example, Sass) source. You can use this
+ * object to get PostCSS input source.
+ *
+ * @example
+ * error.input.file //=> 'a.css'
+ * error.file //=> 'a.sass'
+ */
+ ;
+
+ return CssSyntaxError;
+}(_wrapNativeSuper(Error));
+
+var _default = CssSyntaxError;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNzcy1zeW50YXgtZXJyb3IuZXM2Il0sIm5hbWVzIjpbIkNzc1N5bnRheEVycm9yIiwibWVzc2FnZSIsImxpbmUiLCJjb2x1bW4iLCJzb3VyY2UiLCJmaWxlIiwicGx1Z2luIiwibmFtZSIsInJlYXNvbiIsInNldE1lc3NhZ2UiLCJFcnJvciIsImNhcHR1cmVTdGFja1RyYWNlIiwic2hvd1NvdXJjZUNvZGUiLCJjb2xvciIsImNzcyIsInRlcm1pbmFsSGlnaGxpZ2h0Iiwic3VwcG9ydHNDb2xvciIsInN0ZG91dCIsImxpbmVzIiwic3BsaXQiLCJzdGFydCIsIk1hdGgiLCJtYXgiLCJlbmQiLCJtaW4iLCJsZW5ndGgiLCJtYXhXaWR0aCIsIlN0cmluZyIsIm1hcmsiLCJ0ZXh0IiwiY2hhbGsiLCJyZWQiLCJib2xkIiwiYXNpZGUiLCJncmF5Iiwic2xpY2UiLCJtYXAiLCJpbmRleCIsIm51bWJlciIsImd1dHRlciIsInNwYWNpbmciLCJyZXBsYWNlIiwiam9pbiIsInRvU3RyaW5nIiwiY29kZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQTs7QUFDQTs7QUFFQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBMkJNQSxjOzs7OztBQUNKOzs7Ozs7OztBQVFBLDBCQUFhQyxPQUFiLEVBQXNCQyxJQUF0QixFQUE0QkMsTUFBNUIsRUFBb0NDLE1BQXBDLEVBQTRDQyxJQUE1QyxFQUFrREMsTUFBbEQsRUFBMEQ7QUFBQTs7QUFDeEQsOEJBQU1MLE9BQU47QUFFQTs7Ozs7Ozs7Ozs7Ozs7QUFhQSxVQUFLTSxJQUFMLEdBQVksZ0JBQVo7QUFDQTs7Ozs7Ozs7O0FBUUEsVUFBS0MsTUFBTCxHQUFjUCxPQUFkOztBQUVBLFFBQUlJLElBQUosRUFBVTtBQUNSOzs7Ozs7Ozs7QUFTQSxZQUFLQSxJQUFMLEdBQVlBLElBQVo7QUFDRDs7QUFDRCxRQUFJRCxNQUFKLEVBQVk7QUFDVjs7Ozs7Ozs7O0FBU0EsWUFBS0EsTUFBTCxHQUFj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OztBQUNBLFVBQUlZLE1BQU0sS0FBSyxNQUFJLENBQUNwQyxJQUFwQixFQUEwQjtBQUN4QixZQUFJc0MsT0FBTyxHQUFHUCxLQUFLLENBQUNNLE1BQU0sQ0FBQ0UsT0FBUCxDQUFlLEtBQWYsRUFBc0IsR0FBdEIsQ0FBRCxDQUFMLEdBQ1p2QyxJQUFJLENBQUNpQyxLQUFMLENBQVcsQ0FBWCxFQUFjLE1BQUksQ0FBQ2hDLE1BQUwsR0FBYyxDQUE1QixFQUErQnNDLE9BQS9CLENBQXVDLFFBQXZDLEVBQWlELEdBQWpELENBREY7QUFFQSxlQUFPYixJQUFJLENBQUMsR0FBRCxDQUFKLEdBQVlLLEtBQUssQ0FBQ00sTUFBRCxDQUFqQixHQUE0QnJDLElBQTVCLEdBQW1DLEtBQW5DLEdBQTJDc0MsT0FBM0MsR0FBcURaLElBQUksQ0FBQyxHQUFELENBQWhFO0FBQ0Q7O0FBQ0QsYUFBTyxNQUFNSyxLQUFLLENBQUNNLE1BQUQsQ0FBWCxHQUFzQnJDLElBQTdCO0FBQ0QsS0FUTSxFQVNKd0MsSUFUSSxDQVNDLElBVEQsQ0FBUDtBQVVEO0FBRUQ7Ozs7Ozs7Ozs7OztTQVVBQyxRLEdBQUEsb0JBQVk7QUFDVixRQUFJQyxJQUFJLEdBQUcsS0FBS2hDLGNBQUwsRUFBWDs7QUFDQSxRQUFJZ0MsSUFBSixFQUFVO0FBQ1JBLE1BQUFBLElBQUksR0FBRyxTQUFTQSxJQUFULEdBQWdCLElBQXZCO0FBQ0Q7O0FBQ0QsV0FBTyxLQUFLckMsSUFBTCxHQUFZLElBQVosR0FBbUIsS0FBS04sT0FBeEIsR0FBa0MyQyxJQUF6QztBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7OzttQkF0TTJCbEMsSzs7ZUFvTmRWLGMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3VwcG9ydHNDb2xvciBmcm9tICdzdXBwb3J0cy1jb2xvcidcbmltcG9ydCBjaGFsayBmcm9tICdjaGFsaydcblxuaW1wb3J0IHRlcm1pbmFsSGlnaGxpZ2h0IGZyb20gJy4vdGVybWluYWwtaGlnaGxpZ2h0J1xuXG4vKipcbiAqIFRoZSBDU1MgcGFyc2VyIHRocm93cyB0aGlzIGVycm9yIGZvciBicm9rZW4gQ1NTLlxuICpcbiAqIEN1c3RvbSBwYXJzZXJzIGNhbiB0aHJvdyB0aGlzIGVycm9yIGZvciBicm9rZW4gY3VzdG9tIHN5bnRheCB1c2luZ1xuICogdGhlIHtAbGluayBOb2RlI2Vycm9yfSBtZXRob2QuXG4gKlxuICogUG9zdENTUyB3aWxsIHVzZSB0aGUgaW5wdXQgc291cmNlIG1hcCB0byBkZXRlY3QgdGhlIG9yaWdpbmFsIGVycm9yIGxvY2F0aW9uLlxuICogSWYgeW91IHdyb3RlIGEgU2FzcyBmaWxlLCBjb21waWxlZCBpdCB0byBDU1MgYW5kIHRoZW4gcGFyc2VkIGl0IHdpdGggUG9zdENTUyxcbiAqIFBvc3RDU1Mgd2lsbCBzaG93IHRoZSBvcmlnaW5hbCBwb3NpdGlvbiBpbiB0aGUgU2FzcyBmaWxlLlxuICpcbiAqIElmIHlvdSBuZWVkIHRoZSBwb3NpdGlvbiBpbiB0aGUgUG9zdENTUyBpbnB1dFxuICogKGUuZy4sIHRvIGRlYnVnIHRoZSBwcmV2aW91cyBjb21waWxlciksIHVzZSBgZXJyb3IuaW5wdXQuZmlsZWAuXG4gKlxuICogQGV4YW1wbGVcbiAqIC8vIENhdGNoaW5nIGFuZCBjaGVja2luZyBzeW50YXggZXJyb3JcbiAqIHRyeSB7XG4gKiAgIHBvc3Rjc3MucGFyc2UoJ2F7JylcbiAqIH0gY2F0Y2ggKGVycm9yKSB7XG4gKiAgIGlmIChlcnJvci5uYW1lID09PSAnQ3NzU3ludGF4RXJyb3InKSB7XG4gKiAgICAgZXJyb3IgLy89PiBDc3NTeW50YXhFcnJvclxuICogICB9XG4gKiB9XG4gKlxuICogQGV4YW1wbGVcbiAqIC8vIFJhaXNpbmcgZXJyb3IgZnJvbSBwbHVnaW5cbiAqIHRocm93IG5vZGUuZXJyb3IoJ1Vua25vd24gdmFyaWFibGUnLCB7IHBsdWdpbjogJ3Bvc3Rjc3MtdmFycycgfSlcbiAqL1xuY2xhc3MgQ3NzU3ludGF4RXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIC8qKlxuICAgKiBAcGFyYW0ge3N0cmluZ30gbWVzc2FnZSAgRXJyb3IgbWVzc2FnZS5cbiAgICogQHBhcmFtIHtudW1iZXJ9IFtsaW5lXSAgIFNvdXJjZSBsaW5lIG9mIHRoZSBlcnJvci5cbiAgICogQHBhcmFtIHtudW1iZXJ9IFtjb2x1bW5dIFNvdXJjZSBjb2x1bW4gb2YgdGhlIGVycm9yLlxuICAgKiBAcGFyYW0ge3N0cmluZ30gW3NvdXJjZV0gU291cmNlIGNvZGUgb2YgdGhlIGJyb2tlbiBmaWxlLlxuICAgKiBAcGFyYW0ge3N0cmluZ30gW2ZpbGVdICAgQWJzb2x1dGUgcGF0aCB0byB0aGUgYnJva2VuIGZpbGUuXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBbcGx1Z2luXSBQb3N0Q1NTIHBsdWdpbiBuYW1lLCBpZiBlcnJvciBjYW1lIGZyb20gcGx1Z2luLlxuICAgKi9cbiAgY29uc3RydWN0b3IgKG1lc3NhZ2UsIGxpbmUsIGNvbHVtbiwgc291cmNlLCBmaWxlLCBwbHVnaW4pIHtcbiAgICBzdXBlcihtZXNzYWdlKVxuXG4gICAgLyoqXG4gICAgICogQWx3YXlzIGVxdWFsIHRvIGAnQ3NzU3ludGF4RXJyb3InYC4gWW91IHNob3VsZCBhbHdheXMgY2hlY2sgZXJyb3IgdHlwZVxuICAgICAqIGJ5IGBlcnJvci5uYW1lID09PSAnQ3NzU3ludGF4RXJyb3InYFxuICAgICAqIGluc3RlYWQgb2YgYGVycm9yIGluc3RhbmNlb2YgQ3NzU3ludGF4RXJyb3JgLFxuICAgICAqIGJlY2F1c2UgbnBtIGNvdWxkIGhhdmUgc2V2ZXJhbCBQb3N0Q1NTIHZlcnNpb25zLlxuICAgICAqXG4gICAgICogQHR5cGUge3N0cmluZ31cbiAgICAgKlxuICAgICAqIEBleGFtcGxlXG4gICAgICogaWYgKGVycm9yLm5hbWUgPT09ICdDc3NTeW50YXhFcnJvcicpIHtcbiAgICAgKiAgIGVycm9yIC8vPT4gQ3NzU3ludGF4RXJyb3JcbiAgICAgKiB9XG4gICAgICovXG4gICAgdGhpcy5uYW1lID0gJ0Nzc1N5bnRheEVycm9yJ1xuICAgIC8qKlxuICAgICAqIEVycm9yIG1lc3NhZ2UuXG4gICAgICpcbiAgICAgKiBAdHlwZSB7c3RyaW5nfVxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiBlcnJvci5tZXNzYWdlIC8vPT4gJ1VuY2xvc2VkIGJsb2NrJ1xuICAgICAqL1xuICAgIHRoaXMucmVhc29uID0gbWVzc2FnZVxuXG4gICAgaWYgKGZpbGUpIHtcbiAgICAgIC8qKlxuICAgICAgICogQWJzb2x1dGUgcGF0aCB0byB0aGUgYnJva2VuIGZpbGUuXG4gICAgICAgKlxuICAgICAgICogQHR5cGUge3N0cmluZ31cbiAgICAgICAqXG4gICAgICAgKiBAZXhhbXBsZVxuICAgICAgICogZXJyb3IuZmlsZSAgICAgICAvLz0+ICdhLnNhc3MnXG4gICAgICAgKiBlcnJvci5pbnB1dC5maWxlIC8vPT4gJ2EuY3NzJ1xuICAgICAgICovXG4gICAgICB0aGlzLmZpbGUgPSBmaWxlXG4gICAgfVxuICAgIGlmIChzb3VyY2UpIHtcbiAgICAgIC8qKlxuICAgICAgICogU291cmNlIGNvZGUgb2YgdGhlIGJyb2tlbiBmaWxlLlxuICAgICAgICpcbiAgICAgICAqIEB0eXBlIHtzdHJpbmd9XG4gICAgICAgKlxuICAgICAgICogQGV4YW1wbGVcbiAgICAgICAqIGVycm9yLnNvdXJjZSAgICAgICAvLz0+ICdhIHsgYiB7fSB9J1xuICAgICAgICogZXJyb3IuaW5wdXQuY29sdW1uIC8vPT4gJ2EgYiB7IH0nXG4gICAgICAgKi9cbiAgICAgIHRoaXMuc291cmNlID0gc291cmNlXG4gICAgfVxuICAgIGlmIChwbHVnaW4pIHtcbiAgICAgIC8qKlxuICAgICAgICogUGx1Z2luIG5hbWUsIGlmIGVycm9yIGNhbWUgZnJvbSBwbHVnaW4uXG4gICAgICAgKlxuICAgICAgICogQHR5cGUge3N0cmluZ31cbiAgICAgICAqXG4gICAgICAgKiBAZXhhbXBsZVxuICAgICAgICogZXJyb3IucGx1Z2luIC8vPT4gJ3Bvc3Rjc3MtdmFycydcbiAgICAgICAqL1xuICAgICAgdGhpcy5wbHVnaW4gPSBwbHVnaW5cbiAgICB9XG4gICAgaWYgKHR5cGVvZiBsaW5lICE9PSAndW5kZWZpbmVkJyAmJiB0eXBlb2YgY29sdW1uICE9PSAndW5kZWZpbmVkJykge1xuICAgICAgLyoqXG4gICAgICAgKiBTb3VyY2UgbGluZSBvZiB0aGUgZXJyb3IuXG4gICAgICAgKlxuICAgICAgICogQHR5cGUge251bWJlcn1cbiAgICAgICAqXG4gICAgICAgKiBAZXhhbXBsZVxuICAgICAgICogZXJyb3IubGluZSAgICAgICAvLz0+IDJcbiAgICAgICAqIGVycm9yLmlucHV0LmxpbmUgLy89PiA0XG4gICAgICAgKi9cbiAgICAgIHRoaXMubGluZSA9IGxpbmVcbiAgICAgIC8qKlxuICAgICAgICogU291cmNlIGNvbHVtbiBvZiB0aGUgZXJyb3IuXG4gICAgICAgKlxuICAgICAgICogQHR5cGUge251bWJlcn1cbiAgICAgICAqXG4gICAgICAgKiBAZXhhbXBsZVxuICAgICAgICogZXJyb3IuY29sdW1uICAgICAgIC8vPT4gMVxuICAgICAgICogZXJyb3IuaW5wdXQuY29sdW1uIC8vPT4gNFxuICAgICAgICovXG4gICAgICB0aGlzLmNvbHVtbiA9IGNvbHVtblxuICAgIH1cblxuICAgIHRoaXMuc2V0TWVzc2FnZSgpXG5cbiAgICBpZiAoRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UpIHtcbiAgICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIENzc1N5bnRheEVycm9yKVxuICAgIH1cbiAgfVxuXG4gIHNldE1lc3NhZ2UgKCkge1xuICAgIC8qKlxuICAgICAqIEZ1bGwgZXJyb3IgdGV4dCBpbiB0aGUgR05VIGVycm9yIGZvcm1hdFxuICAgICAqIHdpdGggcGx1Z2luLCBmaWxlLCBsaW5lIGFuZCBjb2x1bW4uXG4gICAgICpcbiAgICAgKiBAdHlwZSB7c3RyaW5nfVxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiBlcnJvci5tZXNzYWdlIC8vPT4gJ2EuY3NzOjE6MTogVW5jbG9zZWQgYmxvY2snXG4gICAgICovXG4gICAgdGhpcy5tZXNzYWdlID0gdGhpcy5wbHVnaW4gPyB0aGlzLnBsdWdpbiArICc6ICcgOiAnJ1xuICAgIHRoaXMubWVzc2FnZSArPSB0aGlzLmZpbGUgPyB0aGlzLmZpbGUgOiAnPGNzcyBpbnB1dD4nXG4gICAgaWYgKHR5cGVvZiB0aGlzLmxpbmUgIT09ICd1bmRlZmluZWQnKSB7XG4gICAgICB0aGlzLm1lc3NhZ2UgKz0gJzonICsgdGhpcy5saW5lICsgJzonICsgdGhpcy5jb2x1bW5cbiAgICB9XG4gICAgdGhpcy5tZXNzYWdlICs9ICc6ICcgKyB0aGlzLnJlYXNvblxuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgYSBmZXcgbGluZXMgb2YgQ1NTIHNvdXJjZSB0aGF0IGNhdXNlZCB0aGUgZXJyb3IuXG4gICAqXG4gICAqIElmIHRoZSBDU1MgaGFzIGFuIGlucHV0IHNvdXJjZSBtYXAgd2l0aG91dCBgc291cmNlQ29udGVudGAsXG4gICAqIHRoaXMgbWV0aG9kIHdpbGwgcmV0dXJuIGFuIGVtcHR5IHN0cmluZy5cbiAgICpcbiAgICogQHBhcmFtIHtib29sZWFufSBbY29sb3JdIFdoZXRoZXIgYXJyb3cgd2lsbCBiZSBjb2xvcmVkIHJlZCBieSB0ZXJtaW5hbFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3IgY29kZXMuIEJ5IGRlZmF1bHQsIFBvc3RDU1Mgd2lsbCBkZXRlY3RcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgIGNvbG9yIHN1cHBvcnQgYnkgYHByb2Nlc3Muc3Rkb3V0LmlzVFRZYFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgYW5kIGBwcm9jZXNzLmVudi5OT0RFX0RJU0FCTEVfQ09MT1JTYC5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogZXJyb3Iuc2hvd1NvdXJjZUNvZGUoKSAvLz0+IFwiICA0IHwgfVxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgIC8vICAgICAgNSB8IGEge1xuICAgKiAgICAgICAgICAgICAgICAgICAgICAgIC8vICAgID4gNiB8ICAgYmFkXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgLy8gICAgICAgIHwgICBeXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgLy8gICAgICA3IHwgfVxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgIC8vICAgICAgOCB8IGIge1wiXG4gICAqXG4gICAqIEByZXR1cm4ge3N0cmluZ30gRmV3IGxpbmVzIG9mIENTUyBzb3VyY2UgdGhhdCBjYXVzZWQgdGhlIGVycm9yLlxuICAgKi9cbiAgc2hvd1NvdXJjZUNvZGUgKGNvbG9yKSB7XG4gICAgaWYgKCF0aGlzLnNvdXJjZSkgcmV0dXJuICcnXG5cbiAgICBsZXQgY3NzID0gdGhpcy5zb3VyY2VcbiAgICBpZiAodGVybWluYWxIaWdobGlnaHQpIHtcbiAgICAgIGlmICh0eXBlb2YgY29sb3IgPT09ICd1bmRlZmluZWQnKSBjb2xvciA9IHN1cHBvcnRzQ29sb3Iuc3Rkb3V0XG4gICAgICBpZiAoY29sb3IpIGNzcyA9IHRlcm1pbmFsSGlnaGxpZ2h0KGNzcylcbiAgICB9XG5cbiAgICBsZXQgbGluZXMgPSBjc3Muc3BsaXQoL1xccj9cXG4vKVxuICAgIGxldCBzdGFydCA9IE1hdGgubWF4KHRoaXMubGluZSAtIDMsIDApXG4gICAgbGV0IGVuZCA9IE1hdGgubWluKHRoaXMubGluZSArIDIsIGxpbmVzLmxlbmd0aClcblxuICAgIGxldCBtYXhXaWR0aCA9IFN0cmluZyhlbmQpLmxlbmd0aFxuXG4gICAgZnVuY3Rpb24gbWFyayAodGV4dCkge1xuICAgICAgaWYgKGNvbG9yICYmIGNoYWxrLnJlZCkge1xuICAgICAgICByZXR1cm4gY2hhbGsucmVkLmJvbGQodGV4dClcbiAgICAgIH1cbiAgICAgIHJldHVybiB0ZXh0XG4gICAgfVxuICAgIGZ1bmN0aW9uIGFzaWRlICh0ZXh0KSB7XG4gICAgICBpZiAoY29sb3IgJiYgY2hhbGsuZ3JheSkge1xuICAgICAgICByZXR1cm4gY2hhbGsuZ3JheSh0ZXh0KVxuICAgICAgfVxuICAgICAgcmV0dXJuIHRleHRcbiAgICB9XG5cbiAgICByZXR1cm4gbGluZXMuc2xpY2Uoc3RhcnQsIGVuZCkubWFwKChsaW5lLCBpbmRleCkgPT4ge1xuICAgICAgbGV0IG51bWJlciA9IHN0YXJ0ICsgMSArIGluZGV4XG4gICAgICBsZXQgZ3V0dGVyID0gJyAnICsgKCcgJyArIG51bWJlcikuc2xpY2UoLW1heFdpZHRoKSArICcgfCAnXG4gICAgICBpZiAobnVtYmVyID09PSB0aGlzLmxpbmUpIHtcbiAgICAgICAgbGV0IHNwYWNpbmcgPSBhc2lkZShndXR0ZXIucmVwbGFjZSgvXFxkL2csICcgJykpICtcbiAgICAgICAgICBsaW5lLnNsaWNlKDAsIHRoaXMuY29sdW1uIC0gMSkucmVwbGFjZSgvW15cXHRdL2csICcgJylcbiAgICAgICAgcmV0dXJuIG1hcmsoJz4nKSArIGFzaWRlKGd1dHRlcikgKyBsaW5lICsgJ1xcbiAnICsgc3BhY2luZyArIG1hcmsoJ14nKVxuICAgICAgfVxuICAgICAgcmV0dXJuICcgJyArIGFzaWRlKGd1dHRlcikgKyBsaW5lXG4gICAgfSkuam9pbignXFxuJylcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGVycm9yIHBvc2l0aW9uLCBtZXNzYWdlIGFuZCBzb3VyY2UgY29kZSBvZiB0aGUgYnJva2VuIHBhcnQuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGVycm9yLnRvU3RyaW5nKCkgLy89PiBcIkNzc1N5bnRheEVycm9yOiBhcHAuY3NzOjE6MTogVW5jbG9zZWQgYmxvY2tcbiAgICogICAgICAgICAgICAgICAgICAvLyAgICA+IDEgfCBhIHtcbiAgICogICAgICAgICAgICAgICAgICAvLyAgICAgICAgfCBeXCJcbiAgICpcbiAgICogQHJldHVybiB7c3RyaW5nfSBFcnJvciBwb3NpdGlvbiwgbWVzc2FnZSBhbmQgc291cmNlIGNvZGUuXG4gICAqL1xuICB0b1N0cmluZyAoKSB7XG4gICAgbGV0IGNvZGUgPSB0aGlzLnNob3dTb3VyY2VDb2RlKClcbiAgICBpZiAoY29kZSkge1xuICAgICAgY29kZSA9ICdcXG5cXG4nICsgY29kZSArICdcXG4nXG4gICAgfVxuICAgIHJldHVybiB0aGlzLm5hbWUgKyAnOiAnICsgdGhpcy5tZXNzYWdlICsgY29kZVxuICB9XG5cbiAgLyoqXG4gICAqIEBtZW1iZXJvZiBDc3NTeW50YXhFcnJvciNcbiAgICogQG1lbWJlciB7SW5wdXR9IGlucHV0IElucHV0IG9iamVjdCB3aXRoIFBvc3RDU1MgaW50ZXJuYWwgaW5mb3JtYXRpb25cbiAgICogICAgICAgICAgICAgICAgICAgICAgIGFib3V0IGlucHV0IGZpbGUuIElmIGlucHV0IGhhcyBzb3VyY2UgbWFwXG4gICAqICAgICAgICAgICAgICAgICAgICAgICBmcm9tIHByZXZpb3VzIHRvb2wsIFBvc3RDU1Mgd2lsbCB1c2Ugb3JpZ2luXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAoZm9yIGV4YW1wbGUsIFNhc3MpIHNvdXJjZS4gWW91IGNhbiB1c2UgdGhpc1xuICAgKiAgICAgICAgICAgICAgICAgICAgICAgb2JqZWN0IHRvIGdldCBQb3N0Q1NTIGlucHV0IHNvdXJjZS5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogZXJyb3IuaW5wdXQuZmlsZSAvLz0+ICdhLmNzcydcbiAgICogZXJyb3IuZmlsZSAgICAgICAvLz0+ICdhLnNhc3MnXG4gICAqL1xufVxuXG5leHBvcnQgZGVmYXVsdCBDc3NTeW50YXhFcnJvclxuIl0sImZpbGUiOiJjc3Mtc3ludGF4LWVycm9yLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/declaration.js b/node_modules/autoprefixer/node_modules/postcss/lib/declaration.js
new file mode 100644
index 0000000..6faf751
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/declaration.js
@@ -0,0 +1,98 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _node = _interopRequireDefault(require("./node"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
+
+/**
+ * Represents a CSS declaration.
+ *
+ * @extends Node
+ *
+ * @example
+ * const root = postcss.parse('a { color: black }')
+ * const decl = root.first.first
+ * decl.type //=> 'decl'
+ * decl.toString() //=> ' color: black'
+ */
+var Declaration =
+/*#__PURE__*/
+function (_Node) {
+ _inheritsLoose(Declaration, _Node);
+
+ function Declaration(defaults) {
+ var _this;
+
+ _this = _Node.call(this, defaults) || this;
+ _this.type = 'decl';
+ return _this;
+ }
+ /**
+ * @memberof Declaration#
+ * @member {string} prop The declaration’s property name.
+ *
+ * @example
+ * const root = postcss.parse('a { color: black }')
+ * const decl = root.first.first
+ * decl.prop //=> 'color'
+ */
+
+ /**
+ * @memberof Declaration#
+ * @member {string} value The declaration’s value.
+ *
+ * @example
+ * const root = postcss.parse('a { color: black }')
+ * const decl = root.first.first
+ * decl.value //=> 'black'
+ */
+
+ /**
+ * @memberof Declaration#
+ * @member {boolean} important `true` if the declaration
+ * has an !important annotation.
+ *
+ * @example
+ * const root = postcss.parse('a { color: black !important; color: red }')
+ * root.first.first.important //=> true
+ * root.first.last.important //=> undefined
+ */
+
+ /**
+ * @memberof Declaration#
+ * @member {object} raws Information to generate byte-to-byte equal
+ * node string as it was in the origin input.
+ *
+ * Every parser saves its own properties,
+ * but the default CSS parser uses:
+ *
+ * * `before`: the space symbols before the node. It also stores `*`
+ * and `_` symbols before the declaration (IE hack).
+ * * `between`: the symbols between the property and value
+ * for declarations.
+ * * `important`: the content of the important statement,
+ * if it is not just `!important`.
+ *
+ * PostCSS cleans declaration from comments and extra spaces,
+ * but it stores origin content in raws properties.
+ * As such, if you don’t change a declaration’s value,
+ * PostCSS will use the raw value with comments.
+ *
+ * @example
+ * const root = postcss.parse('a {\n color:black\n}')
+ * root.first.first.raws //=> { before: '\n ', between: ':' }
+ */
+
+
+ return Declaration;
+}(_node.default);
+
+var _default = Declaration;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRlY2xhcmF0aW9uLmVzNiJdLCJuYW1lcyI6WyJEZWNsYXJhdGlvbiIsImRlZmF1bHRzIiwidHlwZSIsIk5vZGUiXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7Ozs7OztBQUVBOzs7Ozs7Ozs7OztJQVdNQSxXOzs7OztBQUNKLHVCQUFhQyxRQUFiLEVBQXVCO0FBQUE7O0FBQ3JCLDZCQUFNQSxRQUFOO0FBQ0EsVUFBS0MsSUFBTCxHQUFZLE1BQVo7QUFGcUI7QUFHdEI7QUFFRDs7Ozs7Ozs7OztBQVVBOzs7Ozs7Ozs7O0FBVUE7Ozs7Ozs7Ozs7O0FBV0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztFQXJDd0JDLGE7O2VBK0RYSCxXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IE5vZGUgZnJvbSAnLi9ub2RlJ1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBDU1MgZGVjbGFyYXRpb24uXG4gKlxuICogQGV4dGVuZHMgTm9kZVxuICpcbiAqIEBleGFtcGxlXG4gKiBjb25zdCByb290ID0gcG9zdGNzcy5wYXJzZSgnYSB7IGNvbG9yOiBibGFjayB9JylcbiAqIGNvbnN0IGRlY2wgPSByb290LmZpcnN0LmZpcnN0XG4gKiBkZWNsLnR5cGUgICAgICAgLy89PiAnZGVjbCdcbiAqIGRlY2wudG9TdHJpbmcoKSAvLz0+ICcgY29sb3I6IGJsYWNrJ1xuICovXG5jbGFzcyBEZWNsYXJhdGlvbiBleHRlbmRzIE5vZGUge1xuICBjb25zdHJ1Y3RvciAoZGVmYXVsdHMpIHtcbiAgICBzdXBlcihkZWZhdWx0cylcbiAgICB0aGlzLnR5cGUgPSAnZGVjbCdcbiAgfVxuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgRGVjbGFyYXRpb24jXG4gICAqIEBtZW1iZXIge3N0cmluZ30gcHJvcCBUaGUgZGVjbGFyYXRpb27igJlzIHByb3BlcnR5IG5hbWUuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGNvbnN0IHJvb3QgPSBwb3N0Y3NzLnBhcnNlKCdhIHsgY29sb3I6IGJsYWNrIH0nKVxuICAgKiBjb25zdCBkZWNsID0gcm9vdC5maXJzdC5maXJzdFxuICAgKiBkZWNsLnByb3AgLy89PiAnY29sb3InXG4gICAqL1xuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgRGVjbGFyYXRpb24jXG4gICAqIEBtZW1iZXIge3N0cmluZ30gdmFsdWUgVGhlIGRlY2xhcmF0aW9u4oCZcyB2YWx1ZS5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2EgeyBjb2xvcjogYmxhY2sgfScpXG4gICAqIGNvbnN0IGRlY2wgPSByb290LmZpcnN0LmZpcnN0XG4gICAqIGRlY2wudmFsdWUgLy89PiAnYmxhY2snXG4gICAqL1xuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgRGVjbGFyYXRpb24jXG4gICAqIEBtZW1iZXIge2Jvb2xlYW59IGltcG9ydGFudCBgdHJ1ZWAgaWYgdGhlIGRlY2xhcmF0aW9uXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICBoYXMgYW4gIWltcG9ydGFudCBhbm5vdGF0aW9uLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBjb25zdCByb290ID0gcG9zdGNzcy5wYXJzZSgnYSB7IGNvbG9yOiBibGFjayAhaW1wb3J0YW50OyBjb2xvcjogcmVkIH0nKVxuICAgKiByb290LmZpcnN0LmZpcnN0LmltcG9ydGFudCAvLz0+IHRydWVcbiAgICogcm9vdC5maXJzdC5sYXN0LmltcG9ydGFudCAgLy89PiB1bmRlZmluZWRcbiAgICovXG5cbiAgLyoqXG4gICAqIEBtZW1iZXJvZiBEZWNsYXJhdGlvbiNcbiAgICogQG1lbWJlciB7b2JqZWN0fSByYXdzIEluZm9ybWF0aW9uIHRvIGdlbmVyYXRlIGJ5dGUtdG8tYnl0ZSBlcXVhbFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgbm9kZSBzdHJpbmcgYXMgaXQgd2FzIGluIHRoZSBvcmlnaW4gaW5wdXQuXG4gICAqXG4gICAqIEV2ZXJ5IHBhcnNlciBzYXZlcyBpdHMgb3duIHByb3BlcnRpZXMsXG4gICAqIGJ1dCB0aGUgZGVmYXVsdCBDU1MgcGFyc2VyIHVzZXM6XG4gICAqXG4gICAqICogYGJlZm9yZWA6IHRoZSBzcGFjZSBzeW1ib2xzIGJlZm9yZSB0aGUgbm9kZS4gSXQgYWxzbyBzdG9yZXMgYCpgXG4gICAqICAgYW5kIGBfYCBzeW1ib2xzIGJlZm9yZSB0aGUgZGVjbGFyYXRpb24gKElFIGhhY2spLlxuICAgKiAqIGBiZXR3ZWVuYDogdGhlIHN5bWJvbHMgYmV0d2VlbiB0aGUgcHJvcGVydHkgYW5kIHZhbHVlXG4gICAqICAgZm9yIGRlY2xhcmF0aW9ucy5cbiAgICogKiBgaW1wb3J0YW50YDogdGhlIGNvbnRlbnQgb2YgdGhlIGltcG9ydGFudCBzdGF0ZW1lbnQsXG4gICAqICAgaWYgaXQgaXMgbm90IGp1c3QgYCFpbXBvcnRhbnRgLlxuICAgKlxuICAgKiBQb3N0Q1NTIGNsZWFucyBkZWNsYXJhdGlvbiBmcm9tIGNvbW1lbnRzIGFuZCBleHRyYSBzcGFjZXMsXG4gICAqIGJ1dCBpdCBzdG9yZXMgb3JpZ2luIGNvbnRlbnQgaW4gcmF3cyBwcm9wZXJ0aWVzLlxuICAgKiBBcyBzdWNoLCBpZiB5b3UgZG9u4oCZdCBjaGFuZ2UgYSBkZWNsYXJhdGlvbuKAmXMgdmFsdWUsXG4gICAqIFBvc3RDU1Mgd2lsbCB1c2UgdGhlIHJhdyB2YWx1ZSB3aXRoIGNvbW1lbnRzLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBjb25zdCByb290ID0gcG9zdGNzcy5wYXJzZSgnYSB7XFxuICBjb2xvcjpibGFja1xcbn0nKVxuICAgKiByb290LmZpcnN0LmZpcnN0LnJhd3MgLy89PiB7IGJlZm9yZTogJ1xcbiAgJywgYmV0d2VlbjogJzonIH1cbiAgICovXG59XG5cbmV4cG9ydCBkZWZhdWx0IERlY2xhcmF0aW9uXG4iXSwiZmlsZSI6ImRlY2xhcmF0aW9uLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/input.js b/node_modules/autoprefixer/node_modules/postcss/lib/input.js
new file mode 100644
index 0000000..5a43956
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/input.js
@@ -0,0 +1,216 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _path = _interopRequireDefault(require("path"));
+
+var _cssSyntaxError = _interopRequireDefault(require("./css-syntax-error"));
+
+var _previousMap = _interopRequireDefault(require("./previous-map"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+var sequence = 0;
+/**
+ * Represents the source CSS.
+ *
+ * @example
+ * const root = postcss.parse(css, { from: file })
+ * const input = root.source.input
+ */
+
+var Input =
+/*#__PURE__*/
+function () {
+ /**
+ * @param {string} css Input CSS source.
+ * @param {object} [opts] {@link Processor#process} options.
+ */
+ function Input(css, opts) {
+ if (opts === void 0) {
+ opts = {};
+ }
+
+ if (css === null || typeof css === 'object' && !css.toString) {
+ throw new Error("PostCSS received " + css + " instead of CSS string");
+ }
+ /**
+ * Input CSS source
+ *
+ * @type {string}
+ *
+ * @example
+ * const input = postcss.parse('a{}', { from: file }).input
+ * input.css //=> "a{}"
+ */
+
+
+ this.css = css.toString();
+
+ if (this.css[0] === "\uFEFF" || this.css[0] === "\uFFFE") {
+ this.hasBOM = true;
+ this.css = this.css.slice(1);
+ } else {
+ this.hasBOM = false;
+ }
+
+ if (opts.from) {
+ if (/^\w+:\/\//.test(opts.from)) {
+ /**
+ * The absolute path to the CSS source file defined
+ * with the `from` option.
+ *
+ * @type {string}
+ *
+ * @example
+ * const root = postcss.parse(css, { from: 'a.css' })
+ * root.source.input.file //=> '/home/ai/a.css'
+ */
+ this.file = opts.from;
+ } else {
+ this.file = _path.default.resolve(opts.from);
+ }
+ }
+
+ var map = new _previousMap.default(this.css, opts);
+
+ if (map.text) {
+ /**
+ * The input source map passed from a compilation step before PostCSS
+ * (for example, from Sass compiler).
+ *
+ * @type {PreviousMap}
+ *
+ * @example
+ * root.source.input.map.consumer().sources //=> ['a.sass']
+ */
+ this.map = map;
+ var file = map.consumer().file;
+ if (!this.file && file) this.file = this.mapResolve(file);
+ }
+
+ if (!this.file) {
+ sequence += 1;
+ /**
+ * The unique ID of the CSS source. It will be created if `from` option
+ * is not provided (because PostCSS does not know the file path).
+ *
+ * @type {string}
+ *
+ * @example
+ * const root = postcss.parse(css)
+ * root.source.input.file //=> undefined
+ * root.source.input.id //=> "<input css 1>"
+ */
+
+ this.id = '<input css ' + sequence + '>';
+ }
+
+ if (this.map) this.map.file = this.from;
+ }
+
+ var _proto = Input.prototype;
+
+ _proto.error = function error(message, line, column, opts) {
+ if (opts === void 0) {
+ opts = {};
+ }
+
+ var result;
+ var origin = this.origin(line, column);
+
+ if (origin) {
+ result = new _cssSyntaxError.default(message, origin.line, origin.column, origin.source, origin.file, opts.plugin);
+ } else {
+ result = new _cssSyntaxError.default(message, line, column, this.css, this.file, opts.plugin);
+ }
+
+ result.input = {
+ line: line,
+ column: column,
+ source: this.css
+ };
+ if (this.file) result.input.file = this.file;
+ return result;
+ }
+ /**
+ * Reads the input source map and returns a symbol position
+ * in the input source (e.g., in a Sass file that was compiled
+ * to CSS before being passed to PostCSS).
+ *
+ * @param {number} line Line in input CSS.
+ * @param {number} column Column in input CSS.
+ *
+ * @return {filePosition} Position in input source.
+ *
+ * @example
+ * root.source.input.origin(1, 1) //=> { file: 'a.css', line: 3, column: 1 }
+ */
+ ;
+
+ _proto.origin = function origin(line, column) {
+ if (!this.map) return false;
+ var consumer = this.map.consumer();
+ var from = consumer.originalPositionFor({
+ line: line,
+ column: column
+ });
+ if (!from.source) return false;
+ var result = {
+ file: this.mapResolve(from.source),
+ line: from.line,
+ column: from.column
+ };
+ var source = consumer.sourceContentFor(from.source);
+ if (source) result.source = source;
+ return result;
+ };
+
+ _proto.mapResolve = function mapResolve(file) {
+ if (/^\w+:\/\//.test(file)) {
+ return file;
+ }
+
+ return _path.default.resolve(this.map.consumer().sourceRoot || '.', file);
+ }
+ /**
+ * The CSS source identifier. Contains {@link Input#file} if the user
+ * set the `from` option, or {@link Input#id} if they did not.
+ *
+ * @type {string}
+ *
+ * @example
+ * const root = postcss.parse(css, { from: 'a.css' })
+ * root.source.input.from //=> "/home/ai/a.css"
+ *
+ * const root = postcss.parse(css)
+ * root.source.input.from //=> "<input css 1>"
+ */
+ ;
+
+ _createClass(Input, [{
+ key: "from",
+ get: function get() {
+ return this.file || this.id;
+ }
+ }]);
+
+ return Input;
+}();
+
+var _default = Input;
+/**
+ * @typedef {object} filePosition
+ * @property {string} file Path to file.
+ * @property {number} line Source line in file.
+ * @property {number} column Source column in file.
+ */
+
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImlucHV0LmVzNiJdLCJuYW1lcyI6WyJzZXF1ZW5jZSIsIklucHV0IiwiY3NzIiwib3B0cyIsInRvU3RyaW5nIiwiRXJyb3IiLCJoYXNCT00iLCJzbGljZSIsImZyb20iLCJ0ZXN0IiwiZmlsZSIsInBhdGgiLCJyZXNvbHZlIiwibWFwIiwiUHJldmlvdXNNYXAiLCJ0ZXh0IiwiY29uc3VtZXIiLCJtYXBSZXNvbHZlIiwiaWQiLCJlcnJvciIsIm1lc3NhZ2UiLCJsaW5lIiwiY29sdW1uIiwicmVzdWx0Iiwib3JpZ2luIiwiQ3NzU3ludGF4RXJyb3IiLCJzb3VyY2UiLCJwbHVnaW4iLCJpbnB1dCIsIm9yaWdpbmFsUG9zaXRpb25Gb3IiLCJzb3VyY2VDb250ZW50Rm9yIiwic291cmNlUm9vdCJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQTs7QUFFQTs7QUFDQTs7Ozs7Ozs7QUFFQSxJQUFJQSxRQUFRLEdBQUcsQ0FBZjtBQUVBOzs7Ozs7OztJQU9NQyxLOzs7QUFDSjs7OztBQUlBLGlCQUFhQyxHQUFiLEVBQWtCQyxJQUFsQixFQUE4QjtBQUFBLFFBQVpBLElBQVk7QUFBWkEsTUFBQUEsSUFBWSxHQUFMLEVBQUs7QUFBQTs7QUFDNUIsUUFBSUQsR0FBRyxLQUFLLElBQVIsSUFBaUIsT0FBT0EsR0FBUCxLQUFlLFFBQWYsSUFBMkIsQ0FBQ0EsR0FBRyxDQUFDRSxRQUFyRCxFQUFnRTtBQUM5RCxZQUFNLElBQUlDLEtBQUosdUJBQStCSCxHQUEvQiw0QkFBTjtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7O0FBU0EsU0FBS0EsR0FBTCxHQUFXQSxHQUFHLENBQUNFLFFBQUosRUFBWDs7QUFFQSxRQUFJLEtBQUtGLEdBQUwsQ0FBUyxDQUFULE1BQWdCLFFBQWhCLElBQTRCLEtBQUtBLEdBQUwsQ0FBUyxDQUFULE1BQWdCLFFBQWhELEVBQTBEO0FBQ3hELFdBQUtJLE1BQUwsR0FBYyxJQUFkO0FBQ0EsV0FBS0osR0FBTCxHQUFXLEtBQUtBLEdBQUwsQ0FBU0ssS0FBVCxDQUFlLENB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WDtBQUNBLFFBQUksQ0FBQ2QsSUFBSSxDQUFDa0IsTUFBVixFQUFrQixPQUFPLEtBQVA7QUFFbEIsUUFBSUgsTUFBTSxHQUFHO0FBQ1hiLE1BQUFBLElBQUksRUFBRSxLQUFLTyxVQUFMLENBQWdCVCxJQUFJLENBQUNrQixNQUFyQixDQURLO0FBRVhMLE1BQUFBLElBQUksRUFBRWIsSUFBSSxDQUFDYSxJQUZBO0FBR1hDLE1BQUFBLE1BQU0sRUFBRWQsSUFBSSxDQUFDYztBQUhGLEtBQWI7QUFNQSxRQUFJSSxNQUFNLEdBQUdWLFFBQVEsQ0FBQ2MsZ0JBQVQsQ0FBMEJ0QixJQUFJLENBQUNrQixNQUEvQixDQUFiO0FBQ0EsUUFBSUEsTUFBSixFQUFZSCxNQUFNLENBQUNHLE1BQVAsR0FBZ0JBLE1BQWhCO0FBRVosV0FBT0gsTUFBUDtBQUNELEc7O1NBRUROLFUsR0FBQSxvQkFBWVAsSUFBWixFQUFrQjtBQUNoQixRQUFJLFlBQVlELElBQVosQ0FBaUJDLElBQWpCLENBQUosRUFBNEI7QUFDMUIsYUFBT0EsSUFBUDtBQUNEOztBQUNELFdBQU9DLGNBQUtDLE9BQUwsQ0FBYSxLQUFLQyxHQUFMLENBQVNHLFFBQVQsR0FBb0JlLFVBQXBCLElBQWtDLEdBQS9DLEVBQW9EckIsSUFBcEQsQ0FBUDtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7O3dCQWFZO0FBQ1YsYUFBTyxLQUFLQSxJQUFMLElBQWEsS0FBS1EsRUFBekI7QUFDRDs7Ozs7O2VBR1lqQixLO0FBRWYiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgcGF0aCBmcm9tICdwYXRoJ1xuXG5pbXBvcnQgQ3NzU3ludGF4RXJyb3IgZnJvbSAnLi9jc3Mtc3ludGF4LWVycm9yJ1xuaW1wb3J0IFByZXZpb3VzTWFwIGZyb20gJy4vcHJldmlvdXMtbWFwJ1xuXG5sZXQgc2VxdWVuY2UgPSAwXG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgc291cmNlIENTUy5cbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3Qgcm9vdCAgPSBwb3N0Y3NzLnBhcnNlKGNzcywgeyBmcm9tOiBmaWxlIH0pXG4gKiBjb25zdCBpbnB1dCA9IHJvb3Quc291cmNlLmlucHV0XG4gKi9cbmNsYXNzIElucHV0IHtcbiAgLyoqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBjc3MgICAgSW5wdXQgQ1NTIHNvdXJjZS5cbiAgICogQHBhcmFtIHtvYmplY3R9IFtvcHRzXSB7QGxpbmsgUHJvY2Vzc29yI3Byb2Nlc3N9IG9wdGlvbnMuXG4gICAqL1xuICBjb25zdHJ1Y3RvciAoY3NzLCBvcHRzID0geyB9KSB7XG4gICAgaWYgKGNzcyA9PT0gbnVsbCB8fCAodHlwZW9mIGNzcyA9PT0gJ29iamVjdCcgJiYgIWNzcy50b1N0cmluZykpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgUG9zdENTUyByZWNlaXZlZCAkeyBjc3MgfSBpbnN0ZWFkIG9mIENTUyBzdHJpbmdgKVxuICAgIH1cblxuICAgIC8qKlxuICAgICAqIElucHV0IENTUyBzb3VyY2VcbiAgICAgKlxuICAgICAqIEB0eXBlIHtzdHJpbmd9XG4gICAgICpcbiAgICAgKiBAZXhhbXBsZVxuICAgICAqIGNvbnN0IGlucHV0ID0gcG9zdGNzcy5wYXJzZSgnYXt9JywgeyBmcm9tOiBmaWxlIH0pLmlucHV0XG4gICAgICogaW5wdXQuY3NzIC8vPT4gXCJhe31cIlxuICAgICAqL1xuICAgIHRoaXMuY3NzID0gY3NzLnRvU3RyaW5nKClcblxuICAgIGlmICh0aGlzLmNzc1swXSA9PT0gJ1xcdUZFRkYnIHx8IHRoaXMuY3NzWzBdID09PSAnXFx1RkZGRScpIHtcbiAgICAgIHRoaXMuaGFzQk9NID0gdHJ1ZVxuICAgICAgdGhpcy5jc3MgPSB0aGlzLmNzcy5zbGljZSgxKVxuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmhhc0JPTSA9IGZhbHNlXG4gICAgfVxuXG4gICAgaWYgKG9wdHMuZnJvbSkge1xuICAgICAgaWYgKC9eXFx3KzpcXC9cXC8vLnRlc3Qob3B0cy5mcm9tKSkge1xuICAgICAgICAvKipcbiAgICAgICAgICogVGhlIGFic29sdXRlIHBhdGggdG8gdGhlIENTUyBzb3VyY2UgZmlsZSBkZWZpbmVkXG4gICAgICAgICAqIHdpdGggdGhlIGBmcm9tYCBvcHRpb24uXG4gICAgICAgICAqXG4gICAgICAgICAqIEB0eXBlIHtzdHJpbmd9XG4gICAgICAgICAqXG4gICAgICAgICAqIEBleGFtcGxlXG4gICAgICAgICAqIGNvbnN0IHJvb3QgPSBwb3N0Y3NzLnBhcnNlKGNzcywgeyBmcm9tOiAnYS5jc3MnIH0pXG4gICAgICAgICAqIHJvb3Quc291cmNlLmlucHV0LmZpbGUgLy89PiAnL2hvbWUvYWkvYS5jc3MnXG4gICAgICAgICAqL1xuICAgICAgICB0aGlzLmZpbGUgPSBvcHRzLmZyb21cbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRoaXMuZmlsZSA9IHBhdGgucmVzb2x2ZShvcHRzLmZyb20pXG4gICAgICB9XG4gICAgfVxuXG4gICAgbGV0IG1hcCA9IG5ldyBQcmV2aW91c01hcCh0aGlzLmNzcywgb3B0cylcbiAgICBpZiAobWFwLnRleHQpIHtcbiAgICAgIC8qKlxuICAgICAgICogVGhlIGlucHV0IHNvdXJjZSBtYXAgcGFzc2VkIGZyb20gYSBjb21waWxhdGlvbiBzdGVwIGJlZm9yZSBQb3N0Q1NTXG4gICAgICAgKiAoZm9yIGV4YW1wbGUsIGZyb20gU2FzcyBjb21waWxlcikuXG4gICAgICAgKlxuICAgICAgICogQHR5cGUge1ByZXZpb3VzTWFwfVxuICAgICAgICpcbiAgICAgICAqIEBleGFtcGxlXG4gICAgICAgKiByb290LnNvdXJjZS5pbnB1dC5tYXAuY29uc3VtZXIoKS5zb3VyY2VzIC8vPT4gWydhLnNhc3MnXVxuICAgICAgICovXG4gICAgICB0aGlzLm1hcCA9IG1hcFxuICAgICAgbGV0IGZpbGUgPSBtYXAuY29uc3VtZXIoKS5maWxlXG4gICAgICBpZiAoIXRoaXMuZmlsZSAmJiBmaWxlKSB0aGlzLmZpbGUgPSB0aGlzLm1hcFJlc29sdmUoZmlsZSlcbiAgICB9XG5cbiAgICBpZiAoIXRoaXMuZmlsZSkge1xuICAgICAgc2VxdWVuY2UgKz0gMVxuICAgICAgLyoqXG4gICAgICAgKiBUaGUgdW5pcXVlIElEIG9mIHRoZSBDU1Mgc291cmNlLiBJdCB3aWxsIGJlIGNyZWF0ZWQgaWYgYGZyb21gIG9wdGlvblxuICAgICAgICogaXMgbm90IHByb3ZpZGVkIChiZWNhdXNlIFBvc3RDU1MgZG9lcyBub3Qga25vdyB0aGUgZmlsZSBwYXRoKS5cbiAgICAgICAqXG4gICAgICAgKiBAdHlwZSB7c3RyaW5nfVxuICAgICAgICpcbiAgICAgICAqIEBleGFtcGxlXG4gICAgICAgKiBjb25zdCByb290ID0gcG9zdGNzcy5wYXJzZShjc3MpXG4gICAgICAgKiByb290LnNvdXJjZS5pbnB1dC5maWxlIC8vPT4gdW5kZWZpbmVkXG4gICAgICAgKiByb290LnNvdXJjZS5pbnB1dC5pZCAgIC8vPT4gXCI8aW5wdXQgY3NzIDE+XCJcbiAgICAgICAqL1xuICAgICAgdGhpcy5pZCA9ICc8aW5wdXQgY3NzICcgKyBzZXF1ZW5jZSArICc+J1xuICAgIH1cbiAgICBpZiAodGhpcy5tYXApIHRoaXMubWFwLmZpbGUgPSB0aGlzLmZyb21cbiAgfVxuXG4gIGVycm9yIChtZXNzYWdlLCBsaW5lLCBjb2x1bW4sIG9wdHMgPSB7IH0pIHtcbiAgICBsZXQgcmVzdWx0XG4gICAgbGV0IG9yaWdpbiA9IHRoaXMub3JpZ2luKGxpbmUsIGNvbHVtbilcbiAgICBpZiAob3JpZ2luKSB7XG4gICAgICByZXN1bHQgPSBuZXcgQ3NzU3ludGF4RXJyb3IoXG4gICAgICAgIG1lc3NhZ2UsIG9yaWdpbi5saW5lLCBvcmlnaW4uY29sdW1uLFxuICAgICAgICBvcmlnaW4uc291cmNlLCBvcmlnaW4uZmlsZSwgb3B0cy5wbHVnaW5cbiAgICAgIClcbiAgICB9IGVsc2Uge1xuICAgICAgcmVzdWx0ID0gbmV3IENzc1N5bnRheEVycm9yKFxuICAgICAgICBtZXNzYWdlLCBsaW5lLCBjb2x1bW4sIHRoaXMuY3NzLCB0aGlzLmZpbGUsIG9wdHMucGx1Z2luKVxuICAgIH1cblxuICAgIHJlc3VsdC5pbnB1dCA9IHsgbGluZSwgY29sdW1uLCBzb3VyY2U6IHRoaXMuY3NzIH1cbiAgICBpZiAodGhpcy5maWxlKSByZXN1bHQuaW5wdXQuZmlsZSA9IHRoaXMuZmlsZVxuXG4gICAgcmV0dXJuIHJlc3VsdFxuICB9XG5cbiAgLyoqXG4gICAqIFJlYWRzIHRoZSBpbnB1dCBzb3VyY2UgbWFwIGFuZCByZXR1cm5zIGEgc3ltYm9sIHBvc2l0aW9uXG4gICAqIGluIHRoZSBpbnB1dCBzb3VyY2UgKGUuZy4sIGluIGEgU2FzcyBmaWxlIHRoYXQgd2FzIGNvbXBpbGVkXG4gICAqIHRvIENTUyBiZWZvcmUgYmVpbmcgcGFzc2VkIHRvIFBvc3RDU1MpLlxuICAgKlxuICAgKiBAcGFyYW0ge251bWJlcn0gbGluZSAgIExpbmUgaW4gaW5wdXQgQ1NTLlxuICAgKiBAcGFyYW0ge251bWJlcn0gY29sdW1uIENvbHVtbiBpbiBpbnB1dCBDU1MuXG4gICAqXG4gICAqIEByZXR1cm4ge2ZpbGVQb3NpdGlvbn0gUG9zaXRpb24gaW4gaW5wdXQgc291cmNlLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiByb290LnNvdXJjZS5pbnB1dC5vcmlnaW4oMSwgMSkgLy89PiB7IGZpbGU6ICdhLmNzcycsIGxpbmU6IDMsIGNvbHVtbjogMSB9XG4gICAqL1xuICBvcmlnaW4gKGxpbmUsIGNvbHVtbikge1xuICAgIGlmICghdGhpcy5tYXApIHJldHVybiBmYWxzZVxuICAgIGxldCBjb25zdW1lciA9IHRoaXMubWFwLmNvbnN1bWVyKClcblxuICAgIGxldCBmcm9tID0gY29uc3VtZXIub3JpZ2luYWxQb3NpdGlvbkZvcih7IGxpbmUsIGNvbHVtbiB9KVxuICAgIGlmICghZnJvbS5zb3VyY2UpIHJldHVybiBmYWxzZVxuXG4gICAgbGV0IHJlc3VsdCA9IHtcbiAgICAgIGZpbGU6IHRoaXMubWFwUmVzb2x2ZShmcm9tLnNvdXJjZSksXG4gICAgICBsaW5lOiBmcm9tLmxpbmUsXG4gICAgICBjb2x1bW46IGZyb20uY29sdW1uXG4gICAgfVxuXG4gICAgbGV0IHNvdXJjZSA9IGNvbnN1bWVyLnNvdXJjZUNvbnRlbnRGb3IoZnJvbS5zb3VyY2UpXG4gICAgaWYgKHNvdXJjZSkgcmVzdWx0LnNvdXJjZSA9IHNvdXJjZVxuXG4gICAgcmV0dXJuIHJlc3VsdFxuICB9XG5cbiAgbWFwUmVzb2x2ZSAoZmlsZSkge1xuICAgIGlmICgvXlxcdys6XFwvXFwvLy50ZXN0KGZpbGUpKSB7XG4gICAgICByZXR1cm4gZmlsZVxuICAgIH1cbiAgICByZXR1cm4gcGF0aC5yZXNvbHZlKHRoaXMubWFwLmNvbnN1bWVyKCkuc291cmNlUm9vdCB8fCAnLicsIGZpbGUpXG4gIH1cblxuICAvKipcbiAgICogVGhlIENTUyBzb3VyY2UgaWRlbnRpZmllci4gQ29udGFpbnMge0BsaW5rIElucHV0I2ZpbGV9IGlmIHRoZSB1c2VyXG4gICAqIHNldCB0aGUgYGZyb21gIG9wdGlvbiwgb3Ige0BsaW5rIElucHV0I2lkfSBpZiB0aGV5IGRpZCBub3QuXG4gICAqXG4gICAqIEB0eXBlIHtzdHJpbmd9XG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGNvbnN0IHJvb3QgPSBwb3N0Y3NzLnBhcnNlKGNzcywgeyBmcm9tOiAnYS5jc3MnIH0pXG4gICAqIHJvb3Quc291cmNlLmlucHV0LmZyb20gLy89PiBcIi9ob21lL2FpL2EuY3NzXCJcbiAgICpcbiAgICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoY3NzKVxuICAgKiByb290LnNvdXJjZS5pbnB1dC5mcm9tIC8vPT4gXCI8aW5wdXQgY3NzIDE+XCJcbiAgICovXG4gIGdldCBmcm9tICgpIHtcbiAgICByZXR1cm4gdGhpcy5maWxlIHx8IHRoaXMuaWRcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBJbnB1dFxuXG4vKipcbiAqIEB0eXBlZGVmICB7b2JqZWN0fSBmaWxlUG9zaXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBmaWxlICAgUGF0aCB0byBmaWxlLlxuICogQHByb3BlcnR5IHtudW1iZXJ9IGxpbmUgICBTb3VyY2UgbGluZSBpbiBmaWxlLlxuICogQHByb3BlcnR5IHtudW1iZXJ9IGNvbHVtbiBTb3VyY2UgY29sdW1uIGluIGZpbGUuXG4gKi9cbiJdLCJmaWxlIjoiaW5wdXQuanMifQ==
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/lazy-result.js b/node_modules/autoprefixer/node_modules/postcss/lib/lazy-result.js
new file mode 100644
index 0000000..79c31c6
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/lazy-result.js
@@ -0,0 +1,444 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _mapGenerator = _interopRequireDefault(require("./map-generator"));
+
+var _stringify2 = _interopRequireDefault(require("./stringify"));
+
+var _warnOnce = _interopRequireDefault(require("./warn-once"));
+
+var _result = _interopRequireDefault(require("./result"));
+
+var _parse = _interopRequireDefault(require("./parse"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function isPromise(obj) {
+ return typeof obj === 'object' && typeof obj.then === 'function';
+}
+/**
+ * A Promise proxy for the result of PostCSS transformations.
+ *
+ * A `LazyResult` instance is returned by {@link Processor#process}.
+ *
+ * @example
+ * const lazy = postcss([autoprefixer]).process(css)
+ */
+
+
+var LazyResult =
+/*#__PURE__*/
+function () {
+ function LazyResult(processor, css, opts) {
+ this.stringified = false;
+ this.processed = false;
+ var root;
+
+ if (typeof css === 'object' && css !== null && css.type === 'root') {
+ root = css;
+ } else if (css instanceof LazyResult || css instanceof _result.default) {
+ root = css.root;
+
+ if (css.map) {
+ if (typeof opts.map === 'undefined') opts.map = {};
+ if (!opts.map.inline) opts.map.inline = false;
+ opts.map.prev = css.map;
+ }
+ } else {
+ var parser = _parse.default;
+ if (opts.syntax) parser = opts.syntax.parse;
+ if (opts.parser) parser = opts.parser;
+ if (parser.parse) parser = parser.parse;
+
+ try {
+ root = parser(css, opts);
+ } catch (error) {
+ this.error = error;
+ }
+ }
+
+ this.result = new _result.default(processor, root, opts);
+ }
+ /**
+ * Returns a {@link Processor} instance, which will be used
+ * for CSS transformations.
+ *
+ * @type {Processor}
+ */
+
+
+ var _proto = LazyResult.prototype;
+
+ /**
+ * Processes input CSS through synchronous plugins
+ * and calls {@link Result#warnings()}.
+ *
+ * @return {Warning[]} Warnings from plugins.
+ */
+ _proto.warnings = function warnings() {
+ return this.sync().warnings();
+ }
+ /**
+ * Alias for the {@link LazyResult#css} property.
+ *
+ * @example
+ * lazy + '' === lazy.css
+ *
+ * @return {string} Output CSS.
+ */
+ ;
+
+ _proto.toString = function toString() {
+ return this.css;
+ }
+ /**
+ * Processes input CSS through synchronous and asynchronous plugins
+ * and calls `onFulfilled` with a Result instance. If a plugin throws
+ * an error, the `onRejected` callback will be executed.
+ *
+ * It implements standard Promise API.
+ *
+ * @param {onFulfilled} onFulfilled Callback will be executed
+ * when all plugins will finish work.
+ * @param {onRejected} onRejected Callback will be executed on any error.
+ *
+ * @return {Promise} Promise API to make queue.
+ *
+ * @example
+ * postcss([autoprefixer]).process(css, { from: cssPath }).then(result => {
+ * console.log(result.css)
+ * })
+ */
+ ;
+
+ _proto.then = function then(onFulfilled, onRejected) {
+ if (process.env.NODE_ENV !== 'production') {
+ if (!('from' in this.opts)) {
+ (0, _warnOnce.default)('Without `from` option PostCSS could generate wrong source map ' + 'and will not find Browserslist config. Set it to CSS file path ' + 'or to `undefined` to prevent this warning.');
+ }
+ }
+
+ return this.async().then(onFulfilled, onRejected);
+ }
+ /**
+ * Processes input CSS through synchronous and asynchronous plugins
+ * and calls onRejected for each error thrown in any plugin.
+ *
+ * It implements standard Promise API.
+ *
+ * @param {onRejected} onRejected Callback will be executed on any error.
+ *
+ * @return {Promise} Promise API to make queue.
+ *
+ * @example
+ * postcss([autoprefixer]).process(css).then(result => {
+ * console.log(result.css)
+ * }).catch(error => {
+ * console.error(error)
+ * })
+ */
+ ;
+
+ _proto.catch = function _catch(onRejected) {
+ return this.async().catch(onRejected);
+ }
+ /**
+ * Processes input CSS through synchronous and asynchronous plugins
+ * and calls onFinally on any error or when all plugins will finish work.
+ *
+ * It implements standard Promise API.
+ *
+ * @param {onFinally} onFinally Callback will be executed on any error or
+ * when all plugins will finish work.
+ *
+ * @return {Promise} Promise API to make queue.
+ *
+ * @example
+ * postcss([autoprefixer]).process(css).finally(() => {
+ * console.log('processing ended')
+ * })
+ */
+ ;
+
+ _proto.finally = function _finally(onFinally) {
+ return this.async().then(onFinally, onFinally);
+ };
+
+ _proto.handleError = function handleError(error, plugin) {
+ try {
+ this.error = error;
+
+ if (error.name === 'CssSyntaxError' && !error.plugin) {
+ error.plugin = plugin.postcssPlugin;
+ error.setMessage();
+ } else if (plugin.postcssVersion) {
+ if (process.env.NODE_ENV !== 'production') {
+ var pluginName = plugin.postcssPlugin;
+ var pluginVer = plugin.postcssVersion;
+ var runtimeVer = this.result.processor.version;
+ var a = pluginVer.split('.');
+ var b = runtimeVer.split('.');
+
+ if (a[0] !== b[0] || parseInt(a[1]) > parseInt(b[1])) {
+ console.error('Unknown error from PostCSS plugin. Your current PostCSS ' + 'version is ' + runtimeVer + ', but ' + pluginName + ' uses ' + pluginVer + '. Perhaps this is the source of the error below.');
+ }
+ }
+ }
+ } catch (err) {
+ if (console && console.error) console.error(err);
+ }
+ };
+
+ _proto.asyncTick = function asyncTick(resolve, reject) {
+ var _this = this;
+
+ if (this.plugin >= this.processor.plugins.length) {
+ this.processed = true;
+ return resolve();
+ }
+
+ try {
+ var plugin = this.processor.plugins[this.plugin];
+ var promise = this.run(plugin);
+ this.plugin += 1;
+
+ if (isPromise(promise)) {
+ promise.then(function () {
+ _this.asyncTick(resolve, reject);
+ }).catch(function (error) {
+ _this.handleError(error, plugin);
+
+ _this.processed = true;
+ reject(error);
+ });
+ } else {
+ this.asyncTick(resolve, reject);
+ }
+ } catch (error) {
+ this.processed = true;
+ reject(error);
+ }
+ };
+
+ _proto.async = function async() {
+ var _this2 = this;
+
+ if (this.processed) {
+ return new Promise(function (resolve, reject) {
+ if (_this2.error) {
+ reject(_this2.error);
+ } else {
+ resolve(_this2.stringify());
+ }
+ });
+ }
+
+ if (this.processing) {
+ return this.processing;
+ }
+
+ this.processing = new Promise(function (resolve, reject) {
+ if (_this2.error) return reject(_this2.error);
+ _this2.plugin = 0;
+
+ _this2.asyncTick(resolve, reject);
+ }).then(function () {
+ _this2.processed = true;
+ return _this2.stringify();
+ });
+ return this.processing;
+ };
+
+ _proto.sync = function sync() {
+ if (this.processed) return this.result;
+ this.processed = true;
+
+ if (this.processing) {
+ throw new Error('Use process(css).then(cb) to work with async plugins');
+ }
+
+ if (this.error) throw this.error;
+
+ for (var _iterator = this.result.processor.plugins, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
+ var _ref;
+
+ if (_isArray) {
+ if (_i >= _iterator.length) break;
+ _ref = _iterator[_i++];
+ } else {
+ _i = _iterator.next();
+ if (_i.done) break;
+ _ref = _i.value;
+ }
+
+ var plugin = _ref;
+ var promise = this.run(plugin);
+
+ if (isPromise(promise)) {
+ throw new Error('Use process(css).then(cb) to work with async plugins');
+ }
+ }
+
+ return this.result;
+ };
+
+ _proto.run = function run(plugin) {
+ this.result.lastPlugin = plugin;
+
+ try {
+ return plugin(this.result.root, this.result);
+ } catch (error) {
+ this.handleError(error, plugin);
+ throw error;
+ }
+ };
+
+ _proto.stringify = function stringify() {
+ if (this.stringified) return this.result;
+ this.stringified = true;
+ this.sync();
+ var opts = this.result.opts;
+ var str = _stringify2.default;
+ if (opts.syntax) str = opts.syntax.stringify;
+ if (opts.stringifier) str = opts.stringifier;
+ if (str.stringify) str = str.stringify;
+ var map = new _mapGenerator.default(str, this.result.root, this.result.opts);
+ var data = map.generate();
+ this.result.css = data[0];
+ this.result.map = data[1];
+ return this.result;
+ };
+
+ _createClass(LazyResult, [{
+ key: "processor",
+ get: function get() {
+ return this.result.processor;
+ }
+ /**
+ * Options from the {@link Processor#process} call.
+ *
+ * @type {processOptions}
+ */
+
+ }, {
+ key: "opts",
+ get: function get() {
+ return this.result.opts;
+ }
+ /**
+ * Processes input CSS through synchronous plugins, converts `Root`
+ * to a CSS string and returns {@link Result#css}.
+ *
+ * This property will only work with synchronous plugins.
+ * If the processor contains any asynchronous plugins
+ * it will throw an error. This is why this method is only
+ * for debug purpose, you should always use {@link LazyResult#then}.
+ *
+ * @type {string}
+ * @see Result#css
+ */
+
+ }, {
+ key: "css",
+ get: function get() {
+ return this.stringify().css;
+ }
+ /**
+ * An alias for the `css` property. Use it with syntaxes
+ * that generate non-CSS output.
+ *
+ * This property will only work with synchronous plugins.
+ * If the processor contains any asynchronous plugins
+ * it will throw an error. This is why this method is only
+ * for debug purpose, you should always use {@link LazyResult#then}.
+ *
+ * @type {string}
+ * @see Result#content
+ */
+
+ }, {
+ key: "content",
+ get: function get() {
+ return this.stringify().content;
+ }
+ /**
+ * Processes input CSS through synchronous plugins
+ * and returns {@link Result#map}.
+ *
+ * This property will only work with synchronous plugins.
+ * If the processor contains any asynchronous plugins
+ * it will throw an error. This is why this method is only
+ * for debug purpose, you should always use {@link LazyResult#then}.
+ *
+ * @type {SourceMapGenerator}
+ * @see Result#map
+ */
+
+ }, {
+ key: "map",
+ get: function get() {
+ return this.stringify().map;
+ }
+ /**
+ * Processes input CSS through synchronous plugins
+ * and returns {@link Result#root}.
+ *
+ * This property will only work with synchronous plugins. If the processor
+ * contains any asynchronous plugins it will throw an error.
+ *
+ * This is why this method is only for debug purpose,
+ * you should always use {@link LazyResult#then}.
+ *
+ * @type {Root}
+ * @see Result#root
+ */
+
+ }, {
+ key: "root",
+ get: function get() {
+ return this.sync().root;
+ }
+ /**
+ * Processes input CSS through synchronous plugins
+ * and returns {@link Result#messages}.
+ *
+ * This property will only work with synchronous plugins. If the processor
+ * contains any asynchronous plugins it will throw an error.
+ *
+ * This is why this method is only for debug purpose,
+ * you should always use {@link LazyResult#then}.
+ *
+ * @type {Message[]}
+ * @see Result#messages
+ */
+
+ }, {
+ key: "messages",
+ get: function get() {
+ return this.sync().messages;
+ }
+ }]);
+
+ return LazyResult;
+}();
+
+var _default = LazyResult;
+/**
+ * @callback onFulfilled
+ * @param {Result} result
+ */
+
+/**
+ * @callback onRejected
+ * @param {Error} error
+ */
+
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxhenktcmVzdWx0LmVzNiJdLCJuYW1lcyI6WyJpc1Byb21pc2UiLCJvYmoiLCJ0aGVuIiwiTGF6eVJlc3VsdCIsInByb2Nlc3NvciIsImNzcyIsIm9wdHMiLCJzdHJpbmdpZmllZCIsInByb2Nlc3NlZCIsInJvb3QiLCJ0eXBlIiwiUmVzdWx0IiwibWFwIiwiaW5saW5lIiwicHJldiIsInBhcnNlciIsInBhcnNlIiwic3ludGF4IiwiZXJyb3IiLCJyZXN1bHQiLCJ3YXJuaW5ncyIsInN5bmMiLCJ0b1N0cmluZyIsIm9uRnVsZmlsbGVkIiwib25SZWplY3RlZCIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsImFzeW5jIiwiY2F0Y2giLCJmaW5hbGx5Iiwib25GaW5hbGx5IiwiaGFuZGxlRXJyb3IiLCJwbHVnaW4iLCJuYW1lIiwicG9zdGNzc1BsdWdpbiIsInNldE1lc3NhZ2UiLCJwb3N0Y3NzVmVyc2lvbiIsInBsdWdpbk5hbWUiLCJwbHVnaW5WZXIiLCJydW50aW1lVmVyIiwidmVyc2lvbiIsImEiLCJzcGxpdCIsImIiLCJwYXJzZUludCIsImNvbnNvbGUiLCJlcnIiLCJhc3luY1RpY2siLCJyZXNvbHZlIiwicmVqZWN0IiwicGx1Z2lucyIsImxlbmd0aCIsInByb21pc2UiLCJydW4iLCJQcm9taXNlIiwic3RyaW5naWZ5IiwicHJvY2Vzc2luZyIsIkVycm9yIiwibGFzdFBsdWdpbiIsInN0ciIsInN0cmluZ2lmaWVyIiwiTWFwR2VuZXJhdG9yIiwiZGF0YSIsImdlbmVyYXRlIiwiY29udGVudCIsIm1lc3NhZ2VzIl0sIm1hcHBpbmdzIjoiOzs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOzs7Ozs7OztBQUVBLFNBQVNBLFNBQVQsQ0FBb0JDLEdBQXBCLEVBQXlCO0FBQ3ZCLFNBQU8sT0FBT0EsR0FBUCxLQUFlLFFBQWYsSUFBMkIsT0FBT0EsR0FBRyxDQUFDQyxJQUFYLEtBQW9CLFVBQXREO0FBQ0Q7QUFFRDs7Ozs7Ozs7OztJQVFNQyxV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QUdBLEdBQUcsQ0FBQ0osU0FBVjtBQUVuQixRQUFJNUMsR0FBRyxHQUFHLElBQUlrRCxxQkFBSixDQUFpQkYsR0FBakIsRUFBc0IsS0FBS3pDLE1BQUwsQ0FBWVYsSUFBbEMsRUFBd0MsS0FBS1UsTUFBTCxDQUFZYixJQUFwRCxDQUFWO0FBQ0EsUUFBSXlELElBQUksR0FBR25ELEdBQUcsQ0FBQ29ELFFBQUosRUFBWDtBQUNBLFNBQUs3QyxNQUFMLENBQVlkLEdBQVosR0FBa0IwRCxJQUFJLENBQUMsQ0FBRCxDQUF0QjtBQUNBLFNBQUs1QyxNQUFMLENBQVlQLEdBQVosR0FBa0JtRCxJQUFJLENBQUMsQ0FBRCxDQUF0QjtBQUVBLFdBQU8sS0FBSzVDLE1BQVo7QUFDRCxHOzs7O3dCQWpVZ0I7QUFDZixhQUFPLEtBQUtBLE1BQUwsQ0FBWWYsU0FBbkI7QUFDRDtBQUVEOzs7Ozs7Ozt3QkFLWTtBQUNWLGFBQU8sS0FBS2UsTUFBTCxDQUFZYixJQUFuQjtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozt3QkFZVztBQUNULGFBQU8sS0FBS2tELFNBQUwsR0FBaUJuRCxHQUF4QjtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozt3QkFZZTtBQUNiLGFBQU8sS0FBS21ELFNBQUwsR0FBaUJTLE9BQXhCO0FBQ0Q7QUFFRDs7Ozs7Ozs7Ozs7Ozs7O3dCQVlXO0FBQ1QsYUFBTyxLQUFLVCxTQUFMLEdBQWlCNUMsR0FBeEI7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs7Ozs7O3dCQWFZO0FBQ1YsYUFBTyxLQUFLUyxJQUFMLEdBQVlaLElBQW5CO0FBQ0Q7QUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozt3QkFhZ0I7QUFDZCxhQUFPLEtBQUtZLElBQUwsR0FBWTZDLFFBQW5CO0FBQ0Q7Ozs7OztlQXVPWS9ELFU7QUFFZjs7Ozs7QUFLQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBNYXBHZW5lcmF0b3IgZnJvbSAnLi9tYXAtZ2VuZXJhdG9yJ1xuaW1wb3J0IHN0cmluZ2lmeSBmcm9tICcuL3N0cmluZ2lmeSdcbmltcG9ydCB3YXJuT25jZSBmcm9tICcuL3dhcm4tb25jZSdcbmltcG9ydCBSZXN1bHQgZnJvbSAnLi9yZXN1bHQnXG5pbXBvcnQgcGFyc2UgZnJvbSAnLi9wYXJzZSdcblxuZnVuY3Rpb24gaXNQcm9taXNlIChvYmopIHtcbiAgcmV0dXJuIHR5cGVvZiBvYmogPT09ICdvYmplY3QnICYmIHR5cGVvZiBvYmoudGhlbiA9PT0gJ2Z1bmN0aW9uJ1xufVxuXG4vKipcbiAqIEEgUHJvbWlzZSBwcm94eSBmb3IgdGhlIHJlc3VsdCBvZiBQb3N0Q1NTIHRyYW5zZm9ybWF0aW9ucy5cbiAqXG4gKiBBIGBMYXp5UmVzdWx0YCBpbnN0YW5jZSBpcyByZXR1cm5lZCBieSB7QGxpbmsgUHJvY2Vzc29yI3Byb2Nlc3N9LlxuICpcbiAqIEBleGFtcGxlXG4gKiBjb25zdCBsYXp5ID0gcG9zdGNzcyhbYXV0b3ByZWZpeGVyXSkucHJvY2Vzcyhjc3MpXG4gKi9cbmNsYXNzIExhenlSZXN1bHQge1xuICBjb25zdHJ1Y3RvciAocHJvY2Vzc29yLCBjc3MsIG9wdHMpIHtcbiAgICB0aGlzLnN0cmluZ2lmaWVkID0gZmFsc2VcbiAgICB0aGlzLnByb2Nlc3NlZCA9IGZhbHNlXG5cbiAgICBsZXQgcm9vdFxuICAgIGlmICh0eXBlb2YgY3NzID09PSAnb2JqZWN0JyAmJiBjc3MgIT09IG51bGwgJiYgY3NzLnR5cGUgPT09ICdyb290Jykge1xuICAgICAgcm9vdCA9IGNzc1xuICAgIH0gZWxzZSBpZiAoY3NzIGluc3RhbmNlb2YgTGF6eVJlc3VsdCB8fCBjc3MgaW5zdGFuY2VvZiBSZXN1bHQpIHtcbiAgICAgIHJvb3QgPSBjc3Mucm9vdFxuICAgICAgaWYgKGNzcy5tYXApIHtcbiAgICAgICAgaWYgKHR5cGVvZiBvcHRzLm1hcCA9PT0gJ3VuZGVmaW5lZCcpIG9wdHMubWFwID0geyB9XG4gICAgICAgIGlmICghb3B0cy5tYXAuaW5saW5lKSBvcHRzLm1hcC5pbmxpbmUgPSBmYWxzZVxuICAgICAgICBvcHRzLm1hcC5wcmV2ID0gY3NzLm1hcFxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBsZXQgcGFyc2VyID0gcGFyc2VcbiAgICAgIGlmIChvcHRzLnN5bnRheCkgcGFyc2VyID0gb3B0cy5zeW50YXgucGFyc2VcbiAgICAgIGlmIChvcHRzLnBhcnNlcikgcGFyc2VyID0gb3B0cy5wYXJzZXJcbiAgICAgIGlmIChwYXJzZXIucGFyc2UpIHBhcnNlciA9IHBhcnNlci5wYXJzZVxuXG4gICAgICB0cnkge1xuICAgICAgICByb290ID0gcGFyc2VyKGNzcywgb3B0cylcbiAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgIHRoaXMuZXJyb3IgPSBlcnJvclxuICAgICAgfVxuICAgIH1cblxuICAgIHRoaXMucmVzdWx0ID0gbmV3IFJlc3VsdChwcm9jZXNzb3IsIHJvb3QsIG9wdHMpXG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyBhIHtAbGluayBQcm9jZXNzb3J9IGluc3RhbmNlLCB3aGljaCB3aWxsIGJlIHVzZWRcbiAgICogZm9yIENTUyB0cmFuc2Zvcm1hdGlvbnMuXG4gICAqXG4gICAqIEB0eXBlIHtQcm9jZXNzb3J9XG4gICAqL1xuICBnZXQgcHJvY2Vzc29yICgpIHtcbiAgICByZXR1cm4gdGhpcy5yZXN1bHQucHJvY2Vzc29yXG4gIH1cblxuICAvKipcbiAgICogT3B0aW9ucyBmcm9tIHRoZSB7QGxpbmsgUHJvY2Vzc29yI3Byb2Nlc3N9IGNhbGwuXG4gICAqXG4gICAqIEB0eXBlIHtwcm9jZXNzT3B0aW9uc31cbiAgICovXG4gIGdldCBvcHRzICgpIHtcbiAgICByZXR1cm4gdGhpcy5yZXN1bHQub3B0c1xuICB9XG5cbiAgLyoqXG4gICAqIFByb2Nlc3NlcyBpbnB1dCBDU1MgdGhyb3VnaCBzeW5jaHJvbm91cyBwbHVnaW5zLCBjb252ZXJ0cyBgUm9vdGBcbiAgICogdG8gYSBDU1Mgc3RyaW5nIGFuZCByZXR1cm5zIHtAbGluayBSZXN1bHQjY3NzfS5cbiAgICpcbiAgICogVGhpcyBwcm9wZXJ0eSB3aWxsIG9ubHkgd29yayB3aXRoIHN5bmNocm9ub3VzIHBsdWdpbnMuXG4gICAqIElmIHRoZSBwcm9jZXNzb3IgY29udGFpbnMgYW55IGFzeW5jaHJvbm91cyBwbHVnaW5zXG4gICAqIGl0IHdpbGwgdGhyb3cgYW4gZXJyb3IuIFRoaXMgaXMgd2h5IHRoaXMgbWV0aG9kIGlzIG9ubHlcbiAgICogZm9yIGRlYnVnIHB1cnBvc2UsIHlvdSBzaG91bGQgYWx3YXlzIHVzZSB7QGxpbmsgTGF6eVJlc3VsdCN0aGVufS5cbiAgICpcbiAgICogQHR5cGUge3N0cmluZ31cbiAgICogQHNlZSBSZXN1bHQjY3NzXG4gICAqL1xuICBnZXQgY3NzICgpIHtcbiAgICByZXR1cm4gdGhpcy5zdHJpbmdpZnkoKS5jc3NcbiAgfVxuXG4gIC8qKlxuICAgKiBBbiBhbGlhcyBmb3IgdGhlIGBjc3NgIHByb3BlcnR5LiBVc2UgaXQgd2l0aCBzeW50YXhlc1xuICAgKiB0aGF0IGdlbmVyYXRlIG5vbi1DU1Mgb3V0cHV0LlxuICAgKlxuICAgKiBUaGlzIHByb3BlcnR5IHdpbGwgb25seSB3b3JrIHdpdGggc3luY2hyb25vdXMgcGx1Z2lucy5cbiAgICogSWYgdGhlIHByb2Nlc3NvciBjb250YWlucyBhbnkgYXN5bmNocm9ub3VzIHBsdWdpbnNcbiAgICogaXQgd2lsbCB0aHJvdyBhbiBlcnJvci4gVGhpcyBpcyB3aHkgdGhpcyBtZXRob2QgaXMgb25seVxuICAgKiBmb3IgZGVidWcgcHVycG9zZSwgeW91IHNob3VsZCBhbHdheXMgdXNlIHtAbGluayBMYXp5UmVzdWx0I3RoZW59LlxuICAgKlxuICAgKiBAdHlwZSB7c3RyaW5nfVxuICAgKiBAc2VlIFJlc3VsdCNjb250ZW50XG4gICAqL1xuICBnZXQgY29udGVudCAoKSB7XG4gICAgcmV0dXJuIHRoaXMuc3RyaW5naWZ5KCkuY29udGVudFxuICB9XG5cbiAgLyoqXG4gICAqIFByb2Nlc3NlcyBpbnB1dCBDU1MgdGhyb3VnaCBzeW5jaHJvbm91cyBwbHVnaW5zXG4gICAqIGFuZCByZXR1cm5zIHtAbGluayBSZXN1bHQjbWFwfS5cbiAgICpcbiAgICogVGhpcyBwcm9wZXJ0eSB3aWxsIG9ubHkgd29yayB3aXRoIHN5bmNocm9ub3VzIHBsdWdpbnMuXG4gICAqIElmIHRoZSBwcm9jZXNzb3IgY29udGFpbnMgYW55IGFzeW5jaHJvbm91cyBwbHVnaW5zXG4gICAqIGl0IHdpbGwgdGhyb3cgYW4gZXJyb3IuIFRoaXMgaXMgd2h5IHRoaXMgbWV0aG9kIGlzIG9ubHlcbiAgICogZm9yIGRlYnVnIHB1cnBvc2UsIHlvdSBzaG91bGQgYWx3YXlzIHVzZSB7QGxpbmsgTGF6eVJlc3VsdCN0aGVufS5cbiAgICpcbiAgICogQHR5cGUge1NvdXJjZU1hcEdlbmVyYXRvcn1cbiAgICogQHNlZSBSZXN1bHQjbWFwXG4gICAqL1xuICBnZXQgbWFwICgpIHtcbiAgICByZXR1cm4gdGhpcy5zdHJpbmdpZnkoKS5tYXBcbiAgfVxuXG4gIC8qKlxuICAgKiBQcm9jZXNzZXMgaW5wdXQgQ1NTIHRocm91Z2ggc3luY2hyb25vdXMgcGx1Z2luc1xuICAgKiBhbmQgcmV0dXJucyB7QGxpbmsgUmVzdWx0I3Jvb3R9LlxuICAgKlxuICAgKiBUaGlzIHByb3BlcnR5IHdpbGwgb25seSB3b3JrIHdpdGggc3luY2hyb25vdXMgcGx1Z2lucy4gSWYgdGhlIHByb2Nlc3NvclxuICAgKiBjb250YWlucyBhbnkgYXN5bmNocm9ub3VzIHBsdWdpbnMgaXQgd2lsbCB0aHJvdyBhbiBlcnJvci5cbiAgICpcbiAgICogVGhpcyBpcyB3aHkgdGhpcyBtZXRob2QgaXMgb25seSBmb3IgZGVidWcgcHVycG9zZSxcbiAgICogeW91IHNob3VsZCBhbHdheXMgdXNlIHtAbGluayBMYXp5UmVzdWx0I3RoZW59LlxuICAgKlxuICAgKiBAdHlwZSB7Um9vdH1cbiAgICogQHNlZSBSZXN1bHQjcm9vdFxuICAgKi9cbiAgZ2V0IHJvb3QgKCkge1xuICAgIHJldHVybiB0aGlzLnN5bmMoKS5yb290XG4gIH1cblxuICAvKipcbiAgICogUHJvY2Vzc2VzIGlucHV0IENTUyB0aHJvdWdoIHN5bmNocm9ub3VzIHBsdWdpbnNcbiAgICogYW5kIHJldHVybnMge0BsaW5rIFJlc3VsdCNtZXNzYWdlc30uXG4gICAqXG4gICAqIFRoaXMgcHJvcGVydHkgd2lsbCBvbmx5IHdvcmsgd2l0aCBzeW5jaHJvbm91cyBwbHVnaW5zLiBJZiB0aGUgcHJvY2Vzc29yXG4gICAqIGNvbnRhaW5zIGFueSBhc3luY2hyb25vdXMgcGx1Z2lucyBpdCB3aWxsIHRocm93IGFuIGVycm9yLlxuICAgKlxuICAgKiBUaGlzIGlzIHdoeSB0aGlzIG1ldGhvZCBpcyBvbmx5IGZvciBkZWJ1ZyBwdXJwb3NlLFxuICAgKiB5b3Ugc2hvdWxkIGFsd2F5cyB1c2Uge0BsaW5rIExhenlSZXN1bHQjdGhlbn0uXG4gICAqXG4gICAqIEB0eXBlIHtNZXNzYWdlW119XG4gICAqIEBzZWUgUmVzdWx0I21lc3NhZ2VzXG4gICAqL1xuICBnZXQgbWVzc2FnZXMgKCkge1xuICAgIHJldHVybiB0aGlzLnN5bmMoKS5tZXNzYWdlc1xuICB9XG5cbiAgLyoqXG4gICAqIFByb2Nlc3NlcyBpbnB1dCBDU1MgdGhyb3VnaCBzeW5jaHJvbm91cyBwbHVnaW5zXG4gICAqIGFuZCBjYWxscyB7QGxpbmsgUmVzdWx0I3dhcm5pbmdzKCl9LlxuICAgKlxuICAgKiBAcmV0dXJuIHtXYXJuaW5nW119IFdhcm5pbmdzIGZyb20gcGx1Z2lucy5cbiAgICovXG4gIHdhcm5pbmdzICgpIHtcbiAgICByZXR1cm4gdGhpcy5zeW5jKCkud2FybmluZ3MoKVxuICB9XG5cbiAgLyoqXG4gICAqIEFsaWFzIGZvciB0aGUge0BsaW5rIExhenlSZXN1bHQjY3NzfSBwcm9wZXJ0eS5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogbGF6eSArICcnID09PSBsYXp5LmNzc1xuICAgKlxuICAgKiBAcmV0dXJuIHtzdHJpbmd9IE91dHB1dCBDU1MuXG4gICAqL1xuICB0b1N0cmluZyAoKSB7XG4gICAgcmV0dXJuIHRoaXMuY3NzXG4gIH1cblxuICAvKipcbiAgICogUHJvY2Vzc2VzIGlucHV0IENTUyB0aHJvdWdoIHN5bmNocm9ub3VzIGFuZCBhc3luY2hyb25vdXMgcGx1Z2luc1xuICAgKiBhbmQgY2FsbHMgYG9uRnVsZmlsbGVkYCB3aXRoIGEgUmVzdWx0IGluc3RhbmNlLiBJZiBhIHBsdWdpbiB0aHJvd3NcbiAgICogYW4gZXJyb3IsIHRoZSBgb25SZWplY3RlZGAgY2FsbGJhY2sgd2lsbCBiZSBleGVjdXRlZC5cbiAgICpcbiAgICogSXQgaW1wbGVtZW50cyBzdGFuZGFyZCBQcm9taXNlIEFQSS5cbiAgICpcbiAgICogQHBhcmFtIHtvbkZ1bGZpbGxlZH0gb25GdWxmaWxsZWQgQ2FsbGJhY2sgd2lsbCBiZSBleGVjdXRlZFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aGVuIGFsbCBwbHVnaW5zIHdpbGwgZmluaXNoIHdvcmsuXG4gICAqIEBwYXJhbSB7b25SZWplY3RlZH0gIG9uUmVqZWN0ZWQgIENhbGxiYWNrIHdpbGwgYmUgZXhlY3V0ZWQgb24gYW55IGVycm9yLlxuICAgKlxuICAgKiBAcmV0dXJuIHtQcm9taXNlfSBQcm9taXNlIEFQSSB0byBtYWtlIHF1ZXVlLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBwb3N0Y3NzKFthdXRvcHJlZml4ZXJdKS5wcm9jZXNzKGNzcywgeyBmcm9tOiBjc3NQYXRoIH0pLnRoZW4ocmVzdWx0ID0+IHtcbiAgICogICBjb25zb2xlLmxvZyhyZXN1bHQuY3NzKVxuICAgKiB9KVxuICAgKi9cbiAgdGhlbiAob25GdWxmaWxsZWQsIG9uUmVqZWN0ZWQpIHtcbiAgICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJykge1xuICAgICAgaWYgKCEoJ2Zyb20nIGluIHRoaXMub3B0cykpIHtcbiAgICAgICAgd2Fybk9uY2UoXG4gICAgICAgICAgJ1dpdGhvdXQgYGZyb21gIG9wdGlvbiBQb3N0Q1NTIGNvdWxkIGdlbmVyYXRlIHdyb25nIHNvdXJjZSBtYXAgJyArXG4gICAgICAgICAgJ2FuZCB3aWxsIG5vdCBmaW5kIEJyb3dzZXJzbGlzdCBjb25maWcuIFNldCBpdCB0byBDU1MgZmlsZSBwYXRoICcgK1xuICAgICAgICAgICdvciB0byBgdW5kZWZpbmVkYCB0byBwcmV2ZW50IHRoaXMgd2FybmluZy4nXG4gICAgICAgIClcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuYXN5bmMoKS50aGVuKG9uRnVsZmlsbGVkLCBvblJlamVjdGVkKVxuICB9XG5cbiAgLyoqXG4gICAqIFByb2Nlc3NlcyBpbnB1dCBDU1MgdGhyb3VnaCBzeW5jaHJvbm91cyBhbmQgYXN5bmNocm9ub3VzIHBsdWdpbnNcbiAgICogYW5kIGNhbGxzIG9uUmVqZWN0ZWQgZm9yIGVhY2ggZXJyb3IgdGhyb3duIGluIGFueSBwbHVnaW4uXG4gICAqXG4gICAqIEl0IGltcGxlbWVudHMgc3RhbmRhcmQgUHJvbWlzZSBBUEkuXG4gICAqXG4gICAqIEBwYXJhbSB7b25SZWplY3RlZH0gb25SZWplY3RlZCBDYWxsYmFjayB3aWxsIGJlIGV4ZWN1dGVkIG9uIGFueSBlcnJvci5cbiAgICpcbiAgICogQHJldHVybiB7UHJvbWlzZX0gUHJvbWlzZSBBUEkgdG8gbWFrZSBxdWV1ZS5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcG9zdGNzcyhbYXV0b3ByZWZpeGVyXSkucHJvY2Vzcyhjc3MpLnRoZW4ocmVzdWx0ID0+IHtcbiAgICogICBjb25zb2xlLmxvZyhyZXN1bHQuY3NzKVxuICAgKiB9KS5jYXRjaChlcnJvciA9PiB7XG4gICAqICAgY29uc29sZS5lcnJvcihlcnJvcilcbiAgICogfSlcbiAgICovXG4gIGNhdGNoIChvblJlamVjdGVkKSB7XG4gICAgcmV0dXJuIHRoaXMuYXN5bmMoKS5jYXRjaChvblJlamVjdGVkKVxuICB9XG4gIC8qKlxuICAgKiBQcm9jZXNzZXMgaW5wdXQgQ1NTIHRocm91Z2ggc3luY2hyb25vdXMgYW5kIGFzeW5jaHJvbm91cyBwbHVnaW5zXG4gICAqIGFuZCBjYWxscyBvbkZpbmFsbHkgb24gYW55IGVycm9yIG9yIHdoZW4gYWxsIHBsdWdpbnMgd2lsbCBmaW5pc2ggd29yay5cbiAgICpcbiAgICogSXQgaW1wbGVtZW50cyBzdGFuZGFyZCBQcm9taXNlIEFQSS5cbiAgICpcbiAgICogQHBhcmFtIHtvbkZpbmFsbHl9IG9uRmluYWxseSBDYWxsYmFjayB3aWxsIGJlIGV4ZWN1dGVkIG9uIGFueSBlcnJvciBvclxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHdoZW4gYWxsIHBsdWdpbnMgd2lsbCBmaW5pc2ggd29yay5cbiAgICpcbiAgICogQHJldHVybiB7UHJvbWlzZX0gUHJvbWlzZSBBUEkgdG8gbWFrZSBxdWV1ZS5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcG9zdGNzcyhbYXV0b3ByZWZpeGVyXSkucHJvY2Vzcyhjc3MpLmZpbmFsbHkoKCkgPT4ge1xuICAgKiAgIGNvbnNvbGUubG9nKCdwcm9jZXNzaW5nIGVuZGVkJylcbiAgICogfSlcbiAgICovXG4gIGZpbmFsbHkgKG9uRmluYWxseSkge1xuICAgIHJldHVybiB0aGlzLmFzeW5jKCkudGhlbihvbkZpbmFsbHksIG9uRmluYWxseSlcbiAgfVxuXG4gIGhhbmRsZUVycm9yIChlcnJvciwgcGx1Z2luKSB7XG4gICAgdHJ5IHtcbiAgICAgIHRoaXMuZXJyb3IgPSBlcnJvclxuICAgICAgaWYgKGVycm9yLm5hbWUgPT09ICdDc3NTeW50YXhFcnJvcicgJiYgIWVycm9yLnBsdWdpbikge1xuICAgICAgICBlcnJvci5wbHVnaW4gPSBwbHVnaW4ucG9zdGNzc1BsdWdpblxuICAgICAgICBlcnJvci5zZXRNZXNzYWdlKClcbiAgICAgIH0gZWxzZSBpZiAocGx1Z2luLnBvc3Rjc3NWZXJzaW9uKSB7XG4gICAgICAgIGlmIChwcm9jZXNzLmVudi5OT0RFX0VOViAhPT0gJ3Byb2R1Y3Rpb24nKSB7XG4gICAgICAgICAgbGV0IHBsdWdpbk5hbWUgPSBwbHVnaW4ucG9zdGNzc1BsdWdpblxuICAgICAgICAgIGxldCBwbHVnaW5WZXIgPSBwbHVnaW4ucG9zdGNzc1ZlcnNpb25cbiAgICAgICAgICBsZXQgcnVudGltZVZlciA9IHRoaXMucmVzdWx0LnByb2Nlc3Nvci52ZXJzaW9uXG4gICAgICAgICAgbGV0IGEgPSBwbHVnaW5WZXIuc3BsaXQoJy4nKVxuICAgICAgICAgIGxldCBiID0gcnVudGltZVZlci5zcGxpdCgnLicpXG5cbiAgICAgICAgICBpZiAoYVswXSAhPT0gYlswXSB8fCBwYXJzZUludChhWzFdKSA+IHBhcnNlSW50KGJbMV0pKSB7XG4gICAgICAgICAgICBjb25zb2xlLmVycm9yKFxuICAgICAgICAgICAgICAnVW5rbm93biBlcnJvciBmcm9tIFBvc3RDU1MgcGx1Z2luLiBZb3VyIGN1cnJlbnQgUG9zdENTUyAnICtcbiAgICAgICAgICAgICAgJ3ZlcnNpb24gaXMgJyArIHJ1bnRpbWVWZXIgKyAnLCBidXQgJyArIHBsdWdpbk5hbWUgKyAnIHVzZXMgJyArXG4gICAgICAgICAgICAgIHBsdWdpblZlciArICcuIFBlcmhhcHMgdGhpcyBpcyB0aGUgc291cmNlIG9mIHRoZSBlcnJvciBiZWxvdy4nXG4gICAgICAgICAgICApXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICBpZiAoY29uc29sZSAmJiBjb25zb2xlLmVycm9yKSBjb25zb2xlLmVycm9yKGVycilcbiAgICB9XG4gIH1cblxuICBhc3luY1RpY2sgKHJlc29sdmUsIHJlamVjdCkge1xuICAgIGlmICh0aGlzLnBsdWdpbiA+PSB0aGlzLnByb2Nlc3Nvci5wbHVnaW5zLmxlbmd0aCkge1xuICAgICAgdGhpcy5wcm9jZXNzZWQgPSB0cnVlXG4gICAgICByZXR1cm4gcmVzb2x2ZSgpXG4gICAgfVxuXG4gICAgdHJ5IHtcbiAgICAgIGxldCBwbHVnaW4gPSB0aGlzLnByb2Nlc3Nvci5wbHVnaW5zW3RoaXMucGx1Z2luXVxuICAgICAgbGV0IHByb21pc2UgPSB0aGlzLnJ1bihwbHVnaW4pXG4gICAgICB0aGlzLnBsdWdpbiArPSAxXG5cbiAgICAgIGlmIChpc1Byb21pc2UocHJvbWlzZSkpIHtcbiAgICAgICAgcHJvbWlzZS50aGVuKCgpID0+IHtcbiAgICAgICAgICB0aGlzLmFzeW5jVGljayhyZXNvbHZlLCByZWplY3QpXG4gICAgICAgIH0pLmNhdGNoKGVycm9yID0+IHtcbiAgICAgICAgICB0aGlzLmhhbmRsZUVycm9yKGVycm9yLCBwbHVnaW4pXG4gICAgICAgICAgdGhpcy5wcm9jZXNzZWQgPSB0cnVlXG4gICAgICAgICAgcmVqZWN0KGVycm9yKVxuICAgICAgICB9KVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhpcy5hc3luY1RpY2socmVzb2x2ZSwgcmVqZWN0KVxuICAgICAgfVxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICB0aGlzLnByb2Nlc3NlZCA9IHRydWVcbiAgICAgIHJlamVjdChlcnJvcilcbiAgICB9XG4gIH1cblxuICBhc3luYyAoKSB7XG4gICAgaWYgKHRoaXMucHJvY2Vzc2VkKSB7XG4gICAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgICBpZiAodGhpcy5lcnJvcikge1xuICAgICAgICAgIHJlamVjdCh0aGlzLmVycm9yKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHJlc29sdmUodGhpcy5zdHJpbmdpZnkoKSlcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICB9XG4gICAgaWYgKHRoaXMucHJvY2Vzc2luZykge1xuICAgICAgcmV0dXJuIHRoaXMucHJvY2Vzc2luZ1xuICAgIH1cblxuICAgIHRoaXMucHJvY2Vzc2luZyA9IG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIGlmICh0aGlzLmVycm9yKSByZXR1cm4gcmVqZWN0KHRoaXMuZXJyb3IpXG4gICAgICB0aGlzLnBsdWdpbiA9IDBcbiAgICAgIHRoaXMuYXN5bmNUaWNrKHJlc29sdmUsIHJlamVjdClcbiAgICB9KS50aGVuKCgpID0+IHtcbiAgICAgIHRoaXMucHJvY2Vzc2VkID0gdHJ1ZVxuICAgICAgcmV0dXJuIHRoaXMuc3RyaW5naWZ5KClcbiAgICB9KVxuXG4gICAgcmV0dXJuIHRoaXMucHJvY2Vzc2luZ1xuICB9XG5cbiAgc3luYyAoKSB7XG4gICAgaWYgKHRoaXMucHJvY2Vzc2VkKSByZXR1cm4gdGhpcy5yZXN1bHRcbiAgICB0aGlzLnByb2Nlc3NlZCA9IHRydWVcblxuICAgIGlmICh0aGlzLnByb2Nlc3NpbmcpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgJ1VzZSBwcm9jZXNzKGNzcykudGhlbihjYikgdG8gd29yayB3aXRoIGFzeW5jIHBsdWdpbnMnKVxuICAgIH1cblxuICAgIGlmICh0aGlzLmVycm9yKSB0aHJvdyB0aGlzLmVycm9yXG5cbiAgICBmb3IgKGxldCBwbHVnaW4gb2YgdGhpcy5yZXN1bHQucHJvY2Vzc29yLnBsdWdpbnMpIHtcbiAgICAgIGxldCBwcm9taXNlID0gdGhpcy5ydW4ocGx1Z2luKVxuICAgICAgaWYgKGlzUHJvbWlzZShwcm9taXNlKSkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICAgJ1VzZSBwcm9jZXNzKGNzcykudGhlbihjYikgdG8gd29yayB3aXRoIGFzeW5jIHBsdWdpbnMnKVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiB0aGlzLnJlc3VsdFxuICB9XG5cbiAgcnVuIChwbHVnaW4pIHtcbiAgICB0aGlzLnJlc3VsdC5sYXN0UGx1Z2luID0gcGx1Z2luXG5cbiAgICB0cnkge1xuICAgICAgcmV0dXJuIHBsdWdpbih0aGlzLnJlc3VsdC5yb290LCB0aGlzLnJlc3VsdClcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgdGhpcy5oYW5kbGVFcnJvcihlcnJvciwgcGx1Z2luKVxuICAgICAgdGhyb3cgZXJyb3JcbiAgICB9XG4gIH1cblxuICBzdHJpbmdpZnkgKCkge1xuICAgIGlmICh0aGlzLnN0cmluZ2lmaWVkKSByZXR1cm4gdGhpcy5yZXN1bHRcbiAgICB0aGlzLnN0cmluZ2lmaWVkID0gdHJ1ZVxuXG4gICAgdGhpcy5zeW5jKClcblxuICAgIGxldCBvcHRzID0gdGhpcy5yZXN1bHQub3B0c1xuICAgIGxldCBzdHIgPSBzdHJpbmdpZnlcbiAgICBpZiAob3B0cy5zeW50YXgpIHN0ciA9IG9wdHMuc3ludGF4LnN0cmluZ2lmeVxuICAgIGlmIChvcHRzLnN0cmluZ2lmaWVyKSBzdHIgPSBvcHRzLnN0cmluZ2lmaWVyXG4gICAgaWYgKHN0ci5zdHJpbmdpZnkpIHN0ciA9IHN0ci5zdHJpbmdpZnlcblxuICAgIGxldCBtYXAgPSBuZXcgTWFwR2VuZXJhdG9yKHN0ciwgdGhpcy5yZXN1bHQucm9vdCwgdGhpcy5yZXN1bHQub3B0cylcbiAgICBsZXQgZGF0YSA9IG1hcC5nZW5lcmF0ZSgpXG4gICAgdGhpcy5yZXN1bHQuY3NzID0gZGF0YVswXVxuICAgIHRoaXMucmVzdWx0Lm1hcCA9IGRhdGFbMV1cblxuICAgIHJldHVybiB0aGlzLnJlc3VsdFxuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IExhenlSZXN1bHRcblxuLyoqXG4gKiBAY2FsbGJhY2sgb25GdWxmaWxsZWRcbiAqIEBwYXJhbSB7UmVzdWx0fSByZXN1bHRcbiAqL1xuXG4vKipcbiAqIEBjYWxsYmFjayBvblJlamVjdGVkXG4gKiBAcGFyYW0ge0Vycm9yfSBlcnJvclxuICovXG4iXSwiZmlsZSI6ImxhenktcmVzdWx0LmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/list.js b/node_modules/autoprefixer/node_modules/postcss/lib/list.js
new file mode 100644
index 0000000..d2feb76
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/list.js
@@ -0,0 +1,93 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+/**
+ * Contains helpers for safely splitting lists of CSS values,
+ * preserving parentheses and quotes.
+ *
+ * @example
+ * const list = postcss.list
+ *
+ * @namespace list
+ */
+var list = {
+ split: function split(string, separators, last) {
+ var array = [];
+ var current = '';
+ var split = false;
+ var func = 0;
+ var quote = false;
+ var escape = false;
+
+ for (var i = 0; i < string.length; i++) {
+ var letter = string[i];
+
+ if (quote) {
+ if (escape) {
+ escape = false;
+ } else if (letter === '\\') {
+ escape = true;
+ } else if (letter === quote) {
+ quote = false;
+ }
+ } else if (letter === '"' || letter === '\'') {
+ quote = letter;
+ } else if (letter === '(') {
+ func += 1;
+ } else if (letter === ')') {
+ if (func > 0) func -= 1;
+ } else if (func === 0) {
+ if (separators.indexOf(letter) !== -1) split = true;
+ }
+
+ if (split) {
+ if (current !== '') array.push(current.trim());
+ current = '';
+ split = false;
+ } else {
+ current += letter;
+ }
+ }
+
+ if (last || current !== '') array.push(current.trim());
+ return array;
+ },
+
+ /**
+ * Safely splits space-separated values (such as those for `background`,
+ * `border-radius`, and other shorthand properties).
+ *
+ * @param {string} string Space-separated values.
+ *
+ * @return {string[]} Split values.
+ *
+ * @example
+ * postcss.list.space('1px calc(10% + 1px)') //=> ['1px', 'calc(10% + 1px)']
+ */
+ space: function space(string) {
+ var spaces = [' ', '\n', '\t'];
+ return list.split(string, spaces);
+ },
+
+ /**
+ * Safely splits comma-separated values (such as those for `transition-*`
+ * and `background` properties).
+ *
+ * @param {string} string Comma-separated values.
+ *
+ * @return {string[]} Split values.
+ *
+ * @example
+ * postcss.list.comma('black, linear-gradient(white, black)')
+ * //=> ['black', 'linear-gradient(white, black)']
+ */
+ comma: function comma(string) {
+ return list.split(string, [','], true);
+ }
+};
+var _default = list;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpc3QuZXM2Il0sIm5hbWVzIjpbImxpc3QiLCJzcGxpdCIsInN0cmluZyIsInNlcGFyYXRvcnMiLCJsYXN0IiwiYXJyYXkiLCJjdXJyZW50IiwiZnVuYyIsInF1b3RlIiwiZXNjYXBlIiwiaSIsImxlbmd0aCIsImxldHRlciIsImluZGV4T2YiLCJwdXNoIiwidHJpbSIsInNwYWNlIiwic3BhY2VzIiwiY29tbWEiXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7Ozs7Ozs7OztBQVNBLElBQUlBLElBQUksR0FBRztBQUVUQyxFQUFBQSxLQUZTLGlCQUVGQyxNQUZFLEVBRU1DLFVBRk4sRUFFa0JDLElBRmxCLEVBRXdCO0FBQy9CLFFBQUlDLEtBQUssR0FBRyxFQUFaO0FBQ0EsUUFBSUMsT0FBTyxHQUFHLEVBQWQ7QUFDQSxRQUFJTCxLQUFLLEdBQUcsS0FBWjtBQUVBLFFBQUlNLElBQUksR0FBRyxDQUFYO0FBQ0EsUUFBSUMsS0FBSyxHQUFHLEtBQVo7QUFDQSxRQUFJQyxNQUFNLEdBQUcsS0FBYjs7QUFFQSxTQUFLLElBQUlDLENBQUMsR0FBRyxDQUFiLEVBQWdCQSxDQUFDLEdBQUdSLE1BQU0sQ0FBQ1MsTUFBM0IsRUFBbUNELENBQUMsRUFBcEMsRUFBd0M7QUFDdEMsVUFBSUUsTUFBTSxHQUFHVixNQUFNLENBQUNRLENBQUQsQ0FBbkI7O0FBRUEsVUFBSUYsS0FBSixFQUFXO0FBQ1QsWUFBSUMsTUFBSixFQUFZO0FBQ1ZBLFVBQUFBLE1BQU0sR0FBRyxLQUFUO0FBQ0QsU0FGRCxNQUVPLElBQUlHLE1BQU0sS0FBSyxJQUFmLEVBQXFCO0FBQzFCSCxVQUFBQSxNQUFNLEdBQUcsSUFBVDtBQUNELFNBRk0sTUFFQSxJQUFJRyxNQUFNLEtBQUtKLEtBQWYsRUFBc0I7QUFDM0JBLFVBQUFBLEtBQUssR0FBRyxLQUFSO0FBQ0Q7QUFDRixPQVJELE1BUU8sSUFBSUksTUFBTSxLQUFLLEdBQVgsSUFBa0JBLE1BQU0sS0FBSyxJQUFqQyxFQUF1QztBQUM1Q0osUUFBQUEsS0FBSyxHQUFHSSxNQUFSO0FBQ0QsT0FGTSxNQUVBLElBQUlBLE1BQU0sS0FBSyxHQUFmLEVBQW9CO0FBQ3pCTCxRQUFBQSxJQUFJLElBQUksQ0FBUjtBQUNELE9BRk0sTUFFQSxJQUFJSyxNQUFNLEtBQUssR0FBZixFQUFvQjtBQUN6QixZQUFJTCxJQUFJLEdBQUcsQ0FBWCxFQUFjQSxJQUFJLElBQUksQ0FBUjtBQUNmLE9BRk0sTUFFQSxJQUFJQSxJQUFJLEtBQUssQ0FBYixFQUFnQjtBQUNyQixZQUFJSixVQUFVLENBQUNVLE9BQVgsQ0FBbUJELE1BQW5CLE1BQStCLENBQUMsQ0FBcEMsRUFBdUNYLEtBQUssR0FBRyxJQUFSO0FBQ3hDOztBQUVELFVBQUlBLEtBQUosRUFBVztBQUNULFlBQUlLLE9BQU8sS0FBSyxFQUFoQixFQUFvQkQsS0FBSyxDQUFDUyxJQUFOLENBQVdSLE9BQU8sQ0FBQ1MsSUFBUixFQUFYO0FBQ3BCVCxRQUFBQSxPQUFPLEdBQUcsRUFBVjtBQUNBTCxRQUFBQSxLQUFLLEdBQUcsS0FBUjtBQUNELE9BSkQsTUFJTztBQUNMSyxRQUFBQSxPQUFPLElBQUlNLE1BQVg7QUFDRDtBQUNGOztBQUVELFFBQUlSLElBQUksSUFBSUUsT0FBTyxLQUFLLEVBQXhCLEVBQTRCRCxLQUFLLENBQUNTLElBQU4sQ0FBV1IsT0FBTyxDQUFDUyxJQUFSLEVBQVg7QUFDNUIsV0FBT1YsS0FBUDtBQUNELEdBM0NROztBQTZDVDs7Ozs7Ozs7Ozs7QUFXQVcsRUFBQUEsS0F4RFMsaUJBd0RGZCxNQXhERSxFQXdETTtBQUNiLFFBQUllLE1BQU0sR0FBRyxDQUFDLEdBQUQsRUFBTSxJQUFOLEVBQVksSUFBWixDQUFiO0FBQ0EsV0FBT2pCLElBQUksQ0FBQ0MsS0FBTCxDQUFXQyxNQUFYLEVBQW1CZSxNQUFuQixDQUFQO0FBQ0QsR0EzRFE7O0FBNkRUOzs7Ozs7Ozs7Ozs7QUFZQUMsRUFBQUEsS0F6RVMsaUJBeUVGaEIsTUF6RUUsRUF5RU07QUFDYixXQUFPRixJQUFJLENBQUNDLEtBQUwsQ0FBV0MsTUFBWCxFQUFtQixDQUFDLEdBQUQsQ0FBbkIsRUFBMEIsSUFBMUIsQ0FBUDtBQUNEO0FBM0VRLENBQVg7ZUErRWVGLEkiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvbnRhaW5zIGhlbHBlcnMgZm9yIHNhZmVseSBzcGxpdHRpbmcgbGlzdHMgb2YgQ1NTIHZhbHVlcyxcbiAqIHByZXNlcnZpbmcgcGFyZW50aGVzZXMgYW5kIHF1b3Rlcy5cbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3QgbGlzdCA9IHBvc3Rjc3MubGlzdFxuICpcbiAqIEBuYW1lc3BhY2UgbGlzdFxuICovXG5sZXQgbGlzdCA9IHtcblxuICBzcGxpdCAoc3RyaW5nLCBzZXBhcmF0b3JzLCBsYXN0KSB7XG4gICAgbGV0IGFycmF5ID0gW11cbiAgICBsZXQgY3VycmVudCA9ICcnXG4gICAgbGV0IHNwbGl0ID0gZmFsc2VcblxuICAgIGxldCBmdW5jID0gMFxuICAgIGxldCBxdW90ZSA9IGZhbHNlXG4gICAgbGV0IGVzY2FwZSA9IGZhbHNlXG5cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHN0cmluZy5sZW5ndGg7IGkrKykge1xuICAgICAgbGV0IGxldHRlciA9IHN0cmluZ1tpXVxuXG4gICAgICBpZiAocXVvdGUpIHtcbiAgICAgICAgaWYgKGVzY2FwZSkge1xuICAgICAgICAgIGVzY2FwZSA9IGZhbHNlXG4gICAgICAgIH0gZWxzZSBpZiAobGV0dGVyID09PSAnXFxcXCcpIHtcbiAgICAgICAgICBlc2NhcGUgPSB0cnVlXG4gICAgICAgIH0gZWxzZSBpZiAobGV0dGVyID09PSBxdW90ZSkge1xuICAgICAgICAgIHF1b3RlID0gZmFsc2VcbiAgICAgICAgfVxuICAgICAgfSBlbHNlIGlmIChsZXR0ZXIgPT09ICdcIicgfHwgbGV0dGVyID09PSAnXFwnJykge1xuICAgICAgICBxdW90ZSA9IGxldHRlclxuICAgICAgfSBlbHNlIGlmIChsZXR0ZXIgPT09ICcoJykge1xuICAgICAgICBmdW5jICs9IDFcbiAgICAgIH0gZWxzZSBpZiAobGV0dGVyID09PSAnKScpIHtcbiAgICAgICAgaWYgKGZ1bmMgPiAwKSBmdW5jIC09IDFcbiAgICAgIH0gZWxzZSBpZiAoZnVuYyA9PT0gMCkge1xuICAgICAgICBpZiAoc2VwYXJhdG9ycy5pbmRleE9mKGxldHRlcikgIT09IC0xKSBzcGxpdCA9IHRydWVcbiAgICAgIH1cblxuICAgICAgaWYgKHNwbGl0KSB7XG4gICAgICAgIGlmIChjdXJyZW50ICE9PSAnJykgYXJyYXkucHVzaChjdXJyZW50LnRyaW0oKSlcbiAgICAgICAgY3VycmVudCA9ICcnXG4gICAgICAgIHNwbGl0ID0gZmFsc2VcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGN1cnJlbnQgKz0gbGV0dGVyXG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKGxhc3QgfHwgY3VycmVudCAhPT0gJycpIGFycmF5LnB1c2goY3VycmVudC50cmltKCkpXG4gICAgcmV0dXJuIGFycmF5XG4gIH0sXG5cbiAgLyoqXG4gICAqIFNhZmVseSBzcGxpdHMgc3BhY2Utc2VwYXJhdGVkIHZhbHVlcyAoc3VjaCBhcyB0aG9zZSBmb3IgYGJhY2tncm91bmRgLFxuICAgKiBgYm9yZGVyLXJhZGl1c2AsIGFuZCBvdGhlciBzaG9ydGhhbmQgcHJvcGVydGllcykuXG4gICAqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBzdHJpbmcgU3BhY2Utc2VwYXJhdGVkIHZhbHVlcy5cbiAgICpcbiAgICogQHJldHVybiB7c3RyaW5nW119IFNwbGl0IHZhbHVlcy5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcG9zdGNzcy5saXN0LnNwYWNlKCcxcHggY2FsYygxMCUgKyAxcHgpJykgLy89PiBbJzFweCcsICdjYWxjKDEwJSArIDFweCknXVxuICAgKi9cbiAgc3BhY2UgKHN0cmluZykge1xuICAgIGxldCBzcGFjZXMgPSBbJyAnLCAnXFxuJywgJ1xcdCddXG4gICAgcmV0dXJuIGxpc3Quc3BsaXQoc3RyaW5nLCBzcGFjZXMpXG4gIH0sXG5cbiAgLyoqXG4gICAqIFNhZmVseSBzcGxpdHMgY29tbWEtc2VwYXJhdGVkIHZhbHVlcyAoc3VjaCBhcyB0aG9zZSBmb3IgYHRyYW5zaXRpb24tKmBcbiAgICogYW5kIGBiYWNrZ3JvdW5kYCBwcm9wZXJ0aWVzKS5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IHN0cmluZyBDb21tYS1zZXBhcmF0ZWQgdmFsdWVzLlxuICAgKlxuICAgKiBAcmV0dXJuIHtzdHJpbmdbXX0gU3BsaXQgdmFsdWVzLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBwb3N0Y3NzLmxpc3QuY29tbWEoJ2JsYWNrLCBsaW5lYXItZ3JhZGllbnQod2hpdGUsIGJsYWNrKScpXG4gICAqIC8vPT4gWydibGFjaycsICdsaW5lYXItZ3JhZGllbnQod2hpdGUsIGJsYWNrKSddXG4gICAqL1xuICBjb21tYSAoc3RyaW5nKSB7XG4gICAgcmV0dXJuIGxpc3Quc3BsaXQoc3RyaW5nLCBbJywnXSwgdHJ1ZSlcbiAgfVxuXG59XG5cbmV4cG9ydCBkZWZhdWx0IGxpc3RcbiJdLCJmaWxlIjoibGlzdC5qcyJ9
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/map-generator.js b/node_modules/autoprefixer/node_modules/postcss/lib/map-generator.js
new file mode 100644
index 0000000..22dc1d9
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/map-generator.js
@@ -0,0 +1,354 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _sourceMap = _interopRequireDefault(require("source-map"));
+
+var _path = _interopRequireDefault(require("path"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var MapGenerator =
+/*#__PURE__*/
+function () {
+ function MapGenerator(stringify, root, opts) {
+ this.stringify = stringify;
+ this.mapOpts = opts.map || {};
+ this.root = root;
+ this.opts = opts;
+ }
+
+ var _proto = MapGenerator.prototype;
+
+ _proto.isMap = function isMap() {
+ if (typeof this.opts.map !== 'undefined') {
+ return !!this.opts.map;
+ }
+
+ return this.previous().length > 0;
+ };
+
+ _proto.previous = function previous() {
+ var _this = this;
+
+ if (!this.previousMaps) {
+ this.previousMaps = [];
+ this.root.walk(function (node) {
+ if (node.source && node.source.input.map) {
+ var map = node.source.input.map;
+
+ if (_this.previousMaps.indexOf(map) === -1) {
+ _this.previousMaps.push(map);
+ }
+ }
+ });
+ }
+
+ return this.previousMaps;
+ };
+
+ _proto.isInline = function isInline() {
+ if (typeof this.mapOpts.inline !== 'undefined') {
+ return this.mapOpts.inline;
+ }
+
+ var annotation = this.mapOpts.annotation;
+
+ if (typeof annotation !== 'undefined' && annotation !== true) {
+ return false;
+ }
+
+ if (this.previous().length) {
+ return this.previous().some(function (i) {
+ return i.inline;
+ });
+ }
+
+ return true;
+ };
+
+ _proto.isSourcesContent = function isSourcesContent() {
+ if (typeof this.mapOpts.sourcesContent !== 'undefined') {
+ return this.mapOpts.sourcesContent;
+ }
+
+ if (this.previous().length) {
+ return this.previous().some(function (i) {
+ return i.withContent();
+ });
+ }
+
+ return true;
+ };
+
+ _proto.clearAnnotation = function clearAnnotation() {
+ if (this.mapOpts.annotation === false) return;
+ var node;
+
+ for (var i = this.root.nodes.length - 1; i >= 0; i--) {
+ node = this.root.nodes[i];
+ if (node.type !== 'comment') continue;
+
+ if (node.text.indexOf('# sourceMappingURL=') === 0) {
+ this.root.removeChild(i);
+ }
+ }
+ };
+
+ _proto.setSourcesContent = function setSourcesContent() {
+ var _this2 = this;
+
+ var already = {};
+ this.root.walk(function (node) {
+ if (node.source) {
+ var from = node.source.input.from;
+
+ if (from && !already[from]) {
+ already[from] = true;
+
+ var relative = _this2.relative(from);
+
+ _this2.map.setSourceContent(relative, node.source.input.css);
+ }
+ }
+ });
+ };
+
+ _proto.applyPrevMaps = function applyPrevMaps() {
+ for (var _iterator = this.previous(), _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
+ var _ref;
+
+ if (_isArray) {
+ if (_i >= _iterator.length) break;
+ _ref = _iterator[_i++];
+ } else {
+ _i = _iterator.next();
+ if (_i.done) break;
+ _ref = _i.value;
+ }
+
+ var prev = _ref;
+ var from = this.relative(prev.file);
+
+ var root = prev.root || _path.default.dirname(prev.file);
+
+ var map = void 0;
+
+ if (this.mapOpts.sourcesContent === false) {
+ map = new _sourceMap.default.SourceMapConsumer(prev.text);
+
+ if (map.sourcesContent) {
+ map.sourcesContent = map.sourcesContent.map(function () {
+ return null;
+ });
+ }
+ } else {
+ map = prev.consumer();
+ }
+
+ this.map.applySourceMap(map, from, this.relative(root));
+ }
+ };
+
+ _proto.isAnnotation = function isAnnotation() {
+ if (this.isInline()) {
+ return true;
+ }
+
+ if (typeof this.mapOpts.annotation !== 'undefined') {
+ return this.mapOpts.annotation;
+ }
+
+ if (this.previous().length) {
+ return this.previous().some(function (i) {
+ return i.annotation;
+ });
+ }
+
+ return true;
+ };
+
+ _proto.toBase64 = function toBase64(str) {
+ if (Buffer) {
+ return Buffer.from(str).toString('base64');
+ }
+
+ return window.btoa(unescape(encodeURIComponent(str)));
+ };
+
+ _proto.addAnnotation = function addAnnotation() {
+ var content;
+
+ if (this.isInline()) {
+ content = 'data:application/json;base64,' + this.toBase64(this.map.toString());
+ } else if (typeof this.mapOpts.annotation === 'string') {
+ content = this.mapOpts.annotation;
+ } else {
+ content = this.outputFile() + '.map';
+ }
+
+ var eol = '\n';
+ if (this.css.indexOf('\r\n') !== -1) eol = '\r\n';
+ this.css += eol + '/*# sourceMappingURL=' + content + ' */';
+ };
+
+ _proto.outputFile = function outputFile() {
+ if (this.opts.to) {
+ return this.relative(this.opts.to);
+ }
+
+ if (this.opts.from) {
+ return this.relative(this.opts.from);
+ }
+
+ return 'to.css';
+ };
+
+ _proto.generateMap = function generateMap() {
+ this.generateString();
+ if (this.isSourcesContent()) this.setSourcesContent();
+ if (this.previous().length > 0) this.applyPrevMaps();
+ if (this.isAnnotation()) this.addAnnotation();
+
+ if (this.isInline()) {
+ return [this.css];
+ }
+
+ return [this.css, this.map];
+ };
+
+ _proto.relative = function relative(file) {
+ if (file.indexOf('<') === 0) return file;
+ if (/^\w+:\/\//.test(file)) return file;
+ var from = this.opts.to ? _path.default.dirname(this.opts.to) : '.';
+
+ if (typeof this.mapOpts.annotation === 'string') {
+ from = _path.default.dirname(_path.default.resolve(from, this.mapOpts.annotation));
+ }
+
+ file = _path.default.relative(from, file);
+
+ if (_path.default.sep === '\\') {
+ return file.replace(/\\/g, '/');
+ }
+
+ return file;
+ };
+
+ _proto.sourcePath = function sourcePath(node) {
+ if (this.mapOpts.from) {
+ return this.mapOpts.from;
+ }
+
+ return this.relative(node.source.input.from);
+ };
+
+ _proto.generateString = function generateString() {
+ var _this3 = this;
+
+ this.css = '';
+ this.map = new _sourceMap.default.SourceMapGenerator({
+ file: this.outputFile()
+ });
+ var line = 1;
+ var column = 1;
+ var lines, last;
+ this.stringify(this.root, function (str, node, type) {
+ _this3.css += str;
+
+ if (node && type !== 'end') {
+ if (node.source && node.source.start) {
+ _this3.map.addMapping({
+ source: _this3.sourcePath(node),
+ generated: {
+ line: line,
+ column: column - 1
+ },
+ original: {
+ line: node.source.start.line,
+ column: node.source.start.column - 1
+ }
+ });
+ } else {
+ _this3.map.addMapping({
+ source: '<no source>',
+ original: {
+ line: 1,
+ column: 0
+ },
+ generated: {
+ line: line,
+ column: column - 1
+ }
+ });
+ }
+ }
+
+ lines = str.match(/\n/g);
+
+ if (lines) {
+ line += lines.length;
+ last = str.lastIndexOf('\n');
+ column = str.length - last;
+ } else {
+ column += str.length;
+ }
+
+ if (node && type !== 'start') {
+ var p = node.parent || {
+ raws: {}
+ };
+
+ if (node.type !== 'decl' || node !== p.last || p.raws.semicolon) {
+ if (node.source && node.source.end) {
+ _this3.map.addMapping({
+ source: _this3.sourcePath(node),
+ generated: {
+ line: line,
+ column: column - 2
+ },
+ original: {
+ line: node.source.end.line,
+ column: node.source.end.column - 1
+ }
+ });
+ } else {
+ _this3.map.addMapping({
+ source: '<no source>',
+ original: {
+ line: 1,
+ column: 0
+ },
+ generated: {
+ line: line,
+ column: column - 1
+ }
+ });
+ }
+ }
+ }
+ });
+ };
+
+ _proto.generate = function generate() {
+ this.clearAnnotation();
+
+ if (this.isMap()) {
+ return this.generateMap();
+ }
+
+ var result = '';
+ this.stringify(this.root, function (i) {
+ result += i;
+ });
+ return [result];
+ };
+
+ return MapGenerator;
+}();
+
+var _default = MapGenerator;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm1hcC1nZW5lcmF0b3IuZXM2Il0sIm5hbWVzIjpbIk1hcEdlbmVyYXRvciIsInN0cmluZ2lmeSIsInJvb3QiLCJvcHRzIiwibWFwT3B0cyIsIm1hcCIsImlzTWFwIiwicHJldmlvdXMiLCJsZW5ndGgiLCJwcmV2aW91c01hcHMiLCJ3YWxrIiwibm9kZSIsInNvdXJjZSIsImlucHV0IiwiaW5kZXhPZiIsInB1c2giLCJpc0lubGluZSIsImlubGluZSIsImFubm90YXRpb24iLCJzb21lIiwiaSIsImlzU291cmNlc0NvbnRlbnQiLCJzb3VyY2VzQ29udGVudCIsIndpdGhDb250ZW50IiwiY2xlYXJBbm5vdGF0aW9uIiwibm9kZXMiLCJ0eXBlIiwidGV4dCIsInJlbW92ZUNoaWxkIiwic2V0U291cmNlc0NvbnRlbnQiLCJhbHJlYWR5IiwiZnJvbSIsInJlbGF0aXZlIiwic2V0U291cmNlQ29udGVudCIsImNzcyIsImFwcGx5UHJldk1hcHMiLCJwcmV2IiwiZmlsZSIsInBhdGgiLCJkaXJuYW1lIiwibW96aWxsYSIsIlNvdXJjZU1hcENvbnN1bWVyIiwiY29uc3VtZXIiLCJhcHBseVNvdXJjZU1hcCIsImlzQW5ub3RhdGlvbiIsInRvQmFzZTY0Iiwic3RyIiwiQnVmZmVyIiwidG9TdHJpbmciLCJ3aW5kb3ciLCJidG9hIiwidW5lc2NhcGUiLCJlbmNvZGVVUklDb21wb25lbnQiLCJhZGRBbm5vdGF0aW9uIiwiY29udGVudCIsIm91dHB1dEZpbGUiLCJlb2wiLCJ0byIsImdlbmVyYXRlTWFwIiwiZ2VuZXJhdGVTdHJpbmciLCJ0ZXN0IiwicmVzb2x2ZSIsInNlcCIsInJlcGxhY2UiLCJzb3VyY2VQYXRoIiwiU291cmNlTWFwR2VuZXJhdG9yIiwibGluZSIsImNvbHVtbiIsImxpbmVzIiwibGFzdCIsInN0YXJ0IiwiYWRkTWFwcGluZyIsImdlbmVyYXRlZCIsIm9yaWdpbmFsIiwibWF0Y2giLCJsYXN0SW5kZXhPZiIsInAiLCJwYXJlbnQiLCJyYXdzIiwic2VtaWNv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QVFDLGdCQUFBQSxNQUFNLEVBQUVBLE1BQU0sR0FBRztBQUF6QjtBQUhPLGFBQXBCO0FBS0Q7QUFDRjtBQUNGO0FBQ0YsS0FwREQ7QUFxREQsRzs7U0FFRGMsUSxHQUFBLG9CQUFZO0FBQ1YsU0FBS3pELGVBQUw7O0FBRUEsUUFBSSxLQUFLbEIsS0FBTCxFQUFKLEVBQWtCO0FBQ2hCLGFBQU8sS0FBS29ELFdBQUwsRUFBUDtBQUNEOztBQUVELFFBQUl3QixNQUFNLEdBQUcsRUFBYjtBQUNBLFNBQUtqRixTQUFMLENBQWUsS0FBS0MsSUFBcEIsRUFBMEIsVUFBQWtCLENBQUMsRUFBSTtBQUM3QjhELE1BQUFBLE1BQU0sSUFBSTlELENBQVY7QUFDRCxLQUZEO0FBR0EsV0FBTyxDQUFDOEQsTUFBRCxDQUFQO0FBQ0QsRzs7Ozs7ZUFHWWxGLFkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbW96aWxsYSBmcm9tICdzb3VyY2UtbWFwJ1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCdcblxuY2xhc3MgTWFwR2VuZXJhdG9yIHtcbiAgY29uc3RydWN0b3IgKHN0cmluZ2lmeSwgcm9vdCwgb3B0cykge1xuICAgIHRoaXMuc3RyaW5naWZ5ID0gc3RyaW5naWZ5XG4gICAgdGhpcy5tYXBPcHRzID0gb3B0cy5tYXAgfHwgeyB9XG4gICAgdGhpcy5yb290ID0gcm9vdFxuICAgIHRoaXMub3B0cyA9IG9wdHNcbiAgfVxuXG4gIGlzTWFwICgpIHtcbiAgICBpZiAodHlwZW9mIHRoaXMub3B0cy5tYXAgIT09ICd1bmRlZmluZWQnKSB7XG4gICAgICByZXR1cm4gISF0aGlzLm9wdHMubWFwXG4gICAgfVxuICAgIHJldHVybiB0aGlzLnByZXZpb3VzKCkubGVuZ3RoID4gMFxuICB9XG5cbiAgcHJldmlvdXMgKCkge1xuICAgIGlmICghdGhpcy5wcmV2aW91c01hcHMpIHtcbiAgICAgIHRoaXMucHJldmlvdXNNYXBzID0gW11cbiAgICAgIHRoaXMucm9vdC53YWxrKG5vZGUgPT4ge1xuICAgICAgICBpZiAobm9kZS5zb3VyY2UgJiYgbm9kZS5zb3VyY2UuaW5wdXQubWFwKSB7XG4gICAgICAgICAgbGV0IG1hcCA9IG5vZGUuc291cmNlLmlucHV0Lm1hcFxuICAgICAgICAgIGlmICh0aGlzLnByZXZpb3VzTWFwcy5pbmRleE9mKG1hcCkgPT09IC0xKSB7XG4gICAgICAgICAgICB0aGlzLnByZXZpb3VzTWFwcy5wdXNoKG1hcClcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMucHJldmlvdXNNYXBzXG4gIH1cblxuICBpc0lubGluZSAoKSB7XG4gICAgaWYgKHR5cGVvZiB0aGlzLm1hcE9wdHMuaW5saW5lICE9PSAndW5kZWZpbmVkJykge1xuICAgICAgcmV0dXJuIHRoaXMubWFwT3B0cy5pbmxpbmVcbiAgICB9XG5cbiAgICBsZXQgYW5ub3RhdGlvbiA9IHRoaXMubWFwT3B0cy5hbm5vdGF0aW9uXG4gICAgaWYgKHR5cGVvZiBhbm5vdGF0aW9uICE9PSAndW5kZWZpbmVkJyAmJiBhbm5vdGF0aW9uICE9PSB0cnVlKSB7XG4gICAgICByZXR1cm4gZmFsc2VcbiAgICB9XG5cbiAgICBpZiAodGhpcy5wcmV2aW91cygpLmxlbmd0aCkge1xuICAgICAgcmV0dXJuIHRoaXMucHJldmlvdXMoKS5zb21lKGkgPT4gaS5pbmxpbmUpXG4gICAgfVxuICAgIHJldHVybiB0cnVlXG4gIH1cblxuICBpc1NvdXJjZXNDb250ZW50ICgpIHtcbiAgICBpZiAodHlwZW9mIHRoaXMubWFwT3B0cy5zb3VyY2VzQ29udGVudCAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgIHJldHVybiB0aGlzLm1hcE9wdHMuc291cmNlc0NvbnRlbnRcbiAgICB9XG4gICAgaWYgKHRoaXMucHJldmlvdXMoKS5sZW5ndGgpIHtcbiAgICAgIHJldHVybiB0aGlzLnByZXZpb3VzKCkuc29tZShpID0+IGkud2l0aENvbnRlbnQoKSlcbiAgICB9XG4gICAgcmV0dXJuIHRydWVcbiAgfVxuXG4gIGNsZWFyQW5ub3RhdGlvbiAoKSB7XG4gICAgaWYgKHRoaXMubWFwT3B0cy5hbm5vdGF0aW9uID09PSBmYWxzZSkgcmV0dXJuXG5cbiAgICBsZXQgbm9kZVxuICAgIGZvciAobGV0IGkgPSB0aGlzLnJvb3Qubm9kZXMubGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcbiAgICAgIG5vZGUgPSB0aGlzLnJvb3Qubm9kZXNbaV1cbiAgICAgIGlmIChub2RlLnR5cGUgIT09ICdjb21tZW50JykgY29udGludWVcbiAgICAgIGlmIChub2RlLnRleHQuaW5kZXhPZignIyBzb3VyY2VNYXBwaW5nVVJMPScpID09PSAwKSB7XG4gICAgICAgIHRoaXMucm9vdC5yZW1vdmVDaGlsZChpKVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHNldFNvdXJjZXNDb250ZW50ICgpIHtcbiAgICBsZXQgYWxyZWFkeSA9IHsgfVxuICAgIHRoaXMucm9vdC53YWxrKG5vZGUgPT4ge1xuICAgICAgaWYgKG5vZGUuc291cmNlKSB7XG4gICAgICAgIGxldCBmcm9tID0gbm9kZS5zb3VyY2UuaW5wdXQuZnJvbVxuICAgICAgICBpZiAoZnJvbSAmJiAhYWxyZWFkeVtmcm9tXSkge1xuICAgICAgICAgIGFscmVhZHlbZnJvbV0gPSB0cnVlXG4gICAgICAgICAgbGV0IHJlbGF0aXZlID0gdGhpcy5yZWxhdGl2ZShmcm9tKVxuICAgICAgICAgIHRoaXMubWFwLnNldFNvdXJjZUNvbnRlbnQocmVsYXRpdmUsIG5vZGUuc291cmNlLmlucHV0LmNzcylcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pXG4gIH1cblxuICBhcHBseVByZXZNYXBzICgpIHtcbiAgICBmb3IgKGxldCBwcmV2IG9mIHRoaXMucHJldmlvdXMoKSkge1xuICAgICAgbGV0IGZyb20gPSB0aGlzLnJlbGF0aXZlKHByZXYuZmlsZSlcbiAgICAgIGxldCByb290ID0gcHJldi5yb290IHx8IHBhdGguZGlybmFtZShwcmV2LmZpbGUpXG4gICAgICBsZXQgbWFwXG5cbiAgICAgIGlmICh0aGlzLm1hcE9wdHMuc291cmNlc0NvbnRlbnQgPT09IGZhbHNlKSB7XG4gICAgICAgIG1hcCA9IG5ldyBtb3ppbGxhLlNvdXJjZU1hcENvbnN1bWVyKHByZXYudGV4dClcbiAgICAgICAgaWYgKG1hcC5zb3VyY2VzQ29udGVudCkge1xuICAgICAgICAgIG1hcC5zb3VyY2VzQ29udGVudCA9IG1hcC5zb3VyY2VzQ29udGVudC5tYXAoKCkgPT4gbnVsbClcbiAgICAgICAgfVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgbWFwID0gcHJldi5jb25zdW1lcigpXG4gICAgICB9XG5cbiAgICAgIHRoaXMubWFwLmFwcGx5U291cmNlTWFwKG1hcCwgZnJvbSwgdGhpcy5yZWxhdGl2ZShyb290KSlcbiAgICB9XG4gIH1cblxuICBpc0Fubm90YXRpb24gKCkge1xuICAgIGlmICh0aGlzLmlzSW5saW5lKCkpIHtcbiAgICAgIHJldHVybiB0cnVlXG4gICAgfVxuICAgIGlmICh0eXBlb2YgdGhpcy5tYXBPcHRzLmFubm90YXRpb24gIT09ICd1bmRlZmluZWQnKSB7XG4gICAgICByZXR1cm4gdGhpcy5tYXBPcHRzLmFubm90YXRpb25cbiAgICB9XG4gICAgaWYgKHRoaXMucHJldmlvdXMoKS5sZW5ndGgpIHtcbiAgICAgIHJldHVybiB0aGlzLnByZXZpb3VzKCkuc29tZShpID0+IGkuYW5ub3RhdGlvbilcbiAgICB9XG4gICAgcmV0dXJuIHRydWVcbiAgfVxuXG4gIHRvQmFzZTY0IChzdHIpIHtcbiAgICBpZiAoQnVmZmVyKSB7XG4gICAgICByZXR1cm4gQnVmZmVyLmZyb20oc3RyKS50b1N0cmluZygnYmFzZTY0JylcbiAgICB9XG4gICAgcmV0dXJuIHdpbmRvdy5idG9hKHVuZXNjYXBlKGVuY29kZVVSSUNvbXBvbmVudChzdHIpKSlcbiAgfVxuXG4gIGFkZEFubm90YXRpb24gKCkge1xuICAgIGxldCBjb250ZW50XG5cbiAgICBpZiAodGhpcy5pc0lubGluZSgpKSB7XG4gICAgICBjb250ZW50ID0gJ2RhdGE6YXBwbGljYXRpb24vanNvbjtiYXNlNjQsJyArXG4gICAgICAgICAgICAgICAgdGhpcy50b0Jhc2U2NCh0aGlzLm1hcC50b1N0cmluZygpKVxuICAgIH0gZWxzZSBpZiAodHlwZW9mIHRoaXMubWFwT3B0cy5hbm5vdGF0aW9uID09PSAnc3RyaW5nJykge1xuICAgICAgY29udGVudCA9IHRoaXMubWFwT3B0cy5hbm5vdGF0aW9uXG4gICAgfSBlbHNlIHtcbiAgICAgIGNvbnRlbnQgPSB0aGlzLm91dHB1dEZpbGUoKSArICcubWFwJ1xuICAgIH1cblxuICAgIGxldCBlb2wgPSAnXFxuJ1xuICAgIGlmICh0aGlzLmNzcy5pbmRleE9mKCdcXHJcXG4nKSAhPT0gLTEpIGVvbCA9ICdcXHJcXG4nXG5cbiAgICB0aGlzLmNzcyArPSBlb2wgKyAnLyojIHNvdXJjZU1hcHBpbmdVUkw9JyArIGNvbnRlbnQgKyAnICovJ1xuICB9XG5cbiAgb3V0cHV0RmlsZSAoKSB7XG4gICAgaWYgKHRoaXMub3B0cy50bykge1xuICAgICAgcmV0dXJuIHRoaXMucmVsYXRpdmUodGhpcy5vcHRzLnRvKVxuICAgIH1cbiAgICBpZiAodGhpcy5vcHRzLmZyb20pIHtcbiAgICAgIHJldHVybiB0aGlzLnJlbGF0aXZlKHRoaXMub3B0cy5mcm9tKVxuICAgIH1cbiAgICByZXR1cm4gJ3RvLmNzcydcbiAgfVxuXG4gIGdlbmVyYXRlTWFwICgpIHtcbiAgICB0aGlzLmdlbmVyYXRlU3RyaW5nKClcbiAgICBpZiAodGhpcy5pc1NvdXJjZXNDb250ZW50KCkpIHRoaXMuc2V0U291cmNlc0NvbnRlbnQoKVxuICAgIGlmICh0aGlzLnByZXZpb3VzKCkubGVuZ3RoID4gMCkgdGhpcy5hcHBseVByZXZNYXBzKClcbiAgICBpZiAodGhpcy5pc0Fubm90YXRpb24oKSkgdGhpcy5hZGRBbm5vdGF0aW9uKClcblxuICAgIGlmICh0aGlzLmlzSW5saW5lKCkpIHtcbiAgICAgIHJldHVybiBbdGhpcy5jc3NdXG4gICAgfVxuICAgIHJldHVybiBbdGhpcy5jc3MsIHRoaXMubWFwXVxuICB9XG5cbiAgcmVsYXRpdmUgKGZpbGUpIHtcbiAgICBpZiAoZmlsZS5pbmRleE9mKCc8JykgPT09IDApIHJldHVybiBmaWxlXG4gICAgaWYgKC9eXFx3KzpcXC9cXC8vLnRlc3QoZmlsZSkpIHJldHVybiBmaWxlXG5cbiAgICBsZXQgZnJvbSA9IHRoaXMub3B0cy50byA/IHBhdGguZGlybmFtZSh0aGlzLm9wdHMudG8pIDogJy4nXG5cbiAgICBpZiAodHlwZW9mIHRoaXMubWFwT3B0cy5hbm5vdGF0aW9uID09PSAnc3RyaW5nJykge1xuICAgICAgZnJvbSA9IHBhdGguZGlybmFtZShwYXRoLnJlc29sdmUoZnJvbSwgdGhpcy5tYXBPcHRzLmFubm90YXRpb24pKVxuICAgIH1cblxuICAgIGZpbGUgPSBwYXRoLnJlbGF0aXZlKGZyb20sIGZpbGUpXG4gICAgaWYgKHBhdGguc2VwID09PSAnXFxcXCcpIHtcbiAgICAgIHJldHVybiBmaWxlLnJlcGxhY2UoL1xcXFwvZywgJy8nKVxuICAgIH1cbiAgICByZXR1cm4gZmlsZVxuICB9XG5cbiAgc291cmNlUGF0aCAobm9kZSkge1xuICAgIGlmICh0aGlzLm1hcE9wdHMuZnJvbSkge1xuICAgICAgcmV0dXJuIHRoaXMubWFwT3B0cy5mcm9tXG4gICAgfVxuICAgIHJldHVybiB0aGlzLnJlbGF0aXZlKG5vZGUuc291cmNlLmlucHV0LmZyb20pXG4gIH1cblxuICBnZW5lcmF0ZVN0cmluZyAoKSB7XG4gICAgdGhpcy5jc3MgPSAnJ1xuICAgIHRoaXMubWFwID0gbmV3IG1vemlsbGEuU291cmNlTWFwR2VuZXJhdG9yKHsgZmlsZTogdGhpcy5vdXRwdXRGaWxlKCkgfSlcblxuICAgIGxldCBsaW5lID0gMVxuICAgIGxldCBjb2x1bW4gPSAxXG5cbiAgICBsZXQgbGluZXMsIGxhc3RcbiAgICB0aGlzLnN0cmluZ2lmeSh0aGlzLnJvb3QsIChzdHIsIG5vZGUsIHR5cGUpID0+IHtcbiAgICAgIHRoaXMuY3NzICs9IHN0clxuXG4gICAgICBpZiAobm9kZSAmJiB0eXBlICE9PSAnZW5kJykge1xuICAgICAgICBpZiAobm9kZS5zb3VyY2UgJiYgbm9kZS5zb3VyY2Uuc3RhcnQpIHtcbiAgICAgICAgICB0aGlzLm1hcC5hZGRNYXBwaW5nKHtcbiAgICAgICAgICAgIHNvdXJjZTogdGhpcy5zb3VyY2VQYXRoKG5vZGUpLFxuICAgICAgICAgICAgZ2VuZXJhdGVkOiB7IGxpbmUsIGNvbHVtbjogY29sdW1uIC0gMSB9LFxuICAgICAgICAgICAgb3JpZ2luYWw6IHtcbiAgICAgICAgICAgICAgbGluZTogbm9kZS5zb3VyY2Uuc3RhcnQubGluZSxcbiAgICAgICAgICAgICAgY29sdW1uOiBub2RlLnNvdXJjZS5zdGFydC5jb2x1bW4gLSAxXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSlcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICB0aGlzLm1hcC5hZGRNYXBwaW5nKHtcbiAgICAgICAgICAgIHNvdXJjZTogJzxubyBzb3VyY2U+JyxcbiAgICAgICAgICAgIG9yaWdpbmFsOiB7IGxpbmU6IDEsIGNvbHVtbjogMCB9LFxuICAgICAgICAgICAgZ2VuZXJhdGVkOiB7IGxpbmUsIGNvbHVtbjogY29sdW1uIC0gMSB9XG4gICAgICAgICAgfSlcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBsaW5lcyA9IHN0ci5tYXRjaCgvXFxuL2cpXG4gICAgICBpZiAobGluZXMpIHtcbiAgICAgICAgbGluZSArPSBsaW5lcy5sZW5ndGhcbiAgICAgICAgbGFzdCA9IHN0ci5sYXN0SW5kZXhPZignXFxuJylcbiAgICAgICAgY29sdW1uID0gc3RyLmxlbmd0aCAtIGxhc3RcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbHVtbiArPSBzdHIubGVuZ3RoXG4gICAgICB9XG5cbiAgICAgIGlmIChub2RlICYmIHR5cGUgIT09ICdzdGFydCcpIHtcbiAgICAgICAgbGV0IHAgPSBub2RlLnBhcmVudCB8fCB7IHJhd3M6IHsgfSB9XG4gICAgICAgIGlmIChub2RlLnR5cGUgIT09ICdkZWNsJyB8fCBub2RlICE9PSBwLmxhc3QgfHwgcC5yYXdzLnNlbWljb2xvbikge1xuICAgICAgICAgIGlmIChub2RlLnNvdXJjZSAmJiBub2RlLnNvdXJjZS5lbmQpIHtcbiAgICAgICAgICAgIHRoaXMubWFwLmFkZE1hcHBpbmcoe1xuICAgICAgICAgICAgICBzb3VyY2U6IHRoaXMuc291cmNlUGF0aChub2RlKSxcbiAgICAgICAgICAgICAgZ2VuZXJhdGVkOiB7IGxpbmUsIGNvbHVtbjogY29sdW1uIC0gMiB9LFxuICAgICAgICAgICAgICBvcmlnaW5hbDoge1xuICAgICAgICAgICAgICAgIGxpbmU6IG5vZGUuc291cmNlLmVuZC5saW5lLFxuICAgICAgICAgICAgICAgIGNvbHVtbjogbm9kZS5zb3VyY2UuZW5kLmNvbHVtbiAtIDFcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSlcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5tYXAuYWRkTWFwcGluZyh7XG4gICAgICAgICAgICAgIHNvdXJjZTogJzxubyBzb3VyY2U+JyxcbiAgICAgICAgICAgICAgb3JpZ2luYWw6IHsgbGluZTogMSwgY29sdW1uOiAwIH0sXG4gICAgICAgICAgICAgIGdlbmVyYXRlZDogeyBsaW5lLCBjb2x1bW46IGNvbHVtbiAtIDEgfVxuICAgICAgICAgICAgfSlcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KVxuICB9XG5cbiAgZ2VuZXJhdGUgKCkge1xuICAgIHRoaXMuY2xlYXJBbm5vdGF0aW9uKClcblxuICAgIGlmICh0aGlzLmlzTWFwKCkpIHtcbiAgICAgIHJldHVybiB0aGlzLmdlbmVyYXRlTWFwKClcbiAgICB9XG5cbiAgICBsZXQgcmVzdWx0ID0gJydcbiAgICB0aGlzLnN0cmluZ2lmeSh0aGlzLnJvb3QsIGkgPT4ge1xuICAgICAgcmVzdWx0ICs9IGlcbiAgICB9KVxuICAgIHJldHVybiBbcmVzdWx0XVxuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IE1hcEdlbmVyYXRvclxuIl0sImZpbGUiOiJtYXAtZ2VuZXJhdG9yLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/node.js b/node_modules/autoprefixer/node_modules/postcss/lib/node.js
new file mode 100644
index 0000000..a0e582c
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/node.js
@@ -0,0 +1,608 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _cssSyntaxError = _interopRequireDefault(require("./css-syntax-error"));
+
+var _stringifier = _interopRequireDefault(require("./stringifier"));
+
+var _stringify = _interopRequireDefault(require("./stringify"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function cloneNode(obj, parent) {
+ var cloned = new obj.constructor();
+
+ for (var i in obj) {
+ if (!obj.hasOwnProperty(i)) continue;
+ var value = obj[i];
+ var type = typeof value;
+
+ if (i === 'parent' && type === 'object') {
+ if (parent) cloned[i] = parent;
+ } else if (i === 'source') {
+ cloned[i] = value;
+ } else if (value instanceof Array) {
+ cloned[i] = value.map(function (j) {
+ return cloneNode(j, cloned);
+ });
+ } else {
+ if (type === 'object' && value !== null) value = cloneNode(value);
+ cloned[i] = value;
+ }
+ }
+
+ return cloned;
+}
+/**
+ * All node classes inherit the following common methods.
+ *
+ * @abstract
+ */
+
+
+var Node =
+/*#__PURE__*/
+function () {
+ /**
+ * @param {object} [defaults] Value for node properties.
+ */
+ function Node(defaults) {
+ if (defaults === void 0) {
+ defaults = {};
+ }
+
+ this.raws = {};
+
+ if (process.env.NODE_ENV !== 'production') {
+ if (typeof defaults !== 'object' && typeof defaults !== 'undefined') {
+ throw new Error('PostCSS nodes constructor accepts object, not ' + JSON.stringify(defaults));
+ }
+ }
+
+ for (var name in defaults) {
+ this[name] = defaults[name];
+ }
+ }
+ /**
+ * Returns a `CssSyntaxError` instance containing the original position
+ * of the node in the source, showing line and column numbers and also
+ * a small excerpt to facilitate debugging.
+ *
+ * If present, an input source map will be used to get the original position
+ * of the source, even from a previous compilation step
+ * (e.g., from Sass compilation).
+ *
+ * This method produces very useful error messages.
+ *
+ * @param {string} message Error description.
+ * @param {object} [opts] Options.
+ * @param {string} opts.plugin Plugin name that created this error.
+ * PostCSS will set it automatically.
+ * @param {string} opts.word A word inside a node’s string that should
+ * be highlighted as the source of the error.
+ * @param {number} opts.index An index inside a node’s string that should
+ * be highlighted as the source of the error.
+ *
+ * @return {CssSyntaxError} Error object to throw it.
+ *
+ * @example
+ * if (!variables[name]) {
+ * throw decl.error('Unknown variable ' + name, { word: name })
+ * // CssSyntaxError: postcss-vars:a.sass:4:3: Unknown variable $black
+ * // color: $black
+ * // a
+ * // ^
+ * // background: white
+ * }
+ */
+
+
+ var _proto = Node.prototype;
+
+ _proto.error = function error(message, opts) {
+ if (opts === void 0) {
+ opts = {};
+ }
+
+ if (this.source) {
+ var pos = this.positionBy(opts);
+ return this.source.input.error(message, pos.line, pos.column, opts);
+ }
+
+ return new _cssSyntaxError.default(message);
+ }
+ /**
+ * This method is provided as a convenience wrapper for {@link Result#warn}.
+ *
+ * @param {Result} result The {@link Result} instance
+ * that will receive the warning.
+ * @param {string} text Warning message.
+ * @param {object} [opts] Options
+ * @param {string} opts.plugin Plugin name that created this warning.
+ * PostCSS will set it automatically.
+ * @param {string} opts.word A word inside a node’s string that should
+ * be highlighted as the source of the warning.
+ * @param {number} opts.index An index inside a node’s string that should
+ * be highlighted as the source of the warning.
+ *
+ * @return {Warning} Created warning object.
+ *
+ * @example
+ * const plugin = postcss.plugin('postcss-deprecated', () => {
+ * return (root, result) => {
+ * root.walkDecls('bad', decl => {
+ * decl.warn(result, 'Deprecated property bad')
+ * })
+ * }
+ * })
+ */
+ ;
+
+ _proto.warn = function warn(result, text, opts) {
+ var data = {
+ node: this
+ };
+
+ for (var i in opts) {
+ data[i] = opts[i];
+ }
+
+ return result.warn(text, data);
+ }
+ /**
+ * Removes the node from its parent and cleans the parent properties
+ * from the node and its children.
+ *
+ * @example
+ * if (decl.prop.match(/^-webkit-/)) {
+ * decl.remove()
+ * }
+ *
+ * @return {Node} Node to make calls chain.
+ */
+ ;
+
+ _proto.remove = function remove() {
+ if (this.parent) {
+ this.parent.removeChild(this);
+ }
+
+ this.parent = undefined;
+ return this;
+ }
+ /**
+ * Returns a CSS string representing the node.
+ *
+ * @param {stringifier|syntax} [stringifier] A syntax to use
+ * in string generation.
+ *
+ * @return {string} CSS string of this node.
+ *
+ * @example
+ * postcss.rule({ selector: 'a' }).toString() //=> "a {}"
+ */
+ ;
+
+ _proto.toString = function toString(stringifier) {
+ if (stringifier === void 0) {
+ stringifier = _stringify.default;
+ }
+
+ if (stringifier.stringify) stringifier = stringifier.stringify;
+ var result = '';
+ stringifier(this, function (i) {
+ result += i;
+ });
+ return result;
+ }
+ /**
+ * Returns an exact clone of the node.
+ *
+ * The resulting cloned node and its (cloned) children will retain
+ * code style properties.
+ *
+ * @param {object} [overrides] New properties to override in the clone.
+ *
+ * @example
+ * decl.raws.before //=> "\n "
+ * const cloned = decl.clone({ prop: '-moz-' + decl.prop })
+ * cloned.raws.before //=> "\n "
+ * cloned.toString() //=> -moz-transform: scale(0)
+ *
+ * @return {Node} Clone of the node.
+ */
+ ;
+
+ _proto.clone = function clone(overrides) {
+ if (overrides === void 0) {
+ overrides = {};
+ }
+
+ var cloned = cloneNode(this);
+
+ for (var name in overrides) {
+ cloned[name] = overrides[name];
+ }
+
+ return cloned;
+ }
+ /**
+ * Shortcut to clone the node and insert the resulting cloned node
+ * before the current node.
+ *
+ * @param {object} [overrides] Mew properties to override in the clone.
+ *
+ * @example
+ * decl.cloneBefore({ prop: '-moz-' + decl.prop })
+ *
+ * @return {Node} New node
+ */
+ ;
+
+ _proto.cloneBefore = function cloneBefore(overrides) {
+ if (overrides === void 0) {
+ overrides = {};
+ }
+
+ var cloned = this.clone(overrides);
+ this.parent.insertBefore(this, cloned);
+ return cloned;
+ }
+ /**
+ * Shortcut to clone the node and insert the resulting cloned node
+ * after the current node.
+ *
+ * @param {object} [overrides] New properties to override in the clone.
+ *
+ * @return {Node} New node.
+ */
+ ;
+
+ _proto.cloneAfter = function cloneAfter(overrides) {
+ if (overrides === void 0) {
+ overrides = {};
+ }
+
+ var cloned = this.clone(overrides);
+ this.parent.insertAfter(this, cloned);
+ return cloned;
+ }
+ /**
+ * Inserts node(s) before the current node and removes the current node.
+ *
+ * @param {...Node} nodes Mode(s) to replace current one.
+ *
+ * @example
+ * if (atrule.name === 'mixin') {
+ * atrule.replaceWith(mixinRules[atrule.params])
+ * }
+ *
+ * @return {Node} Current node to methods chain.
+ */
+ ;
+
+ _proto.replaceWith = function replaceWith() {
+ if (this.parent) {
+ for (var _len = arguments.length, nodes = new Array(_len), _key = 0; _key < _len; _key++) {
+ nodes[_key] = arguments[_key];
+ }
+
+ for (var _i = 0, _nodes = nodes; _i < _nodes.length; _i++) {
+ var node = _nodes[_i];
+ this.parent.insertBefore(this, node);
+ }
+
+ this.remove();
+ }
+
+ return this;
+ }
+ /**
+ * Returns the next child of the node’s parent.
+ * Returns `undefined` if the current node is the last child.
+ *
+ * @return {Node|undefined} Next node.
+ *
+ * @example
+ * if (comment.text === 'delete next') {
+ * const next = comment.next()
+ * if (next) {
+ * next.remove()
+ * }
+ * }
+ */
+ ;
+
+ _proto.next = function next() {
+ if (!this.parent) return undefined;
+ var index = this.parent.index(this);
+ return this.parent.nodes[index + 1];
+ }
+ /**
+ * Returns the previous child of the node’s parent.
+ * Returns `undefined` if the current node is the first child.
+ *
+ * @return {Node|undefined} Previous node.
+ *
+ * @example
+ * const annotation = decl.prev()
+ * if (annotation.type === 'comment') {
+ * readAnnotation(annotation.text)
+ * }
+ */
+ ;
+
+ _proto.prev = function prev() {
+ if (!this.parent) return undefined;
+ var index = this.parent.index(this);
+ return this.parent.nodes[index - 1];
+ }
+ /**
+ * Insert new node before current node to current node’s parent.
+ *
+ * Just alias for `node.parent.insertBefore(node, add)`.
+ *
+ * @param {Node|object|string|Node[]} add New node.
+ *
+ * @return {Node} This node for methods chain.
+ *
+ * @example
+ * decl.before('content: ""')
+ */
+ ;
+
+ _proto.before = function before(add) {
+ this.parent.insertBefore(this, add);
+ return this;
+ }
+ /**
+ * Insert new node after current node to current node’s parent.
+ *
+ * Just alias for `node.parent.insertAfter(node, add)`.
+ *
+ * @param {Node|object|string|Node[]} add New node.
+ *
+ * @return {Node} This node for methods chain.
+ *
+ * @example
+ * decl.after('color: black')
+ */
+ ;
+
+ _proto.after = function after(add) {
+ this.parent.insertAfter(this, add);
+ return this;
+ };
+
+ _proto.toJSON = function toJSON() {
+ var fixed = {};
+
+ for (var name in this) {
+ if (!this.hasOwnProperty(name)) continue;
+ if (name === 'parent') continue;
+ var value = this[name];
+
+ if (value instanceof Array) {
+ fixed[name] = value.map(function (i) {
+ if (typeof i === 'object' && i.toJSON) {
+ return i.toJSON();
+ } else {
+ return i;
+ }
+ });
+ } else if (typeof value === 'object' && value.toJSON) {
+ fixed[name] = value.toJSON();
+ } else {
+ fixed[name] = value;
+ }
+ }
+
+ return fixed;
+ }
+ /**
+ * Returns a {@link Node#raws} value. If the node is missing
+ * the code style property (because the node was manually built or cloned),
+ * PostCSS will try to autodetect the code style property by looking
+ * at other nodes in the tree.
+ *
+ * @param {string} prop Name of code style property.
+ * @param {string} [defaultType] Name of default value, it can be missed
+ * if the value is the same as prop.
+ *
+ * @example
+ * const root = postcss.parse('a { background: white }')
+ * root.nodes[0].append({ prop: 'color', value: 'black' })
+ * root.nodes[0].nodes[1].raws.before //=> undefined
+ * root.nodes[0].nodes[1].raw('before') //=> ' '
+ *
+ * @return {string} Code style value.
+ */
+ ;
+
+ _proto.raw = function raw(prop, defaultType) {
+ var str = new _stringifier.default();
+ return str.raw(this, prop, defaultType);
+ }
+ /**
+ * Finds the Root instance of the node’s tree.
+ *
+ * @example
+ * root.nodes[0].nodes[0].root() === root
+ *
+ * @return {Root} Root parent.
+ */
+ ;
+
+ _proto.root = function root() {
+ var result = this;
+
+ while (result.parent) {
+ result = result.parent;
+ }
+
+ return result;
+ }
+ /**
+ * Clear the code style properties for the node and its children.
+ *
+ * @param {boolean} [keepBetween] Keep the raws.between symbols.
+ *
+ * @return {undefined}
+ *
+ * @example
+ * node.raws.before //=> ' '
+ * node.cleanRaws()
+ * node.raws.before //=> undefined
+ */
+ ;
+
+ _proto.cleanRaws = function cleanRaws(keepBetween) {
+ delete this.raws.before;
+ delete this.raws.after;
+ if (!keepBetween) delete this.raws.between;
+ };
+
+ _proto.positionInside = function positionInside(index) {
+ var string = this.toString();
+ var column = this.source.start.column;
+ var line = this.source.start.line;
+
+ for (var i = 0; i < index; i++) {
+ if (string[i] === '\n') {
+ column = 1;
+ line += 1;
+ } else {
+ column += 1;
+ }
+ }
+
+ return {
+ line: line,
+ column: column
+ };
+ };
+
+ _proto.positionBy = function positionBy(opts) {
+ var pos = this.source.start;
+
+ if (opts.index) {
+ pos = this.positionInside(opts.index);
+ } else if (opts.word) {
+ var index = this.toString().indexOf(opts.word);
+ if (index !== -1) pos = this.positionInside(index);
+ }
+
+ return pos;
+ }
+ /**
+ * @memberof Node#
+ * @member {string} type String representing the node’s type.
+ * Possible values are `root`, `atrule`, `rule`,
+ * `decl`, or `comment`.
+ *
+ * @example
+ * postcss.decl({ prop: 'color', value: 'black' }).type //=> 'decl'
+ */
+
+ /**
+ * @memberof Node#
+ * @member {Container} parent The node’s parent node.
+ *
+ * @example
+ * root.nodes[0].parent === root
+ */
+
+ /**
+ * @memberof Node#
+ * @member {source} source The input source of the node.
+ *
+ * The property is used in source map generation.
+ *
+ * If you create a node manually (e.g., with `postcss.decl()`),
+ * that node will not have a `source` property and will be absent
+ * from the source map. For this reason, the plugin developer should
+ * consider cloning nodes to create new ones (in which case the new node’s
+ * source will reference the original, cloned node) or setting
+ * the `source` property manually.
+ *
+ * ```js
+ * // Bad
+ * const prefixed = postcss.decl({
+ * prop: '-moz-' + decl.prop,
+ * value: decl.value
+ * })
+ *
+ * // Good
+ * const prefixed = decl.clone({ prop: '-moz-' + decl.prop })
+ * ```
+ *
+ * ```js
+ * if (atrule.name === 'add-link') {
+ * const rule = postcss.rule({ selector: 'a', source: atrule.source })
+ * atrule.parent.insertBefore(atrule, rule)
+ * }
+ * ```
+ *
+ * @example
+ * decl.source.input.from //=> '/home/ai/a.sass'
+ * decl.source.start //=> { line: 10, column: 2 }
+ * decl.source.end //=> { line: 10, column: 12 }
+ */
+
+ /**
+ * @memberof Node#
+ * @member {object} raws Information to generate byte-to-byte equal
+ * node string as it was in the origin input.
+ *
+ * Every parser saves its own properties,
+ * but the default CSS parser uses:
+ *
+ * * `before`: the space symbols before the node. It also stores `*`
+ * and `_` symbols before the declaration (IE hack).
+ * * `after`: the space symbols after the last child of the node
+ * to the end of the node.
+ * * `between`: the symbols between the property and value
+ * for declarations, selector and `{` for rules, or last parameter
+ * and `{` for at-rules.
+ * * `semicolon`: contains true if the last child has
+ * an (optional) semicolon.
+ * * `afterName`: the space between the at-rule name and its parameters.
+ * * `left`: the space symbols between `/*` and the comment’s text.
+ * * `right`: the space symbols between the comment’s text
+ * and <code>*&#47;</code>.
+ * * `important`: the content of the important statement,
+ * if it is not just `!important`.
+ *
+ * PostCSS cleans selectors, declaration values and at-rule parameters
+ * from comments and extra spaces, but it stores origin content in raws
+ * properties. As such, if you don’t change a declaration’s value,
+ * PostCSS will use the raw value with comments.
+ *
+ * @example
+ * const root = postcss.parse('a {\n color:black\n}')
+ * root.first.first.raws //=> { before: '\n ', between: ':' }
+ */
+ ;
+
+ return Node;
+}();
+
+var _default = Node;
+/**
+ * @typedef {object} position
+ * @property {number} line Source line in file.
+ * @property {number} column Source column in file.
+ */
+
+/**
+ * @typedef {object} source
+ * @property {Input} input {@link Input} with input file
+ * @property {position} start The starting position of the node’s source.
+ * @property {position} end The ending position of the node’s source.
+ */
+
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGUuZXM2Il0sIm5hbWVzIjpbImNsb25lTm9kZSIsIm9iaiIsInBhcmVudCIsImNsb25lZCIsImNvbnN0cnVjdG9yIiwiaSIsImhhc093blByb3BlcnR5IiwidmFsdWUiLCJ0eXBlIiwiQXJyYXkiLCJtYXAiLCJqIiwiTm9kZSIsImRlZmF1bHRzIiwicmF3cyIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIkVycm9yIiwiSlNPTiIsInN0cmluZ2lmeSIsIm5hbWUiLCJlcnJvciIsIm1lc3NhZ2UiLCJvcHRzIiwic291cmNlIiwicG9zIiwicG9zaXRpb25CeSIsImlucHV0IiwibGluZSIsImNvbHVtbiIsIkNzc1N5bnRheEVycm9yIiwid2FybiIsInJlc3VsdCIsInRleHQiLCJkYXRhIiwibm9kZSIsInJlbW92ZSIsInJlbW92ZUNoaWxkIiwidW5kZWZpbmVkIiwidG9TdHJpbmciLCJzdHJpbmdpZmllciIsImNsb25lIiwib3ZlcnJpZGVzIiwiY2xvbmVCZWZvcmUiLCJpbnNlcnRCZWZvcmUiLCJjbG9uZUFmdGVyIiwiaW5zZXJ0QWZ0ZXIiLCJyZXBsYWNlV2l0aCIsIm5vZGVzIiwibmV4dCIsImluZGV4IiwicHJldiIsImJlZm9yZSIsImFkZCIsImFmdGVyIiwidG9KU09OIiwiZml4ZWQiLCJyYXciLCJwcm9wIiwiZGVmYXVsdFR5cGUiLCJzdHIiLCJTdHJpbmdpZmllciIsInJvb3QiLCJjbGVhblJhd3MiLCJrZWVwQmV0d2VlbiIsImJldHdlZW4iLCJwb3NpdGlvbkluc2lkZSIsInN0cmluZyIsInN0YXJ0Iiwid29yZCIsImluZGV4T2YiXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7Ozs7QUFFQSxTQUFTQSxTQUFULENBQW9CQyxHQUFwQixFQUF5QkMsTUFBekIsRUFBaUM7QUFDL0IsTUFBSUMsTUFBTSxHQUFHLElBQUlGLEdBQUcsQ0FBQ0csV0FBUixFQUFiOztBQUVBLE9BQUssSUFBSUMsQ0FBVCxJQUFjSixHQUFkLEVBQW1CO0FBQ2pCLFFBQUksQ0FBQ0EsR0FBRyxDQUFDSyxjQUFKLENBQW1CRCxDQUFuQixDQUFMLEVBQTRCO0FBQzVCLFFBQUlFLEtBQUssR0FBR04sR0FBRyxDQUFDSSxDQUFELENBQWY7QUFDQSxRQUFJRyxJQUFJLEdBQUcsT0FBT0QsS0FBbEI7O0FBRUEsUUFBSUYsQ0FBQyxLQUFLLFFBQU4sSUFBa0JHLElBQUksS0FBSyxRQUEvQixFQUF5QztBQUN2QyxVQUFJTixNQUFKLEVBQVlDLE1BQU0sQ0FBQ0UsQ0FBRCxDQUFOLEdBQVlILE1BQVo7QUFDYixLQUZELE1BRU8sSUFBSUcsQ0FBQyxLQUFLLFFBQVYsRUFBb0I7QUFDekJGLE1BQUFBLE1BQU0sQ0FBQ0UsQ0FBRCxDQUFOLEdBQVlFLEtBQVo7QUFDRCxLQUZNLE1BRUEsSUFBSUEsS0FBSyxZQUFZRSxLQUFyQixFQUE0QjtBQUNqQ04sTUFBQUEsTUFBTSxDQUFDRSxDQUFELENBQU4sR0FBWUUsS0FBSyxDQUFDRyxHQUFOLENBQVUsVUFBQUMsQ0FBQztBQUFBLGVBQUlYLFNBQVMsQ0FBQ1csQ0FBRCxFQUFJUixNQUFKLENBQWI7QUFBQSxPQUFYLENBQVo7QUFDRCxLQUZNLE1BRUE7QUFDTCxVQUFJSyxJQUFJLEtBQUssUUFBVCxJQUFxQkQsS0FBSyxLQUFLLElBQW5DLEVBQXlDQSxLQUFLLEdBQUdQLFNBQVMsQ0FBQ08sS0FBRCxDQUFqQjtBQUN6Q0osTUFBQUEsTUFBTSxDQUFDRSxDQUFELENBQU4sR0FBWUUsS0FBWjtBQUNEO0FBQ0Y7O0FBRUQsU0FBT0osTUFBUDtBQUNEO0FBRUQ7Ozs7Ozs7SUFLTVMsSTs7O0FBQ0o7OztBQUdBLGdCQUFhQyxRQUFiLEVBQTZCO0FBQUEsUUFBaEJBLFFBQWdCO0FBQWhCQSxNQUFBQSxRQUFnQixHQUFMLEVBQUs7QUFBQTs7QUFDM0IsU0FBS0MsSUFBTCxHQUFZLEVBQVo7O0FBQ0EsUUFBSUMsT0FBTyxDQUFDQyxHQUFSLENBQVlDLFFBQVosS0FBeUIsWUFBN0IsRUFBMkM7QUFDekMsVUFBSSxPQUFPSixRQUFQLEtBQW9CLFFBQXBCLElBQWdDLE9BQU9BLFFBQVAsS0FBb0IsV0FBeEQsRUFBcUU7QUFDbkUsY0FBTSxJQUFJSyxLQUFKLENBQ0osbURBQ0FDLElBQUksQ0FBQ0MsU0FBTCxDQUFlUCxRQUFmLENBRkksQ0FBTjtBQUlEO0FBQ0Y7O0FBQ0QsU0FBSyxJQUFJUSxJQUFULElBQWlCUixRQUFqQixFQUEyQjtBQUN6QixXQUFLUSxJQUFMLElBQWFSLFFBQVEsQ0FBQ1EsSUFBRCxDQUFyQjtBQUNEO0FBQ0Y7QUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O1NBZ0NBQyxLLEdBQUEsZUFBT0MsT0FBUCxFQUFnQkMsSUFBaEIsRUFBNEI7QUFBQSxRQUFaQSxJQUFZO0FBQVpBLE1BQUFBLElBQVksR0FBTCxFQUFLO0FBQUE7O0FBQzFCLFFBQUksS0FBS0MsTUFBVCxFQUFpQjtBQUNmLFVBQUlDLEdBQUcsR0FBRyxLQUFLQyxVQUFMLENBQWdCSCxJQUFoQixDQUFWO0FBQ0EsYUFBTyxLQUFLQyxNQUFMLENBQVlHLEtBQVosQ0FBa0JOLEtBQWxCLENBQXdCQyxPQUF4QixFQUFpQ0csR0FBRyxDQUFDRyxJQUFyQyxFQUEyQ0gsR0FBRyxDQUFDSSxNQUEvQyxFQUF1RE4sSUFBdkQsQ0FBUDtBQUNEOztBQUNELFdBQU8sSUFBSU8sdUJBQUosQ0FBbUJSLE9BQW5CLENBQVA7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7U0F5QkFTLEksR0FBQSxjQUFNQyxNQUFOLEVBQWNDLElBQWQsRUFBb0JWLElBQXBCLEVBQTBCO0FBQ3hCLFFBQUlXLElBQUksR0FBRztBQUFFQyxNQUFBQSxJQUFJLEVBQUU7QUFBUixLQUFYOztBQUNBLFNBQUssSUFBSS9CLENBQVQsSUFBY21CLElBQWQ7QUFBb0JXLE1BQUFBLElBQUksQ0FBQzlCLENBQUQsQ0FBSixHQUFVbUIsSUFBSSxDQUFDbkIsQ0FBRCxDQUFkO0FBQXBCOztBQUNBLFdBQU80QixNQUFNLENBQUNELElBQVAsQ0FBWUUsSUFBWixFQUFrQkMsSUFBbEIsQ0FBUDtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7U0FXQUUsTSxHQUFBLGtCQUFVO0FBQ1IsUUFBSSxLQUFLbkMsTUFBVCxFQUFpQjtBQUNmLFdBQUtBLE1BQUwsQ0FBWW9DLFdBQVosQ0FBd0IsSUFBeEI7QUFDRDs7QUFDRCxTQUFLcEMsTUFBTCxHQUFjcUMsU0FBZDtBQUNBLFdBQU8sSUFBUDtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7U0FXQUMsUSxHQUFBLGtCQUFVQyxXQUFWLEVBQW1DO0FBQUEsUUFBekJBLFdBQXlCO0FBQXpCQSxNQUFBQSxXQUF5QixHQUFYckIsa0JBQVc7QUFBQTs7QUFDakMsUUFBSXFCLFdBQVcsQ0FBQ3JCLFNBQWhCLEVBQTJCcUIsV0FBVyxHQUFHQSxXQUFXLENBQUNyQixTQUExQjtBQUMzQixRQUFJYSxNQUFNLEdBQUcsRUFBYjtBQUNBUSxJQUFBQSxXQUFXLENBQUMsSUFBRCxFQUFPLFVBQUFwQyxDQUFDLEVBQUk7QUFDckI0QixNQUFBQSxNQUFNLElBQUk1QixDQUFWO0FBQ0QsS0FGVSxDQUFYO0FBR0EsV0FBTzRCLE1BQVA7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7U0FnQkFTLEssR0FBQSxlQUFPQyxTQUFQLEVBQXdCO0FBQUEsUUFBakJBLFNBQWlCO0FBQWpCQSxNQUFBQSxTQUFpQixHQUFMLEVBQUs7QUFBQTs7QUFDdEIsUUFBSXhDLE1BQU0sR0FBR0gsU0FBUyxDQUFDLElBQUQsQ0FBdEI7O0FBQ0EsU0FBSyxJQUFJcUIsSUFBVCxJQUFpQnNCLFNBQWpCLEVBQTRCO0FBQzFCeEMsTUFBQUEsTUFBTSxDQUFDa0IsSUFBRCxDQUFOLEdBQWVzQixTQUFTLENBQUN0QixJQUFELENBQXhCO0FBQ0Q7O0FBQ0QsV0FBT2xCLE1BQVA7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs7O1NBV0F5QyxXLEdBQUEscUJBQWFELFNBQWIsRUFBOEI7QUFBQSxRQUFqQkEsU0FBaUI7QUFBakJBLE1BQUFBLFNBQWlCLEdBQUwsRUFBSztBQUFBOztBQUM1QixRQUFJeEMsTUFBTSxHQUFHLEtBQUt1QyxLQUFMLENBQVdDLFNBQVgsQ0FBYjtBQUNBLFNBQUt6QyxNQUFMLENBQVkyQyxZQUFaLENBQXlCLElBQXpCLEVBQStCMUMsTUFBL0I7QUFDQSxXQUFPQSxNQUFQO0FBQ0Q7QUFFRDs7Ozs7Ozs7OztTQVFBMkMsVSxHQUFBLG9CQUFZSCxTQUFaLEVBQTZCO0FBQUEsUUFBakJBLFNBQWlCO0FBQWpCQSxNQUFBQSxTQUFpQixHQUFMLEVBQUs7QUFBQTs7QUFDM0IsUUFBSXhDLE1BQU0sR0FBRyxLQUFLdUMsS0FBTCxDQUFXQyxTQUFYLENBQWI7QUFDQSxTQUFLekMsTUFBTCxDQUFZNkMsV0FBWixDQUF3QixJQUF4QixFQUE4QjVDLE1BQTlCO0FBQ0EsV0FBT0EsTUFBUDtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7O1NBWUE2QyxXLEdBQUEsdUJBQXVCO0FBQ3JCLFFBQUksS0FBSzlDLE1BQVQsRUFBaUI7QUFBQSx3Q0FESCtDLEtBQ0c7QUFESEEsUUFBQUEsS0FDRztBQUFBOztBQUNmLGdDQUFpQkEsS0FBakIsNEJBQXdCO0FBQW5CLFlBQUliLElBQUksYUFBUjtBQUNILGFBQUtsQyxNQUFMLENBQVkyQyxZQUFaLENBQXlCLElBQXpCLEVBQStCVCxJQUEvQjtBQUNEOztBQUVELFdBQUtDLE1BQUw7QUFDRDs7QUFFRCxXQUFPLElBQVA7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs7Ozs7O1NBY0FhLEksR0FBQSxnQkFBUTtBQUNOLFFBQUksQ0FBQyxLQUFLaEQsTUFBVixFQUFrQixPQUFPcUMsU0FBUDtBQUNsQixRQUFJWSxLQUFLLEdBQUcsS0FBS2pELE1BQUwsQ0FBWWlELEtBQVosQ0FBa0IsSUFBbEIsQ0FBWjtBQUNBLFdBQU8sS0FBS2pELE1BQUwsQ0FBWStDLEtBQVosQ0FBa0JFLEtBQUssR0FBRyxDQUExQixDQUFQO0FBQ0Q7QUFFRDs7Ozs7Ozs7Ozs7Ozs7U0FZQUMsSSxHQUFBLGdCQUFRO0FBQ04sUUFBSSxDQUFDLEtBQUtsRCxNQUFWLEVBQWtCLE9BQU9xQyxTQUFQO0FBQ2xCLFFBQUlZLEtBQUssR0FBRyxLQUFLakQsTUFBTCxDQUFZaUQsS0FBWixDQUFrQixJQUFsQixDQUFaO0FBQ0EsV0FBTyxLQUFLakQsTUFBTCxDQUFZK0MsS0FBWixDQUFrQkUsS0FBSyxHQUFHLENBQTFCLENBQVA7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs7OztTQVlBRSxNLEdBQUEsZ0JBQVFDLEdBQVIsRUFBYTtBQUNYLFNBQUtwRCxNQUFMLENBQVkyQyxZQUFaLENBQXlCLElBQXpCLEVBQStCUyxHQUEvQjtBQUNBLFdBQU8sSUFBUDtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7O1NBWUFDLEssR0FBQSxlQUFPRCxHQUFQLEVBQVk7QUFDVixTQUFLcEQsTUFBTCxDQUFZNkMsV0FBWixDQUF3QixJQUF4QixFQUE4Qk8sR0FBOUI7QUFDQSxXQUFPLElBQVA7QUFDRCxHOztTQUVERSxNLEdBQUEsa0JBQVU7QUFDUixRQUFJQyxLQUFLLEdBQUcsRUFBWjs7QUFFQSxTQUFLLElBQUlwQyxJQUFULElBQWlCLElBQWpCLEVBQXVCO0FBQ3JCLFVBQUksQ0FBQyxLQUFLZixjQUFMLENBQW9CZSxJQUFwQixDQUFMLEVBQWdDO0FBQ2hDLFVBQUlBLElBQUksS0FBSyxRQUFiLEVBQXVCO0FBQ3ZCLFVBQUlkLEtBQUssR0FBRyxLQUFLYyxJQUFMLENBQVo7O0FBRUEsVUFBSWQsS0FBSyxZQUFZRSxLQUFyQixFQUE0QjtBQUMxQmdELFFBQUFBLEtBQUssQ0FBQ3BDLElBQUQsQ0FBTCxHQUFjZCxLQUFLLENBQUNHLEdBQU4sQ0FBVSxVQUFBTCxDQUFDLEVBQUk7QUFDM0IsY0FBSSxPQUFPQSxDQUFQLEtBQWEsUUFBYixJQUF5QkEsQ0FBQyxDQUFDbUQsTUFBL0IsRUFBdUM7QUFDckMsbUJBQU9uRCxDQUFDLENBQUNtRCxNQUFGLEVBQVA7QUFDRCxXQUZELE1BRU87QUFDTCxtQkFBT25ELENBQVA7QUFDRDtBQUNGLFNBTmEsQ0FBZDtBQU9ELE9BUkQsTUFRTyxJQUFJLE9BQU9FLEtBQVAsS0FBaUIsUUFBakIsSUFBNkJBLEtBQUssQ0FBQ2lELE1BQXZDLEVBQStDO0FBQ3BEQyxRQUFBQSxLQUFLLENBQUNwQyxJQUFELENBQUwsR0FBY2QsS0FBSyxDQUFDaUQsTUFBTixFQUFkO0FBQ0QsT0FGTSxNQUVBO0FBQ0xDLFFBQUFBLEtBQUssQ0FBQ3BDLElBQUQsQ0FBTCxHQUFjZCxLQUFkO0FBQ0Q7QUFDRjs7QUFFRCxXQUFPa0QsS0FBUDtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O1NBa0JBQyxHLEdBQUEsYUFBS0MsSUFBTCxFQUFXQyxXQUFYLEVBQXdCO0FBQ3RCLFFBQUlDLEdBQUcsR0FBRyxJQUFJQyxvQkFBSixFQUFWO0FBQ0EsV0FBT0QsR0FBRyxDQUFDSCxHQUFKLENBQVEsSUFBUixFQUFjQyxJQUFkLEVBQW9CQyxXQUFwQixDQUFQO0FBQ0Q7QUFFRDs7Ozs7Ozs7OztTQVFBRyxJLEdBQUEsZ0JBQVE7QUFDTixRQUFJOUIsTUFBTSxHQUFHLElBQWI7O0FBQ0EsV0FBT0EsTUFBTSxDQUFDL0IsTUFBZDtBQUFzQitCLE1BQUFBLE1BQU0sR0FBR0EsTUFBTSxDQUFDL0IsTUFBaEI7QUFBdEI7O0FBQ0EsV0FBTytCLE1BQVA7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs7OztTQVlBK0IsUyxHQUFBLG1CQUFXQyxXQUFYLEVBQXdCO0FBQ3RCLFdBQU8sS0FBS25ELElBQUwsQ0FBVXVDLE1BQWpCO0FBQ0EsV0FBTyxLQUFLdkMsSUFBTCxDQUFVeUMsS0FBakI7QUFDQSxRQUFJLENBQUNVLFdBQUwsRUFBa0IsT0FBTyxLQUFLbkQsSUFBTCxDQUFVb0QsT0FBakI7QUFDbkIsRzs7U0FFREMsYyxHQUFBLHdCQUFnQmhCLEtBQWhCLEVBQXVCO0FBQ3JCLFFBQUlpQixNQUFNLEdBQUcsS0FBSzVCLFFBQUwsRUFBYjtBQUNBLFFBQUlWLE1BQU0sR0FBRyxLQUFLTCxNQUFMLENBQVk0QyxLQUFaLENBQWtCdkMsTUFBL0I7QUFDQSxRQUFJRCxJQUFJLEdBQUcsS0FBS0osTUFBTCxDQUFZNEMsS0FBWixDQUFrQnhDLElBQTdCOztBQUVBLFNBQUssSUFBSXhCLENBQUMsR0FBRyxDQUFiLEVBQWdCQSxDQUFDLEdBQUc4QyxLQUFwQixFQUEyQjlDLENBQUMsRUFBNUIsRUFBZ0M7QUFDOUIsVUFBSStELE1BQU0sQ0FBQy9ELENBQUQsQ0FBTixLQUFjLElBQWxCLEVBQXdCO0FBQ3RCeUIsUUFBQUEsTUFBTSxHQUFHLENBQVQ7QUFDQUQsUUFBQUEsSUFBSSxJQUFJLENBQVI7QUFDRCxPQUhELE1BR087QUFDTEMsUUFBQUEsTUFBTSxJQUFJLENBQVY7QUFDRDtBQUNGOztBQUVELFdBQU87QUFBRUQsTUFBQUEsSUFBSSxFQUFKQSxJQUFGO0FBQVFDLE1BQUFBLE1BQU0sRUFBTkE7QUFBUixLQUFQO0FBQ0QsRzs7U0FFREgsVSxHQUFBLG9CQUFZSCxJQUFaLEVBQWtCO0FBQ2hCLFFBQUlFLEdBQUcsR0FBRyxLQUFLRCxNQUFMLENBQVk0QyxLQUF0Qjs7QUFDQSxRQUFJN0MsSUFBSSxDQUFDMkIsS0FBVCxFQUFnQjtBQUNkekIsTUFBQUEsR0FBRyxHQUFHLEtBQUt5QyxjQUFMLENBQW9CM0MsSUFBSSxDQUFDMkIsS0FBekIsQ0FBTjtBQUNELEtBRkQsTUFFTyxJQUFJM0IsSUFBSSxDQUFDOEMsSUFBVCxFQUFlO0FBQ3BCLFVBQUluQixLQUFLLEdBQUcsS0FBS1gsUUFBTCxHQUFnQitCLE9BQWhCLENBQXdCL0MsSUFBSSxDQUFDOEMsSUFBN0IsQ0FBWjtBQUNBLFVBQUluQixLQUFLLEtBQUssQ0FBQyxDQUFmLEVBQWtCekIsR0FBRyxHQUFHLEtBQUt5QyxjQUFMLENBQW9CaEIsS0FBcEIsQ0FBTjtBQUNuQjs7QUFDRCxXQUFPekIsR0FBUDtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7QUFVQTs7Ozs7Ozs7QUFRQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQXFDQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7ZUFtQ2FkLEk7QUFFZjs7Ozs7O0FBTUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQ3NzU3ludGF4RXJyb3IgZnJvbSAnLi9jc3Mtc3ludGF4LWVycm9yJ1xuaW1wb3J0IFN0cmluZ2lmaWVyIGZyb20gJy4vc3RyaW5naWZpZXInXG5pbXBvcnQgc3RyaW5naWZ5IGZyb20gJy4vc3RyaW5naWZ5J1xuXG5mdW5jdGlvbiBjbG9uZU5vZGUgKG9iaiwgcGFyZW50KSB7XG4gIGxldCBjbG9uZWQgPSBuZXcgb2JqLmNvbnN0cnVjdG9yKClcblxuICBmb3IgKGxldCBpIGluIG9iaikge1xuICAgIGlmICghb2JqLmhhc093blByb3BlcnR5KGkpKSBjb250aW51ZVxuICAgIGxldCB2YWx1ZSA9IG9ialtpXVxuICAgIGxldCB0eXBlID0gdHlwZW9mIHZhbHVlXG5cbiAgICBpZiAoaSA9PT0gJ3BhcmVudCcgJiYgdHlwZSA9PT0gJ29iamVjdCcpIHtcbiAgICAgIGlmIChwYXJlbnQpIGNsb25lZFtpXSA9IHBhcmVudFxuICAgIH0gZWxzZSBpZiAoaSA9PT0gJ3NvdXJjZScpIHtcbiAgICAgIGNsb25lZFtpXSA9IHZhbHVlXG4gICAgfSBlbHNlIGlmICh2YWx1ZSBpbnN0YW5jZW9mIEFycmF5KSB7XG4gICAgICBjbG9uZWRbaV0gPSB2YWx1ZS5tYXAoaiA9PiBjbG9uZU5vZGUoaiwgY2xvbmVkKSlcbiAgICB9IGVsc2Uge1xuICAgICAgaWYgKHR5cGUgPT09ICdvYmplY3QnICYmIHZhbHVlICE9PSBudWxsKSB2YWx1ZSA9IGNsb25lTm9kZSh2YWx1ZSlcbiAgICAgIGNsb25lZFtpXSA9IHZhbHVlXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGNsb25lZFxufVxuXG4vKipcbiAqIEFsbCBub2RlIGNsYXNzZXMgaW5oZXJpdCB0aGUgZm9sbG93aW5nIGNvbW1vbiBtZXRob2RzLlxuICpcbiAqIEBhYnN0cmFjdFxuICovXG5jbGFzcyBOb2RlIHtcbiAgLyoqXG4gICAqIEBwYXJhbSB7b2JqZWN0fSBbZGVmYXVsdHNdIFZhbHVlIGZvciBub2RlIHByb3BlcnRpZXMuXG4gICAqL1xuICBjb25zdHJ1Y3RvciAoZGVmYXVsdHMgPSB7IH0pIHtcbiAgICB0aGlzLnJhd3MgPSB7IH1cbiAgICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJykge1xuICAgICAgaWYgKHR5cGVvZiBkZWZhdWx0cyAhPT0gJ29iamVjdCcgJiYgdHlwZW9mIGRlZmF1bHRzICE9PSAndW5kZWZpbmVkJykge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICAgJ1Bvc3RDU1Mgbm9kZXMgY29uc3RydWN0b3IgYWNjZXB0cyBvYmplY3QsIG5vdCAnICtcbiAgICAgICAgICBKU09OLnN0cmluZ2lmeShkZWZhdWx0cylcbiAgICAgICAgKVxuICAgICAgfVxuICAgIH1cbiAgICBmb3IgKGxldCBuYW1lIGluIGRlZmF1bHRzKSB7XG4gICAgICB0aGlzW25hbWVdID0gZGVmYXVsdHNbbmFtZV1cbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyBhIGBDc3NTeW50YXhFcnJvcmAgaW5zdGFuY2UgY29udGFpbmluZyB0aGUgb3JpZ2luYWwgcG9zaXRpb25cbiAgICogb2YgdGhlIG5vZGUgaW4gdGhlIHNvdXJjZSwgc2hvd2luZyBsaW5lIGFuZCBjb2x1bW4gbnVtYmVycyBhbmQgYWxzb1xuICAgKiBhIHNtYWxsIGV4Y2VycHQgdG8gZmFjaWxpdGF0ZSBkZWJ1Z2dpbmcuXG4gICAqXG4gICAqIElmIHByZXNlbnQsIGFuIGlucHV0IHNvdXJjZSBtYXAgd2lsbCBiZSB1c2VkIHRvIGdldCB0aGUgb3JpZ2luYWwgcG9zaXRpb25cbiAgICogb2YgdGhlIHNvdXJjZSwgZXZlbiBmcm9tIGEgcHJldmlvdXMgY29tcGlsYXRpb24gc3RlcFxuICAgKiAoZS5nLiwgZnJvbSBTYXNzIGNvbXBpbGF0aW9uKS5cbiAgICpcbiAgICogVGhpcyBtZXRob2QgcHJvZHVjZXMgdmVyeSB1c2VmdWwgZXJyb3IgbWVzc2FnZXMuXG4gICAqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBtZXNzYWdlICAgICBFcnJvciBkZXNjcmlwdGlvbi5cbiAgICogQHBhcmFtIHtvYmplY3R9IFtvcHRzXSAgICAgIE9wdGlvbnMuXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBvcHRzLnBsdWdpbiBQbHVnaW4gbmFtZSB0aGF0IGNyZWF0ZWQgdGhpcyBlcnJvci5cbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgIFBvc3RDU1Mgd2lsbCBzZXQgaXQgYXV0b21hdGljYWxseS5cbiAgICogQHBhcmFtIHtzdHJpbmd9IG9wdHMud29yZCAgIEEgd29yZCBpbnNpZGUgYSBub2Rl4oCZcyBzdHJpbmcgdGhhdCBzaG91bGRcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJlIGhpZ2hsaWdodGVkIGFzIHRoZSBzb3VyY2Ugb2YgdGhlIGVycm9yLlxuICAgKiBAcGFyYW0ge251bWJlcn0gb3B0cy5pbmRleCAgQW4gaW5kZXggaW5zaWRlIGEgbm9kZeKAmXMgc3RyaW5nIHRoYXQgc2hvdWxkXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiZSBoaWdobGlnaHRlZCBhcyB0aGUgc291cmNlIG9mIHRoZSBlcnJvci5cbiAgICpcbiAgICogQHJldHVybiB7Q3NzU3ludGF4RXJyb3J9IEVycm9yIG9iamVjdCB0byB0aHJvdyBpdC5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogaWYgKCF2YXJpYWJsZXNbbmFtZV0pIHtcbiAgICogICB0aHJvdyBkZWNsLmVycm9yKCdVbmtub3duIHZhcmlhYmxlICcgKyBuYW1lLCB7IHdvcmQ6IG5hbWUgfSlcbiAgICogICAvLyBDc3NTeW50YXhFcnJvcjogcG9zdGNzcy12YXJzOmEuc2Fzczo0OjM6IFVua25vd24gdmFyaWFibGUgJGJsYWNrXG4gICAqICAgLy8gICBjb2xvcjogJGJsYWNrXG4gICAqICAgLy8gYVxuICAgKiAgIC8vICAgICAgICAgIF5cbiAgICogICAvLyAgIGJhY2tncm91bmQ6IHdoaXRlXG4gICAqIH1cbiAgICovXG4gIGVycm9yIChtZXNzYWdlLCBvcHRzID0geyB9KSB7XG4gICAgaWYgKHRoaXMuc291cmNlKSB7XG4gICAgICBsZXQgcG9zID0gdGhpcy5wb3NpdGlvbkJ5KG9wdHMpXG4gICAgICByZXR1cm4gdGhpcy5zb3VyY2UuaW5wdXQuZXJyb3IobWVzc2FnZSwgcG9zLmxpbmUsIHBvcy5jb2x1bW4sIG9wdHMpXG4gICAgfVxuICAgIHJldHVybiBuZXcgQ3NzU3ludGF4RXJyb3IobWVzc2FnZSlcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGlzIG1ldGhvZCBpcyBwcm92aWRlZCBhcyBhIGNvbnZlbmllbmNlIHdyYXBwZXIgZm9yIHtAbGluayBSZXN1bHQjd2Fybn0uXG4gICAqXG4gICAqIEBwYXJhbSB7UmVzdWx0fSByZXN1bHQgICAgICBUaGUge0BsaW5rIFJlc3VsdH0gaW5zdGFuY2VcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoYXQgd2lsbCByZWNlaXZlIHRoZSB3YXJuaW5nLlxuICAgKiBAcGFyYW0ge3N0cmluZ30gdGV4dCAgICAgICAgV2FybmluZyBtZXNzYWdlLlxuICAgKiBAcGFyYW0ge29iamVjdH0gW29wdHNdICAgICAgT3B0aW9uc1xuICAgKiBAcGFyYW0ge3N0cmluZ30gb3B0cy5wbHVnaW4gUGx1Z2luIG5hbWUgdGhhdCBjcmVhdGVkIHRoaXMgd2FybmluZy5cbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgIFBvc3RDU1Mgd2lsbCBzZXQgaXQgYXV0b21hdGljYWxseS5cbiAgICogQHBhcmFtIHtzdHJpbmd9IG9wdHMud29yZCAgIEEgd29yZCBpbnNpZGUgYSBub2Rl4oCZcyBzdHJpbmcgdGhhdCBzaG91bGRcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJlIGhpZ2hsaWdodGVkIGFzIHRoZSBzb3VyY2Ugb2YgdGhlIHdhcm5pbmcuXG4gICAqIEBwYXJhbSB7bnVtYmVyfSBvcHRzLmluZGV4ICBBbiBpbmRleCBpbnNpZGUgYSBub2Rl4oCZcyBzdHJpbmcgdGhhdCBzaG91bGRcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJlIGhpZ2hsaWdodGVkIGFzIHRoZSBzb3VyY2Ugb2YgdGhlIHdhcm5pbmcuXG4gICAqXG4gICAqIEByZXR1cm4ge1dhcm5pbmd9IENyZWF0ZWQgd2FybmluZyBvYmplY3QuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGNvbnN0IHBsdWdpbiA9IHBvc3Rjc3MucGx1Z2luKCdwb3N0Y3NzLWRlcHJlY2F0ZWQnLCAoKSA9PiB7XG4gICAqICAgcmV0dXJuIChyb290LCByZXN1bHQpID0+IHtcbiAgICogICAgIHJvb3Qud2Fsa0RlY2xzKCdiYWQnLCBkZWNsID0+IHtcbiAgICogICAgICAgZGVjbC53YXJuKHJlc3VsdCwgJ0RlcHJlY2F0ZWQgcHJvcGVydHkgYmFkJylcbiAgICogICAgIH0pXG4gICAqICAgfVxuICAgKiB9KVxuICAgKi9cbiAgd2FybiAocmVzdWx0LCB0ZXh0LCBvcHRzKSB7XG4gICAgbGV0IGRhdGEgPSB7IG5vZGU6IHRoaXMgfVxuICAgIGZvciAobGV0IGkgaW4gb3B0cykgZGF0YVtpXSA9IG9wdHNbaV1cbiAgICByZXR1cm4gcmVzdWx0Lndhcm4odGV4dCwgZGF0YSlcbiAgfVxuXG4gIC8qKlxuICAgKiBSZW1vdmVzIHRoZSBub2RlIGZyb20gaXRzIHBhcmVudCBhbmQgY2xlYW5zIHRoZSBwYXJlbnQgcHJvcGVydGllc1xuICAgKiBmcm9tIHRoZSBub2RlIGFuZCBpdHMgY2hpbGRyZW4uXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGlmIChkZWNsLnByb3AubWF0Y2goL14td2Via2l0LS8pKSB7XG4gICAqICAgZGVjbC5yZW1vdmUoKVxuICAgKiB9XG4gICAqXG4gICAqIEByZXR1cm4ge05vZGV9IE5vZGUgdG8gbWFrZSBjYWxscyBjaGFpbi5cbiAgICovXG4gIHJlbW92ZSAoKSB7XG4gICAgaWYgKHRoaXMucGFyZW50KSB7XG4gICAgICB0aGlzLnBhcmVudC5yZW1vdmVDaGlsZCh0aGlzKVxuICAgIH1cbiAgICB0aGlzLnBhcmVudCA9IHVuZGVmaW5lZFxuICAgIHJldHVybiB0aGlzXG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyBhIENTUyBzdHJpbmcgcmVwcmVzZW50aW5nIHRoZSBub2RlLlxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ2lmaWVyfHN5bnRheH0gW3N0cmluZ2lmaWVyXSBBIHN5bnRheCB0byB1c2VcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaW4gc3RyaW5nIGdlbmVyYXRpb24uXG4gICAqXG4gICAqIEByZXR1cm4ge3N0cmluZ30gQ1NTIHN0cmluZyBvZiB0aGlzIG5vZGUuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIHBvc3Rjc3MucnVsZSh7IHNlbGVjdG9yOiAnYScgfSkudG9TdHJpbmcoKSAvLz0+IFwiYSB7fVwiXG4gICAqL1xuICB0b1N0cmluZyAoc3RyaW5naWZpZXIgPSBzdHJpbmdpZnkpIHtcbiAgICBpZiAoc3RyaW5naWZpZXIuc3RyaW5naWZ5KSBzdHJpbmdpZmllciA9IHN0cmluZ2lmaWVyLnN0cmluZ2lmeVxuICAgIGxldCByZXN1bHQgPSAnJ1xuICAgIHN0cmluZ2lmaWVyKHRoaXMsIGkgPT4ge1xuICAgICAgcmVzdWx0ICs9IGlcbiAgICB9KVxuICAgIHJldHVybiByZXN1bHRcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGFuIGV4YWN0IGNsb25lIG9mIHRoZSBub2RlLlxuICAgKlxuICAgKiBUaGUgcmVzdWx0aW5nIGNsb25lZCBub2RlIGFuZCBpdHMgKGNsb25lZCkgY2hpbGRyZW4gd2lsbCByZXRhaW5cbiAgICogY29kZSBzdHlsZSBwcm9wZXJ0aWVzLlxuICAgKlxuICAgKiBAcGFyYW0ge29iamVjdH0gW292ZXJyaWRlc10gTmV3IHByb3BlcnRpZXMgdG8gb3ZlcnJpZGUgaW4gdGhlIGNsb25lLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBkZWNsLnJhd3MuYmVmb3JlICAgIC8vPT4gXCJcXG4gIFwiXG4gICAqIGNvbnN0IGNsb25lZCA9IGRlY2wuY2xvbmUoeyBwcm9wOiAnLW1vei0nICsgZGVjbC5wcm9wIH0pXG4gICAqIGNsb25lZC5yYXdzLmJlZm9yZSAgLy89PiBcIlxcbiAgXCJcbiAgICogY2xvbmVkLnRvU3RyaW5nKCkgICAvLz0+IC1tb3otdHJhbnNmb3JtOiBzY2FsZSgwKVxuICAgKlxuICAgKiBAcmV0dXJuIHtOb2RlfSBDbG9uZSBvZiB0aGUgbm9kZS5cbiAgICovXG4gIGNsb25lIChvdmVycmlkZXMgPSB7IH0pIHtcbiAgICBsZXQgY2xvbmVkID0gY2xvbmVOb2RlKHRoaXMpXG4gICAgZm9yIChsZXQgbmFtZSBpbiBvdmVycmlkZXMpIHtcbiAgICAgIGNsb25lZFtuYW1lXSA9IG92ZXJyaWRlc1tuYW1lXVxuICAgIH1cbiAgICByZXR1cm4gY2xvbmVkXG4gIH1cblxuICAvKipcbiAgICogU2hvcnRjdXQgdG8gY2xvbmUgdGhlIG5vZGUgYW5kIGluc2VydCB0aGUgcmVzdWx0aW5nIGNsb25lZCBub2RlXG4gICAqIGJlZm9yZSB0aGUgY3VycmVudCBub2RlLlxuICAgKlxuICAgKiBAcGFyYW0ge29iamVjdH0gW292ZXJyaWRlc10gTWV3IHByb3BlcnRpZXMgdG8gb3ZlcnJpZGUgaW4gdGhlIGNsb25lLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBkZWNsLmNsb25lQmVmb3JlKHsgcHJvcDogJy1tb3otJyArIGRlY2wucHJvcCB9KVxuICAgKlxuICAgKiBAcmV0dXJuIHtOb2RlfSBOZXcgbm9kZVxuICAgKi9cbiAgY2xvbmVCZWZvcmUgKG92ZXJyaWRlcyA9IHsgfSkge1xuICAgIGxldCBjbG9uZWQgPSB0aGlzLmNsb25lKG92ZXJyaWRlcylcbiAgICB0aGlzLnBhcmVudC5pbnNlcnRCZWZvcmUodGhpcywgY2xvbmVkKVxuICAgIHJldHVybiBjbG9uZWRcbiAgfVxuXG4gIC8qKlxuICAgKiBTaG9ydGN1dCB0byBjbG9uZSB0aGUgbm9kZSBhbmQgaW5zZXJ0IHRoZSByZXN1bHRpbmcgY2xvbmVkIG5vZGVcbiAgICogYWZ0ZXIgdGhlIGN1cnJlbnQgbm9kZS5cbiAgICpcbiAgICogQHBhcmFtIHtvYmplY3R9IFtvdmVycmlkZXNdIE5ldyBwcm9wZXJ0aWVzIHRvIG92ZXJyaWRlIGluIHRoZSBjbG9uZS5cbiAgICpcbiAgICogQHJldHVybiB7Tm9kZX0gTmV3IG5vZGUuXG4gICAqL1xuICBjbG9uZUFmdGVyIChvdmVycmlkZXMgPSB7IH0pIHtcbiAgICBsZXQgY2xvbmVkID0gdGhpcy5jbG9uZShvdmVycmlkZXMpXG4gICAgdGhpcy5wYXJlbnQuaW5zZXJ0QWZ0ZXIodGhpcywgY2xvbmVkKVxuICAgIHJldHVybiBjbG9uZWRcbiAgfVxuXG4gIC8qKlxuICAgKiBJbnNlcnRzIG5vZGUocykgYmVmb3JlIHRoZSBjdXJyZW50IG5vZGUgYW5kIHJlbW92ZXMgdGhlIGN1cnJlbnQgbm9kZS5cbiAgICpcbiAgICogQHBhcmFtIHsuLi5Ob2RlfSBub2RlcyBNb2RlKHMpIHRvIHJlcGxhY2UgY3VycmVudCBvbmUuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGlmIChhdHJ1bGUubmFtZSA9PT0gJ21peGluJykge1xuICAgKiAgIGF0cnVsZS5yZXBsYWNlV2l0aChtaXhpblJ1bGVzW2F0cnVsZS5wYXJhbXNdKVxuICAgKiB9XG4gICAqXG4gICAqIEByZXR1cm4ge05vZGV9IEN1cnJlbnQgbm9kZSB0byBtZXRob2RzIGNoYWluLlxuICAgKi9cbiAgcmVwbGFjZVdpdGggKC4uLm5vZGVzKSB7XG4gICAgaWYgKHRoaXMucGFyZW50KSB7XG4gICAgICBmb3IgKGxldCBub2RlIG9mIG5vZGVzKSB7XG4gICAgICAgIHRoaXMucGFyZW50Lmluc2VydEJlZm9yZSh0aGlzLCBub2RlKVxuICAgICAgfVxuXG4gICAgICB0aGlzLnJlbW92ZSgpXG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXNcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBuZXh0IGNoaWxkIG9mIHRoZSBub2Rl4oCZcyBwYXJlbnQuXG4gICAqIFJldHVybnMgYHVuZGVmaW5lZGAgaWYgdGhlIGN1cnJlbnQgbm9kZSBpcyB0aGUgbGFzdCBjaGlsZC5cbiAgICpcbiAgICogQHJldHVybiB7Tm9kZXx1bmRlZmluZWR9IE5leHQgbm9kZS5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogaWYgKGNvbW1lbnQudGV4dCA9PT0gJ2RlbGV0ZSBuZXh0Jykge1xuICAgKiAgIGNvbnN0IG5leHQgPSBjb21tZW50Lm5leHQoKVxuICAgKiAgIGlmIChuZXh0KSB7XG4gICAqICAgICBuZXh0LnJlbW92ZSgpXG4gICAqICAgfVxuICAgKiB9XG4gICAqL1xuICBuZXh0ICgpIHtcbiAgICBpZiAoIXRoaXMucGFyZW50KSByZXR1cm4gdW5kZWZpbmVkXG4gICAgbGV0IGluZGV4ID0gdGhpcy5wYXJlbnQuaW5kZXgodGhpcylcbiAgICByZXR1cm4gdGhpcy5wYXJlbnQubm9kZXNbaW5kZXggKyAxXVxuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIHByZXZpb3VzIGNoaWxkIG9mIHRoZSBub2Rl4oCZcyBwYXJlbnQuXG4gICAqIFJldHVybnMgYHVuZGVmaW5lZGAgaWYgdGhlIGN1cnJlbnQgbm9kZSBpcyB0aGUgZmlyc3QgY2hpbGQuXG4gICAqXG4gICAqIEByZXR1cm4ge05vZGV8dW5kZWZpbmVkfSBQcmV2aW91cyBub2RlLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBjb25zdCBhbm5vdGF0aW9uID0gZGVjbC5wcmV2KClcbiAgICogaWYgKGFubm90YXRpb24udHlwZSA9PT0gJ2NvbW1lbnQnKSB7XG4gICAqICAgcmVhZEFubm90YXRpb24oYW5ub3RhdGlvbi50ZXh0KVxuICAgKiB9XG4gICAqL1xuICBwcmV2ICgpIHtcbiAgICBpZiAoIXRoaXMucGFyZW50KSByZXR1cm4gdW5kZWZpbmVkXG4gICAgbGV0IGluZGV4ID0gdGhpcy5wYXJlbnQuaW5kZXgodGhpcylcbiAgICByZXR1cm4gdGhpcy5wYXJlbnQubm9kZXNbaW5kZXggLSAxXVxuICB9XG5cbiAgLyoqXG4gICAqIEluc2VydCBuZXcgbm9kZSBiZWZvcmUgY3VycmVudCBub2RlIHRvIGN1cnJlbnQgbm9kZeKAmXMgcGFyZW50LlxuICAgKlxuICAgKiBKdXN0IGFsaWFzIGZvciBgbm9kZS5wYXJlbnQuaW5zZXJ0QmVmb3JlKG5vZGUsIGFkZClgLlxuICAgKlxuICAgKiBAcGFyYW0ge05vZGV8b2JqZWN0fHN0cmluZ3xOb2RlW119IGFkZCBOZXcgbm9kZS5cbiAgICpcbiAgICogQHJldHVybiB7Tm9kZX0gVGhpcyBub2RlIGZvciBtZXRob2RzIGNoYWluLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBkZWNsLmJlZm9yZSgnY29udGVudDogXCJcIicpXG4gICAqL1xuICBiZWZvcmUgKGFkZCkge1xuICAgIHRoaXMucGFyZW50Lmluc2VydEJlZm9yZSh0aGlzLCBhZGQpXG4gICAgcmV0dXJuIHRoaXNcbiAgfVxuXG4gIC8qKlxuICAgKiBJbnNlcnQgbmV3IG5vZGUgYWZ0ZXIgY3VycmVudCBub2RlIHRvIGN1cnJlbnQgbm9kZeKAmXMgcGFyZW50LlxuICAgKlxuICAgKiBKdXN0IGFsaWFzIGZvciBgbm9kZS5wYXJlbnQuaW5zZXJ0QWZ0ZXIobm9kZSwgYWRkKWAuXG4gICAqXG4gICAqIEBwYXJhbSB7Tm9kZXxvYmplY3R8c3RyaW5nfE5vZGVbXX0gYWRkIE5ldyBub2RlLlxuICAgKlxuICAgKiBAcmV0dXJuIHtOb2RlfSBUaGlzIG5vZGUgZm9yIG1ldGhvZHMgY2hhaW4uXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGRlY2wuYWZ0ZXIoJ2NvbG9yOiBibGFjaycpXG4gICAqL1xuICBhZnRlciAoYWRkKSB7XG4gICAgdGhpcy5wYXJlbnQuaW5zZXJ0QWZ0ZXIodGhpcywgYWRkKVxuICAgIHJldHVybiB0aGlzXG4gIH1cblxuICB0b0pTT04gKCkge1xuICAgIGxldCBmaXhlZCA9IHsgfVxuXG4gICAgZm9yIChsZXQgbmFtZSBpbiB0aGlzKSB7XG4gICAgICBpZiAoIXRoaXMuaGFzT3duUHJvcGVydHkobmFtZSkpIGNvbnRpbnVlXG4gICAgICBpZiAobmFtZSA9PT0gJ3BhcmVudCcpIGNvbnRpbnVlXG4gICAgICBsZXQgdmFsdWUgPSB0aGlzW25hbWVdXG5cbiAgICAgIGlmICh2YWx1ZSBpbnN0YW5jZW9mIEFycmF5KSB7XG4gICAgICAgIGZpeGVkW25hbWVdID0gdmFsdWUubWFwKGkgPT4ge1xuICAgICAgICAgIGlmICh0eXBlb2YgaSA9PT0gJ29iamVjdCcgJiYgaS50b0pTT04pIHtcbiAgICAgICAgICAgIHJldHVybiBpLnRvSlNPTigpXG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiBpXG4gICAgICAgICAgfVxuICAgICAgICB9KVxuICAgICAgfSBlbHNlIGlmICh0eXBlb2YgdmFsdWUgPT09ICdvYmplY3QnICYmIHZhbHVlLnRvSlNPTikge1xuICAgICAgICBmaXhlZFtuYW1lXSA9IHZhbHVlLnRvSlNPTigpXG4gICAgICB9IGVsc2Uge1xuICAgICAgICBmaXhlZFtuYW1lXSA9IHZhbHVlXG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGZpeGVkXG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyBhIHtAbGluayBOb2RlI3Jhd3N9IHZhbHVlLiBJZiB0aGUgbm9kZSBpcyBtaXNzaW5nXG4gICAqIHRoZSBjb2RlIHN0eWxlIHByb3BlcnR5IChiZWNhdXNlIHRoZSBub2RlIHdhcyBtYW51YWxseSBidWlsdCBvciBjbG9uZWQpLFxuICAgKiBQb3N0Q1NTIHdpbGwgdHJ5IHRvIGF1dG9kZXRlY3QgdGhlIGNvZGUgc3R5bGUgcHJvcGVydHkgYnkgbG9va2luZ1xuICAgKiBhdCBvdGhlciBub2RlcyBpbiB0aGUgdHJlZS5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IHByb3AgICAgICAgICAgTmFtZSBvZiBjb2RlIHN0eWxlIHByb3BlcnR5LlxuICAgKiBAcGFyYW0ge3N0cmluZ30gW2RlZmF1bHRUeXBlXSBOYW1lIG9mIGRlZmF1bHQgdmFsdWUsIGl0IGNhbiBiZSBtaXNzZWRcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgdGhlIHZhbHVlIGlzIHRoZSBzYW1lIGFzIHByb3AuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGNvbnN0IHJvb3QgPSBwb3N0Y3NzLnBhcnNlKCdhIHsgYmFja2dyb3VuZDogd2hpdGUgfScpXG4gICAqIHJvb3Qubm9kZXNbMF0uYXBwZW5kKHsgcHJvcDogJ2NvbG9yJywgdmFsdWU6ICdibGFjaycgfSlcbiAgICogcm9vdC5ub2Rlc1swXS5ub2Rlc1sxXS5yYXdzLmJlZm9yZSAgIC8vPT4gdW5kZWZpbmVkXG4gICAqIHJvb3Qubm9kZXNbMF0ubm9kZXNbMV0ucmF3KCdiZWZvcmUnKSAvLz0+ICcgJ1xuICAgKlxuICAgKiBAcmV0dXJuIHtzdHJpbmd9IENvZGUgc3R5bGUgdmFsdWUuXG4gICAqL1xuICByYXcgKHByb3AsIGRlZmF1bHRUeXBlKSB7XG4gICAgbGV0IHN0ciA9IG5ldyBTdHJpbmdpZmllcigpXG4gICAgcmV0dXJuIHN0ci5yYXcodGhpcywgcHJvcCwgZGVmYXVsdFR5cGUpXG4gIH1cblxuICAvKipcbiAgICogRmluZHMgdGhlIFJvb3QgaW5zdGFuY2Ugb2YgdGhlIG5vZGXigJlzIHRyZWUuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIHJvb3Qubm9kZXNbMF0ubm9kZXNbMF0ucm9vdCgpID09PSByb290XG4gICAqXG4gICAqIEByZXR1cm4ge1Jvb3R9IFJvb3QgcGFyZW50LlxuICAgKi9cbiAgcm9vdCAoKSB7XG4gICAgbGV0IHJlc3VsdCA9IHRoaXNcbiAgICB3aGlsZSAocmVzdWx0LnBhcmVudCkgcmVzdWx0ID0gcmVzdWx0LnBhcmVudFxuICAgIHJldHVybiByZXN1bHRcbiAgfVxuXG4gIC8qKlxuICAgKiBDbGVhciB0aGUgY29kZSBzdHlsZSBwcm9wZXJ0aWVzIGZvciB0aGUgbm9kZSBhbmQgaXRzIGNoaWxkcmVuLlxuICAgKlxuICAgKiBAcGFyYW0ge2Jvb2xlYW59IFtrZWVwQmV0d2Vlbl0gS2VlcCB0aGUgcmF3cy5iZXR3ZWVuIHN5bWJvbHMuXG4gICAqXG4gICAqIEByZXR1cm4ge3VuZGVmaW5lZH1cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogbm9kZS5yYXdzLmJlZm9yZSAgLy89PiAnICdcbiAgICogbm9kZS5jbGVhblJhd3MoKVxuICAgKiBub2RlLnJhd3MuYmVmb3JlICAvLz0+IHVuZGVmaW5lZFxuICAgKi9cbiAgY2xlYW5SYXdzIChrZWVwQmV0d2Vlbikge1xuICAgIGRlbGV0ZSB0aGlzLnJhd3MuYmVmb3JlXG4gICAgZGVsZXRlIHRoaXMucmF3cy5hZnRlclxuICAgIGlmICgha2VlcEJldHdlZW4pIGRlbGV0ZSB0aGlzLnJhd3MuYmV0d2VlblxuICB9XG5cbiAgcG9zaXRpb25JbnNpZGUgKGluZGV4KSB7XG4gICAgbGV0IHN0cmluZyA9IHRoaXMudG9TdHJpbmcoKVxuICAgIGxldCBjb2x1bW4gPSB0aGlzLnNvdXJjZS5zdGFydC5jb2x1bW5cbiAgICBsZXQgbGluZSA9IHRoaXMuc291cmNlLnN0YXJ0LmxpbmVcblxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgaW5kZXg7IGkrKykge1xuICAgICAgaWYgKHN0cmluZ1tpXSA9PT0gJ1xcbicpIHtcbiAgICAgICAgY29sdW1uID0gMVxuICAgICAgICBsaW5lICs9IDFcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbHVtbiArPSAxXG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHsgbGluZSwgY29sdW1uIH1cbiAgfVxuXG4gIHBvc2l0aW9uQnkgKG9wdHMpIHtcbiAgICBsZXQgcG9zID0gdGhpcy5zb3VyY2Uuc3RhcnRcbiAgICBpZiAob3B0cy5pbmRleCkge1xuICAgICAgcG9zID0gdGhpcy5wb3NpdGlvbkluc2lkZShvcHRzLmluZGV4KVxuICAgIH0gZWxzZSBpZiAob3B0cy53b3JkKSB7XG4gICAgICBsZXQgaW5kZXggPSB0aGlzLnRvU3RyaW5nKCkuaW5kZXhPZihvcHRzLndvcmQpXG4gICAgICBpZiAoaW5kZXggIT09IC0xKSBwb3MgPSB0aGlzLnBvc2l0aW9uSW5zaWRlKGluZGV4KVxuICAgIH1cbiAgICByZXR1cm4gcG9zXG4gIH1cblxuICAvKipcbiAgICogQG1lbWJlcm9mIE5vZGUjXG4gICAqIEBtZW1iZXIge3N0cmluZ30gdHlwZSBTdHJpbmcgcmVwcmVzZW50aW5nIHRoZSBub2Rl4oCZcyB0eXBlLlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgUG9zc2libGUgdmFsdWVzIGFyZSBgcm9vdGAsIGBhdHJ1bGVgLCBgcnVsZWAsXG4gICAqICAgICAgICAgICAgICAgICAgICAgICBgZGVjbGAsIG9yIGBjb21tZW50YC5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcG9zdGNzcy5kZWNsKHsgcHJvcDogJ2NvbG9yJywgdmFsdWU6ICdibGFjaycgfSkudHlwZSAvLz0+ICdkZWNsJ1xuICAgKi9cblxuICAvKipcbiAgICogQG1lbWJlcm9mIE5vZGUjXG4gICAqIEBtZW1iZXIge0NvbnRhaW5lcn0gcGFyZW50IFRoZSBub2Rl4oCZcyBwYXJlbnQgbm9kZS5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcm9vdC5ub2Rlc1swXS5wYXJlbnQgPT09IHJvb3RcbiAgICovXG5cbiAgLyoqXG4gICAqIEBtZW1iZXJvZiBOb2RlI1xuICAgKiBAbWVtYmVyIHtzb3VyY2V9IHNvdXJjZSBUaGUgaW5wdXQgc291cmNlIG9mIHRoZSBub2RlLlxuICAgKlxuICAgKiBUaGUgcHJvcGVydHkgaXMgdXNlZCBpbiBzb3VyY2UgbWFwIGdlbmVyYXRpb24uXG4gICAqXG4gICAqIElmIHlvdSBjcmVhdGUgYSBub2RlIG1hbnVhbGx5IChlLmcuLCB3aXRoIGBwb3N0Y3NzLmRlY2woKWApLFxuICAgKiB0aGF0IG5vZGUgd2lsbCBub3QgaGF2ZSBhIGBzb3VyY2VgIHByb3BlcnR5IGFuZCB3aWxsIGJlIGFic2VudFxuICAgKiBmcm9tIHRoZSBzb3VyY2UgbWFwLiBGb3IgdGhpcyByZWFzb24sIHRoZSBwbHVnaW4gZGV2ZWxvcGVyIHNob3VsZFxuICAgKiBjb25zaWRlciBjbG9uaW5nIG5vZGVzIHRvIGNyZWF0ZSBuZXcgb25lcyAoaW4gd2hpY2ggY2FzZSB0aGUgbmV3IG5vZGXigJlzXG4gICAqIHNvdXJjZSB3aWxsIHJlZmVyZW5jZSB0aGUgb3JpZ2luYWwsIGNsb25lZCBub2RlKSBvciBzZXR0aW5nXG4gICAqIHRoZSBgc291cmNlYCBwcm9wZXJ0eSBtYW51YWxseS5cbiAgICpcbiAgICogYGBganNcbiAgICogLy8gQmFkXG4gICAqIGNvbnN0IHByZWZpeGVkID0gcG9zdGNzcy5kZWNsKHtcbiAgICogICBwcm9wOiAnLW1vei0nICsgZGVjbC5wcm9wLFxuICAgKiAgIHZhbHVlOiBkZWNsLnZhbHVlXG4gICAqIH0pXG4gICAqXG4gICAqIC8vIEdvb2RcbiAgICogY29uc3QgcHJlZml4ZWQgPSBkZWNsLmNsb25lKHsgcHJvcDogJy1tb3otJyArIGRlY2wucHJvcCB9KVxuICAgKiBgYGBcbiAgICpcbiAgICogYGBganNcbiAgICogaWYgKGF0cnVsZS5uYW1lID09PSAnYWRkLWxpbmsnKSB7XG4gICAqICAgY29uc3QgcnVsZSA9IHBvc3Rjc3MucnVsZSh7IHNlbGVjdG9yOiAnYScsIHNvdXJjZTogYXRydWxlLnNvdXJjZSB9KVxuICAgKiAgIGF0cnVsZS5wYXJlbnQuaW5zZXJ0QmVmb3JlKGF0cnVsZSwgcnVsZSlcbiAgICogfVxuICAgKiBgYGBcbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogZGVjbC5zb3VyY2UuaW5wdXQuZnJvbSAvLz0+ICcvaG9tZS9haS9hLnNhc3MnXG4gICAqIGRlY2wuc291cmNlLnN0YXJ0ICAgICAgLy89PiB7IGxpbmU6IDEwLCBjb2x1bW46IDIgfVxuICAgKiBkZWNsLnNvdXJjZS5lbmQgICAgICAgIC8vPT4geyBsaW5lOiAxMCwgY29sdW1uOiAxMiB9XG4gICAqL1xuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgTm9kZSNcbiAgICogQG1lbWJlciB7b2JqZWN0fSByYXdzIEluZm9ybWF0aW9uIHRvIGdlbmVyYXRlIGJ5dGUtdG8tYnl0ZSBlcXVhbFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgbm9kZSBzdHJpbmcgYXMgaXQgd2FzIGluIHRoZSBvcmlnaW4gaW5wdXQuXG4gICAqXG4gICAqIEV2ZXJ5IHBhcnNlciBzYXZlcyBpdHMgb3duIHByb3BlcnRpZXMsXG4gICAqIGJ1dCB0aGUgZGVmYXVsdCBDU1MgcGFyc2VyIHVzZXM6XG4gICAqXG4gICAqICogYGJlZm9yZWA6IHRoZSBzcGFjZSBzeW1ib2xzIGJlZm9yZSB0aGUgbm9kZS4gSXQgYWxzbyBzdG9yZXMgYCpgXG4gICAqICAgYW5kIGBfYCBzeW1ib2xzIGJlZm9yZSB0aGUgZGVjbGFyYXRpb24gKElFIGhhY2spLlxuICAgKiAqIGBhZnRlcmA6IHRoZSBzcGFjZSBzeW1ib2xzIGFmdGVyIHRoZSBsYXN0IGNoaWxkIG9mIHRoZSBub2RlXG4gICAqICAgdG8gdGhlIGVuZCBvZiB0aGUgbm9kZS5cbiAgICogKiBgYmV0d2VlbmA6IHRoZSBzeW1ib2xzIGJldHdlZW4gdGhlIHByb3BlcnR5IGFuZCB2YWx1ZVxuICAgKiAgIGZvciBkZWNsYXJhdGlvbnMsIHNlbGVjdG9yIGFuZCBge2AgZm9yIHJ1bGVzLCBvciBsYXN0IHBhcmFtZXRlclxuICAgKiAgIGFuZCBge2AgZm9yIGF0LXJ1bGVzLlxuICAgKiAqIGBzZW1pY29sb25gOiBjb250YWlucyB0cnVlIGlmIHRoZSBsYXN0IGNoaWxkIGhhc1xuICAgKiAgIGFuIChvcHRpb25hbCkgc2VtaWNvbG9uLlxuICAgKiAqIGBhZnRlck5hbWVgOiB0aGUgc3BhY2UgYmV0d2VlbiB0aGUgYXQtcnVsZSBuYW1lIGFuZCBpdHMgcGFyYW1ldGVycy5cbiAgICogKiBgbGVmdGA6IHRoZSBzcGFjZSBzeW1ib2xzIGJldHdlZW4gYC8qYCBhbmQgdGhlIGNvbW1lbnTigJlzIHRleHQuXG4gICAqICogYHJpZ2h0YDogdGhlIHNwYWNlIHN5bWJvbHMgYmV0d2VlbiB0aGUgY29tbWVudOKAmXMgdGV4dFxuICAgKiAgIGFuZCA8Y29kZT4qJiM0Nzs8L2NvZGU+LlxuICAgKiAqIGBpbXBvcnRhbnRgOiB0aGUgY29udGVudCBvZiB0aGUgaW1wb3J0YW50IHN0YXRlbWVudCxcbiAgICogICBpZiBpdCBpcyBub3QganVzdCBgIWltcG9ydGFudGAuXG4gICAqXG4gICAqIFBvc3RDU1MgY2xlYW5zIHNlbGVjdG9ycywgZGVjbGFyYXRpb24gdmFsdWVzIGFuZCBhdC1ydWxlIHBhcmFtZXRlcnNcbiAgICogZnJvbSBjb21tZW50cyBhbmQgZXh0cmEgc3BhY2VzLCBidXQgaXQgc3RvcmVzIG9yaWdpbiBjb250ZW50IGluIHJhd3NcbiAgICogcHJvcGVydGllcy4gQXMgc3VjaCwgaWYgeW91IGRvbuKAmXQgY2hhbmdlIGEgZGVjbGFyYXRpb27igJlzIHZhbHVlLFxuICAgKiBQb3N0Q1NTIHdpbGwgdXNlIHRoZSByYXcgdmFsdWUgd2l0aCBjb21tZW50cy5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2Ege1xcbiAgY29sb3I6YmxhY2tcXG59JylcbiAgICogcm9vdC5maXJzdC5maXJzdC5yYXdzIC8vPT4geyBiZWZvcmU6ICdcXG4gICcsIGJldHdlZW46ICc6JyB9XG4gICAqL1xufVxuXG5leHBvcnQgZGVmYXVsdCBOb2RlXG5cbi8qKlxuICogQHR5cGVkZWYge29iamVjdH0gcG9zaXRpb25cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBsaW5lICAgU291cmNlIGxpbmUgaW4gZmlsZS5cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBjb2x1bW4gU291cmNlIGNvbHVtbiBpbiBmaWxlLlxuICovXG5cbi8qKlxuICogQHR5cGVkZWYge29iamVjdH0gc291cmNlXG4gKiBAcHJvcGVydHkge0lucHV0fSBpbnB1dCAgICB7QGxpbmsgSW5wdXR9IHdpdGggaW5wdXQgZmlsZVxuICogQHByb3BlcnR5IHtwb3NpdGlvbn0gc3RhcnQgVGhlIHN0YXJ0aW5nIHBvc2l0aW9uIG9mIHRoZSBub2Rl4oCZcyBzb3VyY2UuXG4gKiBAcHJvcGVydHkge3Bvc2l0aW9ufSBlbmQgICBUaGUgZW5kaW5nIHBvc2l0aW9uIG9mIHRoZSBub2Rl4oCZcyBzb3VyY2UuXG4gKi9cbiJdLCJmaWxlIjoibm9kZS5qcyJ9
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/parse.js b/node_modules/autoprefixer/node_modules/postcss/lib/parse.js
new file mode 100644
index 0000000..99c417e
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/parse.js
@@ -0,0 +1,40 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _parser = _interopRequireDefault(require("./parser"));
+
+var _input = _interopRequireDefault(require("./input"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function parse(css, opts) {
+ var input = new _input.default(css, opts);
+ var parser = new _parser.default(input);
+
+ try {
+ parser.parse();
+ } catch (e) {
+ if (process.env.NODE_ENV !== 'production') {
+ if (e.name === 'CssSyntaxError' && opts && opts.from) {
+ if (/\.scss$/i.test(opts.from)) {
+ e.message += '\nYou tried to parse SCSS with ' + 'the standard CSS parser; ' + 'try again with the postcss-scss parser';
+ } else if (/\.sass/i.test(opts.from)) {
+ e.message += '\nYou tried to parse Sass with ' + 'the standard CSS parser; ' + 'try again with the postcss-sass parser';
+ } else if (/\.less$/i.test(opts.from)) {
+ e.message += '\nYou tried to parse Less with ' + 'the standard CSS parser; ' + 'try again with the postcss-less parser';
+ }
+ }
+ }
+
+ throw e;
+ }
+
+ return parser.root;
+}
+
+var _default = parse;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInBhcnNlLmVzNiJdLCJuYW1lcyI6WyJwYXJzZSIsImNzcyIsIm9wdHMiLCJpbnB1dCIsIklucHV0IiwicGFyc2VyIiwiUGFyc2VyIiwiZSIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIm5hbWUiLCJmcm9tIiwidGVzdCIsIm1lc3NhZ2UiLCJyb290Il0sIm1hcHBpbmdzIjoiOzs7OztBQUFBOztBQUNBOzs7O0FBRUEsU0FBU0EsS0FBVCxDQUFnQkMsR0FBaEIsRUFBcUJDLElBQXJCLEVBQTJCO0FBQ3pCLE1BQUlDLEtBQUssR0FBRyxJQUFJQyxjQUFKLENBQVVILEdBQVYsRUFBZUMsSUFBZixDQUFaO0FBQ0EsTUFBSUcsTUFBTSxHQUFHLElBQUlDLGVBQUosQ0FBV0gsS0FBWCxDQUFiOztBQUNBLE1BQUk7QUFDRkUsSUFBQUEsTUFBTSxDQUFDTCxLQUFQO0FBQ0QsR0FGRCxDQUVFLE9BQU9PLENBQVAsRUFBVTtBQUNWLFFBQUlDLE9BQU8sQ0FBQ0MsR0FBUixDQUFZQyxRQUFaLEtBQXlCLFlBQTdCLEVBQTJDO0FBQ3pDLFVBQUlILENBQUMsQ0FBQ0ksSUFBRixLQUFXLGdCQUFYLElBQStCVCxJQUEvQixJQUF1Q0EsSUFBSSxDQUFDVSxJQUFoRCxFQUFzRDtBQUNwRCxZQUFJLFdBQVdDLElBQVgsQ0FBZ0JYLElBQUksQ0FBQ1UsSUFBckIsQ0FBSixFQUFnQztBQUM5QkwsVUFBQUEsQ0FBQyxDQUFDTyxPQUFGLElBQWEsb0NBQ0EsMkJBREEsR0FFQSx3Q0FGYjtBQUdELFNBSkQsTUFJTyxJQUFJLFVBQVVELElBQVYsQ0FBZVgsSUFBSSxDQUFDVSxJQUFwQixDQUFKLEVBQStCO0FBQ3BDTCxVQUFBQSxDQUFDLENBQUNPLE9BQUYsSUFBYSxvQ0FDQSwyQkFEQSxHQUVBLHdDQUZiO0FBR0QsU0FKTSxNQUlBLElBQUksV0FBV0QsSUFBWCxDQUFnQlgsSUFBSSxDQUFDVSxJQUFyQixDQUFKLEVBQWdDO0FBQ3JDTCxVQUFBQSxDQUFDLENBQUNPLE9BQUYsSUFBYSxvQ0FDQSwyQkFEQSxHQUVBLHdDQUZiO0FBR0Q7QUFDRjtBQUNGOztBQUNELFVBQU1QLENBQU47QUFDRDs7QUFFRCxTQUFPRixNQUFNLENBQUNVLElBQWQ7QUFDRDs7ZUFFY2YsSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQYXJzZXIgZnJvbSAnLi9wYXJzZXInXG5pbXBvcnQgSW5wdXQgZnJvbSAnLi9pbnB1dCdcblxuZnVuY3Rpb24gcGFyc2UgKGNzcywgb3B0cykge1xuICBsZXQgaW5wdXQgPSBuZXcgSW5wdXQoY3NzLCBvcHRzKVxuICBsZXQgcGFyc2VyID0gbmV3IFBhcnNlcihpbnB1dClcbiAgdHJ5IHtcbiAgICBwYXJzZXIucGFyc2UoKVxuICB9IGNhdGNoIChlKSB7XG4gICAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WICE9PSAncHJvZHVjdGlvbicpIHtcbiAgICAgIGlmIChlLm5hbWUgPT09ICdDc3NTeW50YXhFcnJvcicgJiYgb3B0cyAmJiBvcHRzLmZyb20pIHtcbiAgICAgICAgaWYgKC9cXC5zY3NzJC9pLnRlc3Qob3B0cy5mcm9tKSkge1xuICAgICAgICAgIGUubWVzc2FnZSArPSAnXFxuWW91IHRyaWVkIHRvIHBhcnNlIFNDU1Mgd2l0aCAnICtcbiAgICAgICAgICAgICAgICAgICAgICAgJ3RoZSBzdGFuZGFyZCBDU1MgcGFyc2VyOyAnICtcbiAgICAgICAgICAgICAgICAgICAgICAgJ3RyeSBhZ2FpbiB3aXRoIHRoZSBwb3N0Y3NzLXNjc3MgcGFyc2VyJ1xuICAgICAgICB9IGVsc2UgaWYgKC9cXC5zYXNzL2kudGVzdChvcHRzLmZyb20pKSB7XG4gICAgICAgICAgZS5tZXNzYWdlICs9ICdcXG5Zb3UgdHJpZWQgdG8gcGFyc2UgU2FzcyB3aXRoICcgK1xuICAgICAgICAgICAgICAgICAgICAgICAndGhlIHN0YW5kYXJkIENTUyBwYXJzZXI7ICcgK1xuICAgICAgICAgICAgICAgICAgICAgICAndHJ5IGFnYWluIHdpdGggdGhlIHBvc3Rjc3Mtc2FzcyBwYXJzZXInXG4gICAgICAgIH0gZWxzZSBpZiAoL1xcLmxlc3MkL2kudGVzdChvcHRzLmZyb20pKSB7XG4gICAgICAgICAgZS5tZXNzYWdlICs9ICdcXG5Zb3UgdHJpZWQgdG8gcGFyc2UgTGVzcyB3aXRoICcgK1xuICAgICAgICAgICAgICAgICAgICAgICAndGhlIHN0YW5kYXJkIENTUyBwYXJzZXI7ICcgK1xuICAgICAgICAgICAgICAgICAgICAgICAndHJ5IGFnYWluIHdpdGggdGhlIHBvc3Rjc3MtbGVzcyBwYXJzZXInXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gICAgdGhyb3cgZVxuICB9XG5cbiAgcmV0dXJuIHBhcnNlci5yb290XG59XG5cbmV4cG9ydCBkZWZhdWx0IHBhcnNlXG4iXSwiZmlsZSI6InBhcnNlLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/parser.js b/node_modules/autoprefixer/node_modules/postcss/lib/parser.js
new file mode 100644
index 0000000..74bdcf0
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/parser.js
@@ -0,0 +1,611 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _declaration = _interopRequireDefault(require("./declaration"));
+
+var _tokenize = _interopRequireDefault(require("./tokenize"));
+
+var _comment = _interopRequireDefault(require("./comment"));
+
+var _atRule = _interopRequireDefault(require("./at-rule"));
+
+var _root = _interopRequireDefault(require("./root"));
+
+var _rule = _interopRequireDefault(require("./rule"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var Parser =
+/*#__PURE__*/
+function () {
+ function Parser(input) {
+ this.input = input;
+ this.root = new _root.default();
+ this.current = this.root;
+ this.spaces = '';
+ this.semicolon = false;
+ this.createTokenizer();
+ this.root.source = {
+ input: input,
+ start: {
+ line: 1,
+ column: 1
+ }
+ };
+ }
+
+ var _proto = Parser.prototype;
+
+ _proto.createTokenizer = function createTokenizer() {
+ this.tokenizer = (0, _tokenize.default)(this.input);
+ };
+
+ _proto.parse = function parse() {
+ var token;
+
+ while (!this.tokenizer.endOfFile()) {
+ token = this.tokenizer.nextToken();
+
+ switch (token[0]) {
+ case 'space':
+ this.spaces += token[1];
+ break;
+
+ case ';':
+ this.freeSemicolon(token);
+ break;
+
+ case '}':
+ this.end(token);
+ break;
+
+ case 'comment':
+ this.comment(token);
+ break;
+
+ case 'at-word':
+ this.atrule(token);
+ break;
+
+ case '{':
+ this.emptyRule(token);
+ break;
+
+ default:
+ this.other(token);
+ break;
+ }
+ }
+
+ this.endFile();
+ };
+
+ _proto.comment = function comment(token) {
+ var node = new _comment.default();
+ this.init(node, token[2], token[3]);
+ node.source.end = {
+ line: token[4],
+ column: token[5]
+ };
+ var text = token[1].slice(2, -2);
+
+ if (/^\s*$/.test(text)) {
+ node.text = '';
+ node.raws.left = text;
+ node.raws.right = '';
+ } else {
+ var match = text.match(/^(\s*)([^]*[^\s])(\s*)$/);
+ node.text = match[2];
+ node.raws.left = match[1];
+ node.raws.right = match[3];
+ }
+ };
+
+ _proto.emptyRule = function emptyRule(token) {
+ var node = new _rule.default();
+ this.init(node, token[2], token[3]);
+ node.selector = '';
+ node.raws.between = '';
+ this.current = node;
+ };
+
+ _proto.other = function other(start) {
+ var end = false;
+ var type = null;
+ var colon = false;
+ var bracket = null;
+ var brackets = [];
+ var tokens = [];
+ var token = start;
+
+ while (token) {
+ type = token[0];
+ tokens.push(token);
+
+ if (type === '(' || type === '[') {
+ if (!bracket) bracket = token;
+ brackets.push(type === '(' ? ')' : ']');
+ } else if (brackets.length === 0) {
+ if (type === ';') {
+ if (colon) {
+ this.decl(tokens);
+ return;
+ } else {
+ break;
+ }
+ } else if (type === '{') {
+ this.rule(tokens);
+ return;
+ } else if (type === '}') {
+ this.tokenizer.back(tokens.pop());
+ end = true;
+ break;
+ } else if (type === ':') {
+ colon = true;
+ }
+ } else if (type === brackets[brackets.length - 1]) {
+ brackets.pop();
+ if (brackets.length === 0) bracket = null;
+ }
+
+ token = this.tokenizer.nextToken();
+ }
+
+ if (this.tokenizer.endOfFile()) end = true;
+ if (brackets.length > 0) this.unclosedBracket(bracket);
+
+ if (end && colon) {
+ while (tokens.length) {
+ token = tokens[tokens.length - 1][0];
+ if (token !== 'space' && token !== 'comment') break;
+ this.tokenizer.back(tokens.pop());
+ }
+
+ this.decl(tokens);
+ } else {
+ this.unknownWord(tokens);
+ }
+ };
+
+ _proto.rule = function rule(tokens) {
+ tokens.pop();
+ var node = new _rule.default();
+ this.init(node, tokens[0][2], tokens[0][3]);
+ node.raws.between = this.spacesAndCommentsFromEnd(tokens);
+ this.raw(node, 'selector', tokens);
+ this.current = node;
+ };
+
+ _proto.decl = function decl(tokens) {
+ var node = new _declaration.default();
+ this.init(node);
+ var last = tokens[tokens.length - 1];
+
+ if (last[0] === ';') {
+ this.semicolon = true;
+ tokens.pop();
+ }
+
+ if (last[4]) {
+ node.source.end = {
+ line: last[4],
+ column: last[5]
+ };
+ } else {
+ node.source.end = {
+ line: last[2],
+ column: last[3]
+ };
+ }
+
+ while (tokens[0][0] !== 'word') {
+ if (tokens.length === 1) this.unknownWord(tokens);
+ node.raws.before += tokens.shift()[1];
+ }
+
+ node.source.start = {
+ line: tokens[0][2],
+ column: tokens[0][3]
+ };
+ node.prop = '';
+
+ while (tokens.length) {
+ var type = tokens[0][0];
+
+ if (type === ':' || type === 'space' || type === 'comment') {
+ break;
+ }
+
+ node.prop += tokens.shift()[1];
+ }
+
+ node.raws.between = '';
+ var token;
+
+ while (tokens.length) {
+ token = tokens.shift();
+
+ if (token[0] === ':') {
+ node.raws.between += token[1];
+ break;
+ } else {
+ if (token[0] === 'word' && /\w/.test(token[1])) {
+ this.unknownWord([token]);
+ }
+
+ node.raws.between += token[1];
+ }
+ }
+
+ if (node.prop[0] === '_' || node.prop[0] === '*') {
+ node.raws.before += node.prop[0];
+ node.prop = node.prop.slice(1);
+ }
+
+ node.raws.between += this.spacesAndCommentsFromStart(tokens);
+ this.precheckMissedSemicolon(tokens);
+
+ for (var i = tokens.length - 1; i > 0; i--) {
+ token = tokens[i];
+
+ if (token[1].toLowerCase() === '!important') {
+ node.important = true;
+ var string = this.stringFrom(tokens, i);
+ string = this.spacesFromEnd(tokens) + string;
+ if (string !== ' !important') node.raws.important = string;
+ break;
+ } else if (token[1].toLowerCase() === 'important') {
+ var cache = tokens.slice(0);
+ var str = '';
+
+ for (var j = i; j > 0; j--) {
+ var _type = cache[j][0];
+
+ if (str.trim().indexOf('!') === 0 && _type !== 'space') {
+ break;
+ }
+
+ str = cache.pop()[1] + str;
+ }
+
+ if (str.trim().indexOf('!') === 0) {
+ node.important = true;
+ node.raws.important = str;
+ tokens = cache;
+ }
+ }
+
+ if (token[0] !== 'space' && token[0] !== 'comment') {
+ break;
+ }
+ }
+
+ this.raw(node, 'value', tokens);
+ if (node.value.indexOf(':') !== -1) this.checkMissedSemicolon(tokens);
+ };
+
+ _proto.atrule = function atrule(token) {
+ var node = new _atRule.default();
+ node.name = token[1].slice(1);
+
+ if (node.name === '') {
+ this.unnamedAtrule(node, token);
+ }
+
+ this.init(node, token[2], token[3]);
+ var prev;
+ var shift;
+ var last = false;
+ var open = false;
+ var params = [];
+
+ while (!this.tokenizer.endOfFile()) {
+ token = this.tokenizer.nextToken();
+
+ if (token[0] === ';') {
+ node.source.end = {
+ line: token[2],
+ column: token[3]
+ };
+ this.semicolon = true;
+ break;
+ } else if (token[0] === '{') {
+ open = true;
+ break;
+ } else if (token[0] === '}') {
+ if (params.length > 0) {
+ shift = params.length - 1;
+ prev = params[shift];
+
+ while (prev && prev[0] === 'space') {
+ prev = params[--shift];
+ }
+
+ if (prev) {
+ node.source.end = {
+ line: prev[4],
+ column: prev[5]
+ };
+ }
+ }
+
+ this.end(token);
+ break;
+ } else {
+ params.push(token);
+ }
+
+ if (this.tokenizer.endOfFile()) {
+ last = true;
+ break;
+ }
+ }
+
+ node.raws.between = this.spacesAndCommentsFromEnd(params);
+
+ if (params.length) {
+ node.raws.afterName = this.spacesAndCommentsFromStart(params);
+ this.raw(node, 'params', params);
+
+ if (last) {
+ token = params[params.length - 1];
+ node.source.end = {
+ line: token[4],
+ column: token[5]
+ };
+ this.spaces = node.raws.between;
+ node.raws.between = '';
+ }
+ } else {
+ node.raws.afterName = '';
+ node.params = '';
+ }
+
+ if (open) {
+ node.nodes = [];
+ this.current = node;
+ }
+ };
+
+ _proto.end = function end(token) {
+ if (this.current.nodes && this.current.nodes.length) {
+ this.current.raws.semicolon = this.semicolon;
+ }
+
+ this.semicolon = false;
+ this.current.raws.after = (this.current.raws.after || '') + this.spaces;
+ this.spaces = '';
+
+ if (this.current.parent) {
+ this.current.source.end = {
+ line: token[2],
+ column: token[3]
+ };
+ this.current = this.current.parent;
+ } else {
+ this.unexpectedClose(token);
+ }
+ };
+
+ _proto.endFile = function endFile() {
+ if (this.current.parent) this.unclosedBlock();
+
+ if (this.current.nodes && this.current.nodes.length) {
+ this.current.raws.semicolon = this.semicolon;
+ }
+
+ this.current.raws.after = (this.current.raws.after || '') + this.spaces;
+ };
+
+ _proto.freeSemicolon = function freeSemicolon(token) {
+ this.spaces += token[1];
+
+ if (this.current.nodes) {
+ var prev = this.current.nodes[this.current.nodes.length - 1];
+
+ if (prev && prev.type === 'rule' && !prev.raws.ownSemicolon) {
+ prev.raws.ownSemicolon = this.spaces;
+ this.spaces = '';
+ }
+ }
+ } // Helpers
+ ;
+
+ _proto.init = function init(node, line, column) {
+ this.current.push(node);
+ node.source = {
+ start: {
+ line: line,
+ column: column
+ },
+ input: this.input
+ };
+ node.raws.before = this.spaces;
+ this.spaces = '';
+ if (node.type !== 'comment') this.semicolon = false;
+ };
+
+ _proto.raw = function raw(node, prop, tokens) {
+ var token, type;
+ var length = tokens.length;
+ var value = '';
+ var clean = true;
+ var next, prev;
+ var pattern = /^([.|#])?([\w])+/i;
+
+ for (var i = 0; i < length; i += 1) {
+ token = tokens[i];
+ type = token[0];
+
+ if (type === 'comment' && node.type === 'rule') {
+ prev = tokens[i - 1];
+ next = tokens[i + 1];
+
+ if (prev[0] !== 'space' && next[0] !== 'space' && pattern.test(prev[1]) && pattern.test(next[1])) {
+ value += token[1];
+ } else {
+ clean = false;
+ }
+
+ continue;
+ }
+
+ if (type === 'comment' || type === 'space' && i === length - 1) {
+ clean = false;
+ } else {
+ value += token[1];
+ }
+ }
+
+ if (!clean) {
+ var raw = tokens.reduce(function (all, i) {
+ return all + i[1];
+ }, '');
+ node.raws[prop] = {
+ value: value,
+ raw: raw
+ };
+ }
+
+ node[prop] = value;
+ };
+
+ _proto.spacesAndCommentsFromEnd = function spacesAndCommentsFromEnd(tokens) {
+ var lastTokenType;
+ var spaces = '';
+
+ while (tokens.length) {
+ lastTokenType = tokens[tokens.length - 1][0];
+ if (lastTokenType !== 'space' && lastTokenType !== 'comment') break;
+ spaces = tokens.pop()[1] + spaces;
+ }
+
+ return spaces;
+ };
+
+ _proto.spacesAndCommentsFromStart = function spacesAndCommentsFromStart(tokens) {
+ var next;
+ var spaces = '';
+
+ while (tokens.length) {
+ next = tokens[0][0];
+ if (next !== 'space' && next !== 'comment') break;
+ spaces += tokens.shift()[1];
+ }
+
+ return spaces;
+ };
+
+ _proto.spacesFromEnd = function spacesFromEnd(tokens) {
+ var lastTokenType;
+ var spaces = '';
+
+ while (tokens.length) {
+ lastTokenType = tokens[tokens.length - 1][0];
+ if (lastTokenType !== 'space') break;
+ spaces = tokens.pop()[1] + spaces;
+ }
+
+ return spaces;
+ };
+
+ _proto.stringFrom = function stringFrom(tokens, from) {
+ var result = '';
+
+ for (var i = from; i < tokens.length; i++) {
+ result += tokens[i][1];
+ }
+
+ tokens.splice(from, tokens.length - from);
+ return result;
+ };
+
+ _proto.colon = function colon(tokens) {
+ var brackets = 0;
+ var token, type, prev;
+
+ for (var i = 0; i < tokens.length; i++) {
+ token = tokens[i];
+ type = token[0];
+
+ if (type === '(') {
+ brackets += 1;
+ }
+
+ if (type === ')') {
+ brackets -= 1;
+ }
+
+ if (brackets === 0 && type === ':') {
+ if (!prev) {
+ this.doubleColon(token);
+ } else if (prev[0] === 'word' && prev[1] === 'progid') {
+ continue;
+ } else {
+ return i;
+ }
+ }
+
+ prev = token;
+ }
+
+ return false;
+ } // Errors
+ ;
+
+ _proto.unclosedBracket = function unclosedBracket(bracket) {
+ throw this.input.error('Unclosed bracket', bracket[2], bracket[3]);
+ };
+
+ _proto.unknownWord = function unknownWord(tokens) {
+ throw this.input.error('Unknown word', tokens[0][2], tokens[0][3]);
+ };
+
+ _proto.unexpectedClose = function unexpectedClose(token) {
+ throw this.input.error('Unexpected }', token[2], token[3]);
+ };
+
+ _proto.unclosedBlock = function unclosedBlock() {
+ var pos = this.current.source.start;
+ throw this.input.error('Unclosed block', pos.line, pos.column);
+ };
+
+ _proto.doubleColon = function doubleColon(token) {
+ throw this.input.error('Double colon', token[2], token[3]);
+ };
+
+ _proto.unnamedAtrule = function unnamedAtrule(node, token) {
+ throw this.input.error('At-rule without name', token[2], token[3]);
+ };
+
+ _proto.precheckMissedSemicolon = function precheckMissedSemicolon()
+ /* tokens */
+ {// Hook for Safe Parser
+ };
+
+ _proto.checkMissedSemicolon = function checkMissedSemicolon(tokens) {
+ var colon = this.colon(tokens);
+ if (colon === false) return;
+ var founded = 0;
+ var token;
+
+ for (var j = colon - 1; j >= 0; j--) {
+ token = tokens[j];
+
+ if (token[0] !== 'space') {
+ founded += 1;
+ if (founded === 2) break;
+ }
+ }
+
+ throw this.input.error('Missed semicolon', token[2], token[3]);
+ };
+
+ return Parser;
+}();
+
+exports.default = Parser;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInBhcnNlci5lczYiXSwibmFtZXMiOlsiUGFyc2VyIiwiaW5wdXQiLCJyb290IiwiUm9vdCIsImN1cnJlbnQiLCJzcGFjZXMiLCJzZW1pY29sb24iLCJjcmVhdGVUb2tlbml6ZXIiLCJzb3VyY2UiLCJzdGFydCIsImxpbmUiLCJjb2x1bW4iLCJ0b2tlbml6ZXIiLCJwYXJzZSIsInRva2VuIiwiZW5kT2ZGaWxlIiwibmV4dFRva2VuIiwiZnJlZVNlbWljb2xvbiIsImVuZCIsImNvbW1lbnQiLCJhdHJ1bGUiLCJlbXB0eVJ1bGUiLCJvdGhlciIsImVuZEZpbGUiLCJub2RlIiwiQ29tbWVudCIsImluaXQiLCJ0ZXh0Iiwic2xpY2UiLCJ0ZXN0IiwicmF3cyIsImxlZnQiLCJyaWdodCIsIm1hdGNoIiwiUnVsZSIsInNlbGVjdG9yIiwiYmV0d2VlbiIsInR5cGUiLCJjb2xvbiIsImJyYWNrZXQiLCJicmFja2V0cyIsInRva2VucyIsInB1c2giLCJsZW5ndGgiLCJkZWNsIiwicnVsZSIsImJhY2siLCJwb3AiLCJ1bmNsb3NlZEJyYWNrZXQiLCJ1bmtub3duV29yZCIsInNwYWNlc0FuZENvbW1lbnRzRnJvbUVuZCIsInJhdyIsIkRlY2xhcmF0aW9uIiwibGFzdCIsImJlZm9yZSIsInNoaWZ0IiwicHJvcCIsInNwYWNlc0FuZENvbW1lbnRzRnJvbVN0YXJ0IiwicHJlY2hlY2tNaXNzZWRTZW1pY29sb24iLCJpIiwidG9Mb3dlckNhc2UiLCJpbXBvcnRhbnQiLCJzdHJpbmciLCJzdHJpbmdGcm9tIiwic3BhY2VzRnJvbUVuZCIsImNhY2hlIiwic3RyIiwiaiIsInRyaW0iLCJpbmRleE9mIiwidmFsdWUiLCJjaGVja01pc3NlZFNlbWljb2xvbiIsIkF0UnVsZSIsIm5hbWUiLCJ1bm5hbWVkQXRydWxlIiwicHJldiIsIm9wZW4iLCJwYXJhbXMiLCJhZnRlck5hbWUiLCJub2RlcyIsImFmdGVyIiwicGFyZW50IiwidW5leHBlY3RlZENsb3NlIiwidW5jbG9zZWRCbG9jayIsIm93blNlbWljb2xvbiIsImNsZWFuIiwibmV4dCIsInBhdHRlcm4iLCJyZWR1Y2UiLCJhbGwiLCJsYXN0VG9rZW5UeXBlIiwiZnJvbSIsInJlc3VsdCIsInNwbGljZSIsImRvdWJsZUNvbG9uIiwiZXJyb3IiLCJwb3MiLCJmb3VuZGVkIl0sIm1hcHBpbmdzIjoiOzs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOzs7O0lBRXFCQSxNOzs7QUFDbkIsa0JBQWFDLEtBQWIsRUFBb0I7QUFDbEIsU0FBS0EsS0FBTCxHQUFhQSxLQUFiO0FBRUEsU0FBS0MsSUFBTCxHQUFZLElBQUlDLGFBQUosRUFBWjtBQUNBLFNBQUtDLE9BQUwsR0FBZSxLQUFLRixJQUFwQjtBQUNBLFNBQUtHLE1BQUwsR0FBYyxFQUFkO0FBQ0EsU0FBS0MsU0FBTCxHQUFpQixLQUFqQjtBQUVBLFNBQUtDLGVBQUw7QUFDQSxTQUFLTCxJQUFMLENBQVVNLE1BQVYsR0FBbUI7QUFBRVAsTUFBQUEsS0FBSyxFQUFMQSxLQUFGO0FBQVNRLE1BQUFBLEtBQUssRUFBRTtBQUFFQyxRQUFBQSxJQUFJLEVBQUUsQ0FBUjtBQUFXQyxRQUFBQSxNQUFNLEVBQUU7QUFBbkI7QUFBaEIsS0FBbkI7QUFDRDs7OztTQUVESixlLEdBQUEsMkJBQW1CO0FBQ2pCLFNBQUtLLFNBQUwsR0FBaUIsdUJBQVUsS0FBS1gsS0FBZixDQUFqQjtBQUNELEc7O1NBRURZLEssR0FBQSxpQkFBUztBQUNQLFFBQUlDLEtBQUo7O0FBQ0EsV0FBTyxDQUFDLEtBQUtGLFNBQUwsQ0FBZUcsU0FBZixFQUFSLEVBQW9DO0FBQ2xDRCxNQUFBQSxLQUFLLEdBQUcsS0FBS0YsU0FBTCxDQUFlSSxTQUFmLEVBQVI7O0FBRUEsY0FBUUYsS0FBSyxDQUFDLENBQUQsQ0FBYjtBQUNFLGFBQUssT0FBTDtBQUNFLGVBQUtULE1BQUwsSUFBZVMsS0FBSyxDQUFDLENBQUQsQ0FBcEI7QUFDQTs7QUFFRixhQUFLLEdBQUw7QUFDRSxlQUFLRyxhQUFMLENBQW1CSCxLQUFuQjtB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QUssQ0FBaEIsRUFBbUI7QUFDcEI7QUFDRjs7QUFDRCxVQUFNLEtBQUtoRyxLQUFMLENBQVc4RixLQUFYLENBQWlCLGtCQUFqQixFQUFxQ2pGLEtBQUssQ0FBQyxDQUFELENBQTFDLEVBQStDQSxLQUFLLENBQUMsQ0FBRCxDQUFwRCxDQUFOO0FBQ0QsRyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBEZWNsYXJhdGlvbiBmcm9tICcuL2RlY2xhcmF0aW9uJ1xuaW1wb3J0IHRva2VuaXplciBmcm9tICcuL3Rva2VuaXplJ1xuaW1wb3J0IENvbW1lbnQgZnJvbSAnLi9jb21tZW50J1xuaW1wb3J0IEF0UnVsZSBmcm9tICcuL2F0LXJ1bGUnXG5pbXBvcnQgUm9vdCBmcm9tICcuL3Jvb3QnXG5pbXBvcnQgUnVsZSBmcm9tICcuL3J1bGUnXG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFBhcnNlciB7XG4gIGNvbnN0cnVjdG9yIChpbnB1dCkge1xuICAgIHRoaXMuaW5wdXQgPSBpbnB1dFxuXG4gICAgdGhpcy5yb290ID0gbmV3IFJvb3QoKVxuICAgIHRoaXMuY3VycmVudCA9IHRoaXMucm9vdFxuICAgIHRoaXMuc3BhY2VzID0gJydcbiAgICB0aGlzLnNlbWljb2xvbiA9IGZhbHNlXG5cbiAgICB0aGlzLmNyZWF0ZVRva2VuaXplcigpXG4gICAgdGhpcy5yb290LnNvdXJjZSA9IHsgaW5wdXQsIHN0YXJ0OiB7IGxpbmU6IDEsIGNvbHVtbjogMSB9IH1cbiAgfVxuXG4gIGNyZWF0ZVRva2VuaXplciAoKSB7XG4gICAgdGhpcy50b2tlbml6ZXIgPSB0b2tlbml6ZXIodGhpcy5pbnB1dClcbiAgfVxuXG4gIHBhcnNlICgpIHtcbiAgICBsZXQgdG9rZW5cbiAgICB3aGlsZSAoIXRoaXMudG9rZW5pemVyLmVuZE9mRmlsZSgpKSB7XG4gICAgICB0b2tlbiA9IHRoaXMudG9rZW5pemVyLm5leHRUb2tlbigpXG5cbiAgICAgIHN3aXRjaCAodG9rZW5bMF0pIHtcbiAgICAgICAgY2FzZSAnc3BhY2UnOlxuICAgICAgICAgIHRoaXMuc3BhY2VzICs9IHRva2VuWzFdXG4gICAgICAgICAgYnJlYWtcblxuICAgICAgICBjYXNlICc7JzpcbiAgICAgICAgICB0aGlzLmZyZWVTZW1pY29sb24odG9rZW4pXG4gICAgICAgICAgYnJlYWtcblxuICAgICAgICBjYXNlICd9JzpcbiAgICAgICAgICB0aGlzLmVuZCh0b2tlbilcbiAgICAgICAgICBicmVha1xuXG4gICAgICAgIGNhc2UgJ2NvbW1lbnQnOlxuICAgICAgICAgIHRoaXMuY29tbWVudCh0b2tlbilcbiAgICAgICAgICBicmVha1xuXG4gICAgICAgIGNhc2UgJ2F0LXdvcmQnOlxuICAgICAgICAgIHRoaXMuYXRydWxlKHRva2VuKVxuICAgICAgICAgIGJyZWFrXG5cbiAgICAgICAgY2FzZSAneyc6XG4gICAgICAgICAgdGhpcy5lbXB0eVJ1bGUodG9rZW4pXG4gICAgICAgICAgYnJlYWtcblxuICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgIHRoaXMub3RoZXIodG9rZW4pXG4gICAgICAgICAgYnJlYWtcbiAgICAgIH1cbiAgICB9XG4gICAgdGhpcy5lbmRGaWxlKClcbiAgfVxuXG4gIGNvbW1lbnQgKHRva2VuKSB7XG4gICAgbGV0IG5vZGUgPSBuZXcgQ29tbWVudCgpXG4gICAgdGhpcy5pbml0KG5vZGUsIHRva2VuWzJdLCB0b2tlblszXSlcbiAgICBub2RlLnNvdXJjZS5lbmQgPSB7IGxpbmU6IHRva2VuWzRdLCBjb2x1bW46IHRva2VuWzVdIH1cblxuICAgIGxldCB0ZXh0ID0gdG9rZW5bMV0uc2xpY2UoMiwgLTIpXG4gICAgaWYgKC9eXFxzKiQvLnRlc3QodGV4dCkpIHtcbiAgICAgIG5vZGUudGV4dCA9ICcnXG4gICAgICBub2RlLnJhd3MubGVmdCA9IHRleHRcbiAgICAgIG5vZGUucmF3cy5yaWdodCA9ICcnXG4gICAgfSBlbHNlIHtcbiAgICAgIGxldCBtYXRjaCA9IHRleHQubWF0Y2goL14oXFxzKikoW15dKlteXFxzXSkoXFxzKikkLylcbiAgICAgIG5vZGUudGV4dCA9IG1hdGNoWzJdXG4gICAgICBub2RlLnJhd3MubGVmdCA9IG1hdGNoWzFdXG4gICAgICBub2RlLnJhd3MucmlnaHQgPSBtYXRjaFszXVxuICAgIH1cbiAgfVxuXG4gIGVtcHR5UnVsZSAodG9rZW4pIHtcbiAgICBsZXQgbm9kZSA9IG5ldyBSdWxlKClcbiAgICB0aGlzLmluaXQobm9kZSwgdG9rZW5bMl0sIHRva2VuWzNdKVxuICAgIG5vZGUuc2VsZWN0b3IgPSAnJ1xuICAgIG5vZGUucmF3cy5iZXR3ZWVuID0gJydcbiAgICB0aGlzLmN1cnJlbnQgPSBub2RlXG4gIH1cblxuICBvdGhlciAoc3RhcnQpIHtcbiAgICBsZXQgZW5kID0gZmFsc2VcbiAgICBsZXQgdHlwZSA9IG51bGxcbiAgICBsZXQgY29sb24gPSBmYWxzZVxuICAgIGxldCBicmFja2V0ID0gbnVsbFxuICAgIGxldCBicmFja2V0cyA9IFtdXG5cbiAgICBsZXQgdG9rZW5zID0gW11cbiAgICBsZXQgdG9rZW4gPSBzdGFydFxuICAgIHdoaWxlICh0b2tlbikge1xuICAgICAgdHlwZSA9IHRva2VuWzBdXG4gICAgICB0b2tlbnMucHVzaCh0b2tlbilcblxuICAgICAgaWYgKHR5cGUgPT09ICcoJyB8fCB0eXBlID09PSAnWycpIHtcbiAgICAgICAgaWYgKCFicmFja2V0KSBicmFja2V0ID0gdG9rZW5cbiAgICAgICAgYnJhY2tldHMucHVzaCh0eXBlID09PSAnKCcgPyAnKScgOiAnXScpXG4gICAgICB9IGVsc2UgaWYgKGJyYWNrZXRzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICBpZiAodHlwZSA9PT0gJzsnKSB7XG4gICAgICAgICAgaWYgKGNvbG9uKSB7XG4gICAgICAgICAgICB0aGlzLmRlY2wodG9rZW5zKVxuICAgICAgICAgICAgcmV0dXJuXG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGJyZWFrXG4gICAgICAgICAgfVxuICAgICAgICB9IGVsc2UgaWYgKHR5cGUgPT09ICd7Jykge1xuICAgICAgICAgIHRoaXMucnVsZSh0b2tlbnMpXG4gICAgICAgICAgcmV0dXJuXG4gICAgICAgIH0gZWxzZSBpZiAodHlwZSA9PT0gJ30nKSB7XG4gICAgICAgICAgdGhpcy50b2tlbml6ZXIuYmFjayh0b2tlbnMucG9wKCkpXG4gICAgICAgICAgZW5kID0gdHJ1ZVxuICAgICAgICAgIGJyZWFrXG4gICAgICAgIH0gZWxzZSBpZiAodHlwZSA9PT0gJzonKSB7XG4gICAgICAgICAgY29sb24gPSB0cnVlXG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSBpZiAodHlwZSA9PT0gYnJhY2tldHNbYnJhY2tldHMubGVuZ3RoIC0gMV0pIHtcbiAgICAgICAgYnJhY2tldHMucG9wKClcbiAgICAgICAgaWYgKGJyYWNrZXRzLmxlbmd0aCA9PT0gMCkgYnJhY2tldCA9IG51bGxcbiAgICAgIH1cblxuICAgICAgdG9rZW4gPSB0aGlzLnRva2VuaXplci5uZXh0VG9rZW4oKVxuICAgIH1cblxuICAgIGlmICh0aGlzLnRva2VuaXplci5lbmRPZkZpbGUoKSkgZW5kID0gdHJ1ZVxuICAgIGlmIChicmFja2V0cy5sZW5ndGggPiAwKSB0aGlzLnVuY2xvc2VkQnJhY2tldChicmFja2V0KVxuXG4gICAgaWYgKGVuZCAmJiBjb2xvbikge1xuICAgICAgd2hpbGUgKHRva2Vucy5sZW5ndGgpIHtcbiAgICAgICAgdG9rZW4gPSB0b2tlbnNbdG9rZW5zLmxlbmd0aCAtIDFdWzBdXG4gICAgICAgIGlmICh0b2tlbiAhPT0gJ3NwYWNlJyAmJiB0b2tlbiAhPT0gJ2NvbW1lbnQnKSBicmVha1xuICAgICAgICB0aGlzLnRva2VuaXplci5iYWNrKHRva2Vucy5wb3AoKSlcbiAgICAgIH1cbiAgICAgIHRoaXMuZGVjbCh0b2tlbnMpXG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMudW5rbm93bldvcmQodG9rZW5zKVxuICAgIH1cbiAgfVxuXG4gIHJ1bGUgKHRva2Vucykge1xuICAgIHRva2Vucy5wb3AoKVxuXG4gICAgbGV0IG5vZGUgPSBuZXcgUnVsZSgpXG4gICAgdGhpcy5pbml0KG5vZGUsIHRva2Vuc1swXVsyXSwgdG9rZW5zWzBdWzNdKVxuXG4gICAgbm9kZS5yYXdzLmJldHdlZW4gPSB0aGlzLnNwYWNlc0FuZENvbW1lbnRzRnJvbUVuZCh0b2tlbnMpXG4gICAgdGhpcy5yYXcobm9kZSwgJ3NlbGVjdG9yJywgdG9rZW5zKVxuICAgIHRoaXMuY3VycmVudCA9IG5vZGVcbiAgfVxuXG4gIGRlY2wgKHRva2Vucykge1xuICAgIGxldCBub2RlID0gbmV3IERlY2xhcmF0aW9uKClcbiAgICB0aGlzLmluaXQobm9kZSlcblxuICAgIGxldCBsYXN0ID0gdG9rZW5zW3Rva2Vucy5sZW5ndGggLSAxXVxuICAgIGlmIChsYXN0WzBdID09PSAnOycpIHtcbiAgICAgIHRoaXMuc2VtaWNvbG9uID0gdHJ1ZVxuICAgICAgdG9rZW5zLnBvcCgpXG4gICAgfVxuICAgIGlmIChsYXN0WzRdKSB7XG4gICAgICBub2RlLnNvdXJjZS5lbmQgPSB7IGxpbmU6IGxhc3RbNF0sIGNvbHVtbjogbGFzdFs1XSB9XG4gICAgfSBlbHNlIHtcbiAgICAgIG5vZGUuc291cmNlLmVuZCA9IHsgbGluZTogbGFzdFsyXSwgY29sdW1uOiBsYXN0WzNdIH1cbiAgICB9XG5cbiAgICB3aGlsZSAodG9rZW5zWzBdWzBdICE9PSAnd29yZCcpIHtcbiAgICAgIGlmICh0b2tlbnMubGVuZ3RoID09PSAxKSB0aGlzLnVua25vd25Xb3JkKHRva2VucylcbiAgICAgIG5vZGUucmF3cy5iZWZvcmUgKz0gdG9rZW5zLnNoaWZ0KClbMV1cbiAgICB9XG4gICAgbm9kZS5zb3VyY2Uuc3RhcnQgPSB7IGxpbmU6IHRva2Vuc1swXVsyXSwgY29sdW1uOiB0b2tlbnNbMF1bM10gfVxuXG4gICAgbm9kZS5wcm9wID0gJydcbiAgICB3aGlsZSAodG9rZW5zLmxlbmd0aCkge1xuICAgICAgbGV0IHR5cGUgPSB0b2tlbnNbMF1bMF1cbiAgICAgIGlmICh0eXBlID09PSAnOicgfHwgdHlwZSA9PT0gJ3NwYWNlJyB8fCB0eXBlID09PSAnY29tbWVudCcpIHtcbiAgICAgICAgYnJlYWtcbiAgICAgIH1cbiAgICAgIG5vZGUucHJvcCArPSB0b2tlbnMuc2hpZnQoKVsxXVxuICAgIH1cblxuICAgIG5vZGUucmF3cy5iZXR3ZWVuID0gJydcblxuICAgIGxldCB0b2tlblxuICAgIHdoaWxlICh0b2tlbnMubGVuZ3RoKSB7XG4gICAgICB0b2tlbiA9IHRva2Vucy5zaGlmdCgpXG5cbiAgICAgIGlmICh0b2tlblswXSA9PT0gJzonKSB7XG4gICAgICAgIG5vZGUucmF3cy5iZXR3ZWVuICs9IHRva2VuWzFdXG4gICAgICAgIGJyZWFrXG4gICAgICB9IGVsc2Uge1xuICAgICAgICBpZiAodG9rZW5bMF0gPT09ICd3b3JkJyAmJiAvXFx3Ly50ZXN0KHRva2VuWzFdKSkge1xuICAgICAgICAgIHRoaXMudW5rbm93bldvcmQoW3Rva2VuXSlcbiAgICAgICAgfVxuICAgICAgICBub2RlLnJhd3MuYmV0d2VlbiArPSB0b2tlblsxXVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmIChub2RlLnByb3BbMF0gPT09ICdfJyB8fCBub2RlLnByb3BbMF0gPT09ICcqJykge1xuICAgICAgbm9kZS5yYXdzLmJlZm9yZSArPSBub2RlLnByb3BbMF1cbiAgICAgIG5vZGUucHJvcCA9IG5vZGUucHJvcC5zbGljZSgxKVxuICAgIH1cbiAgICBub2RlLnJhd3MuYmV0d2VlbiArPSB0aGlzLnNwYWNlc0FuZENvbW1lbnRzRnJvbVN0YXJ0KHRva2VucylcbiAgICB0aGlzLnByZWNoZWNrTWlzc2VkU2VtaWNvbG9uKHRva2VucylcblxuICAgIGZvciAobGV0IGkgPSB0b2tlbnMubGVuZ3RoIC0gMTsgaSA+IDA7IGktLSkge1xuICAgICAgdG9rZW4gPSB0b2tlbnNbaV1cbiAgICAgIGlmICh0b2tlblsxXS50b0xvd2VyQ2FzZSgpID09PSAnIWltcG9ydGFudCcpIHtcbiAgICAgICAgbm9kZS5pbXBvcnRhbnQgPSB0cnVlXG4gICAgICAgIGxldCBzdHJpbmcgPSB0aGlzLnN0cmluZ0Zyb20odG9rZW5zLCBpKVxuICAgICAgICBzdHJpbmcgPSB0aGlzLnNwYWNlc0Zyb21FbmQodG9rZW5zKSArIHN0cmluZ1xuICAgICAgICBpZiAoc3RyaW5nICE9PSAnICFpbXBvcnRhbnQnKSBub2RlLnJhd3MuaW1wb3J0YW50ID0gc3RyaW5nXG4gICAgICAgIGJyZWFrXG4gICAgICB9IGVsc2UgaWYgKHRva2VuWzFdLnRvTG93ZXJDYXNlKCkgPT09ICdpbXBvcnRhbnQnKSB7XG4gICAgICAgIGxldCBjYWNoZSA9IHRva2Vucy5zbGljZSgwKVxuICAgICAgICBsZXQgc3RyID0gJydcbiAgICAgICAgZm9yIChsZXQgaiA9IGk7IGogPiAwOyBqLS0pIHtcbiAgICAgICAgICBsZXQgdHlwZSA9IGNhY2hlW2pdWzBdXG4gICAgICAgICAgaWYgKHN0ci50cmltKCkuaW5kZXhPZignIScpID09PSAwICYmIHR5cGUgIT09ICdzcGFjZScpIHtcbiAgICAgICAgICAgIGJyZWFrXG4gICAgICAgICAgfVxuICAgICAgICAgIHN0ciA9IGNhY2hlLnBvcCgpWzFdICsgc3RyXG4gICAgICAgIH1cbiAgICAgICAgaWYgKHN0ci50cmltKCkuaW5kZXhPZignIScpID09PSAwKSB7XG4gICAgICAgICAgbm9kZS5pbXBvcnRhbnQgPSB0cnVlXG4gICAgICAgICAgbm9kZS5yYXdzLmltcG9ydGFudCA9IHN0clxuICAgICAgICAgIHRva2VucyA9IGNhY2hlXG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgaWYgKHRva2VuWzBdICE9PSAnc3BhY2UnICYmIHRva2VuWzBdICE9PSAnY29tbWVudCcpIHtcbiAgICAgICAgYnJlYWtcbiAgICAgIH1cbiAgICB9XG5cbiAgICB0aGlzLnJhdyhub2RlLCAndmFsdWUnLCB0b2tlbnMpXG5cbiAgICBpZiAobm9kZS52YWx1ZS5pbmRleE9mKCc6JykgIT09IC0xKSB0aGlzLmNoZWNrTWlzc2VkU2VtaWNvbG9uKHRva2VucylcbiAgfVxuXG4gIGF0cnVsZSAodG9rZW4pIHtcbiAgICBsZXQgbm9kZSA9IG5ldyBBdFJ1bGUoKVxuICAgIG5vZGUubmFtZSA9IHRva2VuWzFdLnNsaWNlKDEpXG4gICAgaWYgKG5vZGUubmFtZSA9PT0gJycpIHtcbiAgICAgIHRoaXMudW5uYW1lZEF0cnVsZShub2RlLCB0b2tlbilcbiAgICB9XG4gICAgdGhpcy5pbml0KG5vZGUsIHRva2VuWzJdLCB0b2tlblszXSlcblxuICAgIGxldCBwcmV2XG4gICAgbGV0IHNoaWZ0XG4gICAgbGV0IGxhc3QgPSBmYWxzZVxuICAgIGxldCBvcGVuID0gZmFsc2VcbiAgICBsZXQgcGFyYW1zID0gW11cblxuICAgIHdoaWxlICghdGhpcy50b2tlbml6ZXIuZW5kT2ZGaWxlKCkpIHtcbiAgICAgIHRva2VuID0gdGhpcy50b2tlbml6ZXIubmV4dFRva2VuKClcblxuICAgICAgaWYgKHRva2VuWzBdID09PSAnOycpIHtcbiAgICAgICAgbm9kZS5zb3VyY2UuZW5kID0geyBsaW5lOiB0b2tlblsyXSwgY29sdW1uOiB0b2tlblszXSB9XG4gICAgICAgIHRoaXMuc2VtaWNvbG9uID0gdHJ1ZVxuICAgICAgICBicmVha1xuICAgICAgfSBlbHNlIGlmICh0b2tlblswXSA9PT0gJ3snKSB7XG4gICAgICAgIG9wZW4gPSB0cnVlXG4gICAgICAgIGJyZWFrXG4gICAgICB9IGVsc2UgaWYgKHRva2VuWzBdID09PSAnfScpIHtcbiAgICAgICAgaWYgKHBhcmFtcy5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgc2hpZnQgPSBwYXJhbXMubGVuZ3RoIC0gMVxuICAgICAgICAgIHByZXYgPSBwYXJhbXNbc2hpZnRdXG4gICAgICAgICAgd2hpbGUgKHByZXYgJiYgcHJldlswXSA9PT0gJ3NwYWNlJykge1xuICAgICAgICAgICAgcHJldiA9IHBhcmFtc1stLXNoaWZ0XVxuICAgICAgICAgIH1cbiAgICAgICAgICBpZiAocHJldikge1xuICAgICAgICAgICAgbm9kZS5zb3VyY2UuZW5kID0geyBsaW5lOiBwcmV2WzRdLCBjb2x1bW46IHByZXZbNV0gfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICB0aGlzLmVuZCh0b2tlbilcbiAgICAgICAgYnJlYWtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHBhcmFtcy5wdXNoKHRva2VuKVxuICAgICAgfVxuXG4gICAgICBpZiAodGhpcy50b2tlbml6ZXIuZW5kT2ZGaWxlKCkpIHtcbiAgICAgICAgbGFzdCA9IHRydWVcbiAgICAgICAgYnJlYWtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBub2RlLnJhd3MuYmV0d2VlbiA9IHRoaXMuc3BhY2VzQW5kQ29tbWVudHNGcm9tRW5kKHBhcmFtcylcbiAgICBpZiAocGFyYW1zLmxlbmd0aCkge1xuICAgICAgbm9kZS5yYXdzLmFmdGVyTmFtZSA9IHRoaXMuc3BhY2VzQW5kQ29tbWVudHNGcm9tU3RhcnQocGFyYW1zKVxuICAgICAgdGhpcy5yYXcobm9kZSwgJ3BhcmFtcycsIHBhcmFtcylcbiAgICAgIGlmIChsYXN0KSB7XG4gICAgICAgIHRva2VuID0gcGFyYW1zW3BhcmFtcy5sZW5ndGggLSAxXVxuICAgICAgICBub2RlLnNvdXJjZS5lbmQgPSB7IGxpbmU6IHRva2VuWzRdLCBjb2x1bW46IHRva2VuWzVdIH1cbiAgICAgICAgdGhpcy5zcGFjZXMgPSBub2RlLnJhd3MuYmV0d2VlblxuICAgICAgICBub2RlLnJhd3MuYmV0d2VlbiA9ICcnXG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIG5vZGUucmF3cy5hZnRlck5hbWUgPSAnJ1xuICAgICAgbm9kZS5wYXJhbXMgPSAnJ1xuICAgIH1cblxuICAgIGlmIChvcGVuKSB7XG4gICAgICBub2RlLm5vZGVzID0gW11cbiAgICAgIHRoaXMuY3VycmVudCA9IG5vZGVcbiAgICB9XG4gIH1cblxuICBlbmQgKHRva2VuKSB7XG4gICAgaWYgKHRoaXMuY3VycmVudC5ub2RlcyAmJiB0aGlzLmN1cnJlbnQubm9kZXMubGVuZ3RoKSB7XG4gICAgICB0aGlzLmN1cnJlbnQucmF3cy5zZW1pY29sb24gPSB0aGlzLnNlbWljb2xvblxuICAgIH1cbiAgICB0aGlzLnNlbWljb2xvbiA9IGZhbHNlXG5cbiAgICB0aGlzLmN1cnJlbnQucmF3cy5hZnRlciA9ICh0aGlzLmN1cnJlbnQucmF3cy5hZnRlciB8fCAnJykgKyB0aGlzLnNwYWNlc1xuICAgIHRoaXMuc3BhY2VzID0gJydcblxuICAgIGlmICh0aGlzLmN1cnJlbnQucGFyZW50KSB7XG4gICAgICB0aGlzLmN1cnJlbnQuc291cmNlLmVuZCA9IHsgbGluZTogdG9rZW5bMl0sIGNvbHVtbjogdG9rZW5bM10gfVxuICAgICAgdGhpcy5jdXJyZW50ID0gdGhpcy5jdXJyZW50LnBhcmVudFxuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnVuZXhwZWN0ZWRDbG9zZSh0b2tlbilcbiAgICB9XG4gIH1cblxuICBlbmRGaWxlICgpIHtcbiAgICBpZiAodGhpcy5jdXJyZW50LnBhcmVudCkgdGhpcy51bmNsb3NlZEJsb2NrKClcbiAgICBpZiAodGhpcy5jdXJyZW50Lm5vZGVzICYmIHRoaXMuY3VycmVudC5ub2Rlcy5sZW5ndGgpIHtcbiAgICAgIHRoaXMuY3VycmVudC5yYXdzLnNlbWljb2xvbiA9IHRoaXMuc2VtaWNvbG9uXG4gICAgfVxuICAgIHRoaXMuY3VycmVudC5yYXdzLmFmdGVyID0gKHRoaXMuY3VycmVudC5yYXdzLmFmdGVyIHx8ICcnKSArIHRoaXMuc3BhY2VzXG4gIH1cblxuICBmcmVlU2VtaWNvbG9uICh0b2tlbikge1xuICAgIHRoaXMuc3BhY2VzICs9IHRva2VuWzFdXG4gICAgaWYgKHRoaXMuY3VycmVudC5ub2Rlcykge1xuICAgICAgbGV0IHByZXYgPSB0aGlzLmN1cnJlbnQubm9kZXNbdGhpcy5jdXJyZW50Lm5vZGVzLmxlbmd0aCAtIDFdXG4gICAgICBpZiAocHJldiAmJiBwcmV2LnR5cGUgPT09ICdydWxlJyAmJiAhcHJldi5yYXdzLm93blNlbWljb2xvbikge1xuICAgICAgICBwcmV2LnJhd3Mub3duU2VtaWNvbG9uID0gdGhpcy5zcGFjZXNcbiAgICAgICAgdGhpcy5zcGFjZXMgPSAnJ1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIC8vIEhlbHBlcnNcblxuICBpbml0IChub2RlLCBsaW5lLCBjb2x1bW4pIHtcbiAgICB0aGlzLmN1cnJlbnQucHVzaChub2RlKVxuXG4gICAgbm9kZS5zb3VyY2UgPSB7IHN0YXJ0OiB7IGxpbmUsIGNvbHVtbiB9LCBpbnB1dDogdGhpcy5pbnB1dCB9XG4gICAgbm9kZS5yYXdzLmJlZm9yZSA9IHRoaXMuc3BhY2VzXG4gICAgdGhpcy5zcGFjZXMgPSAnJ1xuICAgIGlmIChub2RlLnR5cGUgIT09ICdjb21tZW50JykgdGhpcy5zZW1pY29sb24gPSBmYWxzZVxuICB9XG5cbiAgcmF3IChub2RlLCBwcm9wLCB0b2tlbnMpIHtcbiAgICBsZXQgdG9rZW4sIHR5cGVcbiAgICBsZXQgbGVuZ3RoID0gdG9rZW5zLmxlbmd0aFxuICAgIGxldCB2YWx1ZSA9ICcnXG4gICAgbGV0IGNsZWFuID0gdHJ1ZVxuICAgIGxldCBuZXh0LCBwcmV2XG4gICAgbGV0IHBhdHRlcm4gPSAvXihbLnwjXSk/KFtcXHddKSsvaVxuXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBsZW5ndGg7IGkgKz0gMSkge1xuICAgICAgdG9rZW4gPSB0b2tlbnNbaV1cbiAgICAgIHR5cGUgPSB0b2tlblswXVxuXG4gICAgICBpZiAodHlwZSA9PT0gJ2NvbW1lbnQnICYmIG5vZGUudHlwZSA9PT0gJ3J1bGUnKSB7XG4gICAgICAgIHByZXYgPSB0b2tlbnNbaSAtIDFdXG4gICAgICAgIG5leHQgPSB0b2tlbnNbaSArIDFdXG5cbiAgICAgICAgaWYgKFxuICAgICAgICAgIHByZXZbMF0gIT09ICdzcGFjZScgJiZcbiAgICAgICAgICBuZXh0WzBdICE9PSAnc3BhY2UnICYmXG4gICAgICAgICAgcGF0dGVybi50ZXN0KHByZXZbMV0pICYmXG4gICAgICAgICAgcGF0dGVybi50ZXN0KG5leHRbMV0pXG4gICAgICAgICkge1xuICAgICAgICAgIHZhbHVlICs9IHRva2VuWzFdXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgY2xlYW4gPSBmYWxzZVxuICAgICAgICB9XG5cbiAgICAgICAgY29udGludWVcbiAgICAgIH1cblxuICAgICAgaWYgKHR5cGUgPT09ICdjb21tZW50JyB8fCAodHlwZSA9PT0gJ3NwYWNlJyAmJiBpID09PSBsZW5ndGggLSAxKSkge1xuICAgICAgICBjbGVhbiA9IGZhbHNlXG4gICAgICB9IGVsc2Uge1xuICAgICAgICB2YWx1ZSArPSB0b2tlblsxXVxuICAgICAgfVxuICAgIH1cbiAgICBpZiAoIWNsZWFuKSB7XG4gICAgICBsZXQgcmF3ID0gdG9rZW5zLnJlZHVjZSgoYWxsLCBpKSA9PiBhbGwgKyBpWzFdLCAnJylcbiAgICAgIG5vZGUucmF3c1twcm9wXSA9IHsgdmFsdWUsIHJhdyB9XG4gICAgfVxuICAgIG5vZGVbcHJvcF0gPSB2YWx1ZVxuICB9XG5cbiAgc3BhY2VzQW5kQ29tbWVudHNGcm9tRW5kICh0b2tlbnMpIHtcbiAgICBsZXQgbGFzdFRva2VuVHlwZVxuICAgIGxldCBzcGFjZXMgPSAnJ1xuICAgIHdoaWxlICh0b2tlbnMubGVuZ3RoKSB7XG4gICAgICBsYXN0VG9rZW5UeXBlID0gdG9rZW5zW3Rva2Vucy5sZW5ndGggLSAxXVswXVxuICAgICAgaWYgKGxhc3RUb2tlblR5cGUgIT09ICdzcGFjZScgJiYgbGFzdFRva2VuVHlwZSAhPT0gJ2NvbW1lbnQnKSBicmVha1xuICAgICAgc3BhY2VzID0gdG9rZW5zLnBvcCgpWzFdICsgc3BhY2VzXG4gICAgfVxuICAgIHJldHVybiBzcGFjZXNcbiAgfVxuXG4gIHNwYWNlc0FuZENvbW1lbnRzRnJvbVN0YXJ0ICh0b2tlbnMpIHtcbiAgICBsZXQgbmV4dFxuICAgIGxldCBzcGFjZXMgPSAnJ1xuICAgIHdoaWxlICh0b2tlbnMubGVuZ3RoKSB7XG4gICAgICBuZXh0ID0gdG9rZW5zWzBdWzBdXG4gICAgICBpZiAobmV4dCAhPT0gJ3NwYWNlJyAmJiBuZXh0ICE9PSAnY29tbWVudCcpIGJyZWFrXG4gICAgICBzcGFjZXMgKz0gdG9rZW5zLnNoaWZ0KClbMV1cbiAgICB9XG4gICAgcmV0dXJuIHNwYWNlc1xuICB9XG5cbiAgc3BhY2VzRnJvbUVuZCAodG9rZW5zKSB7XG4gICAgbGV0IGxhc3RUb2tlblR5cGVcbiAgICBsZXQgc3BhY2VzID0gJydcbiAgICB3aGlsZSAodG9rZW5zLmxlbmd0aCkge1xuICAgICAgbGFzdFRva2VuVHlwZSA9IHRva2Vuc1t0b2tlbnMubGVuZ3RoIC0gMV1bMF1cbiAgICAgIGlmIChsYXN0VG9rZW5UeXBlICE9PSAnc3BhY2UnKSBicmVha1xuICAgICAgc3BhY2VzID0gdG9rZW5zLnBvcCgpWzFdICsgc3BhY2VzXG4gICAgfVxuICAgIHJldHVybiBzcGFjZXNcbiAgfVxuXG4gIHN0cmluZ0Zyb20gKHRva2VucywgZnJvbSkge1xuICAgIGxldCByZXN1bHQgPSAnJ1xuICAgIGZvciAobGV0IGkgPSBmcm9tOyBpIDwgdG9rZW5zLmxlbmd0aDsgaSsrKSB7XG4gICAgICByZXN1bHQgKz0gdG9rZW5zW2ldWzFdXG4gICAgfVxuICAgIHRva2Vucy5zcGxpY2UoZnJvbSwgdG9rZW5zLmxlbmd0aCAtIGZyb20pXG4gICAgcmV0dXJuIHJlc3VsdFxuICB9XG5cbiAgY29sb24gKHRva2Vucykge1xuICAgIGxldCBicmFja2V0cyA9IDBcbiAgICBsZXQgdG9rZW4sIHR5cGUsIHByZXZcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRva2Vucy5sZW5ndGg7IGkrKykge1xuICAgICAgdG9rZW4gPSB0b2tlbnNbaV1cbiAgICAgIHR5cGUgPSB0b2tlblswXVxuXG4gICAgICBpZiAodHlwZSA9PT0gJygnKSB7XG4gICAgICAgIGJyYWNrZXRzICs9IDFcbiAgICAgIH1cbiAgICAgIGlmICh0eXBlID09PSAnKScpIHtcbiAgICAgICAgYnJhY2tldHMgLT0gMVxuICAgICAgfVxuICAgICAgaWYgKGJyYWNrZXRzID09PSAwICYmIHR5cGUgPT09ICc6Jykge1xuICAgICAgICBpZiAoIXByZXYpIHtcbiAgICAgICAgICB0aGlzLmRvdWJsZUNvbG9uKHRva2VuKVxuICAgICAgICB9IGVsc2UgaWYgKHByZXZbMF0gPT09ICd3b3JkJyAmJiBwcmV2WzFdID09PSAncHJvZ2lkJykge1xuICAgICAgICAgIGNvbnRpbnVlXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgcmV0dXJuIGlcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBwcmV2ID0gdG9rZW5cbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlXG4gIH1cblxuICAvLyBFcnJvcnNcblxuICB1bmNsb3NlZEJyYWNrZXQgKGJyYWNrZXQpIHtcbiAgICB0aHJvdyB0aGlzLmlucHV0LmVycm9yKCdVbmNsb3NlZCBicmFja2V0JywgYnJhY2tldFsyXSwgYnJhY2tldFszXSlcbiAgfVxuXG4gIHVua25vd25Xb3JkICh0b2tlbnMpIHtcbiAgICB0aHJvdyB0aGlzLmlucHV0LmVycm9yKCdVbmtub3duIHdvcmQnLCB0b2tlbnNbMF1bMl0sIHRva2Vuc1swXVszXSlcbiAgfVxuXG4gIHVuZXhwZWN0ZWRDbG9zZSAodG9rZW4pIHtcbiAgICB0aHJvdyB0aGlzLmlucHV0LmVycm9yKCdVbmV4cGVjdGVkIH0nLCB0b2tlblsyXSwgdG9rZW5bM10pXG4gIH1cblxuICB1bmNsb3NlZEJsb2NrICgpIHtcbiAgICBsZXQgcG9zID0gdGhpcy5jdXJyZW50LnNvdXJjZS5zdGFydFxuICAgIHRocm93IHRoaXMuaW5wdXQuZXJyb3IoJ1VuY2xvc2VkIGJsb2NrJywgcG9zLmxpbmUsIHBvcy5jb2x1bW4pXG4gIH1cblxuICBkb3VibGVDb2xvbiAodG9rZW4pIHtcbiAgICB0aHJvdyB0aGlzLmlucHV0LmVycm9yKCdEb3VibGUgY29sb24nLCB0b2tlblsyXSwgdG9rZW5bM10pXG4gIH1cblxuICB1bm5hbWVkQXRydWxlIChub2RlLCB0b2tlbikge1xuICAgIHRocm93IHRoaXMuaW5wdXQuZXJyb3IoJ0F0LXJ1bGUgd2l0aG91dCBuYW1lJywgdG9rZW5bMl0sIHRva2VuWzNdKVxuICB9XG5cbiAgcHJlY2hlY2tNaXNzZWRTZW1pY29sb24gKC8qIHRva2VucyAqLykge1xuICAgIC8vIEhvb2sgZm9yIFNhZmUgUGFyc2VyXG4gIH1cblxuICBjaGVja01pc3NlZFNlbWljb2xvbiAodG9rZW5zKSB7XG4gICAgbGV0IGNvbG9uID0gdGhpcy5jb2xvbih0b2tlbnMpXG4gICAgaWYgKGNvbG9uID09PSBmYWxzZSkgcmV0dXJuXG5cbiAgICBsZXQgZm91bmRlZCA9IDBcbiAgICBsZXQgdG9rZW5cbiAgICBmb3IgKGxldCBqID0gY29sb24gLSAxOyBqID49IDA7IGotLSkge1xuICAgICAgdG9rZW4gPSB0b2tlbnNbal1cbiAgICAgIGlmICh0b2tlblswXSAhPT0gJ3NwYWNlJykge1xuICAgICAgICBmb3VuZGVkICs9IDFcbiAgICAgICAgaWYgKGZvdW5kZWQgPT09IDIpIGJyZWFrXG4gICAgICB9XG4gICAgfVxuICAgIHRocm93IHRoaXMuaW5wdXQuZXJyb3IoJ01pc3NlZCBzZW1pY29sb24nLCB0b2tlblsyXSwgdG9rZW5bM10pXG4gIH1cbn1cbiJdLCJmaWxlIjoicGFyc2VyLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/postcss.d.ts b/node_modules/autoprefixer/node_modules/postcss/lib/postcss.d.ts
new file mode 100644
index 0000000..5a8d2d9
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/postcss.d.ts
@@ -0,0 +1,1277 @@
+import * as mozilla from 'source-map';
+
+/**
+ * @param plugins Can also be included with the Processor#use method.
+ * @returns A processor that will apply plugins as CSS processors.
+ */
+declare function postcss(plugins?: postcss.AcceptedPlugin[]): postcss.Processor;
+declare function postcss(...plugins: postcss.AcceptedPlugin[]): postcss.Processor;
+declare namespace postcss {
+ type AcceptedPlugin = Plugin<any> | Transformer | {
+ postcss: TransformCallback | Processor;
+ } | Processor;
+ /**
+ * Creates a PostCSS plugin with a standard API.
+ * @param name Plugin name. Same as in name property in package.json. It will
+ * be saved in plugin.postcssPlugin property.
+ * @param initializer Will receive plugin options and should return functions
+ * to modify nodes in input CSS.
+ */
+ function plugin<T>(name: string, initializer: PluginInitializer<T>): Plugin<T>;
+ interface Plugin<T> extends Transformer {
+ (opts?: T): Transformer;
+ postcss: Transformer;
+ process: (css: string | {
+ toString(): string;
+ } | Result, opts?: any) => LazyResult;
+ }
+ interface Transformer extends TransformCallback {
+ postcssPlugin?: string;
+ postcssVersion?: string;
+ }
+ interface TransformCallback {
+ /**
+ * @returns A Promise that resolves when all work is complete. May return
+ * synchronously, but that style of plugin is only meant for debugging and
+ * development. In either case, the resolved or returned value is not used -
+ * the "result" is the output.
+ */
+ (root: Root, result: Result): Promise<any> | any;
+ }
+ interface PluginInitializer<T> {
+ (pluginOptions?: T): Transformer;
+ }
+ /**
+ * Contains helpers for working with vendor prefixes.
+ */
+ export namespace vendor {
+ /**
+ * @returns The vendor prefix extracted from the input string.
+ */
+ function prefix(prop: string): string;
+ /**
+ * @returns The input string stripped of its vendor prefix.
+ */
+ function unprefixed(prop: string): string;
+ }
+ type ParserInput = string | { toString(): string };
+ interface Parser {
+ (css: ParserInput, opts?: Pick<ProcessOptions, 'map' | 'from'>): Root;
+ }
+ interface Builder {
+ (part: string, node?: Node, type?: 'start' | 'end'): void;
+ }
+ interface Stringifier {
+ (node: Node, builder: Builder): void;
+ }
+ /**
+ * Default function to convert a node tree into a CSS string.
+ */
+ const stringify: Stringifier;
+ /**
+ * Parses source CSS.
+ * @param css The CSS to parse.
+ * @param options
+ * @returns {} A new Root node, which contains the source CSS nodes.
+ */
+ const parse: Parser;
+ /**
+ * Contains helpers for safely splitting lists of CSS values, preserving
+ * parentheses and quotes.
+ */
+ export namespace list {
+ /**
+ * Safely splits space-separated values (such as those for background,
+ * border-radius and other shorthand properties).
+ */
+ function space(str: string): string[];
+ /**
+ * Safely splits comma-separated values (such as those for transition-* and
+ * background properties).
+ */
+ function comma(str: string): string[];
+ }
+ /**
+ * Creates a new Comment node.
+ * @param defaults Properties for the new Comment node.
+ * @returns The new node.
+ */
+ function comment(defaults?: CommentNewProps): Comment;
+ /**
+ * Creates a new AtRule node.
+ * @param defaults Properties for the new AtRule node.
+ * @returns The new node.
+ */
+ function atRule(defaults?: AtRuleNewProps): AtRule;
+ /**
+ * Creates a new Declaration node.
+ * @param defaults Properties for the new Declaration node.
+ * @returns The new node.
+ */
+ function decl(defaults?: DeclarationNewProps): Declaration;
+ /**
+ * Creates a new Rule node.
+ * @param defaults Properties for the new Rule node.
+ * @returns The new node.
+ */
+ function rule(defaults?: RuleNewProps): Rule;
+ /**
+ * Creates a new Root node.
+ * @param defaults Properties for the new Root node.
+ * @returns The new node.
+ */
+ function root(defaults?: object): Root;
+ interface SourceMapOptions {
+ /**
+ * Indicates that the source map should be embedded in the output CSS as a
+ * Base64-encoded comment. By default, it is true. But if all previous maps
+ * are external, not inline, PostCSS will not embed the map even if you do
+ * not set this option.
+ *
+ * If you have an inline source map, the result.map property will be empty,
+ * as the source map will be contained within the text of result.css.
+ */
+ inline?: boolean;
+ /**
+ * Source map content from a previous processing step (e.g., Sass compilation).
+ * PostCSS will try to read the previous source map automatically (based on comments
+ * within the source CSS), but you can use this option to identify it manually.
+ * If desired, you can omit the previous map with prev: false.
+ */
+ prev?: any;
+ /**
+ * Indicates that PostCSS should set the origin content (e.g., Sass source)
+ * of the source map. By default, it is true. But if all previous maps do not
+ * contain sources content, PostCSS will also leave it out even if you do not set
+ * this option.
+ */
+ sourcesContent?: boolean;
+ /**
+ * Indicates that PostCSS should add annotation comments to the CSS. By default,
+ * PostCSS will always add a comment with a path to the source map. PostCSS will
+ * not add annotations to CSS files that do not contain any comments.
+ *
+ * By default, PostCSS presumes that you want to save the source map as
+ * opts.to + '.map' and will use this path in the annotation comment. A different
+ * path can be set by providing a string value for annotation.
+ *
+ * If you have set inline: true, annotation cannot be disabled.
+ */
+ annotation?: string | false;
+ /**
+ * Override "from" in map's sources.
+ */
+ from?: string;
+ }
+ /**
+ * A Processor instance contains plugins to process CSS. Create one
+ * Processor instance, initialize its plugins, and then use that instance
+ * on numerous CSS files.
+ */
+ interface Processor {
+ /**
+ * Adds a plugin to be used as a CSS processor. Plugins can also be
+ * added by passing them as arguments when creating a postcss instance.
+ */
+ use(plugin: AcceptedPlugin): Processor;
+ /**
+ * Parses source CSS. Because some plugins can be asynchronous it doesn't
+ * make any transformations. Transformations will be applied in LazyResult's
+ * methods.
+ * @param css Input CSS or any object with toString() method, like a file
+ * stream. If a Result instance is passed the processor will take the
+ * existing Root parser from it.
+ */
+ process(css: ParserInput | Result | LazyResult | Root, options?: ProcessOptions): LazyResult;
+ /**
+ * Contains plugins added to this processor.
+ */
+ plugins: Plugin<any>[];
+ /**
+ * Contains the current version of PostCSS (e.g., "4.0.5").
+ */
+ version: string;
+ }
+ interface ProcessOptions {
+ /**
+ * The path of the CSS source file. You should always set "from", because it is
+ * used in source map generation and syntax error messages.
+ */
+ from?: string;
+ /**
+ * The path where you'll put the output CSS file. You should always set "to"
+ * to generate correct source maps.
+ */
+ to?: string;
+ /**
+ * Function to generate AST by string.
+ */
+ parser?: Parser;
+ /**
+ * Class to generate string by AST.
+ */
+ stringifier?: Stringifier;
+ /**
+ * Object with parse and stringify.
+ */
+ syntax?: Syntax;
+ /**
+ * Source map options
+ */
+ map?: SourceMapOptions | boolean;
+ }
+ interface Syntax {
+ /**
+ * Function to generate AST by string.
+ */
+ parse?: Parser;
+ /**
+ * Class to generate string by AST.
+ */
+ stringify?: Stringifier;
+ }
+ /**
+ * A promise proxy for the result of PostCSS transformations.
+ */
+ interface LazyResult {
+ /**
+ * Processes input CSS through synchronous and asynchronous plugins.
+ * @param onRejected Called if any plugin throws an error.
+ */
+ then: Promise<Result>["then"];
+ /**
+ * Processes input CSS through synchronous and asynchronous plugins.
+ * @param onRejected Called if any plugin throws an error.
+ */
+ catch: Promise<Result>["catch"];
+ /**
+ * Alias for css property.
+ */
+ toString(): string;
+ /**
+ * Processes input CSS through synchronous plugins and converts Root to
+ * CSS string. This property will only work with synchronous plugins. If
+ * the processor contains any asynchronous plugins it will throw an error.
+ * In this case, you should use LazyResult#then() instead.
+ * @returns Result#css.
+ */
+ css: string;
+ /**
+ * Alias for css property to use when syntaxes generate non-CSS output.
+ */
+ content: string;
+ /**
+ * Processes input CSS through synchronous plugins. This property will
+ * work only with synchronous plugins. If processor contains any
+ * asynchronous plugins it will throw an error. You should use
+ * LazyResult#then() instead.
+ */
+ map: ResultMap;
+ /**
+ * Processes input CSS through synchronous plugins. This property will work
+ * only with synchronous plugins. If processor contains any asynchronous
+ * plugins it will throw an error. You should use LazyResult#then() instead.
+ */
+ root: Root;
+ /**
+ * Processes input CSS through synchronous plugins and calls Result#warnings().
+ * This property will only work with synchronous plugins. If the processor
+ * contains any asynchronous plugins it will throw an error. In this case,
+ * you should use LazyResult#then() instead.
+ */
+ warnings(): Warning[];
+ /**
+ * Processes input CSS through synchronous plugins. This property will work
+ * only with synchronous plugins. If processor contains any asynchronous
+ * plugins it will throw an error. You should use LazyResult#then() instead.
+ */
+ messages: ResultMessage[];
+ /**
+ * @returns A processor used for CSS transformations.
+ */
+ processor: Processor;
+ /**
+ * @returns Options from the Processor#process(css, opts) call that produced
+ * this Result instance.
+ */
+ opts: ResultOptions;
+ }
+ /**
+ * Provides the result of the PostCSS transformations.
+ */
+ interface Result {
+ /**
+ * Alias for css property.
+ */
+ toString(): string;
+ /**
+ * Creates an instance of Warning and adds it to messages.
+ * @param message Used in the text property of the message object.
+ * @param options Properties for Message object.
+ */
+ warn(message: string, options?: WarningOptions): void;
+ /**
+ * @returns Warnings from plugins, filtered from messages.
+ */
+ warnings(): Warning[];
+ /**
+ * A CSS string representing this Result's Root instance.
+ */
+ css: string;
+ /**
+ * Alias for css property to use with syntaxes that generate non-CSS output.
+ */
+ content: string;
+ /**
+ * An instance of the SourceMapGenerator class from the source-map library,
+ * representing changes to the Result's Root instance.
+ * This property will have a value only if the user does not want an inline
+ * source map. By default, PostCSS generates inline source maps, written
+ * directly into the processed CSS. The map property will be empty by default.
+ * An external source map will be generated — and assigned to map — only if
+ * the user has set the map.inline option to false, or if PostCSS was passed
+ * an external input source map.
+ */
+ map: ResultMap;
+ /**
+ * Contains the Root node after all transformations.
+ */
+ root?: Root;
+ /**
+ * Contains messages from plugins (e.g., warnings or custom messages).
+ * Add a warning using Result#warn() and get all warnings
+ * using the Result#warnings() method.
+ */
+ messages: ResultMessage[];
+ /**
+ * The Processor instance used for this transformation.
+ */
+ processor?: Processor;
+ /**
+ * Options from the Processor#process(css, opts) or Root#toResult(opts) call
+ * that produced this Result instance.
+ */
+ opts?: ResultOptions;
+ }
+ interface ResultOptions extends ProcessOptions {
+ /**
+ * The CSS node that was the source of the warning.
+ */
+ node?: postcss.Node;
+ /**
+ * Name of plugin that created this warning. Result#warn() will fill it
+ * automatically with plugin.postcssPlugin value.
+ */
+ plugin?: string;
+ }
+ interface ResultMap {
+ /**
+ * Add a single mapping from original source line and column to the generated
+ * source's line and column for this source map being created. The mapping
+ * object should have the following properties:
+ * @param mapping
+ * @returns {}
+ */
+ addMapping(mapping: mozilla.Mapping): void;
+ /**
+ * Set the source content for an original source file.
+ * @param sourceFile The URL of the original source file.
+ * @param sourceContent The content of the source file.
+ */
+ setSourceContent(sourceFile: string, sourceContent: string): void;
+ /**
+ * Applies a SourceMap for a source file to the SourceMap. Each mapping to
+ * the supplied source file is rewritten using the supplied SourceMap.
+ * Note: The resolution for the resulting mappings is the minimum of this
+ * map and the supplied map.
+ * @param sourceMapConsumer The SourceMap to be applied.
+ * @param sourceFile The filename of the source file. If omitted, sourceMapConsumer
+ * file will be used, if it exists. Otherwise an error will be thrown.
+ * @param sourceMapPath The dirname of the path to the SourceMap to be applied.
+ * If relative, it is relative to the SourceMap. This parameter is needed when
+ * the two SourceMaps aren't in the same directory, and the SourceMap to be
+ * applied contains relative source paths. If so, those relative source paths
+ * need to be rewritten relative to the SourceMap.
+ * If omitted, it is assumed that both SourceMaps are in the same directory;
+ * thus, not needing any rewriting (Supplying '.' has the same effect).
+ */
+ applySourceMap(
+ sourceMapConsumer: mozilla.SourceMapConsumer,
+ sourceFile?: string,
+ sourceMapPath?: string
+ ): void;
+ /**
+ * Renders the source map being generated to JSON.
+ */
+ toJSON: () => mozilla.RawSourceMap;
+ /**
+ * Renders the source map being generated to a string.
+ */
+ toString: () => string;
+ }
+ interface ResultMessage {
+ type: string;
+ plugin: string;
+ [others: string]: any;
+ }
+ /**
+ * Represents a plugin warning. It can be created using Result#warn().
+ */
+ interface Warning {
+ /**
+ * @returns Error position, message.
+ */
+ toString(): string;
+ /**
+ * Contains the warning message.
+ */
+ text: string;
+ /**
+ * Contains the name of the plugin that created this warning. When you
+ * call Result#warn(), it will fill this property automatically.
+ */
+ plugin: string;
+ /**
+ * The CSS node that caused the warning.
+ */
+ node: Node;
+ /**
+ * The line in the input file with this warning's source.
+ */
+ line: number;
+ /**
+ * Column in the input file with this warning's source.
+ */
+ column: number;
+ }
+ interface WarningOptions extends ResultOptions {
+ /**
+ * A word inside a node's string that should be highlighted as source
+ * of warning.
+ */
+ word?: string;
+ /**
+ * The index inside a node's string that should be highlighted as
+ * source of warning.
+ */
+ index?: number;
+ }
+ /**
+ * The CSS parser throws this error for broken CSS.
+ */
+ interface CssSyntaxError extends InputOrigin {
+ name: string;
+ /**
+ * @returns Error position, message and source code of broken part.
+ */
+ toString(): string;
+ /**
+ * @param color Whether arrow should be colored red by terminal color codes.
+ * By default, PostCSS will use process.stdout.isTTY and
+ * process.env.NODE_DISABLE_COLORS.
+ * @returns A few lines of CSS source that caused the error. If CSS has
+ * input source map without sourceContent this method will return an empty
+ * string.
+ */
+ showSourceCode(color?: boolean): string;
+ /**
+ * Contains full error text in the GNU error format.
+ */
+ message: string;
+ /**
+ * Contains only the error description.
+ */
+ reason: string;
+ /**
+ * Contains the PostCSS plugin name if the error didn't come from the
+ * CSS parser.
+ */
+ plugin?: string;
+ input?: InputOrigin;
+ }
+ interface InputOrigin {
+ /**
+ * If parser's from option is set, contains the absolute path to the
+ * broken file. PostCSS will use the input source map to detect the
+ * original error location. If you wrote a Sass file, then compiled it
+ * to CSS and parsed it with PostCSS, PostCSS will show the original
+ * position in the Sass file. If you need the position in the PostCSS
+ * input (e.g., to debug the previous compiler), use error.input.file.
+ */
+ file?: string;
+ /**
+ * Contains the source line of the error. PostCSS will use the input
+ * source map to detect the original error location. If you wrote a Sass
+ * file, then compiled it to CSS and parsed it with PostCSS, PostCSS
+ * will show the original position in the Sass file. If you need the
+ * position in the PostCSS input (e.g., to debug the previous
+ * compiler), use error.input.line.
+ */
+ line?: number;
+ /**
+ * Contains the source column of the error. PostCSS will use input
+ * source map to detect the original error location. If you wrote a
+ * Sass file, then compiled it to CSS and parsed it with PostCSS,
+ * PostCSS will show the original position in the Sass file. If you
+ * need the position in the PostCSS input (e.g., to debug the
+ * previous compiler), use error.input.column.
+ */
+ column?: number;
+ /**
+ * Contains the source code of the broken file. PostCSS will use the
+ * input source map to detect the original error location. If you wrote
+ * a Sass file, then compiled it to CSS and parsed it with PostCSS,
+ * PostCSS will show the original position in the Sass file. If you need
+ * the position in the PostCSS input (e.g., to debug the previous
+ * compiler), use error.input.source.
+ */
+ source?: string;
+ }
+ export class PreviousMap {
+ private inline;
+ annotation: string;
+ root: string;
+ private consumerCache;
+ text: string;
+ file: string;
+ constructor(css: any, opts: any);
+ consumer(): mozilla.SourceMapConsumer;
+ withContent(): boolean;
+ startWith(string: string, start: string): boolean;
+ loadAnnotation(css: string): void;
+ decodeInline(text: string): string;
+ loadMap(
+ file: any,
+ prev: string | Function | mozilla.SourceMapConsumer | mozilla.SourceMapGenerator | mozilla.RawSourceMap
+ ): string;
+ isMap(map: any): boolean;
+ }
+ /**
+ * Represents the source CSS.
+ */
+ interface Input {
+ /**
+ * The absolute path to the CSS source file defined with the "from" option.
+ * Either this property or the "id" property are always defined.
+ */
+ file?: string;
+ /**
+ * The unique ID of the CSS source. Used if "from" option is not provided
+ * (because PostCSS does not know the file path). Either this property
+ * or the "file" property are always defined.
+ */
+ id?: string;
+ /**
+ * The CSS source identifier. Contains input.file if the user set the
+ * "from" option, or input.id if they did not.
+ */
+ from: string;
+ /**
+ * Represents the input source map passed from a compilation step before
+ * PostCSS (e.g., from the Sass compiler).
+ */
+ map: PreviousMap;
+ /**
+ * The flag to indicate whether or not the source code has Unicode BOM.
+ */
+ hasBOM: boolean;
+ /**
+ * Reads the input source map.
+ * @returns A symbol position in the input source (e.g., in a Sass file
+ * that was compiled to CSS before being passed to PostCSS):
+ */
+ origin(line: number, column: number): InputOrigin;
+ }
+ type ChildNode = AtRule | Rule | Declaration | Comment;
+ type Node = Root | ChildNode;
+ interface NodeBase {
+ /**
+ * Returns the input source of the node. The property is used in source
+ * map generation. If you create a node manually
+ * (e.g., with postcss.decl() ), that node will not have a source
+ * property and will be absent from the source map. For this reason, the
+ * plugin developer should consider cloning nodes to create new ones
+ * (in which case the new node's source will reference the original,
+ * cloned node) or setting the source property manually.
+ */
+ source?: NodeSource;
+ /**
+ * Contains information to generate byte-to-byte equal node string as it
+ * was in origin input.
+ */
+ raws: NodeRaws;
+ /**
+ * @returns A CSS string representing the node.
+ */
+ toString(): string;
+ /**
+ * This method produces very useful error messages. If present, an input
+ * source map will be used to get the original position of the source, even
+ * from a previous compilation step (e.g., from Sass compilation).
+ * @returns The original position of the node in the source, showing line
+ * and column numbers and also a small excerpt to facilitate debugging.
+ */
+ error(
+ /**
+ * Error description.
+ */
+ message: string, options?: NodeErrorOptions): CssSyntaxError;
+ /**
+ * Creates an instance of Warning and adds it to messages. This method is
+ * provided as a convenience wrapper for Result#warn.
+ * Note that `opts.node` is automatically passed to Result#warn for you.
+ * @param result The result that will receive the warning.
+ * @param text Warning message. It will be used in the `text` property of
+ * the message object.
+ * @param opts Properties to assign to the message object.
+ */
+ warn(result: Result, text: string, opts?: WarningOptions): void;
+ /**
+ * @returns The next child of the node's parent; or, returns undefined if
+ * the current node is the last child.
+ */
+ next(): ChildNode | void;
+ /**
+ * @returns The previous child of the node's parent; or, returns undefined
+ * if the current node is the first child.
+ */
+ prev(): ChildNode | void;
+ /**
+ * Insert new node before current node to current node’s parent.
+ *
+ * Just an alias for `node.parent.insertBefore(node, newNode)`.
+ *
+ * @returns this node for method chaining.
+ *
+ * @example
+ * decl.before('content: ""');
+ */
+ before(newNode: Node | object | string | Node[]): this;
+ /**
+ * Insert new node after current node to current node’s parent.
+ *
+ * Just an alias for `node.parent.insertAfter(node, newNode)`.
+ *
+ * @returns this node for method chaining.
+ *
+ * @example
+ * decl.after('color: black');
+ */
+ after(newNode: Node | object | string | Node[]): this;
+ /**
+ * @returns The Root instance of the node's tree.
+ */
+ root(): Root;
+ /**
+ * Removes the node from its parent and cleans the parent property in the
+ * node and its children.
+ * @returns This node for chaining.
+ */
+ remove(): this;
+ /**
+ * Inserts node(s) before the current node and removes the current node.
+ * @returns This node for chaining.
+ */
+ replaceWith(...nodes: (Node | object)[]): this;
+ /**
+ * @param overrides New properties to override in the clone.
+ * @returns A clone of this node. The node and its (cloned) children will
+ * have a clean parent and code style properties.
+ */
+ clone(overrides?: object): this;
+ /**
+ * Shortcut to clone the node and insert the resulting cloned node before
+ * the current node.
+ * @param overrides New Properties to override in the clone.
+ * @returns The cloned node.
+ */
+ cloneBefore(overrides?: object): this;
+ /**
+ * Shortcut to clone the node and insert the resulting cloned node after
+ * the current node.
+ * @param overrides New Properties to override in the clone.
+ * @returns The cloned node.
+ */
+ cloneAfter(overrides?: object): this;
+ /**
+ * @param prop Name or code style property.
+ * @param defaultType Name of default value. It can be easily missed if the
+ * value is the same as prop.
+ * @returns A code style property value. If the node is missing the code
+ * style property (because the node was manually built or cloned), PostCSS
+ * will try to autodetect the code style property by looking at other nodes
+ * in the tree.
+ */
+ raw(prop: string, defaultType?: string): any;
+ }
+ interface NodeNewProps {
+ source?: NodeSource;
+ raws?: NodeRaws;
+ }
+ interface NodeRaws {
+ /**
+ * The space symbols before the node. It also stores `*` and `_`
+ * symbols before the declaration (IE hack).
+ */
+ before?: string;
+ /**
+ * The space symbols after the last child of the node to the end of
+ * the node.
+ */
+ after?: string;
+ /**
+ * The symbols between the property and value for declarations,
+ * selector and "{" for rules, last parameter and "{" for at-rules.
+ */
+ between?: string;
+ /**
+ * True if last child has (optional) semicolon.
+ */
+ semicolon?: boolean;
+ /**
+ * The space between the at-rule's name and parameters.
+ */
+ afterName?: string;
+ /**
+ * The space symbols between "/*" and comment's text.
+ */
+ left?: string;
+ /**
+ * The space symbols between comment's text and "*\/".
+ */
+ right?: string;
+ /**
+ * The content of important statement, if it is not just "!important".
+ */
+ important?: string;
+ }
+ interface NodeSource {
+ input: Input;
+ /**
+ * The starting position of the node's source.
+ */
+ start?: {
+ column: number;
+ line: number;
+ };
+ /**
+ * The ending position of the node's source.
+ */
+ end?: {
+ column: number;
+ line: number;
+ };
+ }
+ interface NodeErrorOptions {
+ /**
+ * Plugin name that created this error. PostCSS will set it automatically.
+ */
+ plugin?: string;
+ /**
+ * A word inside a node's string, that should be highlighted as source
+ * of error.
+ */
+ word?: string;
+ /**
+ * An index inside a node's string that should be highlighted as source
+ * of error.
+ */
+ index?: number;
+ }
+ interface JsonNode {
+ /**
+ * Returns a string representing the node's type. Possible values are
+ * root, atrule, rule, decl or comment.
+ */
+ type?: string;
+ /**
+ * Returns the node's parent node.
+ */
+ parent?: JsonContainer;
+ /**
+ * Returns the input source of the node. The property is used in source
+ * map generation. If you create a node manually (e.g., with
+ * postcss.decl() ), that node will not have a source property and
+ * will be absent from the source map. For this reason, the plugin
+ * developer should consider cloning nodes to create new ones (in which
+ * case the new node's source will reference the original, cloned node)
+ * or setting the source property manually.
+ */
+ source?: NodeSource;
+ /**
+ * Contains information to generate byte-to-byte equal node string as it
+ * was in origin input.
+ */
+ raws?: NodeRaws;
+ }
+ type Container = Root | AtRule | Rule;
+ /**
+ * Containers can store any content. If you write a rule inside a rule,
+ * PostCSS will parse it.
+ */
+ interface ContainerBase extends NodeBase {
+ /**
+ * Contains the container's children.
+ */
+ nodes?: ChildNode[];
+ /**
+ * @returns The container's first child.
+ */
+ first?: ChildNode;
+ /**
+ * @returns The container's last child.
+ */
+ last?: ChildNode;
+ /**
+ * @param overrides New properties to override in the clone.
+ * @returns A clone of this node. The node and its (cloned) children will
+ * have a clean parent and code style properties.
+ */
+ clone(overrides?: object): this;
+ /**
+ * @param child Child of the current container.
+ * @returns The child's index within the container's "nodes" array.
+ */
+ index(child: ChildNode | number): number;
+ /**
+ * Determines whether all child nodes satisfy the specified test.
+ * @param callback A function that accepts up to three arguments. The
+ * every method calls the callback function for each node until the
+ * callback returns false, or until the end of the array.
+ * @returns True if the callback returns true for all of the container's
+ * children.
+ */
+ every(callback: (node: ChildNode, index: number, nodes: ChildNode[]) => any, thisArg?: any): boolean;
+ /**
+ * Determines whether the specified callback returns true for any child node.
+ * @param callback A function that accepts up to three arguments. The some
+ * method calls the callback for each node until the callback returns true,
+ * or until the end of the array.
+ * @param thisArg An object to which the this keyword can refer in the
+ * callback function. If thisArg is omitted, undefined is used as the
+ * this value.
+ * @returns True if callback returns true for (at least) one of the
+ * container's children.
+ */
+ some(callback: (node: ChildNode, index: number, nodes: ChildNode[]) => boolean, thisArg?: any): boolean;
+ /**
+ * Iterates through the container's immediate children, calling the
+ * callback function for each child. If you need to recursively iterate
+ * through all the container's descendant nodes, use container.walk().
+ * Unlike the for {} -cycle or Array#forEach() this iterator is safe if
+ * you are mutating the array of child nodes during iteration.
+ * @param callback Iterator. Returning false will break iteration. Safe
+ * if you are mutating the array of child nodes during iteration. PostCSS
+ * will adjust the current index to match the mutations.
+ * @returns False if the callback returns false during iteration.
+ */
+ each(callback: (node: ChildNode, index: number) => any): boolean | void;
+ /**
+ * Traverses the container's descendant nodes, calling `callback` for each
+ * node. Like container.each(), this method is safe to use if you are
+ * mutating arrays during iteration. If you only need to iterate through
+ * the container's immediate children, use container.each().
+ * @param callback Iterator.
+ */
+ walk(callback: (node: ChildNode, index: number) => any): boolean | void;
+ /**
+ * Traverses the container's descendant nodes, calling `callback` for each
+ * declaration. Like container.each(), this method is safe to use if you
+ * are mutating arrays during iteration.
+ * @param propFilter Filters declarations by property name. Only those
+ * declarations whose property matches propFilter will be iterated over.
+ * @param callback Called for each declaration node within the container.
+ */
+ walkDecls(propFilter: string | RegExp, callback?: (decl: Declaration, index: number) => any): boolean | void;
+ walkDecls(callback: (decl: Declaration, index: number) => any): boolean | void;
+ /**
+ * Traverses the container's descendant nodes, calling `callback` for each
+ * at-rule. Like container.each(), this method is safe to use if you are
+ * mutating arrays during iteration.
+ * @param nameFilter Filters at-rules by name. If provided, iteration
+ * will only happen over at-rules that have matching names.
+ * @param callback Iterator called for each at-rule node within the
+ * container.
+ */
+ walkAtRules(nameFilter: string | RegExp, callback: (atRule: AtRule, index: number) => any): boolean | void;
+ walkAtRules(callback: (atRule: AtRule, index: number) => any): boolean | void;
+ /**
+ * Traverses the container's descendant nodes, calling `callback` for each
+ * rule. Like container.each(), this method is safe to use if you are
+ * mutating arrays during iteration.
+ * @param selectorFilter Filters rules by selector. If provided,
+ * iteration will only happen over rules that have matching names.
+ * @param callback Iterator called for each rule node within the
+ * container.
+ */
+ walkRules(selectorFilter: string | RegExp, callback: (atRule: Rule, index: number) => any): boolean | void;
+ walkRules(callback: (atRule: Rule, index: number) => any): boolean | void;
+ walkRules(selectorFilter: any, callback?: (atRule: Rule, index: number) => any): boolean | void;
+ /**
+ * Traverses the container's descendant nodes, calling `callback` for each
+ * comment. Like container.each(), this method is safe to use if you are
+ * mutating arrays during iteration.
+ * @param callback Iterator called for each comment node within the container.
+ */
+ walkComments(callback: (comment: Comment, indexed: number) => any): void | boolean;
+ /**
+ * Passes all declaration values within the container that match pattern
+ * through the callback, replacing those values with the returned result of
+ * callback. This method is useful if you are using a custom unit or
+ * function and need to iterate through all values.
+ * @param pattern Pattern that we need to replace.
+ * @param options Options to speed up the search.
+ * @param callbackOrReplaceValue String to replace pattern or callback
+ * that will return a new value. The callback will receive the same
+ * arguments as those passed to a function parameter of String#replace.
+ */
+ replaceValues(pattern: string | RegExp, options: {
+ /**
+ * Property names. The method will only search for values that match
+ * regexp within declarations of listed properties.
+ */
+ props?: string[];
+ /**
+ * Used to narrow down values and speed up the regexp search. Searching
+ * every single value with a regexp can be slow. If you pass a fast
+ * string, PostCSS will first check whether the value contains the fast
+ * string; and only if it does will PostCSS check that value against
+ * regexp. For example, instead of just checking for /\d+rem/ on all
+ * values, set fast: 'rem' to first check whether a value has the rem
+ * unit, and only if it does perform the regexp check.
+ */
+ fast?: string;
+ }, callbackOrReplaceValue: string | {
+ (substring: string, ...args: any[]): string;
+ }): this;
+ replaceValues(pattern: string | RegExp, callbackOrReplaceValue: string | {
+ (substring: string, ...args: any[]): string;
+ }): this;
+ /**
+ * Inserts new nodes to the beginning of the container.
+ * Because each node class is identifiable by unique properties, use the
+ * following shortcuts to create nodes in insert methods:
+ * root.prepend({ name: '@charset', params: '"UTF-8"' }); // at-rule
+ * root.prepend({ selector: 'a' }); // rule
+ * rule.prepend({ prop: 'color', value: 'black' }); // declaration
+ * rule.prepend({ text: 'Comment' }) // comment
+ * A string containing the CSS of the new element can also be used. This
+ * approach is slower than the above shortcuts.
+ * root.prepend('a {}');
+ * root.first.prepend('color: black; z-index: 1');
+ * @param nodes New nodes.
+ * @returns This container for chaining.
+ */
+ prepend(...nodes: (Node | object | string)[]): this;
+ /**
+ * Inserts new nodes to the end of the container.
+ * Because each node class is identifiable by unique properties, use the
+ * following shortcuts to create nodes in insert methods:
+ * root.append({ name: '@charset', params: '"UTF-8"' }); // at-rule
+ * root.append({ selector: 'a' }); // rule
+ * rule.append({ prop: 'color', value: 'black' }); // declaration
+ * rule.append({ text: 'Comment' }) // comment
+ * A string containing the CSS of the new element can also be used. This
+ * approach is slower than the above shortcuts.
+ * root.append('a {}');
+ * root.first.append('color: black; z-index: 1');
+ * @param nodes New nodes.
+ * @returns This container for chaining.
+ */
+ append(...nodes: (Node | object | string)[]): this;
+ /**
+ * Insert newNode before oldNode within the container.
+ * @param oldNode Child or child's index.
+ * @returns This container for chaining.
+ */
+ insertBefore(oldNode: ChildNode | number, newNode: ChildNode | object | string): this;
+ /**
+ * Insert newNode after oldNode within the container.
+ * @param oldNode Child or child's index.
+ * @returns This container for chaining.
+ */
+ insertAfter(oldNode: ChildNode | number, newNode: ChildNode | object | string): this;
+ /**
+ * Removes the container from its parent and cleans the parent property in the
+ * container and its children.
+ * @returns This container for chaining.
+ */
+ remove(): this;
+ /**
+ * Removes child from the container and cleans the parent properties
+ * from the node and its children.
+ * @param child Child or child's index.
+ * @returns This container for chaining.
+ */
+ removeChild(child: ChildNode | number): this;
+ /**
+ * Removes all children from the container and cleans their parent
+ * properties.
+ * @returns This container for chaining.
+ */
+ removeAll(): this;
+ }
+ interface ContainerNewProps extends NodeNewProps {
+ /**
+ * Contains the container's children.
+ */
+ nodes?: ChildNode[];
+ raws?: ContainerRaws;
+ }
+ interface ContainerRaws extends NodeRaws {
+ indent?: string;
+ }
+ interface JsonContainer extends JsonNode {
+ /**
+ * Contains the container's children.
+ */
+ nodes?: ChildNode[];
+ /**
+ * @returns The container's first child.
+ */
+ first?: ChildNode;
+ /**
+ * @returns The container's last child.
+ */
+ last?: ChildNode;
+ }
+ /**
+ * Represents a CSS file and contains all its parsed nodes.
+ */
+ interface Root extends ContainerBase {
+ type: 'root';
+ /**
+ * Inherited from Container. Should always be undefined for a Root node.
+ */
+ parent: void;
+ /**
+ * @param overrides New properties to override in the clone.
+ * @returns A clone of this node. The node and its (cloned) children will
+ * have a clean parent and code style properties.
+ */
+ clone(overrides?: object): this;
+ /**
+ * @returns A Result instance representing the root's CSS.
+ */
+ toResult(options?: {
+ /**
+ * The path where you'll put the output CSS file. You should always
+ * set "to" to generate correct source maps.
+ */
+ to?: string;
+ map?: SourceMapOptions;
+ }): Result;
+ /**
+ * Removes child from the root node, and the parent properties of node and
+ * its children.
+ * @param child Child or child's index.
+ * @returns This root node for chaining.
+ */
+ removeChild(child: ChildNode | number): this;
+ }
+ interface RootNewProps extends ContainerNewProps {
+ }
+ interface JsonRoot extends JsonContainer {
+ }
+ /**
+ * Represents an at-rule. If it's followed in the CSS by a {} block, this
+ * node will have a nodes property representing its children.
+ */
+ interface AtRule extends ContainerBase {
+ type: 'atrule';
+ /**
+ * Returns the atrule's parent node.
+ */
+ parent: Container;
+ /**
+ * The identifier that immediately follows the @.
+ */
+ name: string;
+ /**
+ * These are the values that follow the at-rule's name, but precede any {}
+ * block. The spec refers to this area as the at-rule's "prelude".
+ */
+ params: string;
+ /**
+ * @param overrides New properties to override in the clone.
+ * @returns A clone of this node. The node and its (cloned) children will
+ * have a clean parent and code style properties.
+ */
+ clone(overrides?: object): this;
+ }
+ interface AtRuleNewProps extends ContainerNewProps {
+ /**
+ * The identifier that immediately follows the @.
+ */
+ name?: string;
+ /**
+ * These are the values that follow the at-rule's name, but precede any {}
+ * block. The spec refers to this area as the at-rule's "prelude".
+ */
+ params?: string | number;
+ raws?: AtRuleRaws;
+ }
+ interface AtRuleRaws extends NodeRaws {
+ params?: string;
+ }
+ interface JsonAtRule extends JsonContainer {
+ /**
+ * The identifier that immediately follows the @.
+ */
+ name?: string;
+ /**
+ * These are the values that follow the at-rule's name, but precede any {}
+ * block. The spec refers to this area as the at-rule's "prelude".
+ */
+ params?: string;
+ }
+ /**
+ * Represents a CSS rule: a selector followed by a declaration block.
+ */
+ interface Rule extends ContainerBase {
+ type: 'rule';
+ /**
+ * Returns the rule's parent node.
+ */
+ parent: Container;
+ /**
+ * The rule's full selector. If there are multiple comma-separated selectors,
+ * the entire group will be included.
+ */
+ selector: string;
+ /**
+ * An array containing the rule's individual selectors.
+ * Groups of selectors are split at commas.
+ */
+ selectors: string[];
+ /**
+ * @param overrides New properties to override in the clone.
+ * @returns A clone of this node. The node and its (cloned) children will
+ * have a clean parent and code style properties.
+ */
+ clone(overrides?: object): this;
+ }
+ interface RuleNewProps extends ContainerNewProps {
+ /**
+ * The rule's full selector. If there are multiple comma-separated selectors,
+ * the entire group will be included.
+ */
+ selector?: string;
+ /**
+ * An array containing the rule's individual selectors. Groups of selectors
+ * are split at commas.
+ */
+ selectors?: string[];
+ raws?: RuleRaws;
+ }
+ interface RuleRaws extends ContainerRaws {
+ /**
+ * The rule's full selector. If there are multiple comma-separated selectors,
+ * the entire group will be included.
+ */
+ selector?: string;
+ }
+ interface JsonRule extends JsonContainer {
+ /**
+ * The rule's full selector. If there are multiple comma-separated selectors,
+ * the entire group will be included.
+ */
+ selector?: string;
+ /**
+ * An array containing the rule's individual selectors.
+ * Groups of selectors are split at commas.
+ */
+ selectors?: string[];
+ }
+ /**
+ * Represents a CSS declaration.
+ */
+ interface Declaration extends NodeBase {
+ type: 'decl';
+ /**
+ * Returns the declaration's parent node.
+ */
+ parent: Container;
+ /**
+ * The declaration's property name.
+ */
+ prop: string;
+ /**
+ * The declaration's value. This value will be cleaned of comments. If the
+ * source value contained comments, those comments will be available in the
+ * _value.raws property. If you have not changed the value, the result of
+ * decl.toString() will include the original raws value (comments and all).
+ */
+ value: string;
+ /**
+ * True if the declaration has an !important annotation.
+ */
+ important: boolean;
+ /**
+ * @param overrides New properties to override in the clone.
+ * @returns A clone of this node. The node and its (cloned) children will
+ * have a clean parent and code style properties.
+ */
+ clone(overrides?: object): this;
+ }
+ interface DeclarationNewProps {
+ /**
+ * The declaration's property name.
+ */
+ prop?: string;
+ /**
+ * The declaration's value. This value will be cleaned of comments. If the
+ * source value contained comments, those comments will be available in the
+ * _value.raws property. If you have not changed the value, the result of
+ * decl.toString() will include the original raws value (comments and all).
+ */
+ value?: string;
+ raws?: DeclarationRaws;
+ }
+ interface DeclarationRaws extends NodeRaws {
+ /**
+ * The declaration's value. This value will be cleaned of comments.
+ * If the source value contained comments, those comments will be
+ * available in the _value.raws property. If you have not changed the value, the result of
+ * decl.toString() will include the original raws value (comments and all).
+ */
+ value?: string;
+ }
+ interface JsonDeclaration extends JsonNode {
+ /**
+ * True if the declaration has an !important annotation.
+ */
+ important?: boolean;
+ }
+ /**
+ * Represents a comment between declarations or statements (rule and at-rules).
+ * Comments inside selectors, at-rule parameters, or declaration values will
+ * be stored in the Node#raws properties.
+ */
+ interface Comment extends NodeBase {
+ type: 'comment';
+ /**
+ * Returns the comment's parent node.
+ */
+ parent: Container;
+ /**
+ * The comment's text.
+ */
+ text: string;
+ /**
+ * @param overrides New properties to override in the clone.
+ * @returns A clone of this node. The node and its (cloned) children will
+ * have a clean parent and code style properties.
+ */
+ clone(overrides?: object): this;
+ }
+ interface CommentNewProps {
+ /**
+ * The comment's text.
+ */
+ text?: string;
+ }
+ interface JsonComment extends JsonNode {
+ }
+}
+export = postcss;
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/postcss.js b/node_modules/autoprefixer/node_modules/postcss/lib/postcss.js
new file mode 100644
index 0000000..2e6c5ce
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/postcss.js
@@ -0,0 +1,285 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _declaration = _interopRequireDefault(require("./declaration"));
+
+var _processor = _interopRequireDefault(require("./processor"));
+
+var _stringify = _interopRequireDefault(require("./stringify"));
+
+var _comment = _interopRequireDefault(require("./comment"));
+
+var _atRule = _interopRequireDefault(require("./at-rule"));
+
+var _vendor = _interopRequireDefault(require("./vendor"));
+
+var _parse = _interopRequireDefault(require("./parse"));
+
+var _list = _interopRequireDefault(require("./list"));
+
+var _rule = _interopRequireDefault(require("./rule"));
+
+var _root = _interopRequireDefault(require("./root"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Create a new {@link Processor} instance that will apply `plugins`
+ * as CSS processors.
+ *
+ * @param {Array.<Plugin|pluginFunction>|Processor} plugins PostCSS plugins.
+ * See {@link Processor#use} for plugin format.
+ *
+ * @return {Processor} Processor to process multiple CSS.
+ *
+ * @example
+ * import postcss from 'postcss'
+ *
+ * postcss(plugins).process(css, { from, to }).then(result => {
+ * console.log(result.css)
+ * })
+ *
+ * @namespace postcss
+ */
+function postcss() {
+ for (var _len = arguments.length, plugins = new Array(_len), _key = 0; _key < _len; _key++) {
+ plugins[_key] = arguments[_key];
+ }
+
+ if (plugins.length === 1 && Array.isArray(plugins[0])) {
+ plugins = plugins[0];
+ }
+
+ return new _processor.default(plugins);
+}
+/**
+ * Creates a PostCSS plugin with a standard API.
+ *
+ * The newly-wrapped function will provide both the name and PostCSS
+ * version of the plugin.
+ *
+ * ```js
+ * const processor = postcss([replace])
+ * processor.plugins[0].postcssPlugin //=> 'postcss-replace'
+ * processor.plugins[0].postcssVersion //=> '6.0.0'
+ * ```
+ *
+ * The plugin function receives 2 arguments: {@link Root}
+ * and {@link Result} instance. The function should mutate the provided
+ * `Root` node. Alternatively, you can create a new `Root` node
+ * and override the `result.root` property.
+ *
+ * ```js
+ * const cleaner = postcss.plugin('postcss-cleaner', () => {
+ * return (root, result) => {
+ * result.root = postcss.root()
+ * }
+ * })
+ * ```
+ *
+ * As a convenience, plugins also expose a `process` method so that you can use
+ * them as standalone tools.
+ *
+ * ```js
+ * cleaner.process(css, processOpts, pluginOpts)
+ * // This is equivalent to:
+ * postcss([ cleaner(pluginOpts) ]).process(css, processOpts)
+ * ```
+ *
+ * Asynchronous plugins should return a `Promise` instance.
+ *
+ * ```js
+ * postcss.plugin('postcss-import', () => {
+ * return (root, result) => {
+ * return new Promise( (resolve, reject) => {
+ * fs.readFile('base.css', (base) => {
+ * root.prepend(base)
+ * resolve()
+ * })
+ * })
+ * }
+ * })
+ * ```
+ *
+ * Add warnings using the {@link Node#warn} method.
+ * Send data to other plugins using the {@link Result#messages} array.
+ *
+ * ```js
+ * postcss.plugin('postcss-caniuse-test', () => {
+ * return (root, result) => {
+ * root.walkDecls(decl => {
+ * if (!caniuse.support(decl.prop)) {
+ * decl.warn(result, 'Some browsers do not support ' + decl.prop)
+ * }
+ * })
+ * }
+ * })
+ * ```
+ *
+ * @param {string} name PostCSS plugin name. Same as in `name`
+ * property in `package.json`. It will be saved
+ * in `plugin.postcssPlugin` property.
+ * @param {function} initializer Will receive plugin options
+ * and should return {@link pluginFunction}
+ *
+ * @return {Plugin} PostCSS plugin.
+ */
+
+
+postcss.plugin = function plugin(name, initializer) {
+ function creator() {
+ var transformer = initializer.apply(void 0, arguments);
+ transformer.postcssPlugin = name;
+ transformer.postcssVersion = new _processor.default().version;
+ return transformer;
+ }
+
+ var cache;
+ Object.defineProperty(creator, 'postcss', {
+ get: function get() {
+ if (!cache) cache = creator();
+ return cache;
+ }
+ });
+
+ creator.process = function (css, processOpts, pluginOpts) {
+ return postcss([creator(pluginOpts)]).process(css, processOpts);
+ };
+
+ return creator;
+};
+/**
+ * Default function to convert a node tree into a CSS string.
+ *
+ * @param {Node} node Start node for stringifing. Usually {@link Root}.
+ * @param {builder} builder Function to concatenate CSS from node’s parts
+ * or generate string and source map.
+ *
+ * @return {void}
+ *
+ * @function
+ */
+
+
+postcss.stringify = _stringify.default;
+/**
+ * Parses source css and returns a new {@link Root} node,
+ * which contains the source CSS nodes.
+ *
+ * @param {string|toString} css String with input CSS or any object
+ * with toString() method, like a Buffer
+ * @param {processOptions} [opts] Options with only `from` and `map` keys.
+ *
+ * @return {Root} PostCSS AST.
+ *
+ * @example
+ * // Simple CSS concatenation with source map support
+ * const root1 = postcss.parse(css1, { from: file1 })
+ * const root2 = postcss.parse(css2, { from: file2 })
+ * root1.append(root2).toResult().css
+ *
+ * @function
+ */
+
+postcss.parse = _parse.default;
+/**
+ * Contains the {@link vendor} module.
+ *
+ * @type {vendor}
+ *
+ * @example
+ * postcss.vendor.unprefixed('-moz-tab') //=> ['tab']
+ */
+
+postcss.vendor = _vendor.default;
+/**
+ * Contains the {@link list} module.
+ *
+ * @member {list}
+ *
+ * @example
+ * postcss.list.space('5px calc(10% + 5px)') //=> ['5px', 'calc(10% + 5px)']
+ */
+
+postcss.list = _list.default;
+/**
+ * Creates a new {@link Comment} node.
+ *
+ * @param {object} [defaults] Properties for the new node.
+ *
+ * @return {Comment} New comment node
+ *
+ * @example
+ * postcss.comment({ text: 'test' })
+ */
+
+postcss.comment = function (defaults) {
+ return new _comment.default(defaults);
+};
+/**
+ * Creates a new {@link AtRule} node.
+ *
+ * @param {object} [defaults] Properties for the new node.
+ *
+ * @return {AtRule} new at-rule node
+ *
+ * @example
+ * postcss.atRule({ name: 'charset' }).toString() //=> "@charset"
+ */
+
+
+postcss.atRule = function (defaults) {
+ return new _atRule.default(defaults);
+};
+/**
+ * Creates a new {@link Declaration} node.
+ *
+ * @param {object} [defaults] Properties for the new node.
+ *
+ * @return {Declaration} new declaration node
+ *
+ * @example
+ * postcss.decl({ prop: 'color', value: 'red' }).toString() //=> "color: red"
+ */
+
+
+postcss.decl = function (defaults) {
+ return new _declaration.default(defaults);
+};
+/**
+ * Creates a new {@link Rule} node.
+ *
+ * @param {object} [defaults] Properties for the new node.
+ *
+ * @return {Rule} new rule node
+ *
+ * @example
+ * postcss.rule({ selector: 'a' }).toString() //=> "a {\n}"
+ */
+
+
+postcss.rule = function (defaults) {
+ return new _rule.default(defaults);
+};
+/**
+ * Creates a new {@link Root} node.
+ *
+ * @param {object} [defaults] Properties for the new node.
+ *
+ * @return {Root} new root node.
+ *
+ * @example
+ * postcss.root({ after: '\n' }).toString() //=> "\n"
+ */
+
+
+postcss.root = function (defaults) {
+ return new _root.default(defaults);
+};
+
+var _default = postcss;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInBvc3Rjc3MuZXM2Il0sIm5hbWVzIjpbInBvc3Rjc3MiLCJwbHVnaW5zIiwibGVuZ3RoIiwiQXJyYXkiLCJpc0FycmF5IiwiUHJvY2Vzc29yIiwicGx1Z2luIiwibmFtZSIsImluaXRpYWxpemVyIiwiY3JlYXRvciIsInRyYW5zZm9ybWVyIiwicG9zdGNzc1BsdWdpbiIsInBvc3Rjc3NWZXJzaW9uIiwidmVyc2lvbiIsImNhY2hlIiwiT2JqZWN0IiwiZGVmaW5lUHJvcGVydHkiLCJnZXQiLCJwcm9jZXNzIiwiY3NzIiwicHJvY2Vzc09wdHMiLCJwbHVnaW5PcHRzIiwic3RyaW5naWZ5IiwicGFyc2UiLCJ2ZW5kb3IiLCJsaXN0IiwiY29tbWVudCIsImRlZmF1bHRzIiwiQ29tbWVudCIsImF0UnVsZSIsIkF0UnVsZSIsImRlY2wiLCJEZWNsYXJhdGlvbiIsInJ1bGUiLCJSdWxlIiwicm9vdCIsIlJvb3QiXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7QUFFQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBa0JBLFNBQVNBLE9BQVQsR0FBOEI7QUFBQSxvQ0FBVEMsT0FBUztBQUFUQSxJQUFBQSxPQUFTO0FBQUE7O0FBQzVCLE1BQUlBLE9BQU8sQ0FBQ0MsTUFBUixLQUFtQixDQUFuQixJQUF3QkMsS0FBSyxDQUFDQyxPQUFOLENBQWNILE9BQU8sQ0FBQyxDQUFELENBQXJCLENBQTVCLEVBQXVEO0FBQ3JEQSxJQUFBQSxPQUFPLEdBQUdBLE9BQU8sQ0FBQyxDQUFELENBQWpCO0FBQ0Q7O0FBQ0QsU0FBTyxJQUFJSSxrQkFBSixDQUFjSixPQUFkLENBQVA7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQXdFQUQsT0FBTyxDQUFDTSxNQUFSLEdBQWlCLFNBQVNBLE1BQVQsQ0FBaUJDLElBQWpCLEVBQXVCQyxXQUF2QixFQUFvQztBQUNuRCxXQUFTQyxPQUFULEdBQTJCO0FBQ3pCLFFBQUlDLFdBQVcsR0FBR0YsV0FBVyxNQUFYLG1CQUFsQjtBQUNBRSxJQUFBQSxXQUFXLENBQUNDLGFBQVosR0FBNEJKLElBQTVCO0FBQ0FHLElBQUFBLFdBQVcsQ0FBQ0UsY0FBWixHQUE4QixJQUFJUCxrQkFBSixFQUFELENBQWtCUSxPQUEvQztBQUNBLFdBQU9ILFdBQVA7QUFDRDs7QUFFRCxNQUFJSSxLQUFKO0FBQ0FDLEVBQUFBLE1BQU0sQ0FBQ0MsY0FBUCxDQUFzQlAsT0FBdEIsRUFBK0IsU0FBL0IsRUFBMEM7QUFDeENRLElBQUFBLEdBRHdDLGlCQUNqQztBQUNMLFVBQUksQ0FBQ0gsS0FBTCxFQUFZQSxLQUFLLEdBQUdMLE9BQU8sRUFBZjtBQUNaLGFBQU9LLEtBQVA7QUFDRDtBQUp1QyxHQUExQzs7QUFPQUwsRUFBQUEsT0FBTyxDQUFDUyxPQUFSLEdBQWtCLFVBQVVDLEdBQVYsRUFBZUMsV0FBZixFQUE0QkMsVUFBNUIsRUFBd0M7QUFDeEQsV0FBT3JCLE9BQU8sQ0FBQyxDQUFDUyxPQUFPLENBQUNZLFVBQUQsQ0FBUixDQUFELENBQVAsQ0FBK0JILE9BQS9CLENBQXVDQyxHQUF2QyxFQUE0Q0MsV0FBNUMsQ0FBUDtBQUNELEdBRkQ7O0FBSUEsU0FBT1gsT0FBUDtBQUNELENBckJEO0FBdUJBOzs7Ozs7Ozs7Ozs7O0FBV0FULE9BQU8sQ0FBQ3NCLFNBQVIsR0FBb0JBLGtCQUFwQjtBQUVBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBa0JBdEIsT0FBTyxDQUFDdUIsS0FBUixHQUFnQkEsY0FBaEI7QUFFQTs7Ozs7Ozs7O0FBUUF2QixPQUFPLENBQUN3QixNQUFSLEdBQWlCQSxlQUFqQjtBQUVBOzs7Ozs7Ozs7QUFRQXhCLE9BQU8sQ0FBQ3lCLElBQVIsR0FBZUEsYUFBZjtBQUVBOzs7Ozs7Ozs7OztBQVVBekIsT0FBTyxDQUFDMEIsT0FBUixHQUFrQixVQUFBQyxRQUFRO0FBQUEsU0FBSSxJQUFJQyxnQkFBSixDQUFZRCxRQUFaLENBQUo7QUFBQSxDQUExQjtBQUVBOzs7Ozs7Ozs7Ozs7QUFVQTNCLE9BQU8sQ0FBQzZCLE1BQVIsR0FBaUIsVUFBQUYsUUFBUTtBQUFBLFNBQUksSUFBSUcsZUFBSixDQUFXSCxRQUFYLENBQUo7QUFBQSxDQUF6QjtBQUVBOzs7Ozs7Ozs7Ozs7QUFVQTNCLE9BQU8sQ0FBQytCLElBQVIsR0FBZSxVQUFBSixRQUFRO0FBQUEsU0FBSSxJQUFJSyxvQkFBSixDQUFnQkwsUUFBaEIsQ0FBSjtBQUFBLENBQXZCO0FBRUE7Ozs7Ozs7Ozs7OztBQVVBM0IsT0FBTyxDQUFDaUMsSUFBUixHQUFlLFVBQUFOLFFBQVE7QUFBQSxTQUFJLElBQUlPLGFBQUosQ0FBU1AsUUFBVCxDQUFKO0FBQUEsQ0FBdkI7QUFFQTs7Ozs7Ozs7Ozs7O0FBVUEzQixPQUFPLENBQUNtQyxJQUFSLEdBQWUsVUFBQVIsUUFBUTtBQUFBLFNBQUksSUFBSVMsYUFBSixDQUFTVCxRQUFULENBQUo7QUFBQSxDQUF2Qjs7ZUFFZTNCLE8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgRGVjbGFyYXRpb24gZnJvbSAnLi9kZWNsYXJhdGlvbidcbmltcG9ydCBQcm9jZXNzb3IgZnJvbSAnLi9wcm9jZXNzb3InXG5pbXBvcnQgc3RyaW5naWZ5IGZyb20gJy4vc3RyaW5naWZ5J1xuaW1wb3J0IENvbW1lbnQgZnJvbSAnLi9jb21tZW50J1xuaW1wb3J0IEF0UnVsZSBmcm9tICcuL2F0LXJ1bGUnXG5pbXBvcnQgdmVuZG9yIGZyb20gJy4vdmVuZG9yJ1xuaW1wb3J0IHBhcnNlIGZyb20gJy4vcGFyc2UnXG5pbXBvcnQgbGlzdCBmcm9tICcuL2xpc3QnXG5pbXBvcnQgUnVsZSBmcm9tICcuL3J1bGUnXG5pbXBvcnQgUm9vdCBmcm9tICcuL3Jvb3QnXG5cbi8qKlxuICogQ3JlYXRlIGEgbmV3IHtAbGluayBQcm9jZXNzb3J9IGluc3RhbmNlIHRoYXQgd2lsbCBhcHBseSBgcGx1Z2luc2BcbiAqIGFzIENTUyBwcm9jZXNzb3JzLlxuICpcbiAqIEBwYXJhbSB7QXJyYXkuPFBsdWdpbnxwbHVnaW5GdW5jdGlvbj58UHJvY2Vzc29yfSBwbHVnaW5zIFBvc3RDU1MgcGx1Z2lucy5cbiAqICAgICAgICBTZWUge0BsaW5rIFByb2Nlc3NvciN1c2V9IGZvciBwbHVnaW4gZm9ybWF0LlxuICpcbiAqIEByZXR1cm4ge1Byb2Nlc3Nvcn0gUHJvY2Vzc29yIHRvIHByb2Nlc3MgbXVsdGlwbGUgQ1NTLlxuICpcbiAqIEBleGFtcGxlXG4gKiBpbXBvcnQgcG9zdGNzcyBmcm9tICdwb3N0Y3NzJ1xuICpcbiAqIHBvc3Rjc3MocGx1Z2lucykucHJvY2Vzcyhjc3MsIHsgZnJvbSwgdG8gfSkudGhlbihyZXN1bHQgPT4ge1xuICogICBjb25zb2xlLmxvZyhyZXN1bHQuY3NzKVxuICogfSlcbiAqXG4gKiBAbmFtZXNwYWNlIHBvc3Rjc3NcbiAqL1xuZnVuY3Rpb24gcG9zdGNzcyAoLi4ucGx1Z2lucykge1xuICBpZiAocGx1Z2lucy5sZW5ndGggPT09IDEgJiYgQXJyYXkuaXNBcnJheShwbHVnaW5zWzBdKSkge1xuICAgIHBsdWdpbnMgPSBwbHVnaW5zWzBdXG4gIH1cbiAgcmV0dXJuIG5ldyBQcm9jZXNzb3IocGx1Z2lucylcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgUG9zdENTUyBwbHVnaW4gd2l0aCBhIHN0YW5kYXJkIEFQSS5cbiAqXG4gKiBUaGUgbmV3bHktd3JhcHBlZCBmdW5jdGlvbiB3aWxsIHByb3ZpZGUgYm90aCB0aGUgbmFtZSBhbmQgUG9zdENTU1xuICogdmVyc2lvbiBvZiB0aGUgcGx1Z2luLlxuICpcbiAqIGBgYGpzXG4gKiBjb25zdCBwcm9jZXNzb3IgPSBwb3N0Y3NzKFtyZXBsYWNlXSlcbiAqIHByb2Nlc3Nvci5wbHVnaW5zWzBdLnBvc3Rjc3NQbHVnaW4gIC8vPT4gJ3Bvc3Rjc3MtcmVwbGFjZSdcbiAqIHByb2Nlc3Nvci5wbHVnaW5zWzBdLnBvc3Rjc3NWZXJzaW9uIC8vPT4gJzYuMC4wJ1xuICogYGBgXG4gKlxuICogVGhlIHBsdWdpbiBmdW5jdGlvbiByZWNlaXZlcyAyIGFyZ3VtZW50czoge0BsaW5rIFJvb3R9XG4gKiBhbmQge0BsaW5rIFJlc3VsdH0gaW5zdGFuY2UuIFRoZSBmdW5jdGlvbiBzaG91bGQgbXV0YXRlIHRoZSBwcm92aWRlZFxuICogYFJvb3RgIG5vZGUuIEFsdGVybmF0aXZlbHksIHlvdSBjYW4gY3JlYXRlIGEgbmV3IGBSb290YCBub2RlXG4gKiBhbmQgb3ZlcnJpZGUgdGhlIGByZXN1bHQucm9vdGAgcHJvcGVydHkuXG4gKlxuICogYGBganNcbiAqIGNvbnN0IGNsZWFuZXIgPSBwb3N0Y3NzLnBsdWdpbigncG9zdGNzcy1jbGVhbmVyJywgKCkgPT4ge1xuICogICByZXR1cm4gKHJvb3QsIHJlc3VsdCkgPT4ge1xuICogICAgIHJlc3VsdC5yb290ID0gcG9zdGNzcy5yb290KClcbiAqICAgfVxuICogfSlcbiAqIGBgYFxuICpcbiAqIEFzIGEgY29udmVuaWVuY2UsIHBsdWdpbnMgYWxzbyBleHBvc2UgYSBgcHJvY2Vzc2AgbWV0aG9kIHNvIHRoYXQgeW91IGNhbiB1c2VcbiAqIHRoZW0gYXMgc3RhbmRhbG9uZSB0b29scy5cbiAqXG4gKiBgYGBqc1xuICogY2xlYW5lci5wcm9jZXNzKGNzcywgcHJvY2Vzc09wdHMsIHBsdWdpbk9wdHMpXG4gKiAvLyBUaGlzIGlzIGVxdWl2YWxlbnQgdG86XG4gKiBwb3N0Y3NzKFsgY2xlYW5lcihwbHVnaW5PcHRzKSBdKS5wcm9jZXNzKGNzcywgcHJvY2Vzc09wdHMpXG4gKiBgYGBcbiAqXG4gKiBBc3luY2hyb25vdXMgcGx1Z2lucyBzaG91bGQgcmV0dXJuIGEgYFByb21pc2VgIGluc3RhbmNlLlxuICpcbiAqIGBgYGpzXG4gKiBwb3N0Y3NzLnBsdWdpbigncG9zdGNzcy1pbXBvcnQnLCAoKSA9PiB7XG4gKiAgIHJldHVybiAocm9vdCwgcmVzdWx0KSA9PiB7XG4gKiAgICAgcmV0dXJuIG5ldyBQcm9taXNlKCAocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gKiAgICAgICBmcy5yZWFkRmlsZSgnYmFzZS5jc3MnLCAoYmFzZSkgPT4ge1xuICogICAgICAgICByb290LnByZXBlbmQoYmFzZSlcbiAqICAgICAgICAgcmVzb2x2ZSgpXG4gKiAgICAgICB9KVxuICogICAgIH0pXG4gKiAgIH1cbiAqIH0pXG4gKiBgYGBcbiAqXG4gKiBBZGQgd2FybmluZ3MgdXNpbmcgdGhlIHtAbGluayBOb2RlI3dhcm59IG1ldGhvZC5cbiAqIFNlbmQgZGF0YSB0byBvdGhlciBwbHVnaW5zIHVzaW5nIHRoZSB7QGxpbmsgUmVzdWx0I21lc3NhZ2VzfSBhcnJheS5cbiAqXG4gKiBgYGBqc1xuICogcG9zdGNzcy5wbHVnaW4oJ3Bvc3Rjc3MtY2FuaXVzZS10ZXN0JywgKCkgPT4ge1xuICogICByZXR1cm4gKHJvb3QsIHJlc3VsdCkgPT4ge1xuICogICAgIHJvb3Qud2Fsa0RlY2xzKGRlY2wgPT4ge1xuICogICAgICAgaWYgKCFjYW5pdXNlLnN1cHBvcnQoZGVjbC5wcm9wKSkge1xuICogICAgICAgICBkZWNsLndhcm4ocmVzdWx0LCAnU29tZSBicm93c2VycyBkbyBub3Qgc3VwcG9ydCAnICsgZGVjbC5wcm9wKVxuICogICAgICAgfVxuICogICAgIH0pXG4gKiAgIH1cbiAqIH0pXG4gKiBgYGBcbiAqXG4gKiBAcGFyYW0ge3N0cmluZ30gbmFtZSAgICAgICAgICBQb3N0Q1NTIHBsdWdpbiBuYW1lLiBTYW1lIGFzIGluIGBuYW1lYFxuICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJvcGVydHkgaW4gYHBhY2thZ2UuanNvbmAuIEl0IHdpbGwgYmUgc2F2ZWRcbiAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGluIGBwbHVnaW4ucG9zdGNzc1BsdWdpbmAgcHJvcGVydHkuXG4gKiBAcGFyYW0ge2Z1bmN0aW9ufSBpbml0aWFsaXplciBXaWxsIHJlY2VpdmUgcGx1Z2luIG9wdGlvbnNcbiAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFuZCBzaG91bGQgcmV0dXJuIHtAbGluayBwbHVnaW5GdW5jdGlvbn1cbiAqXG4gKiBAcmV0dXJuIHtQbHVnaW59IFBvc3RDU1MgcGx1Z2luLlxuICovXG5wb3N0Y3NzLnBsdWdpbiA9IGZ1bmN0aW9uIHBsdWdpbiAobmFtZSwgaW5pdGlhbGl6ZXIpIHtcbiAgZnVuY3Rpb24gY3JlYXRvciAoLi4uYXJncykge1xuICAgIGxldCB0cmFuc2Zvcm1lciA9IGluaXRpYWxpemVyKC4uLmFyZ3MpXG4gICAgdHJhbnNmb3JtZXIucG9zdGNzc1BsdWdpbiA9IG5hbWVcbiAgICB0cmFuc2Zvcm1lci5wb3N0Y3NzVmVyc2lvbiA9IChuZXcgUHJvY2Vzc29yKCkpLnZlcnNpb25cbiAgICByZXR1cm4gdHJhbnNmb3JtZXJcbiAgfVxuXG4gIGxldCBjYWNoZVxuICBPYmplY3QuZGVmaW5lUHJvcGVydHkoY3JlYXRvciwgJ3Bvc3Rjc3MnLCB7XG4gICAgZ2V0ICgpIHtcbiAgICAgIGlmICghY2FjaGUpIGNhY2hlID0gY3JlYXRvcigpXG4gICAgICByZXR1cm4gY2FjaGVcbiAgICB9XG4gIH0pXG5cbiAgY3JlYXRvci5wcm9jZXNzID0gZnVuY3Rpb24gKGNzcywgcHJvY2Vzc09wdHMsIHBsdWdpbk9wdHMpIHtcbiAgICByZXR1cm4gcG9zdGNzcyhbY3JlYXRvcihwbHVnaW5PcHRzKV0pLnByb2Nlc3MoY3NzLCBwcm9jZXNzT3B0cylcbiAgfVxuXG4gIHJldHVybiBjcmVhdG9yXG59XG5cbi8qKlxuICogRGVmYXVsdCBmdW5jdGlvbiB0byBjb252ZXJ0IGEgbm9kZSB0cmVlIGludG8gYSBDU1Mgc3RyaW5nLlxuICpcbiAqIEBwYXJhbSB7Tm9kZX0gbm9kZSAgICAgICBTdGFydCBub2RlIGZvciBzdHJpbmdpZmluZy4gVXN1YWxseSB7QGxpbmsgUm9vdH0uXG4gKiBAcGFyYW0ge2J1aWxkZXJ9IGJ1aWxkZXIgRnVuY3Rpb24gdG8gY29uY2F0ZW5hdGUgQ1NTIGZyb20gbm9kZeKAmXMgcGFydHNcbiAqICAgICAgICAgICAgICAgICAgICAgICAgICBvciBnZW5lcmF0ZSBzdHJpbmcgYW5kIHNvdXJjZSBtYXAuXG4gKlxuICogQHJldHVybiB7dm9pZH1cbiAqXG4gKiBAZnVuY3Rpb25cbiAqL1xucG9zdGNzcy5zdHJpbmdpZnkgPSBzdHJpbmdpZnlcblxuLyoqXG4gKiBQYXJzZXMgc291cmNlIGNzcyBhbmQgcmV0dXJucyBhIG5ldyB7QGxpbmsgUm9vdH0gbm9kZSxcbiAqIHdoaWNoIGNvbnRhaW5zIHRoZSBzb3VyY2UgQ1NTIG5vZGVzLlxuICpcbiAqIEBwYXJhbSB7c3RyaW5nfHRvU3RyaW5nfSBjc3MgICBTdHJpbmcgd2l0aCBpbnB1dCBDU1Mgb3IgYW55IG9iamVjdFxuICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHdpdGggdG9TdHJpbmcoKSBtZXRob2QsIGxpa2UgYSBCdWZmZXJcbiAqIEBwYXJhbSB7cHJvY2Vzc09wdGlvbnN9IFtvcHRzXSBPcHRpb25zIHdpdGggb25seSBgZnJvbWAgYW5kIGBtYXBgIGtleXMuXG4gKlxuICogQHJldHVybiB7Um9vdH0gUG9zdENTUyBBU1QuXG4gKlxuICogQGV4YW1wbGVcbiAqIC8vIFNpbXBsZSBDU1MgY29uY2F0ZW5hdGlvbiB3aXRoIHNvdXJjZSBtYXAgc3VwcG9ydFxuICogY29uc3Qgcm9vdDEgPSBwb3N0Y3NzLnBhcnNlKGNzczEsIHsgZnJvbTogZmlsZTEgfSlcbiAqIGNvbnN0IHJvb3QyID0gcG9zdGNzcy5wYXJzZShjc3MyLCB7IGZyb206IGZpbGUyIH0pXG4gKiByb290MS5hcHBlbmQocm9vdDIpLnRvUmVzdWx0KCkuY3NzXG4gKlxuICogQGZ1bmN0aW9uXG4gKi9cbnBvc3Rjc3MucGFyc2UgPSBwYXJzZVxuXG4vKipcbiAqIENvbnRhaW5zIHRoZSB7QGxpbmsgdmVuZG9yfSBtb2R1bGUuXG4gKlxuICogQHR5cGUge3ZlbmRvcn1cbiAqXG4gKiBAZXhhbXBsZVxuICogcG9zdGNzcy52ZW5kb3IudW5wcmVmaXhlZCgnLW1vei10YWInKSAvLz0+IFsndGFiJ11cbiAqL1xucG9zdGNzcy52ZW5kb3IgPSB2ZW5kb3JcblxuLyoqXG4gKiBDb250YWlucyB0aGUge0BsaW5rIGxpc3R9IG1vZHVsZS5cbiAqXG4gKiBAbWVtYmVyIHtsaXN0fVxuICpcbiAqIEBleGFtcGxlXG4gKiBwb3N0Y3NzLmxpc3Quc3BhY2UoJzVweCBjYWxjKDEwJSArIDVweCknKSAvLz0+IFsnNXB4JywgJ2NhbGMoMTAlICsgNXB4KSddXG4gKi9cbnBvc3Rjc3MubGlzdCA9IGxpc3RcblxuLyoqXG4gKiBDcmVhdGVzIGEgbmV3IHtAbGluayBDb21tZW50fSBub2RlLlxuICpcbiAqIEBwYXJhbSB7b2JqZWN0fSBbZGVmYXVsdHNdIFByb3BlcnRpZXMgZm9yIHRoZSBuZXcgbm9kZS5cbiAqXG4gKiBAcmV0dXJuIHtDb21tZW50fSBOZXcgY29tbWVudCBub2RlXG4gKlxuICogQGV4YW1wbGVcbiAqIHBvc3Rjc3MuY29tbWVudCh7IHRleHQ6ICd0ZXN0JyB9KVxuICovXG5wb3N0Y3NzLmNvbW1lbnQgPSBkZWZhdWx0cyA9PiBuZXcgQ29tbWVudChkZWZhdWx0cylcblxuLyoqXG4gKiBDcmVhdGVzIGEgbmV3IHtAbGluayBBdFJ1bGV9IG5vZGUuXG4gKlxuICogQHBhcmFtIHtvYmplY3R9IFtkZWZhdWx0c10gUHJvcGVydGllcyBmb3IgdGhlIG5ldyBub2RlLlxuICpcbiAqIEByZXR1cm4ge0F0UnVsZX0gbmV3IGF0LXJ1bGUgbm9kZVxuICpcbiAqIEBleGFtcGxlXG4gKiBwb3N0Y3NzLmF0UnVsZSh7IG5hbWU6ICdjaGFyc2V0JyB9KS50b1N0cmluZygpIC8vPT4gXCJAY2hhcnNldFwiXG4gKi9cbnBvc3Rjc3MuYXRSdWxlID0gZGVmYXVsdHMgPT4gbmV3IEF0UnVsZShkZWZhdWx0cylcblxuLyoqXG4gKiBDcmVhdGVzIGEgbmV3IHtAbGluayBEZWNsYXJhdGlvbn0gbm9kZS5cbiAqXG4gKiBAcGFyYW0ge29iamVjdH0gW2RlZmF1bHRzXSBQcm9wZXJ0aWVzIGZvciB0aGUgbmV3IG5vZGUuXG4gKlxuICogQHJldHVybiB7RGVjbGFyYXRpb259IG5ldyBkZWNsYXJhdGlvbiBub2RlXG4gKlxuICogQGV4YW1wbGVcbiAqIHBvc3Rjc3MuZGVjbCh7IHByb3A6ICdjb2xvcicsIHZhbHVlOiAncmVkJyB9KS50b1N0cmluZygpIC8vPT4gXCJjb2xvcjogcmVkXCJcbiAqL1xucG9zdGNzcy5kZWNsID0gZGVmYXVsdHMgPT4gbmV3IERlY2xhcmF0aW9uKGRlZmF1bHRzKVxuXG4vKipcbiAqIENyZWF0ZXMgYSBuZXcge0BsaW5rIFJ1bGV9IG5vZGUuXG4gKlxuICogQHBhcmFtIHtvYmplY3R9IFtkZWZhdWx0c10gUHJvcGVydGllcyBmb3IgdGhlIG5ldyBub2RlLlxuICpcbiAqIEByZXR1cm4ge1J1bGV9IG5ldyBydWxlIG5vZGVcbiAqXG4gKiBAZXhhbXBsZVxuICogcG9zdGNzcy5ydWxlKHsgc2VsZWN0b3I6ICdhJyB9KS50b1N0cmluZygpIC8vPT4gXCJhIHtcXG59XCJcbiAqL1xucG9zdGNzcy5ydWxlID0gZGVmYXVsdHMgPT4gbmV3IFJ1bGUoZGVmYXVsdHMpXG5cbi8qKlxuICogQ3JlYXRlcyBhIG5ldyB7QGxpbmsgUm9vdH0gbm9kZS5cbiAqXG4gKiBAcGFyYW0ge29iamVjdH0gW2RlZmF1bHRzXSBQcm9wZXJ0aWVzIGZvciB0aGUgbmV3IG5vZGUuXG4gKlxuICogQHJldHVybiB7Um9vdH0gbmV3IHJvb3Qgbm9kZS5cbiAqXG4gKiBAZXhhbXBsZVxuICogcG9zdGNzcy5yb290KHsgYWZ0ZXI6ICdcXG4nIH0pLnRvU3RyaW5nKCkgLy89PiBcIlxcblwiXG4gKi9cbnBvc3Rjc3Mucm9vdCA9IGRlZmF1bHRzID0+IG5ldyBSb290KGRlZmF1bHRzKVxuXG5leHBvcnQgZGVmYXVsdCBwb3N0Y3NzXG4iXSwiZmlsZSI6InBvc3Rjc3MuanMifQ==
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/previous-map.js b/node_modules/autoprefixer/node_modules/postcss/lib/previous-map.js
new file mode 100644
index 0000000..23cee46
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/previous-map.js
@@ -0,0 +1,161 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _sourceMap = _interopRequireDefault(require("source-map"));
+
+var _path = _interopRequireDefault(require("path"));
+
+var _fs = _interopRequireDefault(require("fs"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function fromBase64(str) {
+ if (Buffer) {
+ return Buffer.from(str, 'base64').toString();
+ } else {
+ return window.atob(str);
+ }
+}
+/**
+ * Source map information from input CSS.
+ * For example, source map after Sass compiler.
+ *
+ * This class will automatically find source map in input CSS or in file system
+ * near input file (according `from` option).
+ *
+ * @example
+ * const root = postcss.parse(css, { from: 'a.sass.css' })
+ * root.input.map //=> PreviousMap
+ */
+
+
+var PreviousMap =
+/*#__PURE__*/
+function () {
+ /**
+ * @param {string} css Input CSS source.
+ * @param {processOptions} [opts] {@link Processor#process} options.
+ */
+ function PreviousMap(css, opts) {
+ this.loadAnnotation(css);
+ /**
+ * Was source map inlined by data-uri to input CSS.
+ *
+ * @type {boolean}
+ */
+
+ this.inline = this.startWith(this.annotation, 'data:');
+ var prev = opts.map ? opts.map.prev : undefined;
+ var text = this.loadMap(opts.from, prev);
+ if (text) this.text = text;
+ }
+ /**
+ * Create a instance of `SourceMapGenerator` class
+ * from the `source-map` library to work with source map information.
+ *
+ * It is lazy method, so it will create object only on first call
+ * and then it will use cache.
+ *
+ * @return {SourceMapGenerator} Object with source map information.
+ */
+
+
+ var _proto = PreviousMap.prototype;
+
+ _proto.consumer = function consumer() {
+ if (!this.consumerCache) {
+ this.consumerCache = new _sourceMap.default.SourceMapConsumer(this.text);
+ }
+
+ return this.consumerCache;
+ }
+ /**
+ * Does source map contains `sourcesContent` with input source text.
+ *
+ * @return {boolean} Is `sourcesContent` present.
+ */
+ ;
+
+ _proto.withContent = function withContent() {
+ return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0);
+ };
+
+ _proto.startWith = function startWith(string, start) {
+ if (!string) return false;
+ return string.substr(0, start.length) === start;
+ };
+
+ _proto.loadAnnotation = function loadAnnotation(css) {
+ var match = css.match(/\/\*\s*# sourceMappingURL=(.*)\s*\*\//);
+ if (match) this.annotation = match[1].trim();
+ };
+
+ _proto.decodeInline = function decodeInline(text) {
+ var baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/;
+ var baseUri = /^data:application\/json;base64,/;
+ var uri = 'data:application/json,';
+
+ if (this.startWith(text, uri)) {
+ return decodeURIComponent(text.substr(uri.length));
+ }
+
+ if (baseCharsetUri.test(text) || baseUri.test(text)) {
+ return fromBase64(text.substr(RegExp.lastMatch.length));
+ }
+
+ var encoding = text.match(/data:application\/json;([^,]+),/)[1];
+ throw new Error('Unsupported source map encoding ' + encoding);
+ };
+
+ _proto.loadMap = function loadMap(file, prev) {
+ if (prev === false) return false;
+
+ if (prev) {
+ if (typeof prev === 'string') {
+ return prev;
+ } else if (typeof prev === 'function') {
+ var prevPath = prev(file);
+
+ if (prevPath && _fs.default.existsSync && _fs.default.existsSync(prevPath)) {
+ return _fs.default.readFileSync(prevPath, 'utf-8').toString().trim();
+ } else {
+ throw new Error('Unable to load previous source map: ' + prevPath.toString());
+ }
+ } else if (prev instanceof _sourceMap.default.SourceMapConsumer) {
+ return _sourceMap.default.SourceMapGenerator.fromSourceMap(prev).toString();
+ } else if (prev instanceof _sourceMap.default.SourceMapGenerator) {
+ return prev.toString();
+ } else if (this.isMap(prev)) {
+ return JSON.stringify(prev);
+ } else {
+ throw new Error('Unsupported previous source map format: ' + prev.toString());
+ }
+ } else if (this.inline) {
+ return this.decodeInline(this.annotation);
+ } else if (this.annotation) {
+ var map = this.annotation;
+ if (file) map = _path.default.join(_path.default.dirname(file), map);
+ this.root = _path.default.dirname(map);
+
+ if (_fs.default.existsSync && _fs.default.existsSync(map)) {
+ return _fs.default.readFileSync(map, 'utf-8').toString().trim();
+ } else {
+ return false;
+ }
+ }
+ };
+
+ _proto.isMap = function isMap(map) {
+ if (typeof map !== 'object') return false;
+ return typeof map.mappings === 'string' || typeof map._mappings === 'string';
+ };
+
+ return PreviousMap;
+}();
+
+var _default = PreviousMap;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByZXZpb3VzLW1hcC5lczYiXSwibmFtZXMiOlsiZnJvbUJhc2U2NCIsInN0ciIsIkJ1ZmZlciIsImZyb20iLCJ0b1N0cmluZyIsIndpbmRvdyIsImF0b2IiLCJQcmV2aW91c01hcCIsImNzcyIsIm9wdHMiLCJsb2FkQW5ub3RhdGlvbiIsImlubGluZSIsInN0YXJ0V2l0aCIsImFubm90YXRpb24iLCJwcmV2IiwibWFwIiwidW5kZWZpbmVkIiwidGV4dCIsImxvYWRNYXAiLCJjb25zdW1lciIsImNvbnN1bWVyQ2FjaGUiLCJtb3ppbGxhIiwiU291cmNlTWFwQ29uc3VtZXIiLCJ3aXRoQ29udGVudCIsInNvdXJjZXNDb250ZW50IiwibGVuZ3RoIiwic3RyaW5nIiwic3RhcnQiLCJzdWJzdHIiLCJtYXRjaCIsInRyaW0iLCJkZWNvZGVJbmxpbmUiLCJiYXNlQ2hhcnNldFVyaSIsImJhc2VVcmkiLCJ1cmkiLCJkZWNvZGVVUklDb21wb25lbnQiLCJ0ZXN0IiwiUmVnRXhwIiwibGFzdE1hdGNoIiwiZW5jb2RpbmciLCJFcnJvciIsImZpbGUiLCJwcmV2UGF0aCIsImZzIiwiZXhpc3RzU3luYyIsInJlYWRGaWxlU3luYyIsIlNvdXJjZU1hcEdlbmVyYXRvciIsImZyb21Tb3VyY2VNYXAiLCJpc01hcCIsIkpTT04iLCJzdHJpbmdpZnkiLCJwYXRoIiwiam9pbiIsImRpcm5hbWUiLCJyb290IiwibWFwcGluZ3MiLCJfbWFwcGluZ3MiXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7Ozs7QUFFQSxTQUFTQSxVQUFULENBQXFCQyxHQUFyQixFQUEwQjtBQUN4QixNQUFJQyxNQUFKLEVBQVk7QUFDVixXQUFPQSxNQUFNLENBQUNDLElBQVAsQ0FBWUYsR0FBWixFQUFpQixRQUFqQixFQUEyQkcsUUFBM0IsRUFBUDtBQUNELEdBRkQsTUFFTztBQUNMLFdBQU9DLE1BQU0sQ0FBQ0MsSUFBUCxDQUFZTCxHQUFaLENBQVA7QUFDRDtBQUNGO0FBRUQ7Ozs7Ozs7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LElBQWIsQ0FBVixFQUE4QjFCLEdBQTlCLENBQU47QUFFVixXQUFLdUMsSUFBTCxHQUFZSCxjQUFLRSxPQUFMLENBQWF0QyxHQUFiLENBQVo7O0FBQ0EsVUFBSTRCLFlBQUdDLFVBQUgsSUFBaUJELFlBQUdDLFVBQUgsQ0FBYzdCLEdBQWQsQ0FBckIsRUFBeUM7QUFDdkMsZUFBTzRCLFlBQUdFLFlBQUgsQ0FBZ0I5QixHQUFoQixFQUFxQixPQUFyQixFQUE4QlgsUUFBOUIsR0FBeUMwQixJQUF6QyxFQUFQO0FBQ0QsT0FGRCxNQUVPO0FBQ0wsZUFBTyxLQUFQO0FBQ0Q7QUFDRjtBQUNGLEc7O1NBRURrQixLLEdBQUEsZUFBT2pDLEdBQVAsRUFBWTtBQUNWLFFBQUksT0FBT0EsR0FBUCxLQUFlLFFBQW5CLEVBQTZCLE9BQU8sS0FBUDtBQUM3QixXQUFPLE9BQU9BLEdBQUcsQ0FBQ3dDLFFBQVgsS0FBd0IsUUFBeEIsSUFBb0MsT0FBT3hDLEdBQUcsQ0FBQ3lDLFNBQVgsS0FBeUIsUUFBcEU7QUFDRCxHOzs7OztlQUdZakQsVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBtb3ppbGxhIGZyb20gJ3NvdXJjZS1tYXAnXG5pbXBvcnQgcGF0aCBmcm9tICdwYXRoJ1xuaW1wb3J0IGZzIGZyb20gJ2ZzJ1xuXG5mdW5jdGlvbiBmcm9tQmFzZTY0IChzdHIpIHtcbiAgaWYgKEJ1ZmZlcikge1xuICAgIHJldHVybiBCdWZmZXIuZnJvbShzdHIsICdiYXNlNjQnKS50b1N0cmluZygpXG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIHdpbmRvdy5hdG9iKHN0cilcbiAgfVxufVxuXG4vKipcbiAqIFNvdXJjZSBtYXAgaW5mb3JtYXRpb24gZnJvbSBpbnB1dCBDU1MuXG4gKiBGb3IgZXhhbXBsZSwgc291cmNlIG1hcCBhZnRlciBTYXNzIGNvbXBpbGVyLlxuICpcbiAqIFRoaXMgY2xhc3Mgd2lsbCBhdXRvbWF0aWNhbGx5IGZpbmQgc291cmNlIG1hcCBpbiBpbnB1dCBDU1Mgb3IgaW4gZmlsZSBzeXN0ZW1cbiAqIG5lYXIgaW5wdXQgZmlsZSAoYWNjb3JkaW5nIGBmcm9tYCBvcHRpb24pLlxuICpcbiAqIEBleGFtcGxlXG4gKiBjb25zdCByb290ID0gcG9zdGNzcy5wYXJzZShjc3MsIHsgZnJvbTogJ2Euc2Fzcy5jc3MnIH0pXG4gKiByb290LmlucHV0Lm1hcCAvLz0+IFByZXZpb3VzTWFwXG4gKi9cbmNsYXNzIFByZXZpb3VzTWFwIHtcbiAgLyoqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSAgICAgICAgIGNzcyAgICBJbnB1dCBDU1Mgc291cmNlLlxuICAgKiBAcGFyYW0ge3Byb2Nlc3NPcHRpb25zfSBbb3B0c10ge0BsaW5rIFByb2Nlc3NvciNwcm9jZXNzfSBvcHRpb25zLlxuICAgKi9cbiAgY29uc3RydWN0b3IgKGNzcywgb3B0cykge1xuICAgIHRoaXMubG9hZEFubm90YXRpb24oY3NzKVxuICAgIC8qKlxuICAgICAqIFdhcyBzb3VyY2UgbWFwIGlubGluZWQgYnkgZGF0YS11cmkgdG8gaW5wdXQgQ1NTLlxuICAgICAqXG4gICAgICogQHR5cGUge2Jvb2xlYW59XG4gICAgICovXG4gICAgdGhpcy5pbmxpbmUgPSB0aGlzLnN0YXJ0V2l0aCh0aGlzLmFubm90YXRpb24sICdkYXRhOicpXG5cbiAgICBsZXQgcHJldiA9IG9wdHMubWFwID8gb3B0cy5tYXAucHJldiA6IHVuZGVmaW5lZFxuICAgIGxldCB0ZXh0ID0gdGhpcy5sb2FkTWFwKG9wdHMuZnJvbSwgcHJldilcbiAgICBpZiAodGV4dCkgdGhpcy50ZXh0ID0gdGV4dFxuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZSBhIGluc3RhbmNlIG9mIGBTb3VyY2VNYXBHZW5lcmF0b3JgIGNsYXNzXG4gICAqIGZyb20gdGhlIGBzb3VyY2UtbWFwYCBsaWJyYXJ5IHRvIHdvcmsgd2l0aCBzb3VyY2UgbWFwIGluZm9ybWF0aW9uLlxuICAgKlxuICAgKiBJdCBpcyBsYXp5IG1ldGhvZCwgc28gaXQgd2lsbCBjcmVhdGUgb2JqZWN0IG9ubHkgb24gZmlyc3QgY2FsbFxuICAgKiBhbmQgdGhlbiBpdCB3aWxsIHVzZSBjYWNoZS5cbiAgICpcbiAgICogQHJldHVybiB7U291cmNlTWFwR2VuZXJhdG9yfSBPYmplY3Qgd2l0aCBzb3VyY2UgbWFwIGluZm9ybWF0aW9uLlxuICAgKi9cbiAgY29uc3VtZXIgKCkge1xuICAgIGlmICghdGhpcy5jb25zdW1lckNhY2hlKSB7XG4gICAgICB0aGlzLmNvbnN1bWVyQ2FjaGUgPSBuZXcgbW96aWxsYS5Tb3VyY2VNYXBDb25zdW1lcih0aGlzLnRleHQpXG4gICAgfVxuICAgIHJldHVybiB0aGlzLmNvbnN1bWVyQ2FjaGVcbiAgfVxuXG4gIC8qKlxuICAgKiBEb2VzIHNvdXJjZSBtYXAgY29udGFpbnMgYHNvdXJjZXNDb250ZW50YCB3aXRoIGlucHV0IHNvdXJjZSB0ZXh0LlxuICAgKlxuICAgKiBAcmV0dXJuIHtib29sZWFufSBJcyBgc291cmNlc0NvbnRlbnRgIHByZXNlbnQuXG4gICAqL1xuICB3aXRoQ29udGVudCAoKSB7XG4gICAgcmV0dXJuICEhKHRoaXMuY29uc3VtZXIoKS5zb3VyY2VzQ29udGVudCAmJlxuICAgICAgICAgICAgICB0aGlzLmNvbnN1bWVyKCkuc291cmNlc0NvbnRlbnQubGVuZ3RoID4gMClcbiAgfVxuXG4gIHN0YXJ0V2l0aCAoc3RyaW5nLCBzdGFydCkge1xuICAgIGlmICghc3RyaW5nKSByZXR1cm4gZmFsc2VcbiAgICByZXR1cm4gc3RyaW5nLnN1YnN0cigwLCBzdGFydC5sZW5ndGgpID09PSBzdGFydFxuICB9XG5cbiAgbG9hZEFubm90YXRpb24gKGNzcykge1xuICAgIGxldCBtYXRjaCA9IGNzcy5tYXRjaCgvXFwvXFwqXFxzKiMgc291cmNlTWFwcGluZ1VSTD0oLiopXFxzKlxcKlxcLy8pXG4gICAgaWYgKG1hdGNoKSB0aGlzLmFubm90YXRpb24gPSBtYXRjaFsxXS50cmltKClcbiAgfVxuXG4gIGRlY29kZUlubGluZSAodGV4dCkge1xuICAgIGxldCBiYXNlQ2hhcnNldFVyaSA9IC9eZGF0YTphcHBsaWNhdGlvblxcL2pzb247Y2hhcnNldD11dGYtPzg7YmFzZTY0LC9cbiAgICBsZXQgYmFzZVVyaSA9IC9eZGF0YTphcHBsaWNhdGlvblxcL2pzb247YmFzZTY0LC9cbiAgICBsZXQgdXJpID0gJ2RhdGE6YXBwbGljYXRpb24vanNvbiwnXG5cbiAgICBpZiAodGhpcy5zdGFydFdpdGgodGV4dCwgdXJpKSkge1xuICAgICAgcmV0dXJuIGRlY29kZVVSSUNvbXBvbmVudCh0ZXh0LnN1YnN0cih1cmkubGVuZ3RoKSlcbiAgICB9XG5cbiAgICBpZiAoYmFzZUNoYXJzZXRVcmkudGVzdCh0ZXh0KSB8fCBiYXNlVXJpLnRlc3QodGV4dCkpIHtcbiAgICAgIHJldHVybiBmcm9tQmFzZTY0KHRleHQuc3Vic3RyKFJlZ0V4cC5sYXN0TWF0Y2gubGVuZ3RoKSlcbiAgICB9XG5cbiAgICBsZXQgZW5jb2RpbmcgPSB0ZXh0Lm1hdGNoKC9kYXRhOmFwcGxpY2F0aW9uXFwvanNvbjsoW14sXSspLC8pWzFdXG4gICAgdGhyb3cgbmV3IEVycm9yKCdVbnN1cHBvcnRlZCBzb3VyY2UgbWFwIGVuY29kaW5nICcgKyBlbmNvZGluZylcbiAgfVxuXG4gIGxvYWRNYXAgKGZpbGUsIHByZXYpIHtcbiAgICBpZiAocHJldiA9PT0gZmFsc2UpIHJldHVybiBmYWxzZVxuXG4gICAgaWYgKHByZXYpIHtcbiAgICAgIGlmICh0eXBlb2YgcHJldiA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgcmV0dXJuIHByZXZcbiAgICAgIH0gZWxzZSBpZiAodHlwZW9mIHByZXYgPT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgbGV0IHByZXZQYXRoID0gcHJldihmaWxlKVxuICAgICAgICBpZiAocHJldlBhdGggJiYgZnMuZXhpc3RzU3luYyAmJiBmcy5leGlzdHNTeW5jKHByZXZQYXRoKSkge1xuICAgICAgICAgIHJldHVybiBmcy5yZWFkRmlsZVN5bmMocHJldlBhdGgsICd1dGYtOCcpLnRvU3RyaW5nKCkudHJpbSgpXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICAgICAgJ1VuYWJsZSB0byBsb2FkIHByZXZpb3VzIHNvdXJjZSBtYXA6ICcgKyBwcmV2UGF0aC50b1N0cmluZygpKVxuICAgICAgICB9XG4gICAgICB9IGVsc2UgaWYgKHByZXYgaW5zdGFuY2VvZiBtb3ppbGxhLlNvdXJjZU1hcENvbnN1bWVyKSB7XG4gICAgICAgIHJldHVybiBtb3ppbGxhLlNvdXJjZU1hcEdlbmVyYXRvci5mcm9tU291cmNlTWFwKHByZXYpLnRvU3RyaW5nKClcbiAgICAgIH0gZWxzZSBpZiAocHJldiBpbnN0YW5jZW9mIG1vemlsbGEuU291cmNlTWFwR2VuZXJhdG9yKSB7XG4gICAgICAgIHJldHVybiBwcmV2LnRvU3RyaW5nKClcbiAgICAgIH0gZWxzZSBpZiAodGhpcy5pc01hcChwcmV2KSkge1xuICAgICAgICByZXR1cm4gSlNPTi5zdHJpbmdpZnkocHJldilcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgICAnVW5zdXBwb3J0ZWQgcHJldmlvdXMgc291cmNlIG1hcCBmb3JtYXQ6ICcgKyBwcmV2LnRvU3RyaW5nKCkpXG4gICAgICB9XG4gICAgfSBlbHNlIGlmICh0aGlzLmlubGluZSkge1xuICAgICAgcmV0dXJuIHRoaXMuZGVjb2RlSW5saW5lKHRoaXMuYW5ub3RhdGlvbilcbiAgICB9IGVsc2UgaWYgKHRoaXMuYW5ub3RhdGlvbikge1xuICAgICAgbGV0IG1hcCA9IHRoaXMuYW5ub3RhdGlvblxuICAgICAgaWYgKGZpbGUpIG1hcCA9IHBhdGguam9pbihwYXRoLmRpcm5hbWUoZmlsZSksIG1hcClcblxuICAgICAgdGhpcy5yb290ID0gcGF0aC5kaXJuYW1lKG1hcClcbiAgICAgIGlmIChmcy5leGlzdHNTeW5jICYmIGZzLmV4aXN0c1N5bmMobWFwKSkge1xuICAgICAgICByZXR1cm4gZnMucmVhZEZpbGVTeW5jKG1hcCwgJ3V0Zi04JykudG9TdHJpbmcoKS50cmltKClcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBmYWxzZVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIGlzTWFwIChtYXApIHtcbiAgICBpZiAodHlwZW9mIG1hcCAhPT0gJ29iamVjdCcpIHJldHVybiBmYWxzZVxuICAgIHJldHVybiB0eXBlb2YgbWFwLm1hcHBpbmdzID09PSAnc3RyaW5nJyB8fCB0eXBlb2YgbWFwLl9tYXBwaW5ncyA9PT0gJ3N0cmluZydcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBQcmV2aW91c01hcFxuIl0sImZpbGUiOiJwcmV2aW91cy1tYXAuanMifQ==
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/processor.js b/node_modules/autoprefixer/node_modules/postcss/lib/processor.js
new file mode 100644
index 0000000..8dc8ea5
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/processor.js
@@ -0,0 +1,263 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _lazyResult = _interopRequireDefault(require("./lazy-result"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Contains plugins to process CSS. Create one `Processor` instance,
+ * initialize its plugins, and then use that instance on numerous CSS files.
+ *
+ * @example
+ * const processor = postcss([autoprefixer, precss])
+ * processor.process(css1).then(result => console.log(result.css))
+ * processor.process(css2).then(result => console.log(result.css))
+ */
+var Processor =
+/*#__PURE__*/
+function () {
+ /**
+ * @param {Array.<Plugin|pluginFunction>|Processor} plugins PostCSS plugins.
+ * See {@link Processor#use} for plugin format.
+ */
+ function Processor(plugins) {
+ if (plugins === void 0) {
+ plugins = [];
+ }
+
+ /**
+ * Current PostCSS version.
+ *
+ * @type {string}
+ *
+ * @example
+ * if (result.processor.version.split('.')[0] !== '6') {
+ * throw new Error('This plugin works only with PostCSS 6')
+ * }
+ */
+ this.version = '7.0.18';
+ /**
+ * Plugins added to this processor.
+ *
+ * @type {pluginFunction[]}
+ *
+ * @example
+ * const processor = postcss([autoprefixer, precss])
+ * processor.plugins.length //=> 2
+ */
+
+ this.plugins = this.normalize(plugins);
+ }
+ /**
+ * Adds a plugin to be used as a CSS processor.
+ *
+ * PostCSS plugin can be in 4 formats:
+ * * A plugin created by {@link postcss.plugin} method.
+ * * A function. PostCSS will pass the function a @{link Root}
+ * as the first argument and current {@link Result} instance
+ * as the second.
+ * * An object with a `postcss` method. PostCSS will use that method
+ * as described in #2.
+ * * Another {@link Processor} instance. PostCSS will copy plugins
+ * from that instance into this one.
+ *
+ * Plugins can also be added by passing them as arguments when creating
+ * a `postcss` instance (see [`postcss(plugins)`]).
+ *
+ * Asynchronous plugins should return a `Promise` instance.
+ *
+ * @param {Plugin|pluginFunction|Processor} plugin PostCSS plugin
+ * or {@link Processor}
+ * with plugins.
+ *
+ * @example
+ * const processor = postcss()
+ * .use(autoprefixer)
+ * .use(precss)
+ *
+ * @return {Processes} Current processor to make methods chain.
+ */
+
+
+ var _proto = Processor.prototype;
+
+ _proto.use = function use(plugin) {
+ this.plugins = this.plugins.concat(this.normalize([plugin]));
+ return this;
+ }
+ /**
+ * Parses source CSS and returns a {@link LazyResult} Promise proxy.
+ * Because some plugins can be asynchronous it doesn’t make
+ * any transformations. Transformations will be applied
+ * in the {@link LazyResult} methods.
+ *
+ * @param {string|toString|Result} css String with input CSS or any object
+ * with a `toString()` method,
+ * like a Buffer. Optionally, send
+ * a {@link Result} instance
+ * and the processor will take
+ * the {@link Root} from it.
+ * @param {processOptions} [opts] Options.
+ *
+ * @return {LazyResult} Promise proxy.
+ *
+ * @example
+ * processor.process(css, { from: 'a.css', to: 'a.out.css' })
+ * .then(result => {
+ * console.log(result.css)
+ * })
+ */
+ ;
+
+ _proto.process = function (_process) {
+ function process(_x) {
+ return _process.apply(this, arguments);
+ }
+
+ process.toString = function () {
+ return _process.toString();
+ };
+
+ return process;
+ }(function (css, opts) {
+ if (opts === void 0) {
+ opts = {};
+ }
+
+ if (this.plugins.length === 0 && opts.parser === opts.stringifier) {
+ if (process.env.NODE_ENV !== 'production') {
+ if (typeof console !== 'undefined' && console.warn) {
+ console.warn('You did not set any plugins, parser, or stringifier. ' + 'Right now, PostCSS does nothing. Pick plugins for your case ' + 'on https://www.postcss.parts/ and use them in postcss.config.js.');
+ }
+ }
+ }
+
+ return new _lazyResult.default(this, css, opts);
+ });
+
+ _proto.normalize = function normalize(plugins) {
+ var normalized = [];
+
+ for (var _iterator = plugins, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
+ var _ref;
+
+ if (_isArray) {
+ if (_i >= _iterator.length) break;
+ _ref = _iterator[_i++];
+ } else {
+ _i = _iterator.next();
+ if (_i.done) break;
+ _ref = _i.value;
+ }
+
+ var i = _ref;
+ if (i.postcss) i = i.postcss;
+
+ if (typeof i === 'object' && Array.isArray(i.plugins)) {
+ normalized = normalized.concat(i.plugins);
+ } else if (typeof i === 'function') {
+ normalized.push(i);
+ } else if (typeof i === 'object' && (i.parse || i.stringify)) {
+ if (process.env.NODE_ENV !== 'production') {
+ throw new Error('PostCSS syntaxes cannot be used as plugins. Instead, please use ' + 'one of the syntax/parser/stringifier options as outlined ' + 'in your PostCSS runner documentation.');
+ }
+ } else {
+ throw new Error(i + ' is not a PostCSS plugin');
+ }
+ }
+
+ return normalized;
+ };
+
+ return Processor;
+}();
+
+var _default = Processor;
+/**
+ * @callback builder
+ * @param {string} part Part of generated CSS connected to this node.
+ * @param {Node} node AST node.
+ * @param {"start"|"end"} [type] Node’s part type.
+ */
+
+/**
+ * @callback parser
+ *
+ * @param {string|toString} css String with input CSS or any object
+ * with toString() method, like a Buffer.
+ * @param {processOptions} [opts] Options with only `from` and `map` keys.
+ *
+ * @return {Root} PostCSS AST
+ */
+
+/**
+ * @callback stringifier
+ *
+ * @param {Node} node Start node for stringifing. Usually {@link Root}.
+ * @param {builder} builder Function to concatenate CSS from node’s parts
+ * or generate string and source map.
+ *
+ * @return {void}
+ */
+
+/**
+ * @typedef {object} syntax
+ * @property {parser} parse Function to generate AST by string.
+ * @property {stringifier} stringify Function to generate string by AST.
+ */
+
+/**
+ * @typedef {object} toString
+ * @property {function} toString
+ */
+
+/**
+ * @callback pluginFunction
+ * @param {Root} root Parsed input CSS.
+ * @param {Result} result Result to set warnings or check other plugins.
+ */
+
+/**
+ * @typedef {object} Plugin
+ * @property {function} postcss PostCSS plugin function.
+ */
+
+/**
+ * @typedef {object} processOptions
+ * @property {string} from The path of the CSS source file.
+ * You should always set `from`,
+ * because it is used in source map
+ * generation and syntax error messages.
+ * @property {string} to The path where you’ll put the output
+ * CSS file. You should always set `to`
+ * to generate correct source maps.
+ * @property {parser} parser Function to generate AST by string.
+ * @property {stringifier} stringifier Class to generate string by AST.
+ * @property {syntax} syntax Object with `parse` and `stringify`.
+ * @property {object} map Source map options.
+ * @property {boolean} map.inline Does source map should
+ * be embedded in the output
+ * CSS as a base64-encoded
+ * comment.
+ * @property {string|object|false|function} map.prev Source map content
+ * from a previous
+ * processing step
+ * (for example, Sass).
+ * PostCSS will try to find
+ * previous map automatically,
+ * so you could disable it by
+ * `false` value.
+ * @property {boolean} map.sourcesContent Does PostCSS should set
+ * the origin content to map.
+ * @property {string|false} map.annotation Does PostCSS should set
+ * annotation comment to map.
+ * @property {string} map.from Override `from` in map’s
+ * sources`.
+ */
+
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByb2Nlc3Nvci5lczYiXSwibmFtZXMiOlsiUHJvY2Vzc29yIiwicGx1Z2lucyIsInZlcnNpb24iLCJub3JtYWxpemUiLCJ1c2UiLCJwbHVnaW4iLCJjb25jYXQiLCJwcm9jZXNzIiwiY3NzIiwib3B0cyIsImxlbmd0aCIsInBhcnNlciIsInN0cmluZ2lmaWVyIiwiZW52IiwiTk9ERV9FTlYiLCJjb25zb2xlIiwid2FybiIsIkxhenlSZXN1bHQiLCJub3JtYWxpemVkIiwiaSIsInBvc3Rjc3MiLCJBcnJheSIsImlzQXJyYXkiLCJwdXNoIiwicGFyc2UiLCJzdHJpbmdpZnkiLCJFcnJvciJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQTs7OztBQUVBOzs7Ozs7Ozs7SUFTTUEsUzs7O0FBQ0o7Ozs7QUFJQSxxQkFBYUMsT0FBYixFQUEyQjtBQUFBLFFBQWRBLE9BQWM7QUFBZEEsTUFBQUEsT0FBYyxHQUFKLEVBQUk7QUFBQTs7QUFDekI7Ozs7Ozs7Ozs7QUFVQSxTQUFLQyxPQUFMLEdBQWUsUUFBZjtBQUNBOzs7Ozs7Ozs7O0FBU0EsU0FBS0QsT0FBTCxHQUFlLEtBQUtFLFNBQUwsQ0FBZUYsT0FBZixDQUFmO0FBQ0Q7QUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O1NBNkJBRyxHLEdBQUEsYUFBS0MsTUFBTCxFQUFhO0FBQ1gsU0FBS0osT0FBTCxHQUFlLEtBQUtBLE9BQUwsQ0FBYUssTUFBYixDQUFvQixLQUFLSCxTQUFMLENBQWUsQ0FBQ0UsTUFBRCxDQUFmLENBQXBCLENBQWY7QUFDQSxXQUFPLElBQVA7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7U0FzQkFFLE87Ozs7Ozs7Ozs7SUFBQSxVQUFTQyxHQUFULEVBQWNDLElBQWQsRUFBMEI7QUFBQSxRQUFaQSxJQUFZO0FBQVpBLE1BQUFBLElBQVksR0FBTCxFQUFLO0FBQUE7O0FBQ3hCLFFBQUksS0FBS1IsT0FBTCxDQUFhUyxNQUFiLEtBQXdCLENBQXhCLElBQTZCRCxJQUFJLENBQUNFLE1BQUwsS0FBZ0JGLElBQUksQ0FBQ0csV0FBdEQsRUFBbUU7QUFDakUsVUFBSUwsT0FBTyxDQUFDTSxHQUFSLENBQVlDLFFBQVosS0FBeUIsWUFBN0IsRUFBMkM7QUFDekMsWUFBSSxPQUFPQyxPQUFQLEtBQW1CLFdBQW5CLElBQWtDQSxPQUFPLENBQUNDLElBQTlDLEVBQW9EO0FBQ2xERCxVQUFBQSxPQUFPLENBQUNDLElBQVIsQ0FDRSwwREFDQSw4REFEQSxHQUVBLGtFQUhGO0FBS0Q7QUFDRjtBQUNGOztBQUNELFdBQU8sSUFBSUMsbUJBQUosQ0FBZSxJQUFmLEVBQXFCVCxHQUFyQixFQUEwQkMsSUFBMUIsQ0FBUDtBQUNELEc7O1NBRUROLFMsR0FBQSxtQkFBV0YsT0FBWCxFQUFvQjtBQUNsQixRQUFJaUIsVUFBVSxHQUFHLEVBQWpCOztBQUNBLHlCQUFjakIsT0FBZCxrSEFBdUI7QUFBQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUFBLFVBQWRrQixDQUFjO0FBQ3JCLFVBQUlBLENBQUMsQ0FBQ0MsT0FBTixFQUFlRCxDQUFDLEdBQUdBLENBQUMsQ0FBQ0MsT0FBTjs7QUFFZixVQUFJLE9BQU9ELENBQVAsS0FBYSxRQUFiLElBQXlCRSxLQUFLLENBQUNDLE9BQU4sQ0FBY0gsQ0FBQyxDQUFDbEIsT0FBaEIsQ0FBN0IsRUFBdUQ7QUFDckRpQixRQUFBQSxVQUFVLEdBQUdBLFVBQVUsQ0FBQ1osTUFBWCxDQUFrQmEsQ0FBQyxDQUFDbEIsT0FBcEIsQ0FBYjtBQUNELE9BRkQsTUFFTyxJQUFJLE9BQU9rQixDQUFQLEtBQWEsVUFBakIsRUFBNkI7QUFDbENELFFBQUFBLFVBQVUsQ0FBQ0ssSUFBWCxDQUFnQkosQ0FBaEI7QUFDRCxPQUZNLE1BRUEsSUFBSSxPQUFPQSxDQUFQLEtBQWEsUUFBYixLQUEwQkEsQ0FBQyxDQUFDSyxLQUFGLElBQVdMLENBQUMsQ0FBQ00sU0FBdkMsQ0FBSixFQUF1RDtBQUM1RCxZQUFJbEIsT0FBTyxDQUFDTSxHQUFSLENBQVlDLFFBQVosS0FBeUIsWUFBN0IsRUFBMkM7QUFDekMsZ0JBQU0sSUFBSVksS0FBSixDQUNKLHFFQUNBLDJEQURBLEdBRUEsdUNBSEksQ0FBTjtBQUtEO0FBQ0YsT0FSTSxNQVFBO0FBQ0wsY0FBTSxJQUFJQSxLQUFKLENBQVVQLENBQUMsR0FBRywwQkFBZCxDQUFOO0FBQ0Q7QUFDRjs7QUFDRCxXQUFPRCxVQUFQO0FBQ0QsRzs7Ozs7ZUFHWWxCLFM7QUFFZjs7Ozs7OztBQU9BOzs7Ozs7Ozs7O0FBVUE7Ozs7Ozs7Ozs7QUFVQTs7Ozs7O0FBTUE7Ozs7O0FBS0E7Ozs7OztBQU1BOzs7OztBQUtBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IExhenlSZXN1bHQgZnJvbSAnLi9sYXp5LXJlc3VsdCdcblxuLyoqXG4gKiBDb250YWlucyBwbHVnaW5zIHRvIHByb2Nlc3MgQ1NTLiBDcmVhdGUgb25lIGBQcm9jZXNzb3JgIGluc3RhbmNlLFxuICogaW5pdGlhbGl6ZSBpdHMgcGx1Z2lucywgYW5kIHRoZW4gdXNlIHRoYXQgaW5zdGFuY2Ugb24gbnVtZXJvdXMgQ1NTIGZpbGVzLlxuICpcbiAqIEBleGFtcGxlXG4gKiBjb25zdCBwcm9jZXNzb3IgPSBwb3N0Y3NzKFthdXRvcHJlZml4ZXIsIHByZWNzc10pXG4gKiBwcm9jZXNzb3IucHJvY2Vzcyhjc3MxKS50aGVuKHJlc3VsdCA9PiBjb25zb2xlLmxvZyhyZXN1bHQuY3NzKSlcbiAqIHByb2Nlc3Nvci5wcm9jZXNzKGNzczIpLnRoZW4ocmVzdWx0ID0+IGNvbnNvbGUubG9nKHJlc3VsdC5jc3MpKVxuICovXG5jbGFzcyBQcm9jZXNzb3Ige1xuICAvKipcbiAgICogQHBhcmFtIHtBcnJheS48UGx1Z2lufHBsdWdpbkZ1bmN0aW9uPnxQcm9jZXNzb3J9IHBsdWdpbnMgUG9zdENTUyBwbHVnaW5zLlxuICAgKiAgICAgICAgU2VlIHtAbGluayBQcm9jZXNzb3IjdXNlfSBmb3IgcGx1Z2luIGZvcm1hdC5cbiAgICovXG4gIGNvbnN0cnVjdG9yIChwbHVnaW5zID0gW10pIHtcbiAgICAvKipcbiAgICAgKiBDdXJyZW50IFBvc3RDU1MgdmVyc2lvbi5cbiAgICAgKlxuICAgICAqIEB0eXBlIHtzdHJpbmd9XG4gICAgICpcbiAgICAgKiBAZXhhbXBsZVxuICAgICAqIGlmIChyZXN1bHQucHJvY2Vzc29yLnZlcnNpb24uc3BsaXQoJy4nKVswXSAhPT0gJzYnKSB7XG4gICAgICogICB0aHJvdyBuZXcgRXJyb3IoJ1RoaXMgcGx1Z2luIHdvcmtzIG9ubHkgd2l0aCBQb3N0Q1NTIDYnKVxuICAgICAqIH1cbiAgICAgKi9cbiAgICB0aGlzLnZlcnNpb24gPSAnNy4wLjE4J1xuICAgIC8qKlxuICAgICAqIFBsdWdpbnMgYWRkZWQgdG8gdGhpcyBwcm9jZXNzb3IuXG4gICAgICpcbiAgICAgKiBAdHlwZSB7cGx1Z2luRnVuY3Rpb25bXX1cbiAgICAgKlxuICAgICAqIEBleGFtcGxlXG4gICAgICogY29uc3QgcHJvY2Vzc29yID0gcG9zdGNzcyhbYXV0b3ByZWZpeGVyLCBwcmVjc3NdKVxuICAgICAqIHByb2Nlc3Nvci5wbHVnaW5zLmxlbmd0aCAvLz0+IDJcbiAgICAgKi9cbiAgICB0aGlzLnBsdWdpbnMgPSB0aGlzLm5vcm1hbGl6ZShwbHVnaW5zKVxuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgYSBwbHVnaW4gdG8gYmUgdXNlZCBhcyBhIENTUyBwcm9jZXNzb3IuXG4gICAqXG4gICAqIFBvc3RDU1MgcGx1Z2luIGNhbiBiZSBpbiA0IGZvcm1hdHM6XG4gICAqICogQSBwbHVnaW4gY3JlYXRlZCBieSB7QGxpbmsgcG9zdGNzcy5wbHVnaW59IG1ldGhvZC5cbiAgICogKiBBIGZ1bmN0aW9uLiBQb3N0Q1NTIHdpbGwgcGFzcyB0aGUgZnVuY3Rpb24gYSBAe2xpbmsgUm9vdH1cbiAgICogICBhcyB0aGUgZmlyc3QgYXJndW1lbnQgYW5kIGN1cnJlbnQge0BsaW5rIFJlc3VsdH0gaW5zdGFuY2VcbiAgICogICBhcyB0aGUgc2Vjb25kLlxuICAgKiAqIEFuIG9iamVjdCB3aXRoIGEgYHBvc3Rjc3NgIG1ldGhvZC4gUG9zdENTUyB3aWxsIHVzZSB0aGF0IG1ldGhvZFxuICAgKiAgIGFzIGRlc2NyaWJlZCBpbiAjMi5cbiAgICogKiBBbm90aGVyIHtAbGluayBQcm9jZXNzb3J9IGluc3RhbmNlLiBQb3N0Q1NTIHdpbGwgY29weSBwbHVnaW5zXG4gICAqICAgZnJvbSB0aGF0IGluc3RhbmNlIGludG8gdGhpcyBvbmUuXG4gICAqXG4gICAqIFBsdWdpbnMgY2FuIGFsc28gYmUgYWRkZWQgYnkgcGFzc2luZyB0aGVtIGFzIGFyZ3VtZW50cyB3aGVuIGNyZWF0aW5nXG4gICAqIGEgYHBvc3Rjc3NgIGluc3RhbmNlIChzZWUgW2Bwb3N0Y3NzKHBsdWdpbnMpYF0pLlxuICAgKlxuICAgKiBBc3luY2hyb25vdXMgcGx1Z2lucyBzaG91bGQgcmV0dXJuIGEgYFByb21pc2VgIGluc3RhbmNlLlxuICAgKlxuICAgKiBAcGFyYW0ge1BsdWdpbnxwbHVnaW5GdW5jdGlvbnxQcm9jZXNzb3J9IHBsdWdpbiBQb3N0Q1NTIHBsdWdpblxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBvciB7QGxpbmsgUHJvY2Vzc29yfVxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aXRoIHBsdWdpbnMuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGNvbnN0IHByb2Nlc3NvciA9IHBvc3Rjc3MoKVxuICAgKiAgIC51c2UoYXV0b3ByZWZpeGVyKVxuICAgKiAgIC51c2UocHJlY3NzKVxuICAgKlxuICAgKiBAcmV0dXJuIHtQcm9jZXNzZXN9IEN1cnJlbnQgcHJvY2Vzc29yIHRvIG1ha2UgbWV0aG9kcyBjaGFpbi5cbiAgICovXG4gIHVzZSAocGx1Z2luKSB7XG4gICAgdGhpcy5wbHVnaW5zID0gdGhpcy5wbHVnaW5zLmNvbmNhdCh0aGlzLm5vcm1hbGl6ZShbcGx1Z2luXSkpXG4gICAgcmV0dXJuIHRoaXNcbiAgfVxuXG4gIC8qKlxuICAgKiBQYXJzZXMgc291cmNlIENTUyBhbmQgcmV0dXJucyBhIHtAbGluayBMYXp5UmVzdWx0fSBQcm9taXNlIHByb3h5LlxuICAgKiBCZWNhdXNlIHNvbWUgcGx1Z2lucyBjYW4gYmUgYXN5bmNocm9ub3VzIGl0IGRvZXNu4oCZdCBtYWtlXG4gICAqIGFueSB0cmFuc2Zvcm1hdGlvbnMuIFRyYW5zZm9ybWF0aW9ucyB3aWxsIGJlIGFwcGxpZWRcbiAgICogaW4gdGhlIHtAbGluayBMYXp5UmVzdWx0fSBtZXRob2RzLlxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ3x0b1N0cmluZ3xSZXN1bHR9IGNzcyBTdHJpbmcgd2l0aCBpbnB1dCBDU1Mgb3IgYW55IG9iamVjdFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB3aXRoIGEgYHRvU3RyaW5nKClgIG1ldGhvZCxcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGlrZSBhIEJ1ZmZlci4gT3B0aW9uYWxseSwgc2VuZFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhIHtAbGluayBSZXN1bHR9IGluc3RhbmNlXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFuZCB0aGUgcHJvY2Vzc29yIHdpbGwgdGFrZVxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aGUge0BsaW5rIFJvb3R9IGZyb20gaXQuXG4gICAqIEBwYXJhbSB7cHJvY2Vzc09wdGlvbnN9IFtvcHRzXSAgICAgIE9wdGlvbnMuXG4gICAqXG4gICAqIEByZXR1cm4ge0xhenlSZXN1bHR9IFByb21pc2UgcHJveHkuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIHByb2Nlc3Nvci5wcm9jZXNzKGNzcywgeyBmcm9tOiAnYS5jc3MnLCB0bzogJ2Eub3V0LmNzcycgfSlcbiAgICogICAudGhlbihyZXN1bHQgPT4ge1xuICAgKiAgICAgIGNvbnNvbGUubG9nKHJlc3VsdC5jc3MpXG4gICAqICAgfSlcbiAgICovXG4gIHByb2Nlc3MgKGNzcywgb3B0cyA9IHsgfSkge1xuICAgIGlmICh0aGlzLnBsdWdpbnMubGVuZ3RoID09PSAwICYmIG9wdHMucGFyc2VyID09PSBvcHRzLnN0cmluZ2lmaWVyKSB7XG4gICAgICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJykge1xuICAgICAgICBpZiAodHlwZW9mIGNvbnNvbGUgIT09ICd1bmRlZmluZWQnICYmIGNvbnNvbGUud2Fybikge1xuICAgICAgICAgIGNvbnNvbGUud2FybihcbiAgICAgICAgICAgICdZb3UgZGlkIG5vdCBzZXQgYW55IHBsdWdpbnMsIHBhcnNlciwgb3Igc3RyaW5naWZpZXIuICcgK1xuICAgICAgICAgICAgJ1JpZ2h0IG5vdywgUG9zdENTUyBkb2VzIG5vdGhpbmcuIFBpY2sgcGx1Z2lucyBmb3IgeW91ciBjYXNlICcgK1xuICAgICAgICAgICAgJ29uIGh0dHBzOi8vd3d3LnBvc3Rjc3MucGFydHMvIGFuZCB1c2UgdGhlbSBpbiBwb3N0Y3NzLmNvbmZpZy5qcy4nXG4gICAgICAgICAgKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBuZXcgTGF6eVJlc3VsdCh0aGlzLCBjc3MsIG9wdHMpXG4gIH1cblxuICBub3JtYWxpemUgKHBsdWdpbnMpIHtcbiAgICBsZXQgbm9ybWFsaXplZCA9IFtdXG4gICAgZm9yIChsZXQgaSBvZiBwbHVnaW5zKSB7XG4gICAgICBpZiAoaS5wb3N0Y3NzKSBpID0gaS5wb3N0Y3NzXG5cbiAgICAgIGlmICh0eXBlb2YgaSA9PT0gJ29iamVjdCcgJiYgQXJyYXkuaXNBcnJheShpLnBsdWdpbnMpKSB7XG4gICAgICAgIG5vcm1hbGl6ZWQgPSBub3JtYWxpemVkLmNvbmNhdChpLnBsdWdpbnMpXG4gICAgICB9IGVsc2UgaWYgKHR5cGVvZiBpID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIG5vcm1hbGl6ZWQucHVzaChpKVxuICAgICAgfSBlbHNlIGlmICh0eXBlb2YgaSA9PT0gJ29iamVjdCcgJiYgKGkucGFyc2UgfHwgaS5zdHJpbmdpZnkpKSB7XG4gICAgICAgIGlmIChwcm9jZXNzLmVudi5OT0RFX0VOViAhPT0gJ3Byb2R1Y3Rpb24nKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICAgICAgJ1Bvc3RDU1Mgc3ludGF4ZXMgY2Fubm90IGJlIHVzZWQgYXMgcGx1Z2lucy4gSW5zdGVhZCwgcGxlYXNlIHVzZSAnICtcbiAgICAgICAgICAgICdvbmUgb2YgdGhlIHN5bnRheC9wYXJzZXIvc3RyaW5naWZpZXIgb3B0aW9ucyBhcyBvdXRsaW5lZCAnICtcbiAgICAgICAgICAgICdpbiB5b3VyIFBvc3RDU1MgcnVubmVyIGRvY3VtZW50YXRpb24uJ1xuICAgICAgICAgIClcbiAgICAgICAgfVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGkgKyAnIGlzIG5vdCBhIFBvc3RDU1MgcGx1Z2luJylcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIG5vcm1hbGl6ZWRcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBQcm9jZXNzb3JcblxuLyoqXG4gKiBAY2FsbGJhY2sgYnVpbGRlclxuICogQHBhcmFtIHtzdHJpbmd9IHBhcnQgICAgICAgICAgUGFydCBvZiBnZW5lcmF0ZWQgQ1NTIGNvbm5lY3RlZCB0byB0aGlzIG5vZGUuXG4gKiBAcGFyYW0ge05vZGV9ICAgbm9kZSAgICAgICAgICBBU1Qgbm9kZS5cbiAqIEBwYXJhbSB7XCJzdGFydFwifFwiZW5kXCJ9IFt0eXBlXSBOb2Rl4oCZcyBwYXJ0IHR5cGUuXG4gKi9cblxuLyoqXG4gKiBAY2FsbGJhY2sgcGFyc2VyXG4gKlxuICogQHBhcmFtIHtzdHJpbmd8dG9TdHJpbmd9IGNzcyAgIFN0cmluZyB3aXRoIGlucHV0IENTUyBvciBhbnkgb2JqZWN0XG4gKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgd2l0aCB0b1N0cmluZygpIG1ldGhvZCwgbGlrZSBhIEJ1ZmZlci5cbiAqIEBwYXJhbSB7cHJvY2Vzc09wdGlvbnN9IFtvcHRzXSBPcHRpb25zIHdpdGggb25seSBgZnJvbWAgYW5kIGBtYXBgIGtleXMuXG4gKlxuICogQHJldHVybiB7Um9vdH0gUG9zdENTUyBBU1RcbiAqL1xuXG4vKipcbiAqIEBjYWxsYmFjayBzdHJpbmdpZmllclxuICpcbiAqIEBwYXJhbSB7Tm9kZX0gbm9kZSAgICAgICBTdGFydCBub2RlIGZvciBzdHJpbmdpZmluZy4gVXN1YWxseSB7QGxpbmsgUm9vdH0uXG4gKiBAcGFyYW0ge2J1aWxkZXJ9IGJ1aWxkZXIgRnVuY3Rpb24gdG8gY29uY2F0ZW5hdGUgQ1NTIGZyb20gbm9kZeKAmXMgcGFydHNcbiAqICAgICAgICAgICAgICAgICAgICAgICAgICBvciBnZW5lcmF0ZSBzdHJpbmcgYW5kIHNvdXJjZSBtYXAuXG4gKlxuICogQHJldHVybiB7dm9pZH1cbiAqL1xuXG4vKipcbiAqIEB0eXBlZGVmIHtvYmplY3R9IHN5bnRheFxuICogQHByb3BlcnR5IHtwYXJzZXJ9IHBhcnNlICAgICAgICAgIEZ1bmN0aW9uIHRvIGdlbmVyYXRlIEFTVCBieSBzdHJpbmcuXG4gKiBAcHJvcGVydHkge3N0cmluZ2lmaWVyfSBzdHJpbmdpZnkgRnVuY3Rpb24gdG8gZ2VuZXJhdGUgc3RyaW5nIGJ5IEFTVC5cbiAqL1xuXG4vKipcbiAqIEB0eXBlZGVmIHtvYmplY3R9IHRvU3RyaW5nXG4gKiBAcHJvcGVydHkge2Z1bmN0aW9ufSB0b1N0cmluZ1xuICovXG5cbi8qKlxuICogQGNhbGxiYWNrIHBsdWdpbkZ1bmN0aW9uXG4gKiBAcGFyYW0ge1Jvb3R9IHJvb3QgICAgIFBhcnNlZCBpbnB1dCBDU1MuXG4gKiBAcGFyYW0ge1Jlc3VsdH0gcmVzdWx0IFJlc3VsdCB0byBzZXQgd2FybmluZ3Mgb3IgY2hlY2sgb3RoZXIgcGx1Z2lucy5cbiAqL1xuXG4vKipcbiAqIEB0eXBlZGVmIHtvYmplY3R9IFBsdWdpblxuICogQHByb3BlcnR5IHtmdW5jdGlvbn0gcG9zdGNzcyBQb3N0Q1NTIHBsdWdpbiBmdW5jdGlvbi5cbiAqL1xuXG4vKipcbiAqIEB0eXBlZGVmIHtvYmplY3R9IHByb2Nlc3NPcHRpb25zXG4gKiBAcHJvcGVydHkge3N0cmluZ30gZnJvbSAgICAgICAgICAgICBUaGUgcGF0aCBvZiB0aGUgQ1NTIHNvdXJjZSBmaWxlLlxuICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgWW91IHNob3VsZCBhbHdheXMgc2V0IGBmcm9tYCxcbiAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJlY2F1c2UgaXQgaXMgdXNlZCBpbiBzb3VyY2UgbWFwXG4gKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lcmF0aW9uIGFuZCBzeW50YXggZXJyb3IgbWVzc2FnZXMuXG4gKiBAcHJvcGVydHkge3N0cmluZ30gdG8gICAgICAgICAgICAgICBUaGUgcGF0aCB3aGVyZSB5b3XigJlsbCBwdXQgdGhlIG91dHB1dFxuICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgQ1NTIGZpbGUuIFlvdSBzaG91bGQgYWx3YXlzIHNldCBgdG9gXG4gKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0byBnZW5lcmF0ZSBjb3JyZWN0IHNvdXJjZSBtYXBzLlxuICogQHByb3BlcnR5IHtwYXJzZXJ9IHBhcnNlciAgICAgICAgICAgRnVuY3Rpb24gdG8gZ2VuZXJhdGUgQVNUIGJ5IHN0cmluZy5cbiAqIEBwcm9wZXJ0eSB7c3RyaW5naWZpZXJ9IHN0cmluZ2lmaWVyIENsYXNzIHRvIGdlbmVyYXRlIHN0cmluZyBieSBBU1QuXG4gKiBAcHJvcGVydHkge3N5bnRheH0gc3ludGF4ICAgICAgICAgICBPYmplY3Qgd2l0aCBgcGFyc2VgIGFuZCBgc3RyaW5naWZ5YC5cbiAqIEBwcm9wZXJ0eSB7b2JqZWN0fSBtYXAgICAgICAgICAgICAgIFNvdXJjZSBtYXAgb3B0aW9ucy5cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gbWFwLmlubGluZSAgICAgICAgICAgICAgICAgICAgRG9lcyBzb3VyY2UgbWFwIHNob3VsZFxuICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiZSBlbWJlZGRlZCBpbiB0aGUgb3V0cHV0XG4gKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIENTUyBhcyBhIGJhc2U2NC1lbmNvZGVkXG4gKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNvbW1lbnQuXG4gKiBAcHJvcGVydHkge3N0cmluZ3xvYmplY3R8ZmFsc2V8ZnVuY3Rpb259IG1hcC5wcmV2IFNvdXJjZSBtYXAgY29udGVudFxuICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBmcm9tIGEgcHJldmlvdXNcbiAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcHJvY2Vzc2luZyBzdGVwXG4gKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIChmb3IgZXhhbXBsZSwgU2FzcykuXG4gKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFBvc3RDU1Mgd2lsbCB0cnkgdG8gZmluZFxuICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBwcmV2aW91cyBtYXAgYXV0b21hdGljYWxseSxcbiAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc28geW91IGNvdWxkIGRpc2FibGUgaXQgYnlcbiAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYGZhbHNlYCB2YWx1ZS5cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gbWFwLnNvdXJjZXNDb250ZW50ICAgICAgICAgICAgRG9lcyBQb3N0Q1NTIHNob3VsZCBzZXRcbiAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhlIG9yaWdpbiBjb250ZW50IHRvIG1hcC5cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfGZhbHNlfSBtYXAuYW5ub3RhdGlvbiAgICAgICAgICAgRG9lcyBQb3N0Q1NTIHNob3VsZCBzZXRcbiAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYW5ub3RhdGlvbiBjb21tZW50IHRvIG1hcC5cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBtYXAuZnJvbSAgICAgICAgICAgICAgICAgICAgICAgT3ZlcnJpZGUgYGZyb21gIGluIG1hcOKAmXNcbiAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc291cmNlc2AuXG4gKi9cbiJdLCJmaWxlIjoicHJvY2Vzc29yLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/result.js b/node_modules/autoprefixer/node_modules/postcss/lib/result.js
new file mode 100644
index 0000000..af3610a
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/result.js
@@ -0,0 +1,215 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _warning = _interopRequireDefault(require("./warning"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+/**
+ * Provides the result of the PostCSS transformations.
+ *
+ * A Result instance is returned by {@link LazyResult#then}
+ * or {@link Root#toResult} methods.
+ *
+ * @example
+ * postcss([autoprefixer]).process(css).then(result => {
+ * console.log(result.css)
+ * })
+ *
+ * @example
+ * const result2 = postcss.parse(css).toResult()
+ */
+var Result =
+/*#__PURE__*/
+function () {
+ /**
+ * @param {Processor} processor Processor used for this transformation.
+ * @param {Root} root Root node after all transformations.
+ * @param {processOptions} opts Options from the {@link Processor#process}
+ * or {@link Root#toResult}.
+ */
+ function Result(processor, root, opts) {
+ /**
+ * The Processor instance used for this transformation.
+ *
+ * @type {Processor}
+ *
+ * @example
+ * for (const plugin of result.processor.plugins) {
+ * if (plugin.postcssPlugin === 'postcss-bad') {
+ * throw 'postcss-good is incompatible with postcss-bad'
+ * }
+ * })
+ */
+ this.processor = processor;
+ /**
+ * Contains messages from plugins (e.g., warnings or custom messages).
+ * Each message should have type and plugin properties.
+ *
+ * @type {Message[]}
+ *
+ * @example
+ * postcss.plugin('postcss-min-browser', () => {
+ * return (root, result) => {
+ * const browsers = detectMinBrowsersByCanIUse(root)
+ * result.messages.push({
+ * type: 'min-browser',
+ * plugin: 'postcss-min-browser',
+ * browsers
+ * })
+ * }
+ * })
+ */
+
+ this.messages = [];
+ /**
+ * Root node after all transformations.
+ *
+ * @type {Root}
+ *
+ * @example
+ * root.toResult().root === root
+ */
+
+ this.root = root;
+ /**
+ * Options from the {@link Processor#process} or {@link Root#toResult} call
+ * that produced this Result instance.
+ *
+ * @type {processOptions}
+ *
+ * @example
+ * root.toResult(opts).opts === opts
+ */
+
+ this.opts = opts;
+ /**
+ * A CSS string representing of {@link Result#root}.
+ *
+ * @type {string}
+ *
+ * @example
+ * postcss.parse('a{}').toResult().css //=> "a{}"
+ */
+
+ this.css = undefined;
+ /**
+ * An instance of `SourceMapGenerator` class from the `source-map` library,
+ * representing changes to the {@link Result#root} instance.
+ *
+ * @type {SourceMapGenerator}
+ *
+ * @example
+ * result.map.toJSON() //=> { version: 3, file: 'a.css', … }
+ *
+ * @example
+ * if (result.map) {
+ * fs.writeFileSync(result.opts.to + '.map', result.map.toString())
+ * }
+ */
+
+ this.map = undefined;
+ }
+ /**
+ * Returns for @{link Result#css} content.
+ *
+ * @example
+ * result + '' === result.css
+ *
+ * @return {string} String representing of {@link Result#root}.
+ */
+
+
+ var _proto = Result.prototype;
+
+ _proto.toString = function toString() {
+ return this.css;
+ }
+ /**
+ * Creates an instance of {@link Warning} and adds it
+ * to {@link Result#messages}.
+ *
+ * @param {string} text Warning message.
+ * @param {Object} [opts] Warning options.
+ * @param {Node} opts.node CSS node that caused the warning.
+ * @param {string} opts.word Word in CSS source that caused the warning.
+ * @param {number} opts.index Index in CSS node string that caused
+ * the warning.
+ * @param {string} opts.plugin Name of the plugin that created
+ * this warning. {@link Result#warn} fills
+ * this property automatically.
+ *
+ * @return {Warning} Created warning.
+ */
+ ;
+
+ _proto.warn = function warn(text, opts) {
+ if (opts === void 0) {
+ opts = {};
+ }
+
+ if (!opts.plugin) {
+ if (this.lastPlugin && this.lastPlugin.postcssPlugin) {
+ opts.plugin = this.lastPlugin.postcssPlugin;
+ }
+ }
+
+ var warning = new _warning.default(text, opts);
+ this.messages.push(warning);
+ return warning;
+ }
+ /**
+ * Returns warnings from plugins. Filters {@link Warning} instances
+ * from {@link Result#messages}.
+ *
+ * @example
+ * result.warnings().forEach(warn => {
+ * console.warn(warn.toString())
+ * })
+ *
+ * @return {Warning[]} Warnings from plugins.
+ */
+ ;
+
+ _proto.warnings = function warnings() {
+ return this.messages.filter(function (i) {
+ return i.type === 'warning';
+ });
+ }
+ /**
+ * An alias for the {@link Result#css} property.
+ * Use it with syntaxes that generate non-CSS output.
+ *
+ * @type {string}
+ *
+ * @example
+ * result.css === result.content
+ */
+ ;
+
+ _createClass(Result, [{
+ key: "content",
+ get: function get() {
+ return this.css;
+ }
+ }]);
+
+ return Result;
+}();
+
+var _default = Result;
+/**
+ * @typedef {object} Message
+ * @property {string} type Message type.
+ * @property {string} plugin Source PostCSS plugin name.
+ */
+
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc3VsdC5lczYiXSwibmFtZXMiOlsiUmVzdWx0IiwicHJvY2Vzc29yIiwicm9vdCIsIm9wdHMiLCJtZXNzYWdlcyIsImNzcyIsInVuZGVmaW5lZCIsIm1hcCIsInRvU3RyaW5nIiwid2FybiIsInRleHQiLCJwbHVnaW4iLCJsYXN0UGx1Z2luIiwicG9zdGNzc1BsdWdpbiIsIndhcm5pbmciLCJXYXJuaW5nIiwicHVzaCIsIndhcm5pbmdzIiwiZmlsdGVyIiwiaSIsInR5cGUiXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7Ozs7Ozs7O0FBRUE7Ozs7Ozs7Ozs7Ozs7O0lBY01BLE07OztBQUNKOzs7Ozs7QUFNQSxrQkFBYUMsU0FBYixFQUF3QkMsSUFBeEIsRUFBOEJDLElBQTlCLEVBQW9DO0FBQ2xDOzs7Ozs7Ozs7Ozs7QUFZQSxTQUFLRixTQUFMLEdBQWlCQSxTQUFqQjtBQUNBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBa0JBLFNBQUtHLFFBQUwsR0FBZ0IsRUFBaEI7QUFDQTs7Ozs7Ozs7O0FBUUEsU0FBS0YsSUFBTCxHQUFZQSxJQUFaO0FBQ0E7Ozs7Ozs7Ozs7QUFTQSxTQUFLQyxJQUFMLEdBQVlBLElBQVo7QUFDQTs7Ozs7Ozs7O0FBUUEsU0FBS0UsR0FBTCxHQUFXQyxTQUFYO0FBQ0E7Ozs7Ozs7Ozs7Ozs7OztBQWNBLFNBQUtDLEdBQUwsR0FBV0QsU0FBWDtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7OztTQVFBRSxRLEdBQUEsb0JBQVk7QUFDVixXQUFPLEtBQUtILEdBQVo7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7U0FnQkFJLEksR0FBQSxjQUFNQyxJQUFOLEVBQVlQLElBQVosRUFBd0I7QUFBQSxRQUFaQSxJQUFZO0FBQVpBLE1BQUFBLElBQVksR0FBTCxFQUFLO0FBQUE7O0FBQ3RCLFFBQUksQ0FBQ0EsSUFBSSxDQUFDUSxNQUFWLEVBQWtCO0FBQ2hCLFVBQUksS0FBS0MsVUFBTCxJQUFtQixLQUFLQSxVQUFMLENBQWdCQyxhQUF2QyxFQUFzRDtBQUNwRFYsUUFBQUEsSUFBSSxDQUFDUSxNQUFMLEdBQWMsS0FBS0MsVUFBTCxDQUFnQkMsYUFBOUI7QUFDRDtBQUNGOztBQUVELFFBQUlDLE9BQU8sR0FBRyxJQUFJQyxnQkFBSixDQUFZTCxJQUFaLEVBQWtCUCxJQUFsQixDQUFkO0FBQ0EsU0FBS0MsUUFBTCxDQUFjWSxJQUFkLENBQW1CRixPQUFuQjtBQUVBLFdBQU9BLE9BQVA7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs7O1NBV0FHLFEsR0FBQSxvQkFBWTtBQUNWLFdBQU8sS0FBS2IsUUFBTCxDQUFjYyxNQUFkLENBQXFCLFVBQUFDLENBQUM7QUFBQSxhQUFJQSxDQUFDLENBQUNDLElBQUYsS0FBVyxTQUFmO0FBQUEsS0FBdEIsQ0FBUDtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7d0JBU2U7QUFDYixhQUFPLEtBQUtmLEdBQVo7QUFDRDs7Ozs7O2VBR1lMLE07QUFFZiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBXYXJuaW5nIGZyb20gJy4vd2FybmluZydcblxuLyoqXG4gKiBQcm92aWRlcyB0aGUgcmVzdWx0IG9mIHRoZSBQb3N0Q1NTIHRyYW5zZm9ybWF0aW9ucy5cbiAqXG4gKiBBIFJlc3VsdCBpbnN0YW5jZSBpcyByZXR1cm5lZCBieSB7QGxpbmsgTGF6eVJlc3VsdCN0aGVufVxuICogb3Ige0BsaW5rIFJvb3QjdG9SZXN1bHR9IG1ldGhvZHMuXG4gKlxuICogQGV4YW1wbGVcbiAqIHBvc3Rjc3MoW2F1dG9wcmVmaXhlcl0pLnByb2Nlc3MoY3NzKS50aGVuKHJlc3VsdCA9PiB7XG4gKiAgY29uc29sZS5sb2cocmVzdWx0LmNzcylcbiAqIH0pXG4gKlxuICogQGV4YW1wbGVcbiAqIGNvbnN0IHJlc3VsdDIgPSBwb3N0Y3NzLnBhcnNlKGNzcykudG9SZXN1bHQoKVxuICovXG5jbGFzcyBSZXN1bHQge1xuICAvKipcbiAgICogQHBhcmFtIHtQcm9jZXNzb3J9IHByb2Nlc3NvciBQcm9jZXNzb3IgdXNlZCBmb3IgdGhpcyB0cmFuc2Zvcm1hdGlvbi5cbiAgICogQHBhcmFtIHtSb290fSAgICAgIHJvb3QgICAgICBSb290IG5vZGUgYWZ0ZXIgYWxsIHRyYW5zZm9ybWF0aW9ucy5cbiAgICogQHBhcmFtIHtwcm9jZXNzT3B0aW9uc30gb3B0cyBPcHRpb25zIGZyb20gdGhlIHtAbGluayBQcm9jZXNzb3IjcHJvY2Vzc31cbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICBvciB7QGxpbmsgUm9vdCN0b1Jlc3VsdH0uXG4gICAqL1xuICBjb25zdHJ1Y3RvciAocHJvY2Vzc29yLCByb290LCBvcHRzKSB7XG4gICAgLyoqXG4gICAgICogVGhlIFByb2Nlc3NvciBpbnN0YW5jZSB1c2VkIGZvciB0aGlzIHRyYW5zZm9ybWF0aW9uLlxuICAgICAqXG4gICAgICogQHR5cGUge1Byb2Nlc3Nvcn1cbiAgICAgKlxuICAgICAqIEBleGFtcGxlXG4gICAgICogZm9yIChjb25zdCBwbHVnaW4gb2YgcmVzdWx0LnByb2Nlc3Nvci5wbHVnaW5zKSB7XG4gICAgICogICBpZiAocGx1Z2luLnBvc3Rjc3NQbHVnaW4gPT09ICdwb3N0Y3NzLWJhZCcpIHtcbiAgICAgKiAgICAgdGhyb3cgJ3Bvc3Rjc3MtZ29vZCBpcyBpbmNvbXBhdGlibGUgd2l0aCBwb3N0Y3NzLWJhZCdcbiAgICAgKiAgIH1cbiAgICAgKiB9KVxuICAgICAqL1xuICAgIHRoaXMucHJvY2Vzc29yID0gcHJvY2Vzc29yXG4gICAgLyoqXG4gICAgICogQ29udGFpbnMgbWVzc2FnZXMgZnJvbSBwbHVnaW5zIChlLmcuLCB3YXJuaW5ncyBvciBjdXN0b20gbWVzc2FnZXMpLlxuICAgICAqIEVhY2ggbWVzc2FnZSBzaG91bGQgaGF2ZSB0eXBlIGFuZCBwbHVnaW4gcHJvcGVydGllcy5cbiAgICAgKlxuICAgICAqIEB0eXBlIHtNZXNzYWdlW119XG4gICAgICpcbiAgICAgKiBAZXhhbXBsZVxuICAgICAqIHBvc3Rjc3MucGx1Z2luKCdwb3N0Y3NzLW1pbi1icm93c2VyJywgKCkgPT4ge1xuICAgICAqICAgcmV0dXJuIChyb290LCByZXN1bHQpID0+IHtcbiAgICAgKiAgICAgY29uc3QgYnJvd3NlcnMgPSBkZXRlY3RNaW5Ccm93c2Vyc0J5Q2FuSVVzZShyb290KVxuICAgICAqICAgICByZXN1bHQubWVzc2FnZXMucHVzaCh7XG4gICAgICogICAgICAgdHlwZTogJ21pbi1icm93c2VyJyxcbiAgICAgKiAgICAgICBwbHVnaW46ICdwb3N0Y3NzLW1pbi1icm93c2VyJyxcbiAgICAgKiAgICAgICBicm93c2Vyc1xuICAgICAqICAgICB9KVxuICAgICAqICAgfVxuICAgICAqIH0pXG4gICAgICovXG4gICAgdGhpcy5tZXNzYWdlcyA9IFtdXG4gICAgLyoqXG4gICAgICogUm9vdCBub2RlIGFmdGVyIGFsbCB0cmFuc2Zvcm1hdGlvbnMuXG4gICAgICpcbiAgICAgKiBAdHlwZSB7Um9vdH1cbiAgICAgKlxuICAgICAqIEBleGFtcGxlXG4gICAgICogcm9vdC50b1Jlc3VsdCgpLnJvb3QgPT09IHJvb3RcbiAgICAgKi9cbiAgICB0aGlzLnJvb3QgPSByb290XG4gICAgLyoqXG4gICAgICogT3B0aW9ucyBmcm9tIHRoZSB7QGxpbmsgUHJvY2Vzc29yI3Byb2Nlc3N9IG9yIHtAbGluayBSb290I3RvUmVzdWx0fSBjYWxsXG4gICAgICogdGhhdCBwcm9kdWNlZCB0aGlzIFJlc3VsdCBpbnN0YW5jZS5cbiAgICAgKlxuICAgICAqIEB0eXBlIHtwcm9jZXNzT3B0aW9uc31cbiAgICAgKlxuICAgICAqIEBleGFtcGxlXG4gICAgICogcm9vdC50b1Jlc3VsdChvcHRzKS5vcHRzID09PSBvcHRzXG4gICAgICovXG4gICAgdGhpcy5vcHRzID0gb3B0c1xuICAgIC8qKlxuICAgICAqIEEgQ1NTIHN0cmluZyByZXByZXNlbnRpbmcgb2Yge0BsaW5rIFJlc3VsdCNyb290fS5cbiAgICAgKlxuICAgICAqIEB0eXBlIHtzdHJpbmd9XG4gICAgICpcbiAgICAgKiBAZXhhbXBsZVxuICAgICAqIHBvc3Rjc3MucGFyc2UoJ2F7fScpLnRvUmVzdWx0KCkuY3NzIC8vPT4gXCJhe31cIlxuICAgICAqL1xuICAgIHRoaXMuY3NzID0gdW5kZWZpbmVkXG4gICAgLyoqXG4gICAgICogQW4gaW5zdGFuY2Ugb2YgYFNvdXJjZU1hcEdlbmVyYXRvcmAgY2xhc3MgZnJvbSB0aGUgYHNvdXJjZS1tYXBgIGxpYnJhcnksXG4gICAgICogcmVwcmVzZW50aW5nIGNoYW5nZXMgdG8gdGhlIHtAbGluayBSZXN1bHQjcm9vdH0gaW5zdGFuY2UuXG4gICAgICpcbiAgICAgKiBAdHlwZSB7U291cmNlTWFwR2VuZXJhdG9yfVxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiByZXN1bHQubWFwLnRvSlNPTigpIC8vPT4geyB2ZXJzaW9uOiAzLCBmaWxlOiAnYS5jc3MnLCDigKYgfVxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiBpZiAocmVzdWx0Lm1hcCkge1xuICAgICAqICAgZnMud3JpdGVGaWxlU3luYyhyZXN1bHQub3B0cy50byArICcubWFwJywgcmVzdWx0Lm1hcC50b1N0cmluZygpKVxuICAgICAqIH1cbiAgICAgKi9cbiAgICB0aGlzLm1hcCA9IHVuZGVmaW5lZFxuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgZm9yIEB7bGluayBSZXN1bHQjY3NzfSBjb250ZW50LlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiByZXN1bHQgKyAnJyA9PT0gcmVzdWx0LmNzc1xuICAgKlxuICAgKiBAcmV0dXJuIHtzdHJpbmd9IFN0cmluZyByZXByZXNlbnRpbmcgb2Yge0BsaW5rIFJlc3VsdCNyb290fS5cbiAgICovXG4gIHRvU3RyaW5nICgpIHtcbiAgICByZXR1cm4gdGhpcy5jc3NcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGFuIGluc3RhbmNlIG9mIHtAbGluayBXYXJuaW5nfSBhbmQgYWRkcyBpdFxuICAgKiB0byB7QGxpbmsgUmVzdWx0I21lc3NhZ2VzfS5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IHRleHQgICAgICAgIFdhcm5pbmcgbWVzc2FnZS5cbiAgICogQHBhcmFtIHtPYmplY3R9IFtvcHRzXSAgICAgIFdhcm5pbmcgb3B0aW9ucy5cbiAgICogQHBhcmFtIHtOb2RlfSAgIG9wdHMubm9kZSAgIENTUyBub2RlIHRoYXQgY2F1c2VkIHRoZSB3YXJuaW5nLlxuICAgKiBAcGFyYW0ge3N0cmluZ30gb3B0cy53b3JkICAgV29yZCBpbiBDU1Mgc291cmNlIHRoYXQgY2F1c2VkIHRoZSB3YXJuaW5nLlxuICAgKiBAcGFyYW0ge251bWJlcn0gb3B0cy5pbmRleCAgSW5kZXggaW4gQ1NTIG5vZGUgc3RyaW5nIHRoYXQgY2F1c2VkXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aGUgd2FybmluZy5cbiAgICogQHBhcmFtIHtzdHJpbmd9IG9wdHMucGx1Z2luIE5hbWUgb2YgdGhlIHBsdWdpbiB0aGF0IGNyZWF0ZWRcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMgd2FybmluZy4ge0BsaW5rIFJlc3VsdCN3YXJufSBmaWxsc1xuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcyBwcm9wZXJ0eSBhdXRvbWF0aWNhbGx5LlxuICAgKlxuICAgKiBAcmV0dXJuIHtXYXJuaW5nfSBDcmVhdGVkIHdhcm5pbmcuXG4gICAqL1xuICB3YXJuICh0ZXh0LCBvcHRzID0geyB9KSB7XG4gICAgaWYgKCFvcHRzLnBsdWdpbikge1xuICAgICAgaWYgKHRoaXMubGFzdFBsdWdpbiAmJiB0aGlzLmxhc3RQbHVnaW4ucG9zdGNzc1BsdWdpbikge1xuICAgICAgICBvcHRzLnBsdWdpbiA9IHRoaXMubGFzdFBsdWdpbi5wb3N0Y3NzUGx1Z2luXG4gICAgICB9XG4gICAgfVxuXG4gICAgbGV0IHdhcm5pbmcgPSBuZXcgV2FybmluZyh0ZXh0LCBvcHRzKVxuICAgIHRoaXMubWVzc2FnZXMucHVzaCh3YXJuaW5nKVxuXG4gICAgcmV0dXJuIHdhcm5pbmdcbiAgfVxuXG4gIC8qKlxuICAgICAqIFJldHVybnMgd2FybmluZ3MgZnJvbSBwbHVnaW5zLiBGaWx0ZXJzIHtAbGluayBXYXJuaW5nfSBpbnN0YW5jZXNcbiAgICAgKiBmcm9tIHtAbGluayBSZXN1bHQjbWVzc2FnZXN9LlxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiByZXN1bHQud2FybmluZ3MoKS5mb3JFYWNoKHdhcm4gPT4ge1xuICAgICAqICAgY29uc29sZS53YXJuKHdhcm4udG9TdHJpbmcoKSlcbiAgICAgKiB9KVxuICAgICAqXG4gICAgICogQHJldHVybiB7V2FybmluZ1tdfSBXYXJuaW5ncyBmcm9tIHBsdWdpbnMuXG4gICAgICovXG4gIHdhcm5pbmdzICgpIHtcbiAgICByZXR1cm4gdGhpcy5tZXNzYWdlcy5maWx0ZXIoaSA9PiBpLnR5cGUgPT09ICd3YXJuaW5nJylcbiAgfVxuXG4gIC8qKlxuICAgKiBBbiBhbGlhcyBmb3IgdGhlIHtAbGluayBSZXN1bHQjY3NzfSBwcm9wZXJ0eS5cbiAgICogVXNlIGl0IHdpdGggc3ludGF4ZXMgdGhhdCBnZW5lcmF0ZSBub24tQ1NTIG91dHB1dC5cbiAgICpcbiAgICogQHR5cGUge3N0cmluZ31cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcmVzdWx0LmNzcyA9PT0gcmVzdWx0LmNvbnRlbnRcbiAgICovXG4gIGdldCBjb250ZW50ICgpIHtcbiAgICByZXR1cm4gdGhpcy5jc3NcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBSZXN1bHRcblxuLyoqXG4gKiBAdHlwZWRlZiAge29iamVjdH0gTWVzc2FnZVxuICogQHByb3BlcnR5IHtzdHJpbmd9IHR5cGUgICBNZXNzYWdlIHR5cGUuXG4gKiBAcHJvcGVydHkge3N0cmluZ30gcGx1Z2luIFNvdXJjZSBQb3N0Q1NTIHBsdWdpbiBuYW1lLlxuICovXG4iXSwiZmlsZSI6InJlc3VsdC5qcyJ9
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/root.js b/node_modules/autoprefixer/node_modules/postcss/lib/root.js
new file mode 100644
index 0000000..95649b1
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/root.js
@@ -0,0 +1,129 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _container = _interopRequireDefault(require("./container"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
+
+/**
+ * Represents a CSS file and contains all its parsed nodes.
+ *
+ * @extends Container
+ *
+ * @example
+ * const root = postcss.parse('a{color:black} b{z-index:2}')
+ * root.type //=> 'root'
+ * root.nodes.length //=> 2
+ */
+var Root =
+/*#__PURE__*/
+function (_Container) {
+ _inheritsLoose(Root, _Container);
+
+ function Root(defaults) {
+ var _this;
+
+ _this = _Container.call(this, defaults) || this;
+ _this.type = 'root';
+ if (!_this.nodes) _this.nodes = [];
+ return _this;
+ }
+
+ var _proto = Root.prototype;
+
+ _proto.removeChild = function removeChild(child, ignore) {
+ var index = this.index(child);
+
+ if (!ignore && index === 0 && this.nodes.length > 1) {
+ this.nodes[1].raws.before = this.nodes[index].raws.before;
+ }
+
+ return _Container.prototype.removeChild.call(this, child);
+ };
+
+ _proto.normalize = function normalize(child, sample, type) {
+ var nodes = _Container.prototype.normalize.call(this, child);
+
+ if (sample) {
+ if (type === 'prepend') {
+ if (this.nodes.length > 1) {
+ sample.raws.before = this.nodes[1].raws.before;
+ } else {
+ delete sample.raws.before;
+ }
+ } else if (this.first !== sample) {
+ for (var _iterator = nodes, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
+ var _ref;
+
+ if (_isArray) {
+ if (_i >= _iterator.length) break;
+ _ref = _iterator[_i++];
+ } else {
+ _i = _iterator.next();
+ if (_i.done) break;
+ _ref = _i.value;
+ }
+
+ var node = _ref;
+ node.raws.before = sample.raws.before;
+ }
+ }
+ }
+
+ return nodes;
+ }
+ /**
+ * Returns a {@link Result} instance representing the root’s CSS.
+ *
+ * @param {processOptions} [opts] Options with only `to` and `map` keys.
+ *
+ * @return {Result} Result with current root’s CSS.
+ *
+ * @example
+ * const root1 = postcss.parse(css1, { from: 'a.css' })
+ * const root2 = postcss.parse(css2, { from: 'b.css' })
+ * root1.append(root2)
+ * const result = root1.toResult({ to: 'all.css', map: true })
+ */
+ ;
+
+ _proto.toResult = function toResult(opts) {
+ if (opts === void 0) {
+ opts = {};
+ }
+
+ var LazyResult = require('./lazy-result');
+
+ var Processor = require('./processor');
+
+ var lazy = new LazyResult(new Processor(), this, opts);
+ return lazy.stringify();
+ }
+ /**
+ * @memberof Root#
+ * @member {object} raws Information to generate byte-to-byte equal
+ * node string as it was in the origin input.
+ *
+ * Every parser saves its own properties,
+ * but the default CSS parser uses:
+ *
+ * * `after`: the space symbols after the last child to the end of file.
+ * * `semicolon`: is the last child has an (optional) semicolon.
+ *
+ * @example
+ * postcss.parse('a {}\n').raws //=> { after: '\n' }
+ * postcss.parse('a {}').raws //=> { after: '' }
+ */
+ ;
+
+ return Root;
+}(_container.default);
+
+var _default = Root;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJvb3QuZXM2Il0sIm5hbWVzIjpbIlJvb3QiLCJkZWZhdWx0cyIsInR5cGUiLCJub2RlcyIsInJlbW92ZUNoaWxkIiwiY2hpbGQiLCJpZ25vcmUiLCJpbmRleCIsImxlbmd0aCIsInJhd3MiLCJiZWZvcmUiLCJub3JtYWxpemUiLCJzYW1wbGUiLCJmaXJzdCIsIm5vZGUiLCJ0b1Jlc3VsdCIsIm9wdHMiLCJMYXp5UmVzdWx0IiwicmVxdWlyZSIsIlByb2Nlc3NvciIsImxhenkiLCJzdHJpbmdpZnkiLCJDb250YWluZXIiXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7Ozs7OztBQUVBOzs7Ozs7Ozs7O0lBVU1BLEk7Ozs7O0FBQ0osZ0JBQWFDLFFBQWIsRUFBdUI7QUFBQTs7QUFDckIsa0NBQU1BLFFBQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksTUFBWjtBQUNBLFFBQUksQ0FBQyxNQUFLQyxLQUFWLEVBQWlCLE1BQUtBLEtBQUwsR0FBYSxFQUFiO0FBSEk7QUFJdEI7Ozs7U0FFREMsVyxHQUFBLHFCQUFhQyxLQUFiLEVBQW9CQyxNQUFwQixFQUE0QjtBQUMxQixRQUFJQyxLQUFLLEdBQUcsS0FBS0EsS0FBTCxDQUFXRixLQUFYLENBQVo7O0FBRUEsUUFBSSxDQUFDQyxNQUFELElBQVdDLEtBQUssS0FBSyxDQUFyQixJQUEwQixLQUFLSixLQUFMLENBQVdLLE1BQVgsR0FBb0IsQ0FBbEQsRUFBcUQ7QUFDbkQsV0FBS0wsS0FBTCxDQUFXLENBQVgsRUFBY00sSUFBZCxDQUFtQkMsTUFBbkIsR0FBNEIsS0FBS1AsS0FBTCxDQUFXSSxLQUFYLEVBQWtCRSxJQUFsQixDQUF1QkMsTUFBbkQ7QUFDRDs7QUFFRCxnQ0FBYU4sV0FBYixZQUF5QkMsS0FBekI7QUFDRCxHOztTQUVETSxTLEdBQUEsbUJBQVdOLEtBQVgsRUFBa0JPLE1BQWxCLEVBQTBCVixJQUExQixFQUFnQztBQUM5QixRQUFJQyxLQUFLLHdCQUFTUSxTQUFULFlBQW1CTixLQUFuQixDQUFUOztBQUVBLFFBQUlPLE1BQUosRUFBWTtBQUNWLFVBQUlWLElBQUksS0FBSyxTQUFiLEVBQXdCO0FBQ3RCLFlBQUksS0FBS0MsS0FBTCxDQUFXSyxNQUFYLEdBQW9CLENBQXhCLEVBQTJCO0FBQ3pCSSxVQUFBQSxNQUFNLENBQUNILElBQVAsQ0FBWUMsTUFBWixHQUFxQixLQUFLUCxLQUFMLENBQVcsQ0FBWCxFQUFjTSxJQUFkLENBQW1CQyxNQUF4QztBQUNELFNBRkQsTUFFTztBQUNMLGlCQUFPRSxNQUFNLENBQUNILElBQVAsQ0FBWUMsTUFBbkI7QUFDRDtBQUNGLE9BTkQsTUFNTyxJQUFJLEtBQUtHLEtBQUwsS0FBZUQsTUFBbkIsRUFBMkI7QUFDaEMsNkJBQWlCVCxLQUFqQixrSEFBd0I7QUFBQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUFBLGNBQWZXLElBQWU7QUFDdEJBLFVBQUFBLElBQUksQ0FBQ0wsSUFBTCxDQUFVQyxNQUFWLEdBQW1CRSxNQUFNLENBQUNILElBQVAsQ0FBWUMsTUFBL0I7QUFDRDtBQUNGO0FBQ0Y7O0FBRUQsV0FBT1AsS0FBUDtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7OztTQWFBWSxRLEdBQUEsa0JBQVVDLElBQVYsRUFBc0I7QUFBQSxRQUFaQSxJQUFZO0FBQVpBLE1BQUFBLElBQVksR0FBTCxFQUFLO0FBQUE7O0FBQ3BCLFFBQUlDLFVBQVUsR0FBR0MsT0FBTyxDQUFDLGVBQUQsQ0FBeEI7O0FBQ0EsUUFBSUMsU0FBUyxHQUFHRCxPQUFPLENBQUMsYUFBRCxDQUF2Qjs7QUFFQSxRQUFJRSxJQUFJLEdBQUcsSUFBSUgsVUFBSixDQUFlLElBQUlFLFNBQUosRUFBZixFQUFnQyxJQUFoQyxFQUFzQ0gsSUFBdEMsQ0FBWDtBQUNBLFdBQU9JLElBQUksQ0FBQ0MsU0FBTCxFQUFQO0FBQ0Q7QUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7O0VBMURpQkMsa0I7O2VBMkVKdEIsSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBDb250YWluZXIgZnJvbSAnLi9jb250YWluZXInXG5cbi8qKlxuICogUmVwcmVzZW50cyBhIENTUyBmaWxlIGFuZCBjb250YWlucyBhbGwgaXRzIHBhcnNlZCBub2Rlcy5cbiAqXG4gKiBAZXh0ZW5kcyBDb250YWluZXJcbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2F7Y29sb3I6YmxhY2t9IGJ7ei1pbmRleDoyfScpXG4gKiByb290LnR5cGUgICAgICAgICAvLz0+ICdyb290J1xuICogcm9vdC5ub2Rlcy5sZW5ndGggLy89PiAyXG4gKi9cbmNsYXNzIFJvb3QgZXh0ZW5kcyBDb250YWluZXIge1xuICBjb25zdHJ1Y3RvciAoZGVmYXVsdHMpIHtcbiAgICBzdXBlcihkZWZhdWx0cylcbiAgICB0aGlzLnR5cGUgPSAncm9vdCdcbiAgICBpZiAoIXRoaXMubm9kZXMpIHRoaXMubm9kZXMgPSBbXVxuICB9XG5cbiAgcmVtb3ZlQ2hpbGQgKGNoaWxkLCBpZ25vcmUpIHtcbiAgICBsZXQgaW5kZXggPSB0aGlzLmluZGV4KGNoaWxkKVxuXG4gICAgaWYgKCFpZ25vcmUgJiYgaW5kZXggPT09IDAgJiYgdGhpcy5ub2Rlcy5sZW5ndGggPiAxKSB7XG4gICAgICB0aGlzLm5vZGVzWzFdLnJhd3MuYmVmb3JlID0gdGhpcy5ub2Rlc1tpbmRleF0ucmF3cy5iZWZvcmVcbiAgICB9XG5cbiAgICByZXR1cm4gc3VwZXIucmVtb3ZlQ2hpbGQoY2hpbGQpXG4gIH1cblxuICBub3JtYWxpemUgKGNoaWxkLCBzYW1wbGUsIHR5cGUpIHtcbiAgICBsZXQgbm9kZXMgPSBzdXBlci5ub3JtYWxpemUoY2hpbGQpXG5cbiAgICBpZiAoc2FtcGxlKSB7XG4gICAgICBpZiAodHlwZSA9PT0gJ3ByZXBlbmQnKSB7XG4gICAgICAgIGlmICh0aGlzLm5vZGVzLmxlbmd0aCA+IDEpIHtcbiAgICAgICAgICBzYW1wbGUucmF3cy5iZWZvcmUgPSB0aGlzLm5vZGVzWzFdLnJhd3MuYmVmb3JlXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgZGVsZXRlIHNhbXBsZS5yYXdzLmJlZm9yZVxuICAgICAgICB9XG4gICAgICB9IGVsc2UgaWYgKHRoaXMuZmlyc3QgIT09IHNhbXBsZSkge1xuICAgICAgICBmb3IgKGxldCBub2RlIG9mIG5vZGVzKSB7XG4gICAgICAgICAgbm9kZS5yYXdzLmJlZm9yZSA9IHNhbXBsZS5yYXdzLmJlZm9yZVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIG5vZGVzXG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyBhIHtAbGluayBSZXN1bHR9IGluc3RhbmNlIHJlcHJlc2VudGluZyB0aGUgcm9vdOKAmXMgQ1NTLlxuICAgKlxuICAgKiBAcGFyYW0ge3Byb2Nlc3NPcHRpb25zfSBbb3B0c10gT3B0aW9ucyB3aXRoIG9ubHkgYHRvYCBhbmQgYG1hcGAga2V5cy5cbiAgICpcbiAgICogQHJldHVybiB7UmVzdWx0fSBSZXN1bHQgd2l0aCBjdXJyZW50IHJvb3TigJlzIENTUy5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgcm9vdDEgPSBwb3N0Y3NzLnBhcnNlKGNzczEsIHsgZnJvbTogJ2EuY3NzJyB9KVxuICAgKiBjb25zdCByb290MiA9IHBvc3Rjc3MucGFyc2UoY3NzMiwgeyBmcm9tOiAnYi5jc3MnIH0pXG4gICAqIHJvb3QxLmFwcGVuZChyb290MilcbiAgICogY29uc3QgcmVzdWx0ID0gcm9vdDEudG9SZXN1bHQoeyB0bzogJ2FsbC5jc3MnLCBtYXA6IHRydWUgfSlcbiAgICovXG4gIHRvUmVzdWx0IChvcHRzID0geyB9KSB7XG4gICAgbGV0IExhenlSZXN1bHQgPSByZXF1aXJlKCcuL2xhenktcmVzdWx0JylcbiAgICBsZXQgUHJvY2Vzc29yID0gcmVxdWlyZSgnLi9wcm9jZXNzb3InKVxuXG4gICAgbGV0IGxhenkgPSBuZXcgTGF6eVJlc3VsdChuZXcgUHJvY2Vzc29yKCksIHRoaXMsIG9wdHMpXG4gICAgcmV0dXJuIGxhenkuc3RyaW5naWZ5KClcbiAgfVxuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgUm9vdCNcbiAgICogQG1lbWJlciB7b2JqZWN0fSByYXdzIEluZm9ybWF0aW9uIHRvIGdlbmVyYXRlIGJ5dGUtdG8tYnl0ZSBlcXVhbFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgbm9kZSBzdHJpbmcgYXMgaXQgd2FzIGluIHRoZSBvcmlnaW4gaW5wdXQuXG4gICAqXG4gICAqIEV2ZXJ5IHBhcnNlciBzYXZlcyBpdHMgb3duIHByb3BlcnRpZXMsXG4gICAqIGJ1dCB0aGUgZGVmYXVsdCBDU1MgcGFyc2VyIHVzZXM6XG4gICAqXG4gICAqICogYGFmdGVyYDogdGhlIHNwYWNlIHN5bWJvbHMgYWZ0ZXIgdGhlIGxhc3QgY2hpbGQgdG8gdGhlIGVuZCBvZiBmaWxlLlxuICAgKiAqIGBzZW1pY29sb25gOiBpcyB0aGUgbGFzdCBjaGlsZCBoYXMgYW4gKG9wdGlvbmFsKSBzZW1pY29sb24uXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIHBvc3Rjc3MucGFyc2UoJ2Ege31cXG4nKS5yYXdzIC8vPT4geyBhZnRlcjogJ1xcbicgfVxuICAgKiBwb3N0Y3NzLnBhcnNlKCdhIHt9JykucmF3cyAgIC8vPT4geyBhZnRlcjogJycgfVxuICAgKi9cbn1cblxuZXhwb3J0IGRlZmF1bHQgUm9vdFxuIl0sImZpbGUiOiJyb290LmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/rule.js b/node_modules/autoprefixer/node_modules/postcss/lib/rule.js
new file mode 100644
index 0000000..1fc1f85
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/rule.js
@@ -0,0 +1,118 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _container = _interopRequireDefault(require("./container"));
+
+var _list = _interopRequireDefault(require("./list"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
+
+/**
+ * Represents a CSS rule: a selector followed by a declaration block.
+ *
+ * @extends Container
+ *
+ * @example
+ * const root = postcss.parse('a{}')
+ * const rule = root.first
+ * rule.type //=> 'rule'
+ * rule.toString() //=> 'a{}'
+ */
+var Rule =
+/*#__PURE__*/
+function (_Container) {
+ _inheritsLoose(Rule, _Container);
+
+ function Rule(defaults) {
+ var _this;
+
+ _this = _Container.call(this, defaults) || this;
+ _this.type = 'rule';
+ if (!_this.nodes) _this.nodes = [];
+ return _this;
+ }
+ /**
+ * An array containing the rule’s individual selectors.
+ * Groups of selectors are split at commas.
+ *
+ * @type {string[]}
+ *
+ * @example
+ * const root = postcss.parse('a, b { }')
+ * const rule = root.first
+ *
+ * rule.selector //=> 'a, b'
+ * rule.selectors //=> ['a', 'b']
+ *
+ * rule.selectors = ['a', 'strong']
+ * rule.selector //=> 'a, strong'
+ */
+
+
+ _createClass(Rule, [{
+ key: "selectors",
+ get: function get() {
+ return _list.default.comma(this.selector);
+ },
+ set: function set(values) {
+ var match = this.selector ? this.selector.match(/,\s*/) : null;
+ var sep = match ? match[0] : ',' + this.raw('between', 'beforeOpen');
+ this.selector = values.join(sep);
+ }
+ /**
+ * @memberof Rule#
+ * @member {string} selector The rule’s full selector represented
+ * as a string.
+ *
+ * @example
+ * const root = postcss.parse('a, b { }')
+ * const rule = root.first
+ * rule.selector //=> 'a, b'
+ */
+
+ /**
+ * @memberof Rule#
+ * @member {object} raws Information to generate byte-to-byte equal
+ * node string as it was in the origin input.
+ *
+ * Every parser saves its own properties,
+ * but the default CSS parser uses:
+ *
+ * * `before`: the space symbols before the node. It also stores `*`
+ * and `_` symbols before the declaration (IE hack).
+ * * `after`: the space symbols after the last child of the node
+ * to the end of the node.
+ * * `between`: the symbols between the property and value
+ * for declarations, selector and `{` for rules, or last parameter
+ * and `{` for at-rules.
+ * * `semicolon`: contains `true` if the last child has
+ * an (optional) semicolon.
+ * * `ownSemicolon`: contains `true` if there is semicolon after rule.
+ *
+ * PostCSS cleans selectors from comments and extra spaces,
+ * but it stores origin content in raws properties.
+ * As such, if you don’t change a declaration’s value,
+ * PostCSS will use the raw value with comments.
+ *
+ * @example
+ * const root = postcss.parse('a {\n color:black\n}')
+ * root.first.first.raws //=> { before: '', between: ' ', after: '\n' }
+ */
+
+ }]);
+
+ return Rule;
+}(_container.default);
+
+var _default = Rule;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJ1bGUuZXM2Il0sIm5hbWVzIjpbIlJ1bGUiLCJkZWZhdWx0cyIsInR5cGUiLCJub2RlcyIsImxpc3QiLCJjb21tYSIsInNlbGVjdG9yIiwidmFsdWVzIiwibWF0Y2giLCJzZXAiLCJyYXciLCJqb2luIiwiQ29udGFpbmVyIl0sIm1hcHBpbmdzIjoiOzs7OztBQUFBOztBQUNBOzs7Ozs7Ozs7O0FBRUE7Ozs7Ozs7Ozs7O0lBV01BLEk7Ozs7O0FBQ0osZ0JBQWFDLFFBQWIsRUFBdUI7QUFBQTs7QUFDckIsa0NBQU1BLFFBQU47QUFDQSxVQUFLQyxJQUFMLEdBQVksTUFBWjtBQUNBLFFBQUksQ0FBQyxNQUFLQyxLQUFWLEVBQWlCLE1BQUtBLEtBQUwsR0FBYSxFQUFiO0FBSEk7QUFJdEI7QUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7d0JBZ0JpQjtBQUNmLGFBQU9DLGNBQUtDLEtBQUwsQ0FBVyxLQUFLQyxRQUFoQixDQUFQO0FBQ0QsSztzQkFFY0MsTSxFQUFRO0FBQ3JCLFVBQUlDLEtBQUssR0FBRyxLQUFLRixRQUFMLEdBQWdCLEtBQUtBLFFBQUwsQ0FBY0UsS0FBZCxDQUFvQixNQUFwQixDQUFoQixHQUE4QyxJQUExRDtBQUNBLFVBQUlDLEdBQUcsR0FBR0QsS0FBSyxHQUFHQSxLQUFLLENBQUMsQ0FBRCxDQUFSLEdBQWMsTUFBTSxLQUFLRSxHQUFMLENBQVMsU0FBVCxFQUFvQixZQUFwQixDQUFuQztBQUNBLFdBQUtKLFFBQUwsR0FBZ0JDLE1BQU0sQ0FBQ0ksSUFBUCxDQUFZRixHQUFaLENBQWhCO0FBQ0Q7QUFFRDs7Ozs7Ozs7Ozs7QUFXQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7RUE1Q2lCRyxrQjs7ZUEwRUpaLEkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQ29udGFpbmVyIGZyb20gJy4vY29udGFpbmVyJ1xuaW1wb3J0IGxpc3QgZnJvbSAnLi9saXN0J1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBDU1MgcnVsZTogYSBzZWxlY3RvciBmb2xsb3dlZCBieSBhIGRlY2xhcmF0aW9uIGJsb2NrLlxuICpcbiAqIEBleHRlbmRzIENvbnRhaW5lclxuICpcbiAqIEBleGFtcGxlXG4gKiBjb25zdCByb290ID0gcG9zdGNzcy5wYXJzZSgnYXt9JylcbiAqIGNvbnN0IHJ1bGUgPSByb290LmZpcnN0XG4gKiBydWxlLnR5cGUgICAgICAgLy89PiAncnVsZSdcbiAqIHJ1bGUudG9TdHJpbmcoKSAvLz0+ICdhe30nXG4gKi9cbmNsYXNzIFJ1bGUgZXh0ZW5kcyBDb250YWluZXIge1xuICBjb25zdHJ1Y3RvciAoZGVmYXVsdHMpIHtcbiAgICBzdXBlcihkZWZhdWx0cylcbiAgICB0aGlzLnR5cGUgPSAncnVsZSdcbiAgICBpZiAoIXRoaXMubm9kZXMpIHRoaXMubm9kZXMgPSBbXVxuICB9XG5cbiAgLyoqXG4gICAqIEFuIGFycmF5IGNvbnRhaW5pbmcgdGhlIHJ1bGXigJlzIGluZGl2aWR1YWwgc2VsZWN0b3JzLlxuICAgKiBHcm91cHMgb2Ygc2VsZWN0b3JzIGFyZSBzcGxpdCBhdCBjb21tYXMuXG4gICAqXG4gICAqIEB0eXBlIHtzdHJpbmdbXX1cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2EsIGIgeyB9JylcbiAgICogY29uc3QgcnVsZSA9IHJvb3QuZmlyc3RcbiAgICpcbiAgICogcnVsZS5zZWxlY3RvciAgLy89PiAnYSwgYidcbiAgICogcnVsZS5zZWxlY3RvcnMgLy89PiBbJ2EnLCAnYiddXG4gICAqXG4gICAqIHJ1bGUuc2VsZWN0b3JzID0gWydhJywgJ3N0cm9uZyddXG4gICAqIHJ1bGUuc2VsZWN0b3IgLy89PiAnYSwgc3Ryb25nJ1xuICAgKi9cbiAgZ2V0IHNlbGVjdG9ycyAoKSB7XG4gICAgcmV0dXJuIGxpc3QuY29tbWEodGhpcy5zZWxlY3RvcilcbiAgfVxuXG4gIHNldCBzZWxlY3RvcnMgKHZhbHVlcykge1xuICAgIGxldCBtYXRjaCA9IHRoaXMuc2VsZWN0b3IgPyB0aGlzLnNlbGVjdG9yLm1hdGNoKC8sXFxzKi8pIDogbnVsbFxuICAgIGxldCBzZXAgPSBtYXRjaCA/IG1hdGNoWzBdIDogJywnICsgdGhpcy5yYXcoJ2JldHdlZW4nLCAnYmVmb3JlT3BlbicpXG4gICAgdGhpcy5zZWxlY3RvciA9IHZhbHVlcy5qb2luKHNlcClcbiAgfVxuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgUnVsZSNcbiAgICogQG1lbWJlciB7c3RyaW5nfSBzZWxlY3RvciBUaGUgcnVsZeKAmXMgZnVsbCBzZWxlY3RvciByZXByZXNlbnRlZFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgIGFzIGEgc3RyaW5nLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBjb25zdCByb290ID0gcG9zdGNzcy5wYXJzZSgnYSwgYiB7IH0nKVxuICAgKiBjb25zdCBydWxlID0gcm9vdC5maXJzdFxuICAgKiBydWxlLnNlbGVjdG9yIC8vPT4gJ2EsIGInXG4gICAqL1xuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgUnVsZSNcbiAgICogQG1lbWJlciB7b2JqZWN0fSByYXdzIEluZm9ybWF0aW9uIHRvIGdlbmVyYXRlIGJ5dGUtdG8tYnl0ZSBlcXVhbFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgbm9kZSBzdHJpbmcgYXMgaXQgd2FzIGluIHRoZSBvcmlnaW4gaW5wdXQuXG4gICAqXG4gICAqIEV2ZXJ5IHBhcnNlciBzYXZlcyBpdHMgb3duIHByb3BlcnRpZXMsXG4gICAqIGJ1dCB0aGUgZGVmYXVsdCBDU1MgcGFyc2VyIHVzZXM6XG4gICAqXG4gICAqICogYGJlZm9yZWA6IHRoZSBzcGFjZSBzeW1ib2xzIGJlZm9yZSB0aGUgbm9kZS4gSXQgYWxzbyBzdG9yZXMgYCpgXG4gICAqICAgYW5kIGBfYCBzeW1ib2xzIGJlZm9yZSB0aGUgZGVjbGFyYXRpb24gKElFIGhhY2spLlxuICAgKiAqIGBhZnRlcmA6IHRoZSBzcGFjZSBzeW1ib2xzIGFmdGVyIHRoZSBsYXN0IGNoaWxkIG9mIHRoZSBub2RlXG4gICAqICAgdG8gdGhlIGVuZCBvZiB0aGUgbm9kZS5cbiAgICogKiBgYmV0d2VlbmA6IHRoZSBzeW1ib2xzIGJldHdlZW4gdGhlIHByb3BlcnR5IGFuZCB2YWx1ZVxuICAgKiAgIGZvciBkZWNsYXJhdGlvbnMsIHNlbGVjdG9yIGFuZCBge2AgZm9yIHJ1bGVzLCBvciBsYXN0IHBhcmFtZXRlclxuICAgKiAgIGFuZCBge2AgZm9yIGF0LXJ1bGVzLlxuICAgKiAqIGBzZW1pY29sb25gOiBjb250YWlucyBgdHJ1ZWAgaWYgdGhlIGxhc3QgY2hpbGQgaGFzXG4gICAqICAgYW4gKG9wdGlvbmFsKSBzZW1pY29sb24uXG4gICAqICogYG93blNlbWljb2xvbmA6IGNvbnRhaW5zIGB0cnVlYCBpZiB0aGVyZSBpcyBzZW1pY29sb24gYWZ0ZXIgcnVsZS5cbiAgICpcbiAgICogUG9zdENTUyBjbGVhbnMgc2VsZWN0b3JzIGZyb20gY29tbWVudHMgYW5kIGV4dHJhIHNwYWNlcyxcbiAgICogYnV0IGl0IHN0b3JlcyBvcmlnaW4gY29udGVudCBpbiByYXdzIHByb3BlcnRpZXMuXG4gICAqIEFzIHN1Y2gsIGlmIHlvdSBkb27igJl0IGNoYW5nZSBhIGRlY2xhcmF0aW9u4oCZcyB2YWx1ZSxcbiAgICogUG9zdENTUyB3aWxsIHVzZSB0aGUgcmF3IHZhbHVlIHdpdGggY29tbWVudHMuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGNvbnN0IHJvb3QgPSBwb3N0Y3NzLnBhcnNlKCdhIHtcXG4gIGNvbG9yOmJsYWNrXFxufScpXG4gICAqIHJvb3QuZmlyc3QuZmlyc3QucmF3cyAvLz0+IHsgYmVmb3JlOiAnJywgYmV0d2VlbjogJyAnLCBhZnRlcjogJ1xcbicgfVxuICAgKi9cbn1cblxuZXhwb3J0IGRlZmF1bHQgUnVsZVxuIl0sImZpbGUiOiJydWxlLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/stringifier.js b/node_modules/autoprefixer/node_modules/postcss/lib/stringifier.js
new file mode 100644
index 0000000..3ef3435
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/stringifier.js
@@ -0,0 +1,364 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+var DEFAULT_RAW = {
+ colon: ': ',
+ indent: ' ',
+ beforeDecl: '\n',
+ beforeRule: '\n',
+ beforeOpen: ' ',
+ beforeClose: '\n',
+ beforeComment: '\n',
+ after: '\n',
+ emptyBody: '',
+ commentLeft: ' ',
+ commentRight: ' ',
+ semicolon: false
+};
+
+function capitalize(str) {
+ return str[0].toUpperCase() + str.slice(1);
+}
+
+var Stringifier =
+/*#__PURE__*/
+function () {
+ function Stringifier(builder) {
+ this.builder = builder;
+ }
+
+ var _proto = Stringifier.prototype;
+
+ _proto.stringify = function stringify(node, semicolon) {
+ this[node.type](node, semicolon);
+ };
+
+ _proto.root = function root(node) {
+ this.body(node);
+ if (node.raws.after) this.builder(node.raws.after);
+ };
+
+ _proto.comment = function comment(node) {
+ var left = this.raw(node, 'left', 'commentLeft');
+ var right = this.raw(node, 'right', 'commentRight');
+ this.builder('/*' + left + node.text + right + '*/', node);
+ };
+
+ _proto.decl = function decl(node, semicolon) {
+ var between = this.raw(node, 'between', 'colon');
+ var string = node.prop + between + this.rawValue(node, 'value');
+
+ if (node.important) {
+ string += node.raws.important || ' !important';
+ }
+
+ if (semicolon) string += ';';
+ this.builder(string, node);
+ };
+
+ _proto.rule = function rule(node) {
+ this.block(node, this.rawValue(node, 'selector'));
+
+ if (node.raws.ownSemicolon) {
+ this.builder(node.raws.ownSemicolon, node, 'end');
+ }
+ };
+
+ _proto.atrule = function atrule(node, semicolon) {
+ var name = '@' + node.name;
+ var params = node.params ? this.rawValue(node, 'params') : '';
+
+ if (typeof node.raws.afterName !== 'undefined') {
+ name += node.raws.afterName;
+ } else if (params) {
+ name += ' ';
+ }
+
+ if (node.nodes) {
+ this.block(node, name + params);
+ } else {
+ var end = (node.raws.between || '') + (semicolon ? ';' : '');
+ this.builder(name + params + end, node);
+ }
+ };
+
+ _proto.body = function body(node) {
+ var last = node.nodes.length - 1;
+
+ while (last > 0) {
+ if (node.nodes[last].type !== 'comment') break;
+ last -= 1;
+ }
+
+ var semicolon = this.raw(node, 'semicolon');
+
+ for (var i = 0; i < node.nodes.length; i++) {
+ var child = node.nodes[i];
+ var before = this.raw(child, 'before');
+ if (before) this.builder(before);
+ this.stringify(child, last !== i || semicolon);
+ }
+ };
+
+ _proto.block = function block(node, start) {
+ var between = this.raw(node, 'between', 'beforeOpen');
+ this.builder(start + between + '{', node, 'start');
+ var after;
+
+ if (node.nodes && node.nodes.length) {
+ this.body(node);
+ after = this.raw(node, 'after');
+ } else {
+ after = this.raw(node, 'after', 'emptyBody');
+ }
+
+ if (after) this.builder(after);
+ this.builder('}', node, 'end');
+ };
+
+ _proto.raw = function raw(node, own, detect) {
+ var value;
+ if (!detect) detect = own; // Already had
+
+ if (own) {
+ value = node.raws[own];
+ if (typeof value !== 'undefined') return value;
+ }
+
+ var parent = node.parent; // Hack for first rule in CSS
+
+ if (detect === 'before') {
+ if (!parent || parent.type === 'root' && parent.first === node) {
+ return '';
+ }
+ } // Floating child without parent
+
+
+ if (!parent) return DEFAULT_RAW[detect]; // Detect style by other nodes
+
+ var root = node.root();
+ if (!root.rawCache) root.rawCache = {};
+
+ if (typeof root.rawCache[detect] !== 'undefined') {
+ return root.rawCache[detect];
+ }
+
+ if (detect === 'before' || detect === 'after') {
+ return this.beforeAfter(node, detect);
+ } else {
+ var method = 'raw' + capitalize(detect);
+
+ if (this[method]) {
+ value = this[method](root, node);
+ } else {
+ root.walk(function (i) {
+ value = i.raws[own];
+ if (typeof value !== 'undefined') return false;
+ });
+ }
+ }
+
+ if (typeof value === 'undefined') value = DEFAULT_RAW[detect];
+ root.rawCache[detect] = value;
+ return value;
+ };
+
+ _proto.rawSemicolon = function rawSemicolon(root) {
+ var value;
+ root.walk(function (i) {
+ if (i.nodes && i.nodes.length && i.last.type === 'decl') {
+ value = i.raws.semicolon;
+ if (typeof value !== 'undefined') return false;
+ }
+ });
+ return value;
+ };
+
+ _proto.rawEmptyBody = function rawEmptyBody(root) {
+ var value;
+ root.walk(function (i) {
+ if (i.nodes && i.nodes.length === 0) {
+ value = i.raws.after;
+ if (typeof value !== 'undefined') return false;
+ }
+ });
+ return value;
+ };
+
+ _proto.rawIndent = function rawIndent(root) {
+ if (root.raws.indent) return root.raws.indent;
+ var value;
+ root.walk(function (i) {
+ var p = i.parent;
+
+ if (p && p !== root && p.parent && p.parent === root) {
+ if (typeof i.raws.before !== 'undefined') {
+ var parts = i.raws.before.split('\n');
+ value = parts[parts.length - 1];
+ value = value.replace(/[^\s]/g, '');
+ return false;
+ }
+ }
+ });
+ return value;
+ };
+
+ _proto.rawBeforeComment = function rawBeforeComment(root, node) {
+ var value;
+ root.walkComments(function (i) {
+ if (typeof i.raws.before !== 'undefined') {
+ value = i.raws.before;
+
+ if (value.indexOf('\n') !== -1) {
+ value = value.replace(/[^\n]+$/, '');
+ }
+
+ return false;
+ }
+ });
+
+ if (typeof value === 'undefined') {
+ value = this.raw(node, null, 'beforeDecl');
+ } else if (value) {
+ value = value.replace(/[^\s]/g, '');
+ }
+
+ return value;
+ };
+
+ _proto.rawBeforeDecl = function rawBeforeDecl(root, node) {
+ var value;
+ root.walkDecls(function (i) {
+ if (typeof i.raws.before !== 'undefined') {
+ value = i.raws.before;
+
+ if (value.indexOf('\n') !== -1) {
+ value = value.replace(/[^\n]+$/, '');
+ }
+
+ return false;
+ }
+ });
+
+ if (typeof value === 'undefined') {
+ value = this.raw(node, null, 'beforeRule');
+ } else if (value) {
+ value = value.replace(/[^\s]/g, '');
+ }
+
+ return value;
+ };
+
+ _proto.rawBeforeRule = function rawBeforeRule(root) {
+ var value;
+ root.walk(function (i) {
+ if (i.nodes && (i.parent !== root || root.first !== i)) {
+ if (typeof i.raws.before !== 'undefined') {
+ value = i.raws.before;
+
+ if (value.indexOf('\n') !== -1) {
+ value = value.replace(/[^\n]+$/, '');
+ }
+
+ return false;
+ }
+ }
+ });
+ if (value) value = value.replace(/[^\s]/g, '');
+ return value;
+ };
+
+ _proto.rawBeforeClose = function rawBeforeClose(root) {
+ var value;
+ root.walk(function (i) {
+ if (i.nodes && i.nodes.length > 0) {
+ if (typeof i.raws.after !== 'undefined') {
+ value = i.raws.after;
+
+ if (value.indexOf('\n') !== -1) {
+ value = value.replace(/[^\n]+$/, '');
+ }
+
+ return false;
+ }
+ }
+ });
+ if (value) value = value.replace(/[^\s]/g, '');
+ return value;
+ };
+
+ _proto.rawBeforeOpen = function rawBeforeOpen(root) {
+ var value;
+ root.walk(function (i) {
+ if (i.type !== 'decl') {
+ value = i.raws.between;
+ if (typeof value !== 'undefined') return false;
+ }
+ });
+ return value;
+ };
+
+ _proto.rawColon = function rawColon(root) {
+ var value;
+ root.walkDecls(function (i) {
+ if (typeof i.raws.between !== 'undefined') {
+ value = i.raws.between.replace(/[^\s:]/g, '');
+ return false;
+ }
+ });
+ return value;
+ };
+
+ _proto.beforeAfter = function beforeAfter(node, detect) {
+ var value;
+
+ if (node.type === 'decl') {
+ value = this.raw(node, null, 'beforeDecl');
+ } else if (node.type === 'comment') {
+ value = this.raw(node, null, 'beforeComment');
+ } else if (detect === 'before') {
+ value = this.raw(node, null, 'beforeRule');
+ } else {
+ value = this.raw(node, null, 'beforeClose');
+ }
+
+ var buf = node.parent;
+ var depth = 0;
+
+ while (buf && buf.type !== 'root') {
+ depth += 1;
+ buf = buf.parent;
+ }
+
+ if (value.indexOf('\n') !== -1) {
+ var indent = this.raw(node, null, 'indent');
+
+ if (indent.length) {
+ for (var step = 0; step < depth; step++) {
+ value += indent;
+ }
+ }
+ }
+
+ return value;
+ };
+
+ _proto.rawValue = function rawValue(node, prop) {
+ var value = node[prop];
+ var raw = node.raws[prop];
+
+ if (raw && raw.value === value) {
+ return raw.raw;
+ }
+
+ return value;
+ };
+
+ return Stringifier;
+}();
+
+var _default = Stringifier;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0cmluZ2lmaWVyLmVzNiJdLCJuYW1lcyI6WyJERUZBVUxUX1JBVyIsImNvbG9uIiwiaW5kZW50IiwiYmVmb3JlRGVjbCIsImJlZm9yZVJ1bGUiLCJiZWZvcmVPcGVuIiwiYmVmb3JlQ2xvc2UiLCJiZWZvcmVDb21tZW50IiwiYWZ0ZXIiLCJlbXB0eUJvZHkiLCJjb21tZW50TGVmdCIsImNvbW1lbnRSaWdodCIsInNlbWljb2xvbiIsImNhcGl0YWxpemUiLCJzdHIiLCJ0b1VwcGVyQ2FzZSIsInNsaWNlIiwiU3RyaW5naWZpZXIiLCJidWlsZGVyIiwic3RyaW5naWZ5Iiwibm9kZSIsInR5cGUiLCJyb290IiwiYm9keSIsInJhd3MiLCJjb21tZW50IiwibGVmdCIsInJhdyIsInJpZ2h0IiwidGV4dCIsImRlY2wiLCJiZXR3ZWVuIiwic3RyaW5nIiwicHJvcCIsInJhd1ZhbHVlIiwiaW1wb3J0YW50IiwicnVsZSIsImJsb2NrIiwib3duU2VtaWNvbG9uIiwiYXRydWxlIiwibmFtZSIsInBhcmFtcyIsImFmdGVyTmFtZSIsIm5vZGVzIiwiZW5kIiwibGFzdCIsImxlbmd0aCIsImkiLCJjaGlsZCIsImJlZm9yZSIsInN0YXJ0Iiwib3duIiwiZGV0ZWN0IiwidmFsdWUiLCJwYXJlbnQiLCJmaXJzdCIsInJhd0NhY2hlIiwiYmVmb3JlQWZ0ZXIiLCJtZXRob2QiLCJ3YWxrIiwicmF3U2VtaWNvbG9uIiwicmF3RW1wdHlCb2R5IiwicmF3SW5kZW50IiwicCIsInBhcnRzIiwic3BsaXQiLCJyZXBsYWNlIiwicmF3QmVmb3JlQ29tbWVudCIsIndhbGtDb21tZW50cyIsImluZGV4T2YiLCJyYXdCZWZvcmVEZWNsIiwid2Fsa0RlY2xzIiwicmF3QmVmb3JlUnVsZSIsInJhd0JlZm9yZUNsb3NlIiwicmF3QmVmb3JlT3BlbiIsInJhd0NvbG9uIiwiYnVmIiwiZGVwdGgiLCJzdGVwIl0sIm1hcHBpbmdzIjoiOzs7O0FBQUEsSUFBTUEsV0FBVyxHQUFHO0FBQ2xCQyxFQUFB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UjtBQUNEOztBQUVELFFBQUl3RCxHQUFHLEdBQUd4RCxJQUFJLENBQUNrQyxNQUFmO0FBQ0EsUUFBSXVCLEtBQUssR0FBRyxDQUFaOztBQUNBLFdBQU9ELEdBQUcsSUFBSUEsR0FBRyxDQUFDdkQsSUFBSixLQUFhLE1BQTNCLEVBQW1DO0FBQ2pDd0QsTUFBQUEsS0FBSyxJQUFJLENBQVQ7QUFDQUQsTUFBQUEsR0FBRyxHQUFHQSxHQUFHLENBQUN0QixNQUFWO0FBQ0Q7O0FBRUQsUUFBSUQsS0FBSyxDQUFDZ0IsT0FBTixDQUFjLElBQWQsTUFBd0IsQ0FBQyxDQUE3QixFQUFnQztBQUM5QixVQUFJbkUsTUFBTSxHQUFHLEtBQUt5QixHQUFMLENBQVNQLElBQVQsRUFBZSxJQUFmLEVBQXFCLFFBQXJCLENBQWI7O0FBQ0EsVUFBSWxCLE1BQU0sQ0FBQzRDLE1BQVgsRUFBbUI7QUFDakIsYUFBSyxJQUFJZ0MsSUFBSSxHQUFHLENBQWhCLEVBQW1CQSxJQUFJLEdBQUdELEtBQTFCLEVBQWlDQyxJQUFJLEVBQXJDO0FBQXlDekIsVUFBQUEsS0FBSyxJQUFJbkQsTUFBVDtBQUF6QztBQUNEO0FBQ0Y7O0FBRUQsV0FBT21ELEtBQVA7QUFDRCxHOztTQUVEbkIsUSxHQUFBLGtCQUFVZCxJQUFWLEVBQWdCYSxJQUFoQixFQUFzQjtBQUNwQixRQUFJb0IsS0FBSyxHQUFHakMsSUFBSSxDQUFDYSxJQUFELENBQWhCO0FBQ0EsUUFBSU4sR0FBRyxHQUFHUCxJQUFJLENBQUNJLElBQUwsQ0FBVVMsSUFBVixDQUFWOztBQUNBLFFBQUlOLEdBQUcsSUFBSUEsR0FBRyxDQUFDMEIsS0FBSixLQUFjQSxLQUF6QixFQUFnQztBQUM5QixhQUFPMUIsR0FBRyxDQUFDQSxHQUFYO0FBQ0Q7O0FBRUQsV0FBTzBCLEtBQVA7QUFDRCxHOzs7OztlQUdZcEMsVyIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IERFRkFVTFRfUkFXID0ge1xuICBjb2xvbjogJzogJyxcbiAgaW5kZW50OiAnICAgICcsXG4gIGJlZm9yZURlY2w6ICdcXG4nLFxuICBiZWZvcmVSdWxlOiAnXFxuJyxcbiAgYmVmb3JlT3BlbjogJyAnLFxuICBiZWZvcmVDbG9zZTogJ1xcbicsXG4gIGJlZm9yZUNvbW1lbnQ6ICdcXG4nLFxuICBhZnRlcjogJ1xcbicsXG4gIGVtcHR5Qm9keTogJycsXG4gIGNvbW1lbnRMZWZ0OiAnICcsXG4gIGNvbW1lbnRSaWdodDogJyAnLFxuICBzZW1pY29sb246IGZhbHNlXG59XG5cbmZ1bmN0aW9uIGNhcGl0YWxpemUgKHN0cikge1xuICByZXR1cm4gc3RyWzBdLnRvVXBwZXJDYXNlKCkgKyBzdHIuc2xpY2UoMSlcbn1cblxuY2xhc3MgU3RyaW5naWZpZXIge1xuICBjb25zdHJ1Y3RvciAoYnVpbGRlcikge1xuICAgIHRoaXMuYnVpbGRlciA9IGJ1aWxkZXJcbiAgfVxuXG4gIHN0cmluZ2lmeSAobm9kZSwgc2VtaWNvbG9uKSB7XG4gICAgdGhpc1tub2RlLnR5cGVdKG5vZGUsIHNlbWljb2xvbilcbiAgfVxuXG4gIHJvb3QgKG5vZGUpIHtcbiAgICB0aGlzLmJvZHkobm9kZSlcbiAgICBpZiAobm9kZS5yYXdzLmFmdGVyKSB0aGlzLmJ1aWxkZXIobm9kZS5yYXdzLmFmdGVyKVxuICB9XG5cbiAgY29tbWVudCAobm9kZSkge1xuICAgIGxldCBsZWZ0ID0gdGhpcy5yYXcobm9kZSwgJ2xlZnQnLCAnY29tbWVudExlZnQnKVxuICAgIGxldCByaWdodCA9IHRoaXMucmF3KG5vZGUsICdyaWdodCcsICdjb21tZW50UmlnaHQnKVxuICAgIHRoaXMuYnVpbGRlcignLyonICsgbGVmdCArIG5vZGUudGV4dCArIHJpZ2h0ICsgJyovJywgbm9kZSlcbiAgfVxuXG4gIGRlY2wgKG5vZGUsIHNlbWljb2xvbikge1xuICAgIGxldCBiZXR3ZWVuID0gdGhpcy5yYXcobm9kZSwgJ2JldHdlZW4nLCAnY29sb24nKVxuICAgIGxldCBzdHJpbmcgPSBub2RlLnByb3AgKyBiZXR3ZWVuICsgdGhpcy5yYXdWYWx1ZShub2RlLCAndmFsdWUnKVxuXG4gICAgaWYgKG5vZGUuaW1wb3J0YW50KSB7XG4gICAgICBzdHJpbmcgKz0gbm9kZS5yYXdzLmltcG9ydGFudCB8fCAnICFpbXBvcnRhbnQnXG4gICAgfVxuXG4gICAgaWYgKHNlbWljb2xvbikgc3RyaW5nICs9ICc7J1xuICAgIHRoaXMuYnVpbGRlcihzdHJpbmcsIG5vZGUpXG4gIH1cblxuICBydWxlIChub2RlKSB7XG4gICAgdGhpcy5ibG9jayhub2RlLCB0aGlzLnJhd1ZhbHVlKG5vZGUsICdzZWxlY3RvcicpKVxuICAgIGlmIChub2RlLnJhd3Mub3duU2VtaWNvbG9uKSB7XG4gICAgICB0aGlzLmJ1aWxkZXIobm9kZS5yYXdzLm93blNlbWljb2xvbiwgbm9kZSwgJ2VuZCcpXG4gICAgfVxuICB9XG5cbiAgYXRydWxlIChub2RlLCBzZW1pY29sb24pIHtcbiAgICBsZXQgbmFtZSA9ICdAJyArIG5vZGUubmFtZVxuICAgIGxldCBwYXJhbXMgPSBub2RlLnBhcmFtcyA/IHRoaXMucmF3VmFsdWUobm9kZSwgJ3BhcmFtcycpIDogJydcblxuICAgIGlmICh0eXBlb2Ygbm9kZS5yYXdzLmFmdGVyTmFtZSAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgIG5hbWUgKz0gbm9kZS5yYXdzLmFmdGVyTmFtZVxuICAgIH0gZWxzZSBpZiAocGFyYW1zKSB7XG4gICAgICBuYW1lICs9ICcgJ1xuICAgIH1cblxuICAgIGlmIChub2RlLm5vZGVzKSB7XG4gICAgICB0aGlzLmJsb2NrKG5vZGUsIG5hbWUgKyBwYXJhbXMpXG4gICAgfSBlbHNlIHtcbiAgICAgIGxldCBlbmQgPSAobm9kZS5yYXdzLmJldHdlZW4gfHwgJycpICsgKHNlbWljb2xvbiA/ICc7JyA6ICcnKVxuICAgICAgdGhpcy5idWlsZGVyKG5hbWUgKyBwYXJhbXMgKyBlbmQsIG5vZGUpXG4gICAgfVxuICB9XG5cbiAgYm9keSAobm9kZSkge1xuICAgIGxldCBsYXN0ID0gbm9kZS5ub2Rlcy5sZW5ndGggLSAxXG4gICAgd2hpbGUgKGxhc3QgPiAwKSB7XG4gICAgICBpZiAobm9kZS5ub2Rlc1tsYXN0XS50eXBlICE9PSAnY29tbWVudCcpIGJyZWFrXG4gICAgICBsYXN0IC09IDFcbiAgICB9XG5cbiAgICBsZXQgc2VtaWNvbG9uID0gdGhpcy5yYXcobm9kZSwgJ3NlbWljb2xvbicpXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBub2RlLm5vZGVzLmxlbmd0aDsgaSsrKSB7XG4gICAgICBsZXQgY2hpbGQgPSBub2RlLm5vZGVzW2ldXG4gICAgICBsZXQgYmVmb3JlID0gdGhpcy5yYXcoY2hpbGQsICdiZWZvcmUnKVxuICAgICAgaWYgKGJlZm9yZSkgdGhpcy5idWlsZGVyKGJlZm9yZSlcbiAgICAgIHRoaXMuc3RyaW5naWZ5KGNoaWxkLCBsYXN0ICE9PSBpIHx8IHNlbWljb2xvbilcbiAgICB9XG4gIH1cblxuICBibG9jayAobm9kZSwgc3RhcnQpIHtcbiAgICBsZXQgYmV0d2VlbiA9IHRoaXMucmF3KG5vZGUsICdiZXR3ZWVuJywgJ2JlZm9yZU9wZW4nKVxuICAgIHRoaXMuYnVpbGRlcihzdGFydCArIGJldHdlZW4gKyAneycsIG5vZGUsICdzdGFydCcpXG5cbiAgICBsZXQgYWZ0ZXJcbiAgICBpZiAobm9kZS5ub2RlcyAmJiBub2RlLm5vZGVzLmxlbmd0aCkge1xuICAgICAgdGhpcy5ib2R5KG5vZGUpXG4gICAgICBhZnRlciA9IHRoaXMucmF3KG5vZGUsICdhZnRlcicpXG4gICAgfSBlbHNlIHtcbiAgICAgIGFmdGVyID0gdGhpcy5yYXcobm9kZSwgJ2FmdGVyJywgJ2VtcHR5Qm9keScpXG4gICAgfVxuXG4gICAgaWYgKGFmdGVyKSB0aGlzLmJ1aWxkZXIoYWZ0ZXIpXG4gICAgdGhpcy5idWlsZGVyKCd9Jywgbm9kZSwgJ2VuZCcpXG4gIH1cblxuICByYXcgKG5vZGUsIG93biwgZGV0ZWN0KSB7XG4gICAgbGV0IHZhbHVlXG4gICAgaWYgKCFkZXRlY3QpIGRldGVjdCA9IG93blxuXG4gICAgLy8gQWxyZWFkeSBoYWRcbiAgICBpZiAob3duKSB7XG4gICAgICB2YWx1ZSA9IG5vZGUucmF3c1tvd25dXG4gICAgICBpZiAodHlwZW9mIHZhbHVlICE9PSAndW5kZWZpbmVkJykgcmV0dXJuIHZhbHVlXG4gICAgfVxuXG4gICAgbGV0IHBhcmVudCA9IG5vZGUucGFyZW50XG5cbiAgICAvLyBIYWNrIGZvciBmaXJzdCBydWxlIGluIENTU1xuICAgIGlmIChkZXRlY3QgPT09ICdiZWZvcmUnKSB7XG4gICAgICBpZiAoIXBhcmVudCB8fCAocGFyZW50LnR5cGUgPT09ICdyb290JyAmJiBwYXJlbnQuZmlyc3QgPT09IG5vZGUpKSB7XG4gICAgICAgIHJldHVybiAnJ1xuICAgICAgfVxuICAgIH1cblxuICAgIC8vIEZsb2F0aW5nIGNoaWxkIHdpdGhvdXQgcGFyZW50XG4gICAgaWYgKCFwYXJlbnQpIHJldHVybiBERUZBVUxUX1JBV1tkZXRlY3RdXG5cbiAgICAvLyBEZXRlY3Qgc3R5bGUgYnkgb3RoZXIgbm9kZXNcbiAgICBsZXQgcm9vdCA9IG5vZGUucm9vdCgpXG4gICAgaWYgKCFyb290LnJhd0NhY2hlKSByb290LnJhd0NhY2hlID0geyB9XG4gICAgaWYgKHR5cGVvZiByb290LnJhd0NhY2hlW2RldGVjdF0gIT09ICd1bmRlZmluZWQnKSB7XG4gICAgICByZXR1cm4gcm9vdC5yYXdDYWNoZVtkZXRlY3RdXG4gICAgfVxuXG4gICAgaWYgKGRldGVjdCA9PT0gJ2JlZm9yZScgfHwgZGV0ZWN0ID09PSAnYWZ0ZXInKSB7XG4gICAgICByZXR1cm4gdGhpcy5iZWZvcmVBZnRlcihub2RlLCBkZXRlY3QpXG4gICAgfSBlbHNlIHtcbiAgICAgIGxldCBtZXRob2QgPSAncmF3JyArIGNhcGl0YWxpemUoZGV0ZWN0KVxuICAgICAgaWYgKHRoaXNbbWV0aG9kXSkge1xuICAgICAgICB2YWx1ZSA9IHRoaXNbbWV0aG9kXShyb290LCBub2RlKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcm9vdC53YWxrKGkgPT4ge1xuICAgICAgICAgIHZhbHVlID0gaS5yYXdzW293bl1cbiAgICAgICAgICBpZiAodHlwZW9mIHZhbHVlICE9PSAndW5kZWZpbmVkJykgcmV0dXJuIGZhbHNlXG4gICAgICAgIH0pXG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3VuZGVmaW5lZCcpIHZhbHVlID0gREVGQVVMVF9SQVdbZGV0ZWN0XVxuXG4gICAgcm9vdC5yYXdDYWNoZVtkZXRlY3RdID0gdmFsdWVcbiAgICByZXR1cm4gdmFsdWVcbiAgfVxuXG4gIHJhd1NlbWljb2xvbiAocm9vdCkge1xuICAgIGxldCB2YWx1ZVxuICAgIHJvb3Qud2FsayhpID0+IHtcbiAgICAgIGlmIChpLm5vZGVzICYmIGkubm9kZXMubGVuZ3RoICYmIGkubGFzdC50eXBlID09PSAnZGVjbCcpIHtcbiAgICAgICAgdmFsdWUgPSBpLnJhd3Muc2VtaWNvbG9uXG4gICAgICAgIGlmICh0eXBlb2YgdmFsdWUgIT09ICd1bmRlZmluZWQnKSByZXR1cm4gZmFsc2VcbiAgICAgIH1cbiAgICB9KVxuICAgIHJldHVybiB2YWx1ZVxuICB9XG5cbiAgcmF3RW1wdHlCb2R5IChyb290KSB7XG4gICAgbGV0IHZhbHVlXG4gICAgcm9vdC53YWxrKGkgPT4ge1xuICAgICAgaWYgKGkubm9kZXMgJiYgaS5ub2Rlcy5sZW5ndGggPT09IDApIHtcbiAgICAgICAgdmFsdWUgPSBpLnJhd3MuYWZ0ZXJcbiAgICAgICAgaWYgKHR5cGVvZiB2YWx1ZSAhPT0gJ3VuZGVmaW5lZCcpIHJldHVybiBmYWxzZVxuICAgICAgfVxuICAgIH0pXG4gICAgcmV0dXJuIHZhbHVlXG4gIH1cblxuICByYXdJbmRlbnQgKHJvb3QpIHtcbiAgICBpZiAocm9vdC5yYXdzLmluZGVudCkgcmV0dXJuIHJvb3QucmF3cy5pbmRlbnRcbiAgICBsZXQgdmFsdWVcbiAgICByb290LndhbGsoaSA9PiB7XG4gICAgICBsZXQgcCA9IGkucGFyZW50XG4gICAgICBpZiAocCAmJiBwICE9PSByb290ICYmIHAucGFyZW50ICYmIHAucGFyZW50ID09PSByb290KSB7XG4gICAgICAgIGlmICh0eXBlb2YgaS5yYXdzLmJlZm9yZSAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgICBsZXQgcGFydHMgPSBpLnJhd3MuYmVmb3JlLnNwbGl0KCdcXG4nKVxuICAgICAgICAgIHZhbHVlID0gcGFydHNbcGFydHMubGVuZ3RoIC0gMV1cbiAgICAgICAgICB2YWx1ZSA9IHZhbHVlLnJlcGxhY2UoL1teXFxzXS9nLCAnJylcbiAgICAgICAgICByZXR1cm4gZmFsc2VcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pXG4gICAgcmV0dXJuIHZhbHVlXG4gIH1cblxuICByYXdCZWZvcmVDb21tZW50IChyb290LCBub2RlKSB7XG4gICAgbGV0IHZhbHVlXG4gICAgcm9vdC53YWxrQ29tbWVudHMoaSA9PiB7XG4gICAgICBpZiAodHlwZW9mIGkucmF3cy5iZWZvcmUgIT09ICd1bmRlZmluZWQnKSB7XG4gICAgICAgIHZhbHVlID0gaS5yYXdzLmJlZm9yZVxuICAgICAgICBpZiAodmFsdWUuaW5kZXhPZignXFxuJykgIT09IC0xKSB7XG4gICAgICAgICAgdmFsdWUgPSB2YWx1ZS5yZXBsYWNlKC9bXlxcbl0rJC8sICcnKVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiBmYWxzZVxuICAgICAgfVxuICAgIH0pXG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgIHZhbHVlID0gdGhpcy5yYXcobm9kZSwgbnVsbCwgJ2JlZm9yZURlY2wnKVxuICAgIH0gZWxzZSBpZiAodmFsdWUpIHtcbiAgICAgIHZhbHVlID0gdmFsdWUucmVwbGFjZSgvW15cXHNdL2csICcnKVxuICAgIH1cbiAgICByZXR1cm4gdmFsdWVcbiAgfVxuXG4gIHJhd0JlZm9yZURlY2wgKHJvb3QsIG5vZGUpIHtcbiAgICBsZXQgdmFsdWVcbiAgICByb290LndhbGtEZWNscyhpID0+IHtcbiAgICAgIGlmICh0eXBlb2YgaS5yYXdzLmJlZm9yZSAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgdmFsdWUgPSBpLnJhd3MuYmVmb3JlXG4gICAgICAgIGlmICh2YWx1ZS5pbmRleE9mKCdcXG4nKSAhPT0gLTEpIHtcbiAgICAgICAgICB2YWx1ZSA9IHZhbHVlLnJlcGxhY2UoL1teXFxuXSskLywgJycpXG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGZhbHNlXG4gICAgICB9XG4gICAgfSlcbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAndW5kZWZpbmVkJykge1xuICAgICAgdmFsdWUgPSB0aGlzLnJhdyhub2RlLCBudWxsLCAnYmVmb3JlUnVsZScpXG4gICAgfSBlbHNlIGlmICh2YWx1ZSkge1xuICAgICAgdmFsdWUgPSB2YWx1ZS5yZXBsYWNlKC9bXlxcc10vZywgJycpXG4gICAgfVxuICAgIHJldHVybiB2YWx1ZVxuICB9XG5cbiAgcmF3QmVmb3JlUnVsZSAocm9vdCkge1xuICAgIGxldCB2YWx1ZVxuICAgIHJvb3Qud2FsayhpID0+IHtcbiAgICAgIGlmIChpLm5vZGVzICYmIChpLnBhcmVudCAhPT0gcm9vdCB8fCByb290LmZpcnN0ICE9PSBpKSkge1xuICAgICAgICBpZiAodHlwZW9mIGkucmF3cy5iZWZvcmUgIT09ICd1bmRlZmluZWQnKSB7XG4gICAgICAgICAgdmFsdWUgPSBpLnJhd3MuYmVmb3JlXG4gICAgICAgICAgaWYgKHZhbHVlLmluZGV4T2YoJ1xcbicpICE9PSAtMSkge1xuICAgICAgICAgICAgdmFsdWUgPSB2YWx1ZS5yZXBsYWNlKC9bXlxcbl0rJC8sICcnKVxuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gZmFsc2VcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pXG4gICAgaWYgKHZhbHVlKSB2YWx1ZSA9IHZhbHVlLnJlcGxhY2UoL1teXFxzXS9nLCAnJylcbiAgICByZXR1cm4gdmFsdWVcbiAgfVxuXG4gIHJhd0JlZm9yZUNsb3NlIChyb290KSB7XG4gICAgbGV0IHZhbHVlXG4gICAgcm9vdC53YWxrKGkgPT4ge1xuICAgICAgaWYgKGkubm9kZXMgJiYgaS5ub2Rlcy5sZW5ndGggPiAwKSB7XG4gICAgICAgIGlmICh0eXBlb2YgaS5yYXdzLmFmdGVyICE9PSAndW5kZWZpbmVkJykge1xuICAgICAgICAgIHZhbHVlID0gaS5yYXdzLmFmdGVyXG4gICAgICAgICAgaWYgKHZhbHVlLmluZGV4T2YoJ1xcbicpICE9PSAtMSkge1xuICAgICAgICAgICAgdmFsdWUgPSB2YWx1ZS5yZXBsYWNlKC9bXlxcbl0rJC8sICcnKVxuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gZmFsc2VcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pXG4gICAgaWYgKHZhbHVlKSB2YWx1ZSA9IHZhbHVlLnJlcGxhY2UoL1teXFxzXS9nLCAnJylcbiAgICByZXR1cm4gdmFsdWVcbiAgfVxuXG4gIHJhd0JlZm9yZU9wZW4gKHJvb3QpIHtcbiAgICBsZXQgdmFsdWVcbiAgICByb290LndhbGsoaSA9PiB7XG4gICAgICBpZiAoaS50eXBlICE9PSAnZGVjbCcpIHtcbiAgICAgICAgdmFsdWUgPSBpLnJhd3MuYmV0d2VlblxuICAgICAgICBpZiAodHlwZW9mIHZhbHVlICE9PSAndW5kZWZpbmVkJykgcmV0dXJuIGZhbHNlXG4gICAgICB9XG4gICAgfSlcbiAgICByZXR1cm4gdmFsdWVcbiAgfVxuXG4gIHJhd0NvbG9uIChyb290KSB7XG4gICAgbGV0IHZhbHVlXG4gICAgcm9vdC53YWxrRGVjbHMoaSA9PiB7XG4gICAgICBpZiAodHlwZW9mIGkucmF3cy5iZXR3ZWVuICE9PSAndW5kZWZpbmVkJykge1xuICAgICAgICB2YWx1ZSA9IGkucmF3cy5iZXR3ZWVuLnJlcGxhY2UoL1teXFxzOl0vZywgJycpXG4gICAgICAgIHJldHVybiBmYWxzZVxuICAgICAgfVxuICAgIH0pXG4gICAgcmV0dXJuIHZhbHVlXG4gIH1cblxuICBiZWZvcmVBZnRlciAobm9kZSwgZGV0ZWN0KSB7XG4gICAgbGV0IHZhbHVlXG4gICAgaWYgKG5vZGUudHlwZSA9PT0gJ2RlY2wnKSB7XG4gICAgICB2YWx1ZSA9IHRoaXMucmF3KG5vZGUsIG51bGwsICdiZWZvcmVEZWNsJylcbiAgICB9IGVsc2UgaWYgKG5vZGUudHlwZSA9PT0gJ2NvbW1lbnQnKSB7XG4gICAgICB2YWx1ZSA9IHRoaXMucmF3KG5vZGUsIG51bGwsICdiZWZvcmVDb21tZW50JylcbiAgICB9IGVsc2UgaWYgKGRldGVjdCA9PT0gJ2JlZm9yZScpIHtcbiAgICAgIHZhbHVlID0gdGhpcy5yYXcobm9kZSwgbnVsbCwgJ2JlZm9yZVJ1bGUnKVxuICAgIH0gZWxzZSB7XG4gICAgICB2YWx1ZSA9IHRoaXMucmF3KG5vZGUsIG51bGwsICdiZWZvcmVDbG9zZScpXG4gICAgfVxuXG4gICAgbGV0IGJ1ZiA9IG5vZGUucGFyZW50XG4gICAgbGV0IGRlcHRoID0gMFxuICAgIHdoaWxlIChidWYgJiYgYnVmLnR5cGUgIT09ICdyb290Jykge1xuICAgICAgZGVwdGggKz0gMVxuICAgICAgYnVmID0gYnVmLnBhcmVudFxuICAgIH1cblxuICAgIGlmICh2YWx1ZS5pbmRleE9mKCdcXG4nKSAhPT0gLTEpIHtcbiAgICAgIGxldCBpbmRlbnQgPSB0aGlzLnJhdyhub2RlLCBudWxsLCAnaW5kZW50JylcbiAgICAgIGlmIChpbmRlbnQubGVuZ3RoKSB7XG4gICAgICAgIGZvciAobGV0IHN0ZXAgPSAwOyBzdGVwIDwgZGVwdGg7IHN0ZXArKykgdmFsdWUgKz0gaW5kZW50XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHZhbHVlXG4gIH1cblxuICByYXdWYWx1ZSAobm9kZSwgcHJvcCkge1xuICAgIGxldCB2YWx1ZSA9IG5vZGVbcHJvcF1cbiAgICBsZXQgcmF3ID0gbm9kZS5yYXdzW3Byb3BdXG4gICAgaWYgKHJhdyAmJiByYXcudmFsdWUgPT09IHZhbHVlKSB7XG4gICAgICByZXR1cm4gcmF3LnJhd1xuICAgIH1cblxuICAgIHJldHVybiB2YWx1ZVxuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IFN0cmluZ2lmaWVyXG4iXSwiZmlsZSI6InN0cmluZ2lmaWVyLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/stringify.js b/node_modules/autoprefixer/node_modules/postcss/lib/stringify.js
new file mode 100644
index 0000000..6629ec3
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/stringify.js
@@ -0,0 +1,18 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _stringifier = _interopRequireDefault(require("./stringifier"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function stringify(node, builder) {
+ var str = new _stringifier.default(builder);
+ str.stringify(node);
+}
+
+var _default = stringify;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0cmluZ2lmeS5lczYiXSwibmFtZXMiOlsic3RyaW5naWZ5Iiwibm9kZSIsImJ1aWxkZXIiLCJzdHIiLCJTdHJpbmdpZmllciJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQTs7OztBQUVBLFNBQVNBLFNBQVQsQ0FBb0JDLElBQXBCLEVBQTBCQyxPQUExQixFQUFtQztBQUNqQyxNQUFJQyxHQUFHLEdBQUcsSUFBSUMsb0JBQUosQ0FBZ0JGLE9BQWhCLENBQVY7QUFDQUMsRUFBQUEsR0FBRyxDQUFDSCxTQUFKLENBQWNDLElBQWQ7QUFDRDs7ZUFFY0QsUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBTdHJpbmdpZmllciBmcm9tICcuL3N0cmluZ2lmaWVyJ1xuXG5mdW5jdGlvbiBzdHJpbmdpZnkgKG5vZGUsIGJ1aWxkZXIpIHtcbiAgbGV0IHN0ciA9IG5ldyBTdHJpbmdpZmllcihidWlsZGVyKVxuICBzdHIuc3RyaW5naWZ5KG5vZGUpXG59XG5cbmV4cG9ydCBkZWZhdWx0IHN0cmluZ2lmeVxuIl0sImZpbGUiOiJzdHJpbmdpZnkuanMifQ==
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/terminal-highlight.js b/node_modules/autoprefixer/node_modules/postcss/lib/terminal-highlight.js
new file mode 100644
index 0000000..78868ec
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/terminal-highlight.js
@@ -0,0 +1,84 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+var _chalk = _interopRequireDefault(require("chalk"));
+
+var _tokenize = _interopRequireDefault(require("./tokenize"));
+
+var _input = _interopRequireDefault(require("./input"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var HIGHLIGHT_THEME = {
+ 'brackets': _chalk.default.cyan,
+ 'at-word': _chalk.default.cyan,
+ 'comment': _chalk.default.gray,
+ 'string': _chalk.default.green,
+ 'class': _chalk.default.yellow,
+ 'call': _chalk.default.cyan,
+ 'hash': _chalk.default.magenta,
+ '(': _chalk.default.cyan,
+ ')': _chalk.default.cyan,
+ '{': _chalk.default.yellow,
+ '}': _chalk.default.yellow,
+ '[': _chalk.default.yellow,
+ ']': _chalk.default.yellow,
+ ':': _chalk.default.yellow,
+ ';': _chalk.default.yellow
+};
+
+function getTokenType(_ref, processor) {
+ var type = _ref[0],
+ value = _ref[1];
+
+ if (type === 'word') {
+ if (value[0] === '.') {
+ return 'class';
+ }
+
+ if (value[0] === '#') {
+ return 'hash';
+ }
+ }
+
+ if (!processor.endOfFile()) {
+ var next = processor.nextToken();
+ processor.back(next);
+ if (next[0] === 'brackets' || next[0] === '(') return 'call';
+ }
+
+ return type;
+}
+
+function terminalHighlight(css) {
+ var processor = (0, _tokenize.default)(new _input.default(css), {
+ ignoreErrors: true
+ });
+ var result = '';
+
+ var _loop = function _loop() {
+ var token = processor.nextToken();
+ var color = HIGHLIGHT_THEME[getTokenType(token, processor)];
+
+ if (color) {
+ result += token[1].split(/\r?\n/).map(function (i) {
+ return color(i);
+ }).join('\n');
+ } else {
+ result += token[1];
+ }
+ };
+
+ while (!processor.endOfFile()) {
+ _loop();
+ }
+
+ return result;
+}
+
+var _default = terminalHighlight;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlcm1pbmFsLWhpZ2hsaWdodC5lczYiXSwibmFtZXMiOlsiSElHSExJR0hUX1RIRU1FIiwiY2hhbGsiLCJjeWFuIiwiZ3JheSIsImdyZWVuIiwieWVsbG93IiwibWFnZW50YSIsImdldFRva2VuVHlwZSIsInByb2Nlc3NvciIsInR5cGUiLCJ2YWx1ZSIsImVuZE9mRmlsZSIsIm5leHQiLCJuZXh0VG9rZW4iLCJiYWNrIiwidGVybWluYWxIaWdobGlnaHQiLCJjc3MiLCJJbnB1dCIsImlnbm9yZUVycm9ycyIsInJlc3VsdCIsInRva2VuIiwiY29sb3IiLCJzcGxpdCIsIm1hcCIsImkiLCJqb2luIl0sIm1hcHBpbmdzIjoiOzs7OztBQUFBOztBQUVBOztBQUNBOzs7O0FBRUEsSUFBTUEsZUFBZSxHQUFHO0FBQ3RCLGNBQVlDLGVBQU1DLElBREk7QUFFdEIsYUFBV0QsZUFBTUMsSUFGSztBQUd0QixhQUFXRCxlQUFNRSxJQUhLO0FBSXRCLFlBQVVGLGVBQU1HLEtBSk07QUFLdEIsV0FBU0gsZUFBTUksTUFMTztBQU10QixVQUFRSixlQUFNQyxJQU5RO0FBT3RCLFVBQVFELGVBQU1LLE9BUFE7QUFRdEIsT0FBS0wsZUFBTUMsSUFSVztBQVN0QixPQUFLRCxlQUFNQyxJQVRXO0FBVXRCLE9BQUtELGVBQU1JLE1BVlc7QUFXdEIsT0FBS0osZUFBTUksTUFYVztBQVl0QixPQUFLSixlQUFNSSxNQVpXO0FBYXRCLE9BQUtKLGVBQU1JLE1BYlc7QUFjdEIsT0FBS0osZUFBTUksTUFkVztBQWV0QixPQUFLSixlQUFNSTtBQWZXLENBQXhCOztBQWtCQSxTQUFTRSxZQUFULE9BQXNDQyxTQUF0QyxFQUFpRDtBQUFBLE1BQXpCQyxJQUF5QjtBQUFBLE1BQW5CQyxLQUFtQjs7QUFDL0MsTUFBSUQsSUFBSSxLQUFLLE1BQWIsRUFBcUI7QUFDbkIsUUFBSUMsS0FBSyxDQUFDLENBQUQsQ0FBTCxLQUFhLEdBQWpCLEVBQXNCO0FBQ3BCLGFBQU8sT0FBUDtBQUNEOztBQUNELFFBQUlBLEtBQUssQ0FBQyxDQUFELENBQUwsS0FBYSxHQUFqQixFQUFzQjtBQUNwQixhQUFPLE1BQVA7QUFDRDtBQUNGOztBQUVELE1BQUksQ0FBQ0YsU0FBUyxDQUFDRyxTQUFWLEVBQUwsRUFBNEI7QUFDMUIsUUFBSUMsSUFBSSxHQUFHSixTQUFTLENBQUNLLFNBQVYsRUFBWDtBQUNBTCxJQUFBQSxTQUFTLENBQUNNLElBQVYsQ0FBZUYsSUFBZjtBQUNBLFFBQUlBLElBQUksQ0FBQyxDQUFELENBQUosS0FBWSxVQUFaLElBQTBCQSxJQUFJLENBQUMsQ0FBRCxDQUFKLEtBQVksR0FBMUMsRUFBK0MsT0FBTyxNQUFQO0FBQ2hEOztBQUVELFNBQU9ILElBQVA7QUFDRDs7QUFFRCxTQUFTTSxpQkFBVCxDQUE0QkMsR0FBNUIsRUFBaUM7QUFDL0IsTUFBSVIsU0FBUyxHQUFHLHVCQUFVLElBQUlTLGNBQUosQ0FBVUQsR0FBVixDQUFWLEVBQTBCO0FBQUVFLElBQUFBLFlBQVksRUFBRTtBQUFoQixHQUExQixDQUFoQjtBQUNBLE1BQUlDLE1BQU0sR0FBRyxFQUFiOztBQUYrQjtBQUk3QixRQUFJQyxLQUFLLEdBQUdaLFNBQVMsQ0FBQ0ssU0FBVixFQUFaO0FBQ0EsUUFBSVEsS0FBSyxHQUFHckIsZUFBZSxDQUFDTyxZQUFZLENBQUNhLEtBQUQsRUFBUVosU0FBUixDQUFiLENBQTNCOztBQUNBLFFBQUlhLEtBQUosRUFBVztBQUNURixNQUFBQSxNQUFNLElBQUlDLEtBQUssQ0FBQyxDQUFELENBQUwsQ0FBU0UsS0FBVCxDQUFlLE9BQWYsRUFDUEMsR0FETyxDQUNILFVBQUFDLENBQUM7QUFBQSxlQUFJSCxLQUFLLENBQUNHLENBQUQsQ0FBVDtBQUFBLE9BREUsRUFFUEMsSUFGTyxDQUVGLElBRkUsQ0FBVjtBQUdELEtBSkQsTUFJTztBQUNMTixNQUFBQSxNQUFNLElBQUlDLEtBQUssQ0FBQyxDQUFELENBQWY7QUFDRDtBQVo0Qjs7QUFHL0IsU0FBTyxDQUFDWixTQUFTLENBQUNHLFNBQVYsRUFBUixFQUErQjtBQUFBO0FBVTlCOztBQUNELFNBQU9RLE1BQVA7QUFDRDs7ZUFFY0osaUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2hhbGsgZnJvbSAnY2hhbGsnXG5cbmltcG9ydCB0b2tlbml6ZXIgZnJvbSAnLi90b2tlbml6ZSdcbmltcG9ydCBJbnB1dCBmcm9tICcuL2lucHV0J1xuXG5jb25zdCBISUdITElHSFRfVEhFTUUgPSB7XG4gICdicmFja2V0cyc6IGNoYWxrLmN5YW4sXG4gICdhdC13b3JkJzogY2hhbGsuY3lhbixcbiAgJ2NvbW1lbnQnOiBjaGFsay5ncmF5LFxuICAnc3RyaW5nJzogY2hhbGsuZ3JlZW4sXG4gICdjbGFzcyc6IGNoYWxrLnllbGxvdyxcbiAgJ2NhbGwnOiBjaGFsay5jeWFuLFxuICAnaGFzaCc6IGNoYWxrLm1hZ2VudGEsXG4gICcoJzogY2hhbGsuY3lhbixcbiAgJyknOiBjaGFsay5jeWFuLFxuICAneyc6IGNoYWxrLnllbGxvdyxcbiAgJ30nOiBjaGFsay55ZWxsb3csXG4gICdbJzogY2hhbGsueWVsbG93LFxuICAnXSc6IGNoYWxrLnllbGxvdyxcbiAgJzonOiBjaGFsay55ZWxsb3csXG4gICc7JzogY2hhbGsueWVsbG93XG59XG5cbmZ1bmN0aW9uIGdldFRva2VuVHlwZSAoW3R5cGUsIHZhbHVlXSwgcHJvY2Vzc29yKSB7XG4gIGlmICh0eXBlID09PSAnd29yZCcpIHtcbiAgICBpZiAodmFsdWVbMF0gPT09ICcuJykge1xuICAgICAgcmV0dXJuICdjbGFzcydcbiAgICB9XG4gICAgaWYgKHZhbHVlWzBdID09PSAnIycpIHtcbiAgICAgIHJldHVybiAnaGFzaCdcbiAgICB9XG4gIH1cblxuICBpZiAoIXByb2Nlc3Nvci5lbmRPZkZpbGUoKSkge1xuICAgIGxldCBuZXh0ID0gcHJvY2Vzc29yLm5leHRUb2tlbigpXG4gICAgcHJvY2Vzc29yLmJhY2sobmV4dClcbiAgICBpZiAobmV4dFswXSA9PT0gJ2JyYWNrZXRzJyB8fCBuZXh0WzBdID09PSAnKCcpIHJldHVybiAnY2FsbCdcbiAgfVxuXG4gIHJldHVybiB0eXBlXG59XG5cbmZ1bmN0aW9uIHRlcm1pbmFsSGlnaGxpZ2h0IChjc3MpIHtcbiAgbGV0IHByb2Nlc3NvciA9IHRva2VuaXplcihuZXcgSW5wdXQoY3NzKSwgeyBpZ25vcmVFcnJvcnM6IHRydWUgfSlcbiAgbGV0IHJlc3VsdCA9ICcnXG4gIHdoaWxlICghcHJvY2Vzc29yLmVuZE9mRmlsZSgpKSB7XG4gICAgbGV0IHRva2VuID0gcHJvY2Vzc29yLm5leHRUb2tlbigpXG4gICAgbGV0IGNvbG9yID0gSElHSExJR0hUX1RIRU1FW2dldFRva2VuVHlwZSh0b2tlbiwgcHJvY2Vzc29yKV1cbiAgICBpZiAoY29sb3IpIHtcbiAgICAgIHJlc3VsdCArPSB0b2tlblsxXS5zcGxpdCgvXFxyP1xcbi8pXG4gICAgICAgIC5tYXAoaSA9PiBjb2xvcihpKSlcbiAgICAgICAgLmpvaW4oJ1xcbicpXG4gICAgfSBlbHNlIHtcbiAgICAgIHJlc3VsdCArPSB0b2tlblsxXVxuICAgIH1cbiAgfVxuICByZXR1cm4gcmVzdWx0XG59XG5cbmV4cG9ydCBkZWZhdWx0IHRlcm1pbmFsSGlnaGxpZ2h0XG4iXSwiZmlsZSI6InRlcm1pbmFsLWhpZ2hsaWdodC5qcyJ9
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/tokenize.js b/node_modules/autoprefixer/node_modules/postcss/lib/tokenize.js
new file mode 100644
index 0000000..5b556bf
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/tokenize.js
@@ -0,0 +1,295 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = tokenizer;
+var SINGLE_QUOTE = '\''.charCodeAt(0);
+var DOUBLE_QUOTE = '"'.charCodeAt(0);
+var BACKSLASH = '\\'.charCodeAt(0);
+var SLASH = '/'.charCodeAt(0);
+var NEWLINE = '\n'.charCodeAt(0);
+var SPACE = ' '.charCodeAt(0);
+var FEED = '\f'.charCodeAt(0);
+var TAB = '\t'.charCodeAt(0);
+var CR = '\r'.charCodeAt(0);
+var OPEN_SQUARE = '['.charCodeAt(0);
+var CLOSE_SQUARE = ']'.charCodeAt(0);
+var OPEN_PARENTHESES = '('.charCodeAt(0);
+var CLOSE_PARENTHESES = ')'.charCodeAt(0);
+var OPEN_CURLY = '{'.charCodeAt(0);
+var CLOSE_CURLY = '}'.charCodeAt(0);
+var SEMICOLON = ';'.charCodeAt(0);
+var ASTERISK = '*'.charCodeAt(0);
+var COLON = ':'.charCodeAt(0);
+var AT = '@'.charCodeAt(0);
+var RE_AT_END = /[ \n\t\r\f{}()'"\\;/[\]#]/g;
+var RE_WORD_END = /[ \n\t\r\f(){}:;@!'"\\\][#]|\/(?=\*)/g;
+var RE_BAD_BRACKET = /.[\\/("'\n]/;
+var RE_HEX_ESCAPE = /[a-f0-9]/i;
+
+function tokenizer(input, options) {
+ if (options === void 0) {
+ options = {};
+ }
+
+ var css = input.css.valueOf();
+ var ignore = options.ignoreErrors;
+ var code, next, quote, lines, last, content, escape;
+ var nextLine, nextOffset, escaped, escapePos, prev, n, currentToken;
+ var length = css.length;
+ var offset = -1;
+ var line = 1;
+ var pos = 0;
+ var buffer = [];
+ var returned = [];
+
+ function position() {
+ return pos;
+ }
+
+ function unclosed(what) {
+ throw input.error('Unclosed ' + what, line, pos - offset);
+ }
+
+ function endOfFile() {
+ return returned.length === 0 && pos >= length;
+ }
+
+ function nextToken(opts) {
+ if (returned.length) return returned.pop();
+ if (pos >= length) return;
+ var ignoreUnclosed = opts ? opts.ignoreUnclosed : false;
+ code = css.charCodeAt(pos);
+
+ if (code === NEWLINE || code === FEED || code === CR && css.charCodeAt(pos + 1) !== NEWLINE) {
+ offset = pos;
+ line += 1;
+ }
+
+ switch (code) {
+ case NEWLINE:
+ case SPACE:
+ case TAB:
+ case CR:
+ case FEED:
+ next = pos;
+
+ do {
+ next += 1;
+ code = css.charCodeAt(next);
+
+ if (code === NEWLINE) {
+ offset = next;
+ line += 1;
+ }
+ } while (code === SPACE || code === NEWLINE || code === TAB || code === CR || code === FEED);
+
+ currentToken = ['space', css.slice(pos, next)];
+ pos = next - 1;
+ break;
+
+ case OPEN_SQUARE:
+ case CLOSE_SQUARE:
+ case OPEN_CURLY:
+ case CLOSE_CURLY:
+ case COLON:
+ case SEMICOLON:
+ case CLOSE_PARENTHESES:
+ var controlChar = String.fromCharCode(code);
+ currentToken = [controlChar, controlChar, line, pos - offset];
+ break;
+
+ case OPEN_PARENTHESES:
+ prev = buffer.length ? buffer.pop()[1] : '';
+ n = css.charCodeAt(pos + 1);
+
+ if (prev === 'url' && n !== SINGLE_QUOTE && n !== DOUBLE_QUOTE && n !== SPACE && n !== NEWLINE && n !== TAB && n !== FEED && n !== CR) {
+ next = pos;
+
+ do {
+ escaped = false;
+ next = css.indexOf(')', next + 1);
+
+ if (next === -1) {
+ if (ignore || ignoreUnclosed) {
+ next = pos;
+ break;
+ } else {
+ unclosed('bracket');
+ }
+ }
+
+ escapePos = next;
+
+ while (css.charCodeAt(escapePos - 1) === BACKSLASH) {
+ escapePos -= 1;
+ escaped = !escaped;
+ }
+ } while (escaped);
+
+ currentToken = ['brackets', css.slice(pos, next + 1), line, pos - offset, line, next - offset];
+ pos = next;
+ } else {
+ next = css.indexOf(')', pos + 1);
+ content = css.slice(pos, next + 1);
+
+ if (next === -1 || RE_BAD_BRACKET.test(content)) {
+ currentToken = ['(', '(', line, pos - offset];
+ } else {
+ currentToken = ['brackets', content, line, pos - offset, line, next - offset];
+ pos = next;
+ }
+ }
+
+ break;
+
+ case SINGLE_QUOTE:
+ case DOUBLE_QUOTE:
+ quote = code === SINGLE_QUOTE ? '\'' : '"';
+ next = pos;
+
+ do {
+ escaped = false;
+ next = css.indexOf(quote, next + 1);
+
+ if (next === -1) {
+ if (ignore || ignoreUnclosed) {
+ next = pos + 1;
+ break;
+ } else {
+ unclosed('string');
+ }
+ }
+
+ escapePos = next;
+
+ while (css.charCodeAt(escapePos - 1) === BACKSLASH) {
+ escapePos -= 1;
+ escaped = !escaped;
+ }
+ } while (escaped);
+
+ content = css.slice(pos, next + 1);
+ lines = content.split('\n');
+ last = lines.length - 1;
+
+ if (last > 0) {
+ nextLine = line + last;
+ nextOffset = next - lines[last].length;
+ } else {
+ nextLine = line;
+ nextOffset = offset;
+ }
+
+ currentToken = ['string', css.slice(pos, next + 1), line, pos - offset, nextLine, next - nextOffset];
+ offset = nextOffset;
+ line = nextLine;
+ pos = next;
+ break;
+
+ case AT:
+ RE_AT_END.lastIndex = pos + 1;
+ RE_AT_END.test(css);
+
+ if (RE_AT_END.lastIndex === 0) {
+ next = css.length - 1;
+ } else {
+ next = RE_AT_END.lastIndex - 2;
+ }
+
+ currentToken = ['at-word', css.slice(pos, next + 1), line, pos - offset, line, next - offset];
+ pos = next;
+ break;
+
+ case BACKSLASH:
+ next = pos;
+ escape = true;
+
+ while (css.charCodeAt(next + 1) === BACKSLASH) {
+ next += 1;
+ escape = !escape;
+ }
+
+ code = css.charCodeAt(next + 1);
+
+ if (escape && code !== SLASH && code !== SPACE && code !== NEWLINE && code !== TAB && code !== CR && code !== FEED) {
+ next += 1;
+
+ if (RE_HEX_ESCAPE.test(css.charAt(next))) {
+ while (RE_HEX_ESCAPE.test(css.charAt(next + 1))) {
+ next += 1;
+ }
+
+ if (css.charCodeAt(next + 1) === SPACE) {
+ next += 1;
+ }
+ }
+ }
+
+ currentToken = ['word', css.slice(pos, next + 1), line, pos - offset, line, next - offset];
+ pos = next;
+ break;
+
+ default:
+ if (code === SLASH && css.charCodeAt(pos + 1) === ASTERISK) {
+ next = css.indexOf('*/', pos + 2) + 1;
+
+ if (next === 0) {
+ if (ignore || ignoreUnclosed) {
+ next = css.length;
+ } else {
+ unclosed('comment');
+ }
+ }
+
+ content = css.slice(pos, next + 1);
+ lines = content.split('\n');
+ last = lines.length - 1;
+
+ if (last > 0) {
+ nextLine = line + last;
+ nextOffset = next - lines[last].length;
+ } else {
+ nextLine = line;
+ nextOffset = offset;
+ }
+
+ currentToken = ['comment', content, line, pos - offset, nextLine, next - nextOffset];
+ offset = nextOffset;
+ line = nextLine;
+ pos = next;
+ } else {
+ RE_WORD_END.lastIndex = pos + 1;
+ RE_WORD_END.test(css);
+
+ if (RE_WORD_END.lastIndex === 0) {
+ next = css.length - 1;
+ } else {
+ next = RE_WORD_END.lastIndex - 2;
+ }
+
+ currentToken = ['word', css.slice(pos, next + 1), line, pos - offset, line, next - offset];
+ buffer.push(currentToken);
+ pos = next;
+ }
+
+ break;
+ }
+
+ pos++;
+ return currentToken;
+ }
+
+ function back(token) {
+ returned.push(token);
+ }
+
+ return {
+ back: back,
+ nextToken: nextToken,
+ endOfFile: endOfFile,
+ position: position
+ };
+}
+
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRva2VuaXplLmVzNiJdLCJuYW1lcyI6WyJTSU5HTEVfUVVPVEUiLCJjaGFyQ29kZUF0IiwiRE9VQkxFX1FVT1RFIiwiQkFDS1NMQVNIIiwiU0xBU0giLCJORVdMSU5FIiwiU1BBQ0UiLCJGRUVEIiwiVEFCIiwiQ1IiLCJPUEVOX1NRVUFSRSIsIkNMT1NFX1NRVUFSRSIsIk9QRU5fUEFSRU5USEVTRVMiLCJDTE9TRV9QQVJFTlRIRVNFUyIsIk9QRU5fQ1VSTFkiLCJDTE9TRV9DVVJMWSIsIlNFTUlDT0xPTiIsIkFTVEVSSVNLIiwiQ09MT04iLCJBVCIsIlJFX0FUX0VORCIsIlJFX1dPUkRfRU5EIiwiUkVfQkFEX0JSQUNLRVQiLCJSRV9IRVhfRVNDQVBFIiwidG9rZW5pemVyIiwiaW5wdXQiLCJvcHRpb25zIiwiY3NzIiwidmFsdWVPZiIsImlnbm9yZSIsImlnbm9yZUVycm9ycyIsImNvZGUiLCJuZXh0IiwicXVvdGUiLCJsaW5lcyIsImxhc3QiLCJjb250ZW50IiwiZXNjYXBlIiwibmV4dExpbmUiLCJuZXh0T2Zmc2V0IiwiZXNjYXBlZCIsImVzY2FwZVBvcyIsInByZXYiLCJuIiwiY3VycmVudFRva2VuIiwibGVuZ3RoIiwib2Zmc2V0IiwibGluZSIsInBvcyIsImJ1ZmZlciIsInJldHVybmVkIiwicG9zaXRpb24iLCJ1bmNsb3NlZCIsIndoYXQiLCJlcnJvciIsImVuZE9mRmlsZSIsIm5leHRUb2tlbiIsIm9wdHMiLCJwb3AiLCJpZ25vcmVVbmNsb3NlZCIsInNsaWNlIiwiY29udHJvbENoYXIiLCJTdHJpbmciLCJmcm9tQ2hhckNvZGUiLCJpbmRleE9mIiwidGVzdCIsInNwbGl0IiwibGFzdEluZGV4IiwiY2hhckF0IiwicHVzaCIsImJhY2siLCJ0b2tlbiJdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLElBQU1BLFlBQVksR0FBRyxLQUFLQyxVQUFMLENBQWdCLENBQWhCLENBQXJCO0FBQ0EsSUFBTUMsWUFBWSxHQUFHLElBQUlELFVBQUosQ0FBZSxDQUFm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LElBQVQsQ0FBZUMsS0FBZixFQUFzQjtBQUNwQnJCLElBQUFBLFFBQVEsQ0FBQ21CLElBQVQsQ0FBY0UsS0FBZDtBQUNEOztBQUVELFNBQU87QUFDTEQsSUFBQUEsSUFBSSxFQUFKQSxJQURLO0FBRUxkLElBQUFBLFNBQVMsRUFBVEEsU0FGSztBQUdMRCxJQUFBQSxTQUFTLEVBQVRBLFNBSEs7QUFJTEosSUFBQUEsUUFBUSxFQUFSQTtBQUpLLEdBQVA7QUFNRCIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IFNJTkdMRV9RVU9URSA9ICdcXCcnLmNoYXJDb2RlQXQoMClcbmNvbnN0IERPVUJMRV9RVU9URSA9ICdcIicuY2hhckNvZGVBdCgwKVxuY29uc3QgQkFDS1NMQVNIID0gJ1xcXFwnLmNoYXJDb2RlQXQoMClcbmNvbnN0IFNMQVNIID0gJy8nLmNoYXJDb2RlQXQoMClcbmNvbnN0IE5FV0xJTkUgPSAnXFxuJy5jaGFyQ29kZUF0KDApXG5jb25zdCBTUEFDRSA9ICcgJy5jaGFyQ29kZUF0KDApXG5jb25zdCBGRUVEID0gJ1xcZicuY2hhckNvZGVBdCgwKVxuY29uc3QgVEFCID0gJ1xcdCcuY2hhckNvZGVBdCgwKVxuY29uc3QgQ1IgPSAnXFxyJy5jaGFyQ29kZUF0KDApXG5jb25zdCBPUEVOX1NRVUFSRSA9ICdbJy5jaGFyQ29kZUF0KDApXG5jb25zdCBDTE9TRV9TUVVBUkUgPSAnXScuY2hhckNvZGVBdCgwKVxuY29uc3QgT1BFTl9QQVJFTlRIRVNFUyA9ICcoJy5jaGFyQ29kZUF0KDApXG5jb25zdCBDTE9TRV9QQVJFTlRIRVNFUyA9ICcpJy5jaGFyQ29kZUF0KDApXG5jb25zdCBPUEVOX0NVUkxZID0gJ3snLmNoYXJDb2RlQXQoMClcbmNvbnN0IENMT1NFX0NVUkxZID0gJ30nLmNoYXJDb2RlQXQoMClcbmNvbnN0IFNFTUlDT0xPTiA9ICc7Jy5jaGFyQ29kZUF0KDApXG5jb25zdCBBU1RFUklTSyA9ICcqJy5jaGFyQ29kZUF0KDApXG5jb25zdCBDT0xPTiA9ICc6Jy5jaGFyQ29kZUF0KDApXG5jb25zdCBBVCA9ICdAJy5jaGFyQ29kZUF0KDApXG5cbmNvbnN0IFJFX0FUX0VORCA9IC9bIFxcblxcdFxcclxcZnt9KCknXCJcXFxcOy9bXFxdI10vZ1xuY29uc3QgUkVfV09SRF9FTkQgPSAvWyBcXG5cXHRcXHJcXGYoKXt9OjtAISdcIlxcXFxcXF1bI118XFwvKD89XFwqKS9nXG5jb25zdCBSRV9CQURfQlJBQ0tFVCA9IC8uW1xcXFwvKFwiJ1xcbl0vXG5jb25zdCBSRV9IRVhfRVNDQVBFID0gL1thLWYwLTldL2lcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gdG9rZW5pemVyIChpbnB1dCwgb3B0aW9ucyA9IHt9KSB7XG4gIGxldCBjc3MgPSBpbnB1dC5jc3MudmFsdWVPZigpXG4gIGxldCBpZ25vcmUgPSBvcHRpb25zLmlnbm9yZUVycm9yc1xuXG4gIGxldCBjb2RlLCBuZXh0LCBxdW90ZSwgbGluZXMsIGxhc3QsIGNvbnRlbnQsIGVzY2FwZVxuICBsZXQgbmV4dExpbmUsIG5leHRPZmZzZXQsIGVzY2FwZWQsIGVzY2FwZVBvcywgcHJldiwgbiwgY3VycmVudFRva2VuXG5cbiAgbGV0IGxlbmd0aCA9IGNzcy5sZW5ndGhcbiAgbGV0IG9mZnNldCA9IC0xXG4gIGxldCBsaW5lID0gMVxuICBsZXQgcG9zID0gMFxuICBsZXQgYnVmZmVyID0gW11cbiAgbGV0IHJldHVybmVkID0gW11cblxuICBmdW5jdGlvbiBwb3NpdGlvbiAoKSB7XG4gICAgcmV0dXJuIHBvc1xuICB9XG5cbiAgZnVuY3Rpb24gdW5jbG9zZWQgKHdoYXQpIHtcbiAgICB0aHJvdyBpbnB1dC5lcnJvcignVW5jbG9zZWQgJyArIHdoYXQsIGxpbmUsIHBvcyAtIG9mZnNldClcbiAgfVxuXG4gIGZ1bmN0aW9uIGVuZE9mRmlsZSAoKSB7XG4gICAgcmV0dXJuIHJldHVybmVkLmxlbmd0aCA9PT0gMCAmJiBwb3MgPj0gbGVuZ3RoXG4gIH1cblxuICBmdW5jdGlvbiBuZXh0VG9rZW4gKG9wdHMpIHtcbiAgICBpZiAocmV0dXJuZWQubGVuZ3RoKSByZXR1cm4gcmV0dXJuZWQucG9wKClcbiAgICBpZiAocG9zID49IGxlbmd0aCkgcmV0dXJuXG5cbiAgICBsZXQgaWdub3JlVW5jbG9zZWQgPSBvcHRzID8gb3B0cy5pZ25vcmVVbmNsb3NlZCA6IGZhbHNlXG5cbiAgICBjb2RlID0gY3NzLmNoYXJDb2RlQXQocG9zKVxuICAgIGlmIChcbiAgICAgIGNvZGUgPT09IE5FV0xJTkUgfHwgY29kZSA9PT0gRkVFRCB8fFxuICAgICAgKGNvZGUgPT09IENSICYmIGNzcy5jaGFyQ29kZUF0KHBvcyArIDEpICE9PSBORVdMSU5FKVxuICAgICkge1xuICAgICAgb2Zmc2V0ID0gcG9zXG4gICAgICBsaW5lICs9IDFcbiAgICB9XG5cbiAgICBzd2l0Y2ggKGNvZGUpIHtcbiAgICAgIGNhc2UgTkVXTElORTpcbiAgICAgIGNhc2UgU1BBQ0U6XG4gICAgICBjYXNlIFRBQjpcbiAgICAgIGNhc2UgQ1I6XG4gICAgICBjYXNlIEZFRUQ6XG4gICAgICAgIG5leHQgPSBwb3NcbiAgICAgICAgZG8ge1xuICAgICAgICAgIG5leHQgKz0gMVxuICAgICAgICAgIGNvZGUgPSBjc3MuY2hhckNvZGVBdChuZXh0KVxuICAgICAgICAgIGlmIChjb2RlID09PSBORVdMSU5FKSB7XG4gICAgICAgICAgICBvZmZzZXQgPSBuZXh0XG4gICAgICAgICAgICBsaW5lICs9IDFcbiAgICAgICAgICB9XG4gICAgICAgIH0gd2hpbGUgKFxuICAgICAgICAgIGNvZGUgPT09IFNQQUNFIHx8XG4gICAgICAgICAgY29kZSA9PT0gTkVXTElORSB8fFxuICAgICAgICAgIGNvZGUgPT09IFRBQiB8fFxuICAgICAgICAgIGNvZGUgPT09IENSIHx8XG4gICAgICAgICAgY29kZSA9PT0gRkVFRFxuICAgICAgICApXG5cbiAgICAgICAgY3VycmVudFRva2VuID0gWydzcGFjZScsIGNzcy5zbGljZShwb3MsIG5leHQpXVxuICAgICAgICBwb3MgPSBuZXh0IC0gMVxuICAgICAgICBicmVha1xuXG4gICAgICBjYXNlIE9QRU5fU1FVQVJFOlxuICAgICAgY2FzZSBDTE9TRV9TUVVBUkU6XG4gICAgICBjYXNlIE9QRU5fQ1VSTFk6XG4gICAgICBjYXNlIENMT1NFX0NVUkxZOlxuICAgICAgY2FzZSBDT0xPTjpcbiAgICAgIGNhc2UgU0VNSUNPTE9OOlxuICAgICAgY2FzZSBDTE9TRV9QQVJFTlRIRVNFUzpcbiAgICAgICAgbGV0IGNvbnRyb2xDaGFyID0gU3RyaW5nLmZyb21DaGFyQ29kZShjb2RlKVxuICAgICAgICBjdXJyZW50VG9rZW4gPSBbY29udHJvbENoYXIsIGNvbnRyb2xDaGFyLCBsaW5lLCBwb3MgLSBvZmZzZXRdXG4gICAgICAgIGJyZWFrXG5cbiAgICAgIGNhc2UgT1BFTl9QQVJFTlRIRVNFUzpcbiAgICAgICAgcHJldiA9IGJ1ZmZlci5sZW5ndGggPyBidWZmZXIucG9wKClbMV0gOiAnJ1xuICAgICAgICBuID0gY3NzLmNoYXJDb2RlQXQocG9zICsgMSlcbiAgICAgICAgaWYgKFxuICAgICAgICAgIHByZXYgPT09ICd1cmwnICYmXG4gICAgICAgICAgbiAhPT0gU0lOR0xFX1FVT1RFICYmIG4gIT09IERPVUJMRV9RVU9URSAmJlxuICAgICAgICAgIG4gIT09IFNQQUNFICYmIG4gIT09IE5FV0xJTkUgJiYgbiAhPT0gVEFCICYmXG4gICAgICAgICAgbiAhPT0gRkVFRCAmJiBuICE9PSBDUlxuICAgICAgICApIHtcbiAgICAgICAgICBuZXh0ID0gcG9zXG4gICAgICAgICAgZG8ge1xuICAgICAgICAgICAgZXNjYXBlZCA9IGZhbHNlXG4gICAgICAgICAgICBuZXh0ID0gY3NzLmluZGV4T2YoJyknLCBuZXh0ICsgMSlcbiAgICAgICAgICAgIGlmIChuZXh0ID09PSAtMSkge1xuICAgICAgICAgICAgICBpZiAoaWdub3JlIHx8IGlnbm9yZVVuY2xvc2VkKSB7XG4gICAgICAgICAgICAgICAgbmV4dCA9IHBvc1xuICAgICAgICAgICAgICAgIGJyZWFrXG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgdW5jbG9zZWQoJ2JyYWNrZXQnKVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBlc2NhcGVQb3MgPSBuZXh0XG4gICAgICAgICAgICB3aGlsZSAoY3NzLmNoYXJDb2RlQXQoZXNjYXBlUG9zIC0gMSkgPT09IEJBQ0tTTEFTSCkge1xuICAgICAgICAgICAgICBlc2NhcGVQb3MgLT0gMVxuICAgICAgICAgICAgICBlc2NhcGVkID0gIWVzY2FwZWRcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9IHdoaWxlIChlc2NhcGVkKVxuXG4gICAgICAgICAgY3VycmVudFRva2VuID0gWydicmFja2V0cycsIGNzcy5zbGljZShwb3MsIG5leHQgKyAxKSxcbiAgICAgICAgICAgIGxpbmUsIHBvcyAtIG9mZnNldCxcbiAgICAgICAgICAgIGxpbmUsIG5leHQgLSBvZmZzZXRcbiAgICAgICAgICBdXG5cbiAgICAgICAgICBwb3MgPSBuZXh0XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgbmV4dCA9IGNzcy5pbmRleE9mKCcpJywgcG9zICsgMSlcbiAgICAgICAgICBjb250ZW50ID0gY3NzLnNsaWNlKHBvcywgbmV4dCArIDEpXG5cbiAgICAgICAgICBpZiAobmV4dCA9PT0gLTEgfHwgUkVfQkFEX0JSQUNLRVQudGVzdChjb250ZW50KSkge1xuICAgICAgICAgICAgY3VycmVudFRva2VuID0gWycoJywgJygnLCBsaW5lLCBwb3MgLSBvZmZzZXRdXG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGN1cnJlbnRUb2tlbiA9IFsnYnJhY2tldHMnLCBjb250ZW50LFxuICAgICAgICAgICAgICBsaW5lLCBwb3MgLSBvZmZzZXQsXG4gICAgICAgICAgICAgIGxpbmUsIG5leHQgLSBvZmZzZXRcbiAgICAgICAgICAgIF1cbiAgICAgICAgICAgIHBvcyA9IG5leHRcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICBicmVha1xuXG4gICAgICBjYXNlIFNJTkdMRV9RVU9URTpcbiAgICAgIGNhc2UgRE9VQkxFX1FVT1RFOlxuICAgICAgICBxdW90ZSA9IGNvZGUgPT09IFNJTkdMRV9RVU9URSA/ICdcXCcnIDogJ1wiJ1xuICAgICAgICBuZXh0ID0gcG9zXG4gICAgICAgIGRvIHtcbiAgICAgICAgICBlc2NhcGVkID0gZmFsc2VcbiAgICAgICAgICBuZXh0ID0gY3NzLmluZGV4T2YocXVvdGUsIG5leHQgKyAxKVxuICAgICAgICAgIGlmIChuZXh0ID09PSAtMSkge1xuICAgICAgICAgICAgaWYgKGlnbm9yZSB8fCBpZ25vcmVVbmNsb3NlZCkge1xuICAgICAgICAgICAgICBuZXh0ID0gcG9zICsgMVxuICAgICAgICAgICAgICBicmVha1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgdW5jbG9zZWQoJ3N0cmluZycpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICAgIGVzY2FwZVBvcyA9IG5leHRcbiAgICAgICAgICB3aGlsZSAoY3NzLmNoYXJDb2RlQXQoZXNjYXBlUG9zIC0gMSkgPT09IEJBQ0tTTEFTSCkge1xuICAgICAgICAgICAgZXNjYXBlUG9zIC09IDFcbiAgICAgICAgICAgIGVzY2FwZWQgPSAhZXNjYXBlZFxuICAgICAgICAgIH1cbiAgICAgICAgfSB3aGlsZSAoZXNjYXBlZClcblxuICAgICAgICBjb250ZW50ID0gY3NzLnNsaWNlKHBvcywgbmV4dCArIDEpXG4gICAgICAgIGxpbmVzID0gY29udGVudC5zcGxpdCgnXFxuJylcbiAgICAgICAgbGFzdCA9IGxpbmVzLmxlbmd0aCAtIDFcblxuICAgICAgICBpZiAobGFzdCA+IDApIHtcbiAgICAgICAgICBuZXh0TGluZSA9IGxpbmUgKyBsYXN0XG4gICAgICAgICAgbmV4dE9mZnNldCA9IG5leHQgLSBsaW5lc1tsYXN0XS5sZW5ndGhcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBuZXh0TGluZSA9IGxpbmVcbiAgICAgICAgICBuZXh0T2Zmc2V0ID0gb2Zmc2V0XG4gICAgICAgIH1cblxuICAgICAgICBjdXJyZW50VG9rZW4gPSBbJ3N0cmluZycsIGNzcy5zbGljZShwb3MsIG5leHQgKyAxKSxcbiAgICAgICAgICBsaW5lLCBwb3MgLSBvZmZzZXQsXG4gICAgICAgICAgbmV4dExpbmUsIG5leHQgLSBuZXh0T2Zmc2V0XG4gICAgICAgIF1cblxuICAgICAgICBvZmZzZXQgPSBuZXh0T2Zmc2V0XG4gICAgICAgIGxpbmUgPSBuZXh0TGluZVxuICAgICAgICBwb3MgPSBuZXh0XG4gICAgICAgIGJyZWFrXG5cbiAgICAgIGNhc2UgQVQ6XG4gICAgICAgIFJFX0FUX0VORC5sYXN0SW5kZXggPSBwb3MgKyAxXG4gICAgICAgIFJFX0FUX0VORC50ZXN0KGNzcylcbiAgICAgICAgaWYgKFJFX0FUX0VORC5sYXN0SW5kZXggPT09IDApIHtcbiAgICAgICAgICBuZXh0ID0gY3NzLmxlbmd0aCAtIDFcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBuZXh0ID0gUkVfQVRfRU5ELmxhc3RJbmRleCAtIDJcbiAgICAgICAgfVxuXG4gICAgICAgIGN1cnJlbnRUb2tlbiA9IFsnYXQtd29yZCcsIGNzcy5zbGljZShwb3MsIG5leHQgKyAxKSxcbiAgICAgICAgICBsaW5lLCBwb3MgLSBvZmZzZXQsXG4gICAgICAgICAgbGluZSwgbmV4dCAtIG9mZnNldFxuICAgICAgICBdXG5cbiAgICAgICAgcG9zID0gbmV4dFxuICAgICAgICBicmVha1xuXG4gICAgICBjYXNlIEJBQ0tTTEFTSDpcbiAgICAgICAgbmV4dCA9IHBvc1xuICAgICAgICBlc2NhcGUgPSB0cnVlXG4gICAgICAgIHdoaWxlIChjc3MuY2hhckNvZGVBdChuZXh0ICsgMSkgPT09IEJBQ0tTTEFTSCkge1xuICAgICAgICAgIG5leHQgKz0gMVxuICAgICAgICAgIGVzY2FwZSA9ICFlc2NhcGVcbiAgICAgICAgfVxuICAgICAgICBjb2RlID0gY3NzLmNoYXJDb2RlQXQobmV4dCArIDEpXG4gICAgICAgIGlmIChcbiAgICAgICAgICBlc2NhcGUgJiZcbiAgICAgICAgICBjb2RlICE9PSBTTEFTSCAmJlxuICAgICAgICAgIGNvZGUgIT09IFNQQUNFICYmXG4gICAgICAgICAgY29kZSAhPT0gTkVXTElORSAmJlxuICAgICAgICAgIGNvZGUgIT09IFRBQiAmJlxuICAgICAgICAgIGNvZGUgIT09IENSICYmXG4gICAgICAgICAgY29kZSAhPT0gRkVFRFxuICAgICAgICApIHtcbiAgICAgICAgICBuZXh0ICs9IDFcbiAgICAgICAgICBpZiAoUkVfSEVYX0VTQ0FQRS50ZXN0KGNzcy5jaGFyQXQobmV4dCkpKSB7XG4gICAgICAgICAgICB3aGlsZSAoUkVfSEVYX0VTQ0FQRS50ZXN0KGNzcy5jaGFyQXQobmV4dCArIDEpKSkge1xuICAgICAgICAgICAgICBuZXh0ICs9IDFcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGlmIChjc3MuY2hhckNvZGVBdChuZXh0ICsgMSkgPT09IFNQQUNFKSB7XG4gICAgICAgICAgICAgIG5leHQgKz0gMVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGN1cnJlbnRUb2tlbiA9IFsnd29yZCcsIGNzcy5zbGljZShwb3MsIG5leHQgKyAxKSxcbiAgICAgICAgICBsaW5lLCBwb3MgLSBvZmZzZXQsXG4gICAgICAgICAgbGluZSwgbmV4dCAtIG9mZnNldFxuICAgICAgICBdXG5cbiAgICAgICAgcG9zID0gbmV4dFxuICAgICAgICBicmVha1xuXG4gICAgICBkZWZhdWx0OlxuICAgICAgICBpZiAoY29kZSA9PT0gU0xBU0ggJiYgY3NzLmNoYXJDb2RlQXQocG9zICsgMSkgPT09IEFTVEVSSVNLKSB7XG4gICAgICAgICAgbmV4dCA9IGNzcy5pbmRleE9mKCcqLycsIHBvcyArIDIpICsgMVxuICAgICAgICAgIGlmIChuZXh0ID09PSAwKSB7XG4gICAgICAgICAgICBpZiAoaWdub3JlIHx8IGlnbm9yZVVuY2xvc2VkKSB7XG4gICAgICAgICAgICAgIG5leHQgPSBjc3MubGVuZ3RoXG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICB1bmNsb3NlZCgnY29tbWVudCcpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgY29udGVudCA9IGNzcy5zbGljZShwb3MsIG5leHQgKyAxKVxuICAgICAgICAgIGxpbmVzID0gY29udGVudC5zcGxpdCgnXFxuJylcbiAgICAgICAgICBsYXN0ID0gbGluZXMubGVuZ3RoIC0gMVxuXG4gICAgICAgICAgaWYgKGxhc3QgPiAwKSB7XG4gICAgICAgICAgICBuZXh0TGluZSA9IGxpbmUgKyBsYXN0XG4gICAgICAgICAgICBuZXh0T2Zmc2V0ID0gbmV4dCAtIGxpbmVzW2xhc3RdLmxlbmd0aFxuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBuZXh0TGluZSA9IGxpbmVcbiAgICAgICAgICAgIG5leHRPZmZzZXQgPSBvZmZzZXRcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjdXJyZW50VG9rZW4gPSBbJ2NvbW1lbnQnLCBjb250ZW50LFxuICAgICAgICAgICAgbGluZSwgcG9zIC0gb2Zmc2V0LFxuICAgICAgICAgICAgbmV4dExpbmUsIG5leHQgLSBuZXh0T2Zmc2V0XG4gICAgICAgICAgXVxuXG4gICAgICAgICAgb2Zmc2V0ID0gbmV4dE9mZnNldFxuICAgICAgICAgIGxpbmUgPSBuZXh0TGluZVxuICAgICAgICAgIHBvcyA9IG5leHRcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBSRV9XT1JEX0VORC5sYXN0SW5kZXggPSBwb3MgKyAxXG4gICAgICAgICAgUkVfV09SRF9FTkQudGVzdChjc3MpXG4gICAgICAgICAgaWYgKFJFX1dPUkRfRU5ELmxhc3RJbmRleCA9PT0gMCkge1xuICAgICAgICAgICAgbmV4dCA9IGNzcy5sZW5ndGggLSAxXG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIG5leHQgPSBSRV9XT1JEX0VORC5sYXN0SW5kZXggLSAyXG4gICAgICAgICAgfVxuXG4gICAgICAgICAgY3VycmVudFRva2VuID0gWyd3b3JkJywgY3NzLnNsaWNlKHBvcywgbmV4dCArIDEpLFxuICAgICAgICAgICAgbGluZSwgcG9zIC0gb2Zmc2V0LFxuICAgICAgICAgICAgbGluZSwgbmV4dCAtIG9mZnNldFxuICAgICAgICAgIF1cblxuICAgICAgICAgIGJ1ZmZlci5wdXNoKGN1cnJlbnRUb2tlbilcblxuICAgICAgICAgIHBvcyA9IG5leHRcbiAgICAgICAgfVxuXG4gICAgICAgIGJyZWFrXG4gICAgfVxuXG4gICAgcG9zKytcbiAgICByZXR1cm4gY3VycmVudFRva2VuXG4gIH1cblxuICBmdW5jdGlvbiBiYWNrICh0b2tlbikge1xuICAgIHJldHVybmVkLnB1c2godG9rZW4pXG4gIH1cblxuICByZXR1cm4ge1xuICAgIGJhY2ssXG4gICAgbmV4dFRva2VuLFxuICAgIGVuZE9mRmlsZSxcbiAgICBwb3NpdGlvblxuICB9XG59XG4iXSwiZmlsZSI6InRva2VuaXplLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/vendor.js b/node_modules/autoprefixer/node_modules/postcss/lib/vendor.js
new file mode 100644
index 0000000..8abdeed
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/vendor.js
@@ -0,0 +1,53 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+/**
+ * Contains helpers for working with vendor prefixes.
+ *
+ * @example
+ * const vendor = postcss.vendor
+ *
+ * @namespace vendor
+ */
+var vendor = {
+ /**
+ * Returns the vendor prefix extracted from an input string.
+ *
+ * @param {string} prop String with or without vendor prefix.
+ *
+ * @return {string} vendor prefix or empty string
+ *
+ * @example
+ * postcss.vendor.prefix('-moz-tab-size') //=> '-moz-'
+ * postcss.vendor.prefix('tab-size') //=> ''
+ */
+ prefix: function prefix(prop) {
+ var match = prop.match(/^(-\w+-)/);
+
+ if (match) {
+ return match[0];
+ }
+
+ return '';
+ },
+
+ /**
+ * Returns the input string stripped of its vendor prefix.
+ *
+ * @param {string} prop String with or without vendor prefix.
+ *
+ * @return {string} String name without vendor prefixes.
+ *
+ * @example
+ * postcss.vendor.unprefixed('-moz-tab-size') //=> 'tab-size'
+ */
+ unprefixed: function unprefixed(prop) {
+ return prop.replace(/^-\w+-/, '');
+ }
+};
+var _default = vendor;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInZlbmRvci5lczYiXSwibmFtZXMiOlsidmVuZG9yIiwicHJlZml4IiwicHJvcCIsIm1hdGNoIiwidW5wcmVmaXhlZCIsInJlcGxhY2UiXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7Ozs7Ozs7O0FBUUEsSUFBSUEsTUFBTSxHQUFHO0FBRVg7Ozs7Ozs7Ozs7O0FBV0FDLEVBQUFBLE1BYlcsa0JBYUhDLElBYkcsRUFhRztBQUNaLFFBQUlDLEtBQUssR0FBR0QsSUFBSSxDQUFDQyxLQUFMLENBQVcsVUFBWCxDQUFaOztBQUNBLFFBQUlBLEtBQUosRUFBVztBQUNULGFBQU9BLEtBQUssQ0FBQyxDQUFELENBQVo7QUFDRDs7QUFFRCxXQUFPLEVBQVA7QUFDRCxHQXBCVTs7QUFzQlg7Ozs7Ozs7Ozs7QUFVQUMsRUFBQUEsVUFoQ1csc0JBZ0NDRixJQWhDRCxFQWdDTztBQUNoQixXQUFPQSxJQUFJLENBQUNHLE9BQUwsQ0FBYSxRQUFiLEVBQXVCLEVBQXZCLENBQVA7QUFDRDtBQWxDVSxDQUFiO2VBc0NlTCxNIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb250YWlucyBoZWxwZXJzIGZvciB3b3JraW5nIHdpdGggdmVuZG9yIHByZWZpeGVzLlxuICpcbiAqIEBleGFtcGxlXG4gKiBjb25zdCB2ZW5kb3IgPSBwb3N0Y3NzLnZlbmRvclxuICpcbiAqIEBuYW1lc3BhY2UgdmVuZG9yXG4gKi9cbmxldCB2ZW5kb3IgPSB7XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIHZlbmRvciBwcmVmaXggZXh0cmFjdGVkIGZyb20gYW4gaW5wdXQgc3RyaW5nLlxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ30gcHJvcCBTdHJpbmcgd2l0aCBvciB3aXRob3V0IHZlbmRvciBwcmVmaXguXG4gICAqXG4gICAqIEByZXR1cm4ge3N0cmluZ30gdmVuZG9yIHByZWZpeCBvciBlbXB0eSBzdHJpbmdcbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogcG9zdGNzcy52ZW5kb3IucHJlZml4KCctbW96LXRhYi1zaXplJykgLy89PiAnLW1vei0nXG4gICAqIHBvc3Rjc3MudmVuZG9yLnByZWZpeCgndGFiLXNpemUnKSAgICAgIC8vPT4gJydcbiAgICovXG4gIHByZWZpeCAocHJvcCkge1xuICAgIGxldCBtYXRjaCA9IHByb3AubWF0Y2goL14oLVxcdystKS8pXG4gICAgaWYgKG1hdGNoKSB7XG4gICAgICByZXR1cm4gbWF0Y2hbMF1cbiAgICB9XG5cbiAgICByZXR1cm4gJydcbiAgfSxcblxuICAvKipcbiAgICAgKiBSZXR1cm5zIHRoZSBpbnB1dCBzdHJpbmcgc3RyaXBwZWQgb2YgaXRzIHZlbmRvciBwcmVmaXguXG4gICAgICpcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gcHJvcCBTdHJpbmcgd2l0aCBvciB3aXRob3V0IHZlbmRvciBwcmVmaXguXG4gICAgICpcbiAgICAgKiBAcmV0dXJuIHtzdHJpbmd9IFN0cmluZyBuYW1lIHdpdGhvdXQgdmVuZG9yIHByZWZpeGVzLlxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiBwb3N0Y3NzLnZlbmRvci51bnByZWZpeGVkKCctbW96LXRhYi1zaXplJykgLy89PiAndGFiLXNpemUnXG4gICAgICovXG4gIHVucHJlZml4ZWQgKHByb3ApIHtcbiAgICByZXR1cm4gcHJvcC5yZXBsYWNlKC9eLVxcdystLywgJycpXG4gIH1cblxufVxuXG5leHBvcnQgZGVmYXVsdCB2ZW5kb3JcbiJdLCJmaWxlIjoidmVuZG9yLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/warn-once.js b/node_modules/autoprefixer/node_modules/postcss/lib/warn-once.js
new file mode 100644
index 0000000..f04c7f2
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/warn-once.js
@@ -0,0 +1,17 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = warnOnce;
+var printed = {};
+
+function warnOnce(message) {
+ if (printed[message]) return;
+ printed[message] = true;
+
+ if (typeof console !== 'undefined' && console.warn) {
+ console.warn(message);
+ }
+}
+
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndhcm4tb25jZS5lczYiXSwibmFtZXMiOlsicHJpbnRlZCIsIndhcm5PbmNlIiwibWVzc2FnZSIsImNvbnNvbGUiLCJ3YXJuIl0sIm1hcHBpbmdzIjoiOzs7O0FBQUEsSUFBSUEsT0FBTyxHQUFHLEVBQWQ7O0FBRWUsU0FBU0MsUUFBVCxDQUFtQkMsT0FBbkIsRUFBNEI7QUFDekMsTUFBSUYsT0FBTyxDQUFDRSxPQUFELENBQVgsRUFBc0I7QUFDdEJGLEVBQUFBLE9BQU8sQ0FBQ0UsT0FBRCxDQUFQLEdBQW1CLElBQW5COztBQUVBLE1BQUksT0FBT0MsT0FBUCxLQUFtQixXQUFuQixJQUFrQ0EsT0FBTyxDQUFDQyxJQUE5QyxFQUFvRDtBQUNsREQsSUFBQUEsT0FBTyxDQUFDQyxJQUFSLENBQWFGLE9BQWI7QUFDRDtBQUNGIiwic291cmNlc0NvbnRlbnQiOlsibGV0IHByaW50ZWQgPSB7IH1cblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gd2Fybk9uY2UgKG1lc3NhZ2UpIHtcbiAgaWYgKHByaW50ZWRbbWVzc2FnZV0pIHJldHVyblxuICBwcmludGVkW21lc3NhZ2VdID0gdHJ1ZVxuXG4gIGlmICh0eXBlb2YgY29uc29sZSAhPT0gJ3VuZGVmaW5lZCcgJiYgY29uc29sZS53YXJuKSB7XG4gICAgY29uc29sZS53YXJuKG1lc3NhZ2UpXG4gIH1cbn1cbiJdLCJmaWxlIjoid2Fybi1vbmNlLmpzIn0=
diff --git a/node_modules/autoprefixer/node_modules/postcss/lib/warning.js b/node_modules/autoprefixer/node_modules/postcss/lib/warning.js
new file mode 100644
index 0000000..d59e2e4
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/lib/warning.js
@@ -0,0 +1,133 @@
+"use strict";
+
+exports.__esModule = true;
+exports.default = void 0;
+
+/**
+ * Represents a plugin’s warning. It can be created using {@link Node#warn}.
+ *
+ * @example
+ * if (decl.important) {
+ * decl.warn(result, 'Avoid !important', { word: '!important' })
+ * }
+ */
+var Warning =
+/*#__PURE__*/
+function () {
+ /**
+ * @param {string} text Warning message.
+ * @param {Object} [opts] Warning options.
+ * @param {Node} opts.node CSS node that caused the warning.
+ * @param {string} opts.word Word in CSS source that caused the warning.
+ * @param {number} opts.index Index in CSS node string that caused
+ * the warning.
+ * @param {string} opts.plugin Name of the plugin that created
+ * this warning. {@link Result#warn} fills
+ * this property automatically.
+ */
+ function Warning(text, opts) {
+ if (opts === void 0) {
+ opts = {};
+ }
+
+ /**
+ * Type to filter warnings from {@link Result#messages}.
+ * Always equal to `"warning"`.
+ *
+ * @type {string}
+ *
+ * @example
+ * const nonWarning = result.messages.filter(i => i.type !== 'warning')
+ */
+ this.type = 'warning';
+ /**
+ * The warning message.
+ *
+ * @type {string}
+ *
+ * @example
+ * warning.text //=> 'Try to avoid !important'
+ */
+
+ this.text = text;
+
+ if (opts.node && opts.node.source) {
+ var pos = opts.node.positionBy(opts);
+ /**
+ * Line in the input file with this warning’s source.
+ * @type {number}
+ *
+ * @example
+ * warning.line //=> 5
+ */
+
+ this.line = pos.line;
+ /**
+ * Column in the input file with this warning’s source.
+ *
+ * @type {number}
+ *
+ * @example
+ * warning.column //=> 6
+ */
+
+ this.column = pos.column;
+ }
+
+ for (var opt in opts) {
+ this[opt] = opts[opt];
+ }
+ }
+ /**
+ * Returns a warning position and message.
+ *
+ * @example
+ * warning.toString() //=> 'postcss-lint:a.css:10:14: Avoid !important'
+ *
+ * @return {string} Warning position and message.
+ */
+
+
+ var _proto = Warning.prototype;
+
+ _proto.toString = function toString() {
+ if (this.node) {
+ return this.node.error(this.text, {
+ plugin: this.plugin,
+ index: this.index,
+ word: this.word
+ }).message;
+ }
+
+ if (this.plugin) {
+ return this.plugin + ': ' + this.text;
+ }
+
+ return this.text;
+ }
+ /**
+ * @memberof Warning#
+ * @member {string} plugin The name of the plugin that created
+ * it will fill this property automatically.
+ * this warning. When you call {@link Node#warn}
+ *
+ * @example
+ * warning.plugin //=> 'postcss-important'
+ */
+
+ /**
+ * @memberof Warning#
+ * @member {Node} node Contains the CSS node that caused the warning.
+ *
+ * @example
+ * warning.node.toString() //=> 'color: white !important'
+ */
+ ;
+
+ return Warning;
+}();
+
+var _default = Warning;
+exports.default = _default;
+module.exports = exports.default;
+//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndhcm5pbmcuZXM2Il0sIm5hbWVzIjpbIldhcm5pbmciLCJ0ZXh0Iiwib3B0cyIsInR5cGUiLCJub2RlIiwic291cmNlIiwicG9zIiwicG9zaXRpb25CeSIsImxpbmUiLCJjb2x1bW4iLCJvcHQiLCJ0b1N0cmluZyIsImVycm9yIiwicGx1Z2luIiwiaW5kZXgiLCJ3b3JkIiwibWVzc2FnZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQTs7Ozs7Ozs7SUFRTUEsTzs7O0FBQ0o7Ozs7Ozs7Ozs7O0FBV0EsbUJBQWFDLElBQWIsRUFBbUJDLElBQW5CLEVBQStCO0FBQUEsUUFBWkEsSUFBWTtBQUFaQSxNQUFBQSxJQUFZLEdBQUwsRUFBSztBQUFBOztBQUM3Qjs7Ozs7Ozs7O0FBU0EsU0FBS0MsSUFBTCxHQUFZLFNBQVo7QUFDQTs7Ozs7Ozs7O0FBUUEsU0FBS0YsSUFBTCxHQUFZQSxJQUFaOztBQUVBLFFBQUlDLElBQUksQ0FBQ0UsSUFBTCxJQUFhRixJQUFJLENBQUNFLElBQUwsQ0FBVUMsTUFBM0IsRUFBbUM7QUFDakMsVUFBSUMsR0FBRyxHQUFHSixJQUFJLENBQUNFLElBQUwsQ0FBVUcsVUFBVixDQUFxQkwsSUFBckIsQ0FBVjtBQUNBOzs7Ozs7OztBQU9BLFdBQUtNLElBQUwsR0FBWUYsR0FBRyxDQUFDRSxJQUFoQjtBQUNBOzs7Ozs7Ozs7QUFRQSxXQUFLQyxNQUFMLEdBQWNILEdBQUcsQ0FBQ0csTUFBbEI7QUFDRDs7QUFFRCxTQUFLLElBQUlDLEdBQVQsSUFBZ0JSLElBQWhCO0FBQXNCLFdBQUtRLEdBQUwsSUFBWVIsSUFBSSxDQUFDUSxHQUFELENBQWhCO0FBQXRCO0FBQ0Q7QUFFRDs7Ozs7Ozs7Ozs7O1NBUUFDLFEsR0FBQSxvQkFBWTtBQUNWLFFBQUksS0FBS1AsSUFBVCxFQUFlO0FBQ2IsYUFBTyxLQUFLQSxJQUFMLENBQVVRLEtBQVYsQ0FBZ0IsS0FBS1gsSUFBckIsRUFBMkI7QUFDaENZLFFBQUFBLE1BQU0sRUFBRSxLQUFLQSxNQURtQjtBQUVoQ0MsUUFBQUEsS0FBSyxFQUFFLEtBQUtBLEtBRm9CO0FBR2hDQyxRQUFBQSxJQUFJLEVBQUUsS0FBS0E7QUFIcUIsT0FBM0IsRUFJSkMsT0FKSDtBQUtEOztBQUVELFFBQUksS0FBS0gsTUFBVCxFQUFpQjtBQUNmLGFBQU8sS0FBS0EsTUFBTCxHQUFjLElBQWQsR0FBcUIsS0FBS1osSUFBakM7QUFDRDs7QUFFRCxXQUFPLEtBQUtBLElBQVo7QUFDRDtBQUVEOzs7Ozs7Ozs7O0FBVUE7Ozs7Ozs7Ozs7OztlQVNhRCxPIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBSZXByZXNlbnRzIGEgcGx1Z2lu4oCZcyB3YXJuaW5nLiBJdCBjYW4gYmUgY3JlYXRlZCB1c2luZyB7QGxpbmsgTm9kZSN3YXJufS5cbiAqXG4gKiBAZXhhbXBsZVxuICogaWYgKGRlY2wuaW1wb3J0YW50KSB7XG4gKiAgIGRlY2wud2FybihyZXN1bHQsICdBdm9pZCAhaW1wb3J0YW50JywgeyB3b3JkOiAnIWltcG9ydGFudCcgfSlcbiAqIH1cbiAqL1xuY2xhc3MgV2FybmluZyB7XG4gIC8qKlxuICAgKiBAcGFyYW0ge3N0cmluZ30gdGV4dCAgICAgICAgV2FybmluZyBtZXNzYWdlLlxuICAgKiBAcGFyYW0ge09iamVjdH0gW29wdHNdICAgICAgV2FybmluZyBvcHRpb25zLlxuICAgKiBAcGFyYW0ge05vZGV9ICAgb3B0cy5ub2RlICAgQ1NTIG5vZGUgdGhhdCBjYXVzZWQgdGhlIHdhcm5pbmcuXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBvcHRzLndvcmQgICBXb3JkIGluIENTUyBzb3VyY2UgdGhhdCBjYXVzZWQgdGhlIHdhcm5pbmcuXG4gICAqIEBwYXJhbSB7bnVtYmVyfSBvcHRzLmluZGV4ICBJbmRleCBpbiBDU1Mgbm9kZSBzdHJpbmcgdGhhdCBjYXVzZWRcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoZSB3YXJuaW5nLlxuICAgKiBAcGFyYW0ge3N0cmluZ30gb3B0cy5wbHVnaW4gTmFtZSBvZiB0aGUgcGx1Z2luIHRoYXQgY3JlYXRlZFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcyB3YXJuaW5nLiB7QGxpbmsgUmVzdWx0I3dhcm59IGZpbGxzXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aGlzIHByb3BlcnR5IGF1dG9tYXRpY2FsbHkuXG4gICAqL1xuICBjb25zdHJ1Y3RvciAodGV4dCwgb3B0cyA9IHsgfSkge1xuICAgIC8qKlxuICAgICAqIFR5cGUgdG8gZmlsdGVyIHdhcm5pbmdzIGZyb20ge0BsaW5rIFJlc3VsdCNtZXNzYWdlc30uXG4gICAgICogQWx3YXlzIGVxdWFsIHRvIGBcIndhcm5pbmdcImAuXG4gICAgICpcbiAgICAgKiBAdHlwZSB7c3RyaW5nfVxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiBjb25zdCBub25XYXJuaW5nID0gcmVzdWx0Lm1lc3NhZ2VzLmZpbHRlcihpID0+IGkudHlwZSAhPT0gJ3dhcm5pbmcnKVxuICAgICAqL1xuICAgIHRoaXMudHlwZSA9ICd3YXJuaW5nJ1xuICAgIC8qKlxuICAgICAqIFRoZSB3YXJuaW5nIG1lc3NhZ2UuXG4gICAgICpcbiAgICAgKiBAdHlwZSB7c3RyaW5nfVxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiB3YXJuaW5nLnRleHQgLy89PiAnVHJ5IHRvIGF2b2lkICFpbXBvcnRhbnQnXG4gICAgICovXG4gICAgdGhpcy50ZXh0ID0gdGV4dFxuXG4gICAgaWYgKG9wdHMubm9kZSAmJiBvcHRzLm5vZGUuc291cmNlKSB7XG4gICAgICBsZXQgcG9zID0gb3B0cy5ub2RlLnBvc2l0aW9uQnkob3B0cylcbiAgICAgIC8qKlxuICAgICAgICogTGluZSBpbiB0aGUgaW5wdXQgZmlsZSB3aXRoIHRoaXMgd2FybmluZ+KAmXMgc291cmNlLlxuICAgICAgICogQHR5cGUge251bWJlcn1cbiAgICAgICAqXG4gICAgICAgKiBAZXhhbXBsZVxuICAgICAgICogd2FybmluZy5saW5lIC8vPT4gNVxuICAgICAgICovXG4gICAgICB0aGlzLmxpbmUgPSBwb3MubGluZVxuICAgICAgLyoqXG4gICAgICAgKiBDb2x1bW4gaW4gdGhlIGlucHV0IGZpbGUgd2l0aCB0aGlzIHdhcm5pbmfigJlzIHNvdXJjZS5cbiAgICAgICAqXG4gICAgICAgKiBAdHlwZSB7bnVtYmVyfVxuICAgICAgICpcbiAgICAgICAqIEBleGFtcGxlXG4gICAgICAgKiB3YXJuaW5nLmNvbHVtbiAvLz0+IDZcbiAgICAgICAqL1xuICAgICAgdGhpcy5jb2x1bW4gPSBwb3MuY29sdW1uXG4gICAgfVxuXG4gICAgZm9yIChsZXQgb3B0IGluIG9wdHMpIHRoaXNbb3B0XSA9IG9wdHNbb3B0XVxuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgYSB3YXJuaW5nIHBvc2l0aW9uIGFuZCBtZXNzYWdlLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiB3YXJuaW5nLnRvU3RyaW5nKCkgLy89PiAncG9zdGNzcy1saW50OmEuY3NzOjEwOjE0OiBBdm9pZCAhaW1wb3J0YW50J1xuICAgKlxuICAgKiBAcmV0dXJuIHtzdHJpbmd9IFdhcm5pbmcgcG9zaXRpb24gYW5kIG1lc3NhZ2UuXG4gICAqL1xuICB0b1N0cmluZyAoKSB7XG4gICAgaWYgKHRoaXMubm9kZSkge1xuICAgICAgcmV0dXJuIHRoaXMubm9kZS5lcnJvcih0aGlzLnRleHQsIHtcbiAgICAgICAgcGx1Z2luOiB0aGlzLnBsdWdpbixcbiAgICAgICAgaW5kZXg6IHRoaXMuaW5kZXgsXG4gICAgICAgIHdvcmQ6IHRoaXMud29yZFxuICAgICAgfSkubWVzc2FnZVxuICAgIH1cblxuICAgIGlmICh0aGlzLnBsdWdpbikge1xuICAgICAgcmV0dXJuIHRoaXMucGx1Z2luICsgJzogJyArIHRoaXMudGV4dFxuICAgIH1cblxuICAgIHJldHVybiB0aGlzLnRleHRcbiAgfVxuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgV2FybmluZyNcbiAgICogQG1lbWJlciB7c3RyaW5nfSBwbHVnaW4gVGhlIG5hbWUgb2YgdGhlIHBsdWdpbiB0aGF0IGNyZWF0ZWRcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgaXQgd2lsbCBmaWxsIHRoaXMgcHJvcGVydHkgYXV0b21hdGljYWxseS5cbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgdGhpcyB3YXJuaW5nLiBXaGVuIHlvdSBjYWxsIHtAbGluayBOb2RlI3dhcm59XG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIHdhcm5pbmcucGx1Z2luIC8vPT4gJ3Bvc3Rjc3MtaW1wb3J0YW50J1xuICAgKi9cblxuICAvKipcbiAgICogQG1lbWJlcm9mIFdhcm5pbmcjXG4gICAqIEBtZW1iZXIge05vZGV9IG5vZGUgQ29udGFpbnMgdGhlIENTUyBub2RlIHRoYXQgY2F1c2VkIHRoZSB3YXJuaW5nLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiB3YXJuaW5nLm5vZGUudG9TdHJpbmcoKSAvLz0+ICdjb2xvcjogd2hpdGUgIWltcG9ydGFudCdcbiAgICovXG59XG5cbmV4cG9ydCBkZWZhdWx0IFdhcm5pbmdcbiJdLCJmaWxlIjoid2FybmluZy5qcyJ9
diff --git a/node_modules/autoprefixer/node_modules/postcss/package.json b/node_modules/autoprefixer/node_modules/postcss/package.json
new file mode 100644
index 0000000..87f0592
--- /dev/null
+++ b/node_modules/autoprefixer/node_modules/postcss/package.json
@@ -0,0 +1,82 @@
+{
+ "_from": "postcss@^7.0.18",
+ "_id": "postcss@7.0.18",
+ "_inBundle": false,
+ "_integrity": "sha512-/7g1QXXgegpF+9GJj4iN7ChGF40sYuGYJ8WZu8DZWnmhQ/G36hfdk3q9LBJmoK+lZ+yzZ5KYpOoxq7LF1BxE8g==",
+ "_location": "/autoprefixer/postcss",
+ "_phantomChildren": {},
+ "_requested": {
+ "type": "range",
+ "registry": true,
+ "raw": "postcss@^7.0.18",
+ "name": "postcss",
+ "escapedName": "postcss",
+ "rawSpec": "^7.0.18",
+ "saveSpec": null,
+ "fetchSpec": "^7.0.18"
+ },
+ "_requiredBy": [
+ "/autoprefixer"
+ ],
+ "_resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.18.tgz",
+ "_shasum": "4b9cda95ae6c069c67a4d933029eddd4838ac233",
+ "_spec": "postcss@^7.0.18",
+ "_where": "/home/dstaesse/git/website/node_modules/autoprefixer",
+ "author": {
+ "name": "Andrey Sitnik",
+ "email": "andrey@sitnik.ru"
+ },
+ "browser": {
+ "./lib/terminal-highlight": false,
+ "supports-color": false,
+ "chalk": false,
+ "fs": false
+ },
+ "browserslist": [
+ "last 2 version",
+ "not dead",
+ "not Explorer 11",
+ "not ExplorerMobile 11",
+ "node 6"
+ ],
+ "bugs": {
+ "url": "https://github.com/postcss/postcss/issues"
+ },
+ "bundleDependencies": false,
+ "dependencies": {
+ "chalk": "^2.4.2",
+ "source-map": "^0.6.1",
+ "supports-color": "^6.1.0"
+ },
+ "deprecated": false,
+ "description": "Tool for transforming styles with JS plugins",
+ "engines": {
+ "node": ">=6.0.0"
+ },
+ "homepage": "https://postcss.org/",
+ "husky": {
+ "hooks": {
+ "pre-commit": "lint-staged"
+ }
+ },
+ "keywords": [
+ "css",
+ "postcss",
+ "rework",
+ "preprocessor",
+ "parser",
+ "source map",
+ "transform",
+ "manipulation",
+ "transpiler"
+ ],
+ "license": "MIT",
+ "main": "lib/postcss",
+ "name": "postcss",
+ "repository": {
+ "type": "git",
+ "url": "git+https://github.com/postcss/postcss.git"
+ },
+ "types": "lib/postcss.d.ts",
+ "version": "7.0.18"
+}