result.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  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 _warning = require('./warning');
  5. var _warning2 = _interopRequireDefault(_warning);
  6. function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
  7. function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
  8. /**
  9. * Provides the result of the PostCSS transformations.
  10. *
  11. * A Result instance is returned by {@link LazyResult#then}
  12. * or {@link Root#toResult} methods.
  13. *
  14. * @example
  15. * postcss([cssnext]).process(css).then(function (result) {
  16. * console.log(result.css);
  17. * });
  18. *
  19. * @example
  20. * var result2 = postcss.parse(css).toResult();
  21. */
  22. var Result = function () {
  23. /**
  24. * @param {Processor} processor - processor used for this transformation.
  25. * @param {Root} root - Root node after all transformations.
  26. * @param {processOptions} opts - options from the {@link Processor#process}
  27. * or {@link Root#toResult}
  28. */
  29. function Result(processor, root, opts) {
  30. _classCallCheck(this, Result);
  31. /**
  32. * @member {Processor} - The Processor instance used
  33. * for this transformation.
  34. *
  35. * @example
  36. * for ( let plugin of result.processor.plugins) {
  37. * if ( plugin.postcssPlugin === 'postcss-bad' ) {
  38. * throw 'postcss-good is incompatible with postcss-bad';
  39. * }
  40. * });
  41. */
  42. this.processor = processor;
  43. /**
  44. * @member {Message[]} - Contains messages from plugins
  45. * (e.g., warnings or custom messages).
  46. * Each message should have type
  47. * and plugin properties.
  48. *
  49. * @example
  50. * postcss.plugin('postcss-min-browser', () => {
  51. * return (root, result) => {
  52. * var browsers = detectMinBrowsersByCanIUse(root);
  53. * result.messages.push({
  54. * type: 'min-browser',
  55. * plugin: 'postcss-min-browser',
  56. * browsers: browsers
  57. * });
  58. * };
  59. * });
  60. */
  61. this.messages = [];
  62. /**
  63. * @member {Root} - Root node after all transformations.
  64. *
  65. * @example
  66. * root.toResult().root == root;
  67. */
  68. this.root = root;
  69. /**
  70. * @member {processOptions} - Options from the {@link Processor#process}
  71. * or {@link Root#toResult} call
  72. * that produced this Result instance.
  73. *
  74. * @example
  75. * root.toResult(opts).opts == opts;
  76. */
  77. this.opts = opts;
  78. /**
  79. * @member {string} - A CSS string representing of {@link Result#root}.
  80. *
  81. * @example
  82. * postcss.parse('a{}').toResult().css //=> "a{}"
  83. */
  84. this.css = undefined;
  85. /**
  86. * @member {SourceMapGenerator} - An instance of `SourceMapGenerator`
  87. * class from the `source-map` library,
  88. * representing changes
  89. * to the {@link Result#root} instance.
  90. *
  91. * @example
  92. * result.map.toJSON() //=> { version: 3, file: 'a.css', … }
  93. *
  94. * @example
  95. * if ( result.map ) {
  96. * fs.writeFileSync(result.opts.to + '.map', result.map.toString());
  97. * }
  98. */
  99. this.map = undefined;
  100. }
  101. /**
  102. * Returns for @{link Result#css} content.
  103. *
  104. * @example
  105. * result + '' === result.css
  106. *
  107. * @return {string} string representing of {@link Result#root}
  108. */
  109. Result.prototype.toString = function toString() {
  110. return this.css;
  111. };
  112. /**
  113. * Creates an instance of {@link Warning} and adds it
  114. * to {@link Result#messages}.
  115. *
  116. * @param {string} text - warning message
  117. * @param {Object} [opts] - warning options
  118. * @param {Node} opts.node - CSS node that caused the warning
  119. * @param {string} opts.word - word in CSS source that caused the warning
  120. * @param {number} opts.index - index in CSS node string that caused
  121. * the warning
  122. * @param {string} opts.plugin - name of the plugin that created
  123. * this warning. {@link Result#warn} fills
  124. * this property automatically.
  125. *
  126. * @return {Warning} created warning
  127. */
  128. Result.prototype.warn = function warn(text) {
  129. var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
  130. if (!opts.plugin) {
  131. if (this.lastPlugin && this.lastPlugin.postcssPlugin) {
  132. opts.plugin = this.lastPlugin.postcssPlugin;
  133. }
  134. }
  135. var warning = new _warning2.default(text, opts);
  136. this.messages.push(warning);
  137. return warning;
  138. };
  139. /**
  140. * Returns warnings from plugins. Filters {@link Warning} instances
  141. * from {@link Result#messages}.
  142. *
  143. * @example
  144. * result.warnings().forEach(warn => {
  145. * console.warn(warn.toString());
  146. * });
  147. *
  148. * @return {Warning[]} warnings from plugins
  149. */
  150. Result.prototype.warnings = function warnings() {
  151. return this.messages.filter(function (i) {
  152. return i.type === 'warning';
  153. });
  154. };
  155. /**
  156. * An alias for the {@link Result#css} property.
  157. * Use it with syntaxes that generate non-CSS output.
  158. * @type {string}
  159. *
  160. * @example
  161. * result.css === result.content;
  162. */
  163. _createClass(Result, [{
  164. key: 'content',
  165. get: function get() {
  166. return this.css;
  167. }
  168. }]);
  169. return Result;
  170. }();
  171. exports.default = Result;
  172. /**
  173. * @typedef {object} Message
  174. * @property {string} type - message type
  175. * @property {string} plugin - source PostCSS plugin name
  176. */
  177. module.exports = exports['default'];
  178. //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9saWIvcmVzdWx0LmVzNiJdLCJuYW1lcyI6WyJSZXN1bHQiLCJwcm9jZXNzb3IiLCJyb290Iiwib3B0cyIsIm1lc3NhZ2VzIiwiY3NzIiwidW5kZWZpbmVkIiwibWFwIiwidG9TdHJpbmciLCJ3YXJuIiwidGV4dCIsInBsdWdpbiIsImxhc3RQbHVnaW4iLCJwb3N0Y3NzUGx1Z2luIiwid2FybmluZyIsInB1c2giLCJ3YXJuaW5ncyIsImZpbHRlciIsImkiLCJ0eXBlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7Ozs7Ozs7QUFFQTs7Ozs7Ozs7Ozs7Ozs7SUFjTUEsTTs7QUFFRjs7Ozs7O0FBTUEsa0JBQVlDLFNBQVosRUFBdUJDLElBQXZCLEVBQTZCQyxJQUE3QixFQUFtQztBQUFBOztBQUMvQjs7Ozs7Ozs7Ozs7QUFXQSxTQUFLRixTQUFMLEdBQWlCQSxTQUFqQjtBQUNBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFrQkEsU0FBS0csUUFBTCxHQUFnQixFQUFoQjtBQUNBOzs7Ozs7QUFNQSxTQUFLRixJQUFMLEdBQVlBLElBQVo7QUFDQTs7Ozs7Ozs7QUFRQSxTQUFLQyxJQUFMLEdBQVlBLElBQVo7QUFDQTs7Ozs7O0FBTUEsU0FBS0UsR0FBTCxHQUFXQyxTQUFYO0FBQ0E7Ozs7Ozs7Ozs7Ozs7O0FBY0EsU0FBS0MsR0FBTCxHQUFXRCxTQUFYO0FBQ0g7O0FBRUQ7Ozs7Ozs7Ozs7bUJBUUFFLFEsdUJBQVc7QUFDUCxXQUFPLEtBQUtILEdBQVo7QUFDSCxHOztBQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7bUJBZ0JBSSxJLGlCQUFLQyxJLEVBQWtCO0FBQUEsUUFBWlAsSUFBWSx1RUFBTCxFQUFLOztBQUNuQixRQUFLLENBQUNBLEtBQUtRLE1BQVgsRUFBb0I7QUFDaEIsVUFBSyxLQUFLQyxVQUFMLElBQW1CLEtBQUtBLFVBQUwsQ0FBZ0JDLGFBQXhDLEVBQXdEO0FBQ3BEVixhQUFLUSxNQUFMLEdBQWMsS0FBS0MsVUFBTCxDQUFnQkMsYUFBOUI7QUFDSDtBQUNKOztBQUVELFFBQUlDLFVBQVUsc0JBQVlKLElBQVosRUFBa0JQLElBQWxCLENBQWQ7QUFDQSxTQUFLQyxRQUFMLENBQWNXLElBQWQsQ0FBbUJELE9BQW5COztBQUVBLFdBQU9BLE9BQVA7QUFDSCxHOztBQUVEOzs7Ozs7Ozs7Ozs7O21CQVdBRSxRLHVCQUFXO0FBQ1AsV0FBTyxLQUFLWixRQUFMLENBQWNhLE1BQWQsQ0FBc0I7QUFBQSxhQUFLQyxFQUFFQyxJQUFGLEtBQVcsU0FBaEI7QUFBQSxLQUF0QixDQUFQO0FBQ0gsRzs7QUFFRDs7Ozs7Ozs7Ozs7O3dCQVFjO0FBQ1YsYUFBTyxLQUFLZCxHQUFaO0FBQ0g7Ozs7OztrQkFJVUwsTTs7QUFFZiIsImZpbGUiOiJyZXN1bHQuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgV2FybmluZyBmcm9tICcuL3dhcm5pbmcnO1xuXG4vKipcbiAqIFByb3ZpZGVzIHRoZSByZXN1bHQgb2YgdGhlIFBvc3RDU1MgdHJhbnNmb3JtYXRpb25zLlxuICpcbiAqIEEgUmVzdWx0IGluc3RhbmNlIGlzIHJldHVybmVkIGJ5IHtAbGluayBMYXp5UmVzdWx0I3RoZW59XG4gKiBvciB7QGxpbmsgUm9vdCN0b1Jlc3VsdH0gbWV0aG9kcy5cbiAqXG4gKiBAZXhhbXBsZVxuICogcG9zdGNzcyhbY3NzbmV4dF0pLnByb2Nlc3MoY3NzKS50aGVuKGZ1bmN0aW9uIChyZXN1bHQpIHtcbiAqICAgIGNvbnNvbGUubG9nKHJlc3VsdC5jc3MpO1xuICogfSk7XG4gKlxuICogQGV4YW1wbGVcbiAqIHZhciByZXN1bHQyID0gcG9zdGNzcy5wYXJzZShjc3MpLnRvUmVzdWx0KCk7XG4gKi9cbmNsYXNzIFJlc3VsdCB7XG5cbiAgICAvKipcbiAgICAgKiBAcGFyYW0ge1Byb2Nlc3Nvcn0gcHJvY2Vzc29yIC0gcHJvY2Vzc29yIHVzZWQgZm9yIHRoaXMgdHJhbnNmb3JtYXRpb24uXG4gICAgICogQHBhcmFtIHtSb290fSAgICAgIHJvb3QgICAgICAtIFJvb3Qgbm9kZSBhZnRlciBhbGwgdHJhbnNmb3JtYXRpb25zLlxuICAgICAqIEBwYXJhbSB7cHJvY2Vzc09wdGlvbnN9IG9wdHMgLSBvcHRpb25zIGZyb20gdGhlIHtAbGluayBQcm9jZXNzb3IjcHJvY2Vzc31cbiAgICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgb3Ige0BsaW5rIFJvb3QjdG9SZXN1bHR9XG4gICAgICovXG4gICAgY29uc3RydWN0b3IocHJvY2Vzc29yLCByb290LCBvcHRzKSB7XG4gICAgICAgIC8qKlxuICAgICAgICAgKiBAbWVtYmVyIHtQcm9jZXNzb3J9IC0gVGhlIFByb2Nlc3NvciBpbnN0YW5jZSB1c2VkXG4gICAgICAgICAqICAgICAgICAgICAgICAgICAgICAgICBmb3IgdGhpcyB0cmFuc2Zvcm1hdGlvbi5cbiAgICAgICAgICpcbiAgICAgICAgICogQGV4YW1wbGVcbiAgICAgICAgICogZm9yICggbGV0IHBsdWdpbiBvZiByZXN1bHQucHJvY2Vzc29yLnBsdWdpbnMpIHtcbiAgICAgICAgICogICBpZiAoIHBsdWdpbi5wb3N0Y3NzUGx1Z2luID09PSAncG9zdGNzcy1iYWQnICkge1xuICAgICAgICAgKiAgICAgdGhyb3cgJ3Bvc3Rjc3MtZ29vZCBpcyBpbmNvbXBhdGlibGUgd2l0aCBwb3N0Y3NzLWJhZCc7XG4gICAgICAgICAqICAgfVxuICAgICAgICAgKiB9KTtcbiAgICAgICAgICovXG4gICAgICAgIHRoaXMucHJvY2Vzc29yID0gcHJvY2Vzc29yO1xuICAgICAgICAvKipcbiAgICAgICAgICogQG1lbWJlciB7TWVzc2FnZVtdfSAtIENvbnRhaW5zIG1lc3NhZ2VzIGZyb20gcGx1Z2luc1xuICAgICAgICAgKiAgICAgICAgICAgICAgICAgICAgICAgKGUuZy4sIHdhcm5pbmdzIG9yIGN1c3RvbSBtZXNzYWdlcykuXG4gICAgICAgICAqICAgICAgICAgICAgICAgICAgICAgICBFYWNoIG1lc3NhZ2Ugc2hvdWxkIGhhdmUgdHlwZVxuICAgICAgICAgKiAgICAgICAgICAgICAgICAgICAgICAgYW5kIHBsdWdpbiBwcm9wZXJ0aWVzLlxuICAgICAgICAgKlxuICAgICAgICAgKiBAZXhhbXBsZVxuICAgICAgICAgKiBwb3N0Y3NzLnBsdWdpbigncG9zdGNzcy1taW4tYnJvd3NlcicsICgpID0+IHtcbiAgICAgICAgICogICByZXR1cm4gKHJvb3QsIHJlc3VsdCkgPT4ge1xuICAgICAgICAgKiAgICAgdmFyIGJyb3dzZXJzID0gZGV0ZWN0TWluQnJvd3NlcnNCeUNhbklVc2Uocm9vdCk7XG4gICAgICAgICAqICAgICByZXN1bHQubWVzc2FnZXMucHVzaCh7XG4gICAgICAgICAqICAgICAgIHR5cGU6ICAgICdtaW4tYnJvd3NlcicsXG4gICAgICAgICAqICAgICAgIHBsdWdpbjogICdwb3N0Y3NzLW1pbi1icm93c2VyJyxcbiAgICAgICAgICogICAgICAgYnJvd3NlcnM6IGJyb3dzZXJzXG4gICAgICAgICAqICAgICB9KTtcbiAgICAgICAgICogICB9O1xuICAgICAgICAgKiB9KTtcbiAgICAgICAgICovXG4gICAgICAgIHRoaXMubWVzc2FnZXMgPSBbXTtcbiAgICAgICAgLyoqXG4gICAgICAgICAqIEBtZW1iZXIge1Jvb3R9IC0gUm9vdCBub2RlIGFmdGVyIGFsbCB0cmFuc2Zvcm1hdGlvbnMuXG4gICAgICAgICAqXG4gICAgICAgICAqIEBleGFtcGxlXG4gICAgICAgICAqIHJvb3QudG9SZXN1bHQoKS5yb290ID09IHJvb3Q7XG4gICAgICAgICAqL1xuICAgICAgICB0aGlzLnJvb3QgPSByb290O1xuICAgICAgICAvKipcbiAgICAgICAgICogQG1lbWJlciB7cHJvY2Vzc09wdGlvbnN9IC0gT3B0aW9ucyBmcm9tIHRoZSB7QGxpbmsgUHJvY2Vzc29yI3Byb2Nlc3N9XG4gICAgICAgICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgIG9yIHtAbGluayBSb290I3RvUmVzdWx0fSBjYWxsXG4gICAgICAgICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoYXQgcHJvZHVjZWQgdGhpcyBSZXN1bHQgaW5zdGFuY2UuXG4gICAgICAgICAqXG4gICAgICAgICAqIEBleGFtcGxlXG4gICAgICAgICAqIHJvb3QudG9SZXN1bHQob3B0cykub3B0cyA9PSBvcHRzO1xuICAgICAgICAgKi9cbiAgICAgICAgdGhpcy5vcHRzID0gb3B0cztcbiAgICAgICAgLyoqXG4gICAgICAgICAqIEBtZW1iZXIge3N0cmluZ30gLSBBIENTUyBzdHJpbmcgcmVwcmVzZW50aW5nIG9mIHtAbGluayBSZXN1bHQjcm9vdH0uXG4gICAgICAgICAqXG4gICAgICAgICAqIEBleGFtcGxlXG4gICAgICAgICAqIHBvc3Rjc3MucGFyc2UoJ2F7fScpLnRvUmVzdWx0KCkuY3NzIC8vPT4gXCJhe31cIlxuICAgICAgICAgKi9cbiAgICAgICAgdGhpcy5jc3MgPSB1bmRlZmluZWQ7XG4gICAgICAgIC8qKlxuICAgICAgICAgKiBAbWVtYmVyIHtTb3VyY2VNYXBHZW5lcmF0b3J9IC0gQW4gaW5zdGFuY2Ugb2YgYFNvdXJjZU1hcEdlbmVyYXRvcmBcbiAgICAgICAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzIGZyb20gdGhlIGBzb3VyY2UtbWFwYCBsaWJyYXJ5LFxuICAgICAgICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmVwcmVzZW50aW5nIGNoYW5nZXNcbiAgICAgICAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRvIHRoZSB7QGxpbmsgUmVzdWx0I3Jvb3R9IGluc3RhbmNlLlxuICAgICAgICAgKlxuICAgICAgICAgKiBAZXhhbXBsZVxuICAgICAgICAgKiByZXN1bHQubWFwLnRvSlNPTigpIC8vPT4geyB2ZXJzaW9uOiAzLCBmaWxlOiAnYS5jc3MnLCDigKYgfVxuICAgICAgICAgKlxuICAgICAgICAgKiBAZXhhbXBsZVxuICAgICAgICAgKiBpZiAoIHJlc3VsdC5tYXAgKSB7XG4gICAgICAgICAqICAgZnMud3JpdGVGaWxlU3luYyhyZXN1bHQub3B0cy50byArICcubWFwJywgcmVzdWx0Lm1hcC50b1N0cmluZygpKTtcbiAgICAgICAgICogfVxuICAgICAgICAgKi9cbiAgICAgICAgdGhpcy5tYXAgPSB1bmRlZmluZWQ7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogUmV0dXJucyBmb3IgQHtsaW5rIFJlc3VsdCNjc3N9IGNvbnRlbnQuXG4gICAgICpcbiAgICAgKiBAZXhhbXBsZVxuICAgICAqIHJlc3VsdCArICcnID09PSByZXN1bHQuY3NzXG4gICAgICpcbiAgICAgKiBAcmV0dXJuIHtzdHJpbmd9IHN0cmluZyByZXByZXNlbnRpbmcgb2Yge0BsaW5rIFJlc3VsdCNyb290fVxuICAgICAqL1xuICAgIHRvU3RyaW5nKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5jc3M7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlcyBhbiBpbnN0YW5jZSBvZiB7QGxpbmsgV2FybmluZ30gYW5kIGFkZHMgaXRcbiAgICAgKiB0byB7QGxpbmsgUmVzdWx0I21lc3NhZ2VzfS5cbiAgICAgKlxuICAgICAqIEBwYXJhbSB7c3RyaW5nfSB0ZXh0ICAgICAgICAtIHdhcm5pbmcgbWVzc2FnZVxuICAgICAqIEBwYXJhbSB7T2JqZWN0fSBbb3B0c10gICAgICAtIHdhcm5pbmcgb3B0aW9uc1xuICAgICAqIEBwYXJhbSB7Tm9kZX0gICBvcHRzLm5vZGUgICAtIENTUyBub2RlIHRoYXQgY2F1c2VkIHRoZSB3YXJuaW5nXG4gICAgICogQHBhcmFtIHtzdHJpbmd9IG9wdHMud29yZCAgIC0gd29yZCBpbiBDU1Mgc291cmNlIHRoYXQgY2F1c2VkIHRoZSB3YXJuaW5nXG4gICAgICogQHBhcmFtIHtudW1iZXJ9IG9wdHMuaW5kZXggIC0gaW5kZXggaW4gQ1NTIG5vZGUgc3RyaW5nIHRoYXQgY2F1c2VkXG4gICAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhlIHdhcm5pbmdcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gb3B0cy5wbHVnaW4gLSBuYW1lIG9mIHRoZSBwbHVnaW4gdGhhdCBjcmVhdGVkXG4gICAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcyB3YXJuaW5nLiB7QGxpbmsgUmVzdWx0I3dhcm59IGZpbGxzXG4gICAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcyBwcm9wZXJ0eSBhdXRvbWF0aWNhbGx5LlxuICAgICAqXG4gICAgICogQHJldHVybiB7V2FybmluZ30gY3JlYXRlZCB3YXJuaW5nXG4gICAgICovXG4gICAgd2Fybih0ZXh0LCBvcHRzID0geyB9KSB7XG4gICAgICAgIGlmICggIW9wdHMucGx1Z2luICkge1xuICAgICAgICAgICAgaWYgKCB0aGlzLmxhc3RQbHVnaW4gJiYgdGhpcy5sYXN0UGx1Z2luLnBvc3Rjc3NQbHVnaW4gKSB7XG4gICAgICAgICAgICAgICAgb3B0cy5wbHVnaW4gPSB0aGlzLmxhc3RQbHVnaW4ucG9zdGNzc1BsdWdpbjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGxldCB3YXJuaW5nID0gbmV3IFdhcm5pbmcodGV4dCwgb3B0cyk7XG4gICAgICAgIHRoaXMubWVzc2FnZXMucHVzaCh3YXJuaW5nKTtcblxuICAgICAgICByZXR1cm4gd2FybmluZztcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBSZXR1cm5zIHdhcm5pbmdzIGZyb20gcGx1Z2lucy4gRmlsdGVycyB7QGxpbmsgV2FybmluZ30gaW5zdGFuY2VzXG4gICAgICogZnJvbSB7QGxpbmsgUmVzdWx0I21lc3NhZ2VzfS5cbiAgICAgKlxuICAgICAqIEBleGFtcGxlXG4gICAgICogcmVzdWx0Lndhcm5pbmdzKCkuZm9yRWFjaCh3YXJuID0+IHtcbiAgICAgKiAgIGNvbnNvbGUud2Fybih3YXJuLnRvU3RyaW5nKCkpO1xuICAgICAqIH0pO1xuICAgICAqXG4gICAgICogQHJldHVybiB7V2FybmluZ1tdfSB3YXJuaW5ncyBmcm9tIHBsdWdpbnNcbiAgICAgKi9cbiAgICB3YXJuaW5ncygpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMubWVzc2FnZXMuZmlsdGVyKCBpID0+IGkudHlwZSA9PT0gJ3dhcm5pbmcnICk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQW4gYWxpYXMgZm9yIHRoZSB7QGxpbmsgUmVzdWx0I2Nzc30gcHJvcGVydHkuXG4gICAgICogVXNlIGl0IHdpdGggc3ludGF4ZXMgdGhhdCBnZW5lcmF0ZSBub24tQ1NTIG91dHB1dC5cbiAgICAgKiBAdHlwZSB7c3RyaW5nfVxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiByZXN1bHQuY3NzID09PSByZXN1bHQuY29udGVudDtcbiAgICAgKi9cbiAgICBnZXQgY29udGVudCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY3NzO1xuICAgIH1cblxufVxuXG5leHBvcnQgZGVmYXVsdCBSZXN1bHQ7XG5cbi8qKlxuICogQHR5cGVkZWYgIHtvYmplY3R9IE1lc3NhZ2VcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSB0eXBlICAgLSBtZXNzYWdlIHR5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBwbHVnaW4gLSBzb3VyY2UgUG9zdENTUyBwbHVnaW4gbmFtZVxuICovXG4iXX0=