217 lines
16 KiB
JavaScript
217 lines
16 KiB
JavaScript
|
"use strict";
|
||
|
|
||
|
exports.__esModule = true;
|
||
|
exports.default = void 0;
|
||
|
|
||
|
var _path = _interopRequireDefault(require("path"));
|
||
|
|
||
|
var _cssSyntaxError = _interopRequireDefault(require("./css-syntax-error"));
|
||
|
|
||
|
var _previousMap = _interopRequireDefault(require("./previous-map"));
|
||
|
|
||
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
|
||
|
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); } }
|
||
|
|
||
|
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
|
||
|
|
||
|
var sequence = 0;
|
||
|
/**
|
||
|
* Represents the source CSS.
|
||
|
*
|
||
|
* @example
|
||
|
* const root = postcss.parse(css, { from: file })
|
||
|
* const input = root.source.input
|
||
|
*/
|
||
|
|
||
|
var Input =
|
||
|
/*#__PURE__*/
|
||
|
function () {
|
||
|
/**
|
||
|
* @param {string} css Input CSS source.
|
||
|
* @param {object} [opts] {@link Processor#process} options.
|
||
|
*/
|
||
|
function Input(css, opts) {
|
||
|
if (opts === void 0) {
|
||
|
opts = {};
|
||
|
}
|
||
|
|
||
|
if (css === null || typeof css === 'object' && !css.toString) {
|
||
|
throw new Error("PostCSS received " + css + " instead of CSS string");
|
||
|
}
|
||
|
/**
|
||
|
* Input CSS source
|
||
|
*
|
||
|
* @type {string}
|
||
|
*
|
||
|
* @example
|
||
|
* const input = postcss.parse('a{}', { from: file }).input
|
||
|
* input.css //=> "a{}"
|
||
|
*/
|
||
|
|
||
|
|
||
|
this.css = css.toString();
|
||
|
|
||
|
if (this.css[0] === "\uFEFF" || this.css[0] === "\uFFFE") {
|
||
|
this.hasBOM = true;
|
||
|
this.css = this.css.slice(1);
|
||
|
} else {
|
||
|
this.hasBOM = false;
|
||
|
}
|
||
|
|
||
|
if (opts.from) {
|
||
|
if (/^\w+:\/\//.test(opts.from)) {
|
||
|
/**
|
||
|
* The absolute path to the CSS source file defined
|
||
|
* with the `from` option.
|
||
|
*
|
||
|
* @type {string}
|
||
|
*
|
||
|
* @example
|
||
|
* const root = postcss.parse(css, { from: 'a.css' })
|
||
|
* root.source.input.file //=> '/home/ai/a.css'
|
||
|
*/
|
||
|
this.file = opts.from;
|
||
|
} else {
|
||
|
this.file = _path.default.resolve(opts.from);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
var map = new _previousMap.default(this.css, opts);
|
||
|
|
||
|
if (map.text) {
|
||
|
/**
|
||
|
* The input source map passed from a compilation step before PostCSS
|
||
|
* (for example, from Sass compiler).
|
||
|
*
|
||
|
* @type {PreviousMap}
|
||
|
*
|
||
|
* @example
|
||
|
* root.source.input.map.consumer().sources //=> ['a.sass']
|
||
|
*/
|
||
|
this.map = map;
|
||
|
var file = map.consumer().file;
|
||
|
if (!this.file && file) this.file = this.mapResolve(file);
|
||
|
}
|
||
|
|
||
|
if (!this.file) {
|
||
|
sequence += 1;
|
||
|
/**
|
||
|
* The unique ID of the CSS source. It will be created if `from` option
|
||
|
* is not provided (because PostCSS does not know the file path).
|
||
|
*
|
||
|
* @type {string}
|
||
|
*
|
||
|
* @example
|
||
|
* const root = postcss.parse(css)
|
||
|
* root.source.input.file //=> undefined
|
||
|
* root.source.input.id //=> "<input css 1>"
|
||
|
*/
|
||
|
|
||
|
this.id = '<input css ' + sequence + '>';
|
||
|
}
|
||
|
|
||
|
if (this.map) this.map.file = this.from;
|
||
|
}
|
||
|
|
||
|
var _proto = Input.prototype;
|
||
|
|
||
|
_proto.error = function error(message, line, column, opts) {
|
||
|
if (opts === void 0) {
|
||
|
opts = {};
|
||
|
}
|
||
|
|
||
|
var result;
|
||
|
var origin = this.origin(line, column);
|
||
|
|
||
|
if (origin) {
|
||
|
result = new _cssSyntaxError.default(message, origin.line, origin.column, origin.source, origin.file, opts.plugin);
|
||
|
} else {
|
||
|
result = new _cssSyntaxError.default(message, line, column, this.css, this.file, opts.plugin);
|
||
|
}
|
||
|
|
||
|
result.input = {
|
||
|
line: line,
|
||
|
column: column,
|
||
|
source: this.css
|
||
|
};
|
||
|
if (this.file) result.input.file = this.file;
|
||
|
return result;
|
||
|
}
|
||
|
/**
|
||
|
* Reads the input source map and returns a symbol position
|
||
|
* in the input source (e.g., in a Sass file that was compiled
|
||
|
* to CSS before being passed to PostCSS).
|
||
|
*
|
||
|
* @param {number} line Line in input CSS.
|
||
|
* @param {number} column Column in input CSS.
|
||
|
*
|
||
|
* @return {filePosition} Position in input source.
|
||
|
*
|
||
|
* @example
|
||
|
* root.source.input.origin(1, 1) //=> { file: 'a.css', line: 3, column: 1 }
|
||
|
*/
|
||
|
;
|
||
|
|
||
|
_proto.origin = function origin(line, column) {
|
||
|
if (!this.map) return false;
|
||
|
var consumer = this.map.consumer();
|
||
|
var from = consumer.originalPositionFor({
|
||
|
line: line,
|
||
|
column: column
|
||
|
});
|
||
|
if (!from.source) return false;
|
||
|
var result = {
|
||
|
file: this.mapResolve(from.source),
|
||
|
line: from.line,
|
||
|
column: from.column
|
||
|
};
|
||
|
var source = consumer.sourceContentFor(from.source);
|
||
|
if (source) result.source = source;
|
||
|
return result;
|
||
|
};
|
||
|
|
||
|
_proto.mapResolve = function mapResolve(file) {
|
||
|
if (/^\w+:\/\//.test(file)) {
|
||
|
return file;
|
||
|
}
|
||
|
|
||
|
return _path.default.resolve(this.map.consumer().sourceRoot || '.', file);
|
||
|
}
|
||
|
/**
|
||
|
* The CSS source identifier. Contains {@link Input#file} if the user
|
||
|
* set the `from` option, or {@link Input#id} if they did not.
|
||
|
*
|
||
|
* @type {string}
|
||
|
*
|
||
|
* @example
|
||
|
* const root = postcss.parse(css, { from: 'a.css' })
|
||
|
* root.source.input.from //=> "/home/ai/a.css"
|
||
|
*
|
||
|
* const root = postcss.parse(css)
|
||
|
* root.source.input.from //=> "<input css 1>"
|
||
|
*/
|
||
|
;
|
||
|
|
||
|
_createClass(Input, [{
|
||
|
key: "from",
|
||
|
get: function get() {
|
||
|
return this.file || this.id;
|
||
|
}
|
||
|
}]);
|
||
|
|
||
|
return Input;
|
||
|
}();
|
||
|
|
||
|
var _default = Input;
|
||
|
/**
|
||
|
* @typedef {object} filePosition
|
||
|
* @property {string} file Path to file.
|
||
|
* @property {number} line Source line in file.
|
||
|
* @property {number} column Source column in file.
|
||
|
*/
|
||
|
|
||
|
exports.default = _default;
|
||
|
module.exports = exports.default;
|
||
|
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImlucHV0LmVzNiJdLCJuYW1lcyI6WyJzZXF1ZW5jZSIsIklucHV0IiwiY3NzIiwib3B0cyIsInRvU3RyaW5nIiwiRXJyb3IiLCJoYXNCT00iLCJzbGljZSIsImZyb20iLCJ0ZXN0IiwiZmlsZSIsInBhdGgiLCJyZXNvbHZlIiwibWFwIiwiUHJldmlvdXNNYXAiLCJ0ZXh0IiwiY29uc3VtZXIiLCJtYXBSZXNvbHZlIiwiaWQiLCJlcnJvciIsIm1lc3NhZ2UiLCJsaW5lIiwiY29sdW1uIiwicmVzdWx0Iiwib3JpZ2luIiwiQ3NzU3ludGF4RXJyb3IiLCJzb3VyY2UiLCJwbHVnaW4iLCJpbnB1dCIsIm9yaWdpbmFsUG9zaXRpb25Gb3IiLCJzb3VyY2VDb250ZW50Rm9yIiwic291cmNlUm9vdCJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQTs7QUFFQTs7QUFDQTs7Ozs7Ozs7QUFFQSxJQUFJQSxRQUFRLEdBQUcsQ0FBZjtBQUVBOzs7Ozs7OztJQU9NQyxLOzs7QUFDSjs7OztBQUlBLGlCQUFhQyxHQUFiLEVBQWtCQyxJQUFsQixFQUE4QjtBQUFBLFFBQVpBLElBQVk7QUFBWkEsTUFBQUEsSUFBWSxHQUFMLEVBQUs7QUFBQTs7QUFDNUIsUUFBSUQsR0FBRyxLQUFLLElBQVIsSUFBaUIsT0FBT0EsR0FBUCxLQUFlLFFBQWYsSUFBMkIsQ0FBQ0EsR0FBRyxDQUFDRSxRQUFyRCxFQUFnRTtBQUM5RCxZQUFNLElBQUlDLEtBQUosdUJBQStCSCxHQUEvQiw0QkFBTjtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7O0FBU0EsU0FBS0EsR0FBTCxHQUFXQSxHQUFHLENBQUNFLFFBQUosRUFBWDs7QUFFQSxRQUFJLEtBQUtGLEdBQUwsQ0FBUyxDQUFULE1BQWdCLFFBQWhCLElBQTRCLEtBQUtBLEdBQUwsQ0FBUyxDQUFULE1BQWdCLFFBQWhELEVBQTBEO0FBQ3hELFdBQUtJLE1BQUwsR0FBYyxJQUFkO0FBQ0EsV0FBS0osR0FBTCxHQUFXLEtBQUtBLEdBQUwsQ0FBU0ssS0FBVCxDQUFlLENB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
|