merge fx-team to mozilla-central a=merge
authorCarsten "Tomcat" Book <cbook@mozilla.com>
Fri, 14 Oct 2016 11:57:10 +0200
changeset 317839 3a35f6cea288558cd0433f1b8b00c02e8bc3e4da
parent 317820 a71215ad8ab820b2310f5dd38fcfded38d18768b (current diff)
parent 317838 183b9d08d2648d4ed50fa1d354b50bd43c11a891 (diff)
child 317945 1391a2889aeb2bdd61ad6ef838e65826e35aabc2
push id33170
push usercbook@mozilla.com
push dateFri, 14 Oct 2016 10:37:07 +0000
treeherderautoland@0d101ebfd95c [default view] [failures only]
perfherder[talos] [build metrics] [platform microbench] (compared to previous push)
reviewersmerge
milestone52.0a1
first release with
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
last release without
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
merge fx-team to mozilla-central a=merge
--- a/browser/themes/windows/browser.css
+++ b/browser/themes/windows/browser.css
@@ -2642,8 +2642,62 @@ notification.pluginVulnerable > .notific
   .cui-widget-panelview[id^=PanelUI-webext-] {
     border-radius: 4px;
   }
 }
 
 .webextension-popup-browser {
   border-radius: inherit;
 }
+
+.contentSelectDropdown-ingroup > .menu-iconic-text {
+  padding-inline-start: 20px;
+}
+
+#ContentSelectDropdown > menupopup {
+  background-color: -moz-field;
+  -moz-border-top-colors: GrayText;
+  -moz-border-right-colors: GrayText;
+  -moz-border-bottom-colors: GrayText;
+  -moz-border-left-colors: GrayText;
+}
+
+#ContentSelectDropdown > menupopup > menucaption,
+#ContentSelectDropdown > menupopup > menuitem {
+  padding: 4px 6px;
+}
+
+#ContentSelectDropdown > menupopup > menucaption > .menu-iconic-text,
+#ContentSelectDropdown > menupopup > menuitem > .menu-iconic-text {
+  font: message-box;
+  font-size: 11px;
+  /**
+   * Remove the extra vertical padding set by menu.css since
+   * the menuitem itself will include enough padding.
+   */
+  padding-top: 0px;
+  padding-bottom: 0px;
+}
+
+#ContentSelectDropdown > menupopup > menucaption > .menu-iconic-text {
+  font-weight: bold;
+}
+
+#ContentSelectDropdown > menupopup > menuitem[_moz-menuactive="true"][disabled="true"] {
+  color: GrayText;
+  background-color: unset;
+}
+
+#ContentSelectDropdown > menupopup > menucaption {
+  background-color: buttonface;
+}
+
+#ContentSelectDropdown > menupopup > menucaption[disabled="true"] {
+  color: GrayText;
+}
+
+@media (-moz-touch-enabled) {
+  #ContentSelectDropdown > menupopup > menucaption,
+  #ContentSelectDropdown > menupopup > menuitem {
+    padding-top: 11px;
+    padding-bottom: 11px;
+  }
+}
--- a/devtools/client/debugger/new/bundle.js
+++ b/devtools/client/debugger/new/bundle.js
@@ -1,9 +1,9 @@
-// Generated from: bea6f2d2e0efef114265f177def09806e7f69784 Merge pull request #843 from jlongster/fix-css-var
+// Generated from: 873b94a2fc86b95fb4ff2ba728b50e5f137a909b chore(package): update eslint-plugin-flowtype to version 2.20.0 (#895)
 
 var Debugger =
 /******/ (function(modules) { // webpackBootstrap
 /******/ 	// The module cache
 /******/ 	var installedModules = {};
 /******/
 /******/ 	// The require function
 /******/ 	function __webpack_require__(moduleId) {
@@ -62,16 +62,18 @@ var Debugger =
 	var combineReducers = _require.combineReducers;
 	
 	var _require2 = __webpack_require__(15);
 	
 	var Provider = _require2.Provider;
 	
 	var ReactDOM = __webpack_require__(25);
 	var React = __webpack_require__(17);
+	var dom = React.DOM;
+	
 	
 	var DevToolsUtils = __webpack_require__(27);
 	var AppConstants = __webpack_require__(41).AppConstants;
 	
 	var _require3 = __webpack_require__(45);
 	
 	var injectGlobals = _require3.injectGlobals;
 	
@@ -79,46 +81,46 @@ var Debugger =
 	
 	var isEnabled = _require4.isEnabled;
 	var isFirefoxPanel = _require4.isFirefoxPanel;
 	var getValue = _require4.getValue;
 	var isDevelopment = _require4.isDevelopment;
 	var setConfig = _require4.setConfig;
 	
 	
-	setConfig(({"environment":"firefox-panel","baseWorkerURL":"resource://devtools/client/debugger/new/","logging":false,"clientLogging":false,"features":{"tabs":true}}));
+	setConfig(({"environment":"firefox-panel","baseWorkerURL":"resource://devtools/client/debugger/new/","logging":false,"clientLogging":false,"features":{"tabs":true,"sourceMaps":true}}));
 	
 	// Set various flags before requiring app code.
 	if (isEnabled("logging.client")) {
 	  DevToolsUtils.dumpn.wantLogging = true;
 	}
 	
-	var _require5 = __webpack_require__(96);
+	var _require5 = __webpack_require__(98);
 	
 	var getClient = _require5.getClient;
 	var connectClients = _require5.connectClients;
 	var startDebugging = _require5.startDebugging;
 	
-	var firefox = __webpack_require__(98);
-	var configureStore = __webpack_require__(178);
-	var reducers = __webpack_require__(188);
-	var selectors = __webpack_require__(199);
-	
-	var Tabs = __webpack_require__(200);
-	var App = __webpack_require__(206);
+	var firefox = __webpack_require__(100);
+	var configureStore = __webpack_require__(181);
+	var reducers = __webpack_require__(191);
+	var selectors = __webpack_require__(202);
+	
+	var LandingPage = __webpack_require__(203);
+	var App = __webpack_require__(210);
 	
 	var createStore = configureStore({
 	  log: getValue("logging.actions"),
 	  makeThunkArgs: (args, state) => {
 	    return Object.assign({}, args, { client: getClient(state) });
 	  }
 	});
 	
 	var store = createStore(combineReducers(reducers));
-	var actions = bindActionCreators(__webpack_require__(209), store.dispatch);
+	var actions = bindActionCreators(__webpack_require__(213), store.dispatch);
 	
 	if (isDevelopment()) {
 	  AppConstants.DEBUG_JS_MODULES = true;
 	  injectGlobals({ store });
 	}
 	
 	// Expose the bound actions so external things can do things like
 	// selecting a source.
@@ -130,17 +132,20 @@ var Debugger =
 	function renderRoot(component) {
 	  var mount = document.querySelector("#mount");
 	
 	  // bail in test environments that do not have a mount
 	  if (!mount) {
 	    return;
 	  }
 	
-	  ReactDOM.render(React.createElement(Provider, { store }, React.createElement(component)), mount);
+	  ReactDOM.render(React.createElement(Provider, { store }, dom.div({
+	    className: "theme-light",
+	    style: { flex: 1 }
+	  }, React.createElement(component))), mount);
 	}
 	
 	function unmountRoot() {
 	  var mount = document.querySelector("#mount");
 	  ReactDOM.unmountComponentAtNode(mount);
 	}
 	
 	function getTargetFromQuery() {
@@ -164,40 +169,40 @@ var Debugger =
 	if (connTarget) {
 	  startDebugging(connTarget, actions).then(tabs => {
 	    actions.newTabs(tabs);
 	    actions.selectTab({ id: connTarget.param });
 	    renderRoot(App);
 	  });
 	} else if (isFirefoxPanel()) {
 	  (function () {
-	    var sourceMap = __webpack_require__(211);
+	    var sourceMap = __webpack_require__(215);
 	
 	    module.exports = {
-	      bootstrap: _ref => {
+	      bootstrap: (_ref) => {
 	        var threadClient = _ref.threadClient;
 	        var tabTarget = _ref.tabTarget;
 	
 	        firefox.setThreadClient(threadClient);
 	        firefox.setTabTarget(tabTarget);
 	        renderRoot(App);
 	        return firefox.initPage(actions);
 	      },
 	      destroy: () => {
 	        unmountRoot();
-	        sourceMap.destroy();
+	        sourceMap.destroyWorker();
 	      },
 	      store: store,
 	      actions: actions,
 	      selectors: selectors,
 	      client: firefox.clientCommands
 	    };
 	  })();
 	} else {
-	  renderRoot(Tabs);
+	  renderRoot(LandingPage);
 	  connectClients(tabs => actions.newTabs(tabs));
 	}
 
 /***/ },
 /* 2 */
 /***/ function(module, exports, __webpack_require__) {
 
 	'use strict';
@@ -514,52 +519,51 @@ var Debugger =
 	  }, _ref2[_symbolObservable2["default"]] = observable, _ref2;
 	}
 
 /***/ },
 /* 4 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var getPrototype = __webpack_require__(5),
-	    isHostObject = __webpack_require__(6),
 	    isObjectLike = __webpack_require__(7);
 	
 	/** `Object#toString` result references. */
 	var objectTag = '[object Object]';
 	
 	/** Used for built-in method references. */
-	var objectProto = Object.prototype;
+	var funcProto = Function.prototype,
+	    objectProto = Object.prototype;
 	
 	/** Used to resolve the decompiled source of functions. */
-	var funcToString = Function.prototype.toString;
+	var funcToString = funcProto.toString;
 	
 	/** Used to check objects for own properties. */
 	var hasOwnProperty = objectProto.hasOwnProperty;
 	
 	/** Used to infer the `Object` constructor. */
 	var objectCtorString = funcToString.call(Object);
 	
 	/**
 	 * Used to resolve the
-	 * [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)
+	 * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
 	 * of values.
 	 */
 	var objectToString = objectProto.toString;
 	
 	/**
 	 * Checks if `value` is a plain object, that is, an object created by the
 	 * `Object` constructor or one with a `[[Prototype]]` of `null`.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 0.8.0
 	 * @category Lang
 	 * @param {*} value The value to check.
-	 * @returns {boolean} Returns `true` if `value` is a plain object,
-	 *  else `false`.
+	 * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.
 	 * @example
 	 *
 	 * function Foo() {
 	 *   this.a = 1;
 	 * }
 	 *
 	 * _.isPlainObject(new Foo);
 	 * // => false
@@ -569,77 +573,62 @@ var Debugger =
 	 *
 	 * _.isPlainObject({ 'x': 0, 'y': 0 });
 	 * // => true
 	 *
 	 * _.isPlainObject(Object.create(null));
 	 * // => true
 	 */
 	function isPlainObject(value) {
-	  if (!isObjectLike(value) ||
-	      objectToString.call(value) != objectTag || isHostObject(value)) {
+	  if (!isObjectLike(value) || objectToString.call(value) != objectTag) {
 	    return false;
 	  }
 	  var proto = getPrototype(value);
 	  if (proto === null) {
 	    return true;
 	  }
 	  var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;
 	  return (typeof Ctor == 'function' &&
 	    Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString);
 	}
 	
 	module.exports = isPlainObject;
 
 
 /***/ },
 /* 5 */
-/***/ function(module, exports) {
-
-	/* Built-in method references for those with the same name as other `lodash` methods. */
-	var nativeGetPrototype = Object.getPrototypeOf;
-	
-	/**
-	 * Gets the `[[Prototype]]` of `value`.
-	 *
-	 * @private
-	 * @param {*} value The value to query.
-	 * @returns {null|Object} Returns the `[[Prototype]]`.
-	 */
-	function getPrototype(value) {
-	  return nativeGetPrototype(Object(value));
-	}
+/***/ function(module, exports, __webpack_require__) {
+
+	var overArg = __webpack_require__(6);
+	
+	/** Built-in value references. */
+	var getPrototype = overArg(Object.getPrototypeOf, Object);
 	
 	module.exports = getPrototype;
 
 
 /***/ },
 /* 6 */
 /***/ function(module, exports) {
 
 	/**
-	 * Checks if `value` is a host object in IE < 9.
-	 *
-	 * @private
-	 * @param {*} value The value to check.
-	 * @returns {boolean} Returns `true` if `value` is a host object, else `false`.
-	 */
-	function isHostObject(value) {
-	  // Many host objects are `Object` objects that can coerce to strings
-	  // despite having improperly defined `toString` methods.
-	  var result = false;
-	  if (value != null && typeof value.toString != 'function') {
-	    try {
-	      result = !!(value + '');
-	    } catch (e) {}
-	  }
-	  return result;
-	}
-	
-	module.exports = isHostObject;
+	 * Creates a unary function that invokes `func` with its argument transformed.
+	 *
+	 * @private
+	 * @param {Function} func The function to wrap.
+	 * @param {Function} transform The argument transform.
+	 * @returns {Function} Returns the new function.
+	 */
+	function overArg(func, transform) {
+	  return function(arg) {
+	    return func(transform(arg));
+	  };
+	}
+	
+	module.exports = overArg;
 
 
 /***/ },
 /* 7 */
 /***/ function(module, exports) {
 
 	/**
 	 * Checks if `value` is object-like. A value is object-like if it's not `null`
@@ -661,17 +650,17 @@ var Debugger =
 	 *
 	 * _.isObjectLike(_.noop);
 	 * // => false
 	 *
 	 * _.isObjectLike(null);
 	 * // => false
 	 */
 	function isObjectLike(value) {
-	  return !!value && typeof value == 'object';
+	  return value != null && typeof value == 'object';
 	}
 	
 	module.exports = isObjectLike;
 
 
 /***/ },
 /* 8 */
 /***/ function(module, exports, __webpack_require__) {
@@ -1575,25 +1564,24 @@ var Debugger =
 	      Connect.prototype.componentWillUpdate = function componentWillUpdate() {
 	        if (this.version === version) {
 	          return;
 	        }
 	
 	        // We are hot reloading!
 	        this.version = version;
 	        this.trySubscribe();
-	        // this.clearCache();
+	        this.clearCache();
 	      };
 	    }
 	
 	    return (0, _hoistNonReactStatics2["default"])(Connect, WrappedComponent);
 	  };
 	}
 
-
 /***/ },
 /* 21 */
 /***/ function(module, exports) {
 
 	"use strict";
 	
 	exports.__esModule = true;
 	exports["default"] = shallowEqual;
@@ -8643,17 +8631,17 @@ var Debugger =
 	    window[field] = value;
 	  }
 	}
 	
 	function injectGlobals(_ref) {
 	  var store = _ref.store;
 	
 	  debugGlobal("store", store);
-	  debugGlobal("injectDebuggee", __webpack_require__(95));
+	  debugGlobal("injectDebuggee", __webpack_require__(97));
 	  debugGlobal("serializeStore", () => {
 	    return JSON.parse(JSON.stringify(store.getState()));
 	  });
 	}
 	
 	module.exports = {
 	  debugGlobal,
 	  injectGlobals
@@ -8742,17 +8730,17 @@ var Debugger =
 /***/ },
 /* 49 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var baseGet = __webpack_require__(50);
 	
 	/**
 	 * Gets the value at `path` of `object`. If the resolved value is
-	 * `undefined`, the `defaultValue` is used in its place.
+	 * `undefined`, the `defaultValue` is returned in its place.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 3.7.0
 	 * @category Object
 	 * @param {Object} object The object to query.
 	 * @param {Array|string} path The path of the property to get.
 	 * @param {*} [defaultValue] The value returned for `undefined` resolved values.
@@ -8778,18 +8766,18 @@ var Debugger =
 	module.exports = get;
 
 
 /***/ },
 /* 50 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var castPath = __webpack_require__(51),
-	    isKey = __webpack_require__(93),
-	    toKey = __webpack_require__(94);
+	    isKey = __webpack_require__(95),
+	    toKey = __webpack_require__(96);
 	
 	/**
 	 * The base implementation of `_.get` without support for default values.
 	 *
 	 * @private
 	 * @param {Object} object The object to query.
 	 * @param {Array|string} path The path of the property to get.
 	 * @returns {*} Returns the resolved value.
@@ -8835,21 +8823,19 @@ var Debugger =
 /***/ function(module, exports) {
 
 	/**
 	 * Checks if `value` is classified as an `Array` object.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 0.1.0
-	 * @type {Function}
 	 * @category Lang
 	 * @param {*} value The value to check.
-	 * @returns {boolean} Returns `true` if `value` is correctly classified,
-	 *  else `false`.
+	 * @returns {boolean} Returns `true` if `value` is an array, else `false`.
 	 * @example
 	 *
 	 * _.isArray([1, 2, 3]);
 	 * // => true
 	 *
 	 * _.isArray(document.body.children);
 	 * // => false
 	 *
@@ -8863,63 +8849,101 @@ var Debugger =
 	
 	module.exports = isArray;
 
 
 /***/ },
 /* 53 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var memoize = __webpack_require__(54),
-	    toString = __webpack_require__(89);
+	var memoizeCapped = __webpack_require__(54),
+	    toString = __webpack_require__(90);
 	
 	/** Used to match property names within property paths. */
-	var rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(\.|\[\])(?:\4|$))/g;
+	var reLeadingDot = /^\./,
+	    rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g;
 	
 	/** Used to match backslashes in property paths. */
 	var reEscapeChar = /\\(\\)?/g;
 	
 	/**
 	 * Converts `string` to a property path array.
 	 *
 	 * @private
 	 * @param {string} string The string to convert.
 	 * @returns {Array} Returns the property path array.
 	 */
-	var stringToPath = memoize(function(string) {
+	var stringToPath = memoizeCapped(function(string) {
+	  string = toString(string);
+	
 	  var result = [];
-	  toString(string).replace(rePropName, function(match, number, quote, string) {
+	  if (reLeadingDot.test(string)) {
+	    result.push('');
+	  }
+	  string.replace(rePropName, function(match, number, quote, string) {
 	    result.push(quote ? string.replace(reEscapeChar, '$1') : (number || match));
 	  });
 	  return result;
 	});
 	
 	module.exports = stringToPath;
 
 
 /***/ },
 /* 54 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var MapCache = __webpack_require__(55);
-	
-	/** Used as the `TypeError` message for "Functions" methods. */
+	var memoize = __webpack_require__(55);
+	
+	/** Used as the maximum memoize cache size. */
+	var MAX_MEMOIZE_SIZE = 500;
+	
+	/**
+	 * A specialized version of `_.memoize` which clears the memoized function's
+	 * cache when it exceeds `MAX_MEMOIZE_SIZE`.
+	 *
+	 * @private
+	 * @param {Function} func The function to have its output memoized.
+	 * @returns {Function} Returns the new memoized function.
+	 */
+	function memoizeCapped(func) {
+	  var result = memoize(func, function(key) {
+	    if (cache.size === MAX_MEMOIZE_SIZE) {
+	      cache.clear();
+	    }
+	    return key;
+	  });
+	
+	  var cache = result.cache;
+	  return result;
+	}
+	
+	module.exports = memoizeCapped;
+
+
+/***/ },
+/* 55 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var MapCache = __webpack_require__(56);
+	
+	/** Error message constants. */
 	var FUNC_ERROR_TEXT = 'Expected a function';
 	
 	/**
 	 * Creates a function that memoizes the result of `func`. If `resolver` is
 	 * provided, it determines the cache key for storing the result based on the
 	 * arguments provided to the memoized function. By default, the first argument
 	 * provided to the memoized function is used as the map cache key. The `func`
 	 * is invoked with the `this` binding of the memoized function.
 	 *
 	 * **Note:** The cache is exposed as the `cache` property on the memoized
 	 * function. Its creation may be customized by replacing the `_.memoize.Cache`
 	 * constructor with one whose instances implement the
-	 * [`Map`](http://ecma-international.org/ecma-262/6.0/#sec-properties-of-the-map-prototype-object)
+	 * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)
 	 * method interface of `delete`, `get`, `has`, and `set`.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 0.1.0
 	 * @category Function
 	 * @param {Function} func The function to have its output memoized.
 	 * @param {Function} [resolver] The function to resolve the cache key.
@@ -8956,38 +8980,38 @@ var Debugger =
 	    var args = arguments,
 	        key = resolver ? resolver.apply(this, args) : args[0],
 	        cache = memoized.cache;
 	
 	    if (cache.has(key)) {
 	      return cache.get(key);
 	    }
 	    var result = func.apply(this, args);
-	    memoized.cache = cache.set(key, result);
+	    memoized.cache = cache.set(key, result) || cache;
 	    return result;
 	  };
 	  memoized.cache = new (memoize.Cache || MapCache);
 	  return memoized;
 	}
 	
-	// Assign cache to `_.memoize`.
+	// Expose `MapCache`.
 	memoize.Cache = MapCache;
 	
 	module.exports = memoize;
 
 
 /***/ },
-/* 55 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var mapCacheClear = __webpack_require__(56),
-	    mapCacheDelete = __webpack_require__(83),
-	    mapCacheGet = __webpack_require__(86),
-	    mapCacheHas = __webpack_require__(87),
-	    mapCacheSet = __webpack_require__(88);
+/* 56 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var mapCacheClear = __webpack_require__(57),
+	    mapCacheDelete = __webpack_require__(84),
+	    mapCacheGet = __webpack_require__(87),
+	    mapCacheHas = __webpack_require__(88),
+	    mapCacheSet = __webpack_require__(89);
 	
 	/**
 	 * Creates a map cache object to store key-value pairs.
 	 *
 	 * @private
 	 * @constructor
 	 * @param {Array} [entries] The key-value pairs to cache.
 	 */
@@ -9008,50 +9032,51 @@ var Debugger =
 	MapCache.prototype.get = mapCacheGet;
 	MapCache.prototype.has = mapCacheHas;
 	MapCache.prototype.set = mapCacheSet;
 	
 	module.exports = MapCache;
 
 
 /***/ },
-/* 56 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var Hash = __webpack_require__(57),
-	    ListCache = __webpack_require__(74),
-	    Map = __webpack_require__(82);
+/* 57 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var Hash = __webpack_require__(58),
+	    ListCache = __webpack_require__(75),
+	    Map = __webpack_require__(83);
 	
 	/**
 	 * Removes all key-value entries from the map.
 	 *
 	 * @private
 	 * @name clear
 	 * @memberOf MapCache
 	 */
 	function mapCacheClear() {
+	  this.size = 0;
 	  this.__data__ = {
 	    'hash': new Hash,
 	    'map': new (Map || ListCache),
 	    'string': new Hash
 	  };
 	}
 	
 	module.exports = mapCacheClear;
 
 
 /***/ },
-/* 57 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var hashClear = __webpack_require__(58),
-	    hashDelete = __webpack_require__(70),
-	    hashGet = __webpack_require__(71),
-	    hashHas = __webpack_require__(72),
-	    hashSet = __webpack_require__(73);
+/* 58 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var hashClear = __webpack_require__(59),
+	    hashDelete = __webpack_require__(71),
+	    hashGet = __webpack_require__(72),
+	    hashHas = __webpack_require__(73),
+	    hashSet = __webpack_require__(74);
 	
 	/**
 	 * Creates a hash object.
 	 *
 	 * @private
 	 * @constructor
 	 * @param {Array} [entries] The key-value pairs to cache.
 	 */
@@ -9072,53 +9097,54 @@ var Debugger =
 	Hash.prototype.get = hashGet;
 	Hash.prototype.has = hashHas;
 	Hash.prototype.set = hashSet;
 	
 	module.exports = Hash;
 
 
 /***/ },
-/* 58 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var nativeCreate = __webpack_require__(59);
+/* 59 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var nativeCreate = __webpack_require__(60);
 	
 	/**
 	 * Removes all key-value entries from the hash.
 	 *
 	 * @private
 	 * @name clear
 	 * @memberOf Hash
 	 */
 	function hashClear() {
 	  this.__data__ = nativeCreate ? nativeCreate(null) : {};
+	  this.size = 0;
 	}
 	
 	module.exports = hashClear;
 
 
 /***/ },
-/* 59 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getNative = __webpack_require__(60);
+/* 60 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getNative = __webpack_require__(61);
 	
 	/* Built-in method references that are verified to be native. */
 	var nativeCreate = getNative(Object, 'create');
 	
 	module.exports = nativeCreate;
 
 
 /***/ },
-/* 60 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseIsNative = __webpack_require__(61),
-	    getValue = __webpack_require__(69);
+/* 61 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseIsNative = __webpack_require__(62),
+	    getValue = __webpack_require__(70);
 	
 	/**
 	 * Gets the native function at `key` of `object`.
 	 *
 	 * @private
 	 * @param {Object} object The object to query.
 	 * @param {string} key The key of the method to get.
 	 * @returns {*} Returns the function if it's native, else `undefined`.
@@ -9127,39 +9153,39 @@ var Debugger =
 	  var value = getValue(object, key);
 	  return baseIsNative(value) ? value : undefined;
 	}
 	
 	module.exports = getNative;
 
 
 /***/ },
-/* 61 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isFunction = __webpack_require__(62),
-	    isHostObject = __webpack_require__(6),
-	    isMasked = __webpack_require__(64),
-	    isObject = __webpack_require__(63),
-	    toSource = __webpack_require__(68);
+/* 62 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isFunction = __webpack_require__(63),
+	    isMasked = __webpack_require__(65),
+	    isObject = __webpack_require__(64),
+	    toSource = __webpack_require__(69);
 	
 	/**
 	 * Used to match `RegExp`
-	 * [syntax characters](http://ecma-international.org/ecma-262/6.0/#sec-patterns).
+	 * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).
 	 */
 	var reRegExpChar = /[\\^$.*+?()[\]{}|]/g;
 	
 	/** Used to detect host constructors (Safari). */
 	var reIsHostCtor = /^\[object .+?Constructor\]$/;
 	
 	/** Used for built-in method references. */
-	var objectProto = Object.prototype;
+	var funcProto = Function.prototype,
+	    objectProto = Object.prototype;
 	
 	/** Used to resolve the decompiled source of functions. */
-	var funcToString = Function.prototype.toString;
+	var funcToString = funcProto.toString;
 	
 	/** Used to check objects for own properties. */
 	var hasOwnProperty = objectProto.hasOwnProperty;
 	
 	/** Used to detect if a method is native. */
 	var reIsNative = RegExp('^' +
 	  funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\$&')
 	  .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$'
@@ -9172,79 +9198,78 @@ var Debugger =
 	 * @param {*} value The value to check.
 	 * @returns {boolean} Returns `true` if `value` is a native function,
 	 *  else `false`.
 	 */
 	function baseIsNative(value) {
 	  if (!isObject(value) || isMasked(value)) {
 	    return false;
 	  }
-	  var pattern = (isFunction(value) || isHostObject(value)) ? reIsNative : reIsHostCtor;
+	  var pattern = isFunction(value) ? reIsNative : reIsHostCtor;
 	  return pattern.test(toSource(value));
 	}
 	
 	module.exports = baseIsNative;
 
 
 /***/ },
-/* 62 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isObject = __webpack_require__(63);
+/* 63 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isObject = __webpack_require__(64);
 	
 	/** `Object#toString` result references. */
 	var funcTag = '[object Function]',
-	    genTag = '[object GeneratorFunction]';
+	    genTag = '[object GeneratorFunction]',
+	    proxyTag = '[object Proxy]';
 	
 	/** Used for built-in method references. */
 	var objectProto = Object.prototype;
 	
 	/**
 	 * Used to resolve the
-	 * [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)
+	 * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
 	 * of values.
 	 */
 	var objectToString = objectProto.toString;
 	
 	/**
 	 * Checks if `value` is classified as a `Function` object.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 0.1.0
 	 * @category Lang
 	 * @param {*} value The value to check.
-	 * @returns {boolean} Returns `true` if `value` is correctly classified,
-	 *  else `false`.
+	 * @returns {boolean} Returns `true` if `value` is a function, else `false`.
 	 * @example
 	 *
 	 * _.isFunction(_);
 	 * // => true
 	 *
 	 * _.isFunction(/abc/);
 	 * // => false
 	 */
 	function isFunction(value) {
 	  // The use of `Object#toString` avoids issues with the `typeof` operator
-	  // in Safari 8 which returns 'object' for typed array and weak map constructors,
-	  // and PhantomJS 1.9 which returns 'function' for `NodeList` instances.
+	  // in Safari 9 which returns 'object' for typed array and other constructors.
 	  var tag = isObject(value) ? objectToString.call(value) : '';
-	  return tag == funcTag || tag == genTag;
+	  return tag == funcTag || tag == genTag || tag == proxyTag;
 	}
 	
 	module.exports = isFunction;
 
 
 /***/ },
-/* 63 */
+/* 64 */
 /***/ function(module, exports) {
 
 	/**
 	 * Checks if `value` is the
-	 * [language type](http://www.ecma-international.org/ecma-262/6.0/#sec-ecmascript-language-types)
+	 * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
 	 * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 0.1.0
 	 * @category Lang
 	 * @param {*} value The value to check.
 	 * @returns {boolean} Returns `true` if `value` is an object, else `false`.
@@ -9259,27 +9284,27 @@ var Debugger =
 	 * _.isObject(_.noop);
 	 * // => true
 	 *
 	 * _.isObject(null);
 	 * // => false
 	 */
 	function isObject(value) {
 	  var type = typeof value;
-	  return !!value && (type == 'object' || type == 'function');
+	  return value != null && (type == 'object' || type == 'function');
 	}
 	
 	module.exports = isObject;
 
 
 /***/ },
-/* 64 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var coreJsData = __webpack_require__(65);
+/* 65 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var coreJsData = __webpack_require__(66);
 	
 	/** Used to detect methods masquerading as native. */
 	var maskSrcKey = (function() {
 	  var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');
 	  return uid ? ('Symbol(src)_1.' + uid) : '';
 	}());
 	
 	/**
@@ -9292,73 +9317,62 @@ var Debugger =
 	function isMasked(func) {
 	  return !!maskSrcKey && (maskSrcKey in func);
 	}
 	
 	module.exports = isMasked;
 
 
 /***/ },
-/* 65 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var root = __webpack_require__(66);
+/* 66 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var root = __webpack_require__(67);
 	
 	/** Used to detect overreaching core-js shims. */
 	var coreJsData = root['__core-js_shared__'];
 	
 	module.exports = coreJsData;
 
 
 /***/ },
-/* 66 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* WEBPACK VAR INJECTION */(function(global) {var checkGlobal = __webpack_require__(67);
-	
-	/** Detect free variable `global` from Node.js. */
-	var freeGlobal = checkGlobal(typeof global == 'object' && global);
+/* 67 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var freeGlobal = __webpack_require__(68);
 	
 	/** Detect free variable `self`. */
-	var freeSelf = checkGlobal(typeof self == 'object' && self);
-	
-	/** Detect `this` as the global object. */
-	var thisGlobal = checkGlobal(typeof this == 'object' && this);
+	var freeSelf = typeof self == 'object' && self && self.Object === Object && self;
 	
 	/** Used as a reference to the global object. */
-	var root = freeGlobal || freeSelf || thisGlobal || Function('return this')();
+	var root = freeGlobal || freeSelf || Function('return this')();
 	
 	module.exports = root;
-	
-	/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }())))
-
-/***/ },
-/* 67 */
-/***/ function(module, exports) {
-
-	/**
-	 * Checks if `value` is a global object.
-	 *
-	 * @private
-	 * @param {*} value The value to check.
-	 * @returns {null|Object} Returns `value` if it's a global object, else `null`.
-	 */
-	function checkGlobal(value) {
-	  return (value && value.Object === Object) ? value : null;
-	}
-	
-	module.exports = checkGlobal;
 
 
 /***/ },
 /* 68 */
 /***/ function(module, exports) {
 
+	/* WEBPACK VAR INJECTION */(function(global) {/** Detect free variable `global` from Node.js. */
+	var freeGlobal = typeof global == 'object' && global && global.Object === Object && global;
+	
+	module.exports = freeGlobal;
+	
+	/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }())))
+
+/***/ },
+/* 69 */
+/***/ function(module, exports) {
+
+	/** Used for built-in method references. */
+	var funcProto = Function.prototype;
+	
 	/** Used to resolve the decompiled source of functions. */
-	var funcToString = Function.prototype.toString;
+	var funcToString = funcProto.toString;
 	
 	/**
 	 * Converts `func` to its source code.
 	 *
 	 * @private
 	 * @param {Function} func The function to process.
 	 * @returns {string} Returns the source code.
 	 */
@@ -9373,17 +9387,17 @@ var Debugger =
 	  }
 	  return '';
 	}
 	
 	module.exports = toSource;
 
 
 /***/ },
-/* 69 */
+/* 70 */
 /***/ function(module, exports) {
 
 	/**
 	 * Gets the value at `key` of `object`.
 	 *
 	 * @private
 	 * @param {Object} [object] The object to query.
 	 * @param {string} key The key of the property to get.
@@ -9392,41 +9406,43 @@ var Debugger =
 	function getValue(object, key) {
 	  return object == null ? undefined : object[key];
 	}
 	
 	module.exports = getValue;
 
 
 /***/ },
-/* 70 */
+/* 71 */
 /***/ function(module, exports) {
 
 	/**
 	 * Removes `key` and its value from the hash.
 	 *
 	 * @private
 	 * @name delete
 	 * @memberOf Hash
 	 * @param {Object} hash The hash to modify.
 	 * @param {string} key The key of the value to remove.
 	 * @returns {boolean} Returns `true` if the entry was removed, else `false`.
 	 */
 	function hashDelete(key) {
-	  return this.has(key) && delete this.__data__[key];
+	  var result = this.has(key) && delete this.__data__[key];
+	  this.size -= result ? 1 : 0;
+	  return result;
 	}
 	
 	module.exports = hashDelete;
 
 
 /***/ },
-/* 71 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var nativeCreate = __webpack_require__(59);
+/* 72 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var nativeCreate = __webpack_require__(60);
 	
 	/** Used to stand-in for `undefined` hash values. */
 	var HASH_UNDEFINED = '__lodash_hash_undefined__';
 	
 	/** Used for built-in method references. */
 	var objectProto = Object.prototype;
 	
 	/** Used to check objects for own properties. */
@@ -9449,20 +9465,20 @@ var Debugger =
 	  }
 	  return hasOwnProperty.call(data, key) ? data[key] : undefined;
 	}
 	
 	module.exports = hashGet;
 
 
 /***/ },
-/* 72 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var nativeCreate = __webpack_require__(59);
+/* 73 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var nativeCreate = __webpack_require__(60);
 	
 	/** Used for built-in method references. */
 	var objectProto = Object.prototype;
 	
 	/** Used to check objects for own properties. */
 	var hasOwnProperty = objectProto.hasOwnProperty;
 	
 	/**
@@ -9478,52 +9494,53 @@ var Debugger =
 	  var data = this.__data__;
 	  return nativeCreate ? data[key] !== undefined : hasOwnProperty.call(data, key);
 	}
 	
 	module.exports = hashHas;
 
 
 /***/ },
-/* 73 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var nativeCreate = __webpack_require__(59);
+/* 74 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var nativeCreate = __webpack_require__(60);
 	
 	/** Used to stand-in for `undefined` hash values. */
 	var HASH_UNDEFINED = '__lodash_hash_undefined__';
 	
 	/**
 	 * Sets the hash `key` to `value`.
 	 *
 	 * @private
 	 * @name set
 	 * @memberOf Hash
 	 * @param {string} key The key of the value to set.
 	 * @param {*} value The value to set.
 	 * @returns {Object} Returns the hash instance.
 	 */
 	function hashSet(key, value) {
 	  var data = this.__data__;
+	  this.size += this.has(key) ? 0 : 1;
 	  data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;
 	  return this;
 	}
 	
 	module.exports = hashSet;
 
 
 /***/ },
-/* 74 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var listCacheClear = __webpack_require__(75),
-	    listCacheDelete = __webpack_require__(76),
-	    listCacheGet = __webpack_require__(79),
-	    listCacheHas = __webpack_require__(80),
-	    listCacheSet = __webpack_require__(81);
+/* 75 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var listCacheClear = __webpack_require__(76),
+	    listCacheDelete = __webpack_require__(77),
+	    listCacheGet = __webpack_require__(80),
+	    listCacheHas = __webpack_require__(81),
+	    listCacheSet = __webpack_require__(82);
 	
 	/**
 	 * Creates an list cache object.
 	 *
 	 * @private
 	 * @constructor
 	 * @param {Array} [entries] The key-value pairs to cache.
 	 */
@@ -9544,38 +9561,39 @@ var Debugger =
 	ListCache.prototype.get = listCacheGet;
 	ListCache.prototype.has = listCacheHas;
 	ListCache.prototype.set = listCacheSet;
 	
 	module.exports = ListCache;
 
 
 /***/ },
-/* 75 */
+/* 76 */
 /***/ function(module, exports) {
 
 	/**
 	 * Removes all key-value entries from the list cache.
 	 *
 	 * @private
 	 * @name clear
 	 * @memberOf ListCache
 	 */
 	function listCacheClear() {
 	  this.__data__ = [];
+	  this.size = 0;
 	}
 	
 	module.exports = listCacheClear;
 
 
 /***/ },
-/* 76 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assocIndexOf = __webpack_require__(77);
+/* 77 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assocIndexOf = __webpack_require__(78);
 	
 	/** Used for built-in method references. */
 	var arrayProto = Array.prototype;
 	
 	/** Built-in value references. */
 	var splice = arrayProto.splice;
 	
 	/**
@@ -9595,33 +9613,34 @@ var Debugger =
 	    return false;
 	  }
 	  var lastIndex = data.length - 1;
 	  if (index == lastIndex) {
 	    data.pop();
 	  } else {
 	    splice.call(data, index, 1);
 	  }
+	  --this.size;
 	  return true;
 	}
 	
 	module.exports = listCacheDelete;
 
 
 /***/ },
-/* 77 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var eq = __webpack_require__(78);
+/* 78 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var eq = __webpack_require__(79);
 	
 	/**
 	 * Gets the index at which the `key` is found in `array` of key-value pairs.
 	 *
 	 * @private
-	 * @param {Array} array The array to search.
+	 * @param {Array} array The array to inspect.
 	 * @param {*} key The key to search for.
 	 * @returns {number} Returns the index of the matched value, else `-1`.
 	 */
 	function assocIndexOf(array, key) {
 	  var length = array.length;
 	  while (length--) {
 	    if (eq(array[length][0], key)) {
 	      return length;
@@ -9629,35 +9648,35 @@ var Debugger =
 	  }
 	  return -1;
 	}
 	
 	module.exports = assocIndexOf;
 
 
 /***/ },
-/* 78 */
+/* 79 */
 /***/ function(module, exports) {
 
 	/**
 	 * Performs a
-	 * [`SameValueZero`](http://ecma-international.org/ecma-262/6.0/#sec-samevaluezero)
+	 * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
 	 * comparison between two values to determine if they are equivalent.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 4.0.0
 	 * @category Lang
 	 * @param {*} value The value to compare.
 	 * @param {*} other The other value to compare.
 	 * @returns {boolean} Returns `true` if the values are equivalent, else `false`.
 	 * @example
 	 *
-	 * var object = { 'user': 'fred' };
-	 * var other = { 'user': 'fred' };
+	 * var object = { 'a': 1 };
+	 * var other = { 'a': 1 };
 	 *
 	 * _.eq(object, object);
 	 * // => true
 	 *
 	 * _.eq(object, other);
 	 * // => false
 	 *
 	 * _.eq('a', 'a');
@@ -9672,20 +9691,20 @@ var Debugger =
 	function eq(value, other) {
 	  return value === other || (value !== value && other !== other);
 	}
 	
 	module.exports = eq;
 
 
 /***/ },
-/* 79 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assocIndexOf = __webpack_require__(77);
+/* 80 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assocIndexOf = __webpack_require__(78);
 	
 	/**
 	 * Gets the list cache value for `key`.
 	 *
 	 * @private
 	 * @name get
 	 * @memberOf ListCache
 	 * @param {string} key The key of the value to get.
@@ -9697,20 +9716,20 @@ var Debugger =
 	
 	  return index < 0 ? undefined : data[index][1];
 	}
 	
 	module.exports = listCacheGet;
 
 
 /***/ },
-/* 80 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assocIndexOf = __webpack_require__(77);
+/* 81 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assocIndexOf = __webpack_require__(78);
 	
 	/**
 	 * Checks if a list cache value for `key` exists.
 	 *
 	 * @private
 	 * @name has
 	 * @memberOf ListCache
 	 * @param {string} key The key of the entry to check.
@@ -9719,86 +9738,89 @@ var Debugger =
 	function listCacheHas(key) {
 	  return assocIndexOf(this.__data__, key) > -1;
 	}
 	
 	module.exports = listCacheHas;
 
 
 /***/ },
-/* 81 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assocIndexOf = __webpack_require__(77);
+/* 82 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assocIndexOf = __webpack_require__(78);
 	
 	/**
 	 * Sets the list cache `key` to `value`.
 	 *
 	 * @private
 	 * @name set
 	 * @memberOf ListCache
 	 * @param {string} key The key of the value to set.
 	 * @param {*} value The value to set.
 	 * @returns {Object} Returns the list cache instance.
 	 */
 	function listCacheSet(key, value) {
 	  var data = this.__data__,
 	      index = assocIndexOf(data, key);
 	
 	  if (index < 0) {
+	    ++this.size;
 	    data.push([key, value]);
 	  } else {
 	    data[index][1] = value;
 	  }
 	  return this;
 	}
 	
 	module.exports = listCacheSet;
 
 
 /***/ },
-/* 82 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getNative = __webpack_require__(60),
-	    root = __webpack_require__(66);
+/* 83 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getNative = __webpack_require__(61),
+	    root = __webpack_require__(67);
 	
 	/* Built-in method references that are verified to be native. */
 	var Map = getNative(root, 'Map');
 	
 	module.exports = Map;
 
 
 /***/ },
-/* 83 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getMapData = __webpack_require__(84);
+/* 84 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getMapData = __webpack_require__(85);
 	
 	/**
 	 * Removes `key` and its value from the map.
 	 *
 	 * @private
 	 * @name delete
 	 * @memberOf MapCache
 	 * @param {string} key The key of the value to remove.
 	 * @returns {boolean} Returns `true` if the entry was removed, else `false`.
 	 */
 	function mapCacheDelete(key) {
-	  return getMapData(this, key)['delete'](key);
+	  var result = getMapData(this, key)['delete'](key);
+	  this.size -= result ? 1 : 0;
+	  return result;
 	}
 	
 	module.exports = mapCacheDelete;
 
 
 /***/ },
-/* 84 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isKeyable = __webpack_require__(85);
+/* 85 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isKeyable = __webpack_require__(86);
 	
 	/**
 	 * Gets the data for `map`.
 	 *
 	 * @private
 	 * @param {Object} map The map to query.
 	 * @param {string} key The reference key.
 	 * @returns {*} Returns the map data.
@@ -9809,17 +9831,17 @@ var Debugger =
 	    ? data[typeof key == 'string' ? 'string' : 'hash']
 	    : data.map;
 	}
 	
 	module.exports = getMapData;
 
 
 /***/ },
-/* 85 */
+/* 86 */
 /***/ function(module, exports) {
 
 	/**
 	 * Checks if `value` is suitable for use as unique object key.
 	 *
 	 * @private
 	 * @param {*} value The value to check.
 	 * @returns {boolean} Returns `true` if `value` is suitable, else `false`.
@@ -9830,20 +9852,20 @@ var Debugger =
 	    ? (value !== '__proto__')
 	    : (value === null);
 	}
 	
 	module.exports = isKeyable;
 
 
 /***/ },
-/* 86 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getMapData = __webpack_require__(84);
+/* 87 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getMapData = __webpack_require__(85);
 	
 	/**
 	 * Gets the map value for `key`.
 	 *
 	 * @private
 	 * @name get
 	 * @memberOf MapCache
 	 * @param {string} key The key of the value to get.
@@ -9852,20 +9874,20 @@ var Debugger =
 	function mapCacheGet(key) {
 	  return getMapData(this, key).get(key);
 	}
 	
 	module.exports = mapCacheGet;
 
 
 /***/ },
-/* 87 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getMapData = __webpack_require__(84);
+/* 88 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getMapData = __webpack_require__(85);
 	
 	/**
 	 * Checks if a map value for `key` exists.
 	 *
 	 * @private
 	 * @name has
 	 * @memberOf MapCache
 	 * @param {string} key The key of the entry to check.
@@ -9874,55 +9896,59 @@ var Debugger =
 	function mapCacheHas(key) {
 	  return getMapData(this, key).has(key);
 	}
 	
 	module.exports = mapCacheHas;
 
 
 /***/ },
-/* 88 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getMapData = __webpack_require__(84);
+/* 89 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getMapData = __webpack_require__(85);
 	
 	/**
 	 * Sets the map `key` to `value`.
 	 *
 	 * @private
 	 * @name set
 	 * @memberOf MapCache
 	 * @param {string} key The key of the value to set.
 	 * @param {*} value The value to set.
 	 * @returns {Object} Returns the map cache instance.
 	 */
 	function mapCacheSet(key, value) {
-	  getMapData(this, key).set(key, value);
+	  var data = getMapData(this, key),
+	      size = data.size;
+	
+	  data.set(key, value);
+	  this.size += data.size == size ? 0 : 1;
 	  return this;
 	}
 	
 	module.exports = mapCacheSet;
 
 
 /***/ },
-/* 89 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseToString = __webpack_require__(90);
+/* 90 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseToString = __webpack_require__(91);
 	
 	/**
 	 * Converts `value` to a string. An empty string is returned for `null`
 	 * and `undefined` values. The sign of `-0` is preserved.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 4.0.0
 	 * @category Lang
-	 * @param {*} value The value to process.
-	 * @returns {string} Returns the string.
+	 * @param {*} value The value to convert.
+	 * @returns {string} Returns the converted string.
 	 * @example
 	 *
 	 * _.toString(null);
 	 * // => ''
 	 *
 	 * _.toString(-0);
 	 * // => '-0'
 	 *
@@ -9932,21 +9958,23 @@ var Debugger =
 	function toString(value) {
 	  return value == null ? '' : baseToString(value);
 	}
 	
 	module.exports = toString;
 
 
 /***/ },
-/* 90 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var Symbol = __webpack_require__(91),
-	    isSymbol = __webpack_require__(92);
+/* 91 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var Symbol = __webpack_require__(92),
+	    arrayMap = __webpack_require__(93),
+	    isArray = __webpack_require__(52),
+	    isSymbol = __webpack_require__(94);
 	
 	/** Used as references for various `Number` constants. */
 	var INFINITY = 1 / 0;
 	
 	/** Used to convert symbols to primitives and strings. */
 	var symbolProto = Symbol ? Symbol.prototype : undefined,
 	    symbolToString = symbolProto ? symbolProto.toString : undefined;
 	
@@ -9958,67 +9986,97 @@ var Debugger =
 	 * @param {*} value The value to process.
 	 * @returns {string} Returns the string.
 	 */
 	function baseToString(value) {
 	  // Exit early for strings to avoid a performance hit in some environments.
 	  if (typeof value == 'string') {
 	    return value;
 	  }
+	  if (isArray(value)) {
+	    // Recursively convert values (susceptible to call stack limits).
+	    return arrayMap(value, baseToString) + '';
+	  }
 	  if (isSymbol(value)) {
 	    return symbolToString ? symbolToString.call(value) : '';
 	  }
 	  var result = (value + '');
 	  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;
 	}
 	
 	module.exports = baseToString;
 
 
 /***/ },
-/* 91 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var root = __webpack_require__(66);
+/* 92 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var root = __webpack_require__(67);
 	
 	/** Built-in value references. */
 	var Symbol = root.Symbol;
 	
 	module.exports = Symbol;
 
 
 /***/ },
-/* 92 */
+/* 93 */
+/***/ function(module, exports) {
+
+	/**
+	 * A specialized version of `_.map` for arrays without support for iteratee
+	 * shorthands.
+	 *
+	 * @private
+	 * @param {Array} [array] The array to iterate over.
+	 * @param {Function} iteratee The function invoked per iteration.
+	 * @returns {Array} Returns the new mapped array.
+	 */
+	function arrayMap(array, iteratee) {
+	  var index = -1,
+	      length = array ? array.length : 0,
+	      result = Array(length);
+	
+	  while (++index < length) {
+	    result[index] = iteratee(array[index], index, array);
+	  }
+	  return result;
+	}
+	
+	module.exports = arrayMap;
+
+
+/***/ },
+/* 94 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var isObjectLike = __webpack_require__(7);
 	
 	/** `Object#toString` result references. */
 	var symbolTag = '[object Symbol]';
 	
 	/** Used for built-in method references. */
 	var objectProto = Object.prototype;
 	
 	/**
 	 * Used to resolve the
-	 * [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)
+	 * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
 	 * of values.
 	 */
 	var objectToString = objectProto.toString;
 	
 	/**
 	 * Checks if `value` is classified as a `Symbol` primitive or object.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 4.0.0
 	 * @category Lang
 	 * @param {*} value The value to check.
-	 * @returns {boolean} Returns `true` if `value` is correctly classified,
-	 *  else `false`.
+	 * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.
 	 * @example
 	 *
 	 * _.isSymbol(Symbol.iterator);
 	 * // => true
 	 *
 	 * _.isSymbol('abc');
 	 * // => false
 	 */
@@ -10026,21 +10084,21 @@ var Debugger =
 	  return typeof value == 'symbol' ||
 	    (isObjectLike(value) && objectToString.call(value) == symbolTag);
 	}
 	
 	module.exports = isSymbol;
 
 
 /***/ },
-/* 93 */
+/* 95 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var isArray = __webpack_require__(52),
-	    isSymbol = __webpack_require__(92);
+	    isSymbol = __webpack_require__(94);
 	
 	/** Used to match property names within property paths. */
 	var reIsDeepProp = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,
 	    reIsPlainProp = /^\w*$/;
 	
 	/**
 	 * Checks if `value` is a property name and not a property path.
 	 *
@@ -10061,20 +10119,20 @@ var Debugger =
 	  return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||
 	    (object != null && value in Object(object));
 	}
 	
 	module.exports = isKey;
 
 
 /***/ },
-/* 94 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isSymbol = __webpack_require__(92);
+/* 96 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isSymbol = __webpack_require__(94);
 	
 	/** Used as references for various `Number` constants. */
 	var INFINITY = 1 / 0;
 	
 	/**
 	 * Converts `value` to a string key if it's not a string or symbol.
 	 *
 	 * @private
@@ -10088,17 +10146,17 @@ var Debugger =
 	  var result = (value + '');
 	  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;
 	}
 	
 	module.exports = toKey;
 
 
 /***/ },
-/* 95 */
+/* 97 */
 /***/ function(module, exports) {
 
 	function Debuggee() {
 	  function $(selector) {
 	    var element = document.querySelector(selector);
 	    console.log("$", selector, element);
 	
 	    if (!element) {
@@ -10218,25 +10276,25 @@ var Debugger =
 	  return window.client.debuggeeCommand(debuggeeStatement).then(result => {
 	    injectedDebuggee = result;
 	  });
 	}
 	
 	module.exports = injectDebuggee;
 
 /***/ },
-/* 96 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(97);
+/* 98 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(99);
 	
 	var Task = _require.Task;
 	
-	var firefox = __webpack_require__(98);
-	var chrome = __webpack_require__(173);
+	var firefox = __webpack_require__(100);
+	var chrome = __webpack_require__(176);
 	
 	var _require2 = __webpack_require__(45);
 	
 	var debugGlobal = _require2.debugGlobal;
 	
 	
 	var clientType = void 0;
 	function getClient() {
@@ -10284,17 +10342,17 @@ var Debugger =
 	
 	module.exports = {
 	  getClient,
 	  connectClients,
 	  startDebugging
 	};
 
 /***/ },
-/* 97 */
+/* 99 */
 /***/ function(module, exports) {
 
 	/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
 	/* vim: set ts=2 et sw=2 tw=80 filetype=javascript: */
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
 	 * You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
@@ -10335,54 +10393,54 @@ var Debugger =
 	      callNext(undefined);
 	    });
 	  }
 	};
 	
 	module.exports = { Task };
 
 /***/ },
-/* 98 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(99);
+/* 100 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(101);
 	
 	var DebuggerClient = _require.DebuggerClient;
 	
-	var _require2 = __webpack_require__(105);
+	var _require2 = __webpack_require__(107);
 	
 	var DebuggerTransport = _require2.DebuggerTransport;
 	
-	var WebSocketDebuggerTransport = __webpack_require__(110);
-	
-	var _require3 = __webpack_require__(113);
+	var WebSocketDebuggerTransport = __webpack_require__(112);
+	
+	var _require3 = __webpack_require__(115);
 	
 	var TargetFactory = _require3.TargetFactory;
 	
-	var defer = __webpack_require__(112);
+	var defer = __webpack_require__(114);
 	
 	var _require4 = __webpack_require__(46);
 	
 	var getValue = _require4.getValue;
 	
-	var _require5 = __webpack_require__(114);
+	var _require5 = __webpack_require__(116);
 	
 	var Tab = _require5.Tab;
 	
-	var _require6 = __webpack_require__(170);
+	var _require6 = __webpack_require__(173);
 	
 	var setupCommands = _require6.setupCommands;
 	var clientCommands = _require6.clientCommands;
 	
-	var _require7 = __webpack_require__(171);
+	var _require7 = __webpack_require__(174);
 	
 	var setupEvents = _require7.setupEvents;
 	var clientEvents = _require7.clientEvents;
 	
-	var _require8 = __webpack_require__(172);
+	var _require8 = __webpack_require__(175);
 	
 	var createSource = _require8.createSource;
 	
 	
 	var debuggerClient = null;
 	var threadClient = null;
 	var tabTarget = null;
 	
@@ -10474,17 +10532,17 @@ var Debugger =
 	  });
 	
 	  // In Firefox, we need to initially request all of the sources. This
 	  // usually fires off individual `newSource` notifications as the
 	  // debugger finds them, but there may be existing sources already in
 	  // the debugger (if it's paused already, or if loading the page from
 	  // bfcache) so explicity fire `newSource` events for all returned
 	  // sources.
-	  return threadClient.getSources().then(_ref => {
+	  return threadClient.getSources().then((_ref) => {
 	    var sources = _ref.sources;
 	
 	    actions.newSources(sources.map(createSource));
 	
 	    // If the threadClient is already paused, make sure to show a
 	    // paused state.
 	    var pausedPacket = threadClient.getLastPausePacket();
 	    if (pausedPacket) {
@@ -10500,17 +10558,17 @@ var Debugger =
 	  getThreadClient,
 	  setThreadClient,
 	  getTabTarget,
 	  setTabTarget,
 	  initPage
 	};
 
 /***/ },
-/* 99 */
+/* 101 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
 	/* vim: set ft=javascript ts=2 et sw=2 tw=80: */
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
@@ -10519,18 +10577,18 @@ var Debugger =
 	const { Ci, Cu, components } = __webpack_require__(28);
 	const { Services } = __webpack_require__(33);
 	const DevToolsUtils = __webpack_require__(27);
 	
 	// WARNING I swapped the sync one for the async one here
 	//const promise = require("resource://devtools/shared/deprecated-sync-thenables.js", {}).Promise;
 	const promise = __webpack_require__(39);
 	
-	const events = __webpack_require__(100);
-	const { WebConsoleClient } = __webpack_require__(103);
+	const events = __webpack_require__(102);
+	const { WebConsoleClient } = __webpack_require__(105);
 	/*const { DebuggerSocket } = require("devtools-sham/shared/security/socket");*/
 	/*const Authentication = require("devtools-sham/shared/security/auth");*/
 	
 	const noop = () => {};
 	
 	/**
 	 * TODO: Get rid of this API in favor of EventTarget (bug 1042642)
 	 *
@@ -13667,32 +13725,32 @@ var Debugger =
 	    telemetry: "ASSIGN"
 	  })
 	};
 	
 	eventSource(EnvironmentClient.prototype);
 
 
 /***/ },
-/* 100 */
+/* 102 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* WEBPACK VAR INJECTION */(function(module) {/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	"use strict";
 	
 	module.metadata = {
 	  "stability": "unstable"
 	};
 	
 	const UNCAUGHT_ERROR = 'An error event was emitted for which there was no listener.';
 	const BAD_LISTENER = 'The event listener must be a function.';
 	
-	const { ns } = __webpack_require__(102);
+	const { ns } = __webpack_require__(104);
 	
 	const event = ns();
 	
 	const EVENT_TYPE_PATTERN = /^on([A-Z]\w+$)/;
 	exports.EVENT_TYPE_PATTERN = EVENT_TYPE_PATTERN;
 	
 	// Utility function to access given event `target` object's event listeners for
 	// the specific event `type`. If listeners for this type does not exists they
@@ -13864,36 +13922,36 @@ var Debugger =
 	
 	    let listener = listeners[key];
 	    if (typeof(listener) === 'function')
 	      on(target, type, listener);
 	  });
 	}
 	exports.setListeners = setListeners;
 	
-	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(101)(module)))
-
-/***/ },
-/* 101 */
+	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(103)(module)))
+
+/***/ },
+/* 103 */
 /***/ function(module, exports) {
 
 	module.exports = function(module) {
 		if(!module.webpackPolyfill) {
 			module.deprecate = function() {};
 			module.paths = [];
 			// module.parent = undefined by default
 			module.children = [];
 			module.webpackPolyfill = 1;
 		}
 		return module;
 	}
 
 
 /***/ },
-/* 102 */
+/* 104 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* WEBPACK VAR INJECTION */(function(module) {/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
 	"use strict";
 	
@@ -13930,35 +13988,35 @@ var Debugger =
 	  };
 	};
 	
 	// `Namespace` is a e4x function in the scope, so we export the function also as
 	// `ns` as alias to avoid clashing.
 	exports.ns = ns;
 	exports.Namespace = ns;
 	
-	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(101)(module)))
-
-/***/ },
-/* 103 */
+	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(103)(module)))
+
+/***/ },
+/* 105 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* -*- js-indent-level: 2; indent-tabs-mode: nil -*- */
 	/* vim: set ts=2 et sw=2 tw=80: */
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
 	"use strict";
 	
 	const {Cc, Ci, Cu} = __webpack_require__(28);
 	const DevToolsUtils = __webpack_require__(27);
-	const EventEmitter = __webpack_require__(104);
+	const EventEmitter = __webpack_require__(106);
 	const promise = __webpack_require__(39);
-	const {LongStringClient} = __webpack_require__(99);
+	const {LongStringClient} = __webpack_require__(101);
 	
 	/**
 	 * A WebConsoleClient is used as a front end for the WebConsoleActor that is
 	 * created on the server, hiding implementation details.
 	 *
 	 * @param object aDebuggerClient
 	 *        The DebuggerClient instance we live for.
 	 * @param object aResponse
@@ -14606,17 +14664,17 @@ var Debugger =
 	    });
 	
 	    return deferred.promise;
 	  }
 	};
 
 
 /***/ },
-/* 104 */
+/* 106 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
 	/**
 	 * EventEmitter.
@@ -14744,39 +14802,39 @@ var Debugger =
 	        }
 	      }
 	    }
 	  },
 	};
 
 
 /***/ },
-/* 105 */
+/* 107 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* eslint-env browser */
 	/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
 	/* vim: set ft=javascript ts=2 et sw=2 tw=80: */
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
 	// TODO: Get rid of this code once the marionette server loads transport.js as
 	// an SDK module (see bug 1000814)
 	
 	"use strict";
 	
 	const DevToolsUtils = __webpack_require__(27);
 	const { dumpn, dumpv } = DevToolsUtils;
-	const StreamUtils = __webpack_require__(106);
+	const StreamUtils = __webpack_require__(108);
 	const { Packet, JSONPacket, BulkPacket } =
-	  __webpack_require__(107);
+	  __webpack_require__(109);
 	const promise = __webpack_require__(39);
-	const EventEmitter = __webpack_require__(104);
-	const utf8 = __webpack_require__(109);
+	const EventEmitter = __webpack_require__(106);
+	const utf8 = __webpack_require__(111);
 	
 	const PACKET_HEADER_MAX = 200;
 	
 	/**
 	 * An adapter that handles data transfers between the debugger client and
 	 * server. It can work with both nsIPipe and nsIServerSocket transports so
 	 * long as the properly created input and output streams are specified.
 	 * (However, for intra-process connections, LocalDebuggerTransport, below,
@@ -15616,30 +15674,30 @@ var Debugger =
 	    };
 	
 	    exports.WorkerDebuggerTransport = WorkerDebuggerTransport;
 	  }).call(this);
 	}
 
 
 /***/ },
-/* 106 */
+/* 108 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
 	"use strict";
 	
 	const { Ci, Cc, Cu, Cr, CC } = __webpack_require__(28);
 	const Services = __webpack_require__(33);
 	const DevToolsUtils = __webpack_require__(27);
 	const { dumpv } = DevToolsUtils;
-	const EventEmitter = __webpack_require__(104);
+	const EventEmitter = __webpack_require__(106);
 	const promise = __webpack_require__(39);
 	
 	const IOUtil = Cc("@mozilla.org/io-util;1").getService(Ci.nsIIOUtil);
 	
 	const ScriptableInputStream = CC("@mozilla.org/scriptableinputstream;1",
 	          "nsIScriptableInputStream", "init");
 	
 	const BUFFER_SIZE = 0x8000;
@@ -15866,17 +15924,17 @@ var Debugger =
 	
 	module.exports = {
 	  copyStream: copyStream,
 	  delimitedRead: delimitedRead
 	};
 
 
 /***/ },
-/* 107 */
+/* 109 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
 	"use strict";
 	
@@ -15898,26 +15956,26 @@ var Debugger =
 	 *     Returns true once the packet is done being read / written
 	 *   * destroy()
 	 *     Called to clean up at the end of use
 	 */
 	
 	const { Cc, Ci, Cu } = __webpack_require__(28);
 	const DevToolsUtils = __webpack_require__(27);
 	const { dumpn, dumpv } = DevToolsUtils;
-	const StreamUtils = __webpack_require__(106);
+	const StreamUtils = __webpack_require__(108);
 	const promise = __webpack_require__(39);
 	
 	/*DevToolsUtils.defineLazyGetter(this, "unicodeConverter", () => {
 	  const unicodeConverter = Cc("@mozilla.org/intl/scriptableunicodeconverter")
 	                           .createInstance(Ci.nsIScriptableUnicodeConverter);
 	  unicodeConverter.charset = "UTF-8";
 	  return unicodeConverter;
 	});*/
-	const utf8 = __webpack_require__(108);
+	const utf8 = __webpack_require__(110);
 	
 	// The transport's previous check ensured the header length did not exceed 20
 	// characters.  Here, we opt for the somewhat smaller, but still large limit of
 	// 1 TiB.
 	const PACKET_LENGTH_MAX = Math.pow(2, 40);
 	
 	/**
 	 * A generic Packet processing object (extended by two subtypes below).
@@ -16290,17 +16348,17 @@ var Debugger =
 	Object.defineProperty(RawPacket.prototype, "done", {
 	  get: function() { return this._done; }
 	});
 	
 	exports.RawPacket = RawPacket;
 
 
 /***/ },
-/* 108 */
+/* 110 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var __WEBPACK_AMD_DEFINE_RESULT__;/* WEBPACK VAR INJECTION */(function(module, global) {/*! https://mths.be/utf8js v2.0.0 by @mathias */
 	;(function(root) {
 	
 		// Detect free variables `exports`
 		var freeExports = typeof exports == 'object' && exports;
 	
@@ -16536,20 +16594,20 @@ var Debugger =
 				}
 			}
 		} else { // in Rhino or a web browser
 			root.utf8 = utf8;
 		}
 	
 	}(this));
 	
-	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(101)(module), (function() { return this; }())))
-
-/***/ },
-/* 109 */
+	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(103)(module), (function() { return this; }())))
+
+/***/ },
+/* 111 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var __WEBPACK_AMD_DEFINE_RESULT__;/* WEBPACK VAR INJECTION */(function(module, global) {/*! https://mths.be/utf8js v2.0.0 by @mathias */
 	;(function(root) {
 	
 		// Detect free variables `exports`
 		var freeExports = typeof exports == 'object' && exports;
 	
@@ -16785,29 +16843,29 @@ var Debugger =
 				}
 			}
 		} else { // in Rhino or a web browser
 			root.utf8 = utf8;
 		}
 	
 	}(this));
 	
-	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(101)(module), (function() { return this; }())))
-
-/***/ },
-/* 110 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* This Source Code Form is subject to the terms of the Mozilla Public
-	 * License, v. 2.0. If a copy of the MPL was not distributed with this
-	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-	
-	"use strict";
-	
-	const EventEmitter = __webpack_require__(111);
+	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(103)(module), (function() { return this; }())))
+
+/***/ },
+/* 112 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/* This Source Code Form is subject to the terms of the Mozilla Public
+	 * License, v. 2.0. If a copy of the MPL was not distributed with this
+	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+	
+	"use strict";
+	
+	const EventEmitter = __webpack_require__(113);
 	
 	function WebSocketDebuggerTransport(socket) {
 	  EventEmitter.decorate(this);
 	
 	  this.active = false;
 	  this.hooks = null;
 	  this.socket = socket;
 	}
@@ -16873,22 +16931,22 @@ var Debugger =
 	    }
 	  },
 	};
 	
 	module.exports = WebSocketDebuggerTransport;
 
 
 /***/ },
-/* 111 */
+/* 113 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var EventEmitter = function () {};
 	
-	var defer = __webpack_require__(112);
+	var defer = __webpack_require__(114);
 	
 	/**
 	 * Decorate an object with event emitter functionality.
 	 *
 	 * @param Object objectToDecorate
 	 *        Bind all public methods of EventEmitter to
 	 *        the objectToDecorate object.
 	 */
@@ -17017,17 +17075,17 @@ var Debugger =
 	      if (_ret === "break") break;
 	    }
 	  }
 	};
 	
 	module.exports = EventEmitter;
 
 /***/ },
-/* 112 */
+/* 114 */
 /***/ function(module, exports) {
 
 	module.exports = function defer() {
 	  var resolve = void 0,
 	      reject = void 0;
 	  var promise = new Promise(function () {
 	    resolve = arguments[0];
 	    reject = arguments[1];
@@ -17035,32 +17093,32 @@ var Debugger =
 	  return {
 	    resolve: resolve,
 	    reject: reject,
 	    promise: promise
 	  };
 	};
 
 /***/ },
-/* 113 */
+/* 115 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
 	"use strict";
 	
 	const { Ci, Cu } = __webpack_require__(28);
 	const promise = __webpack_require__(39);
-	const EventEmitter = __webpack_require__(104);
+	const EventEmitter = __webpack_require__(106);
 	const { Services } = __webpack_require__(33);
 	
 	/*const { DebuggerServer } = require("devtools-sham/server/main");*/
-	const { DebuggerClient } = __webpack_require__(99);
+	const { DebuggerClient } = __webpack_require__(101);
 	
 	const targets = new WeakMap();
 	const promiseTargets = new WeakMap();
 	
 	/**
 	 * Functions for creating Targets
 	 */
 	exports.TargetFactory = {
@@ -17731,20 +17789,20 @@ var Debugger =
 	
 	  makeRemote: function () {
 	    return Promise.resolve();
 	  }
 	};
 
 
 /***/ },
-/* 114 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var t = __webpack_require__(115);
+/* 116 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var t = __webpack_require__(117);
 	
 	var Tab = t.struct({
 	  title: t.String,
 	  url: t.String,
 	  id: t.String,
 	  tab: t.Object,
 	  browser: t.enums.of(["chrome", "firefox"])
 	}, "Tab");
@@ -17794,97 +17852,97 @@ var Debugger =
 	  SourceText,
 	  Location,
 	  Breakpoint,
 	  BreakpointResult,
 	  Frame
 	};
 
 /***/ },
-/* 115 */
+/* 117 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/*! @preserve
 	 *
 	 * tcomb.js - Type checking and DDD for JavaScript
 	 *
 	 * The MIT License (MIT)
 	 *
 	 * Copyright (c) 2014-2016 Giulio Canti
 	 *
 	 */
 	
 	// core
-	var t = __webpack_require__(116);
+	var t = __webpack_require__(118);
 	
 	// types
-	t.Any = __webpack_require__(122);
-	t.Array = __webpack_require__(130);
-	t.Boolean = __webpack_require__(131);
-	t.Date = __webpack_require__(133);
-	t.Error = __webpack_require__(134);
-	t.Function = __webpack_require__(135);
-	t.Nil = __webpack_require__(136);
-	t.Number = __webpack_require__(137);
-	t.Integer = __webpack_require__(139);
+	t.Any = __webpack_require__(124);
+	t.Array = __webpack_require__(132);
+	t.Boolean = __webpack_require__(133);
+	t.Date = __webpack_require__(135);
+	t.Error = __webpack_require__(136);
+	t.Function = __webpack_require__(137);
+	t.Nil = __webpack_require__(138);
+	t.Number = __webpack_require__(139);
+	t.Integer = __webpack_require__(141);
 	t.IntegerT = t.Integer;
-	t.Object = __webpack_require__(145);
-	t.RegExp = __webpack_require__(146);
-	t.String = __webpack_require__(147);
-	t.Type = __webpack_require__(148);
+	t.Object = __webpack_require__(147);
+	t.RegExp = __webpack_require__(148);
+	t.String = __webpack_require__(149);
+	t.Type = __webpack_require__(150);
 	t.TypeT = t.Type;
 	
 	// short alias are deprecated
 	t.Arr = t.Array;
 	t.Bool = t.Boolean;
 	t.Dat = t.Date;
 	t.Err = t.Error;
 	t.Func = t.Function;
 	t.Num = t.Number;
 	t.Obj = t.Object;
 	t.Re = t.RegExp;
 	t.Str = t.String;
 	
 	// combinators
-	t.dict = __webpack_require__(149);
-	t.declare = __webpack_require__(150);
-	t.enums = __webpack_require__(152);
-	t.irreducible = __webpack_require__(123);
-	t.list = __webpack_require__(153);
-	t.maybe = __webpack_require__(154);
-	t.refinement = __webpack_require__(140);
-	t.struct = __webpack_require__(156);
-	t.tuple = __webpack_require__(162);
-	t.union = __webpack_require__(163);
-	t.func = __webpack_require__(165);
-	t.intersection = __webpack_require__(166);
+	t.dict = __webpack_require__(151);
+	t.declare = __webpack_require__(152);
+	t.enums = __webpack_require__(155);
+	t.irreducible = __webpack_require__(125);
+	t.list = __webpack_require__(156);
+	t.maybe = __webpack_require__(157);
+	t.refinement = __webpack_require__(142);
+	t.struct = __webpack_require__(159);
+	t.tuple = __webpack_require__(165);
+	t.union = __webpack_require__(166);
+	t.func = __webpack_require__(167);
+	t.intersection = __webpack_require__(168);
 	t.subtype = t.refinement;
-	t.inter = __webpack_require__(167); // IE8 alias
+	t.inter = __webpack_require__(169); // IE8 alias
 	t['interface'] = t.inter;
 	
 	// functions
 	t.assert = t;
-	t.update = __webpack_require__(168);
-	t.mixin = __webpack_require__(151);
-	t.isType = __webpack_require__(127);
-	t.is = __webpack_require__(144);
-	t.getTypeName = __webpack_require__(126);
-	t.match = __webpack_require__(169);
+	t.update = __webpack_require__(171);
+	t.mixin = __webpack_require__(153);
+	t.isType = __webpack_require__(129);
+	t.is = __webpack_require__(146);
+	t.getTypeName = __webpack_require__(128);
+	t.match = __webpack_require__(172);
 	
 	module.exports = t;
 
 
 /***/ },
-/* 116 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isFunction = __webpack_require__(117);
-	var isNil = __webpack_require__(118);
-	var fail = __webpack_require__(119);
-	var stringify = __webpack_require__(120);
+/* 118 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isFunction = __webpack_require__(119);
+	var isNil = __webpack_require__(120);
+	var fail = __webpack_require__(121);
+	var stringify = __webpack_require__(122);
 	
 	function assert(guard, message) {
 	  if (guard !== true) {
 	    if (isFunction(message)) { // handle lazy messages
 	      message = message();
 	    }
 	    else if (isNil(message)) { // use a default message
 	      message = 'Assert failed (turn on "Pause on exceptions" in your Source panel)';
@@ -17894,44 +17952,44 @@ var Debugger =
 	}
 	
 	assert.fail = fail;
 	assert.stringify = stringify;
 	
 	module.exports = assert;
 
 /***/ },
-/* 117 */
+/* 119 */
 /***/ function(module, exports) {
 
 	module.exports = function isFunction(x) {
 	  return typeof x === 'function';
 	};
 
 /***/ },
-/* 118 */
+/* 120 */
 /***/ function(module, exports) {
 
 	module.exports = function isNil(x) {
 	  return x === null || x === void 0;
 	};
 
 /***/ },
-/* 119 */
+/* 121 */
 /***/ function(module, exports) {
 
 	module.exports = function fail(message) {
 	  throw new TypeError('[tcomb] ' + message);
 	};
 
 /***/ },
-/* 120 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getFunctionName = __webpack_require__(121);
+/* 122 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getFunctionName = __webpack_require__(123);
 	
 	function replacer(key, value) {
 	  if (typeof value === 'function') {
 	    return getFunctionName(value);
 	  }
 	  return value;
 	}
 	
@@ -17940,40 +17998,40 @@ var Debugger =
 	    return JSON.stringify(x, replacer, 2);
 	  }
 	  catch (e) {
 	    return String(x);
 	  }
 	};
 
 /***/ },
-/* 121 */
+/* 123 */
 /***/ function(module, exports) {
 
 	module.exports = function getFunctionName(f) {
 	  return f.displayName || f.name || '<function' + f.length + '>';
 	};
 
 /***/ },
-/* 122 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(123);
+/* 124 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(125);
 	
 	module.exports = irreducible('Any', function () { return true; });
 
 
 /***/ },
-/* 123 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isString = __webpack_require__(124);
-	var isFunction = __webpack_require__(117);
-	var forbidNewOperator = __webpack_require__(125);
+/* 125 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isString = __webpack_require__(126);
+	var isFunction = __webpack_require__(119);
+	var forbidNewOperator = __webpack_require__(127);
 	
 	module.exports = function irreducible(name, predicate) {
 	
 	  if (false) {
 	    assert(isString(name), function () { return 'Invalid argument name ' + assert.stringify(name) + ' supplied to irreducible(name, predicate) (expected a string)'; });
 	    assert(isFunction(predicate), 'Invalid argument predicate ' + assert.stringify(predicate) + ' supplied to irreducible(name, predicate) (expected a function)');
 	  }
 	
@@ -17999,185 +18057,185 @@ var Debugger =
 	
 	  Irreducible.is = predicate;
 	
 	  return Irreducible;
 	};
 
 
 /***/ },
-/* 124 */
+/* 126 */
 /***/ function(module, exports) {
 
 	module.exports = function isString(x) {
 	  return typeof x === 'string';
 	};
 
 /***/ },
-/* 125 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var getTypeName = __webpack_require__(126);
+/* 127 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var getTypeName = __webpack_require__(128);
 	
 	module.exports = function forbidNewOperator(x, type) {
 	  assert(!(x instanceof type), function () { return 'Cannot use the new operator to instantiate the type ' + getTypeName(type); });
 	};
 
 /***/ },
-/* 126 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(127);
-	var getFunctionName = __webpack_require__(121);
-	
-	module.exports = function getTypeName(constructor) {
-	  if (isType(constructor)) {
-	    return constructor.displayName;
-	  }
-	  return getFunctionName(constructor);
-	};
-
-/***/ },
-/* 127 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isFunction = __webpack_require__(117);
-	var isObject = __webpack_require__(128);
-	
-	module.exports = function isType(x) {
-	  return isFunction(x) && isObject(x.meta);
-	};
-
-/***/ },
 /* 128 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var isNil = __webpack_require__(118);
-	var isArray = __webpack_require__(129);
-	
-	module.exports = function isObject(x) {
-	  return !isNil(x) && typeof x === 'object' && !isArray(x);
+	var isType = __webpack_require__(129);
+	var getFunctionName = __webpack_require__(123);
+	
+	module.exports = function getTypeName(ctor) {
+	  if (isType(ctor)) {
+	    return ctor.displayName;
+	  }
+	  return getFunctionName(ctor);
 	};
 
 /***/ },
 /* 129 */
-/***/ function(module, exports) {
-
-	module.exports = function isArray(x) {
-	  return x instanceof Array;
+/***/ function(module, exports, __webpack_require__) {
+
+	var isFunction = __webpack_require__(119);
+	var isObject = __webpack_require__(130);
+	
+	module.exports = function isType(x) {
+	  return isFunction(x) && isObject(x.meta);
 	};
 
 /***/ },
 /* 130 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(123);
-	var isArray = __webpack_require__(129);
-	
-	module.exports = irreducible('Array', isArray);
-
+	var isNil = __webpack_require__(120);
+	var isArray = __webpack_require__(131);
+	
+	module.exports = function isObject(x) {
+	  return !isNil(x) && typeof x === 'object' && !isArray(x);
+	};
 
 /***/ },
 /* 131 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(123);
-	var isBoolean = __webpack_require__(132);
-	
-	module.exports = irreducible('Boolean', isBoolean);
-
+/***/ function(module, exports) {
+
+	module.exports = function isArray(x) {
+	  return Array.isArray ? Array.isArray(x) : x instanceof Array;
+	};
 
 /***/ },
 /* 132 */
-/***/ function(module, exports) {
-
-	module.exports = function isBoolean(x) {
-	  return x === true || x === false;
-	};
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(125);
+	var isArray = __webpack_require__(131);
+	
+	module.exports = irreducible('Array', isArray);
+
 
 /***/ },
 /* 133 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(123);
-	
-	module.exports = irreducible('Date', function (x) { return x instanceof Date; });
+	var irreducible = __webpack_require__(125);
+	var isBoolean = __webpack_require__(134);
+	
+	module.exports = irreducible('Boolean', isBoolean);
 
 
 /***/ },
 /* 134 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(123);
-	
-	module.exports = irreducible('Error', function (x) { return x instanceof Error; });
-
+/***/ function(module, exports) {
+
+	module.exports = function isBoolean(x) {
+	  return x === true || x === false;
+	};
 
 /***/ },
 /* 135 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(123);
-	var isFunction = __webpack_require__(117);
-	
-	module.exports = irreducible('Function', isFunction);
+	var irreducible = __webpack_require__(125);
+	
+	module.exports = irreducible('Date', function (x) { return x instanceof Date; });
 
 
 /***/ },
 /* 136 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(123);
-	var isNil = __webpack_require__(118);
-	
-	module.exports = irreducible('Nil', isNil);
+	var irreducible = __webpack_require__(125);
+	
+	module.exports = irreducible('Error', function (x) { return x instanceof Error; });
 
 
 /***/ },
 /* 137 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(123);
-	var isNumber = __webpack_require__(138);
-	
-	module.exports = irreducible('Number', isNumber);
+	var irreducible = __webpack_require__(125);
+	var isFunction = __webpack_require__(119);
+	
+	module.exports = irreducible('Function', isFunction);
 
 
 /***/ },
 /* 138 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(125);
+	var isNil = __webpack_require__(120);
+	
+	module.exports = irreducible('Nil', isNil);
+
+
+/***/ },
+/* 139 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(125);
+	var isNumber = __webpack_require__(140);
+	
+	module.exports = irreducible('Number', isNumber);
+
+
+/***/ },
+/* 140 */
 /***/ function(module, exports) {
 
 	module.exports = function isNumber(x) {
 	  return typeof x === 'number' && isFinite(x) && !isNaN(x);
 	};
 
 /***/ },
-/* 139 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var refinement = __webpack_require__(140);
-	var Number = __webpack_require__(137);
+/* 141 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var refinement = __webpack_require__(142);
+	var Number = __webpack_require__(139);
 	
 	module.exports = refinement(Number, function (x) { return x % 1 === 0; }, 'Integer');
 
 
 /***/ },
-/* 140 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var isFunction = __webpack_require__(117);
-	var forbidNewOperator = __webpack_require__(125);
-	var isIdentity = __webpack_require__(142);
-	var create = __webpack_require__(143);
-	var is = __webpack_require__(144);
-	var getTypeName = __webpack_require__(126);
-	var getFunctionName = __webpack_require__(121);
+/* 142 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var isFunction = __webpack_require__(119);
+	var forbidNewOperator = __webpack_require__(127);
+	var isIdentity = __webpack_require__(144);
+	var create = __webpack_require__(145);
+	var is = __webpack_require__(146);
+	var getTypeName = __webpack_require__(128);
+	var getFunctionName = __webpack_require__(123);
 	
 	function getDefaultName(type, predicate) {
 	  return '{' + getTypeName(type) + ' | ' + getFunctionName(predicate) + '}';
 	}
 	
 	function refinement(type, predicate, name) {
 	
 	  if (false) {
@@ -18187,17 +18245,19 @@ var Debugger =
 	  }
 	
 	  var displayName = name || getDefaultName(type, predicate);
 	  var identity = isIdentity(type);
 	
 	  function Refinement(value, path) {
 	
 	    if (false) {
-	      forbidNewOperator(this, Refinement);
+	      if (identity) {
+	        forbidNewOperator(this, Refinement);
+	      }
 	      path = path || [displayName];
 	    }
 	
 	    var x = create(type, value, path);
 	
 	    if (false) {
 	      assert(predicate(x), function () { return 'Invalid value ' + assert.stringify(value) + ' supplied to ' + path.join('/'); });
 	    }
@@ -18226,137 +18286,136 @@ var Debugger =
 	  return Refinement;
 	}
 	
 	refinement.getDefaultName = getDefaultName;
 	module.exports = refinement;
 
 
 /***/ },
-/* 141 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isNil = __webpack_require__(118);
-	var isString = __webpack_require__(124);
+/* 143 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isNil = __webpack_require__(120);
+	var isString = __webpack_require__(126);
 	
 	module.exports = function isTypeName(name) {
 	  return isNil(name) || isString(name);
 	};
 
 /***/ },
-/* 142 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var Boolean = __webpack_require__(131);
-	var isType = __webpack_require__(127);
-	var getTypeName = __webpack_require__(126);
+/* 144 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var Boolean = __webpack_require__(133);
+	var isType = __webpack_require__(129);
+	var getTypeName = __webpack_require__(128);
 	
 	// return true if the type constructor behaves like the identity function
 	module.exports = function isIdentity(type) {
 	  if (isType(type)) {
 	    if (false) {
 	      assert(Boolean.is(type.meta.identity), function () { return 'Invalid meta identity ' + assert.stringify(type.meta.identity) + ' supplied to type ' + getTypeName(type); });
 	    }
 	    return type.meta.identity;
 	  }
 	  // for tcomb the other constructors, like ES6 classes, are identity-like
 	  return true;
 	};
 
 /***/ },
-/* 143 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(127);
-	var getFunctionName = __webpack_require__(121);
-	var assert = __webpack_require__(116);
-	var stringify = __webpack_require__(120);
+/* 145 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(129);
+	var getFunctionName = __webpack_require__(123);
+	var assert = __webpack_require__(118);
+	var stringify = __webpack_require__(122);
 	
 	// creates an instance of a type, handling the optional new operator
 	module.exports = function create(type, value, path) {
 	  if (isType(type)) {
-	    // for structs the new operator is allowed
-	    return type.meta.kind === 'struct' ? new type(value, path) : type(value, path);
+	    return !type.meta.identity && typeof value === 'object' && value !== null ? new type(value, path): type(value, path);
 	  }
 	
 	  if (false) {
 	    // here type should be a class constructor and value some instance, just check membership and return the value
 	    path = path || [getFunctionName(type)];
 	    assert(value instanceof type, function () { return 'Invalid value ' + stringify(value) + ' supplied to ' + path.join('/'); });
 	  }
 	
 	  return value;
 	};
 
 /***/ },
-/* 144 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(127);
+/* 146 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(129);
 	
 	// returns true if x is an instance of type
 	module.exports = function is(x, type) {
 	  if (isType(type)) {
 	    return type.is(x);
 	  }
 	  return x instanceof type; // type should be a class constructor
 	};
 
 
 /***/ },
-/* 145 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(123);
-	var isObject = __webpack_require__(128);
+/* 147 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(125);
+	var isObject = __webpack_require__(130);
 	
 	module.exports = irreducible('Object', isObject);
 
 
 /***/ },
-/* 146 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(123);
-	
-	module.exports = irreducible('RegExp', function (x) { return x instanceof RegExp; });
-
-
-/***/ },
-/* 147 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(123);
-	var isString = __webpack_require__(124);
-	
-	module.exports = irreducible('String', isString);
-
-
-/***/ },
 /* 148 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(123);
-	var isType = __webpack_require__(127);
-	
-	module.exports = irreducible('Type', isType);
+	var irreducible = __webpack_require__(125);
+	
+	module.exports = irreducible('RegExp', function (x) { return x instanceof RegExp; });
+
 
 /***/ },
 /* 149 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var isFunction = __webpack_require__(117);
-	var getTypeName = __webpack_require__(126);
-	var isIdentity = __webpack_require__(142);
-	var isObject = __webpack_require__(128);
-	var create = __webpack_require__(143);
-	var is = __webpack_require__(144);
+	var irreducible = __webpack_require__(125);
+	var isString = __webpack_require__(126);
+	
+	module.exports = irreducible('String', isString);
+
+
+/***/ },
+/* 150 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(125);
+	var isType = __webpack_require__(129);
+	
+	module.exports = irreducible('Type', isType);
+
+/***/ },
+/* 151 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var isFunction = __webpack_require__(119);
+	var getTypeName = __webpack_require__(128);
+	var isIdentity = __webpack_require__(144);
+	var isObject = __webpack_require__(130);
+	var create = __webpack_require__(145);
+	var is = __webpack_require__(146);
 	
 	function getDefaultName(domain, codomain) {
 	  return '{[key: ' + getTypeName(domain) + ']: ' + getTypeName(codomain) + '}';
 	}
 	
 	function dict(domain, codomain, name) {
 	
 	  if (false) {
@@ -18437,77 +18496,83 @@ var Debugger =
 	  return Dict;
 	}
 	
 	dict.getDefaultName = getDefaultName;
 	module.exports = dict;
 
 
 /***/ },
-/* 150 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var isType = __webpack_require__(127);
-	var isNil = __webpack_require__(118);
-	var mixin = __webpack_require__(151);
-	var getTypeName = __webpack_require__(126);
+/* 152 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var isType = __webpack_require__(129);
+	var isNil = __webpack_require__(120);
+	var mixin = __webpack_require__(153);
+	var getTypeName = __webpack_require__(128);
+	var isUnion = __webpack_require__(154);
 	
 	// All the .declare-d types should be clearly different from each other thus they should have
 	// different names when a name was not explicitly provided.
 	var nextDeclareUniqueId = 1;
 	
 	module.exports = function declare(name) {
 	  if (false) {
 	    assert(isTypeName(name), function () { return 'Invalid argument name ' + name + ' supplied to declare([name]) (expected a string)'; });
 	  }
 	
 	  var type;
 	
 	  function Declare(value, path) {
 	    if (false) {
 	      assert(!isNil(type), function () { return 'Type declared but not defined, don\'t forget to call .define on every declared type'; });
+	      if (isUnion(type)) {
+	        assert(type.dispatch === Declare.dispatch, function () { return 'Please define the custom ' + name + '.dispatch function before calling ' + name + '.define()'; });
+	      }
 	    }
 	    return type(value, path);
 	  }
 	
 	  Declare.define = function (spec) {
 	    if (false) {
 	      assert(isType(spec), function () { return 'Invalid argument type ' + assert.stringify(spec) +  ' supplied to define(type) (expected a type)'; });
 	      assert(isNil(type), function () { return 'Declare.define(type) can only be invoked once'; });
 	      assert(isNil(spec.meta.name) && Object.keys(spec.prototype).length === 0, function () { return 'Invalid argument type ' + assert.stringify(spec) + ' supplied to define(type) (expected a fresh, unnamed type)'; });
 	    }
 	
+	    if (isUnion(spec) && Declare.hasOwnProperty('dispatch')) {
+	      spec.dispatch = Declare.dispatch;
+	    }
 	    type = spec;
 	    mixin(Declare, type, true); // true because it overwrites Declare.displayName
 	    if (name) {
 	      type.displayName = Declare.displayName = name;
 	      Declare.meta.name = name;
 	    }
-	    // ensure identity is still false
-	    Declare.meta.identity = false;
+	    Declare.meta.identity = type.meta.identity;
 	    Declare.prototype = type.prototype;
 	    return Declare;
 	  };
 	
 	  Declare.displayName = name || ( getTypeName(Declare) + "$" + nextDeclareUniqueId++ );
 	  // in general I can't say if this type will be an identity, for safety setting to false
 	  Declare.meta = { identity: false };
 	  Declare.prototype = null;
 	  return Declare;
 	};
 
 
 /***/ },
-/* 151 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isNil = __webpack_require__(118);
-	var assert = __webpack_require__(116);
+/* 153 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isNil = __webpack_require__(120);
+	var assert = __webpack_require__(118);
 	
 	// safe mixin, cannot override props unless specified
 	module.exports = function mixin(target, source, overwrite) {
 	  if (isNil(source)) { return target; }
 	  for (var k in source) {
 	    if (source.hasOwnProperty(k)) {
 	      if (overwrite !== true) {
 	        if (false) {
@@ -18516,24 +18581,34 @@ var Debugger =
 	      }
 	      target[k] = source[k];
 	    }
 	  }
 	  return target;
 	};
 
 /***/ },
-/* 152 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var forbidNewOperator = __webpack_require__(125);
-	var isString = __webpack_require__(124);
-	var isObject = __webpack_require__(128);
+/* 154 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(129);
+	
+	module.exports = function isUnion(x) {
+	  return isType(x) && ( x.meta.kind === 'union' );
+	};
+
+/***/ },
+/* 155 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var forbidNewOperator = __webpack_require__(127);
+	var isString = __webpack_require__(126);
+	var isObject = __webpack_require__(130);
 	
 	function getDefaultName(map) {
 	  return Object.keys(map).map(function (k) { return assert.stringify(k); }).join(' | ');
 	}
 	
 	function enums(map, name) {
 	
 	  if (false) {
@@ -18580,27 +18655,27 @@ var Debugger =
 	};
 	
 	enums.getDefaultName = getDefaultName;
 	module.exports = enums;
 	
 
 
 /***/ },
-/* 153 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var isFunction = __webpack_require__(117);
-	var getTypeName = __webpack_require__(126);
-	var isIdentity = __webpack_require__(142);
-	var create = __webpack_require__(143);
-	var is = __webpack_require__(144);
-	var isArray = __webpack_require__(129);
+/* 156 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var isFunction = __webpack_require__(119);
+	var getTypeName = __webpack_require__(128);
+	var isIdentity = __webpack_require__(144);
+	var create = __webpack_require__(145);
+	var is = __webpack_require__(146);
+	var isArray = __webpack_require__(131);
 	
 	function getDefaultName(type) {
 	  return 'Array<' + getTypeName(type) + '>';
 	}
 	
 	function list(type, name) {
 	
 	  if (false) {
@@ -18667,30 +18742,30 @@ var Debugger =
 	  return List;
 	}
 	
 	list.getDefaultName = getDefaultName;
 	module.exports = list;
 
 
 /***/ },
-/* 154 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var isFunction = __webpack_require__(117);
-	var isMaybe = __webpack_require__(155);
-	var isIdentity = __webpack_require__(142);
-	var Any = __webpack_require__(122);
-	var create = __webpack_require__(143);
-	var Nil = __webpack_require__(136);
-	var forbidNewOperator = __webpack_require__(125);
-	var is = __webpack_require__(144);
-	var getTypeName = __webpack_require__(126);
+/* 157 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var isFunction = __webpack_require__(119);
+	var isMaybe = __webpack_require__(158);
+	var isIdentity = __webpack_require__(144);
+	var Any = __webpack_require__(124);
+	var create = __webpack_require__(145);
+	var Nil = __webpack_require__(138);
+	var forbidNewOperator = __webpack_require__(127);
+	var is = __webpack_require__(146);
+	var getTypeName = __webpack_require__(128);
 	
 	function getDefaultName(type) {
 	  return '?' + getTypeName(type);
 	}
 	
 	function maybe(type, name) {
 	
 	  if (isMaybe(type) || type === Any || type === Nil) { // makes the combinator idempotent and handle Any, Nil
@@ -18698,70 +18773,73 @@ var Debugger =
 	  }
 	
 	  if (false) {
 	    assert(isFunction(type), function () { return 'Invalid argument type ' + assert.stringify(type) + ' supplied to maybe(type, [name]) combinator (expected a type)'; });
 	    assert(isTypeName(name), function () { return 'Invalid argument name ' + assert.stringify(name) + ' supplied to maybe(type, [name]) combinator (expected a string)'; });
 	  }
 	
 	  var displayName = name || getDefaultName(type);
+	  var identity = isIdentity(type);
 	
 	  function Maybe(value, path) {
 	    if (false) {
-	      forbidNewOperator(this, Maybe);
+	      if (identity) {
+	        forbidNewOperator(this, Maybe);
+	      }
 	    }
 	    return Nil.is(value) ? value : create(type, value, path);
 	  }
 	
 	  Maybe.meta = {
 	    kind: 'maybe',
 	    type: type,
 	    name: name,
-	    identity: isIdentity(type)
+	    identity: identity
 	  };
 	
 	  Maybe.displayName = displayName;
 	
 	  Maybe.is = function (x) {
 	    return Nil.is(x) || is(x, type);
 	  };
 	
 	  return Maybe;
 	}
 	
 	maybe.getDefaultName = getDefaultName;
 	module.exports = maybe;
 
 
 /***/ },
-/* 155 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(127);
+/* 158 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(129);
 	
 	module.exports = function isMaybe(x) {
 	  return isType(x) && ( x.meta.kind === 'maybe' );
 	};
 
 /***/ },
-/* 156 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var String = __webpack_require__(147);
-	var Function = __webpack_require__(135);
-	var isBoolean = __webpack_require__(132);
-	var isObject = __webpack_require__(128);
-	var isNil = __webpack_require__(118);
-	var create = __webpack_require__(143);
-	var getTypeName = __webpack_require__(126);
-	var dict = __webpack_require__(149);
-	var getDefaultInterfaceName = __webpack_require__(157);
-	var extend = __webpack_require__(158);
+/* 159 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var String = __webpack_require__(149);
+	var Function = __webpack_require__(137);
+	var isBoolean = __webpack_require__(134);
+	var isObject = __webpack_require__(130);
+	var isNil = __webpack_require__(120);
+	var create = __webpack_require__(145);
+	var getTypeName = __webpack_require__(128);
+	var dict = __webpack_require__(151);
+	var getDefaultInterfaceName = __webpack_require__(160);
+	var extend = __webpack_require__(161);
 	
 	function getDefaultName(props) {
 	  return 'Struct' + getDefaultInterfaceName(props);
 	}
 	
 	function extendStruct(mixins, name) {
 	  return extend(struct, mixins, name);
 	}
@@ -18865,43 +18943,43 @@ var Debugger =
 	struct.strict = false;
 	struct.getOptions = getOptions;
 	struct.getDefaultName = getDefaultName;
 	struct.extend = extendStruct;
 	module.exports = struct;
 
 
 /***/ },
-/* 157 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getTypeName = __webpack_require__(126);
+/* 160 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getTypeName = __webpack_require__(128);
 	
 	function getDefaultInterfaceName(props) {
 	  return '{' + Object.keys(props).map(function (prop) {
 	    return prop + ': ' + getTypeName(props[prop]);
 	  }).join(', ') + '}';
 	}
 	
 	module.exports = getDefaultInterfaceName;
 
 
 /***/ },
-/* 158 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isFunction = __webpack_require__(117);
-	var isArray = __webpack_require__(129);
-	var mixin = __webpack_require__(151);
-	var isStruct = __webpack_require__(159);
-	var isInterface = __webpack_require__(160);
-	var isObject = __webpack_require__(128);
-	var refinement = __webpack_require__(140);
-	var decompose = __webpack_require__(161);
+/* 161 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isFunction = __webpack_require__(119);
+	var isArray = __webpack_require__(131);
+	var mixin = __webpack_require__(153);
+	var isStruct = __webpack_require__(162);
+	var isInterface = __webpack_require__(163);
+	var isObject = __webpack_require__(130);
+	var refinement = __webpack_require__(142);
+	var decompose = __webpack_require__(164);
 	
 	function compose(predicates, unrefinedType) {
 	  return predicates.reduce(function (type, predicate) {
 	    return refinement(type, predicate);
 	  }, unrefinedType);
 	}
 	
 	function getProps(type) {
@@ -18929,52 +19007,52 @@ var Debugger =
 	    var decomposition = decompose(x);
 	    var unrefinedType = decomposition.unrefinedType;
 	    if (false) {
 	      assert(isObject(unrefinedType) || isStruct(unrefinedType) || isInterface(unrefinedType), function () { return 'Invalid argument mixins[' + i + '] supplied to extend(combinator, mixins, options), expected an object, struct, interface or a refinement (of struct or interface)'; });
 	    }
 	    pushAll(predicates, decomposition.predicates);
 	    mixin(props, getProps(unrefinedType));
 	    mixin(prototype, unrefinedType.prototype);
-	    mixin(defaultProps, getDefaultProps(unrefinedType));
+	    mixin(defaultProps, getDefaultProps(unrefinedType), true);
 	  });
 	  options = combinator.getOptions(options);
-	  mixin(options.defaultProps, defaultProps);
+	  options.defaultProps = mixin(defaultProps, options.defaultProps, true);
 	  var result = compose(predicates, combinator(props, options));
 	  mixin(result.prototype, prototype);
 	  return result;
 	}
 	
 	module.exports = extend;
 
 /***/ },
-/* 159 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(127);
+/* 162 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(129);
 	
 	module.exports = function isStruct(x) {
 	  return isType(x) && ( x.meta.kind === 'struct' );
 	};
 
 /***/ },
-/* 160 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(127);
+/* 163 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(129);
 	
 	module.exports = function isInterface(x) {
 	  return isType(x) && ( x.meta.kind === 'interface' );
 	};
 
 /***/ },
-/* 161 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(127);
+/* 164 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(129);
 	
 	function isRefinement(type) {
 	  return isType(type) && type.meta.kind === 'subtype';
 	}
 	
 	function getPredicates(type) {
 	  return isRefinement(type) ?
 	    [type.meta.predicate].concat(getPredicates(type.meta.type)) :
@@ -18992,27 +19070,27 @@ var Debugger =
 	    predicates: getPredicates(type),
 	    unrefinedType: getUnrefinedType(type)
 	  };
 	}
 	
 	module.exports = decompose;
 
 /***/ },
-/* 162 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var isFunction = __webpack_require__(117);
-	var getTypeName = __webpack_require__(126);
-	var isIdentity = __webpack_require__(142);
-	var isArray = __webpack_require__(129);
-	var create = __webpack_require__(143);
-	var is = __webpack_require__(144);
+/* 165 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var isFunction = __webpack_require__(119);
+	var getTypeName = __webpack_require__(128);
+	var isIdentity = __webpack_require__(144);
+	var isArray = __webpack_require__(131);
+	var create = __webpack_require__(145);
+	var is = __webpack_require__(146);
 	
 	function getDefaultName(types) {
 	  return '[' + types.map(getTypeName).join(', ') + ']';
 	}
 	
 	function tuple(types, name) {
 	
 	  if (false) {
@@ -19080,31 +19158,30 @@ var Debugger =
 	
 	  return Tuple;
 	}
 	
 	tuple.getDefaultName = getDefaultName;
 	module.exports = tuple;
 
 /***/ },
-/* 163 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var isFunction = __webpack_require__(117);
-	var getTypeName = __webpack_require__(126);
-	var isIdentity = __webpack_require__(142);
-	var isArray = __webpack_require__(129);
-	var create = __webpack_require__(143);
-	var is = __webpack_require__(144);
-	var forbidNewOperator = __webpack_require__(125);
-	var isType = __webpack_require__(127);
-	var isUnion = __webpack_require__(164);
-	var isNil = __webpack_require__(118);
+/* 166 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var isFunction = __webpack_require__(119);
+	var getTypeName = __webpack_require__(128);
+	var isIdentity = __webpack_require__(144);
+	var isArray = __webpack_require__(131);
+	var create = __webpack_require__(145);
+	var is = __webpack_require__(146);
+	var forbidNewOperator = __webpack_require__(127);
+	var isUnion = __webpack_require__(154);
+	var isNil = __webpack_require__(120);
 	
 	function getDefaultName(types) {
 	  return types.map(getTypeName).join(' | ');
 	}
 	
 	function union(types, name) {
 	
 	  if (false) {
@@ -19124,19 +19201,21 @@ var Debugger =
 	    }
 	
 	    var type = Union.dispatch(value);
 	    if (!type && Union.is(value)) {
 	      return value;
 	    }
 	
 	    if (false) {
-	      forbidNewOperator(this, Union);
+	      if (identity) {
+	        forbidNewOperator(this, Union);
+	      }
 	      path = path || [displayName];
-	      assert(isType(type), function () { return 'Invalid value ' + assert.stringify(value) + ' supplied to ' + path.join('/') + ' (no constructor returned by dispatch)'; });
+	      assert(isFunction(type), function () { return 'Invalid value ' + assert.stringify(value) + ' supplied to ' + path.join('/') + ' (no constructor returned by dispatch)'; });
 	      path[path.length - 1] += '(' + getTypeName(type) + ')';
 	    }
 	
 	    return create(type, value, path);
 	  }
 	
 	  Union.meta = {
 	    kind: 'union',
@@ -19176,42 +19255,32 @@ var Debugger =
 	}
 	
 	union.getDefaultName = getDefaultName;
 	module.exports = union;
 	
 
 
 /***/ },
-/* 164 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(127);
-	
-	module.exports = function isUnion(x) {
-	  return isType(x) && ( x.meta.kind === 'union' );
-	};
-
-/***/ },
-/* 165 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var FunctionType = __webpack_require__(135);
-	var isArray = __webpack_require__(129);
-	var list = __webpack_require__(153);
-	var isObject = __webpack_require__(128);
-	var create = __webpack_require__(143);
-	var isNil = __webpack_require__(118);
-	var isBoolean = __webpack_require__(132);
-	var tuple = __webpack_require__(162);
-	var getFunctionName = __webpack_require__(121);
-	var getTypeName = __webpack_require__(126);
-	var isType = __webpack_require__(127);
+/* 167 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var FunctionType = __webpack_require__(137);
+	var isArray = __webpack_require__(131);
+	var list = __webpack_require__(156);
+	var isObject = __webpack_require__(130);
+	var create = __webpack_require__(145);
+	var isNil = __webpack_require__(120);
+	var isBoolean = __webpack_require__(134);
+	var tuple = __webpack_require__(165);
+	var getFunctionName = __webpack_require__(123);
+	var getTypeName = __webpack_require__(128);
+	var isType = __webpack_require__(129);
 	
 	function getDefaultName(domain, codomain) {
 	  return '(' + domain.map(getTypeName).join(', ') + ') => ' + getTypeName(codomain);
 	}
 	
 	function isInstrumented(f) {
 	  return FunctionType.is(f) && isObject(f.instrumentation);
 	}
@@ -19328,56 +19397,60 @@ var Debugger =
 	}
 	
 	func.getDefaultName = getDefaultName;
 	func.getOptionalArgumentsIndex = getOptionalArgumentsIndex;
 	module.exports = func;
 
 
 /***/ },
-/* 166 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var isFunction = __webpack_require__(117);
-	var isArray = __webpack_require__(129);
-	var forbidNewOperator = __webpack_require__(142);
-	var is = __webpack_require__(144);
-	var getTypeName = __webpack_require__(126);
+/* 168 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var isFunction = __webpack_require__(119);
+	var isArray = __webpack_require__(131);
+	var forbidNewOperator = __webpack_require__(144);
+	var is = __webpack_require__(146);
+	var getTypeName = __webpack_require__(128);
+	var isIdentity = __webpack_require__(144);
 	
 	function getDefaultName(types) {
 	  return types.map(getTypeName).join(' & ');
 	}
 	
 	function intersection(types, name) {
 	
 	  if (false) {
 	    assert(isArray(types) && types.every(isFunction) && types.length >= 2, function () { return 'Invalid argument types ' + assert.stringify(types) + ' supplied to intersection(types, [name]) combinator (expected an array of at least 2 types)'; });
 	    assert(isTypeName(name), function () { return 'Invalid argument name ' + assert.stringify(name) + ' supplied to intersection(types, [name]) combinator (expected a string)'; });
 	  }
 	
 	  var displayName = name || getDefaultName(types);
+	  var identity = types.every(isIdentity);
 	
 	  function Intersection(value, path) {
 	
 	    if (false) {
-	      forbidNewOperator(this, Intersection);
+	      if (identity) {
+	        forbidNewOperator(this, Intersection);
+	      }
 	      path = path || [displayName];
 	      assert(Intersection.is(value), function () { return 'Invalid value ' + assert.stringify(value) + ' supplied to ' + path.join('/'); });
 	    }
 	
 	    return value;
 	  }
 	
 	  Intersection.meta = {
 	    kind: 'intersection',
 	    types: types,
 	    name: name,
-	    identity: true
+	    identity: identity
 	  };
 	
 	  Intersection.displayName = displayName;
 	
 	  Intersection.is = function (x) {
 	    return types.every(function (type) {
 	      return is(x, type);
 	    });
@@ -19391,33 +19464,34 @@ var Debugger =
 	}
 	
 	intersection.getDefaultName = getDefaultName;
 	module.exports = intersection;
 	
 
 
 /***/ },
-/* 167 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isTypeName = __webpack_require__(141);
-	var String = __webpack_require__(147);
-	var Function = __webpack_require__(135);
-	var isBoolean = __webpack_require__(132);
-	var isObject = __webpack_require__(128);
-	var isNil = __webpack_require__(118);
-	var create = __webpack_require__(143);
-	var getTypeName = __webpack_require__(126);
-	var dict = __webpack_require__(149);
-	var getDefaultInterfaceName = __webpack_require__(157);
-	var isIdentity = __webpack_require__(142);
-	var is = __webpack_require__(144);
-	var extend = __webpack_require__(158);
+/* 169 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isTypeName = __webpack_require__(143);
+	var String = __webpack_require__(149);
+	var Function = __webpack_require__(137);
+	var isBoolean = __webpack_require__(134);
+	var isObject = __webpack_require__(130);
+	var isNil = __webpack_require__(120);
+	var create = __webpack_require__(145);
+	var getTypeName = __webpack_require__(128);
+	var dict = __webpack_require__(151);
+	var getDefaultInterfaceName = __webpack_require__(160);
+	var isIdentity = __webpack_require__(144);
+	var is = __webpack_require__(146);
+	var extend = __webpack_require__(161);
+	var assign = __webpack_require__(170);
 	
 	function extendInterface(mixins, name) {
 	  return extend(inter, mixins, name);
 	}
 	
 	function getOptions(options) {
 	  if (!isObject(options)) {
 	    options = isNil(options) ? {} : { name: options };
@@ -19458,17 +19532,17 @@ var Debugger =
 	      if (strict) {
 	        for (var k in value) {
 	          assert(props.hasOwnProperty(k), function () { return 'Invalid additional prop "' + k + '" supplied to ' + path.join('/'); });
 	        }
 	      }
 	    }
 	
 	    var idempotent = true;
-	    var ret = {};
+	    var ret = identity ? {} : assign({}, value);
 	    for (var prop in props) {
 	      var expected = props[prop];
 	      var actual = value[prop];
 	      var instance = create(expected, actual, (  false ? path.concat(prop + ': ' + getTypeName(expected)) : null ));
 	      idempotent = idempotent && ( actual === instance );
 	      ret[prop] = instance;
 	    }
 	
@@ -19490,16 +19564,19 @@ var Debugger =
 	    name: name,
 	    identity: identity,
 	    strict: strict
 	  };
 	
 	  Interface.displayName = displayName;
 	
 	  Interface.is = function (x) {
+	    if (isNil(x)) {
+	      return false;
+	    }
 	    if (strict) {
 	      for (var k in x) {
 	        if (!props.hasOwnProperty(k)) {
 	          return false;
 	        }
 	      }
 	    }
 	    for (var prop in props) {
@@ -19524,36 +19601,49 @@ var Debugger =
 	inter.strict = false;
 	inter.getOptions = getOptions;
 	inter.getDefaultName = getDefaultInterfaceName;
 	inter.extend = extendInterface;
 	module.exports = inter;
 
 
 /***/ },
-/* 168 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isObject = __webpack_require__(128);
-	var isFunction = __webpack_require__(117);
-	var isArray = __webpack_require__(129);
-	var isNumber = __webpack_require__(138);
-	var mixin = __webpack_require__(151);
+/* 170 */
+/***/ function(module, exports) {
+
+	function assign(x, y) {
+	  for (var k in y) {
+	    x[k] = y[k];
+	  }
+	  return x;
+	}
+	
+	module.exports = assign;
+
+/***/ },
+/* 171 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isObject = __webpack_require__(130);
+	var isFunction = __webpack_require__(119);
+	var isArray = __webpack_require__(131);
+	var isNumber = __webpack_require__(140);
+	var assign = __webpack_require__(170);
 	
 	function getShallowCopy(x) {
+	  if (isObject(x)) {
+	    if (x instanceof Date || x instanceof RegExp) {
+	      return x;
+	    }
+	    return assign({}, x);
+	  }
 	  if (isArray(x)) {
 	    return x.concat();
 	  }
-	  if (x instanceof Date || x instanceof RegExp) {
-	    return x;
-	  }
-	  if (isObject(x)) {
-	    return mixin({}, x);
-	  }
 	  return x;
 	}
 	
 	function isCommand(k) {
 	  return update.commands.hasOwnProperty(k);
 	}
 	
 	function getCommand(k) {
@@ -19695,23 +19785,23 @@ var Debugger =
 	  $unshift: $unshift,
 	  $merge: $merge
 	};
 	
 	module.exports = update;
 
 
 /***/ },
-/* 169 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(116);
-	var isFunction = __webpack_require__(117);
-	var isType = __webpack_require__(127);
-	var Any = __webpack_require__(122);
+/* 172 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(118);
+	var isFunction = __webpack_require__(119);
+	var isType = __webpack_require__(129);
+	var Any = __webpack_require__(124);
 	
 	module.exports = function match(x) {
 	  var type, guard, f, count;
 	  for (var i = 1, len = arguments.length; i < len; ) {
 	    type = arguments[i];
 	    guard = arguments[i + 1];
 	    f = arguments[i + 2];
 	
@@ -19735,27 +19825,27 @@ var Debugger =
 	      return f(x);
 	    }
 	  }
 	  assert.fail('Match error');
 	};
 
 
 /***/ },
-/* 170 */
+/* 173 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }();
 	
-	var _require = __webpack_require__(114);
+	var _require = __webpack_require__(116);
 	
 	var BreakpointResult = _require.BreakpointResult;
 	var Location = _require.Location;
 	
-	var defer = __webpack_require__(112);
+	var defer = __webpack_require__(114);
 	
 	var bpClients = void 0;
 	var threadClient = void 0;
 	var tabTarget = void 0;
 	var debuggerClient = void 0;
 	
 	function setupCommands(dependencies) {
 	  threadClient = dependencies.threadClient;
@@ -19800,17 +19890,17 @@ var Debugger =
 	function setBreakpoint(location, condition, noSliding) {
 	  var sourceClient = threadClient.source({ actor: location.sourceId });
 	
 	  return sourceClient.setBreakpoint({
 	    line: location.line,
 	    column: location.column,
 	    condition,
 	    noSliding
-	  }).then(_ref => {
+	  }).then((_ref) => {
 	    var _ref2 = _slicedToArray(_ref, 2);
 	
 	    var res = _ref2[0];
 	    var bpClient = _ref2[1];
 	
 	    bpClients[bpClient.actor] = bpClient;
 	
 	    // Firefox only returns `actualLocation` if it actually changed,
@@ -19902,17 +19992,17 @@ var Debugger =
 	};
 	
 	module.exports = {
 	  setupCommands,
 	  clientCommands
 	};
 
 /***/ },
-/* 171 */
+/* 174 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var paused = (() => {
 	  var _ref = _asyncToGenerator(function* (_, packet) {
 	    // If paused by an explicit interrupt, which are generated by the
 	    // slow script dialog and internal events such as setting
 	    // breakpoints, ignore the event.
 	    if (packet.why.type === "interrupted" && !packet.why.onNext) {
@@ -19931,19 +20021,19 @@ var Debugger =
 	    actions.paused(pause);
 	  });
 	
 	  return function paused(_x, _x2) {
 	    return _ref.apply(this, arguments);
 	  };
 	})();
 	
-	function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { return step("next", value); }, function (err) { return step("throw", err); }); } } return step("next"); }); }; }
-	
-	var _require = __webpack_require__(172);
+	function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
+	
+	var _require = __webpack_require__(175);
 	
 	var createFrame = _require.createFrame;
 	var createSource = _require.createSource;
 	
 	
 	var CALL_STACK_PAGE_SIZE = 1000;
 	
 	var threadClient = void 0;
@@ -19971,20 +20061,20 @@ var Debugger =
 	};
 	
 	module.exports = {
 	  setupEvents,
 	  clientEvents
 	};
 
 /***/ },
-/* 172 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(114);
+/* 175 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(116);
 	
 	var Source = _require.Source;
 	var Frame = _require.Frame;
 	var Location = _require.Location;
 	
 	
 	function createFrame(frame) {
 	  var title = void 0;
@@ -20015,50 +20105,48 @@ var Debugger =
 	    isPrettyPrinted: false,
 	    sourceMapURL: source.sourceMapURL
 	  });
 	}
 	
 	module.exports = { createFrame, createSource };
 
 /***/ },
-/* 173 */
+/* 176 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* eslint-disable */
 	
-	var _require = __webpack_require__(174);
+	var _require = __webpack_require__(177);
 	
 	var connect = _require.connect;
 	
-	var defer = __webpack_require__(112);
-	
-	var _require2 = __webpack_require__(114);
+	var defer = __webpack_require__(114);
+	
+	var _require2 = __webpack_require__(116);
 	
 	var Tab = _require2.Tab;
 	
 	var _require3 = __webpack_require__(46);
 	
 	var isEnabled = _require3.isEnabled;
 	var getValue = _require3.getValue;
 	
-	var _require4 = __webpack_require__(175);
-	
-	var networkRequest = _require4.networkRequest;
-	
-	var _require5 = __webpack_require__(176);
-	
-	var setupCommands = _require5.setupCommands;
-	var clientCommands = _require5.clientCommands;
-	
-	var _require6 = __webpack_require__(177);
-	
-	var setupEvents = _require6.setupEvents;
-	var clientEvents = _require6.clientEvents;
-	var pageEvents = _require6.pageEvents;
+	var networkRequest = __webpack_require__(178);
+	
+	var _require4 = __webpack_require__(179);
+	
+	var setupCommands = _require4.setupCommands;
+	var clientCommands = _require4.clientCommands;
+	
+	var _require5 = __webpack_require__(180);
+	
+	var setupEvents = _require5.setupEvents;
+	var clientEvents = _require5.clientEvents;
+	var pageEvents = _require5.pageEvents;
 	
 	// TODO: figure out a way to avoid patching native prototypes.
 	// Unfortunately the Chrome client requires it to work.
 	
 	Array.prototype.peekLast = function () {
 	  return this[this.length - 1];
 	};
 	
@@ -20134,32 +20222,61 @@ var Debugger =
 	  connectClient,
 	  clientCommands,
 	  connectNode,
 	  connectTab,
 	  initPage
 	};
 
 /***/ },
-/* 174 */
+/* 177 */
 /***/ function(module, exports) {
 
 	module.exports = {};
 
 /***/ },
-/* 175 */
-/***/ function(module, exports) {
-
-	module.exports = devtoolsRequire("devtools/shared/DevToolsUtils")["fetch"];
-
-/***/ },
-/* 176 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(114);
+/* 178 */
+/***/ function(module, exports) {
+
+	function networkRequest(url, opts) {
+	  return new Promise((resolve, reject) => {
+	    const req = new XMLHttpRequest();
+	
+	    req.addEventListener("readystatechange", () => {
+	      if (req.readyState === XMLHttpRequest.DONE) {
+	        if (req.status === 200) {
+	          resolve({ content: req.responseText });
+	        } else {
+	          resolve(req.statusText);
+	        }
+	      }
+	    });
+	
+	    // Not working yet.
+	    // if (!opts.loadFromCache) {
+	    //   req.channel.loadFlags = (
+	    //     Components.interfaces.nsIRequest.LOAD_BYPASS_CACHE |
+	    //       Components.interfaces.nsIRequest.INHIBIT_CACHING |
+	    //       Components.interfaces.nsIRequest.LOAD_ANONYMOUS
+	    //   );
+	    // }
+	
+	    req.open("GET", url);
+	    req.send();
+	  });
+	}
+	
+	module.exports = networkRequest;
+
+
+/***/ },
+/* 179 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(116);
 	
 	var BreakpointResult = _require.BreakpointResult;
 	var Location = _require.Location;
 	
 	
 	var debuggerAgent = void 0;
 	var runtimeAgent = void 0;
 	var pageAgent = void 0;
@@ -20270,17 +20387,17 @@ var Debugger =
 	};
 	
 	module.exports = {
 	  setupCommands,
 	  clientCommands
 	};
 
 /***/ },
-/* 177 */
+/* 180 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var paused = (() => {
 	  var _ref = _asyncToGenerator(function* (callFrames, reason, data, hitBreakpoints, asyncStackTrace) {
 	    var frames = callFrames.map(function (frame) {
 	      return Frame({
 	        id: frame.callFrameId,
 	        displayName: frame.functionName,
@@ -20302,19 +20419,19 @@ var Debugger =
 	    yield actions.paused({ frame, why, frames });
 	  });
 	
 	  return function paused(_x, _x2, _x3, _x4, _x5) {
 	    return _ref.apply(this, arguments);
 	  };
 	})();
 	
-	function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { return step("next", value); }, function (err) { return step("throw", err); }); } } return step("next"); }); }; }
-	
-	var _require = __webpack_require__(114);
+	function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
+	
+	var _require = __webpack_require__(116);
 	
 	var Source = _require.Source;
 	var Location = _require.Location;
 	var Frame = _require.Frame;
 	
 	
 	var actions = void 0;
 	var pageAgent = void 0;
@@ -20380,65 +20497,65 @@ var Debugger =
 	
 	module.exports = {
 	  setupEvents,
 	  pageEvents,
 	  clientEvents
 	};
 
 /***/ },
-/* 178 */
+/* 181 */
 /***/ function(module, exports, __webpack_require__) {
 
 	
 	
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	/* global window */
 	
 	var _require = __webpack_require__(2);
 	
 	var createStore = _require.createStore;
 	var applyMiddleware = _require.applyMiddleware;
 	
-	var _require2 = __webpack_require__(179);
+	var _require2 = __webpack_require__(182);
 	
 	var waitUntilService = _require2.waitUntilService;
 	
-	var _require3 = __webpack_require__(180);
+	var _require3 = __webpack_require__(183);
 	
 	var log = _require3.log;
 	
-	var _require4 = __webpack_require__(181);
+	var _require4 = __webpack_require__(184);
 	
 	var history = _require4.history;
 	
-	var _require5 = __webpack_require__(182);
+	var _require5 = __webpack_require__(185);
 	
 	var promise = _require5.promise;
 	
-	var _require6 = __webpack_require__(187);
+	var _require6 = __webpack_require__(190);
 	
 	var thunk = _require6.thunk;
 	
 	
 	/**
 	 * This creates a dispatcher with all the standard middleware in place
 	 * that all code requires. It can also be optionally configured in
 	 * various ways, such as logging and recording.
 	 *
 	 * @param {object} opts:
 	 *        - log: log all dispatched actions to console
 	 *        - history: an array to store every action in. Should only be
 	 *                   used in tests.
 	 *        - middleware: array of middleware to be included in the redux store
 	 */
 	var configureStore = function () {
-	  var opts = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];
+	  var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
 	
 	  var middleware = [thunk(opts.makeThunkArgs), promise,
 	
 	  // Order is important: services must go last as they always
 	  // operate on "already transformed" actions. Actions going through
 	  // them shouldn't have any special fields like promises, they
 	  // should just be normal JSON objects.
 	  waitUntilService];
@@ -20459,17 +20576,17 @@ var Debugger =
 	  var devtoolsExt = typeof window === "object" && window.devToolsExtension ? window.devToolsExtension() : f => f;
 	
 	  return applyMiddleware.apply(undefined, middleware)(devtoolsExt(createStore));
 	};
 	
 	module.exports = configureStore;
 
 /***/ },
-/* 179 */
+/* 182 */
 /***/ function(module, exports) {
 
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	"use strict";
 	
 	/**
@@ -20529,17 +20646,17 @@ var Debugger =
 	    checkPending(action);
 	    return result;
 	  };
 	}
 	exports.waitUntilService = waitUntilService;
 
 
 /***/ },
-/* 180 */
+/* 183 */
 /***/ function(module, exports) {
 
 	/**
 	 * A middleware that logs all actions coming through the system
 	 * to the console.
 	 */
 	function log(_ref) {
 	  var dispatch = _ref.dispatch;
@@ -20551,17 +20668,17 @@ var Debugger =
 	    console.log(`[DISPATCH ${ action.type }]`, action, truncatedActionText);
 	    next(action);
 	  };
 	}
 	
 	exports.log = log;
 
 /***/ },
-/* 181 */
+/* 184 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
 	var _require = __webpack_require__(46);
 	
@@ -20569,47 +20686,47 @@ var Debugger =
 	
 	/**
 	 * A middleware that stores every action coming through the store in the passed
 	 * in logging object. Should only be used for tests, as it collects all
 	 * action information, which will cause memory bloat.
 	 */
 	
 	exports.history = function () {
-	  var log = arguments.length <= 0 || arguments[0] === undefined ? [] : arguments[0];
-	  return _ref => {
+	  var log = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
+	  return (_ref) => {
 	    var dispatch = _ref.dispatch;
 	    var getState = _ref.getState;
 	
 	    if (isDevelopment()) {
 	      console.warn("Using history middleware stores all actions in state for " + "testing and devtools is not currently running in test " + "mode. Be sure this is intentional.");
 	    }
 	    return next => action => {
 	      log.push(action);
 	      next(action);
 	    };
 	  };
 	};
 
 /***/ },
-/* 182 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* This Source Code Form is subject to the terms of the Mozilla Public
-	 * License, v. 2.0. If a copy of the MPL was not distributed with this
-	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-	
-	var defer = __webpack_require__(112);
-	
-	var _require = __webpack_require__(183);
+/* 185 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/* This Source Code Form is subject to the terms of the Mozilla Public
+	 * License, v. 2.0. If a copy of the MPL was not distributed with this
+	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+	
+	var defer = __webpack_require__(114);
+	
+	var _require = __webpack_require__(186);
 	
 	var entries = _require.entries;
 	var toObject = _require.toObject;
 	
-	var _require2 = __webpack_require__(185);
+	var _require2 = __webpack_require__(188);
 	
 	var executeSoon = _require2.executeSoon;
 	
 	
 	var PROMISE = exports.PROMISE = "@@dispatch/promise";
 	var seqIdVal = 1;
 	
 	function seqIdGen() {
@@ -20656,66 +20773,30 @@ var Debugger =
 	    });
 	    return deferred.promise;
 	  };
 	}
 	
 	exports.promise = promiseMiddleware;
 
 /***/ },
-/* 183 */
+/* 186 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }();
 	
-	var asyncMap = (() => {
-	  var _ref = _asyncToGenerator(function* (items, callback) {
-	    var newItems = [];
-	    for (var item of items) {
-	      item = yield callback(item);
-	      newItems.push(item);
-	    }
-	
-	    return newItems;
-	  });
-	
-	  return function asyncMap(_x, _x2) {
-	    return _ref.apply(this, arguments);
-	  };
-	})();
-	
-	/**
-	 * Interleaves two arrays element by element, returning the combined array, like
-	 * a zip. In the case of arrays with different sizes, undefined values will be
-	 * interleaved at the end along with the extra values of the larger array.
-	 *
-	 * @param Array a
-	 * @param Array b
-	 * @returns Array
-	 *          The combined array, in the form [a1, b1, a2, b2, ...]
-	 */
-	
-	
 	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); } }
 	
-	function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { return step("next", value); }, function (err) { return step("throw", err); }); } } return step("next"); }); }; }
-	
 	/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
 	/* vim: set ft=javascript ts=2 et sw=2 tw=80: */
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
-	var co = __webpack_require__(184);
-	
-	var _require = __webpack_require__(46);
-	
-	var isDevelopment = _require.isDevelopment;
-	
-	var defer = __webpack_require__(112);
+	var co = __webpack_require__(187);
 	
 	function asPaused(client, func) {
 	  if (client.state != "paused") {
 	    return co(function* () {
 	      yield client.interrupt();
 	      var result = void 0;
 	
 	      try {
@@ -20764,30 +20845,57 @@ var Debugger =
 	
 	function endTruncateStr(str, size) {
 	  if (str.length > size) {
 	    return "..." + str.slice(str.length - size);
 	  }
 	  return str;
 	}
 	
-	function workerTask(worker, message) {
-	  var deferred = defer();
-	  worker.postMessage(message);
-	  worker.onmessage = function (result) {
-	    if (result.data && result.data.error) {
-	      deferred.reject(result.data.error);
-	    }
-	
-	    deferred.resolve(result.data);
-	  };
-	
-	  return deferred.promise;
-	}
-	
+	var msgId = 1;
+	function workerTask(worker, method) {
+	  return function () {
+	    for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
+	      args[_key2] = arguments[_key2];
+	    }
+	
+	    return new Promise((resolve, reject) => {
+	      var id = msgId++;
+	      worker.postMessage({ id, method, args });
+	
+	      var listener = (_ref) => {
+	        var result = _ref.data;
+	
+	        if (result.id !== id) {
+	          return;
+	        }
+	
+	        worker.removeEventListener("message", listener);
+	        if (result.error) {
+	          reject(result.error);
+	        } else {
+	          resolve(result.response);
+	        }
+	      };
+	
+	      worker.addEventListener("message", listener);
+	    });
+	  };
+	}
+	
+	/**
+	 * Interleaves two arrays element by element, returning the combined array, like
+	 * a zip. In the case of arrays with different sizes, undefined values will be
+	 * interleaved at the end along with the extra values of the larger array.
+	 *
+	 * @param Array a
+	 * @param Array b
+	 * @returns Array
+	 *          The combined array, in the form [a1, b1, a2, b2, ...]
+	 */
 	function zip(a, b) {
 	  if (!b) {
 	    return a;
 	  }
 	  if (!a) {
 	    return b;
 	  }
 	  var pairs = [];
@@ -20805,17 +20913,17 @@ var Debugger =
 	 * @param object obj
 	 * @returns array
 	 */
 	function entries(obj) {
 	  return Object.keys(obj).map(k => [k, obj[k]]);
 	}
 	
 	function mapObject(obj, iteratee) {
-	  return toObject(entries(obj).map(_ref2 => {
+	  return toObject(entries(obj).map((_ref2) => {
 	    var _ref3 = _slicedToArray(_ref2, 2);
 	
 	    var key = _ref3[0];
 	    var value = _ref3[1];
 	
 	    return [key, iteratee(key, value)];
 	  }));
 	}
@@ -20837,49 +20945,41 @@ var Debugger =
 	 * apply the results of each function right-to-left, starting with
 	 * applying the given arguments to the right-most function.
 	 * `compose(foo, bar, baz)` === `args => foo(bar(baz(args)`
 	 *
 	 * @param ...function funcs
 	 * @returns function
 	 */
 	function compose() {
-	  for (var _len2 = arguments.length, funcs = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
-	    funcs[_key2] = arguments[_key2];
+	  for (var _len3 = arguments.length, funcs = Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
+	    funcs[_key3] = arguments[_key3];
 	  }
 	
 	  return function () {
-	    for (var _len3 = arguments.length, args = Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
-	      args[_key3] = arguments[_key3];
+	    for (var _len4 = arguments.length, args = Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {
+	      args[_key4] = arguments[_key4];
 	    }
 	
 	    var initialValue = funcs[funcs.length - 1].apply(null, args);
 	    var leftFuncs = funcs.slice(0, -1);
 	    return leftFuncs.reduceRight((composed, f) => f(composed), initialValue);
 	  };
 	}
 	
-	function log() {
-	  if (!isDevelopment()) {
-	    return;
-	  }
-	
-	  console.log.apply(console, ["[log]"].concat(Array.prototype.slice.call(arguments)));
-	}
-	
 	function updateObj(obj, fields) {
 	  return Object.assign({}, obj, fields);
 	}
 	
 	function throttle(func, ms) {
 	  var timeout = void 0,
 	      _this = void 0;
 	  return function () {
-	    for (var _len4 = arguments.length, args = Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {
-	      args[_key4] = arguments[_key4];
+	    for (var _len5 = arguments.length, args = Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {
+	      args[_key5] = arguments[_key5];
 	    }
 	
 	    _this = this;
 	    if (!timeout) {
 	      timeout = setTimeout(() => {
 	        func.apply.apply(func, [_this].concat(_toConsumableArray(args)));
 	        timeout = null;
 	      }, ms);
@@ -20889,29 +20989,27 @@ var Debugger =
 	
 	module.exports = {
 	  asPaused,
 	  handleError,
 	  promisify,
 	  truncateStr,
 	  endTruncateStr,
 	  workerTask,
-	  asyncMap,
 	  zip,
 	  entries,
 	  toObject,
 	  mapObject,
 	  compose,
-	  log,
 	  updateObj,
 	  throttle
 	};
 
 /***/ },
-/* 184 */
+/* 187 */
 /***/ function(module, exports) {
 
 	
 	/**
 	 * slice() reference.
 	 */
 	
 	var slice = Array.prototype.slice;
@@ -21144,20 +21242,20 @@ var Debugger =
 	 */
 	
 	function isObject(val) {
 	  return Object == val.constructor;
 	}
 
 
 /***/ },
-/* 185 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(186);
+/* 188 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(189);
 	
 	function reportException(who, exception) {
 	  var msg = who + " threw an exception: ";
 	  console.error(msg, exception);
 	}
 	
 	function executeSoon(fn) {
 	  setTimeout(fn, 0);
@@ -21165,95 +21263,95 @@ var Debugger =
 	
 	module.exports = {
 	  reportException,
 	  executeSoon,
 	  assert
 	};
 
 /***/ },
-/* 186 */
+/* 189 */
 /***/ function(module, exports) {
 
 	function assert(condition, message) {
 	  if (!condition) {
 	    throw new Error("Assertion failure: " + message);
 	  }
 	}
 	
 	module.exports = assert;
 
 /***/ },
-/* 187 */
+/* 190 */
 /***/ function(module, exports) {
 
 	
 	/**
 	 * A middleware that allows thunks (functions) to be dispatched. If
 	 * it's a thunk, it is called with an argument that contains
 	 * `dispatch`, `getState`, and any additional args passed in via the
 	 * middleware constructure. This allows the action to create multiple
 	 * actions (most likely asynchronously).
 	 */
 	function thunk(makeArgs) {
-	  return _ref => {
+	  return (_ref) => {
 	    var dispatch = _ref.dispatch;
 	    var getState = _ref.getState;
 	
 	    var args = { dispatch, getState };
 	
 	    return next => action => {
 	      return typeof action === "function" ? action(makeArgs ? makeArgs(args, getState()) : args) : next(action);
 	    };
 	  };
 	}
 	exports.thunk = thunk;
 
 /***/ },
-/* 188 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* This Source Code Form is subject to the terms of the Mozilla Public
-	 * License, v. 2.0. If a copy of the MPL was not distributed with this
-	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-	
-	var eventListeners = __webpack_require__(189);
-	var sources = __webpack_require__(191);
-	var breakpoints = __webpack_require__(195);
-	var asyncRequests = __webpack_require__(196);
-	var tabs = __webpack_require__(197);
-	var pause = __webpack_require__(198);
+/* 191 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/* This Source Code Form is subject to the terms of the Mozilla Public
+	 * License, v. 2.0. If a copy of the MPL was not distributed with this
+	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+	
+	var eventListeners = __webpack_require__(192);
+	var sources = __webpack_require__(194);
+	var breakpoints = __webpack_require__(198);
+	var asyncRequests = __webpack_require__(199);
+	var tabs = __webpack_require__(200);
+	var pause = __webpack_require__(201);
 	
 	module.exports = {
 	  eventListeners,
 	  sources: sources.update,
 	  breakpoints: breakpoints.update,
 	  pause: pause.update,
 	  asyncRequests,
 	  tabs
 	};
 
 /***/ },
-/* 189 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* This Source Code Form is subject to the terms of the Mozilla Public
-	 * License, v. 2.0. If a copy of the MPL was not distributed with this
-	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-	
-	var constants = __webpack_require__(190);
+/* 192 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/* This Source Code Form is subject to the terms of the Mozilla Public
+	 * License, v. 2.0. If a copy of the MPL was not distributed with this
+	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+	
+	var constants = __webpack_require__(193);
 	
 	var initialState = {
 	  activeEventNames: [],
 	  listeners: [],
 	  fetchingListeners: false
 	};
 	
 	function update() {
-	  var state = arguments.length <= 0 || arguments[0] === undefined ? initialState : arguments[0];
+	  var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
 	  var action = arguments[1];
 	  var emit = arguments[2];
 	
 	  switch (action.type) {
 	    case constants.UPDATE_EVENT_BREAKPOINTS:
 	      state.activeEventNames = action.eventNames;
 	      emit("activeEventNames", state.activeEventNames);
 	      break;
@@ -21271,17 +21369,17 @@ var Debugger =
 	  }
 	
 	  return state;
 	}
 	
 	module.exports = update;
 
 /***/ },
-/* 190 */
+/* 193 */
 /***/ function(module, exports) {
 
 	/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
 	/* vim: set ft=javascript ts=2 et sw=2 tw=80: */
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
@@ -21318,38 +21416,38 @@ var Debugger =
 	exports.SELECT_FRAME = "SELECT_FRAME";
 	exports.LOAD_OBJECT_PROPERTIES = "LOAD_OBJECT_PROPERTIES";
 	exports.ADD_EXPRESSION = "ADD_EXPRESSION";
 	exports.EVALUATE_EXPRESSION = "EVALUATE_EXPRESSION";
 	exports.UPDATE_EXPRESSION = "UPDATE_EXPRESSION";
 	exports.DELETE_EXPRESSION = "DELETE_EXPRESSION";
 
 /***/ },
-/* 191 */
-/***/ function(module, exports, __webpack_require__) {
-
-	
-	/* This Source Code Form is subject to the terms of the Mozilla Public
-	 * License, v. 2.0. If a copy of the MPL was not distributed with this
-	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-	
-	var fromJS = __webpack_require__(192);
-	var I = __webpack_require__(193);
-	var makeRecord = __webpack_require__(194);
+/* 194 */
+/***/ function(module, exports, __webpack_require__) {
+
+	
+	/* This Source Code Form is subject to the terms of the Mozilla Public
+	 * License, v. 2.0. If a copy of the MPL was not distributed with this
+	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+	
+	var fromJS = __webpack_require__(195);
+	var I = __webpack_require__(196);
+	var makeRecord = __webpack_require__(197);
 	
 	var State = makeRecord({
 	  sources: I.Map(),
 	  selectedLocation: undefined,
 	  pendingSelectedLocation: undefined,
 	  sourcesText: I.Map(),
 	  tabs: I.List([])
 	});
 	
 	function update() {
-	  var state = arguments.length <= 0 || arguments[0] === undefined ? State() : arguments[0];
+	  var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : State();
 	  var action = arguments[1];
 	
 	  switch (action.type) {
 	    case "ADD_SOURCE":
 	      {
 	        var _source = action.source;
 	        return state.mergeIn(["sources", action.source.id], _source);
 	      }
@@ -21454,18 +21552,20 @@ var Debugger =
 	
 	/**
 	 * Gets the next tab to select when a tab closes.
 	 */
 	function getNewSelectedSourceId(state, id) {
 	  var tabs = state.get("tabs");
 	  var selectedSource = getSelectedSource({ sources: state });
 	
-	  // if we're not closing the selected tab return the selected tab
-	  if (selectedSource.get("id") != id) {
+	  if (!selectedSource) {
+	    return undefined;
+	  } else if (selectedSource.get("id") != id) {
+	    // If we're not closing the selected tab return the selected tab
 	    return selectedSource.get("id");
 	  }
 	
 	  var tabIndex = tabs.findIndex(tab => tab.get("id") == id);
 	  var numTabs = tabs.count();
 	
 	  if (numTabs == 1) {
 	    return undefined;
@@ -21511,17 +21611,20 @@ var Debugger =
 	  return state.sources.sourcesText.get(id);
 	}
 	
 	function getSourceTabs(state) {
 	  return state.sources.tabs;
 	}
 	
 	function getSelectedSource(state) {
-	  return state.sources.selectedLocation && getSource(state, state.sources.selectedLocation.sourceId);
+	  if (state.sources.selectedLocation) {
+	    return getSource(state, state.sources.selectedLocation.sourceId);
+	  }
+	  return undefined;
 	}
 	
 	function getSelectedLocation(state) {
 	  return state.sources.selectedLocation;
 	}
 	
 	function getPendingSelectedLocation(state) {
 	  return state.sources.pendingSelectedLocation;
@@ -21547,22 +21650,20 @@ var Debugger =
 	  getSourceTabs,
 	  getSelectedSource,
 	  getSelectedLocation,
 	  getPendingSelectedLocation,
 	  getPrettySource
 	};
 
 /***/ },
-/* 192 */
-/***/ function(module, exports, __webpack_require__) {
-
-	
-	
-	var Immutable = __webpack_require__(193);
+/* 195 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var Immutable = __webpack_require__(196);
 	
 	// When our app state is fully types, we should be able to get rid of
 	// this function. This is only temporarily necessary to support
 	// converting typed objects to immutable.js, which usually happens in
 	// reducers.
 	function fromJS(value) {
 	  if (Array.isArray(value)) {
 	    return Immutable.Seq(value).map(fromJS).toList();
@@ -21591,17 +21692,17 @@ var Debugger =
 	  // it's a plain object because we might be objects from other JS
 	  // contexts so `Object !== Object`.
 	  return Immutable.Seq(value).map(fromJS).toMap();
 	}
 	
 	module.exports = fromJS;
 
 /***/ },
-/* 193 */
+/* 196 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/**
 	 *  Copyright (c) 2014-2015, Facebook, Inc.
 	 *  All rights reserved.
 	 *
 	 *  This source code is licensed under the BSD-style license found in the
 	 *  LICENSE file in the root directory of this source tree. An additional grant
@@ -22910,18 +23011,17 @@ var Debugger =
 	    Map.prototype.mergeWith = function(merger) {var iters = SLICE$0.call(arguments, 1);
 	      return mergeIntoMapWith(this, merger, iters);
 	    };
 	
 	    Map.prototype.mergeIn = function(keyPath) {var iters = SLICE$0.call(arguments, 1);
 	      return this.updateIn(
 	        keyPath,
 	        emptyMap(),
-	        function(m) {
-	          return typeof m.merge === 'function' ?
+	        function(m ) {return typeof m.merge === 'function' ?
 	          m.merge.apply(m, iters) :
 	          iters[iters.length - 1]}
 	      );
 	    };
 	
 	    Map.prototype.mergeDeep = function(/*...iters*/) {
 	      return mergeIntoMapWith(this, deepMerger, arguments);
 	    };
@@ -26575,59 +26675,58 @@ var Debugger =
 	    fromJS: fromJS
 	
 	  };
 	
 	  return Immutable;
 	
 	}));
 
-
-/***/ },
-/* 194 */
+/***/ },
+/* 197 */
 /***/ function(module, exports, __webpack_require__) {
 
 	
 	
 	// When Flow 0.29 is released (very soon), we can use this Record type
 	// instead of the builtin immutable.js Record type. This is better
 	// because all the fields are actually typed, unlike the builtin one.
 	// This depends on a performance fix that will go out in 0.29 though;
 	
-	var I = __webpack_require__(193);
+	var I = __webpack_require__(196);
 	
 	/**
 	 * Make an immutable record type
 	 *
 	 * @param spec - the keys and their default values @return a state
 	 * record factory function
 	 */
 	function makeRecord(spec) {
 	  return I.Record(spec);
 	}
 	
 	module.exports = makeRecord;
 
 /***/ },
-/* 195 */
-/***/ function(module, exports, __webpack_require__) {
-
-	
-	/* This Source Code Form is subject to the terms of the Mozilla Public
-	 * License, v. 2.0. If a copy of the MPL was not distributed with this
-	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-	
-	var fromJS = __webpack_require__(192);
-	
-	var _require = __webpack_require__(183);
+/* 198 */
+/***/ function(module, exports, __webpack_require__) {
+
+	
+	/* This Source Code Form is subject to the terms of the Mozilla Public
+	 * License, v. 2.0. If a copy of the MPL was not distributed with this
+	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+	
+	var fromJS = __webpack_require__(195);
+	
+	var _require = __webpack_require__(186);
 	
 	var updateObj = _require.updateObj;
 	
-	var I = __webpack_require__(193);
-	var makeRecord = __webpack_require__(194);
+	var I = __webpack_require__(196);
+	var makeRecord = __webpack_require__(197);
 	
 	var State = makeRecord({
 	  breakpoints: I.Map(),
 	  breakpointsDisabled: false
 	});
 	
 	// Return the first argument that is a string, or null if nothing is a
 	// string.
@@ -26648,17 +26747,17 @@ var Debugger =
 	  return location.line !== newLocation.line || location.column != null && location.column !== newLocation.column;
 	}
 	
 	function makeLocationId(location) {
 	  return location.sourceId + ":" + location.line.toString();
 	}
 	
 	function update() {
-	  var state = arguments.length <= 0 || arguments[0] === undefined ? State() : arguments[0];
+	  var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : State();
 	  var action = arguments[1];
 	
 	  switch (action.type) {
 	    case "ADD_BREAKPOINT":
 	      {
 	        var id = makeLocationId(action.breakpoint.location);
 	
 	        if (action.status === "start") {
@@ -26791,30 +26890,30 @@ var Debugger =
 	  getBreakpoint,
 	  getBreakpoints,
 	  getBreakpointsForSource,
 	  getBreakpointsDisabled,
 	  getBreakpointsLoading
 	};
 
 /***/ },
-/* 196 */
+/* 199 */
 /***/ function(module, exports, __webpack_require__) {
 
 	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); } }
 	
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
-	var constants = __webpack_require__(190);
+	var constants = __webpack_require__(193);
 	var initialState = [];
 	
 	function update() {
-	  var state = arguments.length <= 0 || arguments[0] === undefined ? initialState : arguments[0];
+	  var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
 	  var action = arguments[1];
 	  var seqId = action.seqId;
 	
 	
 	  if (action.type === constants.NAVIGATE) {
 	    return initialState;
 	  } else if (seqId) {
 	    var newState = void 0;
@@ -26828,34 +26927,34 @@ var Debugger =
 	  }
 	
 	  return state;
 	}
 	
 	module.exports = update;
 
 /***/ },
-/* 197 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* This Source Code Form is subject to the terms of the Mozilla Public
-	 * License, v. 2.0. If a copy of the MPL was not distributed with this
-	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-	
-	var constants = __webpack_require__(190);
-	var Immutable = __webpack_require__(193);
-	var fromJS = __webpack_require__(192);
+/* 200 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/* This Source Code Form is subject to the terms of the Mozilla Public
+	 * License, v. 2.0. If a copy of the MPL was not distributed with this
+	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+	
+	var constants = __webpack_require__(193);
+	var Immutable = __webpack_require__(196);
+	var fromJS = __webpack_require__(195);
 	
 	var initialState = fromJS({
 	  tabs: {},
 	  selectedTab: null
 	});
 	
 	function update() {
-	  var state = arguments.length <= 0 || arguments[0] === undefined ? initialState : arguments[0];
+	  var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
 	  var action = arguments[1];
 	
 	  switch (action.type) {
 	    case constants.ADD_TABS:
 	      var tabs = action.value;
 	      if (!tabs) {
 	        return state;
 	      }
@@ -26883,39 +26982,39 @@ var Debugger =
 	  }
 	
 	  return id;
 	}
 	
 	module.exports = update;
 
 /***/ },
-/* 198 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* This Source Code Form is subject to the terms of the Mozilla Public
-	 * License, v. 2.0. If a copy of the MPL was not distributed with this
-	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-	
-	var constants = __webpack_require__(190);
-	var fromJS = __webpack_require__(192);
+/* 201 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/* This Source Code Form is subject to the terms of the Mozilla Public
+	 * License, v. 2.0. If a copy of the MPL was not distributed with this
+	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+	
+	var constants = __webpack_require__(193);
+	var fromJS = __webpack_require__(195);
 	
 	var initialState = fromJS({
 	  pause: null,
 	  isWaitingOnBreak: false,
 	  frames: null,
 	  selectedFrameId: null,
 	  loadedObjects: {},
 	  shouldPauseOnExceptions: false,
 	  shouldIgnoreCaughtExceptions: false,
 	  expressions: []
 	});
 	
 	function update() {
-	  var state = arguments.length <= 0 || arguments[0] === undefined ? initialState : arguments[0];
+	  var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
 	  var action = arguments[1];
 	  var emit = arguments[2];
 	
 	  switch (action.type) {
 	    case constants.PAUSED:
 	      {
 	        var selectedFrameId = action.selectedFrameId;
 	        var frames = action.frames;
@@ -27049,24 +27148,22 @@ var Debugger =
 	  getIsWaitingOnBreak,
 	  getShouldPauseOnExceptions,
 	  getShouldIgnoreCaughtExceptions,
 	  getFrames,
 	  getSelectedFrame
 	};
 
 /***/ },
-/* 199 */
-/***/ function(module, exports, __webpack_require__) {
-
-	
-	
-	var sources = __webpack_require__(191);
-	var pause = __webpack_require__(198);
-	var breakpoints = __webpack_require__(195);
+/* 202 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var sources = __webpack_require__(194);
+	var pause = __webpack_require__(201);
+	var breakpoints = __webpack_require__(198);
 	
 	function getTabs(state) {
 	  return state.tabs.get("tabs");
 	}
 	
 	function getSelectedTab(state) {
 	  return state.tabs.get("selectedTab");
 	}
@@ -27102,71 +27199,123 @@ var Debugger =
 	  getIsWaitingOnBreak: pause.getIsWaitingOnBreak,
 	  getShouldPauseOnExceptions: pause.getShouldPauseOnExceptions,
 	  getShouldIgnoreCaughtExceptions: pause.getShouldIgnoreCaughtExceptions,
 	  getFrames: pause.getFrames,
 	  getSelectedFrame: pause.getSelectedFrame
 	};
 
 /***/ },
-/* 200 */
+/* 203 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(17);
 	
 	var _require = __webpack_require__(15);
 	
 	var connect = _require.connect;
 	
-	var classnames = __webpack_require__(201);
-	
-	var _require2 = __webpack_require__(199);
+	var classnames = __webpack_require__(204);
+	
+	var _require2 = __webpack_require__(202);
 	
 	var getTabs = _require2.getTabs;
 	
 	
-	__webpack_require__(202);
+	__webpack_require__(205);
 	var dom = React.DOM;
 	
+	var ImPropTypes = __webpack_require__(209);
+	
 	var githubUrl = "https://github.com/devtools-html/debugger.html/blob/master";
 	
 	function getTabsByBrowser(tabs, browser) {
 	  return tabs.valueSeq().filter(tab => tab.get("browser") == browser);
 	}
 	
-	function renderTabs(tabTitle, tabs, paramName) {
-	  if (tabs.count() == 0) {
-	    return null;
-	  }
-	
-	  return dom.div({ className: `tab-group ${ tabTitle }` }, dom.div({ className: "tab-group-title" }, tabTitle), dom.ul({ className: "tab-list" }, tabs.valueSeq().map(tab => dom.li({ "className": "tab",
-	    "key": tab.get("id"),
-	    "onClick": () => {
-	      window.location = "/?" + paramName + "=" + tab.get("id");
-	    } }, dom.div({ className: "tab-title" }, tab.get("title")), dom.div({ className: "tab-url" }, tab.get("url"))))));
-	}
-	
-	function renderMessage(noTabs) {
-	  return dom.div({ className: classnames("connect-message", { "not-connected": noTabs }) }, dom.p(null, noTabs && "No remote tabs found. ", "You may be looking to ", dom.a({
-	    href: `/?ws=${ document.location.hostname }:9229/node`
-	  }, "connect to Node"), "."), dom.p(null, "Make sure you run ", dom.a({ href: `${ githubUrl }/CONTRIBUTING.md#firefox` }, "Firefox"), ", ", dom.a({ href: `${ githubUrl }/CONTRIBUTING.md#chrome` }, "Chrome"), " or ", dom.a({ href: `${ githubUrl }/CONTRIBUTING.md#nodejs` }, "Node"), " with the right flags."));
-	}
-	function Tabs(_ref) {
-	  var tabs = _ref.tabs;
-	
-	  var firefoxTabs = getTabsByBrowser(tabs, "firefox");
-	  var chromeTabs = getTabsByBrowser(tabs, "chrome");
-	
-	  return dom.div({ className: "tabs theme-light" }, renderTabs("Firefox Tabs", firefoxTabs, "firefox-tab"), renderTabs("Chrome Tabs", chromeTabs, "chrome-tab"), renderMessage(tabs.isEmpty()));
-	}
-	
-	module.exports = connect(state => ({ tabs: getTabs(state) }))(Tabs);
-
-/***/ },
-/* 201 */
+	function firstTimeMessage(title, urlPart) {
+	  return dom.div({ className: "footer-note" }, `First time connecting to ${ title }? Checkout out the `, dom.a({ href: `${ githubUrl }/CONTRIBUTING.md#${ urlPart }` }, "docs"), ".");
+	}
+	
+	var LandingPage = React.createClass({
+	  propTypes: {
+	    tabs: ImPropTypes.map.isRequired
+	  },
+	
+	  displayName: "LandingPage",
+	
+	  getInitialState() {
+	    return {
+	      selectedPane: "Firefox"
+	    };
+	  },
+	
+	  renderTabs(tabTitle, tabs, paramName) {
+	    if (!tabs || tabs.count() == 0) {
+	      return dom.div({}, "");
+	    }
+	
+	    return dom.div({ className: "tab-group" }, dom.ul({ className: "tab-list" }, tabs.valueSeq().map(tab => dom.li({ "className": "tab",
+	      "key": tab.get("id"),
+	      "onClick": () => {
+	        window.location = "/?" + paramName + "=" + tab.get("id");
+	      } }, dom.div({ className: "tab-title" }, tab.get("title")), dom.div({ className: "tab-url" }, tab.get("url"))))));
+	  },
+	
+	  renderFirefoxPanel() {
+	    var targets = getTabsByBrowser(this.props.tabs, "firefox");
+	    return dom.div({ className: "center" }, this.renderTabs("", targets, "firefox-tab"), firstTimeMessage("Firefox", "firefox"));
+	  },
+	
+	  renderChromePanel() {
+	    var targets = getTabsByBrowser(this.props.tabs, "chrome");
+	    return dom.div({ className: "center" }, this.renderTabs("", targets, "chrome-tab"), firstTimeMessage("Chrome", "chrome"));
+	  },
+	
+	  renderNodePanel() {
+	    return dom.div({ className: "center" }, dom.div({ className: "center-message" }, dom.a({
+	      href: `/?ws=${ document.location.hostname }:9229/node`
+	    }, "Connect to Node")), firstTimeMessage("Node", "nodejs"));
+	  },
+	
+	  renderPanel() {
+	    var panels = {
+	      Firefox: this.renderFirefoxPanel,
+	      Chrome: this.renderChromePanel,
+	      Node: this.renderNodePanel
+	    };
+	
+	    return dom.div({
+	      className: "panel"
+	    }, dom.div({ className: "title" }, dom.h2({}, this.state.selectedPane)), panels[this.state.selectedPane]());
+	  },
+	
+	  renderSidebar() {
+	    return dom.div({
+	      className: "sidebar"
+	    }, dom.h1({}, "Debugger"), dom.ul({}, ["Firefox", "Chrome", "Node"].map(title => dom.li({
+	      className: classnames({
+	        selected: title == this.state.selectedPane
+	      }),
+	
+	      onClick: () => this.setState({ selectedPane: title })
+	    }, dom.a({}, title)))));
+	  },
+	
+	  render() {
+	    return dom.div({
+	      className: "landing-page"
+	    }, this.renderSidebar(), this.renderPanel());
+	  }
+	});
+	
+	module.exports = connect(state => ({ tabs: getTabs(state) }))(LandingPage);
+
+/***/ },
+/* 204 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*!
 	  Copyright (c) 2016 Jed Watson.
 	  Licensed under the MIT License (MIT), see
 	  http://jedwatson.github.io/classnames
 	*/
 	/* global define */
@@ -27210,86 +27359,291 @@ var Debugger =
 			}.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
 		} else {
 			window.classNames = classNames;
 		}
 	}());
 
 
 /***/ },
-/* 202 */
+/* 205 */
 /***/ function(module, exports) {
 
 	// removed by extract-text-webpack-plugin
 
 /***/ },
-/* 203 */,
-/* 204 */,
-/* 205 */,
-/* 206 */
+/* 206 */,
+/* 207 */,
+/* 208 */,
+/* 209 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/**
+	 * This is a straight rip-off of the React.js ReactPropTypes.js proptype validators,
+	 * modified to make it possible to validate Immutable.js data.
+	 *     ImmutableTypes.listOf is patterned after React.PropTypes.arrayOf, but for Immutable.List
+	 *     ImmutableTypes.shape  is based on React.PropTypes.shape, but for any Immutable.Iterable
+	 */
+	"use strict";
+	
+	var Immutable = __webpack_require__(196);
+	
+	var ANONYMOUS = "<<anonymous>>";
+	
+	var ImmutablePropTypes = {
+	  listOf: createListOfTypeChecker,
+	  mapOf: createMapOfTypeChecker,
+	  orderedMapOf: createOrderedMapOfTypeChecker,
+	  setOf: createSetOfTypeChecker,
+	  orderedSetOf: createOrderedSetOfTypeChecker,
+	  stackOf: createStackOfTypeChecker,
+	  iterableOf: createIterableOfTypeChecker,
+	  recordOf: createRecordOfTypeChecker,
+	  shape: createShapeChecker,
+	  contains: createShapeChecker,
+	  mapContains: createMapContainsChecker,
+	  // Primitive Types
+	  list: createImmutableTypeChecker("List", Immutable.List.isList),
+	  map: createImmutableTypeChecker("Map", Immutable.Map.isMap),
+	  orderedMap: createImmutableTypeChecker("OrderedMap", Immutable.OrderedMap.isOrderedMap),
+	  set: createImmutableTypeChecker("Set", Immutable.Set.isSet),
+	  orderedSet: createImmutableTypeChecker("OrderedSet", Immutable.OrderedSet.isOrderedSet),
+	  stack: createImmutableTypeChecker("Stack", Immutable.Stack.isStack),
+	  seq: createImmutableTypeChecker("Seq", Immutable.Seq.isSeq),
+	  record: createImmutableTypeChecker("Record", function (isRecord) {
+	    return isRecord instanceof Immutable.Record;
+	  }),
+	  iterable: createImmutableTypeChecker("Iterable", Immutable.Iterable.isIterable)
+	};
+	
+	function getPropType(propValue) {
+	  var propType = typeof propValue;
+	  if (Array.isArray(propValue)) {
+	    return "array";
+	  }
+	  if (propValue instanceof RegExp) {
+	    // Old webkits (at least until Android 4.0) return 'function' rather than
+	    // 'object' for typeof a RegExp. We'll normalize this here so that /bla/
+	    // passes PropTypes.object.
+	    return "object";
+	  }
+	  if (propValue instanceof Immutable.Iterable) {
+	    return "Immutable." + propValue.toSource().split(" ")[0];
+	  }
+	  return propType;
+	}
+	
+	function createChainableTypeChecker(validate) {
+	  function checkType(isRequired, props, propName, componentName, location, propFullName) {
+	    propFullName = propFullName || propName;
+	    componentName = componentName || ANONYMOUS;
+	    if (props[propName] == null) {
+	      var locationName = location;
+	      if (isRequired) {
+	        return new Error("Required " + locationName + " `" + propFullName + "` was not specified in " + ("`" + componentName + "`."));
+	      }
+	    } else {
+	      return validate(props, propName, componentName, location, propFullName);
+	    }
+	  }
+	
+	  var chainedCheckType = checkType.bind(null, false);
+	  chainedCheckType.isRequired = checkType.bind(null, true);
+	
+	  return chainedCheckType;
+	}
+	
+	function createImmutableTypeChecker(immutableClassName, immutableClassTypeValidator) {
+	  function validate(props, propName, componentName, location, propFullName) {
+	    var propValue = props[propName];
+	    if (!immutableClassTypeValidator(propValue)) {
+	      var propType = getPropType(propValue);
+	      return new Error("Invalid " + location + " `" + propFullName + "` of type `" + propType + "` " + ("supplied to `" + componentName + "`, expected `" + immutableClassName + "`."));
+	    }
+	    return null;
+	  }
+	  return createChainableTypeChecker(validate);
+	}
+	
+	function createIterableTypeChecker(typeChecker, immutableClassName, immutableClassTypeValidator) {
+	
+	  function validate(props, propName, componentName, location, propFullName) {
+	    var propValue = props[propName];
+	    if (!immutableClassTypeValidator(propValue)) {
+	      var locationName = location;
+	      var propType = getPropType(propValue);
+	      return new Error("Invalid " + locationName + " `" + propFullName + "` of type " + ("`" + propType + "` supplied to `" + componentName + "`, expected an Immutable.js " + immutableClassName + "."));
+	    }
+	
+	    if (typeof typeChecker !== "function") {
+	      return new Error("Invalid typeChecker supplied to `" + componentName + "` " + ("for propType `" + propFullName + "`, expected a function."));
+	    }
+	
+	    var propValues = propValue.toArray();
+	    for (var i = 0, len = propValues.length; i < len; i++) {
+	      var error = typeChecker(propValues, i, componentName, location, "" + propFullName + "[" + i + "]");
+	      if (error instanceof Error) {
+	        return error;
+	      }
+	    }
+	  }
+	  return createChainableTypeChecker(validate);
+	}
+	
+	function createListOfTypeChecker(typeChecker) {
+	  return createIterableTypeChecker(typeChecker, "List", Immutable.List.isList);
+	}
+	
+	function createMapOfTypeChecker(typeChecker) {
+	  return createIterableTypeChecker(typeChecker, "Map", Immutable.Map.isMap);
+	}
+	
+	function createOrderedMapOfTypeChecker(typeChecker) {
+	  return createIterableTypeChecker(typeChecker, "OrderedMap", Immutable.OrderedMap.isOrderedMap);
+	}
+	
+	function createSetOfTypeChecker(typeChecker) {
+	  return createIterableTypeChecker(typeChecker, "Set", Immutable.Set.isSet);
+	}
+	
+	function createOrderedSetOfTypeChecker(typeChecker) {
+	  return createIterableTypeChecker(typeChecker, "OrderedSet", Immutable.OrderedSet.isOrderedSet);
+	}
+	
+	function createStackOfTypeChecker(typeChecker) {
+	  return createIterableTypeChecker(typeChecker, "Stack", Immutable.Stack.isStack);
+	}
+	
+	function createIterableOfTypeChecker(typeChecker) {
+	  return createIterableTypeChecker(typeChecker, "Iterable", Immutable.Iterable.isIterable);
+	}
+	
+	function createRecordOfTypeChecker(recordKeys) {
+	  function validate(props, propName, componentName, location, propFullName) {
+	    var propValue = props[propName];
+	    if (!(propValue instanceof Immutable.Record)) {
+	      var propType = getPropType(propValue);
+	      var locationName = location;
+	      return new Error("Invalid " + locationName + " `" + propFullName + "` of type `" + propType + "` " + ("supplied to `" + componentName + "`, expected an Immutable.js Record."));
+	    }
+	    for (var key in recordKeys) {
+	      var checker = recordKeys[key];
+	      if (!checker) {
+	        continue;
+	      }
+	      var mutablePropValue = propValue.toObject();
+	      var error = checker(mutablePropValue, key, componentName, location, "" + propFullName + "." + key);
+	      if (error) {
+	        return error;
+	      }
+	    }
+	  }
+	  return createChainableTypeChecker(validate);
+	}
+	
+	// there is some irony in the fact that shapeTypes is a standard hash and not an immutable collection
+	function createShapeTypeChecker(shapeTypes) {
+	  var immutableClassName = arguments[1] === undefined ? "Iterable" : arguments[1];
+	  var immutableClassTypeValidator = arguments[2] === undefined ? Immutable.Iterable.isIterable : arguments[2];
+	
+	  function validate(props, propName, componentName, location, propFullName) {
+	    var propValue = props[propName];
+	    if (!immutableClassTypeValidator(propValue)) {
+	      var propType = getPropType(propValue);
+	      var locationName = location;
+	      return new Error("Invalid " + locationName + " `" + propFullName + "` of type `" + propType + "` " + ("supplied to `" + componentName + "`, expected an Immutable.js " + immutableClassName + "."));
+	    }
+	    var mutablePropValue = propValue.toObject();
+	    for (var key in shapeTypes) {
+	      var checker = shapeTypes[key];
+	      if (!checker) {
+	        continue;
+	      }
+	      var error = checker(mutablePropValue, key, componentName, location, "" + propFullName + "." + key);
+	      if (error) {
+	        return error;
+	      }
+	    }
+	  }
+	  return createChainableTypeChecker(validate);
+	}
+	
+	function createShapeChecker(shapeTypes) {
+	  return createShapeTypeChecker(shapeTypes);
+	}
+	
+	function createMapContainsChecker(shapeTypes) {
+	  return createShapeTypeChecker(shapeTypes, "Map", Immutable.Map.isMap);
+	}
+	
+	module.exports = ImmutablePropTypes;
+
+/***/ },
+/* 210 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(17);
 	var dom = React.DOM;
 	var PropTypes = React.PropTypes;
 	var createFactory = React.createFactory;
 	
 	var _require = __webpack_require__(15);
 	
 	var connect = _require.connect;
 	
 	var _require2 = __webpack_require__(2);
 	
 	var bindActionCreators = _require2.bindActionCreators;
 	
-	var _require3 = __webpack_require__(207);
+	var _require3 = __webpack_require__(211);
 	
 	var cmdString = _require3.cmdString;
 	
-	var classnames = __webpack_require__(201);
-	var actions = __webpack_require__(209);
+	var classnames = __webpack_require__(204);
+	var actions = __webpack_require__(213);
 	
 	var _require4 = __webpack_require__(46);
 	
 	var isFirefoxPanel = _require4.isFirefoxPanel;
 	
-	var _require5 = __webpack_require__(199);
+	var _require5 = __webpack_require__(202);
 	
 	var getSources = _require5.getSources;
 	var getSelectedSource = _require5.getSelectedSource;
 	
-	var _require6 = __webpack_require__(183);
+	var _require6 = __webpack_require__(186);
 	
 	var endTruncateStr = _require6.endTruncateStr;
 	
-	var _require7 = __webpack_require__(212);
+	var _require7 = __webpack_require__(230);
 	
 	var parseURL = _require7.parse;
 	
-	var _require8 = __webpack_require__(241);
+	var _require8 = __webpack_require__(235);
 	
 	var KeyShortcuts = _require8.KeyShortcuts;
 	
-	
-	__webpack_require__(242);
-	__webpack_require__(244);
+	var shortcuts = new KeyShortcuts({ window });
+	
+	__webpack_require__(236);
+	__webpack_require__(238);
 	
 	// Using this static variable allows webpack to know at compile-time
 	// to avoid this require and not include it at all in the output.
 	if (false) {
 	  require("../lib/themes/light-theme.css");
 	}
 	
-	var Sources = createFactory(__webpack_require__(246));
-	var Editor = createFactory(__webpack_require__(354));
-	var SplitBox = createFactory(__webpack_require__(363));
-	var RightSidebar = createFactory(__webpack_require__(365));
-	var SourceTabs = createFactory(__webpack_require__(424));
-	var Svg = __webpack_require__(328);
-	var Autocomplete = createFactory(__webpack_require__(429));
+	var Sources = createFactory(__webpack_require__(240));
+	var Editor = createFactory(__webpack_require__(325));
+	var SplitBox = createFactory(__webpack_require__(337));
+	var RightSidebar = createFactory(__webpack_require__(339));
+	var SourceTabs = createFactory(__webpack_require__(403));
+	var Svg = __webpack_require__(299);
+	var Autocomplete = createFactory(__webpack_require__(408));
 	
 	function searchResults(sources) {
 	  function getSourcePath(source) {
 	    var _parseURL = parseURL(source.get("url"));
 	
 	    var path = _parseURL.path;
 	
 	    return endTruncateStr(path, 50);
@@ -27314,40 +27668,37 @@ var Debugger =
 	
 	  getInitialState() {
 	    return {
 	      searchOn: false
 	    };
 	  },
 	
 	  getChildContext() {
-	    return {
-	      shortcuts: this.shortcuts
-	    };
+	    return { shortcuts };
 	  },
 	
 	  componentDidMount() {
-	    this.shortcuts = new KeyShortcuts({ window });
-	
-	    this.shortcuts.on("CmdOrCtrl+P", this.toggleSourcesSearch);
+	    shortcuts.on("CmdOrCtrl+P", this.toggleSourcesSearch);
+	    shortcuts.on("Escape", this.onEscape);
 	    window.addEventListener("keydown", this.onKeyDown);
 	  },
 	
 	  componentWillUnmount() {
-	    this.shortcuts.off("CmdOrCtrl+P", this.toggleSourcesSearch);
-	    window.removeEventListener("keydown", this.onKeyDown);
+	    shortcuts.off("CmdOrCtrl+P", this.toggleSourcesSearch);
+	    shortcuts.off("Escape", this.onEscape);
 	  },
 	
 	  toggleSourcesSearch(key, e) {
 	    e.preventDefault();
 	    this.setState({ searchOn: !this.state.searchOn });
 	  },
 	
-	  onKeyDown(e) {
-	    if (this.state.searchOn && e.key === "Escape") {
+	  onEscape(shortcut, e) {
+	    if (this.state.searchOn) {
 	      this.setState({ searchOn: false });
 	      e.preventDefault();
 	    }
 	  },
 	
 	  closeSourcesSearch() {
 	    this.setState({ searchOn: false });
 	  },
@@ -27367,17 +27718,17 @@ var Debugger =
 	  },
 	
 	  renderCenterPane() {
 	    return dom.div({ className: "center-pane" }, dom.div({ className: "editor-container" }, SourceTabs(), Editor(), !this.props.selectedSource ? this.renderWelcomeBox() : null, this.state.searchOn ? this.renderSourcesSearch() : null));
 	  },
 	
 	  render: function () {
 	    return dom.div({ className: classnames("debugger theme-body", { "theme-light": !isFirefoxPanel() }) }, SplitBox({
-	      style: { width: "100vh" },
+	      style: { width: "100vw" },
 	      initialSize: "300px",
 	      minSize: 10,
 	      maxSize: "50%",
 	      splitterSize: 1,
 	      startPanel: Sources({ sources: this.props.sources }),
 	      endPanel: SplitBox({
 	        initialSize: "300px",
 	        minSize: 10,
@@ -27394,34 +27745,34 @@ var Debugger =
 	App.childContextTypes = {
 	  shortcuts: PropTypes.object
 	};
 	
 	module.exports = connect(state => ({ sources: getSources(state),
 	  selectedSource: getSelectedSource(state) }), dispatch => bindActionCreators(actions, dispatch))(App);
 
 /***/ },
-/* 207 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(208);
+/* 211 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(212);
 	
 	var Services = _require.Services;
 	
 	
 	function cmdString() {
 	  return Services.appinfo.OS === "Darwin" ? "⌘" : "Ctrl";
 	}
 	
 	module.exports = {
 	  cmdString
 	};
 
 /***/ },
-/* 208 */
+/* 212 */
 /***/ function(module, exports) {
 
 	/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
 	/* vim: set ts=2 et sw=2 tw=80: */
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
@@ -28026,59 +28377,58 @@ var Debugger =
 	exports.Services = Services;
 	// This is exported to silence eslint and, at some point, perhaps to
 	// provide it when loading devtools.js in order to install the default
 	// preferences.
 	exports.pref = pref;
 
 
 /***/ },
-/* 209 */
-/***/ function(module, exports, __webpack_require__) {
-
-	
-	
-	var breakpoints = __webpack_require__(210);
-	var eventListeners = __webpack_require__(234);
-	var sources = __webpack_require__(235);
-	var tabs = __webpack_require__(238);
-	var pause = __webpack_require__(239);
-	var navigation = __webpack_require__(240);
+/* 213 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var breakpoints = __webpack_require__(214);
+	var eventListeners = __webpack_require__(221);
+	var sources = __webpack_require__(222);
+	var tabs = __webpack_require__(227);
+	var pause = __webpack_require__(228);
+	var navigation = __webpack_require__(229);
 	
 	module.exports = Object.assign(navigation, breakpoints, eventListeners, sources, tabs, pause);
 
 /***/ },
-/* 210 */
+/* 214 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }();
 	
-	function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { return step("next", value); }, function (err) { return step("throw", err); }); } } return step("next"); }); }; }
+	function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
 	
 	/* This Source Code Form is subject to the terms of the Mozilla Public
 	 * License, v. 2.0. If a copy of the MPL was not distributed with this
 	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 	
 	/**
 	 * Redux actions for breakpoints
 	 * @module actions/breakpoints
 	 */
 	
-	var constants = __webpack_require__(190);
-	
-	var _require = __webpack_require__(182);
+	var constants = __webpack_require__(193);
+	
+	var _require = __webpack_require__(185);
 	
 	var PROMISE = _require.PROMISE;
 	
-	var _require2 = __webpack_require__(199);
+	var _require2 = __webpack_require__(202);
 	
 	var getBreakpoint = _require2.getBreakpoint;
 	var getBreakpoints = _require2.getBreakpoints;
-	
-	var _require3 = __webpack_require__(211);
+	var getSource = _require2.getSource;
+	
+	var _require3 = __webpack_require__(215);
 	
 	var getOriginalLocation = _require3.getOriginalLocation;
 	var getGeneratedLocation = _require3.getGeneratedLocation;
 	var isOriginalId = _require3.isOriginalId;
 	
 	/**
 	 * Argument parameters via Thunk middleware for {@link https://github.com/gaearon/redux-thunk|Redux Thunk}
 	 *
@@ -28088,17 +28438,17 @@ var Debugger =
 	 */
 	
 	function _breakpointExists(state, location) {
 	  var currentBp = getBreakpoint(state, location);
 	  return currentBp && !currentBp.disabled;
 	}
 	
 	function _getOrCreateBreakpoint(state, location, condition) {
-	  return getBreakpoint(state, location) || { location, condition };
+	  return getBreakpoint(state, location) || { location, condition, text: "" };
 	}
 	
 	/**
 	 * Enabling a breakpoint calls {@link addBreakpoint}
 	 * which will reuse the existing breakpoint information that is stored.
 	 *
 	 * @memberof actions/breakpoints
 	 * @static
@@ -28111,38 +28461,41 @@ var Debugger =
 	 * Add a new or enable an existing breakpoint
 	 *
 	 * @memberof actions/breakpoints
 	 * @static
 	 * @param {String} $1.condition Conditional breakpoint condition value
 	 * @param {Function} $1.getTextForLine Get the text to represent the line
 	 */
 	function addBreakpoint(location) {
-	  var _ref = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1];
+	  var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
 	
 	  var condition = _ref.condition;
 	  var getTextForLine = _ref.getTextForLine;
 	
-	  return _ref2 => {
+	  return (_ref2) => {
 	    var dispatch = _ref2.dispatch;
 	    var getState = _ref2.getState;
 	    var client = _ref2.client;
 	
 	    if (_breakpointExists(getState(), location)) {
 	      return Promise.resolve();
 	    }
 	
 	    var bp = _getOrCreateBreakpoint(getState(), location, condition);
 	
 	    return dispatch({
 	      type: constants.ADD_BREAKPOINT,
 	      breakpoint: bp,
 	      condition: condition,
 	      [PROMISE]: _asyncToGenerator(function* () {
-	        location = yield getGeneratedLocation(bp.location, getState());
+	        if (isOriginalId(bp.location.sourceId)) {
+	          var source = getSource(getState(), bp.location.sourceId);
+	          location = yield getGeneratedLocation(bp.location, source.toJS());
+	        }
 	
 	        var _ref4 = yield client.setBreakpoint(location, bp.condition, isOriginalId(bp.location.sourceId));
 	
 	        var id = _ref4.id;
 	        var actualLocation = _ref4.actualLocation;
 	
 	
 	        actualLocation = yield getOriginalLocation(actualLocation);
@@ -28176,17 +28529,17 @@ var Debugger =
 	 * @memberof actions/breakpoints
 	 * @static
 	 */
 	function removeBreakpoint(location) {
 	  return _removeOrDisableBreakpoint(location);
 	}
 	
 	function _removeOrDisableBreakpoint(location, isDisabled) {
-	  return _ref5 => {
+	  return (_ref5) => {
 	    var dispatch = _ref5.dispatch;
 	    var getState = _ref5.getState;
 	    var client = _ref5.client;
 	
 	    var bp = getBreakpoint(getState(), location);
 	    if (!bp) {
 	      throw new Error("attempt to remove breakpoint that does not exist");
 	    }
@@ -28217,17 +28570,17 @@ var Debugger =
 	
 	/**
 	 * Toggle All Breakpoints
 	 *
 	 * @memberof actions/breakpoints
 	 * @static
 	 */
 	function toggleAllBreakpoints(shouldDisableBreakpoints) {
-	  return _ref6 => {
+	  return (_ref6) => {
 	    var dispatch = _ref6.dispatch;
 	    var getState = _ref6.getState;
 	
 	    var breakpoints = getBreakpoints(getState());
 	    return dispatch({
 	      type: constants.TOGGLE_BREAKPOINTS,
 	      shouldDisableBreakpoints,
 	      [PROMISE]: _asyncToGenerator(function* () {
@@ -28289,206 +28642,86 @@ var Debugger =
 	  addBreakpoint,
 	  disableBreakpoint,
 	  removeBreakpoint,
 	  toggleAllBreakpoints,
 	  setBreakpointCondition
 	};
 
 /***/ },
-/* 211 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _fetchSourceMap = (() => {
-	  var _ref = _asyncToGenerator(function* (generatedSource) {
-	    // Fetch the sourcemap over the network and create it.
-	    var sourceMapURL = _resolveSourceMapURL(generatedSource);
-	    var fetched = yield networkRequest(sourceMapURL, { loadFromCache: false });
-	
-	    // Create the source map and fix it up.
-	    var map = new SourceMapConsumer(fetched.content);
-	    _setSourceMapRoot(map, sourceMapURL, generatedSource);
-	    return map;
-	  });
-	
-	  return function _fetchSourceMap(_x) {
-	    return _ref.apply(this, arguments);
-	  };
-	})();
-	
-	var getGeneratedLocation = (() => {
-	  var _ref2 = _asyncToGenerator(function* (location, state) {
-	    if (!isOriginalId(location.sourceId)) {
-	      return location;
-	    }
-	
-	    var originalSource = getSource(state, location.sourceId).toJS();
-	    var generatedSourceId = originalToGeneratedId(location.sourceId);
-	    var map = yield getSourceMap(generatedSourceId);
-	    if (!map) {
-	      return location;
-	    }
-	
-	    var _map$generatedPositio = map.generatedPositionFor({
-	      source: originalSource.url,
-	      line: location.line,
-	      column: location.column == null ? 0 : location.column
-	    });
-	
-	    var line = _map$generatedPositio.line;
-	    var column = _map$generatedPositio.column;
-	
-	
-	    return {
-	      sourceId: generatedSourceId,
-	      line: line,
-	      // Treat 0 as no column so that line breakpoints work correctly.
-	      column: column === 0 ? undefined : column
-	    };
-	  });
-	
-	  return function getGeneratedLocation(_x2, _x3) {
-	    return _ref2.apply(this, arguments);
-	  };
-	})();
-	
-	var getOriginalLocation = (() => {
-	  var _ref3 = _asyncToGenerator(function* (location) {
-	    if (!isGeneratedId(location.sourceId)) {
-	      return location;
-	    }
-	
-	    var map = yield getSourceMap(location.sourceId);
-	    if (!map) {
-	      return location;
-	    }
-	
-	    var _map$originalPosition = map.originalPositionFor({
-	      line: location.line,
-	      column: location.column == null ? Infinity : location.column
-	    });
-	
-	    var url = _map$originalPosition.source;
-	    var line = _map$originalPosition.line;
-	    var column = _map$originalPosition.column;
-	
-	
-	    if (url == null) {
-	      // No url means the location didn't map.
-	      return location;
-	    }
-	
-	    return {
-	      sourceId: generatedToOriginalId(location.sourceId, url),
-	      line,
-	      column
-	    };
-	  });
-	
-	  return function getOriginalLocation(_x4) {
-	    return _ref3.apply(this, arguments);
-	  };
-	})();
-	
-	var getOriginalSourceText = (() => {
-	  var _ref4 = _asyncToGenerator(function* (originalSource) {
-	    assert(isOriginalId(originalSource.id), "Source is not an original source");
-	
-	    var generatedSourceId = originalToGeneratedId(originalSource.id);
-	    var map = yield getSourceMap(generatedSourceId);
-	    if (!map) {
-	      return null;
-	    }
-	
-	    var text = map.sourceContentFor(originalSource.url);
-	    if (!text) {
-	      text = (yield networkRequest(originalSource.url, { loadFromCache: false })).content;
-	    }
-	
-	    return {
-	      text,
-	      contentType: isJavaScript(originalSource.url) ? "text/javascript" : "text/plain"
-	    };
-	  });
-	
-	  return function getOriginalSourceText(_x5) {
-	    return _ref4.apply(this, arguments);
-	  };
-	})();
-	
-	function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { return step("next", value); }, function (err) { return step("throw", err); }); } } return step("next"); }); }; }
-	
-	var URL = __webpack_require__(212);
-	var md5 = __webpack_require__(217);
-	
-	var _require = __webpack_require__(221);
-	
-	var SourceMapConsumer = _require.SourceMapConsumer;
-	var SourceMapGenerator = _require.SourceMapGenerator;
-	
-	var path = __webpack_require__(232);
-	var networkRequest = __webpack_require__(175);
-	
-	var _require2 = __webpack_require__(199);
-	
-	var getSource = _require2.getSource;
+/* 215 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(46);
+	
+	var getValue = _require.getValue;
+	
+	var _require2 = __webpack_require__(186);
+	
+	var workerTask = _require2.workerTask;
 	
 	var _require3 = __webpack_require__(46);
 	
 	var isEnabled = _require3.isEnabled;
 	
-	var _require4 = __webpack_require__(233);
-	
-	var isJavaScript = _require4.isJavaScript;
-	
-	var assert = __webpack_require__(186);
-	
-	var sourceMapRequests = new Map();
-	
-	function clearSourceMaps() {
-	  sourceMapRequests = new Map();
-	}
-	
-	function _resolveSourceMapURL(source) {
-	  if (path.isURL(source.sourceMapURL) || !source.url) {
-	    // If it's already a full URL or the source doesn't have a URL,
-	    // don't resolve anything.
-	    return source.sourceMapURL;
-	  } else if (path.isAbsolute(source.sourceMapURL)) {
-	    // If it's an absolute path, it should be resolved relative to the
-	    // host of the source.
-	    var urlObj = URL.parse(source.url);
-	    var base = urlObj.protocol + "//" + urlObj.host;
-	    return base + source.sourceMapURL;
-	  }
-	  // Otherwise, it's a relative path and should be resolved relative
-	  // to the source.
-	  return path.dirname(source.url) + "/" + source.sourceMapURL;
-	}
-	
-	/**
-	 * Sets the source map's sourceRoot to be relative to the source map url.
-	 */
-	function _setSourceMapRoot(sourceMap, absSourceMapURL, source) {
-	  // No need to do this fiddling if we won't be fetching any sources over the
-	  // wire.
-	  if (sourceMap.hasContentsOfAllSources()) {
-	    return;
-	  }
-	
-	  var base = path.dirname(absSourceMapURL.indexOf("data:") === 0 && source.url ? source.url : absSourceMapURL);
-	
-	  if (sourceMap.sourceRoot) {
-	    sourceMap.sourceRoot = path.join(base, sourceMap.sourceRoot);
-	  } else {
-	    sourceMap.sourceRoot = base;
-	  }
-	
-	  return sourceMap;
-	}
+	var _require4 = __webpack_require__(216);
+	
+	var originalToGeneratedId = _require4.originalToGeneratedId;
+	var generatedToOriginalId = _require4.generatedToOriginalId;
+	var isGeneratedId = _require4.isGeneratedId;
+	var isOriginalId = _require4.isOriginalId;
+	
+	
+	var sourceMapWorker = void 0;
+	function restartWorker() {
+	  if (sourceMapWorker) {
+	    sourceMapWorker.terminate();
+	  }
+	  sourceMapWorker = new Worker(getValue("baseWorkerURL") + "source-map-worker.js");
+	
+	  if (isEnabled("sourceMaps")) {
+	    sourceMapWorker.postMessage({ id: 0, method: "enableSourceMaps" });
+	  }
+	}
+	restartWorker();
+	
+	function destroyWorker() {
+	  if (sourceMapWorker) {
+	    sourceMapWorker.terminate();
+	    sourceMapWorker = null;
+	  }
+	}
+	
+	var getOriginalURLs = workerTask(sourceMapWorker, "getOriginalURLs");
+	var getGeneratedLocation = workerTask(sourceMapWorker, "getGeneratedLocation");
+	var getOriginalLocation = workerTask(sourceMapWorker, "getOriginalLocation");
+	var getOriginalSourceText = workerTask(sourceMapWorker, "getOriginalSourceText");
+	var applySourceMap = workerTask(sourceMapWorker, "applySourceMap");
+	var clearSourceMaps = workerTask(sourceMapWorker, "clearSourceMaps");
+	
+	module.exports = {
+	  originalToGeneratedId,
+	  generatedToOriginalId,
+	  isGeneratedId,
+	  isOriginalId,
+	
+	  getOriginalURLs,
+	  getGeneratedLocation,
+	  getOriginalLocation,
+	  getOriginalSourceText,
+	  applySourceMap,
+	  clearSourceMaps,
+	  destroyWorker
+	};
+
+/***/ },
+/* 216 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var md5 = __webpack_require__(217);
 	
 	function originalToGeneratedId(originalId) {
 	  var match = originalId.match(/(.*)\/originalSource/);
 	  return match ? match[1] : null;
 	}
 	
 	function generatedToOriginalId(generatedId, url) {
 	  return generatedId + "/originalSource-" + md5(url);
@@ -28497,65 +28730,1586 @@ var Debugger =
 	function isOriginalId(id) {
 	  return id.match(/\/originalSource/);
 	}
 	
 	function isGeneratedId(id) {
 	  return !isOriginalId(id);
 	}
 	
-	function fetchSourceMap(generatedSource) {
-	  var existingRequest = sourceMapRequests.get(generatedSource.id);
-	
-	  if (!generatedSource.sourceMapURL || !isEnabled("sourceMaps")) {
-	    return Promise.resolve(null);
-	  } else if (existingRequest) {
-	    // If it has already been requested, return the request. An
-	    // important behavior here is that if it's in the middle of
-	    // requesting it, all subsequent calls will block on the initial
-	    // request.
-	    return existingRequest;
-	  }
-	
-	  // Fire off the request, set it in the cache, and return it.
-	  var req = _fetchSourceMap(generatedSource);
-	  sourceMapRequests.set(generatedSource.id, req);
-	  return req;
-	}
-	
-	function getSourceMap(generatedSourceId) {
-	  return sourceMapRequests.get(generatedSourceId);
-	}
-	
-	function applySourceMap(generatedId, url, code, mappings) {
-	  var generator = new SourceMapGenerator({ file: url });
-	  mappings.forEach(mapping => generator.addMapping(mapping));
-	  generator.setSourceContent(url, code);
-	
-	  var map = SourceMapConsumer(generator.toJSON());
-	  sourceMapRequests.set(generatedId, Promise.resolve(map));
-	  return map;
+	module.exports = {
+	  originalToGeneratedId, generatedToOriginalId, isOriginalId, isGeneratedId
+	};
+
+/***/ },
+/* 217 */
+/***/ function(module, exports, __webpack_require__) {
+
+	(function(){
+	  var crypt = __webpack_require__(218),
+	      utf8 = __webpack_require__(219).utf8,
+	      isBuffer = __webpack_require__(220),
+	      bin = __webpack_require__(219).bin,
+	
+	  // The core
+	  md5 = function (message, options) {
+	    // Convert to byte array
+	    if (message.constructor == String)
+	      if (options && options.encoding === 'binary')
+	        message = bin.stringToBytes(message);
+	      else
+	        message = utf8.stringToBytes(message);
+	    else if (isBuffer(message))
+	      message = Array.prototype.slice.call(message, 0);
+	    else if (!Array.isArray(message))
+	      message = message.toString();
+	    // else, assume byte array already
+	
+	    var m = crypt.bytesToWords(message),
+	        l = message.length * 8,
+	        a =  1732584193,
+	        b = -271733879,
+	        c = -1732584194,
+	        d =  271733878;
+	
+	    // Swap endian
+	    for (var i = 0; i < m.length; i++) {
+	      m[i] = ((m[i] <<  8) | (m[i] >>> 24)) & 0x00FF00FF |
+	             ((m[i] << 24) | (m[i] >>>  8)) & 0xFF00FF00;
+	    }
+	
+	    // Padding
+	    m[l >>> 5] |= 0x80 << (l % 32);
+	    m[(((l + 64) >>> 9) << 4) + 14] = l;
+	
+	    // Method shortcuts
+	    var FF = md5._ff,
+	        GG = md5._gg,
+	        HH = md5._hh,
+	        II = md5._ii;
+	
+	    for (var i = 0; i < m.length; i += 16) {
+	
+	      var aa = a,
+	          bb = b,
+	          cc = c,
+	          dd = d;
+	
+	      a = FF(a, b, c, d, m[i+ 0],  7, -680876936);
+	      d = FF(d, a, b, c, m[i+ 1], 12, -389564586);
+	      c = FF(c, d, a, b, m[i+ 2], 17,  606105819);
+	      b = FF(b, c, d, a, m[i+ 3], 22, -1044525330);
+	      a = FF(a, b, c, d, m[i+ 4],  7, -176418897);
+	      d = FF(d, a, b, c, m[i+ 5], 12,  1200080426);
+	      c = FF(c, d, a, b, m[i+ 6], 17, -1473231341);
+	      b = FF(b, c, d, a, m[i+ 7], 22, -45705983);
+	      a = FF(a, b, c, d, m[i+ 8],  7,  1770035416);
+	      d = FF(d, a, b, c, m[i+ 9], 12, -1958414417);
+	      c = FF(c, d, a, b, m[i+10], 17, -42063);
+	      b = FF(b, c, d, a, m[i+11], 22, -1990404162);
+	      a = FF(a, b, c, d, m[i+12],  7,  1804603682);
+	      d = FF(d, a, b, c, m[i+13], 12, -40341101);
+	      c = FF(c, d, a, b, m[i+14], 17, -1502002290);
+	      b = FF(b, c, d, a, m[i+15], 22,  1236535329);
+	
+	      a = GG(a, b, c, d, m[i+ 1],  5, -165796510);
+	      d = GG(d, a, b, c, m[i+ 6],  9, -1069501632);
+	      c = GG(c, d, a, b, m[i+11], 14,  643717713);
+	      b = GG(b, c, d, a, m[i+ 0], 20, -373897302);
+	      a = GG(a, b, c, d, m[i+ 5],  5, -701558691);
+	      d = GG(d, a, b, c, m[i+10],  9,  38016083);
+	      c = GG(c, d, a, b, m[i+15], 14, -660478335);
+	      b = GG(b, c, d, a, m[i+ 4], 20, -405537848);
+	      a = GG(a, b, c, d, m[i+ 9],  5,  568446438);
+	      d = GG(d, a, b, c, m[i+14],  9, -1019803690);
+	      c = GG(c, d, a, b, m[i+ 3], 14, -187363961);
+	      b = GG(b, c, d, a, m[i+ 8], 20,  1163531501);
+	      a = GG(a, b, c, d, m[i+13],  5, -1444681467);
+	      d = GG(d, a, b, c, m[i+ 2],  9, -51403784);
+	      c = GG(c, d, a, b, m[i+ 7], 14,  1735328473);
+	      b = GG(b, c, d, a, m[i+12], 20, -1926607734);
+	
+	      a = HH(a, b, c, d, m[i+ 5],  4, -378558);
+	      d = HH(d, a, b, c, m[i+ 8], 11, -2022574463);
+	      c = HH(c, d, a, b, m[i+11], 16,  1839030562);
+	      b = HH(b, c, d, a, m[i+14], 23, -35309556);
+	      a = HH(a, b, c, d, m[i+ 1],  4, -1530992060);
+	      d = HH(d, a, b, c, m[i+ 4], 11,  1272893353);
+	      c = HH(c, d, a, b, m[i+ 7], 16, -155497632);
+	      b = HH(b, c, d, a, m[i+10], 23, -1094730640);
+	      a = HH(a, b, c, d, m[i+13],  4,  681279174);
+	      d = HH(d, a, b, c, m[i+ 0], 11, -358537222);
+	      c = HH(c, d, a, b, m[i+ 3], 16, -722521979);
+	      b = HH(b, c, d, a, m[i+ 6], 23,  76029189);
+	      a = HH(a, b, c, d, m[i+ 9],  4, -640364487);
+	      d = HH(d, a, b, c, m[i+12], 11, -421815835);
+	      c = HH(c, d, a, b, m[i+15], 16,  530742520);
+	      b = HH(b, c, d, a, m[i+ 2], 23, -995338651);
+	
+	      a = II(a, b, c, d, m[i+ 0],  6, -198630844);
+	      d = II(d, a, b, c, m[i+ 7], 10,  1126891415);
+	      c = II(c, d, a, b, m[i+14], 15, -1416354905);
+	      b = II(b, c, d, a, m[i+ 5], 21, -57434055);
+	      a = II(a, b, c, d, m[i+12],  6,  1700485571);
+	      d = II(d, a, b, c, m[i+ 3], 10, -1894986606);
+	      c = II(c, d, a, b, m[i+10], 15, -1051523);
+	      b = II(b, c, d, a, m[i+ 1], 21, -2054922799);
+	      a = II(a, b, c, d, m[i+ 8],  6,  1873313359);
+	      d = II(d, a, b, c, m[i+15], 10, -30611744);
+	      c = II(c, d, a, b, m[i+ 6], 15, -1560198380);
+	      b = II(b, c, d, a, m[i+13], 21,  1309151649);
+	      a = II(a, b, c, d, m[i+ 4],  6, -145523070);
+	      d = II(d, a, b, c, m[i+11], 10, -1120210379);
+	      c = II(c, d, a, b, m[i+ 2], 15,  718787259);
+	      b = II(b, c, d, a, m[i+ 9], 21, -343485551);
+	
+	      a = (a + aa) >>> 0;
+	      b = (b + bb) >>> 0;
+	      c = (c + cc) >>> 0;
+	      d = (d + dd) >>> 0;
+	    }
+	
+	    return crypt.endian([a, b, c, d]);
+	  };
+	
+	  // Auxiliary functions
+	  md5._ff  = function (a, b, c, d, x, s, t) {
+	    var n = a + (b & c | ~b & d) + (x >>> 0) + t;
+	    return ((n << s) | (n >>> (32 - s))) + b;
+	  };
+	  md5._gg  = function (a, b, c, d, x, s, t) {
+	    var n = a + (b & d | c & ~d) + (x >>> 0) + t;
+	    return ((n << s) | (n >>> (32 - s))) + b;
+	  };
+	  md5._hh  = function (a, b, c, d, x, s, t) {
+	    var n = a + (b ^ c ^ d) + (x >>> 0) + t;
+	    return ((n << s) | (n >>> (32 - s))) + b;
+	  };
+	  md5._ii  = function (a, b, c, d, x, s, t) {
+	    var n = a + (c ^ (b | ~d)) + (x >>> 0) + t;
+	    return ((n << s) | (n >>> (32 - s))) + b;
+	  };
+	
+	  // Package private blocksize
+	  md5._blocksize = 16;
+	  md5._digestsize = 16;
+	
+	  module.exports = function (message, options) {
+	    if (message === undefined || message === null)
+	      throw new Error('Illegal argument ' + message);
+	
+	    var digestbytes = crypt.wordsToBytes(md5(message, options));
+	    return options && options.asBytes ? digestbytes :
+	        options && options.asString ? bin.bytesToString(digestbytes) :
+	        crypt.bytesToHex(digestbytes);
+	  };
+	
+	})();
+
+
+/***/ },
+/* 218 */
+/***/ function(module, exports) {
+
+	(function() {
+	  var base64map
+	      = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',
+	
+	  crypt = {
+	    // Bit-wise rotation left
+	    rotl: function(n, b) {
+	      return (n << b) | (n >>> (32 - b));
+	    },
+	
+	    // Bit-wise rotation right
+	    rotr: function(n, b) {
+	      return (n << (32 - b)) | (n >>> b);
+	    },
+	
+	    // Swap big-endian to little-endian and vice versa
+	    endian: function(n) {
+	      // If number given, swap endian
+	      if (n.constructor == Number) {
+	        return crypt.rotl(n, 8) & 0x00FF00FF | crypt.rotl(n, 24) & 0xFF00FF00;
+	      }
+	
+	      // Else, assume array and swap all items
+	      for (var i = 0; i < n.length; i++)
+	        n[i] = crypt.endian(n[i]);
+	      return n;
+	    },
+	
+	    // Generate an array of any length of random bytes
+	    randomBytes: function(n) {
+	      for (var bytes = []; n > 0; n--)
+	        bytes.push(Math.floor(Math.random() * 256));
+	      return bytes;
+	    },
+	
+	    // Convert a byte array to big-endian 32-bit words
+	    bytesToWords: function(bytes) {
+	      for (var words = [], i = 0, b = 0; i < bytes.length; i++, b += 8)
+	        words[b >>> 5] |= bytes[i] << (24 - b % 32);
+	      return words;
+	    },
+	
+	    // Convert big-endian 32-bit words to a byte array
+	    wordsToBytes: function(words) {
+	      for (var bytes = [], b = 0; b < words.length * 32; b += 8)
+	        bytes.push((words[b >>> 5] >>> (24 - b % 32)) & 0xFF);
+	      return bytes;
+	    },
+	
+	    // Convert a byte array to a hex string
+	    bytesToHex: function(bytes) {
+	      for (var hex = [], i = 0; i < bytes.length; i++) {
+	        hex.push((bytes[i] >>> 4).toString(16));
+	        hex.push((bytes[i] & 0xF).toString(16));
+	      }
+	      return hex.join('');
+	    },
+	
+	    // Convert a hex string to a byte array
+	    hexToBytes: function(hex) {
+	      for (var bytes = [], c = 0; c < hex.length; c += 2)
+	        bytes.push(parseInt(hex.substr(c, 2), 16));
+	      return bytes;
+	    },
+	
+	    // Convert a byte array to a base-64 string
+	    bytesToBase64: function(bytes) {
+	      for (var base64 = [], i = 0; i < bytes.length; i += 3) {
+	        var triplet = (bytes[i] << 16) | (bytes[i + 1] << 8) | bytes[i + 2];
+	        for (var j = 0; j < 4; j++)
+	          if (i * 8 + j * 6 <= bytes.length * 8)
+	            base64.push(base64map.charAt((triplet >>> 6 * (3 - j)) & 0x3F));
+	          else
+	            base64.push('=');
+	      }
+	      return base64.join('');
+	    },
+	
+	    // Convert a base-64 string to a byte array
+	    base64ToBytes: function(base64) {
+	      // Remove non-base-64 characters
+	      base64 = base64.replace(/[^A-Z0-9+\/]/ig, '');
+	
+	      for (var bytes = [], i = 0, imod4 = 0; i < base64.length;
+	          imod4 = ++i % 4) {
+	        if (imod4 == 0) continue;
+	        bytes.push(((base64map.indexOf(base64.charAt(i - 1))
+	            & (Math.pow(2, -2 * imod4 + 8) - 1)) << (imod4 * 2))
+	            | (base64map.indexOf(base64.charAt(i)) >>> (6 - imod4 * 2)));
+	      }
+	      return bytes;
+	    }
+	  };
+	
+	  module.exports = crypt;
+	})();
+
+
+/***/ },
+/* 219 */
+/***/ function(module, exports) {
+
+	var charenc = {
+	  // UTF-8 encoding
+	  utf8: {
+	    // Convert a string to a byte array
+	    stringToBytes: function(str) {
+	      return charenc.bin.stringToBytes(unescape(encodeURIComponent(str)));
+	    },
+	
+	    // Convert a byte array to a string
+	    bytesToString: function(bytes) {
+	      return decodeURIComponent(escape(charenc.bin.bytesToString(bytes)));
+	    }
+	  },
+	
+	  // Binary encoding
+	  bin: {
+	    // Convert a string to a byte array
+	    stringToBytes: function(str) {
+	      for (var bytes = [], i = 0; i < str.length; i++)
+	        bytes.push(str.charCodeAt(i) & 0xFF);
+	      return bytes;
+	    },
+	
+	    // Convert a byte array to a string
+	    bytesToString: function(bytes) {
+	      for (var str = [], i = 0; i < bytes.length; i++)
+	        str.push(String.fromCharCode(bytes[i]));
+	      return str.join('');
+	    }
+	  }
+	};
+	
+	module.exports = charenc;
+
+
+/***/ },
+/* 220 */
+/***/ function(module, exports) {
+
+	/*!
+	 * Determine if an object is a Buffer
+	 *
+	 * @author   Feross Aboukhadijeh <feross@feross.org> <http://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))
+	}
+
+
+/***/ },
+/* 221 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/* This Source Code Form is subject to the terms of the Mozilla Public
+	 * License, v. 2.0. If a copy of the MPL was not distributed with this
+	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+	/* global window gThreadClient setNamedTimeout services EVENTS */
+	/* eslint no-shadow: 0  */
+	
+	/**
+	 * Redux actions for the event listeners state
+	 * @module actions/event-listeners
+	 */
+	
+	var constants = __webpack_require__(193);
+	
+	var _require = __webpack_require__(186);
+	
+	var asPaused = _require.asPaused;
+	
+	var _require2 = __webpack_require__(188);
+	
+	var reportException = _require2.reportException;
+	
+	var _require3 = __webpack_require__(99);
+	
+	var Task = _require3.Task;
+	
+	// delay is in ms
+	
+	var FETCH_EVENT_LISTENERS_DELAY = 200;
+	
+	/**
+	 * @memberof actions/event-listeners
+	 * @static
+	 */
+	function fetchEventListeners() {
+	  return (dispatch, getState) => {
+	    // Make sure we"re not sending a batch of closely repeated requests.
+	    // This can easily happen whenever new sources are fetched.
+	    setNamedTimeout("event-listeners-fetch", FETCH_EVENT_LISTENERS_DELAY, () => {
+	      // In case there is still a request of listeners going on (it
+	      // takes several RDP round trips right now), make sure we wait
+	      // on a currently running request
+	      if (getState().eventListeners.fetchingListeners) {
+	        dispatch({
+	          type: services.WAIT_UNTIL,
+	          predicate: action => action.type === constants.FETCH_EVENT_LISTENERS && action.status === "done",
+	          run: dispatch => dispatch(fetchEventListeners())
+	        });
+	        return;
+	      }
+	
+	      dispatch({
+	        type: constants.FETCH_EVENT_LISTENERS,
+	        status: "begin"
+	      });
+	
+	      asPaused(gThreadClient, _getListeners).then(listeners => {
+	        // Notify that event listeners were fetched and shown in the view,
+	        // and callback to resume the active thread if necessary.
+	        window.emit(EVENTS.EVENT_LISTENERS_FETCHED);
+	
+	        dispatch({
+	          type: constants.FETCH_EVENT_LISTENERS,
+	          status: "done",
+	          listeners: listeners
+	        });
+	      });
+	    });
+	  };
+	}
+	
+	var _getListeners = Task.async(function* () {
+	  var response = yield gThreadClient.eventListeners();
+	
+	  // Make sure all the listeners are sorted by the event type, since
+	  // they"re not guaranteed to be clustered together.
+	  response.listeners.sort((a, b) => a.type > b.type ? 1 : -1);
+	
+	  // Add all the listeners in the debugger view event linsteners container.
+	  var fetchedDefinitions = new Map();
+	  var listeners = [];
+	  for (var listener of response.listeners) {
+	    var definitionSite = void 0;
+	    if (fetchedDefinitions.has(listener.function.actor)) {
+	      definitionSite = fetchedDefinitions.get(listener.function.actor);
+	    } else if (listener.function.class == "Function") {
+	      definitionSite = yield _getDefinitionSite(listener.function);
+	      if (!definitionSite) {
+	        // We don"t know where this listener comes from so don"t show it in
+	        // the UI as breaking on it doesn"t work (bug 942899).
+	        continue;
+	      }
+	
+	      fetchedDefinitions.set(listener.function.actor, definitionSite);
+	    }
+	    listener.function.url = definitionSite;
+	    listeners.push(listener);
+	  }
+	  fetchedDefinitions.clear();
+	
+	  return listeners;
+	});
+	
+	var _getDefinitionSite = Task.async(function* (func) {
+	  var grip = gThreadClient.pauseGrip(func);
+	  var response = void 0;
+	
+	  try {
+	    response = yield grip.getDefinitionSite();
+	  } catch (e) {
+	    // Don't make this error fatal, it would break the entire events pane.
+	    reportException("_getDefinitionSite", e);
+	    return null;
+	  }
+	
+	  return response.source.url;
+	});
+	
+	/**
+	 * @memberof actions/event-listeners
+	 * @static
+	 * @param {string} eventNames
+	 */
+	function updateEventBreakpoints(eventNames) {
+	  return dispatch => {
+	    setNamedTimeout("event-breakpoints-update", 0, () => {
+	      gThreadClient.pauseOnDOMEvents(eventNames, function () {
+	        // Notify that event breakpoints were added/removed on the server.
+	        window.emit(EVENTS.EVENT_BREAKPOINTS_UPDATED);
+	
+	        dispatch({
+	          type: constants.UPDATE_EVENT_BREAKPOINTS,
+	          eventNames: eventNames
+	        });
+	      });
+	    });
+	  };
+	}
+	
+	module.exports = { updateEventBreakpoints, fetchEventListeners };
+
+/***/ },
+/* 222 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }();
+	
+	var _prettyPrintSource = (() => {
+	  var _ref = _asyncToGenerator(function* (_ref2) {
+	    var source = _ref2.source;
+	    var sourceText = _ref2.sourceText;
+	    var url = _ref2.url;
+	
+	    var contentType = sourceText ? sourceText.contentType : null;
+	    var indent = 2;
+	
+	    invariant(isJavaScript(source.url, contentType), "Can't prettify non-javascript files.");
+	
+	    var _ref3 = yield workerTask(new Worker("public/build/pretty-print-worker.js"), {
+	      url,
+	      indent,
+	      source: sourceText.text
+	    });
+	
+	    var code = _ref3.code;
+	    var mappings = _ref3.mappings;
+	
+	
+	    return { code, mappings };
+	  });
+	
+	  return function _prettyPrintSource(_x) {
+	    return _ref.apply(this, arguments);
+	  };
+	})();
+	
+	/**
+	 * Handler for the debugger client's unsolicited newSource notification.
+	 * @memberof actions/sources
+	 * @static
+	 */
+	
+	
+	function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
+	
+	/* This Source Code Form is subject to the terms of the Mozilla Public
+	 * License, v. 2.0. If a copy of the MPL was not distributed with this
+	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+	
+	/**
+	 * Redux actions for the sources state
+	 * @module actions/sources
+	 */
+	
+	var defer = __webpack_require__(114);
+	
+	var _require = __webpack_require__(185);
+	
+	var PROMISE = _require.PROMISE;
+	
+	var _require2 = __webpack_require__(99);
+	
+	var Task = _require2.Task;
+	
+	var _require3 = __webpack_require__(223);
+	
+	var isJavaScript = _require3.isJavaScript;
+	
+	var _require4 = __webpack_require__(186);
+	
+	var workerTask = _require4.workerTask;
+	
+	var _require5 = __webpack_require__(225);
+	
+	var updateFrameLocations = _require5.updateFrameLocations;
+	
+	var _require6 = __webpack_require__(215);
+	
+	var getOriginalURLs = _require6.getOriginalURLs;
+	var getOriginalSourceText = _require6.getOriginalSourceText;
+	var generatedToOriginalId = _require6.generatedToOriginalId;
+	var isOriginalId = _require6.isOriginalId;
+	var applySourceMap = _require6.applySourceMap;
+	
+	
+	var constants = __webpack_require__(193);
+	var invariant = __webpack_require__(24);
+	
+	var _require7 = __webpack_require__(46);
+	
+	var isEnabled = _require7.isEnabled;
+	
+	var _require8 = __webpack_require__(226);
+	
+	var removeDocument = _require8.removeDocument;
+	
+	var _require9 = __webpack_require__(202);
+	
+	var getSource = _require9.getSource;
+	var getSourceByURL = _require9.getSourceByURL;
+	var getSourceText = _require9.getSourceText;
+	var getPendingSelectedLocation = _require9.getPendingSelectedLocation;
+	var getFrames = _require9.getFrames;
+	function newSource(source) {
+	  return (_ref4) => {
+	    var dispatch = _ref4.dispatch;
+	    var getState = _ref4.getState;
+	
+	    if (isEnabled("sourceMaps")) {
+	      dispatch(loadSourceMap(source));
+	    }
+	
+	    dispatch({
+	      type: constants.ADD_SOURCE,
+	      source
+	    });
+	
+	    // If a request has been made to show this source, go ahead and
+	    // select it.
+	    var pendingLocation = getPendingSelectedLocation(getState());
+	    if (pendingLocation && pendingLocation.url === source.url) {
+	      dispatch(selectSource(source.id, { line: pendingLocation.line }));
+	    }
+	  };
+	}
+	
+	function newSources(sources) {
+	  return (_ref5) => {
+	    var dispatch = _ref5.dispatch;
+	    var getState = _ref5.getState;
+	
+	    sources.filter(source => !getSource(getState(), source.id)).forEach(source => dispatch(newSource(source)));
+	  };
+	}
+	
+	/**
+	 * @memberof actions/sources
+	 * @static
+	 */
+	function loadSourceMap(generatedSource) {
+	  return (() => {
+	    var _ref6 = _asyncToGenerator(function* (_ref7) {
+	      var dispatch = _ref7.dispatch;
+	      var getState = _ref7.getState;
+	
+	      var urls = yield getOriginalURLs(generatedSource);
+	      if (!urls) {
+	        // If this source doesn't have a sourcemap, do nothing.
+	        return;
+	      }
+	
+	      var originalSources = urls.map(function (originalUrl) {
+	        return {
+	          url: originalUrl,
+	          id: generatedToOriginalId(generatedSource.id, originalUrl),
+	          isPrettyPrinted: false
+	        };
+	      });
+	
+	      originalSources.forEach(function (s) {
+	        return dispatch(newSource(s));
+	      });
+	    });
+	
+	    return function (_x2) {
+	      return _ref6.apply(this, arguments);
+	    };
+	  })();
+	}
+	
+	/**
+	 * Deterministically select a source that has a given URL. This will
+	 * work regardless of the connection status or if the source exists
+	 * yet. This exists mostly for external things to interact with the
+	 * debugger.
+	 *
+	 * @memberof actions/sources
+	 * @static
+	 */
+	function selectSourceURL(url) {
+	  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+	
+	  return (_ref8) => {
+	    var dispatch = _ref8.dispatch;
+	    var getState = _ref8.getState;
+	
+	    var source = getSourceByURL(getState(), url);
+	    if (source) {
+	      dispatch(selectSource(source.get("id"), options));
+	    } else {
+	      dispatch({
+	        type: constants.SELECT_SOURCE_URL,
+	        url: url,
+	        tabIndex: options.tabIndex,
+	        line: options.line
+	      });
+	    }
+	  };
+	}
+	
+	/**
+	 * @memberof actions/sources
+	 * @static
+	 */
+	function selectSource(id) {
+	  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+	
+	  return (_ref9) => {
+	    var dispatch = _ref9.dispatch;
+	    var getState = _ref9.getState;
+	    var client = _ref9.client;
+	
+	    if (!client) {
+	      // No connection, do nothing. This happens when the debugger is
+	      // shut down too fast and it tries to display a default source.
+	      return;
+	    }
+	
+	    var source = getSource(getState(), id).toJS();
+	
+	    // Make sure to start a request to load the source text.
+	    dispatch(loadSourceText(source));
+	
+	    dispatch({
+	      type: constants.SELECT_SOURCE,
+	      source: source,
+	      tabIndex: options.tabIndex,
+	      line: options.line
+	    });
+	  };
+	}
+	
+	/**
+	 * @memberof actions/sources
+	 * @static
+	 */
+	function closeTab(id) {
+	  removeDocument(id);
+	  return {
+	    type: constants.CLOSE_TAB,
+	    id: id
+	  };
+	}
+	
+	/**
+	 * Set the black boxed status of the given source.
+	 *
+	 * @memberof actions/sources
+	 * @static
+	 * @param Object source
+	 *        The source form.
+	 * @param bool shouldBlackBox
+	 *        True to black box the source, false to un-black box it.
+	 * @returns {Promise}
+	 *          A promize that resolves to [aSource, isBlackBoxed] or rejects to
+	 *          [aSource, error].
+	 */
+	function blackbox(source, shouldBlackBox) {
+	  return (_ref10) => {
+	    var dispatch = _ref10.dispatch;
+	    var client = _ref10.client;
+	
+	    dispatch({
+	      type: constants.BLACKBOX,
+	      source: source,
+	      [PROMISE]: Task.spawn(function* () {
+	        yield shouldBlackBox ? client.blackBox(source.id) : client.unblackBox(source.id);
+	        return {
+	          isBlackBoxed: shouldBlackBox
+	        };
+	      })
+	    });
+	  };
+	}
+	
+	/**
+	 * Toggle the pretty printing of a source's text. All subsequent calls to
+	 * |getText| will return the pretty-toggled text. Nothing will happen for
+	 * non-javascript files.
+	 *
+	 * @memberof actions/sources
+	 * @static
+	 * @param string id The source form from the RDP.
+	 * @returns Promise
+	 *          A promise that resolves to [aSource, prettyText] or rejects to
+	 *          [aSource, error].
+	 */
+	function togglePrettyPrint(sourceId) {
+	  return (_ref11) => {
+	    var dispatch = _ref11.dispatch;
+	    var getState = _ref11.getState;
+	    var client = _ref11.client;
+	
+	    var source = getSource(getState(), sourceId).toJS();
+	    var sourceText = getSourceText(getState(), sourceId).toJS();
+	
+	    if (!isEnabled("prettyPrint") || sourceText.loading || source.isPrettyPrinted) {
+	      return {};
+	    }
+	
+	    var url = source.url + ":formatted";
+	    var id = generatedToOriginalId(source.id, url);
+	    var originalSource = { url, id, isPrettyPrinted: false };
+	    dispatch({
+	      type: constants.ADD_SOURCE,
+	      source: originalSource
+	    });
+	
+	    return dispatch({
+	      type: constants.TOGGLE_PRETTY_PRINT,
+	      source,
+	      originalSource,
+	      [PROMISE]: _asyncToGenerator(function* () {
+	        var _ref13 = yield _prettyPrintSource({ source, sourceText, url });
+	
+	        var code = _ref13.code;
+	        var mappings = _ref13.mappings;
+	
+	        applySourceMap(source.id, url, code, mappings);
+	
+	        var frames = yield updateFrameLocations(getFrames(getState()));
+	        dispatch(selectSource(originalSource.id));
+	
+	        var originalSourceText = {
+	          id: originalSource.id,
+	          contentType: "text/javascript",
+	          code
+	        };
+	
+	        return {
+	          isPrettyPrinted: true,
+	          sourceText: originalSourceText,
+	          frames
+	        };
+	      })()
+	    });
+	  };
+	}
+	
+	/**
+	 * @memberof actions/sources
+	 * @static
+	 */
+	function loadSourceText(source) {
+	  return (_ref14) => {
+	    var dispatch = _ref14.dispatch;
+	    var getState = _ref14.getState;
+	    var client = _ref14.client;
+	
+	    // Fetch the source text only once.
+	    var textInfo = getSourceText(getState(), source.id);
+	    if (textInfo) {
+	      // It's already loaded or is loading
+	      return Promise.resolve(textInfo);
+	    }
+	
+	    return dispatch({
+	      type: constants.LOAD_SOURCE_TEXT,
+	      source: source,
+	      [PROMISE]: _asyncToGenerator(function* () {
+	        if (isOriginalId(source.id)) {
+	          return yield getOriginalSourceText(source);
+	        }
+	
+	        var response = yield client.sourceContents(source.id);
+	        return {
+	          text: response.source,
+	          contentType: response.contentType || "text/javascript"
+	        };
+	
+	        // Automatically pretty print if enabled and the test is
+	        // detected to be "minified"
+	        // if (Prefs.autoPrettyPrint &&
+	        //     !source.isPrettyPrinted &&
+	        //     SourceUtils.isMinified(source.id, response.source)) {
+	        //   dispatch(togglePrettyPrint(source));
+	        // }
+	      })()
+	    });
+	  };
+	}
+	
+	// delay is in ms
+	var FETCH_SOURCE_RESPONSE_DELAY = 200;
+	
+	/**
+	 * Starts fetching all the sources, silently.
+	 *
+	 * @memberof actions/sources
+	 * @static
+	 * @param array actors
+	 *        The urls for the sources to fetch. If fetching a source's text
+	 *        takes too long, it will be discarded.
+	 * @returns {Promise}
+	 *         A promise that is resolved after source texts have been fetched.
+	 */
+	function getTextForSources(actors) {
+	  return (_ref16) => {
+	    var dispatch = _ref16.dispatch;
+	    var getState = _ref16.getState;
+	
+	    var deferred = defer();
+	    var pending = new Set(actors);
+	    var fetched = [];
+	
+	    // Can't use promise.all, because if one fetch operation is rejected, then
+	    // everything is considered rejected, thus no other subsequent source will
+	    // be getting fetched. We don't want that. Something like Q's allSettled
+	    // would work like a charm here.
+	
+	    // Try to fetch as many sources as possible.
+	
+	    var _loop = function (actor) {
+	      var source = getSource(getState(), actor);
+	      dispatch(loadSourceText(source)).then((_ref25) => {
+	        var text = _ref25.text;
+	        var contentType = _ref25.contentType;
+	
+	        onFetch([source, text, contentType]);
+	      }, err => {
+	        onError(source, err);
+	      });
+	    };
+	
+	    for (var actor of actors) {
+	      _loop(actor);
+	    }
+	
+	    setTimeout(onTimeout, FETCH_SOURCE_RESPONSE_DELAY);
+	
+	    /* Called if fetching a source takes too long. */
+	    function onTimeout() {
+	      pending = new Set();
+	      maybeFinish();
+	    }
+	
+	    /* Called if fetching a source finishes successfully. */
+	    function onFetch(_ref17) {
+	      var _ref18 = _slicedToArray(_ref17, 3);
+	
+	      var aSource = _ref18[0];
+	      var aText = _ref18[1];
+	      var aContentType = _ref18[2];
+	
+	      // If fetching the source has previously timed out, discard it this time.
+	      if (!pending.has(aSource.actor)) {
+	        return;
+	      }
+	      pending.delete(aSource.actor);
+	      fetched.push([aSource.actor, aText, aContentType]);
+	      maybeFinish();
+	    }
+	
+	    /* Called if fetching a source failed because of an error. */
+	    function onError(_ref19) {
+	      var _ref20 = _slicedToArray(_ref19, 2);
+	
+	      var aSource = _ref20[0];
+	      var aError = _ref20[1];
+	
+	      pending.delete(aSource.actor);
+	      maybeFinish();
+	    }
+	
+	    /* Called every time something interesting
+	     *  happens while fetching sources.
+	     */
+	    function maybeFinish() {
+	      if (pending.size == 0) {
+	        // Sort the fetched sources alphabetically by their url.
+	        deferred.resolve(fetched.sort((_ref21, _ref22) => {
+	          var _ref24 = _slicedToArray(_ref21, 1);
+	
+	          var aFirst = _ref24[0];
+	
+	          var _ref23 = _slicedToArray(_ref22, 1);
+	
+	          var aSecond = _ref23[0];
+	          return aFirst > aSecond;
+	        }));
+	      }
+	    }
+	
+	    return deferred.promise;
+	  };
 	}
 	
 	module.exports = {
-	  originalToGeneratedId,
-	  generatedToOriginalId,
-	  isGeneratedId,
-	  isOriginalId,
-	
-	  fetchSourceMap,
-	  getGeneratedLocation,
-	  getOriginalLocation,
-	  getOriginalSourceText,
-	  applySourceMap,
-	  clearSourceMaps
-	};
-
-/***/ },
-/* 212 */
+	  newSource,
+	  newSources,
+	  selectSource,
+	  selectSourceURL,
+	  closeTab,
+	  blackbox,
+	  togglePrettyPrint,
+	  loadSourceText,
+	  getTextForSources
+	};
+
+/***/ },
+/* 223 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(186);
+	
+	var endTruncateStr = _require.endTruncateStr;
+	
+	var _require2 = __webpack_require__(224);
+	
+	var basename = _require2.basename;
+	
+	
+	/**
+	 * Trims the query part or reference identifier of a url string, if necessary.
+	 */
+	function trimUrlQuery(url) {
+	  var length = url.length;
+	  var q1 = url.indexOf("?");
+	  var q2 = url.indexOf("&");
+	  var q3 = url.indexOf("#");
+	  var q = Math.min(q1 != -1 ? q1 : length, q2 != -1 ? q2 : length, q3 != -1 ? q3 : length);
+	
+	  return url.slice(0, q);
+	}
+	
+	/**
+	 * Returns true if the specified url and/or content type are specific to
+	 * javascript files.
+	 *
+	 * @return boolean
+	 *         True if the source is likely javascript.
+	 */
+	function isJavaScript(url) {
+	  var contentType = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : "";
+	
+	  return url && /\.(jsm|js)?$/.test(trimUrlQuery(url)) || contentType.includes("javascript");
+	}
+	
+	// TODO: This should use a shared Source type
+	function isPretty(source) {
+	  return source.url ? /formatted$/.test(source.url) : false;
+	}
+	
+	/**
+	 * Show a source url's filename.
+	 * If the source does not have a url, use the source id.
+	 */
+	function getFilename(source) {
+	  var url = source.url;
+	  var id = source.id;
+	
+	  if (!url) {
+	    var sourceId = id.split("/")[1];
+	    return `SOURCE${ sourceId }`;
+	  }
+	
+	  var name = basename(source.url);
+	  return endTruncateStr(name, 50);
+	}
+	
+	module.exports = {
+	  isJavaScript,
+	  isPretty,
+	  getFilename
+	};
+
+/***/ },
+/* 224 */
+/***/ function(module, exports) {
+
+	function basename(path) {
+	  return path.split("/").pop();
+	}
+	
+	function dirname(path) {
+	  var idx = path.lastIndexOf("/");
+	  return path.slice(0, idx);
+	}
+	
+	function isURL(str) {
+	  return str.indexOf("://") !== -1;
+	}
+	
+	function isAbsolute(str) {
+	  return str[0] === "/";
+	}
+	
+	module.exports = {
+	  basename, dirname, isURL, isAbsolute
+	};
+
+/***/ },
+/* 225 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(116);
+	
+	var Frame = _require.Frame;
+	
+	var _require2 = __webpack_require__(215);
+	
+	var getOriginalLocation = _require2.getOriginalLocation;
+	
+	
+	function updateFrameLocations(frames) {
+	  return Promise.all(frames.map(frame => {
+	    return getOriginalLocation(frame.location).then(loc => {
+	      return Frame.update(frame, {
+	        $merge: { location: loc }
+	      });
+	    });
+	  }));
+	}
+	
+	module.exports = {
+	  updateFrameLocations
+	};
+
+/***/ },
+/* 226 */
+/***/ function(module, exports) {
+
+	var sourceDocs = {};
+	
+	function getDocument(key) {
+	  return sourceDocs[key];
+	}
+	
+	function setDocument(key, doc) {
+	  sourceDocs[key] = doc;
+	}
+	
+	function removeDocument(key) {
+	  delete sourceDocs[key];
+	}
+	
+	function clearDocuments() {
+	  sourceDocs = {};
+	}
+	
+	module.exports = {
+	  getDocument,
+	  setDocument,
+	  removeDocument,
+	  clearDocuments
+	};
+
+/***/ },
+/* 227 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/* This Source Code Form is subject to the terms of the Mozilla Public
+	 * License, v. 2.0. If a copy of the MPL was not distributed with this
+	 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+	/* global window */
+	
+	/**
+	 * Redux actions for the pause state
+	 * @module actions/tabs
+	 */
+	
+	var constants = __webpack_require__(193);
+	
+	/**
+	 * @typedef {Object} TabAction
+	 * @memberof actions/tabs
+	 * @static
+	 * @property {number} type The type of Action
+	 * @property {number} value The payload of the Action
+	 */
+	
+	/**
+	 * @memberof actions/tabs
+	 * @static
+	 * @param {Array} tabs
+	 * @returns {TabAction} with type constants.ADD_TABS and tabs as value
+	 */
+	function newTabs(tabs) {
+	  return {
+	    type: constants.ADD_TABS,
+	    value: tabs
+	  };
+	}
+	
+	/**
+	 * @memberof actions/tabs
+	 * @static
+	 * @param {String} $0.id Unique ID of the tab to select
+	 * @returns {TabAction}
+	 */
+	function selectTab(_ref) {
+	  var id = _ref.id;
+	
+	  return {
+	    type: constants.SELECT_TAB,
+	    id: id
+	  };
+	}
+	
+	module.exports = {
+	  newTabs,
+	  selectTab
+	};
+
+/***/ },
+/* 228 */
+/***/ function(module, exports, __webpack_require__) {
+
+	function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
+	
+	var constants = __webpack_require__(193);
+	
+	var _require = __webpack_require__(222);
+	
+	var selectSource = _require.selectSource;
+	
+	var _require2 = __webpack_require__(185);
+	
+	var PROMISE = _require2.PROMISE;
+	
+	var _require3 = __webpack_require__(202);
+	
+	var getExpressions = _require3.getExpressions;
+	
+	var _require4 = __webpack_require__(225);
+	
+	var updateFrameLocations = _require4.updateFrameLocations;
+	
+	/**
+	 * Redux actions for the pause state
+	 * @module actions/pause
+	 */
+	
+	/**
+	 * Debugger has just resumed
+	 *
+	 * @memberof actions/pause
+	 * @static
+	 */
+	
+	function resumed() {
+	  return (_ref) => {
+	    var dispatch = _ref.dispatch;
+	    var client = _ref.client;
+	
+	    return dispatch({
+	      type: constants.RESUME,
+	      value: undefined
+	    });
+	  };
+	}
+	
+	/**
+	 * Debugger has just paused
+	 *
+	 * @param {object} pauseInfo
+	 * @memberof actions/pause
+	 * @static
+	 */
+	function paused(pauseInfo) {
+	  return (() => {
+	    var _ref2 = _asyncToGenerator(function* (_ref3) {
+	      var dispatch = _ref3.dispatch;
+	      var getState = _ref3.getState;
+	      var client = _ref3.client;
+	      var frames = pauseInfo.frames;
+	      var why = pauseInfo.why;
+	
+	      frames = yield updateFrameLocations(frames);
+	      var frame = frames[0];
+	
+	      dispatch(evaluateExpressions());
+	      dispatch({
+	        type: constants.PAUSED,
+	        pauseInfo: { why, frame },
+	        frames: frames,
+	        selectedFrameId: frame.id
+	      });
+	      dispatch(selectSource(frame.location.sourceId, { line: frame.location.line }));
+	    });
+	
+	    return function (_x) {
+	      return _ref2.apply(this, arguments);
+	    };
+	  })();
+	}
+	
+	/**
+	 *
+	 * @memberof actions/pause
+	 * @static
+	 */
+	function pauseOnExceptions(shouldPauseOnExceptions, shouldIgnoreCaughtExceptions) {
+	  return (_ref4) => {
+	    var dispatch = _ref4.dispatch;
+	    var client = _ref4.client;
+	
+	    dispatch({
+	      type: constants.PAUSE_ON_EXCEPTIONS,
+	      shouldPauseOnExceptions,
+	      shouldIgnoreCaughtExceptions,
+	      [PROMISE]: client.pauseOnExceptions(shouldPauseOnExceptions, shouldIgnoreCaughtExceptions)
+	    });
+	  };
+	}
+	
+	/**
+	 * Debugger commands like stepOver, stepIn, stepUp
+	 *
+	 * @param string $0.type
+	 * @memberof actions/pause
+	 * @static
+	 */
+	function command(_ref5) {
+	  var type = _ref5.type;
+	
+	  return (_ref6) => {
+	    var dispatch = _ref6.dispatch;
+	    var client = _ref6.client;
+	
+	    // execute debugger thread command e.g. stepIn, stepOver
+	    client[type]();
+	
+	    return dispatch({
+	      type: constants.COMMAND,
+	      value: undefined
+	    });
+	  };
+	}
+	
+	/**
+	 * StepIn
+	 * @memberof actions/pause
+	 * @static
+	 * @returns {Function} {@link command}
+	 */
+	function stepIn() {
+	  return command({ type: "stepIn" });
+	}
+	
+	/**
+	 * stepOver
+	 * @memberof actions/pause
+	 * @static
+	 * @returns {Function} {@link command}
+	 */
+	function stepOver() {
+	  return command({ type: "stepOver" });
+	}
+	
+	/**
+	 * stepOut
+	 * @memberof actions/pause
+	 * @static
+	 * @returns {Function} {@link command}
+	 */
+	function stepOut() {
+	  return command({ type: "stepOut" });
+	}
+	
+	/**
+	 * resume
+	 * @memberof actions/pause
+	 * @static
+	 * @returns {Function} {@link command}
+	 */
+	function resume() {
+	  return command({ type: "resume" });
+	}
+	
+	/**
+	 * Debugger breakOnNext command.
+	 * It's different from the comand action because we also want to
+	 * highlight the pause icon.
+	 *
+	 * @memberof actions/pause
+	 * @static
+	 */
+	function breakOnNext() {
+	  return (_ref7) => {
+	    var dispatch = _ref7.dispatch;
+	    var client = _ref7.client;
+	
+	    client.breakOnNext();
+	
+	    return dispatch({
+	      type: constants.BREAK_ON_NEXT,
+	      value: true
+	    });
+	  };
+	}
+	
+	/**
+	 * Select a frame
+	 *
+	 * @param frame
+	 * @memberof actions/pause
+	 * @static
+	 */
+	function selectFrame(frame) {
+	  return (_ref8) => {
+	    var dispatch = _ref8.dispatch;
+	
+	    dispatch(selectSource(frame.location.sourceId, { line: frame.location.line }));
+	    dispatch({
+	      type: constants.SELECT_FRAME,
+	      frame
+	    });
+	  };
+	}
+	
+	/**
+	 * Load an object.
+	 *
+	 * @param grip
+	 * TODO: Right now this if Firefox specific and is not implemented
+	 * for Chrome, which is why it takes a grip.
+	 * @memberof actions/pause
+	 * @static
+	 */
+	function loadObjectProperties(grip) {
+	  return (_ref9) => {
+	    var dispatch = _ref9.dispatch;
+	    var client = _ref9.client;
+	
+	    dispatch({
+	      type: constants.LOAD_OBJECT_PROPERTIES,
+	      objectId: grip.actor,
+	      [PROMISE]: client.getProperties(grip)
+	    });
+	  };
+	}
+	
+	/**
+	 * Add expression for debugger to watch
+	 *
+	 * @param {object} expression
+	 * @param {number} expression.id
+	 * @memberof actions/pause
+	 * @static
+	 */
+	function addExpression(expression) {
+	  return (_ref10) => {
+	    var dispatch = _ref10.dispatch;
+	    var getState = _ref10.getState;
+	
+	    var id = expression.id !== undefined ? parseInt(expression.id, 10) : getExpressions(getState()).toSeq().size++;
+	    dispatch({
+	      type: constants.ADD_EXPRESSION,
+	      id: id,
+	      input: expression.input
+	    });
+	    dispatch(evaluateExpressions());
+	  };
+	}
+	
+	/**
+	 *
+	 * @param {object} expression
+	 * @param {number} expression.id
+	 * @memberof actions/pause
+	 * @static
+	 */
+	function updateExpression(expression) {
+	  return (_ref11) => {
+	    var dispatch = _ref11.dispatch;
+	
+	    dispatch({
+	      type: constants.UPDATE_EXPRESSION,
+	      id: expression.id,
+	      input: expression.input
+	    });
+	  };
+	}
+	
+	/**
+	 *
+	 * @param {object} expression
+	 * @param {number} expression.id
+	 * @memberof actions/pause
+	 * @static
+	 */
+	function deleteExpression(expression) {
+	  return (_ref12) => {
+	    var dispatch = _ref12.dispatch;
+	
+	    dispatch({
+	      type: constants.DELETE_EXPRESSION,
+	      id: expression.id
+	    });
+	  };
+	}
+	
+	/**
+	 *
+	 * @memberof actions/pause
+	 * @static
+	 */
+	function evaluateExpressions() {
+	  return (_ref13) => {
+	    var dispatch = _ref13.dispatch;
+	    var getState = _ref13.getState;
+	    var client = _ref13.client;
+	
+	    for (var expression of getExpressions(getState())) {
+	      dispatch({
+	        type: constants.EVALUATE_EXPRESSION,
+	        id: expression.id,
+	        input: expression.input,
+	        [PROMISE]: client.evaluate(expression.input)
+	      });
+	    }
+	  };
+	}
+	
+	module.exports = {
+	  addExpression,
+	  updateExpression,
+	  deleteExpression,
+	  resumed,
+	  paused,
+	  pauseOnExceptions,
+	  command,
+	  stepIn,
+	  stepOut,
+	  stepOver,
+	  resume,
+	  breakOnNext,
+	  selectFrame,
+	  loadObjectProperties
+	};
+
+/***/ },
+/* 229 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var constants = __webpack_require__(193);
+	
+	var _require = __webpack_require__(215);
+	
+	var clearSourceMaps = _require.clearSourceMaps;
+	
+	var _require2 = __webpack_require__(226);
+	
+	var clearDocuments = _require2.clearDocuments;
+	
+	/**
+	 * Redux actions for the navigation state
+	 * @module actions/navigation
+	 */
+	
+	/**
+	 * @memberof actions/navigation
+	 * @static
+	 */
+	
+	function willNavigate() {
+	  clearSourceMaps();
+	  clearDocuments();
+	
+	  return { type: constants.NAVIGATE };
+	}
+	
+	/**
+	 * @memberof actions/navigation
+	 * @static
+	 */
+	function navigated() {
+	  return (_ref) => {
+	    // We need to load all the sources again because they might have
+	    // come from bfcache, so we won't get a `newSource` notification.
+	    //
+	    // TODO: This seems to be buggy on the debugger server side. When
+	    // the page is loaded from bfcache, we still get sources from the
+	    // *previous* page as well. For now, emulate the current debugger
+	    // behavior by not showing sources loaded by bfcache.
+	    // return dispatch(sources.loadSources());
+	
+	    var dispatch = _ref.dispatch;
+	  };
+	}
+	
+	module.exports = {
+	  willNavigate,
+	  navigated
+	};
+
+/***/ },
+/* 230 */
 /***/ function(module, exports, __webpack_require__) {
 
 	// 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,
@@ -28569,17 +30323,17 @@ var Debugger =
 	// 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 punycode = __webpack_require__(213);
+	var punycode = __webpack_require__(231);
 	
 	exports.parse = urlParse;
 	exports.resolve = urlResolve;
 	exports.resolveObject = urlResolveObject;
 	exports.format = urlFormat;
 	
 	exports.Url = Url;
 	
@@ -28641,17 +30395,17 @@ var Debugger =
 	      'gopher': true,
 	      'file': true,
 	      'http:': true,
 	      'https:': true,
 	      'ftp:': true,
 	      'gopher:': true,
 	      'file:': true
 	    },
-	    querystring = __webpack_require__(214);
+	    querystring = __webpack_require__(232);
 	
 	function urlParse(url, parseQueryString, slashesDenoteHost) {
 	  if (url && isObject(url) && url instanceof Url) return url;
 	
 	  var u = new Url;
 	  u.parse(url, parseQueryString, slashesDenoteHost);
 	  return u;
 	}
@@ -29258,17 +31012,17 @@ var Debugger =
 	  return arg === null;
 	}
 	function isNullOrUndefined(arg) {
 	  return  arg == null;
 	}
 
 
 /***/ },
-/* 213 */
+/* 231 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var __WEBPACK_AMD_DEFINE_RESULT__;/* WEBPACK VAR INJECTION */(function(module, global) {/*! https://mths.be/punycode v1.3.2 by @mathias */
 	;(function(root) {
 	
 		/** Detect free variables */
 		var freeExports = typeof exports == 'object' && exports &&
 			!exports.nodeType && exports;
@@ -29790,30 +31544,30 @@ var Debugger =
 				}
 			}
 		} else { // in Rhino or a web browser
 			root.punycode = punycode;
 		}
 	
 	}(this));
 	
-	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(101)(module), (function() { return this; }())))
-
-/***/ },
-/* 214 */
+	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(103)(module), (function() { return this; }())))
+
+/***/ },
+/* 232 */
 /***/ function(module, exports, __webpack_require__) {
 
 	'use strict';
 	
-	exports.decode = exports.parse = __webpack_require__(215);
-	exports.encode = exports.stringify = __webpack_require__(216);
-
-
-/***/ },
-/* 215 */
+	exports.decode = exports.parse = __webpack_require__(233);
+	exports.encode = exports.stringify = __webpack_require__(234);
+
+
+/***/ },
+/* 233 */
 /***/ function(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,
@@ -29889,17 +31643,17 @@ var Debugger =
 	    }
 	  }
 	
 	  return obj;
 	};
 
 
 /***/ },
-/* 216 */
+/* 234 */
 /***/ function(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,
@@ -29959,4572 +31713,27 @@ var Debugger =
 	
 	  if (!name) return '';
 	  return encodeURIComponent(stringifyPrimitive(name)) + eq +
 	         encodeURIComponent(stringifyPrimitive(obj));
 	};
 
 
 /***/ },
-/* 217 */
-/***/ function(module, exports, __webpack_require__) {
-
-	(function(){
-	  var crypt = __webpack_require__(218),
-	      utf8 = __webpack_require__(219).utf8,
-	      isBuffer = __webpack_require__(220),
-	      bin = __webpack_require__(219).bin,
-	
-	  // The core
-	  md5 = function (message, options) {
-	    // Convert to byte array
-	    if (message.constructor == String)
-	      if (options && options.encoding === 'binary')
-	        message = bin.stringToBytes(message);
-	      else
-	        message = utf8.stringToBytes(message);
-	    else if (isBuffer(message))
-	      message = Array.prototype.slice.call(message, 0);
-	    else if (!Array.isArray(message))
-	      message = message.toString();
-	    // else, assume byte array already
-	
-	    var m = crypt.bytesToWords(message),
-	        l = message.length * 8,
-	        a =  1732584193,
-	        b = -271733879,
-	        c = -1732584194,
-	        d =  271733878;
-	
-	    // Swap endian
-	    for (var i = 0; i < m.length; i++) {
-	      m[i] = ((m[i] <<  8) | (m[i] >>> 24)) & 0x00FF00FF |
-	             ((m[i] << 24) | (m[i] >>>  8)) & 0xFF00FF00;
-	    }
-	
-	    // Padding
-	    m[l >>> 5] |= 0x80 << (l % 32);
-	    m[(((l + 64) >>> 9) << 4) + 14] = l;
-	
-	    // Method shortcuts
-	    var FF = md5._ff,
-	        GG = md5._gg,
-	        HH = md5._hh,
-	        II = md5._ii;
-	
-	    for (var i = 0; i < m.length; i += 16) {
-	
-	      var aa = a,
-	          bb = b,
-	          cc = c,
-	          dd = d;
-	
-	      a = FF(a, b, c, d, m[i+ 0],  7, -680876936);
-	      d = FF(d, a, b, c, m[i+ 1], 12, -389564586);
-	      c = FF(c, d, a, b, m[i+ 2], 17,  606105819);
-	      b = FF(b, c, d, a, m[i+ 3], 22, -1044525330);
-	      a = FF(a, b, c, d, m[i+ 4],  7, -176418897);
-	      d = FF(d, a, b, c, m[i+ 5], 12,  1200080426);
-	      c = FF(c, d, a, b, m[i+ 6], 17, -1473231341);
-	      b = FF(b, c, d, a, m[i+ 7], 22, -45705983);
-	      a = FF(a, b, c, d, m[i+ 8],  7,  1770035416);
-	      d = FF(d, a, b, c, m[i+ 9], 12, -1958414417);
-	      c = FF(c, d, a, b, m[i+10], 17, -42063);
-	      b = FF(b, c, d, a, m[i+11], 22, -1990404162);
-	      a = FF(a, b, c, d, m[i+12],  7,  1804603682);
-	      d = FF(d, a, b, c, m[i+13], 12, -40341101);
-	      c = FF(c, d, a, b, m[i+14], 17, -1502002290);
-	      b = FF(b, c, d, a, m[i+15], 22,  1236535329);
-	
-	      a = GG(a, b, c, d, m[i+ 1],  5, -165796510);
-	      d = GG(d, a, b, c, m[i+ 6],  9, -1069501632);
-	      c = GG(c, d, a, b, m[i+11], 14,  643717713);
-	      b = GG(b, c, d, a, m[i+ 0], 20, -373897302);
-	      a = GG(a, b, c, d, m[i+ 5],  5, -701558691);
-	      d = GG(d, a, b, c, m[i+10],  9,  38016083);
-	      c = GG(c, d, a, b, m[i+15], 14, -660478335);
-	      b = GG(b, c, d, a, m[i+ 4], 20, -405537848);
-	      a = GG(a, b, c, d, m[i+ 9],  5,  568446438);
-	      d = GG(d, a, b, c, m[i+14],  9, -1019803690);
-	      c = GG(c, d, a, b, m[i+ 3], 14, -187363961);
-	      b = GG(b, c, d, a, m[i+ 8], 20,  1163531501);
-	      a = GG(a, b, c, d, m[i+13],  5, -1444681467);
-	      d = GG(d, a, b, c, m[i+ 2],  9, -51403784);
-	      c = GG(c, d, a, b, m[i+ 7], 14,  1735328473);
-	      b = GG(b, c, d, a, m[i+12], 20, -1926607734);
-	
-	      a = HH(a, b, c, d, m[i+ 5],  4, -378558);
-	      d = HH(d, a, b, c, m[i+ 8], 11, -2022574463);
-	      c = HH(c, d, a, b, m[i+11], 16,  1839030562);
-	      b = HH(b, c, d, a, m[i+14], 23, -35309556);
-	      a = HH(a, b, c, d, m[i+ 1],  4, -1530992060);
-	      d = HH(d, a, b, c, m[i+ 4], 11,  1272893353);
-	      c = HH(c, d, a, b, m[i+ 7], 16, -155497632);
-	      b = HH(b, c, d, a, m[i+10], 23, -1094730640);
-	      a = HH(a, b, c, d, m[i+13],  4,  681279174);
-	      d = HH(d, a, b, c, m[i+ 0], 11, -358537222);
-	      c = HH(c, d, a, b, m[i+ 3], 16, -722521979);
-	      b = HH(b, c, d, a, m[i+ 6], 23,  76029189);
-	      a = HH(a, b, c, d, m[i+ 9],  4, -640364487);
-	      d = HH(d, a, b, c, m[i+12], 11, -421815835);
-	      c = HH(c, d, a, b, m[i+15], 16,  530742520);
-	      b = HH(b, c, d, a, m[i+ 2], 23, -995338651);
-	
-	      a = II(a, b, c, d, m[i+ 0],  6, -198630844);
-	      d = II(d, a, b, c, m[i+ 7], 10,  1126891415);
-	      c = II(c, d, a, b, m[i+14], 15, -1416354905);
-	      b = II(b, c, d, a, m[i+ 5], 21, -57434055);
-	      a = II(a, b, c, d, m[i+12],  6,  1700485571);
-	      d = II(d, a, b, c, m[i+ 3], 10, -1894986606);
-	      c = II(c, d, a, b, m[i+10], 15, -1051523);
-	      b = II(b, c, d, a, m[i+ 1], 21, -2054922799);
-	      a = II(a, b, c, d, m[i+ 8],  6,  1873313359);
-	      d = II(d, a, b, c, m[i+15], 10, -30611744);
-	      c = II(c, d, a, b, m[i+ 6], 15, -1560198380);
-	      b = II(b, c, d, a, m[i+13], 21,  1309151649);
-	      a = II(a, b, c, d, m[i+ 4],  6, -145523070);
-	      d = II(d, a, b, c, m[i+11], 10, -1120210379);
-	      c = II(c, d, a, b, m[i+ 2], 15,  718787259);
-	      b = II(b, c, d, a, m[i+ 9], 21, -343485551);
-	
-	      a = (a + aa) >>> 0;
-	      b = (b + bb) >>> 0;
-	      c = (c + cc) >>> 0;
-	      d = (d + dd) >>> 0;
-	    }
-	
-	    return crypt.endian([a, b, c, d]);
-	  };
-	
-	  // Auxiliary functions
-	  md5._ff  = function (a, b, c, d, x, s, t) {
-	    var n = a + (b & c | ~b & d) + (x >>> 0) + t;
-	    return ((n << s) | (n >>> (32 - s))) + b;
-	  };
-	  md5._gg  = function (a, b, c, d, x, s, t) {
-	    var n = a + (b & d | c & ~d) + (x >>> 0) + t;
-	    return ((n << s) | (n >>> (32 - s))) + b;
-	  };
-	  md5._hh  = function (a, b, c, d, x, s, t) {
-	    var n = a + (b ^ c ^ d) + (x >>> 0) + t;
-	    return ((n << s) | (n >>> (32 - s))) + b;
-	  };
-	  md5._ii  = function (a, b, c, d, x, s, t) {
-	    var n = a + (c ^ (b | ~d)) + (x >>> 0) + t;
-	    return ((n << s) | (n >>> (32 - s))) + b;
-	  };
-	
-	  // Package private blocksize
-	  md5._blocksize = 16;
-	  md5._digestsize = 16;
-	
-	  module.exports = function (message, options) {
-	    if (message === undefined || message === null)
-	      throw new Error('Illegal argument ' + message);
-	
-	    var digestbytes = crypt.wordsToBytes(md5(message, options));
-	    return options && options.asBytes ? digestbytes :
-	        options && options.asString ? bin.bytesToString(digestbytes) :
-	        crypt.bytesToHex(digestbytes);
-	  };
-	
-	})();
-
-
-/***/ },
-/* 218 */
-/***/ function(module, exports) {
-
-	(function() {
-	  var base64map
-	      = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',
-	
-	  crypt = {
-	    // Bit-wise rotation left
-	    rotl: function(n, b) {
-	      return (n << b) | (n >>> (32 - b));
-	    },
-	
-	    // Bit-wise rotation right
-	    rotr: function(n, b) {
-	      return (n << (32 - b)) | (n >>> b);
-	    },
-	
-	    // Swap big-endian to little-endian and vice versa
-	    endian: function(n) {
-	      // If number given, swap endian
-	      if (n.constructor == Number) {
-	        return crypt.rotl(n, 8) & 0x00FF00FF | crypt.rotl(n, 24) & 0xFF00FF00;
-	      }
-	
-	      // Else, assume array and swap all items
-	      for (var i = 0; i < n.length; i++)
-	        n[i] = crypt.endian(n[i]);
-	      return n;
-	    },
-	
-	    // Generate an array of any length of random bytes
-	    randomBytes: function(n) {
-	      for (var bytes = []; n > 0; n--)
-	        bytes.push(Math.floor(Math.random() * 256));
-	      return bytes;
-	    },
-	
-	    // Convert a byte array to big-endian 32-bit words
-	    bytesToWords: function(bytes) {
-	      for (var words = [], i = 0, b = 0; i < bytes.length; i++, b += 8)
-	        words[b >>> 5] |= bytes[i] << (24 - b % 32);
-	      return words;
-	    },
-	
-	    // Convert big-endian 32-bit words to a byte array
-	    wordsToBytes: function(words) {
-	      for (var bytes = [], b = 0; b < words.length * 32; b += 8)
-	        bytes.push((words[b >>> 5] >>> (24 - b % 32)) & 0xFF);
-	      return bytes;
-	    },
-	
-	    // Convert a byte array to a hex string
-	    bytesToHex: function(bytes) {
-	      for (var hex = [], i = 0; i < bytes.length; i++) {
-	        hex.push((bytes[i] >>> 4).toString(16));
-	        hex.push((bytes[i] & 0xF).toString(16));
-	      }
-	      return hex.join('');
-	    },
-	
-	    // Convert a hex string to a byte array
-	    hexToBytes: function(hex) {
-	      for (var bytes = [], c = 0; c < hex.length; c += 2)
-	        bytes.push(parseInt(hex.substr(c, 2), 16));
-	      return bytes;
-	    },
-	
-	    // Convert a byte array to a base-64 string
-	    bytesToBase64: function(bytes) {
-	      for (var base64 = [], i = 0; i < bytes.length; i += 3) {
-	        var triplet = (bytes[i] << 16) | (bytes[i + 1] << 8) | bytes[i + 2];
-	        for (var j = 0; j < 4; j++)
-	          if (i * 8 + j * 6 <= bytes.length * 8)
-	            base64.push(base64map.charAt((triplet >>> 6 * (3 - j)) & 0x3F));
-	          else
-	            base64.push('=');
-	      }
-	      return base64.join('');
-	    },
-	
-	    // Convert a base-64 string to a byte array
-	    base64ToBytes: function(base64) {
-	      // Remove non-base-64 characters
-	      base64 = base64.replace(/[^A-Z0-9+\/]/ig, '');
-	
-	      for (var bytes = [], i = 0, imod4 = 0; i < base64.length;
-	          imod4 = ++i % 4) {
-	        if (imod4 == 0) continue;
-	        bytes.push(((base64map.indexOf(base64.charAt(i - 1))
-	            & (Math.pow(2, -2 * imod4 + 8) - 1)) << (imod4 * 2))
-	            | (base64map.indexOf(base64.charAt(i)) >>> (6 - imod4 * 2)));
-	      }
-	      return bytes;
-	    }
-	  };
-	
-	  module.exports = crypt;
-	})();
-
-
-/***/ },
-/* 219 */
-/***/ function(module, exports) {
-
-	var charenc = {
-	  // UTF-8 encoding
-	  utf8: {
-	    // Convert a string to a byte array
-	    stringToBytes: function(str) {
-	      return charenc.bin.stringToBytes(unescape(encodeURIComponent(str)));
-	    },
-	
-	    // Convert a byte array to a string
-	    bytesToString: function(bytes) {
-	      return decodeURIComponent(escape(charenc.bin.bytesToString(bytes)));
-	    }
-	  },
-	
-	  // Binary encoding
-	  bin: {
-	    // Convert a string to a byte array
-	    stringToBytes: function(str) {
-	      for (var bytes = [], i = 0; i < str.length; i++)
-	        bytes.push(str.charCodeAt(i) & 0xFF);
-	      return bytes;
-	    },
-	
-	    // Convert a byte array to a string
-	    bytesToString: function(bytes) {
-	      for (var str = [], i = 0; i < bytes.length; i++)
-	        str.push(String.fromCharCode(bytes[i]));
-	      return str.join('');
-	    }
-	  }
-	};
-	
-	module.exports = charenc;
-
-
-/***/ },
-/* 220 */
-/***/ function(module, exports) {
-
-	/**
-	 * Determine if an object is Buffer
-	 *
-	 * Author:   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>
-	 * License:  MIT
-	 *
-	 * `npm install is-buffer`
-	 */
-	
-	module.exports = function (obj) {
-	  return !!(obj != null &&
-	    (obj._isBuffer || // For Safari 5-7 (missing Object.prototype.constructor)
-	      (obj.constructor &&
-	      typeof obj.constructor.isBuffer === 'function' &&
-	      obj.constructor.isBuffer(obj))
-	    ))
-	}
-
-
-/***/ },
-/* 221 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/*
-	 * Copyright 2009-2011 Mozilla Foundation and contributors
-	 * Licensed under the New BSD license. See LICENSE.txt or:
-	 * http://opensource.org/licenses/BSD-3-Clause
-	 */
-	exports.SourceMapGenerator = __webpack_require__(222).SourceMapGenerator;
-	exports.SourceMapConsumer = __webpack_require__(228).SourceMapConsumer;
-	exports.SourceNode = __webpack_require__(231).SourceNode;
-
-
-/***/ },
-/* 222 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* -*- Mode: js; js-indent-level: 2; -*- */
-	/*
-	 * Copyright 2011 Mozilla Foundation and contributors
-	 * Licensed under the New BSD license. See LICENSE or:
-	 * http://opensource.org/licenses/BSD-3-Clause
-	 */
-	
-	var base64VLQ = __webpack_require__(223);
-	var util = __webpack_require__(225);
-	var ArraySet = __webpack_require__(226).ArraySet;
-	var MappingList = __webpack_require__(227).MappingList;
-	
-	/**
-	 * An instance of the SourceMapGenerator represents a source map which is
-	 * being built incrementally. You may pass an object with the following
-	 * properties:
-	 *
-	 *   - file: The filename of the generated source.
-	 *   - sourceRoot: A root for all relative URLs in this source map.
-	 */
-	function SourceMapGenerator(aArgs) {
-	  if (!aArgs) {
-	    aArgs = {};
-	  }
-	  this._file = util.getArg(aArgs, 'file', null);
-	  this._sourceRoot = util.getArg(aArgs, 'sourceRoot', null);
-	  this._skipValidation = util.getArg(aArgs, 'skipValidation', false);
-	  this._sources = new ArraySet();
-	  this._names = new ArraySet();
-	  this._mappings = new MappingList();
-	  this._sourcesContents = null;
-	}
-	
-	SourceMapGenerator.prototype._version = 3;
-	
-	/**
-	 * Creates a new SourceMapGenerator based on a SourceMapConsumer
-	 *
-	 * @param aSourceMapConsumer The SourceMap.
-	 */
-	SourceMapGenerator.fromSourceMap =
-	  function SourceMapGenerator_fromSourceMap(aSourceMapConsumer) {
-	    var sourceRoot = aSourceMapConsumer.sourceRoot;
-	    var generator = new SourceMapGenerator({
-	      file: aSourceMapConsumer.file,
-	      sourceRoot: sourceRoot
-	    });
-	    aSourceMapConsumer.eachMapping(function (mapping) {
-	      var newMapping = {
-	        generated: {
-	          line: mapping.generatedLine,
-	          column: mapping.generatedColumn
-	        }
-	      };
-	
-	      if (mapping.source != null) {
-	        newMapping.source = mapping.source;
-	        if (sourceRoot != null) {
-	          newMapping.source = util.relative(sourceRoot, newMapping.source);
-	        }
-	
-	        newMapping.original = {
-	          line: mapping.originalLine,
-	          column: mapping.originalColumn
-	        };
-	
-	        if (mapping.name != null) {
-	          newMapping.name = mapping.name;
-	        }
-	      }
-	
-	      generator.addMapping(newMapping);
-	    });
-	    aSourceMapConsumer.sources.forEach(function (sourceFile) {
-	      var content = aSourceMapConsumer.sourceContentFor(sourceFile);
-	      if (content != null) {
-	        generator.setSourceContent(sourceFile, content);
-	      }
-	    });
-	    return generator;
-	  };
-	
-	/**
-	 * Add a single mapping from original source line and column to the generated
-	 * source's line and column for this source map being created. The mapping
-	 * object should have the following properties:
-	 *
-	 *   - generated: An object with the generated line and column positions.
-	 *   - original: An object with the original line and column positions.
-	 *   - source: The original source file (relative to the sourceRoot).
-	 *   - name: An optional original token name for this mapping.
-	 */
-	SourceMapGenerator.prototype.addMapping =
-	  function SourceMapGenerator_addMapping(aArgs) {
-	    var generated = util.getArg(aArgs, 'generated');
-	    var original = util.getArg(aArgs, 'original', null);
-	    var source = util.getArg(aArgs, 'source', null);
-	    var name = util.getArg(aArgs, 'name', null);
-	
-	    if (!this._skipValidation) {
-	      this._validateMapping(generated, original, source, name);
-	    }
-	
-	    if (source != null) {
-	      source = String(source);
-	      if (!this._sources.has(source)) {
-	        this._sources.add(source);
-	      }
-	    }
-	
-	    if (name != null) {
-	      name = String(name);
-	      if (!this._names.has(name)) {
-	        this._names.add(name);
-	      }
-	    }
-	
-	    this._mappings.add({
-	      generatedLine: generated.line,
-	      generatedColumn: generated.column,
-	      originalLine: original != null && original.line,
-	      originalColumn: original != null && original.column,
-	      source: source,
-	      name: name
-	    });
-	  };
-	
-	/**
-	 * Set the source content for a source file.
-	 */
-	SourceMapGenerator.prototype.setSourceContent =
-	  function SourceMapGenerator_setSourceContent(aSourceFile, aSourceContent) {
-	    var source = aSourceFile;
-	    if (this._sourceRoot != null) {
-	      source = util.relative(this._sourceRoot, source);
-	    }
-	
-	    if (aSourceContent != null) {
-	      // Add the source content to the _sourcesContents map.
-	      // Create a new _sourcesContents map if the property is null.
-	      if (!this._sourcesContents) {
-	        this._sourcesContents = Object.create(null);
-	      }
-	      this._sourcesContents[util.toSetString(source)] = aSourceContent;
-	    } else if (this._sourcesContents) {
-	      // Remove the source file from the _sourcesContents map.
-	      // If the _sourcesContents map is empty, set the property to null.
-	      delete this._sourcesContents[util.toSetString(source)];
-	      if (Object.keys(this._sourcesContents).length === 0) {
-	        this._sourcesContents = null;
-	      }
-	    }
-	  };
-	
-	/**
-	 * Applies the mappings of a sub-source-map for a specific source file to the
-	 * source map being generated. Each mapping to the supplied source file is
-	 * rewritten using the supplied source map. Note: The resolution for the
-	 * resulting mappings is the minimium of this map and the supplied map.
-	 *
-	 * @param aSourceMapConsumer The source map to be applied.
-	 * @param aSourceFile Optional. The filename of the source file.
-	 *        If omitted, SourceMapConsumer's file property will be used.
-	 * @param aSourceMapPath Optional. The dirname of the path to the source map
-	 *        to be applied. If relative, it is relative to the SourceMapConsumer.
-	 *        This parameter is needed when the two source maps aren't in the same
-	 *        directory, and the source map to be applied contains relative source
-	 *        paths. If so, those relative source paths need to be rewritten
-	 *        relative to the SourceMapGenerator.
-	 */
-	SourceMapGenerator.prototype.applySourceMap =
-	  function SourceMapGenerator_applySourceMap(aSourceMapConsumer, aSourceFile, aSourceMapPath) {
-	    var sourceFile = aSourceFile;
-	    // If aSourceFile is omitted, we will use the file property of the SourceMap
-	    if (aSourceFile == null) {
-	      if (aSourceMapConsumer.file == null) {
-	        throw new Error(
-	          'SourceMapGenerator.prototype.applySourceMap requires either an explicit source file, ' +
-	          'or the source map\'s "file" property. Both were omitted.'
-	        );
-	      }
-	      sourceFile = aSourceMapConsumer.file;
-	    }
-	    var sourceRoot = this._sourceRoot;
-	    // Make "sourceFile" relative if an absolute Url is passed.
-	    if (sourceRoot != null) {
-	      sourceFile = util.relative(sourceRoot, sourceFile);
-	    }
-	    // Applying the SourceMap can add and remove items from the sources and
-	    // the names array.
-	    var newSources = new ArraySet();
-	    var newNames = new ArraySet();
-	
-	    // Find mappings for the "sourceFile"
-	    this._mappings.unsortedForEach(function (mapping) {
-	      if (mapping.source === sourceFile && mapping.originalLine != null) {
-	        // Check if it can be mapped by the source map, then update the mapping.
-	        var original = aSourceMapConsumer.originalPositionFor({
-	          line: mapping.originalLine,
-	          column: mapping.originalColumn
-	        });
-	        if (original.source != null) {
-	          // Copy mapping
-	          mapping.source = original.source;
-	          if (aSourceMapPath != null) {
-	            mapping.source = util.join(aSourceMapPath, mapping.source)
-	          }
-	          if (sourceRoot != null) {
-	            mapping.source = util.relative(sourceRoot, mapping.source);
-	          }
-	          mapping.originalLine = original.line;
-	          mapping.originalColumn = original.column;
-	          if (original.name != null) {
-	            mapping.name = original.name;
-	          }
-	        }
-	      }
-	
-	      var source = mapping.source;
-	      if (source != null && !newSources.has(source)) {
-	        newSources.add(source);
-	      }
-	
-	      var name = mapping.name;
-	      if (name != null && !newNames.has(name)) {
-	        newNames.add(name);
-	      }
-	
-	    }, this);
-	    this._sources = newSources;
-	    this._names = newNames;
-	
-	    // Copy sourcesContents of applied map.
-	    aSourceMapConsumer.sources.forEach(function (sourceFile) {
-	      var content = aSourceMapConsumer.sourceContentFor(sourceFile);
-	      if (content != null) {
-	        if (aSourceMapPath != null) {
-	          sourceFile = util.join(aSourceMapPath, sourceFile);
-	        }
-	        if (sourceRoot != null) {
-	          sourceFile = util.relative(sourceRoot, sourceFile);
-	        }
-	        this.setSourceContent(sourceFile, content);
-	      }
-	    }, this);
-	  };
-	
-	/**
-	 * A mapping can have one of the three levels of data:
-	 *
-	 *   1. Just the generated position.
-	 *   2. The Generated position, original position, and original source.
-	 *   3. Generated and original position, original source, as well as a name
-	 *      token.
-	 *
-	 * To maintain consistency, we validate that any new mapping being added falls
-	 * in to one of these categories.
-	 */
-	SourceMapGenerator.prototype._validateMapping =
-	  function SourceMapGenerator_validateMapping(aGenerated, aOriginal, aSource,
-	                                              aName) {
-	    if (aGenerated && 'line' in aGenerated && 'column' in aGenerated
-	        && aGenerated.line > 0 && aGenerated.column >= 0
-	        && !aOriginal && !aSource && !aName) {
-	      // Case 1.
-	      return;
-	    }
-	    else if (aGenerated && 'line' in aGenerated && 'column' in aGenerated
-	             && aOriginal && 'line' in aOriginal && 'column' in aOriginal
-	             && aGenerated.line > 0 && aGenerated.column >= 0
-	             && aOriginal.line > 0 && aOriginal.column >= 0
-	             && aSource) {
-	      // Cases 2 and 3.
-	      return;
-	    }
-	    else {
-	      throw new Error('Invalid mapping: ' + JSON.stringify({
-	        generated: aGenerated,
-	        source: aSource,
-	        original: aOriginal,
-	        name: aName
-	      }));
-	    }
-	  };
-	
-	/**
-	 * Serialize the accumulated mappings in to the stream of base 64 VLQs
-	 * specified by the source map format.
-	 */
-	SourceMapGenerator.prototype._serializeMappings =
-	  function SourceMapGenerator_serializeMappings() {
-	    var previousGeneratedColumn = 0;
-	    var previousGeneratedLine = 1;
-	    var previousOriginalColumn = 0;
-	    var previousOriginalLine = 0;
-	    var previousName = 0;
-	    var previousSource = 0;
-	    var result = '';
-	    var next;
-	    var mapping;
-	    var nameIdx;
-	    var sourceIdx;
-	
-	    var mappings = this._mappings.toArray();
-	    for (var i = 0, len = mappings.length; i < len; i++) {
-	      mapping = mappings[i];
-	      next = ''
-	
-	      if (mapping.generatedLine !== previousGeneratedLine) {
-	        previousGeneratedColumn = 0;
-	        while (mapping.generatedLine !== previousGeneratedLine) {
-	          next += ';';
-	          previousGeneratedLine++;
-	        }
-	      }
-	      else {
-	        if (i > 0) {
-	          if (!util.compareByGeneratedPositionsInflated(mapping, mappings[i - 1])) {
-	            continue;
-	          }
-	          next += ',';
-	        }
-	      }
-	
-	      next += base64VLQ.encode(mapping.generatedColumn
-	                                 - previousGeneratedColumn);
-	      previousGeneratedColumn = mapping.generatedColumn;
-	
-	      if (mapping.source != null) {
-	        sourceIdx = this._sources.indexOf(mapping.source);
-	        next += base64VLQ.encode(sourceIdx - previousSource);
-	        previousSource = sourceIdx;
-	
-	        // lines are stored 0-based in SourceMap spec version 3
-	        next += base64VLQ.encode(mapping.originalLine - 1
-	                                   - previousOriginalLine);
-	        previousOriginalLine = mapping.originalLine - 1;
-	
-	        next += base64VLQ.encode(mapping.originalColumn
-	                                   - previousOriginalColumn);
-	        previousOriginalColumn = mapping.originalColumn;
-	
-	        if (mapping.name != null) {
-	          nameIdx = this._names.indexOf(mapping.name);
-	          next += base64VLQ.encode(nameIdx - previousName);
-	          previousName = nameIdx;
-	        }
-	      }
-	
-	      result += next;
-	    }
-	
-	    return result;
-	  };
-	
-	SourceMapGenerator.prototype._generateSourcesContent =
-	  function SourceMapGenerator_generateSourcesContent(aSources, aSourceRoot) {
-	    return aSources.map(function (source) {
-	      if (!this._sourcesContents) {
-	        return null;
-	      }
-	      if (aSourceRoot != null) {
-	        source = util.relative(aSourceRoot, source);
-	      }
-	      var key = util.toSetString(source);
-	      return Object.prototype.hasOwnProperty.call(this._sourcesContents, key)
-	        ? this._sourcesContents[key]
-	        : null;
-	    }, this);
-	  };
-	
-	/**
-	 * Externalize the source map.
-	 */
-	SourceMapGenerator.prototype.toJSON =
-	  function SourceMapGenerator_toJSON() {
-	    var map = {
-	      version: this._version,
-	      sources: this._sources.toArray(),
-	      names: this._names.toArray(),
-	      mappings: this._serializeMappings()
-	    };
-	    if (this._file != null) {
-	      map.file = this._file;
-	    }
-	    if (this._sourceRoot != null) {
-	      map.sourceRoot = this._sourceRoot;
-	    }
-	    if (this._sourcesContents) {
-	      map.sourcesContent = this._generateSourcesContent(map.sources, map.sourceRoot);
-	    }
-	
-	    return map;
-	  };
-	
-	/**
-	 * Render the source map being generated to a string.
-	 */
-	SourceMapGenerator.prototype.toString =
-	  function SourceMapGenerator_toString() {
-	    return JSON.stringify(this.toJSON());
-	  };
-	
-	exports.SourceMapGenerator = SourceMapGenerator;
-
-
-/***/ },
-/* 223 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* -*- Mode: js; js-indent-level: 2; -*- */
-	/*
-	 * Copyright 2011 Mozilla Foundation and contributors
-	 * Licensed under the New BSD license. See LICENSE or:
-	 * http://opensource.org/licenses/BSD-3-Clause
-	 *
-	 * Based on the Base 64 VLQ implementation in Closure Compiler:
-	 * https://code.google.com/p/closure-compiler/source/browse/trunk/src/com/google/debugging/sourcemap/Base64VLQ.java
-	 *
-	 * Copyright 2011 The Closure Compiler Authors. All rights reserved.
-	 * Redistribution and use 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 Google Inc. 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.
-	 */
-	
-	var base64 = __webpack_require__(224);
-	
-	// A single base 64 digit can contain 6 bits of data. For the base 64 variable
-	// length quantities we use in the source map spec, the first bit is the sign,
-	// the next four bits are the actual value, and the 6th bit is the
-	// continuation bit. The continuation bit tells us whether there are more
-	// digits in this value following this digit.
-	//
-	//   Continuation
-	//   |    Sign
-	//   |    |
-	//   V    V
-	//   101011
-	
-	var VLQ_BASE_SHIFT = 5;
-	
-	// binary: 100000
-	var VLQ_BASE = 1 << VLQ_BASE_SHIFT;
-	
-	// binary: 011111
-	var VLQ_BASE_MASK = VLQ_BASE - 1;
-	
-	// binary: 100000
-	var VLQ_CONTINUATION_BIT = VLQ_BASE;
-	
-	/**
-	 * Converts from a two-complement value to a value where the sign bit is
-	 * placed in the least significant bit.  For example, as decimals:
-	 *   1 becomes 2 (10 binary), -1 becomes 3 (11 binary)
-	 *   2 becomes 4 (100 binary), -2 becomes 5 (101 binary)
-	 */
-	function toVLQSigned(aValue) {
-	  return aValue < 0
-	    ? ((-aValue) << 1) + 1
-	    : (aValue << 1) + 0;
-	}
-	
-	/**
-	 * Converts to a two-complement value from a value where the sign bit is
-	 * placed in the least significant bit.  For example, as decimals:
-	 *   2 (10 binary) becomes 1, 3 (11 binary) becomes -1
-	 *   4 (100 binary) becomes 2, 5 (101 binary) becomes -2
-	 */
-	function fromVLQSigned(aValue) {
-	  var isNegative = (aValue & 1) === 1;
-	  var shifted = aValue >> 1;
-	  return isNegative
-	    ? -shifted
-	    : shifted;
-	}
-	
-	/**
-	 * Returns the base 64 VLQ encoded value.
-	 */
-	exports.encode = function base64VLQ_encode(aValue) {
-	  var encoded = "";
-	  var digit;
-	
-	  var vlq = toVLQSigned(aValue);
-	
-	  do {
-	    digit = vlq & VLQ_BASE_MASK;
-	    vlq >>>= VLQ_BASE_SHIFT;
-	    if (vlq > 0) {
-	      // There are still more digits in this value, so we must make sure the
-	      // continuation bit is marked.
-	      digit |= VLQ_CONTINUATION_BIT;
-	    }
-	    encoded += base64.encode(digit);
-	  } while (vlq > 0);
-	
-	  return encoded;
-	};
-	
-	/**
-	 * Decodes the next base 64 VLQ value from the given string and returns the
-	 * value and the rest of the string via the out parameter.
-	 */
-	exports.decode = function base64VLQ_decode(aStr, aIndex, aOutParam) {
-	  var strLen = aStr.length;
-	  var result = 0;
-	  var shift = 0;
-	  var continuation, digit;
-	
-	  do {
-	    if (aIndex >= strLen) {
-	      throw new Error("Expected more digits in base 64 VLQ value.");
-	    }
-	
-	    digit = base64.decode(aStr.charCodeAt(aIndex++));
-	    if (digit === -1) {
-	      throw new Error("Invalid base64 digit: " + aStr.charAt(aIndex - 1));
-	    }
-	
-	    continuation = !!(digit & VLQ_CONTINUATION_BIT);
-	    digit &= VLQ_BASE_MASK;
-	    result = result + (digit << shift);
-	    shift += VLQ_BASE_SHIFT;
-	  } while (continuation);
-	
-	  aOutParam.value = fromVLQSigned(result);
-	  aOutParam.rest = aIndex;
-	};
-
-
-/***/ },
-/* 224 */
-/***/ function(module, exports) {
-
-	/* -*- Mode: js; js-indent-level: 2; -*- */
-	/*
-	 * Copyright 2011 Mozilla Foundation and contributors
-	 * Licensed under the New BSD license. See LICENSE or:
-	 * http://opensource.org/licenses/BSD-3-Clause
-	 */
-	
-	var intToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'.split('');
-	
-	/**
-	 * Encode an integer in the range of 0 to 63 to a single base 64 digit.
-	 */
-	exports.encode = function (number) {
-	  if (0 <= number && number < intToCharMap.length) {
-	    return intToCharMap[number];
-	  }
-	  throw new TypeError("Must be between 0 and 63: " + number);
-	};
-	
-	/**
-	 * Decode a single base 64 character code digit to an integer. Returns -1 on
-	 * failure.
-	 */
-	exports.decode = function (charCode) {
-	  var bigA = 65;     // 'A'
-	  var bigZ = 90;     // 'Z'
-	
-	  var littleA = 97;  // 'a'
-	  var littleZ = 122; // 'z'
-	
-	  var zero = 48;     // '0'
-	  var nine = 57;     // '9'
-	
-	  var plus = 43;     // '+'
-	  var slash = 47;    // '/'
-	
-	  var littleOffset = 26;
-	  var numberOffset = 52;
-	
-	  // 0 - 25: ABCDEFGHIJKLMNOPQRSTUVWXYZ
-	  if (bigA <= charCode && charCode <= bigZ) {
-	    return (charCode - bigA);
-	  }
-	
-	  // 26 - 51: abcdefghijklmnopqrstuvwxyz
-	  if (littleA <= charCode && charCode <= littleZ) {
-	    return (charCode - littleA + littleOffset);
-	  }
-	
-	  // 52 - 61: 0123456789
-	  if (zero <= charCode && charCode <= nine) {
-	    return (charCode - zero + numberOffset);
-	  }
-	
-	  // 62: +
-	  if (charCode == plus) {
-	    return 62;
-	  }
-	
-	  // 63: /
-	  if (charCode == slash) {
-	    return 63;
-	  }
-	
-	  // Invalid base64 digit.
-	  return -1;
-	};
-
-
-/***/ },
-/* 225 */
-/***/ function(module, exports) {
-
-	/* -*- Mode: js; js-indent-level: 2; -*- */
-	/*
-	 * Copyright 2011 Mozilla Foundation and contributors
-	 * Licensed under the New BSD license. See LICENSE or:
-	 * http://opensource.org/licenses/BSD-3-Clause
-	 */
-	
-	/**
-	 * This is a helper function for getting values from parameter/options
-	 * objects.
-	 *
-	 * @param args The object we are extracting values from
-	 * @param name The name of the property we are getting.
-	 * @param defaultValue An optional value to return if the property is missing
-	 * from the object. If this is not specified and the property is missing, an
-	 * error will be thrown.
-	 */
-	function getArg(aArgs, aName, aDefaultValue) {
-	  if (aName in aArgs) {
-	    return aArgs[aName];
-	  } else if (arguments.length === 3) {
-	    return aDefaultValue;
-	  } else {
-	    throw new Error('"' + aName + '" is a required argument.');
-	  }
-	}
-	exports.getArg = getArg;
-	
-	var urlRegexp = /^(?:([\w+\-.]+):)?\/\/(?:(\w+:\w+)@)?([\w.]*)(?::(\d+))?(\S*)$/;
-	var dataUrlRegexp = /^data:.+\,.+$/;
-	
-	function urlParse(aUrl) {
-	  var match = aUrl.match(urlRegexp);
-	  if (!match) {
-	    return null;
-	  }
-	  return {
-	    scheme: match[1],
-	    auth: match[2],
-	    host: match[3],
-	    port: match[4],
-	    path: match[5]
-	  };
-	}
-	exports.urlParse = urlParse;
-	
-	function urlGenerate(aParsedUrl) {
-	  var url = '';
-	  if (aParsedUrl.scheme) {
-	    url += aParsedUrl.scheme + ':';
-	  }
-	  url += '//';
-	  if (aParsedUrl.auth) {
-	    url += aParsedUrl.auth + '@';
-	  }
-	  if (aParsedUrl.host) {
-	    url += aParsedUrl.host;
-	  }
-	  if (aParsedUrl.port) {
-	    url += ":" + aParsedUrl.port
-	  }
-	  if (aParsedUrl.path) {
-	    url += aParsedUrl.path;
-	  }
-	  return url;
-	}
-	exports.urlGenerate = urlGenerate;
-	
-	/**
-	 * Normalizes a path, or the path portion of a URL:
-	 *
-	 * - Replaces consecutive slashes with one slash.
-	 * - Removes unnecessary '.' parts.
-	 * - Removes unnecessary '<dir>/..' parts.
-	 *
-	 * Based on code in the Node.js 'path' core module.
-	 *
-	 * @param aPath The path or url to normalize.
-	 */
-	function normalize(aPath) {
-	  var path = aPath;
-	  var url = urlParse(aPath);
-	  if (url) {
-	    if (!url.path) {
-	      return aPath;
-	    }
-	    path = url.path;
-	  }
-	  var isAbsolute = exports.isAbsolute(path);
-	
-	  var parts = path.split(/\/+/);
-	  for (var part, up = 0, i = parts.length - 1; i >= 0; i--) {
-	    part = parts[i];
-	    if (part === '.') {
-	      parts.splice(i, 1);
-	    } else if (part === '..') {
-	      up++;
-	    } else if (up > 0) {
-	      if (part === '') {
-	        // The first part is blank if the path is absolute. Trying to go
-	        // above the root is a no-op. Therefore we can remove all '..' parts
-	        // directly after the root.
-	        parts.splice(i + 1, up);
-	        up = 0;
-	      } else {
-	        parts.splice(i, 2);
-	        up--;
-	      }
-	    }
-	  }
-	  path = parts.join('/');
-	
-	  if (path === '') {
-	    path = isAbsolute ? '/' : '.';
-	  }
-	
-	  if (url) {
-	    url.path = path;
-	    return urlGenerate(url);
-	  }
-	  return path;
-	}
-	exports.normalize = normalize;
-	
-	/**
-	 * Joins two paths/URLs.
-	 *
-	 * @param aRoot The root path or URL.
-	 * @param aPath The path or URL to be joined with the root.
-	 *
-	 * - If aPath is a URL or a data URI, aPath is returned, unless aPath is a
-	 *   scheme-relative URL: Then the scheme of aRoot, if any, is prepended
-	 *   first.
-	 * - Otherwise aPath is a path. If aRoot is a URL, then its path portion
-	 *   is updated with the result and aRoot is returned. Otherwise the result
-	 *   is returned.
-	 *   - If aPath is absolute, the result is aPath.
-	 *   - Otherwise the two paths are joined with a slash.
-	 * - Joining for example 'http://' and 'www.example.com' is also supported.
-	 */
-	function join(aRoot, aPath) {
-	  if (aRoot === "") {
-	    aRoot = ".";
-	  }
-	  if (aPath === "") {
-	    aPath = ".";
-	  }
-	  var aPathUrl = urlParse(aPath);
-	  var aRootUrl = urlParse(aRoot);
-	  if (aRootUrl) {
-	    aRoot = aRootUrl.path || '/';
-	  }
-	
-	  // `join(foo, '//www.example.org')`
-	  if (aPathUrl && !aPathUrl.scheme) {
-	    if (aRootUrl) {
-	      aPathUrl.scheme = aRootUrl.scheme;
-	    }
-	    return urlGenerate(aPathUrl);
-	  }
-	
-	  if (aPathUrl || aPath.match(dataUrlRegexp)) {
-	    return aPath;
-	  }
-	
-	  // `join('http://', 'www.example.com')`
-	  if (aRootUrl && !aRootUrl.host && !aRootUrl.path) {
-	    aRootUrl.host = aPath;
-	    return urlGenerate(aRootUrl);
-	  }
-	
-	  var joined = aPath.charAt(0) === '/'
-	    ? aPath
-	    : normalize(aRoot.replace(/\/+$/, '') + '/' + aPath);
-	
-	  if (aRootUrl) {
-	    aRootUrl.path = joined;
-	    return urlGenerate(aRootUrl);
-	  }
-	  return joined;
-	}
-	exports.join = join;
-	
-	exports.isAbsolute = function (aPath) {
-	  return aPath.charAt(0) === '/' || !!aPath.match(urlRegexp);
-	};
-	
-	/**
-	 * Make a path relative to a URL or another path.
-	 *
-	 * @param aRoot The root path or URL.
-	 * @param aPath The path or URL to be made relative to aRoot.
-	 */
-	function relative(aRoot, aPath) {
-	  if (aRoot === "") {
-	    aRoot = ".";
-	  }
-	
-	  aRoot = aRoot.replace(/\/$/, '');
-	
-	  // It is possible for the path to be above the root. In this case, simply
-	  // checking whether the root is a prefix of the path won't work. Instead, we
-	  // need to remove components from the root one by one, until either we find
-	  // a prefix that fits, or we run out of components to remove.
-	  var level = 0;
-	  while (aPath.indexOf(aRoot + '/') !== 0) {
-	    var index = aRoot.lastIndexOf("/");
-	    if (index < 0) {
-	      return aPath;
-	    }
-	
-	    // If the only part of the root that is left is the scheme (i.e. http://,
-	    // file:///, etc.), one or more slashes (/), or simply nothing at all, we
-	    // have exhausted all components, so the path is not relative to the root.
-	    aRoot = aRoot.slice(0, index);
-	    if (aRoot.match(/^([^\/]+:\/)?\/*$/)) {
-	      return aPath;
-	    }
-	
-	    ++level;
-	  }
-	
-	  // Make sure we add a "../" for each component we removed from the root.
-	  return Array(level + 1).join("../") + aPath.substr(aRoot.length + 1);
-	}
-	exports.relative = relative;
-	
-	var supportsNullProto = (function () {
-	  var obj = Object.create(null);
-	  return !('__proto__' in obj);
-	}());
-	
-	function identity (s) {
-	  return s;
-	}
-	
-	/**
-	 * Because behavior goes wacky when you set `__proto__` on objects, we
-	 * have to prefix all the strings in our set with an arbitrary character.
-	 *
-	 * See https://github.com/mozilla/source-map/pull/31 and
-	 * https://github.com/mozilla/source-map/issues/30
-	 *
-	 * @param String aStr
-	 */
-	function toSetString(aStr) {
-	  if (isProtoString(aStr)) {
-	    return '$' + aStr;
-	  }
-	
-	  return aStr;
-	}
-	exports.toSetString = supportsNullProto ? identity : toSetString;
-	
-	function fromSetString(aStr) {
-	  if (isProtoString(aStr)) {
-	    return aStr.slice(1);
-	  }
-	
-	  return aStr;
-	}
-	exports.fromSetString = supportsNullProto ? identity : fromSetString;
-	
-	function isProtoString(s) {
-	  if (!s) {
-	    return false;
-	  }
-	
-	  var length = s.length;
-	
-	  if (length < 9 /* "__proto__".length */) {
-	    return false;
-	  }
-	
-	  if (s.charCodeAt(length - 1) !== 95  /* '_' */ ||
-	      s.charCodeAt(length - 2) !== 95  /* '_' */ ||
-	      s.charCodeAt(length - 3) !== 111 /* 'o' */ ||
-	      s.charCodeAt(length - 4) !== 116 /* 't' */ ||
-	      s.charCodeAt(length - 5) !== 111 /* 'o' */ ||
-	      s.charCodeAt(length - 6) !== 114 /* 'r' */ ||
-	      s.charCodeAt(length - 7) !== 112 /* 'p' */ ||
-	      s.charCodeAt(length - 8) !== 95  /* '_' */ ||
-	      s.charCodeAt(length - 9) !== 95  /* '_' */) {
-	    return false;
-	  }
-	
-	  for (var i = length - 10; i >= 0; i--) {
-	    if (s.charCodeAt(i) !== 36 /* '$' */) {
-	      return false;
-	    }
-	  }
-	
-	  return true;
-	}
-	
-	/**
-	 * Comparator between two mappings where the original positions are compared.
-	 *
-	 * Optionally pass in `true` as `onlyCompareGenerated` to consider two
-	 * mappings with the same original source/line/column, but different generated
-	 * line and column the same. Useful when searching for a mapping with a
-	 * stubbed out mapping.
-	 */
-	function compareByOriginalPositions(mappingA, mappingB, onlyCompareOriginal) {
-	  var cmp = mappingA.source - mappingB.source;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  cmp = mappingA.originalLine - mappingB.originalLine;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  cmp = mappingA.originalColumn - mappingB.originalColumn;
-	  if (cmp !== 0 || onlyCompareOriginal) {
-	    return cmp;
-	  }
-	
-	  cmp = mappingA.generatedColumn - mappingB.generatedColumn;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  cmp = mappingA.generatedLine - mappingB.generatedLine;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  return mappingA.name - mappingB.name;
-	}
-	exports.compareByOriginalPositions = compareByOriginalPositions;
-	
-	/**
-	 * Comparator between two mappings with deflated source and name indices where
-	 * the generated positions are compared.
-	 *
-	 * Optionally pass in `true` as `onlyCompareGenerated` to consider two
-	 * mappings with the same generated line and column, but different
-	 * source/name/original line and column the same. Useful when searching for a
-	 * mapping with a stubbed out mapping.
-	 */
-	function compareByGeneratedPositionsDeflated(mappingA, mappingB, onlyCompareGenerated) {
-	  var cmp = mappingA.generatedLine - mappingB.generatedLine;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  cmp = mappingA.generatedColumn - mappingB.generatedColumn;
-	  if (cmp !== 0 || onlyCompareGenerated) {
-	    return cmp;
-	  }
-	
-	  cmp = mappingA.source - mappingB.source;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  cmp = mappingA.originalLine - mappingB.originalLine;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  cmp = mappingA.originalColumn - mappingB.originalColumn;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  return mappingA.name - mappingB.name;
-	}
-	exports.compareByGeneratedPositionsDeflated = compareByGeneratedPositionsDeflated;
-	
-	function strcmp(aStr1, aStr2) {
-	  if (aStr1 === aStr2) {
-	    return 0;
-	  }
-	
-	  if (aStr1 > aStr2) {
-	    return 1;
-	  }
-	
-	  return -1;
-	}
-	
-	/**
-	 * Comparator between two mappings with inflated source and name strings where
-	 * the generated positions are compared.
-	 */
-	function compareByGeneratedPositionsInflated(mappingA, mappingB) {
-	  var cmp = mappingA.generatedLine - mappingB.generatedLine;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  cmp = mappingA.generatedColumn - mappingB.generatedColumn;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  cmp = strcmp(mappingA.source, mappingB.source);
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  cmp = mappingA.originalLine - mappingB.originalLine;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  cmp = mappingA.originalColumn - mappingB.originalColumn;
-	  if (cmp !== 0) {
-	    return cmp;
-	  }
-	
-	  return strcmp(mappingA.name, mappingB.name);
-	}
-	exports.compareByGeneratedPositionsInflated = compareByGeneratedPositionsInflated;
-
-
-/***/ },
-/* 226 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* -*- Mode: js; js-indent-level: 2; -*- */
-	/*
-	 * Copyright 2011 Mozilla Foundation and contributors
-	 * Licensed under the New BSD license. See LICENSE or:
-	 * http://opensource.org/licenses/BSD-3-Clause
-	 */
-	
-	var util = __webpack_require__(225);
-	var has = Object.prototype.hasOwnProperty;
-	
-	/**
-	 * A data structure which is a combination of an array and a set. Adding a new
-	 * member is O(1), testing for membership is O(1), and finding the index of an
-	 * element is O(1). Removing elements from the set is not supported. Only
-	 * strings are supported for membership.
-	 */
-	function ArraySet() {
-	  this._array = [];
-	  this._set = Object.create(null);
-	}
-	
-	/**
-	 * Static method for creating ArraySet instances from an existing array.
-	 */
-	ArraySet.fromArray = function ArraySet_fromArray(aArray, aAllowDuplicates) {
-	  var set = new ArraySet();
-	  for (var i = 0, len = aArray.length; i < len; i++) {
-	    set.add(aArray[i], aAllowDuplicates);
-	  }
-	  return set;
-	};
-	
-	/**
-	 * Return how many unique items are in this ArraySet. If duplicates have been
-	 * added, than those do not count towards the size.
-	 *
-	 * @returns Number
-	 */
-	ArraySet.prototype.size = function ArraySet_size() {
-	  return Object.getOwnPropertyNames(this._set).length;
-	};
-	
-	/**
-	 * Add the given string to this set.
-	 *
-	 * @param String aStr
-	 */
-	ArraySet.prototype.add = function ArraySet_add(aStr, aAllowDuplicates) {
-	  var sStr = util.toSetString(aStr);
-	  var isDuplicate = has.call(this._set, sStr);
-	  var idx = this._array.length;
-	  if (!isDuplicate || aAllowDuplicates) {
-	    this._array.push(aStr);
-	  }
-	  if (!isDuplicate) {
-	    this._set[sStr] = idx;
-	  }
-	};
-	
-	/**
-	 * Is the given string a member of this set?
-	 *
-	 * @param String aStr
-	 */
-	ArraySet.prototype.has = function ArraySet_has(aStr) {
-	  var sStr = util.toSetString(aStr);
-	  return has.call(this._set, sStr);
-	};
-	
-	/**
-	 * What is the index of the given string in the array?
-	 *
-	 * @param String aStr
-	 */
-	ArraySet.prototype.indexOf = function ArraySet_indexOf(aStr) {
-	  var sStr = util.toSetString(aStr);
-	  if (has.call(this._set, sStr)) {
-	    return this._set[sStr];
-	  }
-	  throw new Error('"' + aStr + '" is not in the set.');
-	};
-	
-	/**
-	 * What is the element at the given index?
-	 *
-	 * @param Number aIdx
-	 */
-	ArraySet.prototype.at = function ArraySet_at(aIdx) {
-	  if (aIdx >= 0 && aIdx < this._array.length) {
-	    return this._array[aIdx];
-	  }
-	  throw new Error('No element indexed by ' + aIdx);
-	};
-	
-	/**
-	 * Returns the array representation of this set (which has the proper indices
-	 * indicated by indexOf). Note that this is a copy of the internal array used
-	 * for storing the members so that no one can mess with internal state.
-	 */
-	ArraySet.prototype.toArray = function ArraySet_toArray() {
-	  return this._array.slice();
-	};
-	
-	exports.ArraySet = ArraySet;
-
-
-/***/ },
-/* 227 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* -*- Mode: js; js-indent-level: 2; -*- */
-	/*
-	 * Copyright 2014 Mozilla Foundation and contributors
-	 * Licensed under the New BSD license. See LICENSE or:
-	 * http://opensource.org/licenses/BSD-3-Clause
-	 */
-	
-	var util = __webpack_require__(225);
-	
-	/**
-	 * Determine whether mappingB is after mappingA with respect to generated
-	 * position.
-	 */
-	function generatedPositionAfter(mappingA, mappingB) {
-	  // Optimized for most common case
-	  var lineA = mappingA.generatedLine;
-	  var lineB = mappingB.generatedLine;
-	  var columnA = mappingA.generatedColumn;
-	  var columnB = mappingB.generatedColumn;
-	  return lineB > lineA || lineB == lineA && columnB >= columnA ||
-	         util.compareByGeneratedPositionsInflated(mappingA, mappingB) <= 0;
-	}
-	
-	/**
-	 * A data structure to provide a sorted view of accumulated mappings in a
-	 * performance conscious manner. It trades a neglibable overhead in general
-	 * case for a large speedup in case of mappings being added in order.
-	 */
-	function MappingList() {
-	  this._array = [];
-	  this._sorted = true;
-	  // Serves as infimum
-	  this._last = {generatedLine: -1, generatedColumn: 0};
-	}
-	
-	/**
-	 * Iterate through internal items. This method takes the same arguments that
-	 * `Array.prototype.forEach` takes.
-	 *
-	 * NOTE: The order of the mappings is NOT guaranteed.
-	 */
-	MappingList.prototype.unsortedForEach =
-	  function MappingList_forEach(aCallback, aThisArg) {
-	    this._array.forEach(aCallback, aThisArg);
-	  };
-	
-	/**
-	 * Add the given source mapping.
-	 *
-	 * @param Object aMapping
-	 */
-	MappingList.prototype.add = function MappingList_add(aMapping) {
-	  if (generatedPositionAfter(this._last, aMapping)) {
-	    this._last = aMapping;
-	    this._array.push(aMapping);
-	  } else {
-	    this._sorted = false;
-	    this._array.push(aMapping);
-	  }
-	};
-	
-	/**
-	 * Returns the flat, sorted array of mappings. The mappings are sorted by
-	 * generated position.
-	 *
-	 * WARNING: This method returns internal data without copying, for
-	 * performance. The return value must NOT be mutated, and should be treated as
-	 * an immutable borrow. If you want to take ownership, you must make your own
-	 * copy.
-	 */
-	MappingList.prototype.toArray = function MappingList_toArray() {
-	  if (!this._sorted) {
-	    this._array.sort(util.compareByGeneratedPositionsInflated);
-	    this._sorted = true;
-	  }
-	  return this._array;
-	};
-	
-	exports.MappingList = MappingList;
-
-
-/***/ },
-/* 228 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* -*- Mode: js; js-indent-level: 2; -*- */
-	/*
-	 * Copyright 2011 Mozilla Foundation and contributors
-	 * Licensed under the New BSD license. See LICENSE or:
-	 * http://opensource.org/licenses/BSD-3-Clause
-	 */
-	
-	var util = __webpack_require__(225);
-	var binarySearch = __webpack_require__(229);
-	var ArraySet = __webpack_require__(226).ArraySet;
-	var base64VLQ = __webpack_require__(223);
-	var quickSort = __webpack_require__(230).quickSort;
-	
-	function SourceMapConsumer(aSourceMap) {
-	  var sourceMap = aSourceMap;
-	  if (typeof aSourceMap === 'string') {
-	    sourceMap = JSON.parse(aSourceMap.replace(/^\)\]\}'/, ''));
-	  }
-	
-	  return sourceMap.sections != null
-	    ? new IndexedSourceMapConsumer(sourceMap)
-	    : new BasicSourceMapConsumer(sourceMap);
-	}
-	
-	SourceMapConsumer.fromSourceMap = function(aSourceMap) {
-	  return BasicSourceMapConsumer.fromSourceMap(aSourceMap);
-	}
-	
-	/**
-	 * The version of the source mapping spec that we are consuming.
-	 */
-	SourceMapConsumer.prototype._version = 3;
-	
-	// `__generatedMappings` and `__originalMappings` are arrays that hold the
-	// parsed mapping coordinates from the source map's "mappings" attribute. They
-	// are lazily instantiated, accessed via the `_generatedMappings` and
-	// `_originalMappings` getters respectively, and we only parse the mappings
-	// and create these arrays once queried for a source location. We jump through
-	// these hoops because there can be many thousands of mappings, and parsing
-	// them is expensive, so we only want to do it if we must.
-	//
-	// Each object in the arrays is of the form:
-	//
-	//     {
-	//       generatedLine: The line number in the generated code,
-	//       generatedColumn: The column number in the generated code,
-	//       source: The path to the original source file that generated this
-	//               chunk of code,
-	//       originalLine: The line number in the original source that
-	//                     corresponds to this chunk of generated code,
-	//       originalColumn: The column number in the original source that
-	//                       corresponds to this chunk of generated code,
-	//       name: The name of the original symbol which generated this chunk of
-	//             code.
-	//     }
-	//
-	// All properties except for `generatedLine` and `generatedColumn` can be
-	// `null`.
-	//
-	// `_generatedMappings` is ordered by the generated positions.
-	//
-	// `_originalMappings` is ordered by the original positions.
-	
-	SourceMapConsumer.prototype.__generatedMappings = null;
-	Object.defineProperty(SourceMapConsumer.prototype, '_generatedMappings', {
-	  get: function () {
-	    if (!this.__generatedMappings) {
-	      this._parseMappings(this._mappings, this.sourceRoot);
-	    }
-	
-	    return this.__generatedMappings;
-	  }
-	});
-	
-	SourceMapConsumer.prototype.__originalMappings = null;
-	Object.defineProperty(SourceMapConsumer.prototype, '_originalMappings', {
-	  get: function () {
-	    if (!this.__originalMappings) {
-	      this._parseMappings(this._mappings, this.sourceRoot);
-	    }
-	
-	    return this.__originalMappings;
-	  }
-	});
-	
-	SourceMapConsumer.prototype._charIsMappingSeparator =
-	  function SourceMapConsumer_charIsMappingSeparator(aStr, index) {
-	    var c = aStr.charAt(index);
-	    return c === ";" || c === ",";
-	  };
-	
-	/**
-	 * Parse the mappings in a string in to a data structure which we can easily
-	 * query (the ordered arrays in the `this.__generatedMappings` and
-	 * `this.__originalMappings` properties).
-	 */
-	SourceMapConsumer.prototype._parseMappings =
-	  function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {
-	    throw new Error("Subclasses must implement _parseMappings");
-	  };
-	
-	SourceMapConsumer.GENERATED_ORDER = 1;
-	SourceMapConsumer.ORIGINAL_ORDER = 2;
-	
-	SourceMapConsumer.GREATEST_LOWER_BOUND = 1;
-	SourceMapConsumer.LEAST_UPPER_BOUND = 2;
-	
-	/**
-	 * Iterate over each mapping between an original source/line/column and a
-	 * generated line/column in this source map.
-	 *
-	 * @param Function aCallback
-	 *        The function that is called with each mapping.
-	 * @param Object aContext
-	 *        Optional. If specified, this object will be the value of `this` every
-	 *        time that `aCallback` is called.
-	 * @param aOrder
-	 *        Either `SourceMapConsumer.GENERATED_ORDER` or
-	 *        `SourceMapConsumer.ORIGINAL_ORDER`. Specifies whether you want to
-	 *        iterate over the mappings sorted by the generated file's line/column
-	 *        order or the original's source/line/column order, respectively. Defaults to
-	 *        `SourceMapConsumer.GENERATED_ORDER`.
-	 */
-	SourceMapConsumer.prototype.eachMapping =
-	  function SourceMapConsumer_eachMapping(aCallback, aContext, aOrder) {
-	    var context = aContext || null;
-	    var order = aOrder || SourceMapConsumer.GENERATED_ORDER;
-	
-	    var mappings;
-	    switch (order) {
-	    case SourceMapConsumer.GENERATED_ORDER:
-	      mappings = this._generatedMappings;
-	      break;
-	    case SourceMapConsumer.ORIGINAL_ORDER:
-	      mappings = this._originalMappings;
-	      break;
-	    default:
-	      throw new Error("Unknown order of iteration.");
-	    }
-	
-	    var sourceRoot = this.sourceRoot;
-	    mappings.map(function (mapping) {
-	      var source = mapping.source === null ? null : this._sources.at(mapping.source);
-	      if (source != null && sourceRoot != null) {
-	        source = util.join(sourceRoot, source);
-	      }
-	      return {
-	        source: source,
-	        generatedLine: mapping.generatedLine,
-	        generatedColumn: mapping.generatedColumn,
-	        originalLine: mapping.originalLine,
-	        originalColumn: mapping.originalColumn,
-	        name: mapping.name === null ? null : this._names.at(mapping.name)
-	      };
-	    }, this).forEach(aCallback, context);
-	  };
-	
-	/**
-	 * Returns all generated line and column information for the original source,
-	 * line, and column provided. If no column is provided, returns all mappings
-	 * corresponding to a either the line we are searching for or the next
-	 * closest line that has any mappings. Otherwise, returns all mappings
-	 * corresponding to the given line and either the column we are searching for
-	 * or the next closest column that has any offsets.
-	 *
-	 * The only argument is an object with the following properties:
-	 *
-	 *   - source: The filename of the original source.
-	 *   - line: The line number in the original source.
-	 *   - column: Optional. the column number in the original source.
-	 *
-	 * and an array of objects is returned, each with the following properties:
-	 *
-	 *   - line: The line number in the generated source, or null.
-	 *   - column: The column number in the generated source, or null.
-	 */
-	SourceMapConsumer.prototype.allGeneratedPositionsFor =
-	  function SourceMapConsumer_allGeneratedPositionsFor(aArgs) {
-	    var line = util.getArg(aArgs, 'line');
-	
-	    // When there is no exact match, BasicSourceMapConsumer.prototype._findMapping
-	    // returns the index of the closest mapping less than the needle. By
-	    // setting needle.originalColumn to 0, we thus find the last mapping for
-	    // the given line, provided such a mapping exists.
-	    var needle = {
-	      source: util.getArg(aArgs, 'source'),
-	      originalLine: line,
-	      originalColumn: util.getArg(aArgs, 'column', 0)
-	    };
-	
-	    if (this.sourceRoot != null) {
-	      needle.source = util.relative(this.sourceRoot, needle.source);
-	    }
-	    if (!this._sources.has(needle.source)) {
-	      return [];
-	    }
-	    needle.source = this._sources.indexOf(needle.source);
-	
-	    var mappings = [];
-	
-	    var index = this._findMapping(needle,
-	                                  this._originalMappings,
-	                                  "originalLine",
-	                                  "originalColumn",
-	                                  util.compareByOriginalPositions,
-	                                  binarySearch.LEAST_UPPER_BOUND);
-	    if (index >= 0) {
-	      var mapping = this._originalMappings[index];
-	
-	      if (aArgs.column === undefined) {
-	        var originalLine = mapping.originalLine;
-	
-	        // Iterate until either we run out of mappings, or we run into
-	        // a mapping for a different line than the one we found. Since
-	        // mappings are sorted, this is guaranteed to find all mappings for
-	        // the line we found.
-	        while (mapping && mapping.originalLine === originalLine) {
-	          mappings.push({
-	            line: util.getArg(mapping, 'generatedLine', null),
-	            column: util.getArg(mapping, 'generatedColumn', null),
-	            lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
-	          });
-	
-	          mapping = this._originalMappings[++index];
-	        }
-	      } else {
-	        var originalColumn = mapping.originalColumn;
-	
-	        // Iterate until either we run out of mappings, or we run into
-	        // a mapping for a different line than the one we were searching for.
-	        // Since mappings are sorted, this is guaranteed to find all mappings for
-	        // the line we are searching for.
-	        while (mapping &&
-	               mapping.originalLine === line &&
-	               mapping.originalColumn == originalColumn) {
-	          mappings.push({
-	            line: util.getArg(mapping, 'generatedLine', null),
-	            column: util.getArg(mapping, 'generatedColumn', null),
-	            lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
-	          });
-	
-	          mapping = this._originalMappings[++index];
-	        }
-	      }
-	    }
-	
-	    return mappings;
-	  };
-	
-	exports.SourceMapConsumer = SourceMapConsumer;
-	
-	/**
-	 * A BasicSourceMapConsumer instance represents a parsed source map which we can
-	 * query for information about the original file positions by giving it a file
-	 * position in the generated source.
-	 *
-	 * The only parameter is the raw source map (either as a JSON string, or
-	 * already parsed to an object). According to the spec, source maps have the
-	 * following attributes:
-	 *
-	 *   - version: Which version of the source map spec this map is following.
-	 *   - sources: An array of URLs to the original source files.
-	 *   - names: An array of identifiers which can be referrenced by individual mappings.
-	 *   - sourceRoot: Optional. The URL root from which all sources are relative.
-	 *   - sourcesContent: Optional. An array of contents of the original source files.
-	 *   - mappings: A string of base64 VLQs which contain the actual mappings.
-	 *   - file: Optional. The generated file this source map is associated with.
-	 *
-	 * Here is an example source map, taken from the source map spec[0]:
-	 *
-	 *     {
-	 *       version : 3,
-	 *       file: "out.js",
-	 *       sourceRoot : "",
-	 *       sources: ["foo.js", "bar.js"],
-	 *       names: ["src", "maps", "are", "fun"],
-	 *       mappings: "AA,AB;;ABCDE;"
-	 *     }
-	 *
-	 * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit?pli=1#
-	 */
-	function BasicSourceMapConsumer(aSourceMap) {
-	  var sourceMap = aSourceMap;
-	  if (typeof aSourceMap === 'string') {
-	    sourceMap = JSON.parse(aSourceMap.replace(/^\)\]\}'/, ''));
-	  }
-	
-	  var version = util.getArg(sourceMap, 'version');
-	  var sources = util.getArg(sourceMap, 'sources');
-	  // Sass 3.3 leaves out the 'names' array, so we deviate from the spec (which
-	  // requires the array) to play nice here.
-	  var names = util.getArg(sourceMap, 'names', []);
-	  var sourceRoot = util.getArg(sourceMap, 'sourceRoot', null);
-	  var sourcesContent = util.getArg(sourceMap, 'sourcesContent', null);
-	  var mappings = util.getArg(sourceMap, 'mappings');
-	  var file = util.getArg(sourceMap, 'file', null);
-	
-	  // Once again, Sass deviates from the spec and supplies the version as a
-	  // string rather than a number, so we use loose equality checking here.
-	  if (version != this._version) {
-	    throw new Error('Unsupported version: ' + version);
-	  }
-	
-	  sources = sources
-	    .map(String)
-	    // Some source maps produce relative source paths like "./foo.js" instead of
-	    // "foo.js".  Normalize these first so that future comparisons will succeed.
-	    // See bugzil.la/1090768.
-	    .map(util.normalize)
-	    // Always ensure that absolute sources are internally stored relative to
-	    // the source root, if the source root is absolute. Not doing this would
-	    // be particularly problematic when the source root is a prefix of the
-	    // source (valid, but why??). See github issue #199 and bugzil.la/1188982.
-	    .map(function (source) {
-	      return sourceRoot && util.isAbsolute(sourceRoot) && util.isAbsolute(source)
-	        ? util.relative(sourceRoot, source)
-	        : source;
-	    });
-	
-	  // Pass `true` below to allow duplicate names and sources. While source maps
-	  // are intended to be compressed and deduplicated, the TypeScript compiler
-	  // sometimes generates source maps with duplicates in them. See Github issue
-	  // #72 and bugzil.la/889492.
-	  this._names = ArraySet.fromArray(names.map(String), true);
-	  this._sources = ArraySet.fromArray(sources, true);
-	
-	  this.sourceRoot = sourceRoot;
-	  this.sourcesContent = sourcesContent;
-	  this._mappings = mappings;
-	  this.file = file;
-	}
-	
-	BasicSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);
-	BasicSourceMapConsumer.prototype.consumer = SourceMapConsumer;
-	
-	/**
-	 * Create a BasicSourceMapConsumer from a SourceMapGenerator.
-	 *
-	 * @param SourceMapGenerator aSourceMap
-	 *        The source map that will be consumed.
-	 * @returns BasicSourceMapConsumer
-	 */
-	BasicSourceMapConsumer.fromSourceMap =
-	  function SourceMapConsumer_fromSourceMap(aSourceMap) {
-	    var smc = Object.create(BasicSourceMapConsumer.prototype);
-	
-	    var names = smc._names = ArraySet.fromArray(aSourceMap._names.toArray(), true);
-	    var sources = smc._sources = ArraySet.fromArray(aSourceMap._sources.toArray(), true);
-	    smc.sourceRoot = aSourceMap._sourceRoot;
-	    smc.sourcesContent = aSourceMap._generateSourcesContent(smc._sources.toArray(),
-	                                                            smc.sourceRoot);
-	    smc.file = aSourceMap._file;
-	
-	    // Because we are modifying the entries (by converting string sources and
-	    // names to indices into the sources and names ArraySets), we have to make
-	    // a copy of the entry or else bad things happen. Shared mutable state
-	    // strikes again! See github issue #191.
-	
-	    var generatedMappings = aSourceMap._mappings.toArray().slice();
-	    var destGeneratedMappings = smc.__generatedMappings = [];
-	    var destOriginalMappings = smc.__originalMappings = [];
-	
-	    for (var i = 0, length = generatedMappings.length; i < length; i++) {
-	      var srcMapping = generatedMappings[i];
-	      var destMapping = new Mapping;
-	      destMapping.generatedLine = srcMapping.generatedLine;
-	      destMapping.generatedColumn = srcMapping.generatedColumn;
-	
-	      if (srcMapping.source) {
-	        destMapping.source = sources.indexOf(srcMapping.source);
-	        destMapping.originalLine = srcMapping.originalLine;
-	        destMapping.originalColumn = srcMapping.originalColumn;
-	
-	        if (srcMapping.name) {
-	          destMapping.name = names.indexOf(srcMapping.name);
-	        }
-	
-	        destOriginalMappings.push(destMapping);
-	      }
-	
-	      destGeneratedMappings.push(destMapping);
-	    }
-	
-	    quickSort(smc.__originalMappings, util.compareByOriginalPositions);
-	
-	    return smc;
-	  };
-	
-	/**
-	 * The version of the source mapping spec that we are consuming.
-	 */
-	BasicSourceMapConsumer.prototype._version = 3;
-	
-	/**
-	 * The list of original sources.
-	 */
-	Object.defineProperty(BasicSourceMapConsumer.prototype, 'sources', {
-	  get: function () {
-	    return this._sources.toArray().map(function (s) {
-	      return this.sourceRoot != null ? util.join(this.sourceRoot, s) : s;
-	    }, this);
-	  }
-	});
-	
-	/**
-	 * Provide the JIT with a nice shape / hidden class.
-	 */
-	function Mapping() {
-	  this.generatedLine = 0;
-	  this.generatedColumn = 0;
-	  this.source = null;
-	  this.originalLine = null;
-	  this.originalColumn = null;
-	  this.name = null;
-	}
-	
-	/**
-	 * Parse the mappings in a string in to a data structure which we can easily
-	 * query (the ordered arrays in the `this.__generatedMappings` and
-	 * `this.__originalMappings` properties).
-	 */
-	BasicSourceMapConsumer.prototype._parseMappings =
-	  function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {
-	    var generatedLine = 1;
-	    var previousGeneratedColumn = 0;
-	    var previousOriginalLine = 0;
-	    var previousOriginalColumn = 0;
-	    var previousSource = 0;
-	    var previousName = 0;
-	    var length = aStr.length;
-	    var index = 0;
-	    var cachedSegments = {};
-	    var temp = {};
-	    var originalMappings = [];
-	    var generatedMappings = [];
-	    var mapping, str, segment, end, value;
-	
-	    while (index < length) {
-	      if (aStr.charAt(index) === ';') {
-	        generatedLine++;
-	        index++;
-	        previousGeneratedColumn = 0;
-	      }
-	      else if (aStr.charAt(index) === ',') {
-	        index++;
-	      }
-	      else {
-	        mapping = new Mapping();
-	        mapping.generatedLine = generatedLine;
-	
-	        // Because each offset is encoded relative to the previous one,
-	        // many segments often have the same encoding. We can exploit this
-	        // fact by caching the parsed variable length fields of each segment,
-	        // allowing us to avoid a second parse if we encounter the same
-	        // segment again.
-	        for (end = index; end < length; end++) {
-	          if (this._charIsMappingSeparator(aStr, end)) {
-	            break;
-	          }
-	        }
-	        str = aStr.slice(index, end);
-	
-	        segment = cachedSegments[str];
-	        if (segment) {
-	          index += str.length;
-	        } else {
-	          segment = [];
-	          while (index < end) {
-	            base64VLQ.decode(aStr, index, temp);
-	            value = temp.value;
-	            index = temp.rest;
-	            segment.push(value);
-	          }
-	
-	          if (segment.length === 2) {
-	            throw new Error('Found a source, but no line and column');
-	          }
-	
-	          if (segment.length === 3) {
-	            throw new Error('Found a source and line, but no column');
-	          }
-	
-	          cachedSegments[str] = segment;
-	        }
-	
-	        // Generated column.
-	        mapping.generatedColumn = previousGeneratedColumn + segment[0];
-	        previousGeneratedColumn = mapping.generatedColumn;
-	
-	        if (segment.length > 1) {
-	          // Original source.
-	          mapping.source = previousSource + segment[1];
-	          previousSource += segment[1];
-	
-	          // Original line.
-	          mapping.originalLine = previousOriginalLine + segment[2];
-	          previousOriginalLine = mapping.originalLine;
-	          // Lines are stored 0-based
-	          mapping.originalLine += 1;
-	
-	          // Original column.
-	          mapping.originalColumn = previousOriginalColumn + segment[3];
-	          previousOriginalColumn = mapping.originalColumn;
-	
-	          if (segment.length > 4) {
-	            // Original name.
-	            mapping.name = previousName + segment[4];
-	            previousName += segment[4];
-	          }
-	        }
-	
-	        generatedMappings.push(mapping);
-	        if (typeof mapping.originalLine === 'number') {
-	          originalMappings.push(mapping);
-	        }
-	      }
-	    }
-	
-	    quickSort(generatedMappings, util.compareByGeneratedPositionsDeflated);
-	    this.__generatedMappings = generatedMappings;
-	
-	    quickSort(originalMappings, util.compareByOriginalPositions);
-	    this.__originalMappings = originalMappings;
-	  };
-	
-	/**
-	 * Find the mapping that best matches the hypothetical "needle" mapping that
-	 * we are searching for in the given "haystack" of mappings.
-	 */
-	BasicSourceMapConsumer.prototype._findMapping =
-	  function SourceMapConsumer_findMapping(aNeedle, aMappings, aLineName,
-	                                         aColumnName, aComparator, aBias) {
-	    // To return the position we are searching for, we must first find the
-	    // mapping for the given position and then return the opposite position it
-	    // points to. Because the mappings are sorted, we can use binary search to
-	    // find the best mapping.
-	
-	    if (aNeedle[aLineName] <= 0) {
-	      throw new TypeError('Line must be greater than or equal to 1, got '
-	                          + aNeedle[aLineName]);
-	    }
-	    if (aNeedle[aColumnName] < 0) {
-	      throw new TypeError('Column must be greater than or equal to 0, got '
-	                          + aNeedle[aColumnName]);
-	    }
-	
-	    return binarySearch.search(aNeedle, aMappings, aComparator, aBias);
-	  };
-	
-	/**
-	 * Compute the last column for each generated mapping. The last column is
-	 * inclusive.
-	 */
-	BasicSourceMapConsumer.prototype.computeColumnSpans =
-	  function SourceMapConsumer_computeColumnSpans() {
-	    for (var index = 0; index < this._generatedMappings.length; ++index) {
-	      var mapping = this._generatedMappings[index];
-	
-	      // Mappings do not contain a field for the last generated columnt. We
-	      // can come up with an optimistic estimate, however, by assuming that
-	      // mappings are contiguous (i.e. given two consecutive mappings, the
-	      // first mapping ends where the second one starts).
-	      if (index + 1 < this._generatedMappings.length) {
-	        var nextMapping = this._generatedMappings[index + 1];
-	
-	        if (mapping.generatedLine === nextMapping.generatedLine) {
-	          mapping.lastGeneratedColumn = nextMapping.generatedColumn - 1;
-	          continue;
-	        }
-	      }
-	
-	      // The last mapping for each line spans the entire line.
-	      mapping.lastGeneratedColumn = Infinity;
-	    }
-	  };
-	
-	/**
-	 * Returns the original source, line, and column information for the generated
-	 * source's line and column positions provided. The only argument is an object
-	 * with the following properties:
-	 *
-	 *   - line: The line number in the generated source.
-	 *   - column: The column number in the generated source.
-	 *   - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or
-	 *     'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the
-	 *     closest element that is smaller than or greater than the one we are
-	 *     searching for, respectively, if the exact element cannot be found.
-	 *     Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.
-	 *
-	 * and an object is returned with the following properties:
-	 *
-	 *   - source: The original source file, or null.
-	 *   - line: The line number in the original source, or null.
-	 *   - column: The column number in the original source, or null.
-	 *   - name: The original identifier, or null.
-	 */
-	BasicSourceMapConsumer.prototype.originalPositionFor =
-	  function SourceMapConsumer_originalPositionFor(aArgs) {
-	    var needle = {
-	      generatedLine: util.getArg(aArgs, 'line'),
-	      generatedColumn: util.getArg(aArgs, 'column')
-	    };
-	
-	    var index = this._findMapping(
-	      needle,
-	      this._generatedMappings,
-	      "generatedLine",
-	      "generatedColumn",
-	      util.compareByGeneratedPositionsDeflated,
-	      util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)
-	    );
-	
-	    if (index >= 0) {
-	      var mapping = this._generatedMappings[index];
-	
-	      if (mapping.generatedLine === needle.generatedLine) {
-	        var source = util.getArg(mapping, 'source', null);
-	        if (source !== null) {
-	          source = this._sources.at(source);
-	          if (this.sourceRoot != null) {
-	            source = util.join(this.sourceRoot, source);
-	          }
-	        }
-	        var name = util.getArg(mapping, 'name', null);
-	        if (name !== null) {
-	          name = this._names.at(name);
-	        }
-	        return {
-	          source: source,
-	          line: util.getArg(mapping, 'originalLine', null),
-	          column: util.getArg(mapping, 'originalColumn', null),
-	          name: name
-	        };
-	      }
-	    }
-	
-	    return {
-	      source: null,
-	      line: null,
-	      column: null,
-	      name: null
-	    };
-	  };
-	
-	/**
-	 * Return true if we have the source content for every source in the source
-	 * map, false otherwise.
-	 */
-	BasicSourceMapConsumer.prototype.hasContentsOfAllSources =
-	  function BasicSourceMapConsumer_hasContentsOfAllSources() {
-	    if (!this.sourcesContent) {
-	      return false;
-	    }
-	    return this.sourcesContent.length >= this._sources.size() &&
-	      !this.sourcesContent.some(function (sc) { return sc == null; });
-	  };
-	
-	/**
-	 * Returns the original source content. The only argument is the url of the
-	 * original source file. Returns null if no original source content is
-	 * available.
-	 */
-	BasicSourceMapConsumer.prototype.sourceContentFor =
-	  function SourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {
-	    if (!this.sourcesContent) {
-	      return null;
-	    }
-	
-	    if (this.sourceRoot != null) {
-	      aSource = util.relative(this.sourceRoot, aSource);
-	    }
-	
-	    if (this._sources.has(aSource)) {
-	      return this.sourcesContent[this._sources.indexOf(aSource)];
-	    }
-	
-	    var url;
-	    if (this.sourceRoot != null
-	        && (url = util.urlParse(this.sourceRoot))) {
-	      // XXX: file:// URIs and absolute paths lead to unexpected behavior for
-	      // many users. We can help them out when they expect file:// URIs to
-	      // behave like it would if they were running a local HTTP server. See
-	      // https://bugzilla.mozilla.org/show_bug.cgi?id=885597.
-	      var fileUriAbsPath = aSource.replace(/^file:\/\//, "");
-	      if (url.scheme == "file"
-	          && this._sources.has(fileUriAbsPath)) {
-	        return this.sourcesContent[this._sources.indexOf(fileUriAbsPath)]
-	      }
-	
-	      if ((!url.path || url.path == "/")
-	          && this._sources.has("/" + aSource)) {
-	        return this.sourcesContent[this._sources.indexOf("/" + aSource)];
-	      }
-	    }
-	
-	    // This function is used recursively from
-	    // IndexedSourceMapConsumer.prototype.sourceContentFor. In that case, we
-	    // don't want to throw if we can't find the source - we just want to
-	    // return null, so we provide a flag to exit gracefully.
-	    if (nullOnMissing) {
-	      return null;
-	    }
-	    else {
-	      throw new Error('"' + aSource + '" is not in the SourceMap.');
-	    }
-	  };
-	
-	/**
-	 * Returns the generated line and column information for the original source,
-	 * line, and column positions provided. The only argument is an object with
-	 * the following properties:
-	 *
-	 *   - source: The filename of the original source.
-	 *   - line: The line number in the original source.
-	 *   - column: The column number in the original source.
-	 *   - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or
-	 *     'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the
-	 *     closest element that is smaller than or greater than the one we are
-	 *     searching for, respectively, if the exact element cannot be found.
-	 *     Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.
-	 *
-	 * and an object is returned with the following properties:
-	 *
-	 *   - line: The line number in the generated source, or null.
-	 *   - column: The column number in the generated source, or null.
-	 */
-	BasicSourceMapConsumer.prototype.generatedPositionFor =
-	  function SourceMapConsumer_generatedPositionFor(aArgs) {
-	    var source = util.getArg(aArgs, 'source');
-	    if (this.sourceRoot != null) {
-	      source = util.relative(this.sourceRoot, source);
-	    }
-	    if (!this._sources.has(source)) {
-	      return {
-	        line: null,
-	        column: null,
-	        lastColumn: null
-	      };
-	    }
-	    source = this._sources.indexOf(source);
-	
-	    var needle = {
-	      source: source,
-	      originalLine: util.getArg(aArgs, 'line'),
-	      originalColumn: util.getArg(aArgs, 'column')
-	    };
-	
-	    var index = this._findMapping(
-	      needle,
-	      this._originalMappings,
-	      "originalLine",
-	      "originalColumn",
-	      util.compareByOriginalPositions,
-	      util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)
-	    );
-	
-	    if (index >= 0) {
-	      var mapping = this._originalMappings[index];
-	
-	      if (mapping.source === needle.source) {
-	        return {
-	          line: util.getArg(mapping, 'generatedLine', null),
-	          column: util.getArg(mapping, 'generatedColumn', null),
-	          lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)
-	        };
-	      }
-	    }
-	
-	    return {
-	      line: null,
-	      column: null,
-	      lastColumn: null
-	    };
-	  };
-	
-	exports.BasicSourceMapConsumer = BasicSourceMapConsumer;
-	
-	/**
-	 * An IndexedSourceMapConsumer instance represents a parsed source map which
-	 * we can query for information. It differs from BasicSourceMapConsumer in
-	 * that it takes "indexed" source maps (i.e. ones with a "sections" field) as
-	 * input.
-	 *
-	 * The only parameter is a raw source map (either as a JSON string, or already
-	 * parsed to an object). According to the spec for indexed source maps, they
-	 * have the following attributes:
-	 *
-	 *   - version: Which version of the source map spec this map is following.
-	 *   - file: Optional. The generated file this source map is associated with.
-	 *   - sections: A list of section definitions.
-	 *
-	 * Each value under the "sections" field has two fields:
-	 *   - offset: The offset into the original specified at which this section
-	 *       begins to apply, defined as an object with a "line" and "column"
-	 *       field.
-	 *   - map: A source map definition. This source map could also be indexed,
-	 *       but doesn't have to be.
-	 *
-	 * Instead of the "map" field, it's also possible to have a "url" field
-	 * specifying a URL to retrieve a source map from, but that's currently
-	 * unsupported.
-	 *
-	 * Here's an example source map, taken from the source map spec[0], but
-	 * modified to omit a section which uses the "url" field.
-	 *
-	 *  {
-	 *    version : 3,
-	 *    file: "app.js",
-	 *    sections: [{
-	 *      offset: {line:100, column:10},
-	 *      map: {
-	 *        version : 3,
-	 *        file: "section.js",
-	 *        sources: ["foo.js", "bar.js"],
-	 *        names: ["src", "maps", "are", "fun"],
-	 *        mappings: "AAAA,E;;ABCDE;"
-	 *      }
-	 *    }],
-	 *  }
-	 *
-	 * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit#heading=h.535es3xeprgt
-	 */
-	function IndexedSourceMapConsumer(aSourceMap) {
-	  var sourceMap = aSourceMap;
-	  if (typeof aSourceMap === 'string') {
-	    sourceMap = JSON.parse(aSourceMap.replace(/^\)\]\}'/, ''));
-	  }
-	
-	  var version = util.getArg(sourceMap, 'version');
-	  var sections = util.getArg(sourceMap, 'sections');
-	
-	  if (version != this._version) {
-	    throw new Error('Unsupported version: ' + version);
-	  }
-	
-	  this._sources = new ArraySet();
-	  this._names = new ArraySet();
-	
-	  var lastOffset = {
-	    line: -1,
-	    column: 0
-	  };
-	  this._sections = sections.map(function (s) {
-	    if (s.url) {
-	      // The url field will require support for asynchronicity.
-	      // See https://github.com/mozilla/source-map/issues/16
-	      throw new Error('Support for url field in sections not implemented.');
-	    }
-	    var offset = util.getArg(s, 'offset');
-	    var offsetLine = util.getArg(offset, 'line');
-	    var offsetColumn = util.getArg(offset, 'column');
-	
-	    if (offsetLine < lastOffset.line ||
-	        (offsetLine === lastOffset.line && offsetColumn < lastOffset.column)) {
-	      throw new Error('Section offsets must be ordered and non-overlapping.');
-	    }
-	    lastOffset = offset;
-	
-	    return {
-	      generatedOffset: {
-	        // The offset fields are 0-based, but we use 1-based indices when
-	        // encoding/decoding from VLQ.
-	        generatedLine: offsetLine + 1,
-	        generatedColumn: offsetColumn + 1
-	      },
-	      consumer: new SourceMapConsumer(util.getArg(s, 'map'))
-	    }
-	  });
-	}
-	
-	IndexedSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);
-	IndexedSourceMapConsumer.prototype.constructor = SourceMapConsumer;
-	
-	/**
-	 * The version of the source mapping spec that we are consuming.
-	 */
-	IndexedSourceMapConsumer.prototype._version = 3;
-	
-	/**
-	 * The list of original sources.
-	 */
-	Object.defineProperty(IndexedSourceMapConsumer.prototype, 'sources', {
-	  get: function () {
-	    var sources = [];
-	    for (var i = 0; i < this._sections.length; i++) {
-	      for (var j = 0; j < this._sections[i].consumer.sources.length; j++) {
-	        sources.push(this._sections[i].consumer.sources[j]);
-	      }
-	    }
-	    return sources;
-	  }
-	});
-	
-	/**
-	 * Returns the original source, line, and column information for the generated
-	 * source's line and column positions provided. The only argument is an object
-	 * with the following properties:
-	 *
-	 *   - line: The line number in the generated source.
-	 *   - column: The column number in the generated source.
-	 *
-	 * and an object is returned with the following properties:
-	 *
-	 *   - source: The original source file, or null.
-	 *   - line: The line number in the original source, or null.
-	 *   - column: The column number in the original source, or null.
-	 *   - name: The original identifier, or null.
-	 */
-	IndexedSourceMapConsumer.prototype.originalPositionFor =
-	  function IndexedSourceMapConsumer_originalPositionFor(aArgs) {
-	    var needle = {
-	      generatedLine: util.getArg(aArgs, 'line'),
-	      generatedColumn: util.getArg(aArgs, 'column')
-	    };
-	
-	    // Find the section containing the generated position we're trying to map
-	    // to an original position.
-	    var sectionIndex = binarySearch.search(needle, this._sections,
-	      function(needle, section) {
-	        var cmp = needle.generatedLine - section.generatedOffset.generatedLine;
-	        if (cmp) {
-	          return cmp;
-	        }
-	
-	        return (needle.generatedColumn -
-	                section.generatedOffset.generatedColumn);
-	      });
-	    var section = this._sections[sectionIndex];
-	
-	    if (!section) {
-	      return {
-	        source: null,
-	        line: null,
-	        column: null,
-	        name: null
-	      };
-	    }
-	
-	    return section.consumer.originalPositionFor({
-	      line: needle.generatedLine -
-	        (section.generatedOffset.generatedLine - 1),
-	      column: needle.generatedColumn -
-	        (section.generatedOffset.generatedLine === needle.generatedLine
-	         ? section.generatedOffset.generatedColumn - 1
-	         : 0),
-	      bias: aArgs.bias
-	    });
-	  };
-	
-	/**
-	 * Return true if we have the source content for every source in the source
-	 * map, false otherwise.
-	 */
-	IndexedSourceMapConsumer.prototype.hasContentsOfAllSources =
-	  function IndexedSourceMapConsumer_hasContentsOfAllSources() {
-	    return this._sections.every(function (s) {
-	      return s.consumer.hasContentsOfAllSources();
-	    });
-	  };
-	
-	/**
-	 * Returns the original source content. The only argument is the url of the
-	 * original source file. Returns null if no original source content is
-	 * available.
-	 */
-	IndexedSourceMapConsumer.prototype.sourceContentFor =
-	  function IndexedSourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {
-	    for (var i = 0; i < this._sections.length; i++) {
-	      var section = this._sections[i];
-	
-	      var content = section.consumer.sourceContentFor(aSource, true);
-	      if (content) {
-	        return content;
-	      }
-	    }
-	    if (nullOnMissing) {
-	      return null;
-	    }
-	    else {
-	      throw new Error('"' + aSource + '" is not in the SourceMap.');
-	    }
-	  };
-	
-	/**
-	 * Returns the generated line and column information for the original source,
-	 * line, and column positions provided. The only argument is an object with
-	 * the following properties:
-	 *
-	 *   - source: The filename of the original source.
-	 *   - line: The line number in the original source.
-	 *   - column: The column number in the original source.
-	 *
-	 * and an object is returned with the following properties:
-	 *
-	 *   - line: The line number in the generated source, or null.
-	 *   - column: The column number in the generated source, or null.
-	 */
-	IndexedSourceMapConsumer.prototype.generatedPositionFor =
-	  function IndexedSourceMapConsumer_generatedPositionFor(aArgs) {
-	    for (var i = 0; i < this._sections.length; i++) {
-	      var section = this._sections[i];
-	
-	      // Only consider this section if the requested source is in the list of
-	      // sources of the consumer.
-	      if (section.consumer.sources.indexOf(util.getArg(aArgs, 'source')) === -1) {
-	        continue;
-	      }
-	      var generatedPosition = section.consumer.generatedPositionFor(aArgs);
-	      if (generatedPosition) {
-	        var ret = {
-	          line: generatedPosition.line +
-	            (section.generatedOffset.generatedLine - 1),
-	          column: generatedPosition.column +
-	            (section.generatedOffset.generatedLine === generatedPosition.line
-	             ? section.generatedOffset.generatedColumn - 1
-	             : 0)
-	        };
-	        return ret;
-	      }
-	    }
-	
-	    return {
-	      line: null,
-	      column: null
-	    };
-	  };
-	
-	/**
-	 * Parse the mappings in a string in to a data structure which we can easily
-	 * query (the ordered arrays in the `this.__generatedMappings` and
-	 * `this.__originalMappings` properties).
-	 */
-	IndexedSourceMapConsumer.prototype._parseMappings =
-	  function IndexedSourceMapConsumer_parseMappings(aStr, aSourceRoot) {
-	    this.__generatedMappings = [];
-	    this.__originalMappings = [];
-	    for (var i = 0; i < this._sections.length; i++) {
-	      var section = this._sections[i];
-	      var sectionMappings = section.consumer._generatedMappings;
-	      for (var j = 0; j < sectionMappings.length; j++) {
-	        var mapping = sectionMappings[j];
-	
-	        var source = section.consumer._sources.at(mapping.source);
-	        if (section.consumer.sourceRoot !== null) {
-	          source = util.join(section.consumer.sourceRoot, source);
-	        }
-	        this._sources.add(source);
-	        source = this._sources.indexOf(source);
-	
-	        var name = section.consumer._names.at(mapping.name);
-	        this._names.add(name);
-	        name = this._names.indexOf(name);
-	
-	        // The mappings coming from the consumer for the section have
-	        // generated positions relative to the start of the section, so we
-	        // need to offset them to be relative to the start of the concatenated
-	        // generated file.
-	        var adjustedMapping = {
-	          source: source,
-	          generatedLine: mapping.generatedLine +
-	            (section.generatedOffset.generatedLine - 1),
-	          generatedColumn: mapping.generatedColumn +
-	            (section.generatedOffset.generatedLine === mapping.generatedLine
-	            ? section.generatedOffset.generatedColumn - 1
-	            : 0),
-	          originalLine: mapping.originalLine,
-	          originalColumn: mapping.originalColumn,
-	          name: name
-	        };
-	
-	        this.__generatedMappings.push(adjustedMapping);
-	        if (typeof adjustedMapping.originalLine === 'number') {
-	          this.__originalMappings.push(adjustedMapping);
-	        }
-	      }
-	    }
-	
-	    quickSort(this.__generatedMappings, util.compareByGeneratedPositionsDeflated);
-	    quickSort(this.__originalMappings, util.compareByOriginalPositions);
-	  };
-	
-	exports.IndexedSourceMapConsumer = IndexedSourceMapConsumer;
-
-
-/***/ },
-/* 229 */
-/***/ function(module, exports) {
-
-	/* -*- Mode: js; js-indent-level: 2; -*- */
-	/*
-	 * Copyright 2011 Mozilla Foundation and contributors
-	 * Licensed under the New BSD license. See LICENSE or:
-	 * http://opensource.org/licenses/BSD-3-Clause
-	 */
-	
-	exports.GREATEST_LOWER_BOUND = 1;
-	exports.LEAST_UPPER_BOUND = 2;
-	
-	/**
-	 * Recursive implementation of binary search.
-	 *
-	 * @param aLow Indices here and lower do not contain the needle.
-	 * @param aHigh Indices here and higher do not contain the needle.
-	 * @param aNeedle The element being searched for.
-	 * @param aHaystack The non-empty array being searched.
-	 * @param aCompare Function which takes two elements and returns -1, 0, or 1.
-	 * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or
-	 *     'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the
-	 *     closest element that is smaller than or greater than the one we are
-	 *     searching for, respectively, if the exact element cannot be found.
-	 */
-	function recursiveSearch(aLow, aHigh, aNeedle, aHaystack, aCompare, aBias) {
-	  // This function terminates when one of the following is true:
-	  //
-	  //   1. We find the exact element we are looking for.
-	  //
-	  //   2. We did not find the exact element, but we can return the index of
-	  //      the next-closest element.
-	  //
-	  //   3. We did not find the exact element, and there is no next-closest
-	  //      element than the one we are searching for, so we return -1.
-	  var mid = Math.floor((aHigh - aLow) / 2) + aLow;
-	  var cmp = aCompare(aNeedle, aHaystack[mid], true);
-	  if (cmp === 0) {
-	    // Found the element we are looking for.
-	    return mid;
-	  }
-	  else if (cmp > 0) {
-	    // Our needle is greater than aHaystack[mid].
-	    if (aHigh - mid > 1) {
-	      // The element is in the upper half.
-	      return recursiveSearch(mid, aHigh, aNeedle, aHaystack, aCompare, aBias);