postcss 6.0.22 → 7.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of postcss might be problematic. Click here for more details.
- package/CHANGELOG.md +18 -0
- package/README-cn.md +54 -51
- package/README.md +60 -52
- package/docs/architecture.md +2 -2
- package/docs/guidelines/plugin.md +28 -28
- package/docs/guidelines/runner.md +21 -21
- package/docs/source-maps.md +11 -11
- package/docs/syntax.md +23 -23
- package/gulpfile.js +78 -74
- package/lib/at-rule.js +14 -14
- package/lib/comment.js +4 -4
- package/lib/container.js +773 -801
- package/lib/css-syntax-error.js +197 -180
- package/lib/declaration.js +15 -14
- package/lib/input.js +149 -143
- package/lib/lazy-result.js +364 -337
- package/lib/list.js +69 -70
- package/lib/map-generator.js +270 -275
- package/lib/node.js +558 -570
- package/lib/parse.js +20 -21
- package/lib/parser.js +476 -479
- package/lib/postcss.d.ts +1246 -1246
- package/lib/postcss.js +61 -57
- package/lib/previous-map.js +117 -122
- package/lib/processor.js +96 -75
- package/lib/result.js +70 -64
- package/lib/root.js +91 -90
- package/lib/rule.js +12 -12
- package/lib/stringifier.js +295 -295
- package/lib/stringify.js +5 -4
- package/lib/terminal-highlight.js +50 -50
- package/lib/tokenize.js +259 -259
- package/lib/vendor.js +27 -27
- package/lib/warn-once.js +6 -4
- package/lib/warning.js +30 -26
- package/package.json +4 -3
- package/CONTRIBUTING.md +0 -78
package/lib/css-syntax-error.js
CHANGED
@@ -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 (
|
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
|
-
*
|
52
|
-
*
|
53
|
-
*
|
54
|
-
*
|
55
|
-
*
|
56
|
-
* @
|
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
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
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
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
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
|
-
|
142
|
+
this.setMessage();
|
131
143
|
|
132
|
-
|
133
|
-
|
134
|
-
}
|
144
|
+
if (Error.captureStackTrace) {
|
145
|
+
Error.captureStackTrace(this, CssSyntaxError);
|
135
146
|
}
|
147
|
+
}
|
136
148
|
|
137
|
-
|
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
|
-
*
|
151
|
+
* Full error text in the GNU error format
|
152
|
+
* with plugin, file, line and column.
|
155
153
|
*
|
156
|
-
*
|
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.
|
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
|
-
|
190
|
+
CssSyntaxError.prototype.showSourceCode = function showSourceCode(color) {
|
191
|
+
var _this = this;
|
180
192
|
|
181
|
-
|
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
|
-
|
186
|
-
|
187
|
-
|
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
|
-
|
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
|
-
|
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
|
-
|
207
|
-
|
208
|
-
|
209
|
-
|
210
|
-
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
|
215
|
-
|
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
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
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
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
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
|
-
|
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"]}
|
package/lib/declaration.js
CHANGED
@@ -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
|
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
|
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
|
63
|
-
*
|
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
|
74
|
-
*
|
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,
|
102
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRlY2xhcmF0aW9uLmVzNiJdLCJuYW1lcyI6WyJEZWNsYXJhdGlvbiIsImRlZmF1bHRzIiwidHlwZSIsIk5vZGUiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7Ozs7Ozs7Ozs7O0FBRUE7Ozs7Ozs7Ozs7O0lBV01BLFc7OztBQUNKLHVCQUFhQyxRQUFiLEVBQXVCO0FBQUE7O0FBQUEsaURBQ3JCLGlCQUFNQSxRQUFOLENBRHFCOztBQUVyQixVQUFLQyxJQUFMLEdBQVksTUFBWjtBQUZxQjtBQUd0Qjs7QUFFRDs7Ozs7Ozs7OztBQVVBOzs7Ozs7Ozs7O0FBVUE7Ozs7Ozs7Ozs7O0FBV0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztFQXJDd0JDLGM7O2tCQStEWEgsVyIsImZpbGUiOiJkZWNsYXJhdGlvbi5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBOb2RlIGZyb20gJy4vbm9kZSdcblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgQ1NTIGRlY2xhcmF0aW9uLlxuICpcbiAqIEBleHRlbmRzIE5vZGVcbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2EgeyBjb2xvcjogYmxhY2sgfScpXG4gKiBjb25zdCBkZWNsID0gcm9vdC5maXJzdC5maXJzdFxuICogZGVjbC50eXBlICAgICAgIC8vPT4gJ2RlY2wnXG4gKiBkZWNsLnRvU3RyaW5nKCkgLy89PiAnIGNvbG9yOiBibGFjaydcbiAqL1xuY2xhc3MgRGVjbGFyYXRpb24gZXh0ZW5kcyBOb2RlIHtcbiAgY29uc3RydWN0b3IgKGRlZmF1bHRzKSB7XG4gICAgc3VwZXIoZGVmYXVsdHMpXG4gICAgdGhpcy50eXBlID0gJ2RlY2wnXG4gIH1cblxuICAvKipcbiAgICogQG1lbWJlcm9mIERlY2xhcmF0aW9uI1xuICAgKiBAbWVtYmVyIHtzdHJpbmd9IHByb3AgVGhlIGRlY2xhcmF0aW9u4oCZcyBwcm9wZXJ0eSBuYW1lLlxuICAgKlxuICAgKiBAZXhhbXBsZVxuICAgKiBjb25zdCByb290ID0gcG9zdGNzcy5wYXJzZSgnYSB7IGNvbG9yOiBibGFjayB9JylcbiAgICogY29uc3QgZGVjbCA9IHJvb3QuZmlyc3QuZmlyc3RcbiAgICogZGVjbC5wcm9wIC8vPT4gJ2NvbG9yJ1xuICAgKi9cblxuICAvKipcbiAgICogQG1lbWJlcm9mIERlY2xhcmF0aW9uI1xuICAgKiBAbWVtYmVyIHtzdHJpbmd9IHZhbHVlIFRoZSBkZWNsYXJhdGlvbuKAmXMgdmFsdWUuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGNvbnN0IHJvb3QgPSBwb3N0Y3NzLnBhcnNlKCdhIHsgY29sb3I6IGJsYWNrIH0nKVxuICAgKiBjb25zdCBkZWNsID0gcm9vdC5maXJzdC5maXJzdFxuICAgKiBkZWNsLnZhbHVlIC8vPT4gJ2JsYWNrJ1xuICAgKi9cblxuICAvKipcbiAgICogQG1lbWJlcm9mIERlY2xhcmF0aW9uI1xuICAgKiBAbWVtYmVyIHtib29sZWFufSBpbXBvcnRhbnQgYHRydWVgIGlmIHRoZSBkZWNsYXJhdGlvblxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaGFzIGFuICFpbXBvcnRhbnQgYW5ub3RhdGlvbi5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2EgeyBjb2xvcjogYmxhY2sgIWltcG9ydGFudDsgY29sb3I6IHJlZCB9JylcbiAgICogcm9vdC5maXJzdC5maXJzdC5pbXBvcnRhbnQgLy89PiB0cnVlXG4gICAqIHJvb3QuZmlyc3QubGFzdC5pbXBvcnRhbnQgIC8vPT4gdW5kZWZpbmVkXG4gICAqL1xuXG4gIC8qKlxuICAgKiBAbWVtYmVyb2YgRGVjbGFyYXRpb24jXG4gICAqIEBtZW1iZXIge29iamVjdH0gcmF3cyBJbmZvcm1hdGlvbiB0byBnZW5lcmF0ZSBieXRlLXRvLWJ5dGUgZXF1YWxcbiAgICogICAgICAgICAgICAgICAgICAgICAgIG5vZGUgc3RyaW5nIGFzIGl0IHdhcyBpbiB0aGUgb3JpZ2luIGlucHV0LlxuICAgKlxuICAgKiBFdmVyeSBwYXJzZXIgc2F2ZXMgaXRzIG93biBwcm9wZXJ0aWVzLFxuICAgKiBidXQgdGhlIGRlZmF1bHQgQ1NTIHBhcnNlciB1c2VzOlxuICAgKlxuICAgKiAqIGBiZWZvcmVgOiB0aGUgc3BhY2Ugc3ltYm9scyBiZWZvcmUgdGhlIG5vZGUuIEl0IGFsc28gc3RvcmVzIGAqYFxuICAgKiAgIGFuZCBgX2Agc3ltYm9scyBiZWZvcmUgdGhlIGRlY2xhcmF0aW9uIChJRSBoYWNrKS5cbiAgICogKiBgYmV0d2VlbmA6IHRoZSBzeW1ib2xzIGJldHdlZW4gdGhlIHByb3BlcnR5IGFuZCB2YWx1ZVxuICAgKiAgIGZvciBkZWNsYXJhdGlvbnMuXG4gICAqICogYGltcG9ydGFudGA6IHRoZSBjb250ZW50IG9mIHRoZSBpbXBvcnRhbnQgc3RhdGVtZW50LFxuICAgKiAgIGlmIGl0IGlzIG5vdCBqdXN0IGAhaW1wb3J0YW50YC5cbiAgICpcbiAgICogUG9zdENTUyBjbGVhbnMgZGVjbGFyYXRpb24gZnJvbSBjb21tZW50cyBhbmQgZXh0cmEgc3BhY2VzLFxuICAgKiBidXQgaXQgc3RvcmVzIG9yaWdpbiBjb250ZW50IGluIHJhd3MgcHJvcGVydGllcy5cbiAgICogQXMgc3VjaCwgaWYgeW91IGRvbuKAmXQgY2hhbmdlIGEgZGVjbGFyYXRpb27igJlzIHZhbHVlLFxuICAgKiBQb3N0Q1NTIHdpbGwgdXNlIHRoZSByYXcgdmFsdWUgd2l0aCBjb21tZW50cy5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogY29uc3Qgcm9vdCA9IHBvc3Rjc3MucGFyc2UoJ2Ege1xcbiAgY29sb3I6YmxhY2tcXG59JylcbiAgICogcm9vdC5maXJzdC5maXJzdC5yYXdzIC8vPT4geyBiZWZvcmU6ICdcXG4gICcsIGJldHdlZW46ICc6JyB9XG4gICAqL1xufVxuXG5leHBvcnQgZGVmYXVsdCBEZWNsYXJhdGlvblxuIl19
|