postcss 7.0.1 → 7.0.5
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 +14 -1
- package/docs/architecture.md +5 -5
- package/docs/guidelines/plugin.md +10 -10
- package/docs/guidelines/runner.md +2 -2
- package/lib/at-rule.js +21 -23
- package/lib/comment.js +15 -19
- package/lib/container.js +195 -205
- package/lib/css-syntax-error.js +42 -39
- package/lib/declaration.js +15 -19
- package/lib/input.js +53 -50
- package/lib/lazy-result.js +58 -76
- package/lib/list.js +8 -10
- package/lib/map-generator.js +110 -80
- package/lib/node.js +84 -89
- package/lib/parse.js +12 -12
- package/lib/parser.js +162 -104
- package/lib/postcss.d.ts +1 -1
- package/lib/postcss.js +43 -54
- package/lib/previous-map.js +42 -46
- package/lib/processor.js +32 -30
- package/lib/result.js +29 -26
- package/lib/root.js +24 -25
- package/lib/rule.js +20 -25
- package/lib/stringifier.js +72 -53
- package/lib/stringify.js +8 -8
- package/lib/terminal-highlight.js +30 -29
- package/lib/tokenize.js +57 -73
- package/lib/vendor.js +10 -9
- package/lib/warn-once.js +4 -3
- package/lib/warning.js +24 -17
- package/package.json +4 -3
- package/README-cn.md +0 -349
- package/gulpfile.js +0 -101
package/lib/node.js
CHANGED
@@ -1,32 +1,23 @@
|
|
1
|
-
|
1
|
+
"use strict";
|
2
2
|
|
3
3
|
exports.__esModule = true;
|
4
|
+
exports.default = void 0;
|
4
5
|
|
5
|
-
var
|
6
|
+
var _cssSyntaxError = _interopRequireDefault(require("./css-syntax-error"));
|
6
7
|
|
7
|
-
var
|
8
|
+
var _stringifier = _interopRequireDefault(require("./stringifier"));
|
8
9
|
|
9
|
-
var
|
10
|
-
|
11
|
-
var _stringifier = require('./stringifier');
|
12
|
-
|
13
|
-
var _stringifier2 = _interopRequireDefault(_stringifier);
|
14
|
-
|
15
|
-
var _stringify = require('./stringify');
|
16
|
-
|
17
|
-
var _stringify2 = _interopRequireDefault(_stringify);
|
10
|
+
var _stringify = _interopRequireDefault(require("./stringify"));
|
18
11
|
|
19
12
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
20
13
|
|
21
|
-
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
22
|
-
|
23
14
|
function cloneNode(obj, parent) {
|
24
15
|
var cloned = new obj.constructor();
|
25
16
|
|
26
17
|
for (var i in obj) {
|
27
18
|
if (!obj.hasOwnProperty(i)) continue;
|
28
19
|
var value = obj[i];
|
29
|
-
var type = typeof value
|
20
|
+
var type = typeof value;
|
30
21
|
|
31
22
|
if (i === 'parent' && type === 'object') {
|
32
23
|
if (parent) cloned[i] = parent;
|
@@ -44,33 +35,36 @@ function cloneNode(obj, parent) {
|
|
44
35
|
|
45
36
|
return cloned;
|
46
37
|
}
|
47
|
-
|
48
38
|
/**
|
49
39
|
* All node classes inherit the following common methods.
|
50
40
|
*
|
51
41
|
* @abstract
|
52
42
|
*/
|
53
43
|
|
54
|
-
|
44
|
+
|
45
|
+
var Node =
|
46
|
+
/*#__PURE__*/
|
47
|
+
function () {
|
55
48
|
/**
|
56
49
|
* @param {object} [defaults] Value for node properties.
|
57
50
|
*/
|
58
|
-
function Node() {
|
59
|
-
|
60
|
-
|
61
|
-
|
51
|
+
function Node(defaults) {
|
52
|
+
if (defaults === void 0) {
|
53
|
+
defaults = {};
|
54
|
+
}
|
62
55
|
|
63
56
|
this.raws = {};
|
57
|
+
|
64
58
|
if (process.env.NODE_ENV !== 'production') {
|
65
|
-
if (
|
59
|
+
if (typeof defaults !== 'object' && typeof defaults !== 'undefined') {
|
66
60
|
throw new Error('PostCSS nodes constructor accepts object, not ' + JSON.stringify(defaults));
|
67
61
|
}
|
68
62
|
}
|
63
|
+
|
69
64
|
for (var name in defaults) {
|
70
65
|
this[name] = defaults[name];
|
71
66
|
}
|
72
67
|
}
|
73
|
-
|
74
68
|
/**
|
75
69
|
* Returns a `CssSyntaxError` instance containing the original position
|
76
70
|
* of the node in the source, showing line and column numbers and also
|
@@ -105,17 +99,20 @@ var Node = function () {
|
|
105
99
|
*/
|
106
100
|
|
107
101
|
|
108
|
-
Node.prototype
|
109
|
-
|
102
|
+
var _proto = Node.prototype;
|
103
|
+
|
104
|
+
_proto.error = function error(message, opts) {
|
105
|
+
if (opts === void 0) {
|
106
|
+
opts = {};
|
107
|
+
}
|
110
108
|
|
111
109
|
if (this.source) {
|
112
110
|
var pos = this.positionBy(opts);
|
113
111
|
return this.source.input.error(message, pos.line, pos.column, opts);
|
114
|
-
} else {
|
115
|
-
return new _cssSyntaxError2.default(message);
|
116
112
|
}
|
117
|
-
};
|
118
113
|
|
114
|
+
return new _cssSyntaxError.default(message);
|
115
|
+
};
|
119
116
|
/**
|
120
117
|
* This method is provided as a convenience wrapper for {@link Result#warn}.
|
121
118
|
*
|
@@ -143,13 +140,17 @@ var Node = function () {
|
|
143
140
|
*/
|
144
141
|
|
145
142
|
|
146
|
-
|
147
|
-
var data = {
|
143
|
+
_proto.warn = function warn(result, text, opts) {
|
144
|
+
var data = {
|
145
|
+
node: this
|
146
|
+
};
|
147
|
+
|
148
148
|
for (var i in opts) {
|
149
149
|
data[i] = opts[i];
|
150
|
-
}
|
151
|
-
};
|
150
|
+
}
|
152
151
|
|
152
|
+
return result.warn(text, data);
|
153
|
+
};
|
153
154
|
/**
|
154
155
|
* Removes the node from its parent and cleans the parent properties
|
155
156
|
* from the node and its children.
|
@@ -163,14 +164,14 @@ var Node = function () {
|
|
163
164
|
*/
|
164
165
|
|
165
166
|
|
166
|
-
|
167
|
+
_proto.remove = function remove() {
|
167
168
|
if (this.parent) {
|
168
169
|
this.parent.removeChild(this);
|
169
170
|
}
|
171
|
+
|
170
172
|
this.parent = undefined;
|
171
173
|
return this;
|
172
174
|
};
|
173
|
-
|
174
175
|
/**
|
175
176
|
* Returns a CSS string representing the node.
|
176
177
|
*
|
@@ -184,8 +185,10 @@ var Node = function () {
|
|
184
185
|
*/
|
185
186
|
|
186
187
|
|
187
|
-
|
188
|
-
|
188
|
+
_proto.toString = function toString(stringifier) {
|
189
|
+
if (stringifier === void 0) {
|
190
|
+
stringifier = _stringify.default;
|
191
|
+
}
|
189
192
|
|
190
193
|
if (stringifier.stringify) stringifier = stringifier.stringify;
|
191
194
|
var result = '';
|
@@ -194,7 +197,6 @@ var Node = function () {
|
|
194
197
|
});
|
195
198
|
return result;
|
196
199
|
};
|
197
|
-
|
198
200
|
/**
|
199
201
|
* Returns an exact clone of the node.
|
200
202
|
*
|
@@ -213,16 +215,19 @@ var Node = function () {
|
|
213
215
|
*/
|
214
216
|
|
215
217
|
|
216
|
-
|
217
|
-
|
218
|
+
_proto.clone = function clone(overrides) {
|
219
|
+
if (overrides === void 0) {
|
220
|
+
overrides = {};
|
221
|
+
}
|
218
222
|
|
219
223
|
var cloned = cloneNode(this);
|
224
|
+
|
220
225
|
for (var name in overrides) {
|
221
226
|
cloned[name] = overrides[name];
|
222
227
|
}
|
228
|
+
|
223
229
|
return cloned;
|
224
230
|
};
|
225
|
-
|
226
231
|
/**
|
227
232
|
* Shortcut to clone the node and insert the resulting cloned node
|
228
233
|
* before the current node.
|
@@ -236,14 +241,15 @@ var Node = function () {
|
|
236
241
|
*/
|
237
242
|
|
238
243
|
|
239
|
-
|
240
|
-
|
244
|
+
_proto.cloneBefore = function cloneBefore(overrides) {
|
245
|
+
if (overrides === void 0) {
|
246
|
+
overrides = {};
|
247
|
+
}
|
241
248
|
|
242
249
|
var cloned = this.clone(overrides);
|
243
250
|
this.parent.insertBefore(this, cloned);
|
244
251
|
return cloned;
|
245
252
|
};
|
246
|
-
|
247
253
|
/**
|
248
254
|
* Shortcut to clone the node and insert the resulting cloned node
|
249
255
|
* after the current node.
|
@@ -254,14 +260,15 @@ var Node = function () {
|
|
254
260
|
*/
|
255
261
|
|
256
262
|
|
257
|
-
|
258
|
-
|
263
|
+
_proto.cloneAfter = function cloneAfter(overrides) {
|
264
|
+
if (overrides === void 0) {
|
265
|
+
overrides = {};
|
266
|
+
}
|
259
267
|
|
260
268
|
var cloned = this.clone(overrides);
|
261
269
|
this.parent.insertAfter(this, cloned);
|
262
270
|
return cloned;
|
263
271
|
};
|
264
|
-
|
265
272
|
/**
|
266
273
|
* Inserts node(s) before the current node and removes the current node.
|
267
274
|
*
|
@@ -276,26 +283,14 @@ var Node = function () {
|
|
276
283
|
*/
|
277
284
|
|
278
285
|
|
279
|
-
|
286
|
+
_proto.replaceWith = function replaceWith() {
|
280
287
|
if (this.parent) {
|
281
|
-
for (var _len = arguments.length, nodes = Array(_len), _key = 0; _key < _len; _key++) {
|
288
|
+
for (var _len = arguments.length, nodes = new Array(_len), _key = 0; _key < _len; _key++) {
|
282
289
|
nodes[_key] = arguments[_key];
|
283
290
|
}
|
284
291
|
|
285
|
-
for (var
|
286
|
-
var
|
287
|
-
|
288
|
-
if (_isArray) {
|
289
|
-
if (_i >= _iterator.length) break;
|
290
|
-
_ref = _iterator[_i++];
|
291
|
-
} else {
|
292
|
-
_i = _iterator.next();
|
293
|
-
if (_i.done) break;
|
294
|
-
_ref = _i.value;
|
295
|
-
}
|
296
|
-
|
297
|
-
var node = _ref;
|
298
|
-
|
292
|
+
for (var _i = 0; _i < nodes.length; _i++) {
|
293
|
+
var node = nodes[_i];
|
299
294
|
this.parent.insertBefore(this, node);
|
300
295
|
}
|
301
296
|
|
@@ -304,7 +299,6 @@ var Node = function () {
|
|
304
299
|
|
305
300
|
return this;
|
306
301
|
};
|
307
|
-
|
308
302
|
/**
|
309
303
|
* Returns the next child of the node’s parent.
|
310
304
|
* Returns `undefined` if the current node is the last child.
|
@@ -321,12 +315,11 @@ var Node = function () {
|
|
321
315
|
*/
|
322
316
|
|
323
317
|
|
324
|
-
|
318
|
+
_proto.next = function next() {
|
325
319
|
if (!this.parent) return undefined;
|
326
320
|
var index = this.parent.index(this);
|
327
321
|
return this.parent.nodes[index + 1];
|
328
322
|
};
|
329
|
-
|
330
323
|
/**
|
331
324
|
* Returns the previous child of the node’s parent.
|
332
325
|
* Returns `undefined` if the current node is the first child.
|
@@ -341,12 +334,11 @@ var Node = function () {
|
|
341
334
|
*/
|
342
335
|
|
343
336
|
|
344
|
-
|
337
|
+
_proto.prev = function prev() {
|
345
338
|
if (!this.parent) return undefined;
|
346
339
|
var index = this.parent.index(this);
|
347
340
|
return this.parent.nodes[index - 1];
|
348
341
|
};
|
349
|
-
|
350
342
|
/**
|
351
343
|
* Insert new node before current node to current node’s parent.
|
352
344
|
*
|
@@ -361,11 +353,10 @@ var Node = function () {
|
|
361
353
|
*/
|
362
354
|
|
363
355
|
|
364
|
-
|
356
|
+
_proto.before = function before(add) {
|
365
357
|
this.parent.insertBefore(this, add);
|
366
358
|
return this;
|
367
359
|
};
|
368
|
-
|
369
360
|
/**
|
370
361
|
* Insert new node after current node to current node’s parent.
|
371
362
|
*
|
@@ -380,12 +371,12 @@ var Node = function () {
|
|
380
371
|
*/
|
381
372
|
|
382
373
|
|
383
|
-
|
374
|
+
_proto.after = function after(add) {
|
384
375
|
this.parent.insertAfter(this, add);
|
385
376
|
return this;
|
386
377
|
};
|
387
378
|
|
388
|
-
|
379
|
+
_proto.toJSON = function toJSON() {
|
389
380
|
var fixed = {};
|
390
381
|
|
391
382
|
for (var name in this) {
|
@@ -395,13 +386,13 @@ var Node = function () {
|
|
395
386
|
|
396
387
|
if (value instanceof Array) {
|
397
388
|
fixed[name] = value.map(function (i) {
|
398
|
-
if (
|
389
|
+
if (typeof i === 'object' && i.toJSON) {
|
399
390
|
return i.toJSON();
|
400
391
|
} else {
|
401
392
|
return i;
|
402
393
|
}
|
403
394
|
});
|
404
|
-
} else if (
|
395
|
+
} else if (typeof value === 'object' && value.toJSON) {
|
405
396
|
fixed[name] = value.toJSON();
|
406
397
|
} else {
|
407
398
|
fixed[name] = value;
|
@@ -410,7 +401,6 @@ var Node = function () {
|
|
410
401
|
|
411
402
|
return fixed;
|
412
403
|
};
|
413
|
-
|
414
404
|
/**
|
415
405
|
* Returns a {@link Node#raws} value. If the node is missing
|
416
406
|
* the code style property (because the node was manually built or cloned),
|
@@ -431,11 +421,10 @@ var Node = function () {
|
|
431
421
|
*/
|
432
422
|
|
433
423
|
|
434
|
-
|
435
|
-
var str = new
|
424
|
+
_proto.raw = function raw(prop, defaultType) {
|
425
|
+
var str = new _stringifier.default();
|
436
426
|
return str.raw(this, prop, defaultType);
|
437
427
|
};
|
438
|
-
|
439
428
|
/**
|
440
429
|
* Finds the Root instance of the node’s tree.
|
441
430
|
*
|
@@ -446,13 +435,15 @@ var Node = function () {
|
|
446
435
|
*/
|
447
436
|
|
448
437
|
|
449
|
-
|
438
|
+
_proto.root = function root() {
|
450
439
|
var result = this;
|
440
|
+
|
451
441
|
while (result.parent) {
|
452
442
|
result = result.parent;
|
453
|
-
}
|
454
|
-
};
|
443
|
+
}
|
455
444
|
|
445
|
+
return result;
|
446
|
+
};
|
456
447
|
/**
|
457
448
|
* Clear the code style properties for the node and its children.
|
458
449
|
*
|
@@ -467,13 +458,13 @@ var Node = function () {
|
|
467
458
|
*/
|
468
459
|
|
469
460
|
|
470
|
-
|
461
|
+
_proto.cleanRaws = function cleanRaws(keepBetween) {
|
471
462
|
delete this.raws.before;
|
472
463
|
delete this.raws.after;
|
473
464
|
if (!keepBetween) delete this.raws.between;
|
474
465
|
};
|
475
466
|
|
476
|
-
|
467
|
+
_proto.positionInside = function positionInside(index) {
|
477
468
|
var string = this.toString();
|
478
469
|
var column = this.source.start.column;
|
479
470
|
var line = this.source.start.line;
|
@@ -487,20 +478,24 @@ var Node = function () {
|
|
487
478
|
}
|
488
479
|
}
|
489
480
|
|
490
|
-
return {
|
481
|
+
return {
|
482
|
+
line: line,
|
483
|
+
column: column
|
484
|
+
};
|
491
485
|
};
|
492
486
|
|
493
|
-
|
487
|
+
_proto.positionBy = function positionBy(opts) {
|
494
488
|
var pos = this.source.start;
|
489
|
+
|
495
490
|
if (opts.index) {
|
496
491
|
pos = this.positionInside(opts.index);
|
497
492
|
} else if (opts.word) {
|
498
493
|
var index = this.toString().indexOf(opts.word);
|
499
494
|
if (index !== -1) pos = this.positionInside(index);
|
500
495
|
}
|
496
|
+
|
501
497
|
return pos;
|
502
498
|
};
|
503
|
-
|
504
499
|
/**
|
505
500
|
* @memberof Node#
|
506
501
|
* @member {string} type String representing the node’s type.
|
@@ -594,8 +589,7 @@ var Node = function () {
|
|
594
589
|
return Node;
|
595
590
|
}();
|
596
591
|
|
597
|
-
|
598
|
-
|
592
|
+
var _default = Node;
|
599
593
|
/**
|
600
594
|
* @typedef {object} position
|
601
595
|
* @property {number} line Source line in file.
|
@@ -609,5 +603,6 @@ exports.default = Node;
|
|
609
603
|
* @property {position} end The ending position of the node’s source.
|
610
604
|
*/
|
611
605
|
|
612
|
-
|
613
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["node.es6"],"names":["cloneNode","obj","parent","cloned","constructor","i","hasOwnProperty","value","type","Array","map","j","Node","defaults","raws","process","env","NODE_ENV","Error","JSON","stringify","name","error","message","opts","source","pos","positionBy","input","line","column","CssSyntaxError","warn","result","text","data","node","remove","removeChild","undefined","toString","stringifier","clone","overrides","cloneBefore","insertBefore","cloneAfter","insertAfter","replaceWith","nodes","next","index","prev","before","add","after","toJSON","fixed","raw","prop","defaultType","str","Stringifier","root","cleanRaws","keepBetween","between","positionInside","string","start","word","indexOf"],"mappings":"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","file":"node.js","sourcesContent":["import CssSyntaxError from './css-syntax-error'\nimport Stringifier from './stringifier'\nimport stringify from './stringify'\n\nfunction cloneNode (obj, parent) {\n  const cloned = new obj.constructor()\n\n  for (const i in obj) {\n    if (!obj.hasOwnProperty(i)) continue\n    let value = obj[i]\n    const type = typeof value\n\n    if (i === 'parent' && type === 'object') {\n      if (parent) cloned[i] = parent\n    } else if (i === 'source') {\n      cloned[i] = value\n    } else if (value instanceof Array) {\n      cloned[i] = value.map(j => cloneNode(j, cloned))\n    } else {\n      if (type === 'object' && value !== null) value = cloneNode(value)\n      cloned[i] = value\n    }\n  }\n\n  return cloned\n}\n\n/**\n * All node classes inherit the following common methods.\n *\n * @abstract\n */\nclass Node {\n  /**\n   * @param {object} [defaults] Value for node properties.\n   */\n  constructor (defaults = { }) {\n    this.raws = { }\n    if (process.env.NODE_ENV !== 'production') {\n      if (typeof defaults !== 'object' && typeof defaults !== 'undefined') {\n        throw new Error(\n          'PostCSS nodes constructor accepts object, not ' +\n          JSON.stringify(defaults)\n        )\n      }\n    }\n    for (const name in defaults) {\n      this[name] = defaults[name]\n    }\n  }\n\n  /**\n   * Returns a `CssSyntaxError` instance containing the original position\n   * of the node in the source, showing line and column numbers and also\n   * a small excerpt to facilitate debugging.\n   *\n   * If present, an input source map will be used to get the original position\n   * of the source, even from a previous compilation step\n   * (e.g., from Sass compilation).\n   *\n   * This method produces very useful error messages.\n   *\n   * @param {string} message     Error description.\n   * @param {object} [opts]      Options.\n   * @param {string} opts.plugin Plugin name that created this error.\n   *                             PostCSS will set it automatically.\n   * @param {string} opts.word   A word inside a node’s string that should\n   *                             be highlighted as the source of the error.\n   * @param {number} opts.index  An index inside a node’s string that should\n   *                             be highlighted as the source of the error.\n   *\n   * @return {CssSyntaxError} Error object to throw it.\n   *\n   * @example\n   * if (!variables[name]) {\n   *   throw decl.error('Unknown variable ' + name, { word: name })\n   *   // CssSyntaxError: postcss-vars:a.sass:4:3: Unknown variable $black\n   *   //   color: $black\n   *   // a\n   *   //          ^\n   *   //   background: white\n   * }\n   */\n  error (message, opts = { }) {\n    if (this.source) {\n      const pos = this.positionBy(opts)\n      return this.source.input.error(message, pos.line, pos.column, opts)\n    } else {\n      return new CssSyntaxError(message)\n    }\n  }\n\n  /**\n   * This method is provided as a convenience wrapper for {@link Result#warn}.\n   *\n   * @param {Result} result      The {@link Result} instance\n   *                             that will receive the warning.\n   * @param {string} text        Warning message.\n   * @param {object} [opts]      Options\n   * @param {string} opts.plugin Plugin name that created this warning.\n   *                             PostCSS will set it automatically.\n   * @param {string} opts.word   A word inside a node’s string that should\n   *                             be highlighted as the source of the warning.\n   * @param {number} opts.index  An index inside a node’s string that should\n   *                             be highlighted as the source of the warning.\n   *\n   * @return {Warning} Created warning object.\n   *\n   * @example\n   * const plugin = postcss.plugin('postcss-deprecated', () => {\n   *   return (root, result) => {\n   *     root.walkDecls('bad', decl => {\n   *       decl.warn(result, 'Deprecated property bad')\n   *     })\n   *   }\n   * })\n   */\n  warn (result, text, opts) {\n    const data = { node: this }\n    for (const i in opts) data[i] = opts[i]\n    return result.warn(text, data)\n  }\n\n  /**\n   * Removes the node from its parent and cleans the parent properties\n   * from the node and its children.\n   *\n   * @example\n   * if (decl.prop.match(/^-webkit-/)) {\n   *   decl.remove()\n   * }\n   *\n   * @return {Node} Node to make calls chain.\n   */\n  remove () {\n    if (this.parent) {\n      this.parent.removeChild(this)\n    }\n    this.parent = undefined\n    return this\n  }\n\n  /**\n   * Returns a CSS string representing the node.\n   *\n   * @param {stringifier|syntax} [stringifier] A syntax to use\n   *                                           in string generation.\n   *\n   * @return {string} CSS string of this node.\n   *\n   * @example\n   * postcss.rule({ selector: 'a' }).toString() //=> \"a {}\"\n   */\n  toString (stringifier = stringify) {\n    if (stringifier.stringify) stringifier = stringifier.stringify\n    let result = ''\n    stringifier(this, i => {\n      result += i\n    })\n    return result\n  }\n\n  /**\n   * Returns an exact clone of the node.\n   *\n   * The resulting cloned node and its (cloned) children will retain\n   * code style properties.\n   *\n   * @param {object} [overrides] New properties to override in the clone.\n   *\n   * @example\n   * decl.raws.before    //=> \"\\n  \"\n   * const cloned = decl.clone({ prop: '-moz-' + decl.prop })\n   * cloned.raws.before  //=> \"\\n  \"\n   * cloned.toString()   //=> -moz-transform: scale(0)\n   *\n   * @return {Node} Clone of the node.\n   */\n  clone (overrides = { }) {\n    const cloned = cloneNode(this)\n    for (const name in overrides) {\n      cloned[name] = overrides[name]\n    }\n    return cloned\n  }\n\n  /**\n   * Shortcut to clone the node and insert the resulting cloned node\n   * before the current node.\n   *\n   * @param {object} [overrides] Mew properties to override in the clone.\n   *\n   * @example\n   * decl.cloneBefore({ prop: '-moz-' + decl.prop })\n   *\n   * @return {Node} New node\n   */\n  cloneBefore (overrides = { }) {\n    const cloned = this.clone(overrides)\n    this.parent.insertBefore(this, cloned)\n    return cloned\n  }\n\n  /**\n   * Shortcut to clone the node and insert the resulting cloned node\n   * after the current node.\n   *\n   * @param {object} [overrides] New properties to override in the clone.\n   *\n   * @return {Node} New node.\n   */\n  cloneAfter (overrides = { }) {\n    const cloned = this.clone(overrides)\n    this.parent.insertAfter(this, cloned)\n    return cloned\n  }\n\n  /**\n   * Inserts node(s) before the current node and removes the current node.\n   *\n   * @param {...Node} nodes Mode(s) to replace current one.\n   *\n   * @example\n   * if (atrule.name === 'mixin') {\n   *   atrule.replaceWith(mixinRules[atrule.params])\n   * }\n   *\n   * @return {Node} Current node to methods chain.\n   */\n  replaceWith (...nodes) {\n    if (this.parent) {\n      for (const node of nodes) {\n        this.parent.insertBefore(this, node)\n      }\n\n      this.remove()\n    }\n\n    return this\n  }\n\n  /**\n   * Returns the next child of the node’s parent.\n   * Returns `undefined` if the current node is the last child.\n   *\n   * @return {Node|undefined} Next node.\n   *\n   * @example\n   * if (comment.text === 'delete next') {\n   *   const next = comment.next()\n   *   if (next) {\n   *     next.remove()\n   *   }\n   * }\n   */\n  next () {\n    if (!this.parent) return undefined\n    const index = this.parent.index(this)\n    return this.parent.nodes[index + 1]\n  }\n\n  /**\n   * Returns the previous child of the node’s parent.\n   * Returns `undefined` if the current node is the first child.\n   *\n   * @return {Node|undefined} Previous node.\n   *\n   * @example\n   * const annotation = decl.prev()\n   * if (annotation.type === 'comment') {\n   *   readAnnotation(annotation.text)\n   * }\n   */\n  prev () {\n    if (!this.parent) return undefined\n    const index = this.parent.index(this)\n    return this.parent.nodes[index - 1]\n  }\n\n  /**\n   * Insert new node before current node to current node’s parent.\n   *\n   * Just alias for `node.parent.insertBefore(node, add)`.\n   *\n   * @param {Node|object|string|Node[]} add New node.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * decl.before('content: \"\"')\n   */\n  before (add) {\n    this.parent.insertBefore(this, add)\n    return this\n  }\n\n  /**\n   * Insert new node after current node to current node’s parent.\n   *\n   * Just alias for `node.parent.insertAfter(node, add)`.\n   *\n   * @param {Node|object|string|Node[]} add New node.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * decl.after('color: black')\n   */\n  after (add) {\n    this.parent.insertAfter(this, add)\n    return this\n  }\n\n  toJSON () {\n    const fixed = { }\n\n    for (const name in this) {\n      if (!this.hasOwnProperty(name)) continue\n      if (name === 'parent') continue\n      const value = this[name]\n\n      if (value instanceof Array) {\n        fixed[name] = value.map(i => {\n          if (typeof i === 'object' && i.toJSON) {\n            return i.toJSON()\n          } else {\n            return i\n          }\n        })\n      } else if (typeof value === 'object' && value.toJSON) {\n        fixed[name] = value.toJSON()\n      } else {\n        fixed[name] = value\n      }\n    }\n\n    return fixed\n  }\n\n  /**\n   * Returns a {@link Node#raws} value. If the node is missing\n   * the code style property (because the node was manually built or cloned),\n   * PostCSS will try to autodetect the code style property by looking\n   * at other nodes in the tree.\n   *\n   * @param {string} prop          Name of code style property.\n   * @param {string} [defaultType] Name of default value, it can be missed\n   *                               if the value is the same as prop.\n   *\n   * @example\n   * const root = postcss.parse('a { background: white }')\n   * root.nodes[0].append({ prop: 'color', value: 'black' })\n   * root.nodes[0].nodes[1].raws.before   //=> undefined\n   * root.nodes[0].nodes[1].raw('before') //=> ' '\n   *\n   * @return {string} Code style value.\n   */\n  raw (prop, defaultType) {\n    const str = new Stringifier()\n    return str.raw(this, prop, defaultType)\n  }\n\n  /**\n   * Finds the Root instance of the node’s tree.\n   *\n   * @example\n   * root.nodes[0].nodes[0].root() === root\n   *\n   * @return {Root} Root parent.\n   */\n  root () {\n    let result = this\n    while (result.parent) result = result.parent\n    return result\n  }\n\n  /**\n   * Clear the code style properties for the node and its children.\n   *\n   * @param {boolean} [keepBetween] Keep the raws.between symbols.\n   *\n   * @return {undefined}\n   *\n   * @example\n   * node.raws.before  //=> ' '\n   * node.cleanRaws()\n   * node.raws.before  //=> undefined\n   */\n  cleanRaws (keepBetween) {\n    delete this.raws.before\n    delete this.raws.after\n    if (!keepBetween) delete this.raws.between\n  }\n\n  positionInside (index) {\n    const string = this.toString()\n    let column = this.source.start.column\n    let line = this.source.start.line\n\n    for (let i = 0; i < index; i++) {\n      if (string[i] === '\\n') {\n        column = 1\n        line += 1\n      } else {\n        column += 1\n      }\n    }\n\n    return { line, column }\n  }\n\n  positionBy (opts) {\n    let pos = this.source.start\n    if (opts.index) {\n      pos = this.positionInside(opts.index)\n    } else if (opts.word) {\n      const index = this.toString().indexOf(opts.word)\n      if (index !== -1) pos = this.positionInside(index)\n    }\n    return pos\n  }\n\n  /**\n   * @memberof Node#\n   * @member {string} type String representing the node’s type.\n   *                       Possible values are `root`, `atrule`, `rule`,\n   *                       `decl`, or `comment`.\n   *\n   * @example\n   * postcss.decl({ prop: 'color', value: 'black' }).type //=> 'decl'\n   */\n\n  /**\n   * @memberof Node#\n   * @member {Container} parent The node’s parent node.\n   *\n   * @example\n   * root.nodes[0].parent === root\n   */\n\n  /**\n   * @memberof Node#\n   * @member {source} source The input source of the node.\n   *\n   * The property is used in source map generation.\n   *\n   * If you create a node manually (e.g., with `postcss.decl()`),\n   * that node will not have a `source` property and will be absent\n   * from the source map. For this reason, the plugin developer should\n   * consider cloning nodes to create new ones (in which case the new node’s\n   * source will reference the original, cloned node) or setting\n   * the `source` property manually.\n   *\n   * ```js\n   * // Bad\n   * const prefixed = postcss.decl({\n   *   prop: '-moz-' + decl.prop,\n   *   value: decl.value\n   * })\n   *\n   * // Good\n   * const prefixed = decl.clone({ prop: '-moz-' + decl.prop })\n   * ```\n   *\n   * ```js\n   * if (atrule.name === 'add-link') {\n   *   const rule = postcss.rule({ selector: 'a', source: atrule.source })\n   *   atrule.parent.insertBefore(atrule, rule)\n   * }\n   * ```\n   *\n   * @example\n   * decl.source.input.from //=> '/home/ai/a.sass'\n   * decl.source.start      //=> { line: 10, column: 2 }\n   * decl.source.end        //=> { line: 10, column: 12 }\n   */\n\n  /**\n   * @memberof Node#\n   * @member {object} raws Information to generate byte-to-byte equal\n   *                       node string as it was in the origin input.\n   *\n   * Every parser saves its own properties,\n   * but the default CSS parser uses:\n   *\n   * * `before`: the space symbols before the node. It also stores `*`\n   *   and `_` symbols before the declaration (IE hack).\n   * * `after`: the space symbols after the last child of the node\n   *   to the end of the node.\n   * * `between`: the symbols between the property and value\n   *   for declarations, selector and `{` for rules, or last parameter\n   *   and `{` for at-rules.\n   * * `semicolon`: contains true if the last child has\n   *   an (optional) semicolon.\n   * * `afterName`: the space between the at-rule name and its parameters.\n   * * `left`: the space symbols between `/*` and the comment’s text.\n   * * `right`: the space symbols between the comment’s text\n   *   and <code>*&#47;</code>.\n   * * `important`: the content of the important statement,\n   *   if it is not just `!important`.\n   *\n   * PostCSS cleans selectors, declaration values and at-rule parameters\n   * from comments and extra spaces, but it stores origin content in raws\n   * properties. As such, if you don’t change a declaration’s value,\n   * PostCSS will use the raw value with comments.\n   *\n   * @example\n   * const root = postcss.parse('a {\\n  color:black\\n}')\n   * root.first.first.raws //=> { before: '\\n  ', between: ':' }\n   */\n}\n\nexport default Node\n\n/**\n * @typedef {object} position\n * @property {number} line   Source line in file.\n * @property {number} column Source column in file.\n */\n\n/**\n * @typedef {object} source\n * @property {Input} input    {@link Input} with input file\n * @property {position} start The starting position of the node’s source.\n * @property {position} end   The ending position of the node’s source.\n */\n"]}
|
606
|
+
exports.default = _default;
|
607
|
+
module.exports = exports.default;
|
608
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["node.es6"],"names":["cloneNode","obj","parent","cloned","constructor","i","hasOwnProperty","value","type","Array","map","j","Node","defaults","raws","process","env","NODE_ENV","Error","JSON","stringify","name","error","message","opts","source","pos","positionBy","input","line","column","CssSyntaxError","warn","result","text","data","node","remove","removeChild","undefined","toString","stringifier","clone","overrides","cloneBefore","insertBefore","cloneAfter","insertAfter","replaceWith","nodes","next","index","prev","before","add","after","toJSON","fixed","raw","prop","defaultType","str","Stringifier","root","cleanRaws","keepBetween","between","positionInside","string","start","word","indexOf"],"mappings":"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","sourcesContent":["import CssSyntaxError from './css-syntax-error'\nimport Stringifier from './stringifier'\nimport stringify from './stringify'\n\nfunction cloneNode (obj, parent) {\n  let cloned = new obj.constructor()\n\n  for (let i in obj) {\n    if (!obj.hasOwnProperty(i)) continue\n    let value = obj[i]\n    let type = typeof value\n\n    if (i === 'parent' && type === 'object') {\n      if (parent) cloned[i] = parent\n    } else if (i === 'source') {\n      cloned[i] = value\n    } else if (value instanceof Array) {\n      cloned[i] = value.map(j => cloneNode(j, cloned))\n    } else {\n      if (type === 'object' && value !== null) value = cloneNode(value)\n      cloned[i] = value\n    }\n  }\n\n  return cloned\n}\n\n/**\n * All node classes inherit the following common methods.\n *\n * @abstract\n */\nclass Node {\n  /**\n   * @param {object} [defaults] Value for node properties.\n   */\n  constructor (defaults = { }) {\n    this.raws = { }\n    if (process.env.NODE_ENV !== 'production') {\n      if (typeof defaults !== 'object' && typeof defaults !== 'undefined') {\n        throw new Error(\n          'PostCSS nodes constructor accepts object, not ' +\n          JSON.stringify(defaults)\n        )\n      }\n    }\n    for (let name in defaults) {\n      this[name] = defaults[name]\n    }\n  }\n\n  /**\n   * Returns a `CssSyntaxError` instance containing the original position\n   * of the node in the source, showing line and column numbers and also\n   * a small excerpt to facilitate debugging.\n   *\n   * If present, an input source map will be used to get the original position\n   * of the source, even from a previous compilation step\n   * (e.g., from Sass compilation).\n   *\n   * This method produces very useful error messages.\n   *\n   * @param {string} message     Error description.\n   * @param {object} [opts]      Options.\n   * @param {string} opts.plugin Plugin name that created this error.\n   *                             PostCSS will set it automatically.\n   * @param {string} opts.word   A word inside a node’s string that should\n   *                             be highlighted as the source of the error.\n   * @param {number} opts.index  An index inside a node’s string that should\n   *                             be highlighted as the source of the error.\n   *\n   * @return {CssSyntaxError} Error object to throw it.\n   *\n   * @example\n   * if (!variables[name]) {\n   *   throw decl.error('Unknown variable ' + name, { word: name })\n   *   // CssSyntaxError: postcss-vars:a.sass:4:3: Unknown variable $black\n   *   //   color: $black\n   *   // a\n   *   //          ^\n   *   //   background: white\n   * }\n   */\n  error (message, opts = { }) {\n    if (this.source) {\n      let pos = this.positionBy(opts)\n      return this.source.input.error(message, pos.line, pos.column, opts)\n    }\n    return new CssSyntaxError(message)\n  }\n\n  /**\n   * This method is provided as a convenience wrapper for {@link Result#warn}.\n   *\n   * @param {Result} result      The {@link Result} instance\n   *                             that will receive the warning.\n   * @param {string} text        Warning message.\n   * @param {object} [opts]      Options\n   * @param {string} opts.plugin Plugin name that created this warning.\n   *                             PostCSS will set it automatically.\n   * @param {string} opts.word   A word inside a node’s string that should\n   *                             be highlighted as the source of the warning.\n   * @param {number} opts.index  An index inside a node’s string that should\n   *                             be highlighted as the source of the warning.\n   *\n   * @return {Warning} Created warning object.\n   *\n   * @example\n   * const plugin = postcss.plugin('postcss-deprecated', () => {\n   *   return (root, result) => {\n   *     root.walkDecls('bad', decl => {\n   *       decl.warn(result, 'Deprecated property bad')\n   *     })\n   *   }\n   * })\n   */\n  warn (result, text, opts) {\n    let data = { node: this }\n    for (let i in opts) data[i] = opts[i]\n    return result.warn(text, data)\n  }\n\n  /**\n   * Removes the node from its parent and cleans the parent properties\n   * from the node and its children.\n   *\n   * @example\n   * if (decl.prop.match(/^-webkit-/)) {\n   *   decl.remove()\n   * }\n   *\n   * @return {Node} Node to make calls chain.\n   */\n  remove () {\n    if (this.parent) {\n      this.parent.removeChild(this)\n    }\n    this.parent = undefined\n    return this\n  }\n\n  /**\n   * Returns a CSS string representing the node.\n   *\n   * @param {stringifier|syntax} [stringifier] A syntax to use\n   *                                           in string generation.\n   *\n   * @return {string} CSS string of this node.\n   *\n   * @example\n   * postcss.rule({ selector: 'a' }).toString() //=> \"a {}\"\n   */\n  toString (stringifier = stringify) {\n    if (stringifier.stringify) stringifier = stringifier.stringify\n    let result = ''\n    stringifier(this, i => {\n      result += i\n    })\n    return result\n  }\n\n  /**\n   * Returns an exact clone of the node.\n   *\n   * The resulting cloned node and its (cloned) children will retain\n   * code style properties.\n   *\n   * @param {object} [overrides] New properties to override in the clone.\n   *\n   * @example\n   * decl.raws.before    //=> \"\\n  \"\n   * const cloned = decl.clone({ prop: '-moz-' + decl.prop })\n   * cloned.raws.before  //=> \"\\n  \"\n   * cloned.toString()   //=> -moz-transform: scale(0)\n   *\n   * @return {Node} Clone of the node.\n   */\n  clone (overrides = { }) {\n    let cloned = cloneNode(this)\n    for (let name in overrides) {\n      cloned[name] = overrides[name]\n    }\n    return cloned\n  }\n\n  /**\n   * Shortcut to clone the node and insert the resulting cloned node\n   * before the current node.\n   *\n   * @param {object} [overrides] Mew properties to override in the clone.\n   *\n   * @example\n   * decl.cloneBefore({ prop: '-moz-' + decl.prop })\n   *\n   * @return {Node} New node\n   */\n  cloneBefore (overrides = { }) {\n    let cloned = this.clone(overrides)\n    this.parent.insertBefore(this, cloned)\n    return cloned\n  }\n\n  /**\n   * Shortcut to clone the node and insert the resulting cloned node\n   * after the current node.\n   *\n   * @param {object} [overrides] New properties to override in the clone.\n   *\n   * @return {Node} New node.\n   */\n  cloneAfter (overrides = { }) {\n    let cloned = this.clone(overrides)\n    this.parent.insertAfter(this, cloned)\n    return cloned\n  }\n\n  /**\n   * Inserts node(s) before the current node and removes the current node.\n   *\n   * @param {...Node} nodes Mode(s) to replace current one.\n   *\n   * @example\n   * if (atrule.name === 'mixin') {\n   *   atrule.replaceWith(mixinRules[atrule.params])\n   * }\n   *\n   * @return {Node} Current node to methods chain.\n   */\n  replaceWith (...nodes) {\n    if (this.parent) {\n      for (let node of nodes) {\n        this.parent.insertBefore(this, node)\n      }\n\n      this.remove()\n    }\n\n    return this\n  }\n\n  /**\n   * Returns the next child of the node’s parent.\n   * Returns `undefined` if the current node is the last child.\n   *\n   * @return {Node|undefined} Next node.\n   *\n   * @example\n   * if (comment.text === 'delete next') {\n   *   const next = comment.next()\n   *   if (next) {\n   *     next.remove()\n   *   }\n   * }\n   */\n  next () {\n    if (!this.parent) return undefined\n    let index = this.parent.index(this)\n    return this.parent.nodes[index + 1]\n  }\n\n  /**\n   * Returns the previous child of the node’s parent.\n   * Returns `undefined` if the current node is the first child.\n   *\n   * @return {Node|undefined} Previous node.\n   *\n   * @example\n   * const annotation = decl.prev()\n   * if (annotation.type === 'comment') {\n   *   readAnnotation(annotation.text)\n   * }\n   */\n  prev () {\n    if (!this.parent) return undefined\n    let index = this.parent.index(this)\n    return this.parent.nodes[index - 1]\n  }\n\n  /**\n   * Insert new node before current node to current node’s parent.\n   *\n   * Just alias for `node.parent.insertBefore(node, add)`.\n   *\n   * @param {Node|object|string|Node[]} add New node.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * decl.before('content: \"\"')\n   */\n  before (add) {\n    this.parent.insertBefore(this, add)\n    return this\n  }\n\n  /**\n   * Insert new node after current node to current node’s parent.\n   *\n   * Just alias for `node.parent.insertAfter(node, add)`.\n   *\n   * @param {Node|object|string|Node[]} add New node.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * decl.after('color: black')\n   */\n  after (add) {\n    this.parent.insertAfter(this, add)\n    return this\n  }\n\n  toJSON () {\n    let fixed = { }\n\n    for (let name in this) {\n      if (!this.hasOwnProperty(name)) continue\n      if (name === 'parent') continue\n      let value = this[name]\n\n      if (value instanceof Array) {\n        fixed[name] = value.map(i => {\n          if (typeof i === 'object' && i.toJSON) {\n            return i.toJSON()\n          } else {\n            return i\n          }\n        })\n      } else if (typeof value === 'object' && value.toJSON) {\n        fixed[name] = value.toJSON()\n      } else {\n        fixed[name] = value\n      }\n    }\n\n    return fixed\n  }\n\n  /**\n   * Returns a {@link Node#raws} value. If the node is missing\n   * the code style property (because the node was manually built or cloned),\n   * PostCSS will try to autodetect the code style property by looking\n   * at other nodes in the tree.\n   *\n   * @param {string} prop          Name of code style property.\n   * @param {string} [defaultType] Name of default value, it can be missed\n   *                               if the value is the same as prop.\n   *\n   * @example\n   * const root = postcss.parse('a { background: white }')\n   * root.nodes[0].append({ prop: 'color', value: 'black' })\n   * root.nodes[0].nodes[1].raws.before   //=> undefined\n   * root.nodes[0].nodes[1].raw('before') //=> ' '\n   *\n   * @return {string} Code style value.\n   */\n  raw (prop, defaultType) {\n    let str = new Stringifier()\n    return str.raw(this, prop, defaultType)\n  }\n\n  /**\n   * Finds the Root instance of the node’s tree.\n   *\n   * @example\n   * root.nodes[0].nodes[0].root() === root\n   *\n   * @return {Root} Root parent.\n   */\n  root () {\n    let result = this\n    while (result.parent) result = result.parent\n    return result\n  }\n\n  /**\n   * Clear the code style properties for the node and its children.\n   *\n   * @param {boolean} [keepBetween] Keep the raws.between symbols.\n   *\n   * @return {undefined}\n   *\n   * @example\n   * node.raws.before  //=> ' '\n   * node.cleanRaws()\n   * node.raws.before  //=> undefined\n   */\n  cleanRaws (keepBetween) {\n    delete this.raws.before\n    delete this.raws.after\n    if (!keepBetween) delete this.raws.between\n  }\n\n  positionInside (index) {\n    let string = this.toString()\n    let column = this.source.start.column\n    let line = this.source.start.line\n\n    for (let i = 0; i < index; i++) {\n      if (string[i] === '\\n') {\n        column = 1\n        line += 1\n      } else {\n        column += 1\n      }\n    }\n\n    return { line, column }\n  }\n\n  positionBy (opts) {\n    let pos = this.source.start\n    if (opts.index) {\n      pos = this.positionInside(opts.index)\n    } else if (opts.word) {\n      let index = this.toString().indexOf(opts.word)\n      if (index !== -1) pos = this.positionInside(index)\n    }\n    return pos\n  }\n\n  /**\n   * @memberof Node#\n   * @member {string} type String representing the node’s type.\n   *                       Possible values are `root`, `atrule`, `rule`,\n   *                       `decl`, or `comment`.\n   *\n   * @example\n   * postcss.decl({ prop: 'color', value: 'black' }).type //=> 'decl'\n   */\n\n  /**\n   * @memberof Node#\n   * @member {Container} parent The node’s parent node.\n   *\n   * @example\n   * root.nodes[0].parent === root\n   */\n\n  /**\n   * @memberof Node#\n   * @member {source} source The input source of the node.\n   *\n   * The property is used in source map generation.\n   *\n   * If you create a node manually (e.g., with `postcss.decl()`),\n   * that node will not have a `source` property and will be absent\n   * from the source map. For this reason, the plugin developer should\n   * consider cloning nodes to create new ones (in which case the new node’s\n   * source will reference the original, cloned node) or setting\n   * the `source` property manually.\n   *\n   * ```js\n   * // Bad\n   * const prefixed = postcss.decl({\n   *   prop: '-moz-' + decl.prop,\n   *   value: decl.value\n   * })\n   *\n   * // Good\n   * const prefixed = decl.clone({ prop: '-moz-' + decl.prop })\n   * ```\n   *\n   * ```js\n   * if (atrule.name === 'add-link') {\n   *   const rule = postcss.rule({ selector: 'a', source: atrule.source })\n   *   atrule.parent.insertBefore(atrule, rule)\n   * }\n   * ```\n   *\n   * @example\n   * decl.source.input.from //=> '/home/ai/a.sass'\n   * decl.source.start      //=> { line: 10, column: 2 }\n   * decl.source.end        //=> { line: 10, column: 12 }\n   */\n\n  /**\n   * @memberof Node#\n   * @member {object} raws Information to generate byte-to-byte equal\n   *                       node string as it was in the origin input.\n   *\n   * Every parser saves its own properties,\n   * but the default CSS parser uses:\n   *\n   * * `before`: the space symbols before the node. It also stores `*`\n   *   and `_` symbols before the declaration (IE hack).\n   * * `after`: the space symbols after the last child of the node\n   *   to the end of the node.\n   * * `between`: the symbols between the property and value\n   *   for declarations, selector and `{` for rules, or last parameter\n   *   and `{` for at-rules.\n   * * `semicolon`: contains true if the last child has\n   *   an (optional) semicolon.\n   * * `afterName`: the space between the at-rule name and its parameters.\n   * * `left`: the space symbols between `/*` and the comment’s text.\n   * * `right`: the space symbols between the comment’s text\n   *   and <code>*&#47;</code>.\n   * * `important`: the content of the important statement,\n   *   if it is not just `!important`.\n   *\n   * PostCSS cleans selectors, declaration values and at-rule parameters\n   * from comments and extra spaces, but it stores origin content in raws\n   * properties. As such, if you don’t change a declaration’s value,\n   * PostCSS will use the raw value with comments.\n   *\n   * @example\n   * const root = postcss.parse('a {\\n  color:black\\n}')\n   * root.first.first.raws //=> { before: '\\n  ', between: ':' }\n   */\n}\n\nexport default Node\n\n/**\n * @typedef {object} position\n * @property {number} line   Source line in file.\n * @property {number} column Source column in file.\n */\n\n/**\n * @typedef {object} source\n * @property {Input} input    {@link Input} with input file\n * @property {position} start The starting position of the node’s source.\n * @property {position} end   The ending position of the node’s source.\n */\n"],"file":"node.js"}
|
package/lib/parse.js
CHANGED
@@ -1,20 +1,18 @@
|
|
1
|
-
|
1
|
+
"use strict";
|
2
2
|
|
3
3
|
exports.__esModule = true;
|
4
|
+
exports.default = void 0;
|
4
5
|
|
5
|
-
var _parser = require(
|
6
|
+
var _parser = _interopRequireDefault(require("./parser"));
|
6
7
|
|
7
|
-
var
|
8
|
-
|
9
|
-
var _input = require('./input');
|
10
|
-
|
11
|
-
var _input2 = _interopRequireDefault(_input);
|
8
|
+
var _input = _interopRequireDefault(require("./input"));
|
12
9
|
|
13
10
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
14
11
|
|
15
12
|
function parse(css, opts) {
|
16
|
-
var input = new
|
17
|
-
var parser = new
|
13
|
+
var input = new _input.default(css, opts);
|
14
|
+
var parser = new _parser.default(input);
|
15
|
+
|
18
16
|
try {
|
19
17
|
parser.parse();
|
20
18
|
} catch (e) {
|
@@ -29,12 +27,14 @@ function parse(css, opts) {
|
|
29
27
|
}
|
30
28
|
}
|
31
29
|
}
|
30
|
+
|
32
31
|
throw e;
|
33
32
|
}
|
34
33
|
|
35
34
|
return parser.root;
|
36
35
|
}
|
37
36
|
|
38
|
-
|
39
|
-
|
40
|
-
|
37
|
+
var _default = parse;
|
38
|
+
exports.default = _default;
|
39
|
+
module.exports = exports.default;
|
40
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInBhcnNlLmVzNiJdLCJuYW1lcyI6WyJwYXJzZSIsImNzcyIsIm9wdHMiLCJpbnB1dCIsIklucHV0IiwicGFyc2VyIiwiUGFyc2VyIiwiZSIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIm5hbWUiLCJmcm9tIiwidGVzdCIsIm1lc3NhZ2UiLCJyb290Il0sIm1hcHBpbmdzIjoiOzs7OztBQUFBOztBQUNBOzs7O0FBRUEsU0FBU0EsS0FBVCxDQUFnQkMsR0FBaEIsRUFBcUJDLElBQXJCLEVBQTJCO0FBQ3pCLE1BQUlDLEtBQUssR0FBRyxJQUFJQyxjQUFKLENBQVVILEdBQVYsRUFBZUMsSUFBZixDQUFaO0FBQ0EsTUFBSUcsTUFBTSxHQUFHLElBQUlDLGVBQUosQ0FBV0gsS0FBWCxDQUFiOztBQUNBLE1BQUk7QUFDRkUsSUFBQUEsTUFBTSxDQUFDTCxLQUFQO0FBQ0QsR0FGRCxDQUVFLE9BQU9PLENBQVAsRUFBVTtBQUNWLFFBQUlDLE9BQU8sQ0FBQ0MsR0FBUixDQUFZQyxRQUFaLEtBQXlCLFlBQTdCLEVBQTJDO0FBQ3pDLFVBQUlILENBQUMsQ0FBQ0ksSUFBRixLQUFXLGdCQUFYLElBQStCVCxJQUEvQixJQUF1Q0EsSUFBSSxDQUFDVSxJQUFoRCxFQUFzRDtBQUNwRCxZQUFJLFdBQVdDLElBQVgsQ0FBZ0JYLElBQUksQ0FBQ1UsSUFBckIsQ0FBSixFQUFnQztBQUM5QkwsVUFBQUEsQ0FBQyxDQUFDTyxPQUFGLElBQWEsb0NBQ0EsMkJBREEsR0FFQSx3Q0FGYjtBQUdELFNBSkQsTUFJTyxJQUFJLFVBQVVELElBQVYsQ0FBZVgsSUFBSSxDQUFDVSxJQUFwQixDQUFKLEVBQStCO0FBQ3BDTCxVQUFBQSxDQUFDLENBQUNPLE9BQUYsSUFBYSxvQ0FDQSwyQkFEQSxHQUVBLHdDQUZiO0FBR0QsU0FKTSxNQUlBLElBQUksV0FBV0QsSUFBWCxDQUFnQlgsSUFBSSxDQUFDVSxJQUFyQixDQUFKLEVBQWdDO0FBQ3JDTCxVQUFBQSxDQUFDLENBQUNPLE9BQUYsSUFBYSxvQ0FDQSwyQkFEQSxHQUVBLHdDQUZiO0FBR0Q7QUFDRjtBQUNGOztBQUNELFVBQU1QLENBQU47QUFDRDs7QUFFRCxTQUFPRixNQUFNLENBQUNVLElBQWQ7QUFDRDs7ZUFFY2YsSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQYXJzZXIgZnJvbSAnLi9wYXJzZXInXG5pbXBvcnQgSW5wdXQgZnJvbSAnLi9pbnB1dCdcblxuZnVuY3Rpb24gcGFyc2UgKGNzcywgb3B0cykge1xuICBsZXQgaW5wdXQgPSBuZXcgSW5wdXQoY3NzLCBvcHRzKVxuICBsZXQgcGFyc2VyID0gbmV3IFBhcnNlcihpbnB1dClcbiAgdHJ5IHtcbiAgICBwYXJzZXIucGFyc2UoKVxuICB9IGNhdGNoIChlKSB7XG4gICAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WICE9PSAncHJvZHVjdGlvbicpIHtcbiAgICAgIGlmIChlLm5hbWUgPT09ICdDc3NTeW50YXhFcnJvcicgJiYgb3B0cyAmJiBvcHRzLmZyb20pIHtcbiAgICAgICAgaWYgKC9cXC5zY3NzJC9pLnRlc3Qob3B0cy5mcm9tKSkge1xuICAgICAgICAgIGUubWVzc2FnZSArPSAnXFxuWW91IHRyaWVkIHRvIHBhcnNlIFNDU1Mgd2l0aCAnICtcbiAgICAgICAgICAgICAgICAgICAgICAgJ3RoZSBzdGFuZGFyZCBDU1MgcGFyc2VyOyAnICtcbiAgICAgICAgICAgICAgICAgICAgICAgJ3RyeSBhZ2FpbiB3aXRoIHRoZSBwb3N0Y3NzLXNjc3MgcGFyc2VyJ1xuICAgICAgICB9IGVsc2UgaWYgKC9cXC5zYXNzL2kudGVzdChvcHRzLmZyb20pKSB7XG4gICAgICAgICAgZS5tZXNzYWdlICs9ICdcXG5Zb3UgdHJpZWQgdG8gcGFyc2UgU2FzcyB3aXRoICcgK1xuICAgICAgICAgICAgICAgICAgICAgICAndGhlIHN0YW5kYXJkIENTUyBwYXJzZXI7ICcgK1xuICAgICAgICAgICAgICAgICAgICAgICAndHJ5IGFnYWluIHdpdGggdGhlIHBvc3Rjc3Mtc2FzcyBwYXJzZXInXG4gICAgICAgIH0gZWxzZSBpZiAoL1xcLmxlc3MkL2kudGVzdChvcHRzLmZyb20pKSB7XG4gICAgICAgICAgZS5tZXNzYWdlICs9ICdcXG5Zb3UgdHJpZWQgdG8gcGFyc2UgTGVzcyB3aXRoICcgK1xuICAgICAgICAgICAgICAgICAgICAgICAndGhlIHN0YW5kYXJkIENTUyBwYXJzZXI7ICcgK1xuICAgICAgICAgICAgICAgICAgICAgICAndHJ5IGFnYWluIHdpdGggdGhlIHBvc3Rjc3MtbGVzcyBwYXJzZXInXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gICAgdGhyb3cgZVxuICB9XG5cbiAgcmV0dXJuIHBhcnNlci5yb290XG59XG5cbmV4cG9ydCBkZWZhdWx0IHBhcnNlXG4iXSwiZmlsZSI6InBhcnNlLmpzIn0=
|