postcss 7.0.38 → 7.0.39

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/README.md CHANGED
@@ -39,453 +39,5 @@ at <surrender@evilmartians.com>.
39
39
  alt="Sponsored by Evil Martians" width="236" height="54">
40
40
  </a>
41
41
 
42
- ## Sponsorship
43
-
44
- PostCSS needs your support. We are accepting donations
45
- [at Open Collective](https://opencollective.com/postcss/).
46
-
47
- <a href="https://tailwindcss.com/">
48
- <img src="https://refactoringui.nyc3.cdn.digitaloceanspaces.com/tailwind-logo.svg"
49
- alt="Sponsored by Tailwind CSS" width="273" height="64">
50
- </a>
51
-
52
- ## Plugins
53
-
54
- Currently, PostCSS has more than 200 plugins. You can find all of the plugins
55
- in the [plugins list] or in the [searchable catalog]. Below is a list
56
- of our favorite plugins — the best demonstrations of what can be built
57
- on top of PostCSS.
58
-
59
- If you have any new ideas, [PostCSS plugin development] is really easy.
60
-
61
- [searchable catalog]: http://postcss.parts
62
- [plugins list]: https://github.com/postcss/postcss/blob/master/docs/plugins.md
63
-
64
- ### Solve Global CSS Problem
65
-
66
- * [`postcss-use`] allows you to explicitly set PostCSS plugins within CSS
67
- and execute them only for the current file.
68
- * [`postcss-modules`] and [`react-css-modules`] automatically isolate
69
- selectors within components.
70
- * [`postcss-autoreset`] is an alternative to using a global reset
71
- that is better for isolatable components.
72
- * [`postcss-initial`] adds `all: initial` support, which resets
73
- all inherited styles.
74
- * [`cq-prolyfill`] adds container query support, allowing styles that respond
75
- to the width of the parent.
76
-
77
- ### Use Future CSS, Today
78
-
79
- * [`autoprefixer`] adds vendor prefixes, using data from Can I Use.
80
- * [`postcss-preset-env`] allows you to use future CSS features today.
81
-
82
- ### Better CSS Readability
83
-
84
- * [`precss`] contains plugins for Sass-like features, like variables, nesting,
85
- and mixins.
86
- * [`postcss-sorting`] sorts the content of rules and at-rules.
87
- * [`postcss-utilities`] includes the most commonly used shortcuts and helpers.
88
- * [`short`] adds and extends numerous shorthand properties.
89
-
90
- ### Images and Fonts
91
-
92
- * [`postcss-assets`] inserts image dimensions and inlines files.
93
- * [`postcss-sprites`] generates image sprites.
94
- * [`font-magician`] generates all the `@font-face` rules needed in CSS.
95
- * [`postcss-inline-svg`] allows you to inline SVG and customize its styles.
96
- * [`postcss-write-svg`] allows you to write simple SVG directly in your CSS.
97
-
98
- ### Linters
99
-
100
- * [`stylelint`] is a modular stylesheet linter.
101
- * [`stylefmt`] is a tool that automatically formats CSS
102
- according `stylelint` rules.
103
- * [`doiuse`] lints CSS for browser support, using data from Can I Use.
104
- * [`colorguard`] helps you maintain a consistent color palette.
105
-
106
- ### Other
107
-
108
- * [`postcss-rtl`] combines both-directional (left-to-right and right-to-left) styles in one CSS file.
109
- * [`cssnano`] is a modular CSS minifier.
110
- * [`lost`] is a feature-rich `calc()` grid system.
111
- * [`rtlcss`] mirrors styles for right-to-left locales.
112
-
113
- [PostCSS plugin development]: https://github.com/postcss/postcss/blob/master/docs/writing-a-plugin.md
114
- [`postcss-inline-svg`]: https://github.com/TrySound/postcss-inline-svg
115
- [`postcss-preset-env`]: https://github.com/jonathantneal/postcss-preset-env
116
- [`react-css-modules`]: https://github.com/gajus/react-css-modules
117
- [`postcss-autoreset`]: https://github.com/maximkoretskiy/postcss-autoreset
118
- [`postcss-write-svg`]: https://github.com/jonathantneal/postcss-write-svg
119
- [`postcss-utilities`]: https://github.com/ismamz/postcss-utilities
120
- [`postcss-initial`]: https://github.com/maximkoretskiy/postcss-initial
121
- [`postcss-sprites`]: https://github.com/2createStudio/postcss-sprites
122
- [`postcss-modules`]: https://github.com/outpunk/postcss-modules
123
- [`postcss-sorting`]: https://github.com/hudochenkov/postcss-sorting
124
- [`postcss-assets`]: https://github.com/assetsjs/postcss-assets
125
- [`font-magician`]: https://github.com/jonathantneal/postcss-font-magician
126
- [`autoprefixer`]: https://github.com/postcss/autoprefixer
127
- [`cq-prolyfill`]: https://github.com/ausi/cq-prolyfill
128
- [`postcss-rtl`]: https://github.com/vkalinichev/postcss-rtl
129
- [`postcss-use`]: https://github.com/postcss/postcss-use
130
- [`css-modules`]: https://github.com/css-modules/css-modules
131
- [`colorguard`]: https://github.com/SlexAxton/css-colorguard
132
- [`stylelint`]: https://github.com/stylelint/stylelint
133
- [`stylefmt`]: https://github.com/morishitter/stylefmt
134
- [`cssnano`]: http://cssnano.co
135
- [`precss`]: https://github.com/jonathantneal/precss
136
- [`doiuse`]: https://github.com/anandthakker/doiuse
137
- [`rtlcss`]: https://github.com/MohammadYounes/rtlcss
138
- [`short`]: https://github.com/jonathantneal/postcss-short
139
- [`lost`]: https://github.com/peterramsing/lost
140
-
141
- ## Syntaxes
142
-
143
- PostCSS can transform styles in any syntax, not just CSS.
144
- If there is not yet support for your favorite syntax,
145
- you can write a parser and/or stringifier to extend PostCSS.
146
-
147
- * [`sugarss`] is a indent-based syntax like Sass or Stylus.
148
- * [`postcss-syntax`] switch syntax automatically by file extensions.
149
- * [`postcss-html`] parsing styles in `<style>` tags of HTML-like files.
150
- * [`postcss-markdown`] parsing styles in code blocks of Markdown files.
151
- * [`postcss-jsx`] parsing CSS in template / object literals of source files.
152
- * [`postcss-styled`] parsing CSS in template literals of source files.
153
- * [`postcss-scss`] allows you to work with SCSS
154
- *(but does not compile SCSS to CSS)*.
155
- * [`postcss-sass`] allows you to work with Sass
156
- *(but does not compile Sass to CSS)*.
157
- * [`postcss-less`] allows you to work with Less
158
- *(but does not compile LESS to CSS)*.
159
- * [`postcss-less-engine`] allows you to work with Less
160
- *(and DOES compile LESS to CSS using true Less.js evaluation)*.
161
- * [`postcss-js`] allows you to write styles in JS or transform
162
- React Inline Styles, Radium or JSS.
163
- * [`postcss-safe-parser`] finds and fixes CSS syntax errors.
164
- * [`midas`] converts a CSS string to highlighted HTML.
165
-
166
- [`postcss-less-engine`]: https://github.com/Crunch/postcss-less
167
- [`postcss-safe-parser`]: https://github.com/postcss/postcss-safe-parser
168
- [`postcss-syntax`]: https://github.com/gucong3000/postcss-syntax
169
- [`postcss-html`]: https://github.com/gucong3000/postcss-html
170
- [`postcss-markdown`]: https://github.com/gucong3000/postcss-markdown
171
- [`postcss-jsx`]: https://github.com/gucong3000/postcss-jsx
172
- [`postcss-styled`]: https://github.com/gucong3000/postcss-styled
173
- [`postcss-scss`]: https://github.com/postcss/postcss-scss
174
- [`postcss-sass`]: https://github.com/AleshaOleg/postcss-sass
175
- [`postcss-less`]: https://github.com/webschik/postcss-less
176
- [`postcss-js`]: https://github.com/postcss/postcss-js
177
- [`sugarss`]: https://github.com/postcss/sugarss
178
- [`midas`]: https://github.com/ben-eb/midas
179
-
180
- ## Articles
181
-
182
- * [Some things you may think about PostCSS… and you might be wrong](http://julian.io/some-things-you-may-think-about-postcss-and-you-might-be-wrong)
183
- * [What PostCSS Really Is; What It Really Does](http://davidtheclark.com/its-time-for-everyone-to-learn-about-postcss)
184
- * [PostCSS Guides](http://webdesign.tutsplus.com/series/postcss-deep-dive--cms-889)
185
-
186
- More articles and videos you can find on [awesome-postcss](https://github.com/jjaderg/awesome-postcss) list.
187
-
188
- ## Books
189
-
190
- * [Mastering PostCSS for Web Design](https://www.packtpub.com/web-development/mastering-postcss-web-design) by Alex Libby, Packt. (June 2016)
191
-
192
- ## Usage
193
-
194
- You can start using PostCSS in just two steps:
195
-
196
- 1. Find and add PostCSS extensions for your build tool.
197
- 2. [Select plugins] and add them to your PostCSS process.
198
-
199
- [Select plugins]: http://postcss.parts
200
-
201
- ### CSS-in-JS
202
-
203
- The best way to use PostCSS with CSS-in-JS is [`astroturf`].
204
- Add its loader to your `webpack.config.js`:
205
-
206
- ```js
207
- module.exports = {
208
- module: {
209
- rules: [
210
- {
211
- test: /\.css$/,
212
- use: ['style-loader', 'postcss-loader'],
213
- },
214
- {
215
- test: /\.jsx?$/,
216
- use: ['babel-loader', 'astroturf/loader'],
217
- }
218
- ]
219
- }
220
- }
221
- ```
222
-
223
- Then create `postcss.config.js`:
224
-
225
- ```js
226
- module.exports = {
227
- plugins: [
228
- require('autoprefixer'),
229
- require('postcss-nested')
230
- ]
231
- }
232
- ```
233
-
234
- [`astroturf`]: https://github.com/4Catalyzer/astroturf
235
-
236
- ### Parcel
237
-
238
- [Parcel] has built-in PostCSS support. It already uses Autoprefixer
239
- and cssnano. If you want to change plugins, create `postcss.config.js`
240
- in project’s root:
241
-
242
- ```js
243
- module.exports = {
244
- plugins: [
245
- require('autoprefixer'),
246
- require('postcss-nested')
247
- ]
248
- }
249
- ```
250
-
251
- Parcel will even automatically install these plugins for you.
252
-
253
- > Please, be aware of [the several issues in Version 1](https://github.com/parcel-bundler/parcel/labels/CSS%20Preprocessing). Notice, [Version 2](https://github.com/parcel-bundler/parcel/projects/5) may resolve the issues via [issue #2157](https://github.com/parcel-bundler/parcel/issues/2157).
254
-
255
- [Parcel]: https://parceljs.org
256
-
257
- ### Webpack
258
-
259
- Use [`postcss-loader`] in `webpack.config.js`:
260
-
261
- ```js
262
- module.exports = {
263
- module: {
264
- rules: [
265
- {
266
- test: /\.css$/,
267
- exclude: /node_modules/,
268
- use: [
269
- {
270
- loader: 'style-loader',
271
- },
272
- {
273
- loader: 'css-loader',
274
- options: {
275
- importLoaders: 1,
276
- }
277
- },
278
- {
279
- loader: 'postcss-loader'
280
- }
281
- ]
282
- }
283
- ]
284
- }
285
- }
286
- ```
287
-
288
- Then create `postcss.config.js`:
289
-
290
- ```js
291
- module.exports = {
292
- plugins: [
293
- require('precss'),
294
- require('autoprefixer')
295
- ]
296
- }
297
- ```
298
-
299
- [`postcss-loader`]: https://github.com/postcss/postcss-loader
300
-
301
- ### Gulp
302
-
303
- Use [`gulp-postcss`] and [`gulp-sourcemaps`].
304
-
305
- ```js
306
- gulp.task('css', () => {
307
- const postcss = require('gulp-postcss')
308
- const sourcemaps = require('gulp-sourcemaps')
309
-
310
- return gulp.src('src/**/*.css')
311
- .pipe( sourcemaps.init() )
312
- .pipe( postcss([ require('precss'), require('autoprefixer') ]) )
313
- .pipe( sourcemaps.write('.') )
314
- .pipe( gulp.dest('build/') )
315
- })
316
- ```
317
-
318
- [`gulp-sourcemaps`]: https://github.com/floridoo/gulp-sourcemaps
319
- [`gulp-postcss`]: https://github.com/postcss/gulp-postcss
320
-
321
- ### npm run / CLI
322
-
323
- To use PostCSS from your command-line interface or with npm scripts
324
- there is [`postcss-cli`].
325
-
326
- ```sh
327
- postcss --use autoprefixer -c options.json -o main.css css/*.css
328
- ```
329
-
330
- [`postcss-cli`]: https://github.com/postcss/postcss-cli
331
-
332
- ### Browser
333
-
334
- If you want to compile CSS string in browser (for instance, in live edit
335
- tools like CodePen), just use [Browserify] or [webpack]. They will pack
336
- PostCSS and plugins files into a single file.
337
-
338
- To apply PostCSS plugins to React Inline Styles, JSS, Radium
339
- and other [CSS-in-JS], you can use [`postcss-js`] and transforms style objects.
340
-
341
- ```js
342
- var postcss = require('postcss-js')
343
- var prefixer = postcss.sync([ require('autoprefixer') ])
344
-
345
- prefixer({ display: 'flex' }) //=> { display: ['-webkit-box', '-webkit-flex', '-ms-flexbox', 'flex'] }
346
- ```
347
-
348
- [`postcss-js`]: https://github.com/postcss/postcss-js
349
- [Browserify]: http://browserify.org/
350
- [CSS-in-JS]: https://github.com/MicheleBertoli/css-in-js
351
- [webpack]: https://webpack.github.io/
352
-
353
- ### Runners
354
-
355
- * **Grunt**: [`grunt-postcss`](https://github.com/nDmitry/grunt-postcss)
356
- * **HTML**: [`posthtml-postcss`](https://github.com/posthtml/posthtml-postcss)
357
- * **Stylus**: [`poststylus`](https://github.com/seaneking/poststylus)
358
- * **Rollup**: [`rollup-plugin-postcss`](https://github.com/egoist/rollup-plugin-postcss)
359
- * **Brunch**: [`postcss-brunch`](https://github.com/brunch/postcss-brunch)
360
- * **Broccoli**: [`broccoli-postcss`](https://github.com/jeffjewiss/broccoli-postcss)
361
- * **Meteor**: [`postcss`](https://atmospherejs.com/juliancwirko/postcss)
362
- * **ENB**: [`enb-postcss`](https://github.com/awinogradov/enb-postcss)
363
- * **Taskr**: [`taskr-postcss`](https://github.com/lukeed/taskr/tree/master/packages/postcss)
364
- * **Start**: [`start-postcss`](https://github.com/start-runner/postcss)
365
- * **Connect/Express**: [`postcss-middleware`](https://github.com/jedmao/postcss-middleware)
366
-
367
- ### JS API
368
-
369
- For other environments, you can use the JS API:
370
-
371
- ```js
372
- const autoprefixer = require('autoprefixer')
373
- const postcss = require('postcss')
374
- const precss = require('precss')
375
- const fs = require('fs')
376
-
377
- fs.readFile('src/app.css', (err, css) => {
378
- postcss([precss, autoprefixer])
379
- .process(css, { from: 'src/app.css', to: 'dest/app.css' })
380
- .then(result => {
381
- fs.writeFile('dest/app.css', result.css, () => true)
382
- if ( result.map ) {
383
- fs.writeFile('dest/app.css.map', result.map, () => true)
384
- }
385
- })
386
- })
387
- ```
388
-
389
- Read the [PostCSS API documentation] for more details about the JS API.
390
-
391
- All PostCSS runners should pass [PostCSS Runner Guidelines].
392
-
393
- [PostCSS Runner Guidelines]: https://github.com/postcss/postcss/blob/master/docs/guidelines/runner.md
394
- [PostCSS API documentation]: http://api.postcss.org/postcss.html
395
-
396
- ### Options
397
-
398
- Most PostCSS runners accept two parameters:
399
-
400
- * An array of plugins.
401
- * An object of options.
402
-
403
- Common options:
404
-
405
- * `syntax`: an object providing a syntax parser and a stringifier.
406
- * `parser`: a special syntax parser (for example, [SCSS]).
407
- * `stringifier`: a special syntax output generator (for example, [Midas]).
408
- * `map`: [source map options].
409
- * `from`: the input file name (most runners set it automatically).
410
- * `to`: the output file name (most runners set it automatically).
411
-
412
- [source map options]: https://github.com/postcss/postcss/blob/master/docs/source-maps.md
413
- [Midas]: https://github.com/ben-eb/midas
414
- [SCSS]: https://github.com/postcss/postcss-scss
415
-
416
- ### Treat Warnings as Errors
417
-
418
- In some situations it might be helpful to fail the build on any warning
419
- from PostCSS or one of its plugins. This guarantees that no warnings
420
- go unnoticed, and helps to avoid bugs. While there is no option to enable
421
- treating warnings as errors, it can easily be done
422
- by adding `postcss-fail-on-warn` plugin in the end of PostCSS plugins:
423
-
424
- ```js
425
- module.exports = {
426
- plugins: [
427
- require('autoprefixer'),
428
- require('postcss-fail-on-warn')
429
- ]
430
- }
431
- ```
432
-
433
- ## Contributing
434
-
435
- [Our contributing guidelines](./CONTRIBUTING.md) will help you
436
- with making pull request to this project.
437
-
438
- ## Editors & IDE Integration
439
-
440
- ### VS Code
441
-
442
- * [`csstools.postcss`] adds support for PostCSS, `postcss-preset-env`
443
- and CSS Modules.
444
-
445
- [`csstools.postcss`]: https://marketplace.visualstudio.com/items?itemName=csstools.postcss
446
-
447
- ### Atom
448
-
449
- * [`language-postcss`] adds PostCSS and [SugarSS] highlight.
450
- * [`source-preview-postcss`] previews your output CSS in a separate, live pane.
451
-
452
- [SugarSS]: https://github.com/postcss/sugarss
453
-
454
- ### Sublime Text
455
-
456
- * [`Syntax-highlighting-for-PostCSS`] adds PostCSS highlight.
457
-
458
- [`Syntax-highlighting-for-PostCSS`]: https://github.com/hudochenkov/Syntax-highlighting-for-PostCSS
459
- [`source-preview-postcss`]: https://atom.io/packages/source-preview-postcss
460
- [`language-postcss`]: https://atom.io/packages/language-postcss
461
-
462
- ### Vim
463
-
464
- * [`postcss.vim`] adds PostCSS highlight.
465
-
466
- [`postcss.vim`]: https://github.com/stephenway/postcss.vim
467
-
468
- ### WebStorm
469
-
470
- WebStorm 2016.3 [has] built-in PostCSS support.
471
-
472
- [has]: https://blog.jetbrains.com/webstorm/2016/08/webstorm-2016-3-early-access-preview/
473
-
474
-
475
- ## Security Contact
476
-
477
- To report a security vulnerability, please use the [Tidelift security contact].
478
- Tidelift will coordinate the fix and disclosure.
479
-
480
- [Tidelift security contact]: https://tidelift.com/security
481
-
482
-
483
- ## For Enterprise
484
-
485
- Available as part of the Tidelift Subscription.
486
-
487
- The maintainers of `postcss` and thousands of other packages are working
488
- with Tidelift to deliver commercial support and maintenance for the open source
489
- dependencies you use to build your applications. Save time, reduce risk,
490
- and improve code health, while paying the maintainers of the exact dependencies
491
- you use. [Learn more.](https://tidelift.com/subscription/pkg/npm-postcss?utm_source=npm-postcss&utm_medium=referral&utm_campaign=enterprise&utm_term=repo)
42
+ ## Docs
43
+ Read **[full docs](https://github.com/postcss/postcss#readme)** on GitHub.
@@ -3,7 +3,7 @@
3
3
  exports.__esModule = true;
4
4
  exports.default = void 0;
5
5
 
6
- var _nanocolors = _interopRequireDefault(require("nanocolors"));
6
+ var _picocolors = _interopRequireDefault(require("picocolors"));
7
7
 
8
8
  var _terminalHighlight = _interopRequireDefault(require("./terminal-highlight"));
9
9
 
@@ -215,7 +215,7 @@ var CssSyntaxError = /*#__PURE__*/function (_Error) {
215
215
  var css = this.source;
216
216
 
217
217
  if (_terminalHighlight.default) {
218
- if (typeof color === 'undefined') color = _nanocolors.default.isColorSupported;
218
+ if (typeof color === 'undefined') color = _picocolors.default.isColorSupported;
219
219
  if (color) css = (0, _terminalHighlight.default)(css);
220
220
  }
221
221
 
@@ -225,16 +225,16 @@ var CssSyntaxError = /*#__PURE__*/function (_Error) {
225
225
  var maxWidth = String(end).length;
226
226
 
227
227
  function mark(text) {
228
- if (color && _nanocolors.default.red) {
229
- return _nanocolors.default.red(_nanocolors.default.bold(text));
228
+ if (color && _picocolors.default.red) {
229
+ return _picocolors.default.red(_picocolors.default.bold(text));
230
230
  }
231
231
 
232
232
  return text;
233
233
  }
234
234
 
235
235
  function aside(text) {
236
- if (color && _nanocolors.default.gray) {
237
- return _nanocolors.default.gray(text);
236
+ if (color && _picocolors.default.gray) {
237
+ return _picocolors.default.gray(text);
238
238
  }
239
239
 
240
240
  return text;
@@ -293,4 +293,4 @@ var CssSyntaxError = /*#__PURE__*/function (_Error) {
293
293
  var _default = CssSyntaxError;
294
294
  exports.default = _default;
295
295
  module.exports = exports.default;
296
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["css-syntax-error.es6"],"names":["CssSyntaxError","message","line","column","source","file","plugin","name","reason","setMessage","Error","captureStackTrace","showSourceCode","color","css","terminalHighlight","nanocolors","isColorSupported","lines","split","start","Math","max","end","min","length","maxWidth","String","mark","text","red","bold","aside","gray","slice","map","index","number","gutter","spacing","replace","join","toString","code"],"mappings":"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","sourcesContent":["import nanocolors from 'nanocolors'\n\nimport terminalHighlight from './terminal-highlight'\n\n/**\n * The CSS parser throws this error for broken CSS.\n *\n * Custom parsers can throw this error for broken custom syntax using\n * the {@link Node#error} method.\n *\n * PostCSS will use the input source map to detect the original error location.\n * If you wrote a Sass file, compiled it to CSS and then parsed it with PostCSS,\n * PostCSS will show the original position in the Sass file.\n *\n * If you need the position in the PostCSS input\n * (e.g., to debug the previous compiler), use `error.input.file`.\n *\n * @example\n * // Catching and checking syntax error\n * try {\n *   postcss.parse('a{')\n * } catch (error) {\n *   if (error.name === 'CssSyntaxError') {\n *     error //=> CssSyntaxError\n *   }\n * }\n *\n * @example\n * // Raising error from plugin\n * throw node.error('Unknown variable', { plugin: 'postcss-vars' })\n */\nclass CssSyntaxError extends Error {\n  /**\n   * @param {string} message  Error message.\n   * @param {number} [line]   Source line of the error.\n   * @param {number} [column] Source column of the error.\n   * @param {string} [source] Source code of the broken file.\n   * @param {string} [file]   Absolute path to the broken file.\n   * @param {string} [plugin] PostCSS plugin name, if error came from plugin.\n   */\n  constructor (message, line, column, source, file, plugin) {\n    super(message)\n\n    /**\n     * Always equal to `'CssSyntaxError'`. You should always check error type\n     * by `error.name === 'CssSyntaxError'`\n     * instead of `error instanceof CssSyntaxError`,\n     * because npm could have several PostCSS versions.\n     *\n     * @type {string}\n     *\n     * @example\n     * if (error.name === 'CssSyntaxError') {\n     *   error //=> CssSyntaxError\n     * }\n     */\n    this.name = 'CssSyntaxError'\n    /**\n     * Error message.\n     *\n     * @type {string}\n     *\n     * @example\n     * error.message //=> 'Unclosed block'\n     */\n    this.reason = message\n\n    if (file) {\n      /**\n       * Absolute path to the broken file.\n       *\n       * @type {string}\n       *\n       * @example\n       * error.file       //=> 'a.sass'\n       * error.input.file //=> 'a.css'\n       */\n      this.file = file\n    }\n    if (source) {\n      /**\n       * Source code of the broken file.\n       *\n       * @type {string}\n       *\n       * @example\n       * error.source       //=> 'a { b {} }'\n       * error.input.column //=> 'a b { }'\n       */\n      this.source = source\n    }\n    if (plugin) {\n      /**\n       * Plugin name, if error came from plugin.\n       *\n       * @type {string}\n       *\n       * @example\n       * error.plugin //=> 'postcss-vars'\n       */\n      this.plugin = plugin\n    }\n    if (typeof line !== 'undefined' && typeof column !== 'undefined') {\n      /**\n       * Source line of the error.\n       *\n       * @type {number}\n       *\n       * @example\n       * error.line       //=> 2\n       * error.input.line //=> 4\n       */\n      this.line = line\n      /**\n       * Source column of the error.\n       *\n       * @type {number}\n       *\n       * @example\n       * error.column       //=> 1\n       * error.input.column //=> 4\n       */\n      this.column = column\n    }\n\n    this.setMessage()\n\n    if (Error.captureStackTrace) {\n      Error.captureStackTrace(this, CssSyntaxError)\n    }\n  }\n\n  setMessage () {\n    /**\n     * Full error text in the GNU error format\n     * with plugin, file, line and column.\n     *\n     * @type {string}\n     *\n     * @example\n     * error.message //=> 'a.css:1:1: Unclosed block'\n     */\n    this.message = this.plugin ? this.plugin + ': ' : ''\n    this.message += this.file ? this.file : '<css input>'\n    if (typeof this.line !== 'undefined') {\n      this.message += ':' + this.line + ':' + this.column\n    }\n    this.message += ': ' + this.reason\n  }\n\n  /**\n   * Returns a few lines of CSS source that caused the error.\n   *\n   * If the CSS has an input source map without `sourceContent`,\n   * this method will return an empty string.\n   *\n   * @param {boolean} [color] Whether arrow will be colored red by terminal\n   *                          color codes. By default, PostCSS will detect\n   *                          color support by `process.stdout.isTTY`\n   *                          and `process.env.NODE_DISABLE_COLORS`.\n   *\n   * @example\n   * error.showSourceCode() //=> \"  4 | }\n   *                        //      5 | a {\n   *                        //    > 6 |   bad\n   *                        //        |   ^\n   *                        //      7 | }\n   *                        //      8 | b {\"\n   *\n   * @return {string} Few lines of CSS source that caused the error.\n   */\n  showSourceCode (color) {\n    if (!this.source) return ''\n\n    let css = this.source\n    if (terminalHighlight) {\n      if (typeof color === 'undefined') color = nanocolors.isColorSupported\n      if (color) css = terminalHighlight(css)\n    }\n\n    let lines = css.split(/\\r?\\n/)\n    let start = Math.max(this.line - 3, 0)\n    let end = Math.min(this.line + 2, lines.length)\n\n    let maxWidth = String(end).length\n\n    function mark (text) {\n      if (color && nanocolors.red) {\n        return nanocolors.red(nanocolors.bold(text))\n      }\n      return text\n    }\n    function aside (text) {\n      if (color && nanocolors.gray) {\n        return nanocolors.gray(text)\n      }\n      return text\n    }\n\n    return lines\n      .slice(start, end)\n      .map((line, index) => {\n        let number = start + 1 + index\n        let gutter = ' ' + (' ' + number).slice(-maxWidth) + ' | '\n        if (number === this.line) {\n          let spacing =\n            aside(gutter.replace(/\\d/g, ' ')) +\n            line.slice(0, this.column - 1).replace(/[^\\t]/g, ' ')\n          return mark('>') + aside(gutter) + line + '\\n ' + spacing + mark('^')\n        }\n        return ' ' + aside(gutter) + line\n      })\n      .join('\\n')\n  }\n\n  /**\n   * Returns error position, message and source code of the broken part.\n   *\n   * @example\n   * error.toString() //=> \"CssSyntaxError: app.css:1:1: Unclosed block\n   *                  //    > 1 | a {\n   *                  //        | ^\"\n   *\n   * @return {string} Error position, message and source code.\n   */\n  toString () {\n    let code = this.showSourceCode()\n    if (code) {\n      code = '\\n\\n' + code + '\\n'\n    }\n    return this.name + ': ' + this.message + code\n  }\n\n  /**\n   * @memberof CssSyntaxError#\n   * @member {Input} input Input object with PostCSS internal information\n   *                       about input file. If input has source map\n   *                       from previous tool, PostCSS will use origin\n   *                       (for example, Sass) source. You can use this\n   *                       object to get PostCSS input source.\n   *\n   * @example\n   * error.input.file //=> 'a.css'\n   * error.file       //=> 'a.sass'\n   */\n}\n\nexport default CssSyntaxError\n"],"file":"css-syntax-error.js"}
296
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["css-syntax-error.es6"],"names":["CssSyntaxError","message","line","column","source","file","plugin","name","reason","setMessage","Error","captureStackTrace","showSourceCode","color","css","terminalHighlight","pico","isColorSupported","lines","split","start","Math","max","end","min","length","maxWidth","String","mark","text","red","bold","aside","gray","slice","map","index","number","gutter","spacing","replace","join","toString","code"],"mappings":"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","sourcesContent":["import pico from 'picocolors'\n\nimport terminalHighlight from './terminal-highlight'\n\n/**\n * The CSS parser throws this error for broken CSS.\n *\n * Custom parsers can throw this error for broken custom syntax using\n * the {@link Node#error} method.\n *\n * PostCSS will use the input source map to detect the original error location.\n * If you wrote a Sass file, compiled it to CSS and then parsed it with PostCSS,\n * PostCSS will show the original position in the Sass file.\n *\n * If you need the position in the PostCSS input\n * (e.g., to debug the previous compiler), use `error.input.file`.\n *\n * @example\n * // Catching and checking syntax error\n * try {\n *   postcss.parse('a{')\n * } catch (error) {\n *   if (error.name === 'CssSyntaxError') {\n *     error //=> CssSyntaxError\n *   }\n * }\n *\n * @example\n * // Raising error from plugin\n * throw node.error('Unknown variable', { plugin: 'postcss-vars' })\n */\nclass CssSyntaxError extends Error {\n  /**\n   * @param {string} message  Error message.\n   * @param {number} [line]   Source line of the error.\n   * @param {number} [column] Source column of the error.\n   * @param {string} [source] Source code of the broken file.\n   * @param {string} [file]   Absolute path to the broken file.\n   * @param {string} [plugin] PostCSS plugin name, if error came from plugin.\n   */\n  constructor (message, line, column, source, file, plugin) {\n    super(message)\n\n    /**\n     * Always equal to `'CssSyntaxError'`. You should always check error type\n     * by `error.name === 'CssSyntaxError'`\n     * instead of `error instanceof CssSyntaxError`,\n     * because npm could have several PostCSS versions.\n     *\n     * @type {string}\n     *\n     * @example\n     * if (error.name === 'CssSyntaxError') {\n     *   error //=> CssSyntaxError\n     * }\n     */\n    this.name = 'CssSyntaxError'\n    /**\n     * Error message.\n     *\n     * @type {string}\n     *\n     * @example\n     * error.message //=> 'Unclosed block'\n     */\n    this.reason = message\n\n    if (file) {\n      /**\n       * Absolute path to the broken file.\n       *\n       * @type {string}\n       *\n       * @example\n       * error.file       //=> 'a.sass'\n       * error.input.file //=> 'a.css'\n       */\n      this.file = file\n    }\n    if (source) {\n      /**\n       * Source code of the broken file.\n       *\n       * @type {string}\n       *\n       * @example\n       * error.source       //=> 'a { b {} }'\n       * error.input.column //=> 'a b { }'\n       */\n      this.source = source\n    }\n    if (plugin) {\n      /**\n       * Plugin name, if error came from plugin.\n       *\n       * @type {string}\n       *\n       * @example\n       * error.plugin //=> 'postcss-vars'\n       */\n      this.plugin = plugin\n    }\n    if (typeof line !== 'undefined' && typeof column !== 'undefined') {\n      /**\n       * Source line of the error.\n       *\n       * @type {number}\n       *\n       * @example\n       * error.line       //=> 2\n       * error.input.line //=> 4\n       */\n      this.line = line\n      /**\n       * Source column of the error.\n       *\n       * @type {number}\n       *\n       * @example\n       * error.column       //=> 1\n       * error.input.column //=> 4\n       */\n      this.column = column\n    }\n\n    this.setMessage()\n\n    if (Error.captureStackTrace) {\n      Error.captureStackTrace(this, CssSyntaxError)\n    }\n  }\n\n  setMessage () {\n    /**\n     * Full error text in the GNU error format\n     * with plugin, file, line and column.\n     *\n     * @type {string}\n     *\n     * @example\n     * error.message //=> 'a.css:1:1: Unclosed block'\n     */\n    this.message = this.plugin ? this.plugin + ': ' : ''\n    this.message += this.file ? this.file : '<css input>'\n    if (typeof this.line !== 'undefined') {\n      this.message += ':' + this.line + ':' + this.column\n    }\n    this.message += ': ' + this.reason\n  }\n\n  /**\n   * Returns a few lines of CSS source that caused the error.\n   *\n   * If the CSS has an input source map without `sourceContent`,\n   * this method will return an empty string.\n   *\n   * @param {boolean} [color] Whether arrow will be colored red by terminal\n   *                          color codes. By default, PostCSS will detect\n   *                          color support by `process.stdout.isTTY`\n   *                          and `process.env.NODE_DISABLE_COLORS`.\n   *\n   * @example\n   * error.showSourceCode() //=> \"  4 | }\n   *                        //      5 | a {\n   *                        //    > 6 |   bad\n   *                        //        |   ^\n   *                        //      7 | }\n   *                        //      8 | b {\"\n   *\n   * @return {string} Few lines of CSS source that caused the error.\n   */\n  showSourceCode (color) {\n    if (!this.source) return ''\n\n    let css = this.source\n    if (terminalHighlight) {\n      if (typeof color === 'undefined') color = pico.isColorSupported\n      if (color) css = terminalHighlight(css)\n    }\n\n    let lines = css.split(/\\r?\\n/)\n    let start = Math.max(this.line - 3, 0)\n    let end = Math.min(this.line + 2, lines.length)\n\n    let maxWidth = String(end).length\n\n    function mark (text) {\n      if (color && pico.red) {\n        return pico.red(pico.bold(text))\n      }\n      return text\n    }\n    function aside (text) {\n      if (color && pico.gray) {\n        return pico.gray(text)\n      }\n      return text\n    }\n\n    return lines\n      .slice(start, end)\n      .map((line, index) => {\n        let number = start + 1 + index\n        let gutter = ' ' + (' ' + number).slice(-maxWidth) + ' | '\n        if (number === this.line) {\n          let spacing =\n            aside(gutter.replace(/\\d/g, ' ')) +\n            line.slice(0, this.column - 1).replace(/[^\\t]/g, ' ')\n          return mark('>') + aside(gutter) + line + '\\n ' + spacing + mark('^')\n        }\n        return ' ' + aside(gutter) + line\n      })\n      .join('\\n')\n  }\n\n  /**\n   * Returns error position, message and source code of the broken part.\n   *\n   * @example\n   * error.toString() //=> \"CssSyntaxError: app.css:1:1: Unclosed block\n   *                  //    > 1 | a {\n   *                  //        | ^\"\n   *\n   * @return {string} Error position, message and source code.\n   */\n  toString () {\n    let code = this.showSourceCode()\n    if (code) {\n      code = '\\n\\n' + code + '\\n'\n    }\n    return this.name + ': ' + this.message + code\n  }\n\n  /**\n   * @memberof CssSyntaxError#\n   * @member {Input} input Input object with PostCSS internal information\n   *                       about input file. If input has source map\n   *                       from previous tool, PostCSS will use origin\n   *                       (for example, Sass) source. You can use this\n   *                       object to get PostCSS input source.\n   *\n   * @example\n   * error.input.file //=> 'a.css'\n   * error.file       //=> 'a.sass'\n   */\n}\n\nexport default CssSyntaxError\n"],"file":"css-syntax-error.js"}
package/lib/processor.js CHANGED
@@ -42,7 +42,7 @@ var Processor = /*#__PURE__*/function () {
42
42
  * throw new Error('This plugin works only with PostCSS 6')
43
43
  * }
44
44
  */
45
- this.version = '7.0.38';
45
+ this.version = '7.0.39';
46
46
  /**
47
47
  * Plugins added to this processor.
48
48
  *
@@ -261,4 +261,4 @@ var _default = Processor;
261
261
 
262
262
  exports.default = _default;
263
263
  module.exports = exports.default;
264
- //# 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","Error","postcssPlugin","Array","isArray","push","parse","stringify"],"mappings":"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","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.38'\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 does 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 === true) {\n        let plugin = i()\n        throw new Error(\n          'PostCSS plugin ' + plugin.postcssPlugin + ' requires PostCSS 8.\\n' +\n          'Migration guide for end-users:\\n' +\n          'https://github.com/postcss/postcss/wiki/PostCSS-8-for-end-users'\n        )\n      }\n\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 if (typeof i === 'object' && i.postcssPlugin) {\n        throw new Error(\n          'PostCSS plugin ' + i.postcssPlugin + ' requires PostCSS 8.\\n' +\n          'Migration guide for end-users:\\n' +\n          'https://github.com/postcss/postcss/wiki/PostCSS-8-for-end-users'\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"],"file":"processor.js"}
264
+ //# 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","Error","postcssPlugin","Array","isArray","push","parse","stringify"],"mappings":"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","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.39'\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 does 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 === true) {\n        let plugin = i()\n        throw new Error(\n          'PostCSS plugin ' + plugin.postcssPlugin + ' requires PostCSS 8.\\n' +\n          'Migration guide for end-users:\\n' +\n          'https://github.com/postcss/postcss/wiki/PostCSS-8-for-end-users'\n        )\n      }\n\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 if (typeof i === 'object' && i.postcssPlugin) {\n        throw new Error(\n          'PostCSS plugin ' + i.postcssPlugin + ' requires PostCSS 8.\\n' +\n          'Migration guide for end-users:\\n' +\n          'https://github.com/postcss/postcss/wiki/PostCSS-8-for-end-users'\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"],"file":"processor.js"}