hyperstack-config 0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (47) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +15 -0
  3. data/.travis.yml +29 -0
  4. data/Gemfile +3 -0
  5. data/Gemfile.lock +303 -0
  6. data/README.md +73 -0
  7. data/Rakefile +11 -0
  8. data/bin/hyperstack-hotloader +22 -0
  9. data/hyperstack-config.gemspec +45 -0
  10. data/lib/hyperstack-config.rb +45 -0
  11. data/lib/hyperstack-hotloader-config.js.erb +7 -0
  12. data/lib/hyperstack-loader-application.rb.erb +1 -0
  13. data/lib/hyperstack-loader-system-code.rb.erb +1 -0
  14. data/lib/hyperstack-loader.js +6 -0
  15. data/lib/hyperstack-prerender-loader-application.rb.erb +1 -0
  16. data/lib/hyperstack-prerender-loader-system-code.rb.erb +1 -0
  17. data/lib/hyperstack-prerender-loader.js +4 -0
  18. data/lib/hyperstack/active_support_string_inquirer.rb +32 -0
  19. data/lib/hyperstack/autoloader.rb +140 -0
  20. data/lib/hyperstack/autoloader_starter.rb +15 -0
  21. data/lib/hyperstack/boot.rb +41 -0
  22. data/lib/hyperstack/client_readers.rb +19 -0
  23. data/lib/hyperstack/client_stubs.rb +12 -0
  24. data/lib/hyperstack/config/version.rb +5 -0
  25. data/lib/hyperstack/config_settings.rb +49 -0
  26. data/lib/hyperstack/context.rb +36 -0
  27. data/lib/hyperstack/deprecation_warning.rb +10 -0
  28. data/lib/hyperstack/env.rb +10 -0
  29. data/lib/hyperstack/environment/development/hyperstack_env.rb +5 -0
  30. data/lib/hyperstack/environment/production/hyperstack_env.rb +5 -0
  31. data/lib/hyperstack/environment/staging/hyperstack_env.rb +5 -0
  32. data/lib/hyperstack/environment/test/hyperstack_env.rb +5 -0
  33. data/lib/hyperstack/hotloader.rb +129 -0
  34. data/lib/hyperstack/hotloader/add_error_boundry.rb +31 -0
  35. data/lib/hyperstack/hotloader/css_reloader.rb +41 -0
  36. data/lib/hyperstack/hotloader/server.rb +296 -0
  37. data/lib/hyperstack/hotloader/short_cut.js +9 -0
  38. data/lib/hyperstack/hotloader/socket.rb +136 -0
  39. data/lib/hyperstack/hotloader/stack-trace.js +2977 -0
  40. data/lib/hyperstack/hotloader/stub.rb +10 -0
  41. data/lib/hyperstack/imports.rb +104 -0
  42. data/lib/hyperstack/js_imports.rb +18 -0
  43. data/lib/hyperstack/on_client.rb +5 -0
  44. data/lib/hyperstack/on_error.rb +5 -0
  45. data/lib/hyperstack/rail_tie.rb +87 -0
  46. data/lib/hyperstack/string.rb +6 -0
  47. metadata +350 -0
