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/CHANGELOG.md +18 -0
- package/README-cn.md +54 -51
- package/README.md +60 -52
- package/docs/architecture.md +2 -2
- package/docs/guidelines/plugin.md +28 -28
- package/docs/guidelines/runner.md +21 -21
- package/docs/source-maps.md +11 -11
- package/docs/syntax.md +23 -23
- package/gulpfile.js +78 -74
- package/lib/at-rule.js +14 -14
- package/lib/comment.js +4 -4
- package/lib/container.js +773 -801
- package/lib/css-syntax-error.js +197 -180
- package/lib/declaration.js +15 -14
- package/lib/input.js +149 -143
- package/lib/lazy-result.js +364 -337
- package/lib/list.js +69 -70
- package/lib/map-generator.js +270 -275
- package/lib/node.js +558 -570
- package/lib/parse.js +20 -21
- package/lib/parser.js +476 -479
- package/lib/postcss.d.ts +1246 -1246
- package/lib/postcss.js +61 -57
- package/lib/previous-map.js +117 -122
- package/lib/processor.js +96 -75
- package/lib/result.js +70 -64
- package/lib/root.js +91 -90
- package/lib/rule.js +12 -12
- package/lib/stringifier.js +295 -295
- package/lib/stringify.js +5 -4
- package/lib/terminal-highlight.js +50 -50
- package/lib/tokenize.js +259 -259
- package/lib/vendor.js +27 -27
- package/lib/warn-once.js +6 -4
- package/lib/warning.js +30 -26
- package/package.json +4 -3
- package/CONTRIBUTING.md +0 -78
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
|
28
|
-
*
|
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
|
-
*
|
35
|
+
* Current PostCSS version.
|
36
|
+
*
|
37
|
+
* @type {string}
|
37
38
|
*
|
38
39
|
* @example
|
39
|
-
* if (
|
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 = '
|
44
|
+
this.version = '7.0.2';
|
44
45
|
/**
|
45
|
-
*
|
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
|
73
|
-
*
|
74
|
-
*
|
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}
|
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
|
97
|
-
*
|
98
|
-
*
|
99
|
-
*
|
100
|
-
*
|
101
|
-
*
|
102
|
-
* @param {processOptions} [opts]
|
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
|
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
|
-
|
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
|
159
|
-
* @param {Node} node
|
160
|
-
* @param {"start"|"end"} [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
|
167
|
-
*
|
168
|
-
* @param {processOptions} [opts]
|
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
|
177
|
-
* @param {builder} builder
|
178
|
-
*
|
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
|
186
|
-
* @property {stringifier} stringify
|
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
|
197
|
-
* @param {Result} result
|
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
|
224
|
+
* @property {function} postcss PostCSS plugin function.
|
203
225
|
*/
|
204
226
|
|
205
227
|
/**
|
206
228
|
* @typedef {object} processOptions
|
207
|
-
* @property {string} from
|
208
|
-
*
|
209
|
-
*
|
210
|
-
*
|
211
|
-
* @property {string} to
|
212
|
-
*
|
213
|
-
*
|
214
|
-
* @property {parser} parser
|
215
|
-
* @property {stringifier} stringifier
|
216
|
-
* @property {syntax} syntax
|
217
|
-
* @property {object} map
|
218
|
-
* @property {boolean} map.inline
|
219
|
-
*
|
220
|
-
*
|
221
|
-
*
|
222
|
-
* @property {string|object|false|function} map.prev
|
223
|
-
*
|
224
|
-
*
|
225
|
-
*
|
226
|
-
*
|
227
|
-
*
|
228
|
-
*
|
229
|
-
*
|
230
|
-
*
|
231
|
-
*
|
232
|
-
*
|
233
|
-
*
|
234
|
-
*
|
235
|
-
*
|
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(
|
23
|
-
*
|
24
|
-
* })
|
22
|
+
* postcss([cssnext]).process(css).then(result => {
|
23
|
+
* console.log(result.css)
|
24
|
+
* })
|
25
25
|
*
|
26
26
|
* @example
|
27
|
-
*
|
27
|
+
* const result2 = postcss.parse(css).toResult()
|
28
28
|
*/
|
29
29
|
var Result = function () {
|
30
|
-
|
31
30
|
/**
|
32
|
-
* @param {Processor} processor
|
33
|
-
* @param {Root} root
|
34
|
-
* @param {processOptions} opts
|
35
|
-
*
|
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
|
-
*
|
42
|
-
*
|
40
|
+
* The Processor instance used for this transformation.
|
41
|
+
*
|
42
|
+
* @type {Processor}
|
43
43
|
*
|
44
44
|
* @example
|
45
|
-
* for (
|
46
|
-
* if (
|
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
|
-
*
|
54
|
-
*
|
55
|
-
*
|
56
|
-
*
|
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
|
-
*
|
61
|
+
* const browsers = detectMinBrowsersByCanIUse(root)
|
62
62
|
* result.messages.push({
|
63
|
-
* type:
|
64
|
-
* plugin:
|
65
|
-
* 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
|
-
*
|
72
|
+
* Root node after all transformations.
|
73
|
+
*
|
74
|
+
* @type {Root}
|
73
75
|
*
|
74
76
|
* @example
|
75
|
-
* root.toResult().root
|
77
|
+
* root.toResult().root === root
|
76
78
|
*/
|
77
79
|
this.root = root;
|
78
80
|
/**
|
79
|
-
*
|
80
|
-
*
|
81
|
-
*
|
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
|
87
|
+
* root.toResult(opts).opts === opts
|
85
88
|
*/
|
86
89
|
this.opts = opts;
|
87
90
|
/**
|
88
|
-
*
|
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
|
-
*
|
96
|
-
*
|
97
|
-
*
|
98
|
-
*
|
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 (
|
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}
|
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
|
130
|
-
* @param {Object} [opts]
|
131
|
-
* @param {Node} opts.node
|
132
|
-
* @param {string} opts.word
|
133
|
-
* @param {number} opts.index
|
134
|
-
*
|
135
|
-
* @param {string} opts.plugin
|
136
|
-
*
|
137
|
-
*
|
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}
|
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
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
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
|
202
|
-
* @property {string} plugin
|
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,
|
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"]}
|