| (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){ |
| (function (process,global){ |
| 'use strict'; |
| |
| /* eslint no-unused-vars: off */ |
| /* eslint-env commonjs */ |
| |
| /** |
| * Shim process.stdout. |
| */ |
| |
| process.stdout = require('browser-stdout')({label: false}); |
| |
| var Mocha = require('./lib/mocha'); |
| |
| /** |
| * Create a Mocha instance. |
| * |
| * @return {undefined} |
| */ |
| |
| var mocha = new Mocha({reporter: 'html'}); |
| |
| /** |
| * Save timer references to avoid Sinon interfering (see GH-237). |
| */ |
| |
| var Date = global.Date; |
| var setTimeout = global.setTimeout; |
| var setInterval = global.setInterval; |
| var clearTimeout = global.clearTimeout; |
| var clearInterval = global.clearInterval; |
| |
| var uncaughtExceptionHandlers = []; |
| |
| var originalOnerrorHandler = global.onerror; |
| |
| /** |
| * Remove uncaughtException listener. |
| * Revert to original onerror handler if previously defined. |
| */ |
| |
| process.removeListener = function(e, fn) { |
| if (e === 'uncaughtException') { |
| if (originalOnerrorHandler) { |
| global.onerror = originalOnerrorHandler; |
| } else { |
| global.onerror = function() {}; |
| } |
| var i = uncaughtExceptionHandlers.indexOf(fn); |
| if (i !== -1) { |
| uncaughtExceptionHandlers.splice(i, 1); |
| } |
| } |
| }; |
| |
| /** |
| * Implements uncaughtException listener. |
| */ |
| |
| process.on = function(e, fn) { |
| if (e === 'uncaughtException') { |
| global.onerror = function(err, url, line) { |
| fn(new Error(err + ' (' + url + ':' + line + ')')); |
| return !mocha.allowUncaught; |
| }; |
| uncaughtExceptionHandlers.push(fn); |
| } |
| }; |
| |
| // The BDD UI is registered by default, but no UI will be functional in the |
| // browser without an explicit call to the overridden `mocha.ui` (see below). |
| // Ensure that this default UI does not expose its methods to the global scope. |
| mocha.suite.removeAllListeners('pre-require'); |
| |
| var immediateQueue = []; |
| var immediateTimeout; |
| |
| function timeslice() { |
| var immediateStart = new Date().getTime(); |
| while (immediateQueue.length && new Date().getTime() - immediateStart < 100) { |
| immediateQueue.shift()(); |
| } |
| if (immediateQueue.length) { |
| immediateTimeout = setTimeout(timeslice, 0); |
| } else { |
| immediateTimeout = null; |
| } |
| } |
| |
| /** |
| * High-performance override of Runner.immediately. |
| */ |
| |
| Mocha.Runner.immediately = function(callback) { |
| immediateQueue.push(callback); |
| if (!immediateTimeout) { |
| immediateTimeout = setTimeout(timeslice, 0); |
| } |
| }; |
| |
| /** |
| * Function to allow assertion libraries to throw errors directly into mocha. |
| * This is useful when running tests in a browser because window.onerror will |
| * only receive the 'message' attribute of the Error. |
| */ |
| mocha.throwError = function(err) { |
| uncaughtExceptionHandlers.forEach(function(fn) { |
| fn(err); |
| }); |
| throw err; |
| }; |
| |
| /** |
| * Override ui to ensure that the ui functions are initialized. |
| * Normally this would happen in Mocha.prototype.loadFiles. |
| */ |
| |
| mocha.ui = function(ui) { |
| Mocha.prototype.ui.call(this, ui); |
| this.suite.emit('pre-require', global, null, this); |
| return this; |
| }; |
| |
| /** |
| * Setup mocha with the given setting options. |
| */ |
| |
| mocha.setup = function(opts) { |
| if (typeof opts === 'string') { |
| opts = {ui: opts}; |
| } |
| for (var opt in opts) { |
| if (opts.hasOwnProperty(opt)) { |
| this[opt](opts[opt]); |
| } |
| } |
| return this; |
| }; |
| |
| /** |
| * Run mocha, returning the Runner. |
| */ |
| |
| mocha.run = function(fn) { |
| var options = mocha.options; |
| mocha.globals('location'); |
| |
| var query = Mocha.utils.parseQuery(global.location.search || ''); |
| if (query.grep) { |
| mocha.grep(query.grep); |
| } |
| if (query.fgrep) { |
| mocha.fgrep(query.fgrep); |
| } |
| if (query.invert) { |
| mocha.invert(); |
| } |
| |
| return Mocha.prototype.run.call(mocha, function(err) { |
| // The DOM Document is not available in Web Workers. |
| var document = global.document; |
| if ( |
| document && |
| document.getElementById('mocha') && |
| options.noHighlighting !== true |
| ) { |
| Mocha.utils.highlightTags('code'); |
| } |
| if (fn) { |
| fn(err); |
| } |
| }); |
| }; |
| |
| /** |
| * Expose the process shim. |
| * https://github.com/mochajs/mocha/pull/916 |
| */ |
| |
| Mocha.process = process; |
| |
| /** |
| * Expose mocha. |
| */ |
| |
| global.Mocha = Mocha; |
| global.mocha = mocha; |
| |
| // this allows test/acceptance/required-tokens.js to pass; thus, |
| // you can now do `const describe = require('mocha').describe` in a |
| // browser context (assuming browserification). should fix #880 |
| module.exports = global; |
| |
| }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{"./lib/mocha":14,"_process":69,"browser-stdout":41}],2:[function(require,module,exports){ |
| (function (process,global){ |
| 'use strict'; |
| |
| /** |
| * Web Notifications module. |
| * @module Growl |
| */ |
| |
| /** |
| * Save timer references to avoid Sinon interfering (see GH-237). |
| */ |
| var Date = global.Date; |
| var setTimeout = global.setTimeout; |
| var EVENT_RUN_END = require('../runner').constants.EVENT_RUN_END; |
| |
| /** |
| * Checks if browser notification support exists. |
| * |
| * @public |
| * @see {@link https://caniuse.com/#feat=notifications|Browser support (notifications)} |
| * @see {@link https://caniuse.com/#feat=promises|Browser support (promises)} |
| * @see {@link Mocha#growl} |
| * @see {@link Mocha#isGrowlCapable} |
| * @return {boolean} whether browser notification support exists |
| */ |
| exports.isCapable = function() { |
| var hasNotificationSupport = 'Notification' in window; |
| var hasPromiseSupport = typeof Promise === 'function'; |
| return process.browser && hasNotificationSupport && hasPromiseSupport; |
| }; |
| |
| /** |
| * Implements browser notifications as a pseudo-reporter. |
| * |
| * @public |
| * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/notification|Notification API} |
| * @see {@link https://developers.google.com/web/fundamentals/push-notifications/display-a-notification|Displaying a Notification} |
| * @see {@link Growl#isPermitted} |
| * @see {@link Mocha#_growl} |
| * @param {Runner} runner - Runner instance. |
| */ |
| exports.notify = function(runner) { |
| var promise = isPermitted(); |
| |
| /** |
| * Attempt notification. |
| */ |
| var sendNotification = function() { |
| // If user hasn't responded yet... "No notification for you!" (Seinfeld) |
| Promise.race([promise, Promise.resolve(undefined)]) |
| .then(canNotify) |
| .then(function() { |
| display(runner); |
| }) |
| .catch(notPermitted); |
| }; |
| |
| runner.once(EVENT_RUN_END, sendNotification); |
| }; |
| |
| /** |
| * Checks if browser notification is permitted by user. |
| * |
| * @private |
| * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Notification/permission|Notification.permission} |
| * @see {@link Mocha#growl} |
| * @see {@link Mocha#isGrowlPermitted} |
| * @returns {Promise<boolean>} promise determining if browser notification |
| * permissible when fulfilled. |
| */ |
| function isPermitted() { |
| var permitted = { |
| granted: function allow() { |
| return Promise.resolve(true); |
| }, |
| denied: function deny() { |
| return Promise.resolve(false); |
| }, |
| default: function ask() { |
| return Notification.requestPermission().then(function(permission) { |
| return permission === 'granted'; |
| }); |
| } |
| }; |
| |
| return permitted[Notification.permission](); |
| } |
| |
| /** |
| * @summary |
| * Determines if notification should proceed. |
| * |
| * @description |
| * Notification shall <strong>not</strong> proceed unless `value` is true. |
| * |
| * `value` will equal one of: |
| * <ul> |
| * <li><code>true</code> (from `isPermitted`)</li> |
| * <li><code>false</code> (from `isPermitted`)</li> |
| * <li><code>undefined</code> (from `Promise.race`)</li> |
| * </ul> |
| * |
| * @private |
| * @param {boolean|undefined} value - Determines if notification permissible. |
| * @returns {Promise<undefined>} Notification can proceed |
| */ |
| function canNotify(value) { |
| if (!value) { |
| var why = value === false ? 'blocked' : 'unacknowledged'; |
| var reason = 'not permitted by user (' + why + ')'; |
| return Promise.reject(new Error(reason)); |
| } |
| return Promise.resolve(); |
| } |
| |
| /** |
| * Displays the notification. |
| * |
| * @private |
| * @param {Runner} runner - Runner instance. |
| */ |
| function display(runner) { |
| var stats = runner.stats; |
| var symbol = { |
| cross: '\u274C', |
| tick: '\u2705' |
| }; |
| var logo = require('../../package').notifyLogo; |
| var _message; |
| var message; |
| var title; |
| |
| if (stats.failures) { |
| _message = stats.failures + ' of ' + stats.tests + ' tests failed'; |
| message = symbol.cross + ' ' + _message; |
| title = 'Failed'; |
| } else { |
| _message = stats.passes + ' tests passed in ' + stats.duration + 'ms'; |
| message = symbol.tick + ' ' + _message; |
| title = 'Passed'; |
| } |
| |
| // Send notification |
| var options = { |
| badge: logo, |
| body: message, |
| dir: 'ltr', |
| icon: logo, |
| lang: 'en-US', |
| name: 'mocha', |
| requireInteraction: false, |
| timestamp: Date.now() |
| }; |
| var notification = new Notification(title, options); |
| |
| // Autoclose after brief delay (makes various browsers act same) |
| var FORCE_DURATION = 4000; |
| setTimeout(notification.close.bind(notification), FORCE_DURATION); |
| } |
| |
| /** |
| * As notifications are tangential to our purpose, just log the error. |
| * |
| * @private |
| * @param {Error} err - Why notification didn't happen. |
| */ |
| function notPermitted(err) { |
| console.error('notification error:', err.message); |
| } |
| |
| }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{"../../package":90,"../runner":34,"_process":69}],3:[function(require,module,exports){ |
| 'use strict'; |
| |
| /** |
| * Expose `Progress`. |
| */ |
| |
| module.exports = Progress; |
| |
| /** |
| * Initialize a new `Progress` indicator. |
| */ |
| function Progress() { |
| this.percent = 0; |
| this.size(0); |
| this.fontSize(11); |
| this.font('helvetica, arial, sans-serif'); |
| } |
| |
| /** |
| * Set progress size to `size`. |
| * |
| * @public |
| * @param {number} size |
| * @return {Progress} Progress instance. |
| */ |
| Progress.prototype.size = function(size) { |
| this._size = size; |
| return this; |
| }; |
| |
| /** |
| * Set text to `text`. |
| * |
| * @public |
| * @param {string} text |
| * @return {Progress} Progress instance. |
| */ |
| Progress.prototype.text = function(text) { |
| this._text = text; |
| return this; |
| }; |
| |
| /** |
| * Set font size to `size`. |
| * |
| * @public |
| * @param {number} size |
| * @return {Progress} Progress instance. |
| */ |
| Progress.prototype.fontSize = function(size) { |
| this._fontSize = size; |
| return this; |
| }; |
| |
| /** |
| * Set font to `family`. |
| * |
| * @param {string} family |
| * @return {Progress} Progress instance. |
| */ |
| Progress.prototype.font = function(family) { |
| this._font = family; |
| return this; |
| }; |
| |
| /** |
| * Update percentage to `n`. |
| * |
| * @param {number} n |
| * @return {Progress} Progress instance. |
| */ |
| Progress.prototype.update = function(n) { |
| this.percent = n; |
| return this; |
| }; |
| |
| /** |
| * Draw on `ctx`. |
| * |
| * @param {CanvasRenderingContext2d} ctx |
| * @return {Progress} Progress instance. |
| */ |
| Progress.prototype.draw = function(ctx) { |
| try { |
| var percent = Math.min(this.percent, 100); |
| var size = this._size; |
| var half = size / 2; |
| var x = half; |
| var y = half; |
| var rad = half - 1; |
| var fontSize = this._fontSize; |
| |
| ctx.font = fontSize + 'px ' + this._font; |
| |
| var angle = Math.PI * 2 * (percent / 100); |
| ctx.clearRect(0, 0, size, size); |
| |
| // outer circle |
| ctx.strokeStyle = '#9f9f9f'; |
| ctx.beginPath(); |
| ctx.arc(x, y, rad, 0, angle, false); |
| ctx.stroke(); |
| |
| // inner circle |
| ctx.strokeStyle = '#eee'; |
| ctx.beginPath(); |
| ctx.arc(x, y, rad - 1, 0, angle, true); |
| ctx.stroke(); |
| |
| // text |
| var text = this._text || (percent | 0) + '%'; |
| var w = ctx.measureText(text).width; |
| |
| ctx.fillText(text, x - w / 2 + 1, y + fontSize / 2 - 1); |
| } catch (ignore) { |
| // don't fail if we can't render progress |
| } |
| return this; |
| }; |
| |
| },{}],4:[function(require,module,exports){ |
| (function (global){ |
| 'use strict'; |
| |
| exports.isatty = function isatty() { |
| return true; |
| }; |
| |
| exports.getWindowSize = function getWindowSize() { |
| if ('innerHeight' in global) { |
| return [global.innerHeight, global.innerWidth]; |
| } |
| // In a Web Worker, the DOM Window is not available. |
| return [640, 480]; |
| }; |
| |
| }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{}],5:[function(require,module,exports){ |
| 'use strict'; |
| /** |
| * @module Context |
| */ |
| /** |
| * Expose `Context`. |
| */ |
| |
| module.exports = Context; |
| |
| /** |
| * Initialize a new `Context`. |
| * |
| * @private |
| */ |
| function Context() {} |
| |
| /** |
| * Set or get the context `Runnable` to `runnable`. |
| * |
| * @private |
| * @param {Runnable} runnable |
| * @return {Context} context |
| */ |
| Context.prototype.runnable = function(runnable) { |
| if (!arguments.length) { |
| return this._runnable; |
| } |
| this.test = this._runnable = runnable; |
| return this; |
| }; |
| |
| /** |
| * Set or get test timeout `ms`. |
| * |
| * @private |
| * @param {number} ms |
| * @return {Context} self |
| */ |
| Context.prototype.timeout = function(ms) { |
| if (!arguments.length) { |
| return this.runnable().timeout(); |
| } |
| this.runnable().timeout(ms); |
| return this; |
| }; |
| |
| /** |
| * Set test timeout `enabled`. |
| * |
| * @private |
| * @param {boolean} enabled |
| * @return {Context} self |
| */ |
| Context.prototype.enableTimeouts = function(enabled) { |
| if (!arguments.length) { |
| return this.runnable().enableTimeouts(); |
| } |
| this.runnable().enableTimeouts(enabled); |
| return this; |
| }; |
| |
| /** |
| * Set or get test slowness threshold `ms`. |
| * |
| * @private |
| * @param {number} ms |
| * @return {Context} self |
| */ |
| Context.prototype.slow = function(ms) { |
| if (!arguments.length) { |
| return this.runnable().slow(); |
| } |
| this.runnable().slow(ms); |
| return this; |
| }; |
| |
| /** |
| * Mark a test as skipped. |
| * |
| * @private |
| * @throws Pending |
| */ |
| Context.prototype.skip = function() { |
| this.runnable().skip(); |
| }; |
| |
| /** |
| * Set or get a number of allowed retries on failed tests |
| * |
| * @private |
| * @param {number} n |
| * @return {Context} self |
| */ |
| Context.prototype.retries = function(n) { |
| if (!arguments.length) { |
| return this.runnable().retries(); |
| } |
| this.runnable().retries(n); |
| return this; |
| }; |
| |
| },{}],6:[function(require,module,exports){ |
| 'use strict'; |
| /** |
| * @module Errors |
| */ |
| /** |
| * Factory functions to create throwable error objects |
| */ |
| |
| /** |
| * Creates an error object to be thrown when no files to be tested could be found using specified pattern. |
| * |
| * @public |
| * @param {string} message - Error message to be displayed. |
| * @param {string} pattern - User-specified argument value. |
| * @returns {Error} instance detailing the error condition |
| */ |
| function createNoFilesMatchPatternError(message, pattern) { |
| var err = new Error(message); |
| err.code = 'ERR_MOCHA_NO_FILES_MATCH_PATTERN'; |
| err.pattern = pattern; |
| return err; |
| } |
| |
| /** |
| * Creates an error object to be thrown when the reporter specified in the options was not found. |
| * |
| * @public |
| * @param {string} message - Error message to be displayed. |
| * @param {string} reporter - User-specified reporter value. |
| * @returns {Error} instance detailing the error condition |
| */ |
| function createInvalidReporterError(message, reporter) { |
| var err = new TypeError(message); |
| err.code = 'ERR_MOCHA_INVALID_REPORTER'; |
| err.reporter = reporter; |
| return err; |
| } |
| |
| /** |
| * Creates an error object to be thrown when the interface specified in the options was not found. |
| * |
| * @public |
| * @param {string} message - Error message to be displayed. |
| * @param {string} ui - User-specified interface value. |
| * @returns {Error} instance detailing the error condition |
| */ |
| function createInvalidInterfaceError(message, ui) { |
| var err = new Error(message); |
| err.code = 'ERR_MOCHA_INVALID_INTERFACE'; |
| err.interface = ui; |
| return err; |
| } |
| |
| /** |
| * Creates an error object to be thrown when a behavior, option, or parameter is unsupported. |
| * |
| * @public |
| * @param {string} message - Error message to be displayed. |
| * @returns {Error} instance detailing the error condition |
| */ |
| function createUnsupportedError(message) { |
| var err = new Error(message); |
| err.code = 'ERR_MOCHA_UNSUPPORTED'; |
| return err; |
| } |
| |
| /** |
| * Creates an error object to be thrown when an argument is missing. |
| * |
| * @public |
| * @param {string} message - Error message to be displayed. |
| * @param {string} argument - Argument name. |
| * @param {string} expected - Expected argument datatype. |
| * @returns {Error} instance detailing the error condition |
| */ |
| function createMissingArgumentError(message, argument, expected) { |
| return createInvalidArgumentTypeError(message, argument, expected); |
| } |
| |
| /** |
| * Creates an error object to be thrown when an argument did not use the supported type |
| * |
| * @public |
| * @param {string} message - Error message to be displayed. |
| * @param {string} argument - Argument name. |
| * @param {string} expected - Expected argument datatype. |
| * @returns {Error} instance detailing the error condition |
| */ |
| function createInvalidArgumentTypeError(message, argument, expected) { |
| var err = new TypeError(message); |
| err.code = 'ERR_MOCHA_INVALID_ARG_TYPE'; |
| err.argument = argument; |
| err.expected = expected; |
| err.actual = typeof argument; |
| return err; |
| } |
| |
| /** |
| * Creates an error object to be thrown when an argument did not use the supported value |
| * |
| * @public |
| * @param {string} message - Error message to be displayed. |
| * @param {string} argument - Argument name. |
| * @param {string} value - Argument value. |
| * @param {string} [reason] - Why value is invalid. |
| * @returns {Error} instance detailing the error condition |
| */ |
| function createInvalidArgumentValueError(message, argument, value, reason) { |
| var err = new TypeError(message); |
| err.code = 'ERR_MOCHA_INVALID_ARG_VALUE'; |
| err.argument = argument; |
| err.value = value; |
| err.reason = typeof reason !== 'undefined' ? reason : 'is invalid'; |
| return err; |
| } |
| |
| /** |
| * Creates an error object to be thrown when an exception was caught, but the `Error` is falsy or undefined. |
| * |
| * @public |
| * @param {string} message - Error message to be displayed. |
| * @returns {Error} instance detailing the error condition |
| */ |
| function createInvalidExceptionError(message, value) { |
| var err = new Error(message); |
| err.code = 'ERR_MOCHA_INVALID_EXCEPTION'; |
| err.valueType = typeof value; |
| err.value = value; |
| return err; |
| } |
| |
| module.exports = { |
| createInvalidArgumentTypeError: createInvalidArgumentTypeError, |
| createInvalidArgumentValueError: createInvalidArgumentValueError, |
| createInvalidExceptionError: createInvalidExceptionError, |
| createInvalidInterfaceError: createInvalidInterfaceError, |
| createInvalidReporterError: createInvalidReporterError, |
| createMissingArgumentError: createMissingArgumentError, |
| createNoFilesMatchPatternError: createNoFilesMatchPatternError, |
| createUnsupportedError: createUnsupportedError |
| }; |
| |
| },{}],7:[function(require,module,exports){ |
| 'use strict'; |
| |
| var Runnable = require('./runnable'); |
| var inherits = require('./utils').inherits; |
| |
| /** |
| * Expose `Hook`. |
| */ |
| |
| module.exports = Hook; |
| |
| /** |
| * Initialize a new `Hook` with the given `title` and callback `fn` |
| * |
| * @class |
| * @extends Runnable |
| * @param {String} title |
| * @param {Function} fn |
| */ |
| function Hook(title, fn) { |
| Runnable.call(this, title, fn); |
| this.type = 'hook'; |
| } |
| |
| /** |
| * Inherit from `Runnable.prototype`. |
| */ |
| inherits(Hook, Runnable); |
| |
| /** |
| * Get or set the test `err`. |
| * |
| * @memberof Hook |
| * @public |
| * @param {Error} err |
| * @return {Error} |
| */ |
| Hook.prototype.error = function(err) { |
| if (!arguments.length) { |
| err = this._error; |
| this._error = null; |
| return err; |
| } |
| |
| this._error = err; |
| }; |
| |
| },{"./runnable":33,"./utils":38}],8:[function(require,module,exports){ |
| 'use strict'; |
| |
| var Test = require('../test'); |
| var EVENT_FILE_PRE_REQUIRE = require('../suite').constants |
| .EVENT_FILE_PRE_REQUIRE; |
| |
| /** |
| * BDD-style interface: |
| * |
| * describe('Array', function() { |
| * describe('#indexOf()', function() { |
| * it('should return -1 when not present', function() { |
| * // ... |
| * }); |
| * |
| * it('should return the index when present', function() { |
| * // ... |
| * }); |
| * }); |
| * }); |
| * |
| * @param {Suite} suite Root suite. |
| */ |
| module.exports = function bddInterface(suite) { |
| var suites = [suite]; |
| |
| suite.on(EVENT_FILE_PRE_REQUIRE, function(context, file, mocha) { |
| var common = require('./common')(suites, context, mocha); |
| |
| context.before = common.before; |
| context.after = common.after; |
| context.beforeEach = common.beforeEach; |
| context.afterEach = common.afterEach; |
| context.run = mocha.options.delay && common.runWithSuite(suite); |
| /** |
| * Describe a "suite" with the given `title` |
| * and callback `fn` containing nested suites |
| * and/or tests. |
| */ |
| |
| context.describe = context.context = function(title, fn) { |
| return common.suite.create({ |
| title: title, |
| file: file, |
| fn: fn |
| }); |
| }; |
| |
| /** |
| * Pending describe. |
| */ |
| |
| context.xdescribe = context.xcontext = context.describe.skip = function( |
| title, |
| fn |
| ) { |
| return common.suite.skip({ |
| title: title, |
| file: file, |
| fn: fn |
| }); |
| }; |
| |
| /** |
| * Exclusive suite. |
| */ |
| |
| context.describe.only = function(title, fn) { |
| return common.suite.only({ |
| title: title, |
| file: file, |
| fn: fn |
| }); |
| }; |
| |
| /** |
| * Describe a specification or test-case |
| * with the given `title` and callback `fn` |
| * acting as a thunk. |
| */ |
| |
| context.it = context.specify = function(title, fn) { |
| var suite = suites[0]; |
| if (suite.isPending()) { |
| fn = null; |
| } |
| var test = new Test(title, fn); |
| test.file = file; |
| suite.addTest(test); |
| return test; |
| }; |
| |
| /** |
| * Exclusive test-case. |
| */ |
| |
| context.it.only = function(title, fn) { |
| return common.test.only(mocha, context.it(title, fn)); |
| }; |
| |
| /** |
| * Pending test case. |
| */ |
| |
| context.xit = context.xspecify = context.it.skip = function(title) { |
| return context.it(title); |
| }; |
| |
| /** |
| * Number of attempts to retry. |
| */ |
| context.it.retries = function(n) { |
| context.retries(n); |
| }; |
| }); |
| }; |
| |
| module.exports.description = 'BDD or RSpec style [default]'; |
| |
| },{"../suite":36,"../test":37,"./common":9}],9:[function(require,module,exports){ |
| 'use strict'; |
| |
| var Suite = require('../suite'); |
| var errors = require('../errors'); |
| var createMissingArgumentError = errors.createMissingArgumentError; |
| |
| /** |
| * Functions common to more than one interface. |
| * |
| * @param {Suite[]} suites |
| * @param {Context} context |
| * @param {Mocha} mocha |
| * @return {Object} An object containing common functions. |
| */ |
| module.exports = function(suites, context, mocha) { |
| /** |
| * Check if the suite should be tested. |
| * |
| * @private |
| * @param {Suite} suite - suite to check |
| * @returns {boolean} |
| */ |
| function shouldBeTested(suite) { |
| return ( |
| !mocha.options.grep || |
| (mocha.options.grep && |
| mocha.options.grep.test(suite.fullTitle()) && |
| !mocha.options.invert) |
| ); |
| } |
| |
| return { |
| /** |
| * This is only present if flag --delay is passed into Mocha. It triggers |
| * root suite execution. |
| * |
| * @param {Suite} suite The root suite. |
| * @return {Function} A function which runs the root suite |
| */ |
| runWithSuite: function runWithSuite(suite) { |
| return function run() { |
| suite.run(); |
| }; |
| }, |
| |
| /** |
| * Execute before running tests. |
| * |
| * @param {string} name |
| * @param {Function} fn |
| */ |
| before: function(name, fn) { |
| suites[0].beforeAll(name, fn); |
| }, |
| |
| /** |
| * Execute after running tests. |
| * |
| * @param {string} name |
| * @param {Function} fn |
| */ |
| after: function(name, fn) { |
| suites[0].afterAll(name, fn); |
| }, |
| |
| /** |
| * Execute before each test case. |
| * |
| * @param {string} name |
| * @param {Function} fn |
| */ |
| beforeEach: function(name, fn) { |
| suites[0].beforeEach(name, fn); |
| }, |
| |
| /** |
| * Execute after each test case. |
| * |
| * @param {string} name |
| * @param {Function} fn |
| */ |
| afterEach: function(name, fn) { |
| suites[0].afterEach(name, fn); |
| }, |
| |
| suite: { |
| /** |
| * Create an exclusive Suite; convenience function |
| * See docstring for create() below. |
| * |
| * @param {Object} opts |
| * @returns {Suite} |
| */ |
| only: function only(opts) { |
| opts.isOnly = true; |
| return this.create(opts); |
| }, |
| |
| /** |
| * Create a Suite, but skip it; convenience function |
| * See docstring for create() below. |
| * |
| * @param {Object} opts |
| * @returns {Suite} |
| */ |
| skip: function skip(opts) { |
| opts.pending = true; |
| return this.create(opts); |
| }, |
| |
| /** |
| * Creates a suite. |
| * |
| * @param {Object} opts Options |
| * @param {string} opts.title Title of Suite |
| * @param {Function} [opts.fn] Suite Function (not always applicable) |
| * @param {boolean} [opts.pending] Is Suite pending? |
| * @param {string} [opts.file] Filepath where this Suite resides |
| * @param {boolean} [opts.isOnly] Is Suite exclusive? |
| * @returns {Suite} |
| */ |
| create: function create(opts) { |
| var suite = Suite.create(suites[0], opts.title); |
| suite.pending = Boolean(opts.pending); |
| suite.file = opts.file; |
| suites.unshift(suite); |
| if (opts.isOnly) { |
| if (mocha.options.forbidOnly && shouldBeTested(suite)) { |
| throw new Error('`.only` forbidden'); |
| } |
| |
| suite.parent.appendOnlySuite(suite); |
| } |
| if (suite.pending) { |
| if (mocha.options.forbidPending && shouldBeTested(suite)) { |
| throw new Error('Pending test forbidden'); |
| } |
| } |
| if (typeof opts.fn === 'function') { |
| opts.fn.call(suite); |
| suites.shift(); |
| } else if (typeof opts.fn === 'undefined' && !suite.pending) { |
| throw createMissingArgumentError( |
| 'Suite "' + |
| suite.fullTitle() + |
| '" was defined but no callback was supplied. ' + |
| 'Supply a callback or explicitly skip the suite.', |
| 'callback', |
| 'function' |
| ); |
| } else if (!opts.fn && suite.pending) { |
| suites.shift(); |
| } |
| |
| return suite; |
| } |
| }, |
| |
| test: { |
| /** |
| * Exclusive test-case. |
| * |
| * @param {Object} mocha |
| * @param {Function} test |
| * @returns {*} |
| */ |
| only: function(mocha, test) { |
| test.parent.appendOnlyTest(test); |
| return test; |
| }, |
| |
| /** |
| * Pending test case. |
| * |
| * @param {string} title |
| */ |
| skip: function(title) { |
| context.test(title); |
| }, |
| |
| /** |
| * Number of retry attempts |
| * |
| * @param {number} n |
| */ |
| retries: function(n) { |
| context.retries(n); |
| } |
| } |
| }; |
| }; |
| |
| },{"../errors":6,"../suite":36}],10:[function(require,module,exports){ |
| 'use strict'; |
| var Suite = require('../suite'); |
| var Test = require('../test'); |
| |
| /** |
| * Exports-style (as Node.js module) interface: |
| * |
| * exports.Array = { |
| * '#indexOf()': { |
| * 'should return -1 when the value is not present': function() { |
| * |
| * }, |
| * |
| * 'should return the correct index when the value is present': function() { |
| * |
| * } |
| * } |
| * }; |
| * |
| * @param {Suite} suite Root suite. |
| */ |
| module.exports = function(suite) { |
| var suites = [suite]; |
| |
| suite.on(Suite.constants.EVENT_FILE_REQUIRE, visit); |
| |
| function visit(obj, file) { |
| var suite; |
| for (var key in obj) { |
| if (typeof obj[key] === 'function') { |
| var fn = obj[key]; |
| switch (key) { |
| case 'before': |
| suites[0].beforeAll(fn); |
| break; |
| case 'after': |
| suites[0].afterAll(fn); |
| break; |
| case 'beforeEach': |
| suites[0].beforeEach(fn); |
| break; |
| case 'afterEach': |
| suites[0].afterEach(fn); |
| break; |
| default: |
| var test = new Test(key, fn); |
| test.file = file; |
| suites[0].addTest(test); |
| } |
| } else { |
| suite = Suite.create(suites[0], key); |
| suites.unshift(suite); |
| visit(obj[key], file); |
| suites.shift(); |
| } |
| } |
| } |
| }; |
| |
| module.exports.description = 'Node.js module ("exports") style'; |
| |
| },{"../suite":36,"../test":37}],11:[function(require,module,exports){ |
| 'use strict'; |
| |
| exports.bdd = require('./bdd'); |
| exports.tdd = require('./tdd'); |
| exports.qunit = require('./qunit'); |
| exports.exports = require('./exports'); |
| |
| },{"./bdd":8,"./exports":10,"./qunit":12,"./tdd":13}],12:[function(require,module,exports){ |
| 'use strict'; |
| |
| var Test = require('../test'); |
| var EVENT_FILE_PRE_REQUIRE = require('../suite').constants |
| .EVENT_FILE_PRE_REQUIRE; |
| |
| /** |
| * QUnit-style interface: |
| * |
| * suite('Array'); |
| * |
| * test('#length', function() { |
| * var arr = [1,2,3]; |
| * ok(arr.length == 3); |
| * }); |
| * |
| * test('#indexOf()', function() { |
| * var arr = [1,2,3]; |
| * ok(arr.indexOf(1) == 0); |
| * ok(arr.indexOf(2) == 1); |
| * ok(arr.indexOf(3) == 2); |
| * }); |
| * |
| * suite('String'); |
| * |
| * test('#length', function() { |
| * ok('foo'.length == 3); |
| * }); |
| * |
| * @param {Suite} suite Root suite. |
| */ |
| module.exports = function qUnitInterface(suite) { |
| var suites = [suite]; |
| |
| suite.on(EVENT_FILE_PRE_REQUIRE, function(context, file, mocha) { |
| var common = require('./common')(suites, context, mocha); |
| |
| context.before = common.before; |
| context.after = common.after; |
| context.beforeEach = common.beforeEach; |
| context.afterEach = common.afterEach; |
| context.run = mocha.options.delay && common.runWithSuite(suite); |
| /** |
| * Describe a "suite" with the given `title`. |
| */ |
| |
| context.suite = function(title) { |
| if (suites.length > 1) { |
| suites.shift(); |
| } |
| return common.suite.create({ |
| title: title, |
| file: file, |
| fn: false |
| }); |
| }; |
| |
| /** |
| * Exclusive Suite. |
| */ |
| |
| context.suite.only = function(title) { |
| if (suites.length > 1) { |
| suites.shift(); |
| } |
| return common.suite.only({ |
| title: title, |
| file: file, |
| fn: false |
| }); |
| }; |
| |
| /** |
| * Describe a specification or test-case |
| * with the given `title` and callback `fn` |
| * acting as a thunk. |
| */ |
| |
| context.test = function(title, fn) { |
| var test = new Test(title, fn); |
| test.file = file; |
| suites[0].addTest(test); |
| return test; |
| }; |
| |
| /** |
| * Exclusive test-case. |
| */ |
| |
| context.test.only = function(title, fn) { |
| return common.test.only(mocha, context.test(title, fn)); |
| }; |
| |
| context.test.skip = common.test.skip; |
| context.test.retries = common.test.retries; |
| }); |
| }; |
| |
| module.exports.description = 'QUnit style'; |
| |
| },{"../suite":36,"../test":37,"./common":9}],13:[function(require,module,exports){ |
| 'use strict'; |
| |
| var Test = require('../test'); |
| var EVENT_FILE_PRE_REQUIRE = require('../suite').constants |
| .EVENT_FILE_PRE_REQUIRE; |
| |
| /** |
| * TDD-style interface: |
| * |
| * suite('Array', function() { |
| * suite('#indexOf()', function() { |
| * suiteSetup(function() { |
| * |
| * }); |
| * |
| * test('should return -1 when not present', function() { |
| * |
| * }); |
| * |
| * test('should return the index when present', function() { |
| * |
| * }); |
| * |
| * suiteTeardown(function() { |
| * |
| * }); |
| * }); |
| * }); |
| * |
| * @param {Suite} suite Root suite. |
| */ |
| module.exports = function(suite) { |
| var suites = [suite]; |
| |
| suite.on(EVENT_FILE_PRE_REQUIRE, function(context, file, mocha) { |
| var common = require('./common')(suites, context, mocha); |
| |
| context.setup = common.beforeEach; |
| context.teardown = common.afterEach; |
| context.suiteSetup = common.before; |
| context.suiteTeardown = common.after; |
| context.run = mocha.options.delay && common.runWithSuite(suite); |
| |
| /** |
| * Describe a "suite" with the given `title` and callback `fn` containing |
| * nested suites and/or tests. |
| */ |
| context.suite = function(title, fn) { |
| return common.suite.create({ |
| title: title, |
| file: file, |
| fn: fn |
| }); |
| }; |
| |
| /** |
| * Pending suite. |
| */ |
| context.suite.skip = function(title, fn) { |
| return common.suite.skip({ |
| title: title, |
| file: file, |
| fn: fn |
| }); |
| }; |
| |
| /** |
| * Exclusive test-case. |
| */ |
| context.suite.only = function(title, fn) { |
| return common.suite.only({ |
| title: title, |
| file: file, |
| fn: fn |
| }); |
| }; |
| |
| /** |
| * Describe a specification or test-case with the given `title` and |
| * callback `fn` acting as a thunk. |
| */ |
| context.test = function(title, fn) { |
| var suite = suites[0]; |
| if (suite.isPending()) { |
| fn = null; |
| } |
| var test = new Test(title, fn); |
| test.file = file; |
| suite.addTest(test); |
| return test; |
| }; |
| |
| /** |
| * Exclusive test-case. |
| */ |
| |
| context.test.only = function(title, fn) { |
| return common.test.only(mocha, context.test(title, fn)); |
| }; |
| |
| context.test.skip = common.test.skip; |
| context.test.retries = common.test.retries; |
| }); |
| }; |
| |
| module.exports.description = |
| 'traditional "suite"/"test" instead of BDD\'s "describe"/"it"'; |
| |
| },{"../suite":36,"../test":37,"./common":9}],14:[function(require,module,exports){ |
| (function (process,global){ |
| 'use strict'; |
| |
| /*! |
| * mocha |
| * Copyright(c) 2011 TJ Holowaychuk <tj@vision-media.ca> |
| * MIT Licensed |
| */ |
| |
| var escapeRe = require('escape-string-regexp'); |
| var path = require('path'); |
| var builtinReporters = require('./reporters'); |
| var growl = require('./growl'); |
| var utils = require('./utils'); |
| var mocharc = require('./mocharc.json'); |
| var errors = require('./errors'); |
| var Suite = require('./suite'); |
| var createStatsCollector = require('./stats-collector'); |
| var createInvalidReporterError = errors.createInvalidReporterError; |
| var createInvalidInterfaceError = errors.createInvalidInterfaceError; |
| var EVENT_FILE_PRE_REQUIRE = Suite.constants.EVENT_FILE_PRE_REQUIRE; |
| var EVENT_FILE_POST_REQUIRE = Suite.constants.EVENT_FILE_POST_REQUIRE; |
| var EVENT_FILE_REQUIRE = Suite.constants.EVENT_FILE_REQUIRE; |
| var sQuote = utils.sQuote; |
| |
| exports = module.exports = Mocha; |
| |
| /** |
| * To require local UIs and reporters when running in node. |
| */ |
| |
| if (!process.browser) { |
| var cwd = process.cwd(); |
| module.paths.push(cwd, path.join(cwd, 'node_modules')); |
| } |
| |
| /** |
| * Expose internals. |
| */ |
| |
| /** |
| * @public |
| * @class utils |
| * @memberof Mocha |
| */ |
| exports.utils = utils; |
| exports.interfaces = require('./interfaces'); |
| /** |
| * @public |
| * @memberof Mocha |
| */ |
| exports.reporters = builtinReporters; |
| exports.Runnable = require('./runnable'); |
| exports.Context = require('./context'); |
| /** |
| * |
| * @memberof Mocha |
| */ |
| exports.Runner = require('./runner'); |
| exports.Suite = Suite; |
| exports.Hook = require('./hook'); |
| exports.Test = require('./test'); |
| |
| /** |
| * Constructs a new Mocha instance with `options`. |
| * |
| * @public |
| * @class Mocha |
| * @param {Object} [options] - Settings object. |
| * @param {boolean} [options.allowUncaught] - Propagate uncaught errors? |
| * @param {boolean} [options.asyncOnly] - Force `done` callback or promise? |
| * @param {boolean} [options.bail] - Bail after first test failure? |
| * @param {boolean} [options.checkLeaks] - If true, check leaks. |
| * @param {boolean} [options.delay] - Delay root suite execution? |
| * @param {boolean} [options.enableTimeouts] - Enable timeouts? |
| * @param {string} [options.fgrep] - Test filter given string. |
| * @param {boolean} [options.forbidOnly] - Tests marked `only` fail the suite? |
| * @param {boolean} [options.forbidPending] - Pending tests fail the suite? |
| * @param {boolean} [options.fullStackTrace] - Full stacktrace upon failure? |
| * @param {string[]} [options.global] - Variables expected in global scope. |
| * @param {RegExp|string} [options.grep] - Test filter given regular expression. |
| * @param {boolean} [options.growl] - Enable desktop notifications? |
| * @param {boolean} [options.hideDiff] - Suppress diffs from failures? |
| * @param {boolean} [options.ignoreLeaks] - Ignore global leaks? |
| * @param {boolean} [options.invert] - Invert test filter matches? |
| * @param {boolean} [options.noHighlighting] - Disable syntax highlighting? |
| * @param {string} [options.reporter] - Reporter name. |
| * @param {Object} [options.reporterOption] - Reporter settings object. |
| * @param {number} [options.retries] - Number of times to retry failed tests. |
| * @param {number} [options.slow] - Slow threshold value. |
| * @param {number|string} [options.timeout] - Timeout threshold value. |
| * @param {string} [options.ui] - Interface name. |
| * @param {boolean} [options.color] - Color TTY output from reporter? |
| * @param {boolean} [options.useInlineDiffs] - Use inline diffs? |
| */ |
| function Mocha(options) { |
| options = utils.assign({}, mocharc, options || {}); |
| this.files = []; |
| this.options = options; |
| // root suite |
| this.suite = new exports.Suite('', new exports.Context(), true); |
| |
| if ('useColors' in options) { |
| utils.deprecate( |
| 'useColors is DEPRECATED and will be removed from a future version of Mocha. Instead, use the "color" option' |
| ); |
| options.color = 'color' in options ? options.color : options.useColors; |
| } |
| |
| // Globals are passed in as options.global, with options.globals for backward compatibility. |
| options.globals = options.global || options.globals || []; |
| delete options.global; |
| |
| this.grep(options.grep) |
| .fgrep(options.fgrep) |
| .ui(options.ui) |
| .bail(options.bail) |
| .reporter(options.reporter, options.reporterOptions) |
| .useColors(options.color) |
| .slow(options.slow) |
| .useInlineDiffs(options.inlineDiffs) |
| .globals(options.globals); |
| |
| if ('enableTimeouts' in options) { |
| utils.deprecate( |
| 'enableTimeouts is DEPRECATED and will be removed from a future version of Mocha. Instead, use "timeout: false" to disable timeouts.' |
| ); |
| if (options.enableTimeouts === false) { |
| this.timeout(0); |
| } |
| } |
| |
| // this guard exists because Suite#timeout does not consider `undefined` to be valid input |
| if (typeof options.timeout !== 'undefined') { |
| this.timeout(options.timeout === false ? 0 : options.timeout); |
| } |
| |
| if ('retries' in options) { |
| this.retries(options.retries); |
| } |
| |
| if ('diff' in options) { |
| this.hideDiff(!options.diff); |
| } |
| |
| [ |
| 'allowUncaught', |
| 'asyncOnly', |
| 'checkLeaks', |
| 'delay', |
| 'forbidOnly', |
| 'forbidPending', |
| 'fullTrace', |
| 'growl', |
| 'invert' |
| ].forEach(function(opt) { |
| if (options[opt]) { |
| this[opt](); |
| } |
| }, this); |
| } |
| |
| /** |
| * Enables or disables bailing on the first failure. |
| * |
| * @public |
| * @see {@link https://mochajs.org/#-b---bail|CLI option} |
| * @param {boolean} [bail=true] - Whether to bail on first error. |
| * @returns {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.bail = function(bail) { |
| if (!arguments.length) { |
| bail = true; |
| } |
| this.suite.bail(bail); |
| return this; |
| }; |
| |
| /** |
| * @summary |
| * Adds `file` to be loaded for execution. |
| * |
| * @description |
| * Useful for generic setup code that must be included within test suite. |
| * |
| * @public |
| * @see {@link https://mochajs.org/#--file-file|CLI option} |
| * @param {string} file - Pathname of file to be loaded. |
| * @returns {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.addFile = function(file) { |
| this.files.push(file); |
| return this; |
| }; |
| |
| /** |
| * Sets reporter to `reporter`, defaults to "spec". |
| * |
| * @public |
| * @see {@link https://mochajs.org/#-r---reporter-name|CLI option} |
| * @see {@link https://mochajs.org/#reporters|Reporters} |
| * @param {String|Function} reporter - Reporter name or constructor. |
| * @param {Object} [reporterOptions] - Options used to configure the reporter. |
| * @returns {Mocha} this |
| * @chainable |
| * @throws {Error} if requested reporter cannot be loaded |
| * @example |
| * |
| * // Use XUnit reporter and direct its output to file |
| * mocha.reporter('xunit', { output: '/path/to/testspec.xunit.xml' }); |
| */ |
| Mocha.prototype.reporter = function(reporter, reporterOptions) { |
| if (typeof reporter === 'function') { |
| this._reporter = reporter; |
| } else { |
| reporter = reporter || 'spec'; |
| var _reporter; |
| // Try to load a built-in reporter. |
| if (builtinReporters[reporter]) { |
| _reporter = builtinReporters[reporter]; |
| } |
| // Try to load reporters from process.cwd() and node_modules |
| if (!_reporter) { |
| try { |
| _reporter = require(reporter); |
| } catch (err) { |
| if ( |
| err.code !== 'MODULE_NOT_FOUND' || |
| err.message.indexOf('Cannot find module') !== -1 |
| ) { |
| // Try to load reporters from a path (absolute or relative) |
| try { |
| _reporter = require(path.resolve(process.cwd(), reporter)); |
| } catch (_err) { |
| _err.code !== 'MODULE_NOT_FOUND' || |
| _err.message.indexOf('Cannot find module') !== -1 |
| ? console.warn(sQuote(reporter) + ' reporter not found') |
| : console.warn( |
| sQuote(reporter) + |
| ' reporter blew up with error:\n' + |
| err.stack |
| ); |
| } |
| } else { |
| console.warn( |
| sQuote(reporter) + ' reporter blew up with error:\n' + err.stack |
| ); |
| } |
| } |
| } |
| if (!_reporter) { |
| throw createInvalidReporterError( |
| 'invalid reporter ' + sQuote(reporter), |
| reporter |
| ); |
| } |
| this._reporter = _reporter; |
| } |
| this.options.reporterOptions = reporterOptions; |
| return this; |
| }; |
| |
| /** |
| * Sets test UI `name`, defaults to "bdd". |
| * |
| * @public |
| * @see {@link https://mochajs.org/#-u---ui-name|CLI option} |
| * @see {@link https://mochajs.org/#interfaces|Interface DSLs} |
| * @param {string|Function} [ui=bdd] - Interface name or class. |
| * @returns {Mocha} this |
| * @chainable |
| * @throws {Error} if requested interface cannot be loaded |
| */ |
| Mocha.prototype.ui = function(ui) { |
| var bindInterface; |
| if (typeof ui === 'function') { |
| bindInterface = ui; |
| } else { |
| ui = ui || 'bdd'; |
| bindInterface = exports.interfaces[ui]; |
| if (!bindInterface) { |
| try { |
| bindInterface = require(ui); |
| } catch (err) { |
| throw createInvalidInterfaceError( |
| 'invalid interface ' + sQuote(ui), |
| ui |
| ); |
| } |
| } |
| } |
| bindInterface(this.suite); |
| |
| this.suite.on(EVENT_FILE_PRE_REQUIRE, function(context) { |
| exports.afterEach = context.afterEach || context.teardown; |
| exports.after = context.after || context.suiteTeardown; |
| exports.beforeEach = context.beforeEach || context.setup; |
| exports.before = context.before || context.suiteSetup; |
| exports.describe = context.describe || context.suite; |
| exports.it = context.it || context.test; |
| exports.xit = context.xit || (context.test && context.test.skip); |
| exports.setup = context.setup || context.beforeEach; |
| exports.suiteSetup = context.suiteSetup || context.before; |
| exports.suiteTeardown = context.suiteTeardown || context.after; |
| exports.suite = context.suite || context.describe; |
| exports.teardown = context.teardown || context.afterEach; |
| exports.test = context.test || context.it; |
| exports.run = context.run; |
| }); |
| |
| return this; |
| }; |
| |
| /** |
| * Loads `files` prior to execution. |
| * |
| * @description |
| * The implementation relies on Node's `require` to execute |
| * the test interface functions and will be subject to its cache. |
| * |
| * @private |
| * @see {@link Mocha#addFile} |
| * @see {@link Mocha#run} |
| * @see {@link Mocha#unloadFiles} |
| * @param {Function} [fn] - Callback invoked upon completion. |
| */ |
| Mocha.prototype.loadFiles = function(fn) { |
| var self = this; |
| var suite = this.suite; |
| this.files.forEach(function(file) { |
| file = path.resolve(file); |
| suite.emit(EVENT_FILE_PRE_REQUIRE, global, file, self); |
| suite.emit(EVENT_FILE_REQUIRE, require(file), file, self); |
| suite.emit(EVENT_FILE_POST_REQUIRE, global, file, self); |
| }); |
| fn && fn(); |
| }; |
| |
| /** |
| * Removes a previously loaded file from Node's `require` cache. |
| * |
| * @private |
| * @static |
| * @see {@link Mocha#unloadFiles} |
| * @param {string} file - Pathname of file to be unloaded. |
| */ |
| Mocha.unloadFile = function(file) { |
| delete require.cache[require.resolve(file)]; |
| }; |
| |
| /** |
| * Unloads `files` from Node's `require` cache. |
| * |
| * @description |
| * This allows files to be "freshly" reloaded, providing the ability |
| * to reuse a Mocha instance programmatically. |
| * |
| * <strong>Intended for consumers — not used internally</strong> |
| * |
| * @public |
| * @see {@link Mocha.unloadFile} |
| * @see {@link Mocha#loadFiles} |
| * @see {@link Mocha#run} |
| * @returns {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.unloadFiles = function() { |
| this.files.forEach(Mocha.unloadFile); |
| return this; |
| }; |
| |
| /** |
| * Sets `grep` filter after escaping RegExp special characters. |
| * |
| * @public |
| * @see {@link Mocha#grep} |
| * @param {string} str - Value to be converted to a regexp. |
| * @returns {Mocha} this |
| * @chainable |
| * @example |
| * |
| * // Select tests whose full title begins with `"foo"` followed by a period |
| * mocha.fgrep('foo.'); |
| */ |
| Mocha.prototype.fgrep = function(str) { |
| if (!str) { |
| return this; |
| } |
| return this.grep(new RegExp(escapeRe(str))); |
| }; |
| |
| /** |
| * @summary |
| * Sets `grep` filter used to select specific tests for execution. |
| * |
| * @description |
| * If `re` is a regexp-like string, it will be converted to regexp. |
| * The regexp is tested against the full title of each test (i.e., the |
| * name of the test preceded by titles of each its ancestral suites). |
| * As such, using an <em>exact-match</em> fixed pattern against the |
| * test name itself will not yield any matches. |
| * <br> |
| * <strong>Previous filter value will be overwritten on each call!</strong> |
| * |
| * @public |
| * @see {@link https://mochajs.org/#-g---grep-pattern|CLI option} |
| * @see {@link Mocha#fgrep} |
| * @see {@link Mocha#invert} |
| * @param {RegExp|String} re - Regular expression used to select tests. |
| * @return {Mocha} this |
| * @chainable |
| * @example |
| * |
| * // Select tests whose full title contains `"match"`, ignoring case |
| * mocha.grep(/match/i); |
| * @example |
| * |
| * // Same as above but with regexp-like string argument |
| * mocha.grep('/match/i'); |
| * @example |
| * |
| * // ## Anti-example |
| * // Given embedded test `it('only-this-test')`... |
| * mocha.grep('/^only-this-test$/'); // NO! Use `.only()` to do this! |
| */ |
| Mocha.prototype.grep = function(re) { |
| if (utils.isString(re)) { |
| // extract args if it's regex-like, i.e: [string, pattern, flag] |
| var arg = re.match(/^\/(.*)\/(g|i|)$|.*/); |
| this.options.grep = new RegExp(arg[1] || arg[0], arg[2]); |
| } else { |
| this.options.grep = re; |
| } |
| return this; |
| }; |
| |
| /** |
| * Inverts `grep` matches. |
| * |
| * @public |
| * @see {@link Mocha#grep} |
| * @return {Mocha} this |
| * @chainable |
| * @example |
| * |
| * // Select tests whose full title does *not* contain `"match"`, ignoring case |
| * mocha.grep(/match/i).invert(); |
| */ |
| Mocha.prototype.invert = function() { |
| this.options.invert = true; |
| return this; |
| }; |
| |
| /** |
| * Enables or disables ignoring global leaks. |
| * |
| * @public |
| * @see {@link Mocha#checkLeaks} |
| * @param {boolean} ignoreLeaks - Whether to ignore global leaks. |
| * @return {Mocha} this |
| * @chainable |
| * @example |
| * |
| * // Ignore global leaks |
| * mocha.ignoreLeaks(true); |
| */ |
| Mocha.prototype.ignoreLeaks = function(ignoreLeaks) { |
| this.options.ignoreLeaks = Boolean(ignoreLeaks); |
| return this; |
| }; |
| |
| /** |
| * Enables checking for global variables leaked while running tests. |
| * |
| * @public |
| * @see {@link https://mochajs.org/#--check-leaks|CLI option} |
| * @see {@link Mocha#ignoreLeaks} |
| * @return {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.checkLeaks = function() { |
| this.options.ignoreLeaks = false; |
| return this; |
| }; |
| |
| /** |
| * Displays full stack trace upon test failure. |
| * |
| * @public |
| * @return {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.fullTrace = function() { |
| this.options.fullStackTrace = true; |
| return this; |
| }; |
| |
| /** |
| * Enables desktop notification support if prerequisite software installed. |
| * |
| * @public |
| * @see {@link Mocha#isGrowlCapable} |
| * @see {@link Mocha#_growl} |
| * @return {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.growl = function() { |
| this.options.growl = this.isGrowlCapable(); |
| if (!this.options.growl) { |
| var detail = process.browser |
| ? 'notification support not available in this browser...' |
| : 'notification support prerequisites not installed...'; |
| console.error(detail + ' cannot enable!'); |
| } |
| return this; |
| }; |
| |
| /** |
| * @summary |
| * Determines if Growl support seems likely. |
| * |
| * @description |
| * <strong>Not available when run in browser.</strong> |
| * |
| * @private |
| * @see {@link Growl#isCapable} |
| * @see {@link Mocha#growl} |
| * @return {boolean} whether Growl support can be expected |
| */ |
| Mocha.prototype.isGrowlCapable = growl.isCapable; |
| |
| /** |
| * Implements desktop notifications using a pseudo-reporter. |
| * |
| * @private |
| * @see {@link Mocha#growl} |
| * @see {@link Growl#notify} |
| * @param {Runner} runner - Runner instance. |
| */ |
| Mocha.prototype._growl = growl.notify; |
| |
| /** |
| * Specifies whitelist of variable names to be expected in global scope. |
| * |
| * @public |
| * @see {@link https://mochajs.org/#-global-variable-name|CLI option} |
| * @see {@link Mocha#checkLeaks} |
| * @param {String[]|String} globals - Accepted global variable name(s). |
| * @return {Mocha} this |
| * @chainable |
| * @example |
| * |
| * // Specify variables to be expected in global scope |
| * mocha.globals(['jQuery', 'MyLib']); |
| */ |
| Mocha.prototype.globals = function(globals) { |
| this.options.globals = this.options.globals |
| .concat(globals) |
| .filter(Boolean) |
| .filter(function(elt, idx, arr) { |
| return arr.indexOf(elt) === idx; |
| }); |
| return this; |
| }; |
| |
| /** |
| * Enables or disables TTY color output by screen-oriented reporters. |
| * |
| * @public |
| * @param {boolean} colors - Whether to enable color output. |
| * @return {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.useColors = function(colors) { |
| if (colors !== undefined) { |
| this.options.useColors = colors; |
| } |
| return this; |
| }; |
| |
| /** |
| * Determines if reporter should use inline diffs (rather than +/-) |
| * in test failure output. |
| * |
| * @public |
| * @param {boolean} inlineDiffs - Whether to use inline diffs. |
| * @return {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.useInlineDiffs = function(inlineDiffs) { |
| this.options.useInlineDiffs = inlineDiffs !== undefined && inlineDiffs; |
| return this; |
| }; |
| |
| /** |
| * Determines if reporter should include diffs in test failure output. |
| * |
| * @public |
| * @param {boolean} hideDiff - Whether to hide diffs. |
| * @return {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.hideDiff = function(hideDiff) { |
| this.options.hideDiff = hideDiff !== undefined && hideDiff; |
| return this; |
| }; |
| |
| /** |
| * @summary |
| * Sets timeout threshold value. |
| * |
| * @description |
| * A string argument can use shorthand (such as "2s") and will be converted. |
| * If the value is `0`, timeouts will be disabled. |
| * |
| * @public |
| * @see {@link https://mochajs.org/#-t---timeout-ms|CLI option} |
| * @see {@link https://mochajs.org/#--no-timeouts|CLI option} |
| * @see {@link https://mochajs.org/#timeouts|Timeouts} |
| * @see {@link Mocha#enableTimeouts} |
| * @param {number|string} msecs - Timeout threshold value. |
| * @return {Mocha} this |
| * @chainable |
| * @example |
| * |
| * // Sets timeout to one second |
| * mocha.timeout(1000); |
| * @example |
| * |
| * // Same as above but using string argument |
| * mocha.timeout('1s'); |
| */ |
| Mocha.prototype.timeout = function(msecs) { |
| this.suite.timeout(msecs); |
| return this; |
| }; |
| |
| /** |
| * Sets the number of times to retry failed tests. |
| * |
| * @public |
| * @see {@link https://mochajs.org/#retry-tests|Retry Tests} |
| * @param {number} retry - Number of times to retry failed tests. |
| * @return {Mocha} this |
| * @chainable |
| * @example |
| * |
| * // Allow any failed test to retry one more time |
| * mocha.retries(1); |
| */ |
| Mocha.prototype.retries = function(n) { |
| this.suite.retries(n); |
| return this; |
| }; |
| |
| /** |
| * Sets slowness threshold value. |
| * |
| * @public |
| * @see {@link https://mochajs.org/#-s---slow-ms|CLI option} |
| * @param {number} msecs - Slowness threshold value. |
| * @return {Mocha} this |
| * @chainable |
| * @example |
| * |
| * // Sets "slow" threshold to half a second |
| * mocha.slow(500); |
| * @example |
| * |
| * // Same as above but using string argument |
| * mocha.slow('0.5s'); |
| */ |
| Mocha.prototype.slow = function(msecs) { |
| this.suite.slow(msecs); |
| return this; |
| }; |
| |
| /** |
| * Enables or disables timeouts. |
| * |
| * @public |
| * @see {@link https://mochajs.org/#-t---timeout-ms|CLI option} |
| * @see {@link https://mochajs.org/#--no-timeouts|CLI option} |
| * @param {boolean} enableTimeouts - Whether to enable timeouts. |
| * @return {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.enableTimeouts = function(enableTimeouts) { |
| this.suite.enableTimeouts( |
| arguments.length && enableTimeouts !== undefined ? enableTimeouts : true |
| ); |
| return this; |
| }; |
| |
| /** |
| * Forces all tests to either accept a `done` callback or return a promise. |
| * |
| * @public |
| * @return {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.asyncOnly = function() { |
| this.options.asyncOnly = true; |
| return this; |
| }; |
| |
| /** |
| * Disables syntax highlighting (in browser). |
| * |
| * @public |
| * @return {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.noHighlighting = function() { |
| this.options.noHighlighting = true; |
| return this; |
| }; |
| |
| /** |
| * Enables uncaught errors to propagate (in browser). |
| * |
| * @public |
| * @return {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.allowUncaught = function() { |
| this.options.allowUncaught = true; |
| return this; |
| }; |
| |
| /** |
| * @summary |
| * Delays root suite execution. |
| * |
| * @description |
| * Used to perform asynch operations before any suites are run. |
| * |
| * @public |
| * @see {@link https://mochajs.org/#delayed-root-suite|delayed root suite} |
| * @returns {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.delay = function delay() { |
| this.options.delay = true; |
| return this; |
| }; |
| |
| /** |
| * Causes tests marked `only` to fail the suite. |
| * |
| * @public |
| * @returns {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.forbidOnly = function() { |
| this.options.forbidOnly = true; |
| return this; |
| }; |
| |
| /** |
| * Causes pending tests and tests marked `skip` to fail the suite. |
| * |
| * @public |
| * @returns {Mocha} this |
| * @chainable |
| */ |
| Mocha.prototype.forbidPending = function() { |
| this.options.forbidPending = true; |
| return this; |
| }; |
| |
| /** |
| * Mocha version as specified by "package.json". |
| * |
| * @name Mocha#version |
| * @type string |
| * @readonly |
| */ |
| Object.defineProperty(Mocha.prototype, 'version', { |
| value: require('../package.json').version, |
| configurable: false, |
| enumerable: true, |
| writable: false |
| }); |
| |
| /** |
| * Callback to be invoked when test execution is complete. |
| * |
| * @callback DoneCB |
| * @param {number} failures - Number of failures that occurred. |
| */ |
| |
| /** |
| * Runs root suite and invokes `fn()` when complete. |
| * |
| * @description |
| * To run tests multiple times (or to run tests in files that are |
| * already in the `require` cache), make sure to clear them from |
| * the cache first! |
| * |
| * @public |
| * @see {@link Mocha#loadFiles} |
| * @see {@link Mocha#unloadFiles} |
| * @see {@link Runner#run} |
| * @param {DoneCB} [fn] - Callback invoked when test execution completed. |
| * @return {Runner} runner instance |
| */ |
| Mocha.prototype.run = function(fn) { |
| if (this.files.length) { |
| this.loadFiles(); |
| } |
| var suite = this.suite; |
| var options = this.options; |
| options.files = this.files; |
| var runner = new exports.Runner(suite, options.delay); |
| createStatsCollector(runner); |
| var reporter = new this._reporter(runner, options); |
| runner.ignoreLeaks = options.ignoreLeaks !== false; |
| runner.fullStackTrace = options.fullStackTrace; |
| runner.asyncOnly = options.asyncOnly; |
| runner.allowUncaught = options.allowUncaught; |
| runner.forbidOnly = options.forbidOnly; |
| runner.forbidPending = options.forbidPending; |
| if (options.grep) { |
| runner.grep(options.grep, options.invert); |
| } |
| if (options.globals) { |
| runner.globals(options.globals); |
| } |
| if (options.growl) { |
| this._growl(runner); |
| } |
| if (options.useColors !== undefined) { |
| exports.reporters.Base.useColors = options.useColors; |
| } |
| exports.reporters.Base.inlineDiffs = options.useInlineDiffs; |
| exports.reporters.Base.hideDiff = options.hideDiff; |
| |
| function done(failures) { |
| fn = fn || utils.noop; |
| if (reporter.done) { |
| reporter.done(failures, fn); |
| } else { |
| fn(failures); |
| } |
| } |
| |
| return runner.run(done); |
| }; |
| |
| }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{"../package.json":90,"./context":5,"./errors":6,"./growl":2,"./hook":7,"./interfaces":11,"./mocharc.json":15,"./reporters":21,"./runnable":33,"./runner":34,"./stats-collector":35,"./suite":36,"./test":37,"./utils":38,"_process":69,"escape-string-regexp":49,"path":42}],15:[function(require,module,exports){ |
| module.exports={ |
| "diff": true, |
| "extension": ["js"], |
| "opts": "./test/mocha.opts", |
| "package": "./package.json", |
| "reporter": "spec", |
| "slow": 75, |
| "timeout": 2000, |
| "ui": "bdd" |
| } |
| |
| },{}],16:[function(require,module,exports){ |
| 'use strict'; |
| |
| module.exports = Pending; |
| |
| /** |
| * Initialize a new `Pending` error with the given message. |
| * |
| * @param {string} message |
| */ |
| function Pending(message) { |
| this.message = message; |
| } |
| |
| },{}],17:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| /** |
| * @module Base |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var tty = require('tty'); |
| var diff = require('diff'); |
| var milliseconds = require('ms'); |
| var utils = require('../utils'); |
| var supportsColor = process.browser ? null : require('supports-color'); |
| var constants = require('../runner').constants; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| |
| /** |
| * Expose `Base`. |
| */ |
| |
| exports = module.exports = Base; |
| |
| /** |
| * Check if both stdio streams are associated with a tty. |
| */ |
| |
| var isatty = tty.isatty(1) && tty.isatty(2); |
| |
| /** |
| * Save log references to avoid tests interfering (see GH-3604). |
| */ |
| var consoleLog = console.log; |
| |
| /** |
| * Enable coloring by default, except in the browser interface. |
| */ |
| |
| exports.useColors = |
| !process.browser && |
| (supportsColor.stdout || process.env.MOCHA_COLORS !== undefined); |
| |
| /** |
| * Inline diffs instead of +/- |
| */ |
| |
| exports.inlineDiffs = false; |
| |
| /** |
| * Default color map. |
| */ |
| |
| exports.colors = { |
| pass: 90, |
| fail: 31, |
| 'bright pass': 92, |
| 'bright fail': 91, |
| 'bright yellow': 93, |
| pending: 36, |
| suite: 0, |
| 'error title': 0, |
| 'error message': 31, |
| 'error stack': 90, |
| checkmark: 32, |
| fast: 90, |
| medium: 33, |
| slow: 31, |
| green: 32, |
| light: 90, |
| 'diff gutter': 90, |
| 'diff added': 32, |
| 'diff removed': 31 |
| }; |
| |
| /** |
| * Default symbol map. |
| */ |
| |
| exports.symbols = { |
| ok: '✓', |
| err: '✖', |
| dot: '․', |
| comma: ',', |
| bang: '!' |
| }; |
| |
| // With node.js on Windows: use symbols available in terminal default fonts |
| if (process.platform === 'win32') { |
| exports.symbols.ok = '\u221A'; |
| exports.symbols.err = '\u00D7'; |
| exports.symbols.dot = '.'; |
| } |
| |
| /** |
| * Color `str` with the given `type`, |
| * allowing colors to be disabled, |
| * as well as user-defined color |
| * schemes. |
| * |
| * @private |
| * @param {string} type |
| * @param {string} str |
| * @return {string} |
| */ |
| var color = (exports.color = function(type, str) { |
| if (!exports.useColors) { |
| return String(str); |
| } |
| return '\u001b[' + exports.colors[type] + 'm' + str + '\u001b[0m'; |
| }); |
| |
| /** |
| * Expose term window size, with some defaults for when stderr is not a tty. |
| */ |
| |
| exports.window = { |
| width: 75 |
| }; |
| |
| if (isatty) { |
| exports.window.width = process.stdout.getWindowSize |
| ? process.stdout.getWindowSize(1)[0] |
| : tty.getWindowSize()[1]; |
| } |
| |
| /** |
| * Expose some basic cursor interactions that are common among reporters. |
| */ |
| |
| exports.cursor = { |
| hide: function() { |
| isatty && process.stdout.write('\u001b[?25l'); |
| }, |
| |
| show: function() { |
| isatty && process.stdout.write('\u001b[?25h'); |
| }, |
| |
| deleteLine: function() { |
| isatty && process.stdout.write('\u001b[2K'); |
| }, |
| |
| beginningOfLine: function() { |
| isatty && process.stdout.write('\u001b[0G'); |
| }, |
| |
| CR: function() { |
| if (isatty) { |
| exports.cursor.deleteLine(); |
| exports.cursor.beginningOfLine(); |
| } else { |
| process.stdout.write('\r'); |
| } |
| } |
| }; |
| |
| function showDiff(err) { |
| return ( |
| err && |
| err.showDiff !== false && |
| sameType(err.actual, err.expected) && |
| err.expected !== undefined |
| ); |
| } |
| |
| function stringifyDiffObjs(err) { |
| if (!utils.isString(err.actual) || !utils.isString(err.expected)) { |
| err.actual = utils.stringify(err.actual); |
| err.expected = utils.stringify(err.expected); |
| } |
| } |
| |
| /** |
| * Returns a diff between 2 strings with coloured ANSI output. |
| * |
| * @description |
| * The diff will be either inline or unified dependent on the value |
| * of `Base.inlineDiff`. |
| * |
| * @param {string} actual |
| * @param {string} expected |
| * @return {string} Diff |
| */ |
| var generateDiff = (exports.generateDiff = function(actual, expected) { |
| return exports.inlineDiffs |
| ? inlineDiff(actual, expected) |
| : unifiedDiff(actual, expected); |
| }); |
| |
| /** |
| * Outputs the given `failures` as a list. |
| * |
| * @public |
| * @memberof Mocha.reporters.Base |
| * @variation 1 |
| * @param {Object[]} failures - Each is Test instance with corresponding |
| * Error property |
| */ |
| exports.list = function(failures) { |
| Base.consoleLog(); |
| failures.forEach(function(test, i) { |
| // format |
| var fmt = |
| color('error title', ' %s) %s:\n') + |
| color('error message', ' %s') + |
| color('error stack', '\n%s\n'); |
| |
| // msg |
| var msg; |
| var err = test.err; |
| var message; |
| if (err.message && typeof err.message.toString === 'function') { |
| message = err.message + ''; |
| } else if (typeof err.inspect === 'function') { |
| message = err.inspect() + ''; |
| } else { |
| message = ''; |
| } |
| var stack = err.stack || message; |
| var index = message ? stack.indexOf(message) : -1; |
| |
| if (index === -1) { |
| msg = message; |
| } else { |
| index += message.length; |
| msg = stack.slice(0, index); |
| // remove msg from stack |
| stack = stack.slice(index + 1); |
| } |
| |
| // uncaught |
| if (err.uncaught) { |
| msg = 'Uncaught ' + msg; |
| } |
| // explicitly show diff |
| if (!exports.hideDiff && showDiff(err)) { |
| stringifyDiffObjs(err); |
| fmt = |
| color('error title', ' %s) %s:\n%s') + color('error stack', '\n%s\n'); |
| var match = message.match(/^([^:]+): expected/); |
| msg = '\n ' + color('error message', match ? match[1] : msg); |
| |
| msg += generateDiff(err.actual, err.expected); |
| } |
| |
| // indent stack trace |
| stack = stack.replace(/^/gm, ' '); |
| |
| // indented test title |
| var testTitle = ''; |
| test.titlePath().forEach(function(str, index) { |
| if (index !== 0) { |
| testTitle += '\n '; |
| } |
| for (var i = 0; i < index; i++) { |
| testTitle += ' '; |
| } |
| testTitle += str; |
| }); |
| |
| Base.consoleLog(fmt, i + 1, testTitle, msg, stack); |
| }); |
| }; |
| |
| /** |
| * Constructs a new `Base` reporter instance. |
| * |
| * @description |
| * All other reporters generally inherit from this reporter. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function Base(runner, options) { |
| var failures = (this.failures = []); |
| |
| if (!runner) { |
| throw new TypeError('Missing runner argument'); |
| } |
| this.options = options || {}; |
| this.runner = runner; |
| this.stats = runner.stats; // assigned so Reporters keep a closer reference |
| |
| runner.on(EVENT_TEST_PASS, function(test) { |
| if (test.duration > test.slow()) { |
| test.speed = 'slow'; |
| } else if (test.duration > test.slow() / 2) { |
| test.speed = 'medium'; |
| } else { |
| test.speed = 'fast'; |
| } |
| }); |
| |
| runner.on(EVENT_TEST_FAIL, function(test, err) { |
| if (showDiff(err)) { |
| stringifyDiffObjs(err); |
| } |
| test.err = err; |
| failures.push(test); |
| }); |
| } |
| |
| /** |
| * Outputs common epilogue used by many of the bundled reporters. |
| * |
| * @public |
| * @memberof Mocha.reporters.Base |
| */ |
| Base.prototype.epilogue = function() { |
| var stats = this.stats; |
| var fmt; |
| |
| Base.consoleLog(); |
| |
| // passes |
| fmt = |
| color('bright pass', ' ') + |
| color('green', ' %d passing') + |
| color('light', ' (%s)'); |
| |
| Base.consoleLog(fmt, stats.passes || 0, milliseconds(stats.duration)); |
| |
| // pending |
| if (stats.pending) { |
| fmt = color('pending', ' ') + color('pending', ' %d pending'); |
| |
| Base.consoleLog(fmt, stats.pending); |
| } |
| |
| // failures |
| if (stats.failures) { |
| fmt = color('fail', ' %d failing'); |
| |
| Base.consoleLog(fmt, stats.failures); |
| |
| Base.list(this.failures); |
| Base.consoleLog(); |
| } |
| |
| Base.consoleLog(); |
| }; |
| |
| /** |
| * Pads the given `str` to `len`. |
| * |
| * @private |
| * @param {string} str |
| * @param {string} len |
| * @return {string} |
| */ |
| function pad(str, len) { |
| str = String(str); |
| return Array(len - str.length + 1).join(' ') + str; |
| } |
| |
| /** |
| * Returns inline diff between 2 strings with coloured ANSI output. |
| * |
| * @private |
| * @param {String} actual |
| * @param {String} expected |
| * @return {string} Diff |
| */ |
| function inlineDiff(actual, expected) { |
| var msg = errorDiff(actual, expected); |
| |
| // linenos |
| var lines = msg.split('\n'); |
| if (lines.length > 4) { |
| var width = String(lines.length).length; |
| msg = lines |
| .map(function(str, i) { |
| return pad(++i, width) + ' |' + ' ' + str; |
| }) |
| .join('\n'); |
| } |
| |
| // legend |
| msg = |
| '\n' + |
| color('diff removed', 'actual') + |
| ' ' + |
| color('diff added', 'expected') + |
| '\n\n' + |
| msg + |
| '\n'; |
| |
| // indent |
| msg = msg.replace(/^/gm, ' '); |
| return msg; |
| } |
| |
| /** |
| * Returns unified diff between two strings with coloured ANSI output. |
| * |
| * @private |
| * @param {String} actual |
| * @param {String} expected |
| * @return {string} The diff. |
| */ |
| function unifiedDiff(actual, expected) { |
| var indent = ' '; |
| function cleanUp(line) { |
| if (line[0] === '+') { |
| return indent + colorLines('diff added', line); |
| } |
| if (line[0] === '-') { |
| return indent + colorLines('diff removed', line); |
| } |
| if (line.match(/@@/)) { |
| return '--'; |
| } |
| if (line.match(/\\ No newline/)) { |
| return null; |
| } |
| return indent + line; |
| } |
| function notBlank(line) { |
| return typeof line !== 'undefined' && line !== null; |
| } |
| var msg = diff.createPatch('string', actual, expected); |
| var lines = msg.split('\n').splice(5); |
| return ( |
| '\n ' + |
| colorLines('diff added', '+ expected') + |
| ' ' + |
| colorLines('diff removed', '- actual') + |
| '\n\n' + |
| lines |
| .map(cleanUp) |
| .filter(notBlank) |
| .join('\n') |
| ); |
| } |
| |
| /** |
| * Returns character diff for `err`. |
| * |
| * @private |
| * @param {String} actual |
| * @param {String} expected |
| * @return {string} the diff |
| */ |
| function errorDiff(actual, expected) { |
| return diff |
| .diffWordsWithSpace(actual, expected) |
| .map(function(str) { |
| if (str.added) { |
| return colorLines('diff added', str.value); |
| } |
| if (str.removed) { |
| return colorLines('diff removed', str.value); |
| } |
| return str.value; |
| }) |
| .join(''); |
| } |
| |
| /** |
| * Colors lines for `str`, using the color `name`. |
| * |
| * @private |
| * @param {string} name |
| * @param {string} str |
| * @return {string} |
| */ |
| function colorLines(name, str) { |
| return str |
| .split('\n') |
| .map(function(str) { |
| return color(name, str); |
| }) |
| .join('\n'); |
| } |
| |
| /** |
| * Object#toString reference. |
| */ |
| var objToString = Object.prototype.toString; |
| |
| /** |
| * Checks that a / b have the same type. |
| * |
| * @private |
| * @param {Object} a |
| * @param {Object} b |
| * @return {boolean} |
| */ |
| function sameType(a, b) { |
| return objToString.call(a) === objToString.call(b); |
| } |
| |
| Base.consoleLog = consoleLog; |
| |
| Base.abstract = true; |
| |
| }).call(this,require('_process')) |
| },{"../runner":34,"../utils":38,"_process":69,"diff":48,"ms":60,"supports-color":42,"tty":4}],18:[function(require,module,exports){ |
| 'use strict'; |
| /** |
| * @module Doc |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var utils = require('../utils'); |
| var constants = require('../runner').constants; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| var EVENT_SUITE_BEGIN = constants.EVENT_SUITE_BEGIN; |
| var EVENT_SUITE_END = constants.EVENT_SUITE_END; |
| |
| /** |
| * Expose `Doc`. |
| */ |
| |
| exports = module.exports = Doc; |
| |
| /** |
| * Constructs a new `Doc` reporter instance. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function Doc(runner, options) { |
| Base.call(this, runner, options); |
| |
| var indents = 2; |
| |
| function indent() { |
| return Array(indents).join(' '); |
| } |
| |
| runner.on(EVENT_SUITE_BEGIN, function(suite) { |
| if (suite.root) { |
| return; |
| } |
| ++indents; |
| Base.consoleLog('%s<section class="suite">', indent()); |
| ++indents; |
| Base.consoleLog('%s<h1>%s</h1>', indent(), utils.escape(suite.title)); |
| Base.consoleLog('%s<dl>', indent()); |
| }); |
| |
| runner.on(EVENT_SUITE_END, function(suite) { |
| if (suite.root) { |
| return; |
| } |
| Base.consoleLog('%s</dl>', indent()); |
| --indents; |
| Base.consoleLog('%s</section>', indent()); |
| --indents; |
| }); |
| |
| runner.on(EVENT_TEST_PASS, function(test) { |
| Base.consoleLog('%s <dt>%s</dt>', indent(), utils.escape(test.title)); |
| var code = utils.escape(utils.clean(test.body)); |
| Base.consoleLog('%s <dd><pre><code>%s</code></pre></dd>', indent(), code); |
| }); |
| |
| runner.on(EVENT_TEST_FAIL, function(test, err) { |
| Base.consoleLog( |
| '%s <dt class="error">%s</dt>', |
| indent(), |
| utils.escape(test.title) |
| ); |
| var code = utils.escape(utils.clean(test.body)); |
| Base.consoleLog( |
| '%s <dd class="error"><pre><code>%s</code></pre></dd>', |
| indent(), |
| code |
| ); |
| Base.consoleLog( |
| '%s <dd class="error">%s</dd>', |
| indent(), |
| utils.escape(err) |
| ); |
| }); |
| } |
| |
| Doc.description = 'HTML documentation'; |
| |
| },{"../runner":34,"../utils":38,"./base":17}],19:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| /** |
| * @module Dot |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var inherits = require('../utils').inherits; |
| var constants = require('../runner').constants; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| var EVENT_RUN_BEGIN = constants.EVENT_RUN_BEGIN; |
| var EVENT_TEST_PENDING = constants.EVENT_TEST_PENDING; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| |
| /** |
| * Expose `Dot`. |
| */ |
| |
| exports = module.exports = Dot; |
| |
| /** |
| * Constructs a new `Dot` reporter instance. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function Dot(runner, options) { |
| Base.call(this, runner, options); |
| |
| var self = this; |
| var width = (Base.window.width * 0.75) | 0; |
| var n = -1; |
| |
| runner.on(EVENT_RUN_BEGIN, function() { |
| process.stdout.write('\n'); |
| }); |
| |
| runner.on(EVENT_TEST_PENDING, function() { |
| if (++n % width === 0) { |
| process.stdout.write('\n '); |
| } |
| process.stdout.write(Base.color('pending', Base.symbols.comma)); |
| }); |
| |
| runner.on(EVENT_TEST_PASS, function(test) { |
| if (++n % width === 0) { |
| process.stdout.write('\n '); |
| } |
| if (test.speed === 'slow') { |
| process.stdout.write(Base.color('bright yellow', Base.symbols.dot)); |
| } else { |
| process.stdout.write(Base.color(test.speed, Base.symbols.dot)); |
| } |
| }); |
| |
| runner.on(EVENT_TEST_FAIL, function() { |
| if (++n % width === 0) { |
| process.stdout.write('\n '); |
| } |
| process.stdout.write(Base.color('fail', Base.symbols.bang)); |
| }); |
| |
| runner.once(EVENT_RUN_END, function() { |
| process.stdout.write('\n'); |
| self.epilogue(); |
| }); |
| } |
| |
| /** |
| * Inherit from `Base.prototype`. |
| */ |
| inherits(Dot, Base); |
| |
| Dot.description = 'dot matrix representation'; |
| |
| }).call(this,require('_process')) |
| },{"../runner":34,"../utils":38,"./base":17,"_process":69}],20:[function(require,module,exports){ |
| (function (global){ |
| 'use strict'; |
| |
| /* eslint-env browser */ |
| /** |
| * @module HTML |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var utils = require('../utils'); |
| var Progress = require('../browser/progress'); |
| var escapeRe = require('escape-string-regexp'); |
| var constants = require('../runner').constants; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| var EVENT_SUITE_BEGIN = constants.EVENT_SUITE_BEGIN; |
| var EVENT_SUITE_END = constants.EVENT_SUITE_END; |
| var EVENT_TEST_PENDING = constants.EVENT_TEST_PENDING; |
| var escape = utils.escape; |
| |
| /** |
| * Save timer references to avoid Sinon interfering (see GH-237). |
| */ |
| |
| var Date = global.Date; |
| |
| /** |
| * Expose `HTML`. |
| */ |
| |
| exports = module.exports = HTML; |
| |
| /** |
| * Stats template. |
| */ |
| |
| var statsTemplate = |
| '<ul id="mocha-stats">' + |
| '<li class="progress"><canvas width="40" height="40"></canvas></li>' + |
| '<li class="passes"><a href="javascript:void(0);">passes:</a> <em>0</em></li>' + |
| '<li class="failures"><a href="javascript:void(0);">failures:</a> <em>0</em></li>' + |
| '<li class="duration">duration: <em>0</em>s</li>' + |
| '</ul>'; |
| |
| var playIcon = '‣'; |
| |
| /** |
| * Constructs a new `HTML` reporter instance. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function HTML(runner, options) { |
| Base.call(this, runner, options); |
| |
| var self = this; |
| var stats = this.stats; |
| var stat = fragment(statsTemplate); |
| var items = stat.getElementsByTagName('li'); |
| var passes = items[1].getElementsByTagName('em')[0]; |
| var passesLink = items[1].getElementsByTagName('a')[0]; |
| var failures = items[2].getElementsByTagName('em')[0]; |
| var failuresLink = items[2].getElementsByTagName('a')[0]; |
| var duration = items[3].getElementsByTagName('em')[0]; |
| var canvas = stat.getElementsByTagName('canvas')[0]; |
| var report = fragment('<ul id="mocha-report"></ul>'); |
| var stack = [report]; |
| var progress; |
| var ctx; |
| var root = document.getElementById('mocha'); |
| |
| if (canvas.getContext) { |
| var ratio = window.devicePixelRatio || 1; |
| canvas.style.width = canvas.width; |
| canvas.style.height = canvas.height; |
| canvas.width *= ratio; |
| canvas.height *= ratio; |
| ctx = canvas.getContext('2d'); |
| ctx.scale(ratio, ratio); |
| progress = new Progress(); |
| } |
| |
| if (!root) { |
| return error('#mocha div missing, add it to your document'); |
| } |
| |
| // pass toggle |
| on(passesLink, 'click', function(evt) { |
| evt.preventDefault(); |
| unhide(); |
| var name = /pass/.test(report.className) ? '' : ' pass'; |
| report.className = report.className.replace(/fail|pass/g, '') + name; |
| if (report.className.trim()) { |
| hideSuitesWithout('test pass'); |
| } |
| }); |
| |
| // failure toggle |
| on(failuresLink, 'click', function(evt) { |
| evt.preventDefault(); |
| unhide(); |
| var name = /fail/.test(report.className) ? '' : ' fail'; |
| report.className = report.className.replace(/fail|pass/g, '') + name; |
| if (report.className.trim()) { |
| hideSuitesWithout('test fail'); |
| } |
| }); |
| |
| root.appendChild(stat); |
| root.appendChild(report); |
| |
| if (progress) { |
| progress.size(40); |
| } |
| |
| runner.on(EVENT_SUITE_BEGIN, function(suite) { |
| if (suite.root) { |
| return; |
| } |
| |
| // suite |
| var url = self.suiteURL(suite); |
| var el = fragment( |
| '<li class="suite"><h1><a href="%s">%s</a></h1></li>', |
| url, |
| escape(suite.title) |
| ); |
| |
| // container |
| stack[0].appendChild(el); |
| stack.unshift(document.createElement('ul')); |
| el.appendChild(stack[0]); |
| }); |
| |
| runner.on(EVENT_SUITE_END, function(suite) { |
| if (suite.root) { |
| updateStats(); |
| return; |
| } |
| stack.shift(); |
| }); |
| |
| runner.on(EVENT_TEST_PASS, function(test) { |
| var url = self.testURL(test); |
| var markup = |
| '<li class="test pass %e"><h2>%e<span class="duration">%ems</span> ' + |
| '<a href="%s" class="replay">' + |
| playIcon + |
| '</a></h2></li>'; |
| var el = fragment(markup, test.speed, test.title, test.duration, url); |
| self.addCodeToggle(el, test.body); |
| appendToStack(el); |
| updateStats(); |
| }); |
| |
| runner.on(EVENT_TEST_FAIL, function(test) { |
| var el = fragment( |
| '<li class="test fail"><h2>%e <a href="%e" class="replay">' + |
| playIcon + |
| '</a></h2></li>', |
| test.title, |
| self.testURL(test) |
| ); |
| var stackString; // Note: Includes leading newline |
| var message = test.err.toString(); |
| |
| // <=IE7 stringifies to [Object Error]. Since it can be overloaded, we |
| // check for the result of the stringifying. |
| if (message === '[object Error]') { |
| message = test.err.message; |
| } |
| |
| if (test.err.stack) { |
| var indexOfMessage = test.err.stack.indexOf(test.err.message); |
| if (indexOfMessage === -1) { |
| stackString = test.err.stack; |
| } else { |
| stackString = test.err.stack.substr( |
| test.err.message.length + indexOfMessage |
| ); |
| } |
| } else if (test.err.sourceURL && test.err.line !== undefined) { |
| // Safari doesn't give you a stack. Let's at least provide a source line. |
| stackString = '\n(' + test.err.sourceURL + ':' + test.err.line + ')'; |
| } |
| |
| stackString = stackString || ''; |
| |
| if (test.err.htmlMessage && stackString) { |
| el.appendChild( |
| fragment( |
| '<div class="html-error">%s\n<pre class="error">%e</pre></div>', |
| test.err.htmlMessage, |
| stackString |
| ) |
| ); |
| } else if (test.err.htmlMessage) { |
| el.appendChild( |
| fragment('<div class="html-error">%s</div>', test.err.htmlMessage) |
| ); |
| } else { |
| el.appendChild( |
| fragment('<pre class="error">%e%e</pre>', message, stackString) |
| ); |
| } |
| |
| self.addCodeToggle(el, test.body); |
| appendToStack(el); |
| updateStats(); |
| }); |
| |
| runner.on(EVENT_TEST_PENDING, function(test) { |
| var el = fragment( |
| '<li class="test pass pending"><h2>%e</h2></li>', |
| test.title |
| ); |
| appendToStack(el); |
| updateStats(); |
| }); |
| |
| function appendToStack(el) { |
| // Don't call .appendChild if #mocha-report was already .shift()'ed off the stack. |
| if (stack[0]) { |
| stack[0].appendChild(el); |
| } |
| } |
| |
| function updateStats() { |
| // TODO: add to stats |
| var percent = ((stats.tests / runner.total) * 100) | 0; |
| if (progress) { |
| progress.update(percent).draw(ctx); |
| } |
| |
| // update stats |
| var ms = new Date() - stats.start; |
| text(passes, stats.passes); |
| text(failures, stats.failures); |
| text(duration, (ms / 1000).toFixed(2)); |
| } |
| } |
| |
| /** |
| * Makes a URL, preserving querystring ("search") parameters. |
| * |
| * @param {string} s |
| * @return {string} A new URL. |
| */ |
| function makeUrl(s) { |
| var search = window.location.search; |
| |
| // Remove previous grep query parameter if present |
| if (search) { |
| search = search.replace(/[?&]grep=[^&\s]*/g, '').replace(/^&/, '?'); |
| } |
| |
| return ( |
| window.location.pathname + |
| (search ? search + '&' : '?') + |
| 'grep=' + |
| encodeURIComponent(escapeRe(s)) |
| ); |
| } |
| |
| /** |
| * Provide suite URL. |
| * |
| * @param {Object} [suite] |
| */ |
| HTML.prototype.suiteURL = function(suite) { |
| return makeUrl(suite.fullTitle()); |
| }; |
| |
| /** |
| * Provide test URL. |
| * |
| * @param {Object} [test] |
| */ |
| HTML.prototype.testURL = function(test) { |
| return makeUrl(test.fullTitle()); |
| }; |
| |
| /** |
| * Adds code toggle functionality for the provided test's list element. |
| * |
| * @param {HTMLLIElement} el |
| * @param {string} contents |
| */ |
| HTML.prototype.addCodeToggle = function(el, contents) { |
| var h2 = el.getElementsByTagName('h2')[0]; |
| |
| on(h2, 'click', function() { |
| pre.style.display = pre.style.display === 'none' ? 'block' : 'none'; |
| }); |
| |
| var pre = fragment('<pre><code>%e</code></pre>', utils.clean(contents)); |
| el.appendChild(pre); |
| pre.style.display = 'none'; |
| }; |
| |
| /** |
| * Display error `msg`. |
| * |
| * @param {string} msg |
| */ |
| function error(msg) { |
| document.body.appendChild(fragment('<div id="mocha-error">%s</div>', msg)); |
| } |
| |
| /** |
| * Return a DOM fragment from `html`. |
| * |
| * @param {string} html |
| */ |
| function fragment(html) { |
| var args = arguments; |
| var div = document.createElement('div'); |
| var i = 1; |
| |
| div.innerHTML = html.replace(/%([se])/g, function(_, type) { |
| switch (type) { |
| case 's': |
| return String(args[i++]); |
| case 'e': |
| return escape(args[i++]); |
| // no default |
| } |
| }); |
| |
| return div.firstChild; |
| } |
| |
| /** |
| * Check for suites that do not have elements |
| * with `classname`, and hide them. |
| * |
| * @param {text} classname |
| */ |
| function hideSuitesWithout(classname) { |
| var suites = document.getElementsByClassName('suite'); |
| for (var i = 0; i < suites.length; i++) { |
| var els = suites[i].getElementsByClassName(classname); |
| if (!els.length) { |
| suites[i].className += ' hidden'; |
| } |
| } |
| } |
| |
| /** |
| * Unhide .hidden suites. |
| */ |
| function unhide() { |
| var els = document.getElementsByClassName('suite hidden'); |
| for (var i = 0; i < els.length; ++i) { |
| els[i].className = els[i].className.replace('suite hidden', 'suite'); |
| } |
| } |
| |
| /** |
| * Set an element's text contents. |
| * |
| * @param {HTMLElement} el |
| * @param {string} contents |
| */ |
| function text(el, contents) { |
| if (el.textContent) { |
| el.textContent = contents; |
| } else { |
| el.innerText = contents; |
| } |
| } |
| |
| /** |
| * Listen on `event` with callback `fn`. |
| */ |
| function on(el, event, fn) { |
| if (el.addEventListener) { |
| el.addEventListener(event, fn, false); |
| } else { |
| el.attachEvent('on' + event, fn); |
| } |
| } |
| |
| HTML.browserOnly = true; |
| |
| }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{"../browser/progress":3,"../runner":34,"../utils":38,"./base":17,"escape-string-regexp":49}],21:[function(require,module,exports){ |
| 'use strict'; |
| |
| // Alias exports to a their normalized format Mocha#reporter to prevent a need |
| // for dynamic (try/catch) requires, which Browserify doesn't handle. |
| exports.Base = exports.base = require('./base'); |
| exports.Dot = exports.dot = require('./dot'); |
| exports.Doc = exports.doc = require('./doc'); |
| exports.TAP = exports.tap = require('./tap'); |
| exports.JSON = exports.json = require('./json'); |
| exports.HTML = exports.html = require('./html'); |
| exports.List = exports.list = require('./list'); |
| exports.Min = exports.min = require('./min'); |
| exports.Spec = exports.spec = require('./spec'); |
| exports.Nyan = exports.nyan = require('./nyan'); |
| exports.XUnit = exports.xunit = require('./xunit'); |
| exports.Markdown = exports.markdown = require('./markdown'); |
| exports.Progress = exports.progress = require('./progress'); |
| exports.Landing = exports.landing = require('./landing'); |
| exports.JSONStream = exports['json-stream'] = require('./json-stream'); |
| |
| },{"./base":17,"./doc":18,"./dot":19,"./html":20,"./json":23,"./json-stream":22,"./landing":24,"./list":25,"./markdown":26,"./min":27,"./nyan":28,"./progress":29,"./spec":30,"./tap":31,"./xunit":32}],22:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| /** |
| * @module JSONStream |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var constants = require('../runner').constants; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| var EVENT_RUN_BEGIN = constants.EVENT_RUN_BEGIN; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| |
| /** |
| * Expose `JSONStream`. |
| */ |
| |
| exports = module.exports = JSONStream; |
| |
| /** |
| * Constructs a new `JSONStream` reporter instance. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function JSONStream(runner, options) { |
| Base.call(this, runner, options); |
| |
| var self = this; |
| var total = runner.total; |
| |
| runner.once(EVENT_RUN_BEGIN, function() { |
| writeEvent(['start', {total: total}]); |
| }); |
| |
| runner.on(EVENT_TEST_PASS, function(test) { |
| writeEvent(['pass', clean(test)]); |
| }); |
| |
| runner.on(EVENT_TEST_FAIL, function(test, err) { |
| test = clean(test); |
| test.err = err.message; |
| test.stack = err.stack || null; |
| writeEvent(['fail', test]); |
| }); |
| |
| runner.once(EVENT_RUN_END, function() { |
| writeEvent(['end', self.stats]); |
| }); |
| } |
| |
| /** |
| * Mocha event to be written to the output stream. |
| * @typedef {Array} JSONStream~MochaEvent |
| */ |
| |
| /** |
| * Writes Mocha event to reporter output stream. |
| * |
| * @private |
| * @param {JSONStream~MochaEvent} event - Mocha event to be output. |
| */ |
| function writeEvent(event) { |
| process.stdout.write(JSON.stringify(event) + '\n'); |
| } |
| |
| /** |
| * Returns an object literal representation of `test` |
| * free of cyclic properties, etc. |
| * |
| * @private |
| * @param {Test} test - Instance used as data source. |
| * @return {Object} object containing pared-down test instance data |
| */ |
| function clean(test) { |
| return { |
| title: test.title, |
| fullTitle: test.fullTitle(), |
| duration: test.duration, |
| currentRetry: test.currentRetry() |
| }; |
| } |
| |
| JSONStream.description = 'newline delimited JSON events'; |
| |
| }).call(this,require('_process')) |
| },{"../runner":34,"./base":17,"_process":69}],23:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| /** |
| * @module JSON |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var constants = require('../runner').constants; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| var EVENT_TEST_END = constants.EVENT_TEST_END; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| var EVENT_TEST_PENDING = constants.EVENT_TEST_PENDING; |
| |
| /** |
| * Expose `JSON`. |
| */ |
| |
| exports = module.exports = JSONReporter; |
| |
| /** |
| * Constructs a new `JSON` reporter instance. |
| * |
| * @public |
| * @class JSON |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function JSONReporter(runner, options) { |
| Base.call(this, runner, options); |
| |
| var self = this; |
| var tests = []; |
| var pending = []; |
| var failures = []; |
| var passes = []; |
| |
| runner.on(EVENT_TEST_END, function(test) { |
| tests.push(test); |
| }); |
| |
| runner.on(EVENT_TEST_PASS, function(test) { |
| passes.push(test); |
| }); |
| |
| runner.on(EVENT_TEST_FAIL, function(test) { |
| failures.push(test); |
| }); |
| |
| runner.on(EVENT_TEST_PENDING, function(test) { |
| pending.push(test); |
| }); |
| |
| runner.once(EVENT_RUN_END, function() { |
| var obj = { |
| stats: self.stats, |
| tests: tests.map(clean), |
| pending: pending.map(clean), |
| failures: failures.map(clean), |
| passes: passes.map(clean) |
| }; |
| |
| runner.testResults = obj; |
| |
| process.stdout.write(JSON.stringify(obj, null, 2)); |
| }); |
| } |
| |
| /** |
| * Return a plain-object representation of `test` |
| * free of cyclic properties etc. |
| * |
| * @private |
| * @param {Object} test |
| * @return {Object} |
| */ |
| function clean(test) { |
| var err = test.err || {}; |
| if (err instanceof Error) { |
| err = errorJSON(err); |
| } |
| |
| return { |
| title: test.title, |
| fullTitle: test.fullTitle(), |
| duration: test.duration, |
| currentRetry: test.currentRetry(), |
| err: cleanCycles(err) |
| }; |
| } |
| |
| /** |
| * Replaces any circular references inside `obj` with '[object Object]' |
| * |
| * @private |
| * @param {Object} obj |
| * @return {Object} |
| */ |
| function cleanCycles(obj) { |
| var cache = []; |
| return JSON.parse( |
| JSON.stringify(obj, function(key, value) { |
| if (typeof value === 'object' && value !== null) { |
| if (cache.indexOf(value) !== -1) { |
| // Instead of going in a circle, we'll print [object Object] |
| return '' + value; |
| } |
| cache.push(value); |
| } |
| |
| return value; |
| }) |
| ); |
| } |
| |
| /** |
| * Transform an Error object into a JSON object. |
| * |
| * @private |
| * @param {Error} err |
| * @return {Object} |
| */ |
| function errorJSON(err) { |
| var res = {}; |
| Object.getOwnPropertyNames(err).forEach(function(key) { |
| res[key] = err[key]; |
| }, err); |
| return res; |
| } |
| |
| JSONReporter.description = 'single JSON object'; |
| |
| }).call(this,require('_process')) |
| },{"../runner":34,"./base":17,"_process":69}],24:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| /** |
| * @module Landing |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var inherits = require('../utils').inherits; |
| var constants = require('../runner').constants; |
| var EVENT_RUN_BEGIN = constants.EVENT_RUN_BEGIN; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| var EVENT_TEST_END = constants.EVENT_TEST_END; |
| var STATE_FAILED = require('../runnable').constants.STATE_FAILED; |
| |
| var cursor = Base.cursor; |
| var color = Base.color; |
| |
| /** |
| * Expose `Landing`. |
| */ |
| |
| exports = module.exports = Landing; |
| |
| /** |
| * Airplane color. |
| */ |
| |
| Base.colors.plane = 0; |
| |
| /** |
| * Airplane crash color. |
| */ |
| |
| Base.colors['plane crash'] = 31; |
| |
| /** |
| * Runway color. |
| */ |
| |
| Base.colors.runway = 90; |
| |
| /** |
| * Constructs a new `Landing` reporter instance. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function Landing(runner, options) { |
| Base.call(this, runner, options); |
| |
| var self = this; |
| var width = (Base.window.width * 0.75) | 0; |
| var total = runner.total; |
| var stream = process.stdout; |
| var plane = color('plane', '✈'); |
| var crashed = -1; |
| var n = 0; |
| |
| function runway() { |
| var buf = Array(width).join('-'); |
| return ' ' + color('runway', buf); |
| } |
| |
| runner.on(EVENT_RUN_BEGIN, function() { |
| stream.write('\n\n\n '); |
| cursor.hide(); |
| }); |
| |
| runner.on(EVENT_TEST_END, function(test) { |
| // check if the plane crashed |
| var col = crashed === -1 ? ((width * ++n) / total) | 0 : crashed; |
| |
| // show the crash |
| if (test.state === STATE_FAILED) { |
| plane = color('plane crash', '✈'); |
| crashed = col; |
| } |
| |
| // render landing strip |
| stream.write('\u001b[' + (width + 1) + 'D\u001b[2A'); |
| stream.write(runway()); |
| stream.write('\n '); |
| stream.write(color('runway', Array(col).join('⋅'))); |
| stream.write(plane); |
| stream.write(color('runway', Array(width - col).join('⋅') + '\n')); |
| stream.write(runway()); |
| stream.write('\u001b[0m'); |
| }); |
| |
| runner.once(EVENT_RUN_END, function() { |
| cursor.show(); |
| process.stdout.write('\n'); |
| self.epilogue(); |
| }); |
| } |
| |
| /** |
| * Inherit from `Base.prototype`. |
| */ |
| inherits(Landing, Base); |
| |
| Landing.description = 'Unicode landing strip'; |
| |
| }).call(this,require('_process')) |
| },{"../runnable":33,"../runner":34,"../utils":38,"./base":17,"_process":69}],25:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| /** |
| * @module List |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var inherits = require('../utils').inherits; |
| var constants = require('../runner').constants; |
| var EVENT_RUN_BEGIN = constants.EVENT_RUN_BEGIN; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| var EVENT_TEST_BEGIN = constants.EVENT_TEST_BEGIN; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_TEST_PENDING = constants.EVENT_TEST_PENDING; |
| var color = Base.color; |
| var cursor = Base.cursor; |
| |
| /** |
| * Expose `List`. |
| */ |
| |
| exports = module.exports = List; |
| |
| /** |
| * Constructs a new `List` reporter instance. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function List(runner, options) { |
| Base.call(this, runner, options); |
| |
| var self = this; |
| var n = 0; |
| |
| runner.on(EVENT_RUN_BEGIN, function() { |
| Base.consoleLog(); |
| }); |
| |
| runner.on(EVENT_TEST_BEGIN, function(test) { |
| process.stdout.write(color('pass', ' ' + test.fullTitle() + ': ')); |
| }); |
| |
| runner.on(EVENT_TEST_PENDING, function(test) { |
| var fmt = color('checkmark', ' -') + color('pending', ' %s'); |
| Base.consoleLog(fmt, test.fullTitle()); |
| }); |
| |
| runner.on(EVENT_TEST_PASS, function(test) { |
| var fmt = |
| color('checkmark', ' ' + Base.symbols.ok) + |
| color('pass', ' %s: ') + |
| color(test.speed, '%dms'); |
| cursor.CR(); |
| Base.consoleLog(fmt, test.fullTitle(), test.duration); |
| }); |
| |
| runner.on(EVENT_TEST_FAIL, function(test) { |
| cursor.CR(); |
| Base.consoleLog(color('fail', ' %d) %s'), ++n, test.fullTitle()); |
| }); |
| |
| runner.once(EVENT_RUN_END, self.epilogue.bind(self)); |
| } |
| |
| /** |
| * Inherit from `Base.prototype`. |
| */ |
| inherits(List, Base); |
| |
| List.description = 'like "spec" reporter but flat'; |
| |
| }).call(this,require('_process')) |
| },{"../runner":34,"../utils":38,"./base":17,"_process":69}],26:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| /** |
| * @module Markdown |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var utils = require('../utils'); |
| var constants = require('../runner').constants; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| var EVENT_SUITE_BEGIN = constants.EVENT_SUITE_BEGIN; |
| var EVENT_SUITE_END = constants.EVENT_SUITE_END; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| |
| /** |
| * Constants |
| */ |
| |
| var SUITE_PREFIX = '$'; |
| |
| /** |
| * Expose `Markdown`. |
| */ |
| |
| exports = module.exports = Markdown; |
| |
| /** |
| * Constructs a new `Markdown` reporter instance. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function Markdown(runner, options) { |
| Base.call(this, runner, options); |
| |
| var level = 0; |
| var buf = ''; |
| |
| function title(str) { |
| return Array(level).join('#') + ' ' + str; |
| } |
| |
| function mapTOC(suite, obj) { |
| var ret = obj; |
| var key = SUITE_PREFIX + suite.title; |
| |
| obj = obj[key] = obj[key] || {suite: suite}; |
| suite.suites.forEach(function(suite) { |
| mapTOC(suite, obj); |
| }); |
| |
| return ret; |
| } |
| |
| function stringifyTOC(obj, level) { |
| ++level; |
| var buf = ''; |
| var link; |
| for (var key in obj) { |
| if (key === 'suite') { |
| continue; |
| } |
| if (key !== SUITE_PREFIX) { |
| link = ' - [' + key.substring(1) + ']'; |
| link += '(#' + utils.slug(obj[key].suite.fullTitle()) + ')\n'; |
| buf += Array(level).join(' ') + link; |
| } |
| buf += stringifyTOC(obj[key], level); |
| } |
| return buf; |
| } |
| |
| function generateTOC(suite) { |
| var obj = mapTOC(suite, {}); |
| return stringifyTOC(obj, 0); |
| } |
| |
| generateTOC(runner.suite); |
| |
| runner.on(EVENT_SUITE_BEGIN, function(suite) { |
| ++level; |
| var slug = utils.slug(suite.fullTitle()); |
| buf += '<a name="' + slug + '"></a>' + '\n'; |
| buf += title(suite.title) + '\n'; |
| }); |
| |
| runner.on(EVENT_SUITE_END, function() { |
| --level; |
| }); |
| |
| runner.on(EVENT_TEST_PASS, function(test) { |
| var code = utils.clean(test.body); |
| buf += test.title + '.\n'; |
| buf += '\n```js\n'; |
| buf += code + '\n'; |
| buf += '```\n\n'; |
| }); |
| |
| runner.once(EVENT_RUN_END, function() { |
| process.stdout.write('# TOC\n'); |
| process.stdout.write(generateTOC(runner.suite)); |
| process.stdout.write(buf); |
| }); |
| } |
| |
| Markdown.description = 'GitHub Flavored Markdown'; |
| |
| }).call(this,require('_process')) |
| },{"../runner":34,"../utils":38,"./base":17,"_process":69}],27:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| /** |
| * @module Min |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var inherits = require('../utils').inherits; |
| var constants = require('../runner').constants; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| var EVENT_RUN_BEGIN = constants.EVENT_RUN_BEGIN; |
| |
| /** |
| * Expose `Min`. |
| */ |
| |
| exports = module.exports = Min; |
| |
| /** |
| * Constructs a new `Min` reporter instance. |
| * |
| * @description |
| * This minimal test reporter is best used with '--watch'. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function Min(runner, options) { |
| Base.call(this, runner, options); |
| |
| runner.on(EVENT_RUN_BEGIN, function() { |
| // clear screen |
| process.stdout.write('\u001b[2J'); |
| // set cursor position |
| process.stdout.write('\u001b[1;3H'); |
| }); |
| |
| runner.once(EVENT_RUN_END, this.epilogue.bind(this)); |
| } |
| |
| /** |
| * Inherit from `Base.prototype`. |
| */ |
| inherits(Min, Base); |
| |
| Min.description = 'essentially just a summary'; |
| |
| }).call(this,require('_process')) |
| },{"../runner":34,"../utils":38,"./base":17,"_process":69}],28:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| /** |
| * @module Nyan |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var constants = require('../runner').constants; |
| var inherits = require('../utils').inherits; |
| var EVENT_RUN_BEGIN = constants.EVENT_RUN_BEGIN; |
| var EVENT_TEST_PENDING = constants.EVENT_TEST_PENDING; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| |
| /** |
| * Expose `Dot`. |
| */ |
| |
| exports = module.exports = NyanCat; |
| |
| /** |
| * Constructs a new `Nyan` reporter instance. |
| * |
| * @public |
| * @class Nyan |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function NyanCat(runner, options) { |
| Base.call(this, runner, options); |
| |
| var self = this; |
| var width = (Base.window.width * 0.75) | 0; |
| var nyanCatWidth = (this.nyanCatWidth = 11); |
| |
| this.colorIndex = 0; |
| this.numberOfLines = 4; |
| this.rainbowColors = self.generateColors(); |
| this.scoreboardWidth = 5; |
| this.tick = 0; |
| this.trajectories = [[], [], [], []]; |
| this.trajectoryWidthMax = width - nyanCatWidth; |
| |
| runner.on(EVENT_RUN_BEGIN, function() { |
| Base.cursor.hide(); |
| self.draw(); |
| }); |
| |
| runner.on(EVENT_TEST_PENDING, function() { |
| self.draw(); |
| }); |
| |
| runner.on(EVENT_TEST_PASS, function() { |
| self.draw(); |
| }); |
| |
| runner.on(EVENT_TEST_FAIL, function() { |
| self.draw(); |
| }); |
| |
| runner.once(EVENT_RUN_END, function() { |
| Base.cursor.show(); |
| for (var i = 0; i < self.numberOfLines; i++) { |
| write('\n'); |
| } |
| self.epilogue(); |
| }); |
| } |
| |
| /** |
| * Inherit from `Base.prototype`. |
| */ |
| inherits(NyanCat, Base); |
| |
| /** |
| * Draw the nyan cat |
| * |
| * @private |
| */ |
| |
| NyanCat.prototype.draw = function() { |
| this.appendRainbow(); |
| this.drawScoreboard(); |
| this.drawRainbow(); |
| this.drawNyanCat(); |
| this.tick = !this.tick; |
| }; |
| |
| /** |
| * Draw the "scoreboard" showing the number |
| * of passes, failures and pending tests. |
| * |
| * @private |
| */ |
| |
| NyanCat.prototype.drawScoreboard = function() { |
| var stats = this.stats; |
| |
| function draw(type, n) { |
| write(' '); |
| write(Base.color(type, n)); |
| write('\n'); |
| } |
| |
| draw('green', stats.passes); |
| draw('fail', stats.failures); |
| draw('pending', stats.pending); |
| write('\n'); |
| |
| this.cursorUp(this.numberOfLines); |
| }; |
| |
| /** |
| * Append the rainbow. |
| * |
| * @private |
| */ |
| |
| NyanCat.prototype.appendRainbow = function() { |
| var segment = this.tick ? '_' : '-'; |
| var rainbowified = this.rainbowify(segment); |
| |
| for (var index = 0; index < this.numberOfLines; index++) { |
| var trajectory = this.trajectories[index]; |
| if (trajectory.length >= this.trajectoryWidthMax) { |
| trajectory.shift(); |
| } |
| trajectory.push(rainbowified); |
| } |
| }; |
| |
| /** |
| * Draw the rainbow. |
| * |
| * @private |
| */ |
| |
| NyanCat.prototype.drawRainbow = function() { |
| var self = this; |
| |
| this.trajectories.forEach(function(line) { |
| write('\u001b[' + self.scoreboardWidth + 'C'); |
| write(line.join('')); |
| write('\n'); |
| }); |
| |
| this.cursorUp(this.numberOfLines); |
| }; |
| |
| /** |
| * Draw the nyan cat |
| * |
| * @private |
| */ |
| NyanCat.prototype.drawNyanCat = function() { |
| var self = this; |
| var startWidth = this.scoreboardWidth + this.trajectories[0].length; |
| var dist = '\u001b[' + startWidth + 'C'; |
| var padding = ''; |
| |
| write(dist); |
| write('_,------,'); |
| write('\n'); |
| |
| write(dist); |
| padding = self.tick ? ' ' : ' '; |
| write('_|' + padding + '/\\_/\\ '); |
| write('\n'); |
| |
| write(dist); |
| padding = self.tick ? '_' : '__'; |
| var tail = self.tick ? '~' : '^'; |
| write(tail + '|' + padding + this.face() + ' '); |
| write('\n'); |
| |
| write(dist); |
| padding = self.tick ? ' ' : ' '; |
| write(padding + '"" "" '); |
| write('\n'); |
| |
| this.cursorUp(this.numberOfLines); |
| }; |
| |
| /** |
| * Draw nyan cat face. |
| * |
| * @private |
| * @return {string} |
| */ |
| |
| NyanCat.prototype.face = function() { |
| var stats = this.stats; |
| if (stats.failures) { |
| return '( x .x)'; |
| } else if (stats.pending) { |
| return '( o .o)'; |
| } else if (stats.passes) { |
| return '( ^ .^)'; |
| } |
| return '( - .-)'; |
| }; |
| |
| /** |
| * Move cursor up `n`. |
| * |
| * @private |
| * @param {number} n |
| */ |
| |
| NyanCat.prototype.cursorUp = function(n) { |
| write('\u001b[' + n + 'A'); |
| }; |
| |
| /** |
| * Move cursor down `n`. |
| * |
| * @private |
| * @param {number} n |
| */ |
| |
| NyanCat.prototype.cursorDown = function(n) { |
| write('\u001b[' + n + 'B'); |
| }; |
| |
| /** |
| * Generate rainbow colors. |
| * |
| * @private |
| * @return {Array} |
| */ |
| NyanCat.prototype.generateColors = function() { |
| var colors = []; |
| |
| for (var i = 0; i < 6 * 7; i++) { |
| var pi3 = Math.floor(Math.PI / 3); |
| var n = i * (1.0 / 6); |
| var r = Math.floor(3 * Math.sin(n) + 3); |
| var g = Math.floor(3 * Math.sin(n + 2 * pi3) + 3); |
| var b = Math.floor(3 * Math.sin(n + 4 * pi3) + 3); |
| colors.push(36 * r + 6 * g + b + 16); |
| } |
| |
| return colors; |
| }; |
| |
| /** |
| * Apply rainbow to the given `str`. |
| * |
| * @private |
| * @param {string} str |
| * @return {string} |
| */ |
| NyanCat.prototype.rainbowify = function(str) { |
| if (!Base.useColors) { |
| return str; |
| } |
| var color = this.rainbowColors[this.colorIndex % this.rainbowColors.length]; |
| this.colorIndex += 1; |
| return '\u001b[38;5;' + color + 'm' + str + '\u001b[0m'; |
| }; |
| |
| /** |
| * Stdout helper. |
| * |
| * @param {string} string A message to write to stdout. |
| */ |
| function write(string) { |
| process.stdout.write(string); |
| } |
| |
| NyanCat.description = '"nyan cat"'; |
| |
| }).call(this,require('_process')) |
| },{"../runner":34,"../utils":38,"./base":17,"_process":69}],29:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| /** |
| * @module Progress |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var constants = require('../runner').constants; |
| var EVENT_RUN_BEGIN = constants.EVENT_RUN_BEGIN; |
| var EVENT_TEST_END = constants.EVENT_TEST_END; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| var inherits = require('../utils').inherits; |
| var color = Base.color; |
| var cursor = Base.cursor; |
| |
| /** |
| * Expose `Progress`. |
| */ |
| |
| exports = module.exports = Progress; |
| |
| /** |
| * General progress bar color. |
| */ |
| |
| Base.colors.progress = 90; |
| |
| /** |
| * Constructs a new `Progress` reporter instance. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function Progress(runner, options) { |
| Base.call(this, runner, options); |
| |
| var self = this; |
| var width = (Base.window.width * 0.5) | 0; |
| var total = runner.total; |
| var complete = 0; |
| var lastN = -1; |
| |
| // default chars |
| options = options || {}; |
| var reporterOptions = options.reporterOptions || {}; |
| |
| options.open = reporterOptions.open || '['; |
| options.complete = reporterOptions.complete || '▬'; |
| options.incomplete = reporterOptions.incomplete || Base.symbols.dot; |
| options.close = reporterOptions.close || ']'; |
| options.verbose = reporterOptions.verbose || false; |
| |
| // tests started |
| runner.on(EVENT_RUN_BEGIN, function() { |
| process.stdout.write('\n'); |
| cursor.hide(); |
| }); |
| |
| // tests complete |
| runner.on(EVENT_TEST_END, function() { |
| complete++; |
| |
| var percent = complete / total; |
| var n = (width * percent) | 0; |
| var i = width - n; |
| |
| if (n === lastN && !options.verbose) { |
| // Don't re-render the line if it hasn't changed |
| return; |
| } |
| lastN = n; |
| |
| cursor.CR(); |
| process.stdout.write('\u001b[J'); |
| process.stdout.write(color('progress', ' ' + options.open)); |
| process.stdout.write(Array(n).join(options.complete)); |
| process.stdout.write(Array(i).join(options.incomplete)); |
| process.stdout.write(color('progress', options.close)); |
| if (options.verbose) { |
| process.stdout.write(color('progress', ' ' + complete + ' of ' + total)); |
| } |
| }); |
| |
| // tests are complete, output some stats |
| // and the failures if any |
| runner.once(EVENT_RUN_END, function() { |
| cursor.show(); |
| process.stdout.write('\n'); |
| self.epilogue(); |
| }); |
| } |
| |
| /** |
| * Inherit from `Base.prototype`. |
| */ |
| inherits(Progress, Base); |
| |
| Progress.description = 'a progress bar'; |
| |
| }).call(this,require('_process')) |
| },{"../runner":34,"../utils":38,"./base":17,"_process":69}],30:[function(require,module,exports){ |
| 'use strict'; |
| /** |
| * @module Spec |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var constants = require('../runner').constants; |
| var EVENT_RUN_BEGIN = constants.EVENT_RUN_BEGIN; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| var EVENT_SUITE_BEGIN = constants.EVENT_SUITE_BEGIN; |
| var EVENT_SUITE_END = constants.EVENT_SUITE_END; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_TEST_PENDING = constants.EVENT_TEST_PENDING; |
| var inherits = require('../utils').inherits; |
| var color = Base.color; |
| |
| /** |
| * Expose `Spec`. |
| */ |
| |
| exports = module.exports = Spec; |
| |
| /** |
| * Constructs a new `Spec` reporter instance. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function Spec(runner, options) { |
| Base.call(this, runner, options); |
| |
| var self = this; |
| var indents = 0; |
| var n = 0; |
| |
| function indent() { |
| return Array(indents).join(' '); |
| } |
| |
| runner.on(EVENT_RUN_BEGIN, function() { |
| Base.consoleLog(); |
| }); |
| |
| runner.on(EVENT_SUITE_BEGIN, function(suite) { |
| ++indents; |
| Base.consoleLog(color('suite', '%s%s'), indent(), suite.title); |
| }); |
| |
| runner.on(EVENT_SUITE_END, function() { |
| --indents; |
| if (indents === 1) { |
| Base.consoleLog(); |
| } |
| }); |
| |
| runner.on(EVENT_TEST_PENDING, function(test) { |
| var fmt = indent() + color('pending', ' - %s'); |
| Base.consoleLog(fmt, test.title); |
| }); |
| |
| runner.on(EVENT_TEST_PASS, function(test) { |
| var fmt; |
| if (test.speed === 'fast') { |
| fmt = |
| indent() + |
| color('checkmark', ' ' + Base.symbols.ok) + |
| color('pass', ' %s'); |
| Base.consoleLog(fmt, test.title); |
| } else { |
| fmt = |
| indent() + |
| color('checkmark', ' ' + Base.symbols.ok) + |
| color('pass', ' %s') + |
| color(test.speed, ' (%dms)'); |
| Base.consoleLog(fmt, test.title, test.duration); |
| } |
| }); |
| |
| runner.on(EVENT_TEST_FAIL, function(test) { |
| Base.consoleLog(indent() + color('fail', ' %d) %s'), ++n, test.title); |
| }); |
| |
| runner.once(EVENT_RUN_END, self.epilogue.bind(self)); |
| } |
| |
| /** |
| * Inherit from `Base.prototype`. |
| */ |
| inherits(Spec, Base); |
| |
| Spec.description = 'hierarchical & verbose [default]'; |
| |
| },{"../runner":34,"../utils":38,"./base":17}],31:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| /** |
| * @module TAP |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var util = require('util'); |
| var Base = require('./base'); |
| var constants = require('../runner').constants; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| var EVENT_RUN_BEGIN = constants.EVENT_RUN_BEGIN; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| var EVENT_TEST_PENDING = constants.EVENT_TEST_PENDING; |
| var EVENT_TEST_END = constants.EVENT_TEST_END; |
| var inherits = require('../utils').inherits; |
| var sprintf = util.format; |
| |
| /** |
| * Expose `TAP`. |
| */ |
| |
| exports = module.exports = TAP; |
| |
| /** |
| * Constructs a new `TAP` reporter instance. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function TAP(runner, options) { |
| Base.call(this, runner, options); |
| |
| var self = this; |
| var n = 1; |
| |
| var tapVersion = '12'; |
| if (options && options.reporterOptions) { |
| if (options.reporterOptions.tapVersion) { |
| tapVersion = options.reporterOptions.tapVersion.toString(); |
| } |
| } |
| |
| this._producer = createProducer(tapVersion); |
| |
| runner.once(EVENT_RUN_BEGIN, function() { |
| var ntests = runner.grepTotal(runner.suite); |
| self._producer.writeVersion(); |
| self._producer.writePlan(ntests); |
| }); |
| |
| runner.on(EVENT_TEST_END, function() { |
| ++n; |
| }); |
| |
| runner.on(EVENT_TEST_PENDING, function(test) { |
| self._producer.writePending(n, test); |
| }); |
| |
| runner.on(EVENT_TEST_PASS, function(test) { |
| self._producer.writePass(n, test); |
| }); |
| |
| runner.on(EVENT_TEST_FAIL, function(test, err) { |
| self._producer.writeFail(n, test, err); |
| }); |
| |
| runner.once(EVENT_RUN_END, function() { |
| self._producer.writeEpilogue(runner.stats); |
| }); |
| } |
| |
| /** |
| * Inherit from `Base.prototype`. |
| */ |
| inherits(TAP, Base); |
| |
| /** |
| * Returns a TAP-safe title of `test`. |
| * |
| * @private |
| * @param {Test} test - Test instance. |
| * @return {String} title with any hash character removed |
| */ |
| function title(test) { |
| return test.fullTitle().replace(/#/g, ''); |
| } |
| |
| /** |
| * Writes newline-terminated formatted string to reporter output stream. |
| * |
| * @private |
| * @param {string} format - `printf`-like format string |
| * @param {...*} [varArgs] - Format string arguments |
| */ |
| function println(format, varArgs) { |
| var vargs = Array.from(arguments); |
| vargs[0] += '\n'; |
| process.stdout.write(sprintf.apply(null, vargs)); |
| } |
| |
| /** |
| * Returns a `tapVersion`-appropriate TAP producer instance, if possible. |
| * |
| * @private |
| * @param {string} tapVersion - Version of TAP specification to produce. |
| * @returns {TAPProducer} specification-appropriate instance |
| * @throws {Error} if specification version has no associated producer. |
| */ |
| function createProducer(tapVersion) { |
| var producers = { |
| '12': new TAP12Producer(), |
| '13': new TAP13Producer() |
| }; |
| var producer = producers[tapVersion]; |
| |
| if (!producer) { |
| throw new Error( |
| 'invalid or unsupported TAP version: ' + JSON.stringify(tapVersion) |
| ); |
| } |
| |
| return producer; |
| } |
| |
| /** |
| * @summary |
| * Constructs a new TAPProducer. |
| * |
| * @description |
| * <em>Only</em> to be used as an abstract base class. |
| * |
| * @private |
| * @constructor |
| */ |
| function TAPProducer() {} |
| |
| /** |
| * Writes the TAP version to reporter output stream. |
| * |
| * @abstract |
| */ |
| TAPProducer.prototype.writeVersion = function() {}; |
| |
| /** |
| * Writes the plan to reporter output stream. |
| * |
| * @abstract |
| * @param {number} ntests - Number of tests that are planned to run. |
| */ |
| TAPProducer.prototype.writePlan = function(ntests) { |
| println('%d..%d', 1, ntests); |
| }; |
| |
| /** |
| * Writes that test passed to reporter output stream. |
| * |
| * @abstract |
| * @param {number} n - Index of test that passed. |
| * @param {Test} test - Instance containing test information. |
| */ |
| TAPProducer.prototype.writePass = function(n, test) { |
| println('ok %d %s', n, title(test)); |
| }; |
| |
| /** |
| * Writes that test was skipped to reporter output stream. |
| * |
| * @abstract |
| * @param {number} n - Index of test that was skipped. |
| * @param {Test} test - Instance containing test information. |
| */ |
| TAPProducer.prototype.writePending = function(n, test) { |
| println('ok %d %s # SKIP -', n, title(test)); |
| }; |
| |
| /** |
| * Writes that test failed to reporter output stream. |
| * |
| * @abstract |
| * @param {number} n - Index of test that failed. |
| * @param {Test} test - Instance containing test information. |
| * @param {Error} err - Reason the test failed. |
| */ |
| TAPProducer.prototype.writeFail = function(n, test, err) { |
| println('not ok %d %s', n, title(test)); |
| }; |
| |
| /** |
| * Writes the summary epilogue to reporter output stream. |
| * |
| * @abstract |
| * @param {Object} stats - Object containing run statistics. |
| */ |
| TAPProducer.prototype.writeEpilogue = function(stats) { |
| // :TBD: Why is this not counting pending tests? |
| println('# tests ' + (stats.passes + stats.failures)); |
| println('# pass ' + stats.passes); |
| // :TBD: Why are we not showing pending results? |
| println('# fail ' + stats.failures); |
| }; |
| |
| /** |
| * @summary |
| * Constructs a new TAP12Producer. |
| * |
| * @description |
| * Produces output conforming to the TAP12 specification. |
| * |
| * @private |
| * @constructor |
| * @extends TAPProducer |
| * @see {@link https://testanything.org/tap-specification.html|Specification} |
| */ |
| function TAP12Producer() { |
| /** |
| * Writes that test failed to reporter output stream, with error formatting. |
| * @override |
| */ |
| this.writeFail = function(n, test, err) { |
| TAPProducer.prototype.writeFail.call(this, n, test, err); |
| if (err.message) { |
| println(err.message.replace(/^/gm, ' ')); |
| } |
| if (err.stack) { |
| println(err.stack.replace(/^/gm, ' ')); |
| } |
| }; |
| } |
| |
| /** |
| * Inherit from `TAPProducer.prototype`. |
| */ |
| inherits(TAP12Producer, TAPProducer); |
| |
| /** |
| * @summary |
| * Constructs a new TAP13Producer. |
| * |
| * @description |
| * Produces output conforming to the TAP13 specification. |
| * |
| * @private |
| * @constructor |
| * @extends TAPProducer |
| * @see {@link https://testanything.org/tap-version-13-specification.html|Specification} |
| */ |
| function TAP13Producer() { |
| /** |
| * Writes the TAP version to reporter output stream. |
| * @override |
| */ |
| this.writeVersion = function() { |
| println('TAP version 13'); |
| }; |
| |
| /** |
| * Writes that test failed to reporter output stream, with error formatting. |
| * @override |
| */ |
| this.writeFail = function(n, test, err) { |
| TAPProducer.prototype.writeFail.call(this, n, test, err); |
| var emitYamlBlock = err.message != null || err.stack != null; |
| if (emitYamlBlock) { |
| println(indent(1) + '---'); |
| if (err.message) { |
| println(indent(2) + 'message: |-'); |
| println(err.message.replace(/^/gm, indent(3))); |
| } |
| if (err.stack) { |
| println(indent(2) + 'stack: |-'); |
| println(err.stack.replace(/^/gm, indent(3))); |
| } |
| println(indent(1) + '...'); |
| } |
| }; |
| |
| function indent(level) { |
| return Array(level + 1).join(' '); |
| } |
| } |
| |
| /** |
| * Inherit from `TAPProducer.prototype`. |
| */ |
| inherits(TAP13Producer, TAPProducer); |
| |
| TAP.description = 'TAP-compatible output'; |
| |
| }).call(this,require('_process')) |
| },{"../runner":34,"../utils":38,"./base":17,"_process":69,"util":89}],32:[function(require,module,exports){ |
| (function (process,global){ |
| 'use strict'; |
| /** |
| * @module XUnit |
| */ |
| /** |
| * Module dependencies. |
| */ |
| |
| var Base = require('./base'); |
| var utils = require('../utils'); |
| var fs = require('fs'); |
| var mkdirp = require('mkdirp'); |
| var path = require('path'); |
| var errors = require('../errors'); |
| var createUnsupportedError = errors.createUnsupportedError; |
| var constants = require('../runner').constants; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| var EVENT_TEST_PENDING = constants.EVENT_TEST_PENDING; |
| var STATE_FAILED = require('../runnable').constants.STATE_FAILED; |
| var inherits = utils.inherits; |
| var escape = utils.escape; |
| |
| /** |
| * Save timer references to avoid Sinon interfering (see GH-237). |
| */ |
| var Date = global.Date; |
| |
| /** |
| * Expose `XUnit`. |
| */ |
| |
| exports = module.exports = XUnit; |
| |
| /** |
| * Constructs a new `XUnit` reporter instance. |
| * |
| * @public |
| * @class |
| * @memberof Mocha.reporters |
| * @extends Mocha.reporters.Base |
| * @param {Runner} runner - Instance triggers reporter actions. |
| * @param {Object} [options] - runner options |
| */ |
| function XUnit(runner, options) { |
| Base.call(this, runner, options); |
| |
| var stats = this.stats; |
| var tests = []; |
| var self = this; |
| |
| // the name of the test suite, as it will appear in the resulting XML file |
| var suiteName; |
| |
| // the default name of the test suite if none is provided |
| var DEFAULT_SUITE_NAME = 'Mocha Tests'; |
| |
| if (options && options.reporterOptions) { |
| if (options.reporterOptions.output) { |
| if (!fs.createWriteStream) { |
| throw createUnsupportedError('file output not supported in browser'); |
| } |
| |
| mkdirp.sync(path.dirname(options.reporterOptions.output)); |
| self.fileStream = fs.createWriteStream(options.reporterOptions.output); |
| } |
| |
| // get the suite name from the reporter options (if provided) |
| suiteName = options.reporterOptions.suiteName; |
| } |
| |
| // fall back to the default suite name |
| suiteName = suiteName || DEFAULT_SUITE_NAME; |
| |
| runner.on(EVENT_TEST_PENDING, function(test) { |
| tests.push(test); |
| }); |
| |
| runner.on(EVENT_TEST_PASS, function(test) { |
| tests.push(test); |
| }); |
| |
| runner.on(EVENT_TEST_FAIL, function(test) { |
| tests.push(test); |
| }); |
| |
| runner.once(EVENT_RUN_END, function() { |
| self.write( |
| tag( |
| 'testsuite', |
| { |
| name: suiteName, |
| tests: stats.tests, |
| failures: 0, |
| errors: stats.failures, |
| skipped: stats.tests - stats.failures - stats.passes, |
| timestamp: new Date().toUTCString(), |
| time: stats.duration / 1000 || 0 |
| }, |
| false |
| ) |
| ); |
| |
| tests.forEach(function(t) { |
| self.test(t); |
| }); |
| |
| self.write('</testsuite>'); |
| }); |
| } |
| |
| /** |
| * Inherit from `Base.prototype`. |
| */ |
| inherits(XUnit, Base); |
| |
| /** |
| * Override done to close the stream (if it's a file). |
| * |
| * @param failures |
| * @param {Function} fn |
| */ |
| XUnit.prototype.done = function(failures, fn) { |
| if (this.fileStream) { |
| this.fileStream.end(function() { |
| fn(failures); |
| }); |
| } else { |
| fn(failures); |
| } |
| }; |
| |
| /** |
| * Write out the given line. |
| * |
| * @param {string} line |
| */ |
| XUnit.prototype.write = function(line) { |
| if (this.fileStream) { |
| this.fileStream.write(line + '\n'); |
| } else if (typeof process === 'object' && process.stdout) { |
| process.stdout.write(line + '\n'); |
| } else { |
| Base.consoleLog(line); |
| } |
| }; |
| |
| /** |
| * Output tag for the given `test.` |
| * |
| * @param {Test} test |
| */ |
| XUnit.prototype.test = function(test) { |
| Base.useColors = false; |
| |
| var attrs = { |
| classname: test.parent.fullTitle(), |
| name: test.title, |
| time: test.duration / 1000 || 0 |
| }; |
| |
| if (test.state === STATE_FAILED) { |
| var err = test.err; |
| var diff = |
| Base.hideDiff || !err.actual || !err.expected |
| ? '' |
| : '\n' + Base.generateDiff(err.actual, err.expected); |
| this.write( |
| tag( |
| 'testcase', |
| attrs, |
| false, |
| tag( |
| 'failure', |
| {}, |
| false, |
| escape(err.message) + escape(diff) + '\n' + escape(err.stack) |
| ) |
| ) |
| ); |
| } else if (test.isPending()) { |
| this.write(tag('testcase', attrs, false, tag('skipped', {}, true))); |
| } else { |
| this.write(tag('testcase', attrs, true)); |
| } |
| }; |
| |
| /** |
| * HTML tag helper. |
| * |
| * @param name |
| * @param attrs |
| * @param close |
| * @param content |
| * @return {string} |
| */ |
| function tag(name, attrs, close, content) { |
| var end = close ? '/>' : '>'; |
| var pairs = []; |
| var tag; |
| |
| for (var key in attrs) { |
| if (Object.prototype.hasOwnProperty.call(attrs, key)) { |
| pairs.push(key + '="' + escape(attrs[key]) + '"'); |
| } |
| } |
| |
| tag = '<' + name + (pairs.length ? ' ' + pairs.join(' ') : '') + end; |
| if (content) { |
| tag += content + '</' + name + end; |
| } |
| return tag; |
| } |
| |
| XUnit.description = 'XUnit-compatible XML output'; |
| |
| }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{"../errors":6,"../runnable":33,"../runner":34,"../utils":38,"./base":17,"_process":69,"fs":42,"mkdirp":59,"path":42}],33:[function(require,module,exports){ |
| (function (global){ |
| 'use strict'; |
| |
| var EventEmitter = require('events').EventEmitter; |
| var Pending = require('./pending'); |
| var debug = require('debug')('mocha:runnable'); |
| var milliseconds = require('ms'); |
| var utils = require('./utils'); |
| var createInvalidExceptionError = require('./errors') |
| .createInvalidExceptionError; |
| |
| /** |
| * Save timer references to avoid Sinon interfering (see GH-237). |
| */ |
| var Date = global.Date; |
| var setTimeout = global.setTimeout; |
| var clearTimeout = global.clearTimeout; |
| var toString = Object.prototype.toString; |
| |
| module.exports = Runnable; |
| |
| /** |
| * Initialize a new `Runnable` with the given `title` and callback `fn`. |
| * |
| * @class |
| * @extends external:EventEmitter |
| * @public |
| * @param {String} title |
| * @param {Function} fn |
| */ |
| function Runnable(title, fn) { |
| this.title = title; |
| this.fn = fn; |
| this.body = (fn || '').toString(); |
| this.async = fn && fn.length; |
| this.sync = !this.async; |
| this._timeout = 2000; |
| this._slow = 75; |
| this._enableTimeouts = true; |
| this.timedOut = false; |
| this._retries = -1; |
| this._currentRetry = 0; |
| this.pending = false; |
| } |
| |
| /** |
| * Inherit from `EventEmitter.prototype`. |
| */ |
| utils.inherits(Runnable, EventEmitter); |
| |
| /** |
| * Get current timeout value in msecs. |
| * |
| * @private |
| * @returns {number} current timeout threshold value |
| */ |
| /** |
| * @summary |
| * Set timeout threshold value (msecs). |
| * |
| * @description |
| * A string argument can use shorthand (e.g., "2s") and will be converted. |
| * The value will be clamped to range [<code>0</code>, <code>2^<sup>31</sup>-1</code>]. |
| * If clamped value matches either range endpoint, timeouts will be disabled. |
| * |
| * @private |
| * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setTimeout#Maximum_delay_value} |
| * @param {number|string} ms - Timeout threshold value. |
| * @returns {Runnable} this |
| * @chainable |
| */ |
| Runnable.prototype.timeout = function(ms) { |
| if (!arguments.length) { |
| return this._timeout; |
| } |
| if (typeof ms === 'string') { |
| ms = milliseconds(ms); |
| } |
| |
| // Clamp to range |
| var INT_MAX = Math.pow(2, 31) - 1; |
| var range = [0, INT_MAX]; |
| ms = utils.clamp(ms, range); |
| |
| // see #1652 for reasoning |
| if (ms === range[0] || ms === range[1]) { |
| this._enableTimeouts = false; |
| } |
| debug('timeout %d', ms); |
| this._timeout = ms; |
| if (this.timer) { |
| this.resetTimeout(); |
| } |
| return this; |
| }; |
| |
| /** |
| * Set or get slow `ms`. |
| * |
| * @private |
| * @param {number|string} ms |
| * @return {Runnable|number} ms or Runnable instance. |
| */ |
| Runnable.prototype.slow = function(ms) { |
| if (!arguments.length || typeof ms === 'undefined') { |
| return this._slow; |
| } |
| if (typeof ms === 'string') { |
| ms = milliseconds(ms); |
| } |
| debug('slow %d', ms); |
| this._slow = ms; |
| return this; |
| }; |
| |
| /** |
| * Set and get whether timeout is `enabled`. |
| * |
| * @private |
| * @param {boolean} enabled |
| * @return {Runnable|boolean} enabled or Runnable instance. |
| */ |
| Runnable.prototype.enableTimeouts = function(enabled) { |
| if (!arguments.length) { |
| return this._enableTimeouts; |
| } |
| debug('enableTimeouts %s', enabled); |
| this._enableTimeouts = enabled; |
| return this; |
| }; |
| |
| /** |
| * Halt and mark as pending. |
| * |
| * @memberof Mocha.Runnable |
| * @public |
| */ |
| Runnable.prototype.skip = function() { |
| throw new Pending('sync skip'); |
| }; |
| |
| /** |
| * Check if this runnable or its parent suite is marked as pending. |
| * |
| * @private |
| */ |
| Runnable.prototype.isPending = function() { |
| return this.pending || (this.parent && this.parent.isPending()); |
| }; |
| |
| /** |
| * Return `true` if this Runnable has failed. |
| * @return {boolean} |
| * @private |
| */ |
| Runnable.prototype.isFailed = function() { |
| return !this.isPending() && this.state === constants.STATE_FAILED; |
| }; |
| |
| /** |
| * Return `true` if this Runnable has passed. |
| * @return {boolean} |
| * @private |
| */ |
| Runnable.prototype.isPassed = function() { |
| return !this.isPending() && this.state === constants.STATE_PASSED; |
| }; |
| |
| /** |
| * Set or get number of retries. |
| * |
| * @private |
| */ |
| Runnable.prototype.retries = function(n) { |
| if (!arguments.length) { |
| return this._retries; |
| } |
| this._retries = n; |
| }; |
| |
| /** |
| * Set or get current retry |
| * |
| * @private |
| */ |
| Runnable.prototype.currentRetry = function(n) { |
| if (!arguments.length) { |
| return this._currentRetry; |
| } |
| this._currentRetry = n; |
| }; |
| |
| /** |
| * Return the full title generated by recursively concatenating the parent's |
| * full title. |
| * |
| * @memberof Mocha.Runnable |
| * @public |
| * @return {string} |
| */ |
| Runnable.prototype.fullTitle = function() { |
| return this.titlePath().join(' '); |
| }; |
| |
| /** |
| * Return the title path generated by concatenating the parent's title path with the title. |
| * |
| * @memberof Mocha.Runnable |
| * @public |
| * @return {string} |
| */ |
| Runnable.prototype.titlePath = function() { |
| return this.parent.titlePath().concat([this.title]); |
| }; |
| |
| /** |
| * Clear the timeout. |
| * |
| * @private |
| */ |
| Runnable.prototype.clearTimeout = function() { |
| clearTimeout(this.timer); |
| }; |
| |
| /** |
| * Inspect the runnable void of private properties. |
| * |
| * @private |
| * @return {string} |
| */ |
| Runnable.prototype.inspect = function() { |
| return JSON.stringify( |
| this, |
| function(key, val) { |
| if (key[0] === '_') { |
| return; |
| } |
| if (key === 'parent') { |
| return '#<Suite>'; |
| } |
| if (key === 'ctx') { |
| return '#<Context>'; |
| } |
| return val; |
| }, |
| 2 |
| ); |
| }; |
| |
| /** |
| * Reset the timeout. |
| * |
| * @private |
| */ |
| Runnable.prototype.resetTimeout = function() { |
| var self = this; |
| var ms = this.timeout() || 1e9; |
| |
| if (!this._enableTimeouts) { |
| return; |
| } |
| this.clearTimeout(); |
| this.timer = setTimeout(function() { |
| if (!self._enableTimeouts) { |
| return; |
| } |
| self.callback(self._timeoutError(ms)); |
| self.timedOut = true; |
| }, ms); |
| }; |
| |
| /** |
| * Set or get a list of whitelisted globals for this test run. |
| * |
| * @private |
| * @param {string[]} globals |
| */ |
| Runnable.prototype.globals = function(globals) { |
| if (!arguments.length) { |
| return this._allowedGlobals; |
| } |
| this._allowedGlobals = globals; |
| }; |
| |
| /** |
| * Run the test and invoke `fn(err)`. |
| * |
| * @param {Function} fn |
| * @private |
| */ |
| Runnable.prototype.run = function(fn) { |
| var self = this; |
| var start = new Date(); |
| var ctx = this.ctx; |
| var finished; |
| var emitted; |
| |
| // Sometimes the ctx exists, but it is not runnable |
| if (ctx && ctx.runnable) { |
| ctx.runnable(this); |
| } |
| |
| // called multiple times |
| function multiple(err) { |
| if (emitted) { |
| return; |
| } |
| emitted = true; |
| var msg = 'done() called multiple times'; |
| if (err && err.message) { |
| err.message += " (and Mocha's " + msg + ')'; |
| self.emit('error', err); |
| } else { |
| self.emit('error', new Error(msg)); |
| } |
| } |
| |
| // finished |
| function done(err) { |
| var ms = self.timeout(); |
| if (self.timedOut) { |
| return; |
| } |
| |
| if (finished) { |
| return multiple(err); |
| } |
| |
| self.clearTimeout(); |
| self.duration = new Date() - start; |
| finished = true; |
| if (!err && self.duration > ms && self._enableTimeouts) { |
| err = self._timeoutError(ms); |
| } |
| fn(err); |
| } |
| |
| // for .resetTimeout() |
| this.callback = done; |
| |
| // explicit async with `done` argument |
| if (this.async) { |
| this.resetTimeout(); |
| |
| // allows skip() to be used in an explicit async context |
| this.skip = function asyncSkip() { |
| done(new Pending('async skip call')); |
| // halt execution. the Runnable will be marked pending |
| // by the previous call, and the uncaught handler will ignore |
| // the failure. |
| throw new Pending('async skip; aborting execution'); |
| }; |
| |
| if (this.allowUncaught) { |
| return callFnAsync(this.fn); |
| } |
| try { |
| callFnAsync(this.fn); |
| } catch (err) { |
| emitted = true; |
| done(Runnable.toValueOrError(err)); |
| } |
| return; |
| } |
| |
| if (this.allowUncaught) { |
| if (this.isPending()) { |
| done(); |
| } else { |
| callFn(this.fn); |
| } |
| return; |
| } |
| |
| // sync or promise-returning |
| try { |
| if (this.isPending()) { |
| done(); |
| } else { |
| callFn(this.fn); |
| } |
| } catch (err) { |
| emitted = true; |
| done(Runnable.toValueOrError(err)); |
| } |
| |
| function callFn(fn) { |
| var result = fn.call(ctx); |
| if (result && typeof result.then === 'function') { |
| self.resetTimeout(); |
| result.then( |
| function() { |
| done(); |
| // Return null so libraries like bluebird do not warn about |
| // subsequently constructed Promises. |
| return null; |
| }, |
| function(reason) { |
| done(reason || new Error('Promise rejected with no or falsy reason')); |
| } |
| ); |
| } else { |
| if (self.asyncOnly) { |
| return done( |
| new Error( |
| '--async-only option in use without declaring `done()` or returning a promise' |
| ) |
| ); |
| } |
| |
| done(); |
| } |
| } |
| |
| function callFnAsync(fn) { |
| var result = fn.call(ctx, function(err) { |
| if (err instanceof Error || toString.call(err) === '[object Error]') { |
| return done(err); |
| } |
| if (err) { |
| if (Object.prototype.toString.call(err) === '[object Object]') { |
| return done( |
| new Error('done() invoked with non-Error: ' + JSON.stringify(err)) |
| ); |
| } |
| return done(new Error('done() invoked with non-Error: ' + err)); |
| } |
| if (result && utils.isPromise(result)) { |
| return done( |
| new Error( |
| 'Resolution method is overspecified. Specify a callback *or* return a Promise; not both.' |
| ) |
| ); |
| } |
| |
| done(); |
| }); |
| } |
| }; |
| |
| /** |
| * Instantiates a "timeout" error |
| * |
| * @param {number} ms - Timeout (in milliseconds) |
| * @returns {Error} a "timeout" error |
| * @private |
| */ |
| Runnable.prototype._timeoutError = function(ms) { |
| var msg = |
| 'Timeout of ' + |
| ms + |
| 'ms exceeded. For async tests and hooks, ensure "done()" is called; if returning a Promise, ensure it resolves.'; |
| if (this.file) { |
| msg += ' (' + this.file + ')'; |
| } |
| return new Error(msg); |
| }; |
| |
| var constants = utils.defineConstants( |
| /** |
| * {@link Runnable}-related constants. |
| * @public |
| * @memberof Runnable |
| * @readonly |
| * @static |
| * @alias constants |
| * @enum {string} |
| */ |
| { |
| /** |
| * Value of `state` prop when a `Runnable` has failed |
| */ |
| STATE_FAILED: 'failed', |
| /** |
| * Value of `state` prop when a `Runnable` has passed |
| */ |
| STATE_PASSED: 'passed' |
| } |
| ); |
| |
| /** |
| * Given `value`, return identity if truthy, otherwise create an "invalid exception" error and return that. |
| * @param {*} [value] - Value to return, if present |
| * @returns {*|Error} `value`, otherwise an `Error` |
| * @private |
| */ |
| Runnable.toValueOrError = function(value) { |
| return ( |
| value || |
| createInvalidExceptionError( |
| 'Runnable failed with falsy or undefined exception. Please throw an Error instead.', |
| value |
| ) |
| ); |
| }; |
| |
| Runnable.constants = constants; |
| |
| }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{"./errors":6,"./pending":16,"./utils":38,"debug":45,"events":50,"ms":60}],34:[function(require,module,exports){ |
| (function (process,global){ |
| 'use strict'; |
| |
| /** |
| * Module dependencies. |
| */ |
| var util = require('util'); |
| var EventEmitter = require('events').EventEmitter; |
| var Pending = require('./pending'); |
| var utils = require('./utils'); |
| var inherits = utils.inherits; |
| var debug = require('debug')('mocha:runner'); |
| var Runnable = require('./runnable'); |
| var Suite = require('./suite'); |
| var HOOK_TYPE_BEFORE_EACH = Suite.constants.HOOK_TYPE_BEFORE_EACH; |
| var HOOK_TYPE_AFTER_EACH = Suite.constants.HOOK_TYPE_AFTER_EACH; |
| var HOOK_TYPE_AFTER_ALL = Suite.constants.HOOK_TYPE_AFTER_ALL; |
| var HOOK_TYPE_BEFORE_ALL = Suite.constants.HOOK_TYPE_BEFORE_ALL; |
| var EVENT_ROOT_SUITE_RUN = Suite.constants.EVENT_ROOT_SUITE_RUN; |
| var STATE_FAILED = Runnable.constants.STATE_FAILED; |
| var STATE_PASSED = Runnable.constants.STATE_PASSED; |
| var dQuote = utils.dQuote; |
| var ngettext = utils.ngettext; |
| var sQuote = utils.sQuote; |
| var stackFilter = utils.stackTraceFilter(); |
| var stringify = utils.stringify; |
| var type = utils.type; |
| var createInvalidExceptionError = require('./errors') |
| .createInvalidExceptionError; |
| |
| /** |
| * Non-enumerable globals. |
| * @readonly |
| */ |
| var globals = [ |
| 'setTimeout', |
| 'clearTimeout', |
| 'setInterval', |
| 'clearInterval', |
| 'XMLHttpRequest', |
| 'Date', |
| 'setImmediate', |
| 'clearImmediate' |
| ]; |
| |
| var constants = utils.defineConstants( |
| /** |
| * {@link Runner}-related constants. |
| * @public |
| * @memberof Runner |
| * @readonly |
| * @alias constants |
| * @static |
| * @enum {string} |
| */ |
| { |
| /** |
| * Emitted when {@link Hook} execution begins |
| */ |
| EVENT_HOOK_BEGIN: 'hook', |
| /** |
| * Emitted when {@link Hook} execution ends |
| */ |
| EVENT_HOOK_END: 'hook end', |
| /** |
| * Emitted when Root {@link Suite} execution begins (all files have been parsed and hooks/tests are ready for execution) |
| */ |
| EVENT_RUN_BEGIN: 'start', |
| /** |
| * Emitted when Root {@link Suite} execution has been delayed via `delay` option |
| */ |
| EVENT_DELAY_BEGIN: 'waiting', |
| /** |
| * Emitted when delayed Root {@link Suite} execution is triggered by user via `global.run()` |
| */ |
| EVENT_DELAY_END: 'ready', |
| /** |
| * Emitted when Root {@link Suite} execution ends |
| */ |
| EVENT_RUN_END: 'end', |
| /** |
| * Emitted when {@link Suite} execution begins |
| */ |
| EVENT_SUITE_BEGIN: 'suite', |
| /** |
| * Emitted when {@link Suite} execution ends |
| */ |
| EVENT_SUITE_END: 'suite end', |
| /** |
| * Emitted when {@link Test} execution begins |
| */ |
| EVENT_TEST_BEGIN: 'test', |
| /** |
| * Emitted when {@link Test} execution ends |
| */ |
| EVENT_TEST_END: 'test end', |
| /** |
| * Emitted when {@link Test} execution fails |
| */ |
| EVENT_TEST_FAIL: 'fail', |
| /** |
| * Emitted when {@link Test} execution succeeds |
| */ |
| EVENT_TEST_PASS: 'pass', |
| /** |
| * Emitted when {@link Test} becomes pending |
| */ |
| EVENT_TEST_PENDING: 'pending', |
| /** |
| * Emitted when {@link Test} execution has failed, but will retry |
| */ |
| EVENT_TEST_RETRY: 'retry' |
| } |
| ); |
| |
| module.exports = Runner; |
| |
| /** |
| * Initialize a `Runner` at the Root {@link Suite}, which represents a hierarchy of {@link Suite|Suites} and {@link Test|Tests}. |
| * |
| * @extends external:EventEmitter |
| * @public |
| * @class |
| * @param {Suite} suite Root suite |
| * @param {boolean} [delay] Whether or not to delay execution of root suite |
| * until ready. |
| */ |
| function Runner(suite, delay) { |
| var self = this; |
| this._globals = []; |
| this._abort = false; |
| this._delay = delay; |
| this.suite = suite; |
| this.started = false; |
| this.total = suite.total(); |
| this.failures = 0; |
| this.on(constants.EVENT_TEST_END, function(test) { |
| self.checkGlobals(test); |
| }); |
| this.on(constants.EVENT_HOOK_END, function(hook) { |
| self.checkGlobals(hook); |
| }); |
| this._defaultGrep = /.*/; |
| this.grep(this._defaultGrep); |
| this.globals(this.globalProps().concat(extraGlobals())); |
| } |
| |
| /** |
| * Wrapper for setImmediate, process.nextTick, or browser polyfill. |
| * |
| * @param {Function} fn |
| * @private |
| */ |
| Runner.immediately = global.setImmediate || process.nextTick; |
| |
| /** |
| * Inherit from `EventEmitter.prototype`. |
| */ |
| inherits(Runner, EventEmitter); |
| |
| /** |
| * Run tests with full titles matching `re`. Updates runner.total |
| * with number of tests matched. |
| * |
| * @public |
| * @memberof Runner |
| * @param {RegExp} re |
| * @param {boolean} invert |
| * @return {Runner} Runner instance. |
| */ |
| Runner.prototype.grep = function(re, invert) { |
| debug('grep %s', re); |
| this._grep = re; |
| this._invert = invert; |
| this.total = this.grepTotal(this.suite); |
| return this; |
| }; |
| |
| /** |
| * Returns the number of tests matching the grep search for the |
| * given suite. |
| * |
| * @memberof Runner |
| * @public |
| * @param {Suite} suite |
| * @return {number} |
| */ |
| Runner.prototype.grepTotal = function(suite) { |
| var self = this; |
| var total = 0; |
| |
| suite.eachTest(function(test) { |
| var match = self._grep.test(test.fullTitle()); |
| if (self._invert) { |
| match = !match; |
| } |
| if (match) { |
| total++; |
| } |
| }); |
| |
| return total; |
| }; |
| |
| /** |
| * Return a list of global properties. |
| * |
| * @return {Array} |
| * @private |
| */ |
| Runner.prototype.globalProps = function() { |
| var props = Object.keys(global); |
| |
| // non-enumerables |
| for (var i = 0; i < globals.length; ++i) { |
| if (~props.indexOf(globals[i])) { |
| continue; |
| } |
| props.push(globals[i]); |
| } |
| |
| return props; |
| }; |
| |
| /** |
| * Allow the given `arr` of globals. |
| * |
| * @public |
| * @memberof Runner |
| * @param {Array} arr |
| * @return {Runner} Runner instance. |
| */ |
| Runner.prototype.globals = function(arr) { |
| if (!arguments.length) { |
| return this._globals; |
| } |
| debug('globals %j', arr); |
| this._globals = this._globals.concat(arr); |
| return this; |
| }; |
| |
| /** |
| * Check for global variable leaks. |
| * |
| * @private |
| */ |
| Runner.prototype.checkGlobals = function(test) { |
| if (this.ignoreLeaks) { |
| return; |
| } |
| var ok = this._globals; |
| |
| var globals = this.globalProps(); |
| var leaks; |
| |
| if (test) { |
| ok = ok.concat(test._allowedGlobals || []); |
| } |
| |
| if (this.prevGlobalsLength === globals.length) { |
| return; |
| } |
| this.prevGlobalsLength = globals.length; |
| |
| leaks = filterLeaks(ok, globals); |
| this._globals = this._globals.concat(leaks); |
| |
| if (leaks.length) { |
| var format = ngettext( |
| leaks.length, |
| 'global leak detected: %s', |
| 'global leaks detected: %s' |
| ); |
| var error = new Error(util.format(format, leaks.map(sQuote).join(', '))); |
| this.fail(test, error); |
| } |
| }; |
| |
| /** |
| * Fail the given `test`. |
| * |
| * @private |
| * @param {Test} test |
| * @param {Error} err |
| */ |
| Runner.prototype.fail = function(test, err) { |
| if (test.isPending()) { |
| return; |
| } |
| |
| ++this.failures; |
| test.state = STATE_FAILED; |
| |
| if (!isError(err)) { |
| err = thrown2Error(err); |
| } |
| |
| try { |
| err.stack = |
| this.fullStackTrace || !err.stack ? err.stack : stackFilter(err.stack); |
| } catch (ignore) { |
| // some environments do not take kindly to monkeying with the stack |
| } |
| |
| this.emit(constants.EVENT_TEST_FAIL, test, err); |
| }; |
| |
| /** |
| * Fail the given `hook` with `err`. |
| * |
| * Hook failures work in the following pattern: |
| * - If bail, run corresponding `after each` and `after` hooks, |
| * then exit |
| * - Failed `before` hook skips all tests in a suite and subsuites, |
| * but jumps to corresponding `after` hook |
| * - Failed `before each` hook skips remaining tests in a |
| * suite and jumps to corresponding `after each` hook, |
| * which is run only once |
| * - Failed `after` hook does not alter |
| * execution order |
| * - Failed `after each` hook skips remaining tests in a |
| * suite and subsuites, but executes other `after each` |
| * hooks |
| * |
| * @private |
| * @param {Hook} hook |
| * @param {Error} err |
| */ |
| Runner.prototype.failHook = function(hook, err) { |
| hook.originalTitle = hook.originalTitle || hook.title; |
| if (hook.ctx && hook.ctx.currentTest) { |
| hook.title = |
| hook.originalTitle + ' for ' + dQuote(hook.ctx.currentTest.title); |
| } else { |
| var parentTitle; |
| if (hook.parent.title) { |
| parentTitle = hook.parent.title; |
| } else { |
| parentTitle = hook.parent.root ? '{root}' : ''; |
| } |
| hook.title = hook.originalTitle + ' in ' + dQuote(parentTitle); |
| } |
| |
| this.fail(hook, err); |
| }; |
| |
| /** |
| * Run hook `name` callbacks and then invoke `fn()`. |
| * |
| * @private |
| * @param {string} name |
| * @param {Function} fn |
| */ |
| |
| Runner.prototype.hook = function(name, fn) { |
| var suite = this.suite; |
| var hooks = suite.getHooks(name); |
| var self = this; |
| |
| function next(i) { |
| var hook = hooks[i]; |
| if (!hook) { |
| return fn(); |
| } |
| self.currentRunnable = hook; |
| |
| if (name === HOOK_TYPE_BEFORE_ALL) { |
| hook.ctx.currentTest = hook.parent.tests[0]; |
| } else if (name === HOOK_TYPE_AFTER_ALL) { |
| hook.ctx.currentTest = hook.parent.tests[hook.parent.tests.length - 1]; |
| } else { |
| hook.ctx.currentTest = self.test; |
| } |
| |
| hook.allowUncaught = self.allowUncaught; |
| |
| self.emit(constants.EVENT_HOOK_BEGIN, hook); |
| |
| if (!hook.listeners('error').length) { |
| hook.on('error', function(err) { |
| self.failHook(hook, err); |
| }); |
| } |
| |
| hook.run(function(err) { |
| var testError = hook.error(); |
| if (testError) { |
| self.fail(self.test, testError); |
| } |
| if (err) { |
| if (err instanceof Pending) { |
| if (name === HOOK_TYPE_AFTER_ALL) { |
| utils.deprecate( |
| 'Skipping a test within an "after all" hook is DEPRECATED and will throw an exception in a future version of Mocha. ' + |
| 'Use a return statement or other means to abort hook execution.' |
| ); |
| } |
| if (name === HOOK_TYPE_BEFORE_EACH || name === HOOK_TYPE_AFTER_EACH) { |
| if (self.test) { |
| self.test.pending = true; |
| } |
| } else { |
| suite.tests.forEach(function(test) { |
| test.pending = true; |
| }); |
| suite.suites.forEach(function(suite) { |
| suite.pending = true; |
| }); |
| // a pending hook won't be executed twice. |
| hook.pending = true; |
| } |
| } else { |
| self.failHook(hook, err); |
| |
| // stop executing hooks, notify callee of hook err |
| return fn(err); |
| } |
| } |
| self.emit(constants.EVENT_HOOK_END, hook); |
| delete hook.ctx.currentTest; |
| next(++i); |
| }); |
| } |
| |
| Runner.immediately(function() { |
| next(0); |
| }); |
| }; |
| |
| /** |
| * Run hook `name` for the given array of `suites` |
| * in order, and callback `fn(err, errSuite)`. |
| * |
| * @private |
| * @param {string} name |
| * @param {Array} suites |
| * @param {Function} fn |
| */ |
| Runner.prototype.hooks = function(name, suites, fn) { |
| var self = this; |
| var orig = this.suite; |
| |
| function next(suite) { |
| self.suite = suite; |
| |
| if (!suite) { |
| self.suite = orig; |
| return fn(); |
| } |
| |
| self.hook(name, function(err) { |
| if (err) { |
| var errSuite = self.suite; |
| self.suite = orig; |
| return fn(err, errSuite); |
| } |
| |
| next(suites.pop()); |
| }); |
| } |
| |
| next(suites.pop()); |
| }; |
| |
| /** |
| * Run hooks from the top level down. |
| * |
| * @param {String} name |
| * @param {Function} fn |
| * @private |
| */ |
| Runner.prototype.hookUp = function(name, fn) { |
| var suites = [this.suite].concat(this.parents()).reverse(); |
| this.hooks(name, suites, fn); |
| }; |
| |
| /** |
| * Run hooks from the bottom up. |
| * |
| * @param {String} name |
| * @param {Function} fn |
| * @private |
| */ |
| Runner.prototype.hookDown = function(name, fn) { |
| var suites = [this.suite].concat(this.parents()); |
| this.hooks(name, suites, fn); |
| }; |
| |
| /** |
| * Return an array of parent Suites from |
| * closest to furthest. |
| * |
| * @return {Array} |
| * @private |
| */ |
| Runner.prototype.parents = function() { |
| var suite = this.suite; |
| var suites = []; |
| while (suite.parent) { |
| suite = suite.parent; |
| suites.push(suite); |
| } |
| return suites; |
| }; |
| |
| /** |
| * Run the current test and callback `fn(err)`. |
| * |
| * @param {Function} fn |
| * @private |
| */ |
| Runner.prototype.runTest = function(fn) { |
| var self = this; |
| var test = this.test; |
| |
| if (!test) { |
| return; |
| } |
| |
| var suite = this.parents().reverse()[0] || this.suite; |
| if (this.forbidOnly && suite.hasOnly()) { |
| fn(new Error('`.only` forbidden')); |
| return; |
| } |
| if (this.asyncOnly) { |
| test.asyncOnly = true; |
| } |
| test.on('error', function(err) { |
| self.fail(test, err); |
| }); |
| if (this.allowUncaught) { |
| test.allowUncaught = true; |
| return test.run(fn); |
| } |
| try { |
| test.run(fn); |
| } catch (err) { |
| fn(err); |
| } |
| }; |
| |
| /** |
| * Run tests in the given `suite` and invoke the callback `fn()` when complete. |
| * |
| * @private |
| * @param {Suite} suite |
| * @param {Function} fn |
| */ |
| Runner.prototype.runTests = function(suite, fn) { |
| var self = this; |
| var tests = suite.tests.slice(); |
| var test; |
| |
| function hookErr(_, errSuite, after) { |
| // before/after Each hook for errSuite failed: |
| var orig = self.suite; |
| |
| // for failed 'after each' hook start from errSuite parent, |
| // otherwise start from errSuite itself |
| self.suite = after ? errSuite.parent : errSuite; |
| |
| if (self.suite) { |
| // call hookUp afterEach |
| self.hookUp(HOOK_TYPE_AFTER_EACH, function(err2, errSuite2) { |
| self.suite = orig; |
| // some hooks may fail even now |
| if (err2) { |
| return hookErr(err2, errSuite2, true); |
| } |
| // report error suite |
| fn(errSuite); |
| }); |
| } else { |
| // there is no need calling other 'after each' hooks |
| self.suite = orig; |
| fn(errSuite); |
| } |
| } |
| |
| function next(err, errSuite) { |
| // if we bail after first err |
| if (self.failures && suite._bail) { |
| tests = []; |
| } |
| |
| if (self._abort) { |
| return fn(); |
| } |
| |
| if (err) { |
| return hookErr(err, errSuite, true); |
| } |
| |
| // next test |
| test = tests.shift(); |
| |
| // all done |
| if (!test) { |
| return fn(); |
| } |
| |
| // grep |
| var match = self._grep.test(test.fullTitle()); |
| if (self._invert) { |
| match = !match; |
| } |
| if (!match) { |
| // Run immediately only if we have defined a grep. When we |
| // define a grep — It can cause maximum callstack error if |
| // the grep is doing a large recursive loop by neglecting |
| // all tests. The run immediately function also comes with |
| // a performance cost. So we don't want to run immediately |
| // if we run the whole test suite, because running the whole |
| // test suite don't do any immediate recursive loops. Thus, |
| // allowing a JS runtime to breathe. |
| if (self._grep !== self._defaultGrep) { |
| Runner.immediately(next); |
| } else { |
| next(); |
| } |
| return; |
| } |
| |
| if (test.isPending()) { |
| if (self.forbidPending) { |
| test.isPending = alwaysFalse; |
| self.fail(test, new Error('Pending test forbidden')); |
| delete test.isPending; |
| } else { |
| self.emit(constants.EVENT_TEST_PENDING, test); |
| } |
| self.emit(constants.EVENT_TEST_END, test); |
| return next(); |
| } |
| |
| // execute test and hook(s) |
| self.emit(constants.EVENT_TEST_BEGIN, (self.test = test)); |
| self.hookDown(HOOK_TYPE_BEFORE_EACH, function(err, errSuite) { |
| if (test.isPending()) { |
| if (self.forbidPending) { |
| test.isPending = alwaysFalse; |
| self.fail(test, new Error('Pending test forbidden')); |
| delete test.isPending; |
| } else { |
| self.emit(constants.EVENT_TEST_PENDING, test); |
| } |
| self.emit(constants.EVENT_TEST_END, test); |
| return next(); |
| } |
| if (err) { |
| return hookErr(err, errSuite, false); |
| } |
| self.currentRunnable = self.test; |
| self.runTest(function(err) { |
| test = self.test; |
| if (err) { |
| var retry = test.currentRetry(); |
| if (err instanceof Pending && self.forbidPending) { |
| self.fail(test, new Error('Pending test forbidden')); |
| } else if (err instanceof Pending) { |
| test.pending = true; |
| self.emit(constants.EVENT_TEST_PENDING, test); |
| } else if (retry < test.retries()) { |
| var clonedTest = test.clone(); |
| clonedTest.currentRetry(retry + 1); |
| tests.unshift(clonedTest); |
| |
| self.emit(constants.EVENT_TEST_RETRY, test, err); |
| |
| // Early return + hook trigger so that it doesn't |
| // increment the count wrong |
| return self.hookUp(HOOK_TYPE_AFTER_EACH, next); |
| } else { |
| self.fail(test, err); |
| } |
| self.emit(constants.EVENT_TEST_END, test); |
| |
| if (err instanceof Pending) { |
| return next(); |
| } |
| |
| return self.hookUp(HOOK_TYPE_AFTER_EACH, next); |
| } |
| |
| test.state = STATE_PASSED; |
| self.emit(constants.EVENT_TEST_PASS, test); |
| self.emit(constants.EVENT_TEST_END, test); |
| self.hookUp(HOOK_TYPE_AFTER_EACH, next); |
| }); |
| }); |
| } |
| |
| this.next = next; |
| this.hookErr = hookErr; |
| next(); |
| }; |
| |
| function alwaysFalse() { |
| return false; |
| } |
| |
| /** |
| * Run the given `suite` and invoke the callback `fn()` when complete. |
| * |
| * @private |
| * @param {Suite} suite |
| * @param {Function} fn |
| */ |
| Runner.prototype.runSuite = function(suite, fn) { |
| var i = 0; |
| var self = this; |
| var total = this.grepTotal(suite); |
| var afterAllHookCalled = false; |
| |
| debug('run suite %s', suite.fullTitle()); |
| |
| if (!total || (self.failures && suite._bail)) { |
| return fn(); |
| } |
| |
| this.emit(constants.EVENT_SUITE_BEGIN, (this.suite = suite)); |
| |
| function next(errSuite) { |
| if (errSuite) { |
| // current suite failed on a hook from errSuite |
| if (errSuite === suite) { |
| // if errSuite is current suite |
| // continue to the next sibling suite |
| return done(); |
| } |
| // errSuite is among the parents of current suite |
| // stop execution of errSuite and all sub-suites |
| return done(errSuite); |
| } |
| |
| if (self._abort) { |
| return done(); |
| } |
| |
| var curr = suite.suites[i++]; |
| if (!curr) { |
| return done(); |
| } |
| |
| // Avoid grep neglecting large number of tests causing a |
| // huge recursive loop and thus a maximum call stack error. |
| // See comment in `this.runTests()` for more information. |
| if (self._grep !== self._defaultGrep) { |
| Runner.immediately(function() { |
| self.runSuite(curr, next); |
| }); |
| } else { |
| self.runSuite(curr, next); |
| } |
| } |
| |
| function done(errSuite) { |
| self.suite = suite; |
| self.nextSuite = next; |
| |
| if (afterAllHookCalled) { |
| fn(errSuite); |
| } else { |
| // mark that the afterAll block has been called once |
| // and so can be skipped if there is an error in it. |
| afterAllHookCalled = true; |
| |
| // remove reference to test |
| delete self.test; |
| |
| self.hook(HOOK_TYPE_AFTER_ALL, function() { |
| self.emit(constants.EVENT_SUITE_END, suite); |
| fn(errSuite); |
| }); |
| } |
| } |
| |
| this.nextSuite = next; |
| |
| this.hook(HOOK_TYPE_BEFORE_ALL, function(err) { |
| if (err) { |
| return done(); |
| } |
| self.runTests(suite, next); |
| }); |
| }; |
| |
| /** |
| * Handle uncaught exceptions. |
| * |
| * @param {Error} err |
| * @private |
| */ |
| Runner.prototype.uncaught = function(err) { |
| if (err instanceof Pending) { |
| return; |
| } |
| if (err) { |
| debug('uncaught exception %O', err); |
| } else { |
| debug('uncaught undefined/falsy exception'); |
| err = createInvalidExceptionError( |
| 'Caught falsy/undefined exception which would otherwise be uncaught. No stack trace found; try a debugger', |
| err |
| ); |
| } |
| |
| if (!isError(err)) { |
| err = thrown2Error(err); |
| } |
| err.uncaught = true; |
| |
| var runnable = this.currentRunnable; |
| |
| if (!runnable) { |
| runnable = new Runnable('Uncaught error outside test suite'); |
| runnable.parent = this.suite; |
| |
| if (this.started) { |
| this.fail(runnable, err); |
| } else { |
| // Can't recover from this failure |
| this.emit(constants.EVENT_RUN_BEGIN); |
| this.fail(runnable, err); |
| this.emit(constants.EVENT_RUN_END); |
| } |
| |
| return; |
| } |
| |
| runnable.clearTimeout(); |
| |
| // Ignore errors if already failed or pending |
| // See #3226 |
| if (runnable.isFailed() || runnable.isPending()) { |
| return; |
| } |
| // we cannot recover gracefully if a Runnable has already passed |
| // then fails asynchronously |
| var alreadyPassed = runnable.isPassed(); |
| // this will change the state to "failed" regardless of the current value |
| this.fail(runnable, err); |
| if (!alreadyPassed) { |
| // recover from test |
| if (runnable.type === constants.EVENT_TEST_BEGIN) { |
| this.emit(constants.EVENT_TEST_END, runnable); |
| this.hookUp(HOOK_TYPE_AFTER_EACH, this.next); |
| return; |
| } |
| debug(runnable); |
| |
| // recover from hooks |
| var errSuite = this.suite; |
| |
| // XXX how about a less awful way to determine this? |
| // if hook failure is in afterEach block |
| if (runnable.fullTitle().indexOf('after each') > -1) { |
| return this.hookErr(err, errSuite, true); |
| } |
| // if hook failure is in beforeEach block |
| if (runnable.fullTitle().indexOf('before each') > -1) { |
| return this.hookErr(err, errSuite, false); |
| } |
| // if hook failure is in after or before blocks |
| return this.nextSuite(errSuite); |
| } |
| |
| // bail |
| this.emit(constants.EVENT_RUN_END); |
| }; |
| |
| /** |
| * Run the root suite and invoke `fn(failures)` |
| * on completion. |
| * |
| * @public |
| * @memberof Runner |
| * @param {Function} fn |
| * @return {Runner} Runner instance. |
| */ |
| Runner.prototype.run = function(fn) { |
| var self = this; |
| var rootSuite = this.suite; |
| |
| fn = fn || function() {}; |
| |
| function uncaught(err) { |
| self.uncaught(err); |
| } |
| |
| function start() { |
| // If there is an `only` filter |
| if (rootSuite.hasOnly()) { |
| rootSuite.filterOnly(); |
| } |
| self.started = true; |
| if (self._delay) { |
| self.emit(constants.EVENT_DELAY_END); |
| } |
| self.emit(constants.EVENT_RUN_BEGIN); |
| |
| self.runSuite(rootSuite, function() { |
| debug('finished running'); |
| self.emit(constants.EVENT_RUN_END); |
| }); |
| } |
| |
| debug(constants.EVENT_RUN_BEGIN); |
| |
| // references cleanup to avoid memory leaks |
| this.on(constants.EVENT_SUITE_END, function(suite) { |
| suite.cleanReferences(); |
| }); |
| |
| // callback |
| this.on(constants.EVENT_RUN_END, function() { |
| debug(constants.EVENT_RUN_END); |
| process.removeListener('uncaughtException', uncaught); |
| fn(self.failures); |
| }); |
| |
| // uncaught exception |
| process.on('uncaughtException', uncaught); |
| |
| if (this._delay) { |
| // for reporters, I guess. |
| // might be nice to debounce some dots while we wait. |
| this.emit(constants.EVENT_DELAY_BEGIN, rootSuite); |
| rootSuite.once(EVENT_ROOT_SUITE_RUN, start); |
| } else { |
| start(); |
| } |
| |
| return this; |
| }; |
| |
| /** |
| * Cleanly abort execution. |
| * |
| * @memberof Runner |
| * @public |
| * @return {Runner} Runner instance. |
| */ |
| Runner.prototype.abort = function() { |
| debug('aborting'); |
| this._abort = true; |
| |
| return this; |
| }; |
| |
| /** |
| * Filter leaks with the given globals flagged as `ok`. |
| * |
| * @private |
| * @param {Array} ok |
| * @param {Array} globals |
| * @return {Array} |
| */ |
| function filterLeaks(ok, globals) { |
| return globals.filter(function(key) { |
| // Firefox and Chrome exposes iframes as index inside the window object |
| if (/^\d+/.test(key)) { |
| return false; |
| } |
| |
| // in firefox |
| // if runner runs in an iframe, this iframe's window.getInterface method |
| // not init at first it is assigned in some seconds |
| if (global.navigator && /^getInterface/.test(key)) { |
| return false; |
| } |
| |
| // an iframe could be approached by window[iframeIndex] |
| // in ie6,7,8 and opera, iframeIndex is enumerable, this could cause leak |
| if (global.navigator && /^\d+/.test(key)) { |
| return false; |
| } |
| |
| // Opera and IE expose global variables for HTML element IDs (issue #243) |
| if (/^mocha-/.test(key)) { |
| return false; |
| } |
| |
| var matched = ok.filter(function(ok) { |
| if (~ok.indexOf('*')) { |
| return key.indexOf(ok.split('*')[0]) === 0; |
| } |
| return key === ok; |
| }); |
| return !matched.length && (!global.navigator || key !== 'onerror'); |
| }); |
| } |
| |
| /** |
| * Check if argument is an instance of Error object or a duck-typed equivalent. |
| * |
| * @private |
| * @param {Object} err - object to check |
| * @param {string} err.message - error message |
| * @returns {boolean} |
| */ |
| function isError(err) { |
| return err instanceof Error || (err && typeof err.message === 'string'); |
| } |
| |
| /** |
| * |
| * Converts thrown non-extensible type into proper Error. |
| * |
| * @private |
| * @param {*} thrown - Non-extensible type thrown by code |
| * @return {Error} |
| */ |
| function thrown2Error(err) { |
| return new Error( |
| 'the ' + type(err) + ' ' + stringify(err) + ' was thrown, throw an Error :)' |
| ); |
| } |
| |
| /** |
| * Array of globals dependent on the environment. |
| * |
| * @return {Array} |
| * @deprecated |
| * @todo remove; long since unsupported |
| * @private |
| */ |
| function extraGlobals() { |
| if (typeof process === 'object' && typeof process.version === 'string') { |
| var parts = process.version.split('.'); |
| var nodeVersion = parts.reduce(function(a, v) { |
| return (a << 8) | v; |
| }); |
| |
| // 'errno' was renamed to process._errno in v0.9.11. |
| if (nodeVersion < 0x00090b) { |
| return ['errno']; |
| } |
| } |
| |
| return []; |
| } |
| |
| Runner.constants = constants; |
| |
| /** |
| * Node.js' `EventEmitter` |
| * @external EventEmitter |
| * @see {@link https://nodejs.org/api/events.html#events_class_eventemitter} |
| */ |
| |
| }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{"./errors":6,"./pending":16,"./runnable":33,"./suite":36,"./utils":38,"_process":69,"debug":45,"events":50,"util":89}],35:[function(require,module,exports){ |
| (function (global){ |
| 'use strict'; |
| |
| /** |
| * Provides a factory function for a {@link StatsCollector} object. |
| * @module |
| */ |
| |
| var constants = require('./runner').constants; |
| var EVENT_TEST_PASS = constants.EVENT_TEST_PASS; |
| var EVENT_TEST_FAIL = constants.EVENT_TEST_FAIL; |
| var EVENT_SUITE_BEGIN = constants.EVENT_SUITE_BEGIN; |
| var EVENT_RUN_BEGIN = constants.EVENT_RUN_BEGIN; |
| var EVENT_TEST_PENDING = constants.EVENT_TEST_PENDING; |
| var EVENT_RUN_END = constants.EVENT_RUN_END; |
| var EVENT_TEST_END = constants.EVENT_TEST_END; |
| |
| /** |
| * Test statistics collector. |
| * |
| * @public |
| * @typedef {Object} StatsCollector |
| * @property {number} suites - integer count of suites run. |
| * @property {number} tests - integer count of tests run. |
| * @property {number} passes - integer count of passing tests. |
| * @property {number} pending - integer count of pending tests. |
| * @property {number} failures - integer count of failed tests. |
| * @property {Date} start - time when testing began. |
| * @property {Date} end - time when testing concluded. |
| * @property {number} duration - number of msecs that testing took. |
| */ |
| |
| var Date = global.Date; |
| |
| /** |
| * Provides stats such as test duration, number of tests passed / failed etc., by listening for events emitted by `runner`. |
| * |
| * @private |
| * @param {Runner} runner - Runner instance |
| * @throws {TypeError} If falsy `runner` |
| */ |
| function createStatsCollector(runner) { |
| /** |
| * @type StatsCollector |
| */ |
| var stats = { |
| suites: 0, |
| tests: 0, |
| passes: 0, |
| pending: 0, |
| failures: 0 |
| }; |
| |
| if (!runner) { |
| throw new TypeError('Missing runner argument'); |
| } |
| |
| runner.stats = stats; |
| |
| runner.once(EVENT_RUN_BEGIN, function() { |
| stats.start = new Date(); |
| }); |
| runner.on(EVENT_SUITE_BEGIN, function(suite) { |
| suite.root || stats.suites++; |
| }); |
| runner.on(EVENT_TEST_PASS, function() { |
| stats.passes++; |
| }); |
| runner.on(EVENT_TEST_FAIL, function() { |
| stats.failures++; |
| }); |
| runner.on(EVENT_TEST_PENDING, function() { |
| stats.pending++; |
| }); |
| runner.on(EVENT_TEST_END, function() { |
| stats.tests++; |
| }); |
| runner.once(EVENT_RUN_END, function() { |
| stats.end = new Date(); |
| stats.duration = stats.end - stats.start; |
| }); |
| } |
| |
| module.exports = createStatsCollector; |
| |
| }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{"./runner":34}],36:[function(require,module,exports){ |
| 'use strict'; |
| |
| /** |
| * Module dependencies. |
| */ |
| var EventEmitter = require('events').EventEmitter; |
| var Hook = require('./hook'); |
| var utils = require('./utils'); |
| var inherits = utils.inherits; |
| var debug = require('debug')('mocha:suite'); |
| var milliseconds = require('ms'); |
| var errors = require('./errors'); |
| var createInvalidArgumentTypeError = errors.createInvalidArgumentTypeError; |
| |
| /** |
| * Expose `Suite`. |
| */ |
| |
| exports = module.exports = Suite; |
| |
| /** |
| * Create a new `Suite` with the given `title` and parent `Suite`. |
| * |
| * @public |
| * @param {Suite} parent - Parent suite (required!) |
| * @param {string} title - Title |
| * @return {Suite} |
| */ |
| Suite.create = function(parent, title) { |
| var suite = new Suite(title, parent.ctx); |
| suite.parent = parent; |
| title = suite.fullTitle(); |
| parent.addSuite(suite); |
| return suite; |
| }; |
| |
| /** |
| * Constructs a new `Suite` instance with the given `title`, `ctx`, and `isRoot`. |
| * |
| * @public |
| * @class |
| * @extends EventEmitter |
| * @see {@link https://nodejs.org/api/events.html#events_class_eventemitter|EventEmitter} |
| * @param {string} title - Suite title. |
| * @param {Context} parentContext - Parent context instance. |
| * @param {boolean} [isRoot=false] - Whether this is the root suite. |
| */ |
| function Suite(title, parentContext, isRoot) { |
| if (!utils.isString(title)) { |
| throw createInvalidArgumentTypeError( |
| 'Suite argument "title" must be a string. Received type "' + |
| typeof title + |
| '"', |
| 'title', |
| 'string' |
| ); |
| } |
| this.title = title; |
| function Context() {} |
| Context.prototype = parentContext; |
| this.ctx = new Context(); |
| this.suites = []; |
| this.tests = []; |
| this.pending = false; |
| this._beforeEach = []; |
| this._beforeAll = []; |
| this._afterEach = []; |
| this._afterAll = []; |
| this.root = isRoot === true; |
| this._timeout = 2000; |
| this._enableTimeouts = true; |
| this._slow = 75; |
| this._bail = false; |
| this._retries = -1; |
| this._onlyTests = []; |
| this._onlySuites = []; |
| this.delayed = false; |
| |
| this.on('newListener', function(event) { |
| if (deprecatedEvents[event]) { |
| utils.deprecate( |
| 'Event "' + |
| event + |
| '" is deprecated. Please let the Mocha team know about your use case: https://git.io/v6Lwm' |
| ); |
| } |
| }); |
| } |
| |
| /** |
| * Inherit from `EventEmitter.prototype`. |
| */ |
| inherits(Suite, EventEmitter); |
| |
| /** |
| * Return a clone of this `Suite`. |
| * |
| * @private |
| * @return {Suite} |
| */ |
| Suite.prototype.clone = function() { |
| var suite = new Suite(this.title); |
| debug('clone'); |
| suite.ctx = this.ctx; |
| suite.root = this.root; |
| suite.timeout(this.timeout()); |
| suite.retries(this.retries()); |
| suite.enableTimeouts(this.enableTimeouts()); |
| suite.slow(this.slow()); |
| suite.bail(this.bail()); |
| return suite; |
| }; |
| |
| /** |
| * Set or get timeout `ms` or short-hand such as "2s". |
| * |
| * @private |
| * @todo Do not attempt to set value if `ms` is undefined |
| * @param {number|string} ms |
| * @return {Suite|number} for chaining |
| */ |
| Suite.prototype.timeout = function(ms) { |
| if (!arguments.length) { |
| return this._timeout; |
| } |
| if (ms.toString() === '0') { |
| this._enableTimeouts = false; |
| } |
| if (typeof ms === 'string') { |
| ms = milliseconds(ms); |
| } |
| debug('timeout %d', ms); |
| this._timeout = parseInt(ms, 10); |
| return this; |
| }; |
| |
| /** |
| * Set or get number of times to retry a failed test. |
| * |
| * @private |
| * @param {number|string} n |
| * @return {Suite|number} for chaining |
| */ |
| Suite.prototype.retries = function(n) { |
| if (!arguments.length) { |
| return this._retries; |
| } |
| debug('retries %d', n); |
| this._retries = parseInt(n, 10) || 0; |
| return this; |
| }; |
| |
| /** |
| * Set or get timeout to `enabled`. |
| * |
| * @private |
| * @param {boolean} enabled |
| * @return {Suite|boolean} self or enabled |
| */ |
| Suite.prototype.enableTimeouts = function(enabled) { |
| if (!arguments.length) { |
| return this._enableTimeouts; |
| } |
| debug('enableTimeouts %s', enabled); |
| this._enableTimeouts = enabled; |
| return this; |
| }; |
| |
| /** |
| * Set or get slow `ms` or short-hand such as "2s". |
| * |
| * @private |
| * @param {number|string} ms |
| * @return {Suite|number} for chaining |
| */ |
| Suite.prototype.slow = function(ms) { |
| if (!arguments.length) { |
| return this._slow; |
| } |
| if (typeof ms === 'string') { |
| ms = milliseconds(ms); |
| } |
| debug('slow %d', ms); |
| this._slow = ms; |
| return this; |
| }; |
| |
| /** |
| * Set or get whether to bail after first error. |
| * |
| * @private |
| * @param {boolean} bail |
| * @return {Suite|number} for chaining |
| */ |
| Suite.prototype.bail = function(bail) { |
| if (!arguments.length) { |
| return this._bail; |
| } |
| debug('bail %s', bail); |
| this._bail = bail; |
| return this; |
| }; |
| |
| /** |
| * Check if this suite or its parent suite is marked as pending. |
| * |
| * @private |
| */ |
| Suite.prototype.isPending = function() { |
| return this.pending || (this.parent && this.parent.isPending()); |
| }; |
| |
| /** |
| * Generic hook-creator. |
| * @private |
| * @param {string} title - Title of hook |
| * @param {Function} fn - Hook callback |
| * @returns {Hook} A new hook |
| */ |
| Suite.prototype._createHook = function(title, fn) { |
| var hook = new Hook(title, fn); |
| hook.parent = this; |
| hook.timeout(this.timeout()); |
| hook.retries(this.retries()); |
| hook.enableTimeouts(this.enableTimeouts()); |
| hook.slow(this.slow()); |
| hook.ctx = this.ctx; |
| hook.file = this.file; |
| return hook; |
| }; |
| |
| /** |
| * Run `fn(test[, done])` before running tests. |
| * |
| * @private |
| * @param {string} title |
| * @param {Function} fn |
| * @return {Suite} for chaining |
| */ |
| Suite.prototype.beforeAll = function(title, fn) { |
| if (this.isPending()) { |
| return this; |
| } |
| if (typeof title === 'function') { |
| fn = title; |
| title = fn.name; |
| } |
| title = '"before all" hook' + (title ? ': ' + title : ''); |
| |
| var hook = this._createHook(title, fn); |
| this._beforeAll.push(hook); |
| this.emit(constants.EVENT_SUITE_ADD_HOOK_BEFORE_ALL, hook); |
| return this; |
| }; |
| |
| /** |
| * Run `fn(test[, done])` after running tests. |
| * |
| * @private |
| * @param {string} title |
| * @param {Function} fn |
| * @return {Suite} for chaining |
| */ |
| Suite.prototype.afterAll = function(title, fn) { |
| if (this.isPending()) { |
| return this; |
| } |
| if (typeof title === 'function') { |
| fn = title; |
| title = fn.name; |
| } |
| title = '"after all" hook' + (title ? ': ' + title : ''); |
| |
| var hook = this._createHook(title, fn); |
| this._afterAll.push(hook); |
| this.emit(constants.EVENT_SUITE_ADD_HOOK_AFTER_ALL, hook); |
| return this; |
| }; |
| |
| /** |
| * Run `fn(test[, done])` before each test case. |
| * |
| * @private |
| * @param {string} title |
| * @param {Function} fn |
| * @return {Suite} for chaining |
| */ |
| Suite.prototype.beforeEach = function(title, fn) { |
| if (this.isPending()) { |
| return this; |
| } |
| if (typeof title === 'function') { |
| fn = title; |
| title = fn.name; |
| } |
| title = '"before each" hook' + (title ? ': ' + title : ''); |
| |
| var hook = this._createHook(title, fn); |
| this._beforeEach.push(hook); |
| this.emit(constants.EVENT_SUITE_ADD_HOOK_BEFORE_EACH, hook); |
| return this; |
| }; |
| |
| /** |
| * Run `fn(test[, done])` after each test case. |
| * |
| * @private |
| * @param {string} title |
| * @param {Function} fn |
| * @return {Suite} for chaining |
| */ |
| Suite.prototype.afterEach = function(title, fn) { |
| if (this.isPending()) { |
| return this; |
| } |
| if (typeof title === 'function') { |
| fn = title; |
| title = fn.name; |
| } |
| title = '"after each" hook' + (title ? ': ' + title : ''); |
| |
| var hook = this._createHook(title, fn); |
| this._afterEach.push(hook); |
| this.emit(constants.EVENT_SUITE_ADD_HOOK_AFTER_EACH, hook); |
| return this; |
| }; |
| |
| /** |
| * Add a test `suite`. |
| * |
| * @private |
| * @param {Suite} suite |
| * @return {Suite} for chaining |
| */ |
| Suite.prototype.addSuite = function(suite) { |
| suite.parent = this; |
| suite.root = false; |
| suite.timeout(this.timeout()); |
| suite.retries(this.retries()); |
| suite.enableTimeouts(this.enableTimeouts()); |
| suite.slow(this.slow()); |
| suite.bail(this.bail()); |
| this.suites.push(suite); |
| this.emit(constants.EVENT_SUITE_ADD_SUITE, suite); |
| return this; |
| }; |
| |
| /** |
| * Add a `test` to this suite. |
| * |
| * @private |
| * @param {Test} test |
| * @return {Suite} for chaining |
| */ |
| Suite.prototype.addTest = function(test) { |
| test.parent = this; |
| test.timeout(this.timeout()); |
| test.retries(this.retries()); |
| test.enableTimeouts(this.enableTimeouts()); |
| test.slow(this.slow()); |
| test.ctx = this.ctx; |
| this.tests.push(test); |
| this.emit(constants.EVENT_SUITE_ADD_TEST, test); |
| return this; |
| }; |
| |
| /** |
| * Return the full title generated by recursively concatenating the parent's |
| * full title. |
| * |
| * @memberof Suite |
| * @public |
| * @return {string} |
| */ |
| Suite.prototype.fullTitle = function() { |
| return this.titlePath().join(' '); |
| }; |
| |
| /** |
| * Return the title path generated by recursively concatenating the parent's |
| * title path. |
| * |
| * @memberof Suite |
| * @public |
| * @return {string} |
| */ |
| Suite.prototype.titlePath = function() { |
| var result = []; |
| if (this.parent) { |
| result = result.concat(this.parent.titlePath()); |
| } |
| if (!this.root) { |
| result.push(this.title); |
| } |
| return result; |
| }; |
| |
| /** |
| * Return the total number of tests. |
| * |
| * @memberof Suite |
| * @public |
| * @return {number} |
| */ |
| Suite.prototype.total = function() { |
| return ( |
| this.suites.reduce(function(sum, suite) { |
| return sum + suite.total(); |
| }, 0) + this.tests.length |
| ); |
| }; |
| |
| /** |
| * Iterates through each suite recursively to find all tests. Applies a |
| * function in the format `fn(test)`. |
| * |
| * @private |
| * @param {Function} fn |
| * @return {Suite} |
| */ |
| Suite.prototype.eachTest = function(fn) { |
| this.tests.forEach(fn); |
| this.suites.forEach(function(suite) { |
| suite.eachTest(fn); |
| }); |
| return this; |
| }; |
| |
| /** |
| * This will run the root suite if we happen to be running in delayed mode. |
| * @private |
| */ |
| Suite.prototype.run = function run() { |
| if (this.root) { |
| this.emit(constants.EVENT_ROOT_SUITE_RUN); |
| } |
| }; |
| |
| /** |
| * Determines whether a suite has an `only` test or suite as a descendant. |
| * |
| * @private |
| * @returns {Boolean} |
| */ |
| Suite.prototype.hasOnly = function hasOnly() { |
| return ( |
| this._onlyTests.length > 0 || |
| this._onlySuites.length > 0 || |
| this.suites.some(function(suite) { |
| return suite.hasOnly(); |
| }) |
| ); |
| }; |
| |
| /** |
| * Filter suites based on `isOnly` logic. |
| * |
| * @private |
| * @returns {Boolean} |
| */ |
| Suite.prototype.filterOnly = function filterOnly() { |
| if (this._onlyTests.length) { |
| // If the suite contains `only` tests, run those and ignore any nested suites. |
| this.tests = this._onlyTests; |
| this.suites = []; |
| } else { |
| // Otherwise, do not run any of the tests in this suite. |
| this.tests = []; |
| this._onlySuites.forEach(function(onlySuite) { |
| // If there are other `only` tests/suites nested in the current `only` suite, then filter that `only` suite. |
| // Otherwise, all of the tests on this `only` suite should be run, so don't filter it. |
| if (onlySuite.hasOnly()) { |
| onlySuite.filterOnly(); |
| } |
| }); |
| // Run the `only` suites, as well as any other suites that have `only` tests/suites as descendants. |
| var onlySuites = this._onlySuites; |
| this.suites = this.suites.filter(function(childSuite) { |
| return onlySuites.indexOf(childSuite) !== -1 || childSuite.filterOnly(); |
| }); |
| } |
| // Keep the suite only if there is something to run |
| return this.tests.length > 0 || this.suites.length > 0; |
| }; |
| |
| /** |
| * Adds a suite to the list of subsuites marked `only`. |
| * |
| * @private |
| * @param {Suite} suite |
| */ |
| Suite.prototype.appendOnlySuite = function(suite) { |
| this._onlySuites.push(suite); |
| }; |
| |
| /** |
| * Adds a test to the list of tests marked `only`. |
| * |
| * @private |
| * @param {Test} test |
| */ |
| Suite.prototype.appendOnlyTest = function(test) { |
| this._onlyTests.push(test); |
| }; |
| |
| /** |
| * Returns the array of hooks by hook name; see `HOOK_TYPE_*` constants. |
| * @private |
| */ |
| Suite.prototype.getHooks = function getHooks(name) { |
| return this['_' + name]; |
| }; |
| |
| /** |
| * Cleans up the references to all the deferred functions |
| * (before/after/beforeEach/afterEach) and tests of a Suite. |
| * These must be deleted otherwise a memory leak can happen, |
| * as those functions may reference variables from closures, |
| * thus those variables can never be garbage collected as long |
| * as the deferred functions exist. |
| * |
| * @private |
| */ |
| Suite.prototype.cleanReferences = function cleanReferences() { |
| function cleanArrReferences(arr) { |
| for (var i = 0; i < arr.length; i++) { |
| delete arr[i].fn; |
| } |
| } |
| |
| if (Array.isArray(this._beforeAll)) { |
| cleanArrReferences(this._beforeAll); |
| } |
| |
| if (Array.isArray(this._beforeEach)) { |
| cleanArrReferences(this._beforeEach); |
| } |
| |
| if (Array.isArray(this._afterAll)) { |
| cleanArrReferences(this._afterAll); |
| } |
| |
| if (Array.isArray(this._afterEach)) { |
| cleanArrReferences(this._afterEach); |
| } |
| |
| for (var i = 0; i < this.tests.length; i++) { |
| delete this.tests[i].fn; |
| } |
| }; |
| |
| var constants = utils.defineConstants( |
| /** |
| * {@link Suite}-related constants. |
| * @public |
| * @memberof Suite |
| * @alias constants |
| * @readonly |
| * @static |
| * @enum {string} |
| */ |
| { |
| /** |
| * Event emitted after a test file has been loaded Not emitted in browser. |
| */ |
| EVENT_FILE_POST_REQUIRE: 'post-require', |
| /** |
| * Event emitted before a test file has been loaded. In browser, this is emitted once an interface has been selected. |
| */ |
| EVENT_FILE_PRE_REQUIRE: 'pre-require', |
| /** |
| * Event emitted immediately after a test file has been loaded. Not emitted in browser. |
| */ |
| EVENT_FILE_REQUIRE: 'require', |
| /** |
| * Event emitted when `global.run()` is called (use with `delay` option) |
| */ |
| EVENT_ROOT_SUITE_RUN: 'run', |
| |
| /** |
| * Namespace for collection of a `Suite`'s "after all" hooks |
| */ |
| HOOK_TYPE_AFTER_ALL: 'afterAll', |
| /** |
| * Namespace for collection of a `Suite`'s "after each" hooks |
| */ |
| HOOK_TYPE_AFTER_EACH: 'afterEach', |
| /** |
| * Namespace for collection of a `Suite`'s "before all" hooks |
| */ |
| HOOK_TYPE_BEFORE_ALL: 'beforeAll', |
| /** |
| * Namespace for collection of a `Suite`'s "before all" hooks |
| */ |
| HOOK_TYPE_BEFORE_EACH: 'beforeEach', |
| |
| // the following events are all deprecated |
| |
| /** |
| * Emitted after an "after all" `Hook` has been added to a `Suite`. Deprecated |
| */ |
| EVENT_SUITE_ADD_HOOK_AFTER_ALL: 'afterAll', |
| /** |
| * Emitted after an "after each" `Hook` has been added to a `Suite` Deprecated |
| */ |
| EVENT_SUITE_ADD_HOOK_AFTER_EACH: 'afterEach', |
| /** |
| * Emitted after an "before all" `Hook` has been added to a `Suite` Deprecated |
| */ |
| EVENT_SUITE_ADD_HOOK_BEFORE_ALL: 'beforeAll', |
| /** |
| * Emitted after an "before each" `Hook` has been added to a `Suite` Deprecated |
| */ |
| EVENT_SUITE_ADD_HOOK_BEFORE_EACH: 'beforeEach', |
| /** |
| * Emitted after a child `Suite` has been added to a `Suite`. Deprecated |
| */ |
| EVENT_SUITE_ADD_SUITE: 'suite', |
| /** |
| * Emitted after a `Test` has been added to a `Suite`. Deprecated |
| */ |
| EVENT_SUITE_ADD_TEST: 'test' |
| } |
| ); |
| |
| /** |
| * @summary There are no known use cases for these events. |
| * @desc This is a `Set`-like object having all keys being the constant's string value and the value being `true`. |
| * @todo Remove eventually |
| * @type {Object<string,boolean>} |
| * @ignore |
| */ |
| var deprecatedEvents = Object.keys(constants) |
| .filter(function(constant) { |
| return constant.substring(0, 15) === 'EVENT_SUITE_ADD'; |
| }) |
| .reduce(function(acc, constant) { |
| acc[constants[constant]] = true; |
| return acc; |
| }, utils.createMap()); |
| |
| Suite.constants = constants; |
| |
| },{"./errors":6,"./hook":7,"./utils":38,"debug":45,"events":50,"ms":60}],37:[function(require,module,exports){ |
| 'use strict'; |
| var Runnable = require('./runnable'); |
| var utils = require('./utils'); |
| var errors = require('./errors'); |
| var createInvalidArgumentTypeError = errors.createInvalidArgumentTypeError; |
| var isString = utils.isString; |
| |
| module.exports = Test; |
| |
| /** |
| * Initialize a new `Test` with the given `title` and callback `fn`. |
| * |
| * @public |
| * @class |
| * @extends Runnable |
| * @param {String} title - Test title (required) |
| * @param {Function} [fn] - Test callback. If omitted, the Test is considered "pending" |
| */ |
| function Test(title, fn) { |
| if (!isString(title)) { |
| throw createInvalidArgumentTypeError( |
| 'Test argument "title" should be a string. Received type "' + |
| typeof title + |
| '"', |
| 'title', |
| 'string' |
| ); |
| } |
| Runnable.call(this, title, fn); |
| this.pending = !fn; |
| this.type = 'test'; |
| } |
| |
| /** |
| * Inherit from `Runnable.prototype`. |
| */ |
| utils.inherits(Test, Runnable); |
| |
| Test.prototype.clone = function() { |
| var test = new Test(this.title, this.fn); |
| test.timeout(this.timeout()); |
| test.slow(this.slow()); |
| test.enableTimeouts(this.enableTimeouts()); |
| test.retries(this.retries()); |
| test.currentRetry(this.currentRetry()); |
| test.globals(this.globals()); |
| test.parent = this.parent; |
| test.file = this.file; |
| test.ctx = this.ctx; |
| return test; |
| }; |
| |
| },{"./errors":6,"./runnable":33,"./utils":38}],38:[function(require,module,exports){ |
| (function (process,Buffer){ |
| 'use strict'; |
| |
| /** |
| * Various utility functions used throughout Mocha's codebase. |
| * @module utils |
| */ |
| |
| /** |
| * Module dependencies. |
| */ |
| |
| var fs = require('fs'); |
| var path = require('path'); |
| var util = require('util'); |
| var glob = require('glob'); |
| var he = require('he'); |
| var errors = require('./errors'); |
| var createNoFilesMatchPatternError = errors.createNoFilesMatchPatternError; |
| var createMissingArgumentError = errors.createMissingArgumentError; |
| |
| var assign = (exports.assign = require('object.assign').getPolyfill()); |
| |
| /** |
| * Inherit the prototype methods from one constructor into another. |
| * |
| * @param {function} ctor - Constructor function which needs to inherit the |
| * prototype. |
| * @param {function} superCtor - Constructor function to inherit prototype from. |
| * @throws {TypeError} if either constructor is null, or if super constructor |
| * lacks a prototype. |
| */ |
| exports.inherits = util.inherits; |
| |
| /** |
| * Escape special characters in the given string of html. |
| * |
| * @private |
| * @param {string} html |
| * @return {string} |
| */ |
| exports.escape = function(html) { |
| return he.encode(String(html), {useNamedReferences: false}); |
| }; |
| |
| /** |
| * Test if the given obj is type of string. |
| * |
| * @private |
| * @param {Object} obj |
| * @return {boolean} |
| */ |
| exports.isString = function(obj) { |
| return typeof obj === 'string'; |
| }; |
| |
| /** |
| * Watch the given `files` for changes |
| * and invoke `fn(file)` on modification. |
| * |
| * @private |
| * @param {Array} files |
| * @param {Function} fn |
| */ |
| exports.watch = function(files, fn) { |
| var options = {interval: 100}; |
| var debug = require('debug')('mocha:watch'); |
| files.forEach(function(file) { |
| debug('file %s', file); |
| fs.watchFile(file, options, function(curr, prev) { |
| if (prev.mtime < curr.mtime) { |
| fn(file); |
| } |
| }); |
| }); |
| }; |
| |
| /** |
| * Predicate to screen `pathname` for further consideration. |
| * |
| * @description |
| * Returns <code>false</code> for pathname referencing: |
| * <ul> |
| * <li>'npm' package installation directory |
| * <li>'git' version control directory |
| * </ul> |
| * |
| * @private |
| * @param {string} pathname - File or directory name to screen |
| * @return {boolean} whether pathname should be further considered |
| * @example |
| * ['node_modules', 'test.js'].filter(considerFurther); // => ['test.js'] |
| */ |
| function considerFurther(pathname) { |
| var ignore = ['node_modules', '.git']; |
| |
| return !~ignore.indexOf(pathname); |
| } |
| |
| /** |
| * Lookup files in the given `dir`. |
| * |
| * @description |
| * Filenames are returned in _traversal_ order by the OS/filesystem. |
| * **Make no assumption that the names will be sorted in any fashion.** |
| * |
| * @private |
| * @param {string} dir |
| * @param {string[]} [exts=['js']] |
| * @param {Array} [ret=[]] |
| * @return {Array} |
| */ |
| exports.files = function(dir, exts, ret) { |
| ret = ret || []; |
| exts = exts || ['js']; |
| |
| fs.readdirSync(dir) |
| .filter(considerFurther) |
| .forEach(function(dirent) { |
| var pathname = path.join(dir, dirent); |
| if (fs.lstatSync(pathname).isDirectory()) { |
| exports.files(pathname, exts, ret); |
| } else if (hasMatchingExtname(pathname, exts)) { |
| ret.push(pathname); |
| } |
| }); |
| |
| return ret; |
| }; |
| |
| /** |
| * Compute a slug from the given `str`. |
| * |
| * @private |
| * @param {string} str |
| * @return {string} |
| */ |
| exports.slug = function(str) { |
| return str |
| .toLowerCase() |
| .replace(/ +/g, '-') |
| .replace(/[^-\w]/g, ''); |
| }; |
| |
| /** |
| * Strip the function definition from `str`, and re-indent for pre whitespace. |
| * |
| * @param {string} str |
| * @return {string} |
| */ |
| exports.clean = function(str) { |
| str = str |
| .replace(/\r\n?|[\n\u2028\u2029]/g, '\n') |
| .replace(/^\uFEFF/, '') |
| // (traditional)-> space/name parameters body (lambda)-> parameters body multi-statement/single keep body content |
| .replace( |
| /^function(?:\s*|\s+[^(]*)\([^)]*\)\s*\{((?:.|\n)*?)\s*\}$|^\([^)]*\)\s*=>\s*(?:\{((?:.|\n)*?)\s*\}|((?:.|\n)*))$/, |
| '$1$2$3' |
| ); |
| |
| var spaces = str.match(/^\n?( *)/)[1].length; |
| var tabs = str.match(/^\n?(\t*)/)[1].length; |
| var re = new RegExp( |
| '^\n?' + (tabs ? '\t' : ' ') + '{' + (tabs || spaces) + '}', |
| 'gm' |
| ); |
| |
| str = str.replace(re, ''); |
| |
| return str.trim(); |
| }; |
| |
| /** |
| * Parse the given `qs`. |
| * |
| * @private |
| * @param {string} qs |
| * @return {Object} |
| */ |
| exports.parseQuery = function(qs) { |
| return qs |
| .replace('?', '') |
| .split('&') |
| .reduce(function(obj, pair) { |
| var i = pair.indexOf('='); |
| var key = pair.slice(0, i); |
| var val = pair.slice(++i); |
| |
| // Due to how the URLSearchParams API treats spaces |
| obj[key] = decodeURIComponent(val.replace(/\+/g, '%20')); |
| |
| return obj; |
| }, {}); |
| }; |
| |
| /** |
| * Highlight the given string of `js`. |
| * |
| * @private |
| * @param {string} js |
| * @return {string} |
| */ |
| function highlight(js) { |
| return js |
| .replace(/</g, '<') |
| .replace(/>/g, '>') |
| .replace(/\/\/(.*)/gm, '<span class="comment">//$1</span>') |
| .replace(/('.*?')/gm, '<span class="string">$1</span>') |
| .replace(/(\d+\.\d+)/gm, '<span class="number">$1</span>') |
| .replace(/(\d+)/gm, '<span class="number">$1</span>') |
| .replace( |
| /\bnew[ \t]+(\w+)/gm, |
| '<span class="keyword">new</span> <span class="init">$1</span>' |
| ) |
| .replace( |
| /\b(function|new|throw|return|var|if|else)\b/gm, |
| '<span class="keyword">$1</span>' |
| ); |
| } |
| |
| /** |
| * Highlight the contents of tag `name`. |
| * |
| * @private |
| * @param {string} name |
| */ |
| exports.highlightTags = function(name) { |
| var code = document.getElementById('mocha').getElementsByTagName(name); |
| for (var i = 0, len = code.length; i < len; ++i) { |
| code[i].innerHTML = highlight(code[i].innerHTML); |
| } |
| }; |
| |
| /** |
| * If a value could have properties, and has none, this function is called, |
| * which returns a string representation of the empty value. |
| * |
| * Functions w/ no properties return `'[Function]'` |
| * Arrays w/ length === 0 return `'[]'` |
| * Objects w/ no properties return `'{}'` |
| * All else: return result of `value.toString()` |
| * |
| * @private |
| * @param {*} value The value to inspect. |
| * @param {string} typeHint The type of the value |
| * @returns {string} |
| */ |
| function emptyRepresentation(value, typeHint) { |
| switch (typeHint) { |
| case 'function': |
| return '[Function]'; |
| case 'object': |
| return '{}'; |
| case 'array': |
| return '[]'; |
| default: |
| return value.toString(); |
| } |
| } |
| |
| /** |
| * Takes some variable and asks `Object.prototype.toString()` what it thinks it |
| * is. |
| * |
| * @private |
| * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/toString |
| * @param {*} value The value to test. |
| * @returns {string} Computed type |
| * @example |
| * type({}) // 'object' |
| * type([]) // 'array' |
| * type(1) // 'number' |
| * type(false) // 'boolean' |
| * type(Infinity) // 'number' |
| * type(null) // 'null' |
| * type(new Date()) // 'date' |
| * type(/foo/) // 'regexp' |
| * type('type') // 'string' |
| * type(global) // 'global' |
| * type(new String('foo') // 'object' |
| */ |
| var type = (exports.type = function type(value) { |
| if (value === undefined) { |
| return 'undefined'; |
| } else if (value === null) { |
| return 'null'; |
| } else if (Buffer.isBuffer(value)) { |
| return 'buffer'; |
| } |
| return Object.prototype.toString |
| .call(value) |
| .replace(/^\[.+\s(.+?)]$/, '$1') |
| .toLowerCase(); |
| }); |
| |
| /** |
| * Stringify `value`. Different behavior depending on type of value: |
| * |
| * - If `value` is undefined or null, return `'[undefined]'` or `'[null]'`, respectively. |
| * - If `value` is not an object, function or array, return result of `value.toString()` wrapped in double-quotes. |
| * - If `value` is an *empty* object, function, or array, return result of function |
| * {@link emptyRepresentation}. |
| * - If `value` has properties, call {@link exports.canonicalize} on it, then return result of |
| * JSON.stringify(). |
| * |
| * @private |
| * @see exports.type |
| * @param {*} value |
| * @return {string} |
| */ |
| exports.stringify = function(value) { |
| var typeHint = type(value); |
| |
| if (!~['object', 'array', 'function'].indexOf(typeHint)) { |
| if (typeHint === 'buffer') { |
| var json = Buffer.prototype.toJSON.call(value); |
| // Based on the toJSON result |
| return jsonStringify( |
| json.data && json.type ? json.data : json, |
| 2 |
| ).replace(/,(\n|$)/g, '$1'); |
| } |
| |
| // IE7/IE8 has a bizarre String constructor; needs to be coerced |
| // into an array and back to obj. |
| if (typeHint === 'string' && typeof value === 'object') { |
| value = value.split('').reduce(function(acc, char, idx) { |
| acc[idx] = char; |
| return acc; |
| }, {}); |
| typeHint = 'object'; |
| } else { |
| return jsonStringify(value); |
| } |
| } |
| |
| for (var prop in value) { |
| if (Object.prototype.hasOwnProperty.call(value, prop)) { |
| return jsonStringify( |
| exports.canonicalize(value, null, typeHint), |
| 2 |
| ).replace(/,(\n|$)/g, '$1'); |
| } |
| } |
| |
| return emptyRepresentation(value, typeHint); |
| }; |
| |
| /** |
| * like JSON.stringify but more sense. |
| * |
| * @private |
| * @param {Object} object |
| * @param {number=} spaces |
| * @param {number=} depth |
| * @returns {*} |
| */ |
| function jsonStringify(object, spaces, depth) { |
| if (typeof spaces === 'undefined') { |
| // primitive types |
| return _stringify(object); |
| } |
| |
| depth = depth || 1; |
| var space = spaces * depth; |
| var str = Array.isArray(object) ? '[' : '{'; |
| var end = Array.isArray(object) ? ']' : '}'; |
| var length = |
| typeof object.length === 'number' |
| ? object.length |
| : Object.keys(object).length; |
| // `.repeat()` polyfill |
| function repeat(s, n) { |
| return new Array(n).join(s); |
| } |
| |
| function _stringify(val) { |
| switch (type(val)) { |
| case 'null': |
| case 'undefined': |
| val = '[' + val + ']'; |
| break; |
| case 'array': |
| case 'object': |
| val = jsonStringify(val, spaces, depth + 1); |
| break; |
| case 'boolean': |
| case 'regexp': |
| case 'symbol': |
| case 'number': |
| val = |
| val === 0 && 1 / val === -Infinity // `-0` |
| ? '-0' |
| : val.toString(); |
| break; |
| case 'date': |
| var sDate = isNaN(val.getTime()) ? val.toString() : val.toISOString(); |
| val = '[Date: ' + sDate + ']'; |
| break; |
| case 'buffer': |
| var json = val.toJSON(); |
| // Based on the toJSON result |
| json = json.data && json.type ? json.data : json; |
| val = '[Buffer: ' + jsonStringify(json, 2, depth + 1) + ']'; |
| break; |
| default: |
| val = |
| val === '[Function]' || val === '[Circular]' |
| ? val |
| : JSON.stringify(val); // string |
| } |
| return val; |
| } |
| |
| for (var i in object) { |
| if (!Object.prototype.hasOwnProperty.call(object, i)) { |
| continue; // not my business |
| } |
| --length; |
| str += |
| '\n ' + |
| repeat(' ', space) + |
| (Array.isArray(object) ? '' : '"' + i + '": ') + // key |
| _stringify(object[i]) + // value |
| (length ? ',' : ''); // comma |
| } |
| |
| return ( |
| str + |
| // [], {} |
| (str.length !== 1 ? '\n' + repeat(' ', --space) + end : end) |
| ); |
| } |
| |
| /** |
| * Return a new Thing that has the keys in sorted order. Recursive. |
| * |
| * If the Thing... |
| * - has already been seen, return string `'[Circular]'` |
| * - is `undefined`, return string `'[undefined]'` |
| * - is `null`, return value `null` |
| * - is some other primitive, return the value |
| * - is not a primitive or an `Array`, `Object`, or `Function`, return the value of the Thing's `toString()` method |
| * - is a non-empty `Array`, `Object`, or `Function`, return the result of calling this function again. |
| * - is an empty `Array`, `Object`, or `Function`, return the result of calling `emptyRepresentation()` |
| * |
| * @private |
| * @see {@link exports.stringify} |
| * @param {*} value Thing to inspect. May or may not have properties. |
| * @param {Array} [stack=[]] Stack of seen values |
| * @param {string} [typeHint] Type hint |
| * @return {(Object|Array|Function|string|undefined)} |
| */ |
| exports.canonicalize = function canonicalize(value, stack, typeHint) { |
| var canonicalizedObj; |
| /* eslint-disable no-unused-vars */ |
| var prop; |
| /* eslint-enable no-unused-vars */ |
| typeHint = typeHint || type(value); |
| function withStack(value, fn) { |
| stack.push(value); |
| fn(); |
| stack.pop(); |
| } |
| |
| stack = stack || []; |
| |
| if (stack.indexOf(value) !== -1) { |
| return '[Circular]'; |
| } |
| |
| switch (typeHint) { |
| case 'undefined': |
| case 'buffer': |
| case 'null': |
| canonicalizedObj = value; |
| break; |
| case 'array': |
| withStack(value, function() { |
| canonicalizedObj = value.map(function(item) { |
| return exports.canonicalize(item, stack); |
| }); |
| }); |
| break; |
| case 'function': |
| /* eslint-disable guard-for-in */ |
| for (prop in value) { |
| canonicalizedObj = {}; |
| break; |
| } |
| /* eslint-enable guard-for-in */ |
| if (!canonicalizedObj) { |
| canonicalizedObj = emptyRepresentation(value, typeHint); |
| break; |
| } |
| /* falls through */ |
| case 'object': |
| canonicalizedObj = canonicalizedObj || {}; |
| withStack(value, function() { |
| Object.keys(value) |
| .sort() |
| .forEach(function(key) { |
| canonicalizedObj[key] = exports.canonicalize(value[key], stack); |
| }); |
| }); |
| break; |
| case 'date': |
| case 'number': |
| case 'regexp': |
| case 'boolean': |
| case 'symbol': |
| canonicalizedObj = value; |
| break; |
| default: |
| canonicalizedObj = value + ''; |
| } |
| |
| return canonicalizedObj; |
| }; |
| |
| /** |
| * Determines if pathname has a matching file extension. |
| * |
| * @private |
| * @param {string} pathname - Pathname to check for match. |
| * @param {string[]} exts - List of file extensions (sans period). |
| * @return {boolean} whether file extension matches. |
| * @example |
| * hasMatchingExtname('foo.html', ['js', 'css']); // => false |
| */ |
| function hasMatchingExtname(pathname, exts) { |
| var suffix = path.extname(pathname).slice(1); |
| return exts.some(function(element) { |
| return suffix === element; |
| }); |
| } |
| |
| /** |
| * Determines if pathname would be a "hidden" file (or directory) on UN*X. |
| * |
| * @description |
| * On UN*X, pathnames beginning with a full stop (aka dot) are hidden during |
| * typical usage. Dotfiles, plain-text configuration files, are prime examples. |
| * |
| * @see {@link http://xahlee.info/UnixResource_dir/writ/unix_origin_of_dot_filename.html|Origin of Dot File Names} |
| * |
| * @private |
| * @param {string} pathname - Pathname to check for match. |
| * @return {boolean} whether pathname would be considered a hidden file. |
| * @example |
| * isHiddenOnUnix('.profile'); // => true |
| */ |
| function isHiddenOnUnix(pathname) { |
| return path.basename(pathname)[0] === '.'; |
| } |
| |
| /** |
| * Lookup file names at the given `path`. |
| * |
| * @description |
| * Filenames are returned in _traversal_ order by the OS/filesystem. |
| * **Make no assumption that the names will be sorted in any fashion.** |
| * |
| * @public |
| * @memberof Mocha.utils |
| * @param {string} filepath - Base path to start searching from. |
| * @param {string[]} [extensions=[]] - File extensions to look for. |
| * @param {boolean} [recursive=false] - Whether to recurse into subdirectories. |
| * @return {string[]} An array of paths. |
| * @throws {Error} if no files match pattern. |
| * @throws {TypeError} if `filepath` is directory and `extensions` not provided. |
| */ |
| exports.lookupFiles = function lookupFiles(filepath, extensions, recursive) { |
| extensions = extensions || []; |
| recursive = recursive || false; |
| var files = []; |
| var stat; |
| |
| if (!fs.existsSync(filepath)) { |
| var pattern; |
| if (glob.hasMagic(filepath)) { |
| // Handle glob as is without extensions |
| pattern = filepath; |
| } else { |
| // glob pattern e.g. 'filepath+(.js|.ts)' |
| var strExtensions = extensions |
| .map(function(v) { |
| return '.' + v; |
| }) |
| .join('|'); |
| pattern = filepath + '+(' + strExtensions + ')'; |
| } |
| files = glob.sync(pattern, {nodir: true}); |
| if (!files.length) { |
| throw createNoFilesMatchPatternError( |
| 'Cannot find any files matching pattern ' + exports.dQuote(filepath), |
| filepath |
| ); |
| } |
| return files; |
| } |
| |
| // Handle file |
| try { |
| stat = fs.statSync(filepath); |
| if (stat.isFile()) { |
| return filepath; |
| } |
| } catch (err) { |
| // ignore error |
| return; |
| } |
| |
| // Handle directory |
| fs.readdirSync(filepath).forEach(function(dirent) { |
| var pathname = path.join(filepath, dirent); |
| var stat; |
| |
| try { |
| stat = fs.statSync(pathname); |
| if (stat.isDirectory()) { |
| if (recursive) { |
| files = files.concat(lookupFiles(pathname, extensions, recursive)); |
| } |
| return; |
| } |
| } catch (err) { |
| // ignore error |
| return; |
| } |
| if (!extensions.length) { |
| throw createMissingArgumentError( |
| util.format( |
| 'Argument %s required when argument %s is a directory', |
| exports.sQuote('extensions'), |
| exports.sQuote('filepath') |
| ), |
| 'extensions', |
| 'array' |
| ); |
| } |
| |
| if ( |
| !stat.isFile() || |
| !hasMatchingExtname(pathname, extensions) || |
| isHiddenOnUnix(pathname) |
| ) { |
| return; |
| } |
| files.push(pathname); |
| }); |
| |
| return files; |
| }; |
| |
| /** |
| * process.emitWarning or a polyfill |
| * @see https://nodejs.org/api/process.html#process_process_emitwarning_warning_options |
| * @ignore |
| */ |
| function emitWarning(msg, type) { |
| if (process.emitWarning) { |
| process.emitWarning(msg, type); |
| } else { |
| process.nextTick(function() { |
| console.warn(type + ': ' + msg); |
| }); |
| } |
| } |
| |
| /** |
| * Show a deprecation warning. Each distinct message is only displayed once. |
| * Ignores empty messages. |
| * |
| * @param {string} [msg] - Warning to print |
| * @private |
| */ |
| exports.deprecate = function deprecate(msg) { |
| msg = String(msg); |
| if (msg && !deprecate.cache[msg]) { |
| deprecate.cache[msg] = true; |
| emitWarning(msg, 'DeprecationWarning'); |
| } |
| }; |
| exports.deprecate.cache = {}; |
| |
| /** |
| * Show a generic warning. |
| * Ignores empty messages. |
| * |
| * @param {string} [msg] - Warning to print |
| * @private |
| */ |
| exports.warn = function warn(msg) { |
| if (msg) { |
| emitWarning(msg); |
| } |
| }; |
| |
| /** |
| * @summary |
| * This Filter based on `mocha-clean` module.(see: `github.com/rstacruz/mocha-clean`) |
| * @description |
| * When invoking this function you get a filter function that get the Error.stack as an input, |
| * and return a prettify output. |
| * (i.e: strip Mocha and internal node functions from stack trace). |
| * @returns {Function} |
| */ |
| exports.stackTraceFilter = function() { |
| // TODO: Replace with `process.browser` |
| var is = typeof document === 'undefined' ? {node: true} : {browser: true}; |
| var slash = path.sep; |
| var cwd; |
| if (is.node) { |
| cwd = process.cwd() + slash; |
| } else { |
| cwd = (typeof location === 'undefined' |
| ? window.location |
| : location |
| ).href.replace(/\/[^/]*$/, '/'); |
| slash = '/'; |
| } |
| |
| function isMochaInternal(line) { |
| return ( |
| ~line.indexOf('node_modules' + slash + 'mocha' + slash) || |
| ~line.indexOf(slash + 'mocha.js') || |
| ~line.indexOf(slash + 'mocha.min.js') |
| ); |
| } |
| |
| function isNodeInternal(line) { |
| return ( |
| ~line.indexOf('(timers.js:') || |
| ~line.indexOf('(events.js:') || |
| ~line.indexOf('(node.js:') || |
| ~line.indexOf('(module.js:') || |
| ~line.indexOf('GeneratorFunctionPrototype.next (native)') || |
| false |
| ); |
| } |
| |
| return function(stack) { |
| stack = stack.split('\n'); |
| |
| stack = stack.reduce(function(list, line) { |
| if (isMochaInternal(line)) { |
| return list; |
| } |
| |
| if (is.node && isNodeInternal(line)) { |
| return list; |
| } |
| |
| // Clean up cwd(absolute) |
| if (/:\d+:\d+\)?$/.test(line)) { |
| line = line.replace('(' + cwd, '('); |
| } |
| |
| list.push(line); |
| return list; |
| }, []); |
| |
| return stack.join('\n'); |
| }; |
| }; |
| |
| /** |
| * Crude, but effective. |
| * @public |
| * @param {*} value |
| * @returns {boolean} Whether or not `value` is a Promise |
| */ |
| exports.isPromise = function isPromise(value) { |
| return ( |
| typeof value === 'object' && |
| value !== null && |
| typeof value.then === 'function' |
| ); |
| }; |
| |
| /** |
| * Clamps a numeric value to an inclusive range. |
| * |
| * @param {number} value - Value to be clamped. |
| * @param {numer[]} range - Two element array specifying [min, max] range. |
| * @returns {number} clamped value |
| */ |
| exports.clamp = function clamp(value, range) { |
| return Math.min(Math.max(value, range[0]), range[1]); |
| }; |
| |
| /** |
| * Single quote text by combining with undirectional ASCII quotation marks. |
| * |
| * @description |
| * Provides a simple means of markup for quoting text to be used in output. |
| * Use this to quote names of variables, methods, and packages. |
| * |
| * <samp>package 'foo' cannot be found</samp> |
| * |
| * @private |
| * @param {string} str - Value to be quoted. |
| * @returns {string} quoted value |
| * @example |
| * sQuote('n') // => 'n' |
| */ |
| exports.sQuote = function(str) { |
| return "'" + str + "'"; |
| }; |
| |
| /** |
| * Double quote text by combining with undirectional ASCII quotation marks. |
| * |
| * @description |
| * Provides a simple means of markup for quoting text to be used in output. |
| * Use this to quote names of datatypes, classes, pathnames, and strings. |
| * |
| * <samp>argument 'value' must be "string" or "number"</samp> |
| * |
| * @private |
| * @param {string} str - Value to be quoted. |
| * @returns {string} quoted value |
| * @example |
| * dQuote('number') // => "number" |
| */ |
| exports.dQuote = function(str) { |
| return '"' + str + '"'; |
| }; |
| |
| /** |
| * Provides simplistic message translation for dealing with plurality. |
| * |
| * @description |
| * Use this to create messages which need to be singular or plural. |
| * Some languages have several plural forms, so _complete_ message clauses |
| * are preferable to generating the message on the fly. |
| * |
| * @private |
| * @param {number} n - Non-negative integer |
| * @param {string} msg1 - Message to be used in English for `n = 1` |
| * @param {string} msg2 - Message to be used in English for `n = 0, 2, 3, ...` |
| * @returns {string} message corresponding to value of `n` |
| * @example |
| * var sprintf = require('util').format; |
| * var pkgs = ['one', 'two']; |
| * var msg = sprintf( |
| * ngettext( |
| * pkgs.length, |
| * 'cannot load package: %s', |
| * 'cannot load packages: %s' |
| * ), |
| * pkgs.map(sQuote).join(', ') |
| * ); |
| * console.log(msg); // => cannot load packages: 'one', 'two' |
| */ |
| exports.ngettext = function(n, msg1, msg2) { |
| if (typeof n === 'number' && n >= 0) { |
| return n === 1 ? msg1 : msg2; |
| } |
| }; |
| |
| /** |
| * It's a noop. |
| * @public |
| */ |
| exports.noop = function() {}; |
| |
| /** |
| * Creates a map-like object. |
| * |
| * @description |
| * A "map" is an object with no prototype, for our purposes. In some cases |
| * this would be more appropriate than a `Map`, especially if your environment |
| * doesn't support it. Recommended for use in Mocha's public APIs. |
| * |
| * @public |
| * @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map|MDN:Map} |
| * @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/create#Custom_and_Null_objects|MDN:Object.create - Custom objects} |
| * @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/assign|MDN:Object.assign} |
| * @param {...*} [obj] - Arguments to `Object.assign()`. |
| * @returns {Object} An object with no prototype, having `...obj` properties |
| */ |
| exports.createMap = function(obj) { |
| return assign.apply( |
| null, |
| [Object.create(null)].concat(Array.prototype.slice.call(arguments)) |
| ); |
| }; |
| |
| /** |
| * Creates a read-only map-like object. |
| * |
| * @description |
| * This differs from {@link module:utils.createMap createMap} only in that |
| * the argument must be non-empty, because the result is frozen. |
| * |
| * @see {@link module:utils.createMap createMap} |
| * @param {...*} [obj] - Arguments to `Object.assign()`. |
| * @returns {Object} A frozen object with no prototype, having `...obj` properties |
| * @throws {TypeError} if argument is not a non-empty object. |
| */ |
| exports.defineConstants = function(obj) { |
| if (type(obj) !== 'object' || !Object.keys(obj).length) { |
| throw new TypeError('Invalid argument; expected a non-empty object'); |
| } |
| return Object.freeze(exports.createMap(obj)); |
| }; |
| |
| }).call(this,require('_process'),require("buffer").Buffer) |
| },{"./errors":6,"_process":69,"buffer":43,"debug":45,"fs":42,"glob":42,"he":54,"object.assign":65,"path":42,"util":89}],39:[function(require,module,exports){ |
| 'use strict' |
| |
| exports.byteLength = byteLength |
| exports.toByteArray = toByteArray |
| exports.fromByteArray = fromByteArray |
| |
| var lookup = [] |
| var revLookup = [] |
| var Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array |
| |
| var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/' |
| for (var i = 0, len = code.length; i < len; ++i) { |
| lookup[i] = code[i] |
| revLookup[code.charCodeAt(i)] = i |
| } |
| |
| // Support decoding URL-safe base64 strings, as Node.js does. |
| // See: https://en.wikipedia.org/wiki/Base64#URL_applications |
| revLookup['-'.charCodeAt(0)] = 62 |
| revLookup['_'.charCodeAt(0)] = 63 |
| |
| function getLens (b64) { |
| var len = b64.length |
| |
| if (len % 4 > 0) { |
| throw new Error('Invalid string. Length must be a multiple of 4') |
| } |
| |
| // Trim off extra bytes after placeholder bytes are found |
| // See: https://github.com/beatgammit/base64-js/issues/42 |
| var validLen = b64.indexOf('=') |
| if (validLen === -1) validLen = len |
| |
| var placeHoldersLen = validLen === len |
| ? 0 |
| : 4 - (validLen % 4) |
| |
| return [validLen, placeHoldersLen] |
| } |
| |
| // base64 is 4/3 + up to two characters of the original data |
| function byteLength (b64) { |
| var lens = getLens(b64) |
| var validLen = lens[0] |
| var placeHoldersLen = lens[1] |
| return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen |
| } |
| |
| function _byteLength (b64, validLen, placeHoldersLen) { |
| return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen |
| } |
| |
| function toByteArray (b64) { |
| var tmp |
| var lens = getLens(b64) |
| var validLen = lens[0] |
| var placeHoldersLen = lens[1] |
| |
| var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen)) |
| |
| var curByte = 0 |
| |
| // if there are placeholders, only get up to the last complete 4 chars |
| var len = placeHoldersLen > 0 |
| ? validLen - 4 |
| : validLen |
| |
| for (var i = 0; i < len; i += 4) { |
| tmp = |
| (revLookup[b64.charCodeAt(i)] << 18) | |
| (revLookup[b64.charCodeAt(i + 1)] << 12) | |
| (revLookup[b64.charCodeAt(i + 2)] << 6) | |
| revLookup[b64.charCodeAt(i + 3)] |
| arr[curByte++] = (tmp >> 16) & 0xFF |
| arr[curByte++] = (tmp >> 8) & 0xFF |
| arr[curByte++] = tmp & 0xFF |
| } |
| |
| if (placeHoldersLen === 2) { |
| tmp = |
| (revLookup[b64.charCodeAt(i)] << 2) | |
| (revLookup[b64.charCodeAt(i + 1)] >> 4) |
| arr[curByte++] = tmp & 0xFF |
| } |
| |
| if (placeHoldersLen === 1) { |
| tmp = |
| (revLookup[b64.charCodeAt(i)] << 10) | |
| (revLookup[b64.charCodeAt(i + 1)] << 4) | |
| (revLookup[b64.charCodeAt(i + 2)] >> 2) |
| arr[curByte++] = (tmp >> 8) & 0xFF |
| arr[curByte++] = tmp & 0xFF |
| } |
| |
| return arr |
| } |
| |
| function tripletToBase64 (num) { |
| return lookup[num >> 18 & 0x3F] + |
| lookup[num >> 12 & 0x3F] + |
| lookup[num >> 6 & 0x3F] + |
| lookup[num & 0x3F] |
| } |
| |
| function encodeChunk (uint8, start, end) { |
| var tmp |
| var output = [] |
| for (var i = start; i < end; i += 3) { |
| tmp = |
| ((uint8[i] << 16) & 0xFF0000) + |
| ((uint8[i + 1] << 8) & 0xFF00) + |
| (uint8[i + 2] & 0xFF) |
| output.push(tripletToBase64(tmp)) |
| } |
| return output.join('') |
| } |
| |
| function fromByteArray (uint8) { |
| var tmp |
| var len = uint8.length |
| var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes |
| var parts = [] |
| var maxChunkLength = 16383 // must be multiple of 3 |
| |
| // go through the array every three bytes, we'll deal with trailing stuff later |
| for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) { |
| parts.push(encodeChunk( |
| uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength) |
| )) |
| } |
| |
| // pad the end with zeros, but make sure to not forget the extra bytes |
| if (extraBytes === 1) { |
| tmp = uint8[len - 1] |
| parts.push( |
| lookup[tmp >> 2] + |
| lookup[(tmp << 4) & 0x3F] + |
| '==' |
| ) |
| } else if (extraBytes === 2) { |
| tmp = (uint8[len - 2] << 8) + uint8[len - 1] |
| parts.push( |
| lookup[tmp >> 10] + |
| lookup[(tmp >> 4) & 0x3F] + |
| lookup[(tmp << 2) & 0x3F] + |
| '=' |
| ) |
| } |
| |
| return parts.join('') |
| } |
| |
| },{}],40:[function(require,module,exports){ |
| |
| },{}],41:[function(require,module,exports){ |
| (function (process){ |
| var WritableStream = require('stream').Writable |
| var inherits = require('util').inherits |
| |
| module.exports = BrowserStdout |
| |
| |
| inherits(BrowserStdout, WritableStream) |
| |
| function BrowserStdout(opts) { |
| if (!(this instanceof BrowserStdout)) return new BrowserStdout(opts) |
| |
| opts = opts || {} |
| WritableStream.call(this, opts) |
| this.label = (opts.label !== undefined) ? opts.label : 'stdout' |
| } |
| |
| BrowserStdout.prototype._write = function(chunks, encoding, cb) { |
| var output = chunks.toString ? chunks.toString() : chunks |
| if (this.label === false) { |
| console.log(output) |
| } else { |
| console.log(this.label+':', output) |
| } |
| process.nextTick(cb) |
| } |
| |
| }).call(this,require('_process')) |
| },{"_process":69,"stream":84,"util":89}],42:[function(require,module,exports){ |
| arguments[4][40][0].apply(exports,arguments) |
| },{"dup":40}],43:[function(require,module,exports){ |
| (function (Buffer){ |
| /*! |
| * The buffer module from node.js, for the browser. |
| * |
| * @author Feross Aboukhadijeh <https://feross.org> |
| * @license MIT |
| */ |
| /* eslint-disable no-proto */ |
| |
| 'use strict' |
| |
| var base64 = require('base64-js') |
| var ieee754 = require('ieee754') |
| |
| exports.Buffer = Buffer |
| exports.SlowBuffer = SlowBuffer |
| exports.INSPECT_MAX_BYTES = 50 |
| |
| var K_MAX_LENGTH = 0x7fffffff |
| exports.kMaxLength = K_MAX_LENGTH |
| |
| /** |
| * If `Buffer.TYPED_ARRAY_SUPPORT`: |
| * === true Use Uint8Array implementation (fastest) |
| * === false Print warning and recommend using `buffer` v4.x which has an Object |
| * implementation (most compatible, even IE6) |
| * |
| * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+, |
| * Opera 11.6+, iOS 4.2+. |
| * |
| * We report that the browser does not support typed arrays if the are not subclassable |
| * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array` |
| * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support |
| * for __proto__ and has a buggy typed array implementation. |
| */ |
| Buffer.TYPED_ARRAY_SUPPORT = typedArraySupport() |
| |
| if (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' && |
| typeof console.error === 'function') { |
| console.error( |
| 'This browser lacks typed array (Uint8Array) support which is required by ' + |
| '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.' |
| ) |
| } |
| |
| function typedArraySupport () { |
| // Can typed array instances can be augmented? |
| try { |
| var arr = new Uint8Array(1) |
| arr.__proto__ = { __proto__: Uint8Array.prototype, foo: function () { return 42 } } |
| return arr.foo() === 42 |
| } catch (e) { |
| return false |
| } |
| } |
| |
| Object.defineProperty(Buffer.prototype, 'parent', { |
| enumerable: true, |
| get: function () { |
| if (!Buffer.isBuffer(this)) return undefined |
| return this.buffer |
| } |
| }) |
| |
| Object.defineProperty(Buffer.prototype, 'offset', { |
| enumerable: true, |
| get: function () { |
| if (!Buffer.isBuffer(this)) return undefined |
| return this.byteOffset |
| } |
| }) |
| |
| function createBuffer (length) { |
| if (length > K_MAX_LENGTH) { |
| throw new RangeError('The value "' + length + '" is invalid for option "size"') |
| } |
| // Return an augmented `Uint8Array` instance |
| var buf = new Uint8Array(length) |
| buf.__proto__ = Buffer.prototype |
| return buf |
| } |
| |
| /** |
| * The Buffer constructor returns instances of `Uint8Array` that have their |
| * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of |
| * `Uint8Array`, so the returned instances will have all the node `Buffer` methods |
| * and the `Uint8Array` methods. Square bracket notation works as expected -- it |
| * returns a single octet. |
| * |
| * The `Uint8Array` prototype remains unmodified. |
| */ |
| |
| function Buffer (arg, encodingOrOffset, length) { |
| // Common case. |
| if (typeof arg === 'number') { |
| if (typeof encodingOrOffset === 'string') { |
| throw new TypeError( |
| 'The "string" argument must be of type string. Received type number' |
| ) |
| } |
| return allocUnsafe(arg) |
| } |
| return from(arg, encodingOrOffset, length) |
| } |
| |
| // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97 |
| if (typeof Symbol !== 'undefined' && Symbol.species != null && |
| Buffer[Symbol.species] === Buffer) { |
| Object.defineProperty(Buffer, Symbol.species, { |
| value: null, |
| configurable: true, |
| enumerable: false, |
| writable: false |
| }) |
| } |
| |
| Buffer.poolSize = 8192 // not used by this implementation |
| |
| function from (value, encodingOrOffset, length) { |
| if (typeof value === 'string') { |
| return fromString(value, encodingOrOffset) |
| } |
| |
| if (ArrayBuffer.isView(value)) { |
| return fromArrayLike(value) |
| } |
| |
| if (value == null) { |
| throw TypeError( |
| 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' + |
| 'or Array-like Object. Received type ' + (typeof value) |
| ) |
| } |
| |
| if (isInstance(value, ArrayBuffer) || |
| (value && isInstance(value.buffer, ArrayBuffer))) { |
| return fromArrayBuffer(value, encodingOrOffset, length) |
| } |
| |
| if (typeof value === 'number') { |
| throw new TypeError( |
| 'The "value" argument must not be of type number. Received type number' |
| ) |
| } |
| |
| var valueOf = value.valueOf && value.valueOf() |
| if (valueOf != null && valueOf !== value) { |
| return Buffer.from(valueOf, encodingOrOffset, length) |
| } |
| |
| var b = fromObject(value) |
| if (b) return b |
| |
| if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null && |
| typeof value[Symbol.toPrimitive] === 'function') { |
| return Buffer.from( |
| value[Symbol.toPrimitive]('string'), encodingOrOffset, length |
| ) |
| } |
| |
| throw new TypeError( |
| 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' + |
| 'or Array-like Object. Received type ' + (typeof value) |
| ) |
| } |
| |
| /** |
| * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError |
| * if value is a number. |
| * Buffer.from(str[, encoding]) |
| * Buffer.from(array) |
| * Buffer.from(buffer) |
| * Buffer.from(arrayBuffer[, byteOffset[, length]]) |
| **/ |
| Buffer.from = function (value, encodingOrOffset, length) { |
| return from(value, encodingOrOffset, length) |
| } |
| |
| // Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug: |
| // https://github.com/feross/buffer/pull/148 |
| Buffer.prototype.__proto__ = Uint8Array.prototype |
| Buffer.__proto__ = Uint8Array |
| |
| function assertSize (size) { |
| if (typeof size !== 'number') { |
| throw new TypeError('"size" argument must be of type number') |
| } else if (size < 0) { |
| throw new RangeError('The value "' + size + '" is invalid for option "size"') |
| } |
| } |
| |
| function alloc (size, fill, encoding) { |
| assertSize(size) |
| if (size <= 0) { |
| return createBuffer(size) |
| } |
| if (fill !== undefined) { |
| // Only pay attention to encoding if it's a string. This |
| // prevents accidentally sending in a number that would |
| // be interpretted as a start offset. |
| return typeof encoding === 'string' |
| ? createBuffer(size).fill(fill, encoding) |
| : createBuffer(size).fill(fill) |
| } |
| return createBuffer(size) |
| } |
| |
| /** |
| * Creates a new filled Buffer instance. |
| * alloc(size[, fill[, encoding]]) |
| **/ |
| Buffer.alloc = function (size, fill, encoding) { |
| return alloc(size, fill, encoding) |
| } |
| |
| function allocUnsafe (size) { |
| assertSize(size) |
| return createBuffer(size < 0 ? 0 : checked(size) | 0) |
| } |
| |
| /** |
| * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance. |
| * */ |
| Buffer.allocUnsafe = function (size) { |
| return allocUnsafe(size) |
| } |
| /** |
| * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance. |
| */ |
| Buffer.allocUnsafeSlow = function (size) { |
| return allocUnsafe(size) |
| } |
| |
| function fromString (string, encoding) { |
| if (typeof encoding !== 'string' || encoding === '') { |
| encoding = 'utf8' |
| } |
| |
| if (!Buffer.isEncoding(encoding)) { |
| throw new TypeError('Unknown encoding: ' + encoding) |
| } |
| |
| var length = byteLength(string, encoding) | 0 |
| var buf = createBuffer(length) |
| |
| var actual = buf.write(string, encoding) |
| |
| if (actual !== length) { |
| // Writing a hex string, for example, that contains invalid characters will |
| // cause everything after the first invalid character to be ignored. (e.g. |
| // 'abxxcd' will be treated as 'ab') |
| buf = buf.slice(0, actual) |
| } |
| |
| return buf |
| } |
| |
| function fromArrayLike (array) { |
| var length = array.length < 0 ? 0 : checked(array.length) | 0 |
| var buf = createBuffer(length) |
| for (var i = 0; i < length; i += 1) { |
| buf[i] = array[i] & 255 |
| } |
| return buf |
| } |
| |
| function fromArrayBuffer (array, byteOffset, length) { |
| if (byteOffset < 0 || array.byteLength < byteOffset) { |
| throw new RangeError('"offset" is outside of buffer bounds') |
| } |
| |
| if (array.byteLength < byteOffset + (length || 0)) { |
| throw new RangeError('"length" is outside of buffer bounds') |
| } |
| |
| var buf |
| if (byteOffset === undefined && length === undefined) { |
| buf = new Uint8Array(array) |
| } else if (length === undefined) { |
| buf = new Uint8Array(array, byteOffset) |
| } else { |
| buf = new Uint8Array(array, byteOffset, length) |
| } |
| |
| // Return an augmented `Uint8Array` instance |
| buf.__proto__ = Buffer.prototype |
| return buf |
| } |
| |
| function fromObject (obj) { |
| if (Buffer.isBuffer(obj)) { |
| var len = checked(obj.length) | 0 |
| var buf = createBuffer(len) |
| |
| if (buf.length === 0) { |
| return buf |
| } |
| |
| obj.copy(buf, 0, 0, len) |
| return buf |
| } |
| |
| if (obj.length !== undefined) { |
| if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) { |
| return createBuffer(0) |
| } |
| return fromArrayLike(obj) |
| } |
| |
| if (obj.type === 'Buffer' && Array.isArray(obj.data)) { |
| return fromArrayLike(obj.data) |
| } |
| } |
| |
| function checked (length) { |
| // Note: cannot use `length < K_MAX_LENGTH` here because that fails when |
| // length is NaN (which is otherwise coerced to zero.) |
| if (length >= K_MAX_LENGTH) { |
| throw new RangeError('Attempt to allocate Buffer larger than maximum ' + |
| 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes') |
| } |
| return length | 0 |
| } |
| |
| function SlowBuffer (length) { |
| if (+length != length) { // eslint-disable-line eqeqeq |
| length = 0 |
| } |
| return Buffer.alloc(+length) |
| } |
| |
| Buffer.isBuffer = function isBuffer (b) { |
| return b != null && b._isBuffer === true && |
| b !== Buffer.prototype // so Buffer.isBuffer(Buffer.prototype) will be false |
| } |
| |
| Buffer.compare = function compare (a, b) { |
| if (isInstance(a, Uint8Array)) a = Buffer.from(a, a.offset, a.byteLength) |
| if (isInstance(b, Uint8Array)) b = Buffer.from(b, b.offset, b.byteLength) |
| if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) { |
| throw new TypeError( |
| 'The "buf1", "buf2" arguments must be one of type Buffer or Uint8Array' |
| ) |
| } |
| |
| if (a === b) return 0 |
| |
| var x = a.length |
| var y = b.length |
| |
| for (var i = 0, len = Math.min(x, y); i < len; ++i) { |
| if (a[i] !== b[i]) { |
| x = a[i] |
| y = b[i] |
| break |
| } |
| } |
| |
| if (x < y) return -1 |
| if (y < x) return 1 |
| return 0 |
| } |
| |
| Buffer.isEncoding = function isEncoding (encoding) { |
| switch (String(encoding).toLowerCase()) { |
| case 'hex': |
| case 'utf8': |
| case 'utf-8': |
| case 'ascii': |
| case 'latin1': |
| case 'binary': |
| case 'base64': |
| case 'ucs2': |
| case 'ucs-2': |
| case 'utf16le': |
| case 'utf-16le': |
| return true |
| default: |
| return false |
| } |
| } |
| |
| Buffer.concat = function concat (list, length) { |
| if (!Array.isArray(list)) { |
| throw new TypeError('"list" argument must be an Array of Buffers') |
| } |
| |
| if (list.length === 0) { |
| return Buffer.alloc(0) |
| } |
| |
| var i |
| if (length === undefined) { |
| length = 0 |
| for (i = 0; i < list.length; ++i) { |
| length += list[i].length |
| } |
| } |
| |
| var buffer = Buffer.allocUnsafe(length) |
| var pos = 0 |
| for (i = 0; i < list.length; ++i) { |
| var buf = list[i] |
| if (isInstance(buf, Uint8Array)) { |
| buf = Buffer.from(buf) |
| } |
| if (!Buffer.isBuffer(buf)) { |
| throw new TypeError('"list" argument must be an Array of Buffers') |
| } |
| buf.copy(buffer, pos) |
| pos += buf.length |
| } |
| return buffer |
| } |
| |
| function byteLength (string, encoding) { |
| if (Buffer.isBuffer(string)) { |
| return string.length |
| } |
| if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) { |
| return string.byteLength |
| } |
| if (typeof string !== 'string') { |
| throw new TypeError( |
| 'The "string" argument must be one of type string, Buffer, or ArrayBuffer. ' + |
| 'Received type ' + typeof string |
| ) |
| } |
| |
| var len = string.length |
| var mustMatch = (arguments.length > 2 && arguments[2] === true) |
| if (!mustMatch && len === 0) return 0 |
| |
| // Use a for loop to avoid recursion |
| var loweredCase = false |
| for (;;) { |
| switch (encoding) { |
| case 'ascii': |
| case 'latin1': |
| case 'binary': |
| return len |
| case 'utf8': |
| case 'utf-8': |
| return utf8ToBytes(string).length |
| case 'ucs2': |
| case 'ucs-2': |
| case 'utf16le': |
| case 'utf-16le': |
| return len * 2 |
| case 'hex': |
| return len >>> 1 |
| case 'base64': |
| return base64ToBytes(string).length |
| default: |
| if (loweredCase) { |
| return mustMatch ? -1 : utf8ToBytes(string).length // assume utf8 |
| } |
| encoding = ('' + encoding).toLowerCase() |
| loweredCase = true |
| } |
| } |
| } |
| Buffer.byteLength = byteLength |
| |
| function slowToString (encoding, start, end) { |
| var loweredCase = false |
| |
| // No need to verify that "this.length <= MAX_UINT32" since it's a read-only |
| // property of a typed array. |
| |
| // This behaves neither like String nor Uint8Array in that we set start/end |
| // to their upper/lower bounds if the value passed is out of range. |
| // undefined is handled specially as per ECMA-262 6th Edition, |
| // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization. |
| if (start === undefined || start < 0) { |
| start = 0 |
| } |
| // Return early if start > this.length. Done here to prevent potential uint32 |
| // coercion fail below. |
| if (start > this.length) { |
| return '' |
| } |
| |
| if (end === undefined || end > this.length) { |
| end = this.length |
| } |
| |
| if (end <= 0) { |
| return '' |
| } |
| |
| // Force coersion to uint32. This will also coerce falsey/NaN values to 0. |
| end >>>= 0 |
| start >>>= 0 |
| |
| if (end <= start) { |
| return '' |
| } |
| |
| if (!encoding) encoding = 'utf8' |
| |
| while (true) { |
| switch (encoding) { |
| case 'hex': |
| return hexSlice(this, start, end) |
| |
| case 'utf8': |
| case 'utf-8': |
| return utf8Slice(this, start, end) |
| |
| case 'ascii': |
| return asciiSlice(this, start, end) |
| |
| case 'latin1': |
| case 'binary': |
| return latin1Slice(this, start, end) |
| |
| case 'base64': |
| return base64Slice(this, start, end) |
| |
| case 'ucs2': |
| case 'ucs-2': |
| case 'utf16le': |
| case 'utf-16le': |
| return utf16leSlice(this, start, end) |
| |
| default: |
| if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) |
| encoding = (encoding + '').toLowerCase() |
| loweredCase = true |
| } |
| } |
| } |
| |
| // This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package) |
| // to detect a Buffer instance. It's not possible to use `instanceof Buffer` |
| // reliably in a browserify context because there could be multiple different |
| // copies of the 'buffer' package in use. This method works even for Buffer |
| // instances that were created from another copy of the `buffer` package. |
| // See: https://github.com/feross/buffer/issues/154 |
| Buffer.prototype._isBuffer = true |
| |
| function swap (b, n, m) { |
| var i = b[n] |
| b[n] = b[m] |
| b[m] = i |
| } |
| |
| Buffer.prototype.swap16 = function swap16 () { |
| var len = this.length |
| if (len % 2 !== 0) { |
| throw new RangeError('Buffer size must be a multiple of 16-bits') |
| } |
| for (var i = 0; i < len; i += 2) { |
| swap(this, i, i + 1) |
| } |
| return this |
| } |
| |
| Buffer.prototype.swap32 = function swap32 () { |
| var len = this.length |
| if (len % 4 !== 0) { |
| throw new RangeError('Buffer size must be a multiple of 32-bits') |
| } |
| for (var i = 0; i < len; i += 4) { |
| swap(this, i, i + 3) |
| swap(this, i + 1, i + 2) |
| } |
| return this |
| } |
| |
| Buffer.prototype.swap64 = function swap64 () { |
| var len = this.length |
| if (len % 8 !== 0) { |
| throw new RangeError('Buffer size must be a multiple of 64-bits') |
| } |
| for (var i = 0; i < len; i += 8) { |
| swap(this, i, i + 7) |
| swap(this, i + 1, i + 6) |
| swap(this, i + 2, i + 5) |
| swap(this, i + 3, i + 4) |
| } |
| return this |
| } |
| |
| Buffer.prototype.toString = function toString () { |
| var length = this.length |
| if (length === 0) return '' |
| if (arguments.length === 0) return utf8Slice(this, 0, length) |
| return slowToString.apply(this, arguments) |
| } |
| |
| Buffer.prototype.toLocaleString = Buffer.prototype.toString |
| |
| Buffer.prototype.equals = function equals (b) { |
| if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer') |
| if (this === b) return true |
| return Buffer.compare(this, b) === 0 |
| } |
| |
| Buffer.prototype.inspect = function inspect () { |
| var str = '' |
| var max = exports.INSPECT_MAX_BYTES |
| str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim() |
| if (this.length > max) str += ' ... ' |
| return '<Buffer ' + str + '>' |
| } |
| |
| Buffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) { |
| if (isInstance(target, Uint8Array)) { |
| target = Buffer.from(target, target.offset, target.byteLength) |
| } |
| if (!Buffer.isBuffer(target)) { |
| throw new TypeError( |
| 'The "target" argument must be one of type Buffer or Uint8Array. ' + |
| 'Received type ' + (typeof target) |
| ) |
| } |
| |
| if (start === undefined) { |
| start = 0 |
| } |
| if (end === undefined) { |
| end = target ? target.length : 0 |
| } |
| if (thisStart === undefined) { |
| thisStart = 0 |
| } |
| if (thisEnd === undefined) { |
| thisEnd = this.length |
| } |
| |
| if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) { |
| throw new RangeError('out of range index') |
| } |
| |
| if (thisStart >= thisEnd && start >= end) { |
| return 0 |
| } |
| if (thisStart >= thisEnd) { |
| return -1 |
| } |
| if (start >= end) { |
| return 1 |
| } |
| |
| start >>>= 0 |
| end >>>= 0 |
| thisStart >>>= 0 |
| thisEnd >>>= 0 |
| |
| if (this === target) return 0 |
| |
| var x = thisEnd - thisStart |
| var y = end - start |
| var len = Math.min(x, y) |
| |
| var thisCopy = this.slice(thisStart, thisEnd) |
| var targetCopy = target.slice(start, end) |
| |
| for (var i = 0; i < len; ++i) { |
| if (thisCopy[i] !== targetCopy[i]) { |
| x = thisCopy[i] |
| y = targetCopy[i] |
| break |
| } |
| } |
| |
| if (x < y) return -1 |
| if (y < x) return 1 |
| return 0 |
| } |
| |
| // Finds either the first index of `val` in `buffer` at offset >= `byteOffset`, |
| // OR the last index of `val` in `buffer` at offset <= `byteOffset`. |
| // |
| // Arguments: |
| // - buffer - a Buffer to search |
| // - val - a string, Buffer, or number |
| // - byteOffset - an index into `buffer`; will be clamped to an int32 |
| // - encoding - an optional encoding, relevant is val is a string |
| // - dir - true for indexOf, false for lastIndexOf |
| function bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) { |
| // Empty buffer means no match |
| if (buffer.length === 0) return -1 |
| |
| // Normalize byteOffset |
| if (typeof byteOffset === 'string') { |
| encoding = byteOffset |
| byteOffset = 0 |
| } else if (byteOffset > 0x7fffffff) { |
| byteOffset = 0x7fffffff |
| } else if (byteOffset < -0x80000000) { |
| byteOffset = -0x80000000 |
| } |
| byteOffset = +byteOffset // Coerce to Number. |
| if (numberIsNaN(byteOffset)) { |
| // byteOffset: it it's undefined, null, NaN, "foo", etc, search whole buffer |
| byteOffset = dir ? 0 : (buffer.length - 1) |
| } |
| |
| // Normalize byteOffset: negative offsets start from the end of the buffer |
| if (byteOffset < 0) byteOffset = buffer.length + byteOffset |
| if (byteOffset >= buffer.length) { |
| if (dir) return -1 |
| else byteOffset = buffer.length - 1 |
| } else if (byteOffset < 0) { |
| if (dir) byteOffset = 0 |
| else return -1 |
| } |
| |
| // Normalize val |
| if (typeof val === 'string') { |
| val = Buffer.from(val, encoding) |
| } |
| |
| // Finally, search either indexOf (if dir is true) or lastIndexOf |
| if (Buffer.isBuffer(val)) { |
| // Special case: looking for empty string/buffer always fails |
| if (val.length === 0) { |
| return -1 |
| } |
| return arrayIndexOf(buffer, val, byteOffset, encoding, dir) |
| } else if (typeof val === 'number') { |
| val = val & 0xFF // Search for a byte value [0-255] |
| if (typeof Uint8Array.prototype.indexOf === 'function') { |
| if (dir) { |
| return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset) |
| } else { |
| return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset) |
| } |
| } |
| return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir) |
| } |
| |
| throw new TypeError('val must be string, number or Buffer') |
| } |
| |
| function arrayIndexOf (arr, val, byteOffset, encoding, dir) { |
| var indexSize = 1 |
| var arrLength = arr.length |
| var valLength = val.length |
| |
| if (encoding !== undefined) { |
| encoding = String(encoding).toLowerCase() |
| if (encoding === 'ucs2' || encoding === 'ucs-2' || |
| encoding === 'utf16le' || encoding === 'utf-16le') { |
| if (arr.length < 2 || val.length < 2) { |
| return -1 |
| } |
| indexSize = 2 |
| arrLength /= 2 |
| valLength /= 2 |
| byteOffset /= 2 |
| } |
| } |
| |
| function read (buf, i) { |
| if (indexSize === 1) { |
| return buf[i] |
| } else { |
| return buf.readUInt16BE(i * indexSize) |
| } |
| } |
| |
| var i |
| if (dir) { |
| var foundIndex = -1 |
| for (i = byteOffset; i < arrLength; i++) { |
| if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) { |
| if (foundIndex === -1) foundIndex = i |
| if (i - foundIndex + 1 === valLength) return foundIndex * indexSize |
| } else { |
| if (foundIndex !== -1) i -= i - foundIndex |
| foundIndex = -1 |
| } |
| } |
| } else { |
| if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength |
| for (i = byteOffset; i >= 0; i--) { |
| var found = true |
| for (var j = 0; j < valLength; j++) { |
| if (read(arr, i + j) !== read(val, j)) { |
| found = false |
| break |
| } |
| } |
| if (found) return i |
| } |
| } |
| |
| return -1 |
| } |
| |
| Buffer.prototype.includes = function includes (val, byteOffset, encoding) { |
| return this.indexOf(val, byteOffset, encoding) !== -1 |
| } |
| |
| Buffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) { |
| return bidirectionalIndexOf(this, val, byteOffset, encoding, true) |
| } |
| |
| Buffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) { |
| return bidirectionalIndexOf(this, val, byteOffset, encoding, false) |
| } |
| |
| function hexWrite (buf, string, offset, length) { |
| offset = Number(offset) || 0 |
| var remaining = buf.length - offset |
| if (!length) { |
| length = remaining |
| } else { |
| length = Number(length) |
| if (length > remaining) { |
| length = remaining |
| } |
| } |
| |
| var strLen = string.length |
| |
| if (length > strLen / 2) { |
| length = strLen / 2 |
| } |
| for (var i = 0; i < length; ++i) { |
| var parsed = parseInt(string.substr(i * 2, 2), 16) |
| if (numberIsNaN(parsed)) return i |
| buf[offset + i] = parsed |
| } |
| return i |
| } |
| |
| function utf8Write (buf, string, offset, length) { |
| return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length) |
| } |
| |
| function asciiWrite (buf, string, offset, length) { |
| return blitBuffer(asciiToBytes(string), buf, offset, length) |
| } |
| |
| function latin1Write (buf, string, offset, length) { |
| return asciiWrite(buf, string, offset, length) |
| } |
| |
| function base64Write (buf, string, offset, length) { |
| return blitBuffer(base64ToBytes(string), buf, offset, length) |
| } |
| |
| function ucs2Write (buf, string, offset, length) { |
| return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length) |
| } |
| |
| Buffer.prototype.write = function write (string, offset, length, encoding) { |
| // Buffer#write(string) |
| if (offset === undefined) { |
| encoding = 'utf8' |
| length = this.length |
| offset = 0 |
| // Buffer#write(string, encoding) |
| } else if (length === undefined && typeof offset === 'string') { |
| encoding = offset |
| length = this.length |
| offset = 0 |
| // Buffer#write(string, offset[, length][, encoding]) |
| } else if (isFinite(offset)) { |
| offset = offset >>> 0 |
| if (isFinite(length)) { |
| length = length >>> 0 |
| if (encoding === undefined) encoding = 'utf8' |
| } else { |
| encoding = length |
| length = undefined |
| } |
| } else { |
| throw new Error( |
| 'Buffer.write(string, encoding, offset[, length]) is no longer supported' |
| ) |
| } |
| |
| var remaining = this.length - offset |
| if (length === undefined || length > remaining) length = remaining |
| |
| if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) { |
| throw new RangeError('Attempt to write outside buffer bounds') |
| } |
| |
| if (!encoding) encoding = 'utf8' |
| |
| var loweredCase = false |
| for (;;) { |
| switch (encoding) { |
| case 'hex': |
| return hexWrite(this, string, offset, length) |
| |
| case 'utf8': |
| case 'utf-8': |
| return utf8Write(this, string, offset, length) |
| |
| case 'ascii': |
| return asciiWrite(this, string, offset, length) |
| |
| case 'latin1': |
| case 'binary': |
| return latin1Write(this, string, offset, length) |
| |
| case 'base64': |
| // Warning: maxLength not taken into account in base64Write |
| return base64Write(this, string, offset, length) |
| |
| case 'ucs2': |
| case 'ucs-2': |
| case 'utf16le': |
| case 'utf-16le': |
| return ucs2Write(this, string, offset, length) |
| |
| default: |
| if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) |
| encoding = ('' + encoding).toLowerCase() |
| loweredCase = true |
| } |
| } |
| } |
| |
| Buffer.prototype.toJSON = function toJSON () { |
| return { |
| type: 'Buffer', |
| data: Array.prototype.slice.call(this._arr || this, 0) |
| } |
| } |
| |
| function base64Slice (buf, start, end) { |
| if (start === 0 && end === buf.length) { |
| return base64.fromByteArray(buf) |
| } else { |
| return base64.fromByteArray(buf.slice(start, end)) |
| } |
| } |
| |
| function utf8Slice (buf, start, end) { |
| end = Math.min(buf.length, end) |
| var res = [] |
| |
| var i = start |
| while (i < end) { |
| var firstByte = buf[i] |
| var codePoint = null |
| var bytesPerSequence = (firstByte > 0xEF) ? 4 |
| : (firstByte > 0xDF) ? 3 |
| : (firstByte > 0xBF) ? 2 |
| : 1 |
| |
| if (i + bytesPerSequence <= end) { |
| var secondByte, thirdByte, fourthByte, tempCodePoint |
| |
| switch (bytesPerSequence) { |
| case 1: |
| if (firstByte < 0x80) { |
| codePoint = firstByte |
| } |
| break |
| case 2: |
| secondByte = buf[i + 1] |
| if ((secondByte & 0xC0) === 0x80) { |
| tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F) |
| if (tempCodePoint > 0x7F) { |
| codePoint = tempCodePoint |
| } |
| } |
| break |
| case 3: |
| secondByte = buf[i + 1] |
| thirdByte = buf[i + 2] |
| if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) { |
| tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F) |
| if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) { |
| codePoint = tempCodePoint |
| } |
| } |
| break |
| case 4: |
| secondByte = buf[i + 1] |
| thirdByte = buf[i + 2] |
| fourthByte = buf[i + 3] |
| if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) { |
| tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F) |
| if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) { |
| codePoint = tempCodePoint |
| } |
| } |
| } |
| } |
| |
| if (codePoint === null) { |
| // we did not generate a valid codePoint so insert a |
| // replacement char (U+FFFD) and advance only 1 byte |
| codePoint = 0xFFFD |
| bytesPerSequence = 1 |
| } else if (codePoint > 0xFFFF) { |
| // encode to utf16 (surrogate pair dance) |
| codePoint -= 0x10000 |
| res.push(codePoint >>> 10 & 0x3FF | 0xD800) |
| codePoint = 0xDC00 | codePoint & 0x3FF |
| } |
| |
| res.push(codePoint) |
| i += bytesPerSequence |
| } |
| |
| return decodeCodePointsArray(res) |
| } |
| |
| // Based on http://stackoverflow.com/a/22747272/680742, the browser with |
| // the lowest limit is Chrome, with 0x10000 args. |
| // We go 1 magnitude less, for safety |
| var MAX_ARGUMENTS_LENGTH = 0x1000 |
| |
| function decodeCodePointsArray (codePoints) { |
| var len = codePoints.length |
| if (len <= MAX_ARGUMENTS_LENGTH) { |
| return String.fromCharCode.apply(String, codePoints) // avoid extra slice() |
| } |
| |
| // Decode in chunks to avoid "call stack size exceeded". |
| var res = '' |
| var i = 0 |
| while (i < len) { |
| res += String.fromCharCode.apply( |
| String, |
| codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH) |
| ) |
| } |
| return res |
| } |
| |
| function asciiSlice (buf, start, end) { |
| var ret = '' |
| end = Math.min(buf.length, end) |
| |
| for (var i = start; i < end; ++i) { |
| ret += String.fromCharCode(buf[i] & 0x7F) |
| } |
| return ret |
| } |
| |
| function latin1Slice (buf, start, end) { |
| var ret = '' |
| end = Math.min(buf.length, end) |
| |
| for (var i = start; i < end; ++i) { |
| ret += String.fromCharCode(buf[i]) |
| } |
| return ret |
| } |
| |
| function hexSlice (buf, start, end) { |
| var len = buf.length |
| |
| if (!start || start < 0) start = 0 |
| if (!end || end < 0 || end > len) end = len |
| |
| var out = '' |
| for (var i = start; i < end; ++i) { |
| out += toHex(buf[i]) |
| } |
| return out |
| } |
| |
| function utf16leSlice (buf, start, end) { |
| var bytes = buf.slice(start, end) |
| var res = '' |
| for (var i = 0; i < bytes.length; i += 2) { |
| res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256)) |
| } |
| return res |
| } |
| |
| Buffer.prototype.slice = function slice (start, end) { |
| var len = this.length |
| start = ~~start |
| end = end === undefined ? len : ~~end |
| |
| if (start < 0) { |
| start += len |
| if (start < 0) start = 0 |
| } else if (start > len) { |
| start = len |
| } |
| |
| if (end < 0) { |
| end += len |
| if (end < 0) end = 0 |
| } else if (end > len) { |
| end = len |
| } |
| |
| if (end < start) end = start |
| |
| var newBuf = this.subarray(start, end) |
| // Return an augmented `Uint8Array` instance |
| newBuf.__proto__ = Buffer.prototype |
| return newBuf |
| } |
| |
| /* |
| * Need to make sure that buffer isn't trying to write out of bounds. |
| */ |
| function checkOffset (offset, ext, length) { |
| if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint') |
| if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length') |
| } |
| |
| Buffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) { |
| offset = offset >>> 0 |
| byteLength = byteLength >>> 0 |
| if (!noAssert) checkOffset(offset, byteLength, this.length) |
| |
| var val = this[offset] |
| var mul = 1 |
| var i = 0 |
| while (++i < byteLength && (mul *= 0x100)) { |
| val += this[offset + i] * mul |
| } |
| |
| return val |
| } |
| |
| Buffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) { |
| offset = offset >>> 0 |
| byteLength = byteLength >>> 0 |
| if (!noAssert) { |
| checkOffset(offset, byteLength, this.length) |
| } |
| |
| var val = this[offset + --byteLength] |
| var mul = 1 |
| while (byteLength > 0 && (mul *= 0x100)) { |
| val += this[offset + --byteLength] * mul |
| } |
| |
| return val |
| } |
| |
| Buffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 1, this.length) |
| return this[offset] |
| } |
| |
| Buffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 2, this.length) |
| return this[offset] | (this[offset + 1] << 8) |
| } |
| |
| Buffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 2, this.length) |
| return (this[offset] << 8) | this[offset + 1] |
| } |
| |
| Buffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 4, this.length) |
| |
| return ((this[offset]) | |
| (this[offset + 1] << 8) | |
| (this[offset + 2] << 16)) + |
| (this[offset + 3] * 0x1000000) |
| } |
| |
| Buffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 4, this.length) |
| |
| return (this[offset] * 0x1000000) + |
| ((this[offset + 1] << 16) | |
| (this[offset + 2] << 8) | |
| this[offset + 3]) |
| } |
| |
| Buffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) { |
| offset = offset >>> 0 |
| byteLength = byteLength >>> 0 |
| if (!noAssert) checkOffset(offset, byteLength, this.length) |
| |
| var val = this[offset] |
| var mul = 1 |
| var i = 0 |
| while (++i < byteLength && (mul *= 0x100)) { |
| val += this[offset + i] * mul |
| } |
| mul *= 0x80 |
| |
| if (val >= mul) val -= Math.pow(2, 8 * byteLength) |
| |
| return val |
| } |
| |
| Buffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) { |
| offset = offset >>> 0 |
| byteLength = byteLength >>> 0 |
| if (!noAssert) checkOffset(offset, byteLength, this.length) |
| |
| var i = byteLength |
| var mul = 1 |
| var val = this[offset + --i] |
| while (i > 0 && (mul *= 0x100)) { |
| val += this[offset + --i] * mul |
| } |
| mul *= 0x80 |
| |
| if (val >= mul) val -= Math.pow(2, 8 * byteLength) |
| |
| return val |
| } |
| |
| Buffer.prototype.readInt8 = function readInt8 (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 1, this.length) |
| if (!(this[offset] & 0x80)) return (this[offset]) |
| return ((0xff - this[offset] + 1) * -1) |
| } |
| |
| Buffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 2, this.length) |
| var val = this[offset] | (this[offset + 1] << 8) |
| return (val & 0x8000) ? val | 0xFFFF0000 : val |
| } |
| |
| Buffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 2, this.length) |
| var val = this[offset + 1] | (this[offset] << 8) |
| return (val & 0x8000) ? val | 0xFFFF0000 : val |
| } |
| |
| Buffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 4, this.length) |
| |
| return (this[offset]) | |
| (this[offset + 1] << 8) | |
| (this[offset + 2] << 16) | |
| (this[offset + 3] << 24) |
| } |
| |
| Buffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 4, this.length) |
| |
| return (this[offset] << 24) | |
| (this[offset + 1] << 16) | |
| (this[offset + 2] << 8) | |
| (this[offset + 3]) |
| } |
| |
| Buffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 4, this.length) |
| return ieee754.read(this, offset, true, 23, 4) |
| } |
| |
| Buffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 4, this.length) |
| return ieee754.read(this, offset, false, 23, 4) |
| } |
| |
| Buffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 8, this.length) |
| return ieee754.read(this, offset, true, 52, 8) |
| } |
| |
| Buffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) { |
| offset = offset >>> 0 |
| if (!noAssert) checkOffset(offset, 8, this.length) |
| return ieee754.read(this, offset, false, 52, 8) |
| } |
| |
| function checkInt (buf, value, offset, ext, max, min) { |
| if (!Buffer.isBuffer(buf)) throw new TypeError('"buffer" argument must be a Buffer instance') |
| if (value > max || value < min) throw new RangeError('"value" argument is out of bounds') |
| if (offset + ext > buf.length) throw new RangeError('Index out of range') |
| } |
| |
| Buffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| byteLength = byteLength >>> 0 |
| if (!noAssert) { |
| var maxBytes = Math.pow(2, 8 * byteLength) - 1 |
| checkInt(this, value, offset, byteLength, maxBytes, 0) |
| } |
| |
| var mul = 1 |
| var i = 0 |
| this[offset] = value & 0xFF |
| while (++i < byteLength && (mul *= 0x100)) { |
| this[offset + i] = (value / mul) & 0xFF |
| } |
| |
| return offset + byteLength |
| } |
| |
| Buffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| byteLength = byteLength >>> 0 |
| if (!noAssert) { |
| var maxBytes = Math.pow(2, 8 * byteLength) - 1 |
| checkInt(this, value, offset, byteLength, maxBytes, 0) |
| } |
| |
| var i = byteLength - 1 |
| var mul = 1 |
| this[offset + i] = value & 0xFF |
| while (--i >= 0 && (mul *= 0x100)) { |
| this[offset + i] = (value / mul) & 0xFF |
| } |
| |
| return offset + byteLength |
| } |
| |
| Buffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0) |
| this[offset] = (value & 0xff) |
| return offset + 1 |
| } |
| |
| Buffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0) |
| this[offset] = (value & 0xff) |
| this[offset + 1] = (value >>> 8) |
| return offset + 2 |
| } |
| |
| Buffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0) |
| this[offset] = (value >>> 8) |
| this[offset + 1] = (value & 0xff) |
| return offset + 2 |
| } |
| |
| Buffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0) |
| this[offset + 3] = (value >>> 24) |
| this[offset + 2] = (value >>> 16) |
| this[offset + 1] = (value >>> 8) |
| this[offset] = (value & 0xff) |
| return offset + 4 |
| } |
| |
| Buffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0) |
| this[offset] = (value >>> 24) |
| this[offset + 1] = (value >>> 16) |
| this[offset + 2] = (value >>> 8) |
| this[offset + 3] = (value & 0xff) |
| return offset + 4 |
| } |
| |
| Buffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) { |
| var limit = Math.pow(2, (8 * byteLength) - 1) |
| |
| checkInt(this, value, offset, byteLength, limit - 1, -limit) |
| } |
| |
| var i = 0 |
| var mul = 1 |
| var sub = 0 |
| this[offset] = value & 0xFF |
| while (++i < byteLength && (mul *= 0x100)) { |
| if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) { |
| sub = 1 |
| } |
| this[offset + i] = ((value / mul) >> 0) - sub & 0xFF |
| } |
| |
| return offset + byteLength |
| } |
| |
| Buffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) { |
| var limit = Math.pow(2, (8 * byteLength) - 1) |
| |
| checkInt(this, value, offset, byteLength, limit - 1, -limit) |
| } |
| |
| var i = byteLength - 1 |
| var mul = 1 |
| var sub = 0 |
| this[offset + i] = value & 0xFF |
| while (--i >= 0 && (mul *= 0x100)) { |
| if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) { |
| sub = 1 |
| } |
| this[offset + i] = ((value / mul) >> 0) - sub & 0xFF |
| } |
| |
| return offset + byteLength |
| } |
| |
| Buffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80) |
| if (value < 0) value = 0xff + value + 1 |
| this[offset] = (value & 0xff) |
| return offset + 1 |
| } |
| |
| Buffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000) |
| this[offset] = (value & 0xff) |
| this[offset + 1] = (value >>> 8) |
| return offset + 2 |
| } |
| |
| Buffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000) |
| this[offset] = (value >>> 8) |
| this[offset + 1] = (value & 0xff) |
| return offset + 2 |
| } |
| |
| Buffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000) |
| this[offset] = (value & 0xff) |
| this[offset + 1] = (value >>> 8) |
| this[offset + 2] = (value >>> 16) |
| this[offset + 3] = (value >>> 24) |
| return offset + 4 |
| } |
| |
| Buffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000) |
| if (value < 0) value = 0xffffffff + value + 1 |
| this[offset] = (value >>> 24) |
| this[offset + 1] = (value >>> 16) |
| this[offset + 2] = (value >>> 8) |
| this[offset + 3] = (value & 0xff) |
| return offset + 4 |
| } |
| |
| function checkIEEE754 (buf, value, offset, ext, max, min) { |
| if (offset + ext > buf.length) throw new RangeError('Index out of range') |
| if (offset < 0) throw new RangeError('Index out of range') |
| } |
| |
| function writeFloat (buf, value, offset, littleEndian, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) { |
| checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38) |
| } |
| ieee754.write(buf, value, offset, littleEndian, 23, 4) |
| return offset + 4 |
| } |
| |
| Buffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) { |
| return writeFloat(this, value, offset, true, noAssert) |
| } |
| |
| Buffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) { |
| return writeFloat(this, value, offset, false, noAssert) |
| } |
| |
| function writeDouble (buf, value, offset, littleEndian, noAssert) { |
| value = +value |
| offset = offset >>> 0 |
| if (!noAssert) { |
| checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308) |
| } |
| ieee754.write(buf, value, offset, littleEndian, 52, 8) |
| return offset + 8 |
| } |
| |
| Buffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) { |
| return writeDouble(this, value, offset, true, noAssert) |
| } |
| |
| Buffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) { |
| return writeDouble(this, value, offset, false, noAssert) |
| } |
| |
| // copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length) |
| Buffer.prototype.copy = function copy (target, targetStart, start, end) { |
| if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer') |
| if (!start) start = 0 |
| if (!end && end !== 0) end = this.length |
| if (targetStart >= target.length) targetStart = target.length |
| if (!targetStart) targetStart = 0 |
| if (end > 0 && end < start) end = start |
| |
| // Copy 0 bytes; we're done |
| if (end === start) return 0 |
| if (target.length === 0 || this.length === 0) return 0 |
| |
| // Fatal error conditions |
| if (targetStart < 0) { |
| throw new RangeError('targetStart out of bounds') |
| } |
| if (start < 0 || start >= this.length) throw new RangeError('Index out of range') |
| if (end < 0) throw new RangeError('sourceEnd out of bounds') |
| |
| // Are we oob? |
| if (end > this.length) end = this.length |
| if (target.length - targetStart < end - start) { |
| end = target.length - targetStart + start |
| } |
| |
| var len = end - start |
| |
| if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') { |
| // Use built-in when available, missing from IE11 |
| this.copyWithin(targetStart, start, end) |
| } else if (this === target && start < targetStart && targetStart < end) { |
| // descending copy from end |
| for (var i = len - 1; i >= 0; --i) { |
| target[i + targetStart] = this[i + start] |
| } |
| } else { |
| Uint8Array.prototype.set.call( |
| target, |
| this.subarray(start, end), |
| targetStart |
| ) |
| } |
| |
| return len |
| } |
| |
| // Usage: |
| // buffer.fill(number[, offset[, end]]) |
| // buffer.fill(buffer[, offset[, end]]) |
| // buffer.fill(string[, offset[, end]][, encoding]) |
| Buffer.prototype.fill = function fill (val, start, end, encoding) { |
| // Handle string cases: |
| if (typeof val === 'string') { |
| if (typeof start === 'string') { |
| encoding = start |
| start = 0 |
| end = this.length |
| } else if (typeof end === 'string') { |
| encoding = end |
| end = this.length |
| } |
| if (encoding !== undefined && typeof encoding !== 'string') { |
| throw new TypeError('encoding must be a string') |
| } |
| if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) { |
| throw new TypeError('Unknown encoding: ' + encoding) |
| } |
| if (val.length === 1) { |
| var code = val.charCodeAt(0) |
| if ((encoding === 'utf8' && code < 128) || |
| encoding === 'latin1') { |
| // Fast path: If `val` fits into a single byte, use that numeric value. |
| val = code |
| } |
| } |
| } else if (typeof val === 'number') { |
| val = val & 255 |
| } |
| |
| // Invalid ranges are not set to a default, so can range check early. |
| if (start < 0 || this.length < start || this.length < end) { |
| throw new RangeError('Out of range index') |
| } |
| |
| if (end <= start) { |
| return this |
| } |
| |
| start = start >>> 0 |
| end = end === undefined ? this.length : end >>> 0 |
| |
| if (!val) val = 0 |
| |
| var i |
| if (typeof val === 'number') { |
| for (i = start; i < end; ++i) { |
| this[i] = val |
| } |
| } else { |
| var bytes = Buffer.isBuffer(val) |
| ? val |
| : Buffer.from(val, encoding) |
| var len = bytes.length |
| if (len === 0) { |
| throw new TypeError('The value "' + val + |
| '" is invalid for argument "value"') |
| } |
| for (i = 0; i < end - start; ++i) { |
| this[i + start] = bytes[i % len] |
| } |
| } |
| |
| return this |
| } |
| |
| // HELPER FUNCTIONS |
| // ================ |
| |
| var INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g |
| |
| function base64clean (str) { |
| // Node takes equal signs as end of the Base64 encoding |
| str = str.split('=')[0] |
| // Node strips out invalid characters like \n and \t from the string, base64-js does not |
| str = str.trim().replace(INVALID_BASE64_RE, '') |
| // Node converts strings with length < 2 to '' |
| if (str.length < 2) return '' |
| // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not |
| while (str.length % 4 !== 0) { |
| str = str + '=' |
| } |
| return str |
| } |
| |
| function toHex (n) { |
| if (n < 16) return '0' + n.toString(16) |
| return n.toString(16) |
| } |
| |
| function utf8ToBytes (string, units) { |
| units = units || Infinity |
| var codePoint |
| var length = string.length |
| var leadSurrogate = null |
| var bytes = [] |
| |
| for (var i = 0; i < length; ++i) { |
| codePoint = string.charCodeAt(i) |
| |
| // is surrogate component |
| if (codePoint > 0xD7FF && codePoint < 0xE000) { |
| // last char was a lead |
| if (!leadSurrogate) { |
| // no lead yet |
| if (codePoint > 0xDBFF) { |
| // unexpected trail |
| if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) |
| continue |
| } else if (i + 1 === length) { |
| // unpaired lead |
| if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) |
| continue |
| } |
| |
| // valid lead |
| leadSurrogate = codePoint |
| |
| continue |
| } |
| |
| // 2 leads in a row |
| if (codePoint < 0xDC00) { |
| if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) |
| leadSurrogate = codePoint |
| continue |
| } |
| |
| // valid surrogate pair |
| codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000 |
| } else if (leadSurrogate) { |
| // valid bmp char, but last char was a lead |
| if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) |
| } |
| |
| leadSurrogate = null |
| |
| // encode utf8 |
| if (codePoint < 0x80) { |
| if ((units -= 1) < 0) break |
| bytes.push(codePoint) |
| } else if (codePoint < 0x800) { |
| if ((units -= 2) < 0) break |
| bytes.push( |
| codePoint >> 0x6 | 0xC0, |
| codePoint & 0x3F | 0x80 |
| ) |
| } else if (codePoint < 0x10000) { |
| if ((units -= 3) < 0) break |
| bytes.push( |
| codePoint >> 0xC | 0xE0, |
| codePoint >> 0x6 & 0x3F | 0x80, |
| codePoint & 0x3F | 0x80 |
| ) |
| } else if (codePoint < 0x110000) { |
| if ((units -= 4) < 0) break |
| bytes.push( |
| codePoint >> 0x12 | 0xF0, |
| codePoint >> 0xC & 0x3F | 0x80, |
| codePoint >> 0x6 & 0x3F | 0x80, |
| codePoint & 0x3F | 0x80 |
| ) |
| } else { |
| throw new Error('Invalid code point') |
| } |
| } |
| |
| return bytes |
| } |
| |
| function asciiToBytes (str) { |
| var byteArray = [] |
| for (var i = 0; i < str.length; ++i) { |
| // Node's code seems to be doing this and not & 0x7F.. |
| byteArray.push(str.charCodeAt(i) & 0xFF) |
| } |
| return byteArray |
| } |
| |
| function utf16leToBytes (str, units) { |
| var c, hi, lo |
| var byteArray = [] |
| for (var i = 0; i < str.length; ++i) { |
| if ((units -= 2) < 0) break |
| |
| c = str.charCodeAt(i) |
| hi = c >> 8 |
| lo = c % 256 |
| byteArray.push(lo) |
| byteArray.push(hi) |
| } |
| |
| return byteArray |
| } |
| |
| function base64ToBytes (str) { |
| return base64.toByteArray(base64clean(str)) |
| } |
| |
| function blitBuffer (src, dst, offset, length) { |
| for (var i = 0; i < length; ++i) { |
| if ((i + offset >= dst.length) || (i >= src.length)) break |
| dst[i + offset] = src[i] |
| } |
| return i |
| } |
| |
| // ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass |
| // the `instanceof` check but they should be treated as of that type. |
| // See: https://github.com/feross/buffer/issues/166 |
| function isInstance (obj, type) { |
| return obj instanceof type || |
| (obj != null && obj.constructor != null && obj.constructor.name != null && |
| obj.constructor.name === type.name) |
| } |
| function numberIsNaN (obj) { |
| // For IE11 support |
| return obj !== obj // eslint-disable-line no-self-compare |
| } |
| |
| }).call(this,require("buffer").Buffer) |
| },{"base64-js":39,"buffer":43,"ieee754":55}],44:[function(require,module,exports){ |
| (function (Buffer){ |
| // Copyright Joyent, Inc. and other Node contributors. |
| // |
| // Permission is hereby granted, free of charge, to any person obtaining a |
| // copy of this software and associated documentation files (the |
| // "Software"), to deal in the Software without restriction, including |
| // without limitation the rights to use, copy, modify, merge, publish, |
| // distribute, sublicense, and/or sell copies of the Software, and to permit |
| // persons to whom the Software is furnished to do so, subject to the |
| // following conditions: |
| // |
| // The above copyright notice and this permission notice shall be included |
| // in all copies or substantial portions of the Software. |
| // |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN |
| // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
| // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
| // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE |
| // USE OR OTHER DEALINGS IN THE SOFTWARE. |
| |
| // NOTE: These type checking functions intentionally don't use `instanceof` |
| // because it is fragile and can be easily faked with `Object.create()`. |
| |
| function isArray(arg) { |
| if (Array.isArray) { |
| return Array.isArray(arg); |
| } |
| return objectToString(arg) === '[object Array]'; |
| } |
| exports.isArray = isArray; |
| |
| function isBoolean(arg) { |
| return typeof arg === 'boolean'; |
| } |
| exports.isBoolean = isBoolean; |
| |
| function isNull(arg) { |
| return arg === null; |
| } |
| exports.isNull = isNull; |
| |
| function isNullOrUndefined(arg) { |
| return arg == null; |
| } |
| exports.isNullOrUndefined = isNullOrUndefined; |
| |
| function isNumber(arg) { |
| return typeof arg === 'number'; |
| } |
| exports.isNumber = isNumber; |
| |
| function isString(arg) { |
| return typeof arg === 'string'; |
| } |
| exports.isString = isString; |
| |
| function isSymbol(arg) { |
| return typeof arg === 'symbol'; |
| } |
| exports.isSymbol = isSymbol; |
| |
| function isUndefined(arg) { |
| return arg === void 0; |
| } |
| exports.isUndefined = isUndefined; |
| |
| function isRegExp(re) { |
| return objectToString(re) === '[object RegExp]'; |
| } |
| exports.isRegExp = isRegExp; |
| |
| function isObject(arg) { |
| return typeof arg === 'object' && arg !== null; |
| } |
| exports.isObject = isObject; |
| |
| function isDate(d) { |
| return objectToString(d) === '[object Date]'; |
| } |
| exports.isDate = isDate; |
| |
| function isError(e) { |
| return (objectToString(e) === '[object Error]' || e instanceof Error); |
| } |
| exports.isError = isError; |
| |
| function isFunction(arg) { |
| return typeof arg === 'function'; |
| } |
| exports.isFunction = isFunction; |
| |
| function isPrimitive(arg) { |
| return arg === null || |
| typeof arg === 'boolean' || |
| typeof arg === 'number' || |
| typeof arg === 'string' || |
| typeof arg === 'symbol' || // ES6 symbol |
| typeof arg === 'undefined'; |
| } |
| exports.isPrimitive = isPrimitive; |
| |
| exports.isBuffer = Buffer.isBuffer; |
| |
| function objectToString(o) { |
| return Object.prototype.toString.call(o); |
| } |
| |
| }).call(this,{"isBuffer":require("../../is-buffer/index.js")}) |
| },{"../../is-buffer/index.js":57}],45:[function(require,module,exports){ |
| (function (process){ |
| "use strict"; |
| |
| function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } |
| |
| /* eslint-env browser */ |
| |
| /** |
| * This is the web browser implementation of `debug()`. |
| */ |
| exports.log = log; |
| exports.formatArgs = formatArgs; |
| exports.save = save; |
| exports.load = load; |
| exports.useColors = useColors; |
| exports.storage = localstorage(); |
| /** |
| * Colors. |
| */ |
| |
| exports.colors = ['#0000CC', '#0000FF', '#0033CC', '#0033FF', '#0066CC', '#0066FF', '#0099CC', '#0099FF', '#00CC00', '#00CC33', '#00CC66', '#00CC99', '#00CCCC', '#00CCFF', '#3300CC', '#3300FF', '#3333CC', '#3333FF', '#3366CC', '#3366FF', '#3399CC', '#3399FF', '#33CC00', '#33CC33', '#33CC66', '#33CC99', '#33CCCC', '#33CCFF', '#6600CC', '#6600FF', '#6633CC', '#6633FF', '#66CC00', '#66CC33', '#9900CC', '#9900FF', '#9933CC', '#9933FF', '#99CC00', '#99CC33', '#CC0000', '#CC0033', '#CC0066', '#CC0099', '#CC00CC', '#CC00FF', '#CC3300', '#CC3333', '#CC3366', '#CC3399', '#CC33CC', '#CC33FF', '#CC6600', '#CC6633', '#CC9900', '#CC9933', '#CCCC00', '#CCCC33', '#FF0000', '#FF0033', '#FF0066', '#FF0099', '#FF00CC', '#FF00FF', '#FF3300', '#FF3333', '#FF3366', '#FF3399', '#FF33CC', '#FF33FF', '#FF6600', '#FF6633', '#FF9900', '#FF9933', '#FFCC00', '#FFCC33']; |
| /** |
| * Currently only WebKit-based Web Inspectors, Firefox >= v31, |
| * and the Firebug extension (any Firefox version) are known |
| * to support "%c" CSS customizations. |
| * |
| * TODO: add a `localStorage` variable to explicitly enable/disable colors |
| */ |
| // eslint-disable-next-line complexity |
| |
| function useColors() { |
| // NB: In an Electron preload script, document will be defined but not fully |
| // initialized. Since we know we're in Chrome, we'll just detect this case |
| // explicitly |
| if (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) { |
| return true; |
| } // Internet Explorer and Edge do not support colors. |
| |
| |
| if (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)) { |
| return false; |
| } // Is webkit? http://stackoverflow.com/a/16459606/376773 |
| // document is undefined in react-native: https://github.com/facebook/react-native/pull/1632 |
| |
| |
| return typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance || // Is firebug? http://stackoverflow.com/a/398120/376773 |
| typeof window !== 'undefined' && window.console && (window.console.firebug || window.console.exception && window.console.table) || // Is firefox >= v31? |
| // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages |
| typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31 || // Double check webkit in userAgent just in case we are in a worker |
| typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/); |
| } |
| /** |
| * Colorize log arguments if enabled. |
| * |
| * @api public |
| */ |
| |
| |
| function formatArgs(args) { |
| args[0] = (this.useColors ? '%c' : '') + this.namespace + (this.useColors ? ' %c' : ' ') + args[0] + (this.useColors ? '%c ' : ' ') + '+' + module.exports.humanize(this.diff); |
| |
| if (!this.useColors) { |
| return; |
| } |
| |
| var c = 'color: ' + this.color; |
| args.splice(1, 0, c, 'color: inherit'); // The final "%c" is somewhat tricky, because there could be other |
| // arguments passed either before or after the %c, so we need to |
| // figure out the correct index to insert the CSS into |
| |
| var index = 0; |
| var lastC = 0; |
| args[0].replace(/%[a-zA-Z%]/g, function (match) { |
| if (match === '%%') { |
| return; |
| } |
| |
| index++; |
| |
| if (match === '%c') { |
| // We only are interested in the *last* %c |
| // (the user may have provided their own) |
| lastC = index; |
| } |
| }); |
| args.splice(lastC, 0, c); |
| } |
| /** |
| * Invokes `console.log()` when available. |
| * No-op when `console.log` is not a "function". |
| * |
| * @api public |
| */ |
| |
| |
| function log() { |
| var _console; |
| |
| // This hackery is required for IE8/9, where |
| // the `console.log` function doesn't have 'apply' |
| return (typeof console === "undefined" ? "undefined" : _typeof(console)) === 'object' && console.log && (_console = console).log.apply(_console, arguments); |
| } |
| /** |
| * Save `namespaces`. |
| * |
| * @param {String} namespaces |
| * @api private |
| */ |
| |
| |
| function save(namespaces) { |
| try { |
| if (namespaces) { |
| exports.storage.setItem('debug', namespaces); |
| } else { |
| exports.storage.removeItem('debug'); |
| } |
| } catch (error) {// Swallow |
| // XXX (@Qix-) should we be logging these? |
| } |
| } |
| /** |
| * Load `namespaces`. |
| * |
| * @return {String} returns the previously persisted debug modes |
| * @api private |
| */ |
| |
| |
| function load() { |
| var r; |
| |
| try { |
| r = exports.storage.getItem('debug'); |
| } catch (error) {} // Swallow |
| // XXX (@Qix-) should we be logging these? |
| // If debug isn't set in LS, and we're in Electron, try to load $DEBUG |
| |
| |
| if (!r && typeof process !== 'undefined' && 'env' in process) { |
| r = process.env.DEBUG; |
| } |
| |
| return r; |
| } |
| /** |
| * Localstorage attempts to return the localstorage. |
| * |
| * This is necessary because safari throws |
| * when a user disables cookies/localstorage |
| * and you attempt to access it. |
| * |
| * @return {LocalStorage} |
| * @api private |
| */ |
| |
| |
| function localstorage() { |
| try { |
| // TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context |
| // The Browser also has localStorage in the global context. |
| return localStorage; |
| } catch (error) {// Swallow |
| // XXX (@Qix-) should we be logging these? |
| } |
| } |
| |
| module.exports = require('./common')(exports); |
| var formatters = module.exports.formatters; |
| /** |
| * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default. |
| */ |
| |
| formatters.j = function (v) { |
| try { |
| return JSON.stringify(v); |
| } catch (error) { |
| return '[UnexpectedJSONParseError]: ' + error.message; |
| } |
| }; |
| |
| |
| }).call(this,require('_process')) |
| },{"./common":46,"_process":69}],46:[function(require,module,exports){ |
| "use strict"; |
| |
| /** |
| * This is the common logic for both the Node.js and web browser |
| * implementations of `debug()`. |
| */ |
| function setup(env) { |
| createDebug.debug = createDebug; |
| createDebug.default = createDebug; |
| createDebug.coerce = coerce; |
| createDebug.disable = disable; |
| createDebug.enable = enable; |
| createDebug.enabled = enabled; |
| createDebug.humanize = require('ms'); |
| Object.keys(env).forEach(function (key) { |
| createDebug[key] = env[key]; |
| }); |
| /** |
| * Active `debug` instances. |
| */ |
| |
| createDebug.instances = []; |
| /** |
| * The currently active debug mode names, and names to skip. |
| */ |
| |
| createDebug.names = []; |
| createDebug.skips = []; |
| /** |
| * Map of special "%n" handling functions, for the debug "format" argument. |
| * |
| * Valid key names are a single, lower or upper-case letter, i.e. "n" and "N". |
| */ |
| |
| createDebug.formatters = {}; |
| /** |
| * Selects a color for a debug namespace |
| * @param {String} namespace The namespace string for the for the debug instance to be colored |
| * @return {Number|String} An ANSI color code for the given namespace |
| * @api private |
| */ |
| |
| function selectColor(namespace) { |
| var hash = 0; |
| |
| for (var i = 0; i < namespace.length; i++) { |
| hash = (hash << 5) - hash + namespace.charCodeAt(i); |
| hash |= 0; // Convert to 32bit integer |
| } |
| |
| return createDebug.colors[Math.abs(hash) % createDebug.colors.length]; |
| } |
| |
| createDebug.selectColor = selectColor; |
| /** |
| * Create a debugger with the given `namespace`. |
| * |
| * @param {String} namespace |
| * @return {Function} |
| * @api public |
| */ |
| |
| function createDebug(namespace) { |
| var prevTime; |
| |
| function debug() { |
| // Disabled? |
| if (!debug.enabled) { |
| return; |
| } |
| |
| for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { |
| args[_key] = arguments[_key]; |
| } |
| |
| var self = debug; // Set `diff` timestamp |
| |
| var curr = Number(new Date()); |
| var ms = curr - (prevTime || curr); |
| self.diff = ms; |
| self.prev = prevTime; |
| self.curr = curr; |
| prevTime = curr; |
| args[0] = createDebug.coerce(args[0]); |
| |
| if (typeof args[0] !== 'string') { |
| // Anything else let's inspect with %O |
| args.unshift('%O'); |
| } // Apply any `formatters` transformations |
| |
| |
| var index = 0; |
| args[0] = args[0].replace(/%([a-zA-Z%])/g, function (match, format) { |
| // If we encounter an escaped % then don't increase the array index |
| if (match === '%%') { |
| return match; |
| } |
| |
| index++; |
| var formatter = createDebug.formatters[format]; |
| |
| if (typeof formatter === 'function') { |
| var val = args[index]; |
| match = formatter.call(self, val); // Now we need to remove `args[index]` since it's inlined in the `format` |
| |
| args.splice(index, 1); |
| index--; |
| } |
| |
| return match; |
| }); // Apply env-specific formatting (colors, etc.) |
| |
| createDebug.formatArgs.call(self, args); |
| var logFn = self.log || createDebug.log; |
| logFn.apply(self, args); |
| } |
| |
| debug.namespace = namespace; |
| debug.enabled = createDebug.enabled(namespace); |
| debug.useColors = createDebug.useColors(); |
| debug.color = selectColor(namespace); |
| debug.destroy = destroy; |
| debug.extend = extend; // Debug.formatArgs = formatArgs; |
| // debug.rawLog = rawLog; |
| // env-specific initialization logic for debug instances |
| |
| if (typeof createDebug.init === 'function') { |
| createDebug.init(debug); |
| } |
| |
| createDebug.instances.push(debug); |
| return debug; |
| } |
| |
| function destroy() { |
| var index = createDebug.instances.indexOf(this); |
| |
| if (index !== -1) { |
| createDebug.instances.splice(index, 1); |
| return true; |
| } |
| |
| return false; |
| } |
| |
| function extend(namespace, delimiter) { |
| return createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace); |
| } |
| /** |
| * Enables a debug mode by namespaces. This can include modes |
| * separated by a colon and wildcards. |
| * |
| * @param {String} namespaces |
| * @api public |
| */ |
| |
| |
| function enable(namespaces) { |
| createDebug.save(namespaces); |
| createDebug.names = []; |
| createDebug.skips = []; |
| var i; |
| var split = (typeof namespaces === 'string' ? namespaces : '').split(/[\s,]+/); |
| var len = split.length; |
| |
| for (i = 0; i < len; i++) { |
| if (!split[i]) { |
| // ignore empty strings |
| continue; |
| } |
| |
| namespaces = split[i].replace(/\*/g, '.*?'); |
| |
| if (namespaces[0] === '-') { |
| createDebug.skips.push(new RegExp('^' + namespaces.substr(1) + '$')); |
| } else { |
| createDebug.names.push(new RegExp('^' + namespaces + '$')); |
| } |
| } |
| |
| for (i = 0; i < createDebug.instances.length; i++) { |
| var instance = createDebug.instances[i]; |
| instance.enabled = createDebug.enabled(instance.namespace); |
| } |
| } |
| /** |
| * Disable debug output. |
| * |
| * @api public |
| */ |
| |
| |
| function disable() { |
| createDebug.enable(''); |
| } |
| /** |
| * Returns true if the given mode name is enabled, false otherwise. |
| * |
| * @param {String} name |
| * @return {Boolean} |
| * @api public |
| */ |
| |
| |
| function enabled(name) { |
| if (name[name.length - 1] === '*') { |
| return true; |
| } |
| |
| var i; |
| var len; |
| |
| for (i = 0, len = createDebug.skips.length; i < len; i++) { |
| if (createDebug.skips[i].test(name)) { |
| return false; |
| } |
| } |
| |
| for (i = 0, len = createDebug.names.length; i < len; i++) { |
| if (createDebug.names[i].test(name)) { |
| return true; |
| } |
| } |
| |
| return false; |
| } |
| /** |
| * Coerce `val`. |
| * |
| * @param {Mixed} val |
| * @return {Mixed} |
| * @api private |
| */ |
| |
| |
| function coerce(val) { |
| if (val instanceof Error) { |
| return val.stack || val.message; |
| } |
| |
| return val; |
| } |
| |
| createDebug.enable(createDebug.load()); |
| return createDebug; |
| } |
| |
| module.exports = setup; |
| |
| |
| },{"ms":60}],47:[function(require,module,exports){ |
| 'use strict'; |
| |
| var keys = require('object-keys'); |
| var hasSymbols = typeof Symbol === 'function' && typeof Symbol('foo') === 'symbol'; |
| |
| var toStr = Object.prototype.toString; |
| var concat = Array.prototype.concat; |
| var origDefineProperty = Object.defineProperty; |
| |
| var isFunction = function (fn) { |
| return typeof fn === 'function' && toStr.call(fn) === '[object Function]'; |
| }; |
| |
| var arePropertyDescriptorsSupported = function () { |
| var obj = {}; |
| try { |
| origDefineProperty(obj, 'x', { enumerable: false, value: obj }); |
| // eslint-disable-next-line no-unused-vars, no-restricted-syntax |
| for (var _ in obj) { // jscs:ignore disallowUnusedVariables |
| return false; |
| } |
| return obj.x === obj; |
| } catch (e) { /* this is IE 8. */ |
| return false; |
| } |
| }; |
| var supportsDescriptors = origDefineProperty && arePropertyDescriptorsSupported(); |
| |
| var defineProperty = function (object, name, value, predicate) { |
| if (name in object && (!isFunction(predicate) || !predicate())) { |
| return; |
| } |
| if (supportsDescriptors) { |
| origDefineProperty(object, name, { |
| configurable: true, |
| enumerable: false, |
| value: value, |
| writable: true |
| }); |
| } else { |
| object[name] = value; |
| } |
| }; |
| |
| var defineProperties = function (object, map) { |
| var predicates = arguments.length > 2 ? arguments[2] : {}; |
| var props = keys(map); |
| if (hasSymbols) { |
| props = concat.call(props, Object.getOwnPropertySymbols(map)); |
| } |
| for (var i = 0; i < props.length; i += 1) { |
| defineProperty(object, props[i], map[props[i]], predicates[props[i]]); |
| } |
| }; |
| |
| defineProperties.supportsDescriptors = !!supportsDescriptors; |
| |
| module.exports = defineProperties; |
| |
| },{"object-keys":62}],48:[function(require,module,exports){ |
| /*! |
| |
| diff v3.5.0 |
| |
| Software License Agreement (BSD License) |
| |
| Copyright (c) 2009-2015, Kevin Decker <kpdecker@gmail.com> |
| |
| All rights reserved. |
| |
| Redistribution and use of this software in source and binary forms, with or without modification, |
| are permitted provided that the following conditions are met: |
| |
| * Redistributions of source code must retain the above |
| copyright notice, this list of conditions and the |
| following disclaimer. |
| |
| * Redistributions in binary form must reproduce the above |
| copyright notice, this list of conditions and the |
| following disclaimer in the documentation and/or other |
| materials provided with the distribution. |
| |
| * Neither the name of Kevin Decker nor the names of its |
| contributors may be used to endorse or promote products |
| derived from this software without specific prior |
| written permission. |
| |
| THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR |
| IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND |
| FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR |
| CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
| DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER |
| IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT |
| OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| @license |
| */ |
| (function webpackUniversalModuleDefinition(root, factory) { |
| if(typeof exports === 'object' && typeof module === 'object') |
| module.exports = factory(); |
| else if(false) |
| define([], factory); |
| else if(typeof exports === 'object') |
| exports["JsDiff"] = factory(); |
| else |
| root["JsDiff"] = factory(); |
| })(this, function() { |
| return /******/ (function(modules) { // webpackBootstrap |
| /******/ // The module cache |
| /******/ var installedModules = {}; |
| |
| /******/ // The require function |
| /******/ function __webpack_require__(moduleId) { |
| |
| /******/ // Check if module is in cache |
| /******/ if(installedModules[moduleId]) |
| /******/ return installedModules[moduleId].exports; |
| |
| /******/ // Create a new module (and put it into the cache) |
| /******/ var module = installedModules[moduleId] = { |
| /******/ exports: {}, |
| /******/ id: moduleId, |
| /******/ loaded: false |
| /******/ }; |
| |
| /******/ // Execute the module function |
| /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); |
| |
| /******/ // Flag the module as loaded |
| /******/ module.loaded = true; |
| |
| /******/ // Return the exports of the module |
| /******/ return module.exports; |
| /******/ } |
| |
| |
| /******/ // expose the modules object (__webpack_modules__) |
| /******/ __webpack_require__.m = modules; |
| |
| /******/ // expose the module cache |
| /******/ __webpack_require__.c = installedModules; |
| |
| /******/ // __webpack_public_path__ |
| /******/ __webpack_require__.p = ""; |
| |
| /******/ // Load entry module and return exports |
| /******/ return __webpack_require__(0); |
| /******/ }) |
| /************************************************************************/ |
| /******/ ([ |
| /* 0 */ |
| /***/ (function(module, exports, __webpack_require__) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports.canonicalize = exports.convertChangesToXML = exports.convertChangesToDMP = exports.merge = exports.parsePatch = exports.applyPatches = exports.applyPatch = exports.createPatch = exports.createTwoFilesPatch = exports.structuredPatch = exports.diffArrays = exports.diffJson = exports.diffCss = exports.diffSentences = exports.diffTrimmedLines = exports.diffLines = exports.diffWordsWithSpace = exports.diffWords = exports.diffChars = exports.Diff = undefined; |
| |
| /*istanbul ignore end*/var /*istanbul ignore start*/_base = __webpack_require__(1) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/var _base2 = _interopRequireDefault(_base); |
| |
| /*istanbul ignore end*/var /*istanbul ignore start*/_character = __webpack_require__(2) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_word = __webpack_require__(3) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_line = __webpack_require__(5) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_sentence = __webpack_require__(6) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_css = __webpack_require__(7) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_json = __webpack_require__(8) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_array = __webpack_require__(9) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_apply = __webpack_require__(10) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_parse = __webpack_require__(11) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_merge = __webpack_require__(13) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_create = __webpack_require__(14) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_dmp = __webpack_require__(16) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_xml = __webpack_require__(17) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } |
| |
| /* See LICENSE file for terms of use */ |
| |
| /* |
| * Text diff implementation. |
| * |
| * This library supports the following APIS: |
| * JsDiff.diffChars: Character by character diff |
| * JsDiff.diffWords: Word (as defined by \b regex) diff which ignores whitespace |
| * JsDiff.diffLines: Line based diff |
| * |
| * JsDiff.diffCss: Diff targeted at CSS content |
| * |
| * These methods are based on the implementation proposed in |
| * "An O(ND) Difference Algorithm and its Variations" (Myers, 1986). |
| * http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.4.6927 |
| */ |
| exports. /*istanbul ignore end*/Diff = _base2['default']; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/diffChars = _character.diffChars; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/diffWords = _word.diffWords; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/diffWordsWithSpace = _word.diffWordsWithSpace; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/diffLines = _line.diffLines; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/diffTrimmedLines = _line.diffTrimmedLines; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/diffSentences = _sentence.diffSentences; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/diffCss = _css.diffCss; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/diffJson = _json.diffJson; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/diffArrays = _array.diffArrays; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/structuredPatch = _create.structuredPatch; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/createTwoFilesPatch = _create.createTwoFilesPatch; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/createPatch = _create.createPatch; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/applyPatch = _apply.applyPatch; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/applyPatches = _apply.applyPatches; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/parsePatch = _parse.parsePatch; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/merge = _merge.merge; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/convertChangesToDMP = _dmp.convertChangesToDMP; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/convertChangesToXML = _xml.convertChangesToXML; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/canonicalize = _json.canonicalize; |
| |
| |
| |
| /***/ }), |
| /* 1 */ |
| /***/ (function(module, exports) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports['default'] = /*istanbul ignore end*/Diff; |
| function Diff() {} |
| |
| Diff.prototype = { |
| /*istanbul ignore start*/ /*istanbul ignore end*/diff: function diff(oldString, newString) { |
| /*istanbul ignore start*/var /*istanbul ignore end*/options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; |
| |
| var callback = options.callback; |
| if (typeof options === 'function') { |
| callback = options; |
| options = {}; |
| } |
| this.options = options; |
| |
| var self = this; |
| |
| function done(value) { |
| if (callback) { |
| setTimeout(function () { |
| callback(undefined, value); |
| }, 0); |
| return true; |
| } else { |
| return value; |
| } |
| } |
| |
| // Allow subclasses to massage the input prior to running |
| oldString = this.castInput(oldString); |
| newString = this.castInput(newString); |
| |
| oldString = this.removeEmpty(this.tokenize(oldString)); |
| newString = this.removeEmpty(this.tokenize(newString)); |
| |
| var newLen = newString.length, |
| oldLen = oldString.length; |
| var editLength = 1; |
| var maxEditLength = newLen + oldLen; |
| var bestPath = [{ newPos: -1, components: [] }]; |
| |
| // Seed editLength = 0, i.e. the content starts with the same values |
| var oldPos = this.extractCommon(bestPath[0], newString, oldString, 0); |
| if (bestPath[0].newPos + 1 >= newLen && oldPos + 1 >= oldLen) { |
| // Identity per the equality and tokenizer |
| return done([{ value: this.join(newString), count: newString.length }]); |
| } |
| |
| // Main worker method. checks all permutations of a given edit length for acceptance. |
| function execEditLength() { |
| for (var diagonalPath = -1 * editLength; diagonalPath <= editLength; diagonalPath += 2) { |
| var basePath = /*istanbul ignore start*/void 0 /*istanbul ignore end*/; |
| var addPath = bestPath[diagonalPath - 1], |
| removePath = bestPath[diagonalPath + 1], |
| _oldPos = (removePath ? removePath.newPos : 0) - diagonalPath; |
| if (addPath) { |
| // No one else is going to attempt to use this value, clear it |
| bestPath[diagonalPath - 1] = undefined; |
| } |
| |
| var canAdd = addPath && addPath.newPos + 1 < newLen, |
| canRemove = removePath && 0 <= _oldPos && _oldPos < oldLen; |
| if (!canAdd && !canRemove) { |
| // If this path is a terminal then prune |
| bestPath[diagonalPath] = undefined; |
| continue; |
| } |
| |
| // Select the diagonal that we want to branch from. We select the prior |
| // path whose position in the new string is the farthest from the origin |
| // and does not pass the bounds of the diff graph |
| if (!canAdd || canRemove && addPath.newPos < removePath.newPos) { |
| basePath = clonePath(removePath); |
| self.pushComponent(basePath.components, undefined, true); |
| } else { |
| basePath = addPath; // No need to clone, we've pulled it from the list |
| basePath.newPos++; |
| self.pushComponent(basePath.components, true, undefined); |
| } |
| |
| _oldPos = self.extractCommon(basePath, newString, oldString, diagonalPath); |
| |
| // If we have hit the end of both strings, then we are done |
| if (basePath.newPos + 1 >= newLen && _oldPos + 1 >= oldLen) { |
| return done(buildValues(self, basePath.components, newString, oldString, self.useLongestToken)); |
| } else { |
| // Otherwise track this path as a potential candidate and continue. |
| bestPath[diagonalPath] = basePath; |
| } |
| } |
| |
| editLength++; |
| } |
| |
| // Performs the length of edit iteration. Is a bit fugly as this has to support the |
| // sync and async mode which is never fun. Loops over execEditLength until a value |
| // is produced. |
| if (callback) { |
| (function exec() { |
| setTimeout(function () { |
| // This should not happen, but we want to be safe. |
| /* istanbul ignore next */ |
| if (editLength > maxEditLength) { |
| return callback(); |
| } |
| |
| if (!execEditLength()) { |
| exec(); |
| } |
| }, 0); |
| })(); |
| } else { |
| while (editLength <= maxEditLength) { |
| var ret = execEditLength(); |
| if (ret) { |
| return ret; |
| } |
| } |
| } |
| }, |
| /*istanbul ignore start*/ /*istanbul ignore end*/pushComponent: function pushComponent(components, added, removed) { |
| var last = components[components.length - 1]; |
| if (last && last.added === added && last.removed === removed) { |
| // We need to clone here as the component clone operation is just |
| // as shallow array clone |
| components[components.length - 1] = { count: last.count + 1, added: added, removed: removed }; |
| } else { |
| components.push({ count: 1, added: added, removed: removed }); |
| } |
| }, |
| /*istanbul ignore start*/ /*istanbul ignore end*/extractCommon: function extractCommon(basePath, newString, oldString, diagonalPath) { |
| var newLen = newString.length, |
| oldLen = oldString.length, |
| newPos = basePath.newPos, |
| oldPos = newPos - diagonalPath, |
| commonCount = 0; |
| while (newPos + 1 < newLen && oldPos + 1 < oldLen && this.equals(newString[newPos + 1], oldString[oldPos + 1])) { |
| newPos++; |
| oldPos++; |
| commonCount++; |
| } |
| |
| if (commonCount) { |
| basePath.components.push({ count: commonCount }); |
| } |
| |
| basePath.newPos = newPos; |
| return oldPos; |
| }, |
| /*istanbul ignore start*/ /*istanbul ignore end*/equals: function equals(left, right) { |
| if (this.options.comparator) { |
| return this.options.comparator(left, right); |
| } else { |
| return left === right || this.options.ignoreCase && left.toLowerCase() === right.toLowerCase(); |
| } |
| }, |
| /*istanbul ignore start*/ /*istanbul ignore end*/removeEmpty: function removeEmpty(array) { |
| var ret = []; |
| for (var i = 0; i < array.length; i++) { |
| if (array[i]) { |
| ret.push(array[i]); |
| } |
| } |
| return ret; |
| }, |
| /*istanbul ignore start*/ /*istanbul ignore end*/castInput: function castInput(value) { |
| return value; |
| }, |
| /*istanbul ignore start*/ /*istanbul ignore end*/tokenize: function tokenize(value) { |
| return value.split(''); |
| }, |
| /*istanbul ignore start*/ /*istanbul ignore end*/join: function join(chars) { |
| return chars.join(''); |
| } |
| }; |
| |
| function buildValues(diff, components, newString, oldString, useLongestToken) { |
| var componentPos = 0, |
| componentLen = components.length, |
| newPos = 0, |
| oldPos = 0; |
| |
| for (; componentPos < componentLen; componentPos++) { |
| var component = components[componentPos]; |
| if (!component.removed) { |
| if (!component.added && useLongestToken) { |
| var value = newString.slice(newPos, newPos + component.count); |
| value = value.map(function (value, i) { |
| var oldValue = oldString[oldPos + i]; |
| return oldValue.length > value.length ? oldValue : value; |
| }); |
| |
| component.value = diff.join(value); |
| } else { |
| component.value = diff.join(newString.slice(newPos, newPos + component.count)); |
| } |
| newPos += component.count; |
| |
| // Common case |
| if (!component.added) { |
| oldPos += component.count; |
| } |
| } else { |
| component.value = diff.join(oldString.slice(oldPos, oldPos + component.count)); |
| oldPos += component.count; |
| |
| // Reverse add and remove so removes are output first to match common convention |
| // The diffing algorithm is tied to add then remove output and this is the simplest |
| // route to get the desired output with minimal overhead. |
| if (componentPos && components[componentPos - 1].added) { |
| var tmp = components[componentPos - 1]; |
| components[componentPos - 1] = components[componentPos]; |
| components[componentPos] = tmp; |
| } |
| } |
| } |
| |
| // Special case handle for when one terminal is ignored (i.e. whitespace). |
| // For this case we merge the terminal into the prior string and drop the change. |
| // This is only available for string mode. |
| var lastComponent = components[componentLen - 1]; |
| if (componentLen > 1 && typeof lastComponent.value === 'string' && (lastComponent.added || lastComponent.removed) && diff.equals('', lastComponent.value)) { |
| components[componentLen - 2].value += lastComponent.value; |
| components.pop(); |
| } |
| |
| return components; |
| } |
| |
| function clonePath(path) { |
| return { newPos: path.newPos, components: path.components.slice(0) }; |
| } |
| |
| |
| |
| /***/ }), |
| /* 2 */ |
| /***/ (function(module, exports, __webpack_require__) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports.characterDiff = undefined; |
| exports. /*istanbul ignore end*/diffChars = diffChars; |
| |
| var /*istanbul ignore start*/_base = __webpack_require__(1) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/var _base2 = _interopRequireDefault(_base); |
| |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } |
| |
| /*istanbul ignore end*/var characterDiff = /*istanbul ignore start*/exports. /*istanbul ignore end*/characterDiff = new /*istanbul ignore start*/_base2['default'] /*istanbul ignore end*/(); |
| function diffChars(oldStr, newStr, options) { |
| return characterDiff.diff(oldStr, newStr, options); |
| } |
| |
| |
| |
| /***/ }), |
| /* 3 */ |
| /***/ (function(module, exports, __webpack_require__) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports.wordDiff = undefined; |
| exports. /*istanbul ignore end*/diffWords = diffWords; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/diffWordsWithSpace = diffWordsWithSpace; |
| |
| var /*istanbul ignore start*/_base = __webpack_require__(1) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/var _base2 = _interopRequireDefault(_base); |
| |
| /*istanbul ignore end*/var /*istanbul ignore start*/_params = __webpack_require__(4) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } |
| |
| /*istanbul ignore end*/ // Based on https://en.wikipedia.org/wiki/Latin_script_in_Unicode |
| // |
| // Ranges and exceptions: |
| // Latin-1 Supplement, 0080–00FF |
| // - U+00D7 × Multiplication sign |
| // - U+00F7 ÷ Division sign |
| // Latin Extended-A, 0100–017F |
| // Latin Extended-B, 0180–024F |
| // IPA Extensions, 0250–02AF |
| // Spacing Modifier Letters, 02B0–02FF |
| // - U+02C7 ˇ ˇ Caron |
| // - U+02D8 ˘ ˘ Breve |
| // - U+02D9 ˙ ˙ Dot Above |
| // - U+02DA ˚ ˚ Ring Above |
| // - U+02DB ˛ ˛ Ogonek |
| // - U+02DC ˜ ˜ Small Tilde |
| // - U+02DD ˝ ˝ Double Acute Accent |
| // Latin Extended Additional, 1E00–1EFF |
| var extendedWordChars = /^[A-Za-z\xC0-\u02C6\u02C8-\u02D7\u02DE-\u02FF\u1E00-\u1EFF]+$/; |
| |
| var reWhitespace = /\S/; |
| |
| var wordDiff = /*istanbul ignore start*/exports. /*istanbul ignore end*/wordDiff = new /*istanbul ignore start*/_base2['default'] /*istanbul ignore end*/(); |
| wordDiff.equals = function (left, right) { |
| if (this.options.ignoreCase) { |
| left = left.toLowerCase(); |
| right = right.toLowerCase(); |
| } |
| return left === right || this.options.ignoreWhitespace && !reWhitespace.test(left) && !reWhitespace.test(right); |
| }; |
| wordDiff.tokenize = function (value) { |
| var tokens = value.split(/(\s+|\b)/); |
| |
| // Join the boundary splits that we do not consider to be boundaries. This is primarily the extended Latin character set. |
| for (var i = 0; i < tokens.length - 1; i++) { |
| // If we have an empty string in the next field and we have only word chars before and after, merge |
| if (!tokens[i + 1] && tokens[i + 2] && extendedWordChars.test(tokens[i]) && extendedWordChars.test(tokens[i + 2])) { |
| tokens[i] += tokens[i + 2]; |
| tokens.splice(i + 1, 2); |
| i--; |
| } |
| } |
| |
| return tokens; |
| }; |
| |
| function diffWords(oldStr, newStr, options) { |
| options = /*istanbul ignore start*/(0, _params.generateOptions) /*istanbul ignore end*/(options, { ignoreWhitespace: true }); |
| return wordDiff.diff(oldStr, newStr, options); |
| } |
| |
| function diffWordsWithSpace(oldStr, newStr, options) { |
| return wordDiff.diff(oldStr, newStr, options); |
| } |
| |
| |
| |
| /***/ }), |
| /* 4 */ |
| /***/ (function(module, exports) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports. /*istanbul ignore end*/generateOptions = generateOptions; |
| function generateOptions(options, defaults) { |
| if (typeof options === 'function') { |
| defaults.callback = options; |
| } else if (options) { |
| for (var name in options) { |
| /* istanbul ignore else */ |
| if (options.hasOwnProperty(name)) { |
| defaults[name] = options[name]; |
| } |
| } |
| } |
| return defaults; |
| } |
| |
| |
| |
| /***/ }), |
| /* 5 */ |
| /***/ (function(module, exports, __webpack_require__) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports.lineDiff = undefined; |
| exports. /*istanbul ignore end*/diffLines = diffLines; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/diffTrimmedLines = diffTrimmedLines; |
| |
| var /*istanbul ignore start*/_base = __webpack_require__(1) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/var _base2 = _interopRequireDefault(_base); |
| |
| /*istanbul ignore end*/var /*istanbul ignore start*/_params = __webpack_require__(4) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } |
| |
| /*istanbul ignore end*/var lineDiff = /*istanbul ignore start*/exports. /*istanbul ignore end*/lineDiff = new /*istanbul ignore start*/_base2['default'] /*istanbul ignore end*/(); |
| lineDiff.tokenize = function (value) { |
| var retLines = [], |
| linesAndNewlines = value.split(/(\n|\r\n)/); |
| |
| // Ignore the final empty token that occurs if the string ends with a new line |
| if (!linesAndNewlines[linesAndNewlines.length - 1]) { |
| linesAndNewlines.pop(); |
| } |
| |
| // Merge the content and line separators into single tokens |
| for (var i = 0; i < linesAndNewlines.length; i++) { |
| var line = linesAndNewlines[i]; |
| |
| if (i % 2 && !this.options.newlineIsToken) { |
| retLines[retLines.length - 1] += line; |
| } else { |
| if (this.options.ignoreWhitespace) { |
| line = line.trim(); |
| } |
| retLines.push(line); |
| } |
| } |
| |
| return retLines; |
| }; |
| |
| function diffLines(oldStr, newStr, callback) { |
| return lineDiff.diff(oldStr, newStr, callback); |
| } |
| function diffTrimmedLines(oldStr, newStr, callback) { |
| var options = /*istanbul ignore start*/(0, _params.generateOptions) /*istanbul ignore end*/(callback, { ignoreWhitespace: true }); |
| return lineDiff.diff(oldStr, newStr, options); |
| } |
| |
| |
| |
| /***/ }), |
| /* 6 */ |
| /***/ (function(module, exports, __webpack_require__) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports.sentenceDiff = undefined; |
| exports. /*istanbul ignore end*/diffSentences = diffSentences; |
| |
| var /*istanbul ignore start*/_base = __webpack_require__(1) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/var _base2 = _interopRequireDefault(_base); |
| |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } |
| |
| /*istanbul ignore end*/var sentenceDiff = /*istanbul ignore start*/exports. /*istanbul ignore end*/sentenceDiff = new /*istanbul ignore start*/_base2['default'] /*istanbul ignore end*/(); |
| sentenceDiff.tokenize = function (value) { |
| return value.split(/(\S.+?[.!?])(?=\s+|$)/); |
| }; |
| |
| function diffSentences(oldStr, newStr, callback) { |
| return sentenceDiff.diff(oldStr, newStr, callback); |
| } |
| |
| |
| |
| /***/ }), |
| /* 7 */ |
| /***/ (function(module, exports, __webpack_require__) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports.cssDiff = undefined; |
| exports. /*istanbul ignore end*/diffCss = diffCss; |
| |
| var /*istanbul ignore start*/_base = __webpack_require__(1) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/var _base2 = _interopRequireDefault(_base); |
| |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } |
| |
| /*istanbul ignore end*/var cssDiff = /*istanbul ignore start*/exports. /*istanbul ignore end*/cssDiff = new /*istanbul ignore start*/_base2['default'] /*istanbul ignore end*/(); |
| cssDiff.tokenize = function (value) { |
| return value.split(/([{}:;,]|\s+)/); |
| }; |
| |
| function diffCss(oldStr, newStr, callback) { |
| return cssDiff.diff(oldStr, newStr, callback); |
| } |
| |
| |
| |
| /***/ }), |
| /* 8 */ |
| /***/ (function(module, exports, __webpack_require__) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports.jsonDiff = undefined; |
| |
| var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; |
| |
| exports. /*istanbul ignore end*/diffJson = diffJson; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/canonicalize = canonicalize; |
| |
| var /*istanbul ignore start*/_base = __webpack_require__(1) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/var _base2 = _interopRequireDefault(_base); |
| |
| /*istanbul ignore end*/var /*istanbul ignore start*/_line = __webpack_require__(5) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } |
| |
| /*istanbul ignore end*/var objectPrototypeToString = Object.prototype.toString; |
| |
| var jsonDiff = /*istanbul ignore start*/exports. /*istanbul ignore end*/jsonDiff = new /*istanbul ignore start*/_base2['default'] /*istanbul ignore end*/(); |
| // Discriminate between two lines of pretty-printed, serialized JSON where one of them has a |
| // dangling comma and the other doesn't. Turns out including the dangling comma yields the nicest output: |
| jsonDiff.useLongestToken = true; |
| |
| jsonDiff.tokenize = /*istanbul ignore start*/_line.lineDiff /*istanbul ignore end*/.tokenize; |
| jsonDiff.castInput = function (value) { |
| /*istanbul ignore start*/var _options = /*istanbul ignore end*/this.options, |
| undefinedReplacement = _options.undefinedReplacement, |
| _options$stringifyRep = _options.stringifyReplacer, |
| stringifyReplacer = _options$stringifyRep === undefined ? function (k, v) /*istanbul ignore start*/{ |
| return (/*istanbul ignore end*/typeof v === 'undefined' ? undefinedReplacement : v |
| ); |
| } : _options$stringifyRep; |
| |
| |
| return typeof value === 'string' ? value : JSON.stringify(canonicalize(value, null, null, stringifyReplacer), stringifyReplacer, ' '); |
| }; |
| jsonDiff.equals = function (left, right) { |
| return (/*istanbul ignore start*/_base2['default'] /*istanbul ignore end*/.prototype.equals.call(jsonDiff, left.replace(/,([\r\n])/g, '$1'), right.replace(/,([\r\n])/g, '$1')) |
| ); |
| }; |
| |
| function diffJson(oldObj, newObj, options) { |
| return jsonDiff.diff(oldObj, newObj, options); |
| } |
| |
| // This function handles the presence of circular references by bailing out when encountering an |
| // object that is already on the "stack" of items being processed. Accepts an optional replacer |
| function canonicalize(obj, stack, replacementStack, replacer, key) { |
| stack = stack || []; |
| replacementStack = replacementStack || []; |
| |
| if (replacer) { |
| obj = replacer(key, obj); |
| } |
| |
| var i = /*istanbul ignore start*/void 0 /*istanbul ignore end*/; |
| |
| for (i = 0; i < stack.length; i += 1) { |
| if (stack[i] === obj) { |
| return replacementStack[i]; |
| } |
| } |
| |
| var canonicalizedObj = /*istanbul ignore start*/void 0 /*istanbul ignore end*/; |
| |
| if ('[object Array]' === objectPrototypeToString.call(obj)) { |
| stack.push(obj); |
| canonicalizedObj = new Array(obj.length); |
| replacementStack.push(canonicalizedObj); |
| for (i = 0; i < obj.length; i += 1) { |
| canonicalizedObj[i] = canonicalize(obj[i], stack, replacementStack, replacer, key); |
| } |
| stack.pop(); |
| replacementStack.pop(); |
| return canonicalizedObj; |
| } |
| |
| if (obj && obj.toJSON) { |
| obj = obj.toJSON(); |
| } |
| |
| if ( /*istanbul ignore start*/(typeof /*istanbul ignore end*/obj === 'undefined' ? 'undefined' : _typeof(obj)) === 'object' && obj !== null) { |
| stack.push(obj); |
| canonicalizedObj = {}; |
| replacementStack.push(canonicalizedObj); |
| var sortedKeys = [], |
| _key = /*istanbul ignore start*/void 0 /*istanbul ignore end*/; |
| for (_key in obj) { |
| /* istanbul ignore else */ |
| if (obj.hasOwnProperty(_key)) { |
| sortedKeys.push(_key); |
| } |
| } |
| sortedKeys.sort(); |
| for (i = 0; i < sortedKeys.length; i += 1) { |
| _key = sortedKeys[i]; |
| canonicalizedObj[_key] = canonicalize(obj[_key], stack, replacementStack, replacer, _key); |
| } |
| stack.pop(); |
| replacementStack.pop(); |
| } else { |
| canonicalizedObj = obj; |
| } |
| return canonicalizedObj; |
| } |
| |
| |
| |
| /***/ }), |
| /* 9 */ |
| /***/ (function(module, exports, __webpack_require__) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports.arrayDiff = undefined; |
| exports. /*istanbul ignore end*/diffArrays = diffArrays; |
| |
| var /*istanbul ignore start*/_base = __webpack_require__(1) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/var _base2 = _interopRequireDefault(_base); |
| |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } |
| |
| /*istanbul ignore end*/var arrayDiff = /*istanbul ignore start*/exports. /*istanbul ignore end*/arrayDiff = new /*istanbul ignore start*/_base2['default'] /*istanbul ignore end*/(); |
| arrayDiff.tokenize = function (value) { |
| return value.slice(); |
| }; |
| arrayDiff.join = arrayDiff.removeEmpty = function (value) { |
| return value; |
| }; |
| |
| function diffArrays(oldArr, newArr, callback) { |
| return arrayDiff.diff(oldArr, newArr, callback); |
| } |
| |
| |
| |
| /***/ }), |
| /* 10 */ |
| /***/ (function(module, exports, __webpack_require__) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports. /*istanbul ignore end*/applyPatch = applyPatch; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/applyPatches = applyPatches; |
| |
| var /*istanbul ignore start*/_parse = __webpack_require__(11) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_distanceIterator = __webpack_require__(12) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/var _distanceIterator2 = _interopRequireDefault(_distanceIterator); |
| |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } |
| |
| /*istanbul ignore end*/function applyPatch(source, uniDiff) { |
| /*istanbul ignore start*/var /*istanbul ignore end*/options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; |
| |
| if (typeof uniDiff === 'string') { |
| uniDiff = /*istanbul ignore start*/(0, _parse.parsePatch) /*istanbul ignore end*/(uniDiff); |
| } |
| |
| if (Array.isArray(uniDiff)) { |
| if (uniDiff.length > 1) { |
| throw new Error('applyPatch only works with a single input.'); |
| } |
| |
| uniDiff = uniDiff[0]; |
| } |
| |
| // Apply the diff to the input |
| var lines = source.split(/\r\n|[\n\v\f\r\x85]/), |
| delimiters = source.match(/\r\n|[\n\v\f\r\x85]/g) || [], |
| hunks = uniDiff.hunks, |
| compareLine = options.compareLine || function (lineNumber, line, operation, patchContent) /*istanbul ignore start*/{ |
| return (/*istanbul ignore end*/line === patchContent |
| ); |
| }, |
| errorCount = 0, |
| fuzzFactor = options.fuzzFactor || 0, |
| minLine = 0, |
| offset = 0, |
| removeEOFNL = /*istanbul ignore start*/void 0 /*istanbul ignore end*/, |
| addEOFNL = /*istanbul ignore start*/void 0 /*istanbul ignore end*/; |
| |
| /** |
| * Checks if the hunk exactly fits on the provided location |
| */ |
| function hunkFits(hunk, toPos) { |
| for (var j = 0; j < hunk.lines.length; j++) { |
| var line = hunk.lines[j], |
| operation = line.length > 0 ? line[0] : ' ', |
| content = line.length > 0 ? line.substr(1) : line; |
| |
| if (operation === ' ' || operation === '-') { |
| // Context sanity check |
| if (!compareLine(toPos + 1, lines[toPos], operation, content)) { |
| errorCount++; |
| |
| if (errorCount > fuzzFactor) { |
| return false; |
| } |
| } |
| toPos++; |
| } |
| } |
| |
| return true; |
| } |
| |
| // Search best fit offsets for each hunk based on the previous ones |
| for (var i = 0; i < hunks.length; i++) { |
| var hunk = hunks[i], |
| maxLine = lines.length - hunk.oldLines, |
| localOffset = 0, |
| toPos = offset + hunk.oldStart - 1; |
| |
| var iterator = /*istanbul ignore start*/(0, _distanceIterator2['default']) /*istanbul ignore end*/(toPos, minLine, maxLine); |
| |
| for (; localOffset !== undefined; localOffset = iterator()) { |
| if (hunkFits(hunk, toPos + localOffset)) { |
| hunk.offset = offset += localOffset; |
| break; |
| } |
| } |
| |
| if (localOffset === undefined) { |
| return false; |
| } |
| |
| // Set lower text limit to end of the current hunk, so next ones don't try |
| // to fit over already patched text |
| minLine = hunk.offset + hunk.oldStart + hunk.oldLines; |
| } |
| |
| // Apply patch hunks |
| var diffOffset = 0; |
| for (var _i = 0; _i < hunks.length; _i++) { |
| var _hunk = hunks[_i], |
| _toPos = _hunk.oldStart + _hunk.offset + diffOffset - 1; |
| diffOffset += _hunk.newLines - _hunk.oldLines; |
| |
| if (_toPos < 0) { |
| // Creating a new file |
| _toPos = 0; |
| } |
| |
| for (var j = 0; j < _hunk.lines.length; j++) { |
| var line = _hunk.lines[j], |
| operation = line.length > 0 ? line[0] : ' ', |
| content = line.length > 0 ? line.substr(1) : line, |
| delimiter = _hunk.linedelimiters[j]; |
| |
| if (operation === ' ') { |
| _toPos++; |
| } else if (operation === '-') { |
| lines.splice(_toPos, 1); |
| delimiters.splice(_toPos, 1); |
| /* istanbul ignore else */ |
| } else if (operation === '+') { |
| lines.splice(_toPos, 0, content); |
| delimiters.splice(_toPos, 0, delimiter); |
| _toPos++; |
| } else if (operation === '\\') { |
| var previousOperation = _hunk.lines[j - 1] ? _hunk.lines[j - 1][0] : null; |
| if (previousOperation === '+') { |
| removeEOFNL = true; |
| } else if (previousOperation === '-') { |
| addEOFNL = true; |
| } |
| } |
| } |
| } |
| |
| // Handle EOFNL insertion/removal |
| if (removeEOFNL) { |
| while (!lines[lines.length - 1]) { |
| lines.pop(); |
| delimiters.pop(); |
| } |
| } else if (addEOFNL) { |
| lines.push(''); |
| delimiters.push('\n'); |
| } |
| for (var _k = 0; _k < lines.length - 1; _k++) { |
| lines[_k] = lines[_k] + delimiters[_k]; |
| } |
| return lines.join(''); |
| } |
| |
| // Wrapper that supports multiple file patches via callbacks. |
| function applyPatches(uniDiff, options) { |
| if (typeof uniDiff === 'string') { |
| uniDiff = /*istanbul ignore start*/(0, _parse.parsePatch) /*istanbul ignore end*/(uniDiff); |
| } |
| |
| var currentIndex = 0; |
| function processIndex() { |
| var index = uniDiff[currentIndex++]; |
| if (!index) { |
| return options.complete(); |
| } |
| |
| options.loadFile(index, function (err, data) { |
| if (err) { |
| return options.complete(err); |
| } |
| |
| var updatedContent = applyPatch(data, index, options); |
| options.patched(index, updatedContent, function (err) { |
| if (err) { |
| return options.complete(err); |
| } |
| |
| processIndex(); |
| }); |
| }); |
| } |
| processIndex(); |
| } |
| |
| |
| |
| /***/ }), |
| /* 11 */ |
| /***/ (function(module, exports) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports. /*istanbul ignore end*/parsePatch = parsePatch; |
| function parsePatch(uniDiff) { |
| /*istanbul ignore start*/var /*istanbul ignore end*/options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; |
| |
| var diffstr = uniDiff.split(/\r\n|[\n\v\f\r\x85]/), |
| delimiters = uniDiff.match(/\r\n|[\n\v\f\r\x85]/g) || [], |
| list = [], |
| i = 0; |
| |
| function parseIndex() { |
| var index = {}; |
| list.push(index); |
| |
| // Parse diff metadata |
| while (i < diffstr.length) { |
| var line = diffstr[i]; |
| |
| // File header found, end parsing diff metadata |
| if (/^(\-\-\-|\+\+\+|@@)\s/.test(line)) { |
| break; |
| } |
| |
| // Diff index |
| var header = /^(?:Index:|diff(?: -r \w+)+)\s+(.+?)\s*$/.exec(line); |
| if (header) { |
| index.index = header[1]; |
| } |
| |
| i++; |
| } |
| |
| // Parse file headers if they are defined. Unified diff requires them, but |
| // there's no technical issues to have an isolated hunk without file header |
| parseFileHeader(index); |
| parseFileHeader(index); |
| |
| // Parse hunks |
| index.hunks = []; |
| |
| while (i < diffstr.length) { |
| var _line = diffstr[i]; |
| |
| if (/^(Index:|diff|\-\-\-|\+\+\+)\s/.test(_line)) { |
| break; |
| } else if (/^@@/.test(_line)) { |
| index.hunks.push(parseHunk()); |
| } else if (_line && options.strict) { |
| // Ignore unexpected content unless in strict mode |
| throw new Error('Unknown line ' + (i + 1) + ' ' + JSON.stringify(_line)); |
| } else { |
| i++; |
| } |
| } |
| } |
| |
| // Parses the --- and +++ headers, if none are found, no lines |
| // are consumed. |
| function parseFileHeader(index) { |
| var fileHeader = /^(---|\+\+\+)\s+(.*)$/.exec(diffstr[i]); |
| if (fileHeader) { |
| var keyPrefix = fileHeader[1] === '---' ? 'old' : 'new'; |
| var data = fileHeader[2].split('\t', 2); |
| var fileName = data[0].replace(/\\\\/g, '\\'); |
| if (/^".*"$/.test(fileName)) { |
| fileName = fileName.substr(1, fileName.length - 2); |
| } |
| index[keyPrefix + 'FileName'] = fileName; |
| index[keyPrefix + 'Header'] = (data[1] || '').trim(); |
| |
| i++; |
| } |
| } |
| |
| // Parses a hunk |
| // This assumes that we are at the start of a hunk. |
| function parseHunk() { |
| var chunkHeaderIndex = i, |
| chunkHeaderLine = diffstr[i++], |
| chunkHeader = chunkHeaderLine.split(/@@ -(\d+)(?:,(\d+))? \+(\d+)(?:,(\d+))? @@/); |
| |
| var hunk = { |
| oldStart: +chunkHeader[1], |
| oldLines: +chunkHeader[2] || 1, |
| newStart: +chunkHeader[3], |
| newLines: +chunkHeader[4] || 1, |
| lines: [], |
| linedelimiters: [] |
| }; |
| |
| var addCount = 0, |
| removeCount = 0; |
| for (; i < diffstr.length; i++) { |
| // Lines starting with '---' could be mistaken for the "remove line" operation |
| // But they could be the header for the next file. Therefore prune such cases out. |
| if (diffstr[i].indexOf('--- ') === 0 && i + 2 < diffstr.length && diffstr[i + 1].indexOf('+++ ') === 0 && diffstr[i + 2].indexOf('@@') === 0) { |
| break; |
| } |
| var operation = diffstr[i].length == 0 && i != diffstr.length - 1 ? ' ' : diffstr[i][0]; |
| |
| if (operation === '+' || operation === '-' || operation === ' ' || operation === '\\') { |
| hunk.lines.push(diffstr[i]); |
| hunk.linedelimiters.push(delimiters[i] || '\n'); |
| |
| if (operation === '+') { |
| addCount++; |
| } else if (operation === '-') { |
| removeCount++; |
| } else if (operation === ' ') { |
| addCount++; |
| removeCount++; |
| } |
| } else { |
| break; |
| } |
| } |
| |
| // Handle the empty block count case |
| if (!addCount && hunk.newLines === 1) { |
| hunk.newLines = 0; |
| } |
| if (!removeCount && hunk.oldLines === 1) { |
| hunk.oldLines = 0; |
| } |
| |
| // Perform optional sanity checking |
| if (options.strict) { |
| if (addCount !== hunk.newLines) { |
| throw new Error('Added line count did not match for hunk at line ' + (chunkHeaderIndex + 1)); |
| } |
| if (removeCount !== hunk.oldLines) { |
| throw new Error('Removed line count did not match for hunk at line ' + (chunkHeaderIndex + 1)); |
| } |
| } |
| |
| return hunk; |
| } |
| |
| while (i < diffstr.length) { |
| parseIndex(); |
| } |
| |
| return list; |
| } |
| |
| |
| |
| /***/ }), |
| /* 12 */ |
| /***/ (function(module, exports) { |
| |
| /*istanbul ignore start*/"use strict"; |
| |
| exports.__esModule = true; |
| |
| exports["default"] = /*istanbul ignore end*/function (start, minLine, maxLine) { |
| var wantForward = true, |
| backwardExhausted = false, |
| forwardExhausted = false, |
| localOffset = 1; |
| |
| return function iterator() { |
| if (wantForward && !forwardExhausted) { |
| if (backwardExhausted) { |
| localOffset++; |
| } else { |
| wantForward = false; |
| } |
| |
| // Check if trying to fit beyond text length, and if not, check it fits |
| // after offset location (or desired location on first iteration) |
| if (start + localOffset <= maxLine) { |
| return localOffset; |
| } |
| |
| forwardExhausted = true; |
| } |
| |
| if (!backwardExhausted) { |
| if (!forwardExhausted) { |
| wantForward = true; |
| } |
| |
| // Check if trying to fit before text beginning, and if not, check it fits |
| // before offset location |
| if (minLine <= start - localOffset) { |
| return -localOffset++; |
| } |
| |
| backwardExhausted = true; |
| return iterator(); |
| } |
| |
| // We tried to fit hunk before text beginning and beyond text length, then |
| // hunk can't fit on the text. Return undefined |
| }; |
| }; |
| |
| |
| |
| /***/ }), |
| /* 13 */ |
| /***/ (function(module, exports, __webpack_require__) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports. /*istanbul ignore end*/calcLineCount = calcLineCount; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/merge = merge; |
| |
| var /*istanbul ignore start*/_create = __webpack_require__(14) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_parse = __webpack_require__(11) /*istanbul ignore end*/; |
| |
| var /*istanbul ignore start*/_array = __webpack_require__(15) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } |
| |
| /*istanbul ignore end*/function calcLineCount(hunk) { |
| /*istanbul ignore start*/var _calcOldNewLineCount = /*istanbul ignore end*/calcOldNewLineCount(hunk.lines), |
| oldLines = _calcOldNewLineCount.oldLines, |
| newLines = _calcOldNewLineCount.newLines; |
| |
| if (oldLines !== undefined) { |
| hunk.oldLines = oldLines; |
| } else { |
| delete hunk.oldLines; |
| } |
| |
| if (newLines !== undefined) { |
| hunk.newLines = newLines; |
| } else { |
| delete hunk.newLines; |
| } |
| } |
| |
| function merge(mine, theirs, base) { |
| mine = loadPatch(mine, base); |
| theirs = loadPatch(theirs, base); |
| |
| var ret = {}; |
| |
| // For index we just let it pass through as it doesn't have any necessary meaning. |
| // Leaving sanity checks on this to the API consumer that may know more about the |
| // meaning in their own context. |
| if (mine.index || theirs.index) { |
| ret.index = mine.index || theirs.index; |
| } |
| |
| if (mine.newFileName || theirs.newFileName) { |
| if (!fileNameChanged(mine)) { |
| // No header or no change in ours, use theirs (and ours if theirs does not exist) |
| ret.oldFileName = theirs.oldFileName || mine.oldFileName; |
| ret.newFileName = theirs.newFileName || mine.newFileName; |
| ret.oldHeader = theirs.oldHeader || mine.oldHeader; |
| ret.newHeader = theirs.newHeader || mine.newHeader; |
| } else if (!fileNameChanged(theirs)) { |
| // No header or no change in theirs, use ours |
| ret.oldFileName = mine.oldFileName; |
| ret.newFileName = mine.newFileName; |
| ret.oldHeader = mine.oldHeader; |
| ret.newHeader = mine.newHeader; |
| } else { |
| // Both changed... figure it out |
| ret.oldFileName = selectField(ret, mine.oldFileName, theirs.oldFileName); |
| ret.newFileName = selectField(ret, mine.newFileName, theirs.newFileName); |
| ret.oldHeader = selectField(ret, mine.oldHeader, theirs.oldHeader); |
| ret.newHeader = selectField(ret, mine.newHeader, theirs.newHeader); |
| } |
| } |
| |
| ret.hunks = []; |
| |
| var mineIndex = 0, |
| theirsIndex = 0, |
| mineOffset = 0, |
| theirsOffset = 0; |
| |
| while (mineIndex < mine.hunks.length || theirsIndex < theirs.hunks.length) { |
| var mineCurrent = mine.hunks[mineIndex] || { oldStart: Infinity }, |
| theirsCurrent = theirs.hunks[theirsIndex] || { oldStart: Infinity }; |
| |
| if (hunkBefore(mineCurrent, theirsCurrent)) { |
| // This patch does not overlap with any of the others, yay. |
| ret.hunks.push(cloneHunk(mineCurrent, mineOffset)); |
| mineIndex++; |
| theirsOffset += mineCurrent.newLines - mineCurrent.oldLines; |
| } else if (hunkBefore(theirsCurrent, mineCurrent)) { |
| // This patch does not overlap with any of the others, yay. |
| ret.hunks.push(cloneHunk(theirsCurrent, theirsOffset)); |
| theirsIndex++; |
| mineOffset += theirsCurrent.newLines - theirsCurrent.oldLines; |
| } else { |
| // Overlap, merge as best we can |
| var mergedHunk = { |
| oldStart: Math.min(mineCurrent.oldStart, theirsCurrent.oldStart), |
| oldLines: 0, |
| newStart: Math.min(mineCurrent.newStart + mineOffset, theirsCurrent.oldStart + theirsOffset), |
| newLines: 0, |
| lines: [] |
| }; |
| mergeLines(mergedHunk, mineCurrent.oldStart, mineCurrent.lines, theirsCurrent.oldStart, theirsCurrent.lines); |
| theirsIndex++; |
| mineIndex++; |
| |
| ret.hunks.push(mergedHunk); |
| } |
| } |
| |
| return ret; |
| } |
| |
| function loadPatch(param, base) { |
| if (typeof param === 'string') { |
| if (/^@@/m.test(param) || /^Index:/m.test(param)) { |
| return (/*istanbul ignore start*/(0, _parse.parsePatch) /*istanbul ignore end*/(param)[0] |
| ); |
| } |
| |
| if (!base) { |
| throw new Error('Must provide a base reference or pass in a patch'); |
| } |
| return (/*istanbul ignore start*/(0, _create.structuredPatch) /*istanbul ignore end*/(undefined, undefined, base, param) |
| ); |
| } |
| |
| return param; |
| } |
| |
| function fileNameChanged(patch) { |
| return patch.newFileName && patch.newFileName !== patch.oldFileName; |
| } |
| |
| function selectField(index, mine, theirs) { |
| if (mine === theirs) { |
| return mine; |
| } else { |
| index.conflict = true; |
| return { mine: mine, theirs: theirs }; |
| } |
| } |
| |
| function hunkBefore(test, check) { |
| return test.oldStart < check.oldStart && test.oldStart + test.oldLines < check.oldStart; |
| } |
| |
| function cloneHunk(hunk, offset) { |
| return { |
| oldStart: hunk.oldStart, oldLines: hunk.oldLines, |
| newStart: hunk.newStart + offset, newLines: hunk.newLines, |
| lines: hunk.lines |
| }; |
| } |
| |
| function mergeLines(hunk, mineOffset, mineLines, theirOffset, theirLines) { |
| // This will generally result in a conflicted hunk, but there are cases where the context |
| // is the only overlap where we can successfully merge the content here. |
| var mine = { offset: mineOffset, lines: mineLines, index: 0 }, |
| their = { offset: theirOffset, lines: theirLines, index: 0 }; |
| |
| // Handle any leading content |
| insertLeading(hunk, mine, their); |
| insertLeading(hunk, their, mine); |
| |
| // Now in the overlap content. Scan through and select the best changes from each. |
| while (mine.index < mine.lines.length && their.index < their.lines.length) { |
| var mineCurrent = mine.lines[mine.index], |
| theirCurrent = their.lines[their.index]; |
| |
| if ((mineCurrent[0] === '-' || mineCurrent[0] === '+') && (theirCurrent[0] === '-' || theirCurrent[0] === '+')) { |
| // Both modified ... |
| mutualChange(hunk, mine, their); |
| } else if (mineCurrent[0] === '+' && theirCurrent[0] === ' ') { |
| /*istanbul ignore start*/var _hunk$lines; |
| |
| /*istanbul ignore end*/ // Mine inserted |
| /*istanbul ignore start*/(_hunk$lines = /*istanbul ignore end*/hunk.lines).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_hunk$lines /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/collectChange(mine))); |
| } else if (theirCurrent[0] === '+' && mineCurrent[0] === ' ') { |
| /*istanbul ignore start*/var _hunk$lines2; |
| |
| /*istanbul ignore end*/ // Theirs inserted |
| /*istanbul ignore start*/(_hunk$lines2 = /*istanbul ignore end*/hunk.lines).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_hunk$lines2 /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/collectChange(their))); |
| } else if (mineCurrent[0] === '-' && theirCurrent[0] === ' ') { |
| // Mine removed or edited |
| removal(hunk, mine, their); |
| } else if (theirCurrent[0] === '-' && mineCurrent[0] === ' ') { |
| // Their removed or edited |
| removal(hunk, their, mine, true); |
| } else if (mineCurrent === theirCurrent) { |
| // Context identity |
| hunk.lines.push(mineCurrent); |
| mine.index++; |
| their.index++; |
| } else { |
| // Context mismatch |
| conflict(hunk, collectChange(mine), collectChange(their)); |
| } |
| } |
| |
| // Now push anything that may be remaining |
| insertTrailing(hunk, mine); |
| insertTrailing(hunk, their); |
| |
| calcLineCount(hunk); |
| } |
| |
| function mutualChange(hunk, mine, their) { |
| var myChanges = collectChange(mine), |
| theirChanges = collectChange(their); |
| |
| if (allRemoves(myChanges) && allRemoves(theirChanges)) { |
| // Special case for remove changes that are supersets of one another |
| if ( /*istanbul ignore start*/(0, _array.arrayStartsWith) /*istanbul ignore end*/(myChanges, theirChanges) && skipRemoveSuperset(their, myChanges, myChanges.length - theirChanges.length)) { |
| /*istanbul ignore start*/var _hunk$lines3; |
| |
| /*istanbul ignore end*/ /*istanbul ignore start*/(_hunk$lines3 = /*istanbul ignore end*/hunk.lines).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_hunk$lines3 /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/myChanges)); |
| return; |
| } else if ( /*istanbul ignore start*/(0, _array.arrayStartsWith) /*istanbul ignore end*/(theirChanges, myChanges) && skipRemoveSuperset(mine, theirChanges, theirChanges.length - myChanges.length)) { |
| /*istanbul ignore start*/var _hunk$lines4; |
| |
| /*istanbul ignore end*/ /*istanbul ignore start*/(_hunk$lines4 = /*istanbul ignore end*/hunk.lines).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_hunk$lines4 /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/theirChanges)); |
| return; |
| } |
| } else if ( /*istanbul ignore start*/(0, _array.arrayEqual) /*istanbul ignore end*/(myChanges, theirChanges)) { |
| /*istanbul ignore start*/var _hunk$lines5; |
| |
| /*istanbul ignore end*/ /*istanbul ignore start*/(_hunk$lines5 = /*istanbul ignore end*/hunk.lines).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_hunk$lines5 /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/myChanges)); |
| return; |
| } |
| |
| conflict(hunk, myChanges, theirChanges); |
| } |
| |
| function removal(hunk, mine, their, swap) { |
| var myChanges = collectChange(mine), |
| theirChanges = collectContext(their, myChanges); |
| if (theirChanges.merged) { |
| /*istanbul ignore start*/var _hunk$lines6; |
| |
| /*istanbul ignore end*/ /*istanbul ignore start*/(_hunk$lines6 = /*istanbul ignore end*/hunk.lines).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_hunk$lines6 /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/theirChanges.merged)); |
| } else { |
| conflict(hunk, swap ? theirChanges : myChanges, swap ? myChanges : theirChanges); |
| } |
| } |
| |
| function conflict(hunk, mine, their) { |
| hunk.conflict = true; |
| hunk.lines.push({ |
| conflict: true, |
| mine: mine, |
| theirs: their |
| }); |
| } |
| |
| function insertLeading(hunk, insert, their) { |
| while (insert.offset < their.offset && insert.index < insert.lines.length) { |
| var line = insert.lines[insert.index++]; |
| hunk.lines.push(line); |
| insert.offset++; |
| } |
| } |
| function insertTrailing(hunk, insert) { |
| while (insert.index < insert.lines.length) { |
| var line = insert.lines[insert.index++]; |
| hunk.lines.push(line); |
| } |
| } |
| |
| function collectChange(state) { |
| var ret = [], |
| operation = state.lines[state.index][0]; |
| while (state.index < state.lines.length) { |
| var line = state.lines[state.index]; |
| |
| // Group additions that are immediately after subtractions and treat them as one "atomic" modify change. |
| if (operation === '-' && line[0] === '+') { |
| operation = '+'; |
| } |
| |
| if (operation === line[0]) { |
| ret.push(line); |
| state.index++; |
| } else { |
| break; |
| } |
| } |
| |
| return ret; |
| } |
| function collectContext(state, matchChanges) { |
| var changes = [], |
| merged = [], |
| matchIndex = 0, |
| contextChanges = false, |
| conflicted = false; |
| while (matchIndex < matchChanges.length && state.index < state.lines.length) { |
| var change = state.lines[state.index], |
| match = matchChanges[matchIndex]; |
| |
| // Once we've hit our add, then we are done |
| if (match[0] === '+') { |
| break; |
| } |
| |
| contextChanges = contextChanges || change[0] !== ' '; |
| |
| merged.push(match); |
| matchIndex++; |
| |
| // Consume any additions in the other block as a conflict to attempt |
| // to pull in the remaining context after this |
| if (change[0] === '+') { |
| conflicted = true; |
| |
| while (change[0] === '+') { |
| changes.push(change); |
| change = state.lines[++state.index]; |
| } |
| } |
| |
| if (match.substr(1) === change.substr(1)) { |
| changes.push(change); |
| state.index++; |
| } else { |
| conflicted = true; |
| } |
| } |
| |
| if ((matchChanges[matchIndex] || '')[0] === '+' && contextChanges) { |
| conflicted = true; |
| } |
| |
| if (conflicted) { |
| return changes; |
| } |
| |
| while (matchIndex < matchChanges.length) { |
| merged.push(matchChanges[matchIndex++]); |
| } |
| |
| return { |
| merged: merged, |
| changes: changes |
| }; |
| } |
| |
| function allRemoves(changes) { |
| return changes.reduce(function (prev, change) { |
| return prev && change[0] === '-'; |
| }, true); |
| } |
| function skipRemoveSuperset(state, removeChanges, delta) { |
| for (var i = 0; i < delta; i++) { |
| var changeContent = removeChanges[removeChanges.length - delta + i].substr(1); |
| if (state.lines[state.index + i] !== ' ' + changeContent) { |
| return false; |
| } |
| } |
| |
| state.index += delta; |
| return true; |
| } |
| |
| function calcOldNewLineCount(lines) { |
| var oldLines = 0; |
| var newLines = 0; |
| |
| lines.forEach(function (line) { |
| if (typeof line !== 'string') { |
| var myCount = calcOldNewLineCount(line.mine); |
| var theirCount = calcOldNewLineCount(line.theirs); |
| |
| if (oldLines !== undefined) { |
| if (myCount.oldLines === theirCount.oldLines) { |
| oldLines += myCount.oldLines; |
| } else { |
| oldLines = undefined; |
| } |
| } |
| |
| if (newLines !== undefined) { |
| if (myCount.newLines === theirCount.newLines) { |
| newLines += myCount.newLines; |
| } else { |
| newLines = undefined; |
| } |
| } |
| } else { |
| if (newLines !== undefined && (line[0] === '+' || line[0] === ' ')) { |
| newLines++; |
| } |
| if (oldLines !== undefined && (line[0] === '-' || line[0] === ' ')) { |
| oldLines++; |
| } |
| } |
| }); |
| |
| return { oldLines: oldLines, newLines: newLines }; |
| } |
| |
| |
| |
| /***/ }), |
| /* 14 */ |
| /***/ (function(module, exports, __webpack_require__) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports. /*istanbul ignore end*/structuredPatch = structuredPatch; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/createTwoFilesPatch = createTwoFilesPatch; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/createPatch = createPatch; |
| |
| var /*istanbul ignore start*/_line = __webpack_require__(5) /*istanbul ignore end*/; |
| |
| /*istanbul ignore start*/function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } |
| |
| /*istanbul ignore end*/function structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) { |
| if (!options) { |
| options = {}; |
| } |
| if (typeof options.context === 'undefined') { |
| options.context = 4; |
| } |
| |
| var diff = /*istanbul ignore start*/(0, _line.diffLines) /*istanbul ignore end*/(oldStr, newStr, options); |
| diff.push({ value: '', lines: [] }); // Append an empty value to make cleanup easier |
| |
| function contextLines(lines) { |
| return lines.map(function (entry) { |
| return ' ' + entry; |
| }); |
| } |
| |
| var hunks = []; |
| var oldRangeStart = 0, |
| newRangeStart = 0, |
| curRange = [], |
| oldLine = 1, |
| newLine = 1; |
| |
| /*istanbul ignore start*/var _loop = function _loop( /*istanbul ignore end*/i) { |
| var current = diff[i], |
| lines = current.lines || current.value.replace(/\n$/, '').split('\n'); |
| current.lines = lines; |
| |
| if (current.added || current.removed) { |
| /*istanbul ignore start*/var _curRange; |
| |
| /*istanbul ignore end*/ // If we have previous context, start with that |
| if (!oldRangeStart) { |
| var prev = diff[i - 1]; |
| oldRangeStart = oldLine; |
| newRangeStart = newLine; |
| |
| if (prev) { |
| curRange = options.context > 0 ? contextLines(prev.lines.slice(-options.context)) : []; |
| oldRangeStart -= curRange.length; |
| newRangeStart -= curRange.length; |
| } |
| } |
| |
| // Output our changes |
| /*istanbul ignore start*/(_curRange = /*istanbul ignore end*/curRange).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_curRange /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/lines.map(function (entry) { |
| return (current.added ? '+' : '-') + entry; |
| }))); |
| |
| // Track the updated file position |
| if (current.added) { |
| newLine += lines.length; |
| } else { |
| oldLine += lines.length; |
| } |
| } else { |
| // Identical context lines. Track line changes |
| if (oldRangeStart) { |
| // Close out any changes that have been output (or join overlapping) |
| if (lines.length <= options.context * 2 && i < diff.length - 2) { |
| /*istanbul ignore start*/var _curRange2; |
| |
| /*istanbul ignore end*/ // Overlapping |
| /*istanbul ignore start*/(_curRange2 = /*istanbul ignore end*/curRange).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_curRange2 /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/contextLines(lines))); |
| } else { |
| /*istanbul ignore start*/var _curRange3; |
| |
| /*istanbul ignore end*/ // end the range and output |
| var contextSize = Math.min(lines.length, options.context); |
| /*istanbul ignore start*/(_curRange3 = /*istanbul ignore end*/curRange).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_curRange3 /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/contextLines(lines.slice(0, contextSize)))); |
| |
| var hunk = { |
| oldStart: oldRangeStart, |
| oldLines: oldLine - oldRangeStart + contextSize, |
| newStart: newRangeStart, |
| newLines: newLine - newRangeStart + contextSize, |
| lines: curRange |
| }; |
| if (i >= diff.length - 2 && lines.length <= options.context) { |
| // EOF is inside this hunk |
| var oldEOFNewline = /\n$/.test(oldStr); |
| var newEOFNewline = /\n$/.test(newStr); |
| if (lines.length == 0 && !oldEOFNewline) { |
| // special case: old has no eol and no trailing context; no-nl can end up before adds |
| curRange.splice(hunk.oldLines, 0, '\\ No newline at end of file'); |
| } else if (!oldEOFNewline || !newEOFNewline) { |
| curRange.push('\\ No newline at end of file'); |
| } |
| } |
| hunks.push(hunk); |
| |
| oldRangeStart = 0; |
| newRangeStart = 0; |
| curRange = []; |
| } |
| } |
| oldLine += lines.length; |
| newLine += lines.length; |
| } |
| }; |
| |
| for (var i = 0; i < diff.length; i++) { |
| /*istanbul ignore start*/_loop( /*istanbul ignore end*/i); |
| } |
| |
| return { |
| oldFileName: oldFileName, newFileName: newFileName, |
| oldHeader: oldHeader, newHeader: newHeader, |
| hunks: hunks |
| }; |
| } |
| |
| function createTwoFilesPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) { |
| var diff = structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options); |
| |
| var ret = []; |
| if (oldFileName == newFileName) { |
| ret.push('Index: ' + oldFileName); |
| } |
| ret.push('==================================================================='); |
| ret.push('--- ' + diff.oldFileName + (typeof diff.oldHeader === 'undefined' ? '' : '\t' + diff.oldHeader)); |
| ret.push('+++ ' + diff.newFileName + (typeof diff.newHeader === 'undefined' ? '' : '\t' + diff.newHeader)); |
| |
| for (var i = 0; i < diff.hunks.length; i++) { |
| var hunk = diff.hunks[i]; |
| ret.push('@@ -' + hunk.oldStart + ',' + hunk.oldLines + ' +' + hunk.newStart + ',' + hunk.newLines + ' @@'); |
| ret.push.apply(ret, hunk.lines); |
| } |
| |
| return ret.join('\n') + '\n'; |
| } |
| |
| function createPatch(fileName, oldStr, newStr, oldHeader, newHeader, options) { |
| return createTwoFilesPatch(fileName, fileName, oldStr, newStr, oldHeader, newHeader, options); |
| } |
| |
| |
| |
| /***/ }), |
| /* 15 */ |
| /***/ (function(module, exports) { |
| |
| /*istanbul ignore start*/"use strict"; |
| |
| exports.__esModule = true; |
| exports. /*istanbul ignore end*/arrayEqual = arrayEqual; |
| /*istanbul ignore start*/exports. /*istanbul ignore end*/arrayStartsWith = arrayStartsWith; |
| function arrayEqual(a, b) { |
| if (a.length !== b.length) { |
| return false; |
| } |
| |
| return arrayStartsWith(a, b); |
| } |
| |
| function arrayStartsWith(array, start) { |
| if (start.length > array.length) { |
| return false; |
| } |
| |
| for (var i = 0; i < start.length; i++) { |
| if (start[i] !== array[i]) { |
| return false; |
| } |
| } |
| |
| return true; |
| } |
| |
| |
| |
| /***/ }), |
| /* 16 */ |
| /***/ (function(module, exports) { |
| |
| /*istanbul ignore start*/"use strict"; |
| |
| exports.__esModule = true; |
| exports. /*istanbul ignore end*/convertChangesToDMP = convertChangesToDMP; |
| // See: http://code.google.com/p/google-diff-match-patch/wiki/API |
| function convertChangesToDMP(changes) { |
| var ret = [], |
| change = /*istanbul ignore start*/void 0 /*istanbul ignore end*/, |
| operation = /*istanbul ignore start*/void 0 /*istanbul ignore end*/; |
| for (var i = 0; i < changes.length; i++) { |
| change = changes[i]; |
| if (change.added) { |
| operation = 1; |
| } else if (change.removed) { |
| operation = -1; |
| } else { |
| operation = 0; |
| } |
| |
| ret.push([operation, change.value]); |
| } |
| return ret; |
| } |
| |
| |
| |
| /***/ }), |
| /* 17 */ |
| /***/ (function(module, exports) { |
| |
| /*istanbul ignore start*/'use strict'; |
| |
| exports.__esModule = true; |
| exports. /*istanbul ignore end*/convertChangesToXML = convertChangesToXML; |
| function convertChangesToXML(changes) { |
| var ret = []; |
| for (var i = 0; i < changes.length; i++) { |
| var change = changes[i]; |
| if (change.added) { |
| ret.push('<ins>'); |
| } else if (change.removed) { |
| ret.push('<del>'); |
| } |
| |
| ret.push(escapeHTML(change.value)); |
| |
| if (change.added) { |
| ret.push('</ins>'); |
| } else if (change.removed) { |
| ret.push('</del>'); |
| } |
| } |
| return ret.join(''); |
| } |
| |
| function escapeHTML(s) { |
| var n = s; |
| n = n.replace(/&/g, '&'); |
| n = n.replace(/</g, '<'); |
| n = n.replace(/>/g, '>'); |
| n = n.replace(/"/g, '"'); |
| |
| return n; |
| } |
| |
| |
| |
| /***/ }) |
| /******/ ]) |
| }); |
| ; |
| },{}],49:[function(require,module,exports){ |
| 'use strict'; |
| |
| var matchOperatorsRe = /[|\\{}()[\]^$+*?.]/g; |
| |
| module.exports = function (str) { |
| if (typeof str !== 'string') { |
| throw new TypeError('Expected a string'); |
| } |
| |
| return str.replace(matchOperatorsRe, '\\$&'); |
| }; |
| |
| },{}],50:[function(require,module,exports){ |
| // Copyright Joyent, Inc. and other Node contributors. |
| // |
| // Permission is hereby granted, free of charge, to any person obtaining a |
| // copy of this software and associated documentation files (the |
| // "Software"), to deal in the Software without restriction, including |
| // without limitation the rights to use, copy, modify, merge, publish, |
| // distribute, sublicense, and/or sell copies of the Software, and to permit |
| // persons to whom the Software is furnished to do so, subject to the |
| // following conditions: |
| // |
| // The above copyright notice and this permission notice shall be included |
| // in all copies or substantial portions of the Software. |
| // |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN |
| // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
| // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
| // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE |
| // USE OR OTHER DEALINGS IN THE SOFTWARE. |
| |
| var objectCreate = Object.create || objectCreatePolyfill |
| var objectKeys = Object.keys || objectKeysPolyfill |
| var bind = Function.prototype.bind || functionBindPolyfill |
| |
| function EventEmitter() { |
| if (!this._events || !Object.prototype.hasOwnProperty.call(this, '_events')) { |
| this._events = objectCreate(null); |
| this._eventsCount = 0; |
| } |
| |
| this._maxListeners = this._maxListeners || undefined; |
| } |
| module.exports = EventEmitter; |
| |
| // Backwards-compat with node 0.10.x |
| EventEmitter.EventEmitter = EventEmitter; |
| |
| EventEmitter.prototype._events = undefined; |
| EventEmitter.prototype._maxListeners = undefined; |
| |
| // By default EventEmitters will print a warning if more than 10 listeners are |
| // added to it. This is a useful default which helps finding memory leaks. |
| var defaultMaxListeners = 10; |
| |
| var hasDefineProperty; |
| try { |
| var o = {}; |
| if (Object.defineProperty) Object.defineProperty(o, 'x', { value: 0 }); |
| hasDefineProperty = o.x === 0; |
| } catch (err) { hasDefineProperty = false } |
| if (hasDefineProperty) { |
| Object.defineProperty(EventEmitter, 'defaultMaxListeners', { |
| enumerable: true, |
| get: function() { |
| return defaultMaxListeners; |
| }, |
| set: function(arg) { |
| // check whether the input is a positive number (whose value is zero or |
| // greater and not a NaN). |
| if (typeof arg !== 'number' || arg < 0 || arg !== arg) |
| throw new TypeError('"defaultMaxListeners" must be a positive number'); |
| defaultMaxListeners = arg; |
| } |
| }); |
| } else { |
| EventEmitter.defaultMaxListeners = defaultMaxListeners; |
| } |
| |
| // Obviously not all Emitters should be limited to 10. This function allows |
| // that to be increased. Set to zero for unlimited. |
| EventEmitter.prototype.setMaxListeners = function setMaxListeners(n) { |
| if (typeof n !== 'number' || n < 0 || isNaN(n)) |
| throw new TypeError('"n" argument must be a positive number'); |
| this._maxListeners = n; |
| return this; |
| }; |
| |
| function $getMaxListeners(that) { |
| if (that._maxListeners === undefined) |
| return EventEmitter.defaultMaxListeners; |
| return that._maxListeners; |
| } |
| |
| EventEmitter.prototype.getMaxListeners = function getMaxListeners() { |
| return $getMaxListeners(this); |
| }; |
| |
| // These standalone emit* functions are used to optimize calling of event |
| // handlers for fast cases because emit() itself often has a variable number of |
| // arguments and can be deoptimized because of that. These functions always have |
| // the same number of arguments and thus do not get deoptimized, so the code |
| // inside them can execute faster. |
| function emitNone(handler, isFn, self) { |
| if (isFn) |
| handler.call(self); |
| else { |
| var len = handler.length; |
| var listeners = arrayClone(handler, len); |
| for (var i = 0; i < len; ++i) |
| listeners[i].call(self); |
| } |
| } |
| function emitOne(handler, isFn, self, arg1) { |
| if (isFn) |
| handler.call(self, arg1); |
| else { |
| var len = handler.length; |
| var listeners = arrayClone(handler, len); |
| for (var i = 0; i < len; ++i) |
| listeners[i].call(self, arg1); |
| } |
| } |
| function emitTwo(handler, isFn, self, arg1, arg2) { |
| if (isFn) |
| handler.call(self, arg1, arg2); |
| else { |
| var len = handler.length; |
| var listeners = arrayClone(handler, len); |
| for (var i = 0; i < len; ++i) |
| listeners[i].call(self, arg1, arg2); |
| } |
| } |
| function emitThree(handler, isFn, self, arg1, arg2, arg3) { |
| if (isFn) |
| handler.call(self, arg1, arg2, arg3); |
| else { |
| var len = handler.length; |
| var listeners = arrayClone(handler, len); |
| for (var i = 0; i < len; ++i) |
| listeners[i].call(self, arg1, arg2, arg3); |
| } |
| } |
| |
| function emitMany(handler, isFn, self, args) { |
| if (isFn) |
| handler.apply(self, args); |
| else { |
| var len = handler.length; |
| var listeners = arrayClone(handler, len); |
| for (var i = 0; i < len; ++i) |
| listeners[i].apply(self, args); |
| } |
| } |
| |
| EventEmitter.prototype.emit = function emit(type) { |
| var er, handler, len, args, i, events; |
| var doError = (type === 'error'); |
| |
| events = this._events; |
| if (events) |
| doError = (doError && events.error == null); |
| else if (!doError) |
| return false; |
| |
| // If there is no 'error' event listener then throw. |
| if (doError) { |
| if (arguments.length > 1) |
| er = arguments[1]; |
| if (er instanceof Error) { |
| throw er; // Unhandled 'error' event |
| } else { |
| // At least give some kind of context to the user |
| var err = new Error('Unhandled "error" event. (' + er + ')'); |
| err.context = er; |
| throw err; |
| } |
| return false; |
| } |
| |
| handler = events[type]; |
| |
| if (!handler) |
| return false; |
| |
| var isFn = typeof handler === 'function'; |
| len = arguments.length; |
| switch (len) { |
| // fast cases |
| case 1: |
| emitNone(handler, isFn, this); |
| break; |
| case 2: |
| emitOne(handler, isFn, this, arguments[1]); |
| break; |
| case 3: |
| emitTwo(handler, isFn, this, arguments[1], arguments[2]); |
| break; |
| case 4: |
| emitThree(handler, isFn, this, arguments[1], arguments[2], arguments[3]); |
| break; |
| // slower |
| default: |
| args = new Array(len - 1); |
| for (i = 1; i < len; i++) |
| args[i - 1] = arguments[i]; |
| emitMany(handler, isFn, this, args); |
| } |
| |
| return true; |
| }; |
| |
| function _addListener(target, type, listener, prepend) { |
| var m; |
| var events; |
| var existing; |
| |
| if (typeof listener !== 'function') |
| throw new TypeError('"listener" argument must be a function'); |
| |
| events = target._events; |
| if (!events) { |
| events = target._events = objectCreate(null); |
| target._eventsCount = 0; |
| } else { |
| // To avoid recursion in the case that type === "newListener"! Before |
| // adding it to the listeners, first emit "newListener". |
| if (events.newListener) { |
| target.emit('newListener', type, |
| listener.listener ? listener.listener : listener); |
| |
| // Re-assign `events` because a newListener handler could have caused the |
| // this._events to be assigned to a new object |
| events = target._events; |
| } |
| existing = events[type]; |
| } |
| |
| if (!existing) { |
| // Optimize the case of one listener. Don't need the extra array object. |
| existing = events[type] = listener; |
| ++target._eventsCount; |
| } else { |
| if (typeof existing === 'function') { |
| // Adding the second element, need to change to array. |
| existing = events[type] = |
| prepend ? [listener, existing] : [existing, listener]; |
| } else { |
| // If we've already got an array, just append. |
| if (prepend) { |
| existing.unshift(listener); |
| } else { |
| existing.push(listener); |
| } |
| } |
| |
| // Check for listener leak |
| if (!existing.warned) { |
| m = $getMaxListeners(target); |
| if (m && m > 0 && existing.length > m) { |
| existing.warned = true; |
| var w = new Error('Possible EventEmitter memory leak detected. ' + |
| existing.length + ' "' + String(type) + '" listeners ' + |
| 'added. Use emitter.setMaxListeners() to ' + |
| 'increase limit.'); |
| w.name = 'MaxListenersExceededWarning'; |
| w.emitter = target; |
| w.type = type; |
| w.count = existing.length; |
| if (typeof console === 'object' && console.warn) { |
| console.warn('%s: %s', w.name, w.message); |
| } |
| } |
| } |
| } |
| |
| return target; |
| } |
| |
| EventEmitter.prototype.addListener = function addListener(type, listener) { |
| return _addListener(this, type, listener, false); |
| }; |
| |
| EventEmitter.prototype.on = EventEmitter.prototype.addListener; |
| |
| EventEmitter.prototype.prependListener = |
| function prependListener(type, listener) { |
| return _addListener(this, type, listener, true); |
| }; |
| |
| function onceWrapper() { |
| if (!this.fired) { |
| this.target.removeListener(this.type, this.wrapFn); |
| this.fired = true; |
| switch (arguments.length) { |
| case 0: |
| return this.listener.call(this.target); |
| case 1: |
| return this.listener.call(this.target, arguments[0]); |
| case 2: |
| return this.listener.call(this.target, arguments[0], arguments[1]); |
| case 3: |
| return this.listener.call(this.target, arguments[0], arguments[1], |
| arguments[2]); |
| default: |
| var args = new Array(arguments.length); |
| for (var i = 0; i < args.length; ++i) |
| args[i] = arguments[i]; |
| this.listener.apply(this.target, args); |
| } |
| } |
| } |
| |
| function _onceWrap(target, type, listener) { |
| var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener }; |
| var wrapped = bind.call(onceWrapper, state); |
| wrapped.listener = listener; |
| state.wrapFn = wrapped; |
| return wrapped; |
| } |
| |
| EventEmitter.prototype.once = function once(type, listener) { |
| if (typeof listener !== 'function') |
| throw new TypeError('"listener" argument must be a function'); |
| this.on(type, _onceWrap(this, type, listener)); |
| return this; |
| }; |
| |
| EventEmitter.prototype.prependOnceListener = |
| function prependOnceListener(type, listener) { |
| if (typeof listener !== 'function') |
| throw new TypeError('"listener" argument must be a function'); |
| this.prependListener(type, _onceWrap(this, type, listener)); |
| return this; |
| }; |
| |
| // Emits a 'removeListener' event if and only if the listener was removed. |
| EventEmitter.prototype.removeListener = |
| function removeListener(type, listener) { |
| var list, events, position, i, originalListener; |
| |
| if (typeof listener !== 'function') |
| throw new TypeError('"listener" argument must be a function'); |
| |
| events = this._events; |
| if (!events) |
| return this; |
| |
| list = events[type]; |
| if (!list) |
| return this; |
| |
| if (list === listener || list.listener === listener) { |
| if (--this._eventsCount === 0) |
| this._events = objectCreate(null); |
| else { |
| delete events[type]; |
| if (events.removeListener) |
| this.emit('removeListener', type, list.listener || listener); |
| } |
| } else if (typeof list !== 'function') { |
| position = -1; |
| |
| for (i = list.length - 1; i >= 0; i--) { |
| if (list[i] === listener || list[i].listener === listener) { |
| originalListener = list[i].listener; |
| position = i; |
| break; |
| } |
| } |
| |
| if (position < 0) |
| return this; |
| |
| if (position === 0) |
| list.shift(); |
| else |
| spliceOne(list, position); |
| |
| if (list.length === 1) |
| events[type] = list[0]; |
| |
| if (events.removeListener) |
| this.emit('removeListener', type, originalListener || listener); |
| } |
| |
| return this; |
| }; |
| |
| EventEmitter.prototype.removeAllListeners = |
| function removeAllListeners(type) { |
| var listeners, events, i; |
| |
| events = this._events; |
| if (!events) |
| return this; |
| |
| // not listening for removeListener, no need to emit |
| if (!events.removeListener) { |
| if (arguments.length === 0) { |
| this._events = objectCreate(null); |
| this._eventsCount = 0; |
| } else if (events[type]) { |
| if (--this._eventsCount === 0) |
| this._events = objectCreate(null); |
| else |
| delete events[type]; |
| } |
| return this; |
| } |
| |
| // emit removeListener for all listeners on all events |
| if (arguments.length === 0) { |
| var keys = objectKeys(events); |
| var key; |
| for (i = 0; i < keys.length; ++i) { |
| key = keys[i]; |
| if (key === 'removeListener') continue; |
| this.removeAllListeners(key); |
| } |
| this.removeAllListeners('removeListener'); |
| this._events = objectCreate(null); |
| this._eventsCount = 0; |
| return this; |
| } |
| |
| listeners = events[type]; |
| |
| if (typeof listeners === 'function') { |
| this.removeListener(type, listeners); |
| } else if (listeners) { |
| // LIFO order |
| for (i = listeners.length - 1; i >= 0; i--) { |
| this.removeListener(type, listeners[i]); |
| } |
| } |
| |
| return this; |
| }; |
| |
| function _listeners(target, type, unwrap) { |
| var events = target._events; |
| |
| if (!events) |
| return []; |
| |
| var evlistener = events[type]; |
| if (!evlistener) |
| return []; |
| |
| if (typeof evlistener === 'function') |
| return unwrap ? [evlistener.listener || evlistener] : [evlistener]; |
| |
| return unwrap ? unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length); |
| } |
| |
| EventEmitter.prototype.listeners = function listeners(type) { |
| return _listeners(this, type, true); |
| }; |
| |
| EventEmitter.prototype.rawListeners = function rawListeners(type) { |
| return _listeners(this, type, false); |
| }; |
| |
| EventEmitter.listenerCount = function(emitter, type) { |
| if (typeof emitter.listenerCount === 'function') { |
| return emitter.listenerCount(type); |
| } else { |
| return listenerCount.call(emitter, type); |
| } |
| }; |
| |
| EventEmitter.prototype.listenerCount = listenerCount; |
| function listenerCount(type) { |
| var events = this._events; |
| |
| if (events) { |
| var evlistener = events[type]; |
| |
| if (typeof evlistener === 'function') { |
| return 1; |
| } else if (evlistener) { |
| return evlistener.length; |
| } |
| } |
| |
| return 0; |
| } |
| |
| EventEmitter.prototype.eventNames = function eventNames() { |
| return this._eventsCount > 0 ? Reflect.ownKeys(this._events) : []; |
| }; |
| |
| // About 1.5x faster than the two-arg version of Array#splice(). |
| function spliceOne(list, index) { |
| for (var i = index, k = i + 1, n = list.length; k < n; i += 1, k += 1) |
| list[i] = list[k]; |
| list.pop(); |
| } |
| |
| function arrayClone(arr, n) { |
| var copy = new Array(n); |
| for (var i = 0; i < n; ++i) |
| copy[i] = arr[i]; |
| return copy; |
| } |
| |
| function unwrapListeners(arr) { |
| var ret = new Array(arr.length); |
| for (var i = 0; i < ret.length; ++i) { |
| ret[i] = arr[i].listener || arr[i]; |
| } |
| return ret; |
| } |
| |
| function objectCreatePolyfill(proto) { |
| var F = function() {}; |
| F.prototype = proto; |
| return new F; |
| } |
| function objectKeysPolyfill(obj) { |
| var keys = []; |
| for (var k in obj) if (Object.prototype.hasOwnProperty.call(obj, k)) { |
| keys.push(k); |
| } |
| return k; |
| } |
| function functionBindPolyfill(context) { |
| var fn = this; |
| return function () { |
| return fn.apply(context, arguments); |
| }; |
| } |
| |
| },{}],51:[function(require,module,exports){ |
| 'use strict'; |
| |
| /* eslint no-invalid-this: 1 */ |
| |
| var ERROR_MESSAGE = 'Function.prototype.bind called on incompatible '; |
| var slice = Array.prototype.slice; |
| var toStr = Object.prototype.toString; |
| var funcType = '[object Function]'; |
| |
| module.exports = function bind(that) { |
| var target = this; |
| if (typeof target !== 'function' || toStr.call(target) !== funcType) { |
| throw new TypeError(ERROR_MESSAGE + target); |
| } |
| var args = slice.call(arguments, 1); |
| |
| var bound; |
| var binder = function () { |
| if (this instanceof bound) { |
| var result = target.apply( |
| this, |
| args.concat(slice.call(arguments)) |
| ); |
| if (Object(result) === result) { |
| return result; |
| } |
| return this; |
| } else { |
| return target.apply( |
| that, |
| args.concat(slice.call(arguments)) |
| ); |
| } |
| }; |
| |
| var boundLength = Math.max(0, target.length - args.length); |
| var boundArgs = []; |
| for (var i = 0; i < boundLength; i++) { |
| boundArgs.push('$' + i); |
| } |
| |
| bound = Function('binder', 'return function (' + boundArgs.join(',') + '){ return binder.apply(this,arguments); }')(binder); |
| |
| if (target.prototype) { |
| var Empty = function Empty() {}; |
| Empty.prototype = target.prototype; |
| bound.prototype = new Empty(); |
| Empty.prototype = null; |
| } |
| |
| return bound; |
| }; |
| |
| },{}],52:[function(require,module,exports){ |
| 'use strict'; |
| |
| var implementation = require('./implementation'); |
| |
| module.exports = Function.prototype.bind || implementation; |
| |
| },{"./implementation":51}],53:[function(require,module,exports){ |
| 'use strict'; |
| |
| /* eslint complexity: [2, 17], max-statements: [2, 33] */ |
| module.exports = function hasSymbols() { |
| if (typeof Symbol !== 'function' || typeof Object.getOwnPropertySymbols !== 'function') { return false; } |
| if (typeof Symbol.iterator === 'symbol') { return true; } |
| |
| var obj = {}; |
| var sym = Symbol('test'); |
| var symObj = Object(sym); |
| if (typeof sym === 'string') { return false; } |
| |
| if (Object.prototype.toString.call(sym) !== '[object Symbol]') { return false; } |
| if (Object.prototype.toString.call(symObj) !== '[object Symbol]') { return false; } |
| |
| // temp disabled per https://github.com/ljharb/object.assign/issues/17 |
| // if (sym instanceof Symbol) { return false; } |
| // temp disabled per https://github.com/WebReflection/get-own-property-symbols/issues/4 |
| // if (!(symObj instanceof Symbol)) { return false; } |
| |
| // if (typeof Symbol.prototype.toString !== 'function') { return false; } |
| // if (String(sym) !== Symbol.prototype.toString.call(sym)) { return false; } |
| |
| var symVal = 42; |
| obj[sym] = symVal; |
| for (sym in obj) { return false; } // eslint-disable-line no-restricted-syntax |
| if (typeof Object.keys === 'function' && Object.keys(obj).length !== 0) { return false; } |
| |
| if (typeof Object.getOwnPropertyNames === 'function' && Object.getOwnPropertyNames(obj).length !== 0) { return false; } |
| |
| var syms = Object.getOwnPropertySymbols(obj); |
| if (syms.length !== 1 || syms[0] !== sym) { return false; } |
| |
| if (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { return false; } |
| |
| if (typeof Object.getOwnPropertyDescriptor === 'function') { |
| var descriptor = Object.getOwnPropertyDescriptor(obj, sym); |
| if (descriptor.value !== symVal || descriptor.enumerable !== true) { return false; } |
| } |
| |
| return true; |
| }; |
| |
| },{}],54:[function(require,module,exports){ |
| (function (global){ |
| /*! https://mths.be/he v1.2.0 by @mathias | MIT license */ |
| ;(function(root) { |
| |
| // Detect free variables `exports`. |
| var freeExports = typeof exports == 'object' && exports; |
| |
| // Detect free variable `module`. |
| var freeModule = typeof module == 'object' && module && |
| module.exports == freeExports && module; |
| |
| // Detect free variable `global`, from Node.js or Browserified code, |
| // and use it as `root`. |
| var freeGlobal = typeof global == 'object' && global; |
| if (freeGlobal.global === freeGlobal || freeGlobal.window === freeGlobal) { |
| root = freeGlobal; |
| } |
| |
| /*--------------------------------------------------------------------------*/ |
| |
| // All astral symbols. |
| var regexAstralSymbols = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g; |
| // All ASCII symbols (not just printable ASCII) except those listed in the |
| // first column of the overrides table. |
| // https://html.spec.whatwg.org/multipage/syntax.html#table-charref-overrides |
| var regexAsciiWhitelist = /[\x01-\x7F]/g; |
| // All BMP symbols that are not ASCII newlines, printable ASCII symbols, or |
| // code points listed in the first column of the overrides table on |
| // https://html.spec.whatwg.org/multipage/syntax.html#table-charref-overrides. |
| var regexBmpWhitelist = /[\x01-\t\x0B\f\x0E-\x1F\x7F\x81\x8D\x8F\x90\x9D\xA0-\uFFFF]/g; |
| |
| var regexEncodeNonAscii = /<\u20D2|=\u20E5|>\u20D2|\u205F\u200A|\u219D\u0338|\u2202\u0338|\u2220\u20D2|\u2229\uFE00|\u222A\uFE00|\u223C\u20D2|\u223D\u0331|\u223E\u0333|\u2242\u0338|\u224B\u0338|\u224D\u20D2|\u224E\u0338|\u224F\u0338|\u2250\u0338|\u2261\u20E5|\u2264\u20D2|\u2265\u20D2|\u2266\u0338|\u2267\u0338|\u2268\uFE00|\u2269\uFE00|\u226A\u0338|\u226A\u20D2|\u226B\u0338|\u226B\u20D2|\u227F\u0338|\u2282\u20D2|\u2283\u20D2|\u228A\uFE00|\u228B\uFE00|\u228F\u0338|\u2290\u0338|\u2293\uFE00|\u2294\uFE00|\u22B4\u20D2|\u22B5\u20D2|\u22D8\u0338|\u22D9\u0338|\u22DA\uFE00|\u22DB\uFE00|\u22F5\u0338|\u22F9\u0338|\u2933\u0338|\u29CF\u0338|\u29D0\u0338|\u2A6D\u0338|\u2A70\u0338|\u2A7D\u0338|\u2A7E\u0338|\u2AA1\u0338|\u2AA2\u0338|\u2AAC\uFE00|\u2AAD\uFE00|\u2AAF\u0338|\u2AB0\u0338|\u2AC5\u0338|\u2AC6\u0338|\u2ACB\uFE00|\u2ACC\uFE00|\u2AFD\u20E5|[\xA0-\u0113\u0116-\u0122\u0124-\u012B\u012E-\u014D\u0150-\u017E\u0192\u01B5\u01F5\u0237\u02C6\u02C7\u02D8-\u02DD\u0311\u0391-\u03A1\u03A3-\u03A9\u03B1-\u03C9\u03D1\u03D2\u03D5\u03D6\u03DC\u03DD\u03F0\u03F1\u03F5\u03F6\u0401-\u040C\u040E-\u044F\u0451-\u045C\u045E\u045F\u2002-\u2005\u2007-\u2010\u2013-\u2016\u2018-\u201A\u201C-\u201E\u2020-\u2022\u2025\u2026\u2030-\u2035\u2039\u203A\u203E\u2041\u2043\u2044\u204F\u2057\u205F-\u2063\u20AC\u20DB\u20DC\u2102\u2105\u210A-\u2113\u2115-\u211E\u2122\u2124\u2127-\u2129\u212C\u212D\u212F-\u2131\u2133-\u2138\u2145-\u2148\u2153-\u215E\u2190-\u219B\u219D-\u21A7\u21A9-\u21AE\u21B0-\u21B3\u21B5-\u21B7\u21BA-\u21DB\u21DD\u21E4\u21E5\u21F5\u21FD-\u2205\u2207-\u2209\u220B\u220C\u220F-\u2214\u2216-\u2218\u221A\u221D-\u2238\u223A-\u2257\u2259\u225A\u225C\u225F-\u2262\u2264-\u228B\u228D-\u229B\u229D-\u22A5\u22A7-\u22B0\u22B2-\u22BB\u22BD-\u22DB\u22DE-\u22E3\u22E6-\u22F7\u22F9-\u22FE\u2305\u2306\u2308-\u2310\u2312\u2313\u2315\u2316\u231C-\u231F\u2322\u2323\u232D\u232E\u2336\u233D\u233F\u237C\u23B0\u23B1\u23B4-\u23B6\u23DC-\u23DF\u23E2\u23E7\u2423\u24C8\u2500\u2502\u250C\u2510\u2514\u2518\u251C\u2524\u252C\u2534\u253C\u2550-\u256C\u2580\u2584\u2588\u2591-\u2593\u25A1\u25AA\u25AB\u25AD\u25AE\u25B1\u25B3-\u25B5\u25B8\u25B9\u25BD-\u25BF\u25C2\u25C3\u25CA\u25CB\u25EC\u25EF\u25F8-\u25FC\u2605\u2606\u260E\u2640\u2642\u2660\u2663\u2665\u2666\u266A\u266D-\u266F\u2713\u2717\u2720\u2736\u2758\u2772\u2773\u27C8\u27C9\u27E6-\u27ED\u27F5-\u27FA\u27FC\u27FF\u2902-\u2905\u290C-\u2913\u2916\u2919-\u2920\u2923-\u292A\u2933\u2935-\u2939\u293C\u293D\u2945\u2948-\u294B\u294E-\u2976\u2978\u2979\u297B-\u297F\u2985\u2986\u298B-\u2996\u299A\u299C\u299D\u29A4-\u29B7\u29B9\u29BB\u29BC\u29BE-\u29C5\u29C9\u29CD-\u29D0\u29DC-\u29DE\u29E3-\u29E5\u29EB\u29F4\u29F6\u2A00-\u2A02\u2A04\u2A06\u2A0C\u2A0D\u2A10-\u2A17\u2A22-\u2A27\u2A29\u2A2A\u2A2D-\u2A31\u2A33-\u2A3C\u2A3F\u2A40\u2A42-\u2A4D\u2A50\u2A53-\u2A58\u2A5A-\u2A5D\u2A5F\u2A66\u2A6A\u2A6D-\u2A75\u2A77-\u2A9A\u2A9D-\u2AA2\u2AA4-\u2AB0\u2AB3-\u2AC8\u2ACB\u2ACC\u2ACF-\u2ADB\u2AE4\u2AE6-\u2AE9\u2AEB-\u2AF3\u2AFD\uFB00-\uFB04]|\uD835[\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDCCF\uDD04\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDD6B]/g; |
| var encodeMap = {'\xAD':'shy','\u200C':'zwnj','\u200D':'zwj','\u200E':'lrm','\u2063':'ic','\u2062':'it','\u2061':'af','\u200F':'rlm','\u200B':'ZeroWidthSpace','\u2060':'NoBreak','\u0311':'DownBreve','\u20DB':'tdot','\u20DC':'DotDot','\t':'Tab','\n':'NewLine','\u2008':'puncsp','\u205F':'MediumSpace','\u2009':'thinsp','\u200A':'hairsp','\u2004':'emsp13','\u2002':'ensp','\u2005':'emsp14','\u2003':'emsp','\u2007':'numsp','\xA0':'nbsp','\u205F\u200A':'ThickSpace','\u203E':'oline','_':'lowbar','\u2010':'dash','\u2013':'ndash','\u2014':'mdash','\u2015':'horbar',',':'comma',';':'semi','\u204F':'bsemi',':':'colon','\u2A74':'Colone','!':'excl','\xA1':'iexcl','?':'quest','\xBF':'iquest','.':'period','\u2025':'nldr','\u2026':'mldr','\xB7':'middot','\'':'apos','\u2018':'lsquo','\u2019':'rsquo','\u201A':'sbquo','\u2039':'lsaquo','\u203A':'rsaquo','"':'quot','\u201C':'ldquo','\u201D':'rdquo','\u201E':'bdquo','\xAB':'laquo','\xBB':'raquo','(':'lpar',')':'rpar','[':'lsqb',']':'rsqb','{':'lcub','}':'rcub','\u2308':'lceil','\u2309':'rceil','\u230A':'lfloor','\u230B':'rfloor','\u2985':'lopar','\u2986':'ropar','\u298B':'lbrke','\u298C':'rbrke','\u298D':'lbrkslu','\u298E':'rbrksld','\u298F':'lbrksld','\u2990':'rbrkslu','\u2991':'langd','\u2992':'rangd','\u2993':'lparlt','\u2994':'rpargt','\u2995':'gtlPar','\u2996':'ltrPar','\u27E6':'lobrk','\u27E7':'robrk','\u27E8':'lang','\u27E9':'rang','\u27EA':'Lang','\u27EB':'Rang','\u27EC':'loang','\u27ED':'roang','\u2772':'lbbrk','\u2773':'rbbrk','\u2016':'Vert','\xA7':'sect','\xB6':'para','@':'commat','*':'ast','/':'sol','undefined':null,'&':'amp','#':'num','%':'percnt','\u2030':'permil','\u2031':'pertenk','\u2020':'dagger','\u2021':'Dagger','\u2022':'bull','\u2043':'hybull','\u2032':'prime','\u2033':'Prime','\u2034':'tprime','\u2057':'qprime','\u2035':'bprime','\u2041':'caret','`':'grave','\xB4':'acute','\u02DC':'tilde','^':'Hat','\xAF':'macr','\u02D8':'breve','\u02D9':'dot','\xA8':'die','\u02DA':'ring','\u02DD':'dblac','\xB8':'cedil','\u02DB':'ogon','\u02C6':'circ','\u02C7':'caron','\xB0':'deg','\xA9':'copy','\xAE':'reg','\u2117':'copysr','\u2118':'wp','\u211E':'rx','\u2127':'mho','\u2129':'iiota','\u2190':'larr','\u219A':'nlarr','\u2192':'rarr','\u219B':'nrarr','\u2191':'uarr','\u2193':'darr','\u2194':'harr','\u21AE':'nharr','\u2195':'varr','\u2196':'nwarr','\u2197':'nearr','\u2198':'searr','\u2199':'swarr','\u219D':'rarrw','\u219D\u0338':'nrarrw','\u219E':'Larr','\u219F':'Uarr','\u21A0':'Rarr','\u21A1':'Darr','\u21A2':'larrtl','\u21A3':'rarrtl','\u21A4':'mapstoleft','\u21A5':'mapstoup','\u21A6':'map','\u21A7':'mapstodown','\u21A9':'larrhk','\u21AA':'rarrhk','\u21AB':'larrlp','\u21AC':'rarrlp','\u21AD':'harrw','\u21B0':'lsh','\u21B1':'rsh','\u21B2':'ldsh','\u21B3':'rdsh','\u21B5':'crarr','\u21B6':'cularr','\u21B7':'curarr','\u21BA':'olarr','\u21BB':'orarr','\u21BC':'lharu','\u21BD':'lhard','\u21BE':'uharr','\u21BF':'uharl','\u21C0':'rharu','\u21C1':'rhard','\u21C2':'dharr','\u21C3':'dharl','\u21C4':'rlarr','\u21C5':'udarr','\u21C6':'lrarr','\u21C7':'llarr','\u21C8':'uuarr','\u21C9':'rrarr','\u21CA':'ddarr','\u21CB':'lrhar','\u21CC':'rlhar','\u21D0':'lArr','\u21CD':'nlArr','\u21D1':'uArr','\u21D2':'rArr','\u21CF':'nrArr','\u21D3':'dArr','\u21D4':'iff','\u21CE':'nhArr','\u21D5':'vArr','\u21D6':'nwArr','\u21D7':'neArr','\u21D8':'seArr','\u21D9':'swArr','\u21DA':'lAarr','\u21DB':'rAarr','\u21DD':'zigrarr','\u21E4':'larrb','\u21E5':'rarrb','\u21F5':'duarr','\u21FD':'loarr','\u21FE':'roarr','\u21FF':'hoarr','\u2200':'forall','\u2201':'comp','\u2202':'part','\u2202\u0338':'npart','\u2203':'exist','\u2204':'nexist','\u2205':'empty','\u2207':'Del','\u2208':'in','\u2209':'notin','\u220B':'ni','\u220C':'notni','\u03F6':'bepsi','\u220F':'prod','\u2210':'coprod','\u2211':'sum','+':'plus','\xB1':'pm','\xF7':'div','\xD7':'times','<':'lt','\u226E':'nlt','<\u20D2':'nvlt','=':'equals','\u2260':'ne','=\u20E5':'bne','\u2A75':'Equal','>':'gt','\u226F':'ngt','>\u20D2':'nvgt','\xAC':'not','|':'vert','\xA6':'brvbar','\u2212':'minus','\u2213':'mp','\u2214':'plusdo','\u2044':'frasl','\u2216':'setmn','\u2217':'lowast','\u2218':'compfn','\u221A':'Sqrt','\u221D':'prop','\u221E':'infin','\u221F':'angrt','\u2220':'ang','\u2220\u20D2':'nang','\u2221':'angmsd','\u2222':'angsph','\u2223':'mid','\u2224':'nmid','\u2225':'par','\u2226':'npar','\u2227':'and','\u2228':'or','\u2229':'cap','\u2229\uFE00':'caps','\u222A':'cup','\u222A\uFE00':'cups','\u222B':'int','\u222C':'Int','\u222D':'tint','\u2A0C':'qint','\u222E':'oint','\u222F':'Conint','\u2230':'Cconint','\u2231':'cwint','\u2232':'cwconint','\u2233':'awconint','\u2234':'there4','\u2235':'becaus','\u2236':'ratio','\u2237':'Colon','\u2238':'minusd','\u223A':'mDDot','\u223B':'homtht','\u223C':'sim','\u2241':'nsim','\u223C\u20D2':'nvsim','\u223D':'bsim','\u223D\u0331':'race','\u223E':'ac','\u223E\u0333':'acE','\u223F':'acd','\u2240':'wr','\u2242':'esim','\u2242\u0338':'nesim','\u2243':'sime','\u2244':'nsime','\u2245':'cong','\u2247':'ncong','\u2246':'simne','\u2248':'ap','\u2249':'nap','\u224A':'ape','\u224B':'apid','\u224B\u0338':'napid','\u224C':'bcong','\u224D':'CupCap','\u226D':'NotCupCap','\u224D\u20D2':'nvap','\u224E':'bump','\u224E\u0338':'nbump','\u224F':'bumpe','\u224F\u0338':'nbumpe','\u2250':'doteq','\u2250\u0338':'nedot','\u2251':'eDot','\u2252':'efDot','\u2253':'erDot','\u2254':'colone','\u2255':'ecolon','\u2256':'ecir','\u2257':'cire','\u2259':'wedgeq','\u225A':'veeeq','\u225C':'trie','\u225F':'equest','\u2261':'equiv','\u2262':'nequiv','\u2261\u20E5':'bnequiv','\u2264':'le','\u2270':'nle','\u2264\u20D2':'nvle','\u2265':'ge','\u2271':'nge','\u2265\u20D2':'nvge','\u2266':'lE','\u2266\u0338':'nlE','\u2267':'gE','\u2267\u0338':'ngE','\u2268\uFE00':'lvnE','\u2268':'lnE','\u2269':'gnE','\u2269\uFE00':'gvnE','\u226A':'ll','\u226A\u0338':'nLtv','\u226A\u20D2':'nLt','\u226B':'gg','\u226B\u0338':'nGtv','\u226B\u20D2':'nGt','\u226C':'twixt','\u2272':'lsim','\u2274':'nlsim','\u2273':'gsim','\u2275':'ngsim','\u2276':'lg','\u2278':'ntlg','\u2277':'gl','\u2279':'ntgl','\u227A':'pr','\u2280':'npr','\u227B':'sc','\u2281':'nsc','\u227C':'prcue','\u22E0':'nprcue','\u227D':'sccue','\u22E1':'nsccue','\u227E':'prsim','\u227F':'scsim','\u227F\u0338':'NotSucceedsTilde','\u2282':'sub','\u2284':'nsub','\u2282\u20D2':'vnsub','\u2283':'sup','\u2285':'nsup','\u2283\u20D2':'vnsup','\u2286':'sube','\u2288':'nsube','\u2287':'supe','\u2289':'nsupe','\u228A\uFE00':'vsubne','\u228A':'subne','\u228B\uFE00':'vsupne','\u228B':'supne','\u228D':'cupdot','\u228E':'uplus','\u228F':'sqsub','\u228F\u0338':'NotSquareSubset','\u2290':'sqsup','\u2290\u0338':'NotSquareSuperset','\u2291':'sqsube','\u22E2':'nsqsube','\u2292':'sqsupe','\u22E3':'nsqsupe','\u2293':'sqcap','\u2293\uFE00':'sqcaps','\u2294':'sqcup','\u2294\uFE00':'sqcups','\u2295':'oplus','\u2296':'ominus','\u2297':'otimes','\u2298':'osol','\u2299':'odot','\u229A':'ocir','\u229B':'oast','\u229D':'odash','\u229E':'plusb','\u229F':'minusb','\u22A0':'timesb','\u22A1':'sdotb','\u22A2':'vdash','\u22AC':'nvdash','\u22A3':'dashv','\u22A4':'top','\u22A5':'bot','\u22A7':'models','\u22A8':'vDash','\u22AD':'nvDash','\u22A9':'Vdash','\u22AE':'nVdash','\u22AA':'Vvdash','\u22AB':'VDash','\u22AF':'nVDash','\u22B0':'prurel','\u22B2':'vltri','\u22EA':'nltri','\u22B3':'vrtri','\u22EB':'nrtri','\u22B4':'ltrie','\u22EC':'nltrie','\u22B4\u20D2':'nvltrie','\u22B5':'rtrie','\u22ED':'nrtrie','\u22B5\u20D2':'nvrtrie','\u22B6':'origof','\u22B7':'imof','\u22B8':'mumap','\u22B9':'hercon','\u22BA':'intcal','\u22BB':'veebar','\u22BD':'barvee','\u22BE':'angrtvb','\u22BF':'lrtri','\u22C0':'Wedge','\u22C1':'Vee','\u22C2':'xcap','\u22C3':'xcup','\u22C4':'diam','\u22C5':'sdot','\u22C6':'Star','\u22C7':'divonx','\u22C8':'bowtie','\u22C9':'ltimes','\u22CA':'rtimes','\u22CB':'lthree','\u22CC':'rthree','\u22CD':'bsime','\u22CE':'cuvee','\u22CF':'cuwed','\u22D0':'Sub','\u22D1':'Sup','\u22D2':'Cap','\u22D3':'Cup','\u22D4':'fork','\u22D5':'epar','\u22D6':'ltdot','\u22D7':'gtdot','\u22D8':'Ll','\u22D8\u0338':'nLl','\u22D9':'Gg','\u22D9\u0338':'nGg','\u22DA\uFE00':'lesg','\u22DA':'leg','\u22DB':'gel','\u22DB\uFE00':'gesl','\u22DE':'cuepr','\u22DF':'cuesc','\u22E6':'lnsim','\u22E7':'gnsim','\u22E8':'prnsim','\u22E9':'scnsim','\u22EE':'vellip','\u22EF':'ctdot','\u22F0':'utdot','\u22F1':'dtdot','\u22F2':'disin','\u22F3':'isinsv','\u22F4':'isins','\u22F5':'isindot','\u22F5\u0338':'notindot','\u22F6':'notinvc','\u22F7':'notinvb','\u22F9':'isinE','\u22F9\u0338':'notinE','\u22FA':'nisd','\u22FB':'xnis','\u22FC':'nis','\u22FD':'notnivc','\u22FE':'notnivb','\u2305':'barwed','\u2306':'Barwed','\u230C':'drcrop','\u230D':'dlcrop','\u230E':'urcrop','\u230F':'ulcrop','\u2310':'bnot','\u2312':'profline','\u2313':'profsurf','\u2315':'telrec','\u2316':'target','\u231C':'ulcorn','\u231D':'urcorn','\u231E':'dlcorn','\u231F':'drcorn','\u2322':'frown','\u2323':'smile','\u232D':'cylcty','\u232E':'profalar','\u2336':'topbot','\u233D':'ovbar','\u233F':'solbar','\u237C':'angzarr','\u23B0':'lmoust','\u23B1':'rmoust','\u23B4':'tbrk','\u23B5':'bbrk','\u23B6':'bbrktbrk','\u23DC':'OverParenthesis','\u23DD':'UnderParenthesis','\u23DE':'OverBrace','\u23DF':'UnderBrace','\u23E2':'trpezium','\u23E7':'elinters','\u2423':'blank','\u2500':'boxh','\u2502':'boxv','\u250C':'boxdr','\u2510':'boxdl','\u2514':'boxur','\u2518':'boxul','\u251C':'boxvr','\u2524':'boxvl','\u252C':'boxhd','\u2534':'boxhu','\u253C':'boxvh','\u2550':'boxH','\u2551':'boxV','\u2552':'boxdR','\u2553':'boxDr','\u2554':'boxDR','\u2555':'boxdL','\u2556':'boxDl','\u2557':'boxDL','\u2558':'boxuR','\u2559':'boxUr','\u255A':'boxUR','\u255B':'boxuL','\u255C':'boxUl','\u255D':'boxUL','\u255E':'boxvR','\u255F':'boxVr','\u2560':'boxVR','\u2561':'boxvL','\u2562':'boxVl','\u2563':'boxVL','\u2564':'boxHd','\u2565':'boxhD','\u2566':'boxHD','\u2567':'boxHu','\u2568':'boxhU','\u2569':'boxHU','\u256A':'boxvH','\u256B':'boxVh','\u256C':'boxVH','\u2580':'uhblk','\u2584':'lhblk','\u2588':'block','\u2591':'blk14','\u2592':'blk12','\u2593':'blk34','\u25A1':'squ','\u25AA':'squf','\u25AB':'EmptyVerySmallSquare','\u25AD':'rect','\u25AE':'marker','\u25B1':'fltns','\u25B3':'xutri','\u25B4':'utrif','\u25B5':'utri','\u25B8':'rtrif','\u25B9':'rtri','\u25BD':'xdtri','\u25BE':'dtrif','\u25BF':'dtri','\u25C2':'ltrif','\u25C3':'ltri','\u25CA':'loz','\u25CB':'cir','\u25EC':'tridot','\u25EF':'xcirc','\u25F8':'ultri','\u25F9':'urtri','\u25FA':'lltri','\u25FB':'EmptySmallSquare','\u25FC':'FilledSmallSquare','\u2605':'starf','\u2606':'star','\u260E':'phone','\u2640':'female','\u2642':'male','\u2660':'spades','\u2663':'clubs','\u2665':'hearts','\u2666':'diams','\u266A':'sung','\u2713':'check','\u2717':'cross','\u2720':'malt','\u2736':'sext','\u2758':'VerticalSeparator','\u27C8':'bsolhsub','\u27C9':'suphsol','\u27F5':'xlarr','\u27F6':'xrarr','\u27F7':'xharr','\u27F8':'xlArr','\u27F9':'xrArr','\u27FA':'xhArr','\u27FC':'xmap','\u27FF':'dzigrarr','\u2902':'nvlArr','\u2903':'nvrArr','\u2904':'nvHarr','\u2905':'Map','\u290C':'lbarr','\u290D':'rbarr','\u290E':'lBarr','\u290F':'rBarr','\u2910':'RBarr','\u2911':'DDotrahd','\u2912':'UpArrowBar','\u2913':'DownArrowBar','\u2916':'Rarrtl','\u2919':'latail','\u291A':'ratail','\u291B':'lAtail','\u291C':'rAtail','\u291D':'larrfs','\u291E':'rarrfs','\u291F':'larrbfs','\u2920':'rarrbfs','\u2923':'nwarhk','\u2924':'nearhk','\u2925':'searhk','\u2926':'swarhk','\u2927':'nwnear','\u2928':'toea','\u2929':'tosa','\u292A':'swnwar','\u2933':'rarrc','\u2933\u0338':'nrarrc','\u2935':'cudarrr','\u2936':'ldca','\u2937':'rdca','\u2938':'cudarrl','\u2939':'larrpl','\u293C':'curarrm','\u293D':'cularrp','\u2945':'rarrpl','\u2948':'harrcir','\u2949':'Uarrocir','\u294A':'lurdshar','\u294B':'ldrushar','\u294E':'LeftRightVector','\u294F':'RightUpDownVector','\u2950':'DownLeftRightVector','\u2951':'LeftUpDownVector','\u2952':'LeftVectorBar','\u2953':'RightVectorBar','\u2954':'RightUpVectorBar','\u2955':'RightDownVectorBar','\u2956':'DownLeftVectorBar','\u2957':'DownRightVectorBar','\u2958':'LeftUpVectorBar','\u2959':'LeftDownVectorBar','\u295A':'LeftTeeVector','\u295B':'RightTeeVector','\u295C':'RightUpTeeVector','\u295D':'RightDownTeeVector','\u295E':'DownLeftTeeVector','\u295F':'DownRightTeeVector','\u2960':'LeftUpTeeVector','\u2961':'LeftDownTeeVector','\u2962':'lHar','\u2963':'uHar','\u2964':'rHar','\u2965':'dHar','\u2966':'luruhar','\u2967':'ldrdhar','\u2968':'ruluhar','\u2969':'rdldhar','\u296A':'lharul','\u296B':'llhard','\u296C':'rharul','\u296D':'lrhard','\u296E':'udhar','\u296F':'duhar','\u2970':'RoundImplies','\u2971':'erarr','\u2972':'simrarr','\u2973':'larrsim','\u2974':'rarrsim','\u2975':'rarrap','\u2976':'ltlarr','\u2978':'gtrarr','\u2979':'subrarr','\u297B':'suplarr','\u297C':'lfisht','\u297D':'rfisht','\u297E':'ufisht','\u297F':'dfisht','\u299A':'vzigzag','\u299C':'vangrt','\u299D':'angrtvbd','\u29A4':'ange','\u29A5':'range','\u29A6':'dwangle','\u29A7':'uwangle','\u29A8':'angmsdaa','\u29A9':'angmsdab','\u29AA':'angmsdac','\u29AB':'angmsdad','\u29AC':'angmsdae','\u29AD':'angmsdaf','\u29AE':'angmsdag','\u29AF':'angmsdah','\u29B0':'bemptyv','\u29B1':'demptyv','\u29B2':'cemptyv','\u29B3':'raemptyv','\u29B4':'laemptyv','\u29B5':'ohbar','\u29B6':'omid','\u29B7':'opar','\u29B9':'operp','\u29BB':'olcross','\u29BC':'odsold','\u29BE':'olcir','\u29BF':'ofcir','\u29C0':'olt','\u29C1':'ogt','\u29C2':'cirscir','\u29C3':'cirE','\u29C4':'solb','\u29C5':'bsolb','\u29C9':'boxbox','\u29CD':'trisb','\u29CE':'rtriltri','\u29CF':'LeftTriangleBar','\u29CF\u0338':'NotLeftTriangleBar','\u29D0':'RightTriangleBar','\u29D0\u0338':'NotRightTriangleBar','\u29DC':'iinfin','\u29DD':'infintie','\u29DE':'nvinfin','\u29E3':'eparsl','\u29E4':'smeparsl','\u29E5':'eqvparsl','\u29EB':'lozf','\u29F4':'RuleDelayed','\u29F6':'dsol','\u2A00':'xodot','\u2A01':'xoplus','\u2A02':'xotime','\u2A04':'xuplus','\u2A06':'xsqcup','\u2A0D':'fpartint','\u2A10':'cirfnint','\u2A11':'awint','\u2A12':'rppolint','\u2A13':'scpolint','\u2A14':'npolint','\u2A15':'pointint','\u2A16':'quatint','\u2A17':'intlarhk','\u2A22':'pluscir','\u2A23':'plusacir','\u2A24':'simplus','\u2A25':'plusdu','\u2A26':'plussim','\u2A27':'plustwo','\u2A29':'mcomma','\u2A2A':'minusdu','\u2A2D':'loplus','\u2A2E':'roplus','\u2A2F':'Cross','\u2A30':'timesd','\u2A31':'timesbar','\u2A33':'smashp','\u2A34':'lotimes','\u2A35':'rotimes','\u2A36':'otimesas','\u2A37':'Otimes','\u2A38':'odiv','\u2A39':'triplus','\u2A3A':'triminus','\u2A3B':'tritime','\u2A3C':'iprod','\u2A3F':'amalg','\u2A40':'capdot','\u2A42':'ncup','\u2A43':'ncap','\u2A44':'capand','\u2A45':'cupor','\u2A46':'cupcap','\u2A47':'capcup','\u2A48':'cupbrcap','\u2A49':'capbrcup','\u2A4A':'cupcup','\u2A4B':'capcap','\u2A4C':'ccups','\u2A4D':'ccaps','\u2A50':'ccupssm','\u2A53':'And','\u2A54':'Or','\u2A55':'andand','\u2A56':'oror','\u2A57':'orslope','\u2A58':'andslope','\u2A5A':'andv','\u2A5B':'orv','\u2A5C':'andd','\u2A5D':'ord','\u2A5F':'wedbar','\u2A66':'sdote','\u2A6A':'simdot','\u2A6D':'congdot','\u2A6D\u0338':'ncongdot','\u2A6E':'easter','\u2A6F':'apacir','\u2A70':'apE','\u2A70\u0338':'napE','\u2A71':'eplus','\u2A72':'pluse','\u2A73':'Esim','\u2A77':'eDDot','\u2A78':'equivDD','\u2A79':'ltcir','\u2A7A':'gtcir','\u2A7B':'ltquest','\u2A7C':'gtquest','\u2A7D':'les','\u2A7D\u0338':'nles','\u2A7E':'ges','\u2A7E\u0338':'nges','\u2A7F':'lesdot','\u2A80':'gesdot','\u2A81':'lesdoto','\u2A82':'gesdoto','\u2A83':'lesdotor','\u2A84':'gesdotol','\u2A85':'lap','\u2A86':'gap','\u2A87':'lne','\u2A88':'gne','\u2A89':'lnap','\u2A8A':'gnap','\u2A8B':'lEg','\u2A8C':'gEl','\u2A8D':'lsime','\u2A8E':'gsime','\u2A8F':'lsimg','\u2A90':'gsiml','\u2A91':'lgE','\u2A92':'glE','\u2A93':'lesges','\u2A94':'gesles','\u2A95':'els','\u2A96':'egs','\u2A97':'elsdot','\u2A98':'egsdot','\u2A99':'el','\u2A9A':'eg','\u2A9D':'siml','\u2A9E':'simg','\u2A9F':'simlE','\u2AA0':'simgE','\u2AA1':'LessLess','\u2AA1\u0338':'NotNestedLessLess','\u2AA2':'GreaterGreater','\u2AA2\u0338':'NotNestedGreaterGreater','\u2AA4':'glj','\u2AA5':'gla','\u2AA6':'ltcc','\u2AA7':'gtcc','\u2AA8':'lescc','\u2AA9':'gescc','\u2AAA':'smt','\u2AAB':'lat','\u2AAC':'smte','\u2AAC\uFE00':'smtes','\u2AAD':'late','\u2AAD\uFE00':'lates','\u2AAE':'bumpE','\u2AAF':'pre','\u2AAF\u0338':'npre','\u2AB0':'sce','\u2AB0\u0338':'nsce','\u2AB3':'prE','\u2AB4':'scE','\u2AB5':'prnE','\u2AB6':'scnE','\u2AB7':'prap','\u2AB8':'scap','\u2AB9':'prnap','\u2ABA':'scnap','\u2ABB':'Pr','\u2ABC':'Sc','\u2ABD':'subdot','\u2ABE':'supdot','\u2ABF':'subplus','\u2AC0':'supplus','\u2AC1':'submult','\u2AC2':'supmult','\u2AC3':'subedot','\u2AC4':'supedot','\u2AC5':'subE','\u2AC5\u0338':'nsubE','\u2AC6':'supE','\u2AC6\u0338':'nsupE','\u2AC7':'subsim','\u2AC8':'supsim','\u2ACB\uFE00':'vsubnE','\u2ACB':'subnE','\u2ACC\uFE00':'vsupnE','\u2ACC':'supnE','\u2ACF':'csub','\u2AD0':'csup','\u2AD1':'csube','\u2AD2':'csupe','\u2AD3':'subsup','\u2AD4':'supsub','\u2AD5':'subsub','\u2AD6':'supsup','\u2AD7':'suphsub','\u2AD8':'supdsub','\u2AD9':'forkv','\u2ADA':'topfork','\u2ADB':'mlcp','\u2AE4':'Dashv','\u2AE6':'Vdashl','\u2AE7':'Barv','\u2AE8':'vBar','\u2AE9':'vBarv','\u2AEB':'Vbar','\u2AEC':'Not','\u2AED':'bNot','\u2AEE':'rnmid','\u2AEF':'cirmid','\u2AF0':'midcir','\u2AF1':'topcir','\u2AF2':'nhpar','\u2AF3':'parsim','\u2AFD':'parsl','\u2AFD\u20E5':'nparsl','\u266D':'flat','\u266E':'natur','\u266F':'sharp','\xA4':'curren','\xA2':'cent','$':'dollar','\xA3':'pound','\xA5':'yen','\u20AC':'euro','\xB9':'sup1','\xBD':'half','\u2153':'frac13','\xBC':'frac14','\u2155':'frac15','\u2159':'frac16','\u215B':'frac18','\xB2':'sup2','\u2154':'frac23','\u2156':'frac25','\xB3':'sup3','\xBE':'frac34','\u2157':'frac35','\u215C':'frac38','\u2158':'frac45','\u215A':'frac56','\u215D':'frac58','\u215E':'frac78','\uD835\uDCB6':'ascr','\uD835\uDD52':'aopf','\uD835\uDD1E':'afr','\uD835\uDD38':'Aopf','\uD835\uDD04':'Afr','\uD835\uDC9C':'Ascr','\xAA':'ordf','\xE1':'aacute','\xC1':'Aacute','\xE0':'agrave','\xC0':'Agrave','\u0103':'abreve','\u0102':'Abreve','\xE2':'acirc','\xC2':'Acirc','\xE5':'aring','\xC5':'angst','\xE4':'auml','\xC4':'Auml','\xE3':'atilde','\xC3':'Atilde','\u0105':'aogon','\u0104':'Aogon','\u0101':'amacr','\u0100':'Amacr','\xE6':'aelig','\xC6':'AElig','\uD835\uDCB7':'bscr','\uD835\uDD53':'bopf','\uD835\uDD1F':'bfr','\uD835\uDD39':'Bopf','\u212C':'Bscr','\uD835\uDD05':'Bfr','\uD835\uDD20':'cfr','\uD835\uDCB8':'cscr','\uD835\uDD54':'copf','\u212D':'Cfr','\uD835\uDC9E':'Cscr','\u2102':'Copf','\u0107':'cacute','\u0106':'Cacute','\u0109':'ccirc','\u0108':'Ccirc','\u010D':'ccaron','\u010C':'Ccaron','\u010B':'cdot','\u010A':'Cdot','\xE7':'ccedil','\xC7':'Ccedil','\u2105':'incare','\uD835\uDD21':'dfr','\u2146':'dd','\uD835\uDD55':'dopf','\uD835\uDCB9':'dscr','\uD835\uDC9F':'Dscr','\uD835\uDD07':'Dfr','\u2145':'DD','\uD835\uDD3B':'Dopf','\u010F':'dcaron','\u010E':'Dcaron','\u0111':'dstrok','\u0110':'Dstrok','\xF0':'eth','\xD0':'ETH','\u2147':'ee','\u212F':'escr','\uD835\uDD22':'efr','\uD835\uDD56':'eopf','\u2130':'Escr','\uD835\uDD08':'Efr','\uD835\uDD3C':'Eopf','\xE9':'eacute','\xC9':'Eacute','\xE8':'egrave','\xC8':'Egrave','\xEA':'ecirc','\xCA':'Ecirc','\u011B':'ecaron','\u011A':'Ecaron','\xEB':'euml','\xCB':'Euml','\u0117':'edot','\u0116':'Edot','\u0119':'eogon','\u0118':'Eogon','\u0113':'emacr','\u0112':'Emacr','\uD835\uDD23':'ffr','\uD835\uDD57':'fopf','\uD835\uDCBB':'fscr','\uD835\uDD09':'Ffr','\uD835\uDD3D':'Fopf','\u2131':'Fscr','\uFB00':'fflig','\uFB03':'ffilig','\uFB04':'ffllig','\uFB01':'filig','fj':'fjlig','\uFB02':'fllig','\u0192':'fnof','\u210A':'gscr','\uD835\uDD58':'gopf','\uD835\uDD24':'gfr','\uD835\uDCA2':'Gscr','\uD835\uDD3E':'Gopf','\uD835\uDD0A':'Gfr','\u01F5':'gacute','\u011F':'gbreve','\u011E':'Gbreve','\u011D':'gcirc','\u011C':'Gcirc','\u0121':'gdot','\u0120':'Gdot','\u0122':'Gcedil','\uD835\uDD25':'hfr','\u210E':'planckh','\uD835\uDCBD':'hscr','\uD835\uDD59':'hopf','\u210B':'Hscr','\u210C':'Hfr','\u210D':'Hopf','\u0125':'hcirc','\u0124':'Hcirc','\u210F':'hbar','\u0127':'hstrok','\u0126':'Hstrok','\uD835\uDD5A':'iopf','\uD835\uDD26':'ifr','\uD835\uDCBE':'iscr','\u2148':'ii','\uD835\uDD40':'Iopf','\u2110':'Iscr','\u2111':'Im','\xED':'iacute','\xCD':'Iacute','\xEC':'igrave','\xCC':'Igrave','\xEE':'icirc','\xCE':'Icirc','\xEF':'iuml','\xCF':'Iuml','\u0129':'itilde','\u0128':'Itilde','\u0130':'Idot','\u012F':'iogon','\u012E':'Iogon','\u012B':'imacr','\u012A':'Imacr','\u0133':'ijlig','\u0132':'IJlig','\u0131':'imath','\uD835\uDCBF':'jscr','\uD835\uDD5B':'jopf','\uD835\uDD27':'jfr','\uD835\uDCA5':'Jscr','\uD835\uDD0D':'Jfr','\uD835\uDD41':'Jopf','\u0135':'jcirc','\u0134':'Jcirc','\u0237':'jmath','\uD835\uDD5C':'kopf','\uD835\uDCC0':'kscr','\uD835\uDD28':'kfr','\uD835\uDCA6':'Kscr','\uD835\uDD42':'Kopf','\uD835\uDD0E':'Kfr','\u0137':'kcedil','\u0136':'Kcedil','\uD835\uDD29':'lfr','\uD835\uDCC1':'lscr','\u2113':'ell','\uD835\uDD5D':'lopf','\u2112':'Lscr','\uD835\uDD0F':'Lfr','\uD835\uDD43':'Lopf','\u013A':'lacute','\u0139':'Lacute','\u013E':'lcaron','\u013D':'Lcaron','\u013C':'lcedil','\u013B':'Lcedil','\u0142':'lstrok','\u0141':'Lstrok','\u0140':'lmidot','\u013F':'Lmidot','\uD835\uDD2A':'mfr','\uD835\uDD5E':'mopf','\uD835\uDCC2':'mscr','\uD835\uDD10':'Mfr','\uD835\uDD44':'Mopf','\u2133':'Mscr','\uD835\uDD2B':'nfr','\uD835\uDD5F':'nopf','\uD835\uDCC3':'nscr','\u2115':'Nopf','\uD835\uDCA9':'Nscr','\uD835\uDD11':'Nfr','\u0144':'nacute','\u0143':'Nacute','\u0148':'ncaron','\u0147':'Ncaron','\xF1':'ntilde','\xD1':'Ntilde','\u0146':'ncedil','\u0145':'Ncedil','\u2116':'numero','\u014B':'eng','\u014A':'ENG','\uD835\uDD60':'oopf','\uD835\uDD2C':'ofr','\u2134':'oscr','\uD835\uDCAA':'Oscr','\uD835\uDD12':'Ofr','\uD835\uDD46':'Oopf','\xBA':'ordm','\xF3':'oacute','\xD3':'Oacute','\xF2':'ograve','\xD2':'Ograve','\xF4':'ocirc','\xD4':'Ocirc','\xF6':'ouml','\xD6':'Ouml','\u0151':'odblac','\u0150':'Odblac','\xF5':'otilde','\xD5':'Otilde','\xF8':'oslash','\xD8':'Oslash','\u014D':'omacr','\u014C':'Omacr','\u0153':'oelig','\u0152':'OElig','\uD835\uDD2D':'pfr','\uD835\uDCC5':'pscr','\uD835\uDD61':'popf','\u2119':'Popf','\uD835\uDD13':'Pfr','\uD835\uDCAB':'Pscr','\uD835\uDD62':'qopf','\uD835\uDD2E':'qfr','\uD835\uDCC6':'qscr','\uD835\uDCAC':'Qscr','\uD835\uDD14':'Qfr','\u211A':'Qopf','\u0138':'kgreen','\uD835\uDD2F':'rfr','\uD835\uDD63':'ropf','\uD835\uDCC7':'rscr','\u211B':'Rscr','\u211C':'Re','\u211D':'Ropf','\u0155':'racute','\u0154':'Racute','\u0159':'rcaron','\u0158':'Rcaron','\u0157':'rcedil','\u0156':'Rcedil','\uD835\uDD64':'sopf','\uD835\uDCC8':'sscr','\uD835\uDD30':'sfr','\uD835\uDD4A':'Sopf','\uD835\uDD16':'Sfr','\uD835\uDCAE':'Sscr','\u24C8':'oS','\u015B':'sacute','\u015A':'Sacute','\u015D':'scirc','\u015C':'Scirc','\u0161':'scaron','\u0160':'Scaron','\u015F':'scedil','\u015E':'Scedil','\xDF':'szlig','\uD835\uDD31':'tfr','\uD835\uDCC9':'tscr','\uD835\uDD65':'topf','\uD835\uDCAF':'Tscr','\uD835\uDD17':'Tfr','\uD835\uDD4B':'Topf','\u0165':'tcaron','\u0164':'Tcaron','\u0163':'tcedil','\u0162':'Tcedil','\u2122':'trade','\u0167':'tstrok','\u0166':'Tstrok','\uD835\uDCCA':'uscr','\uD835\uDD66':'uopf','\uD835\uDD32':'ufr','\uD835\uDD4C':'Uopf','\uD835\uDD18':'Ufr','\uD835\uDCB0':'Uscr','\xFA':'uacute','\xDA':'Uacute','\xF9':'ugrave','\xD9':'Ugrave','\u016D':'ubreve','\u016C':'Ubreve','\xFB':'ucirc','\xDB':'Ucirc','\u016F':'uring','\u016E':'Uring','\xFC':'uuml','\xDC':'Uuml','\u0171':'udblac','\u0170':'Udblac','\u0169':'utilde','\u0168':'Utilde','\u0173':'uogon','\u0172':'Uogon','\u016B':'umacr','\u016A':'Umacr','\uD835\uDD33':'vfr','\uD835\uDD67':'vopf','\uD835\uDCCB':'vscr','\uD835\uDD19':'Vfr','\uD835\uDD4D':'Vopf','\uD835\uDCB1':'Vscr','\uD835\uDD68':'wopf','\uD835\uDCCC':'wscr','\uD835\uDD34':'wfr','\uD835\uDCB2':'Wscr','\uD835\uDD4E':'Wopf','\uD835\uDD1A':'Wfr','\u0175':'wcirc','\u0174':'Wcirc','\uD835\uDD35':'xfr','\uD835\uDCCD':'xscr','\uD835\uDD69':'xopf','\uD835\uDD4F':'Xopf','\uD835\uDD1B':'Xfr','\uD835\uDCB3':'Xscr','\uD835\uDD36':'yfr','\uD835\uDCCE':'yscr','\uD835\uDD6A':'yopf','\uD835\uDCB4':'Yscr','\uD835\uDD1C':'Yfr','\uD835\uDD50':'Yopf','\xFD':'yacute','\xDD':'Yacute','\u0177':'ycirc','\u0176':'Ycirc','\xFF':'yuml','\u0178':'Yuml','\uD835\uDCCF':'zscr','\uD835\uDD37':'zfr','\uD835\uDD6B':'zopf','\u2128':'Zfr','\u2124':'Zopf','\uD835\uDCB5':'Zscr','\u017A':'zacute','\u0179':'Zacute','\u017E':'zcaron','\u017D':'Zcaron','\u017C':'zdot','\u017B':'Zdot','\u01B5':'imped','\xFE':'thorn','\xDE':'THORN','\u0149':'napos','\u03B1':'alpha','\u0391':'Alpha','\u03B2':'beta','\u0392':'Beta','\u03B3':'gamma','\u0393':'Gamma','\u03B4':'delta','\u0394':'Delta','\u03B5':'epsi','\u03F5':'epsiv','\u0395':'Epsilon','\u03DD':'gammad','\u03DC':'Gammad','\u03B6':'zeta','\u0396':'Zeta','\u03B7':'eta','\u0397':'Eta','\u03B8':'theta','\u03D1':'thetav','\u0398':'Theta','\u03B9':'iota','\u0399':'Iota','\u03BA':'kappa','\u03F0':'kappav','\u039A':'Kappa','\u03BB':'lambda','\u039B':'Lambda','\u03BC':'mu','\xB5':'micro','\u039C':'Mu','\u03BD':'nu','\u039D':'Nu','\u03BE':'xi','\u039E':'Xi','\u03BF':'omicron','\u039F':'Omicron','\u03C0':'pi','\u03D6':'piv','\u03A0':'Pi','\u03C1':'rho','\u03F1':'rhov','\u03A1':'Rho','\u03C3':'sigma','\u03A3':'Sigma','\u03C2':'sigmaf','\u03C4':'tau','\u03A4':'Tau','\u03C5':'upsi','\u03A5':'Upsilon','\u03D2':'Upsi','\u03C6':'phi','\u03D5':'phiv','\u03A6':'Phi','\u03C7':'chi','\u03A7':'Chi','\u03C8':'psi','\u03A8':'Psi','\u03C9':'omega','\u03A9':'ohm','\u0430':'acy','\u0410':'Acy','\u0431':'bcy','\u0411':'Bcy','\u0432':'vcy','\u0412':'Vcy','\u0433':'gcy','\u0413':'Gcy','\u0453':'gjcy','\u0403':'GJcy','\u0434':'dcy','\u0414':'Dcy','\u0452':'djcy','\u0402':'DJcy','\u0435':'iecy','\u0415':'IEcy','\u0451':'iocy','\u0401':'IOcy','\u0454':'jukcy','\u0404':'Jukcy','\u0436':'zhcy','\u0416':'ZHcy','\u0437':'zcy','\u0417':'Zcy','\u0455':'dscy','\u0405':'DScy','\u0438':'icy','\u0418':'Icy','\u0456':'iukcy','\u0406':'Iukcy','\u0457':'yicy','\u0407':'YIcy','\u0439':'jcy','\u0419':'Jcy','\u0458':'jsercy','\u0408':'Jsercy','\u043A':'kcy','\u041A':'Kcy','\u045C':'kjcy','\u040C':'KJcy','\u043B':'lcy','\u041B':'Lcy','\u0459':'ljcy','\u0409':'LJcy','\u043C':'mcy','\u041C':'Mcy','\u043D':'ncy','\u041D':'Ncy','\u045A':'njcy','\u040A':'NJcy','\u043E':'ocy','\u041E':'Ocy','\u043F':'pcy','\u041F':'Pcy','\u0440':'rcy','\u0420':'Rcy','\u0441':'scy','\u0421':'Scy','\u0442':'tcy','\u0422':'Tcy','\u045B':'tshcy','\u040B':'TSHcy','\u0443':'ucy','\u0423':'Ucy','\u045E':'ubrcy','\u040E':'Ubrcy','\u0444':'fcy','\u0424':'Fcy','\u0445':'khcy','\u0425':'KHcy','\u0446':'tscy','\u0426':'TScy','\u0447':'chcy','\u0427':'CHcy','\u045F':'dzcy','\u040F':'DZcy','\u0448':'shcy','\u0428':'SHcy','\u0449':'shchcy','\u0429':'SHCHcy','\u044A':'hardcy','\u042A':'HARDcy','\u044B':'ycy','\u042B':'Ycy','\u044C':'softcy','\u042C':'SOFTcy','\u044D':'ecy','\u042D':'Ecy','\u044E':'yucy','\u042E':'YUcy','\u044F':'yacy','\u042F':'YAcy','\u2135':'aleph','\u2136':'beth','\u2137':'gimel','\u2138':'daleth'}; |
| |
| var regexEscape = /["&'<>`]/g; |
| var escapeMap = { |
| '"': '"', |
| '&': '&', |
| '\'': ''', |
| '<': '<', |
| // See https://mathiasbynens.be/notes/ambiguous-ampersands: in HTML, the |
| // following is not strictly necessary unless it’s part of a tag or an |
| // unquoted attribute value. We’re only escaping it to support those |
| // situations, and for XML support. |
| '>': '>', |
| // In Internet Explorer ≤ 8, the backtick character can be used |
| // to break out of (un)quoted attribute values or HTML comments. |
| // See http://html5sec.org/#102, http://html5sec.org/#108, and |
| // http://html5sec.org/#133. |
| '`': '`' |
| }; |
| |
| var regexInvalidEntity = /&#(?:[xX][^a-fA-F0-9]|[^0-9xX])/; |
| var regexInvalidRawCodePoint = /[\0-\x08\x0B\x0E-\x1F\x7F-\x9F\uFDD0-\uFDEF\uFFFE\uFFFF]|[\uD83F\uD87F\uD8BF\uD8FF\uD93F\uD97F\uD9BF\uD9FF\uDA3F\uDA7F\uDABF\uDAFF\uDB3F\uDB7F\uDBBF\uDBFF][\uDFFE\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]/; |
| var regexDecode = /&(CounterClockwiseContourIntegral|DoubleLongLeftRightArrow|ClockwiseContourIntegral|NotNestedGreaterGreater|NotSquareSupersetEqual|DiacriticalDoubleAcute|NotRightTriangleEqual|NotSucceedsSlantEqual|NotPrecedesSlantEqual|CloseCurlyDoubleQuote|NegativeVeryThinSpace|DoubleContourIntegral|FilledVerySmallSquare|CapitalDifferentialD|OpenCurlyDoubleQuote|EmptyVerySmallSquare|NestedGreaterGreater|DoubleLongRightArrow|NotLeftTriangleEqual|NotGreaterSlantEqual|ReverseUpEquilibrium|DoubleLeftRightArrow|NotSquareSubsetEqual|NotDoubleVerticalBar|RightArrowLeftArrow|NotGreaterFullEqual|NotRightTriangleBar|SquareSupersetEqual|DownLeftRightVector|DoubleLongLeftArrow|leftrightsquigarrow|LeftArrowRightArrow|NegativeMediumSpace|blacktriangleright|RightDownVectorBar|PrecedesSlantEqual|RightDoubleBracket|SucceedsSlantEqual|NotLeftTriangleBar|RightTriangleEqual|SquareIntersection|RightDownTeeVector|ReverseEquilibrium|NegativeThickSpace|longleftrightarrow|Longleftrightarrow|LongLeftRightArrow|DownRightTeeVector|DownRightVectorBar|GreaterSlantEqual|SquareSubsetEqual|LeftDownVectorBar|LeftDoubleBracket|VerticalSeparator|rightleftharpoons|NotGreaterGreater|NotSquareSuperset|blacktriangleleft|blacktriangledown|NegativeThinSpace|LeftDownTeeVector|NotLessSlantEqual|leftrightharpoons|DoubleUpDownArrow|DoubleVerticalBar|LeftTriangleEqual|FilledSmallSquare|twoheadrightarrow|NotNestedLessLess|DownLeftTeeVector|DownLeftVectorBar|RightAngleBracket|NotTildeFullEqual|NotReverseElement|RightUpDownVector|DiacriticalTilde|NotSucceedsTilde|circlearrowright|NotPrecedesEqual|rightharpoondown|DoubleRightArrow|NotSucceedsEqual|NonBreakingSpace|NotRightTriangle|LessEqualGreater|RightUpTeeVector|LeftAngleBracket|GreaterFullEqual|DownArrowUpArrow|RightUpVectorBar|twoheadleftarrow|GreaterEqualLess|downharpoonright|RightTriangleBar|ntrianglerighteq|NotSupersetEqual|LeftUpDownVector|DiacriticalAcute|rightrightarrows|vartriangleright|UpArrowDownArrow|DiacriticalGrave|UnderParenthesis|EmptySmallSquare|LeftUpVectorBar|leftrightarrows|DownRightVector|downharpoonleft|trianglerighteq|ShortRightArrow|OverParenthesis|DoubleLeftArrow|DoubleDownArrow|NotSquareSubset|bigtriangledown|ntrianglelefteq|UpperRightArrow|curvearrowright|vartriangleleft|NotLeftTriangle|nleftrightarrow|LowerRightArrow|NotHumpDownHump|NotGreaterTilde|rightthreetimes|LeftUpTeeVector|NotGreaterEqual|straightepsilon|LeftTriangleBar|rightsquigarrow|ContourIntegral|rightleftarrows|CloseCurlyQuote|RightDownVector|LeftRightVector|nLeftrightarrow|leftharpoondown|circlearrowleft|SquareSuperset|OpenCurlyQuote|hookrightarrow|HorizontalLine|DiacriticalDot|NotLessGreater|ntriangleright|DoubleRightTee|InvisibleComma|InvisibleTimes|LowerLeftArrow|DownLeftVector|NotSubsetEqual|curvearrowleft|trianglelefteq|NotVerticalBar|TildeFullEqual|downdownarrows|NotGreaterLess|RightTeeVector|ZeroWidthSpace|looparrowright|LongRightArrow|doublebarwedge|ShortLeftArrow|ShortDownArrow|RightVectorBar|GreaterGreater|ReverseElement|rightharpoonup|LessSlantEqual|leftthreetimes|upharpoonright|rightarrowtail|LeftDownVector|Longrightarrow|NestedLessLess|UpperLeftArrow|nshortparallel|leftleftarrows|leftrightarrow|Leftrightarrow|LeftRightArrow|longrightarrow|upharpoonleft|RightArrowBar|ApplyFunction|LeftTeeVector|leftarrowtail|NotEqualTilde|varsubsetneqq|varsupsetneqq|RightTeeArrow|SucceedsEqual|SucceedsTilde|LeftVectorBar|SupersetEqual|hookleftarrow|DifferentialD|VerticalTilde|VeryThinSpace|blacktriangle|bigtriangleup|LessFullEqual|divideontimes|leftharpoonup|UpEquilibrium|ntriangleleft|RightTriangle|measuredangle|shortparallel|longleftarrow|Longleftarrow|LongLeftArrow|DoubleLeftTee|Poincareplane|PrecedesEqual|triangleright|DoubleUpArrow|RightUpVector|fallingdotseq|looparrowleft|PrecedesTilde|NotTildeEqual|NotTildeTilde|smallsetminus|Proportional|triangleleft|triangledown|UnderBracket|NotHumpEqual|exponentiale|ExponentialE|NotLessTilde|HilbertSpace|RightCeiling|blacklozenge|varsupsetneq|HumpDownHump|GreaterEqual|VerticalLine|LeftTeeArrow|NotLessEqual|DownTeeArrow|LeftTriangle|varsubsetneq|Intersection|NotCongruent|DownArrowBar|LeftUpVector|LeftArrowBar|risingdotseq|GreaterTilde|RoundImplies|SquareSubset|ShortUpArrow|NotSuperset|quaternions|precnapprox|backepsilon|preccurlyeq|OverBracket|blacksquare|MediumSpace|VerticalBar|circledcirc|circleddash|CircleMinus|CircleTimes|LessGreater|curlyeqprec|curlyeqsucc|diamondsuit|UpDownArrow|Updownarrow|RuleDelayed|Rrightarrow|updownarrow|RightVector|nRightarrow|nrightarrow|eqslantless|LeftCeiling|Equilibrium|SmallCircle|expectation|NotSucceeds|thickapprox|GreaterLess|SquareUnion|NotPrecedes|NotLessLess|straightphi|succnapprox|succcurlyeq|SubsetEqual|sqsupseteq|Proportion|Laplacetrf|ImaginaryI|supsetneqq|NotGreater|gtreqqless|NotElement|ThickSpace|TildeEqual|TildeTilde|Fouriertrf|rmoustache|EqualTilde|eqslantgtr|UnderBrace|LeftVector|UpArrowBar|nLeftarrow|nsubseteqq|subsetneqq|nsupseteqq|nleftarrow|succapprox|lessapprox|UpTeeArrow|upuparrows|curlywedge|lesseqqgtr|varepsilon|varnothing|RightFloor|complement|CirclePlus|sqsubseteq|Lleftarrow|circledast|RightArrow|Rightarrow|rightarrow|lmoustache|Bernoullis|precapprox|mapstoleft|mapstodown|longmapsto|dotsquare|downarrow|DoubleDot|nsubseteq|supsetneq|leftarrow|nsupseteq|subsetneq|ThinSpace|ngeqslant|subseteqq|HumpEqual|NotSubset|triangleq|NotCupCap|lesseqgtr|heartsuit|TripleDot|Leftarrow|Coproduct|Congruent|varpropto|complexes|gvertneqq|LeftArrow|LessTilde|supseteqq|MinusPlus|CircleDot|nleqslant|NotExists|gtreqless|nparallel|UnionPlus|LeftFloor|checkmark|CenterDot|centerdot|Mellintrf|gtrapprox|bigotimes|OverBrace|spadesuit|therefore|pitchfork|rationals|PlusMinus|Backslash|Therefore|DownBreve|backsimeq|backprime|DownArrow|nshortmid|Downarrow|lvertneqq|eqvparsl|imagline|imagpart|infintie|integers|Integral|intercal|LessLess|Uarrocir|intlarhk|sqsupset|angmsdaf|sqsubset|llcorner|vartheta|cupbrcap|lnapprox|Superset|SuchThat|succnsim|succneqq|angmsdag|biguplus|curlyvee|trpezium|Succeeds|NotTilde|bigwedge|angmsdah|angrtvbd|triminus|cwconint|fpartint|lrcorner|smeparsl|subseteq|urcorner|lurdshar|laemptyv|DDotrahd|approxeq|ldrushar|awconint|mapstoup|backcong|shortmid|triangle|geqslant|gesdotol|timesbar|circledR|circledS|setminus|multimap|naturals|scpolint|ncongdot|RightTee|boxminus|gnapprox|boxtimes|andslope|thicksim|angmsdaa|varsigma|cirfnint|rtriltri|angmsdab|rppolint|angmsdac|barwedge|drbkarow|clubsuit|thetasym|bsolhsub|capbrcup|dzigrarr|doteqdot|DotEqual|dotminus|UnderBar|NotEqual|realpart|otimesas|ulcorner|hksearow|hkswarow|parallel|PartialD|elinters|emptyset|plusacir|bbrktbrk|angmsdad|pointint|bigoplus|angmsdae|Precedes|bigsqcup|varkappa|notindot|supseteq|precneqq|precnsim|profalar|profline|profsurf|leqslant|lesdotor|raemptyv|subplus|notnivb|notnivc|subrarr|zigrarr|vzigzag|submult|subedot|Element|between|cirscir|larrbfs|larrsim|lotimes|lbrksld|lbrkslu|lozenge|ldrdhar|dbkarow|bigcirc|epsilon|simrarr|simplus|ltquest|Epsilon|luruhar|gtquest|maltese|npolint|eqcolon|npreceq|bigodot|ddagger|gtrless|bnequiv|harrcir|ddotseq|equivDD|backsim|demptyv|nsqsube|nsqsupe|Upsilon|nsubset|upsilon|minusdu|nsucceq|swarrow|nsupset|coloneq|searrow|boxplus|napprox|natural|asympeq|alefsym|congdot|nearrow|bigstar|diamond|supplus|tritime|LeftTee|nvinfin|triplus|NewLine|nvltrie|nvrtrie|nwarrow|nexists|Diamond|ruluhar|Implies|supmult|angzarr|suplarr|suphsub|questeq|because|digamma|Because|olcross|bemptyv|omicron|Omicron|rotimes|NoBreak|intprod|angrtvb|orderof|uwangle|suphsol|lesdoto|orslope|DownTee|realine|cudarrl|rdldhar|OverBar|supedot|lessdot|supdsub|topfork|succsim|rbrkslu|rbrksld|pertenk|cudarrr|isindot|planckh|lessgtr|pluscir|gesdoto|plussim|plustwo|lesssim|cularrp|rarrsim|Cayleys|notinva|notinvb|notinvc|UpArrow|Uparrow|uparrow|NotLess|dwangle|precsim|Product|curarrm|Cconint|dotplus|rarrbfs|ccupssm|Cedilla|cemptyv|notniva|quatint|frac35|frac38|frac45|frac56|frac58|frac78|tridot|xoplus|gacute|gammad|Gammad|lfisht|lfloor|bigcup|sqsupe|gbreve|Gbreve|lharul|sqsube|sqcups|Gcedil|apacir|llhard|lmidot|Lmidot|lmoust|andand|sqcaps|approx|Abreve|spades|circeq|tprime|divide|topcir|Assign|topbot|gesdot|divonx|xuplus|timesd|gesles|atilde|solbar|SOFTcy|loplus|timesb|lowast|lowbar|dlcorn|dlcrop|softcy|dollar|lparlt|thksim|lrhard|Atilde|lsaquo|smashp|bigvee|thinsp|wreath|bkarow|lsquor|lstrok|Lstrok|lthree|ltimes|ltlarr|DotDot|simdot|ltrPar|weierp|xsqcup|angmsd|sigmav|sigmaf|zeetrf|Zcaron|zcaron|mapsto|vsupne|thetav|cirmid|marker|mcomma|Zacute|vsubnE|there4|gtlPar|vsubne|bottom|gtrarr|SHCHcy|shchcy|midast|midcir|middot|minusb|minusd|gtrdot|bowtie|sfrown|mnplus|models|colone|seswar|Colone|mstpos|searhk|gtrsim|nacute|Nacute|boxbox|telrec|hairsp|Tcedil|nbumpe|scnsim|ncaron|Ncaron|ncedil|Ncedil|hamilt|Scedil|nearhk|hardcy|HARDcy|tcedil|Tcaron|commat|nequiv|nesear|tcaron|target|hearts|nexist|varrho|scedil|Scaron|scaron|hellip|Sacute|sacute|hercon|swnwar|compfn|rtimes|rthree|rsquor|rsaquo|zacute|wedgeq|homtht|barvee|barwed|Barwed|rpargt|horbar|conint|swarhk|roplus|nltrie|hslash|hstrok|Hstrok|rmoust|Conint|bprime|hybull|hyphen|iacute|Iacute|supsup|supsub|supsim|varphi|coprod|brvbar|agrave|Supset|supset|igrave|Igrave|notinE|Agrave|iiiint|iinfin|copysr|wedbar|Verbar|vangrt|becaus|incare|verbar|inodot|bullet|drcorn|intcal|drcrop|cularr|vellip|Utilde|bumpeq|cupcap|dstrok|Dstrok|CupCap|cupcup|cupdot|eacute|Eacute|supdot|iquest|easter|ecaron|Ecaron|ecolon|isinsv|utilde|itilde|Itilde|curarr|succeq|Bumpeq|cacute|ulcrop|nparsl|Cacute|nprcue|egrave|Egrave|nrarrc|nrarrw|subsup|subsub|nrtrie|jsercy|nsccue|Jsercy|kappav|kcedil|Kcedil|subsim|ulcorn|nsimeq|egsdot|veebar|kgreen|capand|elsdot|Subset|subset|curren|aacute|lacute|Lacute|emptyv|ntilde|Ntilde|lagran|lambda|Lambda|capcap|Ugrave|langle|subdot|emsp13|numero|emsp14|nvdash|nvDash|nVdash|nVDash|ugrave|ufisht|nvHarr|larrfs|nvlArr|larrhk|larrlp|larrpl|nvrArr|Udblac|nwarhk|larrtl|nwnear|oacute|Oacute|latail|lAtail|sstarf|lbrace|odblac|Odblac|lbrack|udblac|odsold|eparsl|lcaron|Lcaron|ograve|Ograve|lcedil|Lcedil|Aacute|ssmile|ssetmn|squarf|ldquor|capcup|ominus|cylcty|rharul|eqcirc|dagger|rfloor|rfisht|Dagger|daleth|equals|origof|capdot|equest|dcaron|Dcaron|rdquor|oslash|Oslash|otilde|Otilde|otimes|Otimes|urcrop|Ubreve|ubreve|Yacute|Uacute|uacute|Rcedil|rcedil|urcorn|parsim|Rcaron|Vdashl|rcaron|Tstrok|percnt|period|permil|Exists|yacute|rbrack|rbrace|phmmat|ccaron|Ccaron|planck|ccedil|plankv|tstrok|female|plusdo|plusdu|ffilig|plusmn|ffllig|Ccedil|rAtail|dfisht|bernou|ratail|Rarrtl|rarrtl|angsph|rarrpl|rarrlp|rarrhk|xwedge|xotime|forall|ForAll|Vvdash|vsupnE|preceq|bigcap|frac12|frac13|frac14|primes|rarrfs|prnsim|frac15|Square|frac16|square|lesdot|frac18|frac23|propto|prurel|rarrap|rangle|puncsp|frac25|Racute|qprime|racute|lesges|frac34|abreve|AElig|eqsim|utdot|setmn|urtri|Equal|Uring|seArr|uring|searr|dashv|Dashv|mumap|nabla|iogon|Iogon|sdote|sdotb|scsim|napid|napos|equiv|natur|Acirc|dblac|erarr|nbump|iprod|erDot|ucirc|awint|esdot|angrt|ncong|isinE|scnap|Scirc|scirc|ndash|isins|Ubrcy|nearr|neArr|isinv|nedot|ubrcy|acute|Ycirc|iukcy|Iukcy|xutri|nesim|caret|jcirc|Jcirc|caron|twixt|ddarr|sccue|exist|jmath|sbquo|ngeqq|angst|ccaps|lceil|ngsim|UpTee|delta|Delta|rtrif|nharr|nhArr|nhpar|rtrie|jukcy|Jukcy|kappa|rsquo|Kappa|nlarr|nlArr|TSHcy|rrarr|aogon|Aogon|fflig|xrarr|tshcy|ccirc|nleqq|filig|upsih|nless|dharl|nlsim|fjlig|ropar|nltri|dharr|robrk|roarr|fllig|fltns|roang|rnmid|subnE|subne|lAarr|trisb|Ccirc|acirc|ccups|blank|VDash|forkv|Vdash|langd|cedil|blk12|blk14|laquo|strns|diams|notin|vDash|larrb|blk34|block|disin|uplus|vdash|vBarv|aelig|starf|Wedge|check|xrArr|lates|lbarr|lBarr|notni|lbbrk|bcong|frasl|lbrke|frown|vrtri|vprop|vnsup|gamma|Gamma|wedge|xodot|bdquo|srarr|doteq|ldquo|boxdl|boxdL|gcirc|Gcirc|boxDl|boxDL|boxdr|boxdR|boxDr|TRADE|trade|rlhar|boxDR|vnsub|npart|vltri|rlarr|boxhd|boxhD|nprec|gescc|nrarr|nrArr|boxHd|boxHD|boxhu|boxhU|nrtri|boxHu|clubs|boxHU|times|colon|Colon|gimel|xlArr|Tilde|nsime|tilde|nsmid|nspar|THORN|thorn|xlarr|nsube|nsubE|thkap|xhArr|comma|nsucc|boxul|boxuL|nsupe|nsupE|gneqq|gnsim|boxUl|boxUL|grave|boxur|boxuR|boxUr|boxUR|lescc|angle|bepsi|boxvh|varpi|boxvH|numsp|Theta|gsime|gsiml|theta|boxVh|boxVH|boxvl|gtcir|gtdot|boxvL|boxVl|boxVL|crarr|cross|Cross|nvsim|boxvr|nwarr|nwArr|sqsup|dtdot|Uogon|lhard|lharu|dtrif|ocirc|Ocirc|lhblk|duarr|odash|sqsub|Hacek|sqcup|llarr|duhar|oelig|OElig|ofcir|boxvR|uogon|lltri|boxVr|csube|uuarr|ohbar|csupe|ctdot|olarr|olcir|harrw|oline|sqcap|omacr|Omacr|omega|Omega|boxVR|aleph|lneqq|lnsim|loang|loarr|rharu|lobrk|hcirc|operp|oplus|rhard|Hcirc|orarr|Union|order|ecirc|Ecirc|cuepr|szlig|cuesc|breve|reals|eDDot|Breve|hoarr|lopar|utrif|rdquo|Umacr|umacr|efDot|swArr|ultri|alpha|rceil|ovbar|swarr|Wcirc|wcirc|smtes|smile|bsemi|lrarr|aring|parsl|lrhar|bsime|uhblk|lrtri|cupor|Aring|uharr|uharl|slarr|rbrke|bsolb|lsime|rbbrk|RBarr|lsimg|phone|rBarr|rbarr|icirc|lsquo|Icirc|emacr|Emacr|ratio|simne|plusb|simlE|simgE|simeq|pluse|ltcir|ltdot|empty|xharr|xdtri|iexcl|Alpha|ltrie|rarrw|pound|ltrif|xcirc|bumpe|prcue|bumpE|asymp|amacr|cuvee|Sigma|sigma|iiint|udhar|iiota|ijlig|IJlig|supnE|imacr|Imacr|prime|Prime|image|prnap|eogon|Eogon|rarrc|mdash|mDDot|cuwed|imath|supne|imped|Amacr|udarr|prsim|micro|rarrb|cwint|raquo|infin|eplus|range|rangd|Ucirc|radic|minus|amalg|veeeq|rAarr|epsiv|ycirc|quest|sharp|quot|zwnj|Qscr|race|qscr|Qopf|qopf|qint|rang|Rang|Zscr|zscr|Zopf|zopf|rarr|rArr|Rarr|Pscr|pscr|prop|prod|prnE|prec|ZHcy|zhcy|prap|Zeta|zeta|Popf|popf|Zdot|plus|zdot|Yuml|yuml|phiv|YUcy|yucy|Yscr|yscr|perp|Yopf|yopf|part|para|YIcy|Ouml|rcub|yicy|YAcy|rdca|ouml|osol|Oscr|rdsh|yacy|real|oscr|xvee|andd|rect|andv|Xscr|oror|ordm|ordf|xscr|ange|aopf|Aopf|rHar|Xopf|opar|Oopf|xopf|xnis|rhov|oopf|omid|xmap|oint|apid|apos|ogon|ascr|Ascr|odot|odiv|xcup|xcap|ocir|oast|nvlt|nvle|nvgt|nvge|nvap|Wscr|wscr|auml|ntlg|ntgl|nsup|nsub|nsim|Nscr|nscr|nsce|Wopf|ring|npre|wopf|npar|Auml|Barv|bbrk|Nopf|nopf|nmid|nLtv|beta|ropf|Ropf|Beta|beth|nles|rpar|nleq|bnot|bNot|nldr|NJcy|rscr|Rscr|Vscr|vscr|rsqb|njcy|bopf|nisd|Bopf|rtri|Vopf|nGtv|ngtr|vopf|boxh|boxH|boxv|nges|ngeq|boxV|bscr|scap|Bscr|bsim|Vert|vert|bsol|bull|bump|caps|cdot|ncup|scnE|ncap|nbsp|napE|Cdot|cent|sdot|Vbar|nang|vBar|chcy|Mscr|mscr|sect|semi|CHcy|Mopf|mopf|sext|circ|cire|mldr|mlcp|cirE|comp|shcy|SHcy|vArr|varr|cong|copf|Copf|copy|COPY|malt|male|macr|lvnE|cscr|ltri|sime|ltcc|simg|Cscr|siml|csub|Uuml|lsqb|lsim|uuml|csup|Lscr|lscr|utri|smid|lpar|cups|smte|lozf|darr|Lopf|Uscr|solb|lopf|sopf|Sopf|lneq|uscr|spar|dArr|lnap|Darr|dash|Sqrt|LJcy|ljcy|lHar|dHar|Upsi|upsi|diam|lesg|djcy|DJcy|leqq|dopf|Dopf|dscr|Dscr|dscy|ldsh|ldca|squf|DScy|sscr|Sscr|dsol|lcub|late|star|Star|Uopf|Larr|lArr|larr|uopf|dtri|dzcy|sube|subE|Lang|lang|Kscr|kscr|Kopf|kopf|KJcy|kjcy|KHcy|khcy|DZcy|ecir|edot|eDot|Jscr|jscr|succ|Jopf|jopf|Edot|uHar|emsp|ensp|Iuml|iuml|eopf|isin|Iscr|iscr|Eopf|epar|sung|epsi|escr|sup1|sup2|sup3|Iota|iota|supe|supE|Iopf|iopf|IOcy|iocy|Escr|esim|Esim|imof|Uarr|QUOT|uArr|uarr|euml|IEcy|iecy|Idot|Euml|euro|excl|Hscr|hscr|Hopf|hopf|TScy|tscy|Tscr|hbar|tscr|flat|tbrk|fnof|hArr|harr|half|fopf|Fopf|tdot|gvnE|fork|trie|gtcc|fscr|Fscr|gdot|gsim|Gscr|gscr|Gopf|gopf|gneq|Gdot|tosa|gnap|Topf|topf|geqq|toea|GJcy|gjcy|tint|gesl|mid|Sfr|ggg|top|ges|gla|glE|glj|geq|gne|gEl|gel|gnE|Gcy|gcy|gap|Tfr|tfr|Tcy|tcy|Hat|Tau|Ffr|tau|Tab|hfr|Hfr|ffr|Fcy|fcy|icy|Icy|iff|ETH|eth|ifr|Ifr|Eta|eta|int|Int|Sup|sup|ucy|Ucy|Sum|sum|jcy|ENG|ufr|Ufr|eng|Jcy|jfr|els|ell|egs|Efr|efr|Jfr|uml|kcy|Kcy|Ecy|ecy|kfr|Kfr|lap|Sub|sub|lat|lcy|Lcy|leg|Dot|dot|lEg|leq|les|squ|div|die|lfr|Lfr|lgE|Dfr|dfr|Del|deg|Dcy|dcy|lne|lnE|sol|loz|smt|Cup|lrm|cup|lsh|Lsh|sim|shy|map|Map|mcy|Mcy|mfr|Mfr|mho|gfr|Gfr|sfr|cir|Chi|chi|nap|Cfr|vcy|Vcy|cfr|Scy|scy|ncy|Ncy|vee|Vee|Cap|cap|nfr|scE|sce|Nfr|nge|ngE|nGg|vfr|Vfr|ngt|bot|nGt|nis|niv|Rsh|rsh|nle|nlE|bne|Bfr|bfr|nLl|nlt|nLt|Bcy|bcy|not|Not|rlm|wfr|Wfr|npr|nsc|num|ocy|ast|Ocy|ofr|xfr|Xfr|Ofr|ogt|ohm|apE|olt|Rho|ape|rho|Rfr|rfr|ord|REG|ang|reg|orv|And|and|AMP|Rcy|amp|Afr|ycy|Ycy|yen|yfr|Yfr|rcy|par|pcy|Pcy|pfr|Pfr|phi|Phi|afr|Acy|acy|zcy|Zcy|piv|acE|acd|zfr|Zfr|pre|prE|psi|Psi|qfr|Qfr|zwj|Or|ge|Gg|gt|gg|el|oS|lt|Lt|LT|Re|lg|gl|eg|ne|Im|it|le|DD|wp|wr|nu|Nu|dd|lE|Sc|sc|pi|Pi|ee|af|ll|Ll|rx|gE|xi|pm|Xi|ic|pr|Pr|in|ni|mp|mu|ac|Mu|or|ap|Gt|GT|ii);|&(Aacute|Agrave|Atilde|Ccedil|Eacute|Egrave|Iacute|Igrave|Ntilde|Oacute|Ograve|Oslash|Otilde|Uacute|Ugrave|Yacute|aacute|agrave|atilde|brvbar|ccedil|curren|divide|eacute|egrave|frac12|frac14|frac34|iacute|igrave|iquest|middot|ntilde|oacute|ograve|oslash|otilde|plusmn|uacute|ugrave|yacute|AElig|Acirc|Aring|Ecirc|Icirc|Ocirc|THORN|Ucirc|acirc|acute|aelig|aring|cedil|ecirc|icirc|iexcl|laquo|micro|ocirc|pound|raquo|szlig|thorn|times|ucirc|Auml|COPY|Euml|Iuml|Ouml|QUOT|Uuml|auml|cent|copy|euml|iuml|macr|nbsp|ordf|ordm|ouml|para|quot|sect|sup1|sup2|sup3|uuml|yuml|AMP|ETH|REG|amp|deg|eth|not|reg|shy|uml|yen|GT|LT|gt|lt)(?!;)([=a-zA-Z0-9]?)|&#([0-9]+)(;?)|&#[xX]([a-fA-F0-9]+)(;?)|&([0-9a-zA-Z]+)/g; |
| var decodeMap = {'aacute':'\xE1','Aacute':'\xC1','abreve':'\u0103','Abreve':'\u0102','ac':'\u223E','acd':'\u223F','acE':'\u223E\u0333','acirc':'\xE2','Acirc':'\xC2','acute':'\xB4','acy':'\u0430','Acy':'\u0410','aelig':'\xE6','AElig':'\xC6','af':'\u2061','afr':'\uD835\uDD1E','Afr':'\uD835\uDD04','agrave':'\xE0','Agrave':'\xC0','alefsym':'\u2135','aleph':'\u2135','alpha':'\u03B1','Alpha':'\u0391','amacr':'\u0101','Amacr':'\u0100','amalg':'\u2A3F','amp':'&','AMP':'&','and':'\u2227','And':'\u2A53','andand':'\u2A55','andd':'\u2A5C','andslope':'\u2A58','andv':'\u2A5A','ang':'\u2220','ange':'\u29A4','angle':'\u2220','angmsd':'\u2221','angmsdaa':'\u29A8','angmsdab':'\u29A9','angmsdac':'\u29AA','angmsdad':'\u29AB','angmsdae':'\u29AC','angmsdaf':'\u29AD','angmsdag':'\u29AE','angmsdah':'\u29AF','angrt':'\u221F','angrtvb':'\u22BE','angrtvbd':'\u299D','angsph':'\u2222','angst':'\xC5','angzarr':'\u237C','aogon':'\u0105','Aogon':'\u0104','aopf':'\uD835\uDD52','Aopf':'\uD835\uDD38','ap':'\u2248','apacir':'\u2A6F','ape':'\u224A','apE':'\u2A70','apid':'\u224B','apos':'\'','ApplyFunction':'\u2061','approx':'\u2248','approxeq':'\u224A','aring':'\xE5','Aring':'\xC5','ascr':'\uD835\uDCB6','Ascr':'\uD835\uDC9C','Assign':'\u2254','ast':'*','asymp':'\u2248','asympeq':'\u224D','atilde':'\xE3','Atilde':'\xC3','auml':'\xE4','Auml':'\xC4','awconint':'\u2233','awint':'\u2A11','backcong':'\u224C','backepsilon':'\u03F6','backprime':'\u2035','backsim':'\u223D','backsimeq':'\u22CD','Backslash':'\u2216','Barv':'\u2AE7','barvee':'\u22BD','barwed':'\u2305','Barwed':'\u2306','barwedge':'\u2305','bbrk':'\u23B5','bbrktbrk':'\u23B6','bcong':'\u224C','bcy':'\u0431','Bcy':'\u0411','bdquo':'\u201E','becaus':'\u2235','because':'\u2235','Because':'\u2235','bemptyv':'\u29B0','bepsi':'\u03F6','bernou':'\u212C','Bernoullis':'\u212C','beta':'\u03B2','Beta':'\u0392','beth':'\u2136','between':'\u226C','bfr':'\uD835\uDD1F','Bfr':'\uD835\uDD05','bigcap':'\u22C2','bigcirc':'\u25EF','bigcup':'\u22C3','bigodot':'\u2A00','bigoplus':'\u2A01','bigotimes':'\u2A02','bigsqcup':'\u2A06','bigstar':'\u2605','bigtriangledown':'\u25BD','bigtriangleup':'\u25B3','biguplus':'\u2A04','bigvee':'\u22C1','bigwedge':'\u22C0','bkarow':'\u290D','blacklozenge':'\u29EB','blacksquare':'\u25AA','blacktriangle':'\u25B4','blacktriangledown':'\u25BE','blacktriangleleft':'\u25C2','blacktriangleright':'\u25B8','blank':'\u2423','blk12':'\u2592','blk14':'\u2591','blk34':'\u2593','block':'\u2588','bne':'=\u20E5','bnequiv':'\u2261\u20E5','bnot':'\u2310','bNot':'\u2AED','bopf':'\uD835\uDD53','Bopf':'\uD835\uDD39','bot':'\u22A5','bottom':'\u22A5','bowtie':'\u22C8','boxbox':'\u29C9','boxdl':'\u2510','boxdL':'\u2555','boxDl':'\u2556','boxDL':'\u2557','boxdr':'\u250C','boxdR':'\u2552','boxDr':'\u2553','boxDR':'\u2554','boxh':'\u2500','boxH':'\u2550','boxhd':'\u252C','boxhD':'\u2565','boxHd':'\u2564','boxHD':'\u2566','boxhu':'\u2534','boxhU':'\u2568','boxHu':'\u2567','boxHU':'\u2569','boxminus':'\u229F','boxplus':'\u229E','boxtimes':'\u22A0','boxul':'\u2518','boxuL':'\u255B','boxUl':'\u255C','boxUL':'\u255D','boxur':'\u2514','boxuR':'\u2558','boxUr':'\u2559','boxUR':'\u255A','boxv':'\u2502','boxV':'\u2551','boxvh':'\u253C','boxvH':'\u256A','boxVh':'\u256B','boxVH':'\u256C','boxvl':'\u2524','boxvL':'\u2561','boxVl':'\u2562','boxVL':'\u2563','boxvr':'\u251C','boxvR':'\u255E','boxVr':'\u255F','boxVR':'\u2560','bprime':'\u2035','breve':'\u02D8','Breve':'\u02D8','brvbar':'\xA6','bscr':'\uD835\uDCB7','Bscr':'\u212C','bsemi':'\u204F','bsim':'\u223D','bsime':'\u22CD','bsol':'\\','bsolb':'\u29C5','bsolhsub':'\u27C8','bull':'\u2022','bullet':'\u2022','bump':'\u224E','bumpe':'\u224F','bumpE':'\u2AAE','bumpeq':'\u224F','Bumpeq':'\u224E','cacute':'\u0107','Cacute':'\u0106','cap':'\u2229','Cap':'\u22D2','capand':'\u2A44','capbrcup':'\u2A49','capcap':'\u2A4B','capcup':'\u2A47','capdot':'\u2A40','CapitalDifferentialD':'\u2145','caps':'\u2229\uFE00','caret':'\u2041','caron':'\u02C7','Cayleys':'\u212D','ccaps':'\u2A4D','ccaron':'\u010D','Ccaron':'\u010C','ccedil':'\xE7','Ccedil':'\xC7','ccirc':'\u0109','Ccirc':'\u0108','Cconint':'\u2230','ccups':'\u2A4C','ccupssm':'\u2A50','cdot':'\u010B','Cdot':'\u010A','cedil':'\xB8','Cedilla':'\xB8','cemptyv':'\u29B2','cent':'\xA2','centerdot':'\xB7','CenterDot':'\xB7','cfr':'\uD835\uDD20','Cfr':'\u212D','chcy':'\u0447','CHcy':'\u0427','check':'\u2713','checkmark':'\u2713','chi':'\u03C7','Chi':'\u03A7','cir':'\u25CB','circ':'\u02C6','circeq':'\u2257','circlearrowleft':'\u21BA','circlearrowright':'\u21BB','circledast':'\u229B','circledcirc':'\u229A','circleddash':'\u229D','CircleDot':'\u2299','circledR':'\xAE','circledS':'\u24C8','CircleMinus':'\u2296','CirclePlus':'\u2295','CircleTimes':'\u2297','cire':'\u2257','cirE':'\u29C3','cirfnint':'\u2A10','cirmid':'\u2AEF','cirscir':'\u29C2','ClockwiseContourIntegral':'\u2232','CloseCurlyDoubleQuote':'\u201D','CloseCurlyQuote':'\u2019','clubs':'\u2663','clubsuit':'\u2663','colon':':','Colon':'\u2237','colone':'\u2254','Colone':'\u2A74','coloneq':'\u2254','comma':',','commat':'@','comp':'\u2201','compfn':'\u2218','complement':'\u2201','complexes':'\u2102','cong':'\u2245','congdot':'\u2A6D','Congruent':'\u2261','conint':'\u222E','Conint':'\u222F','ContourIntegral':'\u222E','copf':'\uD835\uDD54','Copf':'\u2102','coprod':'\u2210','Coproduct':'\u2210','copy':'\xA9','COPY':'\xA9','copysr':'\u2117','CounterClockwiseContourIntegral':'\u2233','crarr':'\u21B5','cross':'\u2717','Cross':'\u2A2F','cscr':'\uD835\uDCB8','Cscr':'\uD835\uDC9E','csub':'\u2ACF','csube':'\u2AD1','csup':'\u2AD0','csupe':'\u2AD2','ctdot':'\u22EF','cudarrl':'\u2938','cudarrr':'\u2935','cuepr':'\u22DE','cuesc':'\u22DF','cularr':'\u21B6','cularrp':'\u293D','cup':'\u222A','Cup':'\u22D3','cupbrcap':'\u2A48','cupcap':'\u2A46','CupCap':'\u224D','cupcup':'\u2A4A','cupdot':'\u228D','cupor':'\u2A45','cups':'\u222A\uFE00','curarr':'\u21B7','curarrm':'\u293C','curlyeqprec':'\u22DE','curlyeqsucc':'\u22DF','curlyvee':'\u22CE','curlywedge':'\u22CF','curren':'\xA4','curvearrowleft':'\u21B6','curvearrowright':'\u21B7','cuvee':'\u22CE','cuwed':'\u22CF','cwconint':'\u2232','cwint':'\u2231','cylcty':'\u232D','dagger':'\u2020','Dagger':'\u2021','daleth':'\u2138','darr':'\u2193','dArr':'\u21D3','Darr':'\u21A1','dash':'\u2010','dashv':'\u22A3','Dashv':'\u2AE4','dbkarow':'\u290F','dblac':'\u02DD','dcaron':'\u010F','Dcaron':'\u010E','dcy':'\u0434','Dcy':'\u0414','dd':'\u2146','DD':'\u2145','ddagger':'\u2021','ddarr':'\u21CA','DDotrahd':'\u2911','ddotseq':'\u2A77','deg':'\xB0','Del':'\u2207','delta':'\u03B4','Delta':'\u0394','demptyv':'\u29B1','dfisht':'\u297F','dfr':'\uD835\uDD21','Dfr':'\uD835\uDD07','dHar':'\u2965','dharl':'\u21C3','dharr':'\u21C2','DiacriticalAcute':'\xB4','DiacriticalDot':'\u02D9','DiacriticalDoubleAcute':'\u02DD','DiacriticalGrave':'`','DiacriticalTilde':'\u02DC','diam':'\u22C4','diamond':'\u22C4','Diamond':'\u22C4','diamondsuit':'\u2666','diams':'\u2666','die':'\xA8','DifferentialD':'\u2146','digamma':'\u03DD','disin':'\u22F2','div':'\xF7','divide':'\xF7','divideontimes':'\u22C7','divonx':'\u22C7','djcy':'\u0452','DJcy':'\u0402','dlcorn':'\u231E','dlcrop':'\u230D','dollar':'$','dopf':'\uD835\uDD55','Dopf':'\uD835\uDD3B','dot':'\u02D9','Dot':'\xA8','DotDot':'\u20DC','doteq':'\u2250','doteqdot':'\u2251','DotEqual':'\u2250','dotminus':'\u2238','dotplus':'\u2214','dotsquare':'\u22A1','doublebarwedge':'\u2306','DoubleContourIntegral':'\u222F','DoubleDot':'\xA8','DoubleDownArrow':'\u21D3','DoubleLeftArrow':'\u21D0','DoubleLeftRightArrow':'\u21D4','DoubleLeftTee':'\u2AE4','DoubleLongLeftArrow':'\u27F8','DoubleLongLeftRightArrow':'\u27FA','DoubleLongRightArrow':'\u27F9','DoubleRightArrow':'\u21D2','DoubleRightTee':'\u22A8','DoubleUpArrow':'\u21D1','DoubleUpDownArrow':'\u21D5','DoubleVerticalBar':'\u2225','downarrow':'\u2193','Downarrow':'\u21D3','DownArrow':'\u2193','DownArrowBar':'\u2913','DownArrowUpArrow':'\u21F5','DownBreve':'\u0311','downdownarrows':'\u21CA','downharpoonleft':'\u21C3','downharpoonright':'\u21C2','DownLeftRightVector':'\u2950','DownLeftTeeVector':'\u295E','DownLeftVector':'\u21BD','DownLeftVectorBar':'\u2956','DownRightTeeVector':'\u295F','DownRightVector':'\u21C1','DownRightVectorBar':'\u2957','DownTee':'\u22A4','DownTeeArrow':'\u21A7','drbkarow':'\u2910','drcorn':'\u231F','drcrop':'\u230C','dscr':'\uD835\uDCB9','Dscr':'\uD835\uDC9F','dscy':'\u0455','DScy':'\u0405','dsol':'\u29F6','dstrok':'\u0111','Dstrok':'\u0110','dtdot':'\u22F1','dtri':'\u25BF','dtrif':'\u25BE','duarr':'\u21F5','duhar':'\u296F','dwangle':'\u29A6','dzcy':'\u045F','DZcy':'\u040F','dzigrarr':'\u27FF','eacute':'\xE9','Eacute':'\xC9','easter':'\u2A6E','ecaron':'\u011B','Ecaron':'\u011A','ecir':'\u2256','ecirc':'\xEA','Ecirc':'\xCA','ecolon':'\u2255','ecy':'\u044D','Ecy':'\u042D','eDDot':'\u2A77','edot':'\u0117','eDot':'\u2251','Edot':'\u0116','ee':'\u2147','efDot':'\u2252','efr':'\uD835\uDD22','Efr':'\uD835\uDD08','eg':'\u2A9A','egrave':'\xE8','Egrave':'\xC8','egs':'\u2A96','egsdot':'\u2A98','el':'\u2A99','Element':'\u2208','elinters':'\u23E7','ell':'\u2113','els':'\u2A95','elsdot':'\u2A97','emacr':'\u0113','Emacr':'\u0112','empty':'\u2205','emptyset':'\u2205','EmptySmallSquare':'\u25FB','emptyv':'\u2205','EmptyVerySmallSquare':'\u25AB','emsp':'\u2003','emsp13':'\u2004','emsp14':'\u2005','eng':'\u014B','ENG':'\u014A','ensp':'\u2002','eogon':'\u0119','Eogon':'\u0118','eopf':'\uD835\uDD56','Eopf':'\uD835\uDD3C','epar':'\u22D5','eparsl':'\u29E3','eplus':'\u2A71','epsi':'\u03B5','epsilon':'\u03B5','Epsilon':'\u0395','epsiv':'\u03F5','eqcirc':'\u2256','eqcolon':'\u2255','eqsim':'\u2242','eqslantgtr':'\u2A96','eqslantless':'\u2A95','Equal':'\u2A75','equals':'=','EqualTilde':'\u2242','equest':'\u225F','Equilibrium':'\u21CC','equiv':'\u2261','equivDD':'\u2A78','eqvparsl':'\u29E5','erarr':'\u2971','erDot':'\u2253','escr':'\u212F','Escr':'\u2130','esdot':'\u2250','esim':'\u2242','Esim':'\u2A73','eta':'\u03B7','Eta':'\u0397','eth':'\xF0','ETH':'\xD0','euml':'\xEB','Euml':'\xCB','euro':'\u20AC','excl':'!','exist':'\u2203','Exists':'\u2203','expectation':'\u2130','exponentiale':'\u2147','ExponentialE':'\u2147','fallingdotseq':'\u2252','fcy':'\u0444','Fcy':'\u0424','female':'\u2640','ffilig':'\uFB03','fflig':'\uFB00','ffllig':'\uFB04','ffr':'\uD835\uDD23','Ffr':'\uD835\uDD09','filig':'\uFB01','FilledSmallSquare':'\u25FC','FilledVerySmallSquare':'\u25AA','fjlig':'fj','flat':'\u266D','fllig':'\uFB02','fltns':'\u25B1','fnof':'\u0192','fopf':'\uD835\uDD57','Fopf':'\uD835\uDD3D','forall':'\u2200','ForAll':'\u2200','fork':'\u22D4','forkv':'\u2AD9','Fouriertrf':'\u2131','fpartint':'\u2A0D','frac12':'\xBD','frac13':'\u2153','frac14':'\xBC','frac15':'\u2155','frac16':'\u2159','frac18':'\u215B','frac23':'\u2154','frac25':'\u2156','frac34':'\xBE','frac35':'\u2157','frac38':'\u215C','frac45':'\u2158','frac56':'\u215A','frac58':'\u215D','frac78':'\u215E','frasl':'\u2044','frown':'\u2322','fscr':'\uD835\uDCBB','Fscr':'\u2131','gacute':'\u01F5','gamma':'\u03B3','Gamma':'\u0393','gammad':'\u03DD','Gammad':'\u03DC','gap':'\u2A86','gbreve':'\u011F','Gbreve':'\u011E','Gcedil':'\u0122','gcirc':'\u011D','Gcirc':'\u011C','gcy':'\u0433','Gcy':'\u0413','gdot':'\u0121','Gdot':'\u0120','ge':'\u2265','gE':'\u2267','gel':'\u22DB','gEl':'\u2A8C','geq':'\u2265','geqq':'\u2267','geqslant':'\u2A7E','ges':'\u2A7E','gescc':'\u2AA9','gesdot':'\u2A80','gesdoto':'\u2A82','gesdotol':'\u2A84','gesl':'\u22DB\uFE00','gesles':'\u2A94','gfr':'\uD835\uDD24','Gfr':'\uD835\uDD0A','gg':'\u226B','Gg':'\u22D9','ggg':'\u22D9','gimel':'\u2137','gjcy':'\u0453','GJcy':'\u0403','gl':'\u2277','gla':'\u2AA5','glE':'\u2A92','glj':'\u2AA4','gnap':'\u2A8A','gnapprox':'\u2A8A','gne':'\u2A88','gnE':'\u2269','gneq':'\u2A88','gneqq':'\u2269','gnsim':'\u22E7','gopf':'\uD835\uDD58','Gopf':'\uD835\uDD3E','grave':'`','GreaterEqual':'\u2265','GreaterEqualLess':'\u22DB','GreaterFullEqual':'\u2267','GreaterGreater':'\u2AA2','GreaterLess':'\u2277','GreaterSlantEqual':'\u2A7E','GreaterTilde':'\u2273','gscr':'\u210A','Gscr':'\uD835\uDCA2','gsim':'\u2273','gsime':'\u2A8E','gsiml':'\u2A90','gt':'>','Gt':'\u226B','GT':'>','gtcc':'\u2AA7','gtcir':'\u2A7A','gtdot':'\u22D7','gtlPar':'\u2995','gtquest':'\u2A7C','gtrapprox':'\u2A86','gtrarr':'\u2978','gtrdot':'\u22D7','gtreqless':'\u22DB','gtreqqless':'\u2A8C','gtrless':'\u2277','gtrsim':'\u2273','gvertneqq':'\u2269\uFE00','gvnE':'\u2269\uFE00','Hacek':'\u02C7','hairsp':'\u200A','half':'\xBD','hamilt':'\u210B','hardcy':'\u044A','HARDcy':'\u042A','harr':'\u2194','hArr':'\u21D4','harrcir':'\u2948','harrw':'\u21AD','Hat':'^','hbar':'\u210F','hcirc':'\u0125','Hcirc':'\u0124','hearts':'\u2665','heartsuit':'\u2665','hellip':'\u2026','hercon':'\u22B9','hfr':'\uD835\uDD25','Hfr':'\u210C','HilbertSpace':'\u210B','hksearow':'\u2925','hkswarow':'\u2926','hoarr':'\u21FF','homtht':'\u223B','hookleftarrow':'\u21A9','hookrightarrow':'\u21AA','hopf':'\uD835\uDD59','Hopf':'\u210D','horbar':'\u2015','HorizontalLine':'\u2500','hscr':'\uD835\uDCBD','Hscr':'\u210B','hslash':'\u210F','hstrok':'\u0127','Hstrok':'\u0126','HumpDownHump':'\u224E','HumpEqual':'\u224F','hybull':'\u2043','hyphen':'\u2010','iacute':'\xED','Iacute':'\xCD','ic':'\u2063','icirc':'\xEE','Icirc':'\xCE','icy':'\u0438','Icy':'\u0418','Idot':'\u0130','iecy':'\u0435','IEcy':'\u0415','iexcl':'\xA1','iff':'\u21D4','ifr':'\uD835\uDD26','Ifr':'\u2111','igrave':'\xEC','Igrave':'\xCC','ii':'\u2148','iiiint':'\u2A0C','iiint':'\u222D','iinfin':'\u29DC','iiota':'\u2129','ijlig':'\u0133','IJlig':'\u0132','Im':'\u2111','imacr':'\u012B','Imacr':'\u012A','image':'\u2111','ImaginaryI':'\u2148','imagline':'\u2110','imagpart':'\u2111','imath':'\u0131','imof':'\u22B7','imped':'\u01B5','Implies':'\u21D2','in':'\u2208','incare':'\u2105','infin':'\u221E','infintie':'\u29DD','inodot':'\u0131','int':'\u222B','Int':'\u222C','intcal':'\u22BA','integers':'\u2124','Integral':'\u222B','intercal':'\u22BA','Intersection':'\u22C2','intlarhk':'\u2A17','intprod':'\u2A3C','InvisibleComma':'\u2063','InvisibleTimes':'\u2062','iocy':'\u0451','IOcy':'\u0401','iogon':'\u012F','Iogon':'\u012E','iopf':'\uD835\uDD5A','Iopf':'\uD835\uDD40','iota':'\u03B9','Iota':'\u0399','iprod':'\u2A3C','iquest':'\xBF','iscr':'\uD835\uDCBE','Iscr':'\u2110','isin':'\u2208','isindot':'\u22F5','isinE':'\u22F9','isins':'\u22F4','isinsv':'\u22F3','isinv':'\u2208','it':'\u2062','itilde':'\u0129','Itilde':'\u0128','iukcy':'\u0456','Iukcy':'\u0406','iuml':'\xEF','Iuml':'\xCF','jcirc':'\u0135','Jcirc':'\u0134','jcy':'\u0439','Jcy':'\u0419','jfr':'\uD835\uDD27','Jfr':'\uD835\uDD0D','jmath':'\u0237','jopf':'\uD835\uDD5B','Jopf':'\uD835\uDD41','jscr':'\uD835\uDCBF','Jscr':'\uD835\uDCA5','jsercy':'\u0458','Jsercy':'\u0408','jukcy':'\u0454','Jukcy':'\u0404','kappa':'\u03BA','Kappa':'\u039A','kappav':'\u03F0','kcedil':'\u0137','Kcedil':'\u0136','kcy':'\u043A','Kcy':'\u041A','kfr':'\uD835\uDD28','Kfr':'\uD835\uDD0E','kgreen':'\u0138','khcy':'\u0445','KHcy':'\u0425','kjcy':'\u045C','KJcy':'\u040C','kopf':'\uD835\uDD5C','Kopf':'\uD835\uDD42','kscr':'\uD835\uDCC0','Kscr':'\uD835\uDCA6','lAarr':'\u21DA','lacute':'\u013A','Lacute':'\u0139','laemptyv':'\u29B4','lagran':'\u2112','lambda':'\u03BB','Lambda':'\u039B','lang':'\u27E8','Lang':'\u27EA','langd':'\u2991','langle':'\u27E8','lap':'\u2A85','Laplacetrf':'\u2112','laquo':'\xAB','larr':'\u2190','lArr':'\u21D0','Larr':'\u219E','larrb':'\u21E4','larrbfs':'\u291F','larrfs':'\u291D','larrhk':'\u21A9','larrlp':'\u21AB','larrpl':'\u2939','larrsim':'\u2973','larrtl':'\u21A2','lat':'\u2AAB','latail':'\u2919','lAtail':'\u291B','late':'\u2AAD','lates':'\u2AAD\uFE00','lbarr':'\u290C','lBarr':'\u290E','lbbrk':'\u2772','lbrace':'{','lbrack':'[','lbrke':'\u298B','lbrksld':'\u298F','lbrkslu':'\u298D','lcaron':'\u013E','Lcaron':'\u013D','lcedil':'\u013C','Lcedil':'\u013B','lceil':'\u2308','lcub':'{','lcy':'\u043B','Lcy':'\u041B','ldca':'\u2936','ldquo':'\u201C','ldquor':'\u201E','ldrdhar':'\u2967','ldrushar':'\u294B','ldsh':'\u21B2','le':'\u2264','lE':'\u2266','LeftAngleBracket':'\u27E8','leftarrow':'\u2190','Leftarrow':'\u21D0','LeftArrow':'\u2190','LeftArrowBar':'\u21E4','LeftArrowRightArrow':'\u21C6','leftarrowtail':'\u21A2','LeftCeiling':'\u2308','LeftDoubleBracket':'\u27E6','LeftDownTeeVector':'\u2961','LeftDownVector':'\u21C3','LeftDownVectorBar':'\u2959','LeftFloor':'\u230A','leftharpoondown':'\u21BD','leftharpoonup':'\u21BC','leftleftarrows':'\u21C7','leftrightarrow':'\u2194','Leftrightarrow':'\u21D4','LeftRightArrow':'\u2194','leftrightarrows':'\u21C6','leftrightharpoons':'\u21CB','leftrightsquigarrow':'\u21AD','LeftRightVector':'\u294E','LeftTee':'\u22A3','LeftTeeArrow':'\u21A4','LeftTeeVector':'\u295A','leftthreetimes':'\u22CB','LeftTriangle':'\u22B2','LeftTriangleBar':'\u29CF','LeftTriangleEqual':'\u22B4','LeftUpDownVector':'\u2951','LeftUpTeeVector':'\u2960','LeftUpVector':'\u21BF','LeftUpVectorBar':'\u2958','LeftVector':'\u21BC','LeftVectorBar':'\u2952','leg':'\u22DA','lEg':'\u2A8B','leq':'\u2264','leqq':'\u2266','leqslant':'\u2A7D','les':'\u2A7D','lescc':'\u2AA8','lesdot':'\u2A7F','lesdoto':'\u2A81','lesdotor':'\u2A83','lesg':'\u22DA\uFE00','lesges':'\u2A93','lessapprox':'\u2A85','lessdot':'\u22D6','lesseqgtr':'\u22DA','lesseqqgtr':'\u2A8B','LessEqualGreater':'\u22DA','LessFullEqual':'\u2266','LessGreater':'\u2276','lessgtr':'\u2276','LessLess':'\u2AA1','lesssim':'\u2272','LessSlantEqual':'\u2A7D','LessTilde':'\u2272','lfisht':'\u297C','lfloor':'\u230A','lfr':'\uD835\uDD29','Lfr':'\uD835\uDD0F','lg':'\u2276','lgE':'\u2A91','lHar':'\u2962','lhard':'\u21BD','lharu':'\u21BC','lharul':'\u296A','lhblk':'\u2584','ljcy':'\u0459','LJcy':'\u0409','ll':'\u226A','Ll':'\u22D8','llarr':'\u21C7','llcorner':'\u231E','Lleftarrow':'\u21DA','llhard':'\u296B','lltri':'\u25FA','lmidot':'\u0140','Lmidot':'\u013F','lmoust':'\u23B0','lmoustache':'\u23B0','lnap':'\u2A89','lnapprox':'\u2A89','lne':'\u2A87','lnE':'\u2268','lneq':'\u2A87','lneqq':'\u2268','lnsim':'\u22E6','loang':'\u27EC','loarr':'\u21FD','lobrk':'\u27E6','longleftarrow':'\u27F5','Longleftarrow':'\u27F8','LongLeftArrow':'\u27F5','longleftrightarrow':'\u27F7','Longleftrightarrow':'\u27FA','LongLeftRightArrow':'\u27F7','longmapsto':'\u27FC','longrightarrow':'\u27F6','Longrightarrow':'\u27F9','LongRightArrow':'\u27F6','looparrowleft':'\u21AB','looparrowright':'\u21AC','lopar':'\u2985','lopf':'\uD835\uDD5D','Lopf':'\uD835\uDD43','loplus':'\u2A2D','lotimes':'\u2A34','lowast':'\u2217','lowbar':'_','LowerLeftArrow':'\u2199','LowerRightArrow':'\u2198','loz':'\u25CA','lozenge':'\u25CA','lozf':'\u29EB','lpar':'(','lparlt':'\u2993','lrarr':'\u21C6','lrcorner':'\u231F','lrhar':'\u21CB','lrhard':'\u296D','lrm':'\u200E','lrtri':'\u22BF','lsaquo':'\u2039','lscr':'\uD835\uDCC1','Lscr':'\u2112','lsh':'\u21B0','Lsh':'\u21B0','lsim':'\u2272','lsime':'\u2A8D','lsimg':'\u2A8F','lsqb':'[','lsquo':'\u2018','lsquor':'\u201A','lstrok':'\u0142','Lstrok':'\u0141','lt':'<','Lt':'\u226A','LT':'<','ltcc':'\u2AA6','ltcir':'\u2A79','ltdot':'\u22D6','lthree':'\u22CB','ltimes':'\u22C9','ltlarr':'\u2976','ltquest':'\u2A7B','ltri':'\u25C3','ltrie':'\u22B4','ltrif':'\u25C2','ltrPar':'\u2996','lurdshar':'\u294A','luruhar':'\u2966','lvertneqq':'\u2268\uFE00','lvnE':'\u2268\uFE00','macr':'\xAF','male':'\u2642','malt':'\u2720','maltese':'\u2720','map':'\u21A6','Map':'\u2905','mapsto':'\u21A6','mapstodown':'\u21A7','mapstoleft':'\u21A4','mapstoup':'\u21A5','marker':'\u25AE','mcomma':'\u2A29','mcy':'\u043C','Mcy':'\u041C','mdash':'\u2014','mDDot':'\u223A','measuredangle':'\u2221','MediumSpace':'\u205F','Mellintrf':'\u2133','mfr':'\uD835\uDD2A','Mfr':'\uD835\uDD10','mho':'\u2127','micro':'\xB5','mid':'\u2223','midast':'*','midcir':'\u2AF0','middot':'\xB7','minus':'\u2212','minusb':'\u229F','minusd':'\u2238','minusdu':'\u2A2A','MinusPlus':'\u2213','mlcp':'\u2ADB','mldr':'\u2026','mnplus':'\u2213','models':'\u22A7','mopf':'\uD835\uDD5E','Mopf':'\uD835\uDD44','mp':'\u2213','mscr':'\uD835\uDCC2','Mscr':'\u2133','mstpos':'\u223E','mu':'\u03BC','Mu':'\u039C','multimap':'\u22B8','mumap':'\u22B8','nabla':'\u2207','nacute':'\u0144','Nacute':'\u0143','nang':'\u2220\u20D2','nap':'\u2249','napE':'\u2A70\u0338','napid':'\u224B\u0338','napos':'\u0149','napprox':'\u2249','natur':'\u266E','natural':'\u266E','naturals':'\u2115','nbsp':'\xA0','nbump':'\u224E\u0338','nbumpe':'\u224F\u0338','ncap':'\u2A43','ncaron':'\u0148','Ncaron':'\u0147','ncedil':'\u0146','Ncedil':'\u0145','ncong':'\u2247','ncongdot':'\u2A6D\u0338','ncup':'\u2A42','ncy':'\u043D','Ncy':'\u041D','ndash':'\u2013','ne':'\u2260','nearhk':'\u2924','nearr':'\u2197','neArr':'\u21D7','nearrow':'\u2197','nedot':'\u2250\u0338','NegativeMediumSpace':'\u200B','NegativeThickSpace':'\u200B','NegativeThinSpace':'\u200B','NegativeVeryThinSpace':'\u200B','nequiv':'\u2262','nesear':'\u2928','nesim':'\u2242\u0338','NestedGreaterGreater':'\u226B','NestedLessLess':'\u226A','NewLine':'\n','nexist':'\u2204','nexists':'\u2204','nfr':'\uD835\uDD2B','Nfr':'\uD835\uDD11','nge':'\u2271','ngE':'\u2267\u0338','ngeq':'\u2271','ngeqq':'\u2267\u0338','ngeqslant':'\u2A7E\u0338','nges':'\u2A7E\u0338','nGg':'\u22D9\u0338','ngsim':'\u2275','ngt':'\u226F','nGt':'\u226B\u20D2','ngtr':'\u226F','nGtv':'\u226B\u0338','nharr':'\u21AE','nhArr':'\u21CE','nhpar':'\u2AF2','ni':'\u220B','nis':'\u22FC','nisd':'\u22FA','niv':'\u220B','njcy':'\u045A','NJcy':'\u040A','nlarr':'\u219A','nlArr':'\u21CD','nldr':'\u2025','nle':'\u2270','nlE':'\u2266\u0338','nleftarrow':'\u219A','nLeftarrow':'\u21CD','nleftrightarrow':'\u21AE','nLeftrightarrow':'\u21CE','nleq':'\u2270','nleqq':'\u2266\u0338','nleqslant':'\u2A7D\u0338','nles':'\u2A7D\u0338','nless':'\u226E','nLl':'\u22D8\u0338','nlsim':'\u2274','nlt':'\u226E','nLt':'\u226A\u20D2','nltri':'\u22EA','nltrie':'\u22EC','nLtv':'\u226A\u0338','nmid':'\u2224','NoBreak':'\u2060','NonBreakingSpace':'\xA0','nopf':'\uD835\uDD5F','Nopf':'\u2115','not':'\xAC','Not':'\u2AEC','NotCongruent':'\u2262','NotCupCap':'\u226D','NotDoubleVerticalBar':'\u2226','NotElement':'\u2209','NotEqual':'\u2260','NotEqualTilde':'\u2242\u0338','NotExists':'\u2204','NotGreater':'\u226F','NotGreaterEqual':'\u2271','NotGreaterFullEqual':'\u2267\u0338','NotGreaterGreater':'\u226B\u0338','NotGreaterLess':'\u2279','NotGreaterSlantEqual':'\u2A7E\u0338','NotGreaterTilde':'\u2275','NotHumpDownHump':'\u224E\u0338','NotHumpEqual':'\u224F\u0338','notin':'\u2209','notindot':'\u22F5\u0338','notinE':'\u22F9\u0338','notinva':'\u2209','notinvb':'\u22F7','notinvc':'\u22F6','NotLeftTriangle':'\u22EA','NotLeftTriangleBar':'\u29CF\u0338','NotLeftTriangleEqual':'\u22EC','NotLess':'\u226E','NotLessEqual':'\u2270','NotLessGreater':'\u2278','NotLessLess':'\u226A\u0338','NotLessSlantEqual':'\u2A7D\u0338','NotLessTilde':'\u2274','NotNestedGreaterGreater':'\u2AA2\u0338','NotNestedLessLess':'\u2AA1\u0338','notni':'\u220C','notniva':'\u220C','notnivb':'\u22FE','notnivc':'\u22FD','NotPrecedes':'\u2280','NotPrecedesEqual':'\u2AAF\u0338','NotPrecedesSlantEqual':'\u22E0','NotReverseElement':'\u220C','NotRightTriangle':'\u22EB','NotRightTriangleBar':'\u29D0\u0338','NotRightTriangleEqual':'\u22ED','NotSquareSubset':'\u228F\u0338','NotSquareSubsetEqual':'\u22E2','NotSquareSuperset':'\u2290\u0338','NotSquareSupersetEqual':'\u22E3','NotSubset':'\u2282\u20D2','NotSubsetEqual':'\u2288','NotSucceeds':'\u2281','NotSucceedsEqual':'\u2AB0\u0338','NotSucceedsSlantEqual':'\u22E1','NotSucceedsTilde':'\u227F\u0338','NotSuperset':'\u2283\u20D2','NotSupersetEqual':'\u2289','NotTilde':'\u2241','NotTildeEqual':'\u2244','NotTildeFullEqual':'\u2247','NotTildeTilde':'\u2249','NotVerticalBar':'\u2224','npar':'\u2226','nparallel':'\u2226','nparsl':'\u2AFD\u20E5','npart':'\u2202\u0338','npolint':'\u2A14','npr':'\u2280','nprcue':'\u22E0','npre':'\u2AAF\u0338','nprec':'\u2280','npreceq':'\u2AAF\u0338','nrarr':'\u219B','nrArr':'\u21CF','nrarrc':'\u2933\u0338','nrarrw':'\u219D\u0338','nrightarrow':'\u219B','nRightarrow':'\u21CF','nrtri':'\u22EB','nrtrie':'\u22ED','nsc':'\u2281','nsccue':'\u22E1','nsce':'\u2AB0\u0338','nscr':'\uD835\uDCC3','Nscr':'\uD835\uDCA9','nshortmid':'\u2224','nshortparallel':'\u2226','nsim':'\u2241','nsime':'\u2244','nsimeq':'\u2244','nsmid':'\u2224','nspar':'\u2226','nsqsube':'\u22E2','nsqsupe':'\u22E3','nsub':'\u2284','nsube':'\u2288','nsubE':'\u2AC5\u0338','nsubset':'\u2282\u20D2','nsubseteq':'\u2288','nsubseteqq':'\u2AC5\u0338','nsucc':'\u2281','nsucceq':'\u2AB0\u0338','nsup':'\u2285','nsupe':'\u2289','nsupE':'\u2AC6\u0338','nsupset':'\u2283\u20D2','nsupseteq':'\u2289','nsupseteqq':'\u2AC6\u0338','ntgl':'\u2279','ntilde':'\xF1','Ntilde':'\xD1','ntlg':'\u2278','ntriangleleft':'\u22EA','ntrianglelefteq':'\u22EC','ntriangleright':'\u22EB','ntrianglerighteq':'\u22ED','nu':'\u03BD','Nu':'\u039D','num':'#','numero':'\u2116','numsp':'\u2007','nvap':'\u224D\u20D2','nvdash':'\u22AC','nvDash':'\u22AD','nVdash':'\u22AE','nVDash':'\u22AF','nvge':'\u2265\u20D2','nvgt':'>\u20D2','nvHarr':'\u2904','nvinfin':'\u29DE','nvlArr':'\u2902','nvle':'\u2264\u20D2','nvlt':'<\u20D2','nvltrie':'\u22B4\u20D2','nvrArr':'\u2903','nvrtrie':'\u22B5\u20D2','nvsim':'\u223C\u20D2','nwarhk':'\u2923','nwarr':'\u2196','nwArr':'\u21D6','nwarrow':'\u2196','nwnear':'\u2927','oacute':'\xF3','Oacute':'\xD3','oast':'\u229B','ocir':'\u229A','ocirc':'\xF4','Ocirc':'\xD4','ocy':'\u043E','Ocy':'\u041E','odash':'\u229D','odblac':'\u0151','Odblac':'\u0150','odiv':'\u2A38','odot':'\u2299','odsold':'\u29BC','oelig':'\u0153','OElig':'\u0152','ofcir':'\u29BF','ofr':'\uD835\uDD2C','Ofr':'\uD835\uDD12','ogon':'\u02DB','ograve':'\xF2','Ograve':'\xD2','ogt':'\u29C1','ohbar':'\u29B5','ohm':'\u03A9','oint':'\u222E','olarr':'\u21BA','olcir':'\u29BE','olcross':'\u29BB','oline':'\u203E','olt':'\u29C0','omacr':'\u014D','Omacr':'\u014C','omega':'\u03C9','Omega':'\u03A9','omicron':'\u03BF','Omicron':'\u039F','omid':'\u29B6','ominus':'\u2296','oopf':'\uD835\uDD60','Oopf':'\uD835\uDD46','opar':'\u29B7','OpenCurlyDoubleQuote':'\u201C','OpenCurlyQuote':'\u2018','operp':'\u29B9','oplus':'\u2295','or':'\u2228','Or':'\u2A54','orarr':'\u21BB','ord':'\u2A5D','order':'\u2134','orderof':'\u2134','ordf':'\xAA','ordm':'\xBA','origof':'\u22B6','oror':'\u2A56','orslope':'\u2A57','orv':'\u2A5B','oS':'\u24C8','oscr':'\u2134','Oscr':'\uD835\uDCAA','oslash':'\xF8','Oslash':'\xD8','osol':'\u2298','otilde':'\xF5','Otilde':'\xD5','otimes':'\u2297','Otimes':'\u2A37','otimesas':'\u2A36','ouml':'\xF6','Ouml':'\xD6','ovbar':'\u233D','OverBar':'\u203E','OverBrace':'\u23DE','OverBracket':'\u23B4','OverParenthesis':'\u23DC','par':'\u2225','para':'\xB6','parallel':'\u2225','parsim':'\u2AF3','parsl':'\u2AFD','part':'\u2202','PartialD':'\u2202','pcy':'\u043F','Pcy':'\u041F','percnt':'%','period':'.','permil':'\u2030','perp':'\u22A5','pertenk':'\u2031','pfr':'\uD835\uDD2D','Pfr':'\uD835\uDD13','phi':'\u03C6','Phi':'\u03A6','phiv':'\u03D5','phmmat':'\u2133','phone':'\u260E','pi':'\u03C0','Pi':'\u03A0','pitchfork':'\u22D4','piv':'\u03D6','planck':'\u210F','planckh':'\u210E','plankv':'\u210F','plus':'+','plusacir':'\u2A23','plusb':'\u229E','pluscir':'\u2A22','plusdo':'\u2214','plusdu':'\u2A25','pluse':'\u2A72','PlusMinus':'\xB1','plusmn':'\xB1','plussim':'\u2A26','plustwo':'\u2A27','pm':'\xB1','Poincareplane':'\u210C','pointint':'\u2A15','popf':'\uD835\uDD61','Popf':'\u2119','pound':'\xA3','pr':'\u227A','Pr':'\u2ABB','prap':'\u2AB7','prcue':'\u227C','pre':'\u2AAF','prE':'\u2AB3','prec':'\u227A','precapprox':'\u2AB7','preccurlyeq':'\u227C','Precedes':'\u227A','PrecedesEqual':'\u2AAF','PrecedesSlantEqual':'\u227C','PrecedesTilde':'\u227E','preceq':'\u2AAF','precnapprox':'\u2AB9','precneqq':'\u2AB5','precnsim':'\u22E8','precsim':'\u227E','prime':'\u2032','Prime':'\u2033','primes':'\u2119','prnap':'\u2AB9','prnE':'\u2AB5','prnsim':'\u22E8','prod':'\u220F','Product':'\u220F','profalar':'\u232E','profline':'\u2312','profsurf':'\u2313','prop':'\u221D','Proportion':'\u2237','Proportional':'\u221D','propto':'\u221D','prsim':'\u227E','prurel':'\u22B0','pscr':'\uD835\uDCC5','Pscr':'\uD835\uDCAB','psi':'\u03C8','Psi':'\u03A8','puncsp':'\u2008','qfr':'\uD835\uDD2E','Qfr':'\uD835\uDD14','qint':'\u2A0C','qopf':'\uD835\uDD62','Qopf':'\u211A','qprime':'\u2057','qscr':'\uD835\uDCC6','Qscr':'\uD835\uDCAC','quaternions':'\u210D','quatint':'\u2A16','quest':'?','questeq':'\u225F','quot':'"','QUOT':'"','rAarr':'\u21DB','race':'\u223D\u0331','racute':'\u0155','Racute':'\u0154','radic':'\u221A','raemptyv':'\u29B3','rang':'\u27E9','Rang':'\u27EB','rangd':'\u2992','range':'\u29A5','rangle':'\u27E9','raquo':'\xBB','rarr':'\u2192','rArr':'\u21D2','Rarr':'\u21A0','rarrap':'\u2975','rarrb':'\u21E5','rarrbfs':'\u2920','rarrc':'\u2933','rarrfs':'\u291E','rarrhk':'\u21AA','rarrlp':'\u21AC','rarrpl':'\u2945','rarrsim':'\u2974','rarrtl':'\u21A3','Rarrtl':'\u2916','rarrw':'\u219D','ratail':'\u291A','rAtail':'\u291C','ratio':'\u2236','rationals':'\u211A','rbarr':'\u290D','rBarr':'\u290F','RBarr':'\u2910','rbbrk':'\u2773','rbrace':'}','rbrack':']','rbrke':'\u298C','rbrksld':'\u298E','rbrkslu':'\u2990','rcaron':'\u0159','Rcaron':'\u0158','rcedil':'\u0157','Rcedil':'\u0156','rceil':'\u2309','rcub':'}','rcy':'\u0440','Rcy':'\u0420','rdca':'\u2937','rdldhar':'\u2969','rdquo':'\u201D','rdquor':'\u201D','rdsh':'\u21B3','Re':'\u211C','real':'\u211C','realine':'\u211B','realpart':'\u211C','reals':'\u211D','rect':'\u25AD','reg':'\xAE','REG':'\xAE','ReverseElement':'\u220B','ReverseEquilibrium':'\u21CB','ReverseUpEquilibrium':'\u296F','rfisht':'\u297D','rfloor':'\u230B','rfr':'\uD835\uDD2F','Rfr':'\u211C','rHar':'\u2964','rhard':'\u21C1','rharu':'\u21C0','rharul':'\u296C','rho':'\u03C1','Rho':'\u03A1','rhov':'\u03F1','RightAngleBracket':'\u27E9','rightarrow':'\u2192','Rightarrow':'\u21D2','RightArrow':'\u2192','RightArrowBar':'\u21E5','RightArrowLeftArrow':'\u21C4','rightarrowtail':'\u21A3','RightCeiling':'\u2309','RightDoubleBracket':'\u27E7','RightDownTeeVector':'\u295D','RightDownVector':'\u21C2','RightDownVectorBar':'\u2955','RightFloor':'\u230B','rightharpoondown':'\u21C1','rightharpoonup':'\u21C0','rightleftarrows':'\u21C4','rightleftharpoons':'\u21CC','rightrightarrows':'\u21C9','rightsquigarrow':'\u219D','RightTee':'\u22A2','RightTeeArrow':'\u21A6','RightTeeVector':'\u295B','rightthreetimes':'\u22CC','RightTriangle':'\u22B3','RightTriangleBar':'\u29D0','RightTriangleEqual':'\u22B5','RightUpDownVector':'\u294F','RightUpTeeVector':'\u295C','RightUpVector':'\u21BE','RightUpVectorBar':'\u2954','RightVector':'\u21C0','RightVectorBar':'\u2953','ring':'\u02DA','risingdotseq':'\u2253','rlarr':'\u21C4','rlhar':'\u21CC','rlm':'\u200F','rmoust':'\u23B1','rmoustache':'\u23B1','rnmid':'\u2AEE','roang':'\u27ED','roarr':'\u21FE','robrk':'\u27E7','ropar':'\u2986','ropf':'\uD835\uDD63','Ropf':'\u211D','roplus':'\u2A2E','rotimes':'\u2A35','RoundImplies':'\u2970','rpar':')','rpargt':'\u2994','rppolint':'\u2A12','rrarr':'\u21C9','Rrightarrow':'\u21DB','rsaquo':'\u203A','rscr':'\uD835\uDCC7','Rscr':'\u211B','rsh':'\u21B1','Rsh':'\u21B1','rsqb':']','rsquo':'\u2019','rsquor':'\u2019','rthree':'\u22CC','rtimes':'\u22CA','rtri':'\u25B9','rtrie':'\u22B5','rtrif':'\u25B8','rtriltri':'\u29CE','RuleDelayed':'\u29F4','ruluhar':'\u2968','rx':'\u211E','sacute':'\u015B','Sacute':'\u015A','sbquo':'\u201A','sc':'\u227B','Sc':'\u2ABC','scap':'\u2AB8','scaron':'\u0161','Scaron':'\u0160','sccue':'\u227D','sce':'\u2AB0','scE':'\u2AB4','scedil':'\u015F','Scedil':'\u015E','scirc':'\u015D','Scirc':'\u015C','scnap':'\u2ABA','scnE':'\u2AB6','scnsim':'\u22E9','scpolint':'\u2A13','scsim':'\u227F','scy':'\u0441','Scy':'\u0421','sdot':'\u22C5','sdotb':'\u22A1','sdote':'\u2A66','searhk':'\u2925','searr':'\u2198','seArr':'\u21D8','searrow':'\u2198','sect':'\xA7','semi':';','seswar':'\u2929','setminus':'\u2216','setmn':'\u2216','sext':'\u2736','sfr':'\uD835\uDD30','Sfr':'\uD835\uDD16','sfrown':'\u2322','sharp':'\u266F','shchcy':'\u0449','SHCHcy':'\u0429','shcy':'\u0448','SHcy':'\u0428','ShortDownArrow':'\u2193','ShortLeftArrow':'\u2190','shortmid':'\u2223','shortparallel':'\u2225','ShortRightArrow':'\u2192','ShortUpArrow':'\u2191','shy':'\xAD','sigma':'\u03C3','Sigma':'\u03A3','sigmaf':'\u03C2','sigmav':'\u03C2','sim':'\u223C','simdot':'\u2A6A','sime':'\u2243','simeq':'\u2243','simg':'\u2A9E','simgE':'\u2AA0','siml':'\u2A9D','simlE':'\u2A9F','simne':'\u2246','simplus':'\u2A24','simrarr':'\u2972','slarr':'\u2190','SmallCircle':'\u2218','smallsetminus':'\u2216','smashp':'\u2A33','smeparsl':'\u29E4','smid':'\u2223','smile':'\u2323','smt':'\u2AAA','smte':'\u2AAC','smtes':'\u2AAC\uFE00','softcy':'\u044C','SOFTcy':'\u042C','sol':'/','solb':'\u29C4','solbar':'\u233F','sopf':'\uD835\uDD64','Sopf':'\uD835\uDD4A','spades':'\u2660','spadesuit':'\u2660','spar':'\u2225','sqcap':'\u2293','sqcaps':'\u2293\uFE00','sqcup':'\u2294','sqcups':'\u2294\uFE00','Sqrt':'\u221A','sqsub':'\u228F','sqsube':'\u2291','sqsubset':'\u228F','sqsubseteq':'\u2291','sqsup':'\u2290','sqsupe':'\u2292','sqsupset':'\u2290','sqsupseteq':'\u2292','squ':'\u25A1','square':'\u25A1','Square':'\u25A1','SquareIntersection':'\u2293','SquareSubset':'\u228F','SquareSubsetEqual':'\u2291','SquareSuperset':'\u2290','SquareSupersetEqual':'\u2292','SquareUnion':'\u2294','squarf':'\u25AA','squf':'\u25AA','srarr':'\u2192','sscr':'\uD835\uDCC8','Sscr':'\uD835\uDCAE','ssetmn':'\u2216','ssmile':'\u2323','sstarf':'\u22C6','star':'\u2606','Star':'\u22C6','starf':'\u2605','straightepsilon':'\u03F5','straightphi':'\u03D5','strns':'\xAF','sub':'\u2282','Sub':'\u22D0','subdot':'\u2ABD','sube':'\u2286','subE':'\u2AC5','subedot':'\u2AC3','submult':'\u2AC1','subne':'\u228A','subnE':'\u2ACB','subplus':'\u2ABF','subrarr':'\u2979','subset':'\u2282','Subset':'\u22D0','subseteq':'\u2286','subseteqq':'\u2AC5','SubsetEqual':'\u2286','subsetneq':'\u228A','subsetneqq':'\u2ACB','subsim':'\u2AC7','subsub':'\u2AD5','subsup':'\u2AD3','succ':'\u227B','succapprox':'\u2AB8','succcurlyeq':'\u227D','Succeeds':'\u227B','SucceedsEqual':'\u2AB0','SucceedsSlantEqual':'\u227D','SucceedsTilde':'\u227F','succeq':'\u2AB0','succnapprox':'\u2ABA','succneqq':'\u2AB6','succnsim':'\u22E9','succsim':'\u227F','SuchThat':'\u220B','sum':'\u2211','Sum':'\u2211','sung':'\u266A','sup':'\u2283','Sup':'\u22D1','sup1':'\xB9','sup2':'\xB2','sup3':'\xB3','supdot':'\u2ABE','supdsub':'\u2AD8','supe':'\u2287','supE':'\u2AC6','supedot':'\u2AC4','Superset':'\u2283','SupersetEqual':'\u2287','suphsol':'\u27C9','suphsub':'\u2AD7','suplarr':'\u297B','supmult':'\u2AC2','supne':'\u228B','supnE':'\u2ACC','supplus':'\u2AC0','supset':'\u2283','Supset':'\u22D1','supseteq':'\u2287','supseteqq':'\u2AC6','supsetneq':'\u228B','supsetneqq':'\u2ACC','supsim':'\u2AC8','supsub':'\u2AD4','supsup':'\u2AD6','swarhk':'\u2926','swarr':'\u2199','swArr':'\u21D9','swarrow':'\u2199','swnwar':'\u292A','szlig':'\xDF','Tab':'\t','target':'\u2316','tau':'\u03C4','Tau':'\u03A4','tbrk':'\u23B4','tcaron':'\u0165','Tcaron':'\u0164','tcedil':'\u0163','Tcedil':'\u0162','tcy':'\u0442','Tcy':'\u0422','tdot':'\u20DB','telrec':'\u2315','tfr':'\uD835\uDD31','Tfr':'\uD835\uDD17','there4':'\u2234','therefore':'\u2234','Therefore':'\u2234','theta':'\u03B8','Theta':'\u0398','thetasym':'\u03D1','thetav':'\u03D1','thickapprox':'\u2248','thicksim':'\u223C','ThickSpace':'\u205F\u200A','thinsp':'\u2009','ThinSpace':'\u2009','thkap':'\u2248','thksim':'\u223C','thorn':'\xFE','THORN':'\xDE','tilde':'\u02DC','Tilde':'\u223C','TildeEqual':'\u2243','TildeFullEqual':'\u2245','TildeTilde':'\u2248','times':'\xD7','timesb':'\u22A0','timesbar':'\u2A31','timesd':'\u2A30','tint':'\u222D','toea':'\u2928','top':'\u22A4','topbot':'\u2336','topcir':'\u2AF1','topf':'\uD835\uDD65','Topf':'\uD835\uDD4B','topfork':'\u2ADA','tosa':'\u2929','tprime':'\u2034','trade':'\u2122','TRADE':'\u2122','triangle':'\u25B5','triangledown':'\u25BF','triangleleft':'\u25C3','trianglelefteq':'\u22B4','triangleq':'\u225C','triangleright':'\u25B9','trianglerighteq':'\u22B5','tridot':'\u25EC','trie':'\u225C','triminus':'\u2A3A','TripleDot':'\u20DB','triplus':'\u2A39','trisb':'\u29CD','tritime':'\u2A3B','trpezium':'\u23E2','tscr':'\uD835\uDCC9','Tscr':'\uD835\uDCAF','tscy':'\u0446','TScy':'\u0426','tshcy':'\u045B','TSHcy':'\u040B','tstrok':'\u0167','Tstrok':'\u0166','twixt':'\u226C','twoheadleftarrow':'\u219E','twoheadrightarrow':'\u21A0','uacute':'\xFA','Uacute':'\xDA','uarr':'\u2191','uArr':'\u21D1','Uarr':'\u219F','Uarrocir':'\u2949','ubrcy':'\u045E','Ubrcy':'\u040E','ubreve':'\u016D','Ubreve':'\u016C','ucirc':'\xFB','Ucirc':'\xDB','ucy':'\u0443','Ucy':'\u0423','udarr':'\u21C5','udblac':'\u0171','Udblac':'\u0170','udhar':'\u296E','ufisht':'\u297E','ufr':'\uD835\uDD32','Ufr':'\uD835\uDD18','ugrave':'\xF9','Ugrave':'\xD9','uHar':'\u2963','uharl':'\u21BF','uharr':'\u21BE','uhblk':'\u2580','ulcorn':'\u231C','ulcorner':'\u231C','ulcrop':'\u230F','ultri':'\u25F8','umacr':'\u016B','Umacr':'\u016A','uml':'\xA8','UnderBar':'_','UnderBrace':'\u23DF','UnderBracket':'\u23B5','UnderParenthesis':'\u23DD','Union':'\u22C3','UnionPlus':'\u228E','uogon':'\u0173','Uogon':'\u0172','uopf':'\uD835\uDD66','Uopf':'\uD835\uDD4C','uparrow':'\u2191','Uparrow':'\u21D1','UpArrow':'\u2191','UpArrowBar':'\u2912','UpArrowDownArrow':'\u21C5','updownarrow':'\u2195','Updownarrow':'\u21D5','UpDownArrow':'\u2195','UpEquilibrium':'\u296E','upharpoonleft':'\u21BF','upharpoonright':'\u21BE','uplus':'\u228E','UpperLeftArrow':'\u2196','UpperRightArrow':'\u2197','upsi':'\u03C5','Upsi':'\u03D2','upsih':'\u03D2','upsilon':'\u03C5','Upsilon':'\u03A5','UpTee':'\u22A5','UpTeeArrow':'\u21A5','upuparrows':'\u21C8','urcorn':'\u231D','urcorner':'\u231D','urcrop':'\u230E','uring':'\u016F','Uring':'\u016E','urtri':'\u25F9','uscr':'\uD835\uDCCA','Uscr':'\uD835\uDCB0','utdot':'\u22F0','utilde':'\u0169','Utilde':'\u0168','utri':'\u25B5','utrif':'\u25B4','uuarr':'\u21C8','uuml':'\xFC','Uuml':'\xDC','uwangle':'\u29A7','vangrt':'\u299C','varepsilon':'\u03F5','varkappa':'\u03F0','varnothing':'\u2205','varphi':'\u03D5','varpi':'\u03D6','varpropto':'\u221D','varr':'\u2195','vArr':'\u21D5','varrho':'\u03F1','varsigma':'\u03C2','varsubsetneq':'\u228A\uFE00','varsubsetneqq':'\u2ACB\uFE00','varsupsetneq':'\u228B\uFE00','varsupsetneqq':'\u2ACC\uFE00','vartheta':'\u03D1','vartriangleleft':'\u22B2','vartriangleright':'\u22B3','vBar':'\u2AE8','Vbar':'\u2AEB','vBarv':'\u2AE9','vcy':'\u0432','Vcy':'\u0412','vdash':'\u22A2','vDash':'\u22A8','Vdash':'\u22A9','VDash':'\u22AB','Vdashl':'\u2AE6','vee':'\u2228','Vee':'\u22C1','veebar':'\u22BB','veeeq':'\u225A','vellip':'\u22EE','verbar':'|','Verbar':'\u2016','vert':'|','Vert':'\u2016','VerticalBar':'\u2223','VerticalLine':'|','VerticalSeparator':'\u2758','VerticalTilde':'\u2240','VeryThinSpace':'\u200A','vfr':'\uD835\uDD33','Vfr':'\uD835\uDD19','vltri':'\u22B2','vnsub':'\u2282\u20D2','vnsup':'\u2283\u20D2','vopf':'\uD835\uDD67','Vopf':'\uD835\uDD4D','vprop':'\u221D','vrtri':'\u22B3','vscr':'\uD835\uDCCB','Vscr':'\uD835\uDCB1','vsubne':'\u228A\uFE00','vsubnE':'\u2ACB\uFE00','vsupne':'\u228B\uFE00','vsupnE':'\u2ACC\uFE00','Vvdash':'\u22AA','vzigzag':'\u299A','wcirc':'\u0175','Wcirc':'\u0174','wedbar':'\u2A5F','wedge':'\u2227','Wedge':'\u22C0','wedgeq':'\u2259','weierp':'\u2118','wfr':'\uD835\uDD34','Wfr':'\uD835\uDD1A','wopf':'\uD835\uDD68','Wopf':'\uD835\uDD4E','wp':'\u2118','wr':'\u2240','wreath':'\u2240','wscr':'\uD835\uDCCC','Wscr':'\uD835\uDCB2','xcap':'\u22C2','xcirc':'\u25EF','xcup':'\u22C3','xdtri':'\u25BD','xfr':'\uD835\uDD35','Xfr':'\uD835\uDD1B','xharr':'\u27F7','xhArr':'\u27FA','xi':'\u03BE','Xi':'\u039E','xlarr':'\u27F5','xlArr':'\u27F8','xmap':'\u27FC','xnis':'\u22FB','xodot':'\u2A00','xopf':'\uD835\uDD69','Xopf':'\uD835\uDD4F','xoplus':'\u2A01','xotime':'\u2A02','xrarr':'\u27F6','xrArr':'\u27F9','xscr':'\uD835\uDCCD','Xscr':'\uD835\uDCB3','xsqcup':'\u2A06','xuplus':'\u2A04','xutri':'\u25B3','xvee':'\u22C1','xwedge':'\u22C0','yacute':'\xFD','Yacute':'\xDD','yacy':'\u044F','YAcy':'\u042F','ycirc':'\u0177','Ycirc':'\u0176','ycy':'\u044B','Ycy':'\u042B','yen':'\xA5','yfr':'\uD835\uDD36','Yfr':'\uD835\uDD1C','yicy':'\u0457','YIcy':'\u0407','yopf':'\uD835\uDD6A','Yopf':'\uD835\uDD50','yscr':'\uD835\uDCCE','Yscr':'\uD835\uDCB4','yucy':'\u044E','YUcy':'\u042E','yuml':'\xFF','Yuml':'\u0178','zacute':'\u017A','Zacute':'\u0179','zcaron':'\u017E','Zcaron':'\u017D','zcy':'\u0437','Zcy':'\u0417','zdot':'\u017C','Zdot':'\u017B','zeetrf':'\u2128','ZeroWidthSpace':'\u200B','zeta':'\u03B6','Zeta':'\u0396','zfr':'\uD835\uDD37','Zfr':'\u2128','zhcy':'\u0436','ZHcy':'\u0416','zigrarr':'\u21DD','zopf':'\uD835\uDD6B','Zopf':'\u2124','zscr':'\uD835\uDCCF','Zscr':'\uD835\uDCB5','zwj':'\u200D','zwnj':'\u200C'}; |
| var decodeMapLegacy = {'aacute':'\xE1','Aacute':'\xC1','acirc':'\xE2','Acirc':'\xC2','acute':'\xB4','aelig':'\xE6','AElig':'\xC6','agrave':'\xE0','Agrave':'\xC0','amp':'&','AMP':'&','aring':'\xE5','Aring':'\xC5','atilde':'\xE3','Atilde':'\xC3','auml':'\xE4','Auml':'\xC4','brvbar':'\xA6','ccedil':'\xE7','Ccedil':'\xC7','cedil':'\xB8','cent':'\xA2','copy':'\xA9','COPY':'\xA9','curren':'\xA4','deg':'\xB0','divide':'\xF7','eacute':'\xE9','Eacute':'\xC9','ecirc':'\xEA','Ecirc':'\xCA','egrave':'\xE8','Egrave':'\xC8','eth':'\xF0','ETH':'\xD0','euml':'\xEB','Euml':'\xCB','frac12':'\xBD','frac14':'\xBC','frac34':'\xBE','gt':'>','GT':'>','iacute':'\xED','Iacute':'\xCD','icirc':'\xEE','Icirc':'\xCE','iexcl':'\xA1','igrave':'\xEC','Igrave':'\xCC','iquest':'\xBF','iuml':'\xEF','Iuml':'\xCF','laquo':'\xAB','lt':'<','LT':'<','macr':'\xAF','micro':'\xB5','middot':'\xB7','nbsp':'\xA0','not':'\xAC','ntilde':'\xF1','Ntilde':'\xD1','oacute':'\xF3','Oacute':'\xD3','ocirc':'\xF4','Ocirc':'\xD4','ograve':'\xF2','Ograve':'\xD2','ordf':'\xAA','ordm':'\xBA','oslash':'\xF8','Oslash':'\xD8','otilde':'\xF5','Otilde':'\xD5','ouml':'\xF6','Ouml':'\xD6','para':'\xB6','plusmn':'\xB1','pound':'\xA3','quot':'"','QUOT':'"','raquo':'\xBB','reg':'\xAE','REG':'\xAE','sect':'\xA7','shy':'\xAD','sup1':'\xB9','sup2':'\xB2','sup3':'\xB3','szlig':'\xDF','thorn':'\xFE','THORN':'\xDE','times':'\xD7','uacute':'\xFA','Uacute':'\xDA','ucirc':'\xFB','Ucirc':'\xDB','ugrave':'\xF9','Ugrave':'\xD9','uml':'\xA8','uuml':'\xFC','Uuml':'\xDC','yacute':'\xFD','Yacute':'\xDD','yen':'\xA5','yuml':'\xFF'}; |
| var decodeMapNumeric = {'0':'\uFFFD','128':'\u20AC','130':'\u201A','131':'\u0192','132':'\u201E','133':'\u2026','134':'\u2020','135':'\u2021','136':'\u02C6','137':'\u2030','138':'\u0160','139':'\u2039','140':'\u0152','142':'\u017D','145':'\u2018','146':'\u2019','147':'\u201C','148':'\u201D','149':'\u2022','150':'\u2013','151':'\u2014','152':'\u02DC','153':'\u2122','154':'\u0161','155':'\u203A','156':'\u0153','158':'\u017E','159':'\u0178'}; |
| var invalidReferenceCodePoints = [1,2,3,4,5,6,7,8,11,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,64976,64977,64978,64979,64980,64981,64982,64983,64984,64985,64986,64987,64988,64989,64990,64991,64992,64993,64994,64995,64996,64997,64998,64999,65000,65001,65002,65003,65004,65005,65006,65007,65534,65535,131070,131071,196606,196607,262142,262143,327678,327679,393214,393215,458750,458751,524286,524287,589822,589823,655358,655359,720894,720895,786430,786431,851966,851967,917502,917503,983038,983039,1048574,1048575,1114110,1114111]; |
| |
| /*--------------------------------------------------------------------------*/ |
| |
| var stringFromCharCode = String.fromCharCode; |
| |
| var object = {}; |
| var hasOwnProperty = object.hasOwnProperty; |
| var has = function(object, propertyName) { |
| return hasOwnProperty.call(object, propertyName); |
| }; |
| |
| var contains = function(array, value) { |
| var index = -1; |
| var length = array.length; |
| while (++index < length) { |
| if (array[index] == value) { |
| return true; |
| } |
| } |
| return false; |
| }; |
| |
| var merge = function(options, defaults) { |
| if (!options) { |
| return defaults; |
| } |
| var result = {}; |
| var key; |
| for (key in defaults) { |
| // A `hasOwnProperty` check is not needed here, since only recognized |
| // option names are used anyway. Any others are ignored. |
| result[key] = has(options, key) ? options[key] : defaults[key]; |
| } |
| return result; |
| }; |
| |
| // Modified version of `ucs2encode`; see https://mths.be/punycode. |
| var codePointToSymbol = function(codePoint, strict) { |
| var output = ''; |
| if ((codePoint >= 0xD800 && codePoint <= 0xDFFF) || codePoint > 0x10FFFF) { |
| // See issue #4: |
| // “Otherwise, if the number is in the range 0xD800 to 0xDFFF or is |
| // greater than 0x10FFFF, then this is a parse error. Return a U+FFFD |
| // REPLACEMENT CHARACTER.” |
| if (strict) { |
| parseError('character reference outside the permissible Unicode range'); |
| } |
| return '\uFFFD'; |
| } |
| if (has(decodeMapNumeric, codePoint)) { |
| if (strict) { |
| parseError('disallowed character reference'); |
| } |
| return decodeMapNumeric[codePoint]; |
| } |
| if (strict && contains(invalidReferenceCodePoints, codePoint)) { |
| parseError('disallowed character reference'); |
| } |
| if (codePoint > 0xFFFF) { |
| codePoint -= 0x10000; |
| output += stringFromCharCode(codePoint >>> 10 & 0x3FF | 0xD800); |
| codePoint = 0xDC00 | codePoint & 0x3FF; |
| } |
| output += stringFromCharCode(codePoint); |
| return output; |
| }; |
| |
| var hexEscape = function(codePoint) { |
| return '&#x' + codePoint.toString(16).toUpperCase() + ';'; |
| }; |
| |
| var decEscape = function(codePoint) { |
| return '&#' + codePoint + ';'; |
| }; |
| |
| var parseError = function(message) { |
| throw Error('Parse error: ' + message); |
| }; |
| |
| /*--------------------------------------------------------------------------*/ |
| |
| var encode = function(string, options) { |
| options = merge(options, encode.options); |
| var strict = options.strict; |
| if (strict && regexInvalidRawCodePoint.test(string)) { |
| parseError('forbidden code point'); |
| } |
| var encodeEverything = options.encodeEverything; |
| var useNamedReferences = options.useNamedReferences; |
| var allowUnsafeSymbols = options.allowUnsafeSymbols; |
| var escapeCodePoint = options.decimal ? decEscape : hexEscape; |
| |
| var escapeBmpSymbol = function(symbol) { |
| return escapeCodePoint(symbol.charCodeAt(0)); |
| }; |
| |
| if (encodeEverything) { |
| // Encode ASCII symbols. |
| string = string.replace(regexAsciiWhitelist, function(symbol) { |
| // Use named references if requested & possible. |
| if (useNamedReferences && has(encodeMap, symbol)) { |
| return '&' + encodeMap[symbol] + ';'; |
| } |
| return escapeBmpSymbol(symbol); |
| }); |
| // Shorten a few escapes that represent two symbols, of which at least one |
| // is within the ASCII range. |
| if (useNamedReferences) { |
| string = string |
| .replace(/>\u20D2/g, '>⃒') |
| .replace(/<\u20D2/g, '<⃒') |
| .replace(/fj/g, 'fj'); |
| } |
| // Encode non-ASCII symbols. |
| if (useNamedReferences) { |
| // Encode non-ASCII symbols that can be replaced with a named reference. |
| string = string.replace(regexEncodeNonAscii, function(string) { |
| // Note: there is no need to check `has(encodeMap, string)` here. |
| return '&' + encodeMap[string] + ';'; |
| }); |
| } |
| // Note: any remaining non-ASCII symbols are handled outside of the `if`. |
| } else if (useNamedReferences) { |
| // Apply named character references. |
| // Encode `<>"'&` using named character references. |
| if (!allowUnsafeSymbols) { |
| string = string.replace(regexEscape, function(string) { |
| return '&' + encodeMap[string] + ';'; // no need to check `has()` here |
| }); |
| } |
| // Shorten escapes that represent two symbols, of which at least one is |
| // `<>"'&`. |
| string = string |
| .replace(/>\u20D2/g, '>⃒') |
| .replace(/<\u20D2/g, '<⃒'); |
| // Encode non-ASCII symbols that can be replaced with a named reference. |
| string = string.replace(regexEncodeNonAscii, function(string) { |
| // Note: there is no need to check `has(encodeMap, string)` here. |
| return '&' + encodeMap[string] + ';'; |
| }); |
| } else if (!allowUnsafeSymbols) { |
| // Encode `<>"'&` using hexadecimal escapes, now that they’re not handled |
| // using named character references. |
| string = string.replace(regexEscape, escapeBmpSymbol); |
| } |
| return string |
| // Encode astral symbols. |
| .replace(regexAstralSymbols, function($0) { |
| // https://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae |
| var high = $0.charCodeAt(0); |
| var low = $0.charCodeAt(1); |
| var codePoint = (high - 0xD800) * 0x400 + low - 0xDC00 + 0x10000; |
| return escapeCodePoint(codePoint); |
| }) |
| // Encode any remaining BMP symbols that are not printable ASCII symbols |
| // using a hexadecimal escape. |
| .replace(regexBmpWhitelist, escapeBmpSymbol); |
| }; |
| // Expose default options (so they can be overridden globally). |
| encode.options = { |
| 'allowUnsafeSymbols': false, |
| 'encodeEverything': false, |
| 'strict': false, |
| 'useNamedReferences': false, |
| 'decimal' : false |
| }; |
| |
| var decode = function(html, options) { |
| options = merge(options, decode.options); |
| var strict = options.strict; |
| if (strict && regexInvalidEntity.test(html)) { |
| parseError('malformed character reference'); |
| } |
| return html.replace(regexDecode, function($0, $1, $2, $3, $4, $5, $6, $7, $8) { |
| var codePoint; |
| var semicolon; |
| var decDigits; |
| var hexDigits; |
| var reference; |
| var next; |
| |
| if ($1) { |
| reference = $1; |
| // Note: there is no need to check `has(decodeMap, reference)`. |
| return decodeMap[reference]; |
| } |
| |
| if ($2) { |
| // Decode named character references without trailing `;`, e.g. `&`. |
| // This is only a parse error if it gets converted to `&`, or if it is |
| // followed by `=` in an attribute context. |
| reference = $2; |
| next = $3; |
| if (next && options.isAttributeValue) { |
| if (strict && next == '=') { |
| parseError('`&` did not start a character reference'); |
| } |
| return $0; |
| } else { |
| if (strict) { |
| parseError( |
| 'named character reference was not terminated by a semicolon' |
| ); |
| } |
| // Note: there is no need to check `has(decodeMapLegacy, reference)`. |
| return decodeMapLegacy[reference] + (next || ''); |
| } |
| } |
| |
| if ($4) { |
| // Decode decimal escapes, e.g. `𝌆`. |
| decDigits = $4; |
| semicolon = $5; |
| if (strict && !semicolon) { |
| parseError('character reference was not terminated by a semicolon'); |
| } |
| codePoint = parseInt(decDigits, 10); |
| return codePointToSymbol(codePoint, strict); |
| } |
| |
| if ($6) { |
| // Decode hexadecimal escapes, e.g. `𝌆`. |
| hexDigits = $6; |
| semicolon = $7; |
| if (strict && !semicolon) { |
| parseError('character reference was not terminated by a semicolon'); |
| } |
| codePoint = parseInt(hexDigits, 16); |
| return codePointToSymbol(codePoint, strict); |
| } |
| |
| // If we’re still here, `if ($7)` is implied; it’s an ambiguous |
| // ampersand for sure. https://mths.be/notes/ambiguous-ampersands |
| if (strict) { |
| parseError( |
| 'named character reference was not terminated by a semicolon' |
| ); |
| } |
| return $0; |
| }); |
| }; |
| // Expose default options (so they can be overridden globally). |
| decode.options = { |
| 'isAttributeValue': false, |
| 'strict': false |
| }; |
| |
| var escape = function(string) { |
| return string.replace(regexEscape, function($0) { |
| // Note: there is no need to check `has(escapeMap, $0)` here. |
| return escapeMap[$0]; |
| }); |
| }; |
| |
| /*--------------------------------------------------------------------------*/ |
| |
| var he = { |
| 'version': '1.2.0', |
| 'encode': encode, |
| 'decode': decode, |
| 'escape': escape, |
| 'unescape': decode |
| }; |
| |
| // Some AMD build optimizers, like r.js, check for specific condition patterns |
| // like the following: |
| if ( |
| false |
| ) { |
| define(function() { |
| return he; |
| }); |
| } else if (freeExports && !freeExports.nodeType) { |
| if (freeModule) { // in Node.js, io.js, or RingoJS v0.8.0+ |
| freeModule.exports = he; |
| } else { // in Narwhal or RingoJS v0.7.0- |
| for (var key in he) { |
| has(he, key) && (freeExports[key] = he[key]); |
| } |
| } |
| } else { // in Rhino or a web browser |
| root.he = he; |
| } |
| |
| }(this)); |
| |
| }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{}],55:[function(require,module,exports){ |
| exports.read = function (buffer, offset, isLE, mLen, nBytes) { |
| var e, m |
| var eLen = (nBytes * 8) - mLen - 1 |
| var eMax = (1 << eLen) - 1 |
| var eBias = eMax >> 1 |
| var nBits = -7 |
| var i = isLE ? (nBytes - 1) : 0 |
| var d = isLE ? -1 : 1 |
| var s = buffer[offset + i] |
| |
| i += d |
| |
| e = s & ((1 << (-nBits)) - 1) |
| s >>= (-nBits) |
| nBits += eLen |
| for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {} |
| |
| m = e & ((1 << (-nBits)) - 1) |
| e >>= (-nBits) |
| nBits += mLen |
| for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {} |
| |
| if (e === 0) { |
| e = 1 - eBias |
| } else if (e === eMax) { |
| return m ? NaN : ((s ? -1 : 1) * Infinity) |
| } else { |
| m = m + Math.pow(2, mLen) |
| e = e - eBias |
| } |
| return (s ? -1 : 1) * m * Math.pow(2, e - mLen) |
| } |
| |
| exports.write = function (buffer, value, offset, isLE, mLen, nBytes) { |
| var e, m, c |
| var eLen = (nBytes * 8) - mLen - 1 |
| var eMax = (1 << eLen) - 1 |
| var eBias = eMax >> 1 |
| var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0) |
| var i = isLE ? 0 : (nBytes - 1) |
| var d = isLE ? 1 : -1 |
| var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0 |
| |
| value = Math.abs(value) |
| |
| if (isNaN(value) || value === Infinity) { |
| m = isNaN(value) ? 1 : 0 |
| e = eMax |
| } else { |
| e = Math.floor(Math.log(value) / Math.LN2) |
| if (value * (c = Math.pow(2, -e)) < 1) { |
| e-- |
| c *= 2 |
| } |
| if (e + eBias >= 1) { |
| value += rt / c |
| } else { |
| value += rt * Math.pow(2, 1 - eBias) |
| } |
| if (value * c >= 2) { |
| e++ |
| c /= 2 |
| } |
| |
| if (e + eBias >= eMax) { |
| m = 0 |
| e = eMax |
| } else if (e + eBias >= 1) { |
| m = ((value * c) - 1) * Math.pow(2, mLen) |
| e = e + eBias |
| } else { |
| m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen) |
| e = 0 |
| } |
| } |
| |
| for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {} |
| |
| e = (e << mLen) | m |
| eLen += mLen |
| for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {} |
| |
| buffer[offset + i - d] |= s * 128 |
| } |
| |
| },{}],56:[function(require,module,exports){ |
| if (typeof Object.create === 'function') { |
| // implementation from standard node.js 'util' module |
| module.exports = function inherits(ctor, superCtor) { |
| ctor.super_ = superCtor |
| ctor.prototype = Object.create(superCtor.prototype, { |
| constructor: { |
| value: ctor, |
| enumerable: false, |
| writable: true, |
| configurable: true |
| } |
| }); |
| }; |
| } else { |
| // old school shim for old browsers |
| module.exports = function inherits(ctor, superCtor) { |
| ctor.super_ = superCtor |
| var TempCtor = function () {} |
| TempCtor.prototype = superCtor.prototype |
| ctor.prototype = new TempCtor() |
| ctor.prototype.constructor = ctor |
| } |
| } |
| |
| },{}],57:[function(require,module,exports){ |
| /*! |
| * Determine if an object is a Buffer |
| * |
| * @author Feross Aboukhadijeh <https://feross.org> |
| * @license MIT |
| */ |
| |
| // The _isBuffer check is for Safari 5-7 support, because it's missing |
| // Object.prototype.constructor. Remove this eventually |
| module.exports = function (obj) { |
| return obj != null && (isBuffer(obj) || isSlowBuffer(obj) || !!obj._isBuffer) |
| } |
| |
| function isBuffer (obj) { |
| return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj) |
| } |
| |
| // For Node v0.10 support. Remove this eventually. |
| function isSlowBuffer (obj) { |
| return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isBuffer(obj.slice(0, 0)) |
| } |
| |
| },{}],58:[function(require,module,exports){ |
| var toString = {}.toString; |
| |
| module.exports = Array.isArray || function (arr) { |
| return toString.call(arr) == '[object Array]'; |
| }; |
| |
| },{}],59:[function(require,module,exports){ |
| (function (process){ |
| var path = require('path'); |
| var fs = require('fs'); |
| var _0777 = parseInt('0777', 8); |
| |
| module.exports = mkdirP.mkdirp = mkdirP.mkdirP = mkdirP; |
| |
| function mkdirP (p, opts, f, made) { |
| if (typeof opts === 'function') { |
| f = opts; |
| opts = {}; |
| } |
| else if (!opts || typeof opts !== 'object') { |
| opts = { mode: opts }; |
| } |
| |
| var mode = opts.mode; |
| var xfs = opts.fs || fs; |
| |
| if (mode === undefined) { |
| mode = _0777 & (~process.umask()); |
| } |
| if (!made) made = null; |
| |
| var cb = f || function () {}; |
| p = path.resolve(p); |
| |
| xfs.mkdir(p, mode, function (er) { |
| if (!er) { |
| made = made || p; |
| return cb(null, made); |
| } |
| switch (er.code) { |
| case 'ENOENT': |
| mkdirP(path.dirname(p), opts, function (er, made) { |
| if (er) cb(er, made); |
| else mkdirP(p, opts, cb, made); |
| }); |
| break; |
| |
| // In the case of any other error, just see if there's a dir |
| // there already. If so, then hooray! If not, then something |
| // is borked. |
| default: |
| xfs.stat(p, function (er2, stat) { |
| // if the stat fails, then that's super weird. |
| // let the original error be the failure reason. |
| if (er2 || !stat.isDirectory()) cb(er, made) |
| else cb(null, made); |
| }); |
| break; |
| } |
| }); |
| } |
| |
| mkdirP.sync = function sync (p, opts, made) { |
| if (!opts || typeof opts !== 'object') { |
| opts = { mode: opts }; |
| } |
| |
| var mode = opts.mode; |
| var xfs = opts.fs || fs; |
| |
| if (mode === undefined) { |
| mode = _0777 & (~process.umask()); |
| } |
| if (!made) made = null; |
| |
| p = path.resolve(p); |
| |
| try { |
| xfs.mkdirSync(p, mode); |
| made = made || p; |
| } |
| catch (err0) { |
| switch (err0.code) { |
| case 'ENOENT' : |
| made = sync(path.dirname(p), opts, made); |
| sync(p, opts, made); |
| break; |
| |
| // In the case of any other error, just see if there's a dir |
| // there already. If so, then hooray! If not, then something |
| // is borked. |
| default: |
| var stat; |
| try { |
| stat = xfs.statSync(p); |
| } |
| catch (err1) { |
| throw err0; |
| } |
| if (!stat.isDirectory()) throw err0; |
| break; |
| } |
| } |
| |
| return made; |
| }; |
| |
| }).call(this,require('_process')) |
| },{"_process":69,"fs":42,"path":42}],60:[function(require,module,exports){ |
| /** |
| * Helpers. |
| */ |
| |
| var s = 1000; |
| var m = s * 60; |
| var h = m * 60; |
| var d = h * 24; |
| var w = d * 7; |
| var y = d * 365.25; |
| |
| /** |
| * Parse or format the given `val`. |
| * |
| * Options: |
| * |
| * - `long` verbose formatting [false] |
| * |
| * @param {String|Number} val |
| * @param {Object} [options] |
| * @throws {Error} throw an error if val is not a non-empty string or a number |
| * @return {String|Number} |
| * @api public |
| */ |
| |
| module.exports = function(val, options) { |
| options = options || {}; |
| var type = typeof val; |
| if (type === 'string' && val.length > 0) { |
| return parse(val); |
| } else if (type === 'number' && isNaN(val) === false) { |
| return options.long ? fmtLong(val) : fmtShort(val); |
| } |
| throw new Error( |
| 'val is not a non-empty string or a valid number. val=' + |
| JSON.stringify(val) |
| ); |
| }; |
| |
| /** |
| * Parse the given `str` and return milliseconds. |
| * |
| * @param {String} str |
| * @return {Number} |
| * @api private |
| */ |
| |
| function parse(str) { |
| str = String(str); |
| if (str.length > 100) { |
| return; |
| } |
| var match = /^((?:\d+)?\-?\d?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec( |
| str |
| ); |
| if (!match) { |
| return; |
| } |
| var n = parseFloat(match[1]); |
| var type = (match[2] || 'ms').toLowerCase(); |
| switch (type) { |
| case 'years': |
| case 'year': |
| case 'yrs': |
| case 'yr': |
| case 'y': |
| return n * y; |
| case 'weeks': |
| case 'week': |
| case 'w': |
| return n * w; |
| case 'days': |
| case 'day': |
| case 'd': |
| return n * d; |
| case 'hours': |
| case 'hour': |
| case 'hrs': |
| case 'hr': |
| case 'h': |
| return n * h; |
| case 'minutes': |
| case 'minute': |
| case 'mins': |
| case 'min': |
| case 'm': |
| return n * m; |
| case 'seconds': |
| case 'second': |
| case 'secs': |
| case 'sec': |
| case 's': |
| return n * s; |
| case 'milliseconds': |
| case 'millisecond': |
| case 'msecs': |
| case 'msec': |
| case 'ms': |
| return n; |
| default: |
| return undefined; |
| } |
| } |
| |
| /** |
| * Short format for `ms`. |
| * |
| * @param {Number} ms |
| * @return {String} |
| * @api private |
| */ |
| |
| function fmtShort(ms) { |
| var msAbs = Math.abs(ms); |
| if (msAbs >= d) { |
| return Math.round(ms / d) + 'd'; |
| } |
| if (msAbs >= h) { |
| return Math.round(ms / h) + 'h'; |
| } |
| if (msAbs >= m) { |
| return Math.round(ms / m) + 'm'; |
| } |
| if (msAbs >= s) { |
| return Math.round(ms / s) + 's'; |
| } |
| return ms + 'ms'; |
| } |
| |
| /** |
| * Long format for `ms`. |
| * |
| * @param {Number} ms |
| * @return {String} |
| * @api private |
| */ |
| |
| function fmtLong(ms) { |
| var msAbs = Math.abs(ms); |
| if (msAbs >= d) { |
| return plural(ms, msAbs, d, 'day'); |
| } |
| if (msAbs >= h) { |
| return plural(ms, msAbs, h, 'hour'); |
| } |
| if (msAbs >= m) { |
| return plural(ms, msAbs, m, 'minute'); |
| } |
| if (msAbs >= s) { |
| return plural(ms, msAbs, s, 'second'); |
| } |
| return ms + ' ms'; |
| } |
| |
| /** |
| * Pluralization helper. |
| */ |
| |
| function plural(ms, msAbs, n, name) { |
| var isPlural = msAbs >= n * 1.5; |
| return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : ''); |
| } |
| |
| },{}],61:[function(require,module,exports){ |
| 'use strict'; |
| |
| var keysShim; |
| if (!Object.keys) { |
| // modified from https://github.com/es-shims/es5-shim |
| var has = Object.prototype.hasOwnProperty; |
| var toStr = Object.prototype.toString; |
| var isArgs = require('./isArguments'); // eslint-disable-line global-require |
| var isEnumerable = Object.prototype.propertyIsEnumerable; |
| var hasDontEnumBug = !isEnumerable.call({ toString: null }, 'toString'); |
| var hasProtoEnumBug = isEnumerable.call(function () {}, 'prototype'); |
| var dontEnums = [ |
| 'toString', |
| 'toLocaleString', |
| 'valueOf', |
| 'hasOwnProperty', |
| 'isPrototypeOf', |
| 'propertyIsEnumerable', |
| 'constructor' |
| ]; |
| var equalsConstructorPrototype = function (o) { |
| var ctor = o.constructor; |
| return ctor && ctor.prototype === o; |
| }; |
| var excludedKeys = { |
| $applicationCache: true, |
| $console: true, |
| $external: true, |
| $frame: true, |
| $frameElement: true, |
| $frames: true, |
| $innerHeight: true, |
| $innerWidth: true, |
| $outerHeight: true, |
| $outerWidth: true, |
| $pageXOffset: true, |
| $pageYOffset: true, |
| $parent: true, |
| $scrollLeft: true, |
| $scrollTop: true, |
| $scrollX: true, |
| $scrollY: true, |
| $self: true, |
| $webkitIndexedDB: true, |
| $webkitStorageInfo: true, |
| $window: true |
| }; |
| var hasAutomationEqualityBug = (function () { |
| /* global window */ |
| if (typeof window === 'undefined') { return false; } |
| for (var k in window) { |
| try { |
| if (!excludedKeys['$' + k] && has.call(window, k) && window[k] !== null && typeof window[k] === 'object') { |
| try { |
| equalsConstructorPrototype(window[k]); |
| } catch (e) { |
| return true; |
| } |
| } |
| } catch (e) { |
| return true; |
| } |
| } |
| return false; |
| }()); |
| var equalsConstructorPrototypeIfNotBuggy = function (o) { |
| /* global window */ |
| if (typeof window === 'undefined' || !hasAutomationEqualityBug) { |
| return equalsConstructorPrototype(o); |
| } |
| try { |
| return equalsConstructorPrototype(o); |
| } catch (e) { |
| return false; |
| } |
| }; |
| |
| keysShim = function keys(object) { |
| var isObject = object !== null && typeof object === 'object'; |
| var isFunction = toStr.call(object) === '[object Function]'; |
| var isArguments = isArgs(object); |
| var isString = isObject && toStr.call(object) === '[object String]'; |
| var theKeys = []; |
| |
| if (!isObject && !isFunction && !isArguments) { |
| throw new TypeError('Object.keys called on a non-object'); |
| } |
| |
| var skipProto = hasProtoEnumBug && isFunction; |
| if (isString && object.length > 0 && !has.call(object, 0)) { |
| for (var i = 0; i < object.length; ++i) { |
| theKeys.push(String(i)); |
| } |
| } |
| |
| if (isArguments && object.length > 0) { |
| for (var j = 0; j < object.length; ++j) { |
| theKeys.push(String(j)); |
| } |
| } else { |
| for (var name in object) { |
| if (!(skipProto && name === 'prototype') && has.call(object, name)) { |
| theKeys.push(String(name)); |
| } |
| } |
| } |
| |
| if (hasDontEnumBug) { |
| var skipConstructor = equalsConstructorPrototypeIfNotBuggy(object); |
| |
| for (var k = 0; k < dontEnums.length; ++k) { |
| if (!(skipConstructor && dontEnums[k] === 'constructor') && has.call(object, dontEnums[k])) { |
| theKeys.push(dontEnums[k]); |
| } |
| } |
| } |
| return theKeys; |
| }; |
| } |
| module.exports = keysShim; |
| |
| },{"./isArguments":63}],62:[function(require,module,exports){ |
| 'use strict'; |
| |
| var slice = Array.prototype.slice; |
| var isArgs = require('./isArguments'); |
| |
| var origKeys = Object.keys; |
| var keysShim = origKeys ? function keys(o) { return origKeys(o); } : require('./implementation'); |
| |
| var originalKeys = Object.keys; |
| |
| keysShim.shim = function shimObjectKeys() { |
| if (Object.keys) { |
| var keysWorksWithArguments = (function () { |
| // Safari 5.0 bug |
| var args = Object.keys(arguments); |
| return args && args.length === arguments.length; |
| }(1, 2)); |
| if (!keysWorksWithArguments) { |
| Object.keys = function keys(object) { // eslint-disable-line func-name-matching |
| if (isArgs(object)) { |
| return originalKeys(slice.call(object)); |
| } |
| return originalKeys(object); |
| }; |
| } |
| } else { |
| Object.keys = keysShim; |
| } |
| return Object.keys || keysShim; |
| }; |
| |
| module.exports = keysShim; |
| |
| },{"./implementation":61,"./isArguments":63}],63:[function(require,module,exports){ |
| 'use strict'; |
| |
| var toStr = Object.prototype.toString; |
| |
| module.exports = function isArguments(value) { |
| var str = toStr.call(value); |
| var isArgs = str === '[object Arguments]'; |
| if (!isArgs) { |
| isArgs = str !== '[object Array]' && |
| value !== null && |
| typeof value === 'object' && |
| typeof value.length === 'number' && |
| value.length >= 0 && |
| toStr.call(value.callee) === '[object Function]'; |
| } |
| return isArgs; |
| }; |
| |
| },{}],64:[function(require,module,exports){ |
| 'use strict'; |
| |
| // modified from https://github.com/es-shims/es6-shim |
| var keys = require('object-keys'); |
| var bind = require('function-bind'); |
| var canBeObject = function (obj) { |
| return typeof obj !== 'undefined' && obj !== null; |
| }; |
| var hasSymbols = require('has-symbols/shams')(); |
| var toObject = Object; |
| var push = bind.call(Function.call, Array.prototype.push); |
| var propIsEnumerable = bind.call(Function.call, Object.prototype.propertyIsEnumerable); |
| var originalGetSymbols = hasSymbols ? Object.getOwnPropertySymbols : null; |
| |
| module.exports = function assign(target, source1) { |
| if (!canBeObject(target)) { throw new TypeError('target must be an object'); } |
| var objTarget = toObject(target); |
| var s, source, i, props, syms, value, key; |
| for (s = 1; s < arguments.length; ++s) { |
| source = toObject(arguments[s]); |
| props = keys(source); |
| var getSymbols = hasSymbols && (Object.getOwnPropertySymbols || originalGetSymbols); |
| if (getSymbols) { |
| syms = getSymbols(source); |
| for (i = 0; i < syms.length; ++i) { |
| key = syms[i]; |
| if (propIsEnumerable(source, key)) { |
| push(props, key); |
| } |
| } |
| } |
| for (i = 0; i < props.length; ++i) { |
| key = props[i]; |
| value = source[key]; |
| if (propIsEnumerable(source, key)) { |
| objTarget[key] = value; |
| } |
| } |
| } |
| return objTarget; |
| }; |
| |
| },{"function-bind":52,"has-symbols/shams":53,"object-keys":62}],65:[function(require,module,exports){ |
| 'use strict'; |
| |
| var defineProperties = require('define-properties'); |
| |
| var implementation = require('./implementation'); |
| var getPolyfill = require('./polyfill'); |
| var shim = require('./shim'); |
| |
| var polyfill = getPolyfill(); |
| |
| defineProperties(polyfill, { |
| getPolyfill: getPolyfill, |
| implementation: implementation, |
| shim: shim |
| }); |
| |
| module.exports = polyfill; |
| |
| },{"./implementation":64,"./polyfill":66,"./shim":67,"define-properties":47}],66:[function(require,module,exports){ |
| 'use strict'; |
| |
| var implementation = require('./implementation'); |
| |
| var lacksProperEnumerationOrder = function () { |
| if (!Object.assign) { |
| return false; |
| } |
| // v8, specifically in node 4.x, has a bug with incorrect property enumeration order |
| // note: this does not detect the bug unless there's 20 characters |
| var str = 'abcdefghijklmnopqrst'; |
| var letters = str.split(''); |
| var map = {}; |
| for (var i = 0; i < letters.length; ++i) { |
| map[letters[i]] = letters[i]; |
| } |
| var obj = Object.assign({}, map); |
| var actual = ''; |
| for (var k in obj) { |
| actual += k; |
| } |
| return str !== actual; |
| }; |
| |
| var assignHasPendingExceptions = function () { |
| if (!Object.assign || !Object.preventExtensions) { |
| return false; |
| } |
| // Firefox 37 still has "pending exception" logic in its Object.assign implementation, |
| // which is 72% slower than our shim, and Firefox 40's native implementation. |
| var thrower = Object.preventExtensions({ 1: 2 }); |
| try { |
| Object.assign(thrower, 'xy'); |
| } catch (e) { |
| return thrower[1] === 'y'; |
| } |
| return false; |
| }; |
| |
| module.exports = function getPolyfill() { |
| if (!Object.assign) { |
| return implementation; |
| } |
| if (lacksProperEnumerationOrder()) { |
| return implementation; |
| } |
| if (assignHasPendingExceptions()) { |
| return implementation; |
| } |
| return Object.assign; |
| }; |
| |
| },{"./implementation":64}],67:[function(require,module,exports){ |
| 'use strict'; |
| |
| var define = require('define-properties'); |
| var getPolyfill = require('./polyfill'); |
| |
| module.exports = function shimAssign() { |
| var polyfill = getPolyfill(); |
| define( |
| Object, |
| { assign: polyfill }, |
| { assign: function () { return Object.assign !== polyfill; } } |
| ); |
| return polyfill; |
| }; |
| |
| },{"./polyfill":66,"define-properties":47}],68:[function(require,module,exports){ |
| (function (process){ |
| 'use strict'; |
| |
| if (!process.version || |
| process.version.indexOf('v0.') === 0 || |
| process.version.indexOf('v1.') === 0 && process.version.indexOf('v1.8.') !== 0) { |
| module.exports = { nextTick: nextTick }; |
| } else { |
| module.exports = process |
| } |
| |
| function nextTick(fn, arg1, arg2, arg3) { |
| if (typeof fn !== 'function') { |
| throw new TypeError('"callback" argument must be a function'); |
| } |
| var len = arguments.length; |
| var args, i; |
| switch (len) { |
| case 0: |
| case 1: |
| return process.nextTick(fn); |
| case 2: |
| return process.nextTick(function afterTickOne() { |
| fn.call(null, arg1); |
| }); |
| case 3: |
| return process.nextTick(function afterTickTwo() { |
| fn.call(null, arg1, arg2); |
| }); |
| case 4: |
| return process.nextTick(function afterTickThree() { |
| fn.call(null, arg1, arg2, arg3); |
| }); |
| default: |
| args = new Array(len - 1); |
| i = 0; |
| while (i < args.length) { |
| args[i++] = arguments[i]; |
| } |
| return process.nextTick(function afterTick() { |
| fn.apply(null, args); |
| }); |
| } |
| } |
| |
| |
| }).call(this,require('_process')) |
| },{"_process":69}],69:[function(require,module,exports){ |
| // shim for using process in browser |
| var process = module.exports = {}; |
| |
| // cached from whatever global is present so that test runners that stub it |
| // don't break things. But we need to wrap it in a try catch in case it is |
| // wrapped in strict mode code which doesn't define any globals. It's inside a |
| // function because try/catches deoptimize in certain engines. |
| |
| var cachedSetTimeout; |
| var cachedClearTimeout; |
| |
| function defaultSetTimout() { |
| throw new Error('setTimeout has not been defined'); |
| } |
| function defaultClearTimeout () { |
| throw new Error('clearTimeout has not been defined'); |
| } |
| (function () { |
| try { |
| if (typeof setTimeout === 'function') { |
| cachedSetTimeout = setTimeout; |
| } else { |
| cachedSetTimeout = defaultSetTimout; |
| } |
| } catch (e) { |
| cachedSetTimeout = defaultSetTimout; |
| } |
| try { |
| if (typeof clearTimeout === 'function') { |
| cachedClearTimeout = clearTimeout; |
| } else { |
| cachedClearTimeout = defaultClearTimeout; |
| } |
| } catch (e) { |
| cachedClearTimeout = defaultClearTimeout; |
| } |
| } ()) |
| function runTimeout(fun) { |
| if (cachedSetTimeout === setTimeout) { |
| //normal enviroments in sane situations |
| return setTimeout(fun, 0); |
| } |
| // if setTimeout wasn't available but was latter defined |
| if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) { |
| cachedSetTimeout = setTimeout; |
| return setTimeout(fun, 0); |
| } |
| try { |
| // when when somebody has screwed with setTimeout but no I.E. maddness |
| return cachedSetTimeout(fun, 0); |
| } catch(e){ |
| try { |
| // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally |
| return cachedSetTimeout.call(null, fun, 0); |
| } catch(e){ |
| // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error |
| return cachedSetTimeout.call(this, fun, 0); |
| } |
| } |
| |
| |
| } |
| function runClearTimeout(marker) { |
| if (cachedClearTimeout === clearTimeout) { |
| //normal enviroments in sane situations |
| return clearTimeout(marker); |
| } |
| // if clearTimeout wasn't available but was latter defined |
| if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) { |
| cachedClearTimeout = clearTimeout; |
| return clearTimeout(marker); |
| } |
| try { |
| // when when somebody has screwed with setTimeout but no I.E. maddness |
| return cachedClearTimeout(marker); |
| } catch (e){ |
| try { |
| // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally |
| return cachedClearTimeout.call(null, marker); |
| } catch (e){ |
| // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error. |
| // Some versions of I.E. have different rules for clearTimeout vs setTimeout |
| return cachedClearTimeout.call(this, marker); |
| } |
| } |
| |
| |
| |
| } |
| var queue = []; |
| var draining = false; |
| var currentQueue; |
| var queueIndex = -1; |
| |
| function cleanUpNextTick() { |
| if (!draining || !currentQueue) { |
| return; |
| } |
| draining = false; |
| if (currentQueue.length) { |
| queue = currentQueue.concat(queue); |
| } else { |
| queueIndex = -1; |
| } |
| if (queue.length) { |
| drainQueue(); |
| } |
| } |
| |
| function drainQueue() { |
| if (draining) { |
| return; |
| } |
| var timeout = runTimeout(cleanUpNextTick); |
| draining = true; |
| |
| var len = queue.length; |
| while(len) { |
| currentQueue = queue; |
| queue = []; |
| while (++queueIndex < len) { |
| if (currentQueue) { |
| currentQueue[queueIndex].run(); |
| } |
| } |
| queueIndex = -1; |
| len = queue.length; |
| } |
| currentQueue = null; |
| draining = false; |
| runClearTimeout(timeout); |
| } |
| |
| process.nextTick = function (fun) { |
| var args = new Array(arguments.length - 1); |
| if (arguments.length > 1) { |
| for (var i = 1; i < arguments.length; i++) { |
| args[i - 1] = arguments[i]; |
| } |
| } |
| queue.push(new Item(fun, args)); |
| if (queue.length === 1 && !draining) { |
| runTimeout(drainQueue); |
| } |
| }; |
| |
| // v8 likes predictible objects |
| function Item(fun, array) { |
| this.fun = fun; |
| this.array = array; |
| } |
| Item.prototype.run = function () { |
| this.fun.apply(null, this.array); |
| }; |
| process.title = 'browser'; |
| process.browser = true; |
| process.env = {}; |
| process.argv = []; |
| process.version = ''; // empty string to avoid regexp issues |
| process.versions = {}; |
| |
| function noop() {} |
| |
| process.on = noop; |
| process.addListener = noop; |
| process.once = noop; |
| process.off = noop; |
| process.removeListener = noop; |
| process.removeAllListeners = noop; |
| process.emit = noop; |
| process.prependListener = noop; |
| process.prependOnceListener = noop; |
| |
| process.listeners = function (name) { return [] } |
| |
| process.binding = function (name) { |
| throw new Error('process.binding is not supported'); |
| }; |
| |
| process.cwd = function () { return '/' }; |
| process.chdir = function (dir) { |
| throw new Error('process.chdir is not supported'); |
| }; |
| process.umask = function() { return 0; }; |
| |
| },{}],70:[function(require,module,exports){ |
| module.exports = require('./lib/_stream_duplex.js'); |
| |
| },{"./lib/_stream_duplex.js":71}],71:[function(require,module,exports){ |
| // Copyright Joyent, Inc. and other Node contributors. |
| // |
| // Permission is hereby granted, free of charge, to any person obtaining a |
| // copy of this software and associated documentation files (the |
| // "Software"), to deal in the Software without restriction, including |
| // without limitation the rights to use, copy, modify, merge, publish, |
| // distribute, sublicense, and/or sell copies of the Software, and to permit |
| // persons to whom the Software is furnished to do so, subject to the |
| // following conditions: |
| // |
| // The above copyright notice and this permission notice shall be included |
| // in all copies or substantial portions of the Software. |
| // |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN |
| // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
| // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
| // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE |
| // USE OR OTHER DEALINGS IN THE SOFTWARE. |
| |
| // a duplex stream is just a stream that is both readable and writable. |
| // Since JS doesn't have multiple prototypal inheritance, this class |
| // prototypally inherits from Readable, and then parasitically from |
| // Writable. |
| |
| 'use strict'; |
| |
| /*<replacement>*/ |
| |
| var pna = require('process-nextick-args'); |
| /*</replacement>*/ |
| |
| /*<replacement>*/ |
| var objectKeys = Object.keys || function (obj) { |
| var keys = []; |
| for (var key in obj) { |
| keys.push(key); |
| }return keys; |
| }; |
| /*</replacement>*/ |
| |
| module.exports = Duplex; |
| |
| /*<replacement>*/ |
| var util = require('core-util-is'); |
| util.inherits = require('inherits'); |
| /*</replacement>*/ |
| |
| var Readable = require('./_stream_readable'); |
| var Writable = require('./_stream_writable'); |
| |
| util.inherits(Duplex, Readable); |
| |
| { |
| // avoid scope creep, the keys array can then be collected |
| var keys = objectKeys(Writable.prototype); |
| for (var v = 0; v < keys.length; v++) { |
| var method = keys[v]; |
| if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method]; |
| } |
| } |
| |
| function Duplex(options) { |
| if (!(this instanceof Duplex)) return new Duplex(options); |
| |
| Readable.call(this, options); |
| Writable.call(this, options); |
| |
| if (options && options.readable === false) this.readable = false; |
| |
| if (options && options.writable === false) this.writable = false; |
| |
| this.allowHalfOpen = true; |
| if (options && options.allowHalfOpen === false) this.allowHalfOpen = false; |
| |
| this.once('end', onend); |
| } |
| |
| Object.defineProperty(Duplex.prototype, 'writableHighWaterMark', { |
| // making it explicit this property is not enumerable |
| // because otherwise some prototype manipulation in |
| // userland will fail |
| enumerable: false, |
| get: function () { |
| return this._writableState.highWaterMark; |
| } |
| }); |
| |
| // the no-half-open enforcer |
| function onend() { |
| // if we allow half-open state, or if the writable side ended, |
| // then we're ok. |
| if (this.allowHalfOpen || this._writableState.ended) return; |
| |
| // no more data can be written. |
| // But allow more writes to happen in this tick. |
| pna.nextTick(onEndNT, this); |
| } |
| |
| function onEndNT(self) { |
| self.end(); |
| } |
| |
| Object.defineProperty(Duplex.prototype, 'destroyed', { |
| get: function () { |
| if (this._readableState === undefined || this._writableState === undefined) { |
| return false; |
| } |
| return this._readableState.destroyed && this._writableState.destroyed; |
| }, |
| set: function (value) { |
| // we ignore the value if the stream |
| // has not been initialized yet |
| if (this._readableState === undefined || this._writableState === undefined) { |
| return; |
| } |
| |
| // backward compatibility, the user is explicitly |
| // managing destroyed |
| this._readableState.destroyed = value; |
| this._writableState.destroyed = value; |
| } |
| }); |
| |
| Duplex.prototype._destroy = function (err, cb) { |
| this.push(null); |
| this.end(); |
| |
| pna.nextTick(cb, err); |
| }; |
| },{"./_stream_readable":73,"./_stream_writable":75,"core-util-is":44,"inherits":56,"process-nextick-args":68}],72:[function(require,module,exports){ |
| // Copyright Joyent, Inc. and other Node contributors. |
| // |
| // Permission is hereby granted, free of charge, to any person obtaining a |
| // copy of this software and associated documentation files (the |
| // "Software"), to deal in the Software without restriction, including |
| // without limitation the rights to use, copy, modify, merge, publish, |
| // distribute, sublicense, and/or sell copies of the Software, and to permit |
| // persons to whom the Software is furnished to do so, subject to the |
| // following conditions: |
| // |
| // The above copyright notice and this permission notice shall be included |
| // in all copies or substantial portions of the Software. |
| // |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN |
| // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
| // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
| // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE |
| // USE OR OTHER DEALINGS IN THE SOFTWARE. |
| |
| // a passthrough stream. |
| // basically just the most minimal sort of Transform stream. |
| // Every written chunk gets output as-is. |
| |
| 'use strict'; |
| |
| module.exports = PassThrough; |
| |
| var Transform = require('./_stream_transform'); |
| |
| /*<replacement>*/ |
| var util = require('core-util-is'); |
| util.inherits = require('inherits'); |
| /*</replacement>*/ |
| |
| util.inherits(PassThrough, Transform); |
| |
| function PassThrough(options) { |
| if (!(this instanceof PassThrough)) return new PassThrough(options); |
| |
| Transform.call(this, options); |
| } |
| |
| PassThrough.prototype._transform = function (chunk, encoding, cb) { |
| cb(null, chunk); |
| }; |
| },{"./_stream_transform":74,"core-util-is":44,"inherits":56}],73:[function(require,module,exports){ |
| (function (process,global){ |
| // Copyright Joyent, Inc. and other Node contributors. |
| // |
| // Permission is hereby granted, free of charge, to any person obtaining a |
| // copy of this software and associated documentation files (the |
| // "Software"), to deal in the Software without restriction, including |
| // without limitation the rights to use, copy, modify, merge, publish, |
| // distribute, sublicense, and/or sell copies of the Software, and to permit |
| // persons to whom the Software is furnished to do so, subject to the |
| // following conditions: |
| // |
| // The above copyright notice and this permission notice shall be included |
| // in all copies or substantial portions of the Software. |
| // |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN |
| // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
| // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
| // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE |
| // USE OR OTHER DEALINGS IN THE SOFTWARE. |
| |
| 'use strict'; |
| |
| /*<replacement>*/ |
| |
| var pna = require('process-nextick-args'); |
| /*</replacement>*/ |
| |
| module.exports = Readable; |
| |
| /*<replacement>*/ |
| var isArray = require('isarray'); |
| /*</replacement>*/ |
| |
| /*<replacement>*/ |
| var Duplex; |
| /*</replacement>*/ |
| |
| Readable.ReadableState = ReadableState; |
| |
| /*<replacement>*/ |
| var EE = require('events').EventEmitter; |
| |
| var EElistenerCount = function (emitter, type) { |
| return emitter.listeners(type).length; |
| }; |
| /*</replacement>*/ |
| |
| /*<replacement>*/ |
| var Stream = require('./internal/streams/stream'); |
| /*</replacement>*/ |
| |
| /*<replacement>*/ |
| |
| var Buffer = require('safe-buffer').Buffer; |
| var OurUint8Array = global.Uint8Array || function () {}; |
| function _uint8ArrayToBuffer(chunk) { |
| return Buffer.from(chunk); |
| } |
| function _isUint8Array(obj) { |
| return Buffer.isBuffer(obj) || obj instanceof OurUint8Array; |
| } |
| |
| /*</replacement>*/ |
| |
| /*<replacement>*/ |
| var util = require('core-util-is'); |
| util.inherits = require('inherits'); |
| /*</replacement>*/ |
| |
| /*<replacement>*/ |
| var debugUtil = require('util'); |
| var debug = void 0; |
| if (debugUtil && debugUtil.debuglog) { |
| debug = debugUtil.debuglog('stream'); |
| } else { |
| debug = function () {}; |
| } |
| /*</replacement>*/ |
| |
| var BufferList = require('./internal/streams/BufferList'); |
| var destroyImpl = require('./internal/streams/destroy'); |
| var StringDecoder; |
| |
| util.inherits(Readable, Stream); |
| |
| var kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume']; |
| |
| function prependListener(emitter, event, fn) { |
| // Sadly this is not cacheable as some libraries bundle their own |
| // event emitter implementation with them. |
| if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn); |
| |
| // This is a hack to make sure that our error handler is attached before any |
| // userland ones. NEVER DO THIS. This is here only because this code needs |
| // to continue to work with older versions of Node.js that do not include |
| // the prependListener() method. The goal is to eventually remove this hack. |
| if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]]; |
| } |
| |
| function ReadableState(options, stream) { |
| Duplex = Duplex || require('./_stream_duplex'); |
| |
| options = options || {}; |
| |
| // Duplex streams are both readable and writable, but share |
| // the same options object. |
| // However, some cases require setting options to different |
| // values for the readable and the writable sides of the duplex stream. |
| // These options can be provided separately as readableXXX and writableXXX. |
| var isDuplex = stream instanceof Duplex; |
| |
| // object stream flag. Used to make read(n) ignore n and to |
| // make all the buffer merging and length checks go away |
| this.objectMode = !!options.objectMode; |
| |
| if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode; |
| |
| // the point at which it stops calling _read() to fill the buffer |
| // Note: 0 is a valid value, means "don't call _read preemptively ever" |
| var hwm = options.highWaterMark; |
| var readableHwm = options.readableHighWaterMark; |
| var defaultHwm = this.objectMode ? 16 : 16 * 1024; |
| |
| if (hwm || hwm === 0) this.highWaterMark = hwm;else if (isDuplex && (readableHwm || readableHwm === 0)) this.highWaterMark = readableHwm;else this.highWaterMark = defaultHwm; |
| |
| // cast to ints. |
| this.highWaterMark = Math.floor(this.highWaterMark); |
| |
| // A linked list is used to store data chunks instead of an array because the |
| // linked list can remove elements from the beginning faster than |
| // array.shift() |
| this.buffer = new BufferList(); |
| this.length = 0; |
| this.pipes = null; |
| this.pipesCount = 0; |
| this.flowing = null; |
| this.ended = false; |
| this.endEmitted = false; |
| this.reading = false; |
| |
| // a flag to be able to tell if the event 'readable'/'data' is emitted |
| // immediately, or on a later tick. We set this to true at first, because |
| // any actions that shouldn't happen until "later" should generally also |
| // not happen before the first read call. |
| this.sync = true; |
| |
| // whenever we return null, then we set a flag to say |
| // that we're awaiting a 'readable' event emission. |
| this.needReadable = false; |
| this.emittedReadable = false; |
| this.readableListening = false; |
| this.resumeScheduled = false; |
| |
| // has it been destroyed |
| this.destroyed = false; |
| |
| // Crypto is kind of old and crusty. Historically, its default string |
| // encoding is 'binary' so we have to make this configurable. |
| // Everything else in the universe uses 'utf8', though. |
| this.defaultEncoding = options.defaultEncoding || 'utf8'; |
| |
| // the number of writers that are awaiting a drain event in .pipe()s |
| this.awaitDrain = 0; |
| |
| // if true, a maybeReadMore has been scheduled |
| this.readingMore = false; |
| |
| this.decoder = null; |
| this.encoding = null; |
| if (options.encoding) { |
| if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; |
| this.decoder = new StringDecoder(options.encoding); |
| this.encoding = options.encoding; |
| } |
| } |
| |
| function Readable(options) { |
| Duplex = Duplex || require('./_stream_duplex'); |
| |
| if (!(this instanceof Readable)) return new Readable(options); |
| |
| this._readableState = new ReadableState(options, this); |
| |
| // legacy |
| this.readable = true; |
| |
| if (options) { |
| if (typeof options.read === 'function') this._read = options.read; |
| |
| if (typeof options.destroy === 'function') this._destroy = options.destroy; |
| } |
| |
| Stream.call(this); |
| } |
| |
| Object.defineProperty(Readable.prototype, 'destroyed', { |
| get: function () { |
| if (this._readableState === undefined) { |
| return false; |
| } |
| return this._readableState.destroyed; |
| }, |
| set: function (value) { |
| // we ignore the value if the stream |
| // has not been initialized yet |
| if (!this._readableState) { |
| return; |
| } |
| |
| // backward compatibility, the user is explicitly |
| // managing destroyed |
| this._readableState.destroyed = value; |
| } |
| }); |
| |
| Readable.prototype.destroy = destroyImpl.destroy; |
| Readable.prototype._undestroy = destroyImpl.undestroy; |
| Readable.prototype._destroy = function (err, cb) { |
| this.push(null); |
| cb(err); |
| }; |
| |
| // Manually shove something into the read() buffer. |
| // This returns true if the highWaterMark has not been hit yet, |
| // similar to how Writable.write() returns true if you should |
| // write() some more. |
| Readable.prototype.push = function (chunk, encoding) { |
| var state = this._readableState; |
| var skipChunkCheck; |
| |
| if (!state.objectMode) { |
| if (typeof chunk === 'string') { |
| encoding = encoding || state.defaultEncoding; |
| if (encoding !== state.encoding) { |
| chunk = Buffer.from(chunk, encoding); |
| encoding = ''; |
| } |
| skipChunkCheck = true; |
| } |
| } else { |
| skipChunkCheck = true; |
| } |
| |
| return readableAddChunk(this, chunk, encoding, false, skipChunkCheck); |
| }; |
| |
| // Unshift should *always* be something directly out of read() |
| Readable.prototype.unshift = function (chunk) { |
| return readableAddChunk(this, chunk, null, true, false); |
| }; |
| |
| function readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) { |
| var state = stream._readableState; |
| if (chunk === null) { |
| state.reading = false; |
| onEofChunk(stream, state); |
| } else { |
| var er; |
| if (!skipChunkCheck) er = chunkInvalid(state, chunk); |
| if (er) { |
| stream.emit('error', er); |
| } else if (state.objectMode || chunk && chunk.length > 0) { |
| if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) { |
| chunk = _uint8ArrayToBuffer(chunk); |
| } |
| |
| if (addToFront) { |
| if (state.endEmitted) stream.emit('error', new Error('stream.unshift() after end event'));else addChunk(stream, state, chunk, true); |
| } else if (state.ended) { |
| stream.emit('error', new Error('stream.push() after EOF')); |
| } else { |
| state.reading = false; |
| if (state.decoder && !encoding) { |
| chunk = state.decoder.write(chunk); |
| if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state); |
| } else { |
| addChunk(stream, state, chunk, false); |
| } |
| } |
| } else if (!addToFront) { |
| state.reading = false; |
| } |
| } |
| |
| return needMoreData(state); |
| } |
| |
| function addChunk(stream, state, chunk, addToFront) { |
| if (state.flowing && state.length === 0 && !state.sync) { |
| stream.emit('data', chunk); |
| stream.read(0); |
| } else { |
| // update the buffer info. |
| state.length += state.objectMode ? 1 : chunk.length; |
| if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk); |
| |
| if (state.needReadable) emitReadable(stream); |
| } |
| maybeReadMore(stream, state); |
| } |
| |
| function chunkInvalid(state, chunk) { |
| var er; |
| if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) { |
| er = new TypeError('Invalid non-string/buffer chunk'); |
| } |
| return er; |
| } |
| |
| // if it's past the high water mark, we can push in some more. |
| // Also, if we have no data yet, we can stand some |
| // more bytes. This is to work around cases where hwm=0, |
| // such as the repl. Also, if the push() triggered a |
| // readable event, and the user called read(largeNumber) such that |
| // needReadable was set, then we ought to push more, so that another |
| // 'readable' event will be triggered. |
| function needMoreData(state) { |
| return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0); |
| } |
| |
| Readable.prototype.isPaused = function () { |
| return this._readableState.flowing === false; |
| }; |
| |
| // backwards compatibility. |
| Readable.prototype.setEncoding = function (enc) { |
| if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; |
| this._readableState.decoder = new StringDecoder(enc); |
| this._readableState.encoding = enc; |
| return this; |
| }; |
| |
| // Don't raise the hwm > 8MB |
| var MAX_HWM = 0x800000; |
| function computeNewHighWaterMark(n) { |
| if (n >= MAX_HWM) { |
| n = MAX_HWM; |
| } else { |
| // Get the next highest power of 2 to prevent increasing hwm excessively in |
| // tiny amounts |
| n--; |
| n |= n >>> 1; |
| n |= n >>> 2; |
| n |= n >>> 4; |
| n |= n >>> 8; |
| n |= n >>> 16; |
| n++; |
| } |
| return n; |
| } |
| |
| // This function is designed to be inlinable, so please take care when making |
| // changes to the function body. |
| function howMuchToRead(n, state) { |
| if (n <= 0 || state.length === 0 && state.ended) return 0; |
| if (state.objectMode) return 1; |
| if (n !== n) { |
| // Only flow one buffer at a time |
| if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length; |
| } |
| // If we're asking for more than the current hwm, then raise the hwm. |
| if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n); |
| if (n <= state.length) return n; |
| // Don't have enough |
| if (!state.ended) { |
| state.needReadable = true; |
| return 0; |
| } |
| return state.length; |
| } |
| |
| // you can override either this method, or the async _read(n) below. |
| Readable.prototype.read = function (n) { |
| debug('read', n); |
| n = parseInt(n, 10); |
| var state = this._readableState; |
| var nOrig = n; |
| |
| if (n !== 0) state.emittedReadable = false; |
| |
| // if we're doing read(0) to trigger a readable event, but we |
| // already have a bunch of data in the buffer, then just trigger |
| // the 'readable' event and move on. |
| if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) { |
| debug('read: emitReadable', state.length, state.ended); |
| if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this); |
| return null; |
| } |
| |
| n = howMuchToRead(n, state); |
| |
| // if we've ended, and we're now clear, then finish it up. |
| if (n === 0 && state.ended) { |
| if (state.length === 0) endReadable(this); |
| return null; |
| } |
| |
| // All the actual chunk generation logic needs to be |
| // *below* the call to _read. The reason is that in certain |
| // synthetic stream cases, such as passthrough streams, _read |
| // may be a completely synchronous operation which may change |
| // the state of the read buffer, providing enough data when |
| // before there was *not* enough. |
| // |
| // So, the steps are: |
| // 1. Figure out what the state of things will be after we do |
| // a read from the buffer. |
| // |
| // 2. If that resulting state will trigger a _read, then call _read. |
| // Note that this may be asynchronous, or synchronous. Yes, it is |
| // deeply ugly to write APIs this way, but that still doesn't mean |
| // that the Readable class should behave improperly, as streams are |
| // designed to be sync/async agnostic. |
| // Take note if the _read call is sync or async (ie, if the read call |
| // has returned yet), so that we know whether or not it's safe to emit |
| // 'readable' etc. |
| // |
| // 3. Actually pull the requested chunks out of the buffer and return. |
| |
| // if we need a readable event, then we need to do some reading. |
| var doRead = state.needReadable; |
| debug('need readable', doRead); |
| |
| // if we currently have less than the highWaterMark, then also read some |
| if (state.length === 0 || state.length - n < state.highWaterMark) { |
| doRead = true; |
| debug('length less than watermark', doRead); |
| } |
| |
| // however, if we've ended, then there's no point, and if we're already |
| // reading, then it's unnecessary. |
| if (state.ended || state.reading) { |
| doRead = false; |
| debug('reading or ended', doRead); |
| } else if (doRead) { |
| debug('do read'); |
| state.reading = true; |
| state.sync = true; |
| // if the length is currently zero, then we *need* a readable event. |
| if (state.length === 0) state.needReadable = true; |
| // call internal read method |
| this._read(state.highWaterMark); |
| state.sync = false; |
| // If _read pushed data synchronously, then `reading` will be false, |
| // and we need to re-evaluate how much data we can return to the user. |
| if (!state.reading) n = howMuchToRead(nOrig, state); |
| } |
| |
| var ret; |
| if (n > 0) ret = fromList(n, state);else ret = null; |
| |
| if (ret === null) { |
| state.needReadable = true; |
| n = 0; |
| } else { |
| state.length -= n; |
| } |
| |
| if (state.length === 0) { |
| // If we have nothing in the buffer, then we want to know |
| // as soon as we *do* get something into the buffer. |
| if (!state.ended) state.needReadable = true; |
| |
| // If we tried to read() past the EOF, then emit end on the next tick. |
| if (nOrig !== n && state.ended) endReadable(this); |
| } |
| |
| if (ret !== null) this.emit('data', ret); |
| |
| return ret; |
| }; |
| |
| function onEofChunk(stream, state) { |
| if (state.ended) return; |
| if (state.decoder) { |
| var chunk = state.decoder.end(); |
| if (chunk && chunk.length) { |
| state.buffer.push(chunk); |
| state.length += state.objectMode ? 1 : chunk.length; |
| } |
| } |
| state.ended = true; |
| |
| // emit 'readable' now to make sure it gets picked up. |
| emitReadable(stream); |
| } |
| |
| // Don't emit readable right away in sync mode, because this can trigger |
| // another read() call => stack overflow. This way, it might trigger |
| // a nextTick recursion warning, but that's not so bad. |
| function emitReadable(stream) { |
| var state = stream._readableState; |
| state.needReadable = false; |
| if (!state.emittedReadable) { |
| debug('emitReadable', state.flowing); |
| state.emittedReadable = true; |
| if (state.sync) pna.nextTick(emitReadable_, stream);else emitReadable_(stream); |
| } |
| } |
| |
| function emitReadable_(stream) { |
| debug('emit readable'); |
| stream.emit('readable'); |
| flow(stream); |
| } |
| |
| // at this point, the user has presumably seen the 'readable' event, |
| // and called read() to consume some data. that may have triggered |
| // in turn another _read(n) call, in which case reading = true if |
| // it's in progress. |
| // However, if we're not ended, or reading, and the length < hwm, |
| // then go ahead and try to read some more preemptively. |
| function maybeReadMore(stream, state) { |
| if (!state.readingMore) { |
| state.readingMore = true; |
| pna.nextTick(maybeReadMore_, stream, state); |
| } |
| } |
| |
| function maybeReadMore_(stream, state) { |
| var len = state.length; |
| while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) { |
| debug('maybeReadMore read 0'); |
| stream.read(0); |
| if (len === state.length) |
| // didn't get any data, stop spinning. |
| break;else len = state.length; |
| } |
| state.readingMore = false; |
| } |
| |
| // abstract method. to be overridden in specific implementation classes. |
| // call cb(er, data) where data is <= n in length. |
| // for virtual (non-string, non-buffer) streams, "length" is somewhat |
| // arbitrary, and perhaps not very meaningful. |
| Readable.prototype._read = function (n) { |
| this.emit('error', new Error('_read() is not implemented')); |
| }; |
| |
| Readable.prototype.pipe = function (dest, pipeOpts) { |
| var src = this; |
| var state = this._readableState; |
| |
| switch (state.pipesCount) { |
| case 0: |
| state.pipes = dest; |
| break; |
| case 1: |
| state.pipes = [state.pipes, dest]; |
| break; |
| default: |
| state.pipes.push(dest); |
| break; |
| } |
| state.pipesCount += 1; |
| debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts); |
| |
| var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr; |
| |
| var endFn = doEnd ? onend : unpipe; |
| if (state.endEmitted) pna.nextTick(endFn);else src.once('end', endFn); |
| |
| dest.on('unpipe', onunpipe); |
| function onunpipe(readable, unpipeInfo) { |
| debug('onunpipe'); |
| if (readable === src) { |
| if (unpipeInfo && unpipeInfo.hasUnpiped === false) { |
| unpipeInfo.hasUnpiped = true; |
| cleanup(); |
| } |
| } |
| } |
| |
| function onend() { |
| debug('onend'); |
| dest.end(); |
| } |
| |
| // when the dest drains, it reduces the awaitDrain counter |
| // on the source. This would be more elegant with a .once() |
| // handler in flow(), but adding and removing repeatedly is |
| // too slow. |
| var ondrain = pipeOnDrain(src); |
| dest.on('drain', ondrain); |
| |
| var cleanedUp = false; |
| function cleanup() { |
| debug('cleanup'); |
| // cleanup event handlers once the pipe is broken |
| dest.removeListener('close', onclose); |
| dest.removeListener('finish', onfinish); |
| dest.removeListener('drain', ondrain); |
| dest.removeListener('error', onerror); |
| dest.removeListener('unpipe', onunpipe); |
| src.removeListener('end', onend); |
| src.removeListener('end', unpipe); |
| src.removeListener('data', ondata); |
| |
| cleanedUp = true; |
| |
| // if the reader is waiting for a drain event from this |
| // specific writer, then it would cause it to never start |
| // flowing again. |
| // So, if this is awaiting a drain, then we just call it now. |
| // If we don't know, then assume that we are waiting for one. |
| if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain(); |
| } |
| |
| // If the user pushes more data while we're writing to dest then we'll end up |
| // in ondata again. However, we only want to increase awaitDrain once because |
| // dest will only emit one 'drain' event for the multiple writes. |
| // => Introduce a guard on increasing awaitDrain. |
| var increasedAwaitDrain = false; |
| src.on('data', ondata); |
| function ondata(chunk) { |
| debug('ondata'); |
| increasedAwaitDrain = false; |
| var ret = dest.write(chunk); |
| if (false === ret && !increasedAwaitDrain) { |
| // If the user unpiped during `dest.write()`, it is possible |
| // to get stuck in a permanently paused state if that write |
| // also returned false. |
| // => Check whether `dest` is still a piping destination. |
| if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) { |
| debug('false write response, pause', src._readableState.awaitDrain); |
| src._readableState.awaitDrain++; |
| increasedAwaitDrain = true; |
| } |
| src.pause(); |
| } |
| } |
| |
| // if the dest has an error, then stop piping into it. |
| // however, don't suppress the throwing behavior for this. |
| function onerror(er) { |
| debug('onerror', er); |
| unpipe(); |
| dest.removeListener('error', onerror); |
| if (EElistenerCount(dest, 'error') === 0) dest.emit('error', er); |
| } |
| |
| // Make sure our error handler is attached before userland ones. |
| prependListener(dest, 'error', onerror); |
| |
| // Both close and finish should trigger unpipe, but only once. |
| function onclose() { |
| dest.removeListener('finish', onfinish); |
| unpipe(); |
| } |
| dest.once('close', onclose); |
| function onfinish() { |
| debug('onfinish'); |
| dest.removeListener('close', onclose); |
| unpipe(); |
| } |
| dest.once('finish', onfinish); |
| |
| function unpipe() { |
| debug('unpipe'); |
| src.unpipe(dest); |
| } |
| |
| // tell the dest that it's being piped to |
| dest.emit('pipe', src); |
| |
| // start the flow if it hasn't been started already. |
| if (!state.flowing) { |
| debug('pipe resume'); |
| src.resume(); |
| } |
| |
| return dest; |
| }; |
| |
| function pipeOnDrain(src) { |
| return function () { |
| var state = src._readableState; |
| debug('pipeOnDrain', state.awaitDrain); |
| if (state.awaitDrain) state.awaitDrain--; |
| if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) { |
| state.flowing = true; |
| flow(src); |
| } |
| }; |
| } |
| |
| Readable.prototype.unpipe = function (dest) { |
| var state = this._readableState; |
| var unpipeInfo = { hasUnpiped: false }; |
| |
| // if we're not piping anywhere, then do nothing. |
| if (state.pipesCount === 0) return this; |
| |
| // just one destination. most common case. |
| if (state.pipesCount === 1) { |
| // passed in one, but it's not the right one. |
| if (dest && dest !== state.pipes) return this; |
| |
| if (!dest) dest = state.pipes; |
| |
| // got a match. |
| state.pipes = null; |
| state.pipesCount = 0; |
| state.flowing = false; |
| if (dest) dest.emit('unpipe', this, unpipeInfo); |
| return this; |
| } |
| |
| // slow case. multiple pipe destinations. |
| |
| if (!dest) { |
| // remove all. |
| var dests = state.pipes; |
| var len = state.pipesCount; |
| state.pipes = null; |
| state.pipesCount = 0; |
| state.flowing = false; |
| |
| for (var i = 0; i < len; i++) { |
| dests[i].emit('unpipe', this, unpipeInfo); |
| }return this; |
| } |
| |
| // try to find the right one. |
| var index = indexOf(state.pipes, dest); |
| if (index === -1) return this; |
| |
| state.pipes.splice(index, 1); |
| state.pipesCount -= 1; |
| if (state.pipesCount === 1) state.pipes = state.pipes[0]; |
| |
| dest.emit('unpipe', this, unpipeInfo); |
| |
| return this; |
| }; |
| |
| // set up data events if they are asked for |
| // Ensure readable listeners eventually get something |
| Readable.prototype.on = function (ev, fn) { |
| var res = Stream.prototype.on.call(this, ev, fn); |
| |
| if (ev === 'data') { |
| // Start flowing on next tick if stream isn't explicitly paused |
| if (this._readableState.flowing !== false) this.resume(); |
| } else if (ev === 'readable') { |
| var state = this._readableState; |
| if (!state.endEmitted && !state.readableListening) { |
| state.readableListening = state.needReadable = true; |
| state.emittedReadable = false; |
| if (!state.reading) { |
| pna.nextTick(nReadingNextTick, this); |
| } else if (state.length) { |
| emitReadable(this); |
| } |
| } |
| } |
| |
| return res; |
| }; |
| Readable.prototype.addListener = Readable.prototype.on; |
| |
| function nReadingNextTick(self) { |
| debug('readable nexttick read 0'); |
| self.read(0); |
| } |
| |
| // pause() and resume() are remnants of the legacy readable stream API |
| // If the user uses them, then switch into old mode. |
| Readable.prototype.resume = function () { |
| var state = this._readableState; |
| if (!state.flowing) { |
| debug('resume'); |
| state.flowing = true; |
| resume(this, state); |
| } |
| return this; |
| }; |
| |
| function resume(stream, state) { |
| if (!state.resumeScheduled) { |
| state.resumeScheduled = true; |
| pna.nextTick(resume_, stream, state); |
| } |
| } |
| |
| function resume_(stream, state) { |
| if (!state.reading) { |
| debug('resume read 0'); |
| stream.read(0); |
| } |
| |
| state.resumeScheduled = false; |
| state.awaitDrain = 0; |
| stream.emit('resume'); |
| flow(stream); |
| if (state.flowing && !state.reading) stream.read(0); |
| } |
| |
| Readable.prototype.pause = function () { |
| debug('call pause flowing=%j', this._readableState.flowing); |
| if (false !== this._readableState.flowing) { |
| debug('pause'); |
| this._readableState.flowing = false; |
| this.emit('pause'); |
| } |
| return this; |
| }; |
| |
| function flow(stream) { |
| var state = stream._readableState; |
| debug('flow', state.flowing); |
| while (state.flowing && stream.read() !== null) {} |
| } |
| |
| // wrap an old-style stream as the async data source. |
| // This is *not* part of the readable stream interface. |
| // It is an ugly unfortunate mess of history. |
| Readable.prototype.wrap = function (stream) { |
| var _this = this; |
| |
| var state = this._readableState; |
| var paused = false; |
| |
| stream.on('end', function () { |
| debug('wrapped end'); |
| if (state.decoder && !state.ended) { |
| var chunk = state.decoder.end(); |
| if (chunk && chunk.length) _this.push(chunk); |
| } |
| |
| _this.push(null); |
| }); |
| |
| stream.on('data', function (chunk) { |
| debug('wrapped data'); |
| if (state.decoder) chunk = state.decoder.write(chunk); |
| |
| // don't skip over falsy values in objectMode |
| if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return; |
| |
| var ret = _this.push(chunk); |
| if (!ret) { |
| paused = true; |
| stream.pause(); |
| } |
| }); |
| |
| // proxy all the other methods. |
| // important when wrapping filters and duplexes. |
| for (var i in stream) { |
| if (this[i] === undefined && typeof stream[i] === 'function') { |
| this[i] = function (method) { |
| return function () { |
| return stream[method].apply(stream, arguments); |
| }; |
| }(i); |
| } |
| } |
| |
| // proxy certain important events. |
| for (var n = 0; n < kProxyEvents.length; n++) { |
| stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n])); |
| } |
| |
| // when we try to consume some more bytes, simply unpause the |
| // underlying stream. |
| this._read = function (n) { |
| debug('wrapped _read', n); |
| if (paused) { |
| paused = false; |
| stream.resume(); |
| } |
| }; |
| |
| return this; |
| }; |
| |
| Object.defineProperty(Readable.prototype, 'readableHighWaterMark', { |
| // making it explicit this property is not enumerable |
| // because otherwise some prototype manipulation in |
| // userland will fail |
| enumerable: false, |
| get: function () { |
| return this._readableState.highWaterMark; |
| } |
| }); |
| |
| // exposed for testing purposes only. |
| Readable._fromList = fromList; |
| |
| // Pluck off n bytes from an array of buffers. |
| // Length is the combined lengths of all the buffers in the list. |
| // This function is designed to be inlinable, so please take care when making |
| // changes to the function body. |
| function fromList(n, state) { |
| // nothing buffered |
| if (state.length === 0) return null; |
| |
| var ret; |
| if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) { |
| // read it all, truncate the list |
| if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.head.data;else ret = state.buffer.concat(state.length); |
| state.buffer.clear(); |
| } else { |
| // read part of list |
| ret = fromListPartial(n, state.buffer, state.decoder); |
| } |
| |
| return ret; |
| } |
| |
| // Extracts only enough buffered data to satisfy the amount requested. |
| // This function is designed to be inlinable, so please take care when making |
| // changes to the function body. |
| function fromListPartial(n, list, hasStrings) { |
| var ret; |
| if (n < list.head.data.length) { |
| // slice is the same for buffers and strings |
| ret = list.head.data.slice(0, n); |
| list.head.data = list.head.data.slice(n); |
| } else if (n === list.head.data.length) { |
| // first chunk is a perfect match |
| ret = list.shift(); |
| } else { |
| // result spans more than one buffer |
| ret = hasStrings ? copyFromBufferString(n, list) : copyFromBuffer(n, list); |
| } |
| return ret; |
| } |
| |
| // Copies a specified amount of characters from the list of buffered data |
| // chunks. |
| // This function is designed to be inlinable, so please take care when making |
| // changes to the function body. |
| function copyFromBufferString(n, list) { |
| var p = list.head; |
| var c = 1; |
| var ret = p.data; |
| n -= ret.length; |
| while (p = p.next) { |
| var str = p.data; |
| var nb = n > str.length ? str.length : n; |
| if (nb === str.length) ret += str;else ret += str.slice(0, n); |
| n -= nb; |
| if (n === 0) { |
| if (nb === str.length) { |
| ++c; |
| if (p.next) list.head = p.next;else list.head = list.tail = null; |
| } else { |
| list.head = p; |
| p.data = str.slice(nb); |
| } |
| break; |
| } |
| ++c; |
| } |
| list.length -= c; |
| return ret; |
| } |
| |
| // Copies a specified amount of bytes from the list of buffered data chunks. |
| // This function is designed to be inlinable, so please take care when making |
| // changes to the function body. |
| function copyFromBuffer(n, list) { |
| var ret = Buffer.allocUnsafe(n); |
| var p = list.head; |
| var c = 1; |
| p.data.copy(ret); |
| n -= p.data.length; |
| while (p = p.next) { |
| var buf = p.data; |
| var nb = n > buf.length ? buf.length : n; |
| buf.copy(ret, ret.length - n, 0, nb); |
| n -= nb; |
| if (n === 0) { |
| if (nb === buf.length) { |
| ++c; |
| if (p.next) list.head = p.next;else list.head = list.tail = null; |
| } else { |
| list.head = p; |
| p.data = buf.slice(nb); |
| } |
| break; |
| } |
| ++c; |
| } |
| list.length -= c; |
| return ret; |
| } |
| |
| function endReadable(stream) { |
| var state = stream._readableState; |
| |
| // If we get here before consuming all the bytes, then that is a |
| // bug in node. Should never happen. |
| if (state.length > 0) throw new Error('"endReadable()" called on non-empty stream'); |
| |
| if (!state.endEmitted) { |
| state.ended = true; |
| pna.nextTick(endReadableNT, state, stream); |
| } |
| } |
| |
| function endReadableNT(state, stream) { |
| // Check that we didn't get one last unshift. |
| if (!state.endEmitted && state.length === 0) { |
| state.endEmitted = true; |
| stream.readable = false; |
| stream.emit('end'); |
| } |
| } |
| |
| function indexOf(xs, x) { |
| for (var i = 0, l = xs.length; i < l; i++) { |
| if (xs[i] === x) return i; |
| } |
| return -1; |
| } |
| }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{"./_stream_duplex":71,"./internal/streams/BufferList":76,"./internal/streams/destroy":77,"./internal/streams/stream":78,"_process":69,"core-util-is":44,"events":50,"inherits":56,"isarray":58,"process-nextick-args":68,"safe-buffer":83,"string_decoder/":85,"util":40}],74:[function(require,module,exports){ |
| // Copyright Joyent, Inc. and other Node contributors. |
| // |
| // Permission is hereby granted, free of charge, to any person obtaining a |
| // copy of this software and associated documentation files (the |
| // "Software"), to deal in the Software without restriction, including |
| // without limitation the rights to use, copy, modify, merge, publish, |
| // distribute, sublicense, and/or sell copies of the Software, and to permit |
| // persons to whom the Software is furnished to do so, subject to the |
| // following conditions: |
| // |
| // The above copyright notice and this permission notice shall be included |
| // in all copies or substantial portions of the Software. |
| // |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN |
| // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
| // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
| // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE |
| // USE OR OTHER DEALINGS IN THE SOFTWARE. |
| |
| // a transform stream is a readable/writable stream where you do |
| // something with the data. Sometimes it's called a "filter", |
| // but that's not a great name for it, since that implies a thing where |
| // some bits pass through, and others are simply ignored. (That would |
| // be a valid example of a transform, of course.) |
| // |
| // While the output is causally related to the input, it's not a |
| // necessarily symmetric or synchronous transformation. For example, |
| // a zlib stream might take multiple plain-text writes(), and then |
| // emit a single compressed chunk some time in the future. |
| // |
| // Here's how this works: |
| // |
| // The Transform stream has all the aspects of the readable and writable |
| // stream classes. When you write(chunk), that calls _write(chunk,cb) |
| // internally, and returns false if there's a lot of pending writes |
| // buffered up. When you call read(), that calls _read(n) until |
| // there's enough pending readable data buffered up. |
| // |
| // In a transform stream, the written data is placed in a buffer. When |
| // _read(n) is called, it transforms the queued up data, calling the |
| // buffered _write cb's as it consumes chunks. If consuming a single |
| // written chunk would result in multiple output chunks, then the first |
| // outputted bit calls the readcb, and subsequent chunks just go into |
| // the read buffer, and will cause it to emit 'readable' if necessary. |
| // |
| // This way, back-pressure is actually determined by the reading side, |
| // since _read has to be called to start processing a new chunk. However, |
| // a pathological inflate type of transform can cause excessive buffering |
| // here. For example, imagine a stream where every byte of input is |
| // interpreted as an integer from 0-255, and then results in that many |
| // bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in |
| // 1kb of data being output. In this case, you could write a very small |
| // amount of input, and end up with a very large amount of output. In |
| // such a pathological inflating mechanism, there'd be no way to tell |
| // the system to stop doing the transform. A single 4MB write could |
| // cause the system to run out of memory. |
| // |
| // However, even in such a pathological case, only a single written chunk |
| // would be consumed, and then the rest would wait (un-transformed) until |
| // the results of the previous transformed chunk were consumed. |
| |
| 'use strict'; |
| |
| module.exports = Transform; |
| |
| var Duplex = require('./_stream_duplex'); |
| |
| /*<replacement>*/ |
| var util = require('core-util-is'); |
| util.inherits = require('inherits'); |
| /*</replacement>*/ |
| |
| util.inherits(Transform, Duplex); |
| |
| function afterTransform(er, data) { |
| var ts = this._transformState; |
| ts.transforming = false; |
| |
| var cb = ts.writecb; |
| |
| if (!cb) { |
| return this.emit('error', new Error('write callback called multiple times')); |
| } |
| |
| ts.writechunk = null; |
| ts.writecb = null; |
| |
| if (data != null) // single equals check for both `null` and `undefined` |
| this.push(data); |
| |
| cb(er); |
| |
| var rs = this._readableState; |
| rs.reading = false; |
| if (rs.needReadable || rs.length < rs.highWaterMark) { |
| this._read(rs.highWaterMark); |
| } |
| } |
| |
| function Transform(options) { |
| if (!(this instanceof Transform)) return new Transform(options); |
| |
| Duplex.call(this, options); |
| |
| this._transformState = { |
| afterTransform: afterTransform.bind(this), |
| needTransform: false, |
| transforming: false, |
| writecb: null, |
| writechunk: null, |
| writeencoding: null |
| }; |
| |
| // start out asking for a readable event once data is transformed. |
| this._readableState.needReadable = true; |
| |
| // we have implemented the _read method, and done the other things |
| // that Readable wants before the first _read call, so unset the |
| // sync guard flag. |
| this._readableState.sync = false; |
| |
| if (options) { |
| if (typeof options.transform === 'function') this._transform = options.transform; |
| |
| if (typeof options.flush === 'function') this._flush = options.flush; |
| } |
| |
| // When the writable side finishes, then flush out anything remaining. |
| this.on('prefinish', prefinish); |
| } |
| |
| function prefinish() { |
| var _this = this; |
| |
| if (typeof this._flush === 'function') { |
| this._flush(function (er, data) { |
| done(_this, er, data); |
| }); |
| } else { |
| done(this, null, null); |
| } |
| } |
| |
| Transform.prototype.push = function (chunk, encoding) { |
| this._transformState.needTransform = false; |
| return Duplex.prototype.push.call(this, chunk, encoding); |
| }; |
| |
| // This is the part where you do stuff! |
| // override this function in implementation classes. |
| // 'chunk' is an input chunk. |
| // |
| // Call `push(newChunk)` to pass along transformed output |
| // to the readable side. You may call 'push' zero or more times. |
| // |
| // Call `cb(err)` when you are done with this chunk. If you pass |
| // an error, then that'll put the hurt on the whole operation. If you |
| // never call cb(), then you'll never get another chunk. |
| Transform.prototype._transform = function (chunk, encoding, cb) { |
| throw new Error('_transform() is not implemented'); |
| }; |
| |
| Transform.prototype._write = function (chunk, encoding, cb) { |
| var ts = this._transformState; |
| ts.writecb = cb; |
| ts.writechunk = chunk; |
| ts.writeencoding = encoding; |
| if (!ts.transforming) { |
| var rs = this._readableState; |
| if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark); |
| } |
| }; |
| |
| // Doesn't matter what the args are here. |
| // _transform does all the work. |
| // That we got here means that the readable side wants more data. |
| Transform.prototype._read = function (n) { |
| var ts = this._transformState; |
| |
| if (ts.writechunk !== null && ts.writecb && !ts.transforming) { |
| ts.transforming = true; |
| this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform); |
| } else { |
| // mark that we need a transform, so that any data that comes in |
| // will get processed, now that we've asked for it. |
| ts.needTransform = true; |
| } |
| }; |
| |
| Transform.prototype._destroy = function (err, cb) { |
| var _this2 = this; |
| |
| Duplex.prototype._destroy.call(this, err, function (err2) { |
| cb(err2); |
| _this2.emit('close'); |
| }); |
| }; |
| |
| function done(stream, er, data) { |
| if (er) return stream.emit('error', er); |
| |
| if (data != null) // single equals check for both `null` and `undefined` |
| stream.push(data); |
| |
| // if there's nothing in the write buffer, then that means |
| // that nothing more will ever be provided |
| if (stream._writableState.length) throw new Error('Calling transform done when ws.length != 0'); |
| |
| if (stream._transformState.transforming) throw new Error('Calling transform done when still transforming'); |
| |
| return stream.push(null); |
| } |
| },{"./_stream_duplex":71,"core-util-is":44,"inherits":56}],75:[function(require,module,exports){ |
| (function (process,global,setImmediate){ |
| // Copyright Joyent, Inc. and other Node contributors. |
| // |
| // Permission is hereby granted, free of charge, to any person obtaining a |
| // copy of this software and associated documentation files (the |
| // "Software"), to deal in the Software without restriction, including |
| // without limitation the rights to use, copy, modify, merge, publish, |
| // distribute, sublicense, and/or sell copies of the Software, and to permit |
| // persons to whom the Software is furnished to do so, subject to the |
| // following conditions: |
| // |
| // The above copyright notice and this permission notice shall be included |
| // in all copies or substantial portions of the Software. |
| // |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN |
| // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
| // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
| // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE |
| // USE OR OTHER DEALINGS IN THE SOFTWARE. |
| |
| // A bit simpler than readable streams. |
| // Implement an async ._write(chunk, encoding, cb), and it'll handle all |
| // the drain event emission and buffering. |
| |
| 'use strict'; |
| |
| /*<replacement>*/ |
| |
| var pna = require('process-nextick-args'); |
| /*</replacement>*/ |
| |
| module.exports = Writable; |
| |
| /* <replacement> */ |
| function WriteReq(chunk, encoding, cb) { |
| this.chunk = chunk; |
| this.encoding = encoding; |
| this.callback = cb; |
| this.next = null; |
| } |
| |
| // It seems a linked list but it is not |
| // there will be only 2 of these for each stream |
| function CorkedRequest(state) { |
| var _this = this; |
| |
| this.next = null; |
| this.entry = null; |
| this.finish = function () { |
| onCorkedFinish(_this, state); |
| }; |
| } |
| /* </replacement> */ |
| |
| /*<replacement>*/ |
| var asyncWrite = !process.browser && ['v0.10', 'v0.9.'].indexOf(process.version.slice(0, 5)) > -1 ? setImmediate : pna.nextTick; |
| /*</replacement>*/ |
| |
| /*<replacement>*/ |
| var Duplex; |
| /*</replacement>*/ |
| |
| Writable.WritableState = WritableState; |
| |
| /*<replacement>*/ |
| var util = require('core-util-is'); |
| util.inherits = require('inherits'); |
| /*</replacement>*/ |
| |
| /*<replacement>*/ |
| var internalUtil = { |
| deprecate: require('util-deprecate') |
| }; |
| /*</replacement>*/ |
| |
| /*<replacement>*/ |
| var Stream = require('./internal/streams/stream'); |
| /*</replacement>*/ |
| |
| /*<replacement>*/ |
| |
| var Buffer = require('safe-buffer').Buffer; |
| var OurUint8Array = global.Uint8Array || function () {}; |
| function _uint8ArrayToBuffer(chunk) { |
| return Buffer.from(chunk); |
| } |
| function _isUint8Array(obj) { |
| return Buffer.isBuffer(obj) || obj instanceof OurUint8Array; |
| } |
| |
| /*</replacement>*/ |
| |
| var destroyImpl = require('./internal/streams/destroy'); |
| |
| util.inherits(Writable, Stream); |
| |
| function nop() {} |
| |
| function WritableState(options, stream) { |
| Duplex = Duplex || require('./_stream_duplex'); |
| |
| options = options || {}; |
| |
| // Duplex streams are both readable and writable, but share |
| // the same options object. |
| // However, some cases require setting options to different |
| // values for the readable and the writable sides of the duplex stream. |
| // These options can be provided separately as readableXXX and writableXXX. |
| var isDuplex = stream instanceof Duplex; |
| |
| // object stream flag to indicate whether or not this stream |
| // contains buffers or objects. |
| this.objectMode = !!options.objectMode; |
| |
| if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode; |
| |
| // the point at which write() starts returning false |
| // Note: 0 is a valid value, means that we always return false if |
| // the entire buffer is not flushed immediately on write() |
| var hwm = options.highWaterMark; |
| var writableHwm = options.writableHighWaterMark; |
| var defaultHwm = this.objectMode ? 16 : 16 * 1024; |
| |
| if (hwm || hwm === 0) this.highWaterMark = hwm;else if (isDuplex && (writableHwm || writableHwm === 0)) this.highWaterMark = writableHwm;else this.highWaterMark = defaultHwm; |
| |
| // cast to ints. |
| this.highWaterMark = Math.floor(this.highWaterMark); |
| |
| // if _final has been called |
| this.finalCalled = false; |
| |
| // drain event flag. |
| this.needDrain = false; |
| // at the start of calling end() |
| this.ending = false; |
| // when end() has been called, and returned |
| this.ended = false; |
| // when 'finish' is emitted |
| this.finished = false; |
| |
| // has it been destroyed |
| this.destroyed = false; |
| |
| // should we decode strings into buffers before passing to _write? |
| // this is here so that some node-core streams can optimize string |
| // handling at a lower level. |
| var noDecode = options.decodeStrings === false; |
| this.decodeStrings = !noDecode; |
| |
| // Crypto is kind of old and crusty. Historically, its default string |
| // encoding is 'binary' so we have to make this configurable. |
| // Everything else in the universe uses 'utf8', though. |
| this.defaultEncoding = options.defaultEncoding || 'utf8'; |
| |
| // not an actual buffer we keep track of, but a measurement |
| // of how much we're waiting to get pushed to some underlying |
| // socket or file. |
| this.length = 0; |
| |
| // a flag to see when we're in the middle of a write. |
| this.writing = false; |
| |
| // when true all writes will be buffered until .uncork() call |
| this.corked = 0; |
| |
| // a flag to be able to tell if the onwrite cb is called immediately, |
| // or on a later tick. We set this to true at first, because any |
| // actions that shouldn't happen until "later" should generally also |
| // not happen before the first write call. |
| this.sync = true; |
| |
| // a flag to know if we're processing previously buffered items, which |
| // may call the _write() callback in the same tick, so that we don't |
| // end up in an overlapped onwrite situation. |
| this.bufferProcessing = false; |
| |
| // the callback that's passed to _write(chunk,cb) |
| this.onwrite = function (er) { |
| onwrite(stream, er); |
| }; |
| |
| // the callback that the user supplies to write(chunk,encoding,cb) |
| this.writecb = null; |
| |
| // the amount that is being written when _write is called. |
| this.writelen = 0; |
| |
| this.bufferedRequest = null; |
| this.lastBufferedRequest = null; |
| |
| // number of pending user-supplied write callbacks |
| // this must be 0 before 'finish' can be emitted |
| this.pendingcb = 0; |
| |
| // emit prefinish if the only thing we're waiting for is _write cbs |
| // This is relevant for synchronous Transform streams |
| this.prefinished = false; |
| |
| // True if the error was already emitted and should not be thrown again |
| this.errorEmitted = false; |
| |
| // count buffered requests |
| this.bufferedRequestCount = 0; |
| |
| // allocate the first CorkedRequest, there is always |
| // one allocated and free to use, and we maintain at most two |
| this.corkedRequestsFree = new CorkedRequest(this); |
| } |
| |
| WritableState.prototype.getBuffer = function getBuffer() { |
| var current = this.bufferedRequest; |
| var out = []; |
| while (current) { |
| out.push(current); |
| current = current.next; |
| } |
| return out; |
| }; |
| |
| (function () { |
| try { |
| Object.defineProperty(WritableState.prototype, 'buffer', { |
| get: internalUtil.deprecate(function () { |
| return this.getBuffer(); |
| }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003') |
| }); |
| } catch (_) {} |
| })(); |
| |
| // Test _writableState for inheritance to account for Duplex streams, |
| // whose prototype chain only points to Readable. |
| var realHasInstance; |
| if (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') { |
| realHasInstance = Function.prototype[Symbol.hasInstance]; |
| Object.defineProperty(Writable, Symbol.hasInstance, { |
| value: function (object) { |
| if (realHasInstance.call(this, object)) return true; |
| if (this !== Writable) return false; |
| |
| return object && object._writableState instanceof WritableState; |
| } |
| }); |
| } else { |
| realHasInstance = function (object) { |
| return object instanceof this; |
| }; |
| } |
| |
| function Writable(options) { |
| Duplex = Duplex || require('./_stream_duplex'); |
| |
| // Writable ctor is applied to Duplexes, too. |
| // `realHasInstance` is necessary because using plain `instanceof` |
| // would return false, as no `_writableState` property is attached. |
| |
| // Trying to use the custom `instanceof` for Writable here will also break the |
| // Node.js LazyTransform implementation, which has a non-trivial getter for |
| // `_writableState` that would lead to infinite recursion. |
| if (!realHasInstance.call(Writable, this) && !(this instanceof Duplex)) { |
| return new Writable(options); |
| } |
| |
| this._writableState = new WritableState(options, this); |
| |
| // legacy. |
| this.writable = true; |
| |
| if (options) { |
| if (typeof options.write === 'function') this._write = options.write; |
| |
| if (typeof options.writev === 'function') this._writev = options.writev; |
| |
| if (typeof options.destroy === 'function') this._destroy = options.destroy; |
| |
| if (typeof options.final === 'function') this._final = options.final; |
| } |
| |
| Stream.call(this); |
| } |
| |
| // Otherwise people can pipe Writable streams, which is just wrong. |
| Writable.prototype.pipe = function () { |
| this.emit('error', new Error('Cannot pipe, not readable')); |
| }; |
| |
| function writeAfterEnd(stream, cb) { |
| var er = new Error('write after end'); |
| // TODO: defer error events consistently everywhere, not just the cb |
| stream.emit('error', er); |
| pna.nextTick(cb, er); |
| } |
| |
| // Checks that a user-supplied chunk is valid, especially for the particular |
| // mode the stream is in. Currently this means that `null` is never accepted |
| // and undefined/non-string values are only allowed in object mode. |
| function validChunk(stream, state, chunk, cb) { |
| var valid = true; |
| var er = false; |
| |
| if (chunk === null) { |
| er = new TypeError('May not write null values to stream'); |
| } else if (typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) { |
| er = new TypeError('Invalid non-string/buffer chunk'); |
| } |
| if (er) { |
| stream.emit('error', er); |
| pna.nextTick(cb, er); |
| valid = false; |
| } |
| return valid; |
| } |
| |
| Writable.prototype.write = function (chunk, encoding, cb) { |
| var state = this._writableState; |
| var ret = false; |
| var isBuf = !state.objectMode && _isUint8Array(chunk); |
| |
| if (isBuf && !Buffer.isBuffer(chunk)) { |
| chunk = _uint8ArrayToBuffer(chunk); |
| } |
| |
| if (typeof encoding === 'function') { |
| cb = encoding; |
| encoding = null; |
| } |
| |
| if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding; |
| |
| if (typeof cb !== 'function') cb = nop; |
| |
| if (state.ended) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) { |
| state.pendingcb++; |
| ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb); |
| } |
| |
| return ret; |
| }; |
| |
| Writable.prototype.cork = function () { |
| var state = this._writableState; |
| |
| state.corked++; |
| }; |
| |
| Writable.prototype.uncork = function () { |
| var state = this._writableState; |
| |
| if (state.corked) { |
| state.corked--; |
| |
| if (!state.writing && !state.corked && !state.finished && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state); |
| } |
| }; |
| |
| Writable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) { |
| // node::ParseEncoding() requires lower case. |
| if (typeof encoding === 'string') encoding = encoding.toLowerCase(); |
| if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new TypeError('Unknown encoding: ' + encoding); |
| this._writableState.defaultEncoding = encoding; |
| return this; |
| }; |
| |
| function decodeChunk(state, chunk, encoding) { |
| if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') { |
| chunk = Buffer.from(chunk, encoding); |
| } |
| return chunk; |
| } |
| |
| Object.defineProperty(Writable.prototype, 'writableHighWaterMark', { |
| // making it explicit this property is not enumerable |
| // because otherwise some prototype manipulation in |
| // userland will fail |
| enumerable: false, |
| get: function () { |
| return this._writableState.highWaterMark; |
| } |
| }); |
| |
| // if we're already writing something, then just put this |
| // in the queue, and wait our turn. Otherwise, call _write |
| // If we return false, then we need a drain event, so set that flag. |
| function writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) { |
| if (!isBuf) { |
| var newChunk = decodeChunk(state, chunk, encoding); |
| if (chunk !== newChunk) { |
| isBuf = true; |
| encoding = 'buffer'; |
| chunk = newChunk; |
| } |
| } |
| var len = state.objectMode ? 1 : chunk.length; |
| |
| state.length += len; |
| |
| var ret = state.length < state.highWaterMark; |
| // we must ensure that previous needDrain will not be reset to false. |
| if (!ret) state.needDrain = true; |
| |
| if (state.writing || state.corked) { |
| var last = state.lastBufferedRequest; |
| state.lastBufferedRequest = { |
| chunk: chunk, |
| encoding: encoding, |
| isBuf: isBuf, |
| callback: cb, |
| next: null |
| }; |
| if (last) { |
| last.next = state.lastBufferedRequest; |
| } else { |
| state.bufferedRequest = state.lastBufferedRequest; |
| } |
| state.bufferedRequestCount += 1; |
| } else { |
| doWrite(stream, state, false, len, chunk, encoding, cb); |
| } |
| |
| return ret; |
| } |
| |
| function doWrite(stream, state, writev, len, chunk, encoding, cb) { |
| state.writelen = len; |
| state.writecb = cb; |
| state.writing = true; |
| state.sync = true; |
| if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite); |
| state.sync = false; |
| } |
| |
| function onwriteError(stream, state, sync, er, cb) { |
| --state.pendingcb; |
| |
| if (sync) { |
| // defer the callback if we are being called synchronously |
| // to avoid piling up things on the stack |
| pna.nextTick(cb, er); |
| // this can emit finish, and it will always happen |
| // after error |
| pna.nextTick(finishMaybe, stream, state); |
| stream._writableState.errorEmitted = true; |
| stream.emit('error', er); |
| } else { |
| // the caller expect this to happen before if |
| // it is async |
| cb(er); |
| stream._writableState.errorEmitted = true; |
| stream.emit('error', er); |
| // this can emit finish, but finish must |
| // always follow error |
| finishMaybe(stream, state); |
| } |
| } |
| |
| function onwriteStateUpdate(state) { |
| state.writing = false; |
| state.writecb = null; |
| state.length -= state.writelen; |
| state.writelen = 0; |
| } |
| |
| function onwrite(stream, er) { |
| var state = stream._writableState; |
| var sync = state.sync; |
| var cb = state.writecb; |
| |
| onwriteStateUpdate(state); |
| |
| if (er) onwriteError(stream, state, sync, er, cb);else { |
| // Check if we're actually ready to finish, but don't emit yet |
| var finished = needFinish(state); |
| |
| if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) { |
| clearBuffer(stream, state); |
| } |
| |
| if (sync) { |
| /*<replacement>*/ |
| asyncWrite(afterWrite, stream, state, finished, cb); |
| /*</replacement>*/ |
| } else { |
| afterWrite(stream, state, finished, cb); |
| } |
| } |
| } |
| |
| function afterWrite(stream, state, finished, cb) { |
| if (!finished) onwriteDrain(stream, state); |
| state.pendingcb--; |
| cb(); |
| finishMaybe(stream, state); |
| } |
| |
| // Must force callback to be called on nextTick, so that we don't |
| // emit 'drain' before the write() consumer gets the 'false' return |
| // value, and has a chance to attach a 'drain' listener. |
| function onwriteDrain(stream, state) { |
| if (state.length === 0 && state.needDrain) { |
| state.needDrain = false; |
| stream.emit('drain'); |
| } |
| } |
| |
| // if there's something in the buffer waiting, then process it |
| function clearBuffer(stream, state) { |
| state.bufferProcessing = true; |
| var entry = state.bufferedRequest; |
| |
| if (stream._writev && entry && entry.next) { |
| // Fast case, write everything using _writev() |
| var l = state.bufferedRequestCount; |
| var buffer = new Array(l); |
| var holder = state.corkedRequestsFree; |
| holder.entry = entry; |
| |
| var count = 0; |
| var allBuffers = true; |
| while (entry) { |
| buffer[count] = entry; |
| if (!entry.isBuf) allBuffers = false; |
| entry = entry.next; |
| count += 1; |
| } |
| buffer.allBuffers = allBuffers; |
| |
| doWrite(stream, state, true, state.length, buffer, '', holder.finish); |
| |
| // doWrite is almost always async, defer these to save a bit of time |
| // as the hot path ends with doWrite |
| state.pendingcb++; |
| state.lastBufferedRequest = null; |
| if (holder.next) { |
| state.corkedRequestsFree = holder.next; |
| holder.next = null; |
| } else { |
| state.corkedRequestsFree = new CorkedRequest(state); |
| } |
| state.bufferedRequestCount = 0; |
| } else { |
| // Slow case, write chunks one-by-one |
| while (entry) { |
| var chunk = entry.chunk; |
| var encoding = entry.encoding; |
| var cb = entry.callback; |
| var len = state.objectMode ? 1 : chunk.length; |
| |
| doWrite(stream, state, false, len, chunk, encoding, cb); |
| entry = entry.next; |
| state.bufferedRequestCount--; |
| // if we didn't call the onwrite immediately, then |
| // it means that we need to wait until it does. |
| // also, that means that the chunk and cb are currently |
| // being processed, so move the buffer counter past them. |
| if (state.writing) { |
| break; |
| } |
| } |
| |
| if (entry === null) state.lastBufferedRequest = null; |
| } |
| |
| state.bufferedRequest = entry; |
| state.bufferProcessing = false; |
| } |
| |
| Writable.prototype._write = function (chunk, encoding, cb) { |
| cb(new Error('_write() is not implemented')); |
| }; |
| |
| Writable.prototype._writev = null; |
| |
| Writable.prototype.end = function (chunk, encoding, cb) { |
| var state = this._writableState; |
| |
| if (typeof chunk === 'function') { |
| cb = chunk; |
| chunk = null; |
| encoding = null; |
| } else if (typeof encoding === 'function') { |
| cb = encoding; |
| encoding = null; |
| } |
| |
| if (chunk !== null && chunk !== undefined) this.write(chunk, encoding); |
| |
| // .end() fully uncorks |
| if (state.corked) { |
| state.corked = 1; |
| this.uncork(); |
| } |
| |
| // ignore unnecessary end() calls. |
| if (!state.ending && !state.finished) endWritable(this, state, cb); |
| }; |
| |
| function needFinish(state) { |
| return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing; |
| } |
| function callFinal(stream, state) { |
| stream._final(function (err) { |
| state.pendingcb--; |
| if (err) { |
| stream.emit('error', err); |
| } |
| state.prefinished = true; |
| stream.emit('prefinish'); |
| finishMaybe(stream, state); |
| }); |
| } |
| function prefinish(stream, state) { |
| if (!state.prefinished && !state.finalCalled) { |
| if (typeof stream._final === 'function') { |
| state.pendingcb++; |
| state.finalCalled = true; |
| pna.nextTick(callFinal, stream, state); |
| } else { |
| state.prefinished = true; |
| stream.emit('prefinish'); |
| } |
| } |
| } |
| |
| function finishMaybe(stream, state) { |
| var need = needFinish(state); |
| if (need) { |
| prefinish(stream, state); |
| if (state.pendingcb === 0) { |
| state.finished = true; |
| stream.emit('finish'); |
| } |
| } |
| return need; |
| } |
| |
| function endWritable(stream, state, cb) { |
| state.ending = true; |
| finishMaybe(stream, state); |
| if (cb) { |
| if (state.finished) pna.nextTick(cb);else stream.once('finish', cb); |
| } |
| state.ended = true; |
| stream.writable = false; |
| } |
| |
| function onCorkedFinish(corkReq, state, err) { |
| var entry = corkReq.entry; |
| corkReq.entry = null; |
| while (entry) { |
| var cb = entry.callback; |
| state.pendingcb--; |
| cb(err); |
| entry = entry.next; |
| } |
| if (state.corkedRequestsFree) { |
| state.corkedRequestsFree.next = corkReq; |
| } else { |
| state.corkedRequestsFree = corkReq; |
| } |
| } |
| |
| Object.defineProperty(Writable.prototype, 'destroyed', { |
| get: function () { |
| if (this._writableState === undefined) { |
| return false; |
| } |
| return this._writableState.destroyed; |
| }, |
| set: function (value) { |
| // we ignore the value if the stream |
| // has not been initialized yet |
| if (!this._writableState) { |
| return; |
| } |
| |
| // backward compatibility, the user is explicitly |
| // managing destroyed |
| this._writableState.destroyed = value; |
| } |
| }); |
| |
| Writable.prototype.destroy = destroyImpl.destroy; |
| Writable.prototype._undestroy = destroyImpl.undestroy; |
| Writable.prototype._destroy = function (err, cb) { |
| this.end(); |
| cb(err); |
| }; |
| }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {},require("timers").setImmediate) |
| },{"./_stream_duplex":71,"./internal/streams/destroy":77,"./internal/streams/stream":78,"_process":69,"core-util-is":44,"inherits":56,"process-nextick-args":68,"safe-buffer":83,"timers":86,"util-deprecate":87}],76:[function(require,module,exports){ |
| 'use strict'; |
| |
| function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } |
| |
| var Buffer = require('safe-buffer').Buffer; |
| var util = require('util'); |
| |
| function copyBuffer(src, target, offset) { |
| src.copy(target, offset); |
| } |
| |
| module.exports = function () { |
| function BufferList() { |
| _classCallCheck(this, BufferList); |
| |
| this.head = null; |
| this.tail = null; |
| this.length = 0; |
| } |
| |
| BufferList.prototype.push = function push(v) { |
| var entry = { data: v, next: null }; |
| if (this.length > 0) this.tail.next = entry;else this.head = entry; |
| this.tail = entry; |
| ++this.length; |
| }; |
| |
| BufferList.prototype.unshift = function unshift(v) { |
| var entry = { data: v, next: this.head }; |
| if (this.length === 0) this.tail = entry; |
| this.head = entry; |
| ++this.length; |
| }; |
| |
| BufferList.prototype.shift = function shift() { |
| if (this.length === 0) return; |
| var ret = this.head.data; |
| if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next; |
| --this.length; |
| return ret; |
| }; |
| |
| BufferList.prototype.clear = function clear() { |
| this.head = this.tail = null; |
| this.length = 0; |
| }; |
| |
| BufferList.prototype.join = function join(s) { |
| if (this.length === 0) return ''; |
| var p = this.head; |
| var ret = '' + p.data; |
| while (p = p.next) { |
| ret += s + p.data; |
| }return ret; |
| }; |
| |
| BufferList.prototype.concat = function concat(n) { |
| if (this.length === 0) return Buffer.alloc(0); |
| if (this.length === 1) return this.head.data; |
| var ret = Buffer.allocUnsafe(n >>> 0); |
| var p = this.head; |
| var i = 0; |
| while (p) { |
| copyBuffer(p.data, ret, i); |
| i += p.data.length; |
| p = p.next; |
| } |
| return ret; |
| }; |
| |
| return BufferList; |
| }(); |
| |
| if (util && util.inspect && util.inspect.custom) { |
| module.exports.prototype[util.inspect.custom] = function () { |
| var obj = util.inspect({ length: this.length }); |
| return this.constructor.name + ' ' + obj; |
| }; |
| } |
| },{"safe-buffer":83,"util":40}],77:[function(require,module,exports){ |
| 'use strict'; |
| |
| /*<replacement>*/ |
| |
| var pna = require('process-nextick-args'); |
| /*</replacement>*/ |
| |
| // undocumented cb() API, needed for core, not for public API |
| function destroy(err, cb) { |
| var _this = this; |
| |
| var readableDestroyed = this._readableState && this._readableState.destroyed; |
| var writableDestroyed = this._writableState && this._writableState.destroyed; |
| |
| if (readableDestroyed || writableDestroyed) { |
| if (cb) { |
| cb(err); |
| } else if (err && (!this._writableState || !this._writableState.errorEmitted)) { |
| pna.nextTick(emitErrorNT, this, err); |
| } |
| return this; |
| } |
| |
| // we set destroyed to true before firing error callbacks in order |
| // to make it re-entrance safe in case destroy() is called within callbacks |
| |
| if (this._readableState) { |
| this._readableState.destroyed = true; |
| } |
| |
| // if this is a duplex stream mark the writable part as destroyed as well |
| if (this._writableState) { |
| this._writableState.destroyed = true; |
| } |
| |
| this._destroy(err || null, function (err) { |
| if (!cb && err) { |
| pna.nextTick(emitErrorNT, _this, err); |
| if (_this._writableState) { |
| _this._writableState.errorEmitted = true; |
| } |
| } else if (cb) { |
| cb(err); |
| } |
| }); |
| |
| return this; |
| } |
| |
| function undestroy() { |
| if (this._readableState) { |
| this._readableState.destroyed = false; |
| this._readableState.reading = false; |
| this._readableState.ended = false; |
| this._readableState.endEmitted = false; |
| } |
| |
| if (this._writableState) { |
| this._writableState.destroyed = false; |
| this._writableState.ended = false; |
| this._writableState.ending = false; |
| this._writableState.finished = false; |
| this._writableState.errorEmitted = false; |
| } |
| } |
| |
| function emitErrorNT(self, err) { |
| self.emit('error', err); |
| } |
| |
| module.exports = { |
| destroy: destroy, |
| undestroy: undestroy |
| }; |
| },{"process-nextick-args":68}],78:[function(require,module,exports){ |
| module.exports = require('events').EventEmitter; |
| |
| },{"events":50}],79:[function(require,module,exports){ |
| module.exports = require('./readable').PassThrough |
| |
| },{"./readable":80}],80:[function(require,module,exports){ |
| exports = module.exports = require('./lib/_stream_readable.js'); |
| exports.Stream = exports; |
| exports.Readable = exports; |
| exports.Writable = require('./lib/_stream_writable.js'); |
| exports.Duplex = require('./lib/_stream_duplex.js'); |
| exports.Transform = require('./lib/_stream_transform.js'); |
| exports.PassThrough = require('./lib/_stream_passthrough.js'); |
| |
| },{"./lib/_stream_duplex.js":71,"./lib/_stream_passthrough.js":72,"./lib/_stream_readable.js":73,"./lib/_stream_transform.js":74,"./lib/_stream_writable.js":75}],81:[function(require,module,exports){ |
| module.exports = require('./readable').Transform |
| |
| },{"./readable":80}],82:[function(require,module,exports){ |
| module.exports = require('./lib/_stream_writable.js'); |
| |
| },{"./lib/_stream_writable.js":75}],83:[function(require,module,exports){ |
| /* eslint-disable node/no-deprecated-api */ |
| var buffer = require('buffer') |
| var Buffer = buffer.Buffer |
| |
| // alternative to using Object.keys for old browsers |
| function copyProps (src, dst) { |
| for (var key in src) { |
| dst[key] = src[key] |
| } |
| } |
| if (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) { |
| module.exports = buffer |
| } else { |
| // Copy properties from require('buffer') |
| copyProps(buffer, exports) |
| exports.Buffer = SafeBuffer |
| } |
| |
| function SafeBuffer (arg, encodingOrOffset, length) { |
| return Buffer(arg, encodingOrOffset, length) |
| } |
| |
| // Copy static methods from Buffer |
| copyProps(Buffer, SafeBuffer) |
| |
| SafeBuffer.from = function (arg, encodingOrOffset, length) { |
| if (typeof arg === 'number') { |
| throw new TypeError('Argument must not be a number') |
| } |
| return Buffer(arg, encodingOrOffset, length) |
| } |
| |
| SafeBuffer.alloc = function (size, fill, encoding) { |
| if (typeof size !== 'number') { |
| throw new TypeError('Argument must be a number') |
| } |
| var buf = Buffer(size) |
| if (fill !== undefined) { |
| if (typeof encoding === 'string') { |
| buf.fill(fill, encoding) |
| } else { |
| buf.fill(fill) |
| } |
| } else { |
| buf.fill(0) |
| } |
| return buf |
| } |
| |
| SafeBuffer.allocUnsafe = function (size) { |
| if (typeof size !== 'number') { |
| throw new TypeError('Argument must be a number') |
| } |
| return Buffer(size) |
| } |
| |
| SafeBuffer.allocUnsafeSlow = function (size) { |
| if (typeof size !== 'number') { |
| throw new TypeError('Argument must be a number') |
| } |
| return buffer.SlowBuffer(size) |
| } |
| |
| },{"buffer":43}],84:[function(require,module,exports){ |
| // Copyright Joyent, Inc. and other Node contributors. |
| // |
| // Permission is hereby granted, free of charge, to any person obtaining a |
| // copy of this software and associated documentation files (the |
| // "Software"), to deal in the Software without restriction, including |
| // without limitation the rights to use, copy, modify, merge, publish, |
| // distribute, sublicense, and/or sell copies of the Software, and to permit |
| // persons to whom the Software is furnished to do so, subject to the |
| // following conditions: |
| // |
| // The above copyright notice and this permission notice shall be included |
| // in all copies or substantial portions of the Software. |
| // |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN |
| // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
| // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
| // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE |
| // USE OR OTHER DEALINGS IN THE SOFTWARE. |
| |
| module.exports = Stream; |
| |
| var EE = require('events').EventEmitter; |
| var inherits = require('inherits'); |
| |
| inherits(Stream, EE); |
| Stream.Readable = require('readable-stream/readable.js'); |
| Stream.Writable = require('readable-stream/writable.js'); |
| Stream.Duplex = require('readable-stream/duplex.js'); |
| Stream.Transform = require('readable-stream/transform.js'); |
| Stream.PassThrough = require('readable-stream/passthrough.js'); |
| |
| // Backwards-compat with node 0.4.x |
| Stream.Stream = Stream; |
| |
| |
| |
| // old-style streams. Note that the pipe method (the only relevant |
| // part of this class) is overridden in the Readable class. |
| |
| function Stream() { |
| EE.call(this); |
| } |
| |
| Stream.prototype.pipe = function(dest, options) { |
| var source = this; |
| |
| function ondata(chunk) { |
| if (dest.writable) { |
| if (false === dest.write(chunk) && source.pause) { |
| source.pause(); |
| } |
| } |
| } |
| |
| source.on('data', ondata); |
| |
| function ondrain() { |
| if (source.readable && source.resume) { |
| source.resume(); |
| } |
| } |
| |
| dest.on('drain', ondrain); |
| |
| // If the 'end' option is not supplied, dest.end() will be called when |
| // source gets the 'end' or 'close' events. Only dest.end() once. |
| if (!dest._isStdio && (!options || options.end !== false)) { |
| source.on('end', onend); |
| source.on('close', onclose); |
| } |
| |
| var didOnEnd = false; |
| function onend() { |
| if (didOnEnd) return; |
| didOnEnd = true; |
| |
| dest.end(); |
| } |
| |
| |
| function onclose() { |
| if (didOnEnd) return; |
| didOnEnd = true; |
| |
| if (typeof dest.destroy === 'function') dest.destroy(); |
| } |
| |
| // don't leave dangling pipes when there are errors. |
| function onerror(er) { |
| cleanup(); |
| if (EE.listenerCount(this, 'error') === 0) { |
| throw er; // Unhandled stream error in pipe. |
| } |
| } |
| |
| source.on('error', onerror); |
| dest.on('error', onerror); |
| |
| // remove all the event listeners that were added. |
| function cleanup() { |
| source.removeListener('data', ondata); |
| dest.removeListener('drain', ondrain); |
| |
| source.removeListener('end', onend); |
| source.removeListener('close', onclose); |
| |
| source.removeListener('error', onerror); |
| dest.removeListener('error', onerror); |
| |
| source.removeListener('end', cleanup); |
| source.removeListener('close', cleanup); |
| |
| dest.removeListener('close', cleanup); |
| } |
| |
| source.on('end', cleanup); |
| source.on('close', cleanup); |
| |
| dest.on('close', cleanup); |
| |
| dest.emit('pipe', source); |
| |
| // Allow for unix-like usage: A.pipe(B).pipe(C) |
| return dest; |
| }; |
| |
| },{"events":50,"inherits":56,"readable-stream/duplex.js":70,"readable-stream/passthrough.js":79,"readable-stream/readable.js":80,"readable-stream/transform.js":81,"readable-stream/writable.js":82}],85:[function(require,module,exports){ |
| // Copyright Joyent, Inc. and other Node contributors. |
| // |
| // Permission is hereby granted, free of charge, to any person obtaining a |
| // copy of this software and associated documentation files (the |
| // "Software"), to deal in the Software without restriction, including |
| // without limitation the rights to use, copy, modify, merge, publish, |
| // distribute, sublicense, and/or sell copies of the Software, and to permit |
| // persons to whom the Software is furnished to do so, subject to the |
| // following conditions: |
| // |
| // The above copyright notice and this permission notice shall be included |
| // in all copies or substantial portions of the Software. |
| // |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN |
| // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
| // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
| // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE |
| // USE OR OTHER DEALINGS IN THE SOFTWARE. |
| |
| 'use strict'; |
| |
| /*<replacement>*/ |
| |
| var Buffer = require('safe-buffer').Buffer; |
| /*</replacement>*/ |
| |
| var isEncoding = Buffer.isEncoding || function (encoding) { |
| encoding = '' + encoding; |
| switch (encoding && encoding.toLowerCase()) { |
| case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw': |
| return true; |
| default: |
| return false; |
| } |
| }; |
| |
| function _normalizeEncoding(enc) { |
| if (!enc) return 'utf8'; |
| var retried; |
| while (true) { |
| switch (enc) { |
| case 'utf8': |
| case 'utf-8': |
| return 'utf8'; |
| case 'ucs2': |
| case 'ucs-2': |
| case 'utf16le': |
| case 'utf-16le': |
| return 'utf16le'; |
| case 'latin1': |
| case 'binary': |
| return 'latin1'; |
| case 'base64': |
| case 'ascii': |
| case 'hex': |
| return enc; |
| default: |
| if (retried) return; // undefined |
| enc = ('' + enc).toLowerCase(); |
| retried = true; |
| } |
| } |
| }; |
| |
| // Do not cache `Buffer.isEncoding` when checking encoding names as some |
| // modules monkey-patch it to support additional encodings |
| function normalizeEncoding(enc) { |
| var nenc = _normalizeEncoding(enc); |
| if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc); |
| return nenc || enc; |
| } |
| |
| // StringDecoder provides an interface for efficiently splitting a series of |
| // buffers into a series of JS strings without breaking apart multi-byte |
| // characters. |
| exports.StringDecoder = StringDecoder; |
| function StringDecoder(encoding) { |
| this.encoding = normalizeEncoding(encoding); |
| var nb; |
| switch (this.encoding) { |
| case 'utf16le': |
| this.text = utf16Text; |
| this.end = utf16End; |
| nb = 4; |
| break; |
| case 'utf8': |
| this.fillLast = utf8FillLast; |
| nb = 4; |
| break; |
| case 'base64': |
| this.text = base64Text; |
| this.end = base64End; |
| nb = 3; |
| break; |
| default: |
| this.write = simpleWrite; |
| this.end = simpleEnd; |
| return; |
| } |
| this.lastNeed = 0; |
| this.lastTotal = 0; |
| this.lastChar = Buffer.allocUnsafe(nb); |
| } |
| |
| StringDecoder.prototype.write = function (buf) { |
| if (buf.length === 0) return ''; |
| var r; |
| var i; |
| if (this.lastNeed) { |
| r = this.fillLast(buf); |
| if (r === undefined) return ''; |
| i = this.lastNeed; |
| this.lastNeed = 0; |
| } else { |
| i = 0; |
| } |
| if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i); |
| return r || ''; |
| }; |
| |
| StringDecoder.prototype.end = utf8End; |
| |
| // Returns only complete characters in a Buffer |
| StringDecoder.prototype.text = utf8Text; |
| |
| // Attempts to complete a partial non-UTF-8 character using bytes from a Buffer |
| StringDecoder.prototype.fillLast = function (buf) { |
| if (this.lastNeed <= buf.length) { |
| buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed); |
| return this.lastChar.toString(this.encoding, 0, this.lastTotal); |
| } |
| buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length); |
| this.lastNeed -= buf.length; |
| }; |
| |
| // Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a |
| // continuation byte. If an invalid byte is detected, -2 is returned. |
| function utf8CheckByte(byte) { |
| if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4; |
| return byte >> 6 === 0x02 ? -1 : -2; |
| } |
| |
| // Checks at most 3 bytes at the end of a Buffer in order to detect an |
| // incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4) |
| // needed to complete the UTF-8 character (if applicable) are returned. |
| function utf8CheckIncomplete(self, buf, i) { |
| var j = buf.length - 1; |
| if (j < i) return 0; |
| var nb = utf8CheckByte(buf[j]); |
| if (nb >= 0) { |
| if (nb > 0) self.lastNeed = nb - 1; |
| return nb; |
| } |
| if (--j < i || nb === -2) return 0; |
| nb = utf8CheckByte(buf[j]); |
| if (nb >= 0) { |
| if (nb > 0) self.lastNeed = nb - 2; |
| return nb; |
| } |
| if (--j < i || nb === -2) return 0; |
| nb = utf8CheckByte(buf[j]); |
| if (nb >= 0) { |
| if (nb > 0) { |
| if (nb === 2) nb = 0;else self.lastNeed = nb - 3; |
| } |
| return nb; |
| } |
| return 0; |
| } |
| |
| // Validates as many continuation bytes for a multi-byte UTF-8 character as |
| // needed or are available. If we see a non-continuation byte where we expect |
| // one, we "replace" the validated continuation bytes we've seen so far with |
| // a single UTF-8 replacement character ('\ufffd'), to match v8's UTF-8 decoding |
| // behavior. The continuation byte check is included three times in the case |
| // where all of the continuation bytes for a character exist in the same buffer. |
| // It is also done this way as a slight performance increase instead of using a |
| // loop. |
| function utf8CheckExtraBytes(self, buf, p) { |
| if ((buf[0] & 0xC0) !== 0x80) { |
| self.lastNeed = 0; |
| return '\ufffd'; |
| } |
| if (self.lastNeed > 1 && buf.length > 1) { |
| if ((buf[1] & 0xC0) !== 0x80) { |
| self.lastNeed = 1; |
| return '\ufffd'; |
| } |
| if (self.lastNeed > 2 && buf.length > 2) { |
| if ((buf[2] & 0xC0) !== 0x80) { |
| self.lastNeed = 2; |
| return '\ufffd'; |
| } |
| } |
| } |
| } |
| |
| // Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer. |
| function utf8FillLast(buf) { |
| var p = this.lastTotal - this.lastNeed; |
| var r = utf8CheckExtraBytes(this, buf, p); |
| if (r !== undefined) return r; |
| if (this.lastNeed <= buf.length) { |
| buf.copy(this.lastChar, p, 0, this.lastNeed); |
| return this.lastChar.toString(this.encoding, 0, this.lastTotal); |
| } |
| buf.copy(this.lastChar, p, 0, buf.length); |
| this.lastNeed -= buf.length; |
| } |
| |
| // Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a |
| // partial character, the character's bytes are buffered until the required |
| // number of bytes are available. |
| function utf8Text(buf, i) { |
| var total = utf8CheckIncomplete(this, buf, i); |
| if (!this.lastNeed) return buf.toString('utf8', i); |
| this.lastTotal = total; |
| var end = buf.length - (total - this.lastNeed); |
| buf.copy(this.lastChar, 0, end); |
| return buf.toString('utf8', i, end); |
| } |
| |
| // For UTF-8, a replacement character is added when ending on a partial |
| // character. |
| function utf8End(buf) { |
| var r = buf && buf.length ? this.write(buf) : ''; |
| if (this.lastNeed) return r + '\ufffd'; |
| return r; |
| } |
| |
| // UTF-16LE typically needs two bytes per character, but even if we have an even |
| // number of bytes available, we need to check if we end on a leading/high |
| // surrogate. In that case, we need to wait for the next two bytes in order to |
| // decode the last character properly. |
| function utf16Text(buf, i) { |
| if ((buf.length - i) % 2 === 0) { |
| var r = buf.toString('utf16le', i); |
| if (r) { |
| var c = r.charCodeAt(r.length - 1); |
| if (c >= 0xD800 && c <= 0xDBFF) { |
| this.lastNeed = 2; |
| this.lastTotal = 4; |
| this.lastChar[0] = buf[buf.length - 2]; |
| this.lastChar[1] = buf[buf.length - 1]; |
| return r.slice(0, -1); |
| } |
| } |
| return r; |
| } |
| this.lastNeed = 1; |
| this.lastTotal = 2; |
| this.lastChar[0] = buf[buf.length - 1]; |
| return buf.toString('utf16le', i, buf.length - 1); |
| } |
| |
| // For UTF-16LE we do not explicitly append special replacement characters if we |
| // end on a partial character, we simply let v8 handle that. |
| function utf16End(buf) { |
| var r = buf && buf.length ? this.write(buf) : ''; |
| if (this.lastNeed) { |
| var end = this.lastTotal - this.lastNeed; |
| return r + this.lastChar.toString('utf16le', 0, end); |
| } |
| return r; |
| } |
| |
| function base64Text(buf, i) { |
| var n = (buf.length - i) % 3; |
| if (n === 0) return buf.toString('base64', i); |
| this.lastNeed = 3 - n; |
| this.lastTotal = 3; |
| if (n === 1) { |
| this.lastChar[0] = buf[buf.length - 1]; |
| } else { |
| this.lastChar[0] = buf[buf.length - 2]; |
| this.lastChar[1] = buf[buf.length - 1]; |
| } |
| return buf.toString('base64', i, buf.length - n); |
| } |
| |
| function base64End(buf) { |
| var r = buf && buf.length ? this.write(buf) : ''; |
| if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed); |
| return r; |
| } |
| |
| // Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex) |
| function simpleWrite(buf) { |
| return buf.toString(this.encoding); |
| } |
| |
| function simpleEnd(buf) { |
| return buf && buf.length ? this.write(buf) : ''; |
| } |
| },{"safe-buffer":83}],86:[function(require,module,exports){ |
| (function (setImmediate,clearImmediate){ |
| var nextTick = require('process/browser.js').nextTick; |
| var apply = Function.prototype.apply; |
| var slice = Array.prototype.slice; |
| var immediateIds = {}; |
| var nextImmediateId = 0; |
| |
| // DOM APIs, for completeness |
| |
| exports.setTimeout = function() { |
| return new Timeout(apply.call(setTimeout, window, arguments), clearTimeout); |
| }; |
| exports.setInterval = function() { |
| return new Timeout(apply.call(setInterval, window, arguments), clearInterval); |
| }; |
| exports.clearTimeout = |
| exports.clearInterval = function(timeout) { timeout.close(); }; |
| |
| function Timeout(id, clearFn) { |
| this._id = id; |
| this._clearFn = clearFn; |
| } |
| Timeout.prototype.unref = Timeout.prototype.ref = function() {}; |
| Timeout.prototype.close = function() { |
| this._clearFn.call(window, this._id); |
| }; |
| |
| // Does not start the time, just sets up the members needed. |
| exports.enroll = function(item, msecs) { |
| clearTimeout(item._idleTimeoutId); |
| item._idleTimeout = msecs; |
| }; |
| |
| exports.unenroll = function(item) { |
| clearTimeout(item._idleTimeoutId); |
| item._idleTimeout = -1; |
| }; |
| |
| exports._unrefActive = exports.active = function(item) { |
| clearTimeout(item._idleTimeoutId); |
| |
| var msecs = item._idleTimeout; |
| if (msecs >= 0) { |
| item._idleTimeoutId = setTimeout(function onTimeout() { |
| if (item._onTimeout) |
| item._onTimeout(); |
| }, msecs); |
| } |
| }; |
| |
| // That's not how node.js implements it but the exposed api is the same. |
| exports.setImmediate = typeof setImmediate === "function" ? setImmediate : function(fn) { |
| var id = nextImmediateId++; |
| var args = arguments.length < 2 ? false : slice.call(arguments, 1); |
| |
| immediateIds[id] = true; |
| |
| nextTick(function onNextTick() { |
| if (immediateIds[id]) { |
| // fn.call() is faster so we optimize for the common use-case |
| // @see http://jsperf.com/call-apply-segu |
| if (args) { |
| fn.apply(null, args); |
| } else { |
| fn.call(null); |
| } |
| // Prevent ids from leaking |
| exports.clearImmediate(id); |
| } |
| }); |
| |
| return id; |
| }; |
| |
| exports.clearImmediate = typeof clearImmediate === "function" ? clearImmediate : function(id) { |
| delete immediateIds[id]; |
| }; |
| }).call(this,require("timers").setImmediate,require("timers").clearImmediate) |
| },{"process/browser.js":69,"timers":86}],87:[function(require,module,exports){ |
| (function (global){ |
| |
| /** |
| * Module exports. |
| */ |
| |
| module.exports = deprecate; |
| |
| /** |
| * Mark that a method should not be used. |
| * Returns a modified function which warns once by default. |
| * |
| * If `localStorage.noDeprecation = true` is set, then it is a no-op. |
| * |
| * If `localStorage.throwDeprecation = true` is set, then deprecated functions |
| * will throw an Error when invoked. |
| * |
| * If `localStorage.traceDeprecation = true` is set, then deprecated functions |
| * will invoke `console.trace()` instead of `console.error()`. |
| * |
| * @param {Function} fn - the function to deprecate |
| * @param {String} msg - the string to print to the console when `fn` is invoked |
| * @returns {Function} a new "deprecated" version of `fn` |
| * @api public |
| */ |
| |
| function deprecate (fn, msg) { |
| if (config('noDeprecation')) { |
| return fn; |
| } |
| |
| var warned = false; |
| function deprecated() { |
| if (!warned) { |
| if (config('throwDeprecation')) { |
| throw new Error(msg); |
| } else if (config('traceDeprecation')) { |
| console.trace(msg); |
| } else { |
| console.warn(msg); |
| } |
| warned = true; |
| } |
| return fn.apply(this, arguments); |
| } |
| |
| return deprecated; |
| } |
| |
| /** |
| * Checks `localStorage` for boolean values for the given `name`. |
| * |
| * @param {String} name |
| * @returns {Boolean} |
| * @api private |
| */ |
| |
| function config (name) { |
| // accessing global.localStorage can trigger a DOMException in sandboxed iframes |
| try { |
| if (!global.localStorage) return false; |
| } catch (_) { |
| return false; |
| } |
| var val = global.localStorage[name]; |
| if (null == val) return false; |
| return String(val).toLowerCase() === 'true'; |
| } |
| |
| }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{}],88:[function(require,module,exports){ |
| module.exports = function isBuffer(arg) { |
| return arg && typeof arg === 'object' |
| && typeof arg.copy === 'function' |
| && typeof arg.fill === 'function' |
| && typeof arg.readUInt8 === 'function'; |
| } |
| },{}],89:[function(require,module,exports){ |
| (function (process,global){ |
| // Copyright Joyent, Inc. and other Node contributors. |
| // |
| // Permission is hereby granted, free of charge, to any person obtaining a |
| // copy of this software and associated documentation files (the |
| // "Software"), to deal in the Software without restriction, including |
| // without limitation the rights to use, copy, modify, merge, publish, |
| // distribute, sublicense, and/or sell copies of the Software, and to permit |
| // persons to whom the Software is furnished to do so, subject to the |
| // following conditions: |
| // |
| // The above copyright notice and this permission notice shall be included |
| // in all copies or substantial portions of the Software. |
| // |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN |
| // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
| // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
| // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE |
| // USE OR OTHER DEALINGS IN THE SOFTWARE. |
| |
| var formatRegExp = /%[sdj%]/g; |
| exports.format = function(f) { |
| if (!isString(f)) { |
| var objects = []; |
| for (var i = 0; i < arguments.length; i++) { |
| objects.push(inspect(arguments[i])); |
| } |
| return objects.join(' '); |
| } |
| |
| var i = 1; |
| var args = arguments; |
| var len = args.length; |
| var str = String(f).replace(formatRegExp, function(x) { |
| if (x === '%%') return '%'; |
| if (i >= len) return x; |
| switch (x) { |
| case '%s': return String(args[i++]); |
| case '%d': return Number(args[i++]); |
| case '%j': |
| try { |
| return JSON.stringify(args[i++]); |
| } catch (_) { |
| return '[Circular]'; |
| } |
| default: |
| return x; |
| } |
| }); |
| for (var x = args[i]; i < len; x = args[++i]) { |
| if (isNull(x) || !isObject(x)) { |
| str += ' ' + x; |
| } else { |
| str += ' ' + inspect(x); |
| } |
| } |
| return str; |
| }; |
| |
| |
| // Mark that a method should not be used. |
| // Returns a modified function which warns once by default. |
| // If --no-deprecation is set, then it is a no-op. |
| exports.deprecate = function(fn, msg) { |
| // Allow for deprecating things in the process of starting up. |
| if (isUndefined(global.process)) { |
| return function() { |
| return exports.deprecate(fn, msg).apply(this, arguments); |
| }; |
| } |
| |
| if (process.noDeprecation === true) { |
| return fn; |
| } |
| |
| var warned = false; |
| function deprecated() { |
| if (!warned) { |
| if (process.throwDeprecation) { |
| throw new Error(msg); |
| } else if (process.traceDeprecation) { |
| console.trace(msg); |
| } else { |
| console.error(msg); |
| } |
| warned = true; |
| } |
| return fn.apply(this, arguments); |
| } |
| |
| return deprecated; |
| }; |
| |
| |
| var debugs = {}; |
| var debugEnviron; |
| exports.debuglog = function(set) { |
| if (isUndefined(debugEnviron)) |
| debugEnviron = process.env.NODE_DEBUG || ''; |
| set = set.toUpperCase(); |
| if (!debugs[set]) { |
| if (new RegExp('\\b' + set + '\\b', 'i').test(debugEnviron)) { |
| var pid = process.pid; |
| debugs[set] = function() { |
| var msg = exports.format.apply(exports, arguments); |
| console.error('%s %d: %s', set, pid, msg); |
| }; |
| } else { |
| debugs[set] = function() {}; |
| } |
| } |
| return debugs[set]; |
| }; |
| |
| |
| /** |
| * Echos the value of a value. Trys to print the value out |
| * in the best way possible given the different types. |
| * |
| * @param {Object} obj The object to print out. |
| * @param {Object} opts Optional options object that alters the output. |
| */ |
| /* legacy: obj, showHidden, depth, colors*/ |
| function inspect(obj, opts) { |
| // default options |
| var ctx = { |
| seen: [], |
| stylize: stylizeNoColor |
| }; |
| // legacy... |
| if (arguments.length >= 3) ctx.depth = arguments[2]; |
| if (arguments.length >= 4) ctx.colors = arguments[3]; |
| if (isBoolean(opts)) { |
| // legacy... |
| ctx.showHidden = opts; |
| } else if (opts) { |
| // got an "options" object |
| exports._extend(ctx, opts); |
| } |
| // set default options |
| if (isUndefined(ctx.showHidden)) ctx.showHidden = false; |
| if (isUndefined(ctx.depth)) ctx.depth = 2; |
| if (isUndefined(ctx.colors)) ctx.colors = false; |
| if (isUndefined(ctx.customInspect)) ctx.customInspect = true; |
| if (ctx.colors) ctx.stylize = stylizeWithColor; |
| return formatValue(ctx, obj, ctx.depth); |
| } |
| exports.inspect = inspect; |
| |
| |
| // http://en.wikipedia.org/wiki/ANSI_escape_code#graphics |
| inspect.colors = { |
| 'bold' : [1, 22], |
| 'italic' : [3, 23], |
| 'underline' : [4, 24], |
| 'inverse' : [7, 27], |
| 'white' : [37, 39], |
| 'grey' : [90, 39], |
| 'black' : [30, 39], |
| 'blue' : [34, 39], |
| 'cyan' : [36, 39], |
| 'green' : [32, 39], |
| 'magenta' : [35, 39], |
| 'red' : [31, 39], |
| 'yellow' : [33, 39] |
| }; |
| |
| // Don't use 'blue' not visible on cmd.exe |
| inspect.styles = { |
| 'special': 'cyan', |
| 'number': 'yellow', |
| 'boolean': 'yellow', |
| 'undefined': 'grey', |
| 'null': 'bold', |
| 'string': 'green', |
| 'date': 'magenta', |
| // "name": intentionally not styling |
| 'regexp': 'red' |
| }; |
| |
| |
| function stylizeWithColor(str, styleType) { |
| var style = inspect.styles[styleType]; |
| |
| if (style) { |
| return '\u001b[' + inspect.colors[style][0] + 'm' + str + |
| '\u001b[' + inspect.colors[style][1] + 'm'; |
| } else { |
| return str; |
| } |
| } |
| |
| |
| function stylizeNoColor(str, styleType) { |
| return str; |
| } |
| |
| |
| function arrayToHash(array) { |
| var hash = {}; |
| |
| array.forEach(function(val, idx) { |
| hash[val] = true; |
| }); |
| |
| return hash; |
| } |
| |
| |
| function formatValue(ctx, value, recurseTimes) { |
| // Provide a hook for user-specified inspect functions. |
| // Check that value is an object with an inspect function on it |
| if (ctx.customInspect && |
| value && |
| isFunction(value.inspect) && |
| // Filter out the util module, it's inspect function is special |
| value.inspect !== exports.inspect && |
| // Also filter out any prototype objects using the circular check. |
| !(value.constructor && value.constructor.prototype === value)) { |
| var ret = value.inspect(recurseTimes, ctx); |
| if (!isString(ret)) { |
| ret = formatValue(ctx, ret, recurseTimes); |
| } |
| return ret; |
| } |
| |
| // Primitive types cannot have properties |
| var primitive = formatPrimitive(ctx, value); |
| if (primitive) { |
| return primitive; |
| } |
| |
| // Look up the keys of the object. |
| var keys = Object.keys(value); |
| var visibleKeys = arrayToHash(keys); |
| |
| if (ctx.showHidden) { |
| keys = Object.getOwnPropertyNames(value); |
| } |
| |
| // IE doesn't make error fields non-enumerable |
| // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx |
| if (isError(value) |
| && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) { |
| return formatError(value); |
| } |
| |
| // Some type of object without properties can be shortcutted. |
| if (keys.length === 0) { |
| if (isFunction(value)) { |
| var name = value.name ? ': ' + value.name : ''; |
| return ctx.stylize('[Function' + name + ']', 'special'); |
| } |
| if (isRegExp(value)) { |
| return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp'); |
| } |
| if (isDate(value)) { |
| return ctx.stylize(Date.prototype.toString.call(value), 'date'); |
| } |
| if (isError(value)) { |
| return formatError(value); |
| } |
| } |
| |
| var base = '', array = false, braces = ['{', '}']; |
| |
| // Make Array say that they are Array |
| if (isArray(value)) { |
| array = true; |
| braces = ['[', ']']; |
| } |
| |
| // Make functions say that they are functions |
| if (isFunction(value)) { |
| var n = value.name ? ': ' + value.name : ''; |
| base = ' [Function' + n + ']'; |
| } |
| |
| // Make RegExps say that they are RegExps |
| if (isRegExp(value)) { |
| base = ' ' + RegExp.prototype.toString.call(value); |
| } |
| |
| // Make dates with properties first say the date |
| if (isDate(value)) { |
| base = ' ' + Date.prototype.toUTCString.call(value); |
| } |
| |
| // Make error with message first say the error |
| if (isError(value)) { |
| base = ' ' + formatError(value); |
| } |
| |
| if (keys.length === 0 && (!array || value.length == 0)) { |
| return braces[0] + base + braces[1]; |
| } |
| |
| if (recurseTimes < 0) { |
| if (isRegExp(value)) { |
| return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp'); |
| } else { |
| return ctx.stylize('[Object]', 'special'); |
| } |
| } |
| |
| ctx.seen.push(value); |
| |
| var output; |
| if (array) { |
| output = formatArray(ctx, value, recurseTimes, visibleKeys, keys); |
| } else { |
| output = keys.map(function(key) { |
| return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array); |
| }); |
| } |
| |
| ctx.seen.pop(); |
| |
| return reduceToSingleString(output, base, braces); |
| } |
| |
| |
| function formatPrimitive(ctx, value) { |
| if (isUndefined(value)) |
| return ctx.stylize('undefined', 'undefined'); |
| if (isString(value)) { |
| var simple = '\'' + JSON.stringify(value).replace(/^"|"$/g, '') |
| .replace(/'/g, "\\'") |
| .replace(/\\"/g, '"') + '\''; |
| return ctx.stylize(simple, 'string'); |
| } |
| if (isNumber(value)) |
| return ctx.stylize('' + value, 'number'); |
| if (isBoolean(value)) |
| return ctx.stylize('' + value, 'boolean'); |
| // For some reason typeof null is "object", so special case here. |
| if (isNull(value)) |
| return ctx.stylize('null', 'null'); |
| } |
| |
| |
| function formatError(value) { |
| return '[' + Error.prototype.toString.call(value) + ']'; |
| } |
| |
| |
| function formatArray(ctx, value, recurseTimes, visibleKeys, keys) { |
| var output = []; |
| for (var i = 0, l = value.length; i < l; ++i) { |
| if (hasOwnProperty(value, String(i))) { |
| output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, |
| String(i), true)); |
| } else { |
| output.push(''); |
| } |
| } |
| keys.forEach(function(key) { |
| if (!key.match(/^\d+$/)) { |
| output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, |
| key, true)); |
| } |
| }); |
| return output; |
| } |
| |
| |
| function formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) { |
| var name, str, desc; |
| desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] }; |
| if (desc.get) { |
| if (desc.set) { |
| str = ctx.stylize('[Getter/Setter]', 'special'); |
| } else { |
| str = ctx.stylize('[Getter]', 'special'); |
| } |
| } else { |
| if (desc.set) { |
| str = ctx.stylize('[Setter]', 'special'); |
| } |
| } |
| if (!hasOwnProperty(visibleKeys, key)) { |
| name = '[' + key + ']'; |
| } |
| if (!str) { |
| if (ctx.seen.indexOf(desc.value) < 0) { |
| if (isNull(recurseTimes)) { |
| str = formatValue(ctx, desc.value, null); |
| } else { |
| str = formatValue(ctx, desc.value, recurseTimes - 1); |
| } |
| if (str.indexOf('\n') > -1) { |
| if (array) { |
| str = str.split('\n').map(function(line) { |
| return ' ' + line; |
| }).join('\n').substr(2); |
| } else { |
| str = '\n' + str.split('\n').map(function(line) { |
| return ' ' + line; |
| }).join('\n'); |
| } |
| } |
| } else { |
| str = ctx.stylize('[Circular]', 'special'); |
| } |
| } |
| if (isUndefined(name)) { |
| if (array && key.match(/^\d+$/)) { |
| return str; |
| } |
| name = JSON.stringify('' + key); |
| if (name.match(/^"([a-zA-Z_][a-zA-Z_0-9]*)"$/)) { |
| name = name.substr(1, name.length - 2); |
| name = ctx.stylize(name, 'name'); |
| } else { |
| name = name.replace(/'/g, "\\'") |
| .replace(/\\"/g, '"') |
| .replace(/(^"|"$)/g, "'"); |
| name = ctx.stylize(name, 'string'); |
| } |
| } |
| |
| return name + ': ' + str; |
| } |
| |
| |
| function reduceToSingleString(output, base, braces) { |
| var numLinesEst = 0; |
| var length = output.reduce(function(prev, cur) { |
| numLinesEst++; |
| if (cur.indexOf('\n') >= 0) numLinesEst++; |
| return prev + cur.replace(/\u001b\[\d\d?m/g, '').length + 1; |
| }, 0); |
| |
| if (length > 60) { |
| return braces[0] + |
| (base === '' ? '' : base + '\n ') + |
| ' ' + |
| output.join(',\n ') + |
| ' ' + |
| braces[1]; |
| } |
| |
| return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1]; |
| } |
| |
| |
| // NOTE: These type checking functions intentionally don't use `instanceof` |
| // because it is fragile and can be easily faked with `Object.create()`. |
| function isArray(ar) { |
| return Array.isArray(ar); |
| } |
| exports.isArray = isArray; |
| |
| function isBoolean(arg) { |
| return typeof arg === 'boolean'; |
| } |
| exports.isBoolean = isBoolean; |
| |
| function isNull(arg) { |
| return arg === null; |
| } |
| exports.isNull = isNull; |
| |
| function isNullOrUndefined(arg) { |
| return arg == null; |
| } |
| exports.isNullOrUndefined = isNullOrUndefined; |
| |
| function isNumber(arg) { |
| return typeof arg === 'number'; |
| } |
| exports.isNumber = isNumber; |
| |
| function isString(arg) { |
| return typeof arg === 'string'; |
| } |
| exports.isString = isString; |
| |
| function isSymbol(arg) { |
| return typeof arg === 'symbol'; |
| } |
| exports.isSymbol = isSymbol; |
| |
| function isUndefined(arg) { |
| return arg === void 0; |
| } |
| exports.isUndefined = isUndefined; |
| |
| function isRegExp(re) { |
| return isObject(re) && objectToString(re) === '[object RegExp]'; |
| } |
| exports.isRegExp = isRegExp; |
| |
| function isObject(arg) { |
| return typeof arg === 'object' && arg !== null; |
| } |
| exports.isObject = isObject; |
| |
| function isDate(d) { |
| return isObject(d) && objectToString(d) === '[object Date]'; |
| } |
| exports.isDate = isDate; |
| |
| function isError(e) { |
| return isObject(e) && |
| (objectToString(e) === '[object Error]' || e instanceof Error); |
| } |
| exports.isError = isError; |
| |
| function isFunction(arg) { |
| return typeof arg === 'function'; |
| } |
| exports.isFunction = isFunction; |
| |
| function isPrimitive(arg) { |
| return arg === null || |
| typeof arg === 'boolean' || |
| typeof arg === 'number' || |
| typeof arg === 'string' || |
| typeof arg === 'symbol' || // ES6 symbol |
| typeof arg === 'undefined'; |
| } |
| exports.isPrimitive = isPrimitive; |
| |
| exports.isBuffer = require('./support/isBuffer'); |
| |
| function objectToString(o) { |
| return Object.prototype.toString.call(o); |
| } |
| |
| |
| function pad(n) { |
| return n < 10 ? '0' + n.toString(10) : n.toString(10); |
| } |
| |
| |
| var months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', |
| 'Oct', 'Nov', 'Dec']; |
| |
| // 26 Feb 16:19:34 |
| function timestamp() { |
| var d = new Date(); |
| var time = [pad(d.getHours()), |
| pad(d.getMinutes()), |
| pad(d.getSeconds())].join(':'); |
| return [d.getDate(), months[d.getMonth()], time].join(' '); |
| } |
| |
| |
| // log is just a thin wrapper to console.log that prepends a timestamp |
| exports.log = function() { |
| console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments)); |
| }; |
| |
| |
| /** |
| * Inherit the prototype methods from one constructor into another. |
| * |
| * The Function.prototype.inherits from lang.js rewritten as a standalone |
| * function (not on Function.prototype). NOTE: If this file is to be loaded |
| * during bootstrapping this function needs to be rewritten using some native |
| * functions as prototype setup using normal JavaScript does not work as |
| * expected during bootstrapping (see mirror.js in r114903). |
| * |
| * @param {function} ctor Constructor function which needs to inherit the |
| * prototype. |
| * @param {function} superCtor Constructor function to inherit prototype from. |
| */ |
| exports.inherits = require('inherits'); |
| |
| exports._extend = function(origin, add) { |
| // Don't do anything if add isn't an object |
| if (!add || !isObject(add)) return origin; |
| |
| var keys = Object.keys(add); |
| var i = keys.length; |
| while (i--) { |
| origin[keys[i]] = add[keys[i]]; |
| } |
| return origin; |
| }; |
| |
| function hasOwnProperty(obj, prop) { |
| return Object.prototype.hasOwnProperty.call(obj, prop); |
| } |
| |
| }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) |
| },{"./support/isBuffer":88,"_process":69,"inherits":56}],90:[function(require,module,exports){ |
| module.exports={ |
| "name": "mocha", |
| "version": "6.2.0", |
| "homepage": "https://mochajs.org/", |
| "notifyLogo": "https://ibin.co/4QuRuGjXvl36.png" |
| } |
| },{}]},{},[1]); |