a zip code crypto-currency system good for red ONLY

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. 'use strict';
  2. exports.__esModule = true;
  3. 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; };
  4. 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; }; }();
  5. var _cssSyntaxError = require('./css-syntax-error');
  6. var _cssSyntaxError2 = _interopRequireDefault(_cssSyntaxError);
  7. var _previousMap = require('./previous-map');
  8. var _previousMap2 = _interopRequireDefault(_previousMap);
  9. var _path = require('path');
  10. var _path2 = _interopRequireDefault(_path);
  11. function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
  12. function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
  13. var sequence = 0;
  14. /**
  15. * Represents the source CSS.
  16. *
  17. * @example
  18. * const root = postcss.parse(css, { from: file });
  19. * const input = root.source.input;
  20. */
  21. var Input = function () {
  22. /**
  23. * @param {string} css - input CSS source
  24. * @param {object} [opts] - {@link Processor#process} options
  25. */
  26. function Input(css) {
  27. var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
  28. _classCallCheck(this, Input);
  29. if (css === null || (typeof css === 'undefined' ? 'undefined' : _typeof(css)) === 'object' && !css.toString) {
  30. throw new Error('PostCSS received ' + css + ' instead of CSS string');
  31. }
  32. /**
  33. * @member {string} - input CSS source
  34. *
  35. * @example
  36. * const input = postcss.parse('a{}', { from: file }).input;
  37. * input.css //=> "a{}";
  38. */
  39. this.css = css.toString();
  40. if (this.css[0] === '\uFEFF' || this.css[0] === '\uFFFE') {
  41. this.css = this.css.slice(1);
  42. }
  43. if (opts.from) {
  44. if (/^\w+:\/\//.test(opts.from)) {
  45. /**
  46. * @member {string} - The absolute path to the CSS source file
  47. * defined with the `from` option.
  48. *
  49. * @example
  50. * const root = postcss.parse(css, { from: 'a.css' });
  51. * root.source.input.file //=> '/home/ai/a.css'
  52. */
  53. this.file = opts.from;
  54. } else {
  55. this.file = _path2.default.resolve(opts.from);
  56. }
  57. }
  58. var map = new _previousMap2.default(this.css, opts);
  59. if (map.text) {
  60. /**
  61. * @member {PreviousMap} - The input source map passed from
  62. * a compilation step before PostCSS
  63. * (for example, from Sass compiler).
  64. *
  65. * @example
  66. * root.source.input.map.consumer().sources //=> ['a.sass']
  67. */
  68. this.map = map;
  69. var file = map.consumer().file;
  70. if (!this.file && file) this.file = this.mapResolve(file);
  71. }
  72. if (!this.file) {
  73. sequence += 1;
  74. /**
  75. * @member {string} - The unique ID of the CSS source. It will be
  76. * created if `from` option is not provided
  77. * (because PostCSS does not know the file path).
  78. *
  79. * @example
  80. * const root = postcss.parse(css);
  81. * root.source.input.file //=> undefined
  82. * root.source.input.id //=> "<input css 1>"
  83. */
  84. this.id = '<input css ' + sequence + '>';
  85. }
  86. if (this.map) this.map.file = this.from;
  87. }
  88. Input.prototype.error = function error(message, line, column) {
  89. var opts = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
  90. var result = void 0;
  91. var origin = this.origin(line, column);
  92. if (origin) {
  93. result = new _cssSyntaxError2.default(message, origin.line, origin.column, origin.source, origin.file, opts.plugin);
  94. } else {
  95. result = new _cssSyntaxError2.default(message, line, column, this.css, this.file, opts.plugin);
  96. }
  97. result.input = { line: line, column: column, source: this.css };
  98. if (this.file) result.input.file = this.file;
  99. return result;
  100. };
  101. /**
  102. * Reads the input source map and returns a symbol position
  103. * in the input source (e.g., in a Sass file that was compiled
  104. * to CSS before being passed to PostCSS).
  105. *
  106. * @param {number} line - line in input CSS
  107. * @param {number} column - column in input CSS
  108. *
  109. * @return {filePosition} position in input source
  110. *
  111. * @example
  112. * root.source.input.origin(1, 1) //=> { file: 'a.css', line: 3, column: 1 }
  113. */
  114. Input.prototype.origin = function origin(line, column) {
  115. if (!this.map) return false;
  116. var consumer = this.map.consumer();
  117. var from = consumer.originalPositionFor({ line: line, column: column });
  118. if (!from.source) return false;
  119. var result = {
  120. file: this.mapResolve(from.source),
  121. line: from.line,
  122. column: from.column
  123. };
  124. var source = consumer.sourceContentFor(from.source);
  125. if (source) result.source = source;
  126. return result;
  127. };
  128. Input.prototype.mapResolve = function mapResolve(file) {
  129. if (/^\w+:\/\//.test(file)) {
  130. return file;
  131. } else {
  132. return _path2.default.resolve(this.map.consumer().sourceRoot || '.', file);
  133. }
  134. };
  135. /**
  136. * The CSS source identifier. Contains {@link Input#file} if the user
  137. * set the `from` option, or {@link Input#id} if they did not.
  138. * @type {string}
  139. *
  140. * @example
  141. * const root = postcss.parse(css, { from: 'a.css' });
  142. * root.source.input.from //=> "/home/ai/a.css"
  143. *
  144. * const root = postcss.parse(css);
  145. * root.source.input.from //=> "<input css 1>"
  146. */
  147. _createClass(Input, [{
  148. key: 'from',
  149. get: function get() {
  150. return this.file || this.id;
  151. }
  152. }]);
  153. return Input;
  154. }();
  155. exports.default = Input;
  156. /**
  157. * @typedef {object} filePosition
  158. * @property {string} file - path to file
  159. * @property {number} line - source line in file
  160. * @property {number} column - source column in file
  161. */
  162. module.exports = exports['default'];
  163. //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["input.es6"],"names":["sequence","Input","css","opts","toString","Error","slice","from","test","file","path","resolve","map","PreviousMap","text","consumer","mapResolve","id","error","message","line","column","result","origin","CssSyntaxError","source","plugin","input","originalPositionFor","sourceContentFor","sourceRoot"],"mappings":"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","file":"input.js","sourcesContent":["import CssSyntaxError from './css-syntax-error';\nimport PreviousMap    from './previous-map';\n\nimport path from 'path';\n\nlet sequence = 0;\n\n/**\n * Represents the source CSS.\n *\n * @example\n * const root  = postcss.parse(css, { from: file });\n * const input = root.source.input;\n */\nclass Input {\n\n    /**\n     * @param {string} css    - input CSS source\n     * @param {object} [opts] - {@link Processor#process} options\n     */\n    constructor(css, opts = { }) {\n        if ( css === null || typeof css === 'object' && !css.toString ) {\n            throw new Error(`PostCSS received ${ css } instead of CSS string`);\n        }\n\n        /**\n         * @member {string} - input CSS source\n         *\n         * @example\n         * const input = postcss.parse('a{}', { from: file }).input;\n         * input.css //=> \"a{}\";\n         */\n        this.css = css.toString();\n\n        if ( this.css[0] === '\\uFEFF' || this.css[0] === '\\uFFFE' ) {\n            this.css = this.css.slice(1);\n        }\n\n        if ( opts.from ) {\n            if ( /^\\w+:\\/\\//.test(opts.from) ) {\n                /**\n                 * @member {string} - The absolute path to the CSS source file\n                 *                    defined with the `from` option.\n                 *\n                 * @example\n                 * const root = postcss.parse(css, { from: 'a.css' });\n                 * root.source.input.file //=> '/home/ai/a.css'\n                 */\n                this.file = opts.from;\n            } else {\n                this.file = path.resolve(opts.from);\n            }\n        }\n\n        let map = new PreviousMap(this.css, opts);\n        if ( map.text ) {\n            /**\n             * @member {PreviousMap} - The input source map passed from\n             *                         a compilation step before PostCSS\n             *                         (for example, from Sass compiler).\n             *\n             * @example\n             * root.source.input.map.consumer().sources //=> ['a.sass']\n             */\n            this.map = map;\n            let file = map.consumer().file;\n            if ( !this.file && file ) this.file = this.mapResolve(file);\n        }\n\n        if ( !this.file ) {\n            sequence += 1;\n            /**\n             * @member {string} - The unique ID of the CSS source. It will be\n             *                    created if `from` option is not provided\n             *                    (because PostCSS does not know the file path).\n             *\n             * @example\n             * const root = postcss.parse(css);\n             * root.source.input.file //=> undefined\n             * root.source.input.id   //=> \"<input css 1>\"\n             */\n            this.id   = '<input css ' + sequence + '>';\n        }\n        if ( this.map ) this.map.file = this.from;\n    }\n\n    error(message, line, column, opts = { }) {\n        let result;\n        let origin = this.origin(line, column);\n        if ( origin ) {\n            result = new CssSyntaxError(message, origin.line, origin.column,\n                origin.source, origin.file, opts.plugin);\n        } else {\n            result = new CssSyntaxError(message, line, column,\n                this.css, this.file, opts.plugin);\n        }\n\n        result.input = { line, column, source: this.css };\n        if ( this.file ) result.input.file = this.file;\n\n        return result;\n    }\n\n    /**\n     * Reads the input source map and returns a symbol position\n     * in the input source (e.g., in a Sass file that was compiled\n     * to CSS before being passed to PostCSS).\n     *\n     * @param {number} line   - line in input CSS\n     * @param {number} column - column in input CSS\n     *\n     * @return {filePosition} position in input source\n     *\n     * @example\n     * root.source.input.origin(1, 1) //=> { file: 'a.css', line: 3, column: 1 }\n     */\n    origin(line, column) {\n        if ( !this.map ) return false;\n        let consumer = this.map.consumer();\n\n        let from = consumer.originalPositionFor({ line, column });\n        if ( !from.source ) return false;\n\n        let result = {\n            file:   this.mapResolve(from.source),\n            line:   from.line,\n            column: from.column\n        };\n\n        let source = consumer.sourceContentFor(from.source);\n        if ( source ) result.source = source;\n\n        return result;\n    }\n\n    mapResolve(file) {\n        if ( /^\\w+:\\/\\//.test(file) ) {\n            return file;\n        } else {\n            return path.resolve(this.map.consumer().sourceRoot || '.', file);\n        }\n    }\n\n    /**\n     * The CSS source identifier. Contains {@link Input#file} if the user\n     * set the `from` option, or {@link Input#id} if they did not.\n     * @type {string}\n     *\n     * @example\n     * const root = postcss.parse(css, { from: 'a.css' });\n     * root.source.input.from //=> \"/home/ai/a.css\"\n     *\n     * const root = postcss.parse(css);\n     * root.source.input.from //=> \"<input css 1>\"\n     */\n    get from() {\n        return this.file || this.id;\n    }\n\n}\n\nexport default Input;\n\n/**\n * @typedef  {object} filePosition\n * @property {string} file   - path to file\n * @property {number} line   - source line in file\n * @property {number} column - source column in file\n */\n"]}