postcss 6.0.22 → 7.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of postcss might be problematic. Click here for more details.

package/lib/processor.js CHANGED
@@ -17,15 +17,14 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
17
17
  * initialize its plugins, and then use that instance on numerous CSS files.
18
18
  *
19
19
  * @example
20
- * const processor = postcss([autoprefixer, precss]);
21
- * processor.process(css1).then(result => console.log(result.css));
22
- * processor.process(css2).then(result => console.log(result.css));
20
+ * const processor = postcss([autoprefixer, precss])
21
+ * processor.process(css1).then(result => console.log(result.css))
22
+ * processor.process(css2).then(result => console.log(result.css))
23
23
  */
24
24
  var Processor = function () {
25
-
26
25
  /**
27
- * @param {Array.<Plugin|pluginFunction>|Processor} plugins - PostCSS
28
- * plugins. See {@link Processor#use} for plugin format.
26
+ * @param {Array.<Plugin|pluginFunction>|Processor} plugins PostCSS plugins.
27
+ * See {@link Processor#use} for plugin format.
29
28
  */
30
29
  function Processor() {
31
30
  var plugins = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
@@ -33,19 +32,23 @@ var Processor = function () {
33
32
  _classCallCheck(this, Processor);
34
33
 
35
34
  /**
36
- * @member {string} - Current PostCSS version.
35
+ * Current PostCSS version.
36
+ *
37
+ * @type {string}
37
38
  *
38
39
  * @example
39
- * if ( result.processor.version.split('.')[0] !== '6' ) {
40
- * throw new Error('This plugin works only with PostCSS 6');
40
+ * if (result.processor.version.split('.')[0] !== '6') {
41
+ * throw new Error('This plugin works only with PostCSS 6')
41
42
  * }
42
43
  */
43
- this.version = '6.0.22';
44
+ this.version = '7.0.2';
44
45
  /**
45
- * @member {pluginFunction[]} - Plugins added to this processor.
46
+ * Plugins added to this processor.
47
+ *
48
+ * @type {pluginFunction[]}
46
49
  *
47
50
  * @example
48
- * const processor = postcss([autoprefixer, precss]);
51
+ * const processor = postcss([autoprefixer, precss])
49
52
  * processor.plugins.length //=> 2
50
53
  */
51
54
  this.plugins = this.normalize(plugins);
@@ -69,16 +72,16 @@ var Processor = function () {
69
72
  *
70
73
  * Asynchronous plugins should return a `Promise` instance.
71
74
  *
72
- * @param {Plugin|pluginFunction|Processor} plugin - PostCSS plugin
73
- * or {@link Processor}
74
- * with plugins
75
+ * @param {Plugin|pluginFunction|Processor} plugin PostCSS plugin
76
+ * or {@link Processor}
77
+ * with plugins.
75
78
  *
76
79
  * @example
77
80
  * const processor = postcss()
78
81
  * .use(autoprefixer)
79
- * .use(precss);
82
+ * .use(precss)
80
83
  *
81
- * @return {Processes} current processor to make methods chain
84
+ * @return {Processes} Current processor to make methods chain.
82
85
  */
83
86
 
84
87
 
@@ -93,29 +96,46 @@ var Processor = function () {
93
96
  * any transformations. Transformations will be applied
94
97
  * in the {@link LazyResult} methods.
95
98
  *
96
- * @param {string|toString|Result} css - String with input CSS or
97
- * any object with a `toString()`
98
- * method, like a Buffer.
99
- * Optionally, send a {@link Result}
100
- * instance and the processor will
101
- * take the {@link Root} from it.
102
- * @param {processOptions} [opts] - options
99
+ * @param {string|toString|Result} css String with input CSS or any object
100
+ * with a `toString()` method,
101
+ * like a Buffer. Optionally, send
102
+ * a {@link Result} instance
103
+ * and the processor will take
104
+ * the {@link Root} from it.
105
+ * @param {processOptions} [opts] Options.
103
106
  *
104
- * @return {LazyResult} Promise proxy
107
+ * @return {LazyResult} Promise proxy.
105
108
  *
106
109
  * @example
107
110
  * processor.process(css, { from: 'a.css', to: 'a.out.css' })
108
111
  * .then(result => {
109
- * console.log(result.css);
110
- * });
112
+ * console.log(result.css)
113
+ * })
111
114
  */
112
115
 
113
116
 
114
- Processor.prototype.process = function process(css) {
117
+ Processor.prototype.process = function (_process) {
118
+ function process(_x) {
119
+ return _process.apply(this, arguments);
120
+ }
121
+
122
+ process.toString = function () {
123
+ return _process.toString();
124
+ };
125
+
126
+ return process;
127
+ }(function (css) {
115
128
  var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
116
129
 
130
+ if (this.plugins.length === 0 && opts.parser === opts.stringifier) {
131
+ if (process.env.NODE_ENV !== 'production') {
132
+ if (typeof console !== 'undefined' && console.warn) {
133
+ console.warn('You did not set any plugins, parser, or stringifier. ' + 'Right now PostCSS do nothing. Pick plugins for your case ' + 'on https://www.postcss.parts/ and use them in postcss.config.js.');
134
+ }
135
+ }
136
+ }
117
137
  return new _lazyResult2.default(this, css, opts);
118
- };
138
+ });
119
139
 
120
140
  Processor.prototype.normalize = function normalize(plugins) {
121
141
  var normalized = [];
@@ -140,7 +160,9 @@ var Processor = function () {
140
160
  } else if (typeof i === 'function') {
141
161
  normalized.push(i);
142
162
  } else if ((typeof i === 'undefined' ? 'undefined' : _typeof(i)) === 'object' && (i.parse || i.stringify)) {
143
- 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.');
163
+ if (process.env.NODE_ENV !== 'production') {
164
+ 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.');
165
+ }
144
166
  } else {
145
167
  throw new Error(i + ' is not a PostCSS plugin');
146
168
  }
@@ -155,17 +177,17 @@ exports.default = Processor;
155
177
 
156
178
  /**
157
179
  * @callback builder
158
- * @param {string} part - part of generated CSS connected to this node
159
- * @param {Node} node - AST node
160
- * @param {"start"|"end"} [type] - node’s part type
180
+ * @param {string} part Part of generated CSS connected to this node.
181
+ * @param {Node} node AST node.
182
+ * @param {"start"|"end"} [type] Node’s part type.
161
183
  */
162
184
 
163
185
  /**
164
186
  * @callback parser
165
187
  *
166
- * @param {string|toString} css - string with input CSS or any object
167
- * with toString() method, like a Buffer
168
- * @param {processOptions} [opts] - options with only `from` and `map` keys
188
+ * @param {string|toString} css String with input CSS or any object
189
+ * with toString() method, like a Buffer.
190
+ * @param {processOptions} [opts] Options with only `from` and `map` keys.
169
191
  *
170
192
  * @return {Root} PostCSS AST
171
193
  */
@@ -173,17 +195,17 @@ exports.default = Processor;
173
195
  /**
174
196
  * @callback stringifier
175
197
  *
176
- * @param {Node} node - start node for stringifing. Usually {@link Root}.
177
- * @param {builder} builder - function to concatenate CSS from node’s parts
178
- * or generate string and source map
198
+ * @param {Node} node Start node for stringifing. Usually {@link Root}.
199
+ * @param {builder} builder Function to concatenate CSS from node’s parts
200
+ * or generate string and source map.
179
201
  *
180
202
  * @return {void}
181
203
  */
182
204
 
183
205
  /**
184
206
  * @typedef {object} syntax
185
- * @property {parser} parse - function to generate AST by string
186
- * @property {stringifier} stringify - function to generate string by AST
207
+ * @property {parser} parse Function to generate AST by string.
208
+ * @property {stringifier} stringify Function to generate string by AST.
187
209
  */
188
210
 
189
211
  /**
@@ -193,48 +215,47 @@ exports.default = Processor;
193
215
 
194
216
  /**
195
217
  * @callback pluginFunction
196
- * @param {Root} root - parsed input CSS
197
- * @param {Result} result - result to set warnings or check other plugins
218
+ * @param {Root} root Parsed input CSS.
219
+ * @param {Result} result Result to set warnings or check other plugins.
198
220
  */
199
221
 
200
222
  /**
201
223
  * @typedef {object} Plugin
202
- * @property {function} postcss - PostCSS plugin function
224
+ * @property {function} postcss PostCSS plugin function.
203
225
  */
204
226
 
205
227
  /**
206
228
  * @typedef {object} processOptions
207
- * @property {string} from - the path of the CSS source file.
208
- * You should always set `from`,
209
- * because it is used in source map
210
- * generation and syntax error messages.
211
- * @property {string} to - the path where you’ll put the output
212
- * CSS file. You should always set `to`
213
- * to generate correct source maps.
214
- * @property {parser} parser - function to generate AST by string
215
- * @property {stringifier} stringifier - class to generate string by AST
216
- * @property {syntax} syntax - object with `parse` and `stringify`
217
- * @property {object} map - source map options
218
- * @property {boolean} map.inline - does source map should
219
- * be embedded in the output
220
- * CSS as a base64-encoded
221
- * comment
222
- * @property {string|object|false|function} map.prev - source map content
223
- * from a previous
224
- * processing step
225
- * (for example, Sass).
226
- * PostCSS will try to find
227
- * previous map
228
- * automatically, so you
229
- * could disable it by
230
- * `false` value.
231
- * @property {boolean} map.sourcesContent - does PostCSS should set
232
- * the origin content to map
233
- * @property {string|false} map.annotation - does PostCSS should set
234
- * annotation comment to map
235
- * @property {string} map.from - override `from` in map’s
236
- * `sources`
229
+ * @property {string} from The path of the CSS source file.
230
+ * You should always set `from`,
231
+ * because it is used in source map
232
+ * generation and syntax error messages.
233
+ * @property {string} to The path where you’ll put the output
234
+ * CSS file. You should always set `to`
235
+ * to generate correct source maps.
236
+ * @property {parser} parser Function to generate AST by string.
237
+ * @property {stringifier} stringifier Class to generate string by AST.
238
+ * @property {syntax} syntax Object with `parse` and `stringify`.
239
+ * @property {object} map Source map options.
240
+ * @property {boolean} map.inline Does source map should
241
+ * be embedded in the output
242
+ * CSS as a base64-encoded
243
+ * comment.
244
+ * @property {string|object|false|function} map.prev Source map content
245
+ * from a previous
246
+ * processing step
247
+ * (for example, Sass).
248
+ * PostCSS will try to find
249
+ * previous map automatically,
250
+ * so you could disable it by
251
+ * `false` value.
252
+ * @property {boolean} map.sourcesContent Does PostCSS should set
253
+ * the origin content to map.
254
+ * @property {string|false} map.annotation Does PostCSS should set
255
+ * annotation comment to map.
256
+ * @property {string} map.from Override `from` in map’s
257
+ * sources`.
237
258
  */
238
259
 
239
260
  module.exports = exports['default'];
240
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["processor.es6"],"names":["Processor","plugins","version","normalize","use","plugin","concat","process","css","opts","LazyResult","normalized","i","postcss","Array","isArray","push","parse","stringify","Error"],"mappings":";;;;;;AAAA;;;;;;;;AAEA;;;;;;;;;IASMA,S;;AAEF;;;;AAIA,uBAA0B;AAAA,QAAdC,OAAc,uEAAJ,EAAI;;AAAA;;AACtB;;;;;;;;AAQA,SAAKC,OAAL,GAAe,QAAf;AACA;;;;;;;AAOA,SAAKD,OAAL,GAAe,KAAKE,SAAL,CAAeF,OAAf,CAAf;AACH;;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBA6BAG,G,gBAAIC,M,EAAQ;AACR,SAAKJ,OAAL,GAAe,KAAKA,OAAL,CAAaK,MAAb,CAAoB,KAAKH,SAAL,CAAe,CAACE,MAAD,CAAf,CAApB,CAAf;AACA,WAAO,IAAP;AACH,G;;AAED;;;;;;;;;;;;;;;;;;;;;;;;sBAsBAE,O,oBAAQC,G,EAAiB;AAAA,QAAZC,IAAY,uEAAL,EAAK;;AACrB,WAAO,IAAIC,oBAAJ,CAAe,IAAf,EAAqBF,GAArB,EAA0BC,IAA1B,CAAP;AACH,G;;sBAEDN,S,sBAAUF,O,EAAS;AACf,QAAIU,aAAa,EAAjB;AACA,yBAAeV,OAAf,kHAAyB;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAAA,UAAfW,CAAe;;AACrB,UAAKA,EAAEC,OAAP,EAAiBD,IAAIA,EAAEC,OAAN;;AAEjB,UAAK,QAAOD,CAAP,yCAAOA,CAAP,OAAa,QAAb,IAAyBE,MAAMC,OAAN,CAAcH,EAAEX,OAAhB,CAA9B,EAAyD;AACrDU,qBAAaA,WAAWL,MAAX,CAAkBM,EAAEX,OAApB,CAAb;AACH,OAFD,MAEO,IAAK,OAAOW,CAAP,KAAa,UAAlB,EAA+B;AAClCD,mBAAWK,IAAX,CAAgBJ,CAAhB;AACH,OAFM,MAEA,IAAK,QAAOA,CAAP,yCAAOA,CAAP,OAAa,QAAb,KAA0BA,EAAEK,KAAF,IAAWL,EAAEM,SAAvC,CAAL,EAAyD;AAC5D,cAAM,IAAIC,KAAJ,CAAU,iDACA,iCADA,GAEA,uCAFA,GAGA,2BAHA,GAIA,uBAJV,CAAN;AAKH,OANM,MAMA;AACH,cAAM,IAAIA,KAAJ,CAAUP,IAAI,0BAAd,CAAN;AACH;AACJ;AACD,WAAOD,UAAP;AACH,G;;;;;kBAIUX,S;;AAEf;;;;;;;AAOA;;;;;;;;;;AAUA;;;;;;;;;;AAUA;;;;;;AAMA;;;;;AAKA;;;;;;AAMA;;;;;AAKA","file":"processor.js","sourcesContent":["import LazyResult from './lazy-result';\n\n/**\n * Contains plugins to process CSS. Create one `Processor` instance,\n * initialize its plugins, and then use that instance on numerous CSS files.\n *\n * @example\n * const processor = postcss([autoprefixer, precss]);\n * processor.process(css1).then(result => console.log(result.css));\n * processor.process(css2).then(result => console.log(result.css));\n */\nclass Processor {\n\n    /**\n     * @param {Array.<Plugin|pluginFunction>|Processor} plugins - PostCSS\n     *        plugins. See {@link Processor#use} for plugin format.\n     */\n    constructor(plugins = []) {\n        /**\n         * @member {string} - Current PostCSS version.\n         *\n         * @example\n         * if ( result.processor.version.split('.')[0] !== '6' ) {\n         *   throw new Error('This plugin works only with PostCSS 6');\n         * }\n         */\n        this.version = '6.0.22';\n        /**\n         * @member {pluginFunction[]} - Plugins added to this processor.\n         *\n         * @example\n         * const processor = postcss([autoprefixer, precss]);\n         * processor.plugins.length //=> 2\n         */\n        this.plugins = this.normalize(plugins);\n    }\n\n    /**\n     * Adds a plugin to be used as a CSS processor.\n     *\n     * PostCSS plugin can be in 4 formats:\n     * * A plugin created by {@link postcss.plugin} method.\n     * * A function. PostCSS will pass the function a @{link Root}\n     *   as the first argument and current {@link Result} instance\n     *   as the second.\n     * * An object with a `postcss` method. PostCSS will use that method\n     *   as described in #2.\n     * * Another {@link Processor} instance. PostCSS will copy plugins\n     *   from that instance into this one.\n     *\n     * Plugins can also be added by passing them as arguments when creating\n     * a `postcss` instance (see [`postcss(plugins)`]).\n     *\n     * Asynchronous plugins should return a `Promise` instance.\n     *\n     * @param {Plugin|pluginFunction|Processor} plugin - PostCSS plugin\n     *                                                   or {@link Processor}\n     *                                                   with plugins\n     *\n     * @example\n     * const processor = postcss()\n     *   .use(autoprefixer)\n     *   .use(precss);\n     *\n     * @return {Processes} current processor to make methods chain\n     */\n    use(plugin) {\n        this.plugins = this.plugins.concat(this.normalize([plugin]));\n        return this;\n    }\n\n    /**\n     * Parses source CSS and returns a {@link LazyResult} Promise proxy.\n     * Because some plugins can be asynchronous it doesn’t make\n     * any transformations. Transformations will be applied\n     * in the {@link LazyResult} methods.\n     *\n     * @param {string|toString|Result} css - String with input CSS or\n     *                                       any object with a `toString()`\n     *                                       method, like a Buffer.\n     *                                       Optionally, send a {@link Result}\n     *                                       instance and the processor will\n     *                                       take the {@link Root} from it.\n     * @param {processOptions} [opts]      - options\n     *\n     * @return {LazyResult} Promise proxy\n     *\n     * @example\n     * processor.process(css, { from: 'a.css', to: 'a.out.css' })\n     *   .then(result => {\n     *      console.log(result.css);\n     *   });\n     */\n    process(css, opts = { }) {\n        return new LazyResult(this, css, opts);\n    }\n\n    normalize(plugins) {\n        let normalized = [];\n        for ( let i of plugins ) {\n            if ( i.postcss ) i = i.postcss;\n\n            if ( typeof i === 'object' && Array.isArray(i.plugins) ) {\n                normalized = normalized.concat(i.plugins);\n            } else if ( typeof i === 'function' ) {\n                normalized.push(i);\n            } else if ( typeof i === 'object' && (i.parse || i.stringify) ) {\n                throw new Error('PostCSS syntaxes cannot be used as plugins. ' +\n                                'Instead, please use one of the ' +\n                                'syntax/parser/stringifier options as ' +\n                                'outlined in your PostCSS ' +\n                                'runner documentation.');\n            } else {\n                throw new Error(i + ' is not a PostCSS plugin');\n            }\n        }\n        return normalized;\n    }\n\n}\n\nexport default Processor;\n\n/**\n * @callback builder\n * @param {string} part          - part of generated CSS connected to this node\n * @param {Node}   node          - AST node\n * @param {\"start\"|\"end\"} [type] - node’s part type\n */\n\n/**\n * @callback parser\n *\n * @param {string|toString} css   - string with input CSS or any object\n *                                  with toString() method, like a Buffer\n * @param {processOptions} [opts] - options with only `from` and `map` keys\n *\n * @return {Root} PostCSS AST\n */\n\n/**\n * @callback stringifier\n *\n * @param {Node} node       - start node for stringifing. Usually {@link Root}.\n * @param {builder} builder - function to concatenate CSS from node’s parts\n *                            or generate string and source map\n *\n * @return {void}\n */\n\n/**\n * @typedef {object} syntax\n * @property {parser} parse          - function to generate AST by string\n * @property {stringifier} stringify - function to generate string by AST\n */\n\n/**\n * @typedef {object} toString\n * @property {function} toString\n */\n\n/**\n * @callback pluginFunction\n * @param {Root} root     - parsed input CSS\n * @param {Result} result - result to set warnings or check other plugins\n */\n\n/**\n * @typedef {object} Plugin\n * @property {function} postcss - PostCSS plugin function\n */\n\n/**\n * @typedef {object} processOptions\n * @property {string} from             - the path of the CSS source file.\n *                                       You should always set `from`,\n *                                       because it is used in source map\n *                                       generation and syntax error messages.\n * @property {string} to               - the path where you’ll put the output\n *                                       CSS file. You should always set `to`\n *                                       to generate correct source maps.\n * @property {parser} parser           - function to generate AST by string\n * @property {stringifier} stringifier - class to generate string by AST\n * @property {syntax} syntax           - object with `parse` and `stringify`\n * @property {object} map              - source map options\n * @property {boolean} map.inline                    - does source map should\n *                                                     be embedded in the output\n *                                                     CSS as a base64-encoded\n *                                                     comment\n * @property {string|object|false|function} map.prev - source map content\n *                                                     from a previous\n *                                                     processing step\n *                                                     (for example, Sass).\n *                                                     PostCSS will try to find\n *                                                     previous map\n *                                                     automatically, so you\n *                                                     could disable it by\n *                                                     `false` value.\n * @property {boolean} map.sourcesContent            - does PostCSS should set\n *                                                     the origin content to map\n * @property {string|false} map.annotation           - does PostCSS should set\n *                                                     annotation comment to map\n * @property {string} map.from                       - override `from` in map’s\n *                                                     `sources`\n */\n"]}
261
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["processor.es6"],"names":["Processor","plugins","version","normalize","use","plugin","concat","process","css","opts","length","parser","stringifier","env","NODE_ENV","console","warn","LazyResult","normalized","i","postcss","Array","isArray","push","parse","stringify","Error"],"mappings":";;;;;;AAAA;;;;;;;;AAEA;;;;;;;;;IASMA,S;AACJ;;;;AAIA,uBAA2B;AAAA,QAAdC,OAAc,uEAAJ,EAAI;;AAAA;;AACzB;;;;;;;;;;AAUA,SAAKC,OAAL,GAAe,OAAf;AACA;;;;;;;;;AASA,SAAKD,OAAL,GAAe,KAAKE,SAAL,CAAeF,OAAf,CAAf;AACD;;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBA6BAG,G,gBAAKC,M,EAAQ;AACX,SAAKJ,OAAL,GAAe,KAAKA,OAAL,CAAaK,MAAb,CAAoB,KAAKH,SAAL,CAAe,CAACE,MAAD,CAAf,CAApB,CAAf;AACA,WAAO,IAAP;AACD,G;;AAED;;;;;;;;;;;;;;;;;;;;;;;;sBAsBAE,O;;;;;;;;;;cAASC,G,EAAiB;AAAA,QAAZC,IAAY,uEAAL,EAAK;;AACxB,QAAI,KAAKR,OAAL,CAAaS,MAAb,KAAwB,CAAxB,IAA6BD,KAAKE,MAAL,KAAgBF,KAAKG,WAAtD,EAAmE;AACjE,UAAIL,QAAQM,GAAR,CAAYC,QAAZ,KAAyB,YAA7B,EAA2C;AACzC,YAAI,OAAOC,OAAP,KAAmB,WAAnB,IAAkCA,QAAQC,IAA9C,EAAoD;AAClDD,kBAAQC,IAAR,CACE,0DACA,2DADA,GAEA,kEAHF;AAKD;AACF;AACF;AACD,WAAO,IAAIC,oBAAJ,CAAe,IAAf,EAAqBT,GAArB,EAA0BC,IAA1B,CAAP;AACD,G;;sBAEDN,S,sBAAWF,O,EAAS;AAClB,QAAIiB,aAAa,EAAjB;AACA,yBAAcjB,OAAd,kHAAuB;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAAA,UAAdkB,CAAc;;AACrB,UAAIA,EAAEC,OAAN,EAAeD,IAAIA,EAAEC,OAAN;;AAEf,UAAI,QAAOD,CAAP,yCAAOA,CAAP,OAAa,QAAb,IAAyBE,MAAMC,OAAN,CAAcH,EAAElB,OAAhB,CAA7B,EAAuD;AACrDiB,qBAAaA,WAAWZ,MAAX,CAAkBa,EAAElB,OAApB,CAAb;AACD,OAFD,MAEO,IAAI,OAAOkB,CAAP,KAAa,UAAjB,EAA6B;AAClCD,mBAAWK,IAAX,CAAgBJ,CAAhB;AACD,OAFM,MAEA,IAAI,QAAOA,CAAP,yCAAOA,CAAP,OAAa,QAAb,KAA0BA,EAAEK,KAAF,IAAWL,EAAEM,SAAvC,CAAJ,EAAuD;AAC5D,YAAIlB,QAAQM,GAAR,CAAYC,QAAZ,KAAyB,YAA7B,EAA2C;AACzC,gBAAM,IAAIY,KAAJ,CACJ,qEACA,2DADA,GAEA,uCAHI,CAAN;AAKD;AACF,OARM,MAQA;AACL,cAAM,IAAIA,KAAJ,CAAUP,IAAI,0BAAd,CAAN;AACD;AACF;AACD,WAAOD,UAAP;AACD,G;;;;;kBAGYlB,S;;AAEf;;;;;;;AAOA;;;;;;;;;;AAUA;;;;;;;;;;AAUA;;;;;;AAMA;;;;;AAKA;;;;;;AAMA;;;;;AAKA","file":"processor.js","sourcesContent":["import LazyResult from './lazy-result'\n\n/**\n * Contains plugins to process CSS. Create one `Processor` instance,\n * initialize its plugins, and then use that instance on numerous CSS files.\n *\n * @example\n * const processor = postcss([autoprefixer, precss])\n * processor.process(css1).then(result => console.log(result.css))\n * processor.process(css2).then(result => console.log(result.css))\n */\nclass Processor {\n  /**\n   * @param {Array.<Plugin|pluginFunction>|Processor} plugins PostCSS plugins.\n   *        See {@link Processor#use} for plugin format.\n   */\n  constructor (plugins = []) {\n    /**\n     * Current PostCSS version.\n     *\n     * @type {string}\n     *\n     * @example\n     * if (result.processor.version.split('.')[0] !== '6') {\n     *   throw new Error('This plugin works only with PostCSS 6')\n     * }\n     */\n    this.version = '7.0.2'\n    /**\n     * Plugins added to this processor.\n     *\n     * @type {pluginFunction[]}\n     *\n     * @example\n     * const processor = postcss([autoprefixer, precss])\n     * processor.plugins.length //=> 2\n     */\n    this.plugins = this.normalize(plugins)\n  }\n\n  /**\n   * Adds a plugin to be used as a CSS processor.\n   *\n   * PostCSS plugin can be in 4 formats:\n   * * A plugin created by {@link postcss.plugin} method.\n   * * A function. PostCSS will pass the function a @{link Root}\n   *   as the first argument and current {@link Result} instance\n   *   as the second.\n   * * An object with a `postcss` method. PostCSS will use that method\n   *   as described in #2.\n   * * Another {@link Processor} instance. PostCSS will copy plugins\n   *   from that instance into this one.\n   *\n   * Plugins can also be added by passing them as arguments when creating\n   * a `postcss` instance (see [`postcss(plugins)`]).\n   *\n   * Asynchronous plugins should return a `Promise` instance.\n   *\n   * @param {Plugin|pluginFunction|Processor} plugin PostCSS plugin\n   *                                                 or {@link Processor}\n   *                                                 with plugins.\n   *\n   * @example\n   * const processor = postcss()\n   *   .use(autoprefixer)\n   *   .use(precss)\n   *\n   * @return {Processes} Current processor to make methods chain.\n   */\n  use (plugin) {\n    this.plugins = this.plugins.concat(this.normalize([plugin]))\n    return this\n  }\n\n  /**\n   * Parses source CSS and returns a {@link LazyResult} Promise proxy.\n   * Because some plugins can be asynchronous it doesn’t make\n   * any transformations. Transformations will be applied\n   * in the {@link LazyResult} methods.\n   *\n   * @param {string|toString|Result} css String with input CSS or any object\n   *                                     with a `toString()` method,\n   *                                     like a Buffer. Optionally, send\n   *                                     a {@link Result} instance\n   *                                     and the processor will take\n   *                                     the {@link Root} from it.\n   * @param {processOptions} [opts]      Options.\n   *\n   * @return {LazyResult} Promise proxy.\n   *\n   * @example\n   * processor.process(css, { from: 'a.css', to: 'a.out.css' })\n   *   .then(result => {\n   *      console.log(result.css)\n   *   })\n   */\n  process (css, opts = { }) {\n    if (this.plugins.length === 0 && opts.parser === opts.stringifier) {\n      if (process.env.NODE_ENV !== 'production') {\n        if (typeof console !== 'undefined' && console.warn) {\n          console.warn(\n            'You did not set any plugins, parser, or stringifier. ' +\n            'Right now PostCSS do nothing. Pick plugins for your case ' +\n            'on https://www.postcss.parts/ and use them in postcss.config.js.'\n          )\n        }\n      }\n    }\n    return new LazyResult(this, css, opts)\n  }\n\n  normalize (plugins) {\n    let normalized = []\n    for (let i of plugins) {\n      if (i.postcss) i = i.postcss\n\n      if (typeof i === 'object' && Array.isArray(i.plugins)) {\n        normalized = normalized.concat(i.plugins)\n      } else if (typeof i === 'function') {\n        normalized.push(i)\n      } else if (typeof i === 'object' && (i.parse || i.stringify)) {\n        if (process.env.NODE_ENV !== 'production') {\n          throw new Error(\n            'PostCSS syntaxes cannot be used as plugins. Instead, please use ' +\n            'one of the syntax/parser/stringifier options as outlined ' +\n            'in your PostCSS runner documentation.'\n          )\n        }\n      } else {\n        throw new Error(i + ' is not a PostCSS plugin')\n      }\n    }\n    return normalized\n  }\n}\n\nexport default Processor\n\n/**\n * @callback builder\n * @param {string} part          Part of generated CSS connected to this node.\n * @param {Node}   node          AST node.\n * @param {\"start\"|\"end\"} [type] Node’s part type.\n */\n\n/**\n * @callback parser\n *\n * @param {string|toString} css   String with input CSS or any object\n *                                with toString() method, like a Buffer.\n * @param {processOptions} [opts] Options with only `from` and `map` keys.\n *\n * @return {Root} PostCSS AST\n */\n\n/**\n * @callback stringifier\n *\n * @param {Node} node       Start node for stringifing. Usually {@link Root}.\n * @param {builder} builder Function to concatenate CSS from node’s parts\n *                          or generate string and source map.\n *\n * @return {void}\n */\n\n/**\n * @typedef {object} syntax\n * @property {parser} parse          Function to generate AST by string.\n * @property {stringifier} stringify Function to generate string by AST.\n */\n\n/**\n * @typedef {object} toString\n * @property {function} toString\n */\n\n/**\n * @callback pluginFunction\n * @param {Root} root     Parsed input CSS.\n * @param {Result} result Result to set warnings or check other plugins.\n */\n\n/**\n * @typedef {object} Plugin\n * @property {function} postcss PostCSS plugin function.\n */\n\n/**\n * @typedef {object} processOptions\n * @property {string} from             The path of the CSS source file.\n *                                     You should always set `from`,\n *                                     because it is used in source map\n *                                     generation and syntax error messages.\n * @property {string} to               The path where you’ll put the output\n *                                     CSS file. You should always set `to`\n *                                     to generate correct source maps.\n * @property {parser} parser           Function to generate AST by string.\n * @property {stringifier} stringifier Class to generate string by AST.\n * @property {syntax} syntax           Object with `parse` and `stringify`.\n * @property {object} map              Source map options.\n * @property {boolean} map.inline                    Does source map should\n *                                                   be embedded in the output\n *                                                   CSS as a base64-encoded\n *                                                   comment.\n * @property {string|object|false|function} map.prev Source map content\n *                                                   from a previous\n *                                                   processing step\n *                                                   (for example, Sass).\n *                                                   PostCSS will try to find\n *                                                   previous map automatically,\n *                                                   so you could disable it by\n *                                                   `false` value.\n * @property {boolean} map.sourcesContent            Does PostCSS should set\n *                                                   the origin content to map.\n * @property {string|false} map.annotation           Does PostCSS should set\n *                                                   annotation comment to map.\n * @property {string} map.from                       Override `from` in map’s\n *                                                   sources`.\n */\n"]}
package/lib/result.js CHANGED
@@ -19,90 +19,95 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
19
19
  * or {@link Root#toResult} methods.
20
20
  *
21
21
  * @example
22
- * postcss([cssnext]).process(css).then(function (result) {
23
- * console.log(result.css);
24
- * });
22
+ * postcss([cssnext]).process(css).then(result => {
23
+ * console.log(result.css)
24
+ * })
25
25
  *
26
26
  * @example
27
- * var result2 = postcss.parse(css).toResult();
27
+ * const result2 = postcss.parse(css).toResult()
28
28
  */
29
29
  var Result = function () {
30
-
31
30
  /**
32
- * @param {Processor} processor - processor used for this transformation.
33
- * @param {Root} root - Root node after all transformations.
34
- * @param {processOptions} opts - options from the {@link Processor#process}
35
- * or {@link Root#toResult}
31
+ * @param {Processor} processor Processor used for this transformation.
32
+ * @param {Root} root Root node after all transformations.
33
+ * @param {processOptions} opts Options from the {@link Processor#process}
34
+ * or {@link Root#toResult}.
36
35
  */
37
36
  function Result(processor, root, opts) {
38
37
  _classCallCheck(this, Result);
39
38
 
40
39
  /**
41
- * @member {Processor} - The Processor instance used
42
- * for this transformation.
40
+ * The Processor instance used for this transformation.
41
+ *
42
+ * @type {Processor}
43
43
  *
44
44
  * @example
45
- * for ( let plugin of result.processor.plugins) {
46
- * if ( plugin.postcssPlugin === 'postcss-bad' ) {
47
- * throw 'postcss-good is incompatible with postcss-bad';
45
+ * for (const plugin of result.processor.plugins) {
46
+ * if (plugin.postcssPlugin === 'postcss-bad') {
47
+ * throw 'postcss-good is incompatible with postcss-bad'
48
48
  * }
49
- * });
49
+ * })
50
50
  */
51
51
  this.processor = processor;
52
52
  /**
53
- * @member {Message[]} - Contains messages from plugins
54
- * (e.g., warnings or custom messages).
55
- * Each message should have type
56
- * and plugin properties.
53
+ * Contains messages from plugins (e.g., warnings or custom messages).
54
+ * Each message should have type and plugin properties.
55
+ *
56
+ * @type {Message[]}
57
57
  *
58
58
  * @example
59
59
  * postcss.plugin('postcss-min-browser', () => {
60
60
  * return (root, result) => {
61
- * var browsers = detectMinBrowsersByCanIUse(root);
61
+ * const browsers = detectMinBrowsersByCanIUse(root)
62
62
  * result.messages.push({
63
- * type: 'min-browser',
64
- * plugin: 'postcss-min-browser',
65
- * browsers: browsers
66
- * });
67
- * };
68
- * });
63
+ * type: 'min-browser',
64
+ * plugin: 'postcss-min-browser',
65
+ * browsers
66
+ * })
67
+ * }
68
+ * })
69
69
  */
70
70
  this.messages = [];
71
71
  /**
72
- * @member {Root} - Root node after all transformations.
72
+ * Root node after all transformations.
73
+ *
74
+ * @type {Root}
73
75
  *
74
76
  * @example
75
- * root.toResult().root == root;
77
+ * root.toResult().root === root
76
78
  */
77
79
  this.root = root;
78
80
  /**
79
- * @member {processOptions} - Options from the {@link Processor#process}
80
- * or {@link Root#toResult} call
81
- * that produced this Result instance.
81
+ * Options from the {@link Processor#process} or {@link Root#toResult} call
82
+ * that produced this Result instance.
83
+ *
84
+ * @type {processOptions}
82
85
  *
83
86
  * @example
84
- * root.toResult(opts).opts == opts;
87
+ * root.toResult(opts).opts === opts
85
88
  */
86
89
  this.opts = opts;
87
90
  /**
88
- * @member {string} - A CSS string representing of {@link Result#root}.
91
+ * A CSS string representing of {@link Result#root}.
92
+ *
93
+ * @type {string}
89
94
  *
90
95
  * @example
91
96
  * postcss.parse('a{}').toResult().css //=> "a{}"
92
97
  */
93
98
  this.css = undefined;
94
99
  /**
95
- * @member {SourceMapGenerator} - An instance of `SourceMapGenerator`
96
- * class from the `source-map` library,
97
- * representing changes
98
- * to the {@link Result#root} instance.
100
+ * An instance of `SourceMapGenerator` class from the `source-map` library,
101
+ * representing changes to the {@link Result#root} instance.
102
+ *
103
+ * @type {SourceMapGenerator}
99
104
  *
100
105
  * @example
101
106
  * result.map.toJSON() //=> { version: 3, file: 'a.css', … }
102
107
  *
103
108
  * @example
104
- * if ( result.map ) {
105
- * fs.writeFileSync(result.opts.to + '.map', result.map.toString());
109
+ * if (result.map) {
110
+ * fs.writeFileSync(result.opts.to + '.map', result.map.toString())
106
111
  * }
107
112
  */
108
113
  this.map = undefined;
@@ -114,7 +119,7 @@ var Result = function () {
114
119
  * @example
115
120
  * result + '' === result.css
116
121
  *
117
- * @return {string} string representing of {@link Result#root}
122
+ * @return {string} String representing of {@link Result#root}.
118
123
  */
119
124
 
120
125
 
@@ -126,17 +131,17 @@ var Result = function () {
126
131
  * Creates an instance of {@link Warning} and adds it
127
132
  * to {@link Result#messages}.
128
133
  *
129
- * @param {string} text - warning message
130
- * @param {Object} [opts] - warning options
131
- * @param {Node} opts.node - CSS node that caused the warning
132
- * @param {string} opts.word - word in CSS source that caused the warning
133
- * @param {number} opts.index - index in CSS node string that caused
134
- * the warning
135
- * @param {string} opts.plugin - name of the plugin that created
136
- * this warning. {@link Result#warn} fills
137
- * this property automatically.
134
+ * @param {string} text Warning message.
135
+ * @param {Object} [opts] Warning options.
136
+ * @param {Node} opts.node CSS node that caused the warning.
137
+ * @param {string} opts.word Word in CSS source that caused the warning.
138
+ * @param {number} opts.index Index in CSS node string that caused
139
+ * the warning.
140
+ * @param {string} opts.plugin Name of the plugin that created
141
+ * this warning. {@link Result#warn} fills
142
+ * this property automatically.
138
143
  *
139
- * @return {Warning} created warning
144
+ * @return {Warning} Created warning.
140
145
  */
141
146
 
142
147
 
@@ -156,16 +161,16 @@ var Result = function () {
156
161
  };
157
162
 
158
163
  /**
159
- * Returns warnings from plugins. Filters {@link Warning} instances
160
- * from {@link Result#messages}.
161
- *
162
- * @example
163
- * result.warnings().forEach(warn => {
164
- * console.warn(warn.toString());
165
- * });
166
- *
167
- * @return {Warning[]} warnings from plugins
168
- */
164
+ * Returns warnings from plugins. Filters {@link Warning} instances
165
+ * from {@link Result#messages}.
166
+ *
167
+ * @example
168
+ * result.warnings().forEach(warn => {
169
+ * console.warn(warn.toString())
170
+ * })
171
+ *
172
+ * @return {Warning[]} Warnings from plugins.
173
+ */
169
174
 
170
175
 
171
176
  Result.prototype.warnings = function warnings() {
@@ -177,10 +182,11 @@ var Result = function () {
177
182
  /**
178
183
  * An alias for the {@link Result#css} property.
179
184
  * Use it with syntaxes that generate non-CSS output.
185
+ *
180
186
  * @type {string}
181
187
  *
182
188
  * @example
183
- * result.css === result.content;
189
+ * result.css === result.content
184
190
  */
185
191
 
186
192
 
@@ -198,9 +204,9 @@ exports.default = Result;
198
204
 
199
205
  /**
200
206
  * @typedef {object} Message
201
- * @property {string} type - message type
202
- * @property {string} plugin - source PostCSS plugin name
207
+ * @property {string} type Message type.
208
+ * @property {string} plugin Source PostCSS plugin name.
203
209
  */
204
210
 
205
211
  module.exports = exports['default'];
206
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["result.es6"],"names":["Result","processor","root","opts","messages","css","undefined","map","toString","warn","text","plugin","lastPlugin","postcssPlugin","warning","Warning","push","warnings","filter","i","type"],"mappings":";;;;;;AAAA;;;;;;;;AAEA;;;;;;;;;;;;;;IAcMA,M;;AAEF;;;;;;AAMA,kBAAYC,SAAZ,EAAuBC,IAAvB,EAA6BC,IAA7B,EAAmC;AAAA;;AAC/B;;;;;;;;;;;AAWA,SAAKF,SAAL,GAAiBA,SAAjB;AACA;;;;;;;;;;;;;;;;;;AAkBA,SAAKG,QAAL,GAAgB,EAAhB;AACA;;;;;;AAMA,SAAKF,IAAL,GAAYA,IAAZ;AACA;;;;;;;;AAQA,SAAKC,IAAL,GAAYA,IAAZ;AACA;;;;;;AAMA,SAAKE,GAAL,GAAWC,SAAX;AACA;;;;;;;;;;;;;;AAcA,SAAKC,GAAL,GAAWD,SAAX;AACH;;AAED;;;;;;;;;;mBAQAE,Q,uBAAW;AACP,WAAO,KAAKH,GAAZ;AACH,G;;AAED;;;;;;;;;;;;;;;;;;mBAgBAI,I,iBAAKC,I,EAAkB;AAAA,QAAZP,IAAY,uEAAL,EAAK;;AACnB,QAAK,CAACA,KAAKQ,MAAX,EAAoB;AAChB,UAAK,KAAKC,UAAL,IAAmB,KAAKA,UAAL,CAAgBC,aAAxC,EAAwD;AACpDV,aAAKQ,MAAL,GAAc,KAAKC,UAAL,CAAgBC,aAA9B;AACH;AACJ;;AAED,QAAIC,UAAU,IAAIC,iBAAJ,CAAYL,IAAZ,EAAkBP,IAAlB,CAAd;AACA,SAAKC,QAAL,CAAcY,IAAd,CAAmBF,OAAnB;;AAEA,WAAOA,OAAP;AACH,G;;AAED;;;;;;;;;;;;;mBAWAG,Q,uBAAW;AACP,WAAO,KAAKb,QAAL,CAAcc,MAAd,CAAsB;AAAA,aAAKC,EAAEC,IAAF,KAAW,SAAhB;AAAA,KAAtB,CAAP;AACH,G;;AAED;;;;;;;;;;;;wBAQc;AACV,aAAO,KAAKf,GAAZ;AACH;;;;;;kBAIUL,M;;AAEf","file":"result.js","sourcesContent":["import Warning from './warning';\n\n/**\n * Provides the result of the PostCSS transformations.\n *\n * A Result instance is returned by {@link LazyResult#then}\n * or {@link Root#toResult} methods.\n *\n * @example\n * postcss([cssnext]).process(css).then(function (result) {\n *    console.log(result.css);\n * });\n *\n * @example\n * var result2 = postcss.parse(css).toResult();\n */\nclass Result {\n\n    /**\n     * @param {Processor} processor - processor used for this transformation.\n     * @param {Root}      root      - Root node after all transformations.\n     * @param {processOptions} opts - options from the {@link Processor#process}\n     *                                or {@link Root#toResult}\n     */\n    constructor(processor, root, opts) {\n        /**\n         * @member {Processor} - The Processor instance used\n         *                       for this transformation.\n         *\n         * @example\n         * for ( let plugin of result.processor.plugins) {\n         *   if ( plugin.postcssPlugin === 'postcss-bad' ) {\n         *     throw 'postcss-good is incompatible with postcss-bad';\n         *   }\n         * });\n         */\n        this.processor = processor;\n        /**\n         * @member {Message[]} - Contains messages from plugins\n         *                       (e.g., warnings or custom messages).\n         *                       Each message should have type\n         *                       and plugin properties.\n         *\n         * @example\n         * postcss.plugin('postcss-min-browser', () => {\n         *   return (root, result) => {\n         *     var browsers = detectMinBrowsersByCanIUse(root);\n         *     result.messages.push({\n         *       type:    'min-browser',\n         *       plugin:  'postcss-min-browser',\n         *       browsers: browsers\n         *     });\n         *   };\n         * });\n         */\n        this.messages = [];\n        /**\n         * @member {Root} - Root node after all transformations.\n         *\n         * @example\n         * root.toResult().root == root;\n         */\n        this.root = root;\n        /**\n         * @member {processOptions} - Options from the {@link Processor#process}\n         *                            or {@link Root#toResult} call\n         *                            that produced this Result instance.\n         *\n         * @example\n         * root.toResult(opts).opts == opts;\n         */\n        this.opts = opts;\n        /**\n         * @member {string} - A CSS string representing of {@link Result#root}.\n         *\n         * @example\n         * postcss.parse('a{}').toResult().css //=> \"a{}\"\n         */\n        this.css = undefined;\n        /**\n         * @member {SourceMapGenerator} - An instance of `SourceMapGenerator`\n         *                                class from the `source-map` library,\n         *                                representing changes\n         *                                to the {@link Result#root} instance.\n         *\n         * @example\n         * result.map.toJSON() //=> { version: 3, file: 'a.css', … }\n         *\n         * @example\n         * if ( result.map ) {\n         *   fs.writeFileSync(result.opts.to + '.map', result.map.toString());\n         * }\n         */\n        this.map = undefined;\n    }\n\n    /**\n     * Returns for @{link Result#css} content.\n     *\n     * @example\n     * result + '' === result.css\n     *\n     * @return {string} string representing of {@link Result#root}\n     */\n    toString() {\n        return this.css;\n    }\n\n    /**\n     * Creates an instance of {@link Warning} and adds it\n     * to {@link Result#messages}.\n     *\n     * @param {string} text        - warning message\n     * @param {Object} [opts]      - warning options\n     * @param {Node}   opts.node   - CSS node that caused the warning\n     * @param {string} opts.word   - word in CSS source that caused the warning\n     * @param {number} opts.index  - index in CSS node string that caused\n     *                               the warning\n     * @param {string} opts.plugin - name of the plugin that created\n     *                               this warning. {@link Result#warn} fills\n     *                               this property automatically.\n     *\n     * @return {Warning} created warning\n     */\n    warn(text, opts = { }) {\n        if ( !opts.plugin ) {\n            if ( this.lastPlugin && this.lastPlugin.postcssPlugin ) {\n                opts.plugin = this.lastPlugin.postcssPlugin;\n            }\n        }\n\n        let warning = new Warning(text, opts);\n        this.messages.push(warning);\n\n        return warning;\n    }\n\n    /**\n     * Returns warnings from plugins. Filters {@link Warning} instances\n     * from {@link Result#messages}.\n     *\n     * @example\n     * result.warnings().forEach(warn => {\n     *   console.warn(warn.toString());\n     * });\n     *\n     * @return {Warning[]} warnings from plugins\n     */\n    warnings() {\n        return this.messages.filter( i => i.type === 'warning' );\n    }\n\n    /**\n     * An alias for the {@link Result#css} property.\n     * Use it with syntaxes that generate non-CSS output.\n     * @type {string}\n     *\n     * @example\n     * result.css === result.content;\n     */\n    get content() {\n        return this.css;\n    }\n\n}\n\nexport default Result;\n\n/**\n * @typedef  {object} Message\n * @property {string} type   - message type\n * @property {string} plugin - source PostCSS plugin name\n */\n"]}
212
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["result.es6"],"names":["Result","processor","root","opts","messages","css","undefined","map","toString","warn","text","plugin","lastPlugin","postcssPlugin","warning","Warning","push","warnings","filter","i","type"],"mappings":";;;;;;AAAA;;;;;;;;AAEA;;;;;;;;;;;;;;IAcMA,M;AACJ;;;;;;AAMA,kBAAaC,SAAb,EAAwBC,IAAxB,EAA8BC,IAA9B,EAAoC;AAAA;;AAClC;;;;;;;;;;;;AAYA,SAAKF,SAAL,GAAiBA,SAAjB;AACA;;;;;;;;;;;;;;;;;;AAkBA,SAAKG,QAAL,GAAgB,EAAhB;AACA;;;;;;;;AAQA,SAAKF,IAAL,GAAYA,IAAZ;AACA;;;;;;;;;AASA,SAAKC,IAAL,GAAYA,IAAZ;AACA;;;;;;;;AAQA,SAAKE,GAAL,GAAWC,SAAX;AACA;;;;;;;;;;;;;;AAcA,SAAKC,GAAL,GAAWD,SAAX;AACD;;AAED;;;;;;;;;;mBAQAE,Q,uBAAY;AACV,WAAO,KAAKH,GAAZ;AACD,G;;AAED;;;;;;;;;;;;;;;;;;mBAgBAI,I,iBAAMC,I,EAAkB;AAAA,QAAZP,IAAY,uEAAL,EAAK;;AACtB,QAAI,CAACA,KAAKQ,MAAV,EAAkB;AAChB,UAAI,KAAKC,UAAL,IAAmB,KAAKA,UAAL,CAAgBC,aAAvC,EAAsD;AACpDV,aAAKQ,MAAL,GAAc,KAAKC,UAAL,CAAgBC,aAA9B;AACD;AACF;;AAED,QAAIC,UAAU,IAAIC,iBAAJ,CAAYL,IAAZ,EAAkBP,IAAlB,CAAd;AACA,SAAKC,QAAL,CAAcY,IAAd,CAAmBF,OAAnB;;AAEA,WAAOA,OAAP;AACD,G;;AAED;;;;;;;;;;;;;mBAWAG,Q,uBAAY;AACV,WAAO,KAAKb,QAAL,CAAcc,MAAd,CAAqB;AAAA,aAAKC,EAAEC,IAAF,KAAW,SAAhB;AAAA,KAArB,CAAP;AACD,G;;AAED;;;;;;;;;;;;;wBASe;AACb,aAAO,KAAKf,GAAZ;AACD;;;;;;kBAGYL,M;;AAEf","file":"result.js","sourcesContent":["import Warning from './warning'\n\n/**\n * Provides the result of the PostCSS transformations.\n *\n * A Result instance is returned by {@link LazyResult#then}\n * or {@link Root#toResult} methods.\n *\n * @example\n * postcss([cssnext]).process(css).then(result => {\n *  console.log(result.css)\n * })\n *\n * @example\n * const result2 = postcss.parse(css).toResult()\n */\nclass Result {\n  /**\n   * @param {Processor} processor Processor used for this transformation.\n   * @param {Root}      root      Root node after all transformations.\n   * @param {processOptions} opts Options from the {@link Processor#process}\n   *                              or {@link Root#toResult}.\n   */\n  constructor (processor, root, opts) {\n    /**\n     * The Processor instance used for this transformation.\n     *\n     * @type {Processor}\n     *\n     * @example\n     * for (const plugin of result.processor.plugins) {\n     *   if (plugin.postcssPlugin === 'postcss-bad') {\n     *     throw 'postcss-good is incompatible with postcss-bad'\n     *   }\n     * })\n     */\n    this.processor = processor\n    /**\n     * Contains messages from plugins (e.g., warnings or custom messages).\n     * Each message should have type and plugin properties.\n     *\n     * @type {Message[]}\n     *\n     * @example\n     * postcss.plugin('postcss-min-browser', () => {\n     *   return (root, result) => {\n     *     const browsers = detectMinBrowsersByCanIUse(root)\n     *     result.messages.push({\n     *       type: 'min-browser',\n     *       plugin: 'postcss-min-browser',\n     *       browsers\n     *     })\n     *   }\n     * })\n     */\n    this.messages = []\n    /**\n     * Root node after all transformations.\n     *\n     * @type {Root}\n     *\n     * @example\n     * root.toResult().root === root\n     */\n    this.root = root\n    /**\n     * Options from the {@link Processor#process} or {@link Root#toResult} call\n     * that produced this Result instance.\n     *\n     * @type {processOptions}\n     *\n     * @example\n     * root.toResult(opts).opts === opts\n     */\n    this.opts = opts\n    /**\n     * A CSS string representing of {@link Result#root}.\n     *\n     * @type {string}\n     *\n     * @example\n     * postcss.parse('a{}').toResult().css //=> \"a{}\"\n     */\n    this.css = undefined\n    /**\n     * An instance of `SourceMapGenerator` class from the `source-map` library,\n     * representing changes to the {@link Result#root} instance.\n     *\n     * @type {SourceMapGenerator}\n     *\n     * @example\n     * result.map.toJSON() //=> { version: 3, file: 'a.css', … }\n     *\n     * @example\n     * if (result.map) {\n     *   fs.writeFileSync(result.opts.to + '.map', result.map.toString())\n     * }\n     */\n    this.map = undefined\n  }\n\n  /**\n   * Returns for @{link Result#css} content.\n   *\n   * @example\n   * result + '' === result.css\n   *\n   * @return {string} String representing of {@link Result#root}.\n   */\n  toString () {\n    return this.css\n  }\n\n  /**\n   * Creates an instance of {@link Warning} and adds it\n   * to {@link Result#messages}.\n   *\n   * @param {string} text        Warning message.\n   * @param {Object} [opts]      Warning options.\n   * @param {Node}   opts.node   CSS node that caused the warning.\n   * @param {string} opts.word   Word in CSS source that caused the warning.\n   * @param {number} opts.index  Index in CSS node string that caused\n   *                             the warning.\n   * @param {string} opts.plugin Name of the plugin that created\n   *                             this warning. {@link Result#warn} fills\n   *                             this property automatically.\n   *\n   * @return {Warning} Created warning.\n   */\n  warn (text, opts = { }) {\n    if (!opts.plugin) {\n      if (this.lastPlugin && this.lastPlugin.postcssPlugin) {\n        opts.plugin = this.lastPlugin.postcssPlugin\n      }\n    }\n\n    let warning = new Warning(text, opts)\n    this.messages.push(warning)\n\n    return warning\n  }\n\n  /**\n     * Returns warnings from plugins. Filters {@link Warning} instances\n     * from {@link Result#messages}.\n     *\n     * @example\n     * result.warnings().forEach(warn => {\n     *   console.warn(warn.toString())\n     * })\n     *\n     * @return {Warning[]} Warnings from plugins.\n     */\n  warnings () {\n    return this.messages.filter(i => i.type === 'warning')\n  }\n\n  /**\n   * An alias for the {@link Result#css} property.\n   * Use it with syntaxes that generate non-CSS output.\n   *\n   * @type {string}\n   *\n   * @example\n   * result.css === result.content\n   */\n  get content () {\n    return this.css\n  }\n}\n\nexport default Result\n\n/**\n * @typedef  {object} Message\n * @property {string} type   Message type.\n * @property {string} plugin Source PostCSS plugin name.\n */\n"]}