node.js 55 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669
  1. 'use strict';
  2. exports.__esModule = true;
  3. var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
  4. var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
  5. var _cssSyntaxError = require('./css-syntax-error');
  6. var _cssSyntaxError2 = _interopRequireDefault(_cssSyntaxError);
  7. var _stringifier = require('./stringifier');
  8. var _stringifier2 = _interopRequireDefault(_stringifier);
  9. var _stringify = require('./stringify');
  10. var _stringify2 = _interopRequireDefault(_stringify);
  11. var _warnOnce = require('./warn-once');
  12. var _warnOnce2 = _interopRequireDefault(_warnOnce);
  13. function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
  14. function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
  15. var cloneNode = function cloneNode(obj, parent) {
  16. var cloned = new obj.constructor();
  17. for (var i in obj) {
  18. if (!obj.hasOwnProperty(i)) continue;
  19. var value = obj[i];
  20. var type = typeof value === 'undefined' ? 'undefined' : _typeof(value);
  21. if (i === 'parent' && type === 'object') {
  22. if (parent) cloned[i] = parent;
  23. } else if (i === 'source') {
  24. cloned[i] = value;
  25. } else if (value instanceof Array) {
  26. cloned[i] = value.map(function (j) {
  27. return cloneNode(j, cloned);
  28. });
  29. } else if (i !== 'before' && i !== 'after' && i !== 'between' && i !== 'semicolon') {
  30. if (type === 'object' && value !== null) value = cloneNode(value);
  31. cloned[i] = value;
  32. }
  33. }
  34. return cloned;
  35. };
  36. /**
  37. * All node classes inherit the following common methods.
  38. *
  39. * @abstract
  40. */
  41. var Node = function () {
  42. /**
  43. * @param {object} [defaults] - value for node properties
  44. */
  45. function Node() {
  46. var defaults = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
  47. _classCallCheck(this, Node);
  48. this.raws = {};
  49. for (var name in defaults) {
  50. this[name] = defaults[name];
  51. }
  52. }
  53. /**
  54. * Returns a CssSyntaxError instance containing the original position
  55. * of the node in the source, showing line and column numbers and also
  56. * a small excerpt to facilitate debugging.
  57. *
  58. * If present, an input source map will be used to get the original position
  59. * of the source, even from a previous compilation step
  60. * (e.g., from Sass compilation).
  61. *
  62. * This method produces very useful error messages.
  63. *
  64. * @param {string} message - error description
  65. * @param {object} [opts] - options
  66. * @param {string} opts.plugin - plugin name that created this error.
  67. * PostCSS will set it automatically.
  68. * @param {string} opts.word - a word inside a node’s string that should
  69. * be highlighted as the source of the error
  70. * @param {number} opts.index - an index inside a node’s string that should
  71. * be highlighted as the source of the error
  72. *
  73. * @return {CssSyntaxError} error object to throw it
  74. *
  75. * @example
  76. * if ( !variables[name] ) {
  77. * throw decl.error('Unknown variable ' + name, { word: name });
  78. * // CssSyntaxError: postcss-vars:a.sass:4:3: Unknown variable $black
  79. * // color: $black
  80. * // a
  81. * // ^
  82. * // background: white
  83. * }
  84. */
  85. Node.prototype.error = function error(message) {
  86. var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
  87. if (this.source) {
  88. var pos = this.positionBy(opts);
  89. return this.source.input.error(message, pos.line, pos.column, opts);
  90. } else {
  91. return new _cssSyntaxError2.default(message);
  92. }
  93. };
  94. /**
  95. * This method is provided as a convenience wrapper for {@link Result#warn}.
  96. *
  97. * @param {Result} result - the {@link Result} instance
  98. * that will receive the warning
  99. * @param {string} text - warning message
  100. * @param {object} [opts] - options
  101. * @param {string} opts.plugin - plugin name that created this warning.
  102. * PostCSS will set it automatically.
  103. * @param {string} opts.word - a word inside a node’s string that should
  104. * be highlighted as the source of the warning
  105. * @param {number} opts.index - an index inside a node’s string that should
  106. * be highlighted as the source of the warning
  107. *
  108. * @return {Warning} created warning object
  109. *
  110. * @example
  111. * const plugin = postcss.plugin('postcss-deprecated', () => {
  112. * return (root, result) => {
  113. * root.walkDecls('bad', decl => {
  114. * decl.warn(result, 'Deprecated property bad');
  115. * });
  116. * };
  117. * });
  118. */
  119. Node.prototype.warn = function warn(result, text, opts) {
  120. var data = { node: this };
  121. for (var i in opts) {
  122. data[i] = opts[i];
  123. }return result.warn(text, data);
  124. };
  125. /**
  126. * Removes the node from its parent and cleans the parent properties
  127. * from the node and its children.
  128. *
  129. * @example
  130. * if ( decl.prop.match(/^-webkit-/) ) {
  131. * decl.remove();
  132. * }
  133. *
  134. * @return {Node} node to make calls chain
  135. */
  136. Node.prototype.remove = function remove() {
  137. if (this.parent) {
  138. this.parent.removeChild(this);
  139. }
  140. this.parent = undefined;
  141. return this;
  142. };
  143. /**
  144. * Returns a CSS string representing the node.
  145. *
  146. * @param {stringifier|syntax} [stringifier] - a syntax to use
  147. * in string generation
  148. *
  149. * @return {string} CSS string of this node
  150. *
  151. * @example
  152. * postcss.rule({ selector: 'a' }).toString() //=> "a {}"
  153. */
  154. Node.prototype.toString = function toString() {
  155. var stringifier = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _stringify2.default;
  156. if (stringifier.stringify) stringifier = stringifier.stringify;
  157. var result = '';
  158. stringifier(this, function (i) {
  159. result += i;
  160. });
  161. return result;
  162. };
  163. /**
  164. * Returns a clone of the node.
  165. *
  166. * The resulting cloned node and its (cloned) children will have
  167. * a clean parent and code style properties.
  168. *
  169. * @param {object} [overrides] - new properties to override in the clone.
  170. *
  171. * @example
  172. * const cloned = decl.clone({ prop: '-moz-' + decl.prop });
  173. * cloned.raws.before //=> undefined
  174. * cloned.parent //=> undefined
  175. * cloned.toString() //=> -moz-transform: scale(0)
  176. *
  177. * @return {Node} clone of the node
  178. */
  179. Node.prototype.clone = function clone() {
  180. var overrides = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
  181. var cloned = cloneNode(this);
  182. for (var name in overrides) {
  183. cloned[name] = overrides[name];
  184. }
  185. return cloned;
  186. };
  187. /**
  188. * Shortcut to clone the node and insert the resulting cloned node
  189. * before the current node.
  190. *
  191. * @param {object} [overrides] - new properties to override in the clone.
  192. *
  193. * @example
  194. * decl.cloneBefore({ prop: '-moz-' + decl.prop });
  195. *
  196. * @return {Node} - new node
  197. */
  198. Node.prototype.cloneBefore = function cloneBefore() {
  199. var overrides = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
  200. var cloned = this.clone(overrides);
  201. this.parent.insertBefore(this, cloned);
  202. return cloned;
  203. };
  204. /**
  205. * Shortcut to clone the node and insert the resulting cloned node
  206. * after the current node.
  207. *
  208. * @param {object} [overrides] - new properties to override in the clone.
  209. *
  210. * @return {Node} - new node
  211. */
  212. Node.prototype.cloneAfter = function cloneAfter() {
  213. var overrides = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
  214. var cloned = this.clone(overrides);
  215. this.parent.insertAfter(this, cloned);
  216. return cloned;
  217. };
  218. /**
  219. * Inserts node(s) before the current node and removes the current node.
  220. *
  221. * @param {...Node} nodes - node(s) to replace current one
  222. *
  223. * @example
  224. * if ( atrule.name == 'mixin' ) {
  225. * atrule.replaceWith(mixinRules[atrule.params]);
  226. * }
  227. *
  228. * @return {Node} current node to methods chain
  229. */
  230. Node.prototype.replaceWith = function replaceWith() {
  231. if (this.parent) {
  232. for (var _len = arguments.length, nodes = Array(_len), _key = 0; _key < _len; _key++) {
  233. nodes[_key] = arguments[_key];
  234. }
  235. for (var _iterator = nodes, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
  236. var _ref;
  237. if (_isArray) {
  238. if (_i >= _iterator.length) break;
  239. _ref = _iterator[_i++];
  240. } else {
  241. _i = _iterator.next();
  242. if (_i.done) break;
  243. _ref = _i.value;
  244. }
  245. var node = _ref;
  246. this.parent.insertBefore(this, node);
  247. }
  248. this.remove();
  249. }
  250. return this;
  251. };
  252. /**
  253. * Removes the node from its current parent and inserts it
  254. * at the end of `newParent`.
  255. *
  256. * This will clean the `before` and `after` code {@link Node#raws} data
  257. * from the node and replace them with the indentation style of `newParent`.
  258. * It will also clean the `between` property
  259. * if `newParent` is in another {@link Root}.
  260. *
  261. * @param {Container} newParent - container node where the current node
  262. * will be moved
  263. *
  264. * @example
  265. * atrule.moveTo(atrule.root());
  266. *
  267. * @return {Node} current node to methods chain
  268. */
  269. Node.prototype.moveTo = function moveTo(newParent) {
  270. this.cleanRaws(this.root() === newParent.root());
  271. this.remove();
  272. newParent.append(this);
  273. return this;
  274. };
  275. /**
  276. * Removes the node from its current parent and inserts it into
  277. * a new parent before `otherNode`.
  278. *
  279. * This will also clean the node’s code style properties just as it would
  280. * in {@link Node#moveTo}.
  281. *
  282. * @param {Node} otherNode - node that will be before current node
  283. *
  284. * @return {Node} current node to methods chain
  285. */
  286. Node.prototype.moveBefore = function moveBefore(otherNode) {
  287. this.cleanRaws(this.root() === otherNode.root());
  288. this.remove();
  289. otherNode.parent.insertBefore(otherNode, this);
  290. return this;
  291. };
  292. /**
  293. * Removes the node from its current parent and inserts it into
  294. * a new parent after `otherNode`.
  295. *
  296. * This will also clean the node’s code style properties just as it would
  297. * in {@link Node#moveTo}.
  298. *
  299. * @param {Node} otherNode - node that will be after current node
  300. *
  301. * @return {Node} current node to methods chain
  302. */
  303. Node.prototype.moveAfter = function moveAfter(otherNode) {
  304. this.cleanRaws(this.root() === otherNode.root());
  305. this.remove();
  306. otherNode.parent.insertAfter(otherNode, this);
  307. return this;
  308. };
  309. /**
  310. * Returns the next child of the node’s parent.
  311. * Returns `undefined` if the current node is the last child.
  312. *
  313. * @return {Node|undefined} next node
  314. *
  315. * @example
  316. * if ( comment.text === 'delete next' ) {
  317. * const next = comment.next();
  318. * if ( next ) {
  319. * next.remove();
  320. * }
  321. * }
  322. */
  323. Node.prototype.next = function next() {
  324. var index = this.parent.index(this);
  325. return this.parent.nodes[index + 1];
  326. };
  327. /**
  328. * Returns the previous child of the node’s parent.
  329. * Returns `undefined` if the current node is the first child.
  330. *
  331. * @return {Node|undefined} previous node
  332. *
  333. * @example
  334. * const annotation = decl.prev();
  335. * if ( annotation.type == 'comment' ) {
  336. * readAnnotation(annotation.text);
  337. * }
  338. */
  339. Node.prototype.prev = function prev() {
  340. var index = this.parent.index(this);
  341. return this.parent.nodes[index - 1];
  342. };
  343. Node.prototype.toJSON = function toJSON() {
  344. var fixed = {};
  345. for (var name in this) {
  346. if (!this.hasOwnProperty(name)) continue;
  347. if (name === 'parent') continue;
  348. var value = this[name];
  349. if (value instanceof Array) {
  350. fixed[name] = value.map(function (i) {
  351. if ((typeof i === 'undefined' ? 'undefined' : _typeof(i)) === 'object' && i.toJSON) {
  352. return i.toJSON();
  353. } else {
  354. return i;
  355. }
  356. });
  357. } else if ((typeof value === 'undefined' ? 'undefined' : _typeof(value)) === 'object' && value.toJSON) {
  358. fixed[name] = value.toJSON();
  359. } else {
  360. fixed[name] = value;
  361. }
  362. }
  363. return fixed;
  364. };
  365. /**
  366. * Returns a {@link Node#raws} value. If the node is missing
  367. * the code style property (because the node was manually built or cloned),
  368. * PostCSS will try to autodetect the code style property by looking
  369. * at other nodes in the tree.
  370. *
  371. * @param {string} prop - name of code style property
  372. * @param {string} [defaultType] - name of default value, it can be missed
  373. * if the value is the same as prop
  374. *
  375. * @example
  376. * const root = postcss.parse('a { background: white }');
  377. * root.nodes[0].append({ prop: 'color', value: 'black' });
  378. * root.nodes[0].nodes[1].raws.before //=> undefined
  379. * root.nodes[0].nodes[1].raw('before') //=> ' '
  380. *
  381. * @return {string} code style value
  382. */
  383. Node.prototype.raw = function raw(prop, defaultType) {
  384. var str = new _stringifier2.default();
  385. return str.raw(this, prop, defaultType);
  386. };
  387. /**
  388. * Finds the Root instance of the node’s tree.
  389. *
  390. * @example
  391. * root.nodes[0].nodes[0].root() === root
  392. *
  393. * @return {Root} root parent
  394. */
  395. Node.prototype.root = function root() {
  396. var result = this;
  397. while (result.parent) {
  398. result = result.parent;
  399. }return result;
  400. };
  401. Node.prototype.cleanRaws = function cleanRaws(keepBetween) {
  402. delete this.raws.before;
  403. delete this.raws.after;
  404. if (!keepBetween) delete this.raws.between;
  405. };
  406. Node.prototype.positionInside = function positionInside(index) {
  407. var string = this.toString();
  408. var column = this.source.start.column;
  409. var line = this.source.start.line;
  410. for (var i = 0; i < index; i++) {
  411. if (string[i] === '\n') {
  412. column = 1;
  413. line += 1;
  414. } else {
  415. column += 1;
  416. }
  417. }
  418. return { line: line, column: column };
  419. };
  420. Node.prototype.positionBy = function positionBy(opts) {
  421. var pos = this.source.start;
  422. if (opts.index) {
  423. pos = this.positionInside(opts.index);
  424. } else if (opts.word) {
  425. var index = this.toString().indexOf(opts.word);
  426. if (index !== -1) pos = this.positionInside(index);
  427. }
  428. return pos;
  429. };
  430. Node.prototype.removeSelf = function removeSelf() {
  431. (0, _warnOnce2.default)('Node#removeSelf is deprecated. Use Node#remove.');
  432. return this.remove();
  433. };
  434. Node.prototype.replace = function replace(nodes) {
  435. (0, _warnOnce2.default)('Node#replace is deprecated. Use Node#replaceWith');
  436. return this.replaceWith(nodes);
  437. };
  438. Node.prototype.style = function style(own, detect) {
  439. (0, _warnOnce2.default)('Node#style() is deprecated. Use Node#raw()');
  440. return this.raw(own, detect);
  441. };
  442. Node.prototype.cleanStyles = function cleanStyles(keepBetween) {
  443. (0, _warnOnce2.default)('Node#cleanStyles() is deprecated. Use Node#cleanRaws()');
  444. return this.cleanRaws(keepBetween);
  445. };
  446. _createClass(Node, [{
  447. key: 'before',
  448. get: function get() {
  449. (0, _warnOnce2.default)('Node#before is deprecated. Use Node#raws.before');
  450. return this.raws.before;
  451. },
  452. set: function set(val) {
  453. (0, _warnOnce2.default)('Node#before is deprecated. Use Node#raws.before');
  454. this.raws.before = val;
  455. }
  456. }, {
  457. key: 'between',
  458. get: function get() {
  459. (0, _warnOnce2.default)('Node#between is deprecated. Use Node#raws.between');
  460. return this.raws.between;
  461. },
  462. set: function set(val) {
  463. (0, _warnOnce2.default)('Node#between is deprecated. Use Node#raws.between');
  464. this.raws.between = val;
  465. }
  466. /**
  467. * @memberof Node#
  468. * @member {string} type - String representing the node’s type.
  469. * Possible values are `root`, `atrule`, `rule`,
  470. * `decl`, or `comment`.
  471. *
  472. * @example
  473. * postcss.decl({ prop: 'color', value: 'black' }).type //=> 'decl'
  474. */
  475. /**
  476. * @memberof Node#
  477. * @member {Container} parent - the node’s parent node.
  478. *
  479. * @example
  480. * root.nodes[0].parent == root;
  481. */
  482. /**
  483. * @memberof Node#
  484. * @member {source} source - the input source of the node
  485. *
  486. * The property is used in source map generation.
  487. *
  488. * If you create a node manually (e.g., with `postcss.decl()`),
  489. * that node will not have a `source` property and will be absent
  490. * from the source map. For this reason, the plugin developer should
  491. * consider cloning nodes to create new ones (in which case the new node’s
  492. * source will reference the original, cloned node) or setting
  493. * the `source` property manually.
  494. *
  495. * ```js
  496. * // Bad
  497. * const prefixed = postcss.decl({
  498. * prop: '-moz-' + decl.prop,
  499. * value: decl.value
  500. * });
  501. *
  502. * // Good
  503. * const prefixed = decl.clone({ prop: '-moz-' + decl.prop });
  504. * ```
  505. *
  506. * ```js
  507. * if ( atrule.name == 'add-link' ) {
  508. * const rule = postcss.rule({ selector: 'a', source: atrule.source });
  509. * atrule.parent.insertBefore(atrule, rule);
  510. * }
  511. * ```
  512. *
  513. * @example
  514. * decl.source.input.from //=> '/home/ai/a.sass'
  515. * decl.source.start //=> { line: 10, column: 2 }
  516. * decl.source.end //=> { line: 10, column: 12 }
  517. */
  518. /**
  519. * @memberof Node#
  520. * @member {object} raws - Information to generate byte-to-byte equal
  521. * node string as it was in the origin input.
  522. *
  523. * Every parser saves its own properties,
  524. * but the default CSS parser uses:
  525. *
  526. * * `before`: the space symbols before the node. It also stores `*`
  527. * and `_` symbols before the declaration (IE hack).
  528. * * `after`: the space symbols after the last child of the node
  529. * to the end of the node.
  530. * * `between`: the symbols between the property and value
  531. * for declarations, selector and `{` for rules, or last parameter
  532. * and `{` for at-rules.
  533. * * `semicolon`: contains true if the last child has
  534. * an (optional) semicolon.
  535. * * `afterName`: the space between the at-rule name and its parameters.
  536. * * `left`: the space symbols between `/*` and the comment’s text.
  537. * * `right`: the space symbols between the comment’s text
  538. * and <code>*&#47;</code>.
  539. * * `important`: the content of the important statement,
  540. * if it is not just `!important`.
  541. *
  542. * PostCSS cleans selectors, declaration values and at-rule parameters
  543. * from comments and extra spaces, but it stores origin content in raws
  544. * properties. As such, if you don’t change a declaration’s value,
  545. * PostCSS will use the raw value with comments.
  546. *
  547. * @example
  548. * const root = postcss.parse('a {\n color:black\n}')
  549. * root.first.first.raws //=> { before: '\n ', between: ':' }
  550. */
  551. }]);
  552. return Node;
  553. }();
  554. exports.default = Node;
  555. /**
  556. * @typedef {object} position
  557. * @property {number} line - source line in file
  558. * @property {number} column - source column in file
  559. */
  560. /**
  561. * @typedef {object} source
  562. * @property {Input} input - {@link Input} with input file
  563. * @property {position} start - The starting position of the node’s source
  564. * @property {position} end - The ending position of the node’s source
  565. */
  566. module.exports = exports['default'];
  567. //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["/lib/node.es6"],"names":["cloneNode","obj","parent","cloned","constructor","i","hasOwnProperty","value","type","Array","map","j","Node","defaults","raws","name","error","message","opts","source","pos","positionBy","input","line","column","warn","result","text","data","node","remove","removeChild","undefined","toString","stringifier","stringify","clone","overrides","cloneBefore","insertBefore","cloneAfter","insertAfter","replaceWith","nodes","moveTo","newParent","cleanRaws","root","append","moveBefore","otherNode","moveAfter","next","index","prev","toJSON","fixed","raw","prop","defaultType","str","keepBetween","before","after","between","positionInside","string","start","word","indexOf","removeSelf","replace","style","own","detect","cleanStyles","val"],"mappings":"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","file":"node.js","sourcesContent":["import CssSyntaxError from './css-syntax-error';\nimport Stringifier    from './stringifier';\nimport stringify      from './stringify';\nimport warnOnce       from './warn-once';\n\nlet cloneNode = function (obj, parent) {\n    let cloned = new obj.constructor();\n\n    for ( let i in obj ) {\n        if ( !obj.hasOwnProperty(i) ) continue;\n        let value = obj[i];\n        let type  = typeof value;\n\n        if ( i === 'parent' && type === 'object' ) {\n            if (parent) cloned[i] = parent;\n        } else if ( i === 'source' ) {\n            cloned[i] = value;\n        } else if ( value instanceof Array ) {\n            cloned[i] = value.map( j => cloneNode(j, cloned) );\n        } else if ( i !== 'before'  && i !== 'after' &&\n                    i !== 'between' && i !== 'semicolon' ) {\n            if ( type === 'object' && value !== null ) value = cloneNode(value);\n            cloned[i] = value;\n        }\n    }\n\n    return cloned;\n};\n\n/**\n * All node classes inherit the following common methods.\n *\n * @abstract\n */\nclass Node {\n\n    /**\n     * @param {object} [defaults] - value for node properties\n     */\n    constructor(defaults = { }) {\n        this.raws = { };\n        for ( let name in defaults ) {\n            this[name] = defaults[name];\n        }\n    }\n\n    /**\n     * Returns a CssSyntaxError instance containing the original position\n     * of the node in the source, showing line and column numbers and also\n     * a small excerpt to facilitate debugging.\n     *\n     * If present, an input source map will be used to get the original position\n     * of the source, even from a previous compilation step\n     * (e.g., from Sass compilation).\n     *\n     * This method produces very useful error messages.\n     *\n     * @param {string} message     - error description\n     * @param {object} [opts]      - options\n     * @param {string} opts.plugin - plugin name that created this error.\n     *                               PostCSS will set it automatically.\n     * @param {string} opts.word   - a word inside a node’s string that should\n     *                               be highlighted as the source of the error\n     * @param {number} opts.index  - an index inside a node’s string that should\n     *                               be highlighted as the source of the error\n     *\n     * @return {CssSyntaxError} error object to throw it\n     *\n     * @example\n     * if ( !variables[name] ) {\n     *   throw decl.error('Unknown variable ' + name, { word: name });\n     *   // CssSyntaxError: postcss-vars:a.sass:4:3: Unknown variable $black\n     *   //   color: $black\n     *   // a\n     *   //          ^\n     *   //   background: white\n     * }\n     */\n    error(message, opts = { }) {\n        if ( this.source ) {\n            let pos = this.positionBy(opts);\n            return this.source.input.error(message, pos.line, pos.column, opts);\n        } else {\n            return new CssSyntaxError(message);\n        }\n    }\n\n    /**\n     * This method is provided as a convenience wrapper for {@link Result#warn}.\n     *\n     * @param {Result} result      - the {@link Result} instance\n     *                               that will receive the warning\n     * @param {string} text        - warning message\n     * @param {object} [opts]      - options\n     * @param {string} opts.plugin - plugin name that created this warning.\n     *                               PostCSS will set it automatically.\n     * @param {string} opts.word   - a word inside a node’s string that should\n     *                               be highlighted as the source of the warning\n     * @param {number} opts.index  - an index inside a node’s string that should\n     *                               be highlighted as the source of the warning\n     *\n     * @return {Warning} created warning object\n     *\n     * @example\n     * const plugin = postcss.plugin('postcss-deprecated', () => {\n     *   return (root, result) => {\n     *     root.walkDecls('bad', decl => {\n     *       decl.warn(result, 'Deprecated property bad');\n     *     });\n     *   };\n     * });\n     */\n    warn(result, text, opts) {\n        let data = { node: this };\n        for ( let i in opts ) data[i] = opts[i];\n        return result.warn(text, data);\n    }\n\n    /**\n     * Removes the node from its parent and cleans the parent properties\n     * from the node and its children.\n     *\n     * @example\n     * if ( decl.prop.match(/^-webkit-/) ) {\n     *   decl.remove();\n     * }\n     *\n     * @return {Node} node to make calls chain\n     */\n    remove() {\n        if ( this.parent ) {\n            this.parent.removeChild(this);\n        }\n        this.parent = undefined;\n        return this;\n    }\n\n    /**\n     * Returns a CSS string representing the node.\n     *\n     * @param {stringifier|syntax} [stringifier] - a syntax to use\n     *                                             in string generation\n     *\n     * @return {string} CSS string of this node\n     *\n     * @example\n     * postcss.rule({ selector: 'a' }).toString() //=> \"a {}\"\n     */\n    toString(stringifier = stringify) {\n        if ( stringifier.stringify ) stringifier = stringifier.stringify;\n        let result  = '';\n        stringifier(this, i => {\n            result += i;\n        });\n        return result;\n    }\n\n    /**\n     * Returns a clone of the node.\n     *\n     * The resulting cloned node and its (cloned) children will have\n     * a clean parent and code style properties.\n     *\n     * @param {object} [overrides] - new properties to override in the clone.\n     *\n     * @example\n     * const cloned = decl.clone({ prop: '-moz-' + decl.prop });\n     * cloned.raws.before  //=> undefined\n     * cloned.parent       //=> undefined\n     * cloned.toString()   //=> -moz-transform: scale(0)\n     *\n     * @return {Node} clone of the node\n     */\n    clone(overrides = { }) {\n        let cloned = cloneNode(this);\n        for ( let name in overrides ) {\n            cloned[name] = overrides[name];\n        }\n        return cloned;\n    }\n\n    /**\n     * Shortcut to clone the node and insert the resulting cloned node\n     * before the current node.\n     *\n     * @param {object} [overrides] - new properties to override in the clone.\n     *\n     * @example\n     * decl.cloneBefore({ prop: '-moz-' + decl.prop });\n     *\n     * @return {Node} - new node\n     */\n    cloneBefore(overrides = { }) {\n        let cloned = this.clone(overrides);\n        this.parent.insertBefore(this, cloned);\n        return cloned;\n    }\n\n    /**\n     * Shortcut to clone the node and insert the resulting cloned node\n     * after the current node.\n     *\n     * @param {object} [overrides] - new properties to override in the clone.\n     *\n     * @return {Node} - new node\n     */\n    cloneAfter(overrides = { }) {\n        let cloned = this.clone(overrides);\n        this.parent.insertAfter(this, cloned);\n        return cloned;\n    }\n\n    /**\n     * Inserts node(s) before the current node and removes the current node.\n     *\n     * @param {...Node} nodes - node(s) to replace current one\n     *\n     * @example\n     * if ( atrule.name == 'mixin' ) {\n     *   atrule.replaceWith(mixinRules[atrule.params]);\n     * }\n     *\n     * @return {Node} current node to methods chain\n     */\n    replaceWith(...nodes) {\n        if (this.parent) {\n            for (let node of nodes) {\n                this.parent.insertBefore(this, node);\n            }\n\n            this.remove();\n        }\n\n        return this;\n    }\n\n    /**\n     * Removes the node from its current parent and inserts it\n     * at the end of `newParent`.\n     *\n     * This will clean the `before` and `after` code {@link Node#raws} data\n     * from the node and replace them with the indentation style of `newParent`.\n     * It will also clean the `between` property\n     * if `newParent` is in another {@link Root}.\n     *\n     * @param {Container} newParent - container node where the current node\n     *                                will be moved\n     *\n     * @example\n     * atrule.moveTo(atrule.root());\n     *\n     * @return {Node} current node to methods chain\n     */\n    moveTo(newParent) {\n        this.cleanRaws(this.root() === newParent.root());\n        this.remove();\n        newParent.append(this);\n        return this;\n    }\n\n    /**\n     * Removes the node from its current parent and inserts it into\n     * a new parent before `otherNode`.\n     *\n     * This will also clean the node’s code style properties just as it would\n     * in {@link Node#moveTo}.\n     *\n     * @param {Node} otherNode - node that will be before current node\n     *\n     * @return {Node} current node to methods chain\n     */\n    moveBefore(otherNode) {\n        this.cleanRaws(this.root() === otherNode.root());\n        this.remove();\n        otherNode.parent.insertBefore(otherNode, this);\n        return this;\n    }\n\n    /**\n     * Removes the node from its current parent and inserts it into\n     * a new parent after `otherNode`.\n     *\n     * This will also clean the node’s code style properties just as it would\n     * in {@link Node#moveTo}.\n     *\n     * @param {Node} otherNode - node that will be after current node\n     *\n     * @return {Node} current node to methods chain\n     */\n    moveAfter(otherNode) {\n        this.cleanRaws(this.root() === otherNode.root());\n        this.remove();\n        otherNode.parent.insertAfter(otherNode, this);\n        return this;\n    }\n\n    /**\n     * Returns the next child of the node’s parent.\n     * Returns `undefined` if the current node is the last child.\n     *\n     * @return {Node|undefined} next node\n     *\n     * @example\n     * if ( comment.text === 'delete next' ) {\n     *   const next = comment.next();\n     *   if ( next ) {\n     *     next.remove();\n     *   }\n     * }\n     */\n    next() {\n        let index = this.parent.index(this);\n        return this.parent.nodes[index + 1];\n    }\n\n    /**\n     * Returns the previous child of the node’s parent.\n     * Returns `undefined` if the current node is the first child.\n     *\n     * @return {Node|undefined} previous node\n     *\n     * @example\n     * const annotation = decl.prev();\n     * if ( annotation.type == 'comment' ) {\n     *  readAnnotation(annotation.text);\n     * }\n     */\n    prev() {\n        let index = this.parent.index(this);\n        return this.parent.nodes[index - 1];\n    }\n\n    toJSON() {\n        let fixed = { };\n\n        for ( let name in this ) {\n            if ( !this.hasOwnProperty(name) ) continue;\n            if ( name === 'parent' ) continue;\n            let value = this[name];\n\n            if ( value instanceof Array ) {\n                fixed[name] = value.map( i => {\n                    if ( typeof i === 'object' && i.toJSON ) {\n                        return i.toJSON();\n                    } else {\n                        return i;\n                    }\n                });\n            } else if ( typeof value === 'object' && value.toJSON ) {\n                fixed[name] = value.toJSON();\n            } else {\n                fixed[name] = value;\n            }\n        }\n\n        return fixed;\n    }\n\n    /**\n     * Returns a {@link Node#raws} value. If the node is missing\n     * the code style property (because the node was manually built or cloned),\n     * PostCSS will try to autodetect the code style property by looking\n     * at other nodes in the tree.\n     *\n     * @param {string} prop          - name of code style property\n     * @param {string} [defaultType] - name of default value, it can be missed\n     *                                 if the value is the same as prop\n     *\n     * @example\n     * const root = postcss.parse('a { background: white }');\n     * root.nodes[0].append({ prop: 'color', value: 'black' });\n     * root.nodes[0].nodes[1].raws.before   //=> undefined\n     * root.nodes[0].nodes[1].raw('before') //=> ' '\n     *\n     * @return {string} code style value\n     */\n    raw(prop, defaultType) {\n        let str = new Stringifier();\n        return str.raw(this, prop, defaultType);\n    }\n\n    /**\n     * Finds the Root instance of the node’s tree.\n     *\n     * @example\n     * root.nodes[0].nodes[0].root() === root\n     *\n     * @return {Root} root parent\n     */\n    root() {\n        let result = this;\n        while ( result.parent ) result = result.parent;\n        return result;\n    }\n\n    cleanRaws(keepBetween) {\n        delete this.raws.before;\n        delete this.raws.after;\n        if ( !keepBetween ) delete this.raws.between;\n    }\n\n    positionInside(index) {\n        let string = this.toString();\n        let column = this.source.start.column;\n        let line   = this.source.start.line;\n\n        for ( let i = 0; i < index; i++ ) {\n            if ( string[i] === '\\n' ) {\n                column = 1;\n                line  += 1;\n            } else {\n                column += 1;\n            }\n        }\n\n        return { line, column };\n    }\n\n    positionBy(opts) {\n        let pos = this.source.start;\n        if ( opts.index ) {\n            pos = this.positionInside(opts.index);\n        } else if ( opts.word ) {\n            let index = this.toString().indexOf(opts.word);\n            if ( index !== -1 ) pos = this.positionInside(index);\n        }\n        return pos;\n    }\n\n    removeSelf() {\n        warnOnce('Node#removeSelf is deprecated. Use Node#remove.');\n        return this.remove();\n    }\n\n    replace(nodes) {\n        warnOnce('Node#replace is deprecated. Use Node#replaceWith');\n        return this.replaceWith(nodes);\n    }\n\n    style(own, detect) {\n        warnOnce('Node#style() is deprecated. Use Node#raw()');\n        return this.raw(own, detect);\n    }\n\n    cleanStyles(keepBetween) {\n        warnOnce('Node#cleanStyles() is deprecated. Use Node#cleanRaws()');\n        return this.cleanRaws(keepBetween);\n    }\n\n    get before() {\n        warnOnce('Node#before is deprecated. Use Node#raws.before');\n        return this.raws.before;\n    }\n\n    set before(val) {\n        warnOnce('Node#before is deprecated. Use Node#raws.before');\n        this.raws.before = val;\n    }\n\n    get between() {\n        warnOnce('Node#between is deprecated. Use Node#raws.between');\n        return this.raws.between;\n    }\n\n    set between(val) {\n        warnOnce('Node#between is deprecated. Use Node#raws.between');\n        this.raws.between = val;\n    }\n\n    /**\n     * @memberof Node#\n     * @member {string} type - String representing the node’s type.\n     *                         Possible values are `root`, `atrule`, `rule`,\n     *                         `decl`, or `comment`.\n     *\n     * @example\n     * postcss.decl({ prop: 'color', value: 'black' }).type //=> 'decl'\n     */\n\n    /**\n     * @memberof Node#\n     * @member {Container} parent - the node’s parent node.\n     *\n     * @example\n     * root.nodes[0].parent == root;\n     */\n\n    /**\n     * @memberof Node#\n     * @member {source} source - the input source of the node\n     *\n     * The property is used in source map generation.\n     *\n     * If you create a node manually (e.g., with `postcss.decl()`),\n     * that node will not have a `source` property and will be absent\n     * from the source map. For this reason, the plugin developer should\n     * consider cloning nodes to create new ones (in which case the new node’s\n     * source will reference the original, cloned node) or setting\n     * the `source` property manually.\n     *\n     * ```js\n     * // Bad\n     * const prefixed = postcss.decl({\n     *   prop: '-moz-' + decl.prop,\n     *   value: decl.value\n     * });\n     *\n     * // Good\n     * const prefixed = decl.clone({ prop: '-moz-' + decl.prop });\n     * ```\n     *\n     * ```js\n     * if ( atrule.name == 'add-link' ) {\n     *   const rule = postcss.rule({ selector: 'a', source: atrule.source });\n     *   atrule.parent.insertBefore(atrule, rule);\n     * }\n     * ```\n     *\n     * @example\n     * decl.source.input.from //=> '/home/ai/a.sass'\n     * decl.source.start      //=> { line: 10, column: 2 }\n     * decl.source.end        //=> { line: 10, column: 12 }\n     */\n\n    /**\n     * @memberof Node#\n     * @member {object} raws - Information to generate byte-to-byte equal\n     *                         node string as it was in the origin input.\n     *\n     * Every parser saves its own properties,\n     * but the default CSS parser uses:\n     *\n     * * `before`: the space symbols before the node. It also stores `*`\n     *   and `_` symbols before the declaration (IE hack).\n     * * `after`: the space symbols after the last child of the node\n     *   to the end of the node.\n     * * `between`: the symbols between the property and value\n     *   for declarations, selector and `{` for rules, or last parameter\n     *   and `{` for at-rules.\n     * * `semicolon`: contains true if the last child has\n     *   an (optional) semicolon.\n     * * `afterName`: the space between the at-rule name and its parameters.\n     * * `left`: the space symbols between `/*` and the comment’s text.\n     * * `right`: the space symbols between the comment’s text\n     *   and <code>*&#47;</code>.\n     * * `important`: the content of the important statement,\n     *   if it is not just `!important`.\n     *\n     * PostCSS cleans selectors, declaration values and at-rule parameters\n     * from comments and extra spaces, but it stores origin content in raws\n     * properties. As such, if you don’t change a declaration’s value,\n     * PostCSS will use the raw value with comments.\n     *\n     * @example\n     * const root = postcss.parse('a {\\n  color:black\\n}')\n     * root.first.first.raws //=> { before: '\\n  ', between: ':' }\n     */\n\n}\n\nexport default Node;\n\n/**\n * @typedef {object} position\n * @property {number} line   - source line in file\n * @property {number} column - source column in file\n */\n\n/**\n * @typedef {object} source\n * @property {Input} input    - {@link Input} with input file\n * @property {position} start - The starting position of the node’s source\n * @property {position} end   - The ending position of the node’s source\n */\n"]}