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.

@@ -36,221 +36,238 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
36
36
  * try {
37
37
  * postcss.parse('a{')
38
38
  * } catch (error) {
39
- * if ( error.name === 'CssSyntaxError' ) {
39
+ * if (error.name === 'CssSyntaxError') {
40
40
  * error //=> CssSyntaxError
41
41
  * }
42
42
  * }
43
43
  *
44
44
  * @example
45
45
  * // Raising error from plugin
46
- * throw node.error('Unknown variable', { plugin: 'postcss-vars' });
46
+ * throw node.error('Unknown variable', { plugin: 'postcss-vars' })
47
47
  */
48
48
  var CssSyntaxError = function () {
49
+ /**
50
+ * @param {string} message Error message.
51
+ * @param {number} [line] Source line of the error.
52
+ * @param {number} [column] Source column of the error.
53
+ * @param {string} [source] Source code of the broken file.
54
+ * @param {string} [file] Absolute path to the broken file.
55
+ * @param {string} [plugin] PostCSS plugin name, if error came from plugin.
56
+ */
57
+ function CssSyntaxError(message, line, column, source, file, plugin) {
58
+ _classCallCheck(this, CssSyntaxError);
49
59
 
50
60
  /**
51
- * @param {string} message - error message
52
- * @param {number} [line] - source line of the error
53
- * @param {number} [column] - source column of the error
54
- * @param {string} [source] - source code of the broken file
55
- * @param {string} [file] - absolute path to the broken file
56
- * @param {string} [plugin] - PostCSS plugin name, if error came from plugin
61
+ * Always equal to `'CssSyntaxError'`. You should always check error type
62
+ * by `error.name === 'CssSyntaxError'`
63
+ * instead of `error instanceof CssSyntaxError`,
64
+ * because npm could have several PostCSS versions.
65
+ *
66
+ * @type {string}
67
+ *
68
+ * @example
69
+ * if (error.name === 'CssSyntaxError') {
70
+ * error //=> CssSyntaxError
71
+ * }
57
72
  */
58
- function CssSyntaxError(message, line, column, source, file, plugin) {
59
- _classCallCheck(this, CssSyntaxError);
60
-
61
- /**
62
- * @member {string} - Always equal to `'CssSyntaxError'`. You should
63
- * always check error type
64
- * by `error.name === 'CssSyntaxError'` instead of
65
- * `error instanceof CssSyntaxError`, because
66
- * npm could have several PostCSS versions.
67
- *
68
- * @example
69
- * if ( error.name === 'CssSyntaxError' ) {
70
- * error //=> CssSyntaxError
71
- * }
72
- */
73
- this.name = 'CssSyntaxError';
74
- /**
75
- * @member {string} - Error message.
76
- *
77
- * @example
78
- * error.message //=> 'Unclosed block'
79
- */
80
- this.reason = message;
73
+ this.name = 'CssSyntaxError';
74
+ /**
75
+ * Error message.
76
+ *
77
+ * @type {string}
78
+ *
79
+ * @example
80
+ * error.message //=> 'Unclosed block'
81
+ */
82
+ this.reason = message;
81
83
 
82
- if (file) {
83
- /**
84
- * @member {string} - Absolute path to the broken file.
85
- *
86
- * @example
87
- * error.file //=> 'a.sass'
88
- * error.input.file //=> 'a.css'
89
- */
90
- this.file = file;
91
- }
92
- if (source) {
93
- /**
94
- * @member {string} - Source code of the broken file.
95
- *
96
- * @example
97
- * error.source //=> 'a { b {} }'
98
- * error.input.column //=> 'a b { }'
99
- */
100
- this.source = source;
101
- }
102
- if (plugin) {
103
- /**
104
- * @member {string} - Plugin name, if error came from plugin.
105
- *
106
- * @example
107
- * error.plugin //=> 'postcss-vars'
108
- */
109
- this.plugin = plugin;
110
- }
111
- if (typeof line !== 'undefined' && typeof column !== 'undefined') {
112
- /**
113
- * @member {number} - Source line of the error.
114
- *
115
- * @example
116
- * error.line //=> 2
117
- * error.input.line //=> 4
118
- */
119
- this.line = line;
120
- /**
121
- * @member {number} - Source column of the error.
122
- *
123
- * @example
124
- * error.column //=> 1
125
- * error.input.column //=> 4
126
- */
127
- this.column = column;
128
- }
84
+ if (file) {
85
+ /**
86
+ * Absolute path to the broken file.
87
+ *
88
+ * @type {string}
89
+ *
90
+ * @example
91
+ * error.file //=> 'a.sass'
92
+ * error.input.file //=> 'a.css'
93
+ */
94
+ this.file = file;
95
+ }
96
+ if (source) {
97
+ /**
98
+ * Source code of the broken file.
99
+ *
100
+ * @type {string}
101
+ *
102
+ * @example
103
+ * error.source //=> 'a { b {} }'
104
+ * error.input.column //=> 'a b { }'
105
+ */
106
+ this.source = source;
107
+ }
108
+ if (plugin) {
109
+ /**
110
+ * Plugin name, if error came from plugin.
111
+ *
112
+ * @type {string}
113
+ *
114
+ * @example
115
+ * error.plugin //=> 'postcss-vars'
116
+ */
117
+ this.plugin = plugin;
118
+ }
119
+ if (typeof line !== 'undefined' && typeof column !== 'undefined') {
120
+ /**
121
+ * Source line of the error.
122
+ *
123
+ * @type {number}
124
+ *
125
+ * @example
126
+ * error.line //=> 2
127
+ * error.input.line //=> 4
128
+ */
129
+ this.line = line;
130
+ /**
131
+ * Source column of the error.
132
+ *
133
+ * @type {number}
134
+ *
135
+ * @example
136
+ * error.column //=> 1
137
+ * error.input.column //=> 4
138
+ */
139
+ this.column = column;
140
+ }
129
141
 
130
- this.setMessage();
142
+ this.setMessage();
131
143
 
132
- if (Error.captureStackTrace) {
133
- Error.captureStackTrace(this, CssSyntaxError);
134
- }
144
+ if (Error.captureStackTrace) {
145
+ Error.captureStackTrace(this, CssSyntaxError);
135
146
  }
147
+ }
136
148
 
137
- CssSyntaxError.prototype.setMessage = function setMessage() {
138
- /**
139
- * @member {string} - Full error text in the GNU error format
140
- * with plugin, file, line and column.
141
- *
142
- * @example
143
- * error.message //=> 'a.css:1:1: Unclosed block'
144
- */
145
- this.message = this.plugin ? this.plugin + ': ' : '';
146
- this.message += this.file ? this.file : '<css input>';
147
- if (typeof this.line !== 'undefined') {
148
- this.message += ':' + this.line + ':' + this.column;
149
- }
150
- this.message += ': ' + this.reason;
151
- };
152
-
149
+ CssSyntaxError.prototype.setMessage = function setMessage() {
153
150
  /**
154
- * Returns a few lines of CSS source that caused the error.
151
+ * Full error text in the GNU error format
152
+ * with plugin, file, line and column.
155
153
  *
156
- * If the CSS has an input source map without `sourceContent`,
157
- * this method will return an empty string.
158
- *
159
- * @param {boolean} [color] whether arrow will be colored red by terminal
160
- * color codes. By default, PostCSS will detect
161
- * color support by `process.stdout.isTTY`
162
- * and `process.env.NODE_DISABLE_COLORS`.
154
+ * @type {string}
163
155
  *
164
156
  * @example
165
- * error.showSourceCode() //=> " 4 | }
166
- * // 5 | a {
167
- * // > 6 | bad
168
- * // | ^
169
- * // 7 | }
170
- * // 8 | b {"
171
- *
172
- * @return {string} few lines of CSS source that caused the error
157
+ * error.message //=> 'a.css:1:1: Unclosed block'
173
158
  */
159
+ this.message = this.plugin ? this.plugin + ': ' : '';
160
+ this.message += this.file ? this.file : '<css input>';
161
+ if (typeof this.line !== 'undefined') {
162
+ this.message += ':' + this.line + ':' + this.column;
163
+ }
164
+ this.message += ': ' + this.reason;
165
+ };
174
166
 
167
+ /**
168
+ * Returns a few lines of CSS source that caused the error.
169
+ *
170
+ * If the CSS has an input source map without `sourceContent`,
171
+ * this method will return an empty string.
172
+ *
173
+ * @param {boolean} [color] Whether arrow will be colored red by terminal
174
+ * color codes. By default, PostCSS will detect
175
+ * color support by `process.stdout.isTTY`
176
+ * and `process.env.NODE_DISABLE_COLORS`.
177
+ *
178
+ * @example
179
+ * error.showSourceCode() //=> " 4 | }
180
+ * // 5 | a {
181
+ * // > 6 | bad
182
+ * // | ^
183
+ * // 7 | }
184
+ * // 8 | b {"
185
+ *
186
+ * @return {string} Few lines of CSS source that caused the error.
187
+ */
175
188
 
176
- CssSyntaxError.prototype.showSourceCode = function showSourceCode(color) {
177
- var _this = this;
178
189
 
179
- if (!this.source) return '';
190
+ CssSyntaxError.prototype.showSourceCode = function showSourceCode(color) {
191
+ var _this = this;
180
192
 
181
- var css = this.source;
182
- if (typeof color === 'undefined') color = _supportsColor2.default.stdout;
183
- if (color) css = (0, _terminalHighlight2.default)(css);
193
+ if (!this.source) return '';
184
194
 
185
- var lines = css.split(/\r?\n/);
186
- var start = Math.max(this.line - 3, 0);
187
- var end = Math.min(this.line + 2, lines.length);
195
+ var css = this.source;
196
+ if (_terminalHighlight2.default) {
197
+ if (typeof color === 'undefined') color = _supportsColor2.default.stdout;
198
+ if (color) css = (0, _terminalHighlight2.default)(css);
199
+ }
188
200
 
189
- var maxWidth = String(end).length;
201
+ var lines = css.split(/\r?\n/);
202
+ var start = Math.max(this.line - 3, 0);
203
+ var end = Math.min(this.line + 2, lines.length);
190
204
 
191
- function mark(text) {
192
- if (color && _chalk2.default.red) {
193
- return _chalk2.default.red.bold(text);
194
- } else {
195
- return text;
196
- }
197
- }
198
- function aside(text) {
199
- if (color && _chalk2.default.gray) {
200
- return _chalk2.default.gray(text);
201
- } else {
202
- return text;
203
- }
204
- }
205
+ var maxWidth = String(end).length;
205
206
 
206
- return lines.slice(start, end).map(function (line, index) {
207
- var number = start + 1 + index;
208
- var gutter = ' ' + (' ' + number).slice(-maxWidth) + ' | ';
209
- if (number === _this.line) {
210
- var spacing = aside(gutter.replace(/\d/g, ' ')) + line.slice(0, _this.column - 1).replace(/[^\t]/g, ' ');
211
- return mark('>') + aside(gutter) + line + '\n ' + spacing + mark('^');
212
- } else {
213
- return ' ' + aside(gutter) + line;
214
- }
215
- }).join('\n');
216
- };
207
+ function mark(text) {
208
+ if (color && _chalk2.default.red) {
209
+ return _chalk2.default.red.bold(text);
210
+ } else {
211
+ return text;
212
+ }
213
+ }
214
+ function aside(text) {
215
+ if (color && _chalk2.default.gray) {
216
+ return _chalk2.default.gray(text);
217
+ } else {
218
+ return text;
219
+ }
220
+ }
217
221
 
218
- /**
219
- * Returns error position, message and source code of the broken part.
220
- *
221
- * @example
222
- * error.toString() //=> "CssSyntaxError: app.css:1:1: Unclosed block
223
- * // > 1 | a {
224
- * // | ^"
225
- *
226
- * @return {string} error position, message and source code
227
- */
222
+ return lines.slice(start, end).map(function (line, index) {
223
+ var number = start + 1 + index;
224
+ var gutter = ' ' + (' ' + number).slice(-maxWidth) + ' | ';
225
+ if (number === _this.line) {
226
+ var spacing = aside(gutter.replace(/\d/g, ' ')) + line.slice(0, _this.column - 1).replace(/[^\t]/g, ' ');
227
+ return mark('>') + aside(gutter) + line + '\n ' + spacing + mark('^');
228
+ } else {
229
+ return ' ' + aside(gutter) + line;
230
+ }
231
+ }).join('\n');
232
+ };
228
233
 
234
+ /**
235
+ * Returns error position, message and source code of the broken part.
236
+ *
237
+ * @example
238
+ * error.toString() //=> "CssSyntaxError: app.css:1:1: Unclosed block
239
+ * // > 1 | a {
240
+ * // | ^"
241
+ *
242
+ * @return {string} Error position, message and source code.
243
+ */
229
244
 
230
- CssSyntaxError.prototype.toString = function toString() {
231
- var code = this.showSourceCode();
232
- if (code) {
233
- code = '\n\n' + code + '\n';
234
- }
235
- return this.name + ': ' + this.message + code;
236
- };
237
245
 
238
- /**
239
- * @memberof CssSyntaxError#
240
- * @member {Input} input - Input object with PostCSS internal information
241
- * about input file. If input has source map
242
- * from previous tool, PostCSS will use origin
243
- * (for example, Sass) source. You can use this
244
- * object to get PostCSS input source.
245
- *
246
- * @example
247
- * error.input.file //=> 'a.css'
248
- * error.file //=> 'a.sass'
249
- */
246
+ CssSyntaxError.prototype.toString = function toString() {
247
+ var code = this.showSourceCode();
248
+ if (code) {
249
+ code = '\n\n' + code + '\n';
250
+ }
251
+ return this.name + ': ' + this.message + code;
252
+ };
253
+
254
+ /**
255
+ * @memberof CssSyntaxError#
256
+ * @member {Input} input Input object with PostCSS internal information
257
+ * about input file. If input has source map
258
+ * from previous tool, PostCSS will use origin
259
+ * (for example, Sass) source. You can use this
260
+ * object to get PostCSS input source.
261
+ *
262
+ * @example
263
+ * error.input.file //=> 'a.css'
264
+ * error.file //=> 'a.sass'
265
+ */
266
+
250
267
 
251
- return CssSyntaxError;
268
+ return CssSyntaxError;
252
269
  }();
253
270
 
254
271
  exports.default = CssSyntaxError;
255
272
  module.exports = exports['default'];
256
- //# 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","supportsColor","stdout","lines","split","start","Math","max","end","min","length","maxWidth","String","mark","text","chalk","red","bold","aside","gray","slice","map","index","number","gutter","spacing","replace","join","toString","code"],"mappings":"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","file":"css-syntax-error.js","sourcesContent":["import supportsColor from 'supports-color';\nimport chalk         from 'chalk';\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 {\n\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        /**\n         * @member {string} - Always equal to `'CssSyntaxError'`. You should\n         *                    always check error type\n         *                    by `error.name === 'CssSyntaxError'` instead of\n         *                    `error instanceof CssSyntaxError`, because\n         *                    npm could have several PostCSS versions.\n         *\n         * @example\n         * if ( error.name === 'CssSyntaxError' ) {\n         *   error //=> CssSyntaxError\n         * }\n         */\n        this.name = 'CssSyntaxError';\n        /**\n         * @member {string} - Error message.\n         *\n         * @example\n         * error.message //=> 'Unclosed block'\n         */\n        this.reason = message;\n\n        if ( file ) {\n            /**\n             * @member {string} - Absolute path to the broken file.\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             * @member {string} - Source code of the broken file.\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             * @member {string} - Plugin name, if error came from plugin.\n             *\n             * @example\n             * error.plugin //=> 'postcss-vars'\n             */\n            this.plugin = plugin;\n        }\n        if ( typeof line !== 'undefined' && typeof column !== 'undefined' ) {\n            /**\n             * @member {number} - Source line of the error.\n             *\n             * @example\n             * error.line       //=> 2\n             * error.input.line //=> 4\n             */\n            this.line   = line;\n            /**\n             * @member {number} - Source column of the error.\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         * @member {string} - Full error text in the GNU error format\n         *                    with plugin, file, line and column.\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 ( typeof color === 'undefined' ) color = supportsColor.stdout;\n        if ( color ) css = terminalHighlight(css);\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 && chalk.red ) {\n                return chalk.red.bold(text);\n            } else {\n                return text;\n            }\n        }\n        function aside(text) {\n            if ( color && chalk.gray ) {\n                return chalk.gray(text);\n            } else {\n                return text;\n            }\n        }\n\n        return lines.slice(start, end).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 ' +\n                       spacing + mark('^');\n            } else {\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}\n\nexport default CssSyntaxError;\n"]}
273
+ //# 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","supportsColor","stdout","lines","split","start","Math","max","end","min","length","maxWidth","String","mark","text","chalk","red","bold","aside","gray","slice","map","index","number","gutter","spacing","replace","join","toString","code"],"mappings":"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","file":"css-syntax-error.js","sourcesContent":["import supportsColor from 'supports-color'\nimport chalk from 'chalk'\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 {\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    /**\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 = supportsColor.stdout\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 && chalk.red) {\n        return chalk.red.bold(text)\n      } else {\n        return text\n      }\n    }\n    function aside (text) {\n      if (color && chalk.gray) {\n        return chalk.gray(text)\n      } else {\n        return text\n      }\n    }\n\n    return lines.slice(start, end).map((line, index) => {\n      let number = start + 1 + index\n      let gutter = ' ' + (' ' + number).slice(-maxWidth) + ' | '\n      if (number === this.line) {\n        let spacing = 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      } else {\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"]}
@@ -20,8 +20,8 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
20
20
  * @extends Node
21
21
  *
22
22
  * @example
23
- * const root = postcss.parse('a { color: black }');
24
- * const decl = root.first.first;
23
+ * const root = postcss.parse('a { color: black }')
24
+ * const decl = root.first.first
25
25
  * decl.type //=> 'decl'
26
26
  * decl.toString() //=> ' color: black'
27
27
  */
@@ -39,39 +39,39 @@ var Declaration = function (_Node) {
39
39
 
40
40
  /**
41
41
  * @memberof Declaration#
42
- * @member {string} prop - the declaration’s property name
42
+ * @member {string} prop The declaration’s property name.
43
43
  *
44
44
  * @example
45
- * const root = postcss.parse('a { color: black }');
46
- * const decl = root.first.first;
45
+ * const root = postcss.parse('a { color: black }')
46
+ * const decl = root.first.first
47
47
  * decl.prop //=> 'color'
48
48
  */
49
49
 
50
50
  /**
51
51
  * @memberof Declaration#
52
- * @member {string} value - the declaration’s value
52
+ * @member {string} value The declaration’s value.
53
53
  *
54
54
  * @example
55
- * const root = postcss.parse('a { color: black }');
56
- * const decl = root.first.first;
55
+ * const root = postcss.parse('a { color: black }')
56
+ * const decl = root.first.first
57
57
  * decl.value //=> 'black'
58
58
  */
59
59
 
60
60
  /**
61
61
  * @memberof Declaration#
62
- * @member {boolean} important - `true` if the declaration
63
- * has an !important annotation.
62
+ * @member {boolean} important `true` if the declaration
63
+ * has an !important annotation.
64
64
  *
65
65
  * @example
66
- * const root = postcss.parse('a { color: black !important; color: red }');
66
+ * const root = postcss.parse('a { color: black !important; color: red }')
67
67
  * root.first.first.important //=> true
68
68
  * root.first.last.important //=> undefined
69
69
  */
70
70
 
71
71
  /**
72
72
  * @memberof Declaration#
73
- * @member {object} raws - Information to generate byte-to-byte equal
74
- * node string as it was in the origin input.
73
+ * @member {object} raws Information to generate byte-to-byte equal
74
+ * node string as it was in the origin input.
75
75
  *
76
76
  * Every parser saves its own properties,
77
77
  * but the default CSS parser uses:
@@ -93,9 +93,10 @@ var Declaration = function (_Node) {
93
93
  * root.first.first.raws //=> { before: '\n ', between: ':' }
94
94
  */
95
95
 
96
+
96
97
  return Declaration;
97
98
  }(_node2.default);
98
99
 
99
100
  exports.default = Declaration;
100
101
  module.exports = exports['default'];
101
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRlY2xhcmF0aW9uLmVzNiJdLCJuYW1lcyI6WyJEZWNsYXJhdGlvbiIsImRlZmF1bHRzIiwidHlwZSIsIk5vZGUiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7Ozs7Ozs7Ozs7O0FBRUE7Ozs7Ozs7Ozs7O0lBV01BLFc7OztBQUVGLHVCQUFZQyxRQUFaLEVBQXNCO0FBQUE7O0FBQUEsaURBQ2xCLGlCQUFNQSxRQUFOLENBRGtCOztBQUVsQixVQUFLQyxJQUFMLEdBQVksTUFBWjtBQUZrQjtBQUdyQjs7QUFFRDs7Ozs7Ozs7OztBQVVBOzs7Ozs7Ozs7O0FBVUE7Ozs7Ozs7Ozs7O0FBV0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0VBdENzQkMsYzs7a0JBaUVYSCxXIiwiZmlsZSI6ImRlY2xhcmF0aW9uLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IE5vZGUgZnJvbSAnLi9ub2RlJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgQ1NTIGRlY2xhcmF0aW9uLlxuICpcbiAqIEBleHRlbmRzIE5vZGVcbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2EgeyBjb2xvcjogYmxhY2sgfScpO1xuICogY29uc3QgZGVjbCA9IHJvb3QuZmlyc3QuZmlyc3Q7XG4gKiBkZWNsLnR5cGUgICAgICAgLy89PiAnZGVjbCdcbiAqIGRlY2wudG9TdHJpbmcoKSAvLz0+ICcgY29sb3I6IGJsYWNrJ1xuICovXG5jbGFzcyBEZWNsYXJhdGlvbiBleHRlbmRzIE5vZGUge1xuXG4gICAgY29uc3RydWN0b3IoZGVmYXVsdHMpIHtcbiAgICAgICAgc3VwZXIoZGVmYXVsdHMpO1xuICAgICAgICB0aGlzLnR5cGUgPSAnZGVjbCc7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQG1lbWJlcm9mIERlY2xhcmF0aW9uI1xuICAgICAqIEBtZW1iZXIge3N0cmluZ30gcHJvcCAtIHRoZSBkZWNsYXJhdGlvbuKAmXMgcHJvcGVydHkgbmFtZVxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiBjb25zdCByb290ID0gcG9zdGNzcy5wYXJzZSgnYSB7IGNvbG9yOiBibGFjayB9Jyk7XG4gICAgICogY29uc3QgZGVjbCA9IHJvb3QuZmlyc3QuZmlyc3Q7XG4gICAgICogZGVjbC5wcm9wIC8vPT4gJ2NvbG9yJ1xuICAgICAqL1xuXG4gICAgLyoqXG4gICAgICogQG1lbWJlcm9mIERlY2xhcmF0aW9uI1xuICAgICAqIEBtZW1iZXIge3N0cmluZ30gdmFsdWUgLSB0aGUgZGVjbGFyYXRpb27igJlzIHZhbHVlXG4gICAgICpcbiAgICAgKiBAZXhhbXBsZVxuICAgICAqIGNvbnN0IHJvb3QgPSBwb3N0Y3NzLnBhcnNlKCdhIHsgY29sb3I6IGJsYWNrIH0nKTtcbiAgICAgKiBjb25zdCBkZWNsID0gcm9vdC5maXJzdC5maXJzdDtcbiAgICAgKiBkZWNsLnZhbHVlIC8vPT4gJ2JsYWNrJ1xuICAgICAqL1xuXG4gICAgLyoqXG4gICAgICogQG1lbWJlcm9mIERlY2xhcmF0aW9uI1xuICAgICAqIEBtZW1iZXIge2Jvb2xlYW59IGltcG9ydGFudCAtIGB0cnVlYCBpZiB0aGUgZGVjbGFyYXRpb25cbiAgICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBoYXMgYW4gIWltcG9ydGFudCBhbm5vdGF0aW9uLlxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiBjb25zdCByb290ID0gcG9zdGNzcy5wYXJzZSgnYSB7IGNvbG9yOiBibGFjayAhaW1wb3J0YW50OyBjb2xvcjogcmVkIH0nKTtcbiAgICAgKiByb290LmZpcnN0LmZpcnN0LmltcG9ydGFudCAvLz0+IHRydWVcbiAgICAgKiByb290LmZpcnN0Lmxhc3QuaW1wb3J0YW50ICAvLz0+IHVuZGVmaW5lZFxuICAgICAqL1xuXG4gICAgLyoqXG4gICAgICogQG1lbWJlcm9mIERlY2xhcmF0aW9uI1xuICAgICAqIEBtZW1iZXIge29iamVjdH0gcmF3cyAtIEluZm9ybWF0aW9uIHRvIGdlbmVyYXRlIGJ5dGUtdG8tYnl0ZSBlcXVhbFxuICAgICAqICAgICAgICAgICAgICAgICAgICAgICAgIG5vZGUgc3RyaW5nIGFzIGl0IHdhcyBpbiB0aGUgb3JpZ2luIGlucHV0LlxuICAgICAqXG4gICAgICogRXZlcnkgcGFyc2VyIHNhdmVzIGl0cyBvd24gcHJvcGVydGllcyxcbiAgICAgKiBidXQgdGhlIGRlZmF1bHQgQ1NTIHBhcnNlciB1c2VzOlxuICAgICAqXG4gICAgICogKiBgYmVmb3JlYDogdGhlIHNwYWNlIHN5bWJvbHMgYmVmb3JlIHRoZSBub2RlLiBJdCBhbHNvIHN0b3JlcyBgKmBcbiAgICAgKiAgIGFuZCBgX2Agc3ltYm9scyBiZWZvcmUgdGhlIGRlY2xhcmF0aW9uIChJRSBoYWNrKS5cbiAgICAgKiAqIGBiZXR3ZWVuYDogdGhlIHN5bWJvbHMgYmV0d2VlbiB0aGUgcHJvcGVydHkgYW5kIHZhbHVlXG4gICAgICogICBmb3IgZGVjbGFyYXRpb25zLlxuICAgICAqICogYGltcG9ydGFudGA6IHRoZSBjb250ZW50IG9mIHRoZSBpbXBvcnRhbnQgc3RhdGVtZW50LFxuICAgICAqICAgaWYgaXQgaXMgbm90IGp1c3QgYCFpbXBvcnRhbnRgLlxuICAgICAqXG4gICAgICogUG9zdENTUyBjbGVhbnMgZGVjbGFyYXRpb24gZnJvbSBjb21tZW50cyBhbmQgZXh0cmEgc3BhY2VzLFxuICAgICAqIGJ1dCBpdCBzdG9yZXMgb3JpZ2luIGNvbnRlbnQgaW4gcmF3cyBwcm9wZXJ0aWVzLlxuICAgICAqIEFzIHN1Y2gsIGlmIHlvdSBkb27igJl0IGNoYW5nZSBhIGRlY2xhcmF0aW9u4oCZcyB2YWx1ZSxcbiAgICAgKiBQb3N0Q1NTIHdpbGwgdXNlIHRoZSByYXcgdmFsdWUgd2l0aCBjb21tZW50cy5cbiAgICAgKlxuICAgICAqIEBleGFtcGxlXG4gICAgICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2Ege1xcbiAgY29sb3I6YmxhY2tcXG59JylcbiAgICAgKiByb290LmZpcnN0LmZpcnN0LnJhd3MgLy89PiB7IGJlZm9yZTogJ1xcbiAgJywgYmV0d2VlbjogJzonIH1cbiAgICAgKi9cblxufVxuXG5leHBvcnQgZGVmYXVsdCBEZWNsYXJhdGlvbjtcbiJdfQ==
102
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRlY2xhcmF0aW9uLmVzNiJdLCJuYW1lcyI6WyJEZWNsYXJhdGlvbiIsImRlZmF1bHRzIiwidHlwZSIsIk5vZGUiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7Ozs7Ozs7Ozs7O0FBRUE7Ozs7Ozs7Ozs7O0lBV01BLFc7OztBQUNKLHVCQUFhQyxRQUFiLEVBQXVCO0FBQUE7O0FBQUEsaURBQ3JCLGlCQUFNQSxRQUFOLENBRHFCOztBQUVyQixVQUFLQyxJQUFMLEdBQVksTUFBWjtBQUZxQjtBQUd0Qjs7QUFFRDs7Ozs7Ozs7OztBQVVBOzs7Ozs7Ozs7O0FBVUE7Ozs7Ozs7Ozs7O0FBV0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztFQXJDd0JDLGM7O2tCQStEWEgsVyIsImZpbGUiOiJkZWNsYXJhdGlvbi5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBOb2RlIGZyb20gJy4vbm9kZSdcblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgQ1NTIGRlY2xhcmF0aW9uLlxuICpcbiAqIEBleHRlbmRzIE5vZGVcbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2EgeyBjb2xvcjogYmxhY2sgfScpXG4gKiBjb25zdCBkZWNsID0gcm9vdC5maXJzdC5maXJzdFxuICogZGVjbC50eXBlICAgICAgIC8vPT4gJ2RlY2wnXG4gKiBkZWNsLnRvU3RyaW5nKCkgLy89PiAnIGNvbG9yOiBibGFjaydcbiAqL1xuY2xhc3MgRGVjbGFyYXRpb24gZXh0ZW5kcyBOb2RlIHtcbiAgY29uc3RydWN0b3IgKGRlZmF1bHRzKSB7XG4gICAgc3VwZXIoZGVmYXVsdHMpXG4gICAgdGhpcy50eXBlID0gJ2RlY2wnXG4gIH1cblxuICAvKipcbiAgICogQG1lbWJlcm9mIERlY2xhcmF0aW9uI1xuICAgKiBAbWVtYmVyIHtzdHJpbmd9IHByb3AgVGhlIGRlY2xhcmF0aW9u4oCZcyBwcm9wZXJ0eSBuYW1lLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBjb25zdCByb290ID0gcG9zdGNzcy5wYXJzZSgnYSB7IGNvbG9yOiBibGFjayB9JylcbiAgICogY29uc3QgZGVjbCA9IHJvb3QuZmlyc3QuZmlyc3RcbiAgICogZGVjbC5wcm9wIC8vPT4gJ2NvbG9yJ1xuICAgKi9cblxuICAvKipcbiAgICogQG1lbWJlcm9mIERlY2xhcmF0aW9uI1xuICAgKiBAbWVtYmVyIHtzdHJpbmd9IHZhbHVlIFRoZSBkZWNsYXJhdGlvbuKAmXMgdmFsdWUuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGNvbnN0IHJvb3QgPSBwb3N0Y3NzLnBhcnNlKCdhIHsgY29sb3I6IGJsYWNrIH0nKVxuICAgKiBjb25zdCBkZWNsID0gcm9vdC5maXJzdC5maXJzdFxuICAgKiBkZWNsLnZhbHVlIC8vPT4gJ2JsYWNrJ1xuICAgKi9cblxuICAvKipcbiAgICogQG1lbWJlcm9mIERlY2xhcmF0aW9uI1xuICAgKiBAbWVtYmVyIHtib29sZWFufSBpbXBvcnRhbnQgYHRydWVgIGlmIHRoZSBkZWNsYXJhdGlvblxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaGFzIGFuICFpbXBvcnRhbnQgYW5ub3RhdGlvbi5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2EgeyBjb2xvcjogYmxhY2sgIWltcG9ydGFudDsgY29sb3I6IHJlZCB9JylcbiAgICogcm9vdC5maXJzdC5maXJzdC5pbXBvcnRhbnQgLy89PiB0cnVlXG4gICAqIHJvb3QuZmlyc3QubGFzdC5pbXBvcnRhbnQgIC8vPT4gdW5kZWZpbmVkXG4gICAqL1xuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgRGVjbGFyYXRpb24jXG4gICAqIEBtZW1iZXIge29iamVjdH0gcmF3cyBJbmZvcm1hdGlvbiB0byBnZW5lcmF0ZSBieXRlLXRvLWJ5dGUgZXF1YWxcbiAgICogICAgICAgICAgICAgICAgICAgICAgIG5vZGUgc3RyaW5nIGFzIGl0IHdhcyBpbiB0aGUgb3JpZ2luIGlucHV0LlxuICAgKlxuICAgKiBFdmVyeSBwYXJzZXIgc2F2ZXMgaXRzIG93biBwcm9wZXJ0aWVzLFxuICAgKiBidXQgdGhlIGRlZmF1bHQgQ1NTIHBhcnNlciB1c2VzOlxuICAgKlxuICAgKiAqIGBiZWZvcmVgOiB0aGUgc3BhY2Ugc3ltYm9scyBiZWZvcmUgdGhlIG5vZGUuIEl0IGFsc28gc3RvcmVzIGAqYFxuICAgKiAgIGFuZCBgX2Agc3ltYm9scyBiZWZvcmUgdGhlIGRlY2xhcmF0aW9uIChJRSBoYWNrKS5cbiAgICogKiBgYmV0d2VlbmA6IHRoZSBzeW1ib2xzIGJldHdlZW4gdGhlIHByb3BlcnR5IGFuZCB2YWx1ZVxuICAgKiAgIGZvciBkZWNsYXJhdGlvbnMuXG4gICAqICogYGltcG9ydGFudGA6IHRoZSBjb250ZW50IG9mIHRoZSBpbXBvcnRhbnQgc3RhdGVtZW50LFxuICAgKiAgIGlmIGl0IGlzIG5vdCBqdXN0IGAhaW1wb3J0YW50YC5cbiAgICpcbiAgICogUG9zdENTUyBjbGVhbnMgZGVjbGFyYXRpb24gZnJvbSBjb21tZW50cyBhbmQgZXh0cmEgc3BhY2VzLFxuICAgKiBidXQgaXQgc3RvcmVzIG9yaWdpbiBjb250ZW50IGluIHJhd3MgcHJvcGVydGllcy5cbiAgICogQXMgc3VjaCwgaWYgeW91IGRvbuKAmXQgY2hhbmdlIGEgZGVjbGFyYXRpb27igJlzIHZhbHVlLFxuICAgKiBQb3N0Q1NTIHdpbGwgdXNlIHRoZSByYXcgdmFsdWUgd2l0aCBjb21tZW50cy5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2Ege1xcbiAgY29sb3I6YmxhY2tcXG59JylcbiAgICogcm9vdC5maXJzdC5maXJzdC5yYXdzIC8vPT4geyBiZWZvcmU6ICdcXG4gICcsIGJldHdlZW46ICc6JyB9XG4gICAqL1xufVxuXG5leHBvcnQgZGVmYXVsdCBEZWNsYXJhdGlvblxuIl19