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/lazy-result.js
CHANGED
@@ -31,7 +31,7 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
31
31
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
32
32
|
|
33
33
|
function isPromise(obj) {
|
34
|
-
|
34
|
+
return (typeof obj === 'undefined' ? 'undefined' : _typeof(obj)) === 'object' && typeof obj.then === 'function';
|
35
35
|
}
|
36
36
|
|
37
37
|
/**
|
@@ -40,383 +40,410 @@ function isPromise(obj) {
|
|
40
40
|
* A `LazyResult` instance is returned by {@link Processor#process}.
|
41
41
|
*
|
42
42
|
* @example
|
43
|
-
* const lazy = postcss([cssnext]).process(css)
|
43
|
+
* const lazy = postcss([cssnext]).process(css)
|
44
44
|
*/
|
45
45
|
|
46
46
|
var LazyResult = function () {
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
}
|
75
|
-
|
76
|
-
this.result = new _result2.default(processor, root, opts);
|
47
|
+
function LazyResult(processor, css, opts) {
|
48
|
+
_classCallCheck(this, LazyResult);
|
49
|
+
|
50
|
+
this.stringified = false;
|
51
|
+
this.processed = false;
|
52
|
+
|
53
|
+
var root = void 0;
|
54
|
+
if ((typeof css === 'undefined' ? 'undefined' : _typeof(css)) === 'object' && css !== null && css.type === 'root') {
|
55
|
+
root = css;
|
56
|
+
} else if (css instanceof LazyResult || css instanceof _result2.default) {
|
57
|
+
root = css.root;
|
58
|
+
if (css.map) {
|
59
|
+
if (typeof opts.map === 'undefined') opts.map = {};
|
60
|
+
if (!opts.map.inline) opts.map.inline = false;
|
61
|
+
opts.map.prev = css.map;
|
62
|
+
}
|
63
|
+
} else {
|
64
|
+
var parser = _parse2.default;
|
65
|
+
if (opts.syntax) parser = opts.syntax.parse;
|
66
|
+
if (opts.parser) parser = opts.parser;
|
67
|
+
if (parser.parse) parser = parser.parse;
|
68
|
+
|
69
|
+
try {
|
70
|
+
root = parser(css, opts);
|
71
|
+
} catch (error) {
|
72
|
+
this.error = error;
|
73
|
+
}
|
77
74
|
}
|
78
75
|
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
76
|
+
this.result = new _result2.default(processor, root, opts);
|
77
|
+
}
|
78
|
+
|
79
|
+
/**
|
80
|
+
* Returns a {@link Processor} instance, which will be used
|
81
|
+
* for CSS transformations.
|
82
|
+
*
|
83
|
+
* @type {Processor}
|
84
|
+
*/
|
85
|
+
|
86
|
+
|
87
|
+
/**
|
88
|
+
* Processes input CSS through synchronous plugins
|
89
|
+
* and calls {@link Result#warnings()}.
|
90
|
+
*
|
91
|
+
* @return {Warning[]} Warnings from plugins.
|
92
|
+
*/
|
93
|
+
LazyResult.prototype.warnings = function warnings() {
|
94
|
+
return this.sync().warnings();
|
95
|
+
};
|
96
|
+
|
97
|
+
/**
|
98
|
+
* Alias for the {@link LazyResult#css} property.
|
99
|
+
*
|
100
|
+
* @example
|
101
|
+
* lazy + '' === lazy.css
|
102
|
+
*
|
103
|
+
* @return {string} Output CSS.
|
104
|
+
*/
|
105
|
+
|
106
|
+
|
107
|
+
LazyResult.prototype.toString = function toString() {
|
108
|
+
return this.css;
|
109
|
+
};
|
110
|
+
|
111
|
+
/**
|
112
|
+
* Processes input CSS through synchronous and asynchronous plugins
|
113
|
+
* and calls `onFulfilled` with a Result instance. If a plugin throws
|
114
|
+
* an error, the `onRejected` callback will be executed.
|
115
|
+
*
|
116
|
+
* It implements standard Promise API.
|
117
|
+
*
|
118
|
+
* @param {onFulfilled} onFulfilled Callback will be executed
|
119
|
+
* when all plugins will finish work.
|
120
|
+
* @param {onRejected} onRejected Callback will be executed on any error.
|
121
|
+
*
|
122
|
+
* @return {Promise} Promise API to make queue.
|
123
|
+
*
|
124
|
+
* @example
|
125
|
+
* postcss([cssnext]).process(css, { from: cssPath }).then(result => {
|
126
|
+
* console.log(result.css)
|
127
|
+
* })
|
128
|
+
*/
|
129
|
+
|
130
|
+
|
131
|
+
LazyResult.prototype.then = function then(onFulfilled, onRejected) {
|
132
|
+
if (process.env.NODE_ENV !== 'production') {
|
133
|
+
if (!('from' in this.opts)) {
|
134
|
+
(0, _warnOnce2.default)('Without `from` option PostCSS could generate wrong source map ' + 'and will not find Browserslist config. Set it to CSS file path ' + 'or to `undefined` to prevent this warning.');
|
135
|
+
}
|
136
|
+
}
|
137
|
+
return this.async().then(onFulfilled, onRejected);
|
138
|
+
};
|
139
|
+
|
140
|
+
/**
|
141
|
+
* Processes input CSS through synchronous and asynchronous plugins
|
142
|
+
* and calls onRejected for each error thrown in any plugin.
|
143
|
+
*
|
144
|
+
* It implements standard Promise API.
|
145
|
+
*
|
146
|
+
* @param {onRejected} onRejected Callback will be executed on any error.
|
147
|
+
*
|
148
|
+
* @return {Promise} Promise API to make queue.
|
149
|
+
*
|
150
|
+
* @example
|
151
|
+
* postcss([cssnext]).process(css).then(result => {
|
152
|
+
* console.log(result.css)
|
153
|
+
* }).catch(error => {
|
154
|
+
* console.error(error)
|
155
|
+
* })
|
156
|
+
*/
|
157
|
+
|
158
|
+
|
159
|
+
LazyResult.prototype.catch = function _catch(onRejected) {
|
160
|
+
return this.async().catch(onRejected);
|
161
|
+
};
|
162
|
+
/**
|
163
|
+
* Processes input CSS through synchronous and asynchronous plugins
|
164
|
+
* and calls onFinally on any error or when all plugins will finish work.
|
165
|
+
*
|
166
|
+
* It implements standard Promise API.
|
167
|
+
*
|
168
|
+
* @param {onFinally} onFinally Callback will be executed on any error or
|
169
|
+
* when all plugins will finish work.
|
170
|
+
*
|
171
|
+
* @return {Promise} Promise API to make queue.
|
172
|
+
*
|
173
|
+
* @example
|
174
|
+
* postcss([cssnext]).process(css).finally(() => {
|
175
|
+
* console.log('processing ended')
|
176
|
+
* })
|
177
|
+
*/
|
178
|
+
|
179
|
+
|
180
|
+
LazyResult.prototype.finally = function _finally(onFinally) {
|
181
|
+
return this.async().then(onFinally, onFinally);
|
182
|
+
};
|
183
|
+
|
184
|
+
LazyResult.prototype.handleError = function handleError(error, plugin) {
|
185
|
+
try {
|
186
|
+
this.error = error;
|
187
|
+
if (error.name === 'CssSyntaxError' && !error.plugin) {
|
188
|
+
error.plugin = plugin.postcssPlugin;
|
189
|
+
error.setMessage();
|
190
|
+
} else if (plugin.postcssVersion) {
|
191
|
+
if (process.env.NODE_ENV !== 'production') {
|
192
|
+
var pluginName = plugin.postcssPlugin;
|
193
|
+
var pluginVer = plugin.postcssVersion;
|
194
|
+
var runtimeVer = this.result.processor.version;
|
195
|
+
var a = pluginVer.split('.');
|
196
|
+
var b = runtimeVer.split('.');
|
197
|
+
|
198
|
+
if (a[0] !== b[0] || parseInt(a[1]) > parseInt(b[1])) {
|
199
|
+
console.error('Unknown error from PostCSS plugin. Your current PostCSS ' + 'version is ' + runtimeVer + ', but ' + pluginName + ' uses ' + pluginVer + '. Perhaps this is the source of the error below.');
|
200
|
+
}
|
201
|
+
}
|
202
|
+
}
|
203
|
+
} catch (err) {
|
204
|
+
if (console && console.error) console.error(err);
|
205
|
+
}
|
206
|
+
};
|
104
207
|
|
208
|
+
LazyResult.prototype.asyncTick = function asyncTick(resolve, reject) {
|
209
|
+
var _this = this;
|
105
210
|
|
106
|
-
|
107
|
-
|
108
|
-
|
211
|
+
if (this.plugin >= this.processor.plugins.length) {
|
212
|
+
this.processed = true;
|
213
|
+
return resolve();
|
214
|
+
}
|
109
215
|
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
216
|
+
try {
|
217
|
+
var plugin = this.processor.plugins[this.plugin];
|
218
|
+
var promise = this.run(plugin);
|
219
|
+
this.plugin += 1;
|
220
|
+
|
221
|
+
if (isPromise(promise)) {
|
222
|
+
promise.then(function () {
|
223
|
+
_this.asyncTick(resolve, reject);
|
224
|
+
}).catch(function (error) {
|
225
|
+
_this.handleError(error, plugin);
|
226
|
+
_this.processed = true;
|
227
|
+
reject(error);
|
228
|
+
});
|
229
|
+
} else {
|
230
|
+
this.asyncTick(resolve, reject);
|
231
|
+
}
|
232
|
+
} catch (error) {
|
233
|
+
this.processed = true;
|
234
|
+
reject(error);
|
235
|
+
}
|
236
|
+
};
|
128
237
|
|
238
|
+
LazyResult.prototype.async = function async() {
|
239
|
+
var _this2 = this;
|
129
240
|
|
130
|
-
|
131
|
-
|
132
|
-
|
241
|
+
if (this.processed) {
|
242
|
+
return new Promise(function (resolve, reject) {
|
243
|
+
if (_this2.error) {
|
244
|
+
reject(_this2.error);
|
245
|
+
} else {
|
246
|
+
resolve(_this2.stringify());
|
133
247
|
}
|
134
|
-
|
135
|
-
}
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
* and calls onRejected for each error thrown in any plugin.
|
140
|
-
*
|
141
|
-
* It implements standard Promise API.
|
142
|
-
*
|
143
|
-
* @param {onRejected} onRejected - callback will be executed on any error
|
144
|
-
*
|
145
|
-
* @return {Promise} Promise API to make queue
|
146
|
-
*
|
147
|
-
* @example
|
148
|
-
* postcss([cssnext]).process(css).then(result => {
|
149
|
-
* console.log(result.css);
|
150
|
-
* }).catch(error => {
|
151
|
-
* console.error(error);
|
152
|
-
* });
|
153
|
-
*/
|
248
|
+
});
|
249
|
+
}
|
250
|
+
if (this.processing) {
|
251
|
+
return this.processing;
|
252
|
+
}
|
154
253
|
|
254
|
+
this.processing = new Promise(function (resolve, reject) {
|
255
|
+
if (_this2.error) return reject(_this2.error);
|
256
|
+
_this2.plugin = 0;
|
257
|
+
_this2.asyncTick(resolve, reject);
|
258
|
+
}).then(function () {
|
259
|
+
_this2.processed = true;
|
260
|
+
return _this2.stringify();
|
261
|
+
});
|
155
262
|
|
156
|
-
|
157
|
-
|
158
|
-
};
|
159
|
-
|
160
|
-
LazyResult.prototype.handleError = function handleError(error, plugin) {
|
161
|
-
try {
|
162
|
-
this.error = error;
|
163
|
-
if (error.name === 'CssSyntaxError' && !error.plugin) {
|
164
|
-
error.plugin = plugin.postcssPlugin;
|
165
|
-
error.setMessage();
|
166
|
-
} else if (plugin.postcssVersion) {
|
167
|
-
var pluginName = plugin.postcssPlugin;
|
168
|
-
var pluginVer = plugin.postcssVersion;
|
169
|
-
var runtimeVer = this.result.processor.version;
|
170
|
-
var a = pluginVer.split('.');
|
171
|
-
var b = runtimeVer.split('.');
|
172
|
-
|
173
|
-
if (a[0] !== b[0] || parseInt(a[1]) > parseInt(b[1])) {
|
174
|
-
console.error('Unknown error from PostCSS plugin. ' + 'Your current PostCSS version ' + 'is ' + runtimeVer + ', but ' + pluginName + ' ' + 'uses ' + pluginVer + '. Perhaps this is ' + 'the source of the error below.');
|
175
|
-
}
|
176
|
-
}
|
177
|
-
} catch (err) {
|
178
|
-
if (console && console.error) console.error(err);
|
179
|
-
}
|
180
|
-
};
|
263
|
+
return this.processing;
|
264
|
+
};
|
181
265
|
|
182
|
-
|
183
|
-
|
266
|
+
LazyResult.prototype.sync = function sync() {
|
267
|
+
if (this.processed) return this.result;
|
268
|
+
this.processed = true;
|
184
269
|
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
}
|
270
|
+
if (this.processing) {
|
271
|
+
throw new Error('Use process(css).then(cb) to work with async plugins');
|
272
|
+
}
|
189
273
|
|
190
|
-
|
191
|
-
var plugin = this.processor.plugins[this.plugin];
|
192
|
-
var promise = this.run(plugin);
|
193
|
-
this.plugin += 1;
|
194
|
-
|
195
|
-
if (isPromise(promise)) {
|
196
|
-
promise.then(function () {
|
197
|
-
_this.asyncTick(resolve, reject);
|
198
|
-
}).catch(function (error) {
|
199
|
-
_this.handleError(error, plugin);
|
200
|
-
_this.processed = true;
|
201
|
-
reject(error);
|
202
|
-
});
|
203
|
-
} else {
|
204
|
-
this.asyncTick(resolve, reject);
|
205
|
-
}
|
206
|
-
} catch (error) {
|
207
|
-
this.processed = true;
|
208
|
-
reject(error);
|
209
|
-
}
|
210
|
-
};
|
211
|
-
|
212
|
-
LazyResult.prototype.async = function async() {
|
213
|
-
var _this2 = this;
|
214
|
-
|
215
|
-
if (this.processed) {
|
216
|
-
return new Promise(function (resolve, reject) {
|
217
|
-
if (_this2.error) {
|
218
|
-
reject(_this2.error);
|
219
|
-
} else {
|
220
|
-
resolve(_this2.stringify());
|
221
|
-
}
|
222
|
-
});
|
223
|
-
}
|
224
|
-
if (this.processing) {
|
225
|
-
return this.processing;
|
226
|
-
}
|
274
|
+
if (this.error) throw this.error;
|
227
275
|
|
228
|
-
|
229
|
-
|
230
|
-
_this2.plugin = 0;
|
231
|
-
_this2.asyncTick(resolve, reject);
|
232
|
-
}).then(function () {
|
233
|
-
_this2.processed = true;
|
234
|
-
return _this2.stringify();
|
235
|
-
});
|
276
|
+
for (var _iterator = this.result.processor.plugins, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
|
277
|
+
var _ref;
|
236
278
|
|
237
|
-
|
238
|
-
|
279
|
+
if (_isArray) {
|
280
|
+
if (_i >= _iterator.length) break;
|
281
|
+
_ref = _iterator[_i++];
|
282
|
+
} else {
|
283
|
+
_i = _iterator.next();
|
284
|
+
if (_i.done) break;
|
285
|
+
_ref = _i.value;
|
286
|
+
}
|
239
287
|
|
240
|
-
|
241
|
-
if (this.processed) return this.result;
|
242
|
-
this.processed = true;
|
288
|
+
var plugin = _ref;
|
243
289
|
|
244
|
-
|
245
|
-
|
246
|
-
|
290
|
+
var promise = this.run(plugin);
|
291
|
+
if (isPromise(promise)) {
|
292
|
+
throw new Error('Use process(css).then(cb) to work with async plugins');
|
293
|
+
}
|
294
|
+
}
|
247
295
|
|
248
|
-
|
296
|
+
return this.result;
|
297
|
+
};
|
249
298
|
|
250
|
-
|
251
|
-
|
299
|
+
LazyResult.prototype.run = function run(plugin) {
|
300
|
+
this.result.lastPlugin = plugin;
|
252
301
|
|
253
|
-
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
}
|
302
|
+
try {
|
303
|
+
return plugin(this.result.root, this.result);
|
304
|
+
} catch (error) {
|
305
|
+
this.handleError(error, plugin);
|
306
|
+
throw error;
|
307
|
+
}
|
308
|
+
};
|
261
309
|
|
262
|
-
|
310
|
+
LazyResult.prototype.stringify = function stringify() {
|
311
|
+
if (this.stringified) return this.result;
|
312
|
+
this.stringified = true;
|
263
313
|
|
264
|
-
|
265
|
-
if (isPromise(promise)) {
|
266
|
-
throw new Error('Use process(css).then(cb) to work with async plugins');
|
267
|
-
}
|
268
|
-
}
|
314
|
+
this.sync();
|
269
315
|
|
270
|
-
|
271
|
-
|
316
|
+
var opts = this.result.opts;
|
317
|
+
var str = _stringify3.default;
|
318
|
+
if (opts.syntax) str = opts.syntax.stringify;
|
319
|
+
if (opts.stringifier) str = opts.stringifier;
|
320
|
+
if (str.stringify) str = str.stringify;
|
272
321
|
|
273
|
-
|
274
|
-
|
322
|
+
var map = new _mapGenerator2.default(str, this.result.root, this.result.opts);
|
323
|
+
var data = map.generate();
|
324
|
+
this.result.css = data[0];
|
325
|
+
this.result.map = data[1];
|
275
326
|
|
276
|
-
|
277
|
-
|
278
|
-
} catch (error) {
|
279
|
-
this.handleError(error, plugin);
|
280
|
-
throw error;
|
281
|
-
}
|
282
|
-
};
|
327
|
+
return this.result;
|
328
|
+
};
|
283
329
|
|
284
|
-
|
285
|
-
|
286
|
-
|
330
|
+
_createClass(LazyResult, [{
|
331
|
+
key: 'processor',
|
332
|
+
get: function get() {
|
333
|
+
return this.result.processor;
|
334
|
+
}
|
287
335
|
|
288
|
-
|
336
|
+
/**
|
337
|
+
* Options from the {@link Processor#process} call.
|
338
|
+
*
|
339
|
+
* @type {processOptions}
|
340
|
+
*/
|
289
341
|
|
290
|
-
|
291
|
-
|
292
|
-
|
293
|
-
|
294
|
-
|
342
|
+
}, {
|
343
|
+
key: 'opts',
|
344
|
+
get: function get() {
|
345
|
+
return this.result.opts;
|
346
|
+
}
|
295
347
|
|
296
|
-
|
297
|
-
|
298
|
-
|
299
|
-
|
348
|
+
/**
|
349
|
+
* Processes input CSS through synchronous plugins, converts `Root`
|
350
|
+
* to a CSS string and returns {@link Result#css}.
|
351
|
+
*
|
352
|
+
* This property will only work with synchronous plugins.
|
353
|
+
* If the processor contains any asynchronous plugins
|
354
|
+
* it will throw an error. This is why this method is only
|
355
|
+
* for debug purpose, you should always use {@link LazyResult#then}.
|
356
|
+
*
|
357
|
+
* @type {string}
|
358
|
+
* @see Result#css
|
359
|
+
*/
|
300
360
|
|
301
|
-
|
302
|
-
|
361
|
+
}, {
|
362
|
+
key: 'css',
|
363
|
+
get: function get() {
|
364
|
+
return this.stringify().css;
|
365
|
+
}
|
303
366
|
|
304
|
-
|
305
|
-
|
306
|
-
|
307
|
-
|
308
|
-
|
367
|
+
/**
|
368
|
+
* An alias for the `css` property. Use it with syntaxes
|
369
|
+
* that generate non-CSS output.
|
370
|
+
*
|
371
|
+
* This property will only work with synchronous plugins.
|
372
|
+
* If the processor contains any asynchronous plugins
|
373
|
+
* it will throw an error. This is why this method is only
|
374
|
+
* for debug purpose, you should always use {@link LazyResult#then}.
|
375
|
+
*
|
376
|
+
* @type {string}
|
377
|
+
* @see Result#content
|
378
|
+
*/
|
309
379
|
|
310
|
-
|
311
|
-
|
312
|
-
|
313
|
-
|
380
|
+
}, {
|
381
|
+
key: 'content',
|
382
|
+
get: function get() {
|
383
|
+
return this.stringify().content;
|
384
|
+
}
|
314
385
|
|
315
|
-
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
|
386
|
+
/**
|
387
|
+
* Processes input CSS through synchronous plugins
|
388
|
+
* and returns {@link Result#map}.
|
389
|
+
*
|
390
|
+
* This property will only work with synchronous plugins.
|
391
|
+
* If the processor contains any asynchronous plugins
|
392
|
+
* it will throw an error. This is why this method is only
|
393
|
+
* for debug purpose, you should always use {@link LazyResult#then}.
|
394
|
+
*
|
395
|
+
* @type {SourceMapGenerator}
|
396
|
+
* @see Result#map
|
397
|
+
*/
|
320
398
|
|
321
|
-
|
322
|
-
|
323
|
-
|
324
|
-
|
325
|
-
|
326
|
-
* If the processor contains any asynchronous plugins
|
327
|
-
* it will throw an error. This is why this method is only
|
328
|
-
* for debug purpose, you should always use {@link LazyResult#then}.
|
329
|
-
*
|
330
|
-
* @type {string}
|
331
|
-
* @see Result#css
|
332
|
-
*/
|
333
|
-
|
334
|
-
}, {
|
335
|
-
key: 'css',
|
336
|
-
get: function get() {
|
337
|
-
return this.stringify().css;
|
338
|
-
}
|
399
|
+
}, {
|
400
|
+
key: 'map',
|
401
|
+
get: function get() {
|
402
|
+
return this.stringify().map;
|
403
|
+
}
|
339
404
|
|
340
|
-
|
341
|
-
|
342
|
-
|
343
|
-
|
344
|
-
|
345
|
-
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
353
|
-
}, {
|
354
|
-
key: 'content',
|
355
|
-
get: function get() {
|
356
|
-
return this.stringify().content;
|
357
|
-
}
|
405
|
+
/**
|
406
|
+
* Processes input CSS through synchronous plugins
|
407
|
+
* and returns {@link Result#root}.
|
408
|
+
*
|
409
|
+
* This property will only work with synchronous plugins. If the processor
|
410
|
+
* contains any asynchronous plugins it will throw an error.
|
411
|
+
*
|
412
|
+
* This is why this method is only for debug purpose,
|
413
|
+
* you should always use {@link LazyResult#then}.
|
414
|
+
*
|
415
|
+
* @type {Root}
|
416
|
+
* @see Result#root
|
417
|
+
*/
|
358
418
|
|
359
|
-
|
360
|
-
|
361
|
-
|
362
|
-
|
363
|
-
|
364
|
-
* If the processor contains any asynchronous plugins
|
365
|
-
* it will throw an error. This is why this method is only
|
366
|
-
* for debug purpose, you should always use {@link LazyResult#then}.
|
367
|
-
*
|
368
|
-
* @type {SourceMapGenerator}
|
369
|
-
* @see Result#map
|
370
|
-
*/
|
371
|
-
|
372
|
-
}, {
|
373
|
-
key: 'map',
|
374
|
-
get: function get() {
|
375
|
-
return this.stringify().map;
|
376
|
-
}
|
419
|
+
}, {
|
420
|
+
key: 'root',
|
421
|
+
get: function get() {
|
422
|
+
return this.sync().root;
|
423
|
+
}
|
377
424
|
|
378
|
-
|
379
|
-
|
380
|
-
|
381
|
-
|
382
|
-
|
383
|
-
|
384
|
-
|
385
|
-
|
386
|
-
|
387
|
-
|
388
|
-
|
389
|
-
|
390
|
-
|
391
|
-
|
392
|
-
}, {
|
393
|
-
key: 'root',
|
394
|
-
get: function get() {
|
395
|
-
return this.sync().root;
|
396
|
-
}
|
425
|
+
/**
|
426
|
+
* Processes input CSS through synchronous plugins
|
427
|
+
* and returns {@link Result#messages}.
|
428
|
+
*
|
429
|
+
* This property will only work with synchronous plugins. If the processor
|
430
|
+
* contains any asynchronous plugins it will throw an error.
|
431
|
+
*
|
432
|
+
* This is why this method is only for debug purpose,
|
433
|
+
* you should always use {@link LazyResult#then}.
|
434
|
+
*
|
435
|
+
* @type {Message[]}
|
436
|
+
* @see Result#messages
|
437
|
+
*/
|
397
438
|
|
398
|
-
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
*
|
405
|
-
* This is why this method is only for debug purpose,
|
406
|
-
* you should always use {@link LazyResult#then}.
|
407
|
-
*
|
408
|
-
* @type {Message[]}
|
409
|
-
* @see Result#messages
|
410
|
-
*/
|
411
|
-
|
412
|
-
}, {
|
413
|
-
key: 'messages',
|
414
|
-
get: function get() {
|
415
|
-
return this.sync().messages;
|
416
|
-
}
|
417
|
-
}]);
|
439
|
+
}, {
|
440
|
+
key: 'messages',
|
441
|
+
get: function get() {
|
442
|
+
return this.sync().messages;
|
443
|
+
}
|
444
|
+
}]);
|
418
445
|
|
419
|
-
|
446
|
+
return LazyResult;
|
420
447
|
}();
|
421
448
|
|
422
449
|
exports.default = LazyResult;
|
@@ -432,4 +459,4 @@ exports.default = LazyResult;
|
|
432
459
|
*/
|
433
460
|
|
434
461
|
module.exports = exports['default'];
|
435
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lazy-result.es6"],"names":["isPromise","obj","then","LazyResult","processor","css","opts","stringified","processed","root","type","Result","map","inline","prev","parser","parse","syntax","error","result","warnings","sync","toString","onFulfilled","onRejected","async","catch","handleError","plugin","name","postcssPlugin","setMessage","postcssVersion","pluginName","pluginVer","runtimeVer","version","a","split","b","parseInt","console","err","asyncTick","resolve","reject","plugins","length","promise","run","Promise","stringify","processing","Error","lastPlugin","str","stringifier","MapGenerator","data","generate","content","messages"],"mappings":"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","file":"lazy-result.js","sourcesContent":["import MapGenerator from './map-generator';\nimport stringify    from './stringify';\nimport warnOnce     from './warn-once';\nimport Result       from './result';\nimport parse        from './parse';\n\nfunction isPromise(obj) {\n    return typeof obj === 'object' && typeof obj.then === 'function';\n}\n\n/**\n * A Promise proxy for the result of PostCSS transformations.\n *\n * A `LazyResult` instance is returned by {@link Processor#process}.\n *\n * @example\n * const lazy = postcss([cssnext]).process(css);\n */\nclass LazyResult {\n\n    constructor(processor, css, opts) {\n        this.stringified = false;\n        this.processed   = false;\n\n        let root;\n        if ( typeof css === 'object' && css !== null && css.type === 'root' ) {\n            root = css;\n        } else if ( css instanceof LazyResult || css instanceof Result ) {\n            root = css.root;\n            if ( css.map ) {\n                if ( typeof opts.map === 'undefined' ) opts.map = { };\n                if ( !opts.map.inline ) opts.map.inline = false;\n                opts.map.prev = css.map;\n            }\n        } else {\n            let parser = parse;\n            if ( opts.syntax )  parser = opts.syntax.parse;\n            if ( opts.parser )  parser = opts.parser;\n            if ( parser.parse ) parser = parser.parse;\n\n            try {\n                root = parser(css, opts);\n            } catch (error) {\n                this.error = error;\n            }\n        }\n\n        this.result = new Result(processor, root, opts);\n    }\n\n    /**\n     * Returns a {@link Processor} instance, which will be used\n     * for CSS transformations.\n     * @type {Processor}\n     */\n    get processor() {\n        return this.result.processor;\n    }\n\n    /**\n     * Options from the {@link Processor#process} call.\n     * @type {processOptions}\n     */\n    get opts() {\n        return this.result.opts;\n    }\n\n    /**\n     * Processes input CSS through synchronous plugins, converts `Root`\n     * to a CSS string and returns {@link Result#css}.\n     *\n     * This property will only work with synchronous plugins.\n     * If the processor contains any asynchronous plugins\n     * it will throw an error. This is why this method is only\n     * for debug purpose, you should always use {@link LazyResult#then}.\n     *\n     * @type {string}\n     * @see Result#css\n     */\n    get css() {\n        return this.stringify().css;\n    }\n\n    /**\n     * An alias for the `css` property. Use it with syntaxes\n     * that generate non-CSS output.\n     *\n     * This property will only work with synchronous plugins.\n     * If the processor contains any asynchronous plugins\n     * it will throw an error. This is why this method is only\n     * for debug purpose, you should always use {@link LazyResult#then}.\n     *\n     * @type {string}\n     * @see Result#content\n     */\n    get content() {\n        return this.stringify().content;\n    }\n\n    /**\n     * Processes input CSS through synchronous plugins\n     * and returns {@link Result#map}.\n     *\n     * This property will only work with synchronous plugins.\n     * If the processor contains any asynchronous plugins\n     * it will throw an error. This is why this method is only\n     * for debug purpose, you should always use {@link LazyResult#then}.\n     *\n     * @type {SourceMapGenerator}\n     * @see Result#map\n     */\n    get map() {\n        return this.stringify().map;\n    }\n\n    /**\n     * Processes input CSS through synchronous plugins\n     * and returns {@link Result#root}.\n     *\n     * This property will only work with synchronous plugins. If the processor\n     * contains any asynchronous plugins it will throw an error.\n     *\n     * This is why this method is only for debug purpose,\n     * you should always use {@link LazyResult#then}.\n     *\n     * @type {Root}\n     * @see Result#root\n     */\n    get root() {\n        return this.sync().root;\n    }\n\n    /**\n     * Processes input CSS through synchronous plugins\n     * and returns {@link Result#messages}.\n     *\n     * This property will only work with synchronous plugins. If the processor\n     * contains any asynchronous plugins it will throw an error.\n     *\n     * This is why this method is only for debug purpose,\n     * you should always use {@link LazyResult#then}.\n     *\n     * @type {Message[]}\n     * @see Result#messages\n     */\n    get messages() {\n        return this.sync().messages;\n    }\n\n    /**\n     * Processes input CSS through synchronous plugins\n     * and calls {@link Result#warnings()}.\n     *\n     * @return {Warning[]} warnings from plugins\n     */\n    warnings() {\n        return this.sync().warnings();\n    }\n\n    /**\n     * Alias for the {@link LazyResult#css} property.\n     *\n     * @example\n     * lazy + '' === lazy.css;\n     *\n     * @return {string} output CSS\n     */\n    toString() {\n        return this.css;\n    }\n\n    /**\n     * Processes input CSS through synchronous and asynchronous plugins\n     * and calls `onFulfilled` with a Result instance. If a plugin throws\n     * an error, the `onRejected` callback will be executed.\n     *\n     * It implements standard Promise API.\n     *\n     * @param {onFulfilled} onFulfilled - callback will be executed\n     *                                    when all plugins will finish work\n     * @param {onRejected}  onRejected  - callback will be executed on any error\n     *\n     * @return {Promise} Promise API to make queue\n     *\n     * @example\n     * postcss([cssnext]).process(css, { from: cssPath }).then(result => {\n     *   console.log(result.css);\n     * });\n     */\n    then(onFulfilled, onRejected) {\n        if (!('from' in this.opts)) {\n            warnOnce(\n                'Without `from` option PostCSS could generate wrong ' +\n                'source map and will not find Browserslist config. ' +\n                'Set it to CSS file path or to `undefined` to prevent ' +\n                'this warning.'\n            );\n        }\n        return this.async().then(onFulfilled, onRejected);\n    }\n\n    /**\n     * Processes input CSS through synchronous and asynchronous plugins\n     * and calls onRejected for each error thrown in any plugin.\n     *\n     * It implements standard Promise API.\n     *\n     * @param {onRejected} onRejected - callback will be executed on any error\n     *\n     * @return {Promise} Promise API to make queue\n     *\n     * @example\n     * postcss([cssnext]).process(css).then(result => {\n     *   console.log(result.css);\n     * }).catch(error => {\n     *   console.error(error);\n     * });\n     */\n    catch(onRejected) {\n        return this.async().catch(onRejected);\n    }\n\n    handleError(error, plugin) {\n        try {\n            this.error = error;\n            if ( error.name === 'CssSyntaxError' && !error.plugin ) {\n                error.plugin = plugin.postcssPlugin;\n                error.setMessage();\n            } else if ( plugin.postcssVersion ) {\n                let pluginName = plugin.postcssPlugin;\n                let pluginVer  = plugin.postcssVersion;\n                let runtimeVer = this.result.processor.version;\n                let a = pluginVer.split('.');\n                let b = runtimeVer.split('.');\n\n                if ( a[0] !== b[0] || parseInt(a[1]) > parseInt(b[1]) ) {\n                    console.error(\n                        'Unknown error from PostCSS plugin. ' +\n                        'Your current PostCSS version ' +\n                        'is ' + runtimeVer + ', but ' + pluginName + ' ' +\n                        'uses ' + pluginVer + '. Perhaps this is ' +\n                        'the source of the error below.');\n                }\n            }\n        } catch (err) {\n            if ( console && console.error ) console.error(err);\n        }\n    }\n\n    asyncTick(resolve, reject) {\n        if ( this.plugin >= this.processor.plugins.length ) {\n            this.processed = true;\n            return resolve();\n        }\n\n        try {\n            let plugin  = this.processor.plugins[this.plugin];\n            let promise = this.run(plugin);\n            this.plugin += 1;\n\n            if ( isPromise(promise) ) {\n                promise.then( () => {\n                    this.asyncTick(resolve, reject);\n                }).catch( error => {\n                    this.handleError(error, plugin);\n                    this.processed = true;\n                    reject(error);\n                });\n            } else {\n                this.asyncTick(resolve, reject);\n            }\n\n        } catch (error) {\n            this.processed = true;\n            reject(error);\n        }\n    }\n\n    async() {\n        if ( this.processed ) {\n            return new Promise( (resolve, reject) => {\n                if ( this.error ) {\n                    reject(this.error);\n                } else {\n                    resolve(this.stringify());\n                }\n            });\n        }\n        if ( this.processing ) {\n            return this.processing;\n        }\n\n        this.processing = new Promise( (resolve, reject) => {\n            if ( this.error ) return reject(this.error);\n            this.plugin = 0;\n            this.asyncTick(resolve, reject);\n        }).then( () => {\n            this.processed = true;\n            return this.stringify();\n        });\n\n        return this.processing;\n    }\n\n    sync() {\n        if ( this.processed ) return this.result;\n        this.processed = true;\n\n        if ( this.processing ) {\n            throw new Error(\n                'Use process(css).then(cb) to work with async plugins');\n        }\n\n        if ( this.error ) throw this.error;\n\n        for ( let plugin of this.result.processor.plugins ) {\n            let promise = this.run(plugin);\n            if ( isPromise(promise) ) {\n                throw new Error(\n                    'Use process(css).then(cb) to work with async plugins');\n            }\n        }\n\n        return this.result;\n    }\n\n    run(plugin) {\n        this.result.lastPlugin = plugin;\n\n        try {\n            return plugin(this.result.root, this.result);\n        } catch (error) {\n            this.handleError(error, plugin);\n            throw error;\n        }\n    }\n\n    stringify() {\n        if ( this.stringified ) return this.result;\n        this.stringified = true;\n\n        this.sync();\n\n        let opts = this.result.opts;\n        let str  = stringify;\n        if ( opts.syntax )      str = opts.syntax.stringify;\n        if ( opts.stringifier ) str = opts.stringifier;\n        if ( str.stringify )    str = str.stringify;\n\n        let map  = new MapGenerator(str, this.result.root, this.result.opts);\n        let data = map.generate();\n        this.result.css = data[0];\n        this.result.map = data[1];\n\n        return this.result;\n    }\n\n}\n\nexport default LazyResult;\n\n/**\n * @callback onFulfilled\n * @param {Result} result\n */\n\n/**\n * @callback onRejected\n * @param {Error} error\n */\n"]}
|
462
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lazy-result.es6"],"names":["isPromise","obj","then","LazyResult","processor","css","opts","stringified","processed","root","type","Result","map","inline","prev","parser","parse","syntax","error","result","warnings","sync","toString","onFulfilled","onRejected","process","env","NODE_ENV","async","catch","finally","onFinally","handleError","plugin","name","postcssPlugin","setMessage","postcssVersion","pluginName","pluginVer","runtimeVer","version","a","split","b","parseInt","console","err","asyncTick","resolve","reject","plugins","length","promise","run","Promise","stringify","processing","Error","lastPlugin","str","stringifier","MapGenerator","data","generate","content","messages"],"mappings":"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","file":"lazy-result.js","sourcesContent":["import MapGenerator from './map-generator'\nimport stringify from './stringify'\nimport warnOnce from './warn-once'\nimport Result from './result'\nimport parse from './parse'\n\nfunction isPromise (obj) {\n  return typeof obj === 'object' && typeof obj.then === 'function'\n}\n\n/**\n * A Promise proxy for the result of PostCSS transformations.\n *\n * A `LazyResult` instance is returned by {@link Processor#process}.\n *\n * @example\n * const lazy = postcss([cssnext]).process(css)\n */\nclass LazyResult {\n  constructor (processor, css, opts) {\n    this.stringified = false\n    this.processed = false\n\n    let root\n    if (typeof css === 'object' && css !== null && css.type === 'root') {\n      root = css\n    } else if (css instanceof LazyResult || css instanceof Result) {\n      root = css.root\n      if (css.map) {\n        if (typeof opts.map === 'undefined') opts.map = { }\n        if (!opts.map.inline) opts.map.inline = false\n        opts.map.prev = css.map\n      }\n    } else {\n      let parser = parse\n      if (opts.syntax) parser = opts.syntax.parse\n      if (opts.parser) parser = opts.parser\n      if (parser.parse) parser = parser.parse\n\n      try {\n        root = parser(css, opts)\n      } catch (error) {\n        this.error = error\n      }\n    }\n\n    this.result = new Result(processor, root, opts)\n  }\n\n  /**\n   * Returns a {@link Processor} instance, which will be used\n   * for CSS transformations.\n   *\n   * @type {Processor}\n   */\n  get processor () {\n    return this.result.processor\n  }\n\n  /**\n   * Options from the {@link Processor#process} call.\n   *\n   * @type {processOptions}\n   */\n  get opts () {\n    return this.result.opts\n  }\n\n  /**\n   * Processes input CSS through synchronous plugins, converts `Root`\n   * to a CSS string and returns {@link Result#css}.\n   *\n   * This property will only work with synchronous plugins.\n   * If the processor contains any asynchronous plugins\n   * it will throw an error. This is why this method is only\n   * for debug purpose, you should always use {@link LazyResult#then}.\n   *\n   * @type {string}\n   * @see Result#css\n   */\n  get css () {\n    return this.stringify().css\n  }\n\n  /**\n   * An alias for the `css` property. Use it with syntaxes\n   * that generate non-CSS output.\n   *\n   * This property will only work with synchronous plugins.\n   * If the processor contains any asynchronous plugins\n   * it will throw an error. This is why this method is only\n   * for debug purpose, you should always use {@link LazyResult#then}.\n   *\n   * @type {string}\n   * @see Result#content\n   */\n  get content () {\n    return this.stringify().content\n  }\n\n  /**\n   * Processes input CSS through synchronous plugins\n   * and returns {@link Result#map}.\n   *\n   * This property will only work with synchronous plugins.\n   * If the processor contains any asynchronous plugins\n   * it will throw an error. This is why this method is only\n   * for debug purpose, you should always use {@link LazyResult#then}.\n   *\n   * @type {SourceMapGenerator}\n   * @see Result#map\n   */\n  get map () {\n    return this.stringify().map\n  }\n\n  /**\n   * Processes input CSS through synchronous plugins\n   * and returns {@link Result#root}.\n   *\n   * This property will only work with synchronous plugins. If the processor\n   * contains any asynchronous plugins it will throw an error.\n   *\n   * This is why this method is only for debug purpose,\n   * you should always use {@link LazyResult#then}.\n   *\n   * @type {Root}\n   * @see Result#root\n   */\n  get root () {\n    return this.sync().root\n  }\n\n  /**\n   * Processes input CSS through synchronous plugins\n   * and returns {@link Result#messages}.\n   *\n   * This property will only work with synchronous plugins. If the processor\n   * contains any asynchronous plugins it will throw an error.\n   *\n   * This is why this method is only for debug purpose,\n   * you should always use {@link LazyResult#then}.\n   *\n   * @type {Message[]}\n   * @see Result#messages\n   */\n  get messages () {\n    return this.sync().messages\n  }\n\n  /**\n   * Processes input CSS through synchronous plugins\n   * and calls {@link Result#warnings()}.\n   *\n   * @return {Warning[]} Warnings from plugins.\n   */\n  warnings () {\n    return this.sync().warnings()\n  }\n\n  /**\n   * Alias for the {@link LazyResult#css} property.\n   *\n   * @example\n   * lazy + '' === lazy.css\n   *\n   * @return {string} Output CSS.\n   */\n  toString () {\n    return this.css\n  }\n\n  /**\n   * Processes input CSS through synchronous and asynchronous plugins\n   * and calls `onFulfilled` with a Result instance. If a plugin throws\n   * an error, the `onRejected` callback will be executed.\n   *\n   * It implements standard Promise API.\n   *\n   * @param {onFulfilled} onFulfilled Callback will be executed\n   *                                  when all plugins will finish work.\n   * @param {onRejected}  onRejected  Callback will be executed on any error.\n   *\n   * @return {Promise} Promise API to make queue.\n   *\n   * @example\n   * postcss([cssnext]).process(css, { from: cssPath }).then(result => {\n   *   console.log(result.css)\n   * })\n   */\n  then (onFulfilled, onRejected) {\n    if (process.env.NODE_ENV !== 'production') {\n      if (!('from' in this.opts)) {\n        warnOnce(\n          'Without `from` option PostCSS could generate wrong source map ' +\n          'and will not find Browserslist config. Set it to CSS file path ' +\n          'or to `undefined` to prevent this warning.'\n        )\n      }\n    }\n    return this.async().then(onFulfilled, onRejected)\n  }\n\n  /**\n   * Processes input CSS through synchronous and asynchronous plugins\n   * and calls onRejected for each error thrown in any plugin.\n   *\n   * It implements standard Promise API.\n   *\n   * @param {onRejected} onRejected Callback will be executed on any error.\n   *\n   * @return {Promise} Promise API to make queue.\n   *\n   * @example\n   * postcss([cssnext]).process(css).then(result => {\n   *   console.log(result.css)\n   * }).catch(error => {\n   *   console.error(error)\n   * })\n   */\n  catch (onRejected) {\n    return this.async().catch(onRejected)\n  }\n  /**\n   * Processes input CSS through synchronous and asynchronous plugins\n   * and calls onFinally on any error or when all plugins will finish work.\n   *\n   * It implements standard Promise API.\n   *\n   * @param {onFinally} onFinally Callback will be executed on any error or\n   *                              when all plugins will finish work.\n   *\n   * @return {Promise} Promise API to make queue.\n   *\n   * @example\n   * postcss([cssnext]).process(css).finally(() => {\n   *   console.log('processing ended')\n   * })\n   */\n  finally (onFinally) {\n    return this.async().then(onFinally, onFinally)\n  }\n\n  handleError (error, plugin) {\n    try {\n      this.error = error\n      if (error.name === 'CssSyntaxError' && !error.plugin) {\n        error.plugin = plugin.postcssPlugin\n        error.setMessage()\n      } else if (plugin.postcssVersion) {\n        if (process.env.NODE_ENV !== 'production') {\n          let pluginName = plugin.postcssPlugin\n          let pluginVer = plugin.postcssVersion\n          let runtimeVer = this.result.processor.version\n          let a = pluginVer.split('.')\n          let b = runtimeVer.split('.')\n\n          if (a[0] !== b[0] || parseInt(a[1]) > parseInt(b[1])) {\n            console.error(\n              'Unknown error from PostCSS plugin. Your current PostCSS ' +\n              'version is ' + runtimeVer + ', but ' + pluginName + ' uses ' +\n              pluginVer + '. Perhaps this is the source of the error below.'\n            )\n          }\n        }\n      }\n    } catch (err) {\n      if (console && console.error) console.error(err)\n    }\n  }\n\n  asyncTick (resolve, reject) {\n    if (this.plugin >= this.processor.plugins.length) {\n      this.processed = true\n      return resolve()\n    }\n\n    try {\n      let plugin = this.processor.plugins[this.plugin]\n      let promise = this.run(plugin)\n      this.plugin += 1\n\n      if (isPromise(promise)) {\n        promise.then(() => {\n          this.asyncTick(resolve, reject)\n        }).catch(error => {\n          this.handleError(error, plugin)\n          this.processed = true\n          reject(error)\n        })\n      } else {\n        this.asyncTick(resolve, reject)\n      }\n    } catch (error) {\n      this.processed = true\n      reject(error)\n    }\n  }\n\n  async () {\n    if (this.processed) {\n      return new Promise((resolve, reject) => {\n        if (this.error) {\n          reject(this.error)\n        } else {\n          resolve(this.stringify())\n        }\n      })\n    }\n    if (this.processing) {\n      return this.processing\n    }\n\n    this.processing = new Promise((resolve, reject) => {\n      if (this.error) return reject(this.error)\n      this.plugin = 0\n      this.asyncTick(resolve, reject)\n    }).then(() => {\n      this.processed = true\n      return this.stringify()\n    })\n\n    return this.processing\n  }\n\n  sync () {\n    if (this.processed) return this.result\n    this.processed = true\n\n    if (this.processing) {\n      throw new Error(\n        'Use process(css).then(cb) to work with async plugins')\n    }\n\n    if (this.error) throw this.error\n\n    for (let plugin of this.result.processor.plugins) {\n      let promise = this.run(plugin)\n      if (isPromise(promise)) {\n        throw new Error(\n          'Use process(css).then(cb) to work with async plugins')\n      }\n    }\n\n    return this.result\n  }\n\n  run (plugin) {\n    this.result.lastPlugin = plugin\n\n    try {\n      return plugin(this.result.root, this.result)\n    } catch (error) {\n      this.handleError(error, plugin)\n      throw error\n    }\n  }\n\n  stringify () {\n    if (this.stringified) return this.result\n    this.stringified = true\n\n    this.sync()\n\n    let opts = this.result.opts\n    let str = stringify\n    if (opts.syntax) str = opts.syntax.stringify\n    if (opts.stringifier) str = opts.stringifier\n    if (str.stringify) str = str.stringify\n\n    let map = new MapGenerator(str, this.result.root, this.result.opts)\n    let data = map.generate()\n    this.result.css = data[0]\n    this.result.map = data[1]\n\n    return this.result\n  }\n}\n\nexport default LazyResult\n\n/**\n * @callback onFulfilled\n * @param {Result} result\n */\n\n/**\n * @callback onRejected\n * @param {Error} error\n */\n"]}
|