You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
170 lines
18 KiB
170 lines
18 KiB
'use strict'; |
|
|
|
exports.__esModule = true; |
|
|
|
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; }; |
|
|
|
var _sourceMap = require('source-map'); |
|
|
|
var _sourceMap2 = _interopRequireDefault(_sourceMap); |
|
|
|
var _path = require('path'); |
|
|
|
var _path2 = _interopRequireDefault(_path); |
|
|
|
var _fs = require('fs'); |
|
|
|
var _fs2 = _interopRequireDefault(_fs); |
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } |
|
|
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } |
|
|
|
function fromBase64(str) { |
|
if (Buffer) { |
|
if (Buffer.from && Buffer.from !== Uint8Array.from) { |
|
return Buffer.from(str, 'base64').toString(); |
|
} else { |
|
return new Buffer(str, 'base64').toString(); |
|
} |
|
} else { |
|
return window.atob(str); |
|
} |
|
} |
|
|
|
/** |
|
* Source map information from input CSS. |
|
* For example, source map after Sass compiler. |
|
* |
|
* This class will automatically find source map in input CSS or in file system |
|
* near input file (according `from` option). |
|
* |
|
* @example |
|
* const root = postcss.parse(css, { from: 'a.sass.css' }); |
|
* root.input.map //=> PreviousMap |
|
*/ |
|
|
|
var PreviousMap = function () { |
|
|
|
/** |
|
* @param {string} css - input CSS source |
|
* @param {processOptions} [opts] - {@link Processor#process} options |
|
*/ |
|
function PreviousMap(css, opts) { |
|
_classCallCheck(this, PreviousMap); |
|
|
|
this.loadAnnotation(css); |
|
/** |
|
* @member {boolean} - Was source map inlined by data-uri to input CSS. |
|
*/ |
|
this.inline = this.startWith(this.annotation, 'data:'); |
|
|
|
var prev = opts.map ? opts.map.prev : undefined; |
|
var text = this.loadMap(opts.from, prev); |
|
if (text) this.text = text; |
|
} |
|
|
|
/** |
|
* Create a instance of `SourceMapGenerator` class |
|
* from the `source-map` library to work with source map information. |
|
* |
|
* It is lazy method, so it will create object only on first call |
|
* and then it will use cache. |
|
* |
|
* @return {SourceMapGenerator} object with source map information |
|
*/ |
|
|
|
|
|
PreviousMap.prototype.consumer = function consumer() { |
|
if (!this.consumerCache) { |
|
this.consumerCache = new _sourceMap2.default.SourceMapConsumer(this.text); |
|
} |
|
return this.consumerCache; |
|
}; |
|
|
|
/** |
|
* Does source map contains `sourcesContent` with input source text. |
|
* |
|
* @return {boolean} Is `sourcesContent` present |
|
*/ |
|
|
|
|
|
PreviousMap.prototype.withContent = function withContent() { |
|
return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); |
|
}; |
|
|
|
PreviousMap.prototype.startWith = function startWith(string, start) { |
|
if (!string) return false; |
|
return string.substr(0, start.length) === start; |
|
}; |
|
|
|
PreviousMap.prototype.loadAnnotation = function loadAnnotation(css) { |
|
var match = css.match(/\/\*\s*# sourceMappingURL=(.*)\s*\*\//); |
|
if (match) this.annotation = match[1].trim(); |
|
}; |
|
|
|
PreviousMap.prototype.decodeInline = function decodeInline(text) { |
|
// data:application/json;charset=utf-8;base64, |
|
// data:application/json;charset=utf8;base64, |
|
// data:application/json;base64, |
|
var baseUri = /^data:application\/json;(?:charset=utf-?8;)?base64,/; |
|
var uri = 'data:application/json,'; |
|
|
|
if (this.startWith(text, uri)) { |
|
return decodeURIComponent(text.substr(uri.length)); |
|
} else if (baseUri.test(text)) { |
|
return fromBase64(text.substr(RegExp.lastMatch.length)); |
|
} else { |
|
var encoding = text.match(/data:application\/json;([^,]+),/)[1]; |
|
throw new Error('Unsupported source map encoding ' + encoding); |
|
} |
|
}; |
|
|
|
PreviousMap.prototype.loadMap = function loadMap(file, prev) { |
|
if (prev === false) return false; |
|
|
|
if (prev) { |
|
if (typeof prev === 'string') { |
|
return prev; |
|
} else if (typeof prev === 'function') { |
|
var prevPath = prev(file); |
|
if (prevPath && _fs2.default.existsSync && _fs2.default.existsSync(prevPath)) { |
|
return _fs2.default.readFileSync(prevPath, 'utf-8').toString().trim(); |
|
} else { |
|
throw new Error('Unable to load previous source map: ' + prevPath.toString()); |
|
} |
|
} else if (prev instanceof _sourceMap2.default.SourceMapConsumer) { |
|
return _sourceMap2.default.SourceMapGenerator.fromSourceMap(prev).toString(); |
|
} else if (prev instanceof _sourceMap2.default.SourceMapGenerator) { |
|
return prev.toString(); |
|
} else if (this.isMap(prev)) { |
|
return JSON.stringify(prev); |
|
} else { |
|
throw new Error('Unsupported previous source map format: ' + prev.toString()); |
|
} |
|
} else if (this.inline) { |
|
return this.decodeInline(this.annotation); |
|
} else if (this.annotation) { |
|
var map = this.annotation; |
|
if (file) map = _path2.default.join(_path2.default.dirname(file), map); |
|
|
|
this.root = _path2.default.dirname(map); |
|
if (_fs2.default.existsSync && _fs2.default.existsSync(map)) { |
|
return _fs2.default.readFileSync(map, 'utf-8').toString().trim(); |
|
} else { |
|
return false; |
|
} |
|
} |
|
}; |
|
|
|
PreviousMap.prototype.isMap = function isMap(map) { |
|
if ((typeof map === 'undefined' ? 'undefined' : _typeof(map)) !== 'object') return false; |
|
return typeof map.mappings === 'string' || typeof map._mappings === 'string'; |
|
}; |
|
|
|
return PreviousMap; |
|
}(); |
|
|
|
exports.default = PreviousMap; |
|
module.exports = exports['default']; |
|
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["previous-map.es6"],"names":["fromBase64","str","Buffer","from","Uint8Array","toString","window","atob","PreviousMap","css","opts","loadAnnotation","inline","startWith","annotation","prev","map","undefined","text","loadMap","consumer","consumerCache","mozilla","SourceMapConsumer","withContent","sourcesContent","length","string","start","substr","match","trim","decodeInline","baseUri","uri","decodeURIComponent","test","RegExp","lastMatch","encoding","Error","file","prevPath","fs","existsSync","readFileSync","SourceMapGenerator","fromSourceMap","isMap","JSON","stringify","path","join","dirname","root","mappings","_mappings"],"mappings":"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","file":"previous-map.js","sourcesContent":["import mozilla  from 'source-map';\nimport path     from 'path';\nimport fs       from 'fs';\n\nfunction fromBase64(str) {\n    if ( Buffer ) {\n        if ( Buffer.from && Buffer.from !== Uint8Array.from ) {\n            return Buffer.from(str, 'base64').toString();\n        } else {\n            return new Buffer(str, 'base64').toString();\n        }\n    } else {\n        return window.atob(str);\n    }\n}\n\n/**\n * Source map information from input CSS.\n * For example, source map after Sass compiler.\n *\n * This class will automatically find source map in input CSS or in file system\n * near input file (according `from` option).\n *\n * @example\n * const root = postcss.parse(css, { from: 'a.sass.css' });\n * root.input.map //=> PreviousMap\n */\nclass PreviousMap {\n\n    /**\n     * @param {string}         css    - input CSS source\n     * @param {processOptions} [opts] - {@link Processor#process} options\n     */\n    constructor(css, opts) {\n        this.loadAnnotation(css);\n        /**\n         * @member {boolean} - Was source map inlined by data-uri to input CSS.\n         */\n        this.inline = this.startWith(this.annotation, 'data:');\n\n        let prev = opts.map ? opts.map.prev : undefined;\n        let text = this.loadMap(opts.from, prev);\n        if ( text ) this.text = text;\n    }\n\n    /**\n     * Create a instance of `SourceMapGenerator` class\n     * from the `source-map` library to work with source map information.\n     *\n     * It is lazy method, so it will create object only on first call\n     * and then it will use cache.\n     *\n     * @return {SourceMapGenerator} object with source map information\n     */\n    consumer() {\n        if ( !this.consumerCache ) {\n            this.consumerCache = new mozilla.SourceMapConsumer(this.text);\n        }\n        return this.consumerCache;\n    }\n\n    /**\n     * Does source map contains `sourcesContent` with input source text.\n     *\n     * @return {boolean} Is `sourcesContent` present\n     */\n    withContent() {\n        return !!(this.consumer().sourcesContent &&\n                  this.consumer().sourcesContent.length > 0);\n    }\n\n    startWith(string, start) {\n        if ( !string ) return false;\n        return string.substr(0, start.length) === start;\n    }\n\n    loadAnnotation(css) {\n        let match = css.match(/\\/\\*\\s*# sourceMappingURL=(.*)\\s*\\*\\//);\n        if ( match ) this.annotation = match[1].trim();\n    }\n\n    decodeInline(text) {\n        // data:application/json;charset=utf-8;base64,\n        // data:application/json;charset=utf8;base64,\n        // data:application/json;base64,\n        let baseUri = /^data:application\\/json;(?:charset=utf-?8;)?base64,/;\n        let uri     = 'data:application/json,';\n\n        if ( this.startWith(text, uri) ) {\n            return decodeURIComponent( text.substr(uri.length) );\n\n        } else if ( baseUri.test(text) ) {\n            return fromBase64(text.substr(RegExp.lastMatch.length));\n\n        } else {\n            let encoding = text.match(/data:application\\/json;([^,]+),/)[1];\n            throw new Error('Unsupported source map encoding ' + encoding);\n        }\n    }\n\n    loadMap(file, prev) {\n        if ( prev === false ) return false;\n\n        if ( prev ) {\n            if ( typeof prev === 'string' ) {\n                return prev;\n            } else if ( typeof prev === 'function' ) {\n                let prevPath = prev(file);\n                if ( prevPath && fs.existsSync && fs.existsSync(prevPath) ) {\n                    return fs.readFileSync(prevPath, 'utf-8').toString().trim();\n                } else {\n                    throw new Error('Unable to load previous source map: ' +\n                    prevPath.toString());\n                }\n            } else if ( prev instanceof mozilla.SourceMapConsumer ) {\n                return mozilla.SourceMapGenerator\n                    .fromSourceMap(prev).toString();\n            } else if ( prev instanceof mozilla.SourceMapGenerator ) {\n                return prev.toString();\n            } else if ( this.isMap(prev) ) {\n                return JSON.stringify(prev);\n            } else {\n                throw new Error('Unsupported previous source map format: ' +\n                    prev.toString());\n            }\n\n        } else if ( this.inline ) {\n            return this.decodeInline(this.annotation);\n\n        } else if ( this.annotation ) {\n            let map = this.annotation;\n            if ( file ) map = path.join(path.dirname(file), map);\n\n            this.root = path.dirname(map);\n            if ( fs.existsSync && fs.existsSync(map) ) {\n                return fs.readFileSync(map, 'utf-8').toString().trim();\n            } else {\n                return false;\n            }\n        }\n    }\n\n    isMap(map) {\n        if ( typeof map !== 'object' ) return false;\n        return typeof map.mappings === 'string' ||\n               typeof map._mappings === 'string';\n    }\n}\n\nexport default PreviousMap;\n"]}
|
|
|