postcss 7.0.1 → 7.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of postcss might be problematic. Click here for more details.
- package/CHANGELOG.md +14 -1
- package/docs/architecture.md +5 -5
- package/docs/guidelines/plugin.md +10 -10
- package/docs/guidelines/runner.md +2 -2
- package/lib/at-rule.js +21 -23
- package/lib/comment.js +15 -19
- package/lib/container.js +195 -205
- package/lib/css-syntax-error.js +42 -39
- package/lib/declaration.js +15 -19
- package/lib/input.js +53 -50
- package/lib/lazy-result.js +58 -76
- package/lib/list.js +8 -10
- package/lib/map-generator.js +110 -80
- package/lib/node.js +84 -89
- package/lib/parse.js +12 -12
- package/lib/parser.js +162 -104
- package/lib/postcss.d.ts +1 -1
- package/lib/postcss.js +43 -54
- package/lib/previous-map.js +42 -46
- package/lib/processor.js +32 -30
- package/lib/result.js +29 -26
- package/lib/root.js +24 -25
- package/lib/rule.js +20 -25
- package/lib/stringifier.js +72 -53
- package/lib/stringify.js +8 -8
- package/lib/terminal-highlight.js +30 -29
- package/lib/tokenize.js +57 -73
- package/lib/vendor.js +10 -9
- package/lib/warn-once.js +4 -3
- package/lib/warning.js +24 -17
- package/package.json +4 -3
- package/README-cn.md +0 -349
- package/gulpfile.js +0 -101
package/lib/postcss.d.ts
CHANGED
@@ -411,7 +411,7 @@ declare namespace postcss {
|
|
411
411
|
/**
|
412
412
|
* Applies a SourceMap for a source file to the SourceMap. Each mapping to
|
413
413
|
* the supplied source file is rewritten using the supplied SourceMap.
|
414
|
-
* Note: The resolution for the resulting mappings is the
|
414
|
+
* Note: The resolution for the resulting mappings is the minimum of this
|
415
415
|
* map and the supplied map.
|
416
416
|
* @param sourceMapConsumer The SourceMap to be applied.
|
417
417
|
* @param sourceFile The filename of the source file. If omitted, sourceMapConsumer
|
package/lib/postcss.js
CHANGED
@@ -1,46 +1,27 @@
|
|
1
|
-
|
1
|
+
"use strict";
|
2
2
|
|
3
3
|
exports.__esModule = true;
|
4
|
+
exports.default = void 0;
|
4
5
|
|
5
|
-
var _declaration = require(
|
6
|
+
var _declaration = _interopRequireDefault(require("./declaration"));
|
6
7
|
|
7
|
-
var
|
8
|
+
var _processor = _interopRequireDefault(require("./processor"));
|
8
9
|
|
9
|
-
var
|
10
|
+
var _stringify = _interopRequireDefault(require("./stringify"));
|
10
11
|
|
11
|
-
var
|
12
|
+
var _comment = _interopRequireDefault(require("./comment"));
|
12
13
|
|
13
|
-
var
|
14
|
+
var _atRule = _interopRequireDefault(require("./at-rule"));
|
14
15
|
|
15
|
-
var
|
16
|
+
var _vendor = _interopRequireDefault(require("./vendor"));
|
16
17
|
|
17
|
-
var
|
18
|
+
var _parse = _interopRequireDefault(require("./parse"));
|
18
19
|
|
19
|
-
var
|
20
|
+
var _list = _interopRequireDefault(require("./list"));
|
20
21
|
|
21
|
-
var
|
22
|
+
var _rule = _interopRequireDefault(require("./rule"));
|
22
23
|
|
23
|
-
var
|
24
|
-
|
25
|
-
var _vendor = require('./vendor');
|
26
|
-
|
27
|
-
var _vendor2 = _interopRequireDefault(_vendor);
|
28
|
-
|
29
|
-
var _parse = require('./parse');
|
30
|
-
|
31
|
-
var _parse2 = _interopRequireDefault(_parse);
|
32
|
-
|
33
|
-
var _list = require('./list');
|
34
|
-
|
35
|
-
var _list2 = _interopRequireDefault(_list);
|
36
|
-
|
37
|
-
var _rule = require('./rule');
|
38
|
-
|
39
|
-
var _rule2 = _interopRequireDefault(_rule);
|
40
|
-
|
41
|
-
var _root = require('./root');
|
42
|
-
|
43
|
-
var _root2 = _interopRequireDefault(_root);
|
24
|
+
var _root = _interopRequireDefault(require("./root"));
|
44
25
|
|
45
26
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
46
27
|
|
@@ -63,16 +44,16 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
63
44
|
* @namespace postcss
|
64
45
|
*/
|
65
46
|
function postcss() {
|
66
|
-
for (var _len = arguments.length, plugins = Array(_len), _key = 0; _key < _len; _key++) {
|
47
|
+
for (var _len = arguments.length, plugins = new Array(_len), _key = 0; _key < _len; _key++) {
|
67
48
|
plugins[_key] = arguments[_key];
|
68
49
|
}
|
69
50
|
|
70
51
|
if (plugins.length === 1 && Array.isArray(plugins[0])) {
|
71
52
|
plugins = plugins[0];
|
72
53
|
}
|
73
|
-
return new _processor2.default(plugins);
|
74
|
-
}
|
75
54
|
|
55
|
+
return new _processor.default(plugins);
|
56
|
+
}
|
76
57
|
/**
|
77
58
|
* Creates a PostCSS plugin with a standard API.
|
78
59
|
*
|
@@ -145,15 +126,17 @@ function postcss() {
|
|
145
126
|
*
|
146
127
|
* @return {Plugin} PostCSS plugin.
|
147
128
|
*/
|
129
|
+
|
130
|
+
|
148
131
|
postcss.plugin = function plugin(name, initializer) {
|
149
132
|
function creator() {
|
150
|
-
var transformer = initializer.apply(
|
133
|
+
var transformer = initializer.apply(void 0, arguments);
|
151
134
|
transformer.postcssPlugin = name;
|
152
|
-
transformer.postcssVersion = new
|
135
|
+
transformer.postcssVersion = new _processor.default().version;
|
153
136
|
return transformer;
|
154
137
|
}
|
155
138
|
|
156
|
-
var cache
|
139
|
+
var cache;
|
157
140
|
Object.defineProperty(creator, 'postcss', {
|
158
141
|
get: function get() {
|
159
142
|
if (!cache) cache = creator();
|
@@ -167,7 +150,6 @@ postcss.plugin = function plugin(name, initializer) {
|
|
167
150
|
|
168
151
|
return creator;
|
169
152
|
};
|
170
|
-
|
171
153
|
/**
|
172
154
|
* Default function to convert a node tree into a CSS string.
|
173
155
|
*
|
@@ -179,8 +161,9 @@ postcss.plugin = function plugin(name, initializer) {
|
|
179
161
|
*
|
180
162
|
* @function
|
181
163
|
*/
|
182
|
-
postcss.stringify = _stringify2.default;
|
183
164
|
|
165
|
+
|
166
|
+
postcss.stringify = _stringify.default;
|
184
167
|
/**
|
185
168
|
* Parses source css and returns a new {@link Root} node,
|
186
169
|
* which contains the source CSS nodes.
|
@@ -199,8 +182,8 @@ postcss.stringify = _stringify2.default;
|
|
199
182
|
*
|
200
183
|
* @function
|
201
184
|
*/
|
202
|
-
postcss.parse = _parse2.default;
|
203
185
|
|
186
|
+
postcss.parse = _parse.default;
|
204
187
|
/**
|
205
188
|
* Contains the {@link vendor} module.
|
206
189
|
*
|
@@ -209,8 +192,8 @@ postcss.parse = _parse2.default;
|
|
209
192
|
* @example
|
210
193
|
* postcss.vendor.unprefixed('-moz-tab') //=> ['tab']
|
211
194
|
*/
|
212
|
-
postcss.vendor = _vendor2.default;
|
213
195
|
|
196
|
+
postcss.vendor = _vendor.default;
|
214
197
|
/**
|
215
198
|
* Contains the {@link list} module.
|
216
199
|
*
|
@@ -219,8 +202,8 @@ postcss.vendor = _vendor2.default;
|
|
219
202
|
* @example
|
220
203
|
* postcss.list.space('5px calc(10% + 5px)') //=> ['5px', 'calc(10% + 5px)']
|
221
204
|
*/
|
222
|
-
postcss.list = _list2.default;
|
223
205
|
|
206
|
+
postcss.list = _list.default;
|
224
207
|
/**
|
225
208
|
* Creates a new {@link Comment} node.
|
226
209
|
*
|
@@ -231,10 +214,10 @@ postcss.list = _list2.default;
|
|
231
214
|
* @example
|
232
215
|
* postcss.comment({ text: 'test' })
|
233
216
|
*/
|
217
|
+
|
234
218
|
postcss.comment = function (defaults) {
|
235
|
-
return new
|
219
|
+
return new _comment.default(defaults);
|
236
220
|
};
|
237
|
-
|
238
221
|
/**
|
239
222
|
* Creates a new {@link AtRule} node.
|
240
223
|
*
|
@@ -245,10 +228,11 @@ postcss.comment = function (defaults) {
|
|
245
228
|
* @example
|
246
229
|
* postcss.atRule({ name: 'charset' }).toString() //=> "@charset"
|
247
230
|
*/
|
231
|
+
|
232
|
+
|
248
233
|
postcss.atRule = function (defaults) {
|
249
|
-
return new
|
234
|
+
return new _atRule.default(defaults);
|
250
235
|
};
|
251
|
-
|
252
236
|
/**
|
253
237
|
* Creates a new {@link Declaration} node.
|
254
238
|
*
|
@@ -259,10 +243,11 @@ postcss.atRule = function (defaults) {
|
|
259
243
|
* @example
|
260
244
|
* postcss.decl({ prop: 'color', value: 'red' }).toString() //=> "color: red"
|
261
245
|
*/
|
246
|
+
|
247
|
+
|
262
248
|
postcss.decl = function (defaults) {
|
263
|
-
return new
|
249
|
+
return new _declaration.default(defaults);
|
264
250
|
};
|
265
|
-
|
266
251
|
/**
|
267
252
|
* Creates a new {@link Rule} node.
|
268
253
|
*
|
@@ -273,10 +258,11 @@ postcss.decl = function (defaults) {
|
|
273
258
|
* @example
|
274
259
|
* postcss.rule({ selector: 'a' }).toString() //=> "a {\n}"
|
275
260
|
*/
|
261
|
+
|
262
|
+
|
276
263
|
postcss.rule = function (defaults) {
|
277
|
-
return new
|
264
|
+
return new _rule.default(defaults);
|
278
265
|
};
|
279
|
-
|
280
266
|
/**
|
281
267
|
* Creates a new {@link Root} node.
|
282
268
|
*
|
@@ -287,10 +273,13 @@ postcss.rule = function (defaults) {
|
|
287
273
|
* @example
|
288
274
|
* postcss.root({ after: '\n' }).toString() //=> "\n"
|
289
275
|
*/
|
276
|
+
|
277
|
+
|
290
278
|
postcss.root = function (defaults) {
|
291
|
-
return new
|
279
|
+
return new _root.default(defaults);
|
292
280
|
};
|
293
281
|
|
294
|
-
|
295
|
-
|
296
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["postcss.es6"],"names":["postcss","plugins","length","Array","isArray","Processor","plugin","name","initializer","creator","transformer","postcssPlugin","postcssVersion","version","cache","Object","defineProperty","get","process","css","processOpts","pluginOpts","stringify","parse","vendor","list","comment","Comment","defaults","atRule","AtRule","decl","Declaration","rule","Rule","root","Root"],"mappings":";;;;AAAA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;;;AAEA;;;;;;;;;;;;;;;;;;AAkBA,SAASA,OAAT,GAA8B;AAAA,oCAATC,OAAS;AAATA,WAAS;AAAA;;AAC5B,MAAIA,QAAQC,MAAR,KAAmB,CAAnB,IAAwBC,MAAMC,OAAN,CAAcH,QAAQ,CAAR,CAAd,CAA5B,EAAuD;AACrDA,cAAUA,QAAQ,CAAR,CAAV;AACD;AACD,SAAO,IAAII,mBAAJ,CAAcJ,OAAd,CAAP;AACD;;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwEAD,QAAQM,MAAR,GAAiB,SAASA,MAAT,CAAiBC,IAAjB,EAAuBC,WAAvB,EAAoC;AACnD,WAASC,OAAT,GAA2B;AACzB,QAAMC,cAAcF,uCAApB;AACAE,gBAAYC,aAAZ,GAA4BJ,IAA5B;AACAG,gBAAYE,cAAZ,GAA8B,IAAIP,mBAAJ,EAAD,CAAkBQ,OAA/C;AACA,WAAOH,WAAP;AACD;;AAED,MAAII,cAAJ;AACAC,SAAOC,cAAP,CAAsBP,OAAtB,EAA+B,SAA/B,EAA0C;AACxCQ,OADwC,iBACjC;AACL,UAAI,CAACH,KAAL,EAAYA,QAAQL,SAAR;AACZ,aAAOK,KAAP;AACD;AAJuC,GAA1C;;AAOAL,UAAQS,OAAR,GAAkB,UAAUC,GAAV,EAAeC,WAAf,EAA4BC,UAA5B,EAAwC;AACxD,WAAOrB,QAAQ,CAACS,QAAQY,UAAR,CAAD,CAAR,EAA+BH,OAA/B,CAAuCC,GAAvC,EAA4CC,WAA5C,CAAP;AACD,GAFD;;AAIA,SAAOX,OAAP;AACD,CArBD;;AAuBA;;;;;;;;;;;AAWAT,QAAQsB,SAAR,GAAoBA,mBAApB;;AAEA;;;;;;;;;;;;;;;;;;AAkBAtB,QAAQuB,KAAR,GAAgBA,eAAhB;;AAEA;;;;;;;;AAQAvB,QAAQwB,MAAR,GAAiBA,gBAAjB;;AAEA;;;;;;;;AAQAxB,QAAQyB,IAAR,GAAeA,cAAf;;AAEA;;;;;;;;;;AAUAzB,QAAQ0B,OAAR,GAAkB;AAAA,SAAY,IAAIC,iBAAJ,CAAYC,QAAZ,CAAZ;AAAA,CAAlB;;AAEA;;;;;;;;;;AAUA5B,QAAQ6B,MAAR,GAAiB;AAAA,SAAY,IAAIC,gBAAJ,CAAWF,QAAX,CAAZ;AAAA,CAAjB;;AAEA;;;;;;;;;;AAUA5B,QAAQ+B,IAAR,GAAe;AAAA,SAAY,IAAIC,qBAAJ,CAAgBJ,QAAhB,CAAZ;AAAA,CAAf;;AAEA;;;;;;;;;;AAUA5B,QAAQiC,IAAR,GAAe;AAAA,SAAY,IAAIC,cAAJ,CAASN,QAAT,CAAZ;AAAA,CAAf;;AAEA;;;;;;;;;;AAUA5B,QAAQmC,IAAR,GAAe;AAAA,SAAY,IAAIC,cAAJ,CAASR,QAAT,CAAZ;AAAA,CAAf;;kBAEe5B,O","file":"postcss.js","sourcesContent":["import Declaration from './declaration'\nimport Processor from './processor'\nimport stringify from './stringify'\nimport Comment from './comment'\nimport AtRule from './at-rule'\nimport vendor from './vendor'\nimport parse from './parse'\nimport list from './list'\nimport Rule from './rule'\nimport Root from './root'\n\n/**\n * Create a new {@link Processor} instance that will apply `plugins`\n * as CSS processors.\n *\n * @param {Array.<Plugin|pluginFunction>|Processor} plugins PostCSS plugins.\n *        See {@link Processor#use} for plugin format.\n *\n * @return {Processor} Processor to process multiple CSS.\n *\n * @example\n * import postcss from 'postcss'\n *\n * postcss(plugins).process(css, { from, to }).then(result => {\n *   console.log(result.css)\n * })\n *\n * @namespace postcss\n */\nfunction postcss (...plugins) {\n  if (plugins.length === 1 && Array.isArray(plugins[0])) {\n    plugins = plugins[0]\n  }\n  return new Processor(plugins)\n}\n\n/**\n * Creates a PostCSS plugin with a standard API.\n *\n * The newly-wrapped function will provide both the name and PostCSS\n * version of the plugin.\n *\n * ```js\n * const processor = postcss([replace])\n * processor.plugins[0].postcssPlugin  //=> 'postcss-replace'\n * processor.plugins[0].postcssVersion //=> '6.0.0'\n * ```\n *\n * The plugin function receives 2 arguments: {@link Root}\n * and {@link Result} instance. The function should mutate the provided\n * `Root` node. Alternatively, you can create a new `Root` node\n * and override the `result.root` property.\n *\n * ```js\n * const cleaner = postcss.plugin('postcss-cleaner', () => {\n *   return (root, result) => {\n *     result.root = postcss.root()\n *   }\n * })\n * ```\n *\n * As a convenience, plugins also expose a `process` method so that you can use\n * them as standalone tools.\n *\n * ```js\n * cleaner.process(css, processOpts, pluginOpts)\n * // This is equivalent to:\n * postcss([ cleaner(pluginOpts) ]).process(css, processOpts)\n * ```\n *\n * Asynchronous plugins should return a `Promise` instance.\n *\n * ```js\n * postcss.plugin('postcss-import', () => {\n *   return (root, result) => {\n *     return new Promise( (resolve, reject) => {\n *       fs.readFile('base.css', (base) => {\n *         root.prepend(base)\n *         resolve()\n *       })\n *     })\n *   }\n * })\n * ```\n *\n * Add warnings using the {@link Node#warn} method.\n * Send data to other plugins using the {@link Result#messages} array.\n *\n * ```js\n * postcss.plugin('postcss-caniuse-test', () => {\n *   return (root, result) => {\n *     root.walkDecls(decl => {\n *       if (!caniuse.support(decl.prop)) {\n *         decl.warn(result, 'Some browsers do not support ' + decl.prop)\n *       }\n *     })\n *   }\n * })\n * ```\n *\n * @param {string} name          PostCSS plugin name. Same as in `name`\n *                               property in `package.json`. It will be saved\n *                               in `plugin.postcssPlugin` property.\n * @param {function} initializer Will receive plugin options\n *                               and should return {@link pluginFunction}\n *\n * @return {Plugin} PostCSS plugin.\n */\npostcss.plugin = function plugin (name, initializer) {\n  function creator (...args) {\n    const transformer = initializer(...args)\n    transformer.postcssPlugin = name\n    transformer.postcssVersion = (new Processor()).version\n    return transformer\n  }\n\n  let cache\n  Object.defineProperty(creator, 'postcss', {\n    get () {\n      if (!cache) cache = creator()\n      return cache\n    }\n  })\n\n  creator.process = function (css, processOpts, pluginOpts) {\n    return postcss([creator(pluginOpts)]).process(css, processOpts)\n  }\n\n  return creator\n}\n\n/**\n * Default function to convert a node tree into a CSS string.\n *\n * @param {Node} node       Start node for stringifing. Usually {@link Root}.\n * @param {builder} builder Function to concatenate CSS from node’s parts\n *                          or generate string and source map.\n *\n * @return {void}\n *\n * @function\n */\npostcss.stringify = stringify\n\n/**\n * Parses source css and returns a new {@link Root} node,\n * which contains the source CSS nodes.\n *\n * @param {string|toString} css   String with input CSS or any object\n *                                with toString() method, like a Buffer\n * @param {processOptions} [opts] Options with only `from` and `map` keys.\n *\n * @return {Root} PostCSS AST.\n *\n * @example\n * // Simple CSS concatenation with source map support\n * const root1 = postcss.parse(css1, { from: file1 })\n * const root2 = postcss.parse(css2, { from: file2 })\n * root1.append(root2).toResult().css\n *\n * @function\n */\npostcss.parse = parse\n\n/**\n * Contains the {@link vendor} module.\n *\n * @type {vendor}\n *\n * @example\n * postcss.vendor.unprefixed('-moz-tab') //=> ['tab']\n */\npostcss.vendor = vendor\n\n/**\n * Contains the {@link list} module.\n *\n * @member {list}\n *\n * @example\n * postcss.list.space('5px calc(10% + 5px)') //=> ['5px', 'calc(10% + 5px)']\n */\npostcss.list = list\n\n/**\n * Creates a new {@link Comment} node.\n *\n * @param {object} [defaults] Properties for the new node.\n *\n * @return {Comment} New comment node\n *\n * @example\n * postcss.comment({ text: 'test' })\n */\npostcss.comment = defaults => new Comment(defaults)\n\n/**\n * Creates a new {@link AtRule} node.\n *\n * @param {object} [defaults] Properties for the new node.\n *\n * @return {AtRule} new at-rule node\n *\n * @example\n * postcss.atRule({ name: 'charset' }).toString() //=> \"@charset\"\n */\npostcss.atRule = defaults => new AtRule(defaults)\n\n/**\n * Creates a new {@link Declaration} node.\n *\n * @param {object} [defaults] Properties for the new node.\n *\n * @return {Declaration} new declaration node\n *\n * @example\n * postcss.decl({ prop: 'color', value: 'red' }).toString() //=> \"color: red\"\n */\npostcss.decl = defaults => new Declaration(defaults)\n\n/**\n * Creates a new {@link Rule} node.\n *\n * @param {object} [defaults] Properties for the new node.\n *\n * @return {Rule} new rule node\n *\n * @example\n * postcss.rule({ selector: 'a' }).toString() //=> \"a {\\n}\"\n */\npostcss.rule = defaults => new Rule(defaults)\n\n/**\n * Creates a new {@link Root} node.\n *\n * @param {object} [defaults] Properties for the new node.\n *\n * @return {Root} new root node.\n *\n * @example\n * postcss.root({ after: '\\n' }).toString() //=> \"\\n\"\n */\npostcss.root = defaults => new Root(defaults)\n\nexport default postcss\n"]}
|
282
|
+
var _default = postcss;
|
283
|
+
exports.default = _default;
|
284
|
+
module.exports = exports.default;
|
285
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["postcss.es6"],"names":["postcss","plugins","length","Array","isArray","Processor","plugin","name","initializer","creator","transformer","postcssPlugin","postcssVersion","version","cache","Object","defineProperty","get","process","css","processOpts","pluginOpts","stringify","parse","vendor","list","comment","defaults","Comment","atRule","AtRule","decl","Declaration","rule","Rule","root","Root"],"mappings":";;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAEA;;;;;;;;;;;;;;;;;;AAkBA,SAASA,OAAT,GAA8B;AAAA,oCAATC,OAAS;AAATA,IAAAA,OAAS;AAAA;;AAC5B,MAAIA,OAAO,CAACC,MAAR,KAAmB,CAAnB,IAAwBC,KAAK,CAACC,OAAN,CAAcH,OAAO,CAAC,CAAD,CAArB,CAA5B,EAAuD;AACrDA,IAAAA,OAAO,GAAGA,OAAO,CAAC,CAAD,CAAjB;AACD;;AACD,SAAO,IAAII,kBAAJ,CAAcJ,OAAd,CAAP;AACD;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwEAD,OAAO,CAACM,MAAR,GAAiB,SAASA,MAAT,CAAiBC,IAAjB,EAAuBC,WAAvB,EAAoC;AACnD,WAASC,OAAT,GAA2B;AACzB,QAAIC,WAAW,GAAGF,WAAW,MAAX,mBAAlB;AACAE,IAAAA,WAAW,CAACC,aAAZ,GAA4BJ,IAA5B;AACAG,IAAAA,WAAW,CAACE,cAAZ,GAA8B,IAAIP,kBAAJ,EAAD,CAAkBQ,OAA/C;AACA,WAAOH,WAAP;AACD;;AAED,MAAII,KAAJ;AACAC,EAAAA,MAAM,CAACC,cAAP,CAAsBP,OAAtB,EAA+B,SAA/B,EAA0C;AACxCQ,IAAAA,GADwC,iBACjC;AACL,UAAI,CAACH,KAAL,EAAYA,KAAK,GAAGL,OAAO,EAAf;AACZ,aAAOK,KAAP;AACD;AAJuC,GAA1C;;AAOAL,EAAAA,OAAO,CAACS,OAAR,GAAkB,UAAUC,GAAV,EAAeC,WAAf,EAA4BC,UAA5B,EAAwC;AACxD,WAAOrB,OAAO,CAAC,CAACS,OAAO,CAACY,UAAD,CAAR,CAAD,CAAP,CAA+BH,OAA/B,CAAuCC,GAAvC,EAA4CC,WAA5C,CAAP;AACD,GAFD;;AAIA,SAAOX,OAAP;AACD,CArBD;AAuBA;;;;;;;;;;;;;AAWAT,OAAO,CAACsB,SAAR,GAAoBA,kBAApB;AAEA;;;;;;;;;;;;;;;;;;;AAkBAtB,OAAO,CAACuB,KAAR,GAAgBA,cAAhB;AAEA;;;;;;;;;AAQAvB,OAAO,CAACwB,MAAR,GAAiBA,eAAjB;AAEA;;;;;;;;;AAQAxB,OAAO,CAACyB,IAAR,GAAeA,aAAf;AAEA;;;;;;;;;;;AAUAzB,OAAO,CAAC0B,OAAR,GAAkB,UAAAC,QAAQ;AAAA,SAAI,IAAIC,gBAAJ,CAAYD,QAAZ,CAAJ;AAAA,CAA1B;AAEA;;;;;;;;;;;;AAUA3B,OAAO,CAAC6B,MAAR,GAAiB,UAAAF,QAAQ;AAAA,SAAI,IAAIG,eAAJ,CAAWH,QAAX,CAAJ;AAAA,CAAzB;AAEA;;;;;;;;;;;;AAUA3B,OAAO,CAAC+B,IAAR,GAAe,UAAAJ,QAAQ;AAAA,SAAI,IAAIK,oBAAJ,CAAgBL,QAAhB,CAAJ;AAAA,CAAvB;AAEA;;;;;;;;;;;;AAUA3B,OAAO,CAACiC,IAAR,GAAe,UAAAN,QAAQ;AAAA,SAAI,IAAIO,aAAJ,CAASP,QAAT,CAAJ;AAAA,CAAvB;AAEA;;;;;;;;;;;;AAUA3B,OAAO,CAACmC,IAAR,GAAe,UAAAR,QAAQ;AAAA,SAAI,IAAIS,aAAJ,CAAST,QAAT,CAAJ;AAAA,CAAvB;;eAEe3B,O","sourcesContent":["import Declaration from './declaration'\nimport Processor from './processor'\nimport stringify from './stringify'\nimport Comment from './comment'\nimport AtRule from './at-rule'\nimport vendor from './vendor'\nimport parse from './parse'\nimport list from './list'\nimport Rule from './rule'\nimport Root from './root'\n\n/**\n * Create a new {@link Processor} instance that will apply `plugins`\n * as CSS processors.\n *\n * @param {Array.<Plugin|pluginFunction>|Processor} plugins PostCSS plugins.\n *        See {@link Processor#use} for plugin format.\n *\n * @return {Processor} Processor to process multiple CSS.\n *\n * @example\n * import postcss from 'postcss'\n *\n * postcss(plugins).process(css, { from, to }).then(result => {\n *   console.log(result.css)\n * })\n *\n * @namespace postcss\n */\nfunction postcss (...plugins) {\n  if (plugins.length === 1 && Array.isArray(plugins[0])) {\n    plugins = plugins[0]\n  }\n  return new Processor(plugins)\n}\n\n/**\n * Creates a PostCSS plugin with a standard API.\n *\n * The newly-wrapped function will provide both the name and PostCSS\n * version of the plugin.\n *\n * ```js\n * const processor = postcss([replace])\n * processor.plugins[0].postcssPlugin  //=> 'postcss-replace'\n * processor.plugins[0].postcssVersion //=> '6.0.0'\n * ```\n *\n * The plugin function receives 2 arguments: {@link Root}\n * and {@link Result} instance. The function should mutate the provided\n * `Root` node. Alternatively, you can create a new `Root` node\n * and override the `result.root` property.\n *\n * ```js\n * const cleaner = postcss.plugin('postcss-cleaner', () => {\n *   return (root, result) => {\n *     result.root = postcss.root()\n *   }\n * })\n * ```\n *\n * As a convenience, plugins also expose a `process` method so that you can use\n * them as standalone tools.\n *\n * ```js\n * cleaner.process(css, processOpts, pluginOpts)\n * // This is equivalent to:\n * postcss([ cleaner(pluginOpts) ]).process(css, processOpts)\n * ```\n *\n * Asynchronous plugins should return a `Promise` instance.\n *\n * ```js\n * postcss.plugin('postcss-import', () => {\n *   return (root, result) => {\n *     return new Promise( (resolve, reject) => {\n *       fs.readFile('base.css', (base) => {\n *         root.prepend(base)\n *         resolve()\n *       })\n *     })\n *   }\n * })\n * ```\n *\n * Add warnings using the {@link Node#warn} method.\n * Send data to other plugins using the {@link Result#messages} array.\n *\n * ```js\n * postcss.plugin('postcss-caniuse-test', () => {\n *   return (root, result) => {\n *     root.walkDecls(decl => {\n *       if (!caniuse.support(decl.prop)) {\n *         decl.warn(result, 'Some browsers do not support ' + decl.prop)\n *       }\n *     })\n *   }\n * })\n * ```\n *\n * @param {string} name          PostCSS plugin name. Same as in `name`\n *                               property in `package.json`. It will be saved\n *                               in `plugin.postcssPlugin` property.\n * @param {function} initializer Will receive plugin options\n *                               and should return {@link pluginFunction}\n *\n * @return {Plugin} PostCSS plugin.\n */\npostcss.plugin = function plugin (name, initializer) {\n  function creator (...args) {\n    let transformer = initializer(...args)\n    transformer.postcssPlugin = name\n    transformer.postcssVersion = (new Processor()).version\n    return transformer\n  }\n\n  let cache\n  Object.defineProperty(creator, 'postcss', {\n    get () {\n      if (!cache) cache = creator()\n      return cache\n    }\n  })\n\n  creator.process = function (css, processOpts, pluginOpts) {\n    return postcss([creator(pluginOpts)]).process(css, processOpts)\n  }\n\n  return creator\n}\n\n/**\n * Default function to convert a node tree into a CSS string.\n *\n * @param {Node} node       Start node for stringifing. Usually {@link Root}.\n * @param {builder} builder Function to concatenate CSS from node’s parts\n *                          or generate string and source map.\n *\n * @return {void}\n *\n * @function\n */\npostcss.stringify = stringify\n\n/**\n * Parses source css and returns a new {@link Root} node,\n * which contains the source CSS nodes.\n *\n * @param {string|toString} css   String with input CSS or any object\n *                                with toString() method, like a Buffer\n * @param {processOptions} [opts] Options with only `from` and `map` keys.\n *\n * @return {Root} PostCSS AST.\n *\n * @example\n * // Simple CSS concatenation with source map support\n * const root1 = postcss.parse(css1, { from: file1 })\n * const root2 = postcss.parse(css2, { from: file2 })\n * root1.append(root2).toResult().css\n *\n * @function\n */\npostcss.parse = parse\n\n/**\n * Contains the {@link vendor} module.\n *\n * @type {vendor}\n *\n * @example\n * postcss.vendor.unprefixed('-moz-tab') //=> ['tab']\n */\npostcss.vendor = vendor\n\n/**\n * Contains the {@link list} module.\n *\n * @member {list}\n *\n * @example\n * postcss.list.space('5px calc(10% + 5px)') //=> ['5px', 'calc(10% + 5px)']\n */\npostcss.list = list\n\n/**\n * Creates a new {@link Comment} node.\n *\n * @param {object} [defaults] Properties for the new node.\n *\n * @return {Comment} New comment node\n *\n * @example\n * postcss.comment({ text: 'test' })\n */\npostcss.comment = defaults => new Comment(defaults)\n\n/**\n * Creates a new {@link AtRule} node.\n *\n * @param {object} [defaults] Properties for the new node.\n *\n * @return {AtRule} new at-rule node\n *\n * @example\n * postcss.atRule({ name: 'charset' }).toString() //=> \"@charset\"\n */\npostcss.atRule = defaults => new AtRule(defaults)\n\n/**\n * Creates a new {@link Declaration} node.\n *\n * @param {object} [defaults] Properties for the new node.\n *\n * @return {Declaration} new declaration node\n *\n * @example\n * postcss.decl({ prop: 'color', value: 'red' }).toString() //=> \"color: red\"\n */\npostcss.decl = defaults => new Declaration(defaults)\n\n/**\n * Creates a new {@link Rule} node.\n *\n * @param {object} [defaults] Properties for the new node.\n *\n * @return {Rule} new rule node\n *\n * @example\n * postcss.rule({ selector: 'a' }).toString() //=> \"a {\\n}\"\n */\npostcss.rule = defaults => new Rule(defaults)\n\n/**\n * Creates a new {@link Root} node.\n *\n * @param {object} [defaults] Properties for the new node.\n *\n * @return {Root} new root node.\n *\n * @example\n * postcss.root({ after: '\\n' }).toString() //=> \"\\n\"\n */\npostcss.root = defaults => new Root(defaults)\n\nexport default postcss\n"],"file":"postcss.js"}
|
package/lib/previous-map.js
CHANGED
@@ -1,25 +1,16 @@
|
|
1
|
-
|
1
|
+
"use strict";
|
2
2
|
|
3
3
|
exports.__esModule = true;
|
4
|
+
exports.default = void 0;
|
4
5
|
|
5
|
-
var
|
6
|
+
var _sourceMap = _interopRequireDefault(require("source-map"));
|
6
7
|
|
7
|
-
var
|
8
|
+
var _path = _interopRequireDefault(require("path"));
|
8
9
|
|
9
|
-
var
|
10
|
-
|
11
|
-
var _path = require('path');
|
12
|
-
|
13
|
-
var _path2 = _interopRequireDefault(_path);
|
14
|
-
|
15
|
-
var _fs = require('fs');
|
16
|
-
|
17
|
-
var _fs2 = _interopRequireDefault(_fs);
|
10
|
+
var _fs = _interopRequireDefault(require("fs"));
|
18
11
|
|
19
12
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
20
13
|
|
21
|
-
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
22
|
-
|
23
14
|
function fromBase64(str) {
|
24
15
|
if (Buffer) {
|
25
16
|
return Buffer.from(str, 'base64').toString();
|
@@ -27,7 +18,6 @@ function fromBase64(str) {
|
|
27
18
|
return window.atob(str);
|
28
19
|
}
|
29
20
|
}
|
30
|
-
|
31
21
|
/**
|
32
22
|
* Source map information from input CSS.
|
33
23
|
* For example, source map after Sass compiler.
|
@@ -40,27 +30,27 @@ function fromBase64(str) {
|
|
40
30
|
* root.input.map //=> PreviousMap
|
41
31
|
*/
|
42
32
|
|
43
|
-
|
33
|
+
|
34
|
+
var PreviousMap =
|
35
|
+
/*#__PURE__*/
|
36
|
+
function () {
|
44
37
|
/**
|
45
38
|
* @param {string} css Input CSS source.
|
46
39
|
* @param {processOptions} [opts] {@link Processor#process} options.
|
47
40
|
*/
|
48
41
|
function PreviousMap(css, opts) {
|
49
|
-
_classCallCheck(this, PreviousMap);
|
50
|
-
|
51
42
|
this.loadAnnotation(css);
|
52
43
|
/**
|
53
44
|
* Was source map inlined by data-uri to input CSS.
|
54
45
|
*
|
55
46
|
* @type {boolean}
|
56
47
|
*/
|
57
|
-
this.inline = this.startWith(this.annotation, 'data:');
|
58
48
|
|
49
|
+
this.inline = this.startWith(this.annotation, 'data:');
|
59
50
|
var prev = opts.map ? opts.map.prev : undefined;
|
60
51
|
var text = this.loadMap(opts.from, prev);
|
61
52
|
if (text) this.text = text;
|
62
53
|
}
|
63
|
-
|
64
54
|
/**
|
65
55
|
* Create a instance of `SourceMapGenerator` class
|
66
56
|
* from the `source-map` library to work with source map information.
|
@@ -72,13 +62,15 @@ var PreviousMap = function () {
|
|
72
62
|
*/
|
73
63
|
|
74
64
|
|
75
|
-
PreviousMap.prototype
|
65
|
+
var _proto = PreviousMap.prototype;
|
66
|
+
|
67
|
+
_proto.consumer = function consumer() {
|
76
68
|
if (!this.consumerCache) {
|
77
|
-
this.consumerCache = new
|
69
|
+
this.consumerCache = new _sourceMap.default.SourceMapConsumer(this.text);
|
78
70
|
}
|
71
|
+
|
79
72
|
return this.consumerCache;
|
80
73
|
};
|
81
|
-
|
82
74
|
/**
|
83
75
|
* Does source map contains `sourcesContent` with input source text.
|
84
76
|
*
|
@@ -86,36 +78,38 @@ var PreviousMap = function () {
|
|
86
78
|
*/
|
87
79
|
|
88
80
|
|
89
|
-
|
81
|
+
_proto.withContent = function withContent() {
|
90
82
|
return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0);
|
91
83
|
};
|
92
84
|
|
93
|
-
|
85
|
+
_proto.startWith = function startWith(string, start) {
|
94
86
|
if (!string) return false;
|
95
87
|
return string.substr(0, start.length) === start;
|
96
88
|
};
|
97
89
|
|
98
|
-
|
90
|
+
_proto.loadAnnotation = function loadAnnotation(css) {
|
99
91
|
var match = css.match(/\/\*\s*# sourceMappingURL=(.*)\s*\*\//);
|
100
92
|
if (match) this.annotation = match[1].trim();
|
101
93
|
};
|
102
94
|
|
103
|
-
|
95
|
+
_proto.decodeInline = function decodeInline(text) {
|
104
96
|
var baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/;
|
105
97
|
var baseUri = /^data:application\/json;base64,/;
|
106
98
|
var uri = 'data:application/json,';
|
107
99
|
|
108
100
|
if (this.startWith(text, uri)) {
|
109
101
|
return decodeURIComponent(text.substr(uri.length));
|
110
|
-
}
|
102
|
+
}
|
103
|
+
|
104
|
+
if (baseCharsetUri.test(text) || baseUri.test(text)) {
|
111
105
|
return fromBase64(text.substr(RegExp.lastMatch.length));
|
112
|
-
} else {
|
113
|
-
var encoding = text.match(/data:application\/json;([^,]+),/)[1];
|
114
|
-
throw new Error('Unsupported source map encoding ' + encoding);
|
115
106
|
}
|
107
|
+
|
108
|
+
var encoding = text.match(/data:application\/json;([^,]+),/)[1];
|
109
|
+
throw new Error('Unsupported source map encoding ' + encoding);
|
116
110
|
};
|
117
111
|
|
118
|
-
|
112
|
+
_proto.loadMap = function loadMap(file, prev) {
|
119
113
|
if (prev === false) return false;
|
120
114
|
|
121
115
|
if (prev) {
|
@@ -123,14 +117,15 @@ var PreviousMap = function () {
|
|
123
117
|
return prev;
|
124
118
|
} else if (typeof prev === 'function') {
|
125
119
|
var prevPath = prev(file);
|
126
|
-
|
127
|
-
|
120
|
+
|
121
|
+
if (prevPath && _fs.default.existsSync && _fs.default.existsSync(prevPath)) {
|
122
|
+
return _fs.default.readFileSync(prevPath, 'utf-8').toString().trim();
|
128
123
|
} else {
|
129
124
|
throw new Error('Unable to load previous source map: ' + prevPath.toString());
|
130
125
|
}
|
131
|
-
} else if (prev instanceof
|
132
|
-
return
|
133
|
-
} else if (prev instanceof
|
126
|
+
} else if (prev instanceof _sourceMap.default.SourceMapConsumer) {
|
127
|
+
return _sourceMap.default.SourceMapGenerator.fromSourceMap(prev).toString();
|
128
|
+
} else if (prev instanceof _sourceMap.default.SourceMapGenerator) {
|
134
129
|
return prev.toString();
|
135
130
|
} else if (this.isMap(prev)) {
|
136
131
|
return JSON.stringify(prev);
|
@@ -141,25 +136,26 @@ var PreviousMap = function () {
|
|
141
136
|
return this.decodeInline(this.annotation);
|
142
137
|
} else if (this.annotation) {
|
143
138
|
var map = this.annotation;
|
144
|
-
if (file) map =
|
139
|
+
if (file) map = _path.default.join(_path.default.dirname(file), map);
|
140
|
+
this.root = _path.default.dirname(map);
|
145
141
|
|
146
|
-
|
147
|
-
|
148
|
-
return _fs2.default.readFileSync(map, 'utf-8').toString().trim();
|
142
|
+
if (_fs.default.existsSync && _fs.default.existsSync(map)) {
|
143
|
+
return _fs.default.readFileSync(map, 'utf-8').toString().trim();
|
149
144
|
} else {
|
150
145
|
return false;
|
151
146
|
}
|
152
147
|
}
|
153
148
|
};
|
154
149
|
|
155
|
-
|
156
|
-
if (
|
150
|
+
_proto.isMap = function isMap(map) {
|
151
|
+
if (typeof map !== 'object') return false;
|
157
152
|
return typeof map.mappings === 'string' || typeof map._mappings === 'string';
|
158
153
|
};
|
159
154
|
|
160
155
|
return PreviousMap;
|
161
156
|
}();
|
162
157
|
|
163
|
-
|
164
|
-
|
165
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["previous-map.es6"],"names":["fromBase64","str","Buffer","from","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","baseCharsetUri","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    return Buffer.from(str, 'base64').toString()\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   * @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     * Was source map inlined by data-uri to input CSS.\n     *\n     * @type {boolean}\n     */\n    this.inline = this.startWith(this.annotation, 'data:')\n\n    const prev = opts.map ? opts.map.prev : undefined\n    const 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    const match = css.match(/\\/\\*\\s*# sourceMappingURL=(.*)\\s*\\*\\//)\n    if (match) this.annotation = match[1].trim()\n  }\n\n  decodeInline (text) {\n    const baseCharsetUri = /^data:application\\/json;charset=utf-?8;base64,/\n    const baseUri = /^data:application\\/json;base64,/\n    const uri = 'data:application/json,'\n\n    if (this.startWith(text, uri)) {\n      return decodeURIComponent(text.substr(uri.length))\n    } else if (baseCharsetUri.test(text) || baseUri.test(text)) {\n      return fromBase64(text.substr(RegExp.lastMatch.length))\n    } else {\n      const 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        const 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(\n            'Unable to load previous source map: ' + prevPath.toString())\n        }\n      } else if (prev instanceof mozilla.SourceMapConsumer) {\n        return mozilla.SourceMapGenerator.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(\n          'Unsupported previous source map format: ' + prev.toString())\n      }\n    } else if (this.inline) {\n      return this.decodeInline(this.annotation)\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' || typeof map._mappings === 'string'\n  }\n}\n\nexport default PreviousMap\n"]}
|
158
|
+
var _default = PreviousMap;
|
159
|
+
exports.default = _default;
|
160
|
+
module.exports = exports.default;
|
161
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["previous-map.es6"],"names":["fromBase64","str","Buffer","from","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","baseCharsetUri","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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","sourcesContent":["import mozilla from 'source-map'\nimport path from 'path'\nimport fs from 'fs'\n\nfunction fromBase64 (str) {\n  if (Buffer) {\n    return Buffer.from(str, 'base64').toString()\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   * @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     * Was source map inlined by data-uri to input CSS.\n     *\n     * @type {boolean}\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    let baseCharsetUri = /^data:application\\/json;charset=utf-?8;base64,/\n    let baseUri = /^data:application\\/json;base64,/\n    let uri = 'data:application/json,'\n\n    if (this.startWith(text, uri)) {\n      return decodeURIComponent(text.substr(uri.length))\n    }\n\n    if (baseCharsetUri.test(text) || baseUri.test(text)) {\n      return fromBase64(text.substr(RegExp.lastMatch.length))\n    }\n\n    let encoding = text.match(/data:application\\/json;([^,]+),/)[1]\n    throw new Error('Unsupported source map encoding ' + encoding)\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(\n            'Unable to load previous source map: ' + prevPath.toString())\n        }\n      } else if (prev instanceof mozilla.SourceMapConsumer) {\n        return mozilla.SourceMapGenerator.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(\n          'Unsupported previous source map format: ' + prev.toString())\n      }\n    } else if (this.inline) {\n      return this.decodeInline(this.annotation)\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' || typeof map._mappings === 'string'\n  }\n}\n\nexport default PreviousMap\n"],"file":"previous-map.js"}
|