@@ -0,0 +1,9 @@
1
+ if (typeof window !== 'undefined') {
2
+ window.Hyperstack = {
3
+ hotloader: function(port, ping) {
4
+ Opal.Hyperstack.$const_get('Hotloader').$listen(port || 25222, ping || Opal.nil)
5
+ }
6
+ }
7
+ } else {
8
+ throw 'Attempt to run hotloader during prerendering - make sure you import with the `client_only: true` option'
9
+ }
@@ -0,0 +1,136 @@
1
+ require 'native'
2
+ require 'io/writable'
3
+
4
+ module Hyperstack
5
+
6
+ class Hotloader
7
+
8
+ # Code taken from opal browser, did not want to force an opal-browser dependency
9
+ #
10
+ # A {Socket} allows the browser and a server to have a bidirectional data
11
+ # connection.
12
+ #
13
+ # @see https://developer.mozilla.org/en-US/docs/Web/API/WebSocket
14
+ class Socket
15
+ def self.supported?
16
+ Browser.supports? :WebSocket
17
+ end
18
+
19
+ include Native
20
+ include IO::Writable
21
+
22
+ def on(str, &block)
23
+ puts "putting #{str}"
24
+ b = block
25
+ cmd = "foo.on#{str} = #{b}"
26
+ puts cmd
27
+ `#{cmd}`
28
+ # `foo.on#{str} = #{b}`
29
+ end
30
+ # include DOM::Event::Target
31
+
32
+ # target {|value|
33
+ #Socket.new(value) if Native.is_a?(value, `window.WebSocket`)
34
+ # }
35
+
36
+ # Create a connection to the given URL, optionally using the given protocol.
37
+ #
38
+ # @param url [String] the URL to connect to
39
+ # @param protocol [String] the protocol to use
40
+ #
41
+ # @yield if the block has no parameters it's `instance_exec`d, otherwise it's
42
+ # called with `self`
43
+ def initialize(url, protocol = nil, &block)
44
+ if native?(url)
45
+ super(url)
46
+ elsif protocol
47
+ super(`new window.WebSocket(#{url.to_s}, #{protocol.to_n})`)
48
+ else
49
+ super(`new window.WebSocket(#{url.to_s})`)
50
+ end
51
+
52
+ if block.arity == 0
53
+ instance_exec(&block)
54
+ else
55
+ block.call(self)
56
+ end if block
57
+ end
58
+
59
+ # @!attribute [r] protocol
60
+ # @return [String] the protocol of the socket
61
+ alias_native :protocol
62
+
63
+ # @!attribute [r] url
64
+ # @return [String] the URL the socket is connected to
65
+ alias_native :url
66
+
67
+ # @!attribute [r] buffered
68
+ # @return [Integer] the amount of buffered data.
69
+ alias_native :buffered, :bufferedAmount
70
+
71
+ # @!attribute [r] type
72
+ # @return [:blob, :buffer, :string] the type of the socket
73
+ def type
74
+ %x{
75
+ switch (#@native.binaryType) {
76
+ case "blob":
77
+ return "blob";
78
+
79
+ case "arraybuffer":
80
+ return "buffer";
81
+
82
+ default:
83
+ return "string";
84
+ }
85
+ }
86
+ end
87
+
88
+ # @!attribute [r] state
89
+ # @return [:connecting, :open, :closing, :closed] the state of the socket
90
+ def state
91
+ %x{
92
+ switch (#@native.readyState) {
93
+ case window.WebSocket.CONNECTING:
94
+ return "connecting";
95
+
96
+ case window.WebSocket.OPEN:
97
+ return "open";
98
+
99
+ case window.WebSocket.CLOSING:
100
+ return "closing";
101
+
102
+ case window.WebSocket.CLOSED:
103
+ return "closed";
104
+ }
105
+ }
106
+ end
107
+
108
+ # @!attribute [r] extensions
109
+ # @return [Array<String>] the extensions used by the socket
110
+ def extensions
111
+ `#@native.extensions`.split(/\s*,\s*/)
112
+ end
113
+
114
+ # Check if the socket is alive.
115
+ def alive?
116
+ state == :open
117
+ end
118
+
119
+ # Send data to the socket.
120
+ #
121
+ # @param data [#to_n] the data to send
122
+ def write(data)
123
+ `#@native.send(#{data.to_n})`
124
+ end
125
+
126
+ # Close the socket.
127
+ #
128
+ # @param code [Integer, nil] the error code
129
+ # @param reason [String, nil] the reason for closing
130
+ def close(code = nil, reason = nil)
131
+ `#@native.close(#{code.to_n}, #{reason.to_n})`
132
+ end
133
+ end
134
+
135
+ end
136
+ end
@@ -0,0 +1,2977 @@
1
+ (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.StackTrace = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
2
+ (function(root, factory) {
3
+ 'use strict';
4
+ // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.
5
+
6
+ /* istanbul ignore next */
7
+ if (typeof define === 'function' && define.amd) {
8
+ define('error-stack-parser', ['stackframe'], factory);
9
+ } else if (typeof exports === 'object') {
10
+ module.exports = factory(require('stackframe'));
11
+ } else {
12
+ root.ErrorStackParser = factory(root.StackFrame);
13
+ }
14
+ }(this, function ErrorStackParser(StackFrame) {
15
+ 'use strict';
16
+
17
+ var FIREFOX_SAFARI_STACK_REGEXP = /(^|@)\S+\:\d+/;
18
+ var CHROME_IE_STACK_REGEXP = /^\s*at .*(\S+\:\d+|\(native\))/m;
19
+ var SAFARI_NATIVE_CODE_REGEXP = /^(eval@)?(\[native code\])?$/;
20
+
21
+ return {
22
+ /**
23
+ * Given an Error object, extract the most information from it.
24
+ *
25
+ * @param {Error} error object
26
+ * @return {Array} of StackFrames
27
+ */
28
+ parse: function ErrorStackParser$$parse(error) {
29
+ if (typeof error.stacktrace !== 'undefined' || typeof error['opera#sourceloc'] !== 'undefined') {
30
+ return this.parseOpera(error);
31
+ } else if (error.stack && error.stack.match(CHROME_IE_STACK_REGEXP)) {
32
+ return this.parseV8OrIE(error);
33
+ } else if (error.stack) {
34
+ return this.parseFFOrSafari(error);
35
+ } else {
36
+ throw new Error('Cannot parse given Error object');
37
+ }
38
+ },
39
+
40
+ // Separate line and column numbers from a string of the form: (URI:Line:Column)
41
+ extractLocation: function ErrorStackParser$$extractLocation(urlLike) {
42
+ // Fail-fast but return locations like "(native)"
43
+ if (urlLike.indexOf(':') === -1) {
44
+ return [urlLike];
45
+ }
46
+
47
+ var regExp = /(.+?)(?:\:(\d+))?(?:\:(\d+))?$/;
48
+ var parts = regExp.exec(urlLike.replace(/[\(\)]/g, ''));
49
+ return [parts[1], parts[2] || undefined, parts[3] || undefined];
50
+ },
51
+
52
+ parseV8OrIE: function ErrorStackParser$$parseV8OrIE(error) {
53
+ var filtered = error.stack.split('\n').filter(function(line) {
54
+ return !!line.match(CHROME_IE_STACK_REGEXP);
55
+ }, this);
56
+
57
+ return filtered.map(function(line) {
58
+ if (line.indexOf('(eval ') > -1) {
59
+ // Throw away eval information until we implement stacktrace.js/stackframe#8
60
+ line = line.replace(/eval code/g, 'eval').replace(/(\(eval at [^\()]*)|(\)\,.*$)/g, '');
61
+ }
62
+ var tokens = line.replace(/^\s+/, '').replace(/\(eval code/g, '(').split(/\s+/).slice(1);
63
+ var locationParts = this.extractLocation(tokens.pop());
64
+ var functionName = tokens.join(' ') || undefined;
65
+ var fileName = ['eval', '<anonymous>'].indexOf(locationParts[0]) > -1 ? undefined : locationParts[0];
66
+
67
+ return new StackFrame({
68
+ functionName: functionName,
69
+ fileName: fileName,
70
+ lineNumber: locationParts[1],
71
+ columnNumber: locationParts[2],
72
+ source: line
73
+ });
74
+ }, this);
75
+ },
76
+
77
+ parseFFOrSafari: function ErrorStackParser$$parseFFOrSafari(error) {
78
+ var filtered = error.stack.split('\n').filter(function(line) {
79
+ return !line.match(SAFARI_NATIVE_CODE_REGEXP);
80
+ }, this);
81
+
82
+ return filtered.map(function(line) {
83
+ // Throw away eval information until we implement stacktrace.js/stackframe#8
84
+ if (line.indexOf(' > eval') > -1) {
85
+ line = line.replace(/ line (\d+)(?: > eval line \d+)* > eval\:\d+\:\d+/g, ':$1');
86
+ }
87
+
88
+ if (line.indexOf('@') === -1 && line.indexOf(':') === -1) {
89
+ // Safari eval frames only have function names and nothing else
90
+ return new StackFrame({
91
+ functionName: line
92
+ });
93
+ } else {
94
+ var functionNameRegex = /((.*".+"[^@]*)?[^@]*)(?:@)/;
95
+ var matches = line.match(functionNameRegex);
96
+ var functionName = matches && matches[1] ? matches[1] : undefined;
97
+ var locationParts = this.extractLocation(line.replace(functionNameRegex, ''));
98
+
99
+ return new StackFrame({
100
+ functionName: functionName,
101
+ fileName: locationParts[0],
102
+ lineNumber: locationParts[1],
103
+ columnNumber: locationParts[2],
104
+ source: line
105
+ });
106
+ }
107
+ }, this);
108
+ },
109
+
110
+ parseOpera: function ErrorStackParser$$parseOpera(e) {
111
+ if (!e.stacktrace || (e.message.indexOf('\n') > -1 &&
112
+ e.message.split('\n').length > e.stacktrace.split('\n').length)) {
113
+ return this.parseOpera9(e);
114
+ } else if (!e.stack) {
115
+ return this.parseOpera10(e);
116
+ } else {
117
+ return this.parseOpera11(e);
118
+ }
119
+ },
120
+
121
+ parseOpera9: function ErrorStackParser$$parseOpera9(e) {
122
+ var lineRE = /Line (\d+).*script (?:in )?(\S+)/i;
123
+ var lines = e.message.split('\n');
124
+ var result = [];
125
+
126
+ for (var i = 2, len = lines.length; i < len; i += 2) {
127
+ var match = lineRE.exec(lines[i]);
128
+ if (match) {
129
+ result.push(new StackFrame({
130
+ fileName: match[2],
131
+ lineNumber: match[1],
132
+ source: lines[i]
133
+ }));
134
+ }
135
+ }
136
+
137
+ return result;
138
+ },
139
+
140
+ parseOpera10: function ErrorStackParser$$parseOpera10(e) {
141
+ var lineRE = /Line (\d+).*script (?:in )?(\S+)(?:: In function (\S+))?$/i;
142
+ var lines = e.stacktrace.split('\n');
143
+ var result = [];
144
+
145
+ for (var i = 0, len = lines.length; i < len; i += 2) {
146
+ var match = lineRE.exec(lines[i]);
147
+ if (match) {
148
+ result.push(
149
+ new StackFrame({
150
+ functionName: match[3] || undefined,
151
+ fileName: match[2],
152
+ lineNumber: match[1],
153
+ source: lines[i]
154
+ })
155
+ );
156
+ }
157
+ }
158
+
159
+ return result;
160
+ },
161
+
162
+ // Opera 10.65+ Error.stack very similar to FF/Safari
163
+ parseOpera11: function ErrorStackParser$$parseOpera11(error) {
164
+ var filtered = error.stack.split('\n').filter(function(line) {
165
+ return !!line.match(FIREFOX_SAFARI_STACK_REGEXP) && !line.match(/^Error created at/);
166
+ }, this);
167
+
168
+ return filtered.map(function(line) {
169
+ var tokens = line.split('@');
170
+ var locationParts = this.extractLocation(tokens.pop());
171
+ var functionCall = (tokens.shift() || '');
172
+ var functionName = functionCall
173
+ .replace(/<anonymous function(: (\w+))?>/, '$2')
174
+ .replace(/\([^\)]*\)/g, '') || undefined;
175
+ var argsRaw;
176
+ if (functionCall.match(/\(([^\)]*)\)/)) {
177
+ argsRaw = functionCall.replace(/^[^\(]+\(([^\)]*)\)$/, '$1');
178
+ }
179
+ var args = (argsRaw === undefined || argsRaw === '[arguments not available]') ?
180
+ undefined : argsRaw.split(',');
181
+
182
+ return new StackFrame({
183
+ functionName: functionName,
184
+ args: args,
185
+ fileName: locationParts[0],
186
+ lineNumber: locationParts[1],
187
+ columnNumber: locationParts[2],
188
+ source: line
189
+ });
190
+ }, this);
191
+ }
192
+ };
193
+ }));
194
+
195
+ },{"stackframe":3}],2:[function(require,module,exports){
196
+ (function(root, factory) {
197
+ 'use strict';
198
+ // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.
199
+
200
+ /* istanbul ignore next */
201
+ if (typeof define === 'function' && define.amd) {
202
+ define('stack-generator', ['stackframe'], factory);
203
+ } else if (typeof exports === 'object') {
204
+ module.exports = factory(require('stackframe'));
205
+ } else {
206
+ root.StackGenerator = factory(root.StackFrame);
207
+ }
208
+ }(this, function(StackFrame) {
209
+ return {
210
+ backtrace: function StackGenerator$$backtrace(opts) {
211
+ var stack = [];
212
+ var maxStackSize = 10;
213
+
214
+ if (typeof opts === 'object' && typeof opts.maxStackSize === 'number') {
215
+ maxStackSize = opts.maxStackSize;
216
+ }
217
+
218
+ var curr = arguments.callee;
219
+ while (curr && stack.length < maxStackSize && curr['arguments']) {
220
+ // Allow V8 optimizations
221
+ var args = new Array(curr['arguments'].length);
222
+ for (var i = 0; i < args.length; ++i) {
223
+ args[i] = curr['arguments'][i];
224
+ }
225
+ if (/function(?:\s+([\w$]+))+\s*\(/.test(curr.toString())) {
226
+ stack.push(new StackFrame({functionName: RegExp.$1 || undefined, args: args}));
227
+ } else {
228
+ stack.push(new StackFrame({args: args}));
229
+ }
230
+
231
+ try {
232
+ curr = curr.caller;
233
+ } catch (e) {
234
+ break;
235
+ }
236
+ }
237
+ return stack;
238
+ }
239
+ };
240
+ }));
241
+
242
+ },{"stackframe":3}],3:[function(require,module,exports){
243
+ (function(root, factory) {
244
+ 'use strict';
245
+ // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.
246
+
247
+ /* istanbul ignore next */
248
+ if (typeof define === 'function' && define.amd) {
249
+ define('stackframe', [], factory);
250
+ } else if (typeof exports === 'object') {
251
+ module.exports = factory();
252
+ } else {
253
+ root.StackFrame = factory();
254
+ }
255
+ }(this, function() {
256
+ 'use strict';
257
+ function _isNumber(n) {
258
+ return !isNaN(parseFloat(n)) && isFinite(n);
259
+ }
260
+
261
+ function _capitalize(str) {
262
+ return str.charAt(0).toUpperCase() + str.substring(1);
263
+ }
264
+
265
+ function _getter(p) {
266
+ return function() {
267
+ return this[p];
268
+ };
269
+ }
270
+
271
+ var booleanProps = ['isConstructor', 'isEval', 'isNative', 'isToplevel'];
272
+ var numericProps = ['columnNumber', 'lineNumber'];
273
+ var stringProps = ['fileName', 'functionName', 'source'];
274
+ var arrayProps = ['args'];
275
+
276
+ var props = booleanProps.concat(numericProps, stringProps, arrayProps);
277
+
278
+ function StackFrame(obj) {
279
+ if (obj instanceof Object) {
280
+ for (var i = 0; i < props.length; i++) {
281
+ if (obj.hasOwnProperty(props[i]) && obj[props[i]] !== undefined) {
282
+ this['set' + _capitalize(props[i])](obj[props[i]]);
283
+ }
284
+ }
285
+ }
286
+ }
287
+
288
+ StackFrame.prototype = {
289
+ getArgs: function() {
290
+ return this.args;
291
+ },
292
+ setArgs: function(v) {
293
+ if (Object.prototype.toString.call(v) !== '[object Array]') {
294
+ throw new TypeError('Args must be an Array');
295
+ }
296
+ this.args = v;
297
+ },
298
+
299
+ getEvalOrigin: function() {
300
+ return this.evalOrigin;
301
+ },
302
+ setEvalOrigin: function(v) {
303
+ if (v instanceof StackFrame) {
304
+ this.evalOrigin = v;
305
+ } else if (v instanceof Object) {
306
+ this.evalOrigin = new StackFrame(v);
307
+ } else {
308
+ throw new TypeError('Eval Origin must be an Object or StackFrame');
309
+ }
310
+ },
311
+
312
+ toString: function() {
313
+ var functionName = this.getFunctionName() || '{anonymous}';
314
+ var args = '(' + (this.getArgs() || []).join(',') + ')';
315
+ var fileName = this.getFileName() ? ('@' + this.getFileName()) : '';
316
+ var lineNumber = _isNumber(this.getLineNumber()) ? (':' + this.getLineNumber()) : '';
317
+ var columnNumber = _isNumber(this.getColumnNumber()) ? (':' + this.getColumnNumber()) : '';
318
+ return functionName + args + fileName + lineNumber + columnNumber;
319
+ }
320
+ };
321
+
322
+ for (var i = 0; i < booleanProps.length; i++) {
323
+ StackFrame.prototype['get' + _capitalize(booleanProps[i])] = _getter(booleanProps[i]);
324
+ StackFrame.prototype['set' + _capitalize(booleanProps[i])] = (function(p) {
325
+ return function(v) {
326
+ this[p] = Boolean(v);
327
+ };
328
+ })(booleanProps[i]);
329
+ }
330
+
331
+ for (var j = 0; j < numericProps.length; j++) {
332
+ StackFrame.prototype['get' + _capitalize(numericProps[j])] = _getter(numericProps[j]);
333
+ StackFrame.prototype['set' + _capitalize(numericProps[j])] = (function(p) {
334
+ return function(v) {
335
+ if (!_isNumber(v)) {
336
+ throw new TypeError(p + ' must be a Number');
337
+ }
338
+ this[p] = Number(v);
339
+ };
340
+ })(numericProps[j]);
341
+ }
342
+
343
+ for (var k = 0; k < stringProps.length; k++) {
344
+ StackFrame.prototype['get' + _capitalize(stringProps[k])] = _getter(stringProps[k]);
345
+ StackFrame.prototype['set' + _capitalize(stringProps[k])] = (function(p) {
346
+ return function(v) {
347
+ this[p] = String(v);
348
+ };
349
+ })(stringProps[k]);
350
+ }
351
+
352
+ return StackFrame;
353
+ }));
354
+
355
+ },{}],4:[function(require,module,exports){
356
+ /* -*- Mode: js; js-indent-level: 2; -*- */
357
+ /*
358
+ * Copyright 2011 Mozilla Foundation and contributors
359
+ * Licensed under the New BSD license. See LICENSE or:
360
+ * http://opensource.org/licenses/BSD-3-Clause
361
+ */
362
+
363
+ var util = require('./util');
364
+ var has = Object.prototype.hasOwnProperty;
365
+
366
+ /**
367
+ * A data structure which is a combination of an array and a set. Adding a new
368
+ * member is O(1), testing for membership is O(1), and finding the index of an
369
+ * element is O(1). Removing elements from the set is not supported. Only
370
+ * strings are supported for membership.
371
+ */
372
+ function ArraySet() {
373
+ this._array = [];
374
+ this._set = Object.create(null);
375
+ }
376
+
377
+ /**
378
+ * Static method for creating ArraySet instances from an existing array.
379
+ */
380
+ ArraySet.fromArray = function ArraySet_fromArray(aArray, aAllowDuplicates) {
381
+ var set = new ArraySet();
382
+ for (var i = 0, len = aArray.length; i < len; i++) {
383
+ set.add(aArray[i], aAllowDuplicates);
384
+ }
385
+ return set;
386
+ };
387
+
388
+ /**
389
+ * Return how many unique items are in this ArraySet. If duplicates have been
390
+ * added, than those do not count towards the size.
391
+ *
392
+ * @returns Number
393
+ */
394
+ ArraySet.prototype.size = function ArraySet_size() {
395
+ return Object.getOwnPropertyNames(this._set).length;
396
+ };
397
+
398
+ /**
399
+ * Add the given string to this set.
400
+ *
401
+ * @param String aStr
402
+ */
403
+ ArraySet.prototype.add = function ArraySet_add(aStr, aAllowDuplicates) {
404
+ var sStr = util.toSetString(aStr);
405
+ var isDuplicate = has.call(this._set, sStr);
406
+ var idx = this._array.length;
407
+ if (!isDuplicate || aAllowDuplicates) {
408
+ this._array.push(aStr);
409
+ }
410
+ if (!isDuplicate) {
411
+ this._set[sStr] = idx;
412
+ }
413
+ };
414
+
415
+ /**
416
+ * Is the given string a member of this set?
417
+ *
418
+ * @param String aStr
419
+ */
420
+ ArraySet.prototype.has = function ArraySet_has(aStr) {
421
+ var sStr = util.toSetString(aStr);
422
+ return has.call(this._set, sStr);
423
+ };
424
+
425
+ /**
426
+ * What is the index of the given string in the array?
427
+ *
428
+ * @param String aStr
429
+ */
430
+ ArraySet.prototype.indexOf = function ArraySet_indexOf(aStr) {
431
+ var sStr = util.toSetString(aStr);
432
+ if (has.call(this._set, sStr)) {
433
+ return this._set[sStr];
434
+ }
435
+ throw new Error('"' + aStr + '" is not in the set.');
436
+ };
437
+
438
+ /**
439
+ * What is the element at the given index?
440
+ *
441
+ * @param Number aIdx
442
+ */
443
+ ArraySet.prototype.at = function ArraySet_at(aIdx) {
444
+ if (aIdx >= 0 && aIdx < this._array.length) {
445
+ return this._array[aIdx];
446
+ }
447
+ throw new Error('No element indexed by ' + aIdx);
448
+ };
449
+
450
+ /**
451
+ * Returns the array representation of this set (which has the proper indices
452
+ * indicated by indexOf). Note that this is a copy of the internal array used
453
+ * for storing the members so that no one can mess with internal state.
454
+ */
455
+ ArraySet.prototype.toArray = function ArraySet_toArray() {
456
+ return this._array.slice();
457
+ };
458
+
459
+ exports.ArraySet = ArraySet;
460
+
461
+ },{"./util":10}],5:[function(require,module,exports){
462
+ /* -*- Mode: js; js-indent-level: 2; -*- */
463
+ /*
464
+ * Copyright 2011 Mozilla Foundation and contributors
465
+ * Licensed under the New BSD license. See LICENSE or:
466
+ * http://opensource.org/licenses/BSD-3-Clause
467
+ *
468
+ * Based on the Base 64 VLQ implementation in Closure Compiler:
469
+ * https://code.google.com/p/closure-compiler/source/browse/trunk/src/com/google/debugging/sourcemap/Base64VLQ.java
470
+ *
471
+ * Copyright 2011 The Closure Compiler Authors. All rights reserved.
472
+ * Redistribution and use in source and binary forms, with or without
473
+ * modification, are permitted provided that the following conditions are
474
+ * met:
475
+ *
476
+ * * Redistributions of source code must retain the above copyright
477
+ * notice, this list of conditions and the following disclaimer.
478
+ * * Redistributions in binary form must reproduce the above
479
+ * copyright notice, this list of conditions and the following
480
+ * disclaimer in the documentation and/or other materials provided
481
+ * with the distribution.
482
+ * * Neither the name of Google Inc. nor the names of its
483
+ * contributors may be used to endorse or promote products derived
484
+ * from this software without specific prior written permission.
485
+ *
486
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
487
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
488
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
489
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
490
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
491
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
492
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
493
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
494
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
495
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
496
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
497
+ */
498
+
499
+ var base64 = require('./base64');
500
+
501
+ // A single base 64 digit can contain 6 bits of data. For the base 64 variable
502
+ // length quantities we use in the source map spec, the first bit is the sign,
503
+ // the next four bits are the actual value, and the 6th bit is the
504
+ // continuation bit. The continuation bit tells us whether there are more
505
+ // digits in this value following this digit.
506
+ //
507
+ // Continuation
508
+ // | Sign
509
+ // | |
510
+ // V V
511
+ // 101011
512
+
513
+ var VLQ_BASE_SHIFT = 5;
514
+
515
+ // binary: 100000
516
+ var VLQ_BASE = 1 << VLQ_BASE_SHIFT;
517
+
518
+ // binary: 011111
519
+ var VLQ_BASE_MASK = VLQ_BASE - 1;
520
+
521
+ // binary: 100000
522
+ var VLQ_CONTINUATION_BIT = VLQ_BASE;
523
+
524
+ /**
525
+ * Converts from a two-complement value to a value where the sign bit is
526
+ * placed in the least significant bit. For example, as decimals:
527
+ * 1 becomes 2 (10 binary), -1 becomes 3 (11 binary)
528
+ * 2 becomes 4 (100 binary), -2 becomes 5 (101 binary)
529
+ */
530
+ function toVLQSigned(aValue) {
531
+ return aValue < 0
532
+ ? ((-aValue) << 1) + 1
533
+ : (aValue << 1) + 0;
534
+ }
535
+
536
+ /**
537
+ * Converts to a two-complement value from a value where the sign bit is
538
+ * placed in the least significant bit. For example, as decimals:
539
+ * 2 (10 binary) becomes 1, 3 (11 binary) becomes -1
540
+ * 4 (100 binary) becomes 2, 5 (101 binary) becomes -2
541
+ */
542
+ function fromVLQSigned(aValue) {
543
+ var isNegative = (aValue & 1) === 1;
544
+ var shifted = aValue >> 1;
545
+ return isNegative
546
+ ? -shifted
547
+ : shifted;
548
+ }
549
+
550
+ /**
551
+ * Returns the base 64 VLQ encoded value.
552
+ */
553
+ exports.encode = function base64VLQ_encode(aValue) {
554
+ var encoded = "";
555
+ var digit;
556
+
557
+ var vlq = toVLQSigned(aValue);
558
+
559
+ do {
560
+ digit = vlq & VLQ_BASE_MASK;
561
+ vlq >>>= VLQ_BASE_SHIFT;
562
+ if (vlq > 0) {
563
+ // There are still more digits in this value, so we must make sure the
564
+ // continuation bit is marked.
565
+ digit |= VLQ_CONTINUATION_BIT;
566
+ }
567
+ encoded += base64.encode(digit);
568
+ } while (vlq > 0);
569
+
570
+ return encoded;
571
+ };
572
+
573
+ /**
574
+ * Decodes the next base 64 VLQ value from the given string and returns the
575
+ * value and the rest of the string via the out parameter.
576
+ */
577
+ exports.decode = function base64VLQ_decode(aStr, aIndex, aOutParam) {
578
+ var strLen = aStr.length;
579
+ var result = 0;
580
+ var shift = 0;
581
+ var continuation, digit;
582
+
583
+ do {
584
+ if (aIndex >= strLen) {
585
+ throw new Error("Expected more digits in base 64 VLQ value.");
586
+ }
587
+
588
+ digit = base64.decode(aStr.charCodeAt(aIndex++));
589
+ if (digit === -1) {
590
+ throw new Error("Invalid base64 digit: " + aStr.charAt(aIndex - 1));
591
+ }
592
+
593
+ continuation = !!(digit & VLQ_CONTINUATION_BIT);
594
+ digit &= VLQ_BASE_MASK;
595
+ result = result + (digit << shift);
596
+ shift += VLQ_BASE_SHIFT;
597
+ } while (continuation);
598
+
599
+ aOutParam.value = fromVLQSigned(result);
600
+ aOutParam.rest = aIndex;
601
+ };
602
+
603
+ },{"./base64":6}],6:[function(require,module,exports){
604
+ /* -*- Mode: js; js-indent-level: 2; -*- */
605
+ /*
606
+ * Copyright 2011 Mozilla Foundation and contributors
607
+ * Licensed under the New BSD license. See LICENSE or:
608
+ * http://opensource.org/licenses/BSD-3-Clause
609
+ */
610
+
611
+ var intToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'.split('');
612
+
613
+ /**
614
+ * Encode an integer in the range of 0 to 63 to a single base 64 digit.
615
+ */
616
+ exports.encode = function (number) {
617
+ if (0 <= number && number < intToCharMap.length) {
618
+ return intToCharMap[number];
619
+ }
620
+ throw new TypeError("Must be between 0 and 63: " + number);
621
+ };
622
+
623
+ /**
624
+ * Decode a single base 64 character code digit to an integer. Returns -1 on
625
+ * failure.
626
+ */
627
+ exports.decode = function (charCode) {
628
+ var bigA = 65; // 'A'
629
+ var bigZ = 90; // 'Z'
630
+
631
+ var littleA = 97; // 'a'
632
+ var littleZ = 122; // 'z'
633
+
634
+ var zero = 48; // '0'
635
+ var nine = 57; // '9'
636
+
637
+ var plus = 43; // '+'
638
+ var slash = 47; // '/'
639
+
640
+ var littleOffset = 26;
641
+ var numberOffset = 52;
642
+
643
+ // 0 - 25: ABCDEFGHIJKLMNOPQRSTUVWXYZ
644
+ if (bigA <= charCode && charCode <= bigZ) {
645
+ return (charCode - bigA);
646
+ }
647
+
648
+ // 26 - 51: abcdefghijklmnopqrstuvwxyz
649
+ if (littleA <= charCode && charCode <= littleZ) {
650
+ return (charCode - littleA + littleOffset);
651
+ }
652
+
653
+ // 52 - 61: 0123456789
654
+ if (zero <= charCode && charCode <= nine) {
655
+ return (charCode - zero + numberOffset);
656
+ }
657
+
658
+ // 62: +
659
+ if (charCode == plus) {
660
+ return 62;
661
+ }
662
+
663
+ // 63: /
664
+ if (charCode == slash) {
665
+ return 63;
666
+ }
667
+
668
+ // Invalid base64 digit.
669
+ return -1;
670
+ };
671
+
672
+ },{}],7:[function(require,module,exports){
673
+ /* -*- Mode: js; js-indent-level: 2; -*- */
674
+ /*
675
+ * Copyright 2011 Mozilla Foundation and contributors
676
+ * Licensed under the New BSD license. See LICENSE or:
677
+ * http://opensource.org/licenses/BSD-3-Clause
678
+ */
679
+
680
+ exports.GREATEST_LOWER_BOUND = 1;
681
+ exports.LEAST_UPPER_BOUND = 2;
682
+
683
+ /**
684
+ * Recursive implementation of binary search.
685
+ *
686
+ * @param aLow Indices here and lower do not contain the needle.
687
+ * @param aHigh Indices here and higher do not contain the needle.
688
+ * @param aNeedle The element being searched for.
689
+ * @param aHaystack The non-empty array being searched.
690
+ * @param aCompare Function which takes two elements and returns -1, 0, or 1.
691
+ * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or
692
+ * 'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the
693
+ * closest element that is smaller than or greater than the one we are
694
+ * searching for, respectively, if the exact element cannot be found.
695
+ */
696
+ function recursiveSearch(aLow, aHigh, aNeedle, aHaystack, aCompare, aBias) {
697
+ // This function terminates when one of the following is true:
698
+ //
699
+ // 1. We find the exact element we are looking for.
700
+ //
701
+ // 2. We did not find the exact element, but we can return the index of
702
+ // the next-closest element.
703
+ //
704
+ // 3. We did not find the exact element, and there is no next-closest
705
+ // element than the one we are searching for, so we return -1.
706
+ var mid = Math.floor((aHigh - aLow) / 2) + aLow;
707
+ var cmp = aCompare(aNeedle, aHaystack[mid], true);
708
+ if (cmp === 0) {
709
+ // Found the element we are looking for.
710
+ return mid;
711
+ }
712
+ else if (cmp > 0) {
713
+ // Our needle is greater than aHaystack[mid].
714
+ if (aHigh - mid > 1) {
715
+ // The element is in the upper half.
716
+ return recursiveSearch(mid, aHigh, aNeedle, aHaystack, aCompare, aBias);
717
+ }
718
+
719
+ // The exact needle element was not found in this haystack. Determine if
720
+ // we are in termination case (3) or (2) and return the appropriate thing.
721
+ if (aBias == exports.LEAST_UPPER_BOUND) {
722
+ return aHigh < aHaystack.length ? aHigh : -1;
723
+ } else {
724
+ return mid;
725
+ }
726
+ }
727
+ else {
728
+ // Our needle is less than aHaystack[mid].
729
+ if (mid - aLow > 1) {
730
+ // The element is in the lower half.
731
+ return recursiveSearch(aLow, mid, aNeedle, aHaystack, aCompare, aBias);
732
+ }
733
+
734
+ // we are in termination case (3) or (2) and return the appropriate thing.
735
+ if (aBias == exports.LEAST_UPPER_BOUND) {
736
+ return mid;
737
+ } else {
738
+ return aLow < 0 ? -1 : aLow;
739
+ }
740
+ }
741
+ }
742
+
743
+ /**
744
+ * This is an implementation of binary search which will always try and return
745
+ * the index of the closest element if there is no exact hit. This is because
746
+ * mappings between original and generated line/col pairs are single points,
747
+ * and there is an implicit region between each of them, so a miss just means
748
+ * that you aren't on the very start of a region.
749
+ *
750
+ * @param aNeedle The element you are looking for.
751
+ * @param aHaystack The array that is being searched.
752
+ * @param aCompare A function which takes the needle and an element in the
753
+ * array and returns -1, 0, or 1 depending on whether the needle is less
754
+ * than, equal to, or greater than the element, respectively.
755
+ * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or
756
+ * 'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the
757
+ * closest element that is smaller than or greater than the one we are
758
+ * searching for, respectively, if the exact element cannot be found.
759
+ * Defaults to 'binarySearch.GREATEST_LOWER_BOUND'.
760
+ */
761
+ exports.search = function search(aNeedle, aHaystack, aCompare, aBias) {
762
+ if (aHaystack.length === 0) {
763
+ return -1;
764
+ }
765
+
766
+ var index = recursiveSearch(-1, aHaystack.length, aNeedle, aHaystack,
767
+ aCompare, aBias || exports.GREATEST_LOWER_BOUND);
768
+ if (index < 0) {
769
+ return -1;
770
+ }
771
+
772
+ // We have found either the exact element, or the next-closest element than
773
+ // the one we are searching for. However, there may be more than one such
774
+ // element. Make sure we always return the smallest of these.
775
+ while (index - 1 >= 0) {
776
+ if (aCompare(aHaystack[index], aHaystack[index - 1], true) !== 0) {
777
+ break;
778
+ }
779
+ --index;
780
+ }
781
+
782
+ return index;
783
+ };
784
+
785
+ },{}],8:[function(require,module,exports){
786
+ /* -*- Mode: js; js-indent-level: 2; -*- */
787
+ /*
788
+ * Copyright 2011 Mozilla Foundation and contributors
789
+ * Licensed under the New BSD license. See LICENSE or:
790
+ * http://opensource.org/licenses/BSD-3-Clause
791
+ */
792
+
793
+ // It turns out that some (most?) JavaScript engines don't self-host
794
+ // `Array.prototype.sort`. This makes sense because C++ will likely remain
795
+ // faster than JS when doing raw CPU-intensive sorting. However, when using a
796
+ // custom comparator function, calling back and forth between the VM's C++ and
797
+ // JIT'd JS is rather slow *and* loses JIT type information, resulting in
798
+ // worse generated code for the comparator function than would be optimal. In
799
+ // fact, when sorting with a comparator, these costs outweigh the benefits of
800
+ // sorting in C++. By using our own JS-implemented Quick Sort (below), we get
801
+ // a ~3500ms mean speed-up in `bench/bench.html`.
802
+
803
+ /**
804
+ * Swap the elements indexed by `x` and `y` in the array `ary`.
805
+ *
806
+ * @param {Array} ary
807
+ * The array.
808
+ * @param {Number} x
809
+ * The index of the first item.
810
+ * @param {Number} y
811
+ * The index of the second item.
812
+ */
813
+ function swap(ary, x, y) {
814
+ var temp = ary[x];
815
+ ary[x] = ary[y];
816
+ ary[y] = temp;
817
+ }
818
+
819
+ /**
820
+ * Returns a random integer within the range `low .. high` inclusive.
821
+ *
822
+ * @param {Number} low
823
+ * The lower bound on the range.
824
+ * @param {Number} high
825
+ * The upper bound on the range.
826
+ */
827
+ function randomIntInRange(low, high) {
828
+ return Math.round(low + (Math.random() * (high - low)));
829
+ }
830
+
831
+ /**
832
+ * The Quick Sort algorithm.
833
+ *
834
+ * @param {Array} ary
835
+ * An array to sort.
836
+ * @param {function} comparator
837
+ * Function to use to compare two items.
838
+ * @param {Number} p
839
+ * Start index of the array
840
+ * @param {Number} r
841
+ * End index of the array
842
+ */
843
+ function doQuickSort(ary, comparator, p, r) {
844
+ // If our lower bound is less than our upper bound, we (1) partition the
845
+ // array into two pieces and (2) recurse on each half. If it is not, this is
846
+ // the empty array and our base case.
847
+
848
+ if (p < r) {
849
+ // (1) Partitioning.
850
+ //
851
+ // The partitioning chooses a pivot between `p` and `r` and moves all
852
+ // elements that are less than or equal to the pivot to the before it, and
853
+ // all the elements that are greater than it after it. The effect is that
854
+ // once partition is done, the pivot is in the exact place it will be when
855
+ // the array is put in sorted order, and it will not need to be moved
856
+ // again. This runs in O(n) time.
857
+
858
+ // Always choose a random pivot so that an input array which is reverse
859
+ // sorted does not cause O(n^2) running time.
860
+ var pivotIndex = randomIntInRange(p, r);
861
+ var i = p - 1;
862
+
863
+ swap(ary, pivotIndex, r);
864
+ var pivot = ary[r];
865
+
866
+ // Immediately after `j` is incremented in this loop, the following hold
867
+ // true:
868
+ //
869
+ // * Every element in `ary[p .. i]` is less than or equal to the pivot.
870
+ //
871
+ // * Every element in `ary[i+1 .. j-1]` is greater than the pivot.
872
+ for (var j = p; j < r; j++) {
873
+ if (comparator(ary[j], pivot) <= 0) {
874
+ i += 1;
875
+ swap(ary, i, j);
876
+ }
877
+ }
878
+
879
+ swap(ary, i + 1, j);
880
+ var q = i + 1;
881
+
882
+ // (2) Recurse on each half.
883
+
884
+ doQuickSort(ary, comparator, p, q - 1);
885
+ doQuickSort(ary, comparator, q + 1, r);
886
+ }
887
+ }
888
+
889
+ /**
890
+ * Sort the given array in-place with the given comparator function.
891
+ *
892
+ * @param {Array} ary
893
+ * An array to sort.
894
+ * @param {function} comparator
895
+ * Function to use to compare two items.
896
+ */
897
+ exports.quickSort = function (ary, comparator) {
898
+ doQuickSort(ary, comparator, 0, ary.length - 1);
899
+ };
900
+
901
+ },{}],9:[function(require,module,exports){
902
+ /* -*- Mode: js; js-indent-level: 2; -*- */
903
+ /*
904
+ * Copyright 2011 Mozilla Foundation and contributors
905
+ * Licensed under the New BSD license. See LICENSE or:
906
+ * http://opensource.org/licenses/BSD-3-Clause
907
+ */
908
+
909
+ var util = require('./util');
910
+ var binarySearch = require('./binary-search');
911
+ var ArraySet = require('./array-set').ArraySet;
912
+ var base64VLQ = require('./base64-vlq');
913
+ var quickSort = require('./quick-sort').quickSort;
914
+
915
+ function SourceMapConsumer(aSourceMap) {
916
+ var sourceMap = aSourceMap;
917
+ if (typeof aSourceMap === 'string') {
918
+ sourceMap = JSON.parse(aSourceMap.replace(/^\)\]\}'/, ''));
919
+ }
920
+
921
+ return sourceMap.sections != null
922
+ ? new IndexedSourceMapConsumer(sourceMap)
923
+ : new BasicSourceMapConsumer(sourceMap);
924
+ }
925
+
926
+ SourceMapConsumer.fromSourceMap = function(aSourceMap) {
927
+ return BasicSourceMapConsumer.fromSourceMap(aSourceMap);
928
+ }
929
+
930
+ /**
931
+ * The version of the source mapping spec that we are consuming.
932
+ */
933
+ SourceMapConsumer.prototype._version = 3;
934
+
935
+ // `__generatedMappings` and `__originalMappings` are arrays that hold the
936
+ // parsed mapping coordinates from the source map's "mappings" attribute. They
937
+ // are lazily instantiated, accessed via the `_generatedMappings` and
938
+ // `_originalMappings` getters respectively, and we only parse the mappings
939
+ // and create these arrays once queried for a source location. We jump through
940
+ // these hoops because there can be many thousands of mappings, and parsing
941
+ // them is expensive, so we only want to do it if we must.
942
+ //
943
+ // Each object in the arrays is of the form:
944
+ //
945
+ // {
946
+ // generatedLine: The line number in the generated code,
947
+ // generatedColumn: The column number in the generated code,
948
+ // source: The path to the original source file that generated this
949
+ // chunk of code,
950
+ // originalLine: The line number in the original source that
951
+ // corresponds to this chunk of generated code,
952
+ // originalColumn: The column number in the original source that
953
+ // corresponds to this chunk of generated code,
954
+ // name: The name of the original symbol which generated this chunk of
955
+ // code.
956
+ // }
957
+ //
958
+ // All properties except for `generatedLine` and `generatedColumn` can be
959
+ // `null`.
960
+ //
961
+ // `_generatedMappings` is ordered by the generated positions.
962
+ //
963
+ // `_originalMappings` is ordered by the original positions.
964
+
965
+ SourceMapConsumer.prototype.__generatedMappings = null;
966
+ Object.defineProperty(SourceMapConsumer.prototype, '_generatedMappings', {
967
+ get: function () {
968
+ if (!this.__generatedMappings) {
969
+ this._parseMappings(this._mappings, this.sourceRoot);
970
+ }
971
+
972
+ return this.__generatedMappings;
973
+ }
974
+ });
975
+
976
+ SourceMapConsumer.prototype.__originalMappings = null;
977
+ Object.defineProperty(SourceMapConsumer.prototype, '_originalMappings', {
978
+ get: function () {
979
+ if (!this.__originalMappings) {
980
+ this._parseMappings(this._mappings, this.sourceRoot);
981
+ }
982
+
983
+ return this.__originalMappings;
984
+ }
985
+ });
986
+
987
+ SourceMapConsumer.prototype._charIsMappingSeparator =
988
+ function SourceMapConsumer_charIsMappingSeparator(aStr, index) {
989
+ var c = aStr.charAt(index);
990
+ return c === ";" || c === ",";
991
+ };
992
+
993
+ /**
994
+ * Parse the mappings in a string in to a data structure which we can easily
995
+ * query (the ordered arrays in the `this.__generatedMappings` and
996
+ * `this.__originalMappings` properties).
997
+ */
998
+ SourceMapConsumer.prototype._parseMappings =
999
+ function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {
1000
+ throw new Error("Subclasses must implement _parseMappings");
1001
+ };
1002
+
1003
+ SourceMapConsumer.GENERATED_ORDER = 1;
1004
+ SourceMapConsumer.ORIGINAL_ORDER = 2;
1005
+
1006
+ SourceMapConsumer.GREATEST_LOWER_BOUND = 1;
1007
+ SourceMapConsumer.LEAST_UPPER_BOUND = 2;
1008
+
1009
+ /**
1010
+ * Iterate over each mapping between an original source/line/column and a
1011
+ * generated line/column in this source map.
1012
+ *
1013
+ * @param Function aCallback
1014
+ * The function that is called with each mapping.
1015
+ * @param Object aContext
1016
+ * Optional. If specified, this object will be the value of `this` every
1017
+ * time that `aCallback` is called.
1018
+ * @param aOrder
1019
+ * Either `SourceMapConsumer.GENERATED_ORDER` or
1020
+ * `SourceMapConsumer.ORIGINAL_ORDER`. Specifies whether you want to
1021
+ * iterate over the mappings sorted by the generated file's line/column
1022
+ * order or the original's source/line/column order, respectively. Defaults to
1023
+ * `SourceMapConsumer.GENERATED_ORDER`.
1024
+ */
1025
+ SourceMapConsumer.prototype.eachMapping =
1026
+ function SourceMapConsumer_eachMapping(aCallback, aContext, aOrder) {
1027
+ var context = aContext || null;
1028
+ var order = aOrder || SourceMapConsumer.GENERATED_ORDER;
1029
+
1030
+ var mappings;
1031
+ switch (order) {
1032
+ case SourceMapConsumer.GENERATED_ORDER:
1033
+ mappings = this._generatedMappings;
1034
+ break;
1035
+ case SourceMapConsumer.ORIGINAL_ORDER:
1036
+ mappings = this._originalMappings;
1037
+ break;
1038
+ default:
1039
+ throw new Error("Unknown order of iteration.");
1040
+ }
1041
+
1042
+ var sourceRoot = this.sourceRoot;
1043
+ mappings.map(function (mapping) {
1044
+ var source = mapping.source === null ? null : this._sources.at(mapping.source);
1045
+ if (source != null && sourceRoot != null) {
1046
+ source = util.join(sourceRoot, source);
1047
+ }
1048
+ return {
1049
+ source: source,
1050
+ generatedLine: mapping.generatedLine,
1051
+ generatedColumn: mapping.generatedColumn,
1052
+ originalLine: mapping.originalLine,
1053
+ originalColumn: mapping.originalColumn,
1054
+ name: mapping.name === null ? null : this._names.at(mapping.name)
1055
+ };
1056
+ }, this).forEach(aCallback, context);
1057
+ };
1058
+
1059
+ /**
1060
+ * Returns all generated line and column information for the original source,
1061
+ * line, and column provided. If no column is provided, returns all mappings
1062
+ * corresponding to a either the line we are searching for or the next
1063
+ * closest line that has any mappings. Otherwise, returns all mappings
1064
+ * corresponding to the given line and either the column we are searching for
1065
+ * or the next closest column that has any offsets.
1066
+ *
1067
+ * The only argument is an object with the following properties:
1068
+ *
1069
+ * - source: The filename of the original source.
1070
+ * - line: The line number in the original source.
1071
+ * - column: Optional. the column number in the original source.
1072
+ *
1073
+ * and an array of objects is returned, each with the following properties:
1074
+ *
1075
+ * - line: The line number in the generated source, or null.
1076
+ * - column: The column number in the generated source, or null.
1077
+ */
1078
+ SourceMapConsumer.prototype.allGeneratedPositionsFor =
1079
+ function SourceMapConsumer_allGeneratedPositionsFor(aArgs) {
1080
+ var line = util.getArg(aArgs, 'line');
1081
+
1082
+ // When there is no exact match, BasicSourceMapConsumer.prototype._findMapping
1083
+ // returns the index of the closest mapping less than the needle. By
1084
+ // setting needle.originalColumn to 0, we thus find the last mapping for
1085
+ // the given line, provided such a mapping exists.
1086
+ var needle = {
1087
+ source: util.getArg(aArgs, 'source'),
1088
+ originalLine: line,
1089
+ originalColumn: util.getArg(aArgs, 'column', 0)
1090
+ };
1091
+
1092
+ if (this.sourceRoot != null) {
1093
+ needle.source = util.relative(this.sourceRoot, needle.source);
1094
+ }
1095
+ if (!this._sources.has(needle.source)) {
1096
+ return [];
1097
+ }
1098
+ needle.source = this._sources.indexOf(needle.source);
1099
+
1100
+ var mappings = [];
1101
+
1102
+ var index = this._findMapping(needle,
1103
+ this._originalMappings,
1104
+ "originalLine",
1105
+ "originalColumn",
1106
+ util.compareByOriginalPositions,
1107
+ binarySearch.LEAST_UPPER_BOUND);
1108
+ if (index >= 0) {
1109
+ var mapping = this._originalMappings[index];
1110
+
1111
+ if (aArgs.column === undefined) {
1112
+ var originalLine = mapping.originalLine;
1113
+
1114
+ // Iterate until either we run out of mappings, or we run into
1115
+ // a mapping for a different line than the one we found. Since
1116
+ // mappings are sorted, this is guaranteed to find all mappings for
1117
+ // the line we found.
1118
+ while (mapping && mapping.originalLine === originalLine) {
1119
+ mappings.push({
1120
+ line: util.getArg(mapping, 'generatedLine', null),
1121
+ column: util.getArg(mapping, 'generatedColumn', null),
1122
+ lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
1123
+ });
1124
+
1125
+ mapping = this._originalMappings[++index];
1126
+ }
1127
+ } else {
1128
+ var originalColumn = mapping.originalColumn;
1129
+
1130
+ // Iterate until either we run out of mappings, or we run into
1131
+ // a mapping for a different line than the one we were searching for.
1132
+ // Since mappings are sorted, this is guaranteed to find all mappings for
1133
+ // the line we are searching for.
1134
+ while (mapping &&
1135
+ mapping.originalLine === line &&
1136
+ mapping.originalColumn == originalColumn) {
1137
+ mappings.push({
1138
+ line: util.getArg(mapping, 'generatedLine', null),
1139
+ column: util.getArg(mapping, 'generatedColumn', null),
1140
+ lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
1141
+ });
1142
+
1143
+ mapping = this._originalMappings[++index];
1144
+ }
1145
+ }
1146
+ }
1147
+
1148
+ return mappings;
1149
+ };
1150
+
1151
+ exports.SourceMapConsumer = SourceMapConsumer;
1152
+
1153
+ /**
1154
+ * A BasicSourceMapConsumer instance represents a parsed source map which we can
1155
+ * query for information about the original file positions by giving it a file
1156
+ * position in the generated source.
1157
+ *
1158
+ * The only parameter is the raw source map (either as a JSON string, or
1159
+ * already parsed to an object). According to the spec, source maps have the
1160
+ * following attributes:
1161
+ *
1162
+ * - version: Which version of the source map spec this map is following.
1163
+ * - sources: An array of URLs to the original source files.
1164
+ * - names: An array of identifiers which can be referrenced by individual mappings.
1165
+ * - sourceRoot: Optional. The URL root from which all sources are relative.
1166
+ * - sourcesContent: Optional. An array of contents of the original source files.
1167
+ * - mappings: A string of base64 VLQs which contain the actual mappings.
1168
+ * - file: Optional. The generated file this source map is associated with.
1169
+ *
1170
+ * Here is an example source map, taken from the source map spec[0]:
1171
+ *
1172
+ * {
1173
+ * version : 3,
1174
+ * file: "out.js",
1175
+ * sourceRoot : "",
1176
+ * sources: ["foo.js", "bar.js"],
1177
+ * names: ["src", "maps", "are", "fun"],
1178
+ * mappings: "AA,AB;;ABCDE;"
1179
+ * }
1180
+ *
1181
+ * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit?pli=1#
1182
+ */
1183
+ function BasicSourceMapConsumer(aSourceMap) {
1184
+ var sourceMap = aSourceMap;
1185
+ if (typeof aSourceMap === 'string') {
1186
+ sourceMap = JSON.parse(aSourceMap.replace(/^\)\]\}'/, ''));
1187
+ }
1188
+
1189
+ var version = util.getArg(sourceMap, 'version');
1190
+ var sources = util.getArg(sourceMap, 'sources');
1191
+ // Sass 3.3 leaves out the 'names' array, so we deviate from the spec (which
1192
+ // requires the array) to play nice here.
1193
+ var names = util.getArg(sourceMap, 'names', []);
1194
+ var sourceRoot = util.getArg(sourceMap, 'sourceRoot', null);
1195
+ var sourcesContent = util.getArg(sourceMap, 'sourcesContent', null);
1196
+ var mappings = util.getArg(sourceMap, 'mappings');
1197
+ var file = util.getArg(sourceMap, 'file', null);
1198
+
1199
+ // Once again, Sass deviates from the spec and supplies the version as a
1200
+ // string rather than a number, so we use loose equality checking here.
1201
+ if (version != this._version) {
1202
+ throw new Error('Unsupported version: ' + version);
1203
+ }
1204
+
1205
+ sources = sources
1206
+ .map(String)
1207
+ // Some source maps produce relative source paths like "./foo.js" instead of
1208
+ // "foo.js". Normalize these first so that future comparisons will succeed.
1209
+ // See bugzil.la/1090768.
1210
+ .map(util.normalize)
1211
+ // Always ensure that absolute sources are internally stored relative to
1212
+ // the source root, if the source root is absolute. Not doing this would
1213
+ // be particularly problematic when the source root is a prefix of the
1214
+ // source (valid, but why??). See github issue #199 and bugzil.la/1188982.
1215
+ .map(function (source) {
1216
+ return sourceRoot && util.isAbsolute(sourceRoot) && util.isAbsolute(source)
1217
+ ? util.relative(sourceRoot, source)
1218
+ : source;
1219
+ });
1220
+
1221
+ // Pass `true` below to allow duplicate names and sources. While source maps
1222
+ // are intended to be compressed and deduplicated, the TypeScript compiler
1223
+ // sometimes generates source maps with duplicates in them. See Github issue
1224
+ // #72 and bugzil.la/889492.
1225
+ this._names = ArraySet.fromArray(names.map(String), true);
1226
+ this._sources = ArraySet.fromArray(sources, true);
1227
+
1228
+ this.sourceRoot = sourceRoot;
1229
+ this.sourcesContent = sourcesContent;
1230
+ this._mappings = mappings;
1231
+ this.file = file;
1232
+ }
1233
+
1234
+ BasicSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);
1235
+ BasicSourceMapConsumer.prototype.consumer = SourceMapConsumer;
1236
+
1237
+ /**
1238
+ * Create a BasicSourceMapConsumer from a SourceMapGenerator.
1239
+ *
1240
+ * @param SourceMapGenerator aSourceMap
1241
+ * The source map that will be consumed.
1242
+ * @returns BasicSourceMapConsumer
1243
+ */
1244
+ BasicSourceMapConsumer.fromSourceMap =
1245
+ function SourceMapConsumer_fromSourceMap(aSourceMap) {
1246
+ var smc = Object.create(BasicSourceMapConsumer.prototype);
1247
+
1248
+ var names = smc._names = ArraySet.fromArray(aSourceMap._names.toArray(), true);
1249
+ var sources = smc._sources = ArraySet.fromArray(aSourceMap._sources.toArray(), true);
1250
+ smc.sourceRoot = aSourceMap._sourceRoot;
1251
+ smc.sourcesContent = aSourceMap._generateSourcesContent(smc._sources.toArray(),
1252
+ smc.sourceRoot);
1253
+ smc.file = aSourceMap._file;
1254
+
1255
+ // Because we are modifying the entries (by converting string sources and
1256
+ // names to indices into the sources and names ArraySets), we have to make
1257
+ // a copy of the entry or else bad things happen. Shared mutable state
1258
+ // strikes again! See github issue #191.
1259
+
1260
+ var generatedMappings = aSourceMap._mappings.toArray().slice();
1261
+ var destGeneratedMappings = smc.__generatedMappings = [];
1262
+ var destOriginalMappings = smc.__originalMappings = [];
1263
+
1264
+ for (var i = 0, length = generatedMappings.length; i < length; i++) {
1265
+ var srcMapping = generatedMappings[i];
1266
+ var destMapping = new Mapping;
1267
+ destMapping.generatedLine = srcMapping.generatedLine;
1268
+ destMapping.generatedColumn = srcMapping.generatedColumn;
1269
+
1270
+ if (srcMapping.source) {
1271
+ destMapping.source = sources.indexOf(srcMapping.source);
1272
+ destMapping.originalLine = srcMapping.originalLine;
1273
+ destMapping.originalColumn = srcMapping.originalColumn;
1274
+
1275
+ if (srcMapping.name) {
1276
+ destMapping.name = names.indexOf(srcMapping.name);
1277
+ }
1278
+
1279
+ destOriginalMappings.push(destMapping);
1280
+ }
1281
+
1282
+ destGeneratedMappings.push(destMapping);
1283
+ }
1284
+
1285
+ quickSort(smc.__originalMappings, util.compareByOriginalPositions);
1286
+
1287
+ return smc;
1288
+ };
1289
+
1290
+ /**
1291
+ * The version of the source mapping spec that we are consuming.
1292
+ */
1293
+ BasicSourceMapConsumer.prototype._version = 3;
1294
+
1295
+ /**
1296
+ * The list of original sources.
1297
+ */
1298
+ Object.defineProperty(BasicSourceMapConsumer.prototype, 'sources', {
1299
+ get: function () {
1300
+ return this._sources.toArray().map(function (s) {
1301
+ return this.sourceRoot != null ? util.join(this.sourceRoot, s) : s;
1302
+ }, this);
1303
+ }
1304
+ });
1305
+
1306
+ /**
1307
+ * Provide the JIT with a nice shape / hidden class.
1308
+ */
1309
+ function Mapping() {
1310
+ this.generatedLine = 0;
1311
+ this.generatedColumn = 0;
1312
+ this.source = null;
1313
+ this.originalLine = null;
1314
+ this.originalColumn = null;
1315
+ this.name = null;
1316
+ }
1317
+
1318
+ /**
1319
+ * Parse the mappings in a string in to a data structure which we can easily
1320
+ * query (the ordered arrays in the `this.__generatedMappings` and
1321
+ * `this.__originalMappings` properties).
1322
+ */
1323
+ BasicSourceMapConsumer.prototype._parseMappings =
1324
+ function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {
1325
+ var generatedLine = 1;
1326
+ var previousGeneratedColumn = 0;
1327
+ var previousOriginalLine = 0;
1328
+ var previousOriginalColumn = 0;
1329
+ var previousSource = 0;
1330
+ var previousName = 0;
1331
+ var length = aStr.length;
1332
+ var index = 0;
1333
+ var cachedSegments = {};
1334
+ var temp = {};
1335
+ var originalMappings = [];
1336
+ var generatedMappings = [];
1337
+ var mapping, str, segment, end, value;
1338
+
1339
+ while (index < length) {
1340
+ if (aStr.charAt(index) === ';') {
1341
+ generatedLine++;
1342
+ index++;
1343
+ previousGeneratedColumn = 0;
1344
+ }
1345
+ else if (aStr.charAt(index) === ',') {
1346
+ index++;
1347
+ }
1348
+ else {
1349
+ mapping = new Mapping();
1350
+ mapping.generatedLine = generatedLine;
1351
+
1352
+ // Because each offset is encoded relative to the previous one,
1353
+ // many segments often have the same encoding. We can exploit this
1354
+ // fact by caching the parsed variable length fields of each segment,
1355
+ // allowing us to avoid a second parse if we encounter the same
1356
+ // segment again.
1357
+ for (end = index; end < length; end++) {
1358
+ if (this._charIsMappingSeparator(aStr, end)) {
1359
+ break;
1360
+ }
1361
+ }
1362
+ str = aStr.slice(index, end);
1363
+
1364
+ segment = cachedSegments[str];
1365
+ if (segment) {
1366
+ index += str.length;
1367
+ } else {
1368
+ segment = [];
1369
+ while (index < end) {
1370
+ base64VLQ.decode(aStr, index, temp);
1371
+ value = temp.value;
1372
+ index = temp.rest;
1373
+ segment.push(value);
1374
+ }
1375
+
1376
+ if (segment.length === 2) {
1377
+ throw new Error('Found a source, but no line and column');
1378
+ }
1379
+
1380
+ if (segment.length === 3) {
1381
+ throw new Error('Found a source and line, but no column');
1382
+ }
1383
+
1384
+ cachedSegments[str] = segment;
1385
+ }
1386
+
1387
+ // Generated column.
1388
+ mapping.generatedColumn = previousGeneratedColumn + segment[0];
1389
+ previousGeneratedColumn = mapping.generatedColumn;
1390
+
1391
+ if (segment.length > 1) {
1392
+ // Original source.
1393
+ mapping.source = previousSource + segment[1];
1394
+ previousSource += segment[1];
1395
+
1396
+ // Original line.
1397
+ mapping.originalLine = previousOriginalLine + segment[2];
1398
+ previousOriginalLine = mapping.originalLine;
1399
+ // Lines are stored 0-based
1400
+ mapping.originalLine += 1;
1401
+
1402
+ // Original column.
1403
+ mapping.originalColumn = previousOriginalColumn + segment[3];
1404
+ previousOriginalColumn = mapping.originalColumn;
1405
+
1406
+ if (segment.length > 4) {
1407
+ // Original name.
1408
+ mapping.name = previousName + segment[4];
1409
+ previousName += segment[4];
1410
+ }
1411
+ }
1412
+
1413
+ generatedMappings.push(mapping);
1414
+ if (typeof mapping.originalLine === 'number') {
1415
+ originalMappings.push(mapping);
1416
+ }
1417
+ }
1418
+ }
1419
+
1420
+ quickSort(generatedMappings, util.compareByGeneratedPositionsDeflated);
1421
+ this.__generatedMappings = generatedMappings;
1422
+
1423
+ quickSort(originalMappings, util.compareByOriginalPositions);
1424
+ this.__originalMappings = originalMappings;
1425
+ };
1426
+
1427
+ /**
1428
+ * Find the mapping that best matches the hypothetical "needle" mapping that
1429
+ * we are searching for in the given "haystack" of mappings.
1430
+ */
1431
+ BasicSourceMapConsumer.prototype._findMapping =
1432
+ function SourceMapConsumer_findMapping(aNeedle, aMappings, aLineName,
1433
+ aColumnName, aComparator, aBias) {
1434
+ // To return the position we are searching for, we must first find the
1435
+ // mapping for the given position and then return the opposite position it
1436
+ // points to. Because the mappings are sorted, we can use binary search to
1437
+ // find the best mapping.
1438
+
1439
+ if (aNeedle[aLineName] <= 0) {
1440
+ throw new TypeError('Line must be greater than or equal to 1, got '
1441
+ + aNeedle[aLineName]);
1442
+ }
1443
+ if (aNeedle[aColumnName] < 0) {
1444
+ throw new TypeError('Column must be greater than or equal to 0, got '
1445
+ + aNeedle[aColumnName]);
1446
+ }
1447
+
1448
+ return binarySearch.search(aNeedle, aMappings, aComparator, aBias);
1449
+ };
1450
+
1451
+ /**
1452
+ * Compute the last column for each generated mapping. The last column is
1453
+ * inclusive.
1454
+ */
1455
+ BasicSourceMapConsumer.prototype.computeColumnSpans =
1456
+ function SourceMapConsumer_computeColumnSpans() {
1457
+ for (var index = 0; index < this._generatedMappings.length; ++index) {
1458
+ var mapping = this._generatedMappings[index];
1459
+
1460
+ // Mappings do not contain a field for the last generated columnt. We
1461
+ // can come up with an optimistic estimate, however, by assuming that
1462
+ // mappings are contiguous (i.e. given two consecutive mappings, the
1463
+ // first mapping ends where the second one starts).
1464
+ if (index + 1 < this._generatedMappings.length) {
1465
+ var nextMapping = this._generatedMappings[index + 1];
1466
+
1467
+ if (mapping.generatedLine === nextMapping.generatedLine) {
1468
+ mapping.lastGeneratedColumn = nextMapping.generatedColumn - 1;
1469
+ continue;
1470
+ }
1471
+ }
1472
+
1473
+ // The last mapping for each line spans the entire line.
1474
+ mapping.lastGeneratedColumn = Infinity;
1475
+ }
1476
+ };
1477
+
1478
+ /**
1479
+ * Returns the original source, line, and column information for the generated
1480
+ * source's line and column positions provided. The only argument is an object
1481
+ * with the following properties:
1482
+ *
1483
+ * - line: The line number in the generated source.
1484
+ * - column: The column number in the generated source.
1485
+ * - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or
1486
+ * 'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the
1487
+ * closest element that is smaller than or greater than the one we are
1488
+ * searching for, respectively, if the exact element cannot be found.
1489
+ * Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.
1490
+ *
1491
+ * and an object is returned with the following properties:
1492
+ *
1493
+ * - source: The original source file, or null.
1494
+ * - line: The line number in the original source, or null.
1495
+ * - column: The column number in the original source, or null.
1496
+ * - name: The original identifier, or null.
1497
+ */
1498
+ BasicSourceMapConsumer.prototype.originalPositionFor =
1499
+ function SourceMapConsumer_originalPositionFor(aArgs) {
1500
+ var needle = {
1501
+ generatedLine: util.getArg(aArgs, 'line'),
1502
+ generatedColumn: util.getArg(aArgs, 'column')
1503
+ };
1504
+
1505
+ var index = this._findMapping(
1506
+ needle,
1507
+ this._generatedMappings,
1508
+ "generatedLine",
1509
+ "generatedColumn",
1510
+ util.compareByGeneratedPositionsDeflated,
1511
+ util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)
1512
+ );
1513
+
1514
+ if (index >= 0) {
1515
+ var mapping = this._generatedMappings[index];
1516
+
1517
+ if (mapping.generatedLine === needle.generatedLine) {
1518
+ var source = util.getArg(mapping, 'source', null);
1519
+ if (source !== null) {
1520
+ source = this._sources.at(source);
1521
+ if (this.sourceRoot != null) {
1522
+ source = util.join(this.sourceRoot, source);
1523
+ }
1524
+ }
1525
+ var name = util.getArg(mapping, 'name', null);
1526
+ if (name !== null) {
1527
+ name = this._names.at(name);
1528
+ }
1529
+ return {
1530
+ source: source,
1531
+ line: util.getArg(mapping, 'originalLine', null),
1532
+ column: util.getArg(mapping, 'originalColumn', null),
1533
+ name: name
1534
+ };
1535
+ }
1536
+ }
1537
+
1538
+ return {
1539
+ source: null,
1540
+ line: null,
1541
+ column: null,
1542
+ name: null
1543
+ };
1544
+ };
1545
+
1546
+ /**
1547
+ * Return true if we have the source content for every source in the source
1548
+ * map, false otherwise.
1549
+ */
1550
+ BasicSourceMapConsumer.prototype.hasContentsOfAllSources =
1551
+ function BasicSourceMapConsumer_hasContentsOfAllSources() {
1552
+ if (!this.sourcesContent) {
1553
+ return false;
1554
+ }
1555
+ return this.sourcesContent.length >= this._sources.size() &&
1556
+ !this.sourcesContent.some(function (sc) { return sc == null; });
1557
+ };
1558
+
1559
+ /**
1560
+ * Returns the original source content. The only argument is the url of the
1561
+ * original source file. Returns null if no original source content is
1562
+ * available.
1563
+ */
1564
+ BasicSourceMapConsumer.prototype.sourceContentFor =
1565
+ function SourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {
1566
+ if (!this.sourcesContent) {
1567
+ return null;
1568
+ }
1569
+
1570
+ if (this.sourceRoot != null) {
1571
+ aSource = util.relative(this.sourceRoot, aSource);
1572
+ }
1573
+
1574
+ if (this._sources.has(aSource)) {
1575
+ return this.sourcesContent[this._sources.indexOf(aSource)];
1576
+ }
1577
+
1578
+ var url;
1579
+ if (this.sourceRoot != null
1580
+ && (url = util.urlParse(this.sourceRoot))) {
1581
+ // XXX: file:// URIs and absolute paths lead to unexpected behavior for
1582
+ // many users. We can help them out when they expect file:// URIs to
1583
+ // behave like it would if they were running a local HTTP server. See
1584
+ // https://bugzilla.mozilla.org/show_bug.cgi?id=885597.
1585
+ var fileUriAbsPath = aSource.replace(/^file:\/\//, "");
1586
+ if (url.scheme == "file"
1587
+ && this._sources.has(fileUriAbsPath)) {
1588
+ return this.sourcesContent[this._sources.indexOf(fileUriAbsPath)]
1589
+ }
1590
+
1591
+ if ((!url.path || url.path == "/")
1592
+ && this._sources.has("/" + aSource)) {
1593
+ return this.sourcesContent[this._sources.indexOf("/" + aSource)];
1594
+ }
1595
+ }
1596
+
1597
+ // This function is used recursively from
1598
+ // IndexedSourceMapConsumer.prototype.sourceContentFor. In that case, we
1599
+ // don't want to throw if we can't find the source - we just want to
1600
+ // return null, so we provide a flag to exit gracefully.
1601
+ if (nullOnMissing) {
1602
+ return null;
1603
+ }
1604
+ else {
1605
+ throw new Error('"' + aSource + '" is not in the SourceMap.');
1606
+ }
1607
+ };
1608
+
1609
+ /**
1610
+ * Returns the generated line and column information for the original source,
1611
+ * line, and column positions provided. The only argument is an object with
1612
+ * the following properties:
1613
+ *
1614
+ * - source: The filename of the original source.
1615
+ * - line: The line number in the original source.
1616
+ * - column: The column number in the original source.
1617
+ * - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or
1618
+ * 'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the
1619
+ * closest element that is smaller than or greater than the one we are
1620
+ * searching for, respectively, if the exact element cannot be found.
1621
+ * Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.
1622
+ *
1623
+ * and an object is returned with the following properties:
1624
+ *
1625
+ * - line: The line number in the generated source, or null.
1626
+ * - column: The column number in the generated source, or null.
1627
+ */
1628
+ BasicSourceMapConsumer.prototype.generatedPositionFor =
1629
+ function SourceMapConsumer_generatedPositionFor(aArgs) {
1630
+ var source = util.getArg(aArgs, 'source');
1631
+ if (this.sourceRoot != null) {
1632
+ source = util.relative(this.sourceRoot, source);
1633
+ }
1634
+ if (!this._sources.has(source)) {
1635
+ return {
1636
+ line: null,
1637
+ column: null,
1638
+ lastColumn: null
1639
+ };
1640
+ }
1641
+ source = this._sources.indexOf(source);
1642
+
1643
+ var needle = {
1644
+ source: source,
1645
+ originalLine: util.getArg(aArgs, 'line'),
1646
+ originalColumn: util.getArg(aArgs, 'column')
1647
+ };
1648
+
1649
+ var index = this._findMapping(
1650
+ needle,
1651
+ this._originalMappings,
1652
+ "originalLine",
1653
+ "originalColumn",
1654
+ util.compareByOriginalPositions,
1655
+ util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)
1656
+ );
1657
+
1658
+ if (index >= 0) {
1659
+ var mapping = this._originalMappings[index];
1660
+
1661
+ if (mapping.source === needle.source) {
1662
+ return {
1663
+ line: util.getArg(mapping, 'generatedLine', null),
1664
+ column: util.getArg(mapping, 'generatedColumn', null),
1665
+ lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
1666
+ };
1667
+ }
1668
+ }
1669
+
1670
+ return {
1671
+ line: null,
1672
+ column: null,
1673
+ lastColumn: null
1674
+ };
1675
+ };
1676
+
1677
+ exports.BasicSourceMapConsumer = BasicSourceMapConsumer;
1678
+
1679
+ /**
1680
+ * An IndexedSourceMapConsumer instance represents a parsed source map which
1681
+ * we can query for information. It differs from BasicSourceMapConsumer in
1682
+ * that it takes "indexed" source maps (i.e. ones with a "sections" field) as
1683
+ * input.
1684
+ *
1685
+ * The only parameter is a raw source map (either as a JSON string, or already
1686
+ * parsed to an object). According to the spec for indexed source maps, they
1687
+ * have the following attributes:
1688
+ *
1689
+ * - version: Which version of the source map spec this map is following.
1690
+ * - file: Optional. The generated file this source map is associated with.
1691
+ * - sections: A list of section definitions.
1692
+ *
1693
+ * Each value under the "sections" field has two fields:
1694
+ * - offset: The offset into the original specified at which this section
1695
+ * begins to apply, defined as an object with a "line" and "column"
1696
+ * field.
1697
+ * - map: A source map definition. This source map could also be indexed,
1698
+ * but doesn't have to be.
1699
+ *
1700
+ * Instead of the "map" field, it's also possible to have a "url" field
1701
+ * specifying a URL to retrieve a source map from, but that's currently
1702
+ * unsupported.
1703
+ *
1704
+ * Here's an example source map, taken from the source map spec[0], but
1705
+ * modified to omit a section which uses the "url" field.
1706
+ *
1707
+ * {
1708
+ * version : 3,
1709
+ * file: "app.js",
1710
+ * sections: [{
1711
+ * offset: {line:100, column:10},
1712
+ * map: {
1713
+ * version : 3,
1714
+ * file: "section.js",
1715
+ * sources: ["foo.js", "bar.js"],
1716
+ * names: ["src", "maps", "are", "fun"],
1717
+ * mappings: "AAAA,E;;ABCDE;"
1718
+ * }
1719
+ * }],
1720
+ * }
1721
+ *
1722
+ * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit#heading=h.535es3xeprgt
1723
+ */
1724
+ function IndexedSourceMapConsumer(aSourceMap) {
1725
+ var sourceMap = aSourceMap;
1726
+ if (typeof aSourceMap === 'string') {
1727
+ sourceMap = JSON.parse(aSourceMap.replace(/^\)\]\}'/, ''));
1728
+ }
1729
+
1730
+ var version = util.getArg(sourceMap, 'version');
1731
+ var sections = util.getArg(sourceMap, 'sections');
1732
+
1733
+ if (version != this._version) {
1734
+ throw new Error('Unsupported version: ' + version);
1735
+ }
1736
+
1737
+ this._sources = new ArraySet();
1738
+ this._names = new ArraySet();
1739
+
1740
+ var lastOffset = {
1741
+ line: -1,
1742
+ column: 0
1743
+ };
1744
+ this._sections = sections.map(function (s) {
1745
+ if (s.url) {
1746
+ // The url field will require support for asynchronicity.
1747
+ // See https://github.com/mozilla/source-map/issues/16
1748
+ throw new Error('Support for url field in sections not implemented.');
1749
+ }
1750
+ var offset = util.getArg(s, 'offset');
1751
+ var offsetLine = util.getArg(offset, 'line');
1752
+ var offsetColumn = util.getArg(offset, 'column');
1753
+
1754
+ if (offsetLine < lastOffset.line ||
1755
+ (offsetLine === lastOffset.line && offsetColumn < lastOffset.column)) {
1756
+ throw new Error('Section offsets must be ordered and non-overlapping.');
1757
+ }
1758
+ lastOffset = offset;
1759
+
1760
+ return {
1761
+ generatedOffset: {
1762
+ // The offset fields are 0-based, but we use 1-based indices when
1763
+ // encoding/decoding from VLQ.
1764
+ generatedLine: offsetLine + 1,
1765
+ generatedColumn: offsetColumn + 1
1766
+ },
1767
+ consumer: new SourceMapConsumer(util.getArg(s, 'map'))
1768
+ }
1769
+ });
1770
+ }
1771
+
1772
+ IndexedSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);
1773
+ IndexedSourceMapConsumer.prototype.constructor = SourceMapConsumer;
1774
+
1775
+ /**
1776
+ * The version of the source mapping spec that we are consuming.
1777
+ */
1778
+ IndexedSourceMapConsumer.prototype._version = 3;
1779
+
1780
+ /**
1781
+ * The list of original sources.
1782
+ */
1783
+ Object.defineProperty(IndexedSourceMapConsumer.prototype, 'sources', {
1784
+ get: function () {
1785
+ var sources = [];
1786
+ for (var i = 0; i < this._sections.length; i++) {
1787
+ for (var j = 0; j < this._sections[i].consumer.sources.length; j++) {
1788
+ sources.push(this._sections[i].consumer.sources[j]);
1789
+ }
1790
+ }
1791
+ return sources;
1792
+ }
1793
+ });
1794
+
1795
+ /**
1796
+ * Returns the original source, line, and column information for the generated
1797
+ * source's line and column positions provided. The only argument is an object
1798
+ * with the following properties:
1799
+ *
1800
+ * - line: The line number in the generated source.
1801
+ * - column: The column number in the generated source.
1802
+ *
1803
+ * and an object is returned with the following properties:
1804
+ *
1805
+ * - source: The original source file, or null.
1806
+ * - line: The line number in the original source, or null.
1807
+ * - column: The column number in the original source, or null.
1808
+ * - name: The original identifier, or null.
1809
+ */
1810
+ IndexedSourceMapConsumer.prototype.originalPositionFor =
1811
+ function IndexedSourceMapConsumer_originalPositionFor(aArgs) {
1812
+ var needle = {
1813
+ generatedLine: util.getArg(aArgs, 'line'),
1814
+ generatedColumn: util.getArg(aArgs, 'column')
1815
+ };
1816
+
1817
+ // Find the section containing the generated position we're trying to map
1818
+ // to an original position.
1819
+ var sectionIndex = binarySearch.search(needle, this._sections,
1820
+ function(needle, section) {
1821
+ var cmp = needle.generatedLine - section.generatedOffset.generatedLine;
1822
+ if (cmp) {
1823
+ return cmp;
1824
+ }
1825
+
1826
+ return (needle.generatedColumn -
1827
+ section.generatedOffset.generatedColumn);
1828
+ });
1829
+ var section = this._sections[sectionIndex];
1830
+
1831
+ if (!section) {
1832
+ return {
1833
+ source: null,
1834
+ line: null,
1835
+ column: null,
1836
+ name: null
1837
+ };
1838
+ }
1839
+
1840
+ return section.consumer.originalPositionFor({
1841
+ line: needle.generatedLine -
1842
+ (section.generatedOffset.generatedLine - 1),
1843
+ column: needle.generatedColumn -
1844
+ (section.generatedOffset.generatedLine === needle.generatedLine
1845
+ ? section.generatedOffset.generatedColumn - 1
1846
+ : 0),
1847
+ bias: aArgs.bias
1848
+ });
1849
+ };
1850
+
1851
+ /**
1852
+ * Return true if we have the source content for every source in the source
1853
+ * map, false otherwise.
1854
+ */
1855
+ IndexedSourceMapConsumer.prototype.hasContentsOfAllSources =
1856
+ function IndexedSourceMapConsumer_hasContentsOfAllSources() {
1857
+ return this._sections.every(function (s) {
1858
+ return s.consumer.hasContentsOfAllSources();
1859
+ });
1860
+ };
1861
+
1862
+ /**
1863
+ * Returns the original source content. The only argument is the url of the
1864
+ * original source file. Returns null if no original source content is
1865
+ * available.
1866
+ */
1867
+ IndexedSourceMapConsumer.prototype.sourceContentFor =
1868
+ function IndexedSourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {
1869
+ for (var i = 0; i < this._sections.length; i++) {
1870
+ var section = this._sections[i];
1871
+
1872
+ var content = section.consumer.sourceContentFor(aSource, true);
1873
+ if (content) {
1874
+ return content;
1875
+ }
1876
+ }
1877
+ if (nullOnMissing) {
1878
+ return null;
1879
+ }
1880
+ else {
1881
+ throw new Error('"' + aSource + '" is not in the SourceMap.');
1882
+ }
1883
+ };
1884
+
1885
+ /**
1886
+ * Returns the generated line and column information for the original source,
1887
+ * line, and column positions provided. The only argument is an object with
1888
+ * the following properties:
1889
+ *
1890
+ * - source: The filename of the original source.
1891
+ * - line: The line number in the original source.
1892
+ * - column: The column number in the original source.
1893
+ *
1894
+ * and an object is returned with the following properties:
1895
+ *
1896
+ * - line: The line number in the generated source, or null.
1897
+ * - column: The column number in the generated source, or null.
1898
+ */
1899
+ IndexedSourceMapConsumer.prototype.generatedPositionFor =
1900
+ function IndexedSourceMapConsumer_generatedPositionFor(aArgs) {
1901
+ for (var i = 0; i < this._sections.length; i++) {
1902
+ var section = this._sections[i];
1903
+
1904
+ // Only consider this section if the requested source is in the list of
1905
+ // sources of the consumer.
1906
+ if (section.consumer.sources.indexOf(util.getArg(aArgs, 'source')) === -1) {
1907
+ continue;
1908
+ }
1909
+ var generatedPosition = section.consumer.generatedPositionFor(aArgs);
1910
+ if (generatedPosition) {
1911
+ var ret = {
1912
+ line: generatedPosition.line +
1913
+ (section.generatedOffset.generatedLine - 1),
1914
+ column: generatedPosition.column +
1915
+ (section.generatedOffset.generatedLine === generatedPosition.line
1916
+ ? section.generatedOffset.generatedColumn - 1
1917
+ : 0)
1918
+ };
1919
+ return ret;
1920
+ }
1921
+ }
1922
+
1923
+ return {
1924
+ line: null,
1925
+ column: null
1926
+ };
1927
+ };
1928
+
1929
+ /**
1930
+ * Parse the mappings in a string in to a data structure which we can easily
1931
+ * query (the ordered arrays in the `this.__generatedMappings` and
1932
+ * `this.__originalMappings` properties).
1933
+ */
1934
+ IndexedSourceMapConsumer.prototype._parseMappings =
1935
+ function IndexedSourceMapConsumer_parseMappings(aStr, aSourceRoot) {
1936
+ this.__generatedMappings = [];
1937
+ this.__originalMappings = [];
1938
+ for (var i = 0; i < this._sections.length; i++) {
1939
+ var section = this._sections[i];
1940
+ var sectionMappings = section.consumer._generatedMappings;
1941
+ for (var j = 0; j < sectionMappings.length; j++) {
1942
+ var mapping = sectionMappings[j];
1943
+
1944
+ var source = section.consumer._sources.at(mapping.source);
1945
+ if (section.consumer.sourceRoot !== null) {
1946
+ source = util.join(section.consumer.sourceRoot, source);
1947
+ }
1948
+ this._sources.add(source);
1949
+ source = this._sources.indexOf(source);
1950
+
1951
+ var name = section.consumer._names.at(mapping.name);
1952
+ this._names.add(name);
1953
+ name = this._names.indexOf(name);
1954
+
1955
+ // The mappings coming from the consumer for the section have
1956
+ // generated positions relative to the start of the section, so we
1957
+ // need to offset them to be relative to the start of the concatenated
1958
+ // generated file.
1959
+ var adjustedMapping = {
1960
+ source: source,
1961
+ generatedLine: mapping.generatedLine +
1962
+ (section.generatedOffset.generatedLine - 1),
1963
+ generatedColumn: mapping.generatedColumn +
1964
+ (section.generatedOffset.generatedLine === mapping.generatedLine
1965
+ ? section.generatedOffset.generatedColumn - 1
1966
+ : 0),
1967
+ originalLine: mapping.originalLine,
1968
+ originalColumn: mapping.originalColumn,
1969
+ name: name
1970
+ };
1971
+
1972
+ this.__generatedMappings.push(adjustedMapping);
1973
+ if (typeof adjustedMapping.originalLine === 'number') {
1974
+ this.__originalMappings.push(adjustedMapping);
1975
+ }
1976
+ }
1977
+ }
1978
+
1979
+ quickSort(this.__generatedMappings, util.compareByGeneratedPositionsDeflated);
1980
+ quickSort(this.__originalMappings, util.compareByOriginalPositions);
1981
+ };
1982
+
1983
+ exports.IndexedSourceMapConsumer = IndexedSourceMapConsumer;
1984
+
1985
+ },{"./array-set":4,"./base64-vlq":5,"./binary-search":7,"./quick-sort":8,"./util":10}],10:[function(require,module,exports){
1986
+ /* -*- Mode: js; js-indent-level: 2; -*- */
1987
+ /*
1988
+ * Copyright 2011 Mozilla Foundation and contributors
1989
+ * Licensed under the New BSD license. See LICENSE or:
1990
+ * http://opensource.org/licenses/BSD-3-Clause
1991
+ */
1992
+
1993
+ /**
1994
+ * This is a helper function for getting values from parameter/options
1995
+ * objects.
1996
+ *
1997
+ * @param args The object we are extracting values from
1998
+ * @param name The name of the property we are getting.
1999
+ * @param defaultValue An optional value to return if the property is missing
2000
+ * from the object. If this is not specified and the property is missing, an
2001
+ * error will be thrown.
2002
+ */
2003
+ function getArg(aArgs, aName, aDefaultValue) {
2004
+ if (aName in aArgs) {
2005
+ return aArgs[aName];
2006
+ } else if (arguments.length === 3) {
2007
+ return aDefaultValue;
2008
+ } else {
2009
+ throw new Error('"' + aName + '" is a required argument.');
2010
+ }
2011
+ }
2012
+ exports.getArg = getArg;
2013
+
2014
+ var urlRegexp = /^(?:([\w+\-.]+):)?\/\/(?:(\w+:\w+)@)?([\w.]*)(?::(\d+))?(\S*)$/;
2015
+ var dataUrlRegexp = /^data:.+\,.+$/;
2016
+
2017
+ function urlParse(aUrl) {
2018
+ var match = aUrl.match(urlRegexp);
2019
+ if (!match) {
2020
+ return null;
2021
+ }
2022
+ return {
2023
+ scheme: match[1],
2024
+ auth: match[2],
2025
+ host: match[3],
2026
+ port: match[4],
2027
+ path: match[5]
2028
+ };
2029
+ }
2030
+ exports.urlParse = urlParse;
2031
+
2032
+ function urlGenerate(aParsedUrl) {
2033
+ var url = '';
2034
+ if (aParsedUrl.scheme) {
2035
+ url += aParsedUrl.scheme + ':';
2036
+ }
2037
+ url += '//';
2038
+ if (aParsedUrl.auth) {
2039
+ url += aParsedUrl.auth + '@';
2040
+ }
2041
+ if (aParsedUrl.host) {
2042
+ url += aParsedUrl.host;
2043
+ }
2044
+ if (aParsedUrl.port) {
2045
+ url += ":" + aParsedUrl.port
2046
+ }
2047
+ if (aParsedUrl.path) {
2048
+ url += aParsedUrl.path;
2049
+ }
2050
+ return url;
2051
+ }
2052
+ exports.urlGenerate = urlGenerate;
2053
+
2054
+ /**
2055
+ * Normalizes a path, or the path portion of a URL:
2056
+ *
2057
+ * - Replaces consecutive slashes with one slash.
2058
+ * - Removes unnecessary '.' parts.
2059
+ * - Removes unnecessary '<dir>/..' parts.
2060
+ *
2061
+ * Based on code in the Node.js 'path' core module.
2062
+ *
2063
+ * @param aPath The path or url to normalize.
2064
+ */
2065
+ function normalize(aPath) {
2066
+ var path = aPath;
2067
+ var url = urlParse(aPath);
2068
+ if (url) {
2069
+ if (!url.path) {
2070
+ return aPath;
2071
+ }
2072
+ path = url.path;
2073
+ }
2074
+ var isAbsolute = exports.isAbsolute(path);
2075
+
2076
+ var parts = path.split(/\/+/);
2077
+ for (var part, up = 0, i = parts.length - 1; i >= 0; i--) {
2078
+ part = parts[i];
2079
+ if (part === '.') {
2080
+ parts.splice(i, 1);
2081
+ } else if (part === '..') {
2082
+ up++;
2083
+ } else if (up > 0) {
2084
+ if (part === '') {
2085
+ // The first part is blank if the path is absolute. Trying to go
2086
+ // above the root is a no-op. Therefore we can remove all '..' parts
2087
+ // directly after the root.
2088
+ parts.splice(i + 1, up);
2089
+ up = 0;
2090
+ } else {
2091
+ parts.splice(i, 2);
2092
+ up--;
2093
+ }
2094
+ }
2095
+ }
2096
+ path = parts.join('/');
2097
+
2098
+ if (path === '') {
2099
+ path = isAbsolute ? '/' : '.';
2100
+ }
2101
+
2102
+ if (url) {
2103
+ url.path = path;
2104
+ return urlGenerate(url);
2105
+ }
2106
+ return path;
2107
+ }
2108
+ exports.normalize = normalize;
2109
+
2110
+ /**
2111
+ * Joins two paths/URLs.
2112
+ *
2113
+ * @param aRoot The root path or URL.
2114
+ * @param aPath The path or URL to be joined with the root.
2115
+ *
2116
+ * - If aPath is a URL or a data URI, aPath is returned, unless aPath is a
2117
+ * scheme-relative URL: Then the scheme of aRoot, if any, is prepended
2118
+ * first.
2119
+ * - Otherwise aPath is a path. If aRoot is a URL, then its path portion
2120
+ * is updated with the result and aRoot is returned. Otherwise the result
2121
+ * is returned.
2122
+ * - If aPath is absolute, the result is aPath.
2123
+ * - Otherwise the two paths are joined with a slash.
2124
+ * - Joining for example 'http://' and 'www.example.com' is also supported.
2125
+ */
2126
+ function join(aRoot, aPath) {
2127
+ if (aRoot === "") {
2128
+ aRoot = ".";
2129
+ }
2130
+ if (aPath === "") {
2131
+ aPath = ".";
2132
+ }
2133
+ var aPathUrl = urlParse(aPath);
2134
+ var aRootUrl = urlParse(aRoot);
2135
+ if (aRootUrl) {
2136
+ aRoot = aRootUrl.path || '/';
2137
+ }
2138
+
2139
+ // `join(foo, '//www.example.org')`
2140
+ if (aPathUrl && !aPathUrl.scheme) {
2141
+ if (aRootUrl) {
2142
+ aPathUrl.scheme = aRootUrl.scheme;
2143
+ }
2144
+ return urlGenerate(aPathUrl);
2145
+ }
2146
+
2147
+ if (aPathUrl || aPath.match(dataUrlRegexp)) {
2148
+ return aPath;
2149
+ }
2150
+
2151
+ // `join('http://', 'www.example.com')`
2152
+ if (aRootUrl && !aRootUrl.host && !aRootUrl.path) {
2153
+ aRootUrl.host = aPath;
2154
+ return urlGenerate(aRootUrl);
2155
+ }
2156
+
2157
+ var joined = aPath.charAt(0) === '/'
2158
+ ? aPath
2159
+ : normalize(aRoot.replace(/\/+$/, '') + '/' + aPath);
2160
+
2161
+ if (aRootUrl) {
2162
+ aRootUrl.path = joined;
2163
+ return urlGenerate(aRootUrl);
2164
+ }
2165
+ return joined;
2166
+ }
2167
+ exports.join = join;
2168
+
2169
+ exports.isAbsolute = function (aPath) {
2170
+ return aPath.charAt(0) === '/' || !!aPath.match(urlRegexp);
2171
+ };
2172
+
2173
+ /**
2174
+ * Make a path relative to a URL or another path.
2175
+ *
2176
+ * @param aRoot The root path or URL.
2177
+ * @param aPath The path or URL to be made relative to aRoot.
2178
+ */
2179
+ function relative(aRoot, aPath) {
2180
+ if (aRoot === "") {
2181
+ aRoot = ".";
2182
+ }
2183
+
2184
+ aRoot = aRoot.replace(/\/$/, '');
2185
+
2186
+ // It is possible for the path to be above the root. In this case, simply
2187
+ // checking whether the root is a prefix of the path won't work. Instead, we
2188
+ // need to remove components from the root one by one, until either we find
2189
+ // a prefix that fits, or we run out of components to remove.
2190
+ var level = 0;
2191
+ while (aPath.indexOf(aRoot + '/') !== 0) {
2192
+ var index = aRoot.lastIndexOf("/");
2193
+ if (index < 0) {
2194
+ return aPath;
2195
+ }
2196
+
2197
+ // If the only part of the root that is left is the scheme (i.e. http://,
2198
+ // file:///, etc.), one or more slashes (/), or simply nothing at all, we
2199
+ // have exhausted all components, so the path is not relative to the root.
2200
+ aRoot = aRoot.slice(0, index);
2201
+ if (aRoot.match(/^([^\/]+:\/)?\/*$/)) {
2202
+ return aPath;
2203
+ }
2204
+
2205
+ ++level;
2206
+ }
2207
+
2208
+ // Make sure we add a "../" for each component we removed from the root.
2209
+ return Array(level + 1).join("../") + aPath.substr(aRoot.length + 1);
2210
+ }
2211
+ exports.relative = relative;
2212
+
2213
+ var supportsNullProto = (function () {
2214
+ var obj = Object.create(null);
2215
+ return !('__proto__' in obj);
2216
+ }());
2217
+
2218
+ function identity (s) {
2219
+ return s;
2220
+ }
2221
+
2222
+ /**
2223
+ * Because behavior goes wacky when you set `__proto__` on objects, we
2224
+ * have to prefix all the strings in our set with an arbitrary character.
2225
+ *
2226
+ * See https://github.com/mozilla/source-map/pull/31 and
2227
+ * https://github.com/mozilla/source-map/issues/30
2228
+ *
2229
+ * @param String aStr
2230
+ */
2231
+ function toSetString(aStr) {
2232
+ if (isProtoString(aStr)) {
2233
+ return '$' + aStr;
2234
+ }
2235
+
2236
+ return aStr;
2237
+ }
2238
+ exports.toSetString = supportsNullProto ? identity : toSetString;
2239
+
2240
+ function fromSetString(aStr) {
2241
+ if (isProtoString(aStr)) {
2242
+ return aStr.slice(1);
2243
+ }
2244
+
2245
+ return aStr;
2246
+ }
2247
+ exports.fromSetString = supportsNullProto ? identity : fromSetString;
2248
+
2249
+ function isProtoString(s) {
2250
+ if (!s) {
2251
+ return false;
2252
+ }
2253
+
2254
+ var length = s.length;
2255
+
2256
+ if (length < 9 /* "__proto__".length */) {
2257
+ return false;
2258
+ }
2259
+
2260
+ if (s.charCodeAt(length - 1) !== 95 /* '_' */ ||
2261
+ s.charCodeAt(length - 2) !== 95 /* '_' */ ||
2262
+ s.charCodeAt(length - 3) !== 111 /* 'o' */ ||
2263
+ s.charCodeAt(length - 4) !== 116 /* 't' */ ||
2264
+ s.charCodeAt(length - 5) !== 111 /* 'o' */ ||
2265
+ s.charCodeAt(length - 6) !== 114 /* 'r' */ ||
2266
+ s.charCodeAt(length - 7) !== 112 /* 'p' */ ||
2267
+ s.charCodeAt(length - 8) !== 95 /* '_' */ ||
2268
+ s.charCodeAt(length - 9) !== 95 /* '_' */) {
2269
+ return false;
2270
+ }
2271
+
2272
+ for (var i = length - 10; i >= 0; i--) {
2273
+ if (s.charCodeAt(i) !== 36 /* '$' */) {
2274
+ return false;
2275
+ }
2276
+ }
2277
+
2278
+ return true;
2279
+ }
2280
+
2281
+ /**
2282
+ * Comparator between two mappings where the original positions are compared.
2283
+ *
2284
+ * Optionally pass in `true` as `onlyCompareGenerated` to consider two
2285
+ * mappings with the same original source/line/column, but different generated
2286
+ * line and column the same. Useful when searching for a mapping with a
2287
+ * stubbed out mapping.
2288
+ */
2289
+ function compareByOriginalPositions(mappingA, mappingB, onlyCompareOriginal) {
2290
+ var cmp = mappingA.source - mappingB.source;
2291
+ if (cmp !== 0) {
2292
+ return cmp;
2293
+ }
2294
+
2295
+ cmp = mappingA.originalLine - mappingB.originalLine;
2296
+ if (cmp !== 0) {
2297
+ return cmp;
2298
+ }
2299
+
2300
+ cmp = mappingA.originalColumn - mappingB.originalColumn;
2301
+ if (cmp !== 0 || onlyCompareOriginal) {
2302
+ return cmp;
2303
+ }
2304
+
2305
+ cmp = mappingA.generatedColumn - mappingB.generatedColumn;
2306
+ if (cmp !== 0) {
2307
+ return cmp;
2308
+ }
2309
+
2310
+ cmp = mappingA.generatedLine - mappingB.generatedLine;
2311
+ if (cmp !== 0) {
2312
+ return cmp;
2313
+ }
2314
+
2315
+ return mappingA.name - mappingB.name;
2316
+ }
2317
+ exports.compareByOriginalPositions = compareByOriginalPositions;
2318
+
2319
+ /**
2320
+ * Comparator between two mappings with deflated source and name indices where
2321
+ * the generated positions are compared.
2322
+ *
2323
+ * Optionally pass in `true` as `onlyCompareGenerated` to consider two
2324
+ * mappings with the same generated line and column, but different
2325
+ * source/name/original line and column the same. Useful when searching for a
2326
+ * mapping with a stubbed out mapping.
2327
+ */
2328
+ function compareByGeneratedPositionsDeflated(mappingA, mappingB, onlyCompareGenerated) {
2329
+ var cmp = mappingA.generatedLine - mappingB.generatedLine;
2330
+ if (cmp !== 0) {
2331
+ return cmp;
2332
+ }
2333
+
2334
+ cmp = mappingA.generatedColumn - mappingB.generatedColumn;
2335
+ if (cmp !== 0 || onlyCompareGenerated) {
2336
+ return cmp;
2337
+ }
2338
+
2339
+ cmp = mappingA.source - mappingB.source;
2340
+ if (cmp !== 0) {
2341
+ return cmp;
2342
+ }
2343
+
2344
+ cmp = mappingA.originalLine - mappingB.originalLine;
2345
+ if (cmp !== 0) {
2346
+ return cmp;
2347
+ }
2348
+
2349
+ cmp = mappingA.originalColumn - mappingB.originalColumn;
2350
+ if (cmp !== 0) {
2351
+ return cmp;
2352
+ }
2353
+
2354
+ return mappingA.name - mappingB.name;
2355
+ }
2356
+ exports.compareByGeneratedPositionsDeflated = compareByGeneratedPositionsDeflated;
2357
+
2358
+ function strcmp(aStr1, aStr2) {
2359
+ if (aStr1 === aStr2) {
2360
+ return 0;
2361
+ }
2362
+
2363
+ if (aStr1 > aStr2) {
2364
+ return 1;
2365
+ }
2366
+
2367
+ return -1;
2368
+ }
2369
+
2370
+ /**
2371
+ * Comparator between two mappings with inflated source and name strings where
2372
+ * the generated positions are compared.
2373
+ */
2374
+ function compareByGeneratedPositionsInflated(mappingA, mappingB) {
2375
+ var cmp = mappingA.generatedLine - mappingB.generatedLine;
2376
+ if (cmp !== 0) {
2377
+ return cmp;
2378
+ }
2379
+
2380
+ cmp = mappingA.generatedColumn - mappingB.generatedColumn;
2381
+ if (cmp !== 0) {
2382
+ return cmp;
2383
+ }
2384
+
2385
+ cmp = strcmp(mappingA.source, mappingB.source);
2386
+ if (cmp !== 0) {
2387
+ return cmp;
2388
+ }
2389
+
2390
+ cmp = mappingA.originalLine - mappingB.originalLine;
2391
+ if (cmp !== 0) {
2392
+ return cmp;
2393
+ }
2394
+
2395
+ cmp = mappingA.originalColumn - mappingB.originalColumn;
2396
+ if (cmp !== 0) {
2397
+ return cmp;
2398
+ }
2399
+
2400
+ return strcmp(mappingA.name, mappingB.name);
2401
+ }
2402
+ exports.compareByGeneratedPositionsInflated = compareByGeneratedPositionsInflated;
2403
+
2404
+ },{}],11:[function(require,module,exports){
2405
+ (function(root, factory) {
2406
+ 'use strict';
2407
+ // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.
2408
+
2409
+ /* istanbul ignore next */
2410
+ if (typeof define === 'function' && define.amd) {
2411
+ define('stacktrace-gps', ['source-map', 'stackframe'], factory);
2412
+ } else if (typeof exports === 'object') {
2413
+ module.exports = factory(require('source-map/lib/source-map-consumer'), require('stackframe'));
2414
+ } else {
2415
+ root.StackTraceGPS = factory(root.SourceMap || root.sourceMap, root.StackFrame);
2416
+ }
2417
+ }(this, function(SourceMap, StackFrame) {
2418
+ 'use strict';
2419
+
2420
+ /**
2421
+ * Make a X-Domain request to url and callback.
2422
+ *
2423
+ * @param {String} url
2424
+ * @returns {Promise} with response text if fulfilled
2425
+ */
2426
+ function _xdr(url) {
2427
+ return new Promise(function(resolve, reject) {
2428
+ var req = new XMLHttpRequest();
2429
+ req.open('get', url);
2430
+ req.onerror = reject;
2431
+ req.onreadystatechange = function onreadystatechange() {
2432
+ if (req.readyState === 4) {
2433
+ if ((req.status >= 200 && req.status < 300) ||
2434
+ (url.substr(0, 7) === 'file://' && req.responseText)) {
2435
+ resolve(req.responseText);
2436
+ } else {
2437
+ reject(new Error('HTTP status: ' + req.status + ' retrieving ' + url));
2438
+ }
2439
+ }
2440
+ };
2441
+ req.send();
2442
+ });
2443
+
2444
+ }
2445
+
2446
+ /**
2447
+ * Convert a Base64-encoded string into its original representation.
2448
+ * Used for inline sourcemaps.
2449
+ *
2450
+ * @param {String} b64str Base-64 encoded string
2451
+ * @returns {String} original representation of the base64-encoded string.
2452
+ */
2453
+ function _atob(b64str) {
2454
+ if (typeof window !== 'undefined' && window.atob) {
2455
+ return window.atob(b64str);
2456
+ } else {
2457
+ throw new Error('You must supply a polyfill for window.atob in this environment');
2458
+ }
2459
+ }
2460
+
2461
+ function _parseJson(string) {
2462
+ if (typeof JSON !== 'undefined' && JSON.parse) {
2463
+ return JSON.parse(string);
2464
+ } else {
2465
+ throw new Error('You must supply a polyfill for JSON.parse in this environment');
2466
+ }
2467
+ }
2468
+
2469
+ function _findFunctionName(source, lineNumber/*, columnNumber*/) {
2470
+ var syntaxes = [
2471
+ // {name} = function ({args}) TODO args capture
2472
+ /['"]?([$_A-Za-z][$_A-Za-z0-9]*)['"]?\s*[:=]\s*function\b/,
2473
+ // function {name}({args}) m[1]=name m[2]=args
2474
+ /function\s+([^('"`]*?)\s*\(([^)]*)\)/,
2475
+ // {name} = eval()
2476
+ /['"]?([$_A-Za-z][$_A-Za-z0-9]*)['"]?\s*[:=]\s*(?:eval|new Function)\b/,
2477
+ // fn_name() {
2478
+ /\b(?!(?:if|for|switch|while|with|catch)\b)(?:(?:static)\s+)?(\S+)\s*\(.*?\)\s*\{/,
2479
+ // {name} = () => {
2480
+ /['"]?([$_A-Za-z][$_A-Za-z0-9]*)['"]?\s*[:=]\s*\(.*?\)\s*=>/
2481
+ ];
2482
+ var lines = source.split('\n');
2483
+
2484
+ // Walk backwards in the source lines until we find the line which matches one of the patterns above
2485
+ var code = '';
2486
+ var maxLines = Math.min(lineNumber, 20);
2487
+ for (var i = 0; i < maxLines; ++i) {
2488
+ // lineNo is 1-based, source[] is 0-based
2489
+ var line = lines[lineNumber - i - 1];
2490
+ var commentPos = line.indexOf('//');
2491
+ if (commentPos >= 0) {
2492
+ line = line.substr(0, commentPos);
2493
+ }
2494
+
2495
+ if (line) {
2496
+ code = line + code;
2497
+ var len = syntaxes.length;
2498
+ for (var index = 0; index < len; index++) {
2499
+ var m = syntaxes[index].exec(code);
2500
+ if (m && m[1]) {
2501
+ return m[1];
2502
+ }
2503
+ }
2504
+ }
2505
+ }
2506
+ return undefined;
2507
+ }
2508
+
2509
+ function _ensureSupportedEnvironment() {
2510
+ if (typeof Object.defineProperty !== 'function' || typeof Object.create !== 'function') {
2511
+ throw new Error('Unable to consume source maps in older browsers');
2512
+ }
2513
+ }
2514
+
2515
+ function _ensureStackFrameIsLegit(stackframe) {
2516
+ if (typeof stackframe !== 'object') {
2517
+ throw new TypeError('Given StackFrame is not an object');
2518
+ } else if (typeof stackframe.fileName !== 'string') {
2519
+ throw new TypeError('Given file name is not a String');
2520
+ } else if (typeof stackframe.lineNumber !== 'number' ||
2521
+ stackframe.lineNumber % 1 !== 0 ||
2522
+ stackframe.lineNumber < 1) {
2523
+ throw new TypeError('Given line number must be a positive integer');
2524
+ } else if (typeof stackframe.columnNumber !== 'number' ||
2525
+ stackframe.columnNumber % 1 !== 0 ||
2526
+ stackframe.columnNumber < 0) {
2527
+ throw new TypeError('Given column number must be a non-negative integer');
2528
+ }
2529
+ return true;
2530
+ }
2531
+
2532
+ function _findSourceMappingURL(source) {
2533
+ var sourceMappingUrlRegExp = /\/\/[#@] ?sourceMappingURL=([^\s'"]+)\s*$/mg;
2534
+ var lastSourceMappingUrl;
2535
+ var matchSourceMappingUrl;
2536
+ while (matchSourceMappingUrl = sourceMappingUrlRegExp.exec(source)) { // jshint ignore:line
2537
+ lastSourceMappingUrl = matchSourceMappingUrl[1];
2538
+ }
2539
+ if (lastSourceMappingUrl) {
2540
+ return lastSourceMappingUrl;
2541
+ } else {
2542
+ throw new Error('sourceMappingURL not found');
2543
+ }
2544
+ }
2545
+
2546
+ function _extractLocationInfoFromSourceMapSource(stackframe, sourceMapConsumer, sourceCache) {
2547
+ return new Promise(function(resolve, reject) {
2548
+ var loc = sourceMapConsumer.originalPositionFor({
2549
+ line: stackframe.lineNumber,
2550
+ column: stackframe.columnNumber
2551
+ });
2552
+
2553
+ if (loc.source) {
2554
+ // cache mapped sources
2555
+ var mappedSource = sourceMapConsumer.sourceContentFor(loc.source);
2556
+ if (mappedSource) {
2557
+ sourceCache[loc.source] = mappedSource;
2558
+ }
2559
+
2560
+ resolve(
2561
+ // given stackframe and source location, update stackframe
2562
+ new StackFrame({
2563
+ functionName: loc.name || stackframe.functionName,
2564
+ args: stackframe.args,
2565
+ fileName: loc.source,
2566
+ lineNumber: loc.line,
2567
+ columnNumber: loc.column
2568
+ }));
2569
+ } else {
2570
+ reject(new Error('Could not get original source for given stackframe and source map'));
2571
+ }
2572
+ });
2573
+ }
2574
+
2575
+ /**
2576
+ * @constructor
2577
+ * @param {Object} opts
2578
+ * opts.sourceCache = {url: "Source String"} => preload source cache
2579
+ * opts.sourceMapConsumerCache = {/path/file.js.map: SourceMapConsumer}
2580
+ * opts.offline = True to prevent network requests.
2581
+ * Best effort without sources or source maps.
2582
+ * opts.ajax = Promise returning function to make X-Domain requests
2583
+ */
2584
+ return function StackTraceGPS(opts) {
2585
+ if (!(this instanceof StackTraceGPS)) {
2586
+ return new StackTraceGPS(opts);
2587
+ }
2588
+ opts = opts || {};
2589
+
2590
+ this.sourceCache = opts.sourceCache || {};
2591
+ this.sourceMapConsumerCache = opts.sourceMapConsumerCache || {};
2592
+
2593
+ this.ajax = opts.ajax || _xdr;
2594
+
2595
+ this._atob = opts.atob || _atob;
2596
+
2597
+ this._get = function _get(location) {
2598
+ return new Promise(function(resolve, reject) {
2599
+ var isDataUrl = location.substr(0, 5) === 'data:';
2600
+ if (this.sourceCache[location]) {
2601
+ resolve(this.sourceCache[location]);
2602
+ } else if (opts.offline && !isDataUrl) {
2603
+ reject(new Error('Cannot make network requests in offline mode'));
2604
+ } else {
2605
+ if (isDataUrl) {
2606
+ // data URLs can have parameters.
2607
+ // see http://tools.ietf.org/html/rfc2397
2608
+ var supportedEncodingRegexp =
2609
+ /^data:application\/json;([\w=:"-]+;)*base64,/;
2610
+ var match = location.match(supportedEncodingRegexp);
2611
+ if (match) {
2612
+ var sourceMapStart = match[0].length;
2613
+ var encodedSource = location.substr(sourceMapStart);
2614
+ var source = this._atob(encodedSource);
2615
+ this.sourceCache[location] = source;
2616
+ resolve(source);
2617
+ } else {
2618
+ reject(new Error('The encoding of the inline sourcemap is not supported'));
2619
+ }
2620
+ } else {
2621
+ var xhrPromise = this.ajax(location, {method: 'get'});
2622
+ // Cache the Promise to prevent duplicate in-flight requests
2623
+ this.sourceCache[location] = xhrPromise;
2624
+ xhrPromise.then(resolve, reject);
2625
+ }
2626
+ }
2627
+ }.bind(this));
2628
+ };
2629
+
2630
+ /**
2631
+ * Creating SourceMapConsumers is expensive, so this wraps the creation of a
2632
+ * SourceMapConsumer in a per-instance cache.
2633
+ *
2634
+ * @param {String} sourceMappingURL = URL to fetch source map from
2635
+ * @param {String} defaultSourceRoot = Default source root for source map if undefined
2636
+ * @returns {Promise} that resolves a SourceMapConsumer
2637
+ */
2638
+ this._getSourceMapConsumer = function _getSourceMapConsumer(sourceMappingURL, defaultSourceRoot) {
2639
+ return new Promise(function(resolve, reject) {
2640
+ if (this.sourceMapConsumerCache[sourceMappingURL]) {
2641
+ resolve(this.sourceMapConsumerCache[sourceMappingURL]);
2642
+ } else {
2643
+ var sourceMapConsumerPromise = new Promise(function(resolve, reject) {
2644
+ return this._get(sourceMappingURL).then(function(sourceMapSource) {
2645
+ if (typeof sourceMapSource === 'string') {
2646
+ sourceMapSource = _parseJson(sourceMapSource.replace(/^\)\]\}'/, ''));
2647
+ }
2648
+ if (typeof sourceMapSource.sourceRoot === 'undefined') {
2649
+ sourceMapSource.sourceRoot = defaultSourceRoot;
2650
+ }
2651
+
2652
+ resolve(new SourceMap.SourceMapConsumer(sourceMapSource));
2653
+ }, reject);
2654
+ }.bind(this));
2655
+ this.sourceMapConsumerCache[sourceMappingURL] = sourceMapConsumerPromise;
2656
+ resolve(sourceMapConsumerPromise);
2657
+ }
2658
+ }.bind(this));
2659
+ };
2660
+
2661
+ /**
2662
+ * Given a StackFrame, enhance function name and use source maps for a
2663
+ * better StackFrame.
2664
+ *
2665
+ * @param {StackFrame} stackframe object
2666
+ * @returns {Promise} that resolves with with source-mapped StackFrame
2667
+ */
2668
+ this.pinpoint = function StackTraceGPS$$pinpoint(stackframe) {
2669
+ return new Promise(function(resolve, reject) {
2670
+ this.getMappedLocation(stackframe).then(function(mappedStackFrame) {
2671
+ function resolveMappedStackFrame() {
2672
+ resolve(mappedStackFrame);
2673
+ }
2674
+
2675
+ this.findFunctionName(mappedStackFrame)
2676
+ .then(resolve, resolveMappedStackFrame)
2677
+ ['catch'](resolveMappedStackFrame);
2678
+ }.bind(this), reject);
2679
+ }.bind(this));
2680
+ };
2681
+
2682
+ /**
2683
+ * Given a StackFrame, guess function name from location information.
2684
+ *
2685
+ * @param {StackFrame} stackframe
2686
+ * @returns {Promise} that resolves with enhanced StackFrame.
2687
+ */
2688
+ this.findFunctionName = function StackTraceGPS$$findFunctionName(stackframe) {
2689
+ return new Promise(function(resolve, reject) {
2690
+ _ensureStackFrameIsLegit(stackframe);
2691
+ this._get(stackframe.fileName).then(function getSourceCallback(source) {
2692
+ var lineNumber = stackframe.lineNumber;
2693
+ var columnNumber = stackframe.columnNumber;
2694
+ var guessedFunctionName = _findFunctionName(source, lineNumber, columnNumber);
2695
+ // Only replace functionName if we found something
2696
+ if (guessedFunctionName) {
2697
+ resolve(new StackFrame({
2698
+ functionName: guessedFunctionName,
2699
+ args: stackframe.args,
2700
+ fileName: stackframe.fileName,
2701
+ lineNumber: lineNumber,
2702
+ columnNumber: columnNumber
2703
+ }));
2704
+ } else {
2705
+ resolve(stackframe);
2706
+ }
2707
+ }, reject)['catch'](reject);
2708
+ }.bind(this));
2709
+ };
2710
+
2711
+ /**
2712
+ * Given a StackFrame, seek source-mapped location and return new enhanced StackFrame.
2713
+ *
2714
+ * @param {StackFrame} stackframe
2715
+ * @returns {Promise} that resolves with enhanced StackFrame.
2716
+ */
2717
+ this.getMappedLocation = function StackTraceGPS$$getMappedLocation(stackframe) {
2718
+ return new Promise(function(resolve, reject) {
2719
+ _ensureSupportedEnvironment();
2720
+ _ensureStackFrameIsLegit(stackframe);
2721
+
2722
+ var sourceCache = this.sourceCache;
2723
+ var fileName = stackframe.fileName;
2724
+ this._get(fileName).then(function(source) {
2725
+ var sourceMappingURL = _findSourceMappingURL(source);
2726
+ var isDataUrl = sourceMappingURL.substr(0, 5) === 'data:';
2727
+ var defaultSourceRoot = fileName.substring(0, fileName.lastIndexOf('/') + 1);
2728
+
2729
+ if (sourceMappingURL[0] !== '/' && !isDataUrl && !(/^https?:\/\/|^\/\//i).test(sourceMappingURL)) {
2730
+ sourceMappingURL = defaultSourceRoot + sourceMappingURL;
2731
+ }
2732
+
2733
+ return this._getSourceMapConsumer(sourceMappingURL, defaultSourceRoot)
2734
+ .then(function(sourceMapConsumer) {
2735
+ return _extractLocationInfoFromSourceMapSource(stackframe, sourceMapConsumer, sourceCache)
2736
+ .then(resolve)['catch'](function() {
2737
+ resolve(stackframe);
2738
+ });
2739
+ });
2740
+ }.bind(this), reject)['catch'](reject);
2741
+ }.bind(this));
2742
+ };
2743
+ };
2744
+ }));
2745
+
2746
+ },{"source-map/lib/source-map-consumer":9,"stackframe":3}],12:[function(require,module,exports){
2747
+ (function(root, factory) {
2748
+ 'use strict';
2749
+ // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.
2750
+
2751
+ /* istanbul ignore next */
2752
+ if (typeof define === 'function' && define.amd) {
2753
+ define('stacktrace', ['error-stack-parser', 'stack-generator', 'stacktrace-gps'], factory);
2754
+ } else if (typeof exports === 'object') {
2755
+ module.exports = factory(require('error-stack-parser'), require('stack-generator'), require('stacktrace-gps'));
2756
+ } else {
2757
+ root.StackTrace = factory(root.ErrorStackParser, root.StackGenerator, root.StackTraceGPS);
2758
+ }
2759
+ }(this, function StackTrace(ErrorStackParser, StackGenerator, StackTraceGPS) {
2760
+ var _options = {
2761
+ filter: function(stackframe) {
2762
+ // Filter out stackframes for this library by default
2763
+ return (stackframe.functionName || '').indexOf('StackTrace$$') === -1 &&
2764
+ (stackframe.functionName || '').indexOf('ErrorStackParser$$') === -1 &&
2765
+ (stackframe.functionName || '').indexOf('StackTraceGPS$$') === -1 &&
2766
+ (stackframe.functionName || '').indexOf('StackGenerator$$') === -1;
2767
+ },
2768
+ sourceCache: {}
2769
+ };
2770
+
2771
+ var _generateError = function StackTrace$$GenerateError() {
2772
+ try {
2773
+ // Error must be thrown to get stack in IE
2774
+ throw new Error();
2775
+ } catch (err) {
2776
+ return err;
2777
+ }
2778
+ };
2779
+
2780
+ /**
2781
+ * Merge 2 given Objects. If a conflict occurs the second object wins.
2782
+ * Does not do deep merges.
2783
+ *
2784
+ * @param {Object} first base object
2785
+ * @param {Object} second overrides
2786
+ * @returns {Object} merged first and second
2787
+ * @private
2788
+ */
2789
+ function _merge(first, second) {
2790
+ var target = {};
2791
+
2792
+ [first, second].forEach(function(obj) {
2793
+ for (var prop in obj) {
2794
+ if (obj.hasOwnProperty(prop)) {
2795
+ target[prop] = obj[prop];
2796
+ }
2797
+ }
2798
+ return target;
2799
+ });
2800
+
2801
+ return target;
2802
+ }
2803
+
2804
+ function _isShapedLikeParsableError(err) {
2805
+ return err.stack || err['opera#sourceloc'];
2806
+ }
2807
+
2808
+ function _filtered(stackframes, filter) {
2809
+ if (typeof filter === 'function') {
2810
+ return stackframes.filter(filter);
2811
+ }
2812
+ return stackframes;
2813
+ }
2814
+
2815
+ return {
2816
+ /**
2817
+ * Get a backtrace from invocation point.
2818
+ *
2819
+ * @param {Object} opts
2820
+ * @returns {Array} of StackFrame
2821
+ */
2822
+ get: function StackTrace$$get(opts) {
2823
+ var err = _generateError();
2824
+ return _isShapedLikeParsableError(err) ? this.fromError(err, opts) : this.generateArtificially(opts);
2825
+ },
2826
+
2827
+ /**
2828
+ * Get a backtrace from invocation point.
2829
+ * IMPORTANT: Does not handle source maps or guess function names!
2830
+ *
2831
+ * @param {Object} opts
2832
+ * @returns {Array} of StackFrame
2833
+ */
2834
+ getSync: function StackTrace$$getSync(opts) {
2835
+ opts = _merge(_options, opts);
2836
+ var err = _generateError();
2837
+ var stack = _isShapedLikeParsableError(err) ? ErrorStackParser.parse(err) : StackGenerator.backtrace(opts);
2838
+ return _filtered(stack, opts.filter);
2839
+ },
2840
+
2841
+ /**
2842
+ * Given an error object, parse it.
2843
+ *
2844
+ * @param {Error} error object
2845
+ * @param {Object} opts
2846
+ * @returns {Promise} for Array[StackFrame}
2847
+ */
2848
+ fromError: function StackTrace$$fromError(error, opts) {
2849
+ opts = _merge(_options, opts);
2850
+ var gps = new StackTraceGPS(opts);
2851
+ return new Promise(function(resolve) {
2852
+ var stackframes = _filtered(ErrorStackParser.parse(error), opts.filter);
2853
+ resolve(Promise.all(stackframes.map(function(sf) {
2854
+ return new Promise(function(resolve) {
2855
+ function resolveOriginal() {
2856
+ resolve(sf);
2857
+ }
2858
+
2859
+ gps.pinpoint(sf).then(resolve, resolveOriginal)['catch'](resolveOriginal);
2860
+ });
2861
+ })));
2862
+ }.bind(this));
2863
+ },
2864
+
2865
+ /**
2866
+ * Use StackGenerator to generate a backtrace.
2867
+ *
2868
+ * @param {Object} opts
2869
+ * @returns {Promise} of Array[StackFrame]
2870
+ */
2871
+ generateArtificially: function StackTrace$$generateArtificially(opts) {
2872
+ opts = _merge(_options, opts);
2873
+ var stackFrames = StackGenerator.backtrace(opts);
2874
+ if (typeof opts.filter === 'function') {
2875
+ stackFrames = stackFrames.filter(opts.filter);
2876
+ }
2877
+ return Promise.resolve(stackFrames);
2878
+ },
2879
+
2880
+ /**
2881
+ * Given a function, wrap it such that invocations trigger a callback that
2882
+ * is called with a stack trace.
2883
+ *
2884
+ * @param {Function} fn to be instrumented
2885
+ * @param {Function} callback function to call with a stack trace on invocation
2886
+ * @param {Function} errback optional function to call with error if unable to get stack trace.
2887
+ * @param {Object} thisArg optional context object (e.g. window)
2888
+ */
2889
+ instrument: function StackTrace$$instrument(fn, callback, errback, thisArg) {
2890
+ if (typeof fn !== 'function') {
2891
+ throw new Error('Cannot instrument non-function object');
2892
+ } else if (typeof fn.__stacktraceOriginalFn === 'function') {
2893
+ // Already instrumented, return given Function
2894
+ return fn;
2895
+ }
2896
+
2897
+ var instrumented = function StackTrace$$instrumented() {
2898
+ try {
2899
+ this.get().then(callback, errback)['catch'](errback);
2900
+ return fn.apply(thisArg || this, arguments);
2901
+ } catch (e) {
2902
+ if (_isShapedLikeParsableError(e)) {
2903
+ this.fromError(e).then(callback, errback)['catch'](errback);
2904
+ }
2905
+ throw e;
2906
+ }
2907
+ }.bind(this);
2908
+ instrumented.__stacktraceOriginalFn = fn;
2909
+
2910
+ return instrumented;
2911
+ },
2912
+
2913
+ /**
2914
+ * Given a function that has been instrumented,
2915
+ * revert the function to it's original (non-instrumented) state.
2916
+ *
2917
+ * @param {Function} fn to de-instrument
2918
+ */
2919
+ deinstrument: function StackTrace$$deinstrument(fn) {
2920
+ if (typeof fn !== 'function') {
2921
+ throw new Error('Cannot de-instrument non-function object');
2922
+ } else if (typeof fn.__stacktraceOriginalFn === 'function') {
2923
+ return fn.__stacktraceOriginalFn;
2924
+ } else {
2925
+ // Function not instrumented, return original
2926
+ return fn;
2927
+ }
2928
+ },
2929
+
2930
+ /**
2931
+ * Given an error message and Array of StackFrames, serialize and POST to given URL.
2932
+ *
2933
+ * @param {Array} stackframes
2934
+ * @param {String} url
2935
+ * @param {String} errorMsg
2936
+ * @param {Object} requestOptions
2937
+ */
2938
+ report: function StackTrace$$report(stackframes, url, errorMsg, requestOptions) {
2939
+ return new Promise(function(resolve, reject) {
2940
+ var req = new XMLHttpRequest();
2941
+ req.onerror = reject;
2942
+ req.onreadystatechange = function onreadystatechange() {
2943
+ if (req.readyState === 4) {
2944
+ if (req.status >= 200 && req.status < 400) {
2945
+ resolve(req.responseText);
2946
+ } else {
2947
+ reject(new Error('POST to ' + url + ' failed with status: ' + req.status));
2948
+ }
2949
+ }
2950
+ };
2951
+ req.open('post', url);
2952
+
2953
+ // Set request headers
2954
+ req.setRequestHeader('Content-Type', 'application/json');
2955
+ if (requestOptions && typeof requestOptions.headers === 'object') {
2956
+ var headers = requestOptions.headers;
2957
+ for (var header in headers) {
2958
+ if (headers.hasOwnProperty(header)) {
2959
+ req.setRequestHeader(header, headers[header]);
2960
+ }
2961
+ }
2962
+ }
2963
+
2964
+ var reportPayload = {stack: stackframes};
2965
+ if (errorMsg !== undefined && errorMsg !== null) {
2966
+ reportPayload.message = errorMsg;
2967
+ }
2968
+
2969
+ req.send(JSON.stringify(reportPayload));
2970
+ });
2971
+ }
2972
+ };
2973
+ }));
2974
+
2975
+ },{"error-stack-parser":1,"stack-generator":2,"stacktrace-gps":11}]},{},[12])(12)
2976
+ });
2977
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","node_modules/error-stack-parser/error-stack-parser.js","node_modules/stack-generator/stack-generator.js","node_modules/stackframe/stackframe.js","node_modules/stacktrace-gps/node_modules/source-map/lib/array-set.js","node_modules/stacktrace-gps/node_modules/source-map/lib/base64-vlq.js","node_modules/stacktrace-gps/node_modules/source-map/lib/base64.js","node_modules/stacktrace-gps/node_modules/source-map/lib/binary-search.js","node_modules/stacktrace-gps/node_modules/source-map/lib/quick-sort.js","node_modules/stacktrace-gps/node_modules/source-map/lib/source-map-consumer.js","node_modules/stacktrace-gps/node_modules/source-map/lib/util.js","node_modules/stacktrace-gps/stacktrace-gps.js","stacktrace.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1jCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjaA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","(function(root, factory) {\n    'use strict';\n    // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.\n\n    /* istanbul ignore next */\n    if (typeof define === 'function' && define.amd) {\n        define('error-stack-parser', ['stackframe'], factory);\n    } else if (typeof exports === 'object') {\n        module.exports = factory(require('stackframe'));\n    } else {\n        root.ErrorStackParser = factory(root.StackFrame);\n    }\n}(this, function ErrorStackParser(StackFrame) {\n    'use strict';\n\n    var FIREFOX_SAFARI_STACK_REGEXP = /(^|@)\\S+\\:\\d+/;\n    var CHROME_IE_STACK_REGEXP = /^\\s*at .*(\\S+\\:\\d+|\\(native\\))/m;\n    var SAFARI_NATIVE_CODE_REGEXP = /^(eval@)?(\\[native code\\])?$/;\n\n    return {\n        /**\n         * Given an Error object, extract the most information from it.\n         *\n         * @param {Error} error object\n         * @return {Array} of StackFrames\n         */\n        parse: function ErrorStackParser$$parse(error) {\n            if (typeof error.stacktrace !== 'undefined' || typeof error['opera#sourceloc'] !== 'undefined') {\n                return this.parseOpera(error);\n            } else if (error.stack && error.stack.match(CHROME_IE_STACK_REGEXP)) {\n                return this.parseV8OrIE(error);\n            } else if (error.stack) {\n                return this.parseFFOrSafari(error);\n            } else {\n                throw new Error('Cannot parse given Error object');\n            }\n        },\n\n        // Separate line and column numbers from a string of the form: (URI:Line:Column)\n        extractLocation: function ErrorStackParser$$extractLocation(urlLike) {\n            // Fail-fast but return locations like \"(native)\"\n            if (urlLike.indexOf(':') === -1) {\n                return [urlLike];\n            }\n\n            var regExp = /(.+?)(?:\\:(\\d+))?(?:\\:(\\d+))?$/;\n            var parts = regExp.exec(urlLike.replace(/[\\(\\)]/g, ''));\n            return [parts[1], parts[2] || undefined, parts[3] || undefined];\n        },\n\n        parseV8OrIE: function ErrorStackParser$$parseV8OrIE(error) {\n            var filtered = error.stack.split('\\n').filter(function(line) {\n                return !!line.match(CHROME_IE_STACK_REGEXP);\n            }, this);\n\n            return filtered.map(function(line) {\n                if (line.indexOf('(eval ') > -1) {\n                    // Throw away eval information until we implement stacktrace.js/stackframe#8\n                    line = line.replace(/eval code/g, 'eval').replace(/(\\(eval at [^\\()]*)|(\\)\\,.*$)/g, '');\n                }\n                var tokens = line.replace(/^\\s+/, '').replace(/\\(eval code/g, '(').split(/\\s+/).slice(1);\n                var locationParts = this.extractLocation(tokens.pop());\n                var functionName = tokens.join(' ') || undefined;\n                var fileName = ['eval', '<anonymous>'].indexOf(locationParts[0]) > -1 ? undefined : locationParts[0];\n\n                return new StackFrame({\n                    functionName: functionName,\n                    fileName: fileName,\n                    lineNumber: locationParts[1],\n                    columnNumber: locationParts[2],\n                    source: line\n                });\n            }, this);\n        },\n\n        parseFFOrSafari: function ErrorStackParser$$parseFFOrSafari(error) {\n            var filtered = error.stack.split('\\n').filter(function(line) {\n                return !line.match(SAFARI_NATIVE_CODE_REGEXP);\n            }, this);\n\n            return filtered.map(function(line) {\n                // Throw away eval information until we implement stacktrace.js/stackframe#8\n                if (line.indexOf(' > eval') > -1) {\n                    line = line.replace(/ line (\\d+)(?: > eval line \\d+)* > eval\\:\\d+\\:\\d+/g, ':$1');\n                }\n\n                if (line.indexOf('@') === -1 && line.indexOf(':') === -1) {\n                    // Safari eval frames only have function names and nothing else\n                    return new StackFrame({\n                        functionName: line\n                    });\n                } else {\n                    var functionNameRegex = /((.*\".+\"[^@]*)?[^@]*)(?:@)/;\n                    var matches = line.match(functionNameRegex);\n                    var functionName = matches && matches[1] ? matches[1] : undefined;\n                    var locationParts = this.extractLocation(line.replace(functionNameRegex, ''));\n\n                    return new StackFrame({\n                        functionName: functionName,\n                        fileName: locationParts[0],\n                        lineNumber: locationParts[1],\n                        columnNumber: locationParts[2],\n                        source: line\n                    });\n                }\n            }, this);\n        },\n\n        parseOpera: function ErrorStackParser$$parseOpera(e) {\n            if (!e.stacktrace || (e.message.indexOf('\\n') > -1 &&\n                e.message.split('\\n').length > e.stacktrace.split('\\n').length)) {\n                return this.parseOpera9(e);\n            } else if (!e.stack) {\n                return this.parseOpera10(e);\n            } else {\n                return this.parseOpera11(e);\n            }\n        },\n\n        parseOpera9: function ErrorStackParser$$parseOpera9(e) {\n            var lineRE = /Line (\\d+).*script (?:in )?(\\S+)/i;\n            var lines = e.message.split('\\n');\n            var result = [];\n\n            for (var i = 2, len = lines.length; i < len; i += 2) {\n                var match = lineRE.exec(lines[i]);\n                if (match) {\n                    result.push(new StackFrame({\n                        fileName: match[2],\n                        lineNumber: match[1],\n                        source: lines[i]\n                    }));\n                }\n            }\n\n            return result;\n        },\n\n        parseOpera10: function ErrorStackParser$$parseOpera10(e) {\n            var lineRE = /Line (\\d+).*script (?:in )?(\\S+)(?:: In function (\\S+))?$/i;\n            var lines = e.stacktrace.split('\\n');\n            var result = [];\n\n            for (var i = 0, len = lines.length; i < len; i += 2) {\n                var match = lineRE.exec(lines[i]);\n                if (match) {\n                    result.push(\n                        new StackFrame({\n                            functionName: match[3] || undefined,\n                            fileName: match[2],\n                            lineNumber: match[1],\n                            source: lines[i]\n                        })\n                    );\n                }\n            }\n\n            return result;\n        },\n\n        // Opera 10.65+ Error.stack very similar to FF/Safari\n        parseOpera11: function ErrorStackParser$$parseOpera11(error) {\n            var filtered = error.stack.split('\\n').filter(function(line) {\n                return !!line.match(FIREFOX_SAFARI_STACK_REGEXP) && !line.match(/^Error created at/);\n            }, this);\n\n            return filtered.map(function(line) {\n                var tokens = line.split('@');\n                var locationParts = this.extractLocation(tokens.pop());\n                var functionCall = (tokens.shift() || '');\n                var functionName = functionCall\n                        .replace(/<anonymous function(: (\\w+))?>/, '$2')\n                        .replace(/\\([^\\)]*\\)/g, '') || undefined;\n                var argsRaw;\n                if (functionCall.match(/\\(([^\\)]*)\\)/)) {\n                    argsRaw = functionCall.replace(/^[^\\(]+\\(([^\\)]*)\\)$/, '$1');\n                }\n                var args = (argsRaw === undefined || argsRaw === '[arguments not available]') ?\n                    undefined : argsRaw.split(',');\n\n                return new StackFrame({\n                    functionName: functionName,\n                    args: args,\n                    fileName: locationParts[0],\n                    lineNumber: locationParts[1],\n                    columnNumber: locationParts[2],\n                    source: line\n                });\n            }, this);\n        }\n    };\n}));\n","(function(root, factory) {\n    'use strict';\n    // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.\n\n    /* istanbul ignore next */\n    if (typeof define === 'function' && define.amd) {\n        define('stack-generator', ['stackframe'], factory);\n    } else if (typeof exports === 'object') {\n        module.exports = factory(require('stackframe'));\n    } else {\n        root.StackGenerator = factory(root.StackFrame);\n    }\n}(this, function(StackFrame) {\n    return {\n        backtrace: function StackGenerator$$backtrace(opts) {\n            var stack = [];\n            var maxStackSize = 10;\n\n            if (typeof opts === 'object' && typeof opts.maxStackSize === 'number') {\n                maxStackSize = opts.maxStackSize;\n            }\n\n            var curr = arguments.callee;\n            while (curr && stack.length < maxStackSize && curr['arguments']) {\n                // Allow V8 optimizations\n                var args = new Array(curr['arguments'].length);\n                for (var i = 0; i < args.length; ++i) {\n                    args[i] = curr['arguments'][i];\n                }\n                if (/function(?:\\s+([\\w$]+))+\\s*\\(/.test(curr.toString())) {\n                    stack.push(new StackFrame({functionName: RegExp.$1 || undefined, args: args}));\n                } else {\n                    stack.push(new StackFrame({args: args}));\n                }\n\n                try {\n                    curr = curr.caller;\n                } catch (e) {\n                    break;\n                }\n            }\n            return stack;\n        }\n    };\n}));\n","(function(root, factory) {\n    'use strict';\n    // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.\n\n    /* istanbul ignore next */\n    if (typeof define === 'function' && define.amd) {\n        define('stackframe', [], factory);\n    } else if (typeof exports === 'object') {\n        module.exports = factory();\n    } else {\n        root.StackFrame = factory();\n    }\n}(this, function() {\n    'use strict';\n    function _isNumber(n) {\n        return !isNaN(parseFloat(n)) && isFinite(n);\n    }\n\n    function _capitalize(str) {\n        return str.charAt(0).toUpperCase() + str.substring(1);\n    }\n\n    function _getter(p) {\n        return function() {\n            return this[p];\n        };\n    }\n\n    var booleanProps = ['isConstructor', 'isEval', 'isNative', 'isToplevel'];\n    var numericProps = ['columnNumber', 'lineNumber'];\n    var stringProps = ['fileName', 'functionName', 'source'];\n    var arrayProps = ['args'];\n\n    var props = booleanProps.concat(numericProps, stringProps, arrayProps);\n\n    function StackFrame(obj) {\n        if (obj instanceof Object) {\n            for (var i = 0; i < props.length; i++) {\n                if (obj.hasOwnProperty(props[i]) && obj[props[i]] !== undefined) {\n                    this['set' + _capitalize(props[i])](obj[props[i]]);\n                }\n            }\n        }\n    }\n\n    StackFrame.prototype = {\n        getArgs: function() {\n            return this.args;\n        },\n        setArgs: function(v) {\n            if (Object.prototype.toString.call(v) !== '[object Array]') {\n                throw new TypeError('Args must be an Array');\n            }\n            this.args = v;\n        },\n\n        getEvalOrigin: function() {\n            return this.evalOrigin;\n        },\n        setEvalOrigin: function(v) {\n            if (v instanceof StackFrame) {\n                this.evalOrigin = v;\n            } else if (v instanceof Object) {\n                this.evalOrigin = new StackFrame(v);\n            } else {\n                throw new TypeError('Eval Origin must be an Object or StackFrame');\n            }\n        },\n\n        toString: function() {\n            var functionName = this.getFunctionName() || '{anonymous}';\n            var args = '(' + (this.getArgs() || []).join(',') + ')';\n            var fileName = this.getFileName() ? ('@' + this.getFileName()) : '';\n            var lineNumber = _isNumber(this.getLineNumber()) ? (':' + this.getLineNumber()) : '';\n            var columnNumber = _isNumber(this.getColumnNumber()) ? (':' + this.getColumnNumber()) : '';\n            return functionName + args + fileName + lineNumber + columnNumber;\n        }\n    };\n\n    for (var i = 0; i < booleanProps.length; i++) {\n        StackFrame.prototype['get' + _capitalize(booleanProps[i])] = _getter(booleanProps[i]);\n        StackFrame.prototype['set' + _capitalize(booleanProps[i])] = (function(p) {\n            return function(v) {\n                this[p] = Boolean(v);\n            };\n        })(booleanProps[i]);\n    }\n\n    for (var j = 0; j < numericProps.length; j++) {\n        StackFrame.prototype['get' + _capitalize(numericProps[j])] = _getter(numericProps[j]);\n        StackFrame.prototype['set' + _capitalize(numericProps[j])] = (function(p) {\n            return function(v) {\n                if (!_isNumber(v)) {\n                    throw new TypeError(p + ' must be a Number');\n                }\n                this[p] = Number(v);\n            };\n        })(numericProps[j]);\n    }\n\n    for (var k = 0; k < stringProps.length; k++) {\n        StackFrame.prototype['get' + _capitalize(stringProps[k])] = _getter(stringProps[k]);\n        StackFrame.prototype['set' + _capitalize(stringProps[k])] = (function(p) {\n            return function(v) {\n                this[p] = String(v);\n            };\n        })(stringProps[k]);\n    }\n\n    return StackFrame;\n}));\n","/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\nvar util = require('./util');\nvar has = Object.prototype.hasOwnProperty;\n\n/**\n * A data structure which is a combination of an array and a set. Adding a new\n * member is O(1), testing for membership is O(1), and finding the index of an\n * element is O(1). Removing elements from the set is not supported. Only\n * strings are supported for membership.\n */\nfunction ArraySet() {\n  this._array = [];\n  this._set = Object.create(null);\n}\n\n/**\n * Static method for creating ArraySet instances from an existing array.\n */\nArraySet.fromArray = function ArraySet_fromArray(aArray, aAllowDuplicates) {\n  var set = new ArraySet();\n  for (var i = 0, len = aArray.length; i < len; i++) {\n    set.add(aArray[i], aAllowDuplicates);\n  }\n  return set;\n};\n\n/**\n * Return how many unique items are in this ArraySet. If duplicates have been\n * added, than those do not count towards the size.\n *\n * @returns Number\n */\nArraySet.prototype.size = function ArraySet_size() {\n  return Object.getOwnPropertyNames(this._set).length;\n};\n\n/**\n * Add the given string to this set.\n *\n * @param String aStr\n */\nArraySet.prototype.add = function ArraySet_add(aStr, aAllowDuplicates) {\n  var sStr = util.toSetString(aStr);\n  var isDuplicate = has.call(this._set, sStr);\n  var idx = this._array.length;\n  if (!isDuplicate || aAllowDuplicates) {\n    this._array.push(aStr);\n  }\n  if (!isDuplicate) {\n    this._set[sStr] = idx;\n  }\n};\n\n/**\n * Is the given string a member of this set?\n *\n * @param String aStr\n */\nArraySet.prototype.has = function ArraySet_has(aStr) {\n  var sStr = util.toSetString(aStr);\n  return has.call(this._set, sStr);\n};\n\n/**\n * What is the index of the given string in the array?\n *\n * @param String aStr\n */\nArraySet.prototype.indexOf = function ArraySet_indexOf(aStr) {\n  var sStr = util.toSetString(aStr);\n  if (has.call(this._set, sStr)) {\n    return this._set[sStr];\n  }\n  throw new Error('\"' + aStr + '\" is not in the set.');\n};\n\n/**\n * What is the element at the given index?\n *\n * @param Number aIdx\n */\nArraySet.prototype.at = function ArraySet_at(aIdx) {\n  if (aIdx >= 0 && aIdx < this._array.length) {\n    return this._array[aIdx];\n  }\n  throw new Error('No element indexed by ' + aIdx);\n};\n\n/**\n * Returns the array representation of this set (which has the proper indices\n * indicated by indexOf). Note that this is a copy of the internal array used\n * for storing the members so that no one can mess with internal state.\n */\nArraySet.prototype.toArray = function ArraySet_toArray() {\n  return this._array.slice();\n};\n\nexports.ArraySet = ArraySet;\n","/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n *\n * Based on the Base 64 VLQ implementation in Closure Compiler:\n * https://code.google.com/p/closure-compiler/source/browse/trunk/src/com/google/debugging/sourcemap/Base64VLQ.java\n *\n * Copyright 2011 The Closure Compiler Authors. All rights reserved.\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are\n * met:\n *\n *  * Redistributions of source code must retain the above copyright\n *    notice, this list of conditions and the following disclaimer.\n *  * Redistributions in binary form must reproduce the above\n *    copyright notice, this list of conditions and the following\n *    disclaimer in the documentation and/or other materials provided\n *    with the distribution.\n *  * Neither the name of Google Inc. nor the names of its\n *    contributors may be used to endorse or promote products derived\n *    from this software without specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS\n * \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT\n * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR\n * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT\n * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,\n * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,\n * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY\n * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nvar base64 = require('./base64');\n\n// A single base 64 digit can contain 6 bits of data. For the base 64 variable\n// length quantities we use in the source map spec, the first bit is the sign,\n// the next four bits are the actual value, and the 6th bit is the\n// continuation bit. The continuation bit tells us whether there are more\n// digits in this value following this digit.\n//\n//   Continuation\n//   |    Sign\n//   |    |\n//   V    V\n//   101011\n\nvar VLQ_BASE_SHIFT = 5;\n\n// binary: 100000\nvar VLQ_BASE = 1 << VLQ_BASE_SHIFT;\n\n// binary: 011111\nvar VLQ_BASE_MASK = VLQ_BASE - 1;\n\n// binary: 100000\nvar VLQ_CONTINUATION_BIT = VLQ_BASE;\n\n/**\n * Converts from a two-complement value to a value where the sign bit is\n * placed in the least significant bit.  For example, as decimals:\n *   1 becomes 2 (10 binary), -1 becomes 3 (11 binary)\n *   2 becomes 4 (100 binary), -2 becomes 5 (101 binary)\n */\nfunction toVLQSigned(aValue) {\n  return aValue < 0\n    ? ((-aValue) << 1) + 1\n    : (aValue << 1) + 0;\n}\n\n/**\n * Converts to a two-complement value from a value where the sign bit is\n * placed in the least significant bit.  For example, as decimals:\n *   2 (10 binary) becomes 1, 3 (11 binary) becomes -1\n *   4 (100 binary) becomes 2, 5 (101 binary) becomes -2\n */\nfunction fromVLQSigned(aValue) {\n  var isNegative = (aValue & 1) === 1;\n  var shifted = aValue >> 1;\n  return isNegative\n    ? -shifted\n    : shifted;\n}\n\n/**\n * Returns the base 64 VLQ encoded value.\n */\nexports.encode = function base64VLQ_encode(aValue) {\n  var encoded = \"\";\n  var digit;\n\n  var vlq = toVLQSigned(aValue);\n\n  do {\n    digit = vlq & VLQ_BASE_MASK;\n    vlq >>>= VLQ_BASE_SHIFT;\n    if (vlq > 0) {\n      // There are still more digits in this value, so we must make sure the\n      // continuation bit is marked.\n      digit |= VLQ_CONTINUATION_BIT;\n    }\n    encoded += base64.encode(digit);\n  } while (vlq > 0);\n\n  return encoded;\n};\n\n/**\n * Decodes the next base 64 VLQ value from the given string and returns the\n * value and the rest of the string via the out parameter.\n */\nexports.decode = function base64VLQ_decode(aStr, aIndex, aOutParam) {\n  var strLen = aStr.length;\n  var result = 0;\n  var shift = 0;\n  var continuation, digit;\n\n  do {\n    if (aIndex >= strLen) {\n      throw new Error(\"Expected more digits in base 64 VLQ value.\");\n    }\n\n    digit = base64.decode(aStr.charCodeAt(aIndex++));\n    if (digit === -1) {\n      throw new Error(\"Invalid base64 digit: \" + aStr.charAt(aIndex - 1));\n    }\n\n    continuation = !!(digit & VLQ_CONTINUATION_BIT);\n    digit &= VLQ_BASE_MASK;\n    result = result + (digit << shift);\n    shift += VLQ_BASE_SHIFT;\n  } while (continuation);\n\n  aOutParam.value = fromVLQSigned(result);\n  aOutParam.rest = aIndex;\n};\n","/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\nvar intToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'.split('');\n\n/**\n * Encode an integer in the range of 0 to 63 to a single base 64 digit.\n */\nexports.encode = function (number) {\n  if (0 <= number && number < intToCharMap.length) {\n    return intToCharMap[number];\n  }\n  throw new TypeError(\"Must be between 0 and 63: \" + number);\n};\n\n/**\n * Decode a single base 64 character code digit to an integer. Returns -1 on\n * failure.\n */\nexports.decode = function (charCode) {\n  var bigA = 65;     // 'A'\n  var bigZ = 90;     // 'Z'\n\n  var littleA = 97;  // 'a'\n  var littleZ = 122; // 'z'\n\n  var zero = 48;     // '0'\n  var nine = 57;     // '9'\n\n  var plus = 43;     // '+'\n  var slash = 47;    // '/'\n\n  var littleOffset = 26;\n  var numberOffset = 52;\n\n  // 0 - 25: ABCDEFGHIJKLMNOPQRSTUVWXYZ\n  if (bigA <= charCode && charCode <= bigZ) {\n    return (charCode - bigA);\n  }\n\n  // 26 - 51: abcdefghijklmnopqrstuvwxyz\n  if (littleA <= charCode && charCode <= littleZ) {\n    return (charCode - littleA + littleOffset);\n  }\n\n  // 52 - 61: 0123456789\n  if (zero <= charCode && charCode <= nine) {\n    return (charCode - zero + numberOffset);\n  }\n\n  // 62: +\n  if (charCode == plus) {\n    return 62;\n  }\n\n  // 63: /\n  if (charCode == slash) {\n    return 63;\n  }\n\n  // Invalid base64 digit.\n  return -1;\n};\n","/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\nexports.GREATEST_LOWER_BOUND = 1;\nexports.LEAST_UPPER_BOUND = 2;\n\n/**\n * Recursive implementation of binary search.\n *\n * @param aLow Indices here and lower do not contain the needle.\n * @param aHigh Indices here and higher do not contain the needle.\n * @param aNeedle The element being searched for.\n * @param aHaystack The non-empty array being searched.\n * @param aCompare Function which takes two elements and returns -1, 0, or 1.\n * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or\n *     'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the\n *     closest element that is smaller than or greater than the one we are\n *     searching for, respectively, if the exact element cannot be found.\n */\nfunction recursiveSearch(aLow, aHigh, aNeedle, aHaystack, aCompare, aBias) {\n  // This function terminates when one of the following is true:\n  //\n  //   1. We find the exact element we are looking for.\n  //\n  //   2. We did not find the exact element, but we can return the index of\n  //      the next-closest element.\n  //\n  //   3. We did not find the exact element, and there is no next-closest\n  //      element than the one we are searching for, so we return -1.\n  var mid = Math.floor((aHigh - aLow) / 2) + aLow;\n  var cmp = aCompare(aNeedle, aHaystack[mid], true);\n  if (cmp === 0) {\n    // Found the element we are looking for.\n    return mid;\n  }\n  else if (cmp > 0) {\n    // Our needle is greater than aHaystack[mid].\n    if (aHigh - mid > 1) {\n      // The element is in the upper half.\n      return recursiveSearch(mid, aHigh, aNeedle, aHaystack, aCompare, aBias);\n    }\n\n    // The exact needle element was not found in this haystack. Determine if\n    // we are in termination case (3) or (2) and return the appropriate thing.\n    if (aBias == exports.LEAST_UPPER_BOUND) {\n      return aHigh < aHaystack.length ? aHigh : -1;\n    } else {\n      return mid;\n    }\n  }\n  else {\n    // Our needle is less than aHaystack[mid].\n    if (mid - aLow > 1) {\n      // The element is in the lower half.\n      return recursiveSearch(aLow, mid, aNeedle, aHaystack, aCompare, aBias);\n    }\n\n    // we are in termination case (3) or (2) and return the appropriate thing.\n    if (aBias == exports.LEAST_UPPER_BOUND) {\n      return mid;\n    } else {\n      return aLow < 0 ? -1 : aLow;\n    }\n  }\n}\n\n/**\n * This is an implementation of binary search which will always try and return\n * the index of the closest element if there is no exact hit. This is because\n * mappings between original and generated line/col pairs are single points,\n * and there is an implicit region between each of them, so a miss just means\n * that you aren't on the very start of a region.\n *\n * @param aNeedle The element you are looking for.\n * @param aHaystack The array that is being searched.\n * @param aCompare A function which takes the needle and an element in the\n *     array and returns -1, 0, or 1 depending on whether the needle is less\n *     than, equal to, or greater than the element, respectively.\n * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or\n *     'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the\n *     closest element that is smaller than or greater than the one we are\n *     searching for, respectively, if the exact element cannot be found.\n *     Defaults to 'binarySearch.GREATEST_LOWER_BOUND'.\n */\nexports.search = function search(aNeedle, aHaystack, aCompare, aBias) {\n  if (aHaystack.length === 0) {\n    return -1;\n  }\n\n  var index = recursiveSearch(-1, aHaystack.length, aNeedle, aHaystack,\n                              aCompare, aBias || exports.GREATEST_LOWER_BOUND);\n  if (index < 0) {\n    return -1;\n  }\n\n  // We have found either the exact element, or the next-closest element than\n  // the one we are searching for. However, there may be more than one such\n  // element. Make sure we always return the smallest of these.\n  while (index - 1 >= 0) {\n    if (aCompare(aHaystack[index], aHaystack[index - 1], true) !== 0) {\n      break;\n    }\n    --index;\n  }\n\n  return index;\n};\n","/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\n// It turns out that some (most?) JavaScript engines don't self-host\n// `Array.prototype.sort`. This makes sense because C++ will likely remain\n// faster than JS when doing raw CPU-intensive sorting. However, when using a\n// custom comparator function, calling back and forth between the VM's C++ and\n// JIT'd JS is rather slow *and* loses JIT type information, resulting in\n// worse generated code for the comparator function than would be optimal. In\n// fact, when sorting with a comparator, these costs outweigh the benefits of\n// sorting in C++. By using our own JS-implemented Quick Sort (below), we get\n// a ~3500ms mean speed-up in `bench/bench.html`.\n\n/**\n * Swap the elements indexed by `x` and `y` in the array `ary`.\n *\n * @param {Array} ary\n *        The array.\n * @param {Number} x\n *        The index of the first item.\n * @param {Number} y\n *        The index of the second item.\n */\nfunction swap(ary, x, y) {\n  var temp = ary[x];\n  ary[x] = ary[y];\n  ary[y] = temp;\n}\n\n/**\n * Returns a random integer within the range `low .. high` inclusive.\n *\n * @param {Number} low\n *        The lower bound on the range.\n * @param {Number} high\n *        The upper bound on the range.\n */\nfunction randomIntInRange(low, high) {\n  return Math.round(low + (Math.random() * (high - low)));\n}\n\n/**\n * The Quick Sort algorithm.\n *\n * @param {Array} ary\n *        An array to sort.\n * @param {function} comparator\n *        Function to use to compare two items.\n * @param {Number} p\n *        Start index of the array\n * @param {Number} r\n *        End index of the array\n */\nfunction doQuickSort(ary, comparator, p, r) {\n  // If our lower bound is less than our upper bound, we (1) partition the\n  // array into two pieces and (2) recurse on each half. If it is not, this is\n  // the empty array and our base case.\n\n  if (p < r) {\n    // (1) Partitioning.\n    //\n    // The partitioning chooses a pivot between `p` and `r` and moves all\n    // elements that are less than or equal to the pivot to the before it, and\n    // all the elements that are greater than it after it. The effect is that\n    // once partition is done, the pivot is in the exact place it will be when\n    // the array is put in sorted order, and it will not need to be moved\n    // again. This runs in O(n) time.\n\n    // Always choose a random pivot so that an input array which is reverse\n    // sorted does not cause O(n^2) running time.\n    var pivotIndex = randomIntInRange(p, r);\n    var i = p - 1;\n\n    swap(ary, pivotIndex, r);\n    var pivot = ary[r];\n\n    // Immediately after `j` is incremented in this loop, the following hold\n    // true:\n    //\n    //   * Every element in `ary[p .. i]` is less than or equal to the pivot.\n    //\n    //   * Every element in `ary[i+1 .. j-1]` is greater than the pivot.\n    for (var j = p; j < r; j++) {\n      if (comparator(ary[j], pivot) <= 0) {\n        i += 1;\n        swap(ary, i, j);\n      }\n    }\n\n    swap(ary, i + 1, j);\n    var q = i + 1;\n\n    // (2) Recurse on each half.\n\n    doQuickSort(ary, comparator, p, q - 1);\n    doQuickSort(ary, comparator, q + 1, r);\n  }\n}\n\n/**\n * Sort the given array in-place with the given comparator function.\n *\n * @param {Array} ary\n *        An array to sort.\n * @param {function} comparator\n *        Function to use to compare two items.\n */\nexports.quickSort = function (ary, comparator) {\n  doQuickSort(ary, comparator, 0, ary.length - 1);\n};\n","/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\nvar util = require('./util');\nvar binarySearch = require('./binary-search');\nvar ArraySet = require('./array-set').ArraySet;\nvar base64VLQ = require('./base64-vlq');\nvar quickSort = require('./quick-sort').quickSort;\n\nfunction SourceMapConsumer(aSourceMap) {\n  var sourceMap = aSourceMap;\n  if (typeof aSourceMap === 'string') {\n    sourceMap = JSON.parse(aSourceMap.replace(/^\\)\\]\\}'/, ''));\n  }\n\n  return sourceMap.sections != null\n    ? new IndexedSourceMapConsumer(sourceMap)\n    : new BasicSourceMapConsumer(sourceMap);\n}\n\nSourceMapConsumer.fromSourceMap = function(aSourceMap) {\n  return BasicSourceMapConsumer.fromSourceMap(aSourceMap);\n}\n\n/**\n * The version of the source mapping spec that we are consuming.\n */\nSourceMapConsumer.prototype._version = 3;\n\n// `__generatedMappings` and `__originalMappings` are arrays that hold the\n// parsed mapping coordinates from the source map's \"mappings\" attribute. They\n// are lazily instantiated, accessed via the `_generatedMappings` and\n// `_originalMappings` getters respectively, and we only parse the mappings\n// and create these arrays once queried for a source location. We jump through\n// these hoops because there can be many thousands of mappings, and parsing\n// them is expensive, so we only want to do it if we must.\n//\n// Each object in the arrays is of the form:\n//\n//     {\n//       generatedLine: The line number in the generated code,\n//       generatedColumn: The column number in the generated code,\n//       source: The path to the original source file that generated this\n//               chunk of code,\n//       originalLine: The line number in the original source that\n//                     corresponds to this chunk of generated code,\n//       originalColumn: The column number in the original source that\n//                       corresponds to this chunk of generated code,\n//       name: The name of the original symbol which generated this chunk of\n//             code.\n//     }\n//\n// All properties except for `generatedLine` and `generatedColumn` can be\n// `null`.\n//\n// `_generatedMappings` is ordered by the generated positions.\n//\n// `_originalMappings` is ordered by the original positions.\n\nSourceMapConsumer.prototype.__generatedMappings = null;\nObject.defineProperty(SourceMapConsumer.prototype, '_generatedMappings', {\n  get: function () {\n    if (!this.__generatedMappings) {\n      this._parseMappings(this._mappings, this.sourceRoot);\n    }\n\n    return this.__generatedMappings;\n  }\n});\n\nSourceMapConsumer.prototype.__originalMappings = null;\nObject.defineProperty(SourceMapConsumer.prototype, '_originalMappings', {\n  get: function () {\n    if (!this.__originalMappings) {\n      this._parseMappings(this._mappings, this.sourceRoot);\n    }\n\n    return this.__originalMappings;\n  }\n});\n\nSourceMapConsumer.prototype._charIsMappingSeparator =\n  function SourceMapConsumer_charIsMappingSeparator(aStr, index) {\n    var c = aStr.charAt(index);\n    return c === \";\" || c === \",\";\n  };\n\n/**\n * Parse the mappings in a string in to a data structure which we can easily\n * query (the ordered arrays in the `this.__generatedMappings` and\n * `this.__originalMappings` properties).\n */\nSourceMapConsumer.prototype._parseMappings =\n  function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {\n    throw new Error(\"Subclasses must implement _parseMappings\");\n  };\n\nSourceMapConsumer.GENERATED_ORDER = 1;\nSourceMapConsumer.ORIGINAL_ORDER = 2;\n\nSourceMapConsumer.GREATEST_LOWER_BOUND = 1;\nSourceMapConsumer.LEAST_UPPER_BOUND = 2;\n\n/**\n * Iterate over each mapping between an original source/line/column and a\n * generated line/column in this source map.\n *\n * @param Function aCallback\n *        The function that is called with each mapping.\n * @param Object aContext\n *        Optional. If specified, this object will be the value of `this` every\n *        time that `aCallback` is called.\n * @param aOrder\n *        Either `SourceMapConsumer.GENERATED_ORDER` or\n *        `SourceMapConsumer.ORIGINAL_ORDER`. Specifies whether you want to\n *        iterate over the mappings sorted by the generated file's line/column\n *        order or the original's source/line/column order, respectively. Defaults to\n *        `SourceMapConsumer.GENERATED_ORDER`.\n */\nSourceMapConsumer.prototype.eachMapping =\n  function SourceMapConsumer_eachMapping(aCallback, aContext, aOrder) {\n    var context = aContext || null;\n    var order = aOrder || SourceMapConsumer.GENERATED_ORDER;\n\n    var mappings;\n    switch (order) {\n    case SourceMapConsumer.GENERATED_ORDER:\n      mappings = this._generatedMappings;\n      break;\n    case SourceMapConsumer.ORIGINAL_ORDER:\n      mappings = this._originalMappings;\n      break;\n    default:\n      throw new Error(\"Unknown order of iteration.\");\n    }\n\n    var sourceRoot = this.sourceRoot;\n    mappings.map(function (mapping) {\n      var source = mapping.source === null ? null : this._sources.at(mapping.source);\n      if (source != null && sourceRoot != null) {\n        source = util.join(sourceRoot, source);\n      }\n      return {\n        source: source,\n        generatedLine: mapping.generatedLine,\n        generatedColumn: mapping.generatedColumn,\n        originalLine: mapping.originalLine,\n        originalColumn: mapping.originalColumn,\n        name: mapping.name === null ? null : this._names.at(mapping.name)\n      };\n    }, this).forEach(aCallback, context);\n  };\n\n/**\n * Returns all generated line and column information for the original source,\n * line, and column provided. If no column is provided, returns all mappings\n * corresponding to a either the line we are searching for or the next\n * closest line that has any mappings. Otherwise, returns all mappings\n * corresponding to the given line and either the column we are searching for\n * or the next closest column that has any offsets.\n *\n * The only argument is an object with the following properties:\n *\n *   - source: The filename of the original source.\n *   - line: The line number in the original source.\n *   - column: Optional. the column number in the original source.\n *\n * and an array of objects is returned, each with the following properties:\n *\n *   - line: The line number in the generated source, or null.\n *   - column: The column number in the generated source, or null.\n */\nSourceMapConsumer.prototype.allGeneratedPositionsFor =\n  function SourceMapConsumer_allGeneratedPositionsFor(aArgs) {\n    var line = util.getArg(aArgs, 'line');\n\n    // When there is no exact match, BasicSourceMapConsumer.prototype._findMapping\n    // returns the index of the closest mapping less than the needle. By\n    // setting needle.originalColumn to 0, we thus find the last mapping for\n    // the given line, provided such a mapping exists.\n    var needle = {\n      source: util.getArg(aArgs, 'source'),\n      originalLine: line,\n      originalColumn: util.getArg(aArgs, 'column', 0)\n    };\n\n    if (this.sourceRoot != null) {\n      needle.source = util.relative(this.sourceRoot, needle.source);\n    }\n    if (!this._sources.has(needle.source)) {\n      return [];\n    }\n    needle.source = this._sources.indexOf(needle.source);\n\n    var mappings = [];\n\n    var index = this._findMapping(needle,\n                                  this._originalMappings,\n                                  \"originalLine\",\n                                  \"originalColumn\",\n                                  util.compareByOriginalPositions,\n                                  binarySearch.LEAST_UPPER_BOUND);\n    if (index >= 0) {\n      var mapping = this._originalMappings[index];\n\n      if (aArgs.column === undefined) {\n        var originalLine = mapping.originalLine;\n\n        // Iterate until either we run out of mappings, or we run into\n        // a mapping for a different line than the one we found. Since\n        // mappings are sorted, this is guaranteed to find all mappings for\n        // the line we found.\n        while (mapping && mapping.originalLine === originalLine) {\n          mappings.push({\n            line: util.getArg(mapping, 'generatedLine', null),\n            column: util.getArg(mapping, 'generatedColumn', null),\n            lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)\n          });\n\n          mapping = this._originalMappings[++index];\n        }\n      } else {\n        var originalColumn = mapping.originalColumn;\n\n        // Iterate until either we run out of mappings, or we run into\n        // a mapping for a different line than the one we were searching for.\n        // Since mappings are sorted, this is guaranteed to find all mappings for\n        // the line we are searching for.\n        while (mapping &&\n               mapping.originalLine === line &&\n               mapping.originalColumn == originalColumn) {\n          mappings.push({\n            line: util.getArg(mapping, 'generatedLine', null),\n            column: util.getArg(mapping, 'generatedColumn', null),\n            lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)\n          });\n\n          mapping = this._originalMappings[++index];\n        }\n      }\n    }\n\n    return mappings;\n  };\n\nexports.SourceMapConsumer = SourceMapConsumer;\n\n/**\n * A BasicSourceMapConsumer instance represents a parsed source map which we can\n * query for information about the original file positions by giving it a file\n * position in the generated source.\n *\n * The only parameter is the raw source map (either as a JSON string, or\n * already parsed to an object). According to the spec, source maps have the\n * following attributes:\n *\n *   - version: Which version of the source map spec this map is following.\n *   - sources: An array of URLs to the original source files.\n *   - names: An array of identifiers which can be referrenced by individual mappings.\n *   - sourceRoot: Optional. The URL root from which all sources are relative.\n *   - sourcesContent: Optional. An array of contents of the original source files.\n *   - mappings: A string of base64 VLQs which contain the actual mappings.\n *   - file: Optional. The generated file this source map is associated with.\n *\n * Here is an example source map, taken from the source map spec[0]:\n *\n *     {\n *       version : 3,\n *       file: \"out.js\",\n *       sourceRoot : \"\",\n *       sources: [\"foo.js\", \"bar.js\"],\n *       names: [\"src\", \"maps\", \"are\", \"fun\"],\n *       mappings: \"AA,AB;;ABCDE;\"\n *     }\n *\n * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit?pli=1#\n */\nfunction BasicSourceMapConsumer(aSourceMap) {\n  var sourceMap = aSourceMap;\n  if (typeof aSourceMap === 'string') {\n    sourceMap = JSON.parse(aSourceMap.replace(/^\\)\\]\\}'/, ''));\n  }\n\n  var version = util.getArg(sourceMap, 'version');\n  var sources = util.getArg(sourceMap, 'sources');\n  // Sass 3.3 leaves out the 'names' array, so we deviate from the spec (which\n  // requires the array) to play nice here.\n  var names = util.getArg(sourceMap, 'names', []);\n  var sourceRoot = util.getArg(sourceMap, 'sourceRoot', null);\n  var sourcesContent = util.getArg(sourceMap, 'sourcesContent', null);\n  var mappings = util.getArg(sourceMap, 'mappings');\n  var file = util.getArg(sourceMap, 'file', null);\n\n  // Once again, Sass deviates from the spec and supplies the version as a\n  // string rather than a number, so we use loose equality checking here.\n  if (version != this._version) {\n    throw new Error('Unsupported version: ' + version);\n  }\n\n  sources = sources\n    .map(String)\n    // Some source maps produce relative source paths like \"./foo.js\" instead of\n    // \"foo.js\".  Normalize these first so that future comparisons will succeed.\n    // See bugzil.la/1090768.\n    .map(util.normalize)\n    // Always ensure that absolute sources are internally stored relative to\n    // the source root, if the source root is absolute. Not doing this would\n    // be particularly problematic when the source root is a prefix of the\n    // source (valid, but why??). See github issue #199 and bugzil.la/1188982.\n    .map(function (source) {\n      return sourceRoot && util.isAbsolute(sourceRoot) && util.isAbsolute(source)\n        ? util.relative(sourceRoot, source)\n        : source;\n    });\n\n  // Pass `true` below to allow duplicate names and sources. While source maps\n  // are intended to be compressed and deduplicated, the TypeScript compiler\n  // sometimes generates source maps with duplicates in them. See Github issue\n  // #72 and bugzil.la/889492.\n  this._names = ArraySet.fromArray(names.map(String), true);\n  this._sources = ArraySet.fromArray(sources, true);\n\n  this.sourceRoot = sourceRoot;\n  this.sourcesContent = sourcesContent;\n  this._mappings = mappings;\n  this.file = file;\n}\n\nBasicSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);\nBasicSourceMapConsumer.prototype.consumer = SourceMapConsumer;\n\n/**\n * Create a BasicSourceMapConsumer from a SourceMapGenerator.\n *\n * @param SourceMapGenerator aSourceMap\n *        The source map that will be consumed.\n * @returns BasicSourceMapConsumer\n */\nBasicSourceMapConsumer.fromSourceMap =\n  function SourceMapConsumer_fromSourceMap(aSourceMap) {\n    var smc = Object.create(BasicSourceMapConsumer.prototype);\n\n    var names = smc._names = ArraySet.fromArray(aSourceMap._names.toArray(), true);\n    var sources = smc._sources = ArraySet.fromArray(aSourceMap._sources.toArray(), true);\n    smc.sourceRoot = aSourceMap._sourceRoot;\n    smc.sourcesContent = aSourceMap._generateSourcesContent(smc._sources.toArray(),\n                                                            smc.sourceRoot);\n    smc.file = aSourceMap._file;\n\n    // Because we are modifying the entries (by converting string sources and\n    // names to indices into the sources and names ArraySets), we have to make\n    // a copy of the entry or else bad things happen. Shared mutable state\n    // strikes again! See github issue #191.\n\n    var generatedMappings = aSourceMap._mappings.toArray().slice();\n    var destGeneratedMappings = smc.__generatedMappings = [];\n    var destOriginalMappings = smc.__originalMappings = [];\n\n    for (var i = 0, length = generatedMappings.length; i < length; i++) {\n      var srcMapping = generatedMappings[i];\n      var destMapping = new Mapping;\n      destMapping.generatedLine = srcMapping.generatedLine;\n      destMapping.generatedColumn = srcMapping.generatedColumn;\n\n      if (srcMapping.source) {\n        destMapping.source = sources.indexOf(srcMapping.source);\n        destMapping.originalLine = srcMapping.originalLine;\n        destMapping.originalColumn = srcMapping.originalColumn;\n\n        if (srcMapping.name) {\n          destMapping.name = names.indexOf(srcMapping.name);\n        }\n\n        destOriginalMappings.push(destMapping);\n      }\n\n      destGeneratedMappings.push(destMapping);\n    }\n\n    quickSort(smc.__originalMappings, util.compareByOriginalPositions);\n\n    return smc;\n  };\n\n/**\n * The version of the source mapping spec that we are consuming.\n */\nBasicSourceMapConsumer.prototype._version = 3;\n\n/**\n * The list of original sources.\n */\nObject.defineProperty(BasicSourceMapConsumer.prototype, 'sources', {\n  get: function () {\n    return this._sources.toArray().map(function (s) {\n      return this.sourceRoot != null ? util.join(this.sourceRoot, s) : s;\n    }, this);\n  }\n});\n\n/**\n * Provide the JIT with a nice shape / hidden class.\n */\nfunction Mapping() {\n  this.generatedLine = 0;\n  this.generatedColumn = 0;\n  this.source = null;\n  this.originalLine = null;\n  this.originalColumn = null;\n  this.name = null;\n}\n\n/**\n * Parse the mappings in a string in to a data structure which we can easily\n * query (the ordered arrays in the `this.__generatedMappings` and\n * `this.__originalMappings` properties).\n */\nBasicSourceMapConsumer.prototype._parseMappings =\n  function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {\n    var generatedLine = 1;\n    var previousGeneratedColumn = 0;\n    var previousOriginalLine = 0;\n    var previousOriginalColumn = 0;\n    var previousSource = 0;\n    var previousName = 0;\n    var length = aStr.length;\n    var index = 0;\n    var cachedSegments = {};\n    var temp = {};\n    var originalMappings = [];\n    var generatedMappings = [];\n    var mapping, str, segment, end, value;\n\n    while (index < length) {\n      if (aStr.charAt(index) === ';') {\n        generatedLine++;\n        index++;\n        previousGeneratedColumn = 0;\n      }\n      else if (aStr.charAt(index) === ',') {\n        index++;\n      }\n      else {\n        mapping = new Mapping();\n        mapping.generatedLine = generatedLine;\n\n        // Because each offset is encoded relative to the previous one,\n        // many segments often have the same encoding. We can exploit this\n        // fact by caching the parsed variable length fields of each segment,\n        // allowing us to avoid a second parse if we encounter the same\n        // segment again.\n        for (end = index; end < length; end++) {\n          if (this._charIsMappingSeparator(aStr, end)) {\n            break;\n          }\n        }\n        str = aStr.slice(index, end);\n\n        segment = cachedSegments[str];\n        if (segment) {\n          index += str.length;\n        } else {\n          segment = [];\n          while (index < end) {\n            base64VLQ.decode(aStr, index, temp);\n            value = temp.value;\n            index = temp.rest;\n            segment.push(value);\n          }\n\n          if (segment.length === 2) {\n            throw new Error('Found a source, but no line and column');\n          }\n\n          if (segment.length === 3) {\n            throw new Error('Found a source and line, but no column');\n          }\n\n          cachedSegments[str] = segment;\n        }\n\n        // Generated column.\n        mapping.generatedColumn = previousGeneratedColumn + segment[0];\n        previousGeneratedColumn = mapping.generatedColumn;\n\n        if (segment.length > 1) {\n          // Original source.\n          mapping.source = previousSource + segment[1];\n          previousSource += segment[1];\n\n          // Original line.\n          mapping.originalLine = previousOriginalLine + segment[2];\n          previousOriginalLine = mapping.originalLine;\n          // Lines are stored 0-based\n          mapping.originalLine += 1;\n\n          // Original column.\n          mapping.originalColumn = previousOriginalColumn + segment[3];\n          previousOriginalColumn = mapping.originalColumn;\n\n          if (segment.length > 4) {\n            // Original name.\n            mapping.name = previousName + segment[4];\n            previousName += segment[4];\n          }\n        }\n\n        generatedMappings.push(mapping);\n        if (typeof mapping.originalLine === 'number') {\n          originalMappings.push(mapping);\n        }\n      }\n    }\n\n    quickSort(generatedMappings, util.compareByGeneratedPositionsDeflated);\n    this.__generatedMappings = generatedMappings;\n\n    quickSort(originalMappings, util.compareByOriginalPositions);\n    this.__originalMappings = originalMappings;\n  };\n\n/**\n * Find the mapping that best matches the hypothetical \"needle\" mapping that\n * we are searching for in the given \"haystack\" of mappings.\n */\nBasicSourceMapConsumer.prototype._findMapping =\n  function SourceMapConsumer_findMapping(aNeedle, aMappings, aLineName,\n                                         aColumnName, aComparator, aBias) {\n    // To return the position we are searching for, we must first find the\n    // mapping for the given position and then return the opposite position it\n    // points to. Because the mappings are sorted, we can use binary search to\n    // find the best mapping.\n\n    if (aNeedle[aLineName] <= 0) {\n      throw new TypeError('Line must be greater than or equal to 1, got '\n                          + aNeedle[aLineName]);\n    }\n    if (aNeedle[aColumnName] < 0) {\n      throw new TypeError('Column must be greater than or equal to 0, got '\n                          + aNeedle[aColumnName]);\n    }\n\n    return binarySearch.search(aNeedle, aMappings, aComparator, aBias);\n  };\n\n/**\n * Compute the last column for each generated mapping. The last column is\n * inclusive.\n */\nBasicSourceMapConsumer.prototype.computeColumnSpans =\n  function SourceMapConsumer_computeColumnSpans() {\n    for (var index = 0; index < this._generatedMappings.length; ++index) {\n      var mapping = this._generatedMappings[index];\n\n      // Mappings do not contain a field for the last generated columnt. We\n      // can come up with an optimistic estimate, however, by assuming that\n      // mappings are contiguous (i.e. given two consecutive mappings, the\n      // first mapping ends where the second one starts).\n      if (index + 1 < this._generatedMappings.length) {\n        var nextMapping = this._generatedMappings[index + 1];\n\n        if (mapping.generatedLine === nextMapping.generatedLine) {\n          mapping.lastGeneratedColumn = nextMapping.generatedColumn - 1;\n          continue;\n        }\n      }\n\n      // The last mapping for each line spans the entire line.\n      mapping.lastGeneratedColumn = Infinity;\n    }\n  };\n\n/**\n * Returns the original source, line, and column information for the generated\n * source's line and column positions provided. The only argument is an object\n * with the following properties:\n *\n *   - line: The line number in the generated source.\n *   - column: The column number in the generated source.\n *   - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or\n *     'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the\n *     closest element that is smaller than or greater than the one we are\n *     searching for, respectively, if the exact element cannot be found.\n *     Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.\n *\n * and an object is returned with the following properties:\n *\n *   - source: The original source file, or null.\n *   - line: The line number in the original source, or null.\n *   - column: The column number in the original source, or null.\n *   - name: The original identifier, or null.\n */\nBasicSourceMapConsumer.prototype.originalPositionFor =\n  function SourceMapConsumer_originalPositionFor(aArgs) {\n    var needle = {\n      generatedLine: util.getArg(aArgs, 'line'),\n      generatedColumn: util.getArg(aArgs, 'column')\n    };\n\n    var index = this._findMapping(\n      needle,\n      this._generatedMappings,\n      \"generatedLine\",\n      \"generatedColumn\",\n      util.compareByGeneratedPositionsDeflated,\n      util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)\n    );\n\n    if (index >= 0) {\n      var mapping = this._generatedMappings[index];\n\n      if (mapping.generatedLine === needle.generatedLine) {\n        var source = util.getArg(mapping, 'source', null);\n        if (source !== null) {\n          source = this._sources.at(source);\n          if (this.sourceRoot != null) {\n            source = util.join(this.sourceRoot, source);\n          }\n        }\n        var name = util.getArg(mapping, 'name', null);\n        if (name !== null) {\n          name = this._names.at(name);\n        }\n        return {\n          source: source,\n          line: util.getArg(mapping, 'originalLine', null),\n          column: util.getArg(mapping, 'originalColumn', null),\n          name: name\n        };\n      }\n    }\n\n    return {\n      source: null,\n      line: null,\n      column: null,\n      name: null\n    };\n  };\n\n/**\n * Return true if we have the source content for every source in the source\n * map, false otherwise.\n */\nBasicSourceMapConsumer.prototype.hasContentsOfAllSources =\n  function BasicSourceMapConsumer_hasContentsOfAllSources() {\n    if (!this.sourcesContent) {\n      return false;\n    }\n    return this.sourcesContent.length >= this._sources.size() &&\n      !this.sourcesContent.some(function (sc) { return sc == null; });\n  };\n\n/**\n * Returns the original source content. The only argument is the url of the\n * original source file. Returns null if no original source content is\n * available.\n */\nBasicSourceMapConsumer.prototype.sourceContentFor =\n  function SourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {\n    if (!this.sourcesContent) {\n      return null;\n    }\n\n    if (this.sourceRoot != null) {\n      aSource = util.relative(this.sourceRoot, aSource);\n    }\n\n    if (this._sources.has(aSource)) {\n      return this.sourcesContent[this._sources.indexOf(aSource)];\n    }\n\n    var url;\n    if (this.sourceRoot != null\n        && (url = util.urlParse(this.sourceRoot))) {\n      // XXX: file:// URIs and absolute paths lead to unexpected behavior for\n      // many users. We can help them out when they expect file:// URIs to\n      // behave like it would if they were running a local HTTP server. See\n      // https://bugzilla.mozilla.org/show_bug.cgi?id=885597.\n      var fileUriAbsPath = aSource.replace(/^file:\\/\\//, \"\");\n      if (url.scheme == \"file\"\n          && this._sources.has(fileUriAbsPath)) {\n        return this.sourcesContent[this._sources.indexOf(fileUriAbsPath)]\n      }\n\n      if ((!url.path || url.path == \"/\")\n          && this._sources.has(\"/\" + aSource)) {\n        return this.sourcesContent[this._sources.indexOf(\"/\" + aSource)];\n      }\n    }\n\n    // This function is used recursively from\n    // IndexedSourceMapConsumer.prototype.sourceContentFor. In that case, we\n    // don't want to throw if we can't find the source - we just want to\n    // return null, so we provide a flag to exit gracefully.\n    if (nullOnMissing) {\n      return null;\n    }\n    else {\n      throw new Error('\"' + aSource + '\" is not in the SourceMap.');\n    }\n  };\n\n/**\n * Returns the generated line and column information for the original source,\n * line, and column positions provided. The only argument is an object with\n * the following properties:\n *\n *   - source: The filename of the original source.\n *   - line: The line number in the original source.\n *   - column: The column number in the original source.\n *   - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or\n *     'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the\n *     closest element that is smaller than or greater than the one we are\n *     searching for, respectively, if the exact element cannot be found.\n *     Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.\n *\n * and an object is returned with the following properties:\n *\n *   - line: The line number in the generated source, or null.\n *   - column: The column number in the generated source, or null.\n */\nBasicSourceMapConsumer.prototype.generatedPositionFor =\n  function SourceMapConsumer_generatedPositionFor(aArgs) {\n    var source = util.getArg(aArgs, 'source');\n    if (this.sourceRoot != null) {\n      source = util.relative(this.sourceRoot, source);\n    }\n    if (!this._sources.has(source)) {\n      return {\n        line: null,\n        column: null,\n        lastColumn: null\n      };\n    }\n    source = this._sources.indexOf(source);\n\n    var needle = {\n      source: source,\n      originalLine: util.getArg(aArgs, 'line'),\n      originalColumn: util.getArg(aArgs, 'column')\n    };\n\n    var index = this._findMapping(\n      needle,\n      this._originalMappings,\n      \"originalLine\",\n      \"originalColumn\",\n      util.compareByOriginalPositions,\n      util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)\n    );\n\n    if (index >= 0) {\n      var mapping = this._originalMappings[index];\n\n      if (mapping.source === needle.source) {\n        return {\n          line: util.getArg(mapping, 'generatedLine', null),\n          column: util.getArg(mapping, 'generatedColumn', null),\n          lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)\n        };\n      }\n    }\n\n    return {\n      line: null,\n      column: null,\n      lastColumn: null\n    };\n  };\n\nexports.BasicSourceMapConsumer = BasicSourceMapConsumer;\n\n/**\n * An IndexedSourceMapConsumer instance represents a parsed source map which\n * we can query for information. It differs from BasicSourceMapConsumer in\n * that it takes \"indexed\" source maps (i.e. ones with a \"sections\" field) as\n * input.\n *\n * The only parameter is a raw source map (either as a JSON string, or already\n * parsed to an object). According to the spec for indexed source maps, they\n * have the following attributes:\n *\n *   - version: Which version of the source map spec this map is following.\n *   - file: Optional. The generated file this source map is associated with.\n *   - sections: A list of section definitions.\n *\n * Each value under the \"sections\" field has two fields:\n *   - offset: The offset into the original specified at which this section\n *       begins to apply, defined as an object with a \"line\" and \"column\"\n *       field.\n *   - map: A source map definition. This source map could also be indexed,\n *       but doesn't have to be.\n *\n * Instead of the \"map\" field, it's also possible to have a \"url\" field\n * specifying a URL to retrieve a source map from, but that's currently\n * unsupported.\n *\n * Here's an example source map, taken from the source map spec[0], but\n * modified to omit a section which uses the \"url\" field.\n *\n *  {\n *    version : 3,\n *    file: \"app.js\",\n *    sections: [{\n *      offset: {line:100, column:10},\n *      map: {\n *        version : 3,\n *        file: \"section.js\",\n *        sources: [\"foo.js\", \"bar.js\"],\n *        names: [\"src\", \"maps\", \"are\", \"fun\"],\n *        mappings: \"AAAA,E;;ABCDE;\"\n *      }\n *    }],\n *  }\n *\n * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit#heading=h.535es3xeprgt\n */\nfunction IndexedSourceMapConsumer(aSourceMap) {\n  var sourceMap = aSourceMap;\n  if (typeof aSourceMap === 'string') {\n    sourceMap = JSON.parse(aSourceMap.replace(/^\\)\\]\\}'/, ''));\n  }\n\n  var version = util.getArg(sourceMap, 'version');\n  var sections = util.getArg(sourceMap, 'sections');\n\n  if (version != this._version) {\n    throw new Error('Unsupported version: ' + version);\n  }\n\n  this._sources = new ArraySet();\n  this._names = new ArraySet();\n\n  var lastOffset = {\n    line: -1,\n    column: 0\n  };\n  this._sections = sections.map(function (s) {\n    if (s.url) {\n      // The url field will require support for asynchronicity.\n      // See https://github.com/mozilla/source-map/issues/16\n      throw new Error('Support for url field in sections not implemented.');\n    }\n    var offset = util.getArg(s, 'offset');\n    var offsetLine = util.getArg(offset, 'line');\n    var offsetColumn = util.getArg(offset, 'column');\n\n    if (offsetLine < lastOffset.line ||\n        (offsetLine === lastOffset.line && offsetColumn < lastOffset.column)) {\n      throw new Error('Section offsets must be ordered and non-overlapping.');\n    }\n    lastOffset = offset;\n\n    return {\n      generatedOffset: {\n        // The offset fields are 0-based, but we use 1-based indices when\n        // encoding/decoding from VLQ.\n        generatedLine: offsetLine + 1,\n        generatedColumn: offsetColumn + 1\n      },\n      consumer: new SourceMapConsumer(util.getArg(s, 'map'))\n    }\n  });\n}\n\nIndexedSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);\nIndexedSourceMapConsumer.prototype.constructor = SourceMapConsumer;\n\n/**\n * The version of the source mapping spec that we are consuming.\n */\nIndexedSourceMapConsumer.prototype._version = 3;\n\n/**\n * The list of original sources.\n */\nObject.defineProperty(IndexedSourceMapConsumer.prototype, 'sources', {\n  get: function () {\n    var sources = [];\n    for (var i = 0; i < this._sections.length; i++) {\n      for (var j = 0; j < this._sections[i].consumer.sources.length; j++) {\n        sources.push(this._sections[i].consumer.sources[j]);\n      }\n    }\n    return sources;\n  }\n});\n\n/**\n * Returns the original source, line, and column information for the generated\n * source's line and column positions provided. The only argument is an object\n * with the following properties:\n *\n *   - line: The line number in the generated source.\n *   - column: The column number in the generated source.\n *\n * and an object is returned with the following properties:\n *\n *   - source: The original source file, or null.\n *   - line: The line number in the original source, or null.\n *   - column: The column number in the original source, or null.\n *   - name: The original identifier, or null.\n */\nIndexedSourceMapConsumer.prototype.originalPositionFor =\n  function IndexedSourceMapConsumer_originalPositionFor(aArgs) {\n    var needle = {\n      generatedLine: util.getArg(aArgs, 'line'),\n      generatedColumn: util.getArg(aArgs, 'column')\n    };\n\n    // Find the section containing the generated position we're trying to map\n    // to an original position.\n    var sectionIndex = binarySearch.search(needle, this._sections,\n      function(needle, section) {\n        var cmp = needle.generatedLine - section.generatedOffset.generatedLine;\n        if (cmp) {\n          return cmp;\n        }\n\n        return (needle.generatedColumn -\n                section.generatedOffset.generatedColumn);\n      });\n    var section = this._sections[sectionIndex];\n\n    if (!section) {\n      return {\n        source: null,\n        line: null,\n        column: null,\n        name: null\n      };\n    }\n\n    return section.consumer.originalPositionFor({\n      line: needle.generatedLine -\n        (section.generatedOffset.generatedLine - 1),\n      column: needle.generatedColumn -\n        (section.generatedOffset.generatedLine === needle.generatedLine\n         ? section.generatedOffset.generatedColumn - 1\n         : 0),\n      bias: aArgs.bias\n    });\n  };\n\n/**\n * Return true if we have the source content for every source in the source\n * map, false otherwise.\n */\nIndexedSourceMapConsumer.prototype.hasContentsOfAllSources =\n  function IndexedSourceMapConsumer_hasContentsOfAllSources() {\n    return this._sections.every(function (s) {\n      return s.consumer.hasContentsOfAllSources();\n    });\n  };\n\n/**\n * Returns the original source content. The only argument is the url of the\n * original source file. Returns null if no original source content is\n * available.\n */\nIndexedSourceMapConsumer.prototype.sourceContentFor =\n  function IndexedSourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {\n    for (var i = 0; i < this._sections.length; i++) {\n      var section = this._sections[i];\n\n      var content = section.consumer.sourceContentFor(aSource, true);\n      if (content) {\n        return content;\n      }\n    }\n    if (nullOnMissing) {\n      return null;\n    }\n    else {\n      throw new Error('\"' + aSource + '\" is not in the SourceMap.');\n    }\n  };\n\n/**\n * Returns the generated line and column information for the original source,\n * line, and column positions provided. The only argument is an object with\n * the following properties:\n *\n *   - source: The filename of the original source.\n *   - line: The line number in the original source.\n *   - column: The column number in the original source.\n *\n * and an object is returned with the following properties:\n *\n *   - line: The line number in the generated source, or null.\n *   - column: The column number in the generated source, or null.\n */\nIndexedSourceMapConsumer.prototype.generatedPositionFor =\n  function IndexedSourceMapConsumer_generatedPositionFor(aArgs) {\n    for (var i = 0; i < this._sections.length; i++) {\n      var section = this._sections[i];\n\n      // Only consider this section if the requested source is in the list of\n      // sources of the consumer.\n      if (section.consumer.sources.indexOf(util.getArg(aArgs, 'source')) === -1) {\n        continue;\n      }\n      var generatedPosition = section.consumer.generatedPositionFor(aArgs);\n      if (generatedPosition) {\n        var ret = {\n          line: generatedPosition.line +\n            (section.generatedOffset.generatedLine - 1),\n          column: generatedPosition.column +\n            (section.generatedOffset.generatedLine === generatedPosition.line\n             ? section.generatedOffset.generatedColumn - 1\n             : 0)\n        };\n        return ret;\n      }\n    }\n\n    return {\n      line: null,\n      column: null\n    };\n  };\n\n/**\n * Parse the mappings in a string in to a data structure which we can easily\n * query (the ordered arrays in the `this.__generatedMappings` and\n * `this.__originalMappings` properties).\n */\nIndexedSourceMapConsumer.prototype._parseMappings =\n  function IndexedSourceMapConsumer_parseMappings(aStr, aSourceRoot) {\n    this.__generatedMappings = [];\n    this.__originalMappings = [];\n    for (var i = 0; i < this._sections.length; i++) {\n      var section = this._sections[i];\n      var sectionMappings = section.consumer._generatedMappings;\n      for (var j = 0; j < sectionMappings.length; j++) {\n        var mapping = sectionMappings[j];\n\n        var source = section.consumer._sources.at(mapping.source);\n        if (section.consumer.sourceRoot !== null) {\n          source = util.join(section.consumer.sourceRoot, source);\n        }\n        this._sources.add(source);\n        source = this._sources.indexOf(source);\n\n        var name = section.consumer._names.at(mapping.name);\n        this._names.add(name);\n        name = this._names.indexOf(name);\n\n        // The mappings coming from the consumer for the section have\n        // generated positions relative to the start of the section, so we\n        // need to offset them to be relative to the start of the concatenated\n        // generated file.\n        var adjustedMapping = {\n          source: source,\n          generatedLine: mapping.generatedLine +\n            (section.generatedOffset.generatedLine - 1),\n          generatedColumn: mapping.generatedColumn +\n            (section.generatedOffset.generatedLine === mapping.generatedLine\n            ? section.generatedOffset.generatedColumn - 1\n            : 0),\n          originalLine: mapping.originalLine,\n          originalColumn: mapping.originalColumn,\n          name: name\n        };\n\n        this.__generatedMappings.push(adjustedMapping);\n        if (typeof adjustedMapping.originalLine === 'number') {\n          this.__originalMappings.push(adjustedMapping);\n        }\n      }\n    }\n\n    quickSort(this.__generatedMappings, util.compareByGeneratedPositionsDeflated);\n    quickSort(this.__originalMappings, util.compareByOriginalPositions);\n  };\n\nexports.IndexedSourceMapConsumer = IndexedSourceMapConsumer;\n","/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\n/**\n * This is a helper function for getting values from parameter/options\n * objects.\n *\n * @param args The object we are extracting values from\n * @param name The name of the property we are getting.\n * @param defaultValue An optional value to return if the property is missing\n * from the object. If this is not specified and the property is missing, an\n * error will be thrown.\n */\nfunction getArg(aArgs, aName, aDefaultValue) {\n  if (aName in aArgs) {\n    return aArgs[aName];\n  } else if (arguments.length === 3) {\n    return aDefaultValue;\n  } else {\n    throw new Error('\"' + aName + '\" is a required argument.');\n  }\n}\nexports.getArg = getArg;\n\nvar urlRegexp = /^(?:([\\w+\\-.]+):)?\\/\\/(?:(\\w+:\\w+)@)?([\\w.]*)(?::(\\d+))?(\\S*)$/;\nvar dataUrlRegexp = /^data:.+\\,.+$/;\n\nfunction urlParse(aUrl) {\n  var match = aUrl.match(urlRegexp);\n  if (!match) {\n    return null;\n  }\n  return {\n    scheme: match[1],\n    auth: match[2],\n    host: match[3],\n    port: match[4],\n    path: match[5]\n  };\n}\nexports.urlParse = urlParse;\n\nfunction urlGenerate(aParsedUrl) {\n  var url = '';\n  if (aParsedUrl.scheme) {\n    url += aParsedUrl.scheme + ':';\n  }\n  url += '//';\n  if (aParsedUrl.auth) {\n    url += aParsedUrl.auth + '@';\n  }\n  if (aParsedUrl.host) {\n    url += aParsedUrl.host;\n  }\n  if (aParsedUrl.port) {\n    url += \":\" + aParsedUrl.port\n  }\n  if (aParsedUrl.path) {\n    url += aParsedUrl.path;\n  }\n  return url;\n}\nexports.urlGenerate = urlGenerate;\n\n/**\n * Normalizes a path, or the path portion of a URL:\n *\n * - Replaces consecutive slashes with one slash.\n * - Removes unnecessary '.' parts.\n * - Removes unnecessary '<dir>/..' parts.\n *\n * Based on code in the Node.js 'path' core module.\n *\n * @param aPath The path or url to normalize.\n */\nfunction normalize(aPath) {\n  var path = aPath;\n  var url = urlParse(aPath);\n  if (url) {\n    if (!url.path) {\n      return aPath;\n    }\n    path = url.path;\n  }\n  var isAbsolute = exports.isAbsolute(path);\n\n  var parts = path.split(/\\/+/);\n  for (var part, up = 0, i = parts.length - 1; i >= 0; i--) {\n    part = parts[i];\n    if (part === '.') {\n      parts.splice(i, 1);\n    } else if (part === '..') {\n      up++;\n    } else if (up > 0) {\n      if (part === '') {\n        // The first part is blank if the path is absolute. Trying to go\n        // above the root is a no-op. Therefore we can remove all '..' parts\n        // directly after the root.\n        parts.splice(i + 1, up);\n        up = 0;\n      } else {\n        parts.splice(i, 2);\n        up--;\n      }\n    }\n  }\n  path = parts.join('/');\n\n  if (path === '') {\n    path = isAbsolute ? '/' : '.';\n  }\n\n  if (url) {\n    url.path = path;\n    return urlGenerate(url);\n  }\n  return path;\n}\nexports.normalize = normalize;\n\n/**\n * Joins two paths/URLs.\n *\n * @param aRoot The root path or URL.\n * @param aPath The path or URL to be joined with the root.\n *\n * - If aPath is a URL or a data URI, aPath is returned, unless aPath is a\n *   scheme-relative URL: Then the scheme of aRoot, if any, is prepended\n *   first.\n * - Otherwise aPath is a path. If aRoot is a URL, then its path portion\n *   is updated with the result and aRoot is returned. Otherwise the result\n *   is returned.\n *   - If aPath is absolute, the result is aPath.\n *   - Otherwise the two paths are joined with a slash.\n * - Joining for example 'http://' and 'www.example.com' is also supported.\n */\nfunction join(aRoot, aPath) {\n  if (aRoot === \"\") {\n    aRoot = \".\";\n  }\n  if (aPath === \"\") {\n    aPath = \".\";\n  }\n  var aPathUrl = urlParse(aPath);\n  var aRootUrl = urlParse(aRoot);\n  if (aRootUrl) {\n    aRoot = aRootUrl.path || '/';\n  }\n\n  // `join(foo, '//www.example.org')`\n  if (aPathUrl && !aPathUrl.scheme) {\n    if (aRootUrl) {\n      aPathUrl.scheme = aRootUrl.scheme;\n    }\n    return urlGenerate(aPathUrl);\n  }\n\n  if (aPathUrl || aPath.match(dataUrlRegexp)) {\n    return aPath;\n  }\n\n  // `join('http://', 'www.example.com')`\n  if (aRootUrl && !aRootUrl.host && !aRootUrl.path) {\n    aRootUrl.host = aPath;\n    return urlGenerate(aRootUrl);\n  }\n\n  var joined = aPath.charAt(0) === '/'\n    ? aPath\n    : normalize(aRoot.replace(/\\/+$/, '') + '/' + aPath);\n\n  if (aRootUrl) {\n    aRootUrl.path = joined;\n    return urlGenerate(aRootUrl);\n  }\n  return joined;\n}\nexports.join = join;\n\nexports.isAbsolute = function (aPath) {\n  return aPath.charAt(0) === '/' || !!aPath.match(urlRegexp);\n};\n\n/**\n * Make a path relative to a URL or another path.\n *\n * @param aRoot The root path or URL.\n * @param aPath The path or URL to be made relative to aRoot.\n */\nfunction relative(aRoot, aPath) {\n  if (aRoot === \"\") {\n    aRoot = \".\";\n  }\n\n  aRoot = aRoot.replace(/\\/$/, '');\n\n  // It is possible for the path to be above the root. In this case, simply\n  // checking whether the root is a prefix of the path won't work. Instead, we\n  // need to remove components from the root one by one, until either we find\n  // a prefix that fits, or we run out of components to remove.\n  var level = 0;\n  while (aPath.indexOf(aRoot + '/') !== 0) {\n    var index = aRoot.lastIndexOf(\"/\");\n    if (index < 0) {\n      return aPath;\n    }\n\n    // If the only part of the root that is left is the scheme (i.e. http://,\n    // file:///, etc.), one or more slashes (/), or simply nothing at all, we\n    // have exhausted all components, so the path is not relative to the root.\n    aRoot = aRoot.slice(0, index);\n    if (aRoot.match(/^([^\\/]+:\\/)?\\/*$/)) {\n      return aPath;\n    }\n\n    ++level;\n  }\n\n  // Make sure we add a \"../\" for each component we removed from the root.\n  return Array(level + 1).join(\"../\") + aPath.substr(aRoot.length + 1);\n}\nexports.relative = relative;\n\nvar supportsNullProto = (function () {\n  var obj = Object.create(null);\n  return !('__proto__' in obj);\n}());\n\nfunction identity (s) {\n  return s;\n}\n\n/**\n * Because behavior goes wacky when you set `__proto__` on objects, we\n * have to prefix all the strings in our set with an arbitrary character.\n *\n * See https://github.com/mozilla/source-map/pull/31 and\n * https://github.com/mozilla/source-map/issues/30\n *\n * @param String aStr\n */\nfunction toSetString(aStr) {\n  if (isProtoString(aStr)) {\n    return '$' + aStr;\n  }\n\n  return aStr;\n}\nexports.toSetString = supportsNullProto ? identity : toSetString;\n\nfunction fromSetString(aStr) {\n  if (isProtoString(aStr)) {\n    return aStr.slice(1);\n  }\n\n  return aStr;\n}\nexports.fromSetString = supportsNullProto ? identity : fromSetString;\n\nfunction isProtoString(s) {\n  if (!s) {\n    return false;\n  }\n\n  var length = s.length;\n\n  if (length < 9 /* \"__proto__\".length */) {\n    return false;\n  }\n\n  if (s.charCodeAt(length - 1) !== 95  /* '_' */ ||\n      s.charCodeAt(length - 2) !== 95  /* '_' */ ||\n      s.charCodeAt(length - 3) !== 111 /* 'o' */ ||\n      s.charCodeAt(length - 4) !== 116 /* 't' */ ||\n      s.charCodeAt(length - 5) !== 111 /* 'o' */ ||\n      s.charCodeAt(length - 6) !== 114 /* 'r' */ ||\n      s.charCodeAt(length - 7) !== 112 /* 'p' */ ||\n      s.charCodeAt(length - 8) !== 95  /* '_' */ ||\n      s.charCodeAt(length - 9) !== 95  /* '_' */) {\n    return false;\n  }\n\n  for (var i = length - 10; i >= 0; i--) {\n    if (s.charCodeAt(i) !== 36 /* '$' */) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\n/**\n * Comparator between two mappings where the original positions are compared.\n *\n * Optionally pass in `true` as `onlyCompareGenerated` to consider two\n * mappings with the same original source/line/column, but different generated\n * line and column the same. Useful when searching for a mapping with a\n * stubbed out mapping.\n */\nfunction compareByOriginalPositions(mappingA, mappingB, onlyCompareOriginal) {\n  var cmp = mappingA.source - mappingB.source;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  cmp = mappingA.originalLine - mappingB.originalLine;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  cmp = mappingA.originalColumn - mappingB.originalColumn;\n  if (cmp !== 0 || onlyCompareOriginal) {\n    return cmp;\n  }\n\n  cmp = mappingA.generatedColumn - mappingB.generatedColumn;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  cmp = mappingA.generatedLine - mappingB.generatedLine;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  return mappingA.name - mappingB.name;\n}\nexports.compareByOriginalPositions = compareByOriginalPositions;\n\n/**\n * Comparator between two mappings with deflated source and name indices where\n * the generated positions are compared.\n *\n * Optionally pass in `true` as `onlyCompareGenerated` to consider two\n * mappings with the same generated line and column, but different\n * source/name/original line and column the same. Useful when searching for a\n * mapping with a stubbed out mapping.\n */\nfunction compareByGeneratedPositionsDeflated(mappingA, mappingB, onlyCompareGenerated) {\n  var cmp = mappingA.generatedLine - mappingB.generatedLine;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  cmp = mappingA.generatedColumn - mappingB.generatedColumn;\n  if (cmp !== 0 || onlyCompareGenerated) {\n    return cmp;\n  }\n\n  cmp = mappingA.source - mappingB.source;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  cmp = mappingA.originalLine - mappingB.originalLine;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  cmp = mappingA.originalColumn - mappingB.originalColumn;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  return mappingA.name - mappingB.name;\n}\nexports.compareByGeneratedPositionsDeflated = compareByGeneratedPositionsDeflated;\n\nfunction strcmp(aStr1, aStr2) {\n  if (aStr1 === aStr2) {\n    return 0;\n  }\n\n  if (aStr1 > aStr2) {\n    return 1;\n  }\n\n  return -1;\n}\n\n/**\n * Comparator between two mappings with inflated source and name strings where\n * the generated positions are compared.\n */\nfunction compareByGeneratedPositionsInflated(mappingA, mappingB) {\n  var cmp = mappingA.generatedLine - mappingB.generatedLine;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  cmp = mappingA.generatedColumn - mappingB.generatedColumn;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  cmp = strcmp(mappingA.source, mappingB.source);\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  cmp = mappingA.originalLine - mappingB.originalLine;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  cmp = mappingA.originalColumn - mappingB.originalColumn;\n  if (cmp !== 0) {\n    return cmp;\n  }\n\n  return strcmp(mappingA.name, mappingB.name);\n}\nexports.compareByGeneratedPositionsInflated = compareByGeneratedPositionsInflated;\n","(function(root, factory) {\n    'use strict';\n    // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.\n\n    /* istanbul ignore next */\n    if (typeof define === 'function' && define.amd) {\n        define('stacktrace-gps', ['source-map', 'stackframe'], factory);\n    } else if (typeof exports === 'object') {\n        module.exports = factory(require('source-map/lib/source-map-consumer'), require('stackframe'));\n    } else {\n        root.StackTraceGPS = factory(root.SourceMap || root.sourceMap, root.StackFrame);\n    }\n}(this, function(SourceMap, StackFrame) {\n    'use strict';\n\n    /**\n     * Make a X-Domain request to url and callback.\n     *\n     * @param {String} url\n     * @returns {Promise} with response text if fulfilled\n     */\n    function _xdr(url) {\n        return new Promise(function(resolve, reject) {\n            var req = new XMLHttpRequest();\n            req.open('get', url);\n            req.onerror = reject;\n            req.onreadystatechange = function onreadystatechange() {\n                if (req.readyState === 4) {\n                    if ((req.status >= 200 && req.status < 300) ||\n                        (url.substr(0, 7) === 'file://' && req.responseText)) {\n                        resolve(req.responseText);\n                    } else {\n                        reject(new Error('HTTP status: ' + req.status + ' retrieving ' + url));\n                    }\n                }\n            };\n            req.send();\n        });\n\n    }\n\n    /**\n     * Convert a Base64-encoded string into its original representation.\n     * Used for inline sourcemaps.\n     *\n     * @param {String} b64str Base-64 encoded string\n     * @returns {String} original representation of the base64-encoded string.\n     */\n    function _atob(b64str) {\n        if (typeof window !== 'undefined' && window.atob) {\n            return window.atob(b64str);\n        } else {\n            throw new Error('You must supply a polyfill for window.atob in this environment');\n        }\n    }\n\n    function _parseJson(string) {\n        if (typeof JSON !== 'undefined' && JSON.parse) {\n            return JSON.parse(string);\n        } else {\n            throw new Error('You must supply a polyfill for JSON.parse in this environment');\n        }\n    }\n\n    function _findFunctionName(source, lineNumber/*, columnNumber*/) {\n        var syntaxes = [\n            // {name} = function ({args}) TODO args capture\n            /['\"]?([$_A-Za-z][$_A-Za-z0-9]*)['\"]?\\s*[:=]\\s*function\\b/,\n            // function {name}({args}) m[1]=name m[2]=args\n            /function\\s+([^('\"`]*?)\\s*\\(([^)]*)\\)/,\n            // {name} = eval()\n            /['\"]?([$_A-Za-z][$_A-Za-z0-9]*)['\"]?\\s*[:=]\\s*(?:eval|new Function)\\b/,\n            // fn_name() {\n            /\\b(?!(?:if|for|switch|while|with|catch)\\b)(?:(?:static)\\s+)?(\\S+)\\s*\\(.*?\\)\\s*\\{/,\n            // {name} = () => {\n            /['\"]?([$_A-Za-z][$_A-Za-z0-9]*)['\"]?\\s*[:=]\\s*\\(.*?\\)\\s*=>/\n        ];\n        var lines = source.split('\\n');\n\n        // Walk backwards in the source lines until we find the line which matches one of the patterns above\n        var code = '';\n        var maxLines = Math.min(lineNumber, 20);\n        for (var i = 0; i < maxLines; ++i) {\n            // lineNo is 1-based, source[] is 0-based\n            var line = lines[lineNumber - i - 1];\n            var commentPos = line.indexOf('//');\n            if (commentPos >= 0) {\n                line = line.substr(0, commentPos);\n            }\n\n            if (line) {\n                code = line + code;\n                var len = syntaxes.length;\n                for (var index = 0; index < len; index++) {\n                    var m = syntaxes[index].exec(code);\n                    if (m && m[1]) {\n                        return m[1];\n                    }\n                }\n            }\n        }\n        return undefined;\n    }\n\n    function _ensureSupportedEnvironment() {\n        if (typeof Object.defineProperty !== 'function' || typeof Object.create !== 'function') {\n            throw new Error('Unable to consume source maps in older browsers');\n        }\n    }\n\n    function _ensureStackFrameIsLegit(stackframe) {\n        if (typeof stackframe !== 'object') {\n            throw new TypeError('Given StackFrame is not an object');\n        } else if (typeof stackframe.fileName !== 'string') {\n            throw new TypeError('Given file name is not a String');\n        } else if (typeof stackframe.lineNumber !== 'number' ||\n            stackframe.lineNumber % 1 !== 0 ||\n            stackframe.lineNumber < 1) {\n            throw new TypeError('Given line number must be a positive integer');\n        } else if (typeof stackframe.columnNumber !== 'number' ||\n            stackframe.columnNumber % 1 !== 0 ||\n            stackframe.columnNumber < 0) {\n            throw new TypeError('Given column number must be a non-negative integer');\n        }\n        return true;\n    }\n\n    function _findSourceMappingURL(source) {\n        var sourceMappingUrlRegExp = /\\/\\/[#@] ?sourceMappingURL=([^\\s'\"]+)\\s*$/mg;\n        var lastSourceMappingUrl;\n        var matchSourceMappingUrl;\n        while (matchSourceMappingUrl = sourceMappingUrlRegExp.exec(source)) { // jshint ignore:line\n            lastSourceMappingUrl = matchSourceMappingUrl[1];\n        }\n        if (lastSourceMappingUrl) {\n            return lastSourceMappingUrl;\n        } else {\n            throw new Error('sourceMappingURL not found');\n        }\n    }\n\n    function _extractLocationInfoFromSourceMapSource(stackframe, sourceMapConsumer, sourceCache) {\n        return new Promise(function(resolve, reject) {\n            var loc = sourceMapConsumer.originalPositionFor({\n                line: stackframe.lineNumber,\n                column: stackframe.columnNumber\n            });\n\n            if (loc.source) {\n                // cache mapped sources\n                var mappedSource = sourceMapConsumer.sourceContentFor(loc.source);\n                if (mappedSource) {\n                    sourceCache[loc.source] = mappedSource;\n                }\n\n                resolve(\n                    // given stackframe and source location, update stackframe\n                    new StackFrame({\n                        functionName: loc.name || stackframe.functionName,\n                        args: stackframe.args,\n                        fileName: loc.source,\n                        lineNumber: loc.line,\n                        columnNumber: loc.column\n                    }));\n            } else {\n                reject(new Error('Could not get original source for given stackframe and source map'));\n            }\n        });\n    }\n\n    /**\n     * @constructor\n     * @param {Object} opts\n     *      opts.sourceCache = {url: \"Source String\"} => preload source cache\n     *      opts.sourceMapConsumerCache = {/path/file.js.map: SourceMapConsumer}\n     *      opts.offline = True to prevent network requests.\n     *              Best effort without sources or source maps.\n     *      opts.ajax = Promise returning function to make X-Domain requests\n     */\n    return function StackTraceGPS(opts) {\n        if (!(this instanceof StackTraceGPS)) {\n            return new StackTraceGPS(opts);\n        }\n        opts = opts || {};\n\n        this.sourceCache = opts.sourceCache || {};\n        this.sourceMapConsumerCache = opts.sourceMapConsumerCache || {};\n\n        this.ajax = opts.ajax || _xdr;\n\n        this._atob = opts.atob || _atob;\n\n        this._get = function _get(location) {\n            return new Promise(function(resolve, reject) {\n                var isDataUrl = location.substr(0, 5) === 'data:';\n                if (this.sourceCache[location]) {\n                    resolve(this.sourceCache[location]);\n                } else if (opts.offline && !isDataUrl) {\n                    reject(new Error('Cannot make network requests in offline mode'));\n                } else {\n                    if (isDataUrl) {\n                        // data URLs can have parameters.\n                        // see http://tools.ietf.org/html/rfc2397\n                        var supportedEncodingRegexp =\n                            /^data:application\\/json;([\\w=:\"-]+;)*base64,/;\n                        var match = location.match(supportedEncodingRegexp);\n                        if (match) {\n                            var sourceMapStart = match[0].length;\n                            var encodedSource = location.substr(sourceMapStart);\n                            var source = this._atob(encodedSource);\n                            this.sourceCache[location] = source;\n                            resolve(source);\n                        } else {\n                            reject(new Error('The encoding of the inline sourcemap is not supported'));\n                        }\n                    } else {\n                        var xhrPromise = this.ajax(location, {method: 'get'});\n                        // Cache the Promise to prevent duplicate in-flight requests\n                        this.sourceCache[location] = xhrPromise;\n                        xhrPromise.then(resolve, reject);\n                    }\n                }\n            }.bind(this));\n        };\n\n        /**\n         * Creating SourceMapConsumers is expensive, so this wraps the creation of a\n         * SourceMapConsumer in a per-instance cache.\n         *\n         * @param {String} sourceMappingURL = URL to fetch source map from\n         * @param {String} defaultSourceRoot = Default source root for source map if undefined\n         * @returns {Promise} that resolves a SourceMapConsumer\n         */\n        this._getSourceMapConsumer = function _getSourceMapConsumer(sourceMappingURL, defaultSourceRoot) {\n            return new Promise(function(resolve, reject) {\n                if (this.sourceMapConsumerCache[sourceMappingURL]) {\n                    resolve(this.sourceMapConsumerCache[sourceMappingURL]);\n                } else {\n                    var sourceMapConsumerPromise = new Promise(function(resolve, reject) {\n                        return this._get(sourceMappingURL).then(function(sourceMapSource) {\n                            if (typeof sourceMapSource === 'string') {\n                                sourceMapSource = _parseJson(sourceMapSource.replace(/^\\)\\]\\}'/, ''));\n                            }\n                            if (typeof sourceMapSource.sourceRoot === 'undefined') {\n                                sourceMapSource.sourceRoot = defaultSourceRoot;\n                            }\n\n                            resolve(new SourceMap.SourceMapConsumer(sourceMapSource));\n                        }, reject);\n                    }.bind(this));\n                    this.sourceMapConsumerCache[sourceMappingURL] = sourceMapConsumerPromise;\n                    resolve(sourceMapConsumerPromise);\n                }\n            }.bind(this));\n        };\n\n        /**\n         * Given a StackFrame, enhance function name and use source maps for a\n         * better StackFrame.\n         *\n         * @param {StackFrame} stackframe object\n         * @returns {Promise} that resolves with with source-mapped StackFrame\n         */\n        this.pinpoint = function StackTraceGPS$$pinpoint(stackframe) {\n            return new Promise(function(resolve, reject) {\n                this.getMappedLocation(stackframe).then(function(mappedStackFrame) {\n                    function resolveMappedStackFrame() {\n                        resolve(mappedStackFrame);\n                    }\n\n                    this.findFunctionName(mappedStackFrame)\n                        .then(resolve, resolveMappedStackFrame)\n                        ['catch'](resolveMappedStackFrame);\n                }.bind(this), reject);\n            }.bind(this));\n        };\n\n        /**\n         * Given a StackFrame, guess function name from location information.\n         *\n         * @param {StackFrame} stackframe\n         * @returns {Promise} that resolves with enhanced StackFrame.\n         */\n        this.findFunctionName = function StackTraceGPS$$findFunctionName(stackframe) {\n            return new Promise(function(resolve, reject) {\n                _ensureStackFrameIsLegit(stackframe);\n                this._get(stackframe.fileName).then(function getSourceCallback(source) {\n                    var lineNumber = stackframe.lineNumber;\n                    var columnNumber = stackframe.columnNumber;\n                    var guessedFunctionName = _findFunctionName(source, lineNumber, columnNumber);\n                    // Only replace functionName if we found something\n                    if (guessedFunctionName) {\n                        resolve(new StackFrame({\n                            functionName: guessedFunctionName,\n                            args: stackframe.args,\n                            fileName: stackframe.fileName,\n                            lineNumber: lineNumber,\n                            columnNumber: columnNumber\n                        }));\n                    } else {\n                        resolve(stackframe);\n                    }\n                }, reject)['catch'](reject);\n            }.bind(this));\n        };\n\n        /**\n         * Given a StackFrame, seek source-mapped location and return new enhanced StackFrame.\n         *\n         * @param {StackFrame} stackframe\n         * @returns {Promise} that resolves with enhanced StackFrame.\n         */\n        this.getMappedLocation = function StackTraceGPS$$getMappedLocation(stackframe) {\n            return new Promise(function(resolve, reject) {\n                _ensureSupportedEnvironment();\n                _ensureStackFrameIsLegit(stackframe);\n\n                var sourceCache = this.sourceCache;\n                var fileName = stackframe.fileName;\n                this._get(fileName).then(function(source) {\n                    var sourceMappingURL = _findSourceMappingURL(source);\n                    var isDataUrl = sourceMappingURL.substr(0, 5) === 'data:';\n                    var defaultSourceRoot = fileName.substring(0, fileName.lastIndexOf('/') + 1);\n\n                    if (sourceMappingURL[0] !== '/' && !isDataUrl && !(/^https?:\\/\\/|^\\/\\//i).test(sourceMappingURL)) {\n                        sourceMappingURL = defaultSourceRoot + sourceMappingURL;\n                    }\n\n                    return this._getSourceMapConsumer(sourceMappingURL, defaultSourceRoot)\n                        .then(function(sourceMapConsumer) {\n                            return _extractLocationInfoFromSourceMapSource(stackframe, sourceMapConsumer, sourceCache)\n                                .then(resolve)['catch'](function() {\n                                resolve(stackframe);\n                            });\n                        });\n                }.bind(this), reject)['catch'](reject);\n            }.bind(this));\n        };\n    };\n}));\n","(function(root, factory) {\n    'use strict';\n    // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.\n\n    /* istanbul ignore next */\n    if (typeof define === 'function' && define.amd) {\n        define('stacktrace', ['error-stack-parser', 'stack-generator', 'stacktrace-gps'], factory);\n    } else if (typeof exports === 'object') {\n        module.exports = factory(require('error-stack-parser'), require('stack-generator'), require('stacktrace-gps'));\n    } else {\n        root.StackTrace = factory(root.ErrorStackParser, root.StackGenerator, root.StackTraceGPS);\n    }\n}(this, function StackTrace(ErrorStackParser, StackGenerator, StackTraceGPS) {\n    var _options = {\n        filter: function(stackframe) {\n            // Filter out stackframes for this library by default\n            return (stackframe.functionName || '').indexOf('StackTrace$$') === -1 &&\n                (stackframe.functionName || '').indexOf('ErrorStackParser$$') === -1 &&\n                (stackframe.functionName || '').indexOf('StackTraceGPS$$') === -1 &&\n                (stackframe.functionName || '').indexOf('StackGenerator$$') === -1;\n        },\n        sourceCache: {}\n    };\n\n    var _generateError = function StackTrace$$GenerateError() {\n        try {\n            // Error must be thrown to get stack in IE\n            throw new Error();\n        } catch (err) {\n            return err;\n        }\n    };\n\n    /**\n     * Merge 2 given Objects. If a conflict occurs the second object wins.\n     * Does not do deep merges.\n     *\n     * @param {Object} first base object\n     * @param {Object} second overrides\n     * @returns {Object} merged first and second\n     * @private\n     */\n    function _merge(first, second) {\n        var target = {};\n\n        [first, second].forEach(function(obj) {\n            for (var prop in obj) {\n                if (obj.hasOwnProperty(prop)) {\n                    target[prop] = obj[prop];\n                }\n            }\n            return target;\n        });\n\n        return target;\n    }\n\n    function _isShapedLikeParsableError(err) {\n        return err.stack || err['opera#sourceloc'];\n    }\n\n    function _filtered(stackframes, filter) {\n        if (typeof filter === 'function') {\n            return stackframes.filter(filter);\n        }\n        return stackframes;\n    }\n\n    return {\n        /**\n         * Get a backtrace from invocation point.\n         *\n         * @param {Object} opts\n         * @returns {Array} of StackFrame\n         */\n        get: function StackTrace$$get(opts) {\n            var err = _generateError();\n            return _isShapedLikeParsableError(err) ? this.fromError(err, opts) : this.generateArtificially(opts);\n        },\n\n        /**\n         * Get a backtrace from invocation point.\n         * IMPORTANT: Does not handle source maps or guess function names!\n         *\n         * @param {Object} opts\n         * @returns {Array} of StackFrame\n         */\n        getSync: function StackTrace$$getSync(opts) {\n            opts = _merge(_options, opts);\n            var err = _generateError();\n            var stack = _isShapedLikeParsableError(err) ? ErrorStackParser.parse(err) : StackGenerator.backtrace(opts);\n            return _filtered(stack, opts.filter);\n        },\n\n        /**\n         * Given an error object, parse it.\n         *\n         * @param {Error} error object\n         * @param {Object} opts\n         * @returns {Promise} for Array[StackFrame}\n         */\n        fromError: function StackTrace$$fromError(error, opts) {\n            opts = _merge(_options, opts);\n            var gps = new StackTraceGPS(opts);\n            return new Promise(function(resolve) {\n                var stackframes = _filtered(ErrorStackParser.parse(error), opts.filter);\n                resolve(Promise.all(stackframes.map(function(sf) {\n                    return new Promise(function(resolve) {\n                        function resolveOriginal() {\n                            resolve(sf);\n                        }\n\n                        gps.pinpoint(sf).then(resolve, resolveOriginal)['catch'](resolveOriginal);\n                    });\n                })));\n            }.bind(this));\n        },\n\n        /**\n         * Use StackGenerator to generate a backtrace.\n         *\n         * @param {Object} opts\n         * @returns {Promise} of Array[StackFrame]\n         */\n        generateArtificially: function StackTrace$$generateArtificially(opts) {\n            opts = _merge(_options, opts);\n            var stackFrames = StackGenerator.backtrace(opts);\n            if (typeof opts.filter === 'function') {\n                stackFrames = stackFrames.filter(opts.filter);\n            }\n            return Promise.resolve(stackFrames);\n        },\n\n        /**\n         * Given a function, wrap it such that invocations trigger a callback that\n         * is called with a stack trace.\n         *\n         * @param {Function} fn to be instrumented\n         * @param {Function} callback function to call with a stack trace on invocation\n         * @param {Function} errback optional function to call with error if unable to get stack trace.\n         * @param {Object} thisArg optional context object (e.g. window)\n         */\n        instrument: function StackTrace$$instrument(fn, callback, errback, thisArg) {\n            if (typeof fn !== 'function') {\n                throw new Error('Cannot instrument non-function object');\n            } else if (typeof fn.__stacktraceOriginalFn === 'function') {\n                // Already instrumented, return given Function\n                return fn;\n            }\n\n            var instrumented = function StackTrace$$instrumented() {\n                try {\n                    this.get().then(callback, errback)['catch'](errback);\n                    return fn.apply(thisArg || this, arguments);\n                } catch (e) {\n                    if (_isShapedLikeParsableError(e)) {\n                        this.fromError(e).then(callback, errback)['catch'](errback);\n                    }\n                    throw e;\n                }\n            }.bind(this);\n            instrumented.__stacktraceOriginalFn = fn;\n\n            return instrumented;\n        },\n\n        /**\n         * Given a function that has been instrumented,\n         * revert the function to it's original (non-instrumented) state.\n         *\n         * @param {Function} fn to de-instrument\n         */\n        deinstrument: function StackTrace$$deinstrument(fn) {\n            if (typeof fn !== 'function') {\n                throw new Error('Cannot de-instrument non-function object');\n            } else if (typeof fn.__stacktraceOriginalFn === 'function') {\n                return fn.__stacktraceOriginalFn;\n            } else {\n                // Function not instrumented, return original\n                return fn;\n            }\n        },\n\n        /**\n         * Given an error message and Array of StackFrames, serialize and POST to given URL.\n         *\n         * @param {Array} stackframes\n         * @param {String} url\n         * @param {String} errorMsg\n         * @param {Object} requestOptions\n         */\n        report: function StackTrace$$report(stackframes, url, errorMsg, requestOptions) {\n            return new Promise(function(resolve, reject) {\n                var req = new XMLHttpRequest();\n                req.onerror = reject;\n                req.onreadystatechange = function onreadystatechange() {\n                    if (req.readyState === 4) {\n                        if (req.status >= 200 && req.status < 400) {\n                            resolve(req.responseText);\n                        } else {\n                            reject(new Error('POST to ' + url + ' failed with status: ' + req.status));\n                        }\n                    }\n                };\n                req.open('post', url);\n\n                // Set request headers\n                req.setRequestHeader('Content-Type', 'application/json');\n                if (requestOptions && typeof requestOptions.headers === 'object') {\n                    var headers = requestOptions.headers;\n                    for (var header in headers) {\n                        if (headers.hasOwnProperty(header)) {\n                            req.setRequestHeader(header, headers[header]);\n                        }\n                    }\n                }\n\n                var reportPayload = {stack: stackframes};\n                if (errorMsg !== undefined && errorMsg !== null) {\n                    reportPayload.message = errorMsg;\n                }\n\n                req.send(JSON.stringify(reportPayload));\n            });\n        }\n    };\n}));\n"]}