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/lib/container.js CHANGED
@@ -25,11 +25,11 @@ function _possibleConstructorReturn(self, call) { if (!self) { throw new Referen
25
25
  function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
26
26
 
27
27
  function cleanSource(nodes) {
28
- return nodes.map(function (i) {
29
- if (i.nodes) i.nodes = cleanSource(i.nodes);
30
- delete i.source;
31
- return i;
32
- });
28
+ return nodes.map(function (i) {
29
+ if (i.nodes) i.nodes = cleanSource(i.nodes);
30
+ delete i.source;
31
+ return i;
32
+ });
33
33
  }
34
34
 
35
35
  /**
@@ -44,864 +44,836 @@ function cleanSource(nodes) {
44
44
  */
45
45
 
46
46
  var Container = function (_Node) {
47
- _inherits(Container, _Node);
48
-
49
- function Container() {
50
- _classCallCheck(this, Container);
51
-
52
- return _possibleConstructorReturn(this, _Node.apply(this, arguments));
47
+ _inherits(Container, _Node);
48
+
49
+ function Container() {
50
+ _classCallCheck(this, Container);
51
+
52
+ return _possibleConstructorReturn(this, _Node.apply(this, arguments));
53
+ }
54
+
55
+ Container.prototype.push = function push(child) {
56
+ child.parent = this;
57
+ this.nodes.push(child);
58
+ return this;
59
+ };
60
+
61
+ /**
62
+ * Iterates through the container’s immediate children,
63
+ * calling `callback` for each child.
64
+ *
65
+ * Returning `false` in the callback will break iteration.
66
+ *
67
+ * This method only iterates through the container’s immediate children.
68
+ * If you need to recursively iterate through all the container’s descendant
69
+ * nodes, use {@link Container#walk}.
70
+ *
71
+ * Unlike the for `{}`-cycle or `Array#forEach` this iterator is safe
72
+ * if you are mutating the array of child nodes during iteration.
73
+ * PostCSS will adjust the current index to match the mutations.
74
+ *
75
+ * @param {childIterator} callback Iterator receives each node and index.
76
+ *
77
+ * @return {false|undefined} Returns `false` if iteration was broke.
78
+ *
79
+ * @example
80
+ * const root = postcss.parse('a { color: black; z-index: 1 }')
81
+ * const rule = root.first
82
+ *
83
+ * for (const decl of rule.nodes) {
84
+ * decl.cloneBefore({ prop: '-webkit-' + decl.prop })
85
+ * // Cycle will be infinite, because cloneBefore moves the current node
86
+ * // to the next index
87
+ * }
88
+ *
89
+ * rule.each(decl => {
90
+ * decl.cloneBefore({ prop: '-webkit-' + decl.prop })
91
+ * // Will be executed only for color and z-index
92
+ * })
93
+ */
94
+
95
+
96
+ Container.prototype.each = function each(callback) {
97
+ if (!this.lastEach) this.lastEach = 0;
98
+ if (!this.indexes) this.indexes = {};
99
+
100
+ this.lastEach += 1;
101
+ var id = this.lastEach;
102
+ this.indexes[id] = 0;
103
+
104
+ if (!this.nodes) return undefined;
105
+
106
+ var index = void 0,
107
+ result = void 0;
108
+ while (this.indexes[id] < this.nodes.length) {
109
+ index = this.indexes[id];
110
+ result = callback(this.nodes[index], index);
111
+ if (result === false) break;
112
+
113
+ this.indexes[id] += 1;
53
114
  }
54
115
 
55
- Container.prototype.push = function push(child) {
56
- child.parent = this;
57
- this.nodes.push(child);
58
- return this;
59
- };
60
-
61
- /**
62
- * Iterates through the container’s immediate children,
63
- * calling `callback` for each child.
64
- *
65
- * Returning `false` in the callback will break iteration.
66
- *
67
- * This method only iterates through the container’s immediate children.
68
- * If you need to recursively iterate through all the container’s descendant
69
- * nodes, use {@link Container#walk}.
70
- *
71
- * Unlike the for `{}`-cycle or `Array#forEach` this iterator is safe
72
- * if you are mutating the array of child nodes during iteration.
73
- * PostCSS will adjust the current index to match the mutations.
74
- *
75
- * @param {childIterator} callback - iterator receives each node and index
76
- *
77
- * @return {false|undefined} returns `false` if iteration was broke
78
- *
79
- * @example
80
- * const root = postcss.parse('a { color: black; z-index: 1 }');
81
- * const rule = root.first;
82
- *
83
- * for ( let decl of rule.nodes ) {
84
- * decl.cloneBefore({ prop: '-webkit-' + decl.prop });
85
- * // Cycle will be infinite, because cloneBefore moves the current node
86
- * // to the next index
87
- * }
88
- *
89
- * rule.each(decl => {
90
- * decl.cloneBefore({ prop: '-webkit-' + decl.prop });
91
- * // Will be executed only for color and z-index
92
- * });
93
- */
94
-
95
-
96
- Container.prototype.each = function each(callback) {
97
- if (!this.lastEach) this.lastEach = 0;
98
- if (!this.indexes) this.indexes = {};
99
-
100
- this.lastEach += 1;
101
- var id = this.lastEach;
102
- this.indexes[id] = 0;
103
-
104
- if (!this.nodes) return undefined;
105
-
106
- var index = void 0,
107
- result = void 0;
108
- while (this.indexes[id] < this.nodes.length) {
109
- index = this.indexes[id];
110
- result = callback(this.nodes[index], index);
111
- if (result === false) break;
112
-
113
- this.indexes[id] += 1;
116
+ delete this.indexes[id];
117
+
118
+ return result;
119
+ };
120
+
121
+ /**
122
+ * Traverses the container’s descendant nodes, calling callback
123
+ * for each node.
124
+ *
125
+ * Like container.each(), this method is safe to use
126
+ * if you are mutating arrays during iteration.
127
+ *
128
+ * If you only need to iterate through the container’s immediate children,
129
+ * use {@link Container#each}.
130
+ *
131
+ * @param {childIterator} callback Iterator receives each node and index.
132
+ *
133
+ * @return {false|undefined} Returns `false` if iteration was broke.
134
+ *
135
+ * @example
136
+ * root.walk(node => {
137
+ * // Traverses all descendant nodes.
138
+ * })
139
+ */
140
+
141
+
142
+ Container.prototype.walk = function walk(callback) {
143
+ return this.each(function (child, i) {
144
+ var result = void 0;
145
+ try {
146
+ result = callback(child, i);
147
+ } catch (e) {
148
+ e.postcssNode = child;
149
+ if (e.stack && child.source && /\n\s{4}at /.test(e.stack)) {
150
+ var s = child.source;
151
+ e.stack = e.stack.replace(/\n\s{4}at /, '$&' + s.input.from + ':' + s.start.line + ':' + s.start.column + '$&');
114
152
  }
115
-
116
- delete this.indexes[id];
117
-
118
- return result;
119
- };
120
-
121
- /**
122
- * Traverses the container’s descendant nodes, calling callback
123
- * for each node.
124
- *
125
- * Like container.each(), this method is safe to use
126
- * if you are mutating arrays during iteration.
127
- *
128
- * If you only need to iterate through the container’s immediate children,
129
- * use {@link Container#each}.
130
- *
131
- * @param {childIterator} callback - iterator receives each node and index
132
- *
133
- * @return {false|undefined} returns `false` if iteration was broke
134
- *
135
- * @example
136
- * root.walk(node => {
137
- * // Traverses all descendant nodes.
138
- * });
139
- */
140
-
141
-
142
- Container.prototype.walk = function walk(callback) {
143
- return this.each(function (child, i) {
144
- var result = callback(child, i);
145
- if (result !== false && child.walk) {
146
- result = child.walk(callback);
147
- }
148
- return result;
149
- });
150
- };
151
-
152
- /**
153
- * Traverses the container’s descendant nodes, calling callback
154
- * for each declaration node.
155
- *
156
- * If you pass a filter, iteration will only happen over declarations
157
- * with matching properties.
158
- *
159
- * Like {@link Container#each}, this method is safe
160
- * to use if you are mutating arrays during iteration.
161
- *
162
- * @param {string|RegExp} [prop] - string or regular expression
163
- * to filter declarations by property name
164
- * @param {childIterator} callback - iterator receives each node and index
165
- *
166
- * @return {false|undefined} returns `false` if iteration was broke
167
- *
168
- * @example
169
- * root.walkDecls(decl => {
170
- * checkPropertySupport(decl.prop);
171
- * });
172
- *
173
- * root.walkDecls('border-radius', decl => {
174
- * decl.remove();
175
- * });
176
- *
177
- * root.walkDecls(/^background/, decl => {
178
- * decl.value = takeFirstColorFromGradient(decl.value);
179
- * });
180
- */
181
-
182
-
183
- Container.prototype.walkDecls = function walkDecls(prop, callback) {
184
- if (!callback) {
185
- callback = prop;
186
- return this.walk(function (child, i) {
187
- if (child.type === 'decl') {
188
- return callback(child, i);
189
- }
190
- });
191
- } else if (prop instanceof RegExp) {
192
- return this.walk(function (child, i) {
193
- if (child.type === 'decl' && prop.test(child.prop)) {
194
- return callback(child, i);
195
- }
196
- });
197
- } else {
198
- return this.walk(function (child, i) {
199
- if (child.type === 'decl' && child.prop === prop) {
200
- return callback(child, i);
201
- }
202
- });
203
- }
204
- };
205
-
206
- /**
207
- * Traverses the container’s descendant nodes, calling callback
208
- * for each rule node.
209
- *
210
- * If you pass a filter, iteration will only happen over rules
211
- * with matching selectors.
212
- *
213
- * Like {@link Container#each}, this method is safe
214
- * to use if you are mutating arrays during iteration.
215
- *
216
- * @param {string|RegExp} [selector] - string or regular expression
217
- * to filter rules by selector
218
- * @param {childIterator} callback - iterator receives each node and index
219
- *
220
- * @return {false|undefined} returns `false` if iteration was broke
221
- *
222
- * @example
223
- * const selectors = [];
224
- * root.walkRules(rule => {
225
- * selectors.push(rule.selector);
226
- * });
227
- * console.log(`Your CSS uses ${selectors.length} selectors`);
228
- */
229
-
230
-
231
- Container.prototype.walkRules = function walkRules(selector, callback) {
232
- if (!callback) {
233
- callback = selector;
234
-
235
- return this.walk(function (child, i) {
236
- if (child.type === 'rule') {
237
- return callback(child, i);
238
- }
239
- });
240
- } else if (selector instanceof RegExp) {
241
- return this.walk(function (child, i) {
242
- if (child.type === 'rule' && selector.test(child.selector)) {
243
- return callback(child, i);
244
- }
245
- });
246
- } else {
247
- return this.walk(function (child, i) {
248
- if (child.type === 'rule' && child.selector === selector) {
249
- return callback(child, i);
250
- }
251
- });
153
+ throw e;
154
+ }
155
+ if (result !== false && child.walk) {
156
+ result = child.walk(callback);
157
+ }
158
+ return result;
159
+ });
160
+ };
161
+
162
+ /**
163
+ * Traverses the container’s descendant nodes, calling callback
164
+ * for each declaration node.
165
+ *
166
+ * If you pass a filter, iteration will only happen over declarations
167
+ * with matching properties.
168
+ *
169
+ * Like {@link Container#each}, this method is safe
170
+ * to use if you are mutating arrays during iteration.
171
+ *
172
+ * @param {string|RegExp} [prop] String or regular expression
173
+ * to filter declarations by property name.
174
+ * @param {childIterator} callback Iterator receives each node and index.
175
+ *
176
+ * @return {false|undefined} Returns `false` if iteration was broke.
177
+ *
178
+ * @example
179
+ * root.walkDecls(decl => {
180
+ * checkPropertySupport(decl.prop)
181
+ * })
182
+ *
183
+ * root.walkDecls('border-radius', decl => {
184
+ * decl.remove()
185
+ * })
186
+ *
187
+ * root.walkDecls(/^background/, decl => {
188
+ * decl.value = takeFirstColorFromGradient(decl.value)
189
+ * })
190
+ */
191
+
192
+
193
+ Container.prototype.walkDecls = function walkDecls(prop, callback) {
194
+ if (!callback) {
195
+ callback = prop;
196
+ return this.walk(function (child, i) {
197
+ if (child.type === 'decl') {
198
+ return callback(child, i);
252
199
  }
253
- };
254
-
255
- /**
256
- * Traverses the container’s descendant nodes, calling callback
257
- * for each at-rule node.
258
- *
259
- * If you pass a filter, iteration will only happen over at-rules
260
- * that have matching names.
261
- *
262
- * Like {@link Container#each}, this method is safe
263
- * to use if you are mutating arrays during iteration.
264
- *
265
- * @param {string|RegExp} [name] - string or regular expression
266
- * to filter at-rules by name
267
- * @param {childIterator} callback - iterator receives each node and index
268
- *
269
- * @return {false|undefined} returns `false` if iteration was broke
270
- *
271
- * @example
272
- * root.walkAtRules(rule => {
273
- * if ( isOld(rule.name) ) rule.remove();
274
- * });
275
- *
276
- * let first = false;
277
- * root.walkAtRules('charset', rule => {
278
- * if ( !first ) {
279
- * first = true;
280
- * } else {
281
- * rule.remove();
282
- * }
283
- * });
284
- */
285
-
286
-
287
- Container.prototype.walkAtRules = function walkAtRules(name, callback) {
288
- if (!callback) {
289
- callback = name;
290
- return this.walk(function (child, i) {
291
- if (child.type === 'atrule') {
292
- return callback(child, i);
293
- }
294
- });
295
- } else if (name instanceof RegExp) {
296
- return this.walk(function (child, i) {
297
- if (child.type === 'atrule' && name.test(child.name)) {
298
- return callback(child, i);
299
- }
300
- });
301
- } else {
302
- return this.walk(function (child, i) {
303
- if (child.type === 'atrule' && child.name === name) {
304
- return callback(child, i);
305
- }
306
- });
200
+ });
201
+ } else if (prop instanceof RegExp) {
202
+ return this.walk(function (child, i) {
203
+ if (child.type === 'decl' && prop.test(child.prop)) {
204
+ return callback(child, i);
307
205
  }
308
- };
309
-
310
- /**
311
- * Traverses the container’s descendant nodes, calling callback
312
- * for each comment node.
313
- *
314
- * Like {@link Container#each}, this method is safe
315
- * to use if you are mutating arrays during iteration.
316
- *
317
- * @param {childIterator} callback - iterator receives each node and index
318
- *
319
- * @return {false|undefined} returns `false` if iteration was broke
320
- *
321
- * @example
322
- * root.walkComments(comment => {
323
- * comment.remove();
324
- * });
325
- */
326
-
327
-
328
- Container.prototype.walkComments = function walkComments(callback) {
329
- return this.walk(function (child, i) {
330
- if (child.type === 'comment') {
331
- return callback(child, i);
332
- }
333
- });
334
- };
335
-
336
- /**
337
- * Inserts new nodes to the end of the container.
338
- *
339
- * @param {...(Node|object|string|Node[])} children - new nodes
340
- *
341
- * @return {Node} this node for methods chain
342
- *
343
- * @example
344
- * const decl1 = postcss.decl({ prop: 'color', value: 'black' });
345
- * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' });
346
- * rule.append(decl1, decl2);
347
- *
348
- * root.append({ name: 'charset', params: '"UTF-8"' }); // at-rule
349
- * root.append({ selector: 'a' }); // rule
350
- * rule.append({ prop: 'color', value: 'black' }); // declaration
351
- * rule.append({ text: 'Comment' }) // comment
352
- *
353
- * root.append('a {}');
354
- * root.first.append('color: black; z-index: 1');
355
- */
356
-
357
-
358
- Container.prototype.append = function append() {
359
- for (var _len = arguments.length, children = Array(_len), _key = 0; _key < _len; _key++) {
360
- children[_key] = arguments[_key];
206
+ });
207
+ } else {
208
+ return this.walk(function (child, i) {
209
+ if (child.type === 'decl' && child.prop === prop) {
210
+ return callback(child, i);
361
211
  }
362
-
363
- for (var _iterator = children, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
364
- var _ref;
365
-
366
- if (_isArray) {
367
- if (_i >= _iterator.length) break;
368
- _ref = _iterator[_i++];
369
- } else {
370
- _i = _iterator.next();
371
- if (_i.done) break;
372
- _ref = _i.value;
373
- }
374
-
375
- var child = _ref;
376
-
377
- var nodes = this.normalize(child, this.last);
378
- for (var _iterator2 = nodes, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {
379
- var _ref2;
380
-
381
- if (_isArray2) {
382
- if (_i2 >= _iterator2.length) break;
383
- _ref2 = _iterator2[_i2++];
384
- } else {
385
- _i2 = _iterator2.next();
386
- if (_i2.done) break;
387
- _ref2 = _i2.value;
388
- }
389
-
390
- var node = _ref2;
391
- this.nodes.push(node);
392
- }
212
+ });
213
+ }
214
+ };
215
+
216
+ /**
217
+ * Traverses the container’s descendant nodes, calling callback
218
+ * for each rule node.
219
+ *
220
+ * If you pass a filter, iteration will only happen over rules
221
+ * with matching selectors.
222
+ *
223
+ * Like {@link Container#each}, this method is safe
224
+ * to use if you are mutating arrays during iteration.
225
+ *
226
+ * @param {string|RegExp} [selector] String or regular expression
227
+ * to filter rules by selector.
228
+ * @param {childIterator} callback Iterator receives each node and index.
229
+ *
230
+ * @return {false|undefined} returns `false` if iteration was broke.
231
+ *
232
+ * @example
233
+ * const selectors = []
234
+ * root.walkRules(rule => {
235
+ * selectors.push(rule.selector)
236
+ * })
237
+ * console.log(`Your CSS uses ${ selectors.length } selectors`)
238
+ */
239
+
240
+
241
+ Container.prototype.walkRules = function walkRules(selector, callback) {
242
+ if (!callback) {
243
+ callback = selector;
244
+
245
+ return this.walk(function (child, i) {
246
+ if (child.type === 'rule') {
247
+ return callback(child, i);
393
248
  }
394
- return this;
395
- };
396
-
397
- /**
398
- * Inserts new nodes to the start of the container.
399
- *
400
- * @param {...(Node|object|string|Node[])} children - new nodes
401
- *
402
- * @return {Node} this node for methods chain
403
- *
404
- * @example
405
- * const decl1 = postcss.decl({ prop: 'color', value: 'black' });
406
- * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' });
407
- * rule.prepend(decl1, decl2);
408
- *
409
- * root.append({ name: 'charset', params: '"UTF-8"' }); // at-rule
410
- * root.append({ selector: 'a' }); // rule
411
- * rule.append({ prop: 'color', value: 'black' }); // declaration
412
- * rule.append({ text: 'Comment' }) // comment
413
- *
414
- * root.append('a {}');
415
- * root.first.append('color: black; z-index: 1');
416
- */
417
-
418
-
419
- Container.prototype.prepend = function prepend() {
420
- for (var _len2 = arguments.length, children = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
421
- children[_key2] = arguments[_key2];
249
+ });
250
+ } else if (selector instanceof RegExp) {
251
+ return this.walk(function (child, i) {
252
+ if (child.type === 'rule' && selector.test(child.selector)) {
253
+ return callback(child, i);
422
254
  }
423
-
424
- children = children.reverse();
425
- for (var _iterator3 = children, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {
426
- var _ref3;
427
-
428
- if (_isArray3) {
429
- if (_i3 >= _iterator3.length) break;
430
- _ref3 = _iterator3[_i3++];
431
- } else {
432
- _i3 = _iterator3.next();
433
- if (_i3.done) break;
434
- _ref3 = _i3.value;
435
- }
436
-
437
- var child = _ref3;
438
-
439
- var nodes = this.normalize(child, this.first, 'prepend').reverse();
440
- for (var _iterator4 = nodes, _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {
441
- var _ref4;
442
-
443
- if (_isArray4) {
444
- if (_i4 >= _iterator4.length) break;
445
- _ref4 = _iterator4[_i4++];
446
- } else {
447
- _i4 = _iterator4.next();
448
- if (_i4.done) break;
449
- _ref4 = _i4.value;
450
- }
451
-
452
- var node = _ref4;
453
- this.nodes.unshift(node);
454
- }for (var id in this.indexes) {
455
- this.indexes[id] = this.indexes[id] + nodes.length;
456
- }
255
+ });
256
+ } else {
257
+ return this.walk(function (child, i) {
258
+ if (child.type === 'rule' && child.selector === selector) {
259
+ return callback(child, i);
457
260
  }
458
- return this;
459
- };
460
-
461
- Container.prototype.cleanRaws = function cleanRaws(keepBetween) {
462
- _Node.prototype.cleanRaws.call(this, keepBetween);
463
- if (this.nodes) {
464
- for (var _iterator5 = this.nodes, _isArray5 = Array.isArray(_iterator5), _i5 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) {
465
- var _ref5;
466
-
467
- if (_isArray5) {
468
- if (_i5 >= _iterator5.length) break;
469
- _ref5 = _iterator5[_i5++];
470
- } else {
471
- _i5 = _iterator5.next();
472
- if (_i5.done) break;
473
- _ref5 = _i5.value;
474
- }
475
-
476
- var node = _ref5;
477
- node.cleanRaws(keepBetween);
478
- }
261
+ });
262
+ }
263
+ };
264
+
265
+ /**
266
+ * Traverses the container’s descendant nodes, calling callback
267
+ * for each at-rule node.
268
+ *
269
+ * If you pass a filter, iteration will only happen over at-rules
270
+ * that have matching names.
271
+ *
272
+ * Like {@link Container#each}, this method is safe
273
+ * to use if you are mutating arrays during iteration.
274
+ *
275
+ * @param {string|RegExp} [name] String or regular expression
276
+ * to filter at-rules by name.
277
+ * @param {childIterator} callback Iterator receives each node and index.
278
+ *
279
+ * @return {false|undefined} Returns `false` if iteration was broke.
280
+ *
281
+ * @example
282
+ * root.walkAtRules(rule => {
283
+ * if (isOld(rule.name)) rule.remove()
284
+ * })
285
+ *
286
+ * let first = false
287
+ * root.walkAtRules('charset', rule => {
288
+ * if (!first) {
289
+ * first = true
290
+ * } else {
291
+ * rule.remove()
292
+ * }
293
+ * })
294
+ */
295
+
296
+
297
+ Container.prototype.walkAtRules = function walkAtRules(name, callback) {
298
+ if (!callback) {
299
+ callback = name;
300
+ return this.walk(function (child, i) {
301
+ if (child.type === 'atrule') {
302
+ return callback(child, i);
479
303
  }
480
- };
481
-
482
- /**
483
- * Insert new node before old node within the container.
484
- *
485
- * @param {Node|number} exist - child or child’s index.
486
- * @param {Node|object|string|Node[]} add - new node
487
- *
488
- * @return {Node} this node for methods chain
489
- *
490
- * @example
491
- * rule.insertBefore(decl, decl.clone({ prop: '-webkit-' + decl.prop }));
492
- */
493
-
494
-
495
- Container.prototype.insertBefore = function insertBefore(exist, add) {
496
- exist = this.index(exist);
497
-
498
- var type = exist === 0 ? 'prepend' : false;
499
- var nodes = this.normalize(add, this.nodes[exist], type).reverse();
500
- for (var _iterator6 = nodes, _isArray6 = Array.isArray(_iterator6), _i6 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) {
501
- var _ref6;
502
-
503
- if (_isArray6) {
504
- if (_i6 >= _iterator6.length) break;
505
- _ref6 = _iterator6[_i6++];
506
- } else {
507
- _i6 = _iterator6.next();
508
- if (_i6.done) break;
509
- _ref6 = _i6.value;
510
- }
511
-
512
- var node = _ref6;
513
- this.nodes.splice(exist, 0, node);
514
- }var index = void 0;
515
- for (var id in this.indexes) {
516
- index = this.indexes[id];
517
- if (exist <= index) {
518
- this.indexes[id] = index + nodes.length;
519
- }
304
+ });
305
+ } else if (name instanceof RegExp) {
306
+ return this.walk(function (child, i) {
307
+ if (child.type === 'atrule' && name.test(child.name)) {
308
+ return callback(child, i);
520
309
  }
521
-
522
- return this;
523
- };
524
-
525
- /**
526
- * Insert new node after old node within the container.
527
- *
528
- * @param {Node|number} exist - child or child’s index
529
- * @param {Node|object|string|Node[]} add - new node
530
- *
531
- * @return {Node} this node for methods chain
532
- */
533
-
534
-
535
- Container.prototype.insertAfter = function insertAfter(exist, add) {
536
- exist = this.index(exist);
537
-
538
- var nodes = this.normalize(add, this.nodes[exist]).reverse();
539
- for (var _iterator7 = nodes, _isArray7 = Array.isArray(_iterator7), _i7 = 0, _iterator7 = _isArray7 ? _iterator7 : _iterator7[Symbol.iterator]();;) {
540
- var _ref7;
541
-
542
- if (_isArray7) {
543
- if (_i7 >= _iterator7.length) break;
544
- _ref7 = _iterator7[_i7++];
545
- } else {
546
- _i7 = _iterator7.next();
547
- if (_i7.done) break;
548
- _ref7 = _i7.value;
549
- }
550
-
551
- var node = _ref7;
552
- this.nodes.splice(exist + 1, 0, node);
553
- }var index = void 0;
554
- for (var id in this.indexes) {
555
- index = this.indexes[id];
556
- if (exist < index) {
557
- this.indexes[id] = index + nodes.length;
558
- }
310
+ });
311
+ } else {
312
+ return this.walk(function (child, i) {
313
+ if (child.type === 'atrule' && child.name === name) {
314
+ return callback(child, i);
559
315
  }
316
+ });
317
+ }
318
+ };
319
+
320
+ /**
321
+ * Traverses the container’s descendant nodes, calling callback
322
+ * for each comment node.
323
+ *
324
+ * Like {@link Container#each}, this method is safe
325
+ * to use if you are mutating arrays during iteration.
326
+ *
327
+ * @param {childIterator} callback Iterator receives each node and index.
328
+ *
329
+ * @return {false|undefined} Returns `false` if iteration was broke.
330
+ *
331
+ * @example
332
+ * root.walkComments(comment => {
333
+ * comment.remove()
334
+ * })
335
+ */
336
+
337
+
338
+ Container.prototype.walkComments = function walkComments(callback) {
339
+ return this.walk(function (child, i) {
340
+ if (child.type === 'comment') {
341
+ return callback(child, i);
342
+ }
343
+ });
344
+ };
345
+
346
+ /**
347
+ * Inserts new nodes to the end of the container.
348
+ *
349
+ * @param {...(Node|object|string|Node[])} children New nodes.
350
+ *
351
+ * @return {Node} This node for methods chain.
352
+ *
353
+ * @example
354
+ * const decl1 = postcss.decl({ prop: 'color', value: 'black' })
355
+ * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' })
356
+ * rule.append(decl1, decl2)
357
+ *
358
+ * root.append({ name: 'charset', params: '"UTF-8"' }) // at-rule
359
+ * root.append({ selector: 'a' }) // rule
360
+ * rule.append({ prop: 'color', value: 'black' }) // declaration
361
+ * rule.append({ text: 'Comment' }) // comment
362
+ *
363
+ * root.append('a {}')
364
+ * root.first.append('color: black; z-index: 1')
365
+ */
366
+
367
+
368
+ Container.prototype.append = function append() {
369
+ for (var _len = arguments.length, children = Array(_len), _key = 0; _key < _len; _key++) {
370
+ children[_key] = arguments[_key];
371
+ }
560
372
 
561
- return this;
562
- };
373
+ for (var _iterator = children, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
374
+ var _ref;
563
375
 
564
- /**
565
- * Removes node from the container and cleans the parent properties
566
- * from the node and its children.
567
- *
568
- * @param {Node|number} child - child or child’s index
569
- *
570
- * @return {Node} this node for methods chain
571
- *
572
- * @example
573
- * rule.nodes.length //=> 5
574
- * rule.removeChild(decl);
575
- * rule.nodes.length //=> 4
576
- * decl.parent //=> undefined
577
- */
376
+ if (_isArray) {
377
+ if (_i >= _iterator.length) break;
378
+ _ref = _iterator[_i++];
379
+ } else {
380
+ _i = _iterator.next();
381
+ if (_i.done) break;
382
+ _ref = _i.value;
383
+ }
578
384
 
385
+ var child = _ref;
579
386
 
580
- Container.prototype.removeChild = function removeChild(child) {
581
- child = this.index(child);
582
- this.nodes[child].parent = undefined;
583
- this.nodes.splice(child, 1);
387
+ var nodes = this.normalize(child, this.last);
388
+ for (var _iterator2 = nodes, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {
389
+ var _ref2;
584
390
 
585
- var index = void 0;
586
- for (var id in this.indexes) {
587
- index = this.indexes[id];
588
- if (index >= child) {
589
- this.indexes[id] = index - 1;
590
- }
391
+ if (_isArray2) {
392
+ if (_i2 >= _iterator2.length) break;
393
+ _ref2 = _iterator2[_i2++];
394
+ } else {
395
+ _i2 = _iterator2.next();
396
+ if (_i2.done) break;
397
+ _ref2 = _i2.value;
591
398
  }
592
399
 
593
- return this;
594
- };
595
-
596
- /**
597
- * Removes all children from the container
598
- * and cleans their parent properties.
599
- *
600
- * @return {Node} this node for methods chain
601
- *
602
- * @example
603
- * rule.removeAll();
604
- * rule.nodes.length //=> 0
605
- */
606
-
607
-
608
- Container.prototype.removeAll = function removeAll() {
609
- for (var _iterator8 = this.nodes, _isArray8 = Array.isArray(_iterator8), _i8 = 0, _iterator8 = _isArray8 ? _iterator8 : _iterator8[Symbol.iterator]();;) {
610
- var _ref8;
400
+ var node = _ref2;
401
+ this.nodes.push(node);
402
+ }
403
+ }
404
+ return this;
405
+ };
406
+
407
+ /**
408
+ * Inserts new nodes to the start of the container.
409
+ *
410
+ * @param {...(Node|object|string|Node[])} children New nodes.
411
+ *
412
+ * @return {Node} This node for methods chain.
413
+ *
414
+ * @example
415
+ * const decl1 = postcss.decl({ prop: 'color', value: 'black' })
416
+ * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' })
417
+ * rule.prepend(decl1, decl2)
418
+ *
419
+ * root.append({ name: 'charset', params: '"UTF-8"' }) // at-rule
420
+ * root.append({ selector: 'a' }) // rule
421
+ * rule.append({ prop: 'color', value: 'black' }) // declaration
422
+ * rule.append({ text: 'Comment' }) // comment
423
+ *
424
+ * root.append('a {}')
425
+ * root.first.append('color: black; z-index: 1')
426
+ */
427
+
428
+
429
+ Container.prototype.prepend = function prepend() {
430
+ for (var _len2 = arguments.length, children = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
431
+ children[_key2] = arguments[_key2];
432
+ }
611
433
 
612
- if (_isArray8) {
613
- if (_i8 >= _iterator8.length) break;
614
- _ref8 = _iterator8[_i8++];
615
- } else {
616
- _i8 = _iterator8.next();
617
- if (_i8.done) break;
618
- _ref8 = _i8.value;
619
- }
434
+ children = children.reverse();
435
+ for (var _iterator3 = children, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {
436
+ var _ref3;
620
437
 
621
- var node = _ref8;
622
- node.parent = undefined;
623
- }this.nodes = [];
624
- return this;
625
- };
438
+ if (_isArray3) {
439
+ if (_i3 >= _iterator3.length) break;
440
+ _ref3 = _iterator3[_i3++];
441
+ } else {
442
+ _i3 = _iterator3.next();
443
+ if (_i3.done) break;
444
+ _ref3 = _i3.value;
445
+ }
626
446
 
627
- /**
628
- * Passes all declaration values within the container that match pattern
629
- * through callback, replacing those values with the returned result
630
- * of callback.
631
- *
632
- * This method is useful if you are using a custom unit or function
633
- * and need to iterate through all values.
634
- *
635
- * @param {string|RegExp} pattern - replace pattern
636
- * @param {object} opts - options to speed up the search
637
- * @param {string|string[]} opts.props - an array of property names
638
- * @param {string} opts.fast - string that’s used
639
- * to narrow down values and speed up
640
- the regexp search
641
- * @param {function|string} callback - string to replace pattern
642
- * or callback that returns a new
643
- * value.
644
- * The callback will receive
645
- * the same arguments as those
646
- * passed to a function parameter
647
- * of `String#replace`.
648
- *
649
- * @return {Node} this node for methods chain
650
- *
651
- * @example
652
- * root.replaceValues(/\d+rem/, { fast: 'rem' }, string => {
653
- * return 15 * parseInt(string) + 'px';
654
- * });
655
- */
447
+ var child = _ref3;
656
448
 
449
+ var nodes = this.normalize(child, this.first, 'prepend').reverse();
450
+ for (var _iterator4 = nodes, _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {
451
+ var _ref4;
657
452
 
658
- Container.prototype.replaceValues = function replaceValues(pattern, opts, callback) {
659
- if (!callback) {
660
- callback = opts;
661
- opts = {};
453
+ if (_isArray4) {
454
+ if (_i4 >= _iterator4.length) break;
455
+ _ref4 = _iterator4[_i4++];
456
+ } else {
457
+ _i4 = _iterator4.next();
458
+ if (_i4.done) break;
459
+ _ref4 = _i4.value;
662
460
  }
663
461
 
664
- this.walkDecls(function (decl) {
665
- if (opts.props && opts.props.indexOf(decl.prop) === -1) return;
666
- if (opts.fast && decl.value.indexOf(opts.fast) === -1) return;
667
-
668
- decl.value = decl.value.replace(pattern, callback);
669
- });
670
-
671
- return this;
672
- };
673
-
674
- /**
675
- * Returns `true` if callback returns `true`
676
- * for all of the container’s children.
677
- *
678
- * @param {childCondition} condition - iterator returns true or false.
679
- *
680
- * @return {boolean} is every child pass condition
681
- *
682
- * @example
683
- * const noPrefixes = rule.every(i => i.prop[0] !== '-');
684
- */
685
-
462
+ var node = _ref4;
463
+ this.nodes.unshift(node);
464
+ }for (var id in this.indexes) {
465
+ this.indexes[id] = this.indexes[id] + nodes.length;
466
+ }
467
+ }
468
+ return this;
469
+ };
470
+
471
+ Container.prototype.cleanRaws = function cleanRaws(keepBetween) {
472
+ _Node.prototype.cleanRaws.call(this, keepBetween);
473
+ if (this.nodes) {
474
+ for (var _iterator5 = this.nodes, _isArray5 = Array.isArray(_iterator5), _i5 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) {
475
+ var _ref5;
476
+
477
+ if (_isArray5) {
478
+ if (_i5 >= _iterator5.length) break;
479
+ _ref5 = _iterator5[_i5++];
480
+ } else {
481
+ _i5 = _iterator5.next();
482
+ if (_i5.done) break;
483
+ _ref5 = _i5.value;
484
+ }
686
485
 
687
- Container.prototype.every = function every(condition) {
688
- return this.nodes.every(condition);
689
- };
486
+ var node = _ref5;
487
+ node.cleanRaws(keepBetween);
488
+ }
489
+ }
490
+ };
491
+
492
+ /**
493
+ * Insert new node before old node within the container.
494
+ *
495
+ * @param {Node|number} exist Child or child’s index.
496
+ * @param {Node|object|string|Node[]} add New node.
497
+ *
498
+ * @return {Node} This node for methods chain.
499
+ *
500
+ * @example
501
+ * rule.insertBefore(decl, decl.clone({ prop: '-webkit-' + decl.prop }))
502
+ */
503
+
504
+
505
+ Container.prototype.insertBefore = function insertBefore(exist, add) {
506
+ exist = this.index(exist);
507
+
508
+ var type = exist === 0 ? 'prepend' : false;
509
+ var nodes = this.normalize(add, this.nodes[exist], type).reverse();
510
+ for (var _iterator6 = nodes, _isArray6 = Array.isArray(_iterator6), _i6 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) {
511
+ var _ref6;
512
+
513
+ if (_isArray6) {
514
+ if (_i6 >= _iterator6.length) break;
515
+ _ref6 = _iterator6[_i6++];
516
+ } else {
517
+ _i6 = _iterator6.next();
518
+ if (_i6.done) break;
519
+ _ref6 = _i6.value;
520
+ }
521
+
522
+ var node = _ref6;
523
+ this.nodes.splice(exist, 0, node);
524
+ }var index = void 0;
525
+ for (var id in this.indexes) {
526
+ index = this.indexes[id];
527
+ if (exist <= index) {
528
+ this.indexes[id] = index + nodes.length;
529
+ }
530
+ }
690
531
 
691
- /**
692
- * Returns `true` if callback returns `true` for (at least) one
693
- * of the container’s children.
694
- *
695
- * @param {childCondition} condition - iterator returns true or false.
696
- *
697
- * @return {boolean} is some child pass condition
698
- *
699
- * @example
700
- * const hasPrefix = rule.some(i => i.prop[0] === '-');
701
- */
532
+ return this;
533
+ };
534
+
535
+ /**
536
+ * Insert new node after old node within the container.
537
+ *
538
+ * @param {Node|number} exist Child or child’s index.
539
+ * @param {Node|object|string|Node[]} add New node.
540
+ *
541
+ * @return {Node} This node for methods chain.
542
+ */
543
+
544
+
545
+ Container.prototype.insertAfter = function insertAfter(exist, add) {
546
+ exist = this.index(exist);
547
+
548
+ var nodes = this.normalize(add, this.nodes[exist]).reverse();
549
+ for (var _iterator7 = nodes, _isArray7 = Array.isArray(_iterator7), _i7 = 0, _iterator7 = _isArray7 ? _iterator7 : _iterator7[Symbol.iterator]();;) {
550
+ var _ref7;
551
+
552
+ if (_isArray7) {
553
+ if (_i7 >= _iterator7.length) break;
554
+ _ref7 = _iterator7[_i7++];
555
+ } else {
556
+ _i7 = _iterator7.next();
557
+ if (_i7.done) break;
558
+ _ref7 = _i7.value;
559
+ }
560
+
561
+ var node = _ref7;
562
+ this.nodes.splice(exist + 1, 0, node);
563
+ }var index = void 0;
564
+ for (var id in this.indexes) {
565
+ index = this.indexes[id];
566
+ if (exist < index) {
567
+ this.indexes[id] = index + nodes.length;
568
+ }
569
+ }
702
570
 
571
+ return this;
572
+ };
573
+
574
+ /**
575
+ * Removes node from the container and cleans the parent properties
576
+ * from the node and its children.
577
+ *
578
+ * @param {Node|number} child Child or child’s index.
579
+ *
580
+ * @return {Node} This node for methods chain
581
+ *
582
+ * @example
583
+ * rule.nodes.length //=> 5
584
+ * rule.removeChild(decl)
585
+ * rule.nodes.length //=> 4
586
+ * decl.parent //=> undefined
587
+ */
588
+
589
+
590
+ Container.prototype.removeChild = function removeChild(child) {
591
+ child = this.index(child);
592
+ this.nodes[child].parent = undefined;
593
+ this.nodes.splice(child, 1);
594
+
595
+ var index = void 0;
596
+ for (var id in this.indexes) {
597
+ index = this.indexes[id];
598
+ if (index >= child) {
599
+ this.indexes[id] = index - 1;
600
+ }
601
+ }
703
602
 
704
- Container.prototype.some = function some(condition) {
705
- return this.nodes.some(condition);
706
- };
603
+ return this;
604
+ };
605
+
606
+ /**
607
+ * Removes all children from the container
608
+ * and cleans their parent properties.
609
+ *
610
+ * @return {Node} This node for methods chain.
611
+ *
612
+ * @example
613
+ * rule.removeAll()
614
+ * rule.nodes.length //=> 0
615
+ */
616
+
617
+
618
+ Container.prototype.removeAll = function removeAll() {
619
+ for (var _iterator8 = this.nodes, _isArray8 = Array.isArray(_iterator8), _i8 = 0, _iterator8 = _isArray8 ? _iterator8 : _iterator8[Symbol.iterator]();;) {
620
+ var _ref8;
621
+
622
+ if (_isArray8) {
623
+ if (_i8 >= _iterator8.length) break;
624
+ _ref8 = _iterator8[_i8++];
625
+ } else {
626
+ _i8 = _iterator8.next();
627
+ if (_i8.done) break;
628
+ _ref8 = _i8.value;
629
+ }
630
+
631
+ var node = _ref8;
632
+ node.parent = undefined;
633
+ }this.nodes = [];
634
+ return this;
635
+ };
636
+
637
+ /**
638
+ * Passes all declaration values within the container that match pattern
639
+ * through callback, replacing those values with the returned result
640
+ * of callback.
641
+ *
642
+ * This method is useful if you are using a custom unit or function
643
+ * and need to iterate through all values.
644
+ *
645
+ * @param {string|RegExp} pattern Replace pattern.
646
+ * @param {object} opts Options to speed up the search.
647
+ * @param {string|string[]} opts.props An array of property names.
648
+ * @param {string} opts.fast String that’s used to narrow down
649
+ * values and speed up the regexp search.
650
+ * @param {function|string} callback String to replace pattern or callback
651
+ * that returns a new value. The callback
652
+ * will receive the same arguments
653
+ * as those passed to a function parameter
654
+ * of `String#replace`.
655
+ *
656
+ * @return {Node} This node for methods chain.
657
+ *
658
+ * @example
659
+ * root.replaceValues(/\d+rem/, { fast: 'rem' }, string => {
660
+ * return 15 * parseInt(string) + 'px'
661
+ * })
662
+ */
663
+
664
+
665
+ Container.prototype.replaceValues = function replaceValues(pattern, opts, callback) {
666
+ if (!callback) {
667
+ callback = opts;
668
+ opts = {};
669
+ }
707
670
 
708
- /**
709
- * Returns a `child`’s index within the {@link Container#nodes} array.
710
- *
711
- * @param {Node} child - child of the current container.
712
- *
713
- * @return {number} child index
714
- *
715
- * @example
716
- * rule.index( rule.nodes[2] ) //=> 2
717
- */
671
+ this.walkDecls(function (decl) {
672
+ if (opts.props && opts.props.indexOf(decl.prop) === -1) return;
673
+ if (opts.fast && decl.value.indexOf(opts.fast) === -1) return;
718
674
 
675
+ decl.value = decl.value.replace(pattern, callback);
676
+ });
719
677
 
720
- Container.prototype.index = function index(child) {
721
- if (typeof child === 'number') {
722
- return child;
678
+ return this;
679
+ };
680
+
681
+ /**
682
+ * Returns `true` if callback returns `true`
683
+ * for all of the container’s children.
684
+ *
685
+ * @param {childCondition} condition Iterator returns true or false.
686
+ *
687
+ * @return {boolean} Is every child pass condition.
688
+ *
689
+ * @example
690
+ * const noPrefixes = rule.every(i => i.prop[0] !== '-')
691
+ */
692
+
693
+
694
+ Container.prototype.every = function every(condition) {
695
+ return this.nodes.every(condition);
696
+ };
697
+
698
+ /**
699
+ * Returns `true` if callback returns `true` for (at least) one
700
+ * of the container’s children.
701
+ *
702
+ * @param {childCondition} condition Iterator returns true or false.
703
+ *
704
+ * @return {boolean} Is some child pass condition.
705
+ *
706
+ * @example
707
+ * const hasPrefix = rule.some(i => i.prop[0] === '-')
708
+ */
709
+
710
+
711
+ Container.prototype.some = function some(condition) {
712
+ return this.nodes.some(condition);
713
+ };
714
+
715
+ /**
716
+ * Returns a `child`’s index within the {@link Container#nodes} array.
717
+ *
718
+ * @param {Node} child Child of the current container.
719
+ *
720
+ * @return {number} Child index.
721
+ *
722
+ * @example
723
+ * rule.index( rule.nodes[2] ) //=> 2
724
+ */
725
+
726
+
727
+ Container.prototype.index = function index(child) {
728
+ if (typeof child === 'number') {
729
+ return child;
730
+ } else {
731
+ return this.nodes.indexOf(child);
732
+ }
733
+ };
734
+
735
+ /**
736
+ * The container’s first child.
737
+ *
738
+ * @type {Node}
739
+ *
740
+ * @example
741
+ * rule.first === rules.nodes[0]
742
+ */
743
+
744
+
745
+ Container.prototype.normalize = function normalize(nodes, sample) {
746
+ var _this2 = this;
747
+
748
+ if (typeof nodes === 'string') {
749
+ var parse = require('./parse');
750
+ nodes = cleanSource(parse(nodes).nodes);
751
+ } else if (Array.isArray(nodes)) {
752
+ nodes = nodes.slice(0);
753
+ for (var _iterator9 = nodes, _isArray9 = Array.isArray(_iterator9), _i9 = 0, _iterator9 = _isArray9 ? _iterator9 : _iterator9[Symbol.iterator]();;) {
754
+ var _ref9;
755
+
756
+ if (_isArray9) {
757
+ if (_i9 >= _iterator9.length) break;
758
+ _ref9 = _iterator9[_i9++];
723
759
  } else {
724
- return this.nodes.indexOf(child);
760
+ _i9 = _iterator9.next();
761
+ if (_i9.done) break;
762
+ _ref9 = _i9.value;
725
763
  }
726
- };
727
764
 
728
- /**
729
- * The container’s first child.
730
- *
731
- * @type {Node}
732
- *
733
- * @example
734
- * rule.first == rules.nodes[0];
735
- */
765
+ var i = _ref9;
736
766
 
767
+ if (i.parent) i.parent.removeChild(i, 'ignore');
768
+ }
769
+ } else if (nodes.type === 'root') {
770
+ nodes = nodes.nodes.slice(0);
771
+ for (var _iterator10 = nodes, _isArray10 = Array.isArray(_iterator10), _i11 = 0, _iterator10 = _isArray10 ? _iterator10 : _iterator10[Symbol.iterator]();;) {
772
+ var _ref10;
737
773
 
738
- Container.prototype.normalize = function normalize(nodes, sample) {
739
- var _this2 = this;
740
-
741
- if (typeof nodes === 'string') {
742
- var parse = require('./parse');
743
- nodes = cleanSource(parse(nodes).nodes);
744
- } else if (Array.isArray(nodes)) {
745
- nodes = nodes.slice(0);
746
- for (var _iterator9 = nodes, _isArray9 = Array.isArray(_iterator9), _i9 = 0, _iterator9 = _isArray9 ? _iterator9 : _iterator9[Symbol.iterator]();;) {
747
- var _ref9;
748
-
749
- if (_isArray9) {
750
- if (_i9 >= _iterator9.length) break;
751
- _ref9 = _iterator9[_i9++];
752
- } else {
753
- _i9 = _iterator9.next();
754
- if (_i9.done) break;
755
- _ref9 = _i9.value;
756
- }
757
-
758
- var i = _ref9;
759
-
760
- if (i.parent) i.parent.removeChild(i, 'ignore');
761
- }
762
- } else if (nodes.type === 'root') {
763
- nodes = nodes.nodes.slice(0);
764
- for (var _iterator10 = nodes, _isArray10 = Array.isArray(_iterator10), _i11 = 0, _iterator10 = _isArray10 ? _iterator10 : _iterator10[Symbol.iterator]();;) {
765
- var _ref10;
766
-
767
- if (_isArray10) {
768
- if (_i11 >= _iterator10.length) break;
769
- _ref10 = _iterator10[_i11++];
770
- } else {
771
- _i11 = _iterator10.next();
772
- if (_i11.done) break;
773
- _ref10 = _i11.value;
774
- }
775
-
776
- var _i10 = _ref10;
777
-
778
- if (_i10.parent) _i10.parent.removeChild(_i10, 'ignore');
779
- }
780
- } else if (nodes.type) {
781
- nodes = [nodes];
782
- } else if (nodes.prop) {
783
- if (typeof nodes.value === 'undefined') {
784
- throw new Error('Value field is missed in node creation');
785
- } else if (typeof nodes.value !== 'string') {
786
- nodes.value = String(nodes.value);
787
- }
788
- nodes = [new _declaration2.default(nodes)];
789
- } else if (nodes.selector) {
790
- var Rule = require('./rule');
791
- nodes = [new Rule(nodes)];
792
- } else if (nodes.name) {
793
- var AtRule = require('./at-rule');
794
- nodes = [new AtRule(nodes)];
795
- } else if (nodes.text) {
796
- nodes = [new _comment2.default(nodes)];
774
+ if (_isArray10) {
775
+ if (_i11 >= _iterator10.length) break;
776
+ _ref10 = _iterator10[_i11++];
797
777
  } else {
798
- throw new Error('Unknown node type in node creation');
778
+ _i11 = _iterator10.next();
779
+ if (_i11.done) break;
780
+ _ref10 = _i11.value;
799
781
  }
800
782
 
801
- var processed = nodes.map(function (i) {
802
- if (typeof i.before !== 'function') i = _this2.rebuild(i);
803
-
804
- if (i.parent) i.parent.removeChild(i);
805
- if (typeof i.raws.before === 'undefined') {
806
- if (sample && typeof sample.raws.before !== 'undefined') {
807
- i.raws.before = sample.raws.before.replace(/[^\s]/g, '');
808
- }
809
- }
810
- i.parent = _this2;
811
- return i;
812
- });
813
-
814
- return processed;
815
- };
816
-
817
- Container.prototype.rebuild = function rebuild(node, parent) {
818
- var _this3 = this;
819
-
820
- var fix = void 0;
821
- if (node.type === 'root') {
822
- var Root = require('./root');
823
- fix = new Root();
824
- } else if (node.type === 'atrule') {
825
- var AtRule = require('./at-rule');
826
- fix = new AtRule();
827
- } else if (node.type === 'rule') {
828
- var Rule = require('./rule');
829
- fix = new Rule();
830
- } else if (node.type === 'decl') {
831
- fix = new _declaration2.default();
832
- } else if (node.type === 'comment') {
833
- fix = new _comment2.default();
834
- }
783
+ var _i10 = _ref10;
784
+
785
+ if (_i10.parent) _i10.parent.removeChild(_i10, 'ignore');
786
+ }
787
+ } else if (nodes.type) {
788
+ nodes = [nodes];
789
+ } else if (nodes.prop) {
790
+ if (typeof nodes.value === 'undefined') {
791
+ throw new Error('Value field is missed in node creation');
792
+ } else if (typeof nodes.value !== 'string') {
793
+ nodes.value = String(nodes.value);
794
+ }
795
+ nodes = [new _declaration2.default(nodes)];
796
+ } else if (nodes.selector) {
797
+ var Rule = require('./rule');
798
+ nodes = [new Rule(nodes)];
799
+ } else if (nodes.name) {
800
+ var AtRule = require('./at-rule');
801
+ nodes = [new AtRule(nodes)];
802
+ } else if (nodes.text) {
803
+ nodes = [new _comment2.default(nodes)];
804
+ } else {
805
+ throw new Error('Unknown node type in node creation');
806
+ }
835
807
 
836
- for (var i in node) {
837
- if (i === 'nodes') {
838
- fix.nodes = node.nodes.map(function (j) {
839
- return _this3.rebuild(j, fix);
840
- });
841
- } else if (i === 'parent' && parent) {
842
- fix.parent = parent;
843
- } else if (node.hasOwnProperty(i)) {
844
- fix[i] = node[i];
845
- }
808
+ var processed = nodes.map(function (i) {
809
+ if (i.parent) i.parent.removeChild(i);
810
+ if (typeof i.raws.before === 'undefined') {
811
+ if (sample && typeof sample.raws.before !== 'undefined') {
812
+ i.raws.before = sample.raws.before.replace(/[^\s]/g, '');
846
813
  }
814
+ }
815
+ i.parent = _this2;
816
+ return i;
817
+ });
847
818
 
848
- return fix;
849
- };
819
+ return processed;
820
+ };
821
+
822
+ /**
823
+ * @memberof Container#
824
+ * @member {Node[]} nodes An array containing the container’s children.
825
+ *
826
+ * @example
827
+ * const root = postcss.parse('a { color: black }')
828
+ * root.nodes.length //=> 1
829
+ * root.nodes[0].selector //=> 'a'
830
+ * root.nodes[0].nodes[0].prop //=> 'color'
831
+ */
832
+
833
+
834
+ _createClass(Container, [{
835
+ key: 'first',
836
+ get: function get() {
837
+ if (!this.nodes) return undefined;
838
+ return this.nodes[0];
839
+ }
850
840
 
851
841
  /**
852
- * @memberof Container#
853
- * @member {Node[]} nodes - an array containing the container’s children
842
+ * The container’s last child.
843
+ *
844
+ * @type {Node}
854
845
  *
855
846
  * @example
856
- * const root = postcss.parse('a { color: black }');
857
- * root.nodes.length //=> 1
858
- * root.nodes[0].selector //=> 'a'
859
- * root.nodes[0].nodes[0].prop //=> 'color'
847
+ * rule.last === rule.nodes[rule.nodes.length - 1]
860
848
  */
861
849
 
862
- _createClass(Container, [{
863
- key: 'first',
864
- get: function get() {
865
- if (!this.nodes) return undefined;
866
- return this.nodes[0];
867
- }
868
-
869
- /**
870
- * The container’s last child.
871
- *
872
- * @type {Node}
873
- *
874
- * @example
875
- * rule.last == rule.nodes[rule.nodes.length - 1];
876
- */
877
-
878
- }, {
879
- key: 'last',
880
- get: function get() {
881
- if (!this.nodes) return undefined;
882
- return this.nodes[this.nodes.length - 1];
883
- }
884
- }]);
850
+ }, {
851
+ key: 'last',
852
+ get: function get() {
853
+ if (!this.nodes) return undefined;
854
+ return this.nodes[this.nodes.length - 1];
855
+ }
856
+ }]);
885
857
 
886
- return Container;
858
+ return Container;
887
859
  }(_node2.default);
888
860
 
889
861
  exports.default = Container;
890
862
 
891
863
  /**
892
864
  * @callback childCondition
893
- * @param {Node} node - container child
894
- * @param {number} index - child index
895
- * @param {Node[]} nodes - all container children
865
+ * @param {Node} node Container child.
866
+ * @param {number} index Child index.
867
+ * @param {Node[]} nodes All container children.
896
868
  * @return {boolean}
897
869
  */
898
870
 
899
871
  /**
900
872
  * @callback childIterator
901
- * @param {Node} node - container child
902
- * @param {number} index - child index
903
- * @return {false|undefined} returning `false` will break iteration
873
+ * @param {Node} node Container child.
874
+ * @param {number} index Child index.
875
+ * @return {false|undefined} Returning `false` will break iteration.
904
876
  */
905
877
 
906
878
  module.exports = exports['default'];
907
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["container.es6"],"names":["cleanSource","nodes","map","i","source","Container","push","child","parent","each","callback","lastEach","indexes","id","undefined","index","result","length","walk","walkDecls","prop","type","RegExp","test","walkRules","selector","walkAtRules","name","walkComments","append","children","normalize","last","node","prepend","reverse","first","unshift","cleanRaws","keepBetween","insertBefore","exist","add","splice","insertAfter","removeChild","removeAll","replaceValues","pattern","opts","props","indexOf","decl","fast","value","replace","every","condition","some","sample","parse","require","Array","isArray","slice","Error","String","Declaration","Rule","AtRule","text","Comment","processed","before","rebuild","raws","fix","Root","j","hasOwnProperty","Node"],"mappings":"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","file":"container.js","sourcesContent":["import Declaration from './declaration';\nimport Comment     from './comment';\nimport Node        from './node';\n\nfunction cleanSource(nodes) {\n    return nodes.map( i => {\n        if ( i.nodes ) i.nodes = cleanSource(i.nodes);\n        delete i.source;\n        return i;\n    });\n}\n\n/**\n * The {@link Root}, {@link AtRule}, and {@link Rule} container nodes\n * inherit some common methods to help work with their children.\n *\n * Note that all containers can store any content. If you write a rule inside\n * a rule, PostCSS will parse it.\n *\n * @extends Node\n * @abstract\n */\nclass Container extends Node {\n\n    push(child) {\n        child.parent = this;\n        this.nodes.push(child);\n        return this;\n    }\n\n    /**\n     * Iterates through the container’s immediate children,\n     * calling `callback` for each child.\n     *\n     * Returning `false` in the callback will break iteration.\n     *\n     * This method only iterates through the container’s immediate children.\n     * If you need to recursively iterate through all the container’s descendant\n     * nodes, use {@link Container#walk}.\n     *\n     * Unlike the for `{}`-cycle or `Array#forEach` this iterator is safe\n     * if you are mutating the array of child nodes during iteration.\n     * PostCSS will adjust the current index to match the mutations.\n     *\n     * @param {childIterator} callback - iterator receives each node and index\n     *\n     * @return {false|undefined} returns `false` if iteration was broke\n     *\n     * @example\n     * const root = postcss.parse('a { color: black; z-index: 1 }');\n     * const rule = root.first;\n     *\n     * for ( let decl of rule.nodes ) {\n     *     decl.cloneBefore({ prop: '-webkit-' + decl.prop });\n     *     // Cycle will be infinite, because cloneBefore moves the current node\n     *     // to the next index\n     * }\n     *\n     * rule.each(decl => {\n     *     decl.cloneBefore({ prop: '-webkit-' + decl.prop });\n     *     // Will be executed only for color and z-index\n     * });\n     */\n    each(callback) {\n        if ( !this.lastEach ) this.lastEach = 0;\n        if ( !this.indexes ) this.indexes = { };\n\n        this.lastEach += 1;\n        let id = this.lastEach;\n        this.indexes[id] = 0;\n\n        if ( !this.nodes ) return undefined;\n\n        let index, result;\n        while ( this.indexes[id] < this.nodes.length ) {\n            index  = this.indexes[id];\n            result = callback(this.nodes[index], index);\n            if ( result === false ) break;\n\n            this.indexes[id] += 1;\n        }\n\n        delete this.indexes[id];\n\n        return result;\n    }\n\n    /**\n     * Traverses the container’s descendant nodes, calling callback\n     * for each node.\n     *\n     * Like container.each(), this method is safe to use\n     * if you are mutating arrays during iteration.\n     *\n     * If you only need to iterate through the container’s immediate children,\n     * use {@link Container#each}.\n     *\n     * @param {childIterator} callback - iterator receives each node and index\n     *\n     * @return {false|undefined} returns `false` if iteration was broke\n     *\n     * @example\n     * root.walk(node => {\n     *   // Traverses all descendant nodes.\n     * });\n     */\n    walk(callback) {\n        return this.each( (child, i) => {\n            let result = callback(child, i);\n            if ( result !== false && child.walk ) {\n                result = child.walk(callback);\n            }\n            return result;\n        });\n    }\n\n    /**\n     * Traverses the container’s descendant nodes, calling callback\n     * for each declaration node.\n     *\n     * If you pass a filter, iteration will only happen over declarations\n     * with matching properties.\n     *\n     * Like {@link Container#each}, this method is safe\n     * to use if you are mutating arrays during iteration.\n     *\n     * @param {string|RegExp} [prop]   - string or regular expression\n     *                                   to filter declarations by property name\n     * @param {childIterator} callback - iterator receives each node and index\n     *\n     * @return {false|undefined} returns `false` if iteration was broke\n     *\n     * @example\n     * root.walkDecls(decl => {\n     *   checkPropertySupport(decl.prop);\n     * });\n     *\n     * root.walkDecls('border-radius', decl => {\n     *   decl.remove();\n     * });\n     *\n     * root.walkDecls(/^background/, decl => {\n     *   decl.value = takeFirstColorFromGradient(decl.value);\n     * });\n     */\n    walkDecls(prop, callback) {\n        if ( !callback ) {\n            callback = prop;\n            return this.walk( (child, i) => {\n                if ( child.type === 'decl' ) {\n                    return callback(child, i);\n                }\n            });\n        } else if ( prop instanceof RegExp ) {\n            return this.walk( (child, i) => {\n                if ( child.type === 'decl' && prop.test(child.prop) ) {\n                    return callback(child, i);\n                }\n            });\n        } else {\n            return this.walk( (child, i) => {\n                if ( child.type === 'decl' && child.prop === prop ) {\n                    return callback(child, i);\n                }\n            });\n        }\n    }\n\n    /**\n     * Traverses the container’s descendant nodes, calling callback\n     * for each rule node.\n     *\n     * If you pass a filter, iteration will only happen over rules\n     * with matching selectors.\n     *\n     * Like {@link Container#each}, this method is safe\n     * to use if you are mutating arrays during iteration.\n     *\n     * @param {string|RegExp} [selector] - string or regular expression\n     *                                     to filter rules by selector\n     * @param {childIterator} callback   - iterator receives each node and index\n     *\n     * @return {false|undefined} returns `false` if iteration was broke\n     *\n     * @example\n     * const selectors = [];\n     * root.walkRules(rule => {\n     *   selectors.push(rule.selector);\n     * });\n     * console.log(`Your CSS uses ${selectors.length} selectors`);\n     */\n    walkRules(selector, callback) {\n        if ( !callback ) {\n            callback = selector;\n\n            return this.walk( (child, i) => {\n                if ( child.type === 'rule' ) {\n                    return callback(child, i);\n                }\n            });\n        } else if ( selector instanceof RegExp ) {\n            return this.walk( (child, i) => {\n                if ( child.type === 'rule' && selector.test(child.selector) ) {\n                    return callback(child, i);\n                }\n            });\n        } else {\n            return this.walk( (child, i) => {\n                if ( child.type === 'rule' && child.selector === selector ) {\n                    return callback(child, i);\n                }\n            });\n        }\n    }\n\n    /**\n     * Traverses the container’s descendant nodes, calling callback\n     * for each at-rule node.\n     *\n     * If you pass a filter, iteration will only happen over at-rules\n     * that have matching names.\n     *\n     * Like {@link Container#each}, this method is safe\n     * to use if you are mutating arrays during iteration.\n     *\n     * @param {string|RegExp} [name]   - string or regular expression\n     *                                   to filter at-rules by name\n     * @param {childIterator} callback - iterator receives each node and index\n     *\n     * @return {false|undefined} returns `false` if iteration was broke\n     *\n     * @example\n     * root.walkAtRules(rule => {\n     *   if ( isOld(rule.name) ) rule.remove();\n     * });\n     *\n     * let first = false;\n     * root.walkAtRules('charset', rule => {\n     *   if ( !first ) {\n     *     first = true;\n     *   } else {\n     *     rule.remove();\n     *   }\n     * });\n     */\n    walkAtRules(name, callback) {\n        if ( !callback ) {\n            callback = name;\n            return this.walk( (child, i) => {\n                if ( child.type === 'atrule' ) {\n                    return callback(child, i);\n                }\n            });\n        } else if ( name instanceof RegExp ) {\n            return this.walk( (child, i) => {\n                if ( child.type === 'atrule' && name.test(child.name) ) {\n                    return callback(child, i);\n                }\n            });\n        } else {\n            return this.walk( (child, i) => {\n                if ( child.type === 'atrule' && child.name === name ) {\n                    return callback(child, i);\n                }\n            });\n        }\n    }\n\n    /**\n     * Traverses the container’s descendant nodes, calling callback\n     * for each comment node.\n     *\n     * Like {@link Container#each}, this method is safe\n     * to use if you are mutating arrays during iteration.\n     *\n     * @param {childIterator} callback - iterator receives each node and index\n     *\n     * @return {false|undefined} returns `false` if iteration was broke\n     *\n     * @example\n     * root.walkComments(comment => {\n     *   comment.remove();\n     * });\n     */\n    walkComments(callback) {\n        return this.walk( (child, i) => {\n            if ( child.type === 'comment' ) {\n                return callback(child, i);\n            }\n        });\n    }\n\n    /**\n     * Inserts new nodes to the end of the container.\n     *\n     * @param {...(Node|object|string|Node[])} children - new nodes\n     *\n     * @return {Node} this node for methods chain\n     *\n     * @example\n     * const decl1 = postcss.decl({ prop: 'color', value: 'black' });\n     * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' });\n     * rule.append(decl1, decl2);\n     *\n     * root.append({ name: 'charset', params: '\"UTF-8\"' });  // at-rule\n     * root.append({ selector: 'a' });                       // rule\n     * rule.append({ prop: 'color', value: 'black' });       // declaration\n     * rule.append({ text: 'Comment' })                      // comment\n     *\n     * root.append('a {}');\n     * root.first.append('color: black; z-index: 1');\n     */\n    append(...children) {\n        for ( let child of children ) {\n            let nodes = this.normalize(child, this.last);\n            for ( let node of nodes ) this.nodes.push(node);\n        }\n        return this;\n    }\n\n    /**\n     * Inserts new nodes to the start of the container.\n     *\n     * @param {...(Node|object|string|Node[])} children - new nodes\n     *\n     * @return {Node} this node for methods chain\n     *\n     * @example\n     * const decl1 = postcss.decl({ prop: 'color', value: 'black' });\n     * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' });\n     * rule.prepend(decl1, decl2);\n     *\n     * root.append({ name: 'charset', params: '\"UTF-8\"' });  // at-rule\n     * root.append({ selector: 'a' });                       // rule\n     * rule.append({ prop: 'color', value: 'black' });       // declaration\n     * rule.append({ text: 'Comment' })                      // comment\n     *\n     * root.append('a {}');\n     * root.first.append('color: black; z-index: 1');\n     */\n    prepend(...children) {\n        children = children.reverse();\n        for ( let child of children ) {\n            let nodes = this.normalize(child, this.first, 'prepend').reverse();\n            for ( let node of nodes ) this.nodes.unshift(node);\n            for ( let id in this.indexes ) {\n                this.indexes[id] = this.indexes[id] + nodes.length;\n            }\n        }\n        return this;\n    }\n\n    cleanRaws(keepBetween) {\n        super.cleanRaws(keepBetween);\n        if ( this.nodes ) {\n            for ( let node of this.nodes ) node.cleanRaws(keepBetween);\n        }\n    }\n\n    /**\n     * Insert new node before old node within the container.\n     *\n     * @param {Node|number} exist             - child or child’s index.\n     * @param {Node|object|string|Node[]} add - new node\n     *\n     * @return {Node} this node for methods chain\n     *\n     * @example\n     * rule.insertBefore(decl, decl.clone({ prop: '-webkit-' + decl.prop }));\n     */\n    insertBefore(exist, add) {\n        exist = this.index(exist);\n\n        let type  = exist === 0 ? 'prepend' : false;\n        let nodes = this.normalize(add, this.nodes[exist], type).reverse();\n        for ( let node of nodes ) this.nodes.splice(exist, 0, node);\n\n        let index;\n        for ( let id in this.indexes ) {\n            index = this.indexes[id];\n            if ( exist <= index ) {\n                this.indexes[id] = index + nodes.length;\n            }\n        }\n\n        return this;\n    }\n\n    /**\n     * Insert new node after old node within the container.\n     *\n     * @param {Node|number} exist             - child or child’s index\n     * @param {Node|object|string|Node[]} add - new node\n     *\n     * @return {Node} this node for methods chain\n     */\n    insertAfter(exist, add) {\n        exist = this.index(exist);\n\n        let nodes = this.normalize(add, this.nodes[exist]).reverse();\n        for ( let node of nodes ) this.nodes.splice(exist + 1, 0, node);\n\n        let index;\n        for ( let id in this.indexes ) {\n            index = this.indexes[id];\n            if ( exist < index ) {\n                this.indexes[id] = index + nodes.length;\n            }\n        }\n\n        return this;\n    }\n\n    /**\n     * Removes node from the container and cleans the parent properties\n     * from the node and its children.\n     *\n     * @param {Node|number} child - child or child’s index\n     *\n     * @return {Node} this node for methods chain\n     *\n     * @example\n     * rule.nodes.length  //=> 5\n     * rule.removeChild(decl);\n     * rule.nodes.length  //=> 4\n     * decl.parent        //=> undefined\n     */\n    removeChild(child) {\n        child = this.index(child);\n        this.nodes[child].parent = undefined;\n        this.nodes.splice(child, 1);\n\n        let index;\n        for ( let id in this.indexes ) {\n            index = this.indexes[id];\n            if ( index >= child ) {\n                this.indexes[id] = index - 1;\n            }\n        }\n\n        return this;\n    }\n\n    /**\n     * Removes all children from the container\n     * and cleans their parent properties.\n     *\n     * @return {Node} this node for methods chain\n     *\n     * @example\n     * rule.removeAll();\n     * rule.nodes.length //=> 0\n     */\n    removeAll() {\n        for ( let node of this.nodes ) node.parent = undefined;\n        this.nodes = [];\n        return this;\n    }\n\n    /**\n     * Passes all declaration values within the container that match pattern\n     * through callback, replacing those values with the returned result\n     * of callback.\n     *\n     * This method is useful if you are using a custom unit or function\n     * and need to iterate through all values.\n     *\n     * @param {string|RegExp} pattern      - replace pattern\n     * @param {object} opts                - options to speed up the search\n     * @param {string|string[]} opts.props - an array of property names\n     * @param {string} opts.fast           - string that’s used\n     *                                       to narrow down values and speed up\n                                             the regexp search\n     * @param {function|string} callback   - string to replace pattern\n     *                                       or callback that returns a new\n     *                                       value.\n     *                                       The callback will receive\n     *                                       the same arguments as those\n     *                                       passed to a function parameter\n     *                                       of `String#replace`.\n     *\n     * @return {Node} this node for methods chain\n     *\n     * @example\n     * root.replaceValues(/\\d+rem/, { fast: 'rem' }, string => {\n     *   return 15 * parseInt(string) + 'px';\n     * });\n     */\n    replaceValues(pattern, opts, callback) {\n        if ( !callback ) {\n            callback = opts;\n            opts = { };\n        }\n\n        this.walkDecls( decl => {\n            if ( opts.props && opts.props.indexOf(decl.prop) === -1 ) return;\n            if ( opts.fast  && decl.value.indexOf(opts.fast) === -1 ) return;\n\n            decl.value = decl.value.replace(pattern, callback);\n        });\n\n        return this;\n    }\n\n    /**\n     * Returns `true` if callback returns `true`\n     * for all of the container’s children.\n     *\n     * @param {childCondition} condition - iterator returns true or false.\n     *\n     * @return {boolean} is every child pass condition\n     *\n     * @example\n     * const noPrefixes = rule.every(i => i.prop[0] !== '-');\n     */\n    every(condition) {\n        return this.nodes.every(condition);\n    }\n\n    /**\n     * Returns `true` if callback returns `true` for (at least) one\n     * of the container’s children.\n     *\n     * @param {childCondition} condition - iterator returns true or false.\n     *\n     * @return {boolean} is some child pass condition\n     *\n     * @example\n     * const hasPrefix = rule.some(i => i.prop[0] === '-');\n     */\n    some(condition) {\n        return this.nodes.some(condition);\n    }\n\n    /**\n     * Returns a `child`’s index within the {@link Container#nodes} array.\n     *\n     * @param {Node} child - child of the current container.\n     *\n     * @return {number} child index\n     *\n     * @example\n     * rule.index( rule.nodes[2] ) //=> 2\n     */\n    index(child) {\n        if ( typeof child === 'number' ) {\n            return child;\n        } else {\n            return this.nodes.indexOf(child);\n        }\n    }\n\n    /**\n     * The container’s first child.\n     *\n     * @type {Node}\n     *\n     * @example\n     * rule.first == rules.nodes[0];\n     */\n    get first() {\n        if ( !this.nodes ) return undefined;\n        return this.nodes[0];\n    }\n\n    /**\n     * The container’s last child.\n     *\n     * @type {Node}\n     *\n     * @example\n     * rule.last == rule.nodes[rule.nodes.length - 1];\n     */\n    get last() {\n        if ( !this.nodes ) return undefined;\n        return this.nodes[this.nodes.length - 1];\n    }\n\n    normalize(nodes, sample) {\n        if ( typeof nodes === 'string' ) {\n            let parse = require('./parse');\n            nodes = cleanSource(parse(nodes).nodes);\n        } else if ( Array.isArray(nodes) ) {\n            nodes = nodes.slice(0);\n            for ( let i of nodes ) {\n                if ( i.parent ) i.parent.removeChild(i, 'ignore');\n            }\n        } else if ( nodes.type === 'root' ) {\n            nodes = nodes.nodes.slice(0);\n            for ( let i of nodes ) {\n                if ( i.parent ) i.parent.removeChild(i, 'ignore');\n            }\n        } else if ( nodes.type ) {\n            nodes = [nodes];\n        } else if ( nodes.prop ) {\n            if ( typeof nodes.value === 'undefined' ) {\n                throw new Error('Value field is missed in node creation');\n            } else if ( typeof nodes.value !== 'string' ) {\n                nodes.value = String(nodes.value);\n            }\n            nodes = [new Declaration(nodes)];\n        } else if ( nodes.selector ) {\n            let Rule = require('./rule');\n            nodes = [new Rule(nodes)];\n        } else if ( nodes.name ) {\n            let AtRule = require('./at-rule');\n            nodes = [new AtRule(nodes)];\n        } else if ( nodes.text ) {\n            nodes = [new Comment(nodes)];\n        } else {\n            throw new Error('Unknown node type in node creation');\n        }\n\n        let processed = nodes.map( i => {\n            if ( typeof i.before !== 'function' ) i = this.rebuild(i);\n\n            if ( i.parent ) i.parent.removeChild(i);\n            if ( typeof i.raws.before === 'undefined' ) {\n                if ( sample && typeof sample.raws.before !== 'undefined' ) {\n                    i.raws.before = sample.raws.before.replace(/[^\\s]/g, '');\n                }\n            }\n            i.parent = this;\n            return i;\n        });\n\n        return processed;\n    }\n\n    rebuild(node, parent) {\n        let fix;\n        if ( node.type === 'root' ) {\n            let Root = require('./root');\n            fix = new Root();\n        } else if ( node.type === 'atrule' ) {\n            let AtRule = require('./at-rule');\n            fix = new AtRule();\n        } else if ( node.type === 'rule' ) {\n            let Rule = require('./rule');\n            fix = new Rule();\n        } else if ( node.type === 'decl' ) {\n            fix = new Declaration();\n        } else if ( node.type === 'comment' ) {\n            fix = new Comment();\n        }\n\n        for ( let i in node ) {\n            if ( i === 'nodes' ) {\n                fix.nodes = node.nodes.map( j => this.rebuild(j, fix) );\n            } else if ( i === 'parent' && parent ) {\n                fix.parent = parent;\n            } else if ( node.hasOwnProperty(i) ) {\n                fix[i] = node[i];\n            }\n        }\n\n        return fix;\n    }\n\n    /**\n     * @memberof Container#\n     * @member {Node[]} nodes - an array containing the container’s children\n     *\n     * @example\n     * const root = postcss.parse('a { color: black }');\n     * root.nodes.length           //=> 1\n     * root.nodes[0].selector      //=> 'a'\n     * root.nodes[0].nodes[0].prop //=> 'color'\n     */\n\n}\n\nexport default Container;\n\n\n/**\n * @callback childCondition\n * @param {Node} node    - container child\n * @param {number} index - child index\n * @param {Node[]} nodes - all container children\n * @return {boolean}\n */\n\n/**\n * @callback childIterator\n * @param {Node} node    - container child\n * @param {number} index - child index\n * @return {false|undefined} returning `false` will break iteration\n */\n"]}
879
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["container.es6"],"names":["cleanSource","nodes","map","i","source","Container","push","child","parent","each","callback","lastEach","indexes","id","undefined","index","result","length","walk","e","postcssNode","stack","test","s","replace","input","from","start","line","column","walkDecls","prop","type","RegExp","walkRules","selector","walkAtRules","name","walkComments","append","children","normalize","last","node","prepend","reverse","first","unshift","cleanRaws","keepBetween","insertBefore","exist","add","splice","insertAfter","removeChild","removeAll","replaceValues","pattern","opts","props","indexOf","decl","fast","value","every","condition","some","sample","parse","require","Array","isArray","slice","Error","String","Declaration","Rule","AtRule","text","Comment","processed","raws","before","Node"],"mappings":"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","file":"container.js","sourcesContent":["import Declaration from './declaration'\nimport Comment from './comment'\nimport Node from './node'\n\nfunction cleanSource (nodes) {\n  return nodes.map(i => {\n    if (i.nodes) i.nodes = cleanSource(i.nodes)\n    delete i.source\n    return i\n  })\n}\n\n/**\n * The {@link Root}, {@link AtRule}, and {@link Rule} container nodes\n * inherit some common methods to help work with their children.\n *\n * Note that all containers can store any content. If you write a rule inside\n * a rule, PostCSS will parse it.\n *\n * @extends Node\n * @abstract\n */\nclass Container extends Node {\n  push (child) {\n    child.parent = this\n    this.nodes.push(child)\n    return this\n  }\n\n  /**\n   * Iterates through the container’s immediate children,\n   * calling `callback` for each child.\n   *\n   * Returning `false` in the callback will break iteration.\n   *\n   * This method only iterates through the container’s immediate children.\n   * If you need to recursively iterate through all the container’s descendant\n   * nodes, use {@link Container#walk}.\n   *\n   * Unlike the for `{}`-cycle or `Array#forEach` this iterator is safe\n   * if you are mutating the array of child nodes during iteration.\n   * PostCSS will adjust the current index to match the mutations.\n   *\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * const root = postcss.parse('a { color: black; z-index: 1 }')\n   * const rule = root.first\n   *\n   * for (const decl of rule.nodes) {\n   *   decl.cloneBefore({ prop: '-webkit-' + decl.prop })\n   *   // Cycle will be infinite, because cloneBefore moves the current node\n   *   // to the next index\n   * }\n   *\n   * rule.each(decl => {\n   *   decl.cloneBefore({ prop: '-webkit-' + decl.prop })\n   *   // Will be executed only for color and z-index\n   * })\n   */\n  each (callback) {\n    if (!this.lastEach) this.lastEach = 0\n    if (!this.indexes) this.indexes = { }\n\n    this.lastEach += 1\n    let id = this.lastEach\n    this.indexes[id] = 0\n\n    if (!this.nodes) return undefined\n\n    let index, result\n    while (this.indexes[id] < this.nodes.length) {\n      index = this.indexes[id]\n      result = callback(this.nodes[index], index)\n      if (result === false) break\n\n      this.indexes[id] += 1\n    }\n\n    delete this.indexes[id]\n\n    return result\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each node.\n   *\n   * Like container.each(), this method is safe to use\n   * if you are mutating arrays during iteration.\n   *\n   * If you only need to iterate through the container’s immediate children,\n   * use {@link Container#each}.\n   *\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walk(node => {\n   *   // Traverses all descendant nodes.\n   * })\n   */\n  walk (callback) {\n    return this.each((child, i) => {\n      let result\n      try {\n        result = callback(child, i)\n      } catch (e) {\n        e.postcssNode = child\n        if (e.stack && child.source && /\\n\\s{4}at /.test(e.stack)) {\n          let s = child.source\n          e.stack = e.stack.replace(/\\n\\s{4}at /,\n            `$&${ s.input.from }:${ s.start.line }:${ s.start.column }$&`)\n        }\n        throw e\n      }\n      if (result !== false && child.walk) {\n        result = child.walk(callback)\n      }\n      return result\n    })\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each declaration node.\n   *\n   * If you pass a filter, iteration will only happen over declarations\n   * with matching properties.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {string|RegExp} [prop]   String or regular expression\n   *                                 to filter declarations by property name.\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walkDecls(decl => {\n   *   checkPropertySupport(decl.prop)\n   * })\n   *\n   * root.walkDecls('border-radius', decl => {\n   *   decl.remove()\n   * })\n   *\n   * root.walkDecls(/^background/, decl => {\n   *   decl.value = takeFirstColorFromGradient(decl.value)\n   * })\n   */\n  walkDecls (prop, callback) {\n    if (!callback) {\n      callback = prop\n      return this.walk((child, i) => {\n        if (child.type === 'decl') {\n          return callback(child, i)\n        }\n      })\n    } else if (prop instanceof RegExp) {\n      return this.walk((child, i) => {\n        if (child.type === 'decl' && prop.test(child.prop)) {\n          return callback(child, i)\n        }\n      })\n    } else {\n      return this.walk((child, i) => {\n        if (child.type === 'decl' && child.prop === prop) {\n          return callback(child, i)\n        }\n      })\n    }\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each rule node.\n   *\n   * If you pass a filter, iteration will only happen over rules\n   * with matching selectors.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {string|RegExp} [selector] String or regular expression\n   *                                   to filter rules by selector.\n   * @param {childIterator} callback   Iterator receives each node and index.\n   *\n   * @return {false|undefined} returns `false` if iteration was broke.\n   *\n   * @example\n   * const selectors = []\n   * root.walkRules(rule => {\n   *   selectors.push(rule.selector)\n   * })\n   * console.log(`Your CSS uses ${ selectors.length } selectors`)\n   */\n  walkRules (selector, callback) {\n    if (!callback) {\n      callback = selector\n\n      return this.walk((child, i) => {\n        if (child.type === 'rule') {\n          return callback(child, i)\n        }\n      })\n    } else if (selector instanceof RegExp) {\n      return this.walk((child, i) => {\n        if (child.type === 'rule' && selector.test(child.selector)) {\n          return callback(child, i)\n        }\n      })\n    } else {\n      return this.walk((child, i) => {\n        if (child.type === 'rule' && child.selector === selector) {\n          return callback(child, i)\n        }\n      })\n    }\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each at-rule node.\n   *\n   * If you pass a filter, iteration will only happen over at-rules\n   * that have matching names.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {string|RegExp} [name]   String or regular expression\n   *                                 to filter at-rules by name.\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walkAtRules(rule => {\n   *   if (isOld(rule.name)) rule.remove()\n   * })\n   *\n   * let first = false\n   * root.walkAtRules('charset', rule => {\n   *   if (!first) {\n   *     first = true\n   *   } else {\n   *     rule.remove()\n   *   }\n   * })\n   */\n  walkAtRules (name, callback) {\n    if (!callback) {\n      callback = name\n      return this.walk((child, i) => {\n        if (child.type === 'atrule') {\n          return callback(child, i)\n        }\n      })\n    } else if (name instanceof RegExp) {\n      return this.walk((child, i) => {\n        if (child.type === 'atrule' && name.test(child.name)) {\n          return callback(child, i)\n        }\n      })\n    } else {\n      return this.walk((child, i) => {\n        if (child.type === 'atrule' && child.name === name) {\n          return callback(child, i)\n        }\n      })\n    }\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each comment node.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walkComments(comment => {\n   *   comment.remove()\n   * })\n   */\n  walkComments (callback) {\n    return this.walk((child, i) => {\n      if (child.type === 'comment') {\n        return callback(child, i)\n      }\n    })\n  }\n\n  /**\n   * Inserts new nodes to the end of the container.\n   *\n   * @param {...(Node|object|string|Node[])} children New nodes.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * const decl1 = postcss.decl({ prop: 'color', value: 'black' })\n   * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' })\n   * rule.append(decl1, decl2)\n   *\n   * root.append({ name: 'charset', params: '\"UTF-8\"' })  // at-rule\n   * root.append({ selector: 'a' })                       // rule\n   * rule.append({ prop: 'color', value: 'black' })       // declaration\n   * rule.append({ text: 'Comment' })                     // comment\n   *\n   * root.append('a {}')\n   * root.first.append('color: black; z-index: 1')\n   */\n  append (...children) {\n    for (let child of children) {\n      let nodes = this.normalize(child, this.last)\n      for (let node of nodes) this.nodes.push(node)\n    }\n    return this\n  }\n\n  /**\n   * Inserts new nodes to the start of the container.\n   *\n   * @param {...(Node|object|string|Node[])} children New nodes.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * const decl1 = postcss.decl({ prop: 'color', value: 'black' })\n   * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' })\n   * rule.prepend(decl1, decl2)\n   *\n   * root.append({ name: 'charset', params: '\"UTF-8\"' })  // at-rule\n   * root.append({ selector: 'a' })                       // rule\n   * rule.append({ prop: 'color', value: 'black' })       // declaration\n   * rule.append({ text: 'Comment' })                     // comment\n   *\n   * root.append('a {}')\n   * root.first.append('color: black; z-index: 1')\n   */\n  prepend (...children) {\n    children = children.reverse()\n    for (let child of children) {\n      let nodes = this.normalize(child, this.first, 'prepend').reverse()\n      for (let node of nodes) this.nodes.unshift(node)\n      for (let id in this.indexes) {\n        this.indexes[id] = this.indexes[id] + nodes.length\n      }\n    }\n    return this\n  }\n\n  cleanRaws (keepBetween) {\n    super.cleanRaws(keepBetween)\n    if (this.nodes) {\n      for (let node of this.nodes) node.cleanRaws(keepBetween)\n    }\n  }\n\n  /**\n   * Insert new node before old node within the container.\n   *\n   * @param {Node|number} exist             Child or child’s index.\n   * @param {Node|object|string|Node[]} add New node.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * rule.insertBefore(decl, decl.clone({ prop: '-webkit-' + decl.prop }))\n   */\n  insertBefore (exist, add) {\n    exist = this.index(exist)\n\n    let type = exist === 0 ? 'prepend' : false\n    let nodes = this.normalize(add, this.nodes[exist], type).reverse()\n    for (let node of nodes) this.nodes.splice(exist, 0, node)\n\n    let index\n    for (let id in this.indexes) {\n      index = this.indexes[id]\n      if (exist <= index) {\n        this.indexes[id] = index + nodes.length\n      }\n    }\n\n    return this\n  }\n\n  /**\n   * Insert new node after old node within the container.\n   *\n   * @param {Node|number} exist             Child or child’s index.\n   * @param {Node|object|string|Node[]} add New node.\n   *\n   * @return {Node} This node for methods chain.\n   */\n  insertAfter (exist, add) {\n    exist = this.index(exist)\n\n    let nodes = this.normalize(add, this.nodes[exist]).reverse()\n    for (let node of nodes) this.nodes.splice(exist + 1, 0, node)\n\n    let index\n    for (let id in this.indexes) {\n      index = this.indexes[id]\n      if (exist < index) {\n        this.indexes[id] = index + nodes.length\n      }\n    }\n\n    return this\n  }\n\n  /**\n   * Removes node from the container and cleans the parent properties\n   * from the node and its children.\n   *\n   * @param {Node|number} child Child or child’s index.\n   *\n   * @return {Node} This node for methods chain\n   *\n   * @example\n   * rule.nodes.length  //=> 5\n   * rule.removeChild(decl)\n   * rule.nodes.length  //=> 4\n   * decl.parent        //=> undefined\n   */\n  removeChild (child) {\n    child = this.index(child)\n    this.nodes[child].parent = undefined\n    this.nodes.splice(child, 1)\n\n    let index\n    for (let id in this.indexes) {\n      index = this.indexes[id]\n      if (index >= child) {\n        this.indexes[id] = index - 1\n      }\n    }\n\n    return this\n  }\n\n  /**\n   * Removes all children from the container\n   * and cleans their parent properties.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * rule.removeAll()\n   * rule.nodes.length //=> 0\n   */\n  removeAll () {\n    for (let node of this.nodes) node.parent = undefined\n    this.nodes = []\n    return this\n  }\n\n  /**\n   * Passes all declaration values within the container that match pattern\n   * through callback, replacing those values with the returned result\n   * of callback.\n   *\n   * This method is useful if you are using a custom unit or function\n   * and need to iterate through all values.\n   *\n   * @param {string|RegExp} pattern      Replace pattern.\n   * @param {object} opts                Options to speed up the search.\n   * @param {string|string[]} opts.props An array of property names.\n   * @param {string} opts.fast           String that’s used to narrow down\n   *                                     values and speed up the regexp search.\n   * @param {function|string} callback   String to replace pattern or callback\n   *                                     that returns a new value. The callback\n   *                                     will receive the same arguments\n   *                                     as those passed to a function parameter\n   *                                     of `String#replace`.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * root.replaceValues(/\\d+rem/, { fast: 'rem' }, string => {\n   *   return 15 * parseInt(string) + 'px'\n   * })\n   */\n  replaceValues (pattern, opts, callback) {\n    if (!callback) {\n      callback = opts\n      opts = { }\n    }\n\n    this.walkDecls(decl => {\n      if (opts.props && opts.props.indexOf(decl.prop) === -1) return\n      if (opts.fast && decl.value.indexOf(opts.fast) === -1) return\n\n      decl.value = decl.value.replace(pattern, callback)\n    })\n\n    return this\n  }\n\n  /**\n   * Returns `true` if callback returns `true`\n   * for all of the container’s children.\n   *\n   * @param {childCondition} condition Iterator returns true or false.\n   *\n   * @return {boolean} Is every child pass condition.\n   *\n   * @example\n   * const noPrefixes = rule.every(i => i.prop[0] !== '-')\n   */\n  every (condition) {\n    return this.nodes.every(condition)\n  }\n\n  /**\n   * Returns `true` if callback returns `true` for (at least) one\n   * of the container’s children.\n   *\n   * @param {childCondition} condition Iterator returns true or false.\n   *\n   * @return {boolean} Is some child pass condition.\n   *\n   * @example\n   * const hasPrefix = rule.some(i => i.prop[0] === '-')\n   */\n  some (condition) {\n    return this.nodes.some(condition)\n  }\n\n  /**\n   * Returns a `child`’s index within the {@link Container#nodes} array.\n   *\n   * @param {Node} child Child of the current container.\n   *\n   * @return {number} Child index.\n   *\n   * @example\n   * rule.index( rule.nodes[2] ) //=> 2\n   */\n  index (child) {\n    if (typeof child === 'number') {\n      return child\n    } else {\n      return this.nodes.indexOf(child)\n    }\n  }\n\n  /**\n   * The container’s first child.\n   *\n   * @type {Node}\n   *\n   * @example\n   * rule.first === rules.nodes[0]\n   */\n  get first () {\n    if (!this.nodes) return undefined\n    return this.nodes[0]\n  }\n\n  /**\n   * The container’s last child.\n   *\n   * @type {Node}\n   *\n   * @example\n   * rule.last === rule.nodes[rule.nodes.length - 1]\n   */\n  get last () {\n    if (!this.nodes) return undefined\n    return this.nodes[this.nodes.length - 1]\n  }\n\n  normalize (nodes, sample) {\n    if (typeof nodes === 'string') {\n      let parse = require('./parse')\n      nodes = cleanSource(parse(nodes).nodes)\n    } else if (Array.isArray(nodes)) {\n      nodes = nodes.slice(0)\n      for (let i of nodes) {\n        if (i.parent) i.parent.removeChild(i, 'ignore')\n      }\n    } else if (nodes.type === 'root') {\n      nodes = nodes.nodes.slice(0)\n      for (let i of nodes) {\n        if (i.parent) i.parent.removeChild(i, 'ignore')\n      }\n    } else if (nodes.type) {\n      nodes = [nodes]\n    } else if (nodes.prop) {\n      if (typeof nodes.value === 'undefined') {\n        throw new Error('Value field is missed in node creation')\n      } else if (typeof nodes.value !== 'string') {\n        nodes.value = String(nodes.value)\n      }\n      nodes = [new Declaration(nodes)]\n    } else if (nodes.selector) {\n      let Rule = require('./rule')\n      nodes = [new Rule(nodes)]\n    } else if (nodes.name) {\n      let AtRule = require('./at-rule')\n      nodes = [new AtRule(nodes)]\n    } else if (nodes.text) {\n      nodes = [new Comment(nodes)]\n    } else {\n      throw new Error('Unknown node type in node creation')\n    }\n\n    let processed = nodes.map(i => {\n      if (i.parent) i.parent.removeChild(i)\n      if (typeof i.raws.before === 'undefined') {\n        if (sample && typeof sample.raws.before !== 'undefined') {\n          i.raws.before = sample.raws.before.replace(/[^\\s]/g, '')\n        }\n      }\n      i.parent = this\n      return i\n    })\n\n    return processed\n  }\n\n  /**\n   * @memberof Container#\n   * @member {Node[]} nodes An array containing the container’s children.\n   *\n   * @example\n   * const root = postcss.parse('a { color: black }')\n   * root.nodes.length           //=> 1\n   * root.nodes[0].selector      //=> 'a'\n   * root.nodes[0].nodes[0].prop //=> 'color'\n   */\n}\n\nexport default Container\n\n/**\n * @callback childCondition\n * @param {Node} node    Container child.\n * @param {number} index Child index.\n * @param {Node[]} nodes All container children.\n * @return {boolean}\n */\n\n/**\n * @callback childIterator\n * @param {Node} node    Container child.\n * @param {number} index Child index.\n * @return {false|undefined} Returning `false` will break iteration.\n */\n"]}