Merge inbound to central, a=merge
authorWes Kocher <wkocher@mozilla.com>
Fri, 11 Nov 2016 13:56:45 -0800
changeset 322190 fc104971a4db41e38808e6412bc32e1900172f14
parent 322033 5d1c54f240d077b6b8e141fd44b52a3b694a5dfd (current diff)
parent 322189 db56c201e562b9a377cf04b367b3ed4ba7400a40 (diff)
child 322191 3c7202df78b4e6515085fbeb702ff82d6f8552a2
child 322256 31c113968a618511d13a8123411d2121e64a0132
child 322309 d6a3e31a3deb77ec32d73e0ce336327a803e4873
push id34160
push userkwierso@gmail.com
push dateFri, 11 Nov 2016 22:11:04 +0000
treeherderautoland@3c7202df78b4 [default view] [failures only]
perfherder[talos] [build metrics] [platform microbench] (compared to previous push)
reviewersmerge
milestone52.0a1
first release with
nightly linux32
fc104971a4db / 52.0a1 / 20161112030203 / files
nightly linux64
fc104971a4db / 52.0a1 / 20161112030203 / files
nightly mac
fc104971a4db / 52.0a1 / 20161112030203 / files
nightly win32
fc104971a4db / 52.0a1 / 20161112030203 / files
nightly win64
fc104971a4db / 52.0a1 / 20161112030203 / files
last release without
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
releases
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
Merge inbound to central, a=merge
browser/base/content/browser.css
devtools/client/inspector/shared/style-inspector-overlays.js
js/src/wasm/WasmBinary.cpp
js/src/wasm/WasmBinary.h
layout/reftests/w3c-css/received/css-conditional-3/background-lime.html
layout/reftests/w3c-css/received/css-multicol-1/multicol-basic-ref.html
layout/reftests/w3c-css/received/css-multicol-1/ref-filled-green-100px-square.xht
layout/reftests/w3c-css/received/css-namespaces-3/ref-lime-1-block.xml
layout/reftests/w3c-css/received/css-namespaces-3/ref-lime-1-generic.xml
layout/reftests/w3c-css/received/css-namespaces-3/ref-lime-1.xml
layout/reftests/w3c-css/received/css-namespaces-3/ref-lime-2-generic.xml
layout/reftests/w3c-css/received/css-namespaces-3/ref-lime-2.xml
layout/reftests/w3c-css/received/css-namespaces-3/ref-lime-3.xml
layout/reftests/w3c-css/received/css-namespaces-3/ref-lime-5.xml
layout/reftests/w3c-css/received/css-namespaces-3/ref-lime-6.xml
layout/reftests/w3c-css/received/css-values-3/200-200-green.html
layout/reftests/w3c-css/received/css-values-3/all-green.html
layout/reftests/w3c-css/received/css-values-3/ch-unit-001-ref.html
layout/reftests/w3c-css/received/css-values-3/vh_not_refreshing_on_chrome-ref.html
modules/libpref/init/all.js
testing/web-platform/meta/html/semantics/forms/constraints/form-validation-validity-valueMissing.html.ini
toolkit/components/places/UnifiedComplete.js
toolkit/components/places/tests/unifiedcomplete/head_autocomplete.js
xpcom/tests/TestBase64.cpp
xpcom/tests/TestCallTemplates.cpp
xpcom/tests/TestDeadlockDetector.cpp
xpcom/tests/TestDeadlockDetectorScalability.cpp
xpcom/tests/TestINIParser.cpp
xpcom/tests/TestRacingServiceManager.cpp
xpcom/tests/TestRegistrationOrder.cpp
xpcom/tests/TestSTLWrappers.cpp
xpcom/tests/TestThreadPoolListener.cpp
xpcom/tests/regorder/core/component.js
xpcom/tests/regorder/core/component.manifest
xpcom/tests/regorder/core/component2.js
xpcom/tests/regorder/extension/extComponent.js
xpcom/tests/regorder/extension/extComponent.manifest
xpcom/tests/regorder/extension2.jar
--- a/accessible/tests/mochitest/tree/test_tabbrowser.xul
+++ b/accessible/tests/mochitest/tree/test_tabbrowser.xul
@@ -85,16 +85,25 @@
             {
               // xul:toolbarbutton ("Close current tab")
               role: ROLE_PUSHBUTTON,
               children: []
             }
             );
         } else {
           SimpleTest.ok(true, "Testing Firefox tabbrowser UI.");
+          let newTabChildren = [];
+          if (SpecialPowers.getBoolPref("privacy.userContext.enabled")) {
+            newTabChildren = [
+              {
+                role: ROLE_MENUPOPUP,
+                children: []
+              }
+            ];
+          }
 
           // NB: The (3) buttons are not visible, unless manually hovered,
           //     probably due to size reduction in this test.
           tabsAccTree.children.splice(0, 0,
             {
               // xul:tab ("about:")
               role: ROLE_PAGETAB,
               children: [
@@ -114,17 +123,17 @@
                   role: ROLE_PUSHBUTTON,
                   children: []
                 }
               ]
             },
             {
               // xul:toolbarbutton ("Open a new tab")
               role: ROLE_PUSHBUTTON,
-              children: []
+              children: newTabChildren
             }
             // "List all tabs" dropdown
             // XXX: This child(?) is not present in this test.
             //      I'm not sure why (though probably expected).
             );
         }
 
         testAccessibleTree(tabBrowser().tabContainer, tabsAccTree);
--- a/addon-sdk/source/test/addons/jetpack-addon.ini
+++ b/addon-sdk/source/test/addons/jetpack-addon.ini
@@ -24,16 +24,17 @@ skip-if = true
 [main.xpi]
 [name-in-numbers.xpi]
 [name-in-numbers-plus.xpi]
 [packaging.xpi]
 [packed.xpi]
 [page-mod-debugger-post.xpi]
 [page-mod-debugger-pre.xpi]
 [page-worker.xpi]
+skip-if = true # Bug 1288619 and Bug 1288708
 [places.xpi]
 [predefined-id-with-at.xpi]
 [preferences-branch.xpi]
 [private-browsing-supported.xpi]
 skip-if = true
 [remote.xpi]
 [require.xpi]
 [self.xpi]
--- a/browser/app/profile/firefox.js
+++ b/browser/app/profile/firefox.js
@@ -77,20 +77,26 @@ pref("browser.dictionaries.download.url"
 
 // At startup, should we check to see if the installation
 // date is older than some threshold
 pref("app.update.checkInstallTime", true);
 
 // The number of days a binary is permitted to be old without checking is defined in
 // firefox-branding.js (app.update.checkInstallTime.days)
 
-// The minimum delay in seconds for the timer to fire.
-// default=2 minutes
+// The minimum delay in seconds for the timer to fire between the notification
+// of each consumer of the timer manager.
+// minimum=30 seconds, default=120 seconds, and maximum=300 seconds
 pref("app.update.timerMinimumDelay", 120);
 
+// The minimum delay in milliseconds for the first firing after startup of the timer
+// to notify consumers of the timer manager.
+// minimum=10 seconds, default=30 seconds, and maximum=120 seconds
+pref("app.update.timerFirstInterval", 30000);
+
 // App-specific update preferences
 
 // The interval to check for updates (app.update.interval) is defined in
 // firefox-branding.js
 
 // Alternative windowtype for an application update user interface window. When
 // a window with this windowtype is open the application update service won't
 // open the normal application update user interface window.
@@ -99,22 +105,16 @@ pref("app.update.altwindowtype", "Browse
 // Enables some extra Application Update Logging (can reduce performance)
 pref("app.update.log", false);
 
 // The number of general background check failures to allow before notifying the
 // user of the failure. User initiated update checks always notify the user of
 // the failure.
 pref("app.update.backgroundMaxErrors", 10);
 
-// When |app.update.cert.requireBuiltIn| is true or not specified the
-// final certificate and all certificates the connection is redirected to before
-// the final certificate for the url specified in the |app.update.url|
-// preference must be built-in.
-pref("app.update.cert.requireBuiltIn", false);
-
 // Whether or not app updates are enabled
 pref("app.update.enabled", true);
 
 // If set to true, the Update Service will automatically download updates when
 // app updates are enabled per the app.update.enabled preference and if the user
 // can apply updates.
 pref("app.update.auto", true);
 
--- a/browser/base/content/browser.css
+++ b/browser/base/content/browser.css
@@ -114,16 +114,26 @@ tabbrowser {
 #TabsToolbar[customizing="true"] > #tabbrowser-tabs > .tabbrowser-arrowscrollbox > .tabs-newtab-button {
   visibility: collapse;
 }
 
 #tabbrowser-tabs:not([overflow="true"])[using-closing-tabs-spacer] ~ #alltabs-button {
   visibility: hidden; /* temporary space to keep a tab's close button under the cursor */
 }
 
+.tabs-newtab-button > .toolbarbutton-menu-dropmarker,
+#new-tab-button > .toolbarbutton-menu-dropmarker {
+  display: none;
+}
+
+/* override drop marker image padding */
+.tabs-newtab-button > .toolbarbutton-icon {
+  margin-inline-end: 0;
+}
+
 .tabbrowser-tab {
   -moz-binding: url("chrome://browser/content/tabbrowser.xml#tabbrowser-tab");
 }
 
 .tabbrowser-tab:not([pinned]) {
   -moz-box-flex: 100;
   max-width: 210px;
   min-width: 100px;
@@ -172,16 +182,17 @@ tabbrowser {
   z-index: 2;
   pointer-events: none; /* avoid blocking dragover events on scroll buttons */
 }
 
 .tabbrowser-tabs[movingtab] > .tabbrowser-tab[fadein]:not([selected]) {
   transition: transform 200ms ease-out;
 }
 
+.new-tab-popup,
 #alltabs-popup {
   -moz-binding: url("chrome://browser/content/tabbrowser.xml#tabbrowser-alltabs-popup");
 }
 
 toolbar[printpreview="true"] {
   -moz-binding: url("chrome://global/content/printPreviewBindings.xml#printpreviewtoolbar");
 }
 
--- a/browser/base/content/browser.js
+++ b/browser/base/content/browser.js
@@ -263,93 +263,125 @@ function UpdateBackForwardCommands(aWebN
   }
 }
 
 /**
  * Click-and-Hold implementation for the Back and Forward buttons
  * XXXmano: should this live in toolbarbutton.xml?
  */
 function SetClickAndHoldHandlers() {
-  var timer;
-
-  function openMenu(aButton) {
-    cancelHold(aButton);
-    aButton.firstChild.hidden = false;
-    aButton.open = true;
-  }
-
-  function mousedownHandler(aEvent) {
+  // Bug 414797: Clone the back/forward buttons' context menu into both buttons.
+  let popup = document.getElementById("backForwardMenu").cloneNode(true);
+  popup.removeAttribute("id");
+  // Prevent the back/forward buttons' context attributes from being inherited.
+  popup.setAttribute("context", "");
+
+  let backButton = document.getElementById("back-button");
+  backButton.setAttribute("type", "menu");
+  backButton.appendChild(popup);
+  gClickAndHoldListenersOnElement.add(backButton);
+
+  let forwardButton = document.getElementById("forward-button");
+  popup = popup.cloneNode(true);
+  forwardButton.setAttribute("type", "menu");
+  forwardButton.appendChild(popup);
+  gClickAndHoldListenersOnElement.add(forwardButton);
+}
+
+
+const gClickAndHoldListenersOnElement = {
+  _timers: new Map(),
+
+  _mousedownHandler(aEvent) {
     if (aEvent.button != 0 ||
         aEvent.currentTarget.open ||
         aEvent.currentTarget.disabled)
       return;
 
     // Prevent the menupopup from opening immediately
     aEvent.currentTarget.firstChild.hidden = true;
 
-    aEvent.currentTarget.addEventListener("mouseout", mouseoutHandler, false);
-    aEvent.currentTarget.addEventListener("mouseup", mouseupHandler, false);
-    timer = setTimeout(openMenu, 500, aEvent.currentTarget);
-  }
-
-  function mouseoutHandler(aEvent) {
-    let buttonRect = aEvent.currentTarget.getBoundingClientRect();
-    if (aEvent.clientX >= buttonRect.left &&
-        aEvent.clientX <= buttonRect.right &&
-        aEvent.clientY >= buttonRect.bottom)
-      openMenu(aEvent.currentTarget);
-    else
-      cancelHold(aEvent.currentTarget);
-  }
-
-  function mouseupHandler(aEvent) {
-    cancelHold(aEvent.currentTarget);
-  }
-
-  function cancelHold(aButton) {
-    clearTimeout(timer);
-    aButton.removeEventListener("mouseout", mouseoutHandler, false);
-    aButton.removeEventListener("mouseup", mouseupHandler, false);
-  }
-
-  function clickHandler(aEvent) {
+    aEvent.currentTarget.addEventListener("mouseout", this, false);
+    aEvent.currentTarget.addEventListener("mouseup", this, false);
+    this._timers.set(aEvent.currentTarget, setTimeout((b) => this._openMenu(b), 500, aEvent.currentTarget));
+  },
+
+  _clickHandler(aEvent) {
     if (aEvent.button == 0 &&
         aEvent.target == aEvent.currentTarget &&
         !aEvent.currentTarget.open &&
         !aEvent.currentTarget.disabled) {
       let cmdEvent = document.createEvent("xulcommandevent");
       cmdEvent.initCommandEvent("command", true, true, window, 0,
                                 aEvent.ctrlKey, aEvent.altKey, aEvent.shiftKey,
                                 aEvent.metaKey, null);
       aEvent.currentTarget.dispatchEvent(cmdEvent);
-    }
-  }
-
-  function _addClickAndHoldListenersOnElement(aElm) {
-    aElm.addEventListener("mousedown", mousedownHandler, true);
-    aElm.addEventListener("click", clickHandler, true);
-  }
-
-  // Bug 414797: Clone the back/forward buttons' context menu into both buttons.
-  let popup = document.getElementById("backForwardMenu").cloneNode(true);
-  popup.removeAttribute("id");
-  // Prevent the back/forward buttons' context attributes from being inherited.
-  popup.setAttribute("context", "");
-
-  let backButton = document.getElementById("back-button");
-  backButton.setAttribute("type", "menu");
-  backButton.appendChild(popup);
-  _addClickAndHoldListenersOnElement(backButton);
-
-  let forwardButton = document.getElementById("forward-button");
-  popup = popup.cloneNode(true);
-  forwardButton.setAttribute("type", "menu");
-  forwardButton.appendChild(popup);
-  _addClickAndHoldListenersOnElement(forwardButton);
-}
+
+      // This is here to cancel the XUL default event
+      // dom.click() triggers a command even if there is a click handler
+      // however this can now be prevented with preventDefault().
+      aEvent.preventDefault();
+    }
+  },
+
+  _openMenu(aButton) {
+    this._cancelHold(aButton);
+    aButton.firstChild.hidden = false;
+    aButton.open = true;
+  },
+
+  _mouseoutHandler(aEvent) {
+    let buttonRect = aEvent.currentTarget.getBoundingClientRect();
+    if (aEvent.clientX >= buttonRect.left &&
+        aEvent.clientX <= buttonRect.right &&
+        aEvent.clientY >= buttonRect.bottom)
+      this._openMenu(aEvent.currentTarget);
+    else
+      this._cancelHold(aEvent.currentTarget);
+  },
+
+  _mouseupHandler(aEvent) {
+    this._cancelHold(aEvent.currentTarget);
+  },
+
+  _cancelHold(aButton) {
+    clearTimeout(this._timers.get(aButton));
+    aButton.removeEventListener("mouseout", this, false);
+    aButton.removeEventListener("mouseup", this, false);
+  },
+
+  handleEvent(e) {
+    switch (e.type) {
+      case "mouseout":
+        this._mouseoutHandler(e);
+        break;
+      case "mousedown":
+        this._mousedownHandler(e);
+        break;
+      case "click":
+        this._clickHandler(e);
+        break;
+      case "mouseup":
+        this._mouseupHandler(e);
+        break;
+    }
+  },
+
+  remove(aButton) {
+    aButton.removeEventListener("mousedown", this, true);
+    aButton.removeEventListener("click", this, true);
+  },
+
+  add(aElm) {
+    this._timers.delete(aElm);
+
+    aElm.addEventListener("mousedown", this, true);
+    aElm.addEventListener("click", this, true);
+  }
+};
 
 const gSessionHistoryObserver = {
   observe: function(subject, topic, data)
   {
     if (topic != "browser:purge-session-history")
       return;
 
     var backCommand = document.getElementById("Browser:Back");
--- a/browser/base/content/tabbrowser.xml
+++ b/browser/base/content/tabbrowser.xml
@@ -807,26 +807,28 @@
                 // Don't clear the favicon if this onLocationChange was
                 // triggered by a pushState or a replaceState (bug 550565) or
                 // a hash change (bug 408415).
                 if (aWebProgress.isLoadingDocument && !isSameDocument) {
                   this.mBrowser.mIconURL = null;
                 }
 
                 let unifiedComplete = this.mTabBrowser._unifiedComplete;
+                let userContextId = this.mBrowser.getAttribute("usercontextid") || 0;
                 if (this.mBrowser.registeredOpenURI) {
-                  unifiedComplete.unregisterOpenPage(this.mBrowser.registeredOpenURI);
+                  unifiedComplete.unregisterOpenPage(this.mBrowser.registeredOpenURI,
+                                                     userContextId);
                   delete this.mBrowser.registeredOpenURI;
                 }
                 // Tabs in private windows aren't registered as "Open" so
                 // that they don't appear as switch-to-tab candidates.
                 if (!isBlankPageURL(aLocation.spec) &&
                     (!PrivateBrowsingUtils.isWindowPrivate(window) ||
                     PrivateBrowsingUtils.permanentPrivateBrowsing)) {
-                  unifiedComplete.registerOpenPage(aLocation);
+                  unifiedComplete.registerOpenPage(aLocation, userContextId);
                   this.mBrowser.registeredOpenURI = aLocation;
                 }
               }
 
               if (!this.mBlank) {
                 this._callProgressListeners("onLocationChange",
                                             [aWebProgress, aRequest, aLocation,
                                              aFlags]);
@@ -2586,17 +2588,18 @@
 
             browser.webProgress.removeProgressListener(filter);
 
             const listener = this._tabListeners.get(aTab);
             filter.removeProgressListener(listener);
             listener.destroy();
 
             if (browser.registeredOpenURI && !aAdoptedByTab) {
-              this._unifiedComplete.unregisterOpenPage(browser.registeredOpenURI);
+              this._unifiedComplete.unregisterOpenPage(browser.registeredOpenURI,
+                                                       browser.getAttribute("usercontextid") || 0);
               delete browser.registeredOpenURI;
             }
 
             // We are no longer the primary content area.
             browser.setAttribute("type", "content-targetable");
 
             // Remove this tab as the owner of any other tabs, since it's going away.
             for (let tab of this.tabs) {
@@ -2958,17 +2961,18 @@
 
       <method name="_swapRegisteredOpenURIs">
         <parameter name="aOurBrowser"/>
         <parameter name="aOtherBrowser"/>
         <body>
           <![CDATA[
             // If the current URI is registered as open remove it from the list.
             if (aOurBrowser.registeredOpenURI) {
-              this._unifiedComplete.unregisterOpenPage(aOurBrowser.registeredOpenURI);
+              this._unifiedComplete.unregisterOpenPage(aOurBrowser.registeredOpenURI,
+                                                       aOurBrowser.getAttribute("usercontextid") || 0);
               delete aOurBrowser.registeredOpenURI;
             }
 
             // If the other/new URI is registered as open then copy it over.
             if (aOtherBrowser.registeredOpenURI) {
               aOurBrowser.registeredOpenURI = aOtherBrowser.registeredOpenURI;
               delete aOtherBrowser.registeredOpenURI;
             }
@@ -4869,17 +4873,18 @@
       <destructor>
         <![CDATA[
           Services.obs.removeObserver(this, "live-resize-start", false);
           Services.obs.removeObserver(this, "live-resize-end", false);
 
           for (let tab of this.tabs) {
             let browser = tab.linkedBrowser;
             if (browser.registeredOpenURI) {
-              this._unifiedComplete.unregisterOpenPage(browser.registeredOpenURI);
+              this._unifiedComplete.unregisterOpenPage(browser.registeredOpenURI,
+                                                       browser.getAttribute("usercontextid") || 0);
               delete browser.registeredOpenURI;
             }
             let filter = this._tabFilters.get(tab);
             let listener = this._tabListeners.get(tab);
 
             browser.webProgress.removeProgressListener(filter);
             filter.removeProgressListener(listener);
             listener.destroy();
@@ -5270,17 +5275,17 @@
                            onmouseover="document.getBindingParent(this)._enterNewTab();"
                            onmouseout="document.getBindingParent(this)._leaveNewTab();"
                            tooltip="dynamic-shortcut-tooltip"/>
         <xul:spacer class="closing-tabs-spacer" anonid="closing-tabs-spacer"
                     style="width: 0;"/>
       </xul:arrowscrollbox>
     </content>
 
-    <implementation implements="nsIDOMEventListener">
+    <implementation implements="nsIDOMEventListener, nsIObserver">
       <constructor>
         <![CDATA[
           this.mTabClipWidth = Services.prefs.getIntPref("browser.tabs.tabClipWidth");
 
           var tab = this.firstChild;
           tab.label = this.tabbrowser.mStringBundle.getString("tabs.emptyTabTitle");
           tab.setAttribute("crop", "end");
           tab.setAttribute("onerror", "this.removeAttribute('image');");
@@ -5289,19 +5294,27 @@
           window.addEventListener("load", this, false);
 
           try {
             this._tabAnimationLoggingEnabled = Services.prefs.getBoolPref("browser.tabs.animationLogging.enabled");
           } catch (ex) {
             this._tabAnimationLoggingEnabled = false;
           }
           this._browserNewtabpageEnabled = Services.prefs.getBoolPref("browser.newtabpage.enabled");
+          this.observe(null, "nsPref:changed", "privacy.userContext.enabled");
+          Services.prefs.addObserver("privacy.userContext.enabled", this, false);
         ]]>
       </constructor>
 
+      <destructor>
+        <![CDATA[
+          Services.prefs.removeObserver("privacy.userContext.enabled", this);
+        ]]>
+      </destructor>
+
       <field name="tabbrowser" readonly="true">
         document.getElementById(this.getAttribute("tabbrowser"));
       </field>
 
       <field name="tabbox" readonly="true">
         this.tabbrowser.mTabBox;
       </field>
 
@@ -5317,16 +5330,63 @@
 
       <field name="_firstTab">null</field>
       <field name="_lastTab">null</field>
       <field name="_afterSelectedTab">null</field>
       <field name="_beforeHoveredTab">null</field>
       <field name="_afterHoveredTab">null</field>
       <field name="_hoveredTab">null</field>
 
+      <method name="observe">
+        <parameter name="aSubject"/>
+        <parameter name="aTopic"/>
+        <parameter name="aData"/>
+        <body><![CDATA[
+          switch (aTopic) {
+            case "nsPref:changed":
+              // This is the only pref observed.
+              let containersEnabled = Services.prefs.getBoolPref("privacy.userContext.enabled");
+
+              const newTab = document.getElementById("new-tab-button");
+              const newTab2 = document.getAnonymousElementByAttribute(this, "anonid", "tabs-newtab-button")
+
+              if (containersEnabled) {
+                for (let parent of [newTab, newTab2]) {
+                  if (!parent)
+                    continue;
+                  let popup = document.createElementNS(
+                                "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul",
+                                "menupopup");
+                  if (parent.id) {
+                    popup.id = "newtab-popup";
+                  } else {
+                    popup.setAttribute("anonid", "newtab-popup");
+                  }
+                  popup.className = "new-tab-popup";
+                  popup.setAttribute("position", "after_end");
+                  parent.appendChild(popup);
+
+                  gClickAndHoldListenersOnElement.add(parent);
+                  parent.setAttribute("type", "menu");
+                }
+              } else {
+                for (let parent of [newTab, newTab2]) {
+                  if (!parent)
+                    continue;
+                  gClickAndHoldListenersOnElement.remove(parent);
+                  parent.removeAttribute("type");
+                  parent.firstChild.remove();
+                }
+              }
+
+              break;
+          }
+        ]]></body>
+      </method>
+
       <property name="_isCustomizing" readonly="true">
         <getter>
           let root = document.documentElement;
           return root.getAttribute("customizing") == "true" ||
                  root.getAttribute("customize-exiting") == "true";
         </getter>
       </property>
 
@@ -7020,61 +7080,70 @@
             addEndImage().setAttribute("soundplaying", "true");
         ]]></body>
       </method>
     </implementation>
 
     <handlers>
       <handler event="popupshowing">
       <![CDATA[
-        if (event.target.getAttribute('id') == "alltabs_containersMenuTab") {
+        if (event.target.getAttribute("id") == "alltabs_containersMenuTab") {
           createUserContextMenu(event);
           return;
         }
 
         let containersEnabled = Services.prefs.getBoolPref("privacy.userContext.enabled");
-        document.getElementById("alltabs-popup-separator-1").hidden = !containersEnabled;
-        let containersTab = document.getElementById("alltabs_containersTab");
-
-        containersTab.hidden = !containersEnabled;
-        if (PrivateBrowsingUtils.isWindowPrivate(window)) {
-          containersTab.setAttribute("disabled", "true");
+
+        if (event.target.getAttribute("anonid") == "newtab-popup" ||
+            event.target.id == "newtab-popup") {
+          createUserContextMenu(event);
+        } else {
+          document.getElementById("alltabs-popup-separator-1").hidden = !containersEnabled;
+          let containersTab = document.getElementById("alltabs_containersTab");
+
+          containersTab.hidden = !containersEnabled;
+          if (PrivateBrowsingUtils.isWindowPrivate(window)) {
+            containersTab.setAttribute("disabled", "true");
+          }
+
+          document.getElementById("alltabs_undoCloseTab").disabled =
+            SessionStore.getClosedTabCount(window) == 0;
+
+          var tabcontainer = gBrowser.tabContainer;
+
+          // Listen for changes in the tab bar.
+          tabcontainer.addEventListener("TabAttrModified", this, false);
+          tabcontainer.addEventListener("TabClose", this, false);
+          tabcontainer.mTabstrip.addEventListener("scroll", this, false);
+
+          let tabs = gBrowser.visibleTabs;
+          for (var i = 0; i < tabs.length; i++) {
+            if (!tabs[i].pinned)
+              this._createTabMenuItem(tabs[i]);
+          }
+          this._updateTabsVisibilityStatus();
         }
-
-        document.getElementById("alltabs_undoCloseTab").disabled =
-          SessionStore.getClosedTabCount(window) == 0;
-
-        var tabcontainer = gBrowser.tabContainer;
-
-        // Listen for changes in the tab bar.
-        tabcontainer.addEventListener("TabAttrModified", this, false);
-        tabcontainer.addEventListener("TabClose", this, false);
-        tabcontainer.mTabstrip.addEventListener("scroll", this, false);
-
-        let tabs = gBrowser.visibleTabs;
-        for (var i = 0; i < tabs.length; i++) {
-          if (!tabs[i].pinned)
-            this._createTabMenuItem(tabs[i]);
-        }
-        this._updateTabsVisibilityStatus();
       ]]></handler>
 
       <handler event="popuphidden">
       <![CDATA[
-        if (event.target.getAttribute('id') == "alltabs_containersMenuTab") {
+        if (event.target.getAttribute("id") == "alltabs_containersMenuTab") {
           return;
         }
 
         // clear out the menu popup and remove the listeners
         for (let i = this.childNodes.length - 1; i > 0; i--) {
           let menuItem = this.childNodes[i];
           if (menuItem.tab) {
             menuItem.tab.mCorrespondingMenuitem = null;
             this.removeChild(menuItem);
           }
+          if (menuItem.hasAttribute("usercontextid")) {
+            this.removeChild(menuItem);
+          }
         }
         var tabcontainer = gBrowser.tabContainer;
         tabcontainer.mTabstrip.removeEventListener("scroll", this, false);
         tabcontainer.removeEventListener("TabAttrModified", this, false);
         tabcontainer.removeEventListener("TabClose", this, false);
       ]]></handler>
 
       <handler event="DOMMenuItemActive">
--- a/browser/base/content/test/general/browser.ini
+++ b/browser/base/content/test/general/browser.ini
@@ -493,8 +493,9 @@ skip-if = !e10s || !crashreporter
 [browser_aboutTabCrashed_showForm.js]
 skip-if = !e10s || !crashreporter
 [browser_aboutTabCrashed_withoutDump.js]
 skip-if = !e10s
 [browser_csp_block_all_mixedcontent.js]
 tags = mcb
 [browser_newwindow_focus.js]
 skip-if = (os == "linux" && !e10s) # Bug 1263254 - Perma fails on Linux without e10s for some reason.
+[browser_bug1299667.js]
new file mode 100644
--- /dev/null
+++ b/browser/base/content/test/general/browser_bug1299667.js
@@ -0,0 +1,71 @@
+/* Any copyright is dedicated to the Public Domain.
+   http://creativecommons.org/publicdomain/zero/1.0/ */
+
+const { addObserver, removeObserver } = Cc["@mozilla.org/observer-service;1"].
+                                          getService(Ci.nsIObserverService);
+
+function receive(topic) {
+  return new Promise((resolve, reject) => {
+    let timeout = setTimeout(() => {
+      reject(new Error("Timeout"));
+    }, 90000);
+
+    const observer = {
+      observe: subject => {
+        removeObserver(observer, topic);
+        clearTimeout(timeout);
+        resolve(subject);
+      }
+    };
+    addObserver(observer, topic, false);
+  });
+}
+
+add_task(function* () {
+  yield BrowserTestUtils.openNewForegroundTab(gBrowser, "http://example.com");
+
+  yield ContentTask.spawn(gBrowser.selectedBrowser, {}, function* () {
+    content.history.pushState({}, "2", "2.html");
+  });
+
+  yield receive("sessionstore-state-write-complete");
+
+  // Wait for the session data to be flushed before continuing the test
+  yield new Promise(resolve => SessionStore.getSessionHistory(gBrowser.selectedTab, resolve));
+
+  let backButton = document.getElementById("back-button");
+  let contextMenu = document.getElementById("backForwardMenu");
+
+  info("waiting for the history menu to open");
+
+  let popupShownPromise = BrowserTestUtils.waitForEvent(contextMenu, "popupshown");
+  EventUtils.synthesizeMouseAtCenter(backButton, {type: "contextmenu", button: 2});
+  let event = yield popupShownPromise;
+
+  ok(true, "history menu opened");
+
+  // Wait for the session data to be flushed before continuing the test
+  yield new Promise(resolve => SessionStore.getSessionHistory(gBrowser.selectedTab, resolve));
+
+  is(event.target.children.length, 2, "Two history items");
+
+  let node = event.target.firstChild;
+  is(node.getAttribute("uri"), "http://example.com/2.html", "first item uri");
+  is(node.getAttribute("index"), "1", "first item index");
+  is(node.getAttribute("historyindex"), "0", "first item historyindex");
+
+  node = event.target.lastChild;
+  is(node.getAttribute("uri"), "http://example.com/", "second item uri");
+  is(node.getAttribute("index"), "0", "second item index");
+  is(node.getAttribute("historyindex"), "-1", "second item historyindex");
+
+  let popupHiddenPromise = BrowserTestUtils.waitForEvent(contextMenu, "popuphidden");
+  event.target.hidePopup();
+  yield popupHiddenPromise;
+  info("Hidden popup");
+
+  let onClose = BrowserTestUtils.waitForEvent(gBrowser.tabContainer, "TabClose");
+  yield BrowserTestUtils.removeTab(gBrowser.selectedTab);
+  yield onClose;
+  info("Tab closed");
+});
--- a/browser/base/content/test/general/browser_bug575561.js
+++ b/browser/base/content/test/general/browser_bug575561.js
@@ -32,21 +32,21 @@ add_task(function*() {
   // Tests link to http://www.example.com/browser/browser/base/content/test/general/dummy_page.html
   yield testLink(4, true, false);
 
   // Pinned: Link to a data: URI should not open a new tab
   // Tests link to data:text/html,<!DOCTYPE html><html><body>Another Page</body></html>
   yield testLink(5, true, false);
 
   // Pinned: Link to an about: URI should not open a new tab
-  // Tests link to about:mozilla
+  // Tests link to about:logo
   yield testLink(function(doc) {
     let link = doc.createElement("a");
     link.textContent = "Link to Mozilla";
-    link.href = "about:mozilla";
+    link.href = "about:logo";
     doc.body.appendChild(link);
     return link;
   }, true, false, false, "about:robots");
 });
 
 var waitForPageLoad = Task.async(function*(browser, linkLocation) {
   yield waitForDocLoadComplete();
 
--- a/browser/components/contextualidentity/test/browser/browser.ini
+++ b/browser/components/contextualidentity/test/browser/browser.ini
@@ -9,16 +9,17 @@ support-files =
 
 [browser_aboutURLs.js]
 [browser_eme.js]
 [browser_favicon.js]
 [browser_forgetaboutsite.js]
 [browser_forgetAPI_cookie_getCookiesWithOriginAttributes.js]
 [browser_forgetAPI_EME_forgetThisSite.js]
 [browser_forgetAPI_quota_clearStoragesForPrincipal.js]
+[browser_newtabButton.js]
 [browser_usercontext.js]
 [browser_usercontextid_tabdrop.js]
 skip-if = os == "mac" || os == "win" # Intermittent failure - bug 1268276
 [browser_windowName.js]
 tags = openwindow
 [browser_windowOpen.js]
 tags = openwindow
 [browser_serviceworkers.js]
new file mode 100644
--- /dev/null
+++ b/browser/components/contextualidentity/test/browser/browser_newtabButton.js
@@ -0,0 +1,34 @@
+"use strict";
+
+// Testing that when the user opens the add tab menu and clicks menu items
+// the correct context id is opened
+
+add_task(function* test() {
+  yield SpecialPowers.pushPrefEnv({"set": [
+      ["privacy.userContext.enabled", true]
+  ]});
+
+  let newTab = document.getElementById('tabbrowser-tabs');
+  let newTabButton = document.getAnonymousElementByAttribute(newTab, "anonid", "tabs-newtab-button");
+  ok(newTabButton, "New tab button exists");
+  ok(!newTabButton.hidden, "New tab button is visible");
+  let popup = document.getAnonymousElementByAttribute(newTab, "anonid", "newtab-popup");
+
+  for (let i = 1; i <= 4; i++) {
+    let popupShownPromise = BrowserTestUtils.waitForEvent(popup, "popupshown");
+    EventUtils.synthesizeMouseAtCenter(newTabButton, {type: "mousedown"});
+
+    yield popupShownPromise;
+    let contextIdItem = popup.querySelector(`menuitem[data-usercontextid="${i}"]`);
+
+    ok(contextIdItem, `User context id ${i} exists`);
+
+    let waitForTabPromise = BrowserTestUtils.waitForNewTab(gBrowser);
+    EventUtils.synthesizeMouseAtCenter(contextIdItem, {});
+
+    let tab = yield waitForTabPromise;
+
+    is(tab.getAttribute('usercontextid'), i, `New tab has UCI equal ${i}`);
+    yield BrowserTestUtils.removeTab(tab);
+  }
+});
--- a/browser/components/extensions/ext-contextMenus.js
+++ b/browser/components/extensions/ext-contextMenus.js
@@ -218,18 +218,16 @@ var gMenuBuilder = {
 function contextMenuObserver(subject, topic, data) {
   subject = subject.wrappedJSObject;
   gMenuBuilder.build(subject);
 }
 
 function getContexts(contextData) {
   let contexts = new Set(["all"]);
 
-  contexts.add("page");
-
   if (contextData.inFrame) {
     contexts.add("frame");
   }
 
   if (contextData.isTextSelected) {
     contexts.add("selection");
   }
 
@@ -248,16 +246,20 @@ function getContexts(contextData) {
   if (contextData.onVideo) {
     contexts.add("video");
   }
 
   if (contextData.onAudio) {
     contexts.add("audio");
   }
 
+  if (contexts.size == 1) {
+    contexts.add("page");
+  }
+
   return contexts;
 }
 
 function MenuItem(extension, createProperties, isRoot = false) {
   this.extension = extension;
   this.children = [];
   this.parent = null;
   this.tabManager = TabManager.for(extension);
--- a/browser/components/extensions/test/browser/browser_ext_contextMenus.js
+++ b/browser/components/extensions/test/browser/browser_ext_contextMenus.js
@@ -11,35 +11,40 @@ add_task(function* () {
 
   let extension = ExtensionTestUtils.loadExtension({
     manifest: {
       "permissions": ["contextMenus"],
     },
 
     background: function() {
       browser.contextMenus.create({
-        id: "clickme",
+        id: "clickme-image",
         title: "Click me!",
         contexts: ["image"],
       });
+      browser.contextMenus.create({
+        id: "clickme-page",
+        title: "Click me!",
+        contexts: ["page"],
+      });
       browser.test.notifyPass();
     },
   });
 
   yield extension.startup();
   yield extension.awaitFinish();
 
   let contentAreaContextMenu = yield openContextMenu("#img1");
   let item = contentAreaContextMenu.getElementsByAttribute("label", "Click me!");
   is(item.length, 1, "contextMenu item for image was found");
   yield closeContextMenu();
 
   contentAreaContextMenu = yield openContextMenu("body");
   item = contentAreaContextMenu.getElementsByAttribute("label", "Click me!");
-  is(item.length, 0, "no contextMenu item for image was found");
+  is(item.length, 1, "contextMenu item for page was found");
   yield closeContextMenu();
 
   yield extension.unload();
 
   yield BrowserTestUtils.removeTab(tab1);
 });
 
 add_task(function* () {
--- a/browser/extensions/e10srollout/bootstrap.js
+++ b/browser/extensions/e10srollout/bootstrap.js
@@ -12,17 +12,17 @@ Cu.import("resource://gre/modules/Update
 
  // The amount of people to be part of e10s
 const TEST_THRESHOLD = {
   "beta"    : 0.5,  // 50%
   "release" : 1.0,  // 100%
 };
 
 const ADDON_ROLLOUT_POLICY = {
-  "beta"    : "50allmpc", // Any WebExtension or addon with mpc = true
+  "beta"    : "51alladdons", // Any WebExtension or addon with mpc = true
   "release" : "50allmpc", // Any WebExtension or addon with mpc = true
 };
 
 const PREF_COHORT_SAMPLE       = "e10s.rollout.cohortSample";
 const PREF_COHORT_NAME         = "e10s.rollout.cohort";
 const PREF_E10S_OPTED_IN       = "browser.tabs.remote.autostart";
 const PREF_E10S_FORCE_ENABLED  = "browser.tabs.remote.force-enable";
 const PREF_E10S_FORCE_DISABLED = "browser.tabs.remote.force-disable";
--- a/browser/extensions/e10srollout/install.rdf.in
+++ b/browser/extensions/e10srollout/install.rdf.in
@@ -5,17 +5,17 @@
 
 #filter substitution
 
 <RDF xmlns="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
      xmlns:em="http://www.mozilla.org/2004/em-rdf#">
 
   <Description about="urn:mozilla:install-manifest">
     <em:id>e10srollout@mozilla.org</em:id>
-    <em:version>1.5</em:version>
+    <em:version>1.6</em:version>
     <em:type>2</em:type>
     <em:bootstrap>true</em:bootstrap>
     <em:multiprocessCompatible>true</em:multiprocessCompatible>
 
     <!-- Target Application this theme can install into,
         with minimum and maximum supported versions. -->
     <em:targetApplication>
       <Description>
--- a/browser/locales/en-US/chrome/browser/browser.properties
+++ b/browser/locales/en-US/chrome/browser/browser.properties
@@ -736,24 +736,26 @@ decoder.noCodecs.message = To play video, you may need to install Microsoft’s Media Feature Pack.
 decoder.noCodecsVista.message = To play video, you may need to install Microsoft’s Platform Update Supplement for Windows Vista.
 decoder.noCodecsXP.message = To play video, you may need to enable Adobe’s Primetime Content Decryption Module.
 decoder.noCodecsLinux.message = To play video, you may need to install the required video codecs.
 decoder.noHWAcceleration.message = To improve video quality, you may need to install Microsoft’s Media Feature Pack.
 decoder.noHWAccelerationVista.message = To improve video quality, you may need to install Microsoft’s Platform Update Supplement for Windows Vista.
 decoder.noPulseAudio.message = To play audio, you may need to install the required PulseAudio software.
 decoder.unsupportedLibavcodec.message = libavcodec may be vulnerable or is not supported, and should be updated to play video.
 
-# LOCALIZATION NOTE (captivePortal.infoMessage):
-# This string is shown in a notification bar when we detect a captive portal is blocking network access
+# LOCALIZATION NOTE (captivePortal.infoMessage,
+#                    captivePortal.infoMessage2):
+# Shown in a notification bar when we detect a captive portal is blocking network access
 # and requires the user to log in before browsing. %1$S is replaced with brandShortName.
-captivePortal.infoMessage=This network may require you to login to use the internet. %1$S has opened the login page for you.
+captivePortal.infoMessage = This network may require you to login to use the internet. %1$S has opened the login page for you.
+captivePortal.infoMessage2 = This network may require you to login to use the internet.
 # LOCALIZATION NOTE (captivePortal.showLoginPage):
 # The label for a button shown in the info bar in all tabs except the login page tab.
 # The button shows the portal login page tab when clicked.
-captivePortal.showLoginPage=Show Login Page
+captivePortal.showLoginPage = Show Login Page
 
 permissions.remove.tooltip = Clear this permission and ask again
 
 # LOCALIZATION NOTE (aboutDialog.architecture.*):
 # The sixtyFourBit and thirtyTwoBit strings describe the architecture of the
 # current Firefox build: 32-bit or 64-bit. These strings are used in parentheses
 # between the Firefox version and the "What's new" link in the About dialog,
 # e.g.: "48.0.2 (32-bit) <What's new>" or "51.0a1 (2016-09-05) (64-bit)".
--- a/browser/locales/en-US/chrome/overrides/netError.dtd
+++ b/browser/locales/en-US/chrome/overrides/netError.dtd
@@ -46,16 +46,23 @@
 </ul>
 ">
 
 <!ENTITY generic.title "Oops.">
 <!ENTITY generic.longDesc "
 <p>&brandShortName; can’t load this page for some reason.</p>
 ">
 
+<!ENTITY captivePortal.title "Login to network">
+<!ENTITY captivePortal.longDesc "
+<p>This network may require you to login to access the internet.</p>
+">
+
+<!ENTITY openPortalLoginPage.label "Open Login Page">
+
 <!ENTITY malformedURI.title "The address isn’t valid">
 <!ENTITY malformedURI.longDesc "
 <ul>
   <li>Web addresses are usually written like
     <strong>http://www.example.com/</strong></li>
   <li>Make sure that you’re using forward slashes (i.e.
     <strong>/</strong>).</li>
 </ul>
--- a/caps/nsScriptSecurityManager.cpp
+++ b/caps/nsScriptSecurityManager.cpp
@@ -798,25 +798,37 @@ nsScriptSecurityManager::CheckLoadURIWit
         // exception for foo: linking to view-source:foo for reftests...
         return NS_OK;
     }
 
     // If we get here, check all the schemes can link to each other, from the top down:
     nsCaseInsensitiveCStringComparator stringComparator;
     nsCOMPtr<nsIURI> currentURI = sourceURI;
     nsCOMPtr<nsIURI> currentOtherURI = aTargetURI;
+
+    bool denySameSchemeLinks = false;
+    rv = NS_URIChainHasFlags(aTargetURI, nsIProtocolHandler::URI_SCHEME_NOT_SELF_LINKABLE,
+                             &denySameSchemeLinks);
+    if (NS_FAILED(rv)) return rv;
+
     while (currentURI && currentOtherURI) {
         nsAutoCString scheme, otherScheme;
         currentURI->GetScheme(scheme);
         currentOtherURI->GetScheme(otherScheme);
 
-        // If schemes are not equal, check if the URI flags of the current
-        // target URI allow the current source URI to link to it.
+        // If schemes are not equal, or they're equal but the target URI
+        // is different from the source URI and doesn't always allow linking
+        // from the same scheme, check if the URI flags of the current target
+        // URI allow the current source URI to link to it.
         // The policy is specified by the protocol flags on both URIs.
-        if (!scheme.Equals(otherScheme, stringComparator)) {
+        bool equalExceptRef = false;
+        if (!scheme.Equals(otherScheme, stringComparator) ||
+            (denySameSchemeLinks &&
+             (!NS_SUCCEEDED(currentURI->EqualsExceptRef(currentOtherURI, &equalExceptRef)) ||
+              !equalExceptRef))) {
             return CheckLoadURIFlags(currentURI, currentOtherURI,
                                      sourceBaseURI, targetBaseURI, aFlags);
         }
         // Otherwise... check if we can nest another level:
         nsCOMPtr<nsINestedURI> nestedURI = do_QueryInterface(currentURI);
         nsCOMPtr<nsINestedURI> nestedOtherURI = do_QueryInterface(currentOtherURI);
 
         // If schemes match and neither URI is nested further, we're OK.
--- a/devtools/client/debugger/new/bundle.js
+++ b/devtools/client/debugger/new/bundle.js
@@ -1,9 +1,9 @@
-// Generated from: 5dff6a910f2b9a66c843ea4aac8ebe35e2bf5350 Fix close button size (#1046)
+// Generated from: 8175aacaec380ecf859183ad62bee2a9aef180d2 Disable searching test because it's timing out on try on certain platforms for some reason
 
 var Debugger =
 /******/ (function(modules) { // webpackBootstrap
 /******/ 	// The module cache
 /******/ 	var installedModules = {};
 /******/
 /******/ 	// The require function
 /******/ 	function __webpack_require__(moduleId) {
@@ -66,41 +66,41 @@ var Debugger =
 	var _require2 = __webpack_require__(18);
 	
 	var _require2$client = _require2.client;
 	var getClient = _require2$client.getClient;
 	var firefox = _require2$client.firefox;
 	var renderRoot = _require2.renderRoot;
 	var bootstrap = _require2.bootstrap;
 	
-	var _require3 = __webpack_require__(87);
+	var _require3 = __webpack_require__(89);
 	
 	var getValue = _require3.getValue;
 	var isFirefoxPanel = _require3.isFirefoxPanel;
 	
 	
-	var configureStore = __webpack_require__(236);
-	
-	var reducers = __webpack_require__(247);
-	var selectors = __webpack_require__(257);
-	
-	var App = __webpack_require__(258);
+	var configureStore = __webpack_require__(238);
+	
+	var reducers = __webpack_require__(249);
+	var selectors = __webpack_require__(259);
+	
+	var App = __webpack_require__(260);
 	
 	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__(260), store.dispatch);
-	
-	if (false) {
-	  L10N.setBundle(require("./strings.json"));
+	var actions = bindActionCreators(__webpack_require__(262), store.dispatch);
+	
+	if (!isFirefoxPanel()) {
+	  L10N.setBundle(__webpack_require__(458));
 	}
 	
 	window.appStore = store;
 	
 	// Expose the bound actions so external things can do things like
 	// selecting a source.
 	window.actions = {
 	  selectSource: actions.selectSource,
@@ -109,28 +109,32 @@ var Debugger =
 	
 	function unmountRoot() {
 	  var mount = document.querySelector("#mount");
 	  ReactDOM.unmountComponentAtNode(mount);
 	}
 	
 	if (isFirefoxPanel()) {
 	  (function () {
-	    var sourceMap = __webpack_require__(262);
-	    var prettyPrint = __webpack_require__(274);
+	    var sourceMap = __webpack_require__(264);
+	    var prettyPrint = __webpack_require__(276);
 	
 	    module.exports = {
 	      bootstrap: (_ref) => {
 	        var threadClient = _ref.threadClient;
 	        var tabTarget = _ref.tabTarget;
+	        var toolbox = _ref.toolbox;
+	        var L10N = _ref.L10N;
 	
 	        // TODO (jlast) remove when the panel has L10N
-	        if (!window.L10N) {
-	          window.L10N = __webpack_require__(451);
-	          L10N.setBundle(__webpack_require__(452));
+	        if (L10N) {
+	          window.L10N = L10N;
+	        } else {
+	          window.L10N = __webpack_require__(459);
+	          window.L10N.setBundle(__webpack_require__(458));
 	        }
 	
 	        firefox.setThreadClient(threadClient);
 	        firefox.setTabTarget(tabTarget);
 	        renderRoot(React, ReactDOM, App, store);
 	        return firefox.initPage(actions);
 	      },
 	      destroy: () => {
@@ -1006,43 +1010,43 @@ var Debugger =
 	
 	var Provider = _require2.Provider;
 	
 	var _require3 = __webpack_require__(28);
 	
 	var DevToolsUtils = _require3.DevToolsUtils;
 	var AppConstants = _require3.AppConstants;
 	
-	var _require4 = __webpack_require__(86);
+	var _require4 = __webpack_require__(88);
 	
 	var injectGlobals = _require4.injectGlobals;
 	var debugGlobal = _require4.debugGlobal;
 	
-	var _require5 = __webpack_require__(87);
+	var _require5 = __webpack_require__(89);
 	
 	var setConfig = _require5.setConfig;
 	var isEnabled = _require5.isEnabled;
 	var getValue = _require5.getValue;
 	var isDevelopment = _require5.isDevelopment;
 	
 	
 	setConfig(({"environment":"firefox-panel","baseWorkerURL":"resource://devtools/client/debugger/new/","logging":false,"clientLogging":false,"features":{"tabs":true,"sourceMaps":true,"prettyPrint":true}}));
 	
 	// Set various flags before requiring app code.
 	if (isEnabled("logging.client")) {
 	  DevToolsUtils.dumpn.wantLogging = true;
 	}
 	
-	var client = __webpack_require__(139);
+	var client = __webpack_require__(141);
 	var getClient = client.getClient;
 	var connectClients = client.connectClients;
 	var startDebugging = client.startDebugging;
 	
 	
-	var Root = __webpack_require__(208);
+	var Root = __webpack_require__(210);
 	
 	// 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) {
 	  var theme = getValue("theme");
 	  switch (theme) {
 	    case "dark":
 	      require("./lib/themes/dark-theme.css");break;
@@ -1052,29 +1056,29 @@ var Debugger =
 	      require("./lib/themes/firebug-theme.css");break;
 	  }
 	  document.body.parentNode.classList.add(`theme-${ theme }`);
 	
 	  window.L10N = require("./utils/L10N");
 	}
 	
 	function initApp() {
-	  var configureStore = __webpack_require__(214);
-	  var reducers = __webpack_require__(224);
-	  var LandingPage = __webpack_require__(229);
+	  var configureStore = __webpack_require__(216);
+	  var reducers = __webpack_require__(226);
+	  var LandingPage = __webpack_require__(231);
 	
 	  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__(234), store.dispatch);
+	  var actions = bindActionCreators(__webpack_require__(236), store.dispatch);
 	
 	  if (isDevelopment()) {
 	    AppConstants.DEBUG_JS_MODULES = true;
 	    injectGlobals({ store });
 	  }
 	
 	  return { store, actions, LandingPage };
 	}
@@ -1864,27 +1868,31 @@ var Debugger =
 	var _require4 = __webpack_require__(84);
 	
 	var TargetFactory = _require4.TargetFactory;
 	
 	var DevToolsUtils = __webpack_require__(68);
 	var AppConstants = __webpack_require__(70);
 	var EventEmitter = __webpack_require__(60);
 	var WebsocketTransport = __webpack_require__(85);
+	var Menu = __webpack_require__(86);
+	var MenuItem = __webpack_require__(87);
 	
 	module.exports = {
 	  KeyShortcuts,
 	  PrefsHelper,
 	  DebuggerClient,
 	  DebuggerTransport,
 	  TargetFactory,
 	  DevToolsUtils,
 	  AppConstants,
 	  EventEmitter,
-	  WebsocketTransport
+	  WebsocketTransport,
+	  Menu,
+	  MenuItem
 	};
 
 /***/ },
 /* 29 */
 /***/ 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"); } }; }();
 	
@@ -16345,59 +16353,327 @@ var Debugger =
 	};
 	
 	module.exports = WebSocketDebuggerTransport;
 
 /***/ },
 /* 86 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var _require = __webpack_require__(87);
+	/* -*- 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/. */
+	
+	"use strict";
+	
+	var EventEmitter = __webpack_require__(60);
+	
+	/**
+	 * A partial implementation of the Menu API provided by electron:
+	 * https://github.com/electron/electron/blob/master/docs/api/menu.md.
+	 *
+	 * Extra features:
+	 *  - Emits an 'open' and 'close' event when the menu is opened/closed
+	
+	 * @param String id (non standard)
+	 *        Needed so tests can confirm the XUL implementation is working
+	 */
+	function Menu() {
+	  var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
+	
+	  var _ref$id = _ref.id;
+	  var id = _ref$id === undefined ? null : _ref$id;
+	
+	  this.menuitems = [];
+	  this.id = id;
+	
+	  Object.defineProperty(this, "items", {
+	    get() {
+	      return this.menuitems;
+	    }
+	  });
+	
+	  EventEmitter.decorate(this);
+	}
+	
+	/**
+	 * Add an item to the end of the Menu
+	 *
+	 * @param {MenuItem} menuItem
+	 */
+	Menu.prototype.append = function (menuItem) {
+	  this.menuitems.push(menuItem);
+	};
+	
+	/**
+	 * Add an item to a specified position in the menu
+	 *
+	 * @param {int} pos
+	 * @param {MenuItem} menuItem
+	 */
+	Menu.prototype.insert = function (pos, menuItem) {
+	  throw Error("Not implemented");
+	};
+	
+	/**
+	 * Show the Menu at a specified location on the screen
+	 *
+	 * Missing features:
+	 *   - browserWindow - BrowserWindow (optional) - Default is null.
+	 *   - positioningItem Number - (optional) OS X
+	 *
+	 * @param {int} screenX
+	 * @param {int} screenY
+	 * @param Toolbox toolbox (non standard)
+	 *        Needed so we in which window to inject XUL
+	 */
+	Menu.prototype.popup = function (screenX, screenY, toolbox) {
+	  var doc = toolbox.doc;
+	  var popupset = doc.querySelector("popupset");
+	  // See bug 1285229, on Windows, opening the same popup multiple times in a
+	  // row ends up duplicating the popup. The newly inserted popup doesn't
+	  // dismiss the old one. So remove any previously displayed popup before
+	  // opening a new one.
+	  var popup = popupset.querySelector("menupopup[menu-api=\"true\"]");
+	  if (popup) {
+	    popup.hidePopup();
+	  }
+	
+	  popup = this.createPopup(doc);
+	  popup.setAttribute("menu-api", "true");
+	
+	  if (this.id) {
+	    popup.id = this.id;
+	  }
+	  this._createMenuItems(popup);
+	
+	  // Remove the menu from the DOM once it's hidden.
+	  popup.addEventListener("popuphidden", e => {
+	    if (e.target === popup) {
+	      popup.remove();
+	      this.emit("close", popup);
+	    }
+	  });
+	
+	  popup.addEventListener("popupshown", e => {
+	    if (e.target === popup) {
+	      this.emit("open", popup);
+	    }
+	  });
+	
+	  popupset.appendChild(popup);
+	  popup.openPopupAtScreen(screenX, screenY, true);
+	};
+	
+	Menu.prototype.createPopup = function (doc) {
+	  return doc.createElement("menupopup");
+	};
+	
+	Menu.prototype._createMenuItems = function (parent) {
+	  var doc = parent.ownerDocument;
+	  this.menuitems.forEach(item => {
+	    if (!item.visible) {
+	      return;
+	    }
+	
+	    if (item.submenu) {
+	      var menupopup = doc.createElement("menupopup");
+	      item.submenu._createMenuItems(menupopup);
+	
+	      var menu = doc.createElement("menu");
+	      menu.appendChild(menupopup);
+	      menu.setAttribute("label", item.label);
+	      if (item.disabled) {
+	        menu.setAttribute("disabled", "true");
+	      }
+	      if (item.accesskey) {
+	        menu.setAttribute("accesskey", item.accesskey);
+	      }
+	      if (item.id) {
+	        menu.id = item.id;
+	      }
+	      parent.appendChild(menu);
+	    } else if (item.type === "separator") {
+	      var menusep = doc.createElement("menuseparator");
+	      parent.appendChild(menusep);
+	    } else {
+	      var menuitem = doc.createElement("menuitem");
+	      menuitem.setAttribute("label", item.label);
+	      menuitem.textContent = item.label;
+	      menuitem.addEventListener("command", () => item.click());
+	
+	      if (item.type === "checkbox") {
+	        menuitem.setAttribute("type", "checkbox");
+	      }
+	      if (item.type === "radio") {
+	        menuitem.setAttribute("type", "radio");
+	      }
+	      if (item.disabled) {
+	        menuitem.setAttribute("disabled", "true");
+	      }
+	      if (item.checked) {
+	        menuitem.setAttribute("checked", "true");
+	      }
+	      if (item.accesskey) {
+	        menuitem.setAttribute("accesskey", item.accesskey);
+	      }
+	      if (item.id) {
+	        menuitem.id = item.id;
+	      }
+	
+	      parent.appendChild(menuitem);
+	    }
+	  });
+	};
+	
+	Menu.setApplicationMenu = () => {
+	  throw Error("Not implemented");
+	};
+	
+	Menu.sendActionToFirstResponder = () => {
+	  throw Error("Not implemented");
+	};
+	
+	Menu.buildFromTemplate = () => {
+	  throw Error("Not implemented");
+	};
+	
+	module.exports = Menu;
+
+/***/ },
+/* 87 */
+/***/ 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/. */
+	
+	"use strict";
+	
+	/**
+	 * A partial implementation of the MenuItem API provided by electron:
+	 * https://github.com/electron/electron/blob/master/docs/api/menu-item.md.
+	 *
+	 * Missing features:
+	 *   - id String - Unique within a single menu. If defined then it can be used
+	 *                 as a reference to this item by the position attribute.
+	 *   - role String - Define the action of the menu item; when specified the
+	 *                   click property will be ignored
+	 *   - sublabel String
+	 *   - accelerator Accelerator
+	 *   - icon NativeImage
+	 *   - position String - This field allows fine-grained definition of the
+	 *                       specific location within a given menu.
+	 *
+	 * Implemented features:
+	 *  @param Object options
+	 *    Function click
+	 *      Will be called with click(menuItem, browserWindow) when the menu item
+	 *       is clicked
+	 *    String type
+	 *      Can be normal, separator, submenu, checkbox or radio
+	 *    String label
+	 *    Boolean enabled
+	 *      If false, the menu item will be greyed out and unclickable.
+	 *    Boolean checked
+	 *      Should only be specified for checkbox or radio type menu items.
+	 *    Menu submenu
+	 *      Should be specified for submenu type menu items. If submenu is specified,
+	 *      the type: 'submenu' can be omitted. If the value is not a Menu then it
+	 *      will be automatically converted to one using Menu.buildFromTemplate.
+	 *    Boolean visible
+	 *      If false, the menu item will be entirely hidden.
+	 */
+	
+	function MenuItem() {
+	  var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
+	
+	  var _ref$accesskey = _ref.accesskey;
+	  var accesskey = _ref$accesskey === undefined ? null : _ref$accesskey;
+	  var _ref$checked = _ref.checked;
+	  var checked = _ref$checked === undefined ? false : _ref$checked;
+	  var _ref$click = _ref.click;
+	  var click = _ref$click === undefined ? () => {} : _ref$click;
+	  var _ref$disabled = _ref.disabled;
+	  var disabled = _ref$disabled === undefined ? false : _ref$disabled;
+	  var _ref$label = _ref.label;
+	  var label = _ref$label === undefined ? "" : _ref$label;
+	  var _ref$id = _ref.id;
+	  var id = _ref$id === undefined ? null : _ref$id;
+	  var _ref$submenu = _ref.submenu;
+	  var submenu = _ref$submenu === undefined ? null : _ref$submenu;
+	  var _ref$type = _ref.type;
+	  var type = _ref$type === undefined ? "normal" : _ref$type;
+	  var _ref$visible = _ref.visible;
+	  var visible = _ref$visible === undefined ? true : _ref$visible;
+	
+	  this.accesskey = accesskey;
+	  this.checked = checked;
+	  this.click = click;
+	  this.disabled = disabled;
+	  this.id = id;
+	  this.label = label;
+	  this.submenu = submenu;
+	  this.type = type;
+	  this.visible = visible;
+	}
+	
+	module.exports = MenuItem;
+
+/***/ },
+/* 88 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(89);
 	
 	var isDevelopment = _require.isDevelopment;
 	var isTesting = _require.isTesting;
 	
 	
 	function debugGlobal(field, value) {
 	  if (isDevelopment() || isTesting()) {
 	    window[field] = value;
 	  }
 	}
 	
 	function injectGlobals(_ref) {
 	  var store = _ref.store;
 	
 	  debugGlobal("store", store);
-	  debugGlobal("injectDebuggee", __webpack_require__(138));
+	  debugGlobal("injectDebuggee", __webpack_require__(140));
 	  debugGlobal("serializeStore", () => {
 	    return JSON.parse(JSON.stringify(store.getState()));
 	  });
 	}
 	
 	module.exports = {
 	  debugGlobal,
 	  injectGlobals
 	};
 
 /***/ },
-/* 87 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var feature = __webpack_require__(88);
+/* 89 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var feature = __webpack_require__(90);
 	
 	module.exports = feature;
 
 /***/ },
-/* 88 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var pick = __webpack_require__(89);
+/* 90 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var pick = __webpack_require__(91);
 	var config = void 0;
 	
-	var flag = __webpack_require__(137);
+	var flag = __webpack_require__(139);
 	
 	/**
 	 * Gets a config value for a given key
 	 * e.g "chrome.webSocketPort"
 	 */
 	function getValue(key) {
 	  return pick(config, key);
 	}
@@ -16442,20 +16718,20 @@ var Debugger =
 	  isTesting,
 	  isFirefoxPanel,
 	  isFirefox,
 	  getConfig,
 	  setConfig
 	};
 
 /***/ },
-/* 89 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseGet = __webpack_require__(90);
+/* 91 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseGet = __webpack_require__(92);
 	
 	/**
 	 * Gets the value at `path` of `object`. If the resolved value is
 	 * `undefined`, the `defaultValue` is returned in its place.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 3.7.0
@@ -16481,22 +16757,22 @@ var Debugger =
 	  var result = object == null ? undefined : baseGet(object, path);
 	  return result === undefined ? defaultValue : result;
 	}
 	
 	module.exports = get;
 
 
 /***/ },
-/* 90 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var castPath = __webpack_require__(91),
-	    isKey = __webpack_require__(135),
-	    toKey = __webpack_require__(136);
+/* 92 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var castPath = __webpack_require__(93),
+	    isKey = __webpack_require__(137),
+	    toKey = __webpack_require__(138);
 	
 	/**
 	 * 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.
@@ -16512,38 +16788,38 @@ var Debugger =
 	  }
 	  return (index && index == length) ? object : undefined;
 	}
 	
 	module.exports = baseGet;
 
 
 /***/ },
-/* 91 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isArray = __webpack_require__(92),
-	    stringToPath = __webpack_require__(93);
+/* 93 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isArray = __webpack_require__(94),
+	    stringToPath = __webpack_require__(95);
 	
 	/**
 	 * Casts `value` to a path array if it's not one.
 	 *
 	 * @private
 	 * @param {*} value The value to inspect.
 	 * @returns {Array} Returns the cast property path array.
 	 */
 	function castPath(value) {
 	  return isArray(value) ? value : stringToPath(value);
 	}
 	
 	module.exports = castPath;
 
 
 /***/ },
-/* 92 */
+/* 94 */
 /***/ function(module, exports) {
 
 	/**
 	 * Checks if `value` is classified as an `Array` object.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 0.1.0
@@ -16565,21 +16841,21 @@ var Debugger =
 	 * // => false
 	 */
 	var isArray = Array.isArray;
 	
 	module.exports = isArray;
 
 
 /***/ },
-/* 93 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var memoizeCapped = __webpack_require__(94),
-	    toString = __webpack_require__(130);
+/* 95 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var memoizeCapped = __webpack_require__(96),
+	    toString = __webpack_require__(132);
 	
 	/** Used to match property names within property paths. */
 	var reLeadingDot = /^\./,
 	    rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g;
 	
 	/** Used to match backslashes in property paths. */
 	var reEscapeChar = /\\(\\)?/g;
 	
@@ -16602,20 +16878,20 @@ var Debugger =
 	  });
 	  return result;
 	});
 	
 	module.exports = stringToPath;
 
 
 /***/ },
-/* 94 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var memoize = __webpack_require__(95);
+/* 96 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var memoize = __webpack_require__(97);
 	
 	/** 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`.
 	 *
@@ -16634,20 +16910,20 @@ var Debugger =
 	  var cache = result.cache;
 	  return result;
 	}
 	
 	module.exports = memoizeCapped;
 
 
 /***/ },
-/* 95 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var MapCache = __webpack_require__(96);
+/* 97 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var MapCache = __webpack_require__(98);
 	
 	/** 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
@@ -16713,24 +16989,24 @@ var Debugger =
 	
 	// Expose `MapCache`.
 	memoize.Cache = MapCache;
 	
 	module.exports = memoize;
 
 
 /***/ },
-/* 96 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var mapCacheClear = __webpack_require__(97),
-	    mapCacheDelete = __webpack_require__(124),
-	    mapCacheGet = __webpack_require__(127),
-	    mapCacheHas = __webpack_require__(128),
-	    mapCacheSet = __webpack_require__(129);
+/* 98 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var mapCacheClear = __webpack_require__(99),
+	    mapCacheDelete = __webpack_require__(126),
+	    mapCacheGet = __webpack_require__(129),
+	    mapCacheHas = __webpack_require__(130),
+	    mapCacheSet = __webpack_require__(131);
 	
 	/**
 	 * Creates a map cache object to store key-value pairs.
 	 *
 	 * @private
 	 * @constructor
 	 * @param {Array} [entries] The key-value pairs to cache.
 	 */
@@ -16751,22 +17027,22 @@ var Debugger =
 	MapCache.prototype.get = mapCacheGet;
 	MapCache.prototype.has = mapCacheHas;
 	MapCache.prototype.set = mapCacheSet;
 	
 	module.exports = MapCache;
 
 
 /***/ },
-/* 97 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var Hash = __webpack_require__(98),
-	    ListCache = __webpack_require__(115),
-	    Map = __webpack_require__(123);
+/* 99 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var Hash = __webpack_require__(100),
+	    ListCache = __webpack_require__(117),
+	    Map = __webpack_require__(125);
 	
 	/**
 	 * Removes all key-value entries from the map.
 	 *
 	 * @private
 	 * @name clear
 	 * @memberOf MapCache
 	 */
@@ -16778,24 +17054,24 @@ var Debugger =
 	    'string': new Hash
 	  };
 	}
 	
 	module.exports = mapCacheClear;
 
 
 /***/ },
-/* 98 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var hashClear = __webpack_require__(99),
-	    hashDelete = __webpack_require__(111),
-	    hashGet = __webpack_require__(112),
-	    hashHas = __webpack_require__(113),
-	    hashSet = __webpack_require__(114);
+/* 100 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var hashClear = __webpack_require__(101),
+	    hashDelete = __webpack_require__(113),
+	    hashGet = __webpack_require__(114),
+	    hashHas = __webpack_require__(115),
+	    hashSet = __webpack_require__(116);
 	
 	/**
 	 * Creates a hash object.
 	 *
 	 * @private
 	 * @constructor
 	 * @param {Array} [entries] The key-value pairs to cache.
 	 */
@@ -16816,20 +17092,20 @@ var Debugger =
 	Hash.prototype.get = hashGet;
 	Hash.prototype.has = hashHas;
 	Hash.prototype.set = hashSet;
 	
 	module.exports = Hash;
 
 
 /***/ },
-/* 99 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var nativeCreate = __webpack_require__(100);
+/* 101 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var nativeCreate = __webpack_require__(102);
 	
 	/**
 	 * Removes all key-value entries from the hash.
 	 *
 	 * @private
 	 * @name clear
 	 * @memberOf Hash
 	 */
@@ -16837,33 +17113,33 @@ var Debugger =
 	  this.__data__ = nativeCreate ? nativeCreate(null) : {};
 	  this.size = 0;
 	}
 	
 	module.exports = hashClear;
 
 
 /***/ },
-/* 100 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getNative = __webpack_require__(101);
+/* 102 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getNative = __webpack_require__(103);
 	
 	/* Built-in method references that are verified to be native. */
 	var nativeCreate = getNative(Object, 'create');
 	
 	module.exports = nativeCreate;
 
 
 /***/ },
-/* 101 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseIsNative = __webpack_require__(102),
-	    getValue = __webpack_require__(110);
+/* 103 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseIsNative = __webpack_require__(104),
+	    getValue = __webpack_require__(112);
 	
 	/**
 	 * 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`.
@@ -16872,23 +17148,23 @@ var Debugger =
 	  var value = getValue(object, key);
 	  return baseIsNative(value) ? value : undefined;
 	}
 	
 	module.exports = getNative;
 
 
 /***/ },
-/* 102 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isFunction = __webpack_require__(103),
-	    isMasked = __webpack_require__(105),
-	    isObject = __webpack_require__(104),
-	    toSource = __webpack_require__(109);
+/* 104 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isFunction = __webpack_require__(105),
+	    isMasked = __webpack_require__(107),
+	    isObject = __webpack_require__(106),
+	    toSource = __webpack_require__(111);
 	
 	/**
 	 * Used to match `RegExp`
 	 * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).
 	 */
 	var reRegExpChar = /[\\^$.*+?()[\]{}|]/g;
 	
 	/** Used to detect host constructors (Safari). */
@@ -16925,20 +17201,20 @@ var Debugger =
 	  var pattern = isFunction(value) ? reIsNative : reIsHostCtor;
 	  return pattern.test(toSource(value));
 	}
 	
 	module.exports = baseIsNative;
 
 
 /***/ },
-/* 103 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isObject = __webpack_require__(104);
+/* 105 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isObject = __webpack_require__(106);
 	
 	/** `Object#toString` result references. */
 	var funcTag = '[object Function]',
 	    genTag = '[object GeneratorFunction]',
 	    proxyTag = '[object Proxy]';
 	
 	/** Used for built-in method references. */
 	var objectProto = Object.prototype;
@@ -16973,17 +17249,17 @@ var Debugger =
 	  var tag = isObject(value) ? objectToString.call(value) : '';
 	  return tag == funcTag || tag == genTag || tag == proxyTag;
 	}
 	
 	module.exports = isFunction;
 
 
 /***/ },
-/* 104 */
+/* 106 */
 /***/ function(module, exports) {
 
 	/**
 	 * Checks if `value` is the
 	 * [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
@@ -17010,20 +17286,20 @@ var Debugger =
 	  var type = typeof value;
 	  return value != null && (type == 'object' || type == 'function');
 	}
 	
 	module.exports = isObject;
 
 
 /***/ },
-/* 105 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var coreJsData = __webpack_require__(106);
+/* 107 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var coreJsData = __webpack_require__(108);
 	
 	/** 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) : '';
 	}());
 	
 	/**
@@ -17036,55 +17312,55 @@ var Debugger =
 	function isMasked(func) {
 	  return !!maskSrcKey && (maskSrcKey in func);
 	}
 	
 	module.exports = isMasked;
 
 
 /***/ },
-/* 106 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var root = __webpack_require__(107);
+/* 108 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var root = __webpack_require__(109);
 	
 	/** Used to detect overreaching core-js shims. */
 	var coreJsData = root['__core-js_shared__'];
 	
 	module.exports = coreJsData;
 
 
 /***/ },
-/* 107 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var freeGlobal = __webpack_require__(108);
+/* 109 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var freeGlobal = __webpack_require__(110);
 	
 	/** Detect free variable `self`. */
 	var freeSelf = typeof self == 'object' && self && self.Object === Object && self;
 	
 	/** Used as a reference to the global object. */
 	var root = freeGlobal || freeSelf || Function('return this')();
 	
 	module.exports = root;
 
 
 /***/ },
-/* 108 */
+/* 110 */
 /***/ 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; }())))
 
 /***/ },
-/* 109 */
+/* 111 */
 /***/ function(module, exports) {
 
 	/** Used for built-in method references. */
 	var funcProto = Function.prototype;
 	
 	/** Used to resolve the decompiled source of functions. */
 	var funcToString = funcProto.toString;
 	
@@ -17106,17 +17382,17 @@ var Debugger =
 	  }
 	  return '';
 	}
 	
 	module.exports = toSource;
 
 
 /***/ },
-/* 110 */
+/* 112 */
 /***/ 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.
@@ -17125,17 +17401,17 @@ var Debugger =
 	function getValue(object, key) {
 	  return object == null ? undefined : object[key];
 	}
 	
 	module.exports = getValue;
 
 
 /***/ },
-/* 111 */
+/* 113 */
 /***/ function(module, exports) {
 
 	/**
 	 * Removes `key` and its value from the hash.
 	 *
 	 * @private
 	 * @name delete
 	 * @memberOf Hash
@@ -17148,20 +17424,20 @@ var Debugger =
 	  this.size -= result ? 1 : 0;
 	  return result;
 	}
 	
 	module.exports = hashDelete;
 
 
 /***/ },
-/* 112 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var nativeCreate = __webpack_require__(100);
+/* 114 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var nativeCreate = __webpack_require__(102);
 	
 	/** 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. */
@@ -17184,20 +17460,20 @@ var Debugger =
 	  }
 	  return hasOwnProperty.call(data, key) ? data[key] : undefined;
 	}
 	
 	module.exports = hashGet;
 
 
 /***/ },
-/* 113 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var nativeCreate = __webpack_require__(100);
+/* 115 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var nativeCreate = __webpack_require__(102);
 	
 	/** Used for built-in method references. */
 	var objectProto = Object.prototype;
 	
 	/** Used to check objects for own properties. */
 	var hasOwnProperty = objectProto.hasOwnProperty;
 	
 	/**
@@ -17213,20 +17489,20 @@ var Debugger =
 	  var data = this.__data__;
 	  return nativeCreate ? data[key] !== undefined : hasOwnProperty.call(data, key);
 	}
 	
 	module.exports = hashHas;
 
 
 /***/ },
-/* 114 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var nativeCreate = __webpack_require__(100);
+/* 116 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var nativeCreate = __webpack_require__(102);
 	
 	/** Used to stand-in for `undefined` hash values. */
 	var HASH_UNDEFINED = '__lodash_hash_undefined__';
 	
 	/**
 	 * Sets the hash `key` to `value`.
 	 *
 	 * @private
@@ -17242,24 +17518,24 @@ var Debugger =
 	  data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;
 	  return this;
 	}
 	
 	module.exports = hashSet;
 
 
 /***/ },
-/* 115 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var listCacheClear = __webpack_require__(116),
-	    listCacheDelete = __webpack_require__(117),
-	    listCacheGet = __webpack_require__(120),
-	    listCacheHas = __webpack_require__(121),
-	    listCacheSet = __webpack_require__(122);
+/* 117 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var listCacheClear = __webpack_require__(118),
+	    listCacheDelete = __webpack_require__(119),
+	    listCacheGet = __webpack_require__(122),
+	    listCacheHas = __webpack_require__(123),
+	    listCacheSet = __webpack_require__(124);
 	
 	/**
 	 * Creates an list cache object.
 	 *
 	 * @private
 	 * @constructor
 	 * @param {Array} [entries] The key-value pairs to cache.
 	 */
@@ -17280,17 +17556,17 @@ var Debugger =
 	ListCache.prototype.get = listCacheGet;
 	ListCache.prototype.has = listCacheHas;
 	ListCache.prototype.set = listCacheSet;
 	
 	module.exports = ListCache;
 
 
 /***/ },
-/* 116 */
+/* 118 */
 /***/ function(module, exports) {
 
 	/**
 	 * Removes all key-value entries from the list cache.
 	 *
 	 * @private
 	 * @name clear
 	 * @memberOf ListCache
@@ -17299,20 +17575,20 @@ var Debugger =
 	  this.__data__ = [];
 	  this.size = 0;
 	}
 	
 	module.exports = listCacheClear;
 
 
 /***/ },
-/* 117 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assocIndexOf = __webpack_require__(118);
+/* 119 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assocIndexOf = __webpack_require__(120);
 	
 	/** Used for built-in method references. */
 	var arrayProto = Array.prototype;
 	
 	/** Built-in value references. */
 	var splice = arrayProto.splice;
 	
 	/**
@@ -17340,20 +17616,20 @@ var Debugger =
 	  --this.size;
 	  return true;
 	}
 	
 	module.exports = listCacheDelete;
 
 
 /***/ },
-/* 118 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var eq = __webpack_require__(119);
+/* 120 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var eq = __webpack_require__(121);
 	
 	/**
 	 * Gets the index at which the `key` is found in `array` of key-value pairs.
 	 *
 	 * @private
 	 * @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`.
@@ -17367,17 +17643,17 @@ var Debugger =
 	  }
 	  return -1;
 	}
 	
 	module.exports = assocIndexOf;
 
 
 /***/ },
-/* 119 */
+/* 121 */
 /***/ function(module, exports) {
 
 	/**
 	 * Performs a
 	 * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
 	 * comparison between two values to determine if they are equivalent.
 	 *
 	 * @static
@@ -17410,20 +17686,20 @@ var Debugger =
 	function eq(value, other) {
 	  return value === other || (value !== value && other !== other);
 	}
 	
 	module.exports = eq;
 
 
 /***/ },
-/* 120 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assocIndexOf = __webpack_require__(118);
+/* 122 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assocIndexOf = __webpack_require__(120);
 	
 	/**
 	 * Gets the list cache value for `key`.
 	 *
 	 * @private
 	 * @name get
 	 * @memberOf ListCache
 	 * @param {string} key The key of the value to get.
@@ -17435,20 +17711,20 @@ var Debugger =
 	
 	  return index < 0 ? undefined : data[index][1];
 	}
 	
 	module.exports = listCacheGet;
 
 
 /***/ },
-/* 121 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assocIndexOf = __webpack_require__(118);
+/* 123 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assocIndexOf = __webpack_require__(120);
 	
 	/**
 	 * Checks if a list cache value for `key` exists.
 	 *
 	 * @private
 	 * @name has
 	 * @memberOf ListCache
 	 * @param {string} key The key of the entry to check.
@@ -17457,20 +17733,20 @@ var Debugger =
 	function listCacheHas(key) {
 	  return assocIndexOf(this.__data__, key) > -1;
 	}
 	
 	module.exports = listCacheHas;
 
 
 /***/ },
-/* 122 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assocIndexOf = __webpack_require__(118);
+/* 124 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assocIndexOf = __webpack_require__(120);
 	
 	/**
 	 * Sets the list cache `key` to `value`.
 	 *
 	 * @private
 	 * @name set
 	 * @memberOf ListCache
 	 * @param {string} key The key of the value to set.
@@ -17489,33 +17765,33 @@ var Debugger =
 	  }
 	  return this;
 	}
 	
 	module.exports = listCacheSet;
 
 
 /***/ },
-/* 123 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getNative = __webpack_require__(101),
-	    root = __webpack_require__(107);
+/* 125 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getNative = __webpack_require__(103),
+	    root = __webpack_require__(109);
 	
 	/* Built-in method references that are verified to be native. */
 	var Map = getNative(root, 'Map');
 	
 	module.exports = Map;
 
 
 /***/ },
-/* 124 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getMapData = __webpack_require__(125);
+/* 126 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getMapData = __webpack_require__(127);
 	
 	/**
 	 * Removes `key` and its value from the map.
 	 *
 	 * @private
 	 * @name delete
 	 * @memberOf MapCache
 	 * @param {string} key The key of the value to remove.
@@ -17526,20 +17802,20 @@ var Debugger =
 	  this.size -= result ? 1 : 0;
 	  return result;
 	}
 	
 	module.exports = mapCacheDelete;
 
 
 /***/ },
-/* 125 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isKeyable = __webpack_require__(126);
+/* 127 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isKeyable = __webpack_require__(128);
 	
 	/**
 	 * Gets the data for `map`.
 	 *
 	 * @private
 	 * @param {Object} map The map to query.
 	 * @param {string} key The reference key.
 	 * @returns {*} Returns the map data.
@@ -17550,17 +17826,17 @@ var Debugger =
 	    ? data[typeof key == 'string' ? 'string' : 'hash']
 	    : data.map;
 	}
 	
 	module.exports = getMapData;
 
 
 /***/ },
-/* 126 */
+/* 128 */
 /***/ 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`.
@@ -17571,20 +17847,20 @@ var Debugger =
 	    ? (value !== '__proto__')
 	    : (value === null);
 	}
 	
 	module.exports = isKeyable;
 
 
 /***/ },
-/* 127 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getMapData = __webpack_require__(125);
+/* 129 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getMapData = __webpack_require__(127);
 	
 	/**
 	 * Gets the map value for `key`.
 	 *
 	 * @private
 	 * @name get
 	 * @memberOf MapCache
 	 * @param {string} key The key of the value to get.
@@ -17593,20 +17869,20 @@ var Debugger =
 	function mapCacheGet(key) {
 	  return getMapData(this, key).get(key);
 	}
 	
 	module.exports = mapCacheGet;
 
 
 /***/ },
-/* 128 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getMapData = __webpack_require__(125);
+/* 130 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getMapData = __webpack_require__(127);
 	
 	/**
 	 * Checks if a map value for `key` exists.
 	 *
 	 * @private
 	 * @name has
 	 * @memberOf MapCache
 	 * @param {string} key The key of the entry to check.
@@ -17615,20 +17891,20 @@ var Debugger =
 	function mapCacheHas(key) {
 	  return getMapData(this, key).has(key);
 	}
 	
 	module.exports = mapCacheHas;
 
 
 /***/ },
-/* 129 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getMapData = __webpack_require__(125);
+/* 131 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getMapData = __webpack_require__(127);
 	
 	/**
 	 * Sets the map `key` to `value`.
 	 *
 	 * @private
 	 * @name set
 	 * @memberOf MapCache
 	 * @param {string} key The key of the value to set.
@@ -17643,20 +17919,20 @@ var Debugger =
 	  this.size += data.size == size ? 0 : 1;
 	  return this;
 	}
 	
 	module.exports = mapCacheSet;
 
 
 /***/ },
-/* 130 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseToString = __webpack_require__(131);
+/* 132 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseToString = __webpack_require__(133);
 	
 	/**
 	 * 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
@@ -17677,23 +17953,23 @@ var Debugger =
 	function toString(value) {
 	  return value == null ? '' : baseToString(value);
 	}
 	
 	module.exports = toString;
 
 
 /***/ },
-/* 131 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var Symbol = __webpack_require__(132),
-	    arrayMap = __webpack_require__(133),
-	    isArray = __webpack_require__(92),
-	    isSymbol = __webpack_require__(134);
+/* 133 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var Symbol = __webpack_require__(134),
+	    arrayMap = __webpack_require__(135),
+	    isArray = __webpack_require__(94),
+	    isSymbol = __webpack_require__(136);
 	
 	/** 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;
 	
@@ -17720,29 +17996,29 @@ var Debugger =
 	  var result = (value + '');
 	  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;
 	}
 	
 	module.exports = baseToString;
 
 
 /***/ },
-/* 132 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var root = __webpack_require__(107);
+/* 134 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var root = __webpack_require__(109);
 	
 	/** Built-in value references. */
 	var Symbol = root.Symbol;
 	
 	module.exports = Symbol;
 
 
 /***/ },
-/* 133 */
+/* 135 */
 /***/ function(module, exports) {
 
 	/**
 	 * A specialized version of `_.map` for arrays without support for iteratee
 	 * shorthands.
 	 *
 	 * @private
 	 * @param {Array} [array] The array to iterate over.
@@ -17759,17 +18035,17 @@ var Debugger =
 	  }
 	  return result;
 	}
 	
 	module.exports = arrayMap;
 
 
 /***/ },
-/* 134 */
+/* 136 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var isObjectLike = __webpack_require__(8);
 	
 	/** `Object#toString` result references. */
 	var symbolTag = '[object Symbol]';
 	
 	/** Used for built-in method references. */
@@ -17803,21 +18079,21 @@ var Debugger =
 	  return typeof value == 'symbol' ||
 	    (isObjectLike(value) && objectToString.call(value) == symbolTag);
 	}
 	
 	module.exports = isSymbol;
 
 
 /***/ },
-/* 135 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isArray = __webpack_require__(92),
-	    isSymbol = __webpack_require__(134);
+/* 137 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isArray = __webpack_require__(94),
+	    isSymbol = __webpack_require__(136);
 	
 	/** 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.
 	 *
@@ -17838,20 +18114,20 @@ var Debugger =
 	  return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||
 	    (object != null && value in Object(object));
 	}
 	
 	module.exports = isKey;
 
 
 /***/ },
-/* 136 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isSymbol = __webpack_require__(134);
+/* 138 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isSymbol = __webpack_require__(136);
 	
 	/** 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
@@ -17865,23 +18141,23 @@ var Debugger =
 	  var result = (value + '');
 	  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;
 	}
 	
 	module.exports = toKey;
 
 
 /***/ },
-/* 137 */
+/* 139 */
 /***/ function(module, exports) {
 
 	module.exports = devtoolsRequire("devtools/shared/flags");
 
 /***/ },
-/* 138 */
+/* 140 */
 /***/ function(module, exports) {
 
 	function Debuggee() {
 	  function $(selector) {
 	    var element = document.querySelector(selector);
 	    console.log("$", selector, element);
 	
 	    if (!element) {
@@ -18001,27 +18277,27 @@ var Debugger =
 	  return window.client.debuggeeCommand(debuggeeStatement).then(result => {
 	    injectedDebuggee = result;
 	  });
 	}
 	
 	module.exports = injectDebuggee;
 
 /***/ },
-/* 139 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(140);
+/* 141 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(142);
 	
 	var Task = _require.Task;
 	
-	var firefox = __webpack_require__(141);
-	var chrome = __webpack_require__(203);
-	
-	var _require2 = __webpack_require__(86);
+	var firefox = __webpack_require__(143);
+	var chrome = __webpack_require__(205);
+	
+	var _require2 = __webpack_require__(88);
 	
 	var debugGlobal = _require2.debugGlobal;
 	
 	
 	var clientType = void 0;
 	function getClient() {
 	  if (clientType === "chrome") {
 	    return chrome.clientCommands;
@@ -18069,17 +18345,17 @@ var Debugger =
 	  getClient,
 	  connectClients,
 	  startDebugging,
 	  firefox,
 	  chrome
 	};
 
 /***/ },
-/* 140 */
+/* 142 */
 /***/ 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/. */
 	
@@ -18120,47 +18396,47 @@ var Debugger =
 	      callNext(undefined);
 	    });
 	  }
 	};
 	
 	module.exports = { Task };
 
 /***/ },
-/* 141 */
+/* 143 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var _require = __webpack_require__(28);
 	
 	var DebuggerClient = _require.DebuggerClient;
 	var DebuggerTransport = _require.DebuggerTransport;
 	var TargetFactory = _require.TargetFactory;
 	var WebsocketTransport = _require.WebsocketTransport;
 	
-	var defer = __webpack_require__(142);
-	
-	var _require2 = __webpack_require__(87);
+	var defer = __webpack_require__(144);
+	
+	var _require2 = __webpack_require__(89);
 	
 	var getValue = _require2.getValue;
 	
-	var _require3 = __webpack_require__(143);
+	var _require3 = __webpack_require__(145);
 	
 	var Tab = _require3.Tab;
 	
-	var _require4 = __webpack_require__(200);
+	var _require4 = __webpack_require__(202);
 	
 	var setupCommands = _require4.setupCommands;
 	var clientCommands = _require4.clientCommands;
 	
-	var _require5 = __webpack_require__(201);
+	var _require5 = __webpack_require__(203);
 	
 	var setupEvents = _require5.setupEvents;
 	var clientEvents = _require5.clientEvents;
 	
-	var _require6 = __webpack_require__(202);
+	var _require6 = __webpack_require__(204);
 	
 	var createSource = _require6.createSource;
 	
 	
 	var debuggerClient = null;
 	var threadClient = null;
 	var tabTarget = null;
 	
@@ -18278,17 +18554,17 @@ var Debugger =
 	  getThreadClient,
 	  setThreadClient,
 	  getTabTarget,
 	  setTabTarget,
 	  initPage
 	};
 
 /***/ },
-/* 142 */
+/* 144 */
 /***/ 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];
@@ -18296,20 +18572,20 @@ var Debugger =
 	  return {
 	    resolve: resolve,
 	    reject: reject,
 	    promise: promise
 	  };
 	};
 
 /***/ },
-/* 143 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var t = __webpack_require__(144);
+/* 145 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var t = __webpack_require__(146);
 	
 	var Tab = t.struct({
 	  title: t.String,
 	  url: t.String,
 	  id: t.String,
 	  tab: t.Object,
 	  browser: t.enums.of(["chrome", "firefox"])
 	}, "Tab");
@@ -18359,97 +18635,97 @@ var Debugger =
 	  SourceText,
 	  Location,
 	  Breakpoint,
 	  BreakpointResult,
 	  Frame
 	};
 
 /***/ },
-/* 144 */
+/* 146 */
 /***/ 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__(145);
+	var t = __webpack_require__(147);
 	
 	// types
-	t.Any = __webpack_require__(151);
-	t.Array = __webpack_require__(159);
-	t.Boolean = __webpack_require__(160);
-	t.Date = __webpack_require__(162);
-	t.Error = __webpack_require__(163);
-	t.Function = __webpack_require__(164);
-	t.Nil = __webpack_require__(165);
-	t.Number = __webpack_require__(166);
-	t.Integer = __webpack_require__(168);
+	t.Any = __webpack_require__(153);
+	t.Array = __webpack_require__(161);
+	t.Boolean = __webpack_require__(162);
+	t.Date = __webpack_require__(164);
+	t.Error = __webpack_require__(165);
+	t.Function = __webpack_require__(166);
+	t.Nil = __webpack_require__(167);
+	t.Number = __webpack_require__(168);
+	t.Integer = __webpack_require__(170);
 	t.IntegerT = t.Integer;
-	t.Object = __webpack_require__(174);
-	t.RegExp = __webpack_require__(175);
-	t.String = __webpack_require__(176);
-	t.Type = __webpack_require__(177);
+	t.Object = __webpack_require__(176);
+	t.RegExp = __webpack_require__(177);
+	t.String = __webpack_require__(178);
+	t.Type = __webpack_require__(179);
 	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__(178);
-	t.declare = __webpack_require__(179);
-	t.enums = __webpack_require__(182);
-	t.irreducible = __webpack_require__(152);
-	t.list = __webpack_require__(183);
-	t.maybe = __webpack_require__(184);
-	t.refinement = __webpack_require__(169);
-	t.struct = __webpack_require__(186);
-	t.tuple = __webpack_require__(192);
-	t.union = __webpack_require__(193);
-	t.func = __webpack_require__(194);
-	t.intersection = __webpack_require__(195);
+	t.dict = __webpack_require__(180);
+	t.declare = __webpack_require__(181);
+	t.enums = __webpack_require__(184);
+	t.irreducible = __webpack_require__(154);
+	t.list = __webpack_require__(185);
+	t.maybe = __webpack_require__(186);
+	t.refinement = __webpack_require__(171);
+	t.struct = __webpack_require__(188);
+	t.tuple = __webpack_require__(194);
+	t.union = __webpack_require__(195);
+	t.func = __webpack_require__(196);
+	t.intersection = __webpack_require__(197);
 	t.subtype = t.refinement;
-	t.inter = __webpack_require__(196); // IE8 alias
+	t.inter = __webpack_require__(198); // IE8 alias
 	t['interface'] = t.inter;
 	
 	// functions
 	t.assert = t;
-	t.update = __webpack_require__(198);
-	t.mixin = __webpack_require__(180);
-	t.isType = __webpack_require__(156);
-	t.is = __webpack_require__(173);
-	t.getTypeName = __webpack_require__(155);
-	t.match = __webpack_require__(199);
+	t.update = __webpack_require__(200);
+	t.mixin = __webpack_require__(182);
+	t.isType = __webpack_require__(158);
+	t.is = __webpack_require__(175);
+	t.getTypeName = __webpack_require__(157);
+	t.match = __webpack_require__(201);
 	
 	module.exports = t;
 
 
 /***/ },
-/* 145 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isFunction = __webpack_require__(146);
-	var isNil = __webpack_require__(147);
-	var fail = __webpack_require__(148);
-	var stringify = __webpack_require__(149);
+/* 147 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isFunction = __webpack_require__(148);
+	var isNil = __webpack_require__(149);
+	var fail = __webpack_require__(150);
+	var stringify = __webpack_require__(151);
 	
 	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)';
@@ -18459,44 +18735,44 @@ var Debugger =
 	}
 	
 	assert.fail = fail;
 	assert.stringify = stringify;
 	
 	module.exports = assert;
 
 /***/ },
-/* 146 */
+/* 148 */
 /***/ function(module, exports) {
 
 	module.exports = function isFunction(x) {
 	  return typeof x === 'function';
 	};
 
 /***/ },
-/* 147 */
+/* 149 */
 /***/ function(module, exports) {
 
 	module.exports = function isNil(x) {
 	  return x === null || x === void 0;
 	};
 
 /***/ },
-/* 148 */
+/* 150 */
 /***/ function(module, exports) {
 
 	module.exports = function fail(message) {
 	  throw new TypeError('[tcomb] ' + message);
 	};
 
 /***/ },
-/* 149 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getFunctionName = __webpack_require__(150);
+/* 151 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getFunctionName = __webpack_require__(152);
 	
 	function replacer(key, value) {
 	  if (typeof value === 'function') {
 	    return getFunctionName(value);
 	  }
 	  return value;
 	}
 	
@@ -18505,40 +18781,40 @@ var Debugger =
 	    return JSON.stringify(x, replacer, 2);
 	  }
 	  catch (e) {
 	    return String(x);
 	  }
 	};
 
 /***/ },
-/* 150 */
+/* 152 */
 /***/ function(module, exports) {
 
 	module.exports = function getFunctionName(f) {
 	  return f.displayName || f.name || '<function' + f.length + '>';
 	};
 
 /***/ },
-/* 151 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(152);
+/* 153 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(154);
 	
 	module.exports = irreducible('Any', function () { return true; });
 
 
 /***/ },
-/* 152 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isString = __webpack_require__(153);
-	var isFunction = __webpack_require__(146);
-	var forbidNewOperator = __webpack_require__(154);
+/* 154 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isString = __webpack_require__(155);
+	var isFunction = __webpack_require__(148);
+	var forbidNewOperator = __webpack_require__(156);
 	
 	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)');
 	  }
 	
@@ -18564,185 +18840,185 @@ var Debugger =
 	
 	  Irreducible.is = predicate;
 	
 	  return Irreducible;
 	};
 
 
 /***/ },
-/* 153 */
+/* 155 */
 /***/ function(module, exports) {
 
 	module.exports = function isString(x) {
 	  return typeof x === 'string';
 	};
 
 /***/ },
-/* 154 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var getTypeName = __webpack_require__(155);
+/* 156 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var getTypeName = __webpack_require__(157);
 	
 	module.exports = function forbidNewOperator(x, type) {
 	  assert(!(x instanceof type), function () { return 'Cannot use the new operator to instantiate the type ' + getTypeName(type); });
 	};
 
 /***/ },
-/* 155 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(156);
-	var getFunctionName = __webpack_require__(150);
+/* 157 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(158);
+	var getFunctionName = __webpack_require__(152);
 	
 	module.exports = function getTypeName(ctor) {
 	  if (isType(ctor)) {
 	    return ctor.displayName;
 	  }
 	  return getFunctionName(ctor);
 	};
 
 /***/ },
-/* 156 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isFunction = __webpack_require__(146);
-	var isObject = __webpack_require__(157);
+/* 158 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isFunction = __webpack_require__(148);
+	var isObject = __webpack_require__(159);
 	
 	module.exports = function isType(x) {
 	  return isFunction(x) && isObject(x.meta);
 	};
 
 /***/ },
-/* 157 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isNil = __webpack_require__(147);
-	var isArray = __webpack_require__(158);
-	
-	module.exports = function isObject(x) {
-	  return !isNil(x) && typeof x === 'object' && !isArray(x);
-	};
-
-/***/ },
-/* 158 */
-/***/ function(module, exports) {
-
-	module.exports = function isArray(x) {
-	  return Array.isArray ? Array.isArray(x) : x instanceof Array;
-	};
-
-/***/ },
 /* 159 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(152);
-	var isArray = __webpack_require__(158);
-	
-	module.exports = irreducible('Array', isArray);
-
+	var isNil = __webpack_require__(149);
+	var isArray = __webpack_require__(160);
+	
+	module.exports = function isObject(x) {
+	  return !isNil(x) && typeof x === 'object' && !isArray(x);
+	};
 
 /***/ },
 /* 160 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(152);
-	var isBoolean = __webpack_require__(161);
-	
-	module.exports = irreducible('Boolean', isBoolean);
-
+/***/ function(module, exports) {
+
+	module.exports = function isArray(x) {
+	  return Array.isArray ? Array.isArray(x) : x instanceof Array;
+	};
 
 /***/ },
 /* 161 */
-/***/ function(module, exports) {
-
-	module.exports = function isBoolean(x) {
-	  return x === true || x === false;
-	};
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(154);
+	var isArray = __webpack_require__(160);
+	
+	module.exports = irreducible('Array', isArray);
+
 
 /***/ },
 /* 162 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(152);
-	
-	module.exports = irreducible('Date', function (x) { return x instanceof Date; });
+	var irreducible = __webpack_require__(154);
+	var isBoolean = __webpack_require__(163);
+	
+	module.exports = irreducible('Boolean', isBoolean);
 
 
 /***/ },
 /* 163 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(152);
-	
-	module.exports = irreducible('Error', function (x) { return x instanceof Error; });
-
+/***/ function(module, exports) {
+
+	module.exports = function isBoolean(x) {
+	  return x === true || x === false;
+	};
 
 /***/ },
 /* 164 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(152);
-	var isFunction = __webpack_require__(146);
-	
-	module.exports = irreducible('Function', isFunction);
+	var irreducible = __webpack_require__(154);
+	
+	module.exports = irreducible('Date', function (x) { return x instanceof Date; });
 
 
 /***/ },
 /* 165 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(152);
-	var isNil = __webpack_require__(147);
-	
-	module.exports = irreducible('Nil', isNil);
+	var irreducible = __webpack_require__(154);
+	
+	module.exports = irreducible('Error', function (x) { return x instanceof Error; });
 
 
 /***/ },
 /* 166 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(152);
-	var isNumber = __webpack_require__(167);
-	
-	module.exports = irreducible('Number', isNumber);
+	var irreducible = __webpack_require__(154);
+	var isFunction = __webpack_require__(148);
+	
+	module.exports = irreducible('Function', isFunction);
 
 
 /***/ },
 /* 167 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(154);
+	var isNil = __webpack_require__(149);
+	
+	module.exports = irreducible('Nil', isNil);
+
+
+/***/ },
+/* 168 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(154);
+	var isNumber = __webpack_require__(169);
+	
+	module.exports = irreducible('Number', isNumber);
+
+
+/***/ },
+/* 169 */
 /***/ function(module, exports) {
 
 	module.exports = function isNumber(x) {
 	  return typeof x === 'number' && isFinite(x) && !isNaN(x);
 	};
 
 /***/ },
-/* 168 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var refinement = __webpack_require__(169);
-	var Number = __webpack_require__(166);
+/* 170 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var refinement = __webpack_require__(171);
+	var Number = __webpack_require__(168);
 	
 	module.exports = refinement(Number, function (x) { return x % 1 === 0; }, 'Integer');
 
 
 /***/ },
-/* 169 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var isFunction = __webpack_require__(146);
-	var forbidNewOperator = __webpack_require__(154);
-	var isIdentity = __webpack_require__(171);
-	var create = __webpack_require__(172);
-	var is = __webpack_require__(173);
-	var getTypeName = __webpack_require__(155);
-	var getFunctionName = __webpack_require__(150);
+/* 171 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var isFunction = __webpack_require__(148);
+	var forbidNewOperator = __webpack_require__(156);
+	var isIdentity = __webpack_require__(173);
+	var create = __webpack_require__(174);
+	var is = __webpack_require__(175);
+	var getTypeName = __webpack_require__(157);
+	var getFunctionName = __webpack_require__(152);
 	
 	function getDefaultName(type, predicate) {
 	  return '{' + getTypeName(type) + ' | ' + getFunctionName(predicate) + '}';
 	}
 	
 	function refinement(type, predicate, name) {
 	
 	  if (false) {
@@ -18793,55 +19069,55 @@ var Debugger =
 	  return Refinement;
 	}
 	
 	refinement.getDefaultName = getDefaultName;
 	module.exports = refinement;
 
 
 /***/ },
-/* 170 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isNil = __webpack_require__(147);
-	var isString = __webpack_require__(153);
+/* 172 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isNil = __webpack_require__(149);
+	var isString = __webpack_require__(155);
 	
 	module.exports = function isTypeName(name) {
 	  return isNil(name) || isString(name);
 	};
 
 /***/ },
-/* 171 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var Boolean = __webpack_require__(160);
-	var isType = __webpack_require__(156);
-	var getTypeName = __webpack_require__(155);
+/* 173 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var Boolean = __webpack_require__(162);
+	var isType = __webpack_require__(158);
+	var getTypeName = __webpack_require__(157);
 	
 	// 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;
 	};
 
 /***/ },
-/* 172 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(156);
-	var getFunctionName = __webpack_require__(150);
-	var assert = __webpack_require__(145);
-	var stringify = __webpack_require__(149);
+/* 174 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(158);
+	var getFunctionName = __webpack_require__(152);
+	var assert = __webpack_require__(147);
+	var stringify = __webpack_require__(151);
 	
 	// creates an instance of a type, handling the optional new operator
 	module.exports = function create(type, value, path) {
 	  if (isType(type)) {
 	    return !type.meta.identity && typeof value === 'object' && value !== null ? new type(value, path): type(value, path);
 	  }
 	
 	  if (false) {
@@ -18849,80 +19125,80 @@ var Debugger =
 	    path = path || [getFunctionName(type)];
 	    assert(value instanceof type, function () { return 'Invalid value ' + stringify(value) + ' supplied to ' + path.join('/'); });
 	  }
 	
 	  return value;
 	};
 
 /***/ },
-/* 173 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(156);
+/* 175 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(158);
 	
 	// 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
 	};
 
 
 /***/ },
-/* 174 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(152);
-	var isObject = __webpack_require__(157);
+/* 176 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(154);
+	var isObject = __webpack_require__(159);
 	
 	module.exports = irreducible('Object', isObject);
 
 
 /***/ },
-/* 175 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(152);
-	
-	module.exports = irreducible('RegExp', function (x) { return x instanceof RegExp; });
-
-
-/***/ },
-/* 176 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var irreducible = __webpack_require__(152);
-	var isString = __webpack_require__(153);
-	
-	module.exports = irreducible('String', isString);
-
-
-/***/ },
 /* 177 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var irreducible = __webpack_require__(152);
-	var isType = __webpack_require__(156);
-	
-	module.exports = irreducible('Type', isType);
+	var irreducible = __webpack_require__(154);
+	
+	module.exports = irreducible('RegExp', function (x) { return x instanceof RegExp; });
+
 
 /***/ },
 /* 178 */
 /***/ function(module, exports, __webpack_require__) {
 
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var isFunction = __webpack_require__(146);
-	var getTypeName = __webpack_require__(155);
-	var isIdentity = __webpack_require__(171);
-	var isObject = __webpack_require__(157);
-	var create = __webpack_require__(172);
-	var is = __webpack_require__(173);
+	var irreducible = __webpack_require__(154);
+	var isString = __webpack_require__(155);
+	
+	module.exports = irreducible('String', isString);
+
+
+/***/ },
+/* 179 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var irreducible = __webpack_require__(154);
+	var isType = __webpack_require__(158);
+	
+	module.exports = irreducible('Type', isType);
+
+/***/ },
+/* 180 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var isFunction = __webpack_require__(148);
+	var getTypeName = __webpack_require__(157);
+	var isIdentity = __webpack_require__(173);
+	var isObject = __webpack_require__(159);
+	var create = __webpack_require__(174);
+	var is = __webpack_require__(175);
 	
 	function getDefaultName(domain, codomain) {
 	  return '{[key: ' + getTypeName(domain) + ']: ' + getTypeName(codomain) + '}';
 	}
 	
 	function dict(domain, codomain, name) {
 	
 	  if (false) {
@@ -19003,26 +19279,26 @@ var Debugger =
 	  return Dict;
 	}
 	
 	dict.getDefaultName = getDefaultName;
 	module.exports = dict;
 
 
 /***/ },
-/* 179 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var isType = __webpack_require__(156);
-	var isNil = __webpack_require__(147);
-	var mixin = __webpack_require__(180);
-	var getTypeName = __webpack_require__(155);
-	var isUnion = __webpack_require__(181);
+/* 181 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var isType = __webpack_require__(158);
+	var isNil = __webpack_require__(149);
+	var mixin = __webpack_require__(182);
+	var getTypeName = __webpack_require__(157);
+	var isUnion = __webpack_require__(183);
 	
 	// 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)'; });
@@ -19065,21 +19341,21 @@ var Debugger =
 	  // 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;
 	};
 
 
 /***/ },
-/* 180 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isNil = __webpack_require__(147);
-	var assert = __webpack_require__(145);
+/* 182 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isNil = __webpack_require__(149);
+	var assert = __webpack_require__(147);
 	
 	// 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) {
@@ -19088,34 +19364,34 @@ var Debugger =
 	      }
 	      target[k] = source[k];
 	    }
 	  }
 	  return target;
 	};
 
 /***/ },
-/* 181 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(156);
+/* 183 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(158);
 	
 	module.exports = function isUnion(x) {
 	  return isType(x) && ( x.meta.kind === 'union' );
 	};
 
 /***/ },
-/* 182 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var forbidNewOperator = __webpack_require__(154);
-	var isString = __webpack_require__(153);
-	var isObject = __webpack_require__(157);
+/* 184 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var forbidNewOperator = __webpack_require__(156);
+	var isString = __webpack_require__(155);
+	var isObject = __webpack_require__(159);
 	
 	function getDefaultName(map) {
 	  return Object.keys(map).map(function (k) { return assert.stringify(k); }).join(' | ');
 	}
 	
 	function enums(map, name) {
 	
 	  if (false) {
@@ -19162,27 +19438,27 @@ var Debugger =
 	};
 	
 	enums.getDefaultName = getDefaultName;
 	module.exports = enums;
 	
 
 
 /***/ },
-/* 183 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var isFunction = __webpack_require__(146);
-	var getTypeName = __webpack_require__(155);
-	var isIdentity = __webpack_require__(171);
-	var create = __webpack_require__(172);
-	var is = __webpack_require__(173);
-	var isArray = __webpack_require__(158);
+/* 185 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var isFunction = __webpack_require__(148);
+	var getTypeName = __webpack_require__(157);
+	var isIdentity = __webpack_require__(173);
+	var create = __webpack_require__(174);
+	var is = __webpack_require__(175);
+	var isArray = __webpack_require__(160);
 	
 	function getDefaultName(type) {
 	  return 'Array<' + getTypeName(type) + '>';
 	}
 	
 	function list(type, name) {
 	
 	  if (false) {
@@ -19249,30 +19525,30 @@ var Debugger =
 	  return List;
 	}
 	
 	list.getDefaultName = getDefaultName;
 	module.exports = list;
 
 
 /***/ },
-/* 184 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var isFunction = __webpack_require__(146);
-	var isMaybe = __webpack_require__(185);
-	var isIdentity = __webpack_require__(171);
-	var Any = __webpack_require__(151);
-	var create = __webpack_require__(172);
-	var Nil = __webpack_require__(165);
-	var forbidNewOperator = __webpack_require__(154);
-	var is = __webpack_require__(173);
-	var getTypeName = __webpack_require__(155);
+/* 186 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var isFunction = __webpack_require__(148);
+	var isMaybe = __webpack_require__(187);
+	var isIdentity = __webpack_require__(173);
+	var Any = __webpack_require__(153);
+	var create = __webpack_require__(174);
+	var Nil = __webpack_require__(167);
+	var forbidNewOperator = __webpack_require__(156);
+	var is = __webpack_require__(175);
+	var getTypeName = __webpack_require__(157);
 	
 	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
@@ -19312,41 +19588,41 @@ var Debugger =
 	  return Maybe;
 	}
 	
 	maybe.getDefaultName = getDefaultName;
 	module.exports = maybe;
 
 
 /***/ },
-/* 185 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(156);
+/* 187 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(158);
 	
 	module.exports = function isMaybe(x) {
 	  return isType(x) && ( x.meta.kind === 'maybe' );
 	};
 
 /***/ },
-/* 186 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var String = __webpack_require__(176);
-	var Function = __webpack_require__(164);
-	var isBoolean = __webpack_require__(161);
-	var isObject = __webpack_require__(157);
-	var isNil = __webpack_require__(147);
-	var create = __webpack_require__(172);
-	var getTypeName = __webpack_require__(155);
-	var dict = __webpack_require__(178);
-	var getDefaultInterfaceName = __webpack_require__(187);
-	var extend = __webpack_require__(188);
+/* 188 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var String = __webpack_require__(178);
+	var Function = __webpack_require__(166);
+	var isBoolean = __webpack_require__(163);
+	var isObject = __webpack_require__(159);
+	var isNil = __webpack_require__(149);
+	var create = __webpack_require__(174);
+	var getTypeName = __webpack_require__(157);
+	var dict = __webpack_require__(180);
+	var getDefaultInterfaceName = __webpack_require__(189);
+	var extend = __webpack_require__(190);
 	
 	function getDefaultName(props) {
 	  return 'Struct' + getDefaultInterfaceName(props);
 	}
 	
 	function extendStruct(mixins, name) {
 	  return extend(struct, mixins, name);
 	}
@@ -19450,43 +19726,43 @@ var Debugger =
 	struct.strict = false;
 	struct.getOptions = getOptions;
 	struct.getDefaultName = getDefaultName;
 	struct.extend = extendStruct;
 	module.exports = struct;
 
 
 /***/ },
-/* 187 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getTypeName = __webpack_require__(155);
+/* 189 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getTypeName = __webpack_require__(157);
 	
 	function getDefaultInterfaceName(props) {
 	  return '{' + Object.keys(props).map(function (prop) {
 	    return prop + ': ' + getTypeName(props[prop]);
 	  }).join(', ') + '}';
 	}
 	
 	module.exports = getDefaultInterfaceName;
 
 
 /***/ },
-/* 188 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isFunction = __webpack_require__(146);
-	var isArray = __webpack_require__(158);
-	var mixin = __webpack_require__(180);
-	var isStruct = __webpack_require__(189);
-	var isInterface = __webpack_require__(190);
-	var isObject = __webpack_require__(157);
-	var refinement = __webpack_require__(169);
-	var decompose = __webpack_require__(191);
+/* 190 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isFunction = __webpack_require__(148);
+	var isArray = __webpack_require__(160);
+	var mixin = __webpack_require__(182);
+	var isStruct = __webpack_require__(191);
+	var isInterface = __webpack_require__(192);
+	var isObject = __webpack_require__(159);
+	var refinement = __webpack_require__(171);
+	var decompose = __webpack_require__(193);
 	
 	function compose(predicates, unrefinedType) {
 	  return predicates.reduce(function (type, predicate) {
 	    return refinement(type, predicate);
 	  }, unrefinedType);
 	}
 	
 	function getProps(type) {
@@ -19526,40 +19802,40 @@ var Debugger =
 	  var result = compose(predicates, combinator(props, options));
 	  mixin(result.prototype, prototype);
 	  return result;
 	}
 	
 	module.exports = extend;
 
 /***/ },
-/* 189 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(156);
+/* 191 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(158);
 	
 	module.exports = function isStruct(x) {
 	  return isType(x) && ( x.meta.kind === 'struct' );
 	};
 
 /***/ },
-/* 190 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(156);
+/* 192 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(158);
 	
 	module.exports = function isInterface(x) {
 	  return isType(x) && ( x.meta.kind === 'interface' );
 	};
 
 /***/ },
-/* 191 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isType = __webpack_require__(156);
+/* 193 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isType = __webpack_require__(158);
 	
 	function isRefinement(type) {
 	  return isType(type) && type.meta.kind === 'subtype';
 	}
 	
 	function getPredicates(type) {
 	  return isRefinement(type) ?
 	    [type.meta.predicate].concat(getPredicates(type.meta.type)) :
@@ -19577,27 +19853,27 @@ var Debugger =
 	    predicates: getPredicates(type),
 	    unrefinedType: getUnrefinedType(type)
 	  };
 	}
 	
 	module.exports = decompose;
 
 /***/ },
-/* 192 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var isFunction = __webpack_require__(146);
-	var getTypeName = __webpack_require__(155);
-	var isIdentity = __webpack_require__(171);
-	var isArray = __webpack_require__(158);
-	var create = __webpack_require__(172);
-	var is = __webpack_require__(173);
+/* 194 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var isFunction = __webpack_require__(148);
+	var getTypeName = __webpack_require__(157);
+	var isIdentity = __webpack_require__(173);
+	var isArray = __webpack_require__(160);
+	var create = __webpack_require__(174);
+	var is = __webpack_require__(175);
 	
 	function getDefaultName(types) {
 	  return '[' + types.map(getTypeName).join(', ') + ']';
 	}
 	
 	function tuple(types, name) {
 	
 	  if (false) {
@@ -19665,30 +19941,30 @@ var Debugger =
 	
 	  return Tuple;
 	}
 	
 	tuple.getDefaultName = getDefaultName;
 	module.exports = tuple;
 
 /***/ },
-/* 193 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var isFunction = __webpack_require__(146);
-	var getTypeName = __webpack_require__(155);
-	var isIdentity = __webpack_require__(171);
-	var isArray = __webpack_require__(158);
-	var create = __webpack_require__(172);
-	var is = __webpack_require__(173);
-	var forbidNewOperator = __webpack_require__(154);
-	var isUnion = __webpack_require__(181);
-	var isNil = __webpack_require__(147);
+/* 195 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var isFunction = __webpack_require__(148);
+	var getTypeName = __webpack_require__(157);
+	var isIdentity = __webpack_require__(173);
+	var isArray = __webpack_require__(160);
+	var create = __webpack_require__(174);
+	var is = __webpack_require__(175);
+	var forbidNewOperator = __webpack_require__(156);
+	var isUnion = __webpack_require__(183);
+	var isNil = __webpack_require__(149);
 	
 	function getDefaultName(types) {
 	  return types.map(getTypeName).join(' | ');
 	}
 	
 	function union(types, name) {
 	
 	  if (false) {
@@ -19762,32 +20038,32 @@ var Debugger =
 	}
 	
 	union.getDefaultName = getDefaultName;
 	module.exports = union;
 	
 
 
 /***/ },
-/* 194 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var FunctionType = __webpack_require__(164);
-	var isArray = __webpack_require__(158);
-	var list = __webpack_require__(183);
-	var isObject = __webpack_require__(157);
-	var create = __webpack_require__(172);
-	var isNil = __webpack_require__(147);
-	var isBoolean = __webpack_require__(161);
-	var tuple = __webpack_require__(192);
-	var getFunctionName = __webpack_require__(150);
-	var getTypeName = __webpack_require__(155);
-	var isType = __webpack_require__(156);
+/* 196 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var FunctionType = __webpack_require__(166);
+	var isArray = __webpack_require__(160);
+	var list = __webpack_require__(185);
+	var isObject = __webpack_require__(159);
+	var create = __webpack_require__(174);
+	var isNil = __webpack_require__(149);
+	var isBoolean = __webpack_require__(163);
+	var tuple = __webpack_require__(194);
+	var getFunctionName = __webpack_require__(152);
+	var getTypeName = __webpack_require__(157);
+	var isType = __webpack_require__(158);
 	
 	function getDefaultName(domain, codomain) {
 	  return '(' + domain.map(getTypeName).join(', ') + ') => ' + getTypeName(codomain);
 	}
 	
 	function isInstrumented(f) {
 	  return FunctionType.is(f) && isObject(f.instrumentation);
 	}
@@ -19904,27 +20180,27 @@ var Debugger =
 	}
 	
 	func.getDefaultName = getDefaultName;
 	func.getOptionalArgumentsIndex = getOptionalArgumentsIndex;
 	module.exports = func;
 
 
 /***/ },
-/* 195 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var isFunction = __webpack_require__(146);
-	var isArray = __webpack_require__(158);
-	var forbidNewOperator = __webpack_require__(171);
-	var is = __webpack_require__(173);
-	var getTypeName = __webpack_require__(155);
-	var isIdentity = __webpack_require__(171);
+/* 197 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var isFunction = __webpack_require__(148);
+	var isArray = __webpack_require__(160);
+	var forbidNewOperator = __webpack_require__(173);
+	var is = __webpack_require__(175);
+	var getTypeName = __webpack_require__(157);
+	var isIdentity = __webpack_require__(173);
 	
 	function getDefaultName(types) {
 	  return types.map(getTypeName).join(' & ');
 	}
 	
 	function intersection(types, name) {
 	
 	  if (false) {
@@ -19971,34 +20247,34 @@ var Debugger =
 	}
 	
 	intersection.getDefaultName = getDefaultName;
 	module.exports = intersection;
 	
 
 
 /***/ },
-/* 196 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isTypeName = __webpack_require__(170);
-	var String = __webpack_require__(176);
-	var Function = __webpack_require__(164);
-	var isBoolean = __webpack_require__(161);
-	var isObject = __webpack_require__(157);
-	var isNil = __webpack_require__(147);
-	var create = __webpack_require__(172);
-	var getTypeName = __webpack_require__(155);
-	var dict = __webpack_require__(178);
-	var getDefaultInterfaceName = __webpack_require__(187);
-	var isIdentity = __webpack_require__(171);
-	var is = __webpack_require__(173);
-	var extend = __webpack_require__(188);
-	var assign = __webpack_require__(197);
+/* 198 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isTypeName = __webpack_require__(172);
+	var String = __webpack_require__(178);
+	var Function = __webpack_require__(166);
+	var isBoolean = __webpack_require__(163);
+	var isObject = __webpack_require__(159);
+	var isNil = __webpack_require__(149);
+	var create = __webpack_require__(174);
+	var getTypeName = __webpack_require__(157);
+	var dict = __webpack_require__(180);
+	var getDefaultInterfaceName = __webpack_require__(189);
+	var isIdentity = __webpack_require__(173);
+	var is = __webpack_require__(175);
+	var extend = __webpack_require__(190);
+	var assign = __webpack_require__(199);
 	
 	function extendInterface(mixins, name) {
 	  return extend(inter, mixins, name);
 	}
 	
 	function getOptions(options) {
 	  if (!isObject(options)) {
 	    options = isNil(options) ? {} : { name: options };
@@ -20108,38 +20384,38 @@ var Debugger =
 	inter.strict = false;
 	inter.getOptions = getOptions;
 	inter.getDefaultName = getDefaultInterfaceName;
 	inter.extend = extendInterface;
 	module.exports = inter;
 
 
 /***/ },
-/* 197 */
+/* 199 */
 /***/ function(module, exports) {
 
 	function assign(x, y) {
 	  for (var k in y) {
 	    x[k] = y[k];
 	  }
 	  return x;
 	}
 	
 	module.exports = assign;
 
 /***/ },
-/* 198 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isObject = __webpack_require__(157);
-	var isFunction = __webpack_require__(146);
-	var isArray = __webpack_require__(158);
-	var isNumber = __webpack_require__(167);
-	var assign = __webpack_require__(197);
+/* 200 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isObject = __webpack_require__(159);
+	var isFunction = __webpack_require__(148);
+	var isArray = __webpack_require__(160);
+	var isNumber = __webpack_require__(169);
+	var assign = __webpack_require__(199);
 	
 	function getShallowCopy(x) {
 	  if (isObject(x)) {
 	    if (x instanceof Date || x instanceof RegExp) {
 	      return x;
 	    }
 	    return assign({}, x);
 	  }
@@ -20292,23 +20568,23 @@ var Debugger =
 	  $unshift: $unshift,
 	  $merge: $merge
 	};
 	
 	module.exports = update;
 
 
 /***/ },
-/* 199 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(145);
-	var isFunction = __webpack_require__(146);
-	var isType = __webpack_require__(156);
-	var Any = __webpack_require__(151);
+/* 201 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(147);
+	var isFunction = __webpack_require__(148);
+	var isType = __webpack_require__(158);
+	var Any = __webpack_require__(153);
 	
 	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];
 	
@@ -20332,25 +20608,25 @@ var Debugger =
 	      return f(x);
 	    }
 	  }
 	  assert.fail('Match error');
 	};
 
 
 /***/ },
-/* 200 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(143);
+/* 202 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(145);
 	
 	var BreakpointResult = _require.BreakpointResult;
 	var Location = _require.Location;
 	
-	var defer = __webpack_require__(142);
+	var defer = __webpack_require__(144);
 	
 	var bpClients = void 0;
 	var threadClient = void 0;
 	var tabTarget = void 0;
 	var debuggerClient = void 0;
 	
 	function setupCommands(dependencies) {
 	  threadClient = dependencies.threadClient;
@@ -20431,21 +20707,23 @@ var Debugger =
 	
 	function setBreakpointCondition(breakpointId, location, condition, noSliding) {
 	  var bpClient = bpClients[breakpointId];
 	  bpClients[breakpointId] = null;
 	
 	  return bpClient.setCondition(threadClient, condition, noSliding).then(_bpClient => onNewBreakpoint(location, [{}, _bpClient]));
 	}
 	
-	function evaluate(script) {
+	function evaluate(script, _ref) {
+	  var frameId = _ref.frameId;
+	
 	  var deferred = defer();
 	  tabTarget.activeConsole.evaluateJS(script, result => {
 	    deferred.resolve(result);
-	  });
+	  }, { frameActor: frameId });
 	
 	  return deferred.promise;
 	}
 	
 	function debuggeeCommand(script) {
 	  tabTarget.activeConsole.evaluateJS(script, () => {});
 	
 	  var consoleActor = tabTarget.form.consoleActor;
@@ -20504,17 +20782,17 @@ var Debugger =
 	};
 	
 	module.exports = {
 	  setupCommands,
 	  clientCommands
 	};
 
 /***/ },
-/* 201 */
+/* 203 */
 /***/ 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) {
@@ -20535,17 +20813,17 @@ var Debugger =
 	
 	  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) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
 	
-	var _require = __webpack_require__(202);
+	var _require = __webpack_require__(204);
 	
 	var createFrame = _require.createFrame;
 	var createSource = _require.createSource;
 	
 	
 	var CALL_STACK_PAGE_SIZE = 1000;
 	
 	var threadClient = void 0;
@@ -20573,20 +20851,20 @@ var Debugger =
 	};
 	
 	module.exports = {
 	  setupEvents,
 	  clientEvents
 	};
 
 /***/ },
-/* 202 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(143);
+/* 204 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(145);
 	
 	var Source = _require.Source;
 	var Frame = _require.Frame;
 	var Location = _require.Location;
 	
 	
 	function createFrame(frame) {
 	  var title = void 0;
@@ -20617,44 +20895,44 @@ var Debugger =
 	    isPrettyPrinted: false,
 	    sourceMapURL: source.sourceMapURL
 	  });
 	}
 	
 	module.exports = { createFrame, createSource };
 
 /***/ },
-/* 203 */
+/* 205 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* eslint-disable */
 	
-	var _require = __webpack_require__(204);
+	var _require = __webpack_require__(206);
 	
 	var connect = _require.connect;
 	
-	var defer = __webpack_require__(142);
-	
-	var _require2 = __webpack_require__(143);
+	var defer = __webpack_require__(144);
+	
+	var _require2 = __webpack_require__(145);
 	
 	var Tab = _require2.Tab;
 	
-	var _require3 = __webpack_require__(87);
+	var _require3 = __webpack_require__(89);
 	
 	var isEnabled = _require3.isEnabled;
 	var getValue = _require3.getValue;
 	
-	var networkRequest = __webpack_require__(205);
-	
-	var _require4 = __webpack_require__(206);
+	var networkRequest = __webpack_require__(207);
+	
+	var _require4 = __webpack_require__(208);
 	
 	var setupCommands = _require4.setupCommands;
 	var clientCommands = _require4.clientCommands;
 	
-	var _require5 = __webpack_require__(207);
+	var _require5 = __webpack_require__(209);
 	
 	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.
 	
@@ -20734,23 +21012,23 @@ var Debugger =
 	  connectClient,
 	  clientCommands,
 	  connectNode,
 	  connectTab,
 	  initPage
 	};
 
 /***/ },
-/* 204 */
+/* 206 */
 /***/ function(module, exports) {
 
 	module.exports = {};
 
 /***/ },
-/* 205 */
+/* 207 */
 /***/ function(module, exports) {
 
 	function networkRequest(url, opts) {
 	  return new Promise((resolve, reject) => {
 	    var req = new XMLHttpRequest();
 	
 	    req.addEventListener("readystatechange", () => {
 	      if (req.readyState === XMLHttpRequest.DONE) {
@@ -20774,20 +21052,20 @@ var Debugger =
 	    req.open("GET", url);
 	    req.send();
 	  });
 	}
 	
 	module.exports = networkRequest;
 
 /***/ },
-/* 206 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(143);
+/* 208 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(145);
 	
 	var BreakpointResult = _require.BreakpointResult;
 	var Location = _require.Location;
 	
 	
 	var debuggerAgent = void 0;
 	var runtimeAgent = void 0;
 	var pageAgent = void 0;
@@ -20898,17 +21176,17 @@ var Debugger =
 	};
 	
 	module.exports = {
 	  setupCommands,
 	  clientCommands
 	};
 
 /***/ },
-/* 207 */
+/* 209 */
 /***/ 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,
@@ -20932,17 +21210,17 @@ var Debugger =
 	
 	  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) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
 	
-	var _require = __webpack_require__(143);
+	var _require = __webpack_require__(145);
 	
 	var Source = _require.Source;
 	var Location = _require.Location;
 	var Frame = _require.Frame;
 	
 	
 	var actions = void 0;
 	var pageAgent = void 0;
@@ -21008,46 +21286,46 @@ var Debugger =
 	
 	module.exports = {
 	  setupEvents,
 	  pageEvents,
 	  clientEvents
 	};
 
 /***/ },
-/* 208 */
+/* 210 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
 	var dom = React.DOM;
 	
-	var classnames = __webpack_require__(209);
-	
-	var _require = __webpack_require__(87);
+	var classnames = __webpack_require__(211);
+	
+	var _require = __webpack_require__(89);
 	
 	var getValue = _require.getValue;
 	var isDevelopment = _require.isDevelopment;
 	
 	
-	__webpack_require__(210);
+	__webpack_require__(212);
 	
 	function themeClass() {
 	  var theme = getValue("theme");
 	  return `theme-${ theme }`;
 	}
 	
 	module.exports = function (component) {
 	  return dom.div({
 	    className: classnames("theme-body", { [themeClass()]: isDevelopment() }),
 	    style: { flex: 1 }
 	  }, React.createElement(component));
 	};
 
 /***/ },
-/* 209 */
+/* 211 */
 /***/ 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 */
@@ -21091,57 +21369,57 @@ var Debugger =
 			}.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
 		} else {
 			window.classNames = classNames;
 		}
 	}());
 
 
 /***/ },
-/* 210 */
+/* 212 */
 /***/ function(module, exports) {
 
 	// removed by extract-text-webpack-plugin
 
 /***/ },
-/* 211 */,
-/* 212 */,
 /* 213 */,
-/* 214 */
+/* 214 */,
+/* 215 */,
+/* 216 */
 /***/ 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__(3);
 	
 	var createStore = _require.createStore;
 	var applyMiddleware = _require.applyMiddleware;
 	
-	var _require2 = __webpack_require__(215);
+	var _require2 = __webpack_require__(217);
 	
 	var waitUntilService = _require2.waitUntilService;
 	
-	var _require3 = __webpack_require__(216);
+	var _require3 = __webpack_require__(218);
 	
 	var log = _require3.log;
 	
-	var _require4 = __webpack_require__(217);
+	var _require4 = __webpack_require__(219);
 	
 	var history = _require4.history;
 	
-	var _require5 = __webpack_require__(218);
+	var _require5 = __webpack_require__(220);
 	
 	var promise = _require5.promise;
 	
-	var _require6 = __webpack_require__(223);
+	var _require6 = __webpack_require__(225);
 	
 	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.
@@ -21179,17 +21457,17 @@ var Debugger =
 	  var devtoolsExt = typeof window === "object" && window.devToolsExtension ? window.devToolsExtension() : f => f;
 	
 	  return applyMiddleware.apply(undefined, middleware)(devtoolsExt(createStore));
 	};
 	
 	module.exports = configureStore;
 
 /***/ },
-/* 215 */
+/* 217 */
 /***/ 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";
 	
 	/**
@@ -21252,17 +21530,17 @@ var Debugger =
 	    var result = next(action);
 	    checkPending(action);
 	    return result;
 	  };
 	}
 	exports.waitUntilService = waitUntilService;
 
 /***/ },
-/* 216 */
+/* 218 */
 /***/ function(module, exports) {
 
 	/**
 	 * A middleware that logs all actions coming through the system
 	 * to the console.
 	 */
 	function log(_ref) {
 	  var dispatch = _ref.dispatch;
@@ -21274,24 +21552,24 @@ var Debugger =
 	    console.log(`[DISPATCH ${ action.type }]`, action, truncatedActionText);
 	    next(action);
 	  };
 	}
 	
 	exports.log = log;
 
 /***/ },
-/* 217 */
-/***/ 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__(87);
+/* 219 */
+/***/ 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__(89);
 	
 	var isDevelopment = _require.isDevelopment;
 	
 	/**
 	 * 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.
 	 */
@@ -21308,31 +21586,31 @@ var Debugger =
 	    return next => action => {
 	      log.push(action);
 	      next(action);
 	    };
 	  };
 	};
 
 /***/ },
-/* 218 */
-/***/ 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__(142);
-	
-	var _require = __webpack_require__(219);
+/* 220 */
+/***/ 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__(144);
+	
+	var _require = __webpack_require__(221);
 	
 	var entries = _require.entries;
 	var toObject = _require.toObject;
 	
-	var _require2 = __webpack_require__(221);
+	var _require2 = __webpack_require__(223);
 	
 	var executeSoon = _require2.executeSoon;
 	
 	
 	var PROMISE = exports.PROMISE = "@@dispatch/promise";
 	var seqIdVal = 1;
 	
 	function seqIdGen() {
@@ -21379,30 +21657,30 @@ var Debugger =
 	    });
 	    return deferred.promise;
 	  };
 	}
 	
 	exports.promise = promiseMiddleware;
 
 /***/ },
-/* 219 */
+/* 221 */
 /***/ 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 _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); } }
 	
 	/* -*- 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__(220);
+	var co = __webpack_require__(222);
 	
 	function asPaused(client, func) {
 	  if (client.state != "paused") {
 	    return co(function* () {
 	      yield client.interrupt();
 	      var result = void 0;
 	
 	      try {
@@ -21605,17 +21883,17 @@ var Debugger =
 	  toObject,
 	  mapObject,
 	  compose,
 	  updateObj,
 	  throttle
 	};
 
 /***/ },
-/* 220 */
+/* 222 */
 /***/ function(module, exports) {
 
 	
 	/**
 	 * slice() reference.
 	 */
 	
 	var slice = Array.prototype.slice;
@@ -21848,20 +22126,20 @@ var Debugger =
 	 */
 	
 	function isObject(val) {
 	  return Object == val.constructor;
 	}
 
 
 /***/ },
-/* 221 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(222);
+/* 223 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(224);
 	
 	function reportException(who, exception) {
 	  var msg = who + " threw an exception: ";
 	  console.error(msg, exception);
 	}
 	
 	function executeSoon(fn) {
 	  setTimeout(fn, 0);
@@ -21869,29 +22147,29 @@ var Debugger =
 	
 	module.exports = {
 	  reportException,
 	  executeSoon,
 	  assert
 	};
 
 /***/ },
-/* 222 */
+/* 224 */
 /***/ function(module, exports) {
 
 	function assert(condition, message) {
 	  if (!condition) {
 	    throw new Error("Assertion failure: " + message);
 	  }
 	}
 	
 	module.exports = assert;
 
 /***/ },
-/* 223 */
+/* 225 */
 /***/ 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
@@ -21907,36 +22185,36 @@ var Debugger =
 	    return next => action => {
 	      return typeof action === "function" ? action(makeArgs ? makeArgs(args, getState()) : args) : next(action);
 	    };
 	  };
 	}
 	exports.thunk = thunk;
 
 /***/ },
-/* 224 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var tabs = __webpack_require__(225);
+/* 226 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var tabs = __webpack_require__(227);
 	
 	module.exports = {
 	  tabs
 	};
 
 /***/ },
-/* 225 */
-/***/ 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__(226);
-	var Immutable = __webpack_require__(227);
-	var fromJS = __webpack_require__(228);
+/* 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/. */
+	
+	var constants = __webpack_require__(228);
+	var Immutable = __webpack_require__(229);
+	var fromJS = __webpack_require__(230);
 	
 	var initialState = fromJS({
 	  tabs: {},
 	  selectedTab: null
 	});
 	
 	function update() {
 	  var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
@@ -21972,30 +22250,30 @@ var Debugger =
 	  }
 	
 	  return id;
 	}
 	
 	module.exports = update;
 
 /***/ },
-/* 226 */
+/* 228 */
 /***/ 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/. */
 	
 	exports.ADD_TABS = "ADD_TABS";
 	exports.SELECT_TAB = "SELECT_TAB";
 
 /***/ },
-/* 227 */
+/* 229 */
 /***/ 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
@@ -26969,20 +27247,20 @@ var Debugger =
 	
 	  };
 	
 	  return Immutable;
 	
 	}));
 
 /***/ },
-/* 228 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var Immutable = __webpack_require__(227);
+/* 230 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var Immutable = __webpack_require__(229);
 	
 	// 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();
@@ -27011,36 +27289,36 @@ 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;
 
 /***/ },
-/* 229 */
+/* 231 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
 	
 	var _require = __webpack_require__(19);
 	
 	var connect = _require.connect;
 	
-	var classnames = __webpack_require__(209);
-	
-	var _require2 = __webpack_require__(230);
+	var classnames = __webpack_require__(211);
+	
+	var _require2 = __webpack_require__(232);
 	
 	var getTabs = _require2.getTabs;
 	
 	
-	__webpack_require__(231);
+	__webpack_require__(233);
 	var dom = React.DOM;
 	
-	var ImPropTypes = __webpack_require__(233);
+	var ImPropTypes = __webpack_require__(235);
 	
 	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 firstTimeMessage(title, urlPart) {
@@ -27118,52 +27396,52 @@ var Debugger =
 	      className: "landing-page"
 	    }, this.renderSidebar(), this.renderPanel());
 	  }
 	});
 	
 	module.exports = connect(state => ({ tabs: getTabs(state) }))(LandingPage);
 
 /***/ },
-/* 230 */
+/* 232 */
 /***/ function(module, exports) {
 
 	function getTabs(state) {
 	  return state.tabs.get("tabs");
 	}
 	
 	function getSelectedTab(state) {
 	  return state.tabs.get("selectedTab");
 	}
 	
 	module.exports = {
 	  getTabs,
 	  getSelectedTab
 	};
 
 /***/ },
-/* 231 */
+/* 233 */
 /***/ function(module, exports) {
 
 	// removed by extract-text-webpack-plugin
 
 /***/ },
-/* 232 */,
-/* 233 */
+/* 234 */,
+/* 235 */
 /***/ 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__(227);
+	var Immutable = __webpack_require__(229);
 	
 	var ANONYMOUS = "<<anonymous>>";
 	
 	var ImmutablePropTypes = {
 	  listOf: createListOfTypeChecker,
 	  mapOf: createMapOfTypeChecker,
 	  orderedMapOf: createOrderedMapOfTypeChecker,
 	  setOf: createSetOfTypeChecker,
@@ -27346,39 +27624,39 @@ var Debugger =
 	
 	function createMapContainsChecker(shapeTypes) {
 	  return createShapeTypeChecker(shapeTypes, "Map", Immutable.Map.isMap);
 	}
 	
 	module.exports = ImmutablePropTypes;
 
 /***/ },
-/* 234 */
-/***/ function(module, exports, __webpack_require__) {
-
-	
-	var tabs = __webpack_require__(235);
+/* 236 */
+/***/ function(module, exports, __webpack_require__) {
+
+	
+	var tabs = __webpack_require__(237);
 	
 	module.exports = Object.assign({}, tabs);
 
 /***/ },
-/* 235 */
+/* 237 */
 /***/ 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__(226);
+	var constants = __webpack_require__(228);
 	
 	/**
 	 * @typedef {Object} TabAction
 	 * @memberof actions/tabs
 	 * @static
 	 * @property {number} type The type of Action
 	 * @property {number} value The payload of the Action
 	 */
@@ -27412,62 +27690,73 @@ var Debugger =
 	}
 	
 	module.exports = {
 	  newTabs,
 	  selectTab
 	};
 
 /***/ },
-/* 236 */
+/* 238 */
 /***/ 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 store utils
+	 * @module utils/create-store
+	 */
+	
 	var _require = __webpack_require__(3);
 	
 	var createStore = _require.createStore;
 	var applyMiddleware = _require.applyMiddleware;
 	
-	var _require2 = __webpack_require__(237);
+	var _require2 = __webpack_require__(239);
 	
 	var waitUntilService = _require2.waitUntilService;
 	
-	var _require3 = __webpack_require__(238);
+	var _require3 = __webpack_require__(240);
 	
 	var log = _require3.log;
 	
-	var _require4 = __webpack_require__(239);
+	var _require4 = __webpack_require__(241);
 	
 	var history = _require4.history;
 	
-	var _require5 = __webpack_require__(240);
+	var _require5 = __webpack_require__(242);
 	
 	var promise = _require5.promise;
 	
-	var _require6 = __webpack_require__(246);
+	var _require6 = __webpack_require__(248);
 	
 	var thunk = _require6.thunk;
 	
+	/**
+	 * @memberof utils/create-store
+	 * @static
+	 */
 	
 	/**
 	 * 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
+	 * @memberof utils/create-store
+	 * @static
 	 */
 	var configureStore = function () {
 	  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
@@ -27491,17 +27780,17 @@ var Debugger =
 	  var devtoolsExt = typeof window === "object" && window.devToolsExtension ? window.devToolsExtension() : f => f;
 	
 	  return applyMiddleware.apply(undefined, middleware)(devtoolsExt(createStore));
 	};
 	
 	module.exports = configureStore;
 
 /***/ },
-/* 237 */
+/* 239 */
 /***/ 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/. */
 	
 	/**
 	 * A middleware which acts like a service, because it is stateful
@@ -27562,17 +27851,17 @@ var Debugger =
 	    var result = next(action);
 	    checkPending(action);
 	    return result;
 	  };
 	}
 	exports.waitUntilService = waitUntilService;
 
 /***/ },
-/* 238 */
+/* 240 */
 /***/ function(module, exports) {
 
 	/**
 	 * A middleware that logs all actions coming through the system
 	 * to the console.
 	 */
 	function log(_ref) {
 	  var dispatch = _ref.dispatch;
@@ -27584,24 +27873,24 @@ var Debugger =
 	    console.log(`[DISPATCH ${ action.type }]`, action, truncatedActionText);
 	    next(action);
 	  };
 	}
 	
 	exports.log = log;
 
 /***/ },
-/* 239 */
-/***/ 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__(87);
+/* 241 */
+/***/ 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__(89);
 	
 	var isDevelopment = _require.isDevelopment;
 	
 	/**
 	 * 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.
 	 */
@@ -27618,31 +27907,31 @@ var Debugger =
 	    return next => action => {
 	      log.push(action);
 	      next(action);
 	    };
 	  };
 	};
 
 /***/ },
-/* 240 */
-/***/ 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__(241);
-	
-	var _require = __webpack_require__(242);
+/* 242 */
+/***/ 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__(243);
+	
+	var _require = __webpack_require__(244);
 	
 	var entries = _require.entries;
 	var toObject = _require.toObject;
 	
-	var _require2 = __webpack_require__(244);
+	var _require2 = __webpack_require__(246);
 	
 	var executeSoon = _require2.executeSoon;
 	
 	
 	var PROMISE = exports.PROMISE = "@@dispatch/promise";
 	var seqIdVal = 1;
 	
 	function seqIdGen() {
@@ -27689,49 +27978,62 @@ var Debugger =
 	    });
 	    return deferred.promise;
 	  };
 	}
 	
 	exports.promise = promiseMiddleware;
 
 /***/ },
-/* 241 */
-/***/ 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];
+/* 243 */
+/***/ function(module, exports) {
+
+	
+	
+	function defer() {
+	  var resolve = void 0;
+	  var reject = void 0;
+	  var promise = new Promise(function (innerResolve, innerReject) {
+	    resolve = innerResolve;
+	    reject = innerReject;
 	  });
 	  return {
 	    resolve: resolve,
 	    reject: reject,
 	    promise: promise
 	  };
-	};
-
-/***/ },
-/* 242 */
+	} /* flow */
+	
+	module.exports = defer;
+
+/***/ },
+/* 244 */
 /***/ 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 _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); } }
 	
 	/* -*- 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__(243);
-	
+	/**
+	 * Utils for utils, by utils
+	 * @module utils/utils
+	 */
+	
+	var co = __webpack_require__(245);
+	
+	/**
+	 * @memberof utils/utils
+	 * @static
+	 */
 	function asPaused(client, func) {
 	  if (client.state != "paused") {
 	    return co(function* () {
 	      yield client.interrupt();
 	      var result = void 0;
 	
 	      try {
 	        result = yield func();
@@ -27744,20 +28046,28 @@ var Debugger =
 	
 	      yield client.resume();
 	      return result;
 	    });
 	  }
 	  return func();
 	}
 	
+	/**
+	 * @memberof utils/utils
+	 * @static
+	 */
 	function handleError(err) {
 	  console.log("ERROR: ", err);
 	}
 	
+	/**
+	 * @memberof utils/utils
+	 * @static
+	 */
 	function promisify(context, method) {
 	  for (var _len = arguments.length, args = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {
 	    args[_key - 2] = arguments[_key];
 	  }
 	
 	  return new Promise((resolve, reject) => {
 	    args.push(response => {
 	      if (response.error) {
@@ -27765,31 +28075,43 @@ var Debugger =
 	      } else {
 	        resolve(response);
 	      }
 	    });
 	    method.apply(context, args);
 	  });
 	}
 	
+	/**
+	 * @memberof utils/utils
+	 * @static
+	 */
 	function truncateStr(str, size) {
 	  if (str.length > size) {
 	    return str.slice(0, size) + "...";
 	  }
 	  return str;
 	}
 	
+	/**
+	 * @memberof utils/utils
+	 * @static
+	 */
 	function endTruncateStr(str, size) {
 	  if (str.length > size) {
 	    return "..." + str.slice(str.length - size);
 	  }
 	  return str;
 	}
 	
 	var msgId = 1;
+	/**
+	 * @memberof utils/utils
+	 * @static
+	 */
 	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++;
@@ -27819,16 +28141,18 @@ var Debugger =
 	 * 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, ...]
+	 * @memberof utils/utils
+	 * @static
 	 */
 	function zip(a, b) {
 	  if (!b) {
 	    return a;
 	  }
 	  if (!a) {
 	    return b;
 	  }
@@ -27839,37 +28163,44 @@ var Debugger =
 	  return pairs;
 	}
 	
 	/**
 	 * Converts an object into an array with 2-element arrays as key/value
 	 * pairs of the object. `{ foo: 1, bar: 2}` would become
 	 * `[[foo, 1], [bar 2]]` (order not guaranteed);
 	 *
-	 * @param object obj
 	 * @returns array
+	 * @memberof utils/utils
+	 * @static
 	 */
 	function entries(obj) {
 	  return Object.keys(obj).map(k => [k, obj[k]]);
 	}
 	
+	/**
+	 * @memberof utils/utils
+	 * @static
+	 */
 	function mapObject(obj, iteratee) {
 	  return toObject(entries(obj).map((_ref2) => {
 	    var _ref3 = _slicedToArray(_ref2, 2);
 	
 	    var key = _ref3[0];
 	    var value = _ref3[1];
 	
 	    return [key, iteratee(key, value)];
 	  }));
 	}
 	
 	/**
 	 * Takes an array of 2-element arrays as key/values pairs and
 	 * constructs an object using them.
+	 * @memberof utils/utils
+	 * @static
 	 */
 	function toObject(arr) {
 	  var obj = {};
 	  for (var pair of arr) {
 	    obj[pair[0]] = pair[1];
 	  }
 	  return obj;
 	}
@@ -27877,16 +28208,18 @@ var Debugger =
 	/**
 	 * Composes the given functions into a single function, which will
 	 * 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
+	 * @memberof utils/utils
+	 * @static
 	 */
 	function compose() {
 	  for (var _len3 = arguments.length, funcs = Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
 	    funcs[_key3] = arguments[_key3];
 	  }
 	
 	  return function () {
 	    for (var _len4 = arguments.length, args = Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {
@@ -27894,20 +28227,28 @@ var Debugger =
 	    }
 	
 	    var initialValue = funcs[funcs.length - 1].apply(null, args);
 	    var leftFuncs = funcs.slice(0, -1);
 	    return leftFuncs.reduceRight((composed, f) => f(composed), initialValue);
 	  };
 	}
 	
+	/**
+	 * @memberof utils/utils
+	 * @static
+	 */
 	function updateObj(obj, fields) {
 	  return Object.assign({}, obj, fields);
 	}
 	
+	/**
+	 * @memberof utils/utils
+	 * @static
+	 */
 	function throttle(func, ms) {
 	  var timeout = void 0,
 	      _this = void 0;
 	  return function () {
 	    for (var _len5 = arguments.length, args = Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {
 	      args[_key5] = arguments[_key5];
 	    }
 	
@@ -27933,17 +28274,17 @@ var Debugger =
 	  toObject,
 	  mapObject,
 	  compose,
 	  updateObj,
 	  throttle
 	};
 
 /***/ },
-/* 243 */
+/* 245 */
 /***/ function(module, exports) {
 
 	
 	/**
 	 * slice() reference.
 	 */
 	
 	var slice = Array.prototype.slice;
@@ -28176,20 +28517,20 @@ var Debugger =
 	 */
 	
 	function isObject(val) {
 	  return Object == val.constructor;
 	}
 
 
 /***/ },
-/* 244 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assert = __webpack_require__(245);
+/* 246 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assert = __webpack_require__(247);
 	
 	function reportException(who, exception) {
 	  var msg = who + " threw an exception: ";
 	  console.error(msg, exception);
 	}
 	
 	function executeSoon(fn) {
 	  setTimeout(fn, 0);
@@ -28197,29 +28538,29 @@ var Debugger =
 	
 	module.exports = {
 	  reportException,
 	  executeSoon,
 	  assert
 	};
 
 /***/ },
-/* 245 */
+/* 247 */
 /***/ function(module, exports) {
 
 	function assert(condition, message) {
 	  if (!condition) {
 	    throw new Error("Assertion failure: " + message);
 	  }
 	}
 	
 	module.exports = assert;
 
 /***/ },
-/* 246 */
+/* 248 */
 /***/ 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
@@ -28235,48 +28576,48 @@ var Debugger =
 	    return next => action => {
 	      return typeof action === "function" ? action(makeArgs ? makeArgs(args, getState()) : args) : next(action);
 	    };
 	  };
 	}
 	exports.thunk = thunk;
 
 /***/ },
-/* 247 */
-/***/ 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__(248);
-	var sources = __webpack_require__(250);
-	var breakpoints = __webpack_require__(253);
-	var asyncRequests = __webpack_require__(254);
-	var pause = __webpack_require__(255);
-	var ui = __webpack_require__(256);
+/* 249 */
+/***/ 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__(250);
+	var sources = __webpack_require__(252);
+	var breakpoints = __webpack_require__(255);
+	var asyncRequests = __webpack_require__(256);
+	var pause = __webpack_require__(257);
+	var ui = __webpack_require__(258);
 	
 	module.exports = {
 	  eventListeners,
 	  sources: sources.update,
 	  breakpoints: breakpoints.update,
 	  pause: pause.update,
 	  asyncRequests,
 	  ui: ui.update
 	};
 
 /***/ },
-/* 248 */
-/***/ 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__(249);
+/* 250 */
+/***/ 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__(251);
 	
 	var initialState = {
 	  activeEventNames: [],
 	  listeners: [],
 	  fetchingListeners: false
 	};
 	
 	function update() {
@@ -28303,17 +28644,17 @@ var Debugger =
 	  }
 	
 	  return state;
 	}
 	
 	module.exports = update;
 
 /***/ },
-/* 249 */
+/* 251 */
 /***/ 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
@@ -28354,27 +28695,32 @@ var Debugger =
 	exports.ADD_EXPRESSION = "ADD_EXPRESSION";
 	exports.EVALUATE_EXPRESSION = "EVALUATE_EXPRESSION";
 	exports.UPDATE_EXPRESSION = "UPDATE_EXPRESSION";
 	exports.DELETE_EXPRESSION = "DELETE_EXPRESSION";
 	
 	exports.TOGGLE_FILE_SEARCH = "TOGGLE_FILE_SEARCH";
 
 /***/ },
-/* 250 */
-/***/ 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__(251);
-	var I = __webpack_require__(227);
-	var makeRecord = __webpack_require__(252);
+/* 252 */
+/***/ 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/. */
+	
+	/**
+	 * Sources reducer
+	 * @module reducers/sources
+	 */
+	
+	var fromJS = __webpack_require__(253);
+	var I = __webpack_require__(229);
+	var makeRecord = __webpack_require__(254);
 	
 	var State = makeRecord({
 	  sources: I.Map(),
 	  selectedLocation: undefined,
 	  pendingSelectedLocation: undefined,
 	  sourcesText: I.Map(),
 	  tabs: I.List([])
 	});
@@ -28458,18 +28804,20 @@ var Debugger =
 	    contentType: sourceText.contentType
 	  }));
 	}
 	
 	function removeSourceFromTabList(state, id) {
 	  return state.tabs.filter(tab => tab.get("id") != id);
 	}
 	
-	/*
+	/**
 	 * Adds the new source to the tab list if it is not already there
+	 * @memberof reducers/sources
+	 * @static
 	 */
 	function updateTabList(state, source, tabIndex) {
 	  var tabs = state.get("tabs");
 	  var sourceIndex = tabs.indexOf(source);
 	  var includesSource = !!tabs.find(t => t.get("id") == source.get("id"));
 	
 	  if (includesSource) {
 	    if (tabIndex != undefined) {
@@ -28479,16 +28827,18 @@ var Debugger =
 	    return tabs;
 	  }
 	
 	  return tabs.insert(0, source);
 	}
 	
 	/**
 	 * Gets the next tab to select when a tab closes.
+	 * @memberof reducers/sources
+	 * @static
 	 */
 	function getNewSelectedSourceId(state, id) {
 	  var tabs = state.get("tabs");
 	  var selectedSource = getSelectedSource({ sources: state });
 	
 	  if (!selectedSource) {
 	    return undefined;
 	  } else if (selectedSource.get("id") != id) {
@@ -28510,17 +28860,17 @@ var Debugger =
 	
 	  // return the next tab
 	  return tabs.get(tabIndex + 1).get("id");
 	}
 	
 	// Selectors
 	
 	// Unfortunately, it's really hard to make these functions accept just
-	// the state that we care about and still type if with Flow. The
+	// the state that we care about and still type it with Flow. The
 	// problem is that we want to re-export all selectors from a single
 	// module for the UI, and all of those selectors should take the
 	// top-level app state, so we'd have to "wrap" them to automatically
 	// pick off the piece of state we're interested in. It's impossible
 	// (right now) to type those wrapped functions.
 	
 	
 	function getSource(state, id) {
@@ -28582,25 +28932,38 @@ var Debugger =
 	  getSourceTabs,
 	  getSelectedSource,
 	  getSelectedLocation,
 	  getPendingSelectedLocation,
 	  getPrettySource
 	};
 
 /***/ },
-/* 251 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var Immutable = __webpack_require__(227);
-	
-	// 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.
+/* 253 */
+/***/ function(module, exports, __webpack_require__) {
+
+	
+	
+	/**
+	 * Immutable JS conversion utils
+	 * @deprecated
+	 * @module utils/fromJS
+	 */
+	
+	var Immutable = __webpack_require__(229);
+	
+	/**
+	 * When our app state is fully typed, 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.
+	 *
+	 * @memberof utils/fromJS
+	 * @static
+	 */
 	function fromJS(value) {
 	  if (Array.isArray(value)) {
 	    return Immutable.Seq(value).map(fromJS).toList();
 	  }
 	  if (value && value.constructor.meta) {
 	    // This adds support for tcomb objects which are native JS objects
 	    // but are not "plain", so the above checks fail. Since they
 	    // behave the same we can use the same constructors, but we need
@@ -28624,57 +28987,73 @@ 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;
 
 /***/ },
-/* 252 */
-/***/ 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__(227);
+/* 254 */
+/***/ 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;
+	 * @module utils/makeRecord
+	 */
+	
+	var I = __webpack_require__(229);
+	
+	/**
+	 * @memberof utils/makeRecord
+	 * @static
+	 */
+	
 	
 	/**
 	 * Make an immutable record type
 	 *
-	 * @param spec - the keys and their default values @return a state
-	 * record factory function
+	 * @param spec - the keys and their default values
+	 * @return a state record factory function
+	 * @memberof utils/makeRecord
+	 * @static
 	 */
 	function makeRecord(spec) {
 	  return I.Record(spec);
 	}
 	
 	module.exports = makeRecord;
 
 /***/ },
-/* 253 */
-/***/ 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__(251);
-	
-	var _require = __webpack_require__(242);
+/* 255 */
+/***/ 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/. */
+	
+	/**
+	 * Breakpoints reducer
+	 * @module reducers/breakpoints
+	 */
+	
+	var fromJS = __webpack_require__(253);
+	
+	var _require = __webpack_require__(244);
 	
 	var updateObj = _require.updateObj;
 	
-	var I = __webpack_require__(227);
-	var makeRecord = __webpack_require__(252);
+	var I = __webpack_require__(229);
+	var makeRecord = __webpack_require__(254);
 	
 	var State = makeRecord({
 	  breakpoints: I.Map(),
 	  breakpointsDisabled: false
 	});
 	
 	// Return the first argument that is a string, or null if nothing is a
 	// string.
@@ -28839,26 +29218,26 @@ var Debugger =
 	  getBreakpoint,
 	  getBreakpoints,
 	  getBreakpointsForSource,
 	  getBreakpointsDisabled,
 	  getBreakpointsLoading
 	};
 
 /***/ },
-/* 254 */
+/* 256 */
 /***/ 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__(249);
+	var constants = __webpack_require__(251);
 	var initialState = [];
 	
 	function update() {
 	  var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
 	  var action = arguments[1];
 	  var seqId = action.seqId;
 	
 	
@@ -28876,25 +29255,25 @@ var Debugger =
 	  }
 	
 	  return state;
 	}
 	
 	module.exports = update;
 
 /***/ },
-/* 255 */
-/***/ 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__(249);
-	var fromJS = __webpack_require__(251);
+/* 257 */
+/***/ 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__(251);
+	var fromJS = __webpack_require__(253);
 	
 	var initialState = fromJS({
 	  pause: null,
 	  isWaitingOnBreak: false,
 	  frames: null,
 	  selectedFrameId: null,
 	  loadedObjects: {},
 	  shouldPauseOnExceptions: false,
@@ -29024,17 +29403,17 @@ var Debugger =
 	  return state.pause.get("shouldPauseOnExceptions");
 	}
 	
 	function getShouldIgnoreCaughtExceptions(state) {
 	  return state.pause.get("shouldIgnoreCaughtExceptions");
 	}
 	
 	function getFrames(state) {
-	  return state.pause.get("frames") || [];
+	  return state.pause.get("frames");
 	}
 	
 	function getSelectedFrame(state) {
 	  var selectedFrameId = state.pause.get("selectedFrameId");
 	  var frames = state.pause.get("frames");
 	  return frames && frames.find(frame => frame.id == selectedFrameId);
 	}
 	
@@ -29047,21 +29426,28 @@ var Debugger =
 	  getIsWaitingOnBreak,
 	  getShouldPauseOnExceptions,
 	  getShouldIgnoreCaughtExceptions,
 	  getFrames,
 	  getSelectedFrame
 	};
 
 /***/ },
-/* 256 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var constants = __webpack_require__(249);
-	var makeRecord = __webpack_require__(252);
+/* 258 */
+/***/ function(module, exports, __webpack_require__) {
+
+	
+	
+	/**
+	 * UI reducer
+	 * @module reducers/ui
+	 */
+	
+	var constants = __webpack_require__(251);
+	var makeRecord = __webpack_require__(254);
 	
 	var State = makeRecord({
 	  searchOn: false
 	});
 	
 	function update() {
 	  var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : State();
 	  var action = arguments[1];
@@ -29088,23 +29474,23 @@ var Debugger =
 	
 	module.exports = {
 	  State,
 	  update,
 	  getFileSearchState
 	};
 
 /***/ },
-/* 257 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var sources = __webpack_require__(250);
-	var pause = __webpack_require__(255);
-	var breakpoints = __webpack_require__(253);
-	var ui = __webpack_require__(256);
+/* 259 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var sources = __webpack_require__(252);
+	var pause = __webpack_require__(257);
+	var breakpoints = __webpack_require__(255);
+	var ui = __webpack_require__(258);
 	
 	/**
 	 * @param object - location
 	 */
 	
 	module.exports = {
 	  getSource: sources.getSource,
 	  getSourceByURL: sources.getSourceByURL,
@@ -29121,74 +29507,76 @@ var Debugger =
 	  getBreakpoints: breakpoints.getBreakpoints,
 	  getBreakpointsForSource: breakpoints.getBreakpointsForSource,
 	  getBreakpointsDisabled: breakpoints.getBreakpointsDisabled,
 	  getBreakpointsLoading: breakpoints.getBreakpointsLoading,
 	
 	  getPause: pause.getPause,
 	  getLoadedObjects: pause.getLoadedObjects,
 	  getExpressions: pause.getExpressions,
+	  getExpressionInputVisibility: pause.getExpressionInputVisibility,
 	  getIsWaitingOnBreak: pause.getIsWaitingOnBreak,
 	  getShouldPauseOnExceptions: pause.getShouldPauseOnExceptions,
 	  getShouldIgnoreCaughtExceptions: pause.getShouldIgnoreCaughtExceptions,
 	  getFrames: pause.getFrames,
 	  getSelectedFrame: pause.getSelectedFrame,
 	
 	  getFileSearchState: ui.getFileSearchState
 	};
 
 /***/ },
-/* 258 */
+/* 260 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
 	var dom = React.DOM;
 	var PropTypes = React.PropTypes;
 	var createFactory = React.createFactory;
 	
 	var _require = __webpack_require__(19);
 	
 	var connect = _require.connect;
 	
 	var _require2 = __webpack_require__(3);
 	
 	var bindActionCreators = _require2.bindActionCreators;
 	
-	var _require3 = __webpack_require__(259);
+	var _require3 = __webpack_require__(261);
 	
 	var cmdString = _require3.cmdString;
 	
-	var actions = __webpack_require__(260);
-	
-	var _require4 = __webpack_require__(257);
+	var actions = __webpack_require__(262);
+	
+	var _require4 = __webpack_require__(259);
 	
 	var getSources = _require4.getSources;
 	var getSelectedSource = _require4.getSelectedSource;
 	
 	var _require5 = __webpack_require__(28);
 	
 	var KeyShortcuts = _require5.KeyShortcuts;
 	
 	var shortcuts = new KeyShortcuts({ window });
 	
-	__webpack_require__(281);
-	__webpack_require__(284);
+	__webpack_require__(283);
 	__webpack_require__(286);
+	__webpack_require__(288);
+	__webpack_require__(290);
 	
 	var _require6 = __webpack_require__(30);
 	
 	var SplitBox = _require6.SplitBox;
 	
 	SplitBox = createFactory(SplitBox);
 	
-	var SourceSearch = createFactory(__webpack_require__(288));
-	var Sources = createFactory(__webpack_require__(335));
-	var Editor = createFactory(__webpack_require__(396));
-	var RightSidebar = createFactory(__webpack_require__(409));
-	var SourceTabs = createFactory(__webpack_require__(445));
+	var SourceSearch = createFactory(__webpack_require__(292));
+	var Sources = createFactory(__webpack_require__(339));
+	var Editor = createFactory(__webpack_require__(400));
+	var RightSidebar = createFactory(__webpack_require__(416));
+	var SourceTabs = createFactory(__webpack_require__(452));
 	
 	var App = React.createClass({
 	  propTypes: {
 	    sources: PropTypes.object,
 	    selectSource: PropTypes.func,
 	    selectedSource: PropTypes.object
 	  },
 	
@@ -29231,75 +29619,86 @@ var Debugger =
 	  shortcuts: PropTypes.object
 	};
 	
 	module.exports = connect(state => ({ sources: getSources(state),
 	  selectedSource: getSelectedSource(state)
 	}), dispatch => bindActionCreators(actions, dispatch))(App);
 
 /***/ },
-/* 259 */
-/***/ function(module, exports, __webpack_require__) {
-
+/* 261 */
+/***/ function(module, exports, __webpack_require__) {
+
+	
+	
+	/**
+	 * Utils for keyboard command strings
+	 * @module utils/text
+	 */
+	
 	var _require = __webpack_require__(30);
 	
 	var appinfo = _require.Services.appinfo;
 	
+	/**
+	 * @memberof utils/text
+	 * @static
+	 */
 	
 	function cmdString() {
 	  return appinfo.OS === "Darwin" ? "⌘" : "Ctrl";
 	}
 	
 	module.exports = {
 	  cmdString
 	};
 
 /***/ },
-/* 260 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var breakpoints = __webpack_require__(261);
-	var eventListeners = __webpack_require__(269);
-	var sources = __webpack_require__(271);
-	var pause = __webpack_require__(278);
-	var navigation = __webpack_require__(279);
-	var ui = __webpack_require__(280);
+/* 262 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var breakpoints = __webpack_require__(263);
+	var eventListeners = __webpack_require__(271);
+	var sources = __webpack_require__(273);
+	var pause = __webpack_require__(280);
+	var navigation = __webpack_require__(281);
+	var ui = __webpack_require__(282);
 	
 	module.exports = Object.assign(navigation, breakpoints, eventListeners, sources, pause, ui);
 
 /***/ },
-/* 261 */
+/* 263 */
 /***/ 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) { 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__(249);
-	
-	var _require = __webpack_require__(240);
+	var constants = __webpack_require__(251);
+	
+	var _require = __webpack_require__(242);
 	
 	var PROMISE = _require.PROMISE;
 	
-	var _require2 = __webpack_require__(257);
+	var _require2 = __webpack_require__(259);
 	
 	var getBreakpoint = _require2.getBreakpoint;
 	var getBreakpoints = _require2.getBreakpoints;
 	var getSource = _require2.getSource;
 	
-	var _require3 = __webpack_require__(262);
+	var _require3 = __webpack_require__(264);
 	
 	var getOriginalLocation = _require3.getOriginalLocation;
 	var getGeneratedLocation = _require3.getGeneratedLocation;
 	var isOriginalId = _require3.isOriginalId;
 	
 	
 	function _breakpointExists(state, location) {
 	  var currentBp = getBreakpoint(state, location);
@@ -29461,36 +29860,42 @@ var Debugger =
 	        }
 	      })()
 	    });
 	  };
 	}
 	
 	/**
 	 * Update the condition of a breakpoint.
-	 *  **NOT IMPLEMENTED**
 	 *
 	 * @throws {Error} "not implemented"
 	 * @memberof actions/breakpoints
 	 * @static
 	 * @param {Location} location
 	 *        @see DebuggerController.Breakpoints.addBreakpoint
 	 * @param {string} condition
 	 *        The condition to set on the breakpoint
 	 */
-	function setBreakpointCondition(location, condition) {
-	  return (_ref10) => {
-	    var dispatch = _ref10.dispatch;
-	    var getState = _ref10.getState;
-	    var client = _ref10.client;
+	function setBreakpointCondition(location) {
+	  var _ref10 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+	
+	  var condition = _ref10.condition;
+	  var getTextForLine = _ref10.getTextForLine;
+	
+	  // location: Location, condition: string, { getTextForLine }) {
+	  return (_ref11) => {
+	    var dispatch = _ref11.dispatch;
+	    var getState = _ref11.getState;
+	    var client = _ref11.client;
 	
 	    var bp = getBreakpoint(getState(), location);
 	    if (!bp) {
-	      throw new Error("Breakpoint does not exist at the specified location");
-	    }
+	      return dispatch(addBreakpoint(location, { condition, getTextForLine }));
+	    }
+	
 	    if (bp.loading) {
 	      // TODO(jwl): when this function is called, make sure the action
 	      // creator waits for the breakpoint to exist
 	      throw new Error("breakpoint must be saved");
 	    }
 	
 	    return dispatch({
 	      type: constants.SET_BREAKPOINT_CONDITION,
@@ -29506,36 +29911,36 @@ var Debugger =
 	  addBreakpoint,
 	  disableBreakpoint,
 	  removeBreakpoint,
 	  toggleAllBreakpoints,
 	  setBreakpointCondition
 	};
 
 /***/ },
-/* 262 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(87);
+/* 264 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(89);
 	
 	var getValue = _require.getValue;
 	var isEnabled = _require.isEnabled;
 	
-	var _require2 = __webpack_require__(242);
+	var _require2 = __webpack_require__(244);
 	
 	var workerTask = _require2.workerTask;
 	
-	var _require3 = __webpack_require__(263);
+	var _require3 = __webpack_require__(265);
 	
 	var originalToGeneratedId = _require3.originalToGeneratedId;
 	var generatedToOriginalId = _require3.generatedToOriginalId;
 	var isGeneratedId = _require3.isGeneratedId;
 	var isOriginalId = _require3.isOriginalId;
 	
-	var _require4 = __webpack_require__(268);
+	var _require4 = __webpack_require__(270);
 	
 	var prefs = _require4.prefs;
 	
 	
 	var sourceMapWorker = void 0;
 	function restartWorker() {
 	  if (sourceMapWorker) {
 	    sourceMapWorker.terminate();
@@ -29578,51 +29983,51 @@ var Debugger =
 	  getOriginalSourceText,
 	  applySourceMap,
 	  clearSourceMaps,
 	  destroyWorker,
 	  shouldSourceMap
 	};
 
 /***/ },
-/* 263 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var md5 = __webpack_require__(264);
+/* 265 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var md5 = __webpack_require__(266);
 	
 	function originalToGeneratedId(originalId) {
 	  var match = originalId.match(/(.*)\/originalSource/);
-	  return match ? match[1] : null;
+	  return match ? match[1] : "";
 	}
 	
 	function generatedToOriginalId(generatedId, url) {
 	  return generatedId + "/originalSource-" + md5(url);
 	}
 	
 	function isOriginalId(id) {
-	  return id.match(/\/originalSource/);
+	  return !!id.match(/\/originalSource/);
 	}
 	
 	function isGeneratedId(id) {
 	  return !isOriginalId(id);
 	}
 	
 	module.exports = {
 	  originalToGeneratedId, generatedToOriginalId, isOriginalId, isGeneratedId
 	};
 
 /***/ },
-/* 264 */
+/* 266 */
 /***/ function(module, exports, __webpack_require__) {
 
 	(function(){
-	  var crypt = __webpack_require__(265),
-	      utf8 = __webpack_require__(266).utf8,
-	      isBuffer = __webpack_require__(267),
-	      bin = __webpack_require__(266).bin,
+	  var crypt = __webpack_require__(267),
+	      utf8 = __webpack_require__(268).utf8,
+	      isBuffer = __webpack_require__(269),
+	      bin = __webpack_require__(268).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
@@ -29771,17 +30176,17 @@ var Debugger =
 	        options && options.asString ? bin.bytesToString(digestbytes) :
 	        crypt.bytesToHex(digestbytes);
 	  };
 	
 	})();
 
 
 /***/ },
-/* 265 */
+/* 267 */
 /***/ function(module, exports) {
 
 	(function() {
 	  var base64map
 	      = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',
 	
 	  crypt = {
 	    // Bit-wise rotation left
@@ -29873,17 +30278,17 @@ var Debugger =
 	    }
 	  };
 	
 	  module.exports = crypt;
 	})();
 
 
 /***/ },
-/* 266 */
+/* 268 */
 /***/ 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)));
@@ -29912,17 +30317,17 @@ var Debugger =
 	    }
 	  }
 	};
 	
 	module.exports = charenc;
 
 
 /***/ },
-/* 267 */
+/* 269 */
 /***/ function(module, exports) {
 
 	/*!
 	 * Determine if an object is a Buffer
 	 *
 	 * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>
 	 * @license  MIT
 	 */
@@ -29939,60 +30344,60 @@ var Debugger =
 	
 	// 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))
 	}
 
 
 /***/ },
-/* 268 */
+/* 270 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var { PrefsHelper } = __webpack_require__(28);
 	const { Services: { pref }} = __webpack_require__(30);
-	const { isDevelopment } = __webpack_require__(87);
+	const { isDevelopment } = __webpack_require__(89);
 	
 	if (isDevelopment()) {
 	  pref("devtools.debugger.client-source-maps-enabled", true);
 	}
 	
 	const prefs = new PrefsHelper("devtools", {
 	  clientSourceMapsEnabled: ["Bool", "debugger.client-source-maps-enabled"],
 	});
 	
 	module.exports = { prefs };
 
 
 /***/ },
-/* 269 */
+/* 271 */
 /***/ 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__(249);
-	
-	var _require = __webpack_require__(242);
+	var constants = __webpack_require__(251);
+	
+	var _require = __webpack_require__(244);
 	
 	var asPaused = _require.asPaused;
 	
-	var _require2 = __webpack_require__(244);
+	var _require2 = __webpack_require__(246);
 	
 	var reportException = _require2.reportException;
 	
-	var _require3 = __webpack_require__(270);
+	var _require3 = __webpack_require__(272);
 	
 	var Task = _require3.Task;
 	
 	// delay is in ms
 	
 	var FETCH_EVENT_LISTENERS_DELAY = 200;
 	
 	/**
@@ -30102,17 +30507,17 @@ var Debugger =
 	      });
 	    });
 	  };
 	}
 	
 	module.exports = { updateEventBreakpoints, fetchEventListeners };
 
 /***/ },
-/* 270 */
+/* 272 */
 /***/ 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/. */
 	
@@ -30153,70 +30558,70 @@ var Debugger =
 	      callNext(undefined);
 	    });
 	  }
 	};
 	
 	module.exports = { Task };
 
 /***/ },
-/* 271 */
+/* 273 */
 /***/ 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) { 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__(241);
-	
-	var _require = __webpack_require__(240);
+	var defer = __webpack_require__(243);
+	
+	var _require = __webpack_require__(242);
 	
 	var PROMISE = _require.PROMISE;
 	
-	var assert = __webpack_require__(245);
-	
-	var _require2 = __webpack_require__(272);
+	var assert = __webpack_require__(247);
+	
+	var _require2 = __webpack_require__(274);
 	
 	var updateFrameLocations = _require2.updateFrameLocations;
 	
-	var _require3 = __webpack_require__(262);
+	var _require3 = __webpack_require__(264);
 	
 	var getOriginalURLs = _require3.getOriginalURLs;
 	var getOriginalSourceText = _require3.getOriginalSourceText;
 	var generatedToOriginalId = _require3.generatedToOriginalId;
 	var isOriginalId = _require3.isOriginalId;
 	var isGeneratedId = _require3.isGeneratedId;
 	var applySourceMap = _require3.applySourceMap;
 	var shouldSourceMap = _require3.shouldSourceMap;
 	
-	var _require4 = __webpack_require__(274);
+	var _require4 = __webpack_require__(276);
 	
 	var prettyPrint = _require4.prettyPrint;
 	
 	
-	var constants = __webpack_require__(249);
-	
-	var _require5 = __webpack_require__(87);
+	var constants = __webpack_require__(251);
+	
+	var _require5 = __webpack_require__(89);
 	
 	var isEnabled = _require5.isEnabled;
 	
-	var _require6 = __webpack_require__(277);
+	var _require6 = __webpack_require__(279);
 	
 	var removeDocument = _require6.removeDocument;
 	
-	var _require7 = __webpack_require__(257);
+	var _require7 = __webpack_require__(259);
 	
 	var getSource = _require7.getSource;
 	var getSourceByURL = _require7.getSourceByURL;
 	var getSourceText = _require7.getSourceText;
 	var getPendingSelectedLocation = _require7.getPendingSelectedLocation;
 	var getFrames = _require7.getFrames;
 	
 	
@@ -30340,16 +30745,18 @@ var Debugger =
 	      return;
 	    }
 	
 	    var source = getSource(getState(), id).toJS();
 	
 	    // Make sure to start a request to load the source text.
 	    dispatch(loadSourceText(source));
 	
+	    dispatch({ type: constants.TOGGLE_FILE_SEARCH, searchOn: false });
+	
 	    dispatch({
 	      type: constants.SELECT_SOURCE,
 	      source: source,
 	      tabIndex: options.tabIndex,
 	      line: options.line
 	    });
 	  };
 	}
@@ -30554,26 +30961,28 @@ var Debugger =
 	    }
 	
 	    /* 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((_ref17, _ref18) => {
-	          var _ref20 = _slicedToArray(_ref17, 1);
-	
-	          var aFirst = _ref20[0];
-	
-	          var _ref19 = _slicedToArray(_ref18, 1);
-	
-	          var aSecond = _ref19[0];
-	          return aFirst > aSecond ? -1 : 1;
-	        }));
+	        if (deferred) {
+	          deferred.resolve(fetched.sort((_ref17, _ref18) => {
+	            var _ref20 = _slicedToArray(_ref17, 1);
+	
+	            var aFirst = _ref20[0];
+	
+	            var _ref19 = _slicedToArray(_ref18, 1);
+	
+	            var aSecond = _ref19[0];
+	            return aFirst > aSecond ? -1 : 1;
+	          }));
+	        }
 	      }
 	    }
 	
 	    return deferred.promise;
 	  };
 	}
 	
 	module.exports = {
@@ -30583,47 +30992,50 @@ var Debugger =
 	  selectSourceURL,
 	  closeTab,
 	  togglePrettyPrint,
 	  loadSourceText,
 	  getTextForSources
 	};
 
 /***/ },
-/* 272 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(273);
+/* 274 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(275);
 	
 	var Frame = _require.Frame;
 	
-	var _require2 = __webpack_require__(262);
+	var _require2 = __webpack_require__(264);
 	
 	var getOriginalLocation = _require2.getOriginalLocation;
 	
 	
 	function updateFrameLocations(frames) {
+	  if (!frames) {
+	    return Promise.resolve(frames);
+	  }
 	  return Promise.all(frames.map(frame => {
 	    return getOriginalLocation(frame.location).then(loc => {
 	      return Frame.update(frame, {
 	        $merge: { location: loc }
 	      });
 	    });
 	  }));
 	}
 	
 	module.exports = {
 	  updateFrameLocations
 	};
 
 /***/ },
-/* 273 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var t = __webpack_require__(144);
+/* 275 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var t = __webpack_require__(146);
 	
 	var Location = t.struct({
 	  sourceId: t.String,
 	  line: t.Number,
 	  column: t.union([t.Number, t.Nil])
 	}, "Location");
 	
 	var Frame = t.struct({
@@ -30634,17 +31046,17 @@ var Debugger =
 	  scope: t.union([t.Object, t.Nil])
 	}, "Frame");
 	
 	module.exports = {
 	  Frame
 	};
 
 /***/ },
-/* 274 */
+/* 276 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var prettyPrint = (() => {
 	  var _ref = _asyncToGenerator(function* (_ref2) {
 	    var source = _ref2.source;
 	    var sourceText = _ref2.sourceText;
 	    var url = _ref2.url;
 	
@@ -30662,59 +31074,69 @@ var Debugger =
 	
 	  return function prettyPrint(_x) {
 	    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) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
 	
-	var _require = __webpack_require__(87);
+	var _require = __webpack_require__(89);
 	
 	var getValue = _require.getValue;
 	
-	var _require2 = __webpack_require__(242);
+	var _require2 = __webpack_require__(244);
 	
 	var workerTask = _require2.workerTask;
 	
-	var _require3 = __webpack_require__(275);
+	var _require3 = __webpack_require__(277);
 	
 	var isJavaScript = _require3.isJavaScript;
 	
-	var assert = __webpack_require__(245);
+	var assert = __webpack_require__(247);
 	
 	var prettyPrintWorker = new Worker(getValue("baseWorkerURL") + "pretty-print-worker.js");
 	
 	function destroyWorker() {
 	  prettyPrintWorker.terminate();
 	  prettyPrintWorker = null;
 	}
 	
 	var _prettyPrint = workerTask(prettyPrintWorker, "prettyPrint");
 	
 	module.exports = {
 	  prettyPrint,
 	  destroyWorker
 	};
 
 /***/ },
-/* 275 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(242);
+/* 277 */
+/***/ function(module, exports, __webpack_require__) {
+
+	
+	
+	/**
+	 * Utils for working with Source URLs
+	 * @module utils/source
+	 */
+	
+	var _require = __webpack_require__(244);
 	
 	var endTruncateStr = _require.endTruncateStr;
 	
-	var _require2 = __webpack_require__(276);
+	var _require2 = __webpack_require__(278);
 	
 	var basename = _require2.basename;
 	
 	
 	/**
 	 * Trims the query part or reference identifier of a url string, if necessary.
+	 *
+	 * @memberof utils/source
+	 * @static
 	 */
 	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);
 	
@@ -30722,52 +31144,62 @@ var Debugger =
 	}
 	
 	/**
 	 * Returns true if the specified url and/or content type are specific to
 	 * javascript files.
 	 *
 	 * @return boolean
 	 *         True if the source is likely javascript.
+	 *
+	 * @memberof utils/source
+	 * @static
 	 */
 	function isJavaScript(url) {
 	  var contentType = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : "";
 	
 	  return url && /\.(jsm|js)?$/.test(trimUrlQuery(url)) || contentType.includes("javascript");
 	}
 	
+	/**
+	 * @memberof utils/source
+	 * @static
+	 */
 	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.
+	 *
+	 * @memberof utils/source
+	 * @static
 	 */
 	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);
+	  var name = basename(source.url || "") || "(index)";
 	  return endTruncateStr(name, 50);
 	}
 	
 	module.exports = {
 	  isJavaScript,
 	  isPretty,
 	  getFilename
 	};
 
 /***/ },
-/* 276 */
+/* 278 */
 /***/ function(module, exports) {
 
 	function basename(path) {
 	  return path.split("/").pop();
 	}
 	
 	function dirname(path) {
 	  var idx = path.lastIndexOf("/");
@@ -30777,22 +31209,26 @@ var Debugger =
 	function isURL(str) {
 	  return str.indexOf("://") !== -1;
 	}
 	
 	function isAbsolute(str) {
 	  return str[0] === "/";
 	}
 	
+	function join(base, dir) {
+	  return base + "/" + dir;
+	}
+	
 	module.exports = {
-	  basename, dirname, isURL, isAbsolute
-	};
-
-/***/ },
-/* 277 */
+	  basename, dirname, isURL, isAbsolute, join
+	};
+
+/***/ },
+/* 279 */
 /***/ function(module, exports) {
 
 	var sourceDocs = {};
 	
 	function getDocument(key) {
 	  return sourceDocs[key];
 	}
 	
@@ -30811,36 +31247,37 @@ var Debugger =
 	module.exports = {
 	  getDocument,
 	  setDocument,
 	  removeDocument,
 	  clearDocuments
 	};
 
 /***/ },
-/* 278 */
+/* 280 */
 /***/ 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__(249);
-	
-	var _require = __webpack_require__(271);
+	var constants = __webpack_require__(251);
+	
+	var _require = __webpack_require__(273);
 	
 	var selectSource = _require.selectSource;
 	
-	var _require2 = __webpack_require__(240);
+	var _require2 = __webpack_require__(242);
 	
 	var PROMISE = _require2.PROMISE;
 	
-	var _require3 = __webpack_require__(257);
+	var _require3 = __webpack_require__(259);
 	
 	var getExpressions = _require3.getExpressions;
-	
-	var _require4 = __webpack_require__(272);
+	var getSelectedFrame = _require3.getSelectedFrame;
+	
+	var _require4 = __webpack_require__(274);
 	
 	var updateFrameLocations = _require4.updateFrameLocations;
 	
 	/**
 	 * Redux actions for the pause state
 	 * @module actions/pause
 	 */
 	
@@ -30877,23 +31314,25 @@ var Debugger =
 	      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(evaluateExpressions());
+	
 	      dispatch(selectSource(frame.location.sourceId, { line: frame.location.line }));
 	    });
 	
 	    return function (_x) {
 	      return _ref2.apply(this, arguments);
 	    };
 	  })();
 	}
@@ -31105,60 +31544,74 @@ var Debugger =
 	}
 	
 	/**
 	 *
 	 * @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)
-	      });
-	    }
-	  };
+	  return (() => {
+	    var _ref13 = _asyncToGenerator(function* (_ref14) {
+	      var dispatch = _ref14.dispatch;
+	      var getState = _ref14.getState;
+	      var client = _ref14.client;
+	
+	      var selectedFrame = getSelectedFrame(getState());
+	      if (!selectedFrame) {
+	        return;
+	      }
+	
+	      var frameId = selectedFrame.id;
+	
+	      for (var expression of getExpressions(getState())) {
+	        yield dispatch({
+	          type: constants.EVALUATE_EXPRESSION,
+	          id: expression.id,
+	          input: expression.input,
+	          [PROMISE]: client.evaluate(expression.input, { frameId })
+	        });
+	      }
+	    });
+	
+	    return function (_x2) {
+	      return _ref13.apply(this, arguments);
+	    };
+	  })();
 	}
 	
 	module.exports = {
 	  addExpression,
 	  updateExpression,
 	  deleteExpression,
+	  evaluateExpressions,
 	  resumed,
 	  paused,
 	  pauseOnExceptions,
 	  command,
 	  stepIn,
 	  stepOut,
 	  stepOver,
 	  resume,
 	  breakOnNext,
 	  selectFrame,
 	  loadObjectProperties
 	};
 
 /***/ },
-/* 279 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var constants = __webpack_require__(249);
-	
-	var _require = __webpack_require__(262);
+/* 281 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var constants = __webpack_require__(251);
+	
+	var _require = __webpack_require__(264);
 	
 	var clearSourceMaps = _require.clearSourceMaps;
 	
-	var _require2 = __webpack_require__(277);
+	var _require2 = __webpack_require__(279);
 	
 	var clearDocuments = _require2.clearDocuments;
 	
 	/**
 	 * Redux actions for the navigation state
 	 * @module actions/navigation
 	 */
 	
@@ -31194,106 +31647,115 @@ var Debugger =
 	}
 	
 	module.exports = {
 	  willNavigate,
 	  navigated
 	};
 
 /***/ },
-/* 280 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var constants = __webpack_require__(249);
+/* 282 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var constants = __webpack_require__(251);
 	
 	function toggleFileSearch(searchOn) {
 	  return {
 	    type: constants.TOGGLE_FILE_SEARCH,
 	    searchOn
 	  };
 	}
 	
 	module.exports = {
 	  toggleFileSearch
 	};
 
 /***/ },
-/* 281 */
+/* 283 */
 /***/ function(module, exports) {
 
 	// removed by extract-text-webpack-plugin
 
 /***/ },
-/* 282 */,
-/* 283 */,
-/* 284 */
-/***/ function(module, exports) {
-
-	// removed by extract-text-webpack-plugin
-
-/***/ },
+/* 284 */,
 /* 285 */,
 /* 286 */
 /***/ function(module, exports) {
 
 	// removed by extract-text-webpack-plugin
 
 /***/ },
 /* 287 */,
 /* 288 */
+/***/ function(module, exports) {
+
+	// removed by extract-text-webpack-plugin
+
+/***/ },
+/* 289 */,
+/* 290 */
+/***/ function(module, exports) {
+
+	// removed by extract-text-webpack-plugin
+
+/***/ },
+/* 291 */,
+/* 292 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
 	var dom = React.DOM;
 	var PropTypes = React.PropTypes;
 	var createFactory = React.createFactory;
 	
 	var _require = __webpack_require__(19);
 	
 	var connect = _require.connect;
 	
 	var _require2 = __webpack_require__(3);
 	
 	var bindActionCreators = _require2.bindActionCreators;
 	
-	var actions = __webpack_require__(260);
-	
-	var _require3 = __webpack_require__(257);
+	var actions = __webpack_require__(262);
+	
+	var _require3 = __webpack_require__(259);
 	
 	var getSources = _require3.getSources;
 	var getSelectedSource = _require3.getSelectedSource;
 	var getFileSearchState = _require3.getFileSearchState;
 	
-	var _require4 = __webpack_require__(242);
+	var _require4 = __webpack_require__(244);
 	
 	var endTruncateStr = _require4.endTruncateStr;
 	
-	var _require5 = __webpack_require__(289);
+	var _require5 = __webpack_require__(293);
 	
 	var parseURL = _require5.parse;
 	
-	var _require6 = __webpack_require__(275);
+	var _require6 = __webpack_require__(277);
 	
 	var isPretty = _require6.isPretty;
 	
 	
-	__webpack_require__(294);
-	
-	var Autocomplete = createFactory(__webpack_require__(296));
+	__webpack_require__(298);
+	
+	var Autocomplete = createFactory(__webpack_require__(300));
 	
 	function searchResults(sources) {
 	  function getSourcePath(source) {
 	    var _parseURL = parseURL(source.get("url"));
 	
 	    var path = _parseURL.path;
-	
-	    return endTruncateStr(path, 50);
-	  }
-	
-	  return sources.valueSeq().filter(source => !isPretty(source.toJS() || source.get("url"))).map(source => ({
+	    var href = _parseURL.href;
+	    // for URLs like "about:home" the path is null so we pass the full href
+	
+	    return endTruncateStr(path || href, 50);
+	  }
+	
+	  return sources.valueSeq().filter(source => !isPretty(source.toJS()) && source.get("url")).map(source => ({
 	    value: getSourcePath(source),
 	    title: getSourcePath(source).split("/").pop(),
 	    subtitle: getSourcePath(source),
 	    id: source.get("id")
 	  })).toJS();
 	}
 	
 	var Search = React.createClass({
@@ -31306,16 +31768,22 @@ var Debugger =
 	  },
 	
 	  contextTypes: {
 	    shortcuts: PropTypes.object
 	  },
 	
 	  displayName: "Search",
 	
+	  getInitialState() {
+	    return {
+	      inputValue: ""
+	    };
+	  },
+	
 	  componentWillUnmount() {
 	    var shortcuts = this.context.shortcuts;
 	    shortcuts.off("CmdOrCtrl+P", this.toggle);
 	    shortcuts.off("Escape", this.onEscape);
 	  },
 	
 	  componentDidMount() {
 	    var shortcuts = this.context.shortcuts;
@@ -31326,44 +31794,51 @@ var Debugger =
 	  toggle(key, e) {
 	    e.preventDefault();
 	    this.props.toggleFileSearch(!this.props.searchOn);
 	  },
 	
 	  onEscape(shortcut, e) {
 	    if (this.props.searchOn) {
 	      e.preventDefault();
+	      this.setState({ inputValue: "" });
 	      this.props.toggleFileSearch(false);
 	    }
 	  },
 	
 	  close() {
+	    var inputValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "";
+	
+	    this.setState({ inputValue });
 	    this.props.toggleFileSearch(false);
 	  },
 	
 	  render() {
 	    return this.props.searchOn ? dom.div({ className: "search-container" }, Autocomplete({
 	      selectItem: result => {
 	        this.props.selectSource(result.id);
+	        this.setState({ inputValue: "" });
 	        this.props.toggleFileSearch(false);
 	      },
 	      handleClose: this.close,
-	      items: searchResults(this.props.sources)
+	      items: searchResults(this.props.sources),
+	      inputValue: this.state.inputValue
 	    })) : null;
 	  }
 	
 	});
 	
-	module.exports = connect(state => ({ sources: getSources(state),
+	module.exports = connect(state => ({
+	  sources: getSources(state),
 	  selectedSource: getSelectedSource(state),
 	  searchOn: getFileSearchState(state)
 	}), dispatch => bindActionCreators(actions, dispatch))(Search);
 
 /***/ },
-/* 289 */
+/* 293 */
 /***/ 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,
@@ -31377,17 +31852,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__(290);
+	var punycode = __webpack_require__(294);
 	
 	exports.parse = urlParse;
 	exports.resolve = urlResolve;
 	exports.resolveObject = urlResolveObject;
 	exports.format = urlFormat;
 	
 	exports.Url = Url;
 	
@@ -31449,17 +31924,17 @@ var Debugger =
 	      'gopher': true,
 	      'file': true,
 	      'http:': true,
 	      'https:': true,
 	      'ftp:': true,
 	      'gopher:': true,
 	      'file:': true
 	    },
-	    querystring = __webpack_require__(291);
+	    querystring = __webpack_require__(295);
 	
 	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;
 	}
@@ -32066,17 +32541,17 @@ var Debugger =
 	  return arg === null;
 	}
 	function isNullOrUndefined(arg) {
 	  return  arg == null;
 	}
 
 
 /***/ },
-/* 290 */
+/* 294 */
 /***/ 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;
@@ -32601,27 +33076,27 @@ var Debugger =
 			root.punycode = punycode;
 		}
 	
 	}(this));
 	
 	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(77)(module), (function() { return this; }())))
 
 /***/ },
-/* 291 */
+/* 295 */
 /***/ function(module, exports, __webpack_require__) {
 
 	'use strict';
 	
-	exports.decode = exports.parse = __webpack_require__(292);
-	exports.encode = exports.stringify = __webpack_require__(293);
-
-
-/***/ },
-/* 292 */
+	exports.decode = exports.parse = __webpack_require__(296);
+	exports.encode = exports.stringify = __webpack_require__(297);
+
+
+/***/ },
+/* 296 */
 /***/ 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,
@@ -32697,17 +33172,17 @@ var Debugger =
 	    }
 	  }
 	
 	  return obj;
 	};
 
 
 /***/ },
-/* 293 */
+/* 297 */
 /***/ 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,
@@ -32767,59 +33242,62 @@ var Debugger =
 	
 	  if (!name) return '';
 	  return encodeURIComponent(stringifyPrimitive(name)) + eq +
 	         encodeURIComponent(stringifyPrimitive(obj));
 	};
 
 
 /***/ },
-/* 294 */
+/* 298 */
 /***/ function(module, exports) {
 
 	// removed by extract-text-webpack-plugin
 
 /***/ },
-/* 295 */,
-/* 296 */
+/* 299 */,
+/* 300 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
 	var dom = React.DOM;
 	var PropTypes = React.PropTypes;
 	
-	var _require = __webpack_require__(297);
+	var _require = __webpack_require__(301);
 	
 	var filter = _require.filter;
 	
-	var classnames = __webpack_require__(209);
-	__webpack_require__(304);
-	var Svg = __webpack_require__(306);
-	var CloseButton = __webpack_require__(332);
+	var classnames = __webpack_require__(211);
+	__webpack_require__(308);
+	var Svg = __webpack_require__(310);
+	var CloseButton = __webpack_require__(336);
 	
 	var INITIAL_SELECTED_INDEX = 0;
 	
 	var Autocomplete = React.createClass({
 	  propTypes: {
 	    selectItem: PropTypes.func,
 	    items: PropTypes.array,
-	    handleClose: PropTypes.func
+	    handleClose: PropTypes.func,
+	    inputValue: PropTypes.string
 	  },
 	
 	  displayName: "Autocomplete",
 	
 	  getInitialState() {
 	    return {
-	      inputValue: "",
+	      inputValue: this.props.inputValue,
 	      selectedIndex: INITIAL_SELECTED_INDEX
 	    };
 	  },
 	
 	  componentDidMount() {
+	    var endOfInput = this.state.inputValue.length;
 	    this.refs.searchInput.focus();
+	    this.refs.searchInput.setSelectionRange(endOfInput, endOfInput);
 	  },
 	
 	  componentDidUpdate() {
 	    this.scrollList();
 	  },
 	
 	  scrollList() {
 	    var resultsEl = this.refs.results;
@@ -32858,17 +33336,24 @@ var Debugger =
 	      });
 	      e.preventDefault();
 	    } else if (e.key === "ArrowDown") {
 	      this.setState({
 	        selectedIndex: Math.min(resultCount - 1, this.state.selectedIndex + 1)
 	      });
 	      e.preventDefault();
 	    } else if (e.key === "Enter") {
-	      this.props.selectItem(searchResults[this.state.selectedIndex]);
+	      if (searchResults.length) {
+	        this.props.selectItem(searchResults[this.state.selectedIndex]);
+	      } else {
+	        this.props.handleClose(this.state.inputValue);
+	      }
+	      e.preventDefault();
+	    } else if (e.key === "Tab") {
+	      this.props.handleClose(this.state.inputValue);
 	      e.preventDefault();
 	    }
 	  },
 	
 	  renderSearchItem(result, index) {
 	    return dom.li({
 	      onClick: () => this.props.selectItem(result),
 	      key: result.value,
@@ -32876,16 +33361,17 @@ var Debugger =
 	        selected: index === this.state.selectedIndex
 	      })
 	    }, dom.div({ className: "title" }, result.title), dom.div({ className: "subtitle" }, result.subtitle));
 	  },
 	
 	  renderInput() {
 	    return dom.input({
 	      ref: "searchInput",
+	      value: this.state.inputValue,
 	      onChange: e => this.setState({
 	        inputValue: e.target.value,
 	        selectedIndex: INITIAL_SELECTED_INDEX
 	      }),
 	      onFocus: e => this.setState({ focused: true }),
 	      onBlur: e => this.setState({ focused: false }),
 	      onKeyDown: this.onKeyDown,
 	      placeholder: L10N.getStr("sourceSearch.search")
@@ -32895,46 +33381,59 @@ var Debugger =
 	  renderResults(results) {
 	    if (results.length) {
 	      return dom.ul({ className: "results", ref: "results" }, results.map(this.renderSearchItem));
 	    } else if (this.state.inputValue && !results.length) {
 	      return dom.div({ className: "no-result-msg" }, Svg("sad-face"), L10N.getFormatStr("sourceSearch.noResults", this.state.inputValue));
 	    }
 	  },
 	
+	  renderSummary(searchResults) {
+	    if (searchResults && searchResults.length === 0) {
+	      return;
+	    }
+	
+	    var resultCountSummary = "";
+	    if (this.state.inputValue) {
+	      resultCountSummary = L10N.getFormatStr("sourceSearch.resultsSummary", searchResults.length, this.state.inputValue);
+	    }
+	    return dom.div({ className: "results-summary" }, resultCountSummary);
+	  },
+	
 	  render() {
 	    var searchResults = this.getSearchResults();
 	    return dom.div({ className: classnames({
 	        autocomplete: true,
 	        focused: this.state.focused
 	      })
 	    }, dom.div({ className: "searchinput-container" }, Svg("magnifying-glass"), this.renderInput(), CloseButton({
+	      buttonClass: "big",
 	      handleClick: this.props.handleClose
-	    })), this.renderResults(searchResults));
+	    })), this.renderSummary(searchResults), this.renderResults(searchResults));
 	  }
 	});
 	
 	module.exports = Autocomplete;
 
 /***/ },
-/* 297 */
+/* 301 */
 /***/ function(module, exports, __webpack_require__) {
 
 	(function() {
 	  var PathSeparator, filter, legacy_scorer, matcher, prepQueryCache, scorer;
 	
-	  scorer = __webpack_require__(298);
-	
-	  legacy_scorer = __webpack_require__(301);
-	
-	  filter = __webpack_require__(302);
-	
-	  matcher = __webpack_require__(303);
-	
-	  PathSeparator = __webpack_require__(299).sep;
+	  scorer = __webpack_require__(302);
+	
+	  legacy_scorer = __webpack_require__(305);
+	
+	  filter = __webpack_require__(306);
+	
+	  matcher = __webpack_require__(307);
+	
+	  PathSeparator = __webpack_require__(303).sep;
 	
 	  prepQueryCache = null;
 	
 	  module.exports = {
 	    filter: function(candidates, query, options) {
 	      if (!((query != null ? query.length : void 0) && (candidates != null ? candidates.length : void 0))) {
 	        return [];
 	      }
@@ -32999,23 +33498,23 @@ var Debugger =
 	      return matches;
 	    }
 	  };
 	
 	}).call(this);
 
 
 /***/ },
-/* 298 */
+/* 302 */
 /***/ function(module, exports, __webpack_require__) {
 
 	(function() {
 	  var AcronymResult, PathSeparator, Query, basenameScore, coreChars, countDir, doScore, emptyAcronymResult, file_coeff, isMatch, isSeparator, isWordEnd, isWordStart, miss_coeff, opt_char_re, pos_bonus, scoreAcronyms, scoreCharacter, scoreConsecutives, scoreExact, scoreExactMatch, scorePattern, scorePosition, scoreSize, tau_depth, tau_size, truncatedUpperCase, wm;
 	
-	  PathSeparator = __webpack_require__(299).sep;
+	  PathSeparator = __webpack_require__(303).sep;
 	
 	  wm = 150;
 	
 	  pos_bonus = 20;
 	
 	  tau_depth = 13;
 	
 	  tau_size = 85;
@@ -33392,17 +33891,17 @@ var Debugger =
 	    }
 	    return upper;
 	  };
 	
 	}).call(this);
 
 
 /***/ },
-/* 299 */
+/* 303 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/* WEBPACK VAR INJECTION */(function(process) {// 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,
@@ -33620,20 +34119,20 @@ var Debugger =
 	var substr = 'ab'.substr(-1) === 'b'
 	    ? function (str, start, len) { return str.substr(start, len) }
 	    : function (str, start, len) {
 	        if (start < 0) start = str.length + start;
 	        return str.substr(start, len);
 	    }
 	;
 	
-	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(300)))
-
-/***/ },
-/* 300 */
+	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(304)))
+
+/***/ },
+/* 304 */
 /***/ function(module, exports) {
 
 	// shim for using process in browser
 	var process = module.exports = {};
 	
 	// cached from whatever global is present so that test runners that stub it
 	// don't break things.  But we need to wrap it in a try catch in case it is
 	// wrapped in strict mode code which doesn't define any globals.  It's inside a
@@ -33809,23 +34308,23 @@ var Debugger =
 	process.cwd = function () { return '/' };
 	process.chdir = function (dir) {
 	    throw new Error('process.chdir is not supported');
 	};
 	process.umask = function() { return 0; };
 
 
 /***/ },
-/* 301 */
+/* 305 */
 /***/ function(module, exports, __webpack_require__) {
 
 	(function() {
 	  var PathSeparator, queryIsLastPathSegment;
 	
-	  PathSeparator = __webpack_require__(299).sep;
+	  PathSeparator = __webpack_require__(303).sep;
 	
 	  exports.basenameScore = function(string, query, score) {
 	    var base, depth, index, lastCharacter, segmentCount, slashCount;
 	    index = string.length - 1;
 	    while (string[index] === PathSeparator) {
 	      index--;
 	    }
 	    slashCount = 0;
@@ -33943,35 +34442,35 @@ var Debugger =
 	    }
 	    return matches;
 	  };
 	
 	}).call(this);
 
 
 /***/ },
-/* 302 */
+/* 306 */
 /***/ function(module, exports, __webpack_require__) {
 
 	(function() {
 	  var PathSeparator, legacy_scorer, pluckCandidates, scorer, sortCandidates;
 	
-	  scorer = __webpack_require__(298);
-	
-	  legacy_scorer = __webpack_require__(301);
+	  scorer = __webpack_require__(302);
+	
+	  legacy_scorer = __webpack_require__(305);
 	
 	  pluckCandidates = function(a) {
 	    return a.candidate;
 	  };
 	
 	  sortCandidates = function(a, b) {
 	    return b.score - a.score;
 	  };
 	
-	  PathSeparator = __webpack_require__(299).sep;
+	  PathSeparator = __webpack_require__(303).sep;
 	
 	  module.exports = function(candidates, query, _arg) {
 	    var allowErrors, bAllowErrors, bKey, candidate, coreQuery, key, legacy, maxInners, maxResults, prepQuery, queryHasSlashes, score, scoredCandidates, spotLeft, string, _i, _j, _len, _len1, _ref;
 	    _ref = _arg != null ? _arg : {}, key = _ref.key, maxResults = _ref.maxResults, maxInners = _ref.maxInners, allowErrors = _ref.allowErrors, legacy = _ref.legacy;
 	    scoredCandidates = [];
 	    spotLeft = (maxInners != null) && maxInners > 0 ? maxInners : candidates.length;
 	    bAllowErrors = !!allowErrors;
 	    bKey = key != null;
@@ -34022,25 +34521,25 @@ var Debugger =
 	    }
 	    return candidates;
 	  };
 	
 	}).call(this);
 
 
 /***/ },
-/* 303 */
+/* 307 */
 /***/ function(module, exports, __webpack_require__) {
 
 	(function() {
 	  var PathSeparator, scorer;
 	
-	  PathSeparator = __webpack_require__(299).sep;
-	
-	  scorer = __webpack_require__(298);
+	  PathSeparator = __webpack_require__(303).sep;
+	
+	  scorer = __webpack_require__(302);
 	
 	  exports.basenameMatch = function(subject, subject_lw, prepQuery) {
 	    var basePos, depth, end;
 	    end = subject.length - 1;
 	    while (subject[end] === PathSeparator) {
 	      end--;
 	    }
 	    basePos = subject.lastIndexOf(PathSeparator, end);
@@ -34175,63 +34674,63 @@ var Debugger =
 	    matches.reverse();
 	    return matches;
 	  };
 	
 	}).call(this);
 
 
 /***/ },
-/* 304 */
+/* 308 */
 /***/ function(module, exports) {
 
 	// removed by extract-text-webpack-plugin
 
 /***/ },
-/* 305 */,
-/* 306 */
+/* 309 */,
+/* 310 */
 /***/ function(module, exports, __webpack_require__) {
 
 	/**
 	 * This file maps the SVG React Components in the public/images directory.
 	 */
-	var Svg = __webpack_require__(307);
+	var Svg = __webpack_require__(311);
 	module.exports = Svg;
 
 /***/ },
-/* 307 */
+/* 311 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
-	var InlineSVG = __webpack_require__(308);
+	var InlineSVG = __webpack_require__(312);
 	
 	var svg = {
-	  "angle-brackets": __webpack_require__(309),
-	  "arrow": __webpack_require__(310),
-	  "blackBox": __webpack_require__(311),
-	  "breakpoint": __webpack_require__(312),
-	  "close": __webpack_require__(313),
-	  "domain": __webpack_require__(314),
-	  "file": __webpack_require__(315),
-	  "folder": __webpack_require__(316),
-	  "globe": __webpack_require__(317),
-	  "magnifying-glass": __webpack_require__(318),
-	  "pause": __webpack_require__(319),
-	  "pause-exceptions": __webpack_require__(320),
-	  "plus": __webpack_require__(321),
-	  "prettyPrint": __webpack_require__(322),
-	  "resume": __webpack_require__(323),
-	  "settings": __webpack_require__(324),
-	  "stepIn": __webpack_require__(325),
-	  "stepOut": __webpack_require__(326),
-	  "stepOver": __webpack_require__(327),
-	  "subSettings": __webpack_require__(328),
-	  "toggleBreakpoints": __webpack_require__(329),
-	  "worker": __webpack_require__(330),
-	  "sad-face": __webpack_require__(331)
+	  "angle-brackets": __webpack_require__(313),
+	  "arrow": __webpack_require__(314),
+	  "blackBox": __webpack_require__(315),
+	  "breakpoint": __webpack_require__(316),
+	  "close": __webpack_require__(317),
+	  "domain": __webpack_require__(318),
+	  "file": __webpack_require__(319),
+	  "folder": __webpack_require__(320),
+	  "globe": __webpack_require__(321),
+	  "magnifying-glass": __webpack_require__(322),
+	  "pause": __webpack_require__(323),
+	  "pause-exceptions": __webpack_require__(324),
+	  "plus": __webpack_require__(325),
+	  "prettyPrint": __webpack_require__(326),
+	  "resume": __webpack_require__(327),
+	  "settings": __webpack_require__(328),
+	  "stepIn": __webpack_require__(329),
+	  "stepOut": __webpack_require__(330),
+	  "stepOver": __webpack_require__(331),
+	  "subSettings": __webpack_require__(332),
+	  "toggleBreakpoints": __webpack_require__(333),
+	  "worker": __webpack_require__(334),
+	  "sad-face": __webpack_require__(335)
 	};
 	
 	module.exports = function (name, props) {
 	  // eslint-disable-line
 	  if (!svg[name]) {
 	    throw new Error("Unknown SVG: " + name);
 	  }
 	  var className = name;
@@ -34241,17 +34740,17 @@ var Debugger =
 	  if (name === "subSettings") {
 	    className = "";
 	  }
 	  props = Object.assign({}, props, { className, src: svg[name] });
 	  return React.createElement(InlineSVG, props);
 	};
 
 /***/ },
-/* 308 */
+/* 312 */
 /***/ function(module, exports, __webpack_require__) {
 
 	'use strict';
 	
 	Object.defineProperty(exports, '__esModule', {
 	    value: true
 	});
 	
@@ -34397,216 +34896,220 @@ var Debugger =
 	
 	    return InlineSVG;
 	})(_react2['default'].Component);
 	
 	exports['default'] = InlineSVG;
 	module.exports = exports['default'];
 
 /***/ },
-/* 309 */
+/* 313 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"-1 73 16 11\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"><g id=\"Shape-Copy-3-+-Shape-Copy-4\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(0.000000, 74.000000)\"><path d=\"M0.749321284,4.16081709 L4.43130681,0.242526751 C4.66815444,-0.00952143591 5.06030999,-0.0211407611 5.30721074,0.216574262 C5.55411149,0.454289284 5.56226116,0.851320812 5.32541353,1.103369 L1.95384971,4.69131519 L5.48809879,8.09407556 C5.73499955,8.33179058 5.74314922,8.72882211 5.50630159,8.9808703 C5.26945396,9.23291849 4.87729841,9.24453781 4.63039766,9.00682279 L0.827097345,5.34502101 C0.749816996,5.31670099 0.677016974,5.27216098 0.613753508,5.21125118 C0.427367989,5.03179997 0.377040713,4.7615583 0.465458792,4.53143559 C0.492371834,4.43667624 0.541703274,4.34676528 0.613628034,4.27022448 C0.654709457,4.22650651 0.70046335,4.19002189 0.749321284,4.16081709 Z\" id=\"Shape-Copy-3\" stroke=\"#FFFFFF\" stroke-width=\"0.05\" fill=\"#DDE1E4\"></path><path d=\"M13.7119065,5.44453032 L9.77062746,9.09174784 C9.51677479,9.3266604 9.12476399,9.31089603 8.89504684,9.05653714 C8.66532968,8.80217826 8.68489539,8.40554539 8.93874806,8.17063283 L12.5546008,4.82456128 L9.26827469,1.18571135 C9.03855754,0.931352463 9.05812324,0.534719593 9.31197591,0.299807038 C9.56582858,0.0648944831 9.95783938,0.0806588502 10.1875565,0.335017737 L13.72891,4.25625178 C13.8013755,4.28980469 13.8684335,4.3382578 13.9254821,4.40142604 C14.0883019,4.58171146 14.1258883,4.83347168 14.0435812,5.04846202 C14.0126705,5.15680232 13.9526426,5.2583679 13.8641331,5.34027361 C13.8174417,5.38348136 13.7660763,5.41820853 13.7119065,5.44453032 Z\" id=\"Shape-Copy-4\" stroke=\"#FFFFFF\" stroke-width=\"0.05\" fill=\"#DDE1E4\"></path></g></svg>"
 
 /***/ },
-/* 310 */
+/* 314 */
 /***/ function(module, exports) {
 
 	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/. --><svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" viewBox=\"0 0 16 16\"><path d=\"M8 13.4c-.5 0-.9-.2-1.2-.6L.4 5.2C0 4.7-.1 4.3.2 3.7S1 3 1.6 3h12.8c.6 0 1.2.1 1.4.7.3.6.2 1.1-.2 1.6l-6.4 7.6c-.3.4-.7.5-1.2.5z\"></path></svg>"
 
 /***/ },
-/* 311 */
+/* 315 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><g fill-rule=\"evenodd\"><circle cx=\"8\" cy=\"8.5\" r=\"1.5\"></circle><path d=\"M15.498 8.28l-.001-.03v-.002-.004l-.002-.018-.004-.031c0-.002 0-.002 0 0l-.004-.035.006.082c-.037-.296-.133-.501-.28-.661-.4-.522-.915-1.042-1.562-1.604-1.36-1.182-2.74-1.975-4.178-2.309a6.544 6.544 0 0 0-2.755-.042c-.78.153-1.565.462-2.369.91C3.252 5.147 2.207 6 1.252 7.035c-.216.233-.36.398-.499.577-.338.437-.338 1 0 1.437.428.552.941 1.072 1.59 1.635 1.359 1.181 2.739 1.975 4.177 2.308.907.21 1.829.223 2.756.043.78-.153 1.564-.462 2.369-.91 1.097-.612 2.141-1.464 3.097-2.499.217-.235.36-.398.498-.578.12-.128.216-.334.248-.554 0 .01 0 .01-.008.04l.013-.079-.001.011.003-.031.001-.017v.005l.001-.02v.008l.002-.03.001-.05-.001-.044v-.004-.004zm-.954.045v.007l.001.004V8.33v.012l-.001.01v-.005-.005l.002-.015-.001.008c-.002.014-.002.014 0 0l-.007.084c.003-.057-.004-.041-.014-.031-.143.182-.27.327-.468.543-.89.963-1.856 1.752-2.86 2.311-.724.404-1.419.677-2.095.81a5.63 5.63 0 0 1-2.374-.036c-1.273-.295-2.523-1.014-3.774-2.101-.604-.525-1.075-1.001-1.457-1.496-.054-.07-.054-.107 0-.177.117-.152.244-.298.442-.512.89-.963 1.856-1.752 2.86-2.311.724-.404 1.419-.678 2.095-.81a5.631 5.631 0 0 1 2.374.036c1.272.295 2.523 1.014 3.774 2.101.603.524 1.074 1 1.457 1.496.035.041.043.057.046.076 0 .01 0 .01.008.043l-.009-.047.003.02-.002-.013v-.008.016c0-.004 0-.004 0 0v-.004z\"></path></g></svg>"
 
 /***/ },
-/* 312 */
+/* 316 */
 /***/ function(module, exports) {
 
 	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/. --><svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" viewBox=\"0 0 60 12\"><path id=\"base-path\" d=\"M53.9,0H1C0.4,0,0,0.4,0,1v10c0,0.6,0.4,1,1,1h52.9c0.6,0,1.2-0.3,1.5-0.7L60,6l-4.4-5.3C55,0.3,54.5,0,53.9,0z\"></path></svg>"
 
 /***/ },
-/* 313 */
+/* 317 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 6 6\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"><path d=\"M1.35191454,5.27895256 L5.31214367,1.35518468 C5.50830675,1.16082764 5.50977084,0.844248536 5.3154138,0.648085456 C5.12105677,0.451922377 4.80447766,0.450458288 4.60831458,0.644815324 L0.648085456,4.56858321 C0.451922377,4.76294025 0.450458288,5.07951935 0.644815324,5.27568243 C0.83917236,5.47184551 1.15575146,5.4733096 1.35191454,5.27895256 L1.35191454,5.27895256 Z\" id=\"Line\" stroke=\"none\" fill=\"#696969\" fill-rule=\"evenodd\"></path><path d=\"M5.31214367,4.56858321 L1.35191454,0.644815324 C1.15575146,0.450458288 0.83917236,0.451922377 0.644815324,0.648085456 C0.450458288,0.844248536 0.451922377,1.16082764 0.648085456,1.35518468 L4.60831458,5.27895256 C4.80447766,5.4733096 5.12105677,5.47184551 5.3154138,5.27568243 C5.50977084,5.07951935 5.50830675,4.76294025 5.31214367,4.56858321 L5.31214367,4.56858321 Z\" id=\"Line-Copy-2\" stroke=\"none\" fill=\"#696969\" fill-rule=\"evenodd\"></path></svg>"
 
 /***/ },
-/* 314 */
+/* 318 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M9.05 4.634l-2.144.003-.116.116v1.445l.92.965.492.034.116-.116v-.617L9.13 5.7l.035-.95M12.482 10.38l-1.505-1.462H9.362l-.564.516-.034 1.108.72.768 1.323.034-.117-.116v1.2l.972 1.02.315.034.116-.116v-1.154l.422-.374.034-.927-.117.117h.26l.408-.36V10.5l-.125-.124-.575-.033\"></path><path d=\"M8.47 15.073c-3.088 0-5.6-2.513-5.6-5.602V9.4v-.003c0-.018 0-.018.002-.034l.182-.088.724.587.49.033.497.543-.034.9.317.383h.47l.114.096-.032 1.9.524.553h.105l.025-.338 1.004-.95.054-.474.53-.462v-.888l-.588-.038-1.118-1.155H4.48l-.154-.09V9.01l.155-.1h1.164v-.273l.12-.115.7.033.494-.443.034-.746-.624-.655h-.724v.28l-.11.07H4.64l-.114-.09.025-.64.48-.43v-.244h-.382c-.102 0-.152-.128-.08-.2 1.04-1.01 2.428-1.59 3.903-1.59 1.374 0 2.672.5 3.688 1.39.08.068.03.198-.075.198l-1.144-.034-.81.803.52.523v.16l-.382.388h-.158l-.176-.177v-.16l.076-.074-.252-.252-.37.362.53.53c.072.072.005.194-.096.194l-.752-.005v.844h.783L9.885 8l.16-.143h.16l.62.61v.267l.58.027.003.002V8.76l.18-.03 1.234 1.24.753-.708h.382l.116.108c0 .02.003.016.003.036v.065c0 3.09-2.515 5.603-5.605 5.603M8.47 3C4.904 3 2 5.903 2 9.47c0 3.57 2.903 6.472 6.47 6.472 3.57 0 6.472-2.903 6.472-6.47C14.942 5.9 12.04 3 8.472 3\"></path></svg>"
 
 /***/ },
-/* 315 */
+/* 319 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4 2v12h9V4.775L9.888 2H4zm0-1h5.888c.246 0 .483.09.666.254l3.112 2.774c.212.19.334.462.334.747V14c0 .552-.448 1-1 1H4c-.552 0-1-.448-1-1V2c0-.552.448-1 1-1z\"></path><path d=\"M9 1.5v4c0 .325.306.564.62.485l4-1c.27-.067.432-.338.365-.606-.067-.27-.338-.432-.606-.365l-4 1L10 5.5v-4c0-.276-.224-.5-.5-.5s-.5.224-.5.5z\"></path></svg>"
 
 /***/ },
-/* 316 */
+/* 320 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2 5.193v7.652c0 .003-.002 0 .007 0H14v-7.69c0-.003.002 0-.007 0h-7.53v-2.15c0-.002-.004-.005-.01-.005H2.01C2 3 2 3 2 3.005V5.193zm-1 0V3.005C1 2.45 1.444 2 2.01 2h4.442c.558 0 1.01.45 1.01 1.005v1.15h6.53c.557 0 1.008.44 1.008 1v7.69c0 .553-.45 1-1.007 1H2.007c-.556 0-1.007-.44-1.007-1V5.193zM6.08 4.15H2v1h4.46v-1h-.38z\" fill-rule=\"evenodd\"></path></svg>"
 
 /***/ },
-/* 317 */
+/* 321 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"14 6 13 12\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"><g id=\"world\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(14.000000, 6.000000)\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M6.35076107,0.354 C3.25095418,0.354 0.729,2.87582735 0.729,5.9758879 C0.729,9.07544113 3.25082735,11.5972685 6.35076107,11.5972685 C9.45044113,11.5972685 11.9723953,9.07544113 11.9723953,5.97576107 C11.9723953,2.87582735 9.45044113,0.354 6.35076107,0.354 L6.35076107,0.354 Z M6.35076107,10.8289121 C3.67445071,10.8289121 1.49722956,8.65181776 1.49722956,5.97576107 C1.49722956,5.9443064 1.49900522,5.91335907 1.49976622,5.88215806 L2.20090094,6.4213266 L2.56313696,6.4213266 L2.97268183,6.8306178 L2.97268183,7.68217686 L3.32324919,8.03287105 L3.73926255,8.03287105 L3.73926255,9.79940584 L4.27386509,10.3361645 L4.4591686,10.3361645 L4.4591686,10.000183 L5.37655417,9.08343163 L5.37655417,8.73400577 L5.85585737,8.25203907 L5.85585737,7.37206934 L5.32518666,7.37206934 L4.28439226,6.33140176 L2.82225748,6.33140176 L2.82225748,5.56938704 L3.96286973,5.56938704 L3.96286973,5.23949352 L4.65068695,5.23949352 L5.11477015,4.77667865 L5.11477015,4.03001076 L4.49087694,3.40662489 L3.75359472,3.40662489 L3.75359472,3.78725175 L2.96228149,3.78725175 L2.96228149,3.28385021 L3.42217919,2.82319151 L3.42217919,2.49786399 L2.97001833,2.49786399 C3.84466106,1.64744643 5.03714814,1.12222956 6.35063424,1.12222956 C7.57292716,1.12222956 8.69020207,1.57730759 9.54442463,2.32587797 L8.46164839,2.32587797 L7.680355,3.10666403 L8.21508437,3.64088607 L7.87238068,3.98257509 L7.7165025,3.82669692 L7.85297518,3.68946324 L7.78930484,3.62566607 L7.78943167,3.62566607 L7.56011699,3.39559038 L7.55986332,3.39571722 L7.49758815,3.33318838 L7.01904595,3.78585658 L7.55910232,4.32654712 L6.8069806,4.32198112 L6.8069806,5.25864535 L7.66716433,5.25864535 L7.6723645,4.72112565 L7.81289584,4.57996014 L8.31819988,5.08653251 L8.31819988,5.41921636 L9.00703176,5.41921636 L9.03366676,5.39321553 L9.03430093,5.39194719 L10.195587,6.55259911 L10.8637451,5.88520206 L11.2018828,5.88520206 C11.2023901,5.9153884 11.2041658,5.94532107 11.2041658,5.97563424 C11.2040389,8.65181776 9.0269446,10.8289121 6.35076107,10.8289121 L6.35076107,10.8289121 Z\" id=\"Shape\" stroke=\"#DDE1E5\" stroke-width=\"0.25\" fill=\"#DDE1E5\"></path><polygon id=\"Shape\" stroke=\"#DDE1E5\" stroke-width=\"0.25\" fill=\"#DDE1E5\" points=\"6.50676608 1.61523076 4.52892694 1.61789426 4.52892694 2.95192735 5.34560683 3.76733891 5.72496536 3.76733891 5.72496536 3.1967157 6.50676608 2.41592965\"></polygon><polygon id=\"Shape\" stroke=\"#DDE1E5\" stroke-width=\"0.25\" fill=\"#DDE1E5\" points=\"9.59959714 6.88718547 8.28623788 5.57268471 8.28623788 5.57002121 6.79607294 5.57002121 6.35101474 6.01469891 6.35101474 6.96201714 6.98429362 7.59466185 8.12909136 7.59466185 8.12909136 8.70343893 8.99434843 9.56882283 9.20971144 9.56882283 9.20971144 8.50329592 9.63029081 8.08271655 9.63029081 7.3026915 9.87025949 7.3026915 10.1711082 7.00082814 10.0558167 6.88718547\"></polygon></g></svg>"
 
 /***/ },
-/* 318 */
+/* 322 */
 /***/ function(module, exports) {
 
 	module.exports = "<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 16 16\"><path class=\"st0\" d=\"M9 9.3l3.6 3.6\"></path><ellipse fill=\"transparent\" cx=\"5.9\" cy=\"6.2\" rx=\"4.5\" ry=\"4.5\"></ellipse></svg>"
 
 /***/ },
-/* 319 */
+/* 323 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><g fill-rule=\"evenodd\"><path d=\"M6.5 12.003l.052-9a.5.5 0 1 0-1-.006l-.052 9a.5.5 0 1 0 1 .006zM13 11.997l-.05-9a.488.488 0 0 0-.477-.497.488.488 0 0 0-.473.503l.05 9a.488.488 0 0 0 .477.497.488.488 0 0 0 .473-.503z\"></path></g></svg>"
 
 /***/ },
-/* 320 */
+/* 324 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M10.483 13.995H5.517l-3.512-3.512V5.516l3.512-3.512h4.966l3.512 3.512v4.967l-3.512 3.512zm4.37-9.042l-3.807-3.805A.503.503 0 0 0 10.691 1H5.309a.503.503 0 0 0-.356.148L1.147 4.953A.502.502 0 0 0 1 5.308v5.383c0 .134.053.262.147.356l3.806 3.806a.503.503 0 0 0 .356.147h5.382a.503.503 0 0 0 .355-.147l3.806-3.806A.502.502 0 0 0 15 10.69V5.308a.502.502 0 0 0-.147-.355z\"></path><path d=\"M10 10.5a.5.5 0 1 0 1 0v-5a.5.5 0 1 0-1 0v5zM5 10.5a.5.5 0 1 0 1 0v-5a.5.5 0 0 0-1 0v5z\"></path></svg>"
 
 /***/ },
-/* 321 */
+/* 325 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.5 8.5V14a.5.5 0 1 1-1 0V8.5H2a.5.5 0 0 1 0-1h5.5V2a.5.5 0 0 1 1 0v5.5H14a.5.5 0 1 1 0 1H8.5z\" fill-rule=\"evenodd\"></path></svg>"
 
 /***/ },
-/* 322 */
+/* 326 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4.525 13.21h-.472c-.574 0-.987-.154-1.24-.463-.253-.31-.38-.882-.38-1.719v-.573c0-.746-.097-1.265-.292-1.557-.196-.293-.51-.44-.945-.44v-.974c.435 0 .75-.146.945-.44.195-.292.293-.811.293-1.556v-.58c0-.833.126-1.404.379-1.712.253-.31.666-.464 1.24-.464h.472v.783h-.179c-.37 0-.628.08-.774.24-.145.159-.218.54-.218 1.141v.383c0 .824-.096 1.432-.287 1.823-.191.39-.516.679-.974.866.458.191.783.482.974.873.191.39.287.998.287 1.823v.382c0 .602.073.982.218 1.142.146.16.404.239.774.239h.18v.783zm9.502-4.752c-.43 0-.744.147-.942.44-.197.292-.296.811-.296 1.557v.573c0 .837-.125 1.41-.376 1.719-.251.309-.664.463-1.237.463h-.478v-.783h.185c.37 0 .628-.08.774-.24.145-.159.218-.539.218-1.14v-.383c0-.825.096-1.433.287-1.823.191-.39.516-.682.974-.873-.458-.187-.783-.476-.974-.866-.191-.391-.287-.999-.287-1.823v-.383c0-.602-.073-.982-.218-1.142-.146-.159-.404-.239-.774-.239h-.185v-.783h.478c.573 0 .986.155 1.237.464.25.308.376.88.376 1.712v.58c0 .673.088 1.174.263 1.503.176.329.5.493.975.493v.974z\" fill-rule=\"evenodd\"></path></svg>"
 
 /***/ },
-/* 323 */
+/* 327 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.925 12.5l7.4-5-7.4-5v10zM6 12.5v-10c0-.785.8-1.264 1.415-.848l7.4 5c.58.392.58 1.304 0 1.696l-7.4 5C6.8 13.764 6 13.285 6 12.5z\" fill-rule=\"evenodd\"></path></svg>"
 
 /***/ },
-/* 324 */
+/* 328 */
 /***/ function(module, exports) {
 
 	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/. --><svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" viewBox=\"0 0 33 12\"><path id=\"base-path\" d=\"M27.1,0H1C0.4,0,0,0.4,0,1v10c0,0.6,0.4,1,1,1h26.1 c0.6,0,1.2-0.3,1.5-0.7L33,6l-4.4-5.3C28.2,0.3,27.7,0,27.1,0z\"></path></svg>"
 
 /***/ },
-/* 325 */
+/* 329 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><g fill-rule=\"evenodd\"><path d=\"M1.5 14.042h4.095a.5.5 0 0 0 0-1H1.5a.5.5 0 1 0 0 1zM7.983 2a.5.5 0 0 1 .517.5v7.483l3.136-3.326a.5.5 0 1 1 .728.686l-4 4.243a.499.499 0 0 1-.73-.004L3.635 7.343a.5.5 0 0 1 .728-.686L7.5 9.983V3H1.536C1.24 3 1 2.776 1 2.5s.24-.5.536-.5h6.447zM10.5 14.042h4.095a.5.5 0 0 0 0-1H10.5a.5.5 0 1 0 0 1z\"></path></g></svg>"
 
 /***/ },
-/* 326 */
+/* 330 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><g fill-rule=\"evenodd\"><path d=\"M5 13.5H1a.5.5 0 1 0 0 1h4a.5.5 0 1 0 0-1zM12 13.5H8a.5.5 0 1 0 0 1h4a.5.5 0 1 0 0-1zM6.11 5.012A.427.427 0 0 1 6.21 5h7.083L9.646 1.354a.5.5 0 1 1 .708-.708l4.5 4.5a.498.498 0 0 1 0 .708l-4.5 4.5a.5.5 0 0 1-.708-.708L13.293 6H6.5v5.5a.5.5 0 1 1-1 0v-6a.5.5 0 0 1 .61-.488z\"></path></g></svg>"
 
 /***/ },
-/* 327 */
+/* 331 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><g fill-rule=\"evenodd\"><path d=\"M13.297 6.912C12.595 4.39 10.167 2.5 7.398 2.5A5.898 5.898 0 0 0 1.5 8.398a.5.5 0 0 0 1 0A4.898 4.898 0 0 1 7.398 3.5c2.75 0 5.102 2.236 5.102 4.898v.004L8.669 7.029a.5.5 0 0 0-.338.942l4.462 1.598a.5.5 0 0 0 .651-.34.506.506 0 0 0 .02-.043l2-5a.5.5 0 1 0-.928-.372l-1.24 3.098z\"></path><circle cx=\"7\" cy=\"12\" r=\"1\"></circle></g></svg>"
 
 /***/ },
-/* 328 */
+/* 332 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M12.219 7c.345 0 .635.117.869.352.234.234.351.524.351.869 0 .351-.118.652-.356.903-.238.25-.526.376-.864.376-.332 0-.615-.125-.85-.376a1.276 1.276 0 0 1-.351-.903A1.185 1.185 0 0 1 12.218 7zM8.234 7c.345 0 .635.117.87.352.234.234.351.524.351.869 0 .351-.119.652-.356.903-.238.25-.526.376-.865.376-.332 0-.613-.125-.844-.376a1.286 1.286 0 0 1-.347-.903c0-.352.114-.643.342-.874.228-.231.51-.347.85-.347zM4.201 7c.339 0 .627.117.864.352.238.234.357.524.357.869 0 .351-.119.652-.357.903-.237.25-.525.376-.864.376-.338 0-.623-.125-.854-.376A1.286 1.286 0 0 1 3 8.221 1.185 1.185 0 0 1 4.201 7z\" fill-rule=\"evenodd\"></path></svg>"
 
 /***/ },
-/* 329 */
+/* 333 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><g fill-rule=\"evenodd\"><path d=\"M3.233 11.25l-.417 1H1.712C.763 12.25 0 11.574 0 10.747V6.503C0 5.675.755 5 1.712 5h4.127l-.417 1H1.597C1.257 6 1 6.225 1 6.503v4.244c0 .277.267.503.597.503h1.636zM7.405 11.27L7 12.306c.865.01 2.212-.024 2.315-.04.112-.016.112-.016.185-.035.075-.02.156-.046.251-.082.152-.056.349-.138.592-.244.415-.182.962-.435 1.612-.744l.138-.066a179.35 179.35 0 0 0 2.255-1.094c1.191-.546 1.191-2.074-.025-2.632l-.737-.34a3547.554 3547.554 0 0 0-3.854-1.78c-.029.11-.065.222-.11.336l-.232.596c.894.408 4.56 2.107 4.56 2.107.458.21.458.596 0 .806L9.197 11.27H7.405zM4.462 14.692l5-12a.5.5 0 1 0-.924-.384l-5 12a.5.5 0 1 0 .924.384z\"></path></g></svg>"
 
 /***/ },
-/* 330 */
+/* 334 */
 /***/ function(module, exports) {
 
 	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/. --><svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><path fill-rule=\"evenodd\" d=\"M8.5 8.793L5.854 6.146l-.04-.035L7.5 4.426c.2-.2.3-.4.3-.6 0-.2-.1-.4-.2-.6l-1-1c-.4-.3-.9-.3-1.2 0l-4.1 4.1c-.2.2-.3.4-.3.6 0 .2.1.4.2.6l1 1c.3.3.9.3 1.2 0l1.71-1.71.036.04L7.793 9.5l-3.647 3.646c-.195.196-.195.512 0 .708.196.195.512.195.708 0L8.5 10.207l3.646 3.647c.196.195.512.195.708 0 .195-.196.195-.512 0-.708L9.207 9.5l2.565-2.565L13.3 8.5c.1.1 2.3 1.1 2.7.7.4-.4-.3-2.7-.5-2.9l-1.1-1.1c.1-.1.2-.4.2-.6 0-.2-.1-.4-.2-.6l-.4-.4c-.3-.3-.8-.3-1.1 0l-1.5-1.4c-.2-.2-.3-.2-.5-.2s-.3.1-.5.2L9.2 3.4c-.2.1-.2.2-.2.4s.1.4.2.5l1.874 1.92L8.5 8.792z\"></path></svg>"
 
 /***/ },
-/* 331 */
+/* 335 */
 /***/ function(module, exports) {
 
 	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/. --><svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 16 16\" fill=\"#D92215\"><path d=\"M8 14.5c-3.6 0-6.5-2.9-6.5-6.5S4.4 1.5 8 1.5s6.5 2.9 6.5 6.5-2.9 6.5-6.5 6.5zm0-12C5 2.5 2.5 5 2.5 8S5 13.5 8 13.5 13.5 11 13.5 8 11 2.5 8 2.5z\"></path><circle cx=\"5\" cy=\"6\" r=\"1\" transform=\"translate(1 1)\"></circle><circle cx=\"9\" cy=\"6\" r=\"1\" transform=\"translate(1 1)\"></circle><path d=\"M5.5 11c-.1 0-.2 0-.3-.1-.2-.1-.3-.4-.1-.7C6 9 7 8.5 8.1 8.5c1.7.1 2.8 1.7 2.8 1.8.2.2.1.5-.1.7-.2.1-.6 0-.7-.2 0 0-.9-1.3-2-1.3-.7 0-1.4.4-2.1 1.3-.2.2-.4.2-.5.2z\"></path></svg>"
 
 /***/ },
-/* 332 */
+/* 336 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
 	var dom = React.DOM;
 	var PropTypes = React.PropTypes;
 	
-	var Svg = __webpack_require__(306);
-	
-	__webpack_require__(333);
+	var Svg = __webpack_require__(310);
+	
+	__webpack_require__(337);
 	
 	function CloseButton(_ref) {
 	  var handleClick = _ref.handleClick;
-	
-	  return dom.div({ className: "close-btn", onClick: handleClick }, Svg("close"));
+	  var buttonClass = _ref.buttonClass;
+	
+	  return dom.div({
+	    className: buttonClass ? "close-btn-" + buttonClass : "close-btn",
+	    onClick: handleClick
+	  }, Svg("close"));
 	}
 	
 	CloseButton.propTypes = {
 	  handleClick: PropTypes.func.isRequired
 	};
 	
 	module.exports = CloseButton;
 
 /***/ },
-/* 333 */
+/* 337 */
 /***/ function(module, exports) {
 
 	// removed by extract-text-webpack-plugin
 
 /***/ },
-/* 334 */,
-/* 335 */
+/* 338 */,
+/* 339 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
 	var dom = React.DOM;
 	var PropTypes = React.PropTypes;
 	
-	var ImPropTypes = __webpack_require__(233);
+	var ImPropTypes = __webpack_require__(235);
 	
 	var _require = __webpack_require__(3);
 	
 	var bindActionCreators = _require.bindActionCreators;
 	
 	var _require2 = __webpack_require__(19);
 	
 	var connect = _require2.connect;
 	
-	var _require3 = __webpack_require__(259);
+	var _require3 = __webpack_require__(261);
 	
 	var cmdString = _require3.cmdString;
 	
-	var SourcesTree = React.createFactory(__webpack_require__(336));
-	var actions = __webpack_require__(260);
-	
-	var _require4 = __webpack_require__(257);
+	var SourcesTree = React.createFactory(__webpack_require__(340));
+	var actions = __webpack_require__(262);
+	
+	var _require4 = __webpack_require__(259);
 	
 	var getSelectedSource = _require4.getSelectedSource;
 	var getSources = _require4.getSources;
 	
 	
-	__webpack_require__(394);
+	__webpack_require__(398);
 	
 	var Sources = React.createClass({
 	  propTypes: {
 	    sources: ImPropTypes.map.isRequired,
 	    selectSource: PropTypes.func.isRequired
 	  },
 	
 	  displayName: "Sources",
@@ -34620,42 +35123,42 @@ var Debugger =
 	    return dom.div({ className: "sources-panel" }, dom.div({ className: "sources-header" }, L10N.getStr("sources.header"), dom.span({ className: "sources-header-info" }, L10N.getFormatStr("sources.search", cmdString() + "+P"))), SourcesTree({ sources, selectSource }));
 	  }
 	});
 	
 	module.exports = connect(state => ({ selectedSource: getSelectedSource(state),
 	  sources: getSources(state) }), dispatch => bindActionCreators(actions, dispatch))(Sources);
 
 /***/ },
-/* 336 */
+/* 340 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
 	var dom = React.DOM;
 	var PropTypes = React.PropTypes;
 	
-	var classnames = __webpack_require__(209);
-	var ImPropTypes = __webpack_require__(233);
-	
-	var _require = __webpack_require__(227);
+	var classnames = __webpack_require__(211);
+	var ImPropTypes = __webpack_require__(235);
+	
+	var _require = __webpack_require__(229);
 	
 	var Set = _require.Set;
 	
-	var _require2 = __webpack_require__(337);
+	var _require2 = __webpack_require__(341);
 	
 	var nodeHasChildren = _require2.nodeHasChildren;
 	var createParentMap = _require2.createParentMap;
 	var addToTree = _require2.addToTree;
 	var collapseTree = _require2.collapseTree;
 	var createTree = _require2.createTree;
 	
-	var ManagedTree = React.createFactory(__webpack_require__(390));
-	var Svg = __webpack_require__(306);
-	
-	var _require3 = __webpack_require__(242);
+	var ManagedTree = React.createFactory(__webpack_require__(394));
+	var Svg = __webpack_require__(310);
+	
+	var _require3 = __webpack_require__(244);
 	
 	var throttle = _require3.throttle;
 	
 	
 	var SourcesTree = React.createClass({
 	  propTypes: {
 	    sources: ImPropTypes.map.isRequired,
 	    selectSource: PropTypes.func.isRequired
@@ -34770,17 +35273,17 @@ var Debugger =
 	        if (nodeHasChildren(item)) {
 	          return item.contents;
 	        }
 	        return [];
 	      },
 	      getRoots: () => sourceTree.contents,
 	      getKey: (item, i) => item.path,
 	      itemHeight: 30,
-	      autoExpandDepth: 2,
+	      autoExpandDepth: 1,
 	      onFocus: this.focusItem,
 	      renderItem: this.renderItem
 	    });
 	
 	    return dom.div({
 	      className: "sources-list",
 	      onKeyDown: e => {
 	        if (e.keyCode === 13 && focusedItem) {
@@ -34789,56 +35292,81 @@ var Debugger =
 	      }
 	    }, tree);
 	  }
 	});
 	
 	module.exports = SourcesTree;
 
 /***/ },
-/* 337 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(289);
+/* 341 */
+/***/ function(module, exports, __webpack_require__) {
+
+	
+	
+	/**
+	 * Utils for Sources Tree Component
+	 * @module utils/sources-tree
+	 */
+	
+	var _require = __webpack_require__(293);
 	
 	var parse = _require.parse;
 	
-	var _require2 = __webpack_require__(244);
+	var _require2 = __webpack_require__(246);
 	
 	var assert = _require2.assert;
 	
-	var _require3 = __webpack_require__(275);
+	var _require3 = __webpack_require__(277);
 	
 	var isPretty = _require3.isPretty;
 	
-	var merge = __webpack_require__(338);
+	var merge = __webpack_require__(342);
 	
 	var IGNORED_URLS = ["debugger eval code", "XStringBundle"];
 	
 	/**
 	 * Temporary Source type to be used only within this module
 	 * TODO: Replace with real Source type definition when refactoring types
-	 */
-	
-	
-	// TODO: createNode is exported so this type could be useful to other modules
-	
-	
+	 * @memberof utils/sources-tree
+	 * @static
+	 */
+	
+	
+	/**
+	 * TODO: createNode is exported so this type could be useful to other modules
+	 * @memberof utils/sources-tree
+	 * @static
+	 */
+	
+	
+	/**
+	 * @memberof utils/sources-tree
+	 * @static
+	 */
 	function nodeHasChildren(item) {
 	  return Array.isArray(item.contents);
 	}
 	
+	/**
+	 * @memberof utils/sources-tree
+	 * @static
+	 */
 	function createNode(name, path, contents) {
 	  return {
 	    name,
 	    path,
 	    contents: contents || null
 	  };
 	}
 	
+	/**
+	 * @memberof utils/sources-tree
+	 * @static
+	 */
 	function createParentMap(tree) {
 	  var map = new WeakMap();
 	
 	  function _traverse(subtree) {
 	    if (nodeHasChildren(subtree)) {
 	      for (var child of subtree.contents) {
 	        map.set(child, subtree);
 	        _traverse(child);
@@ -34847,16 +35375,20 @@ var Debugger =
 	  }
 	
 	  // Don't link each top-level path to the "root" node because the
 	  // user never sees the root
 	  tree.contents.forEach(_traverse);
 	  return map;
 	}
 	
+	/**
+	 * @memberof utils/sources-tree
+	 * @static
+	 */
 	function getURL(source) {
 	  var url = source.get("url");
 	  var def = { path: "", group: "" };
 	  if (!url) {
 	    return def;
 	  }
 	
 	  var _parse = parse(url);
@@ -34906,16 +35438,20 @@ var Debugger =
 	  }
 	
 	  return merge(def, {
 	    path: path,
 	    group: protocol ? protocol + "//" : ""
 	  });
 	}
 	
+	/**
+	 * @memberof utils/sources-tree
+	 * @static
+	 */
 	function addToTree(tree, source) {
 	  var url = getURL(source);
 	
 	  if (IGNORED_URLS.indexOf(url) != -1 || !source.get("url") || isPretty(source.toJS())) {
 	    return;
 	  }
 	
 	  url.path = decodeURIComponent(url.path);
@@ -34966,16 +35502,18 @@ var Debugger =
 	  } else {
 	    subtree.contents = source;
 	  }
 	}
 	
 	/**
 	 * Look at the nodes in the source tree, and determine the index of where to
 	 * insert a new node. The ordering is index -> folder -> file.
+	 * @memberof utils/sources-tree
+	 * @static
 	 */
 	function determineFileSortOrder(nodes, pathPart, isLastPart) {
 	  var partIsDir = !isLastPart || pathPart.indexOf(".") === -1;
 	
 	  return nodes.findIndex(node => {
 	    var nodeIsDir = nodeHasChildren(node);
 	
 	    // The index will always be the first thing, so this pathPart will be
@@ -34994,16 +35532,18 @@ var Debugger =
 	    // directory. Keep on searching if the part is a file, as it needs to be
 	    // placed after the directories.
 	    return partIsDir;
 	  });
 	}
 	
 	/**
 	 * Take an existing source tree, and return a new one with collapsed nodes.
+	 * @memberof utils/sources-tree
+	 * @static
 	 */
 	function collapseTree(node) {
 	  var depth = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
 	
 	  // Node is a folder.
 	  if (nodeHasChildren(node)) {
 	    // Node is not a root/domain node, and only contains 1 item.
 	    if (depth > 1 && node.contents.length === 1) {
@@ -35015,16 +35555,20 @@ var Debugger =
 	    }
 	    // Map the contents.
 	    return createNode(node.name, node.path, node.contents.map(next => collapseTree(next, depth + 1)));
 	  }
 	  // Node is a leaf, not a folder, do not modify it.
 	  return node;
 	}
 	
+	/**
+	 * @memberof utils/sources-tree
+	 * @static
+	 */
 	function createTree(sources) {
 	  var uncollapsedTree = createNode("root", "", []);
 	  for (var source of sources.valueSeq()) {
 	    addToTree(uncollapsedTree, source);
 	  }
 	  var sourceTree = collapseTree(uncollapsedTree);
 	
 	  return { uncollapsedTree,
@@ -35038,21 +35582,21 @@ var Debugger =
 	  nodeHasChildren,
 	  createParentMap,
 	  addToTree,
 	  collapseTree,
 	  createTree
 	};
 
 /***/ },
-/* 338 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseMerge = __webpack_require__(339),
-	    createAssigner = __webpack_require__(380);
+/* 342 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseMerge = __webpack_require__(343),
+	    createAssigner = __webpack_require__(384);
 	
 	/**
 	 * This method is like `_.assign` except that it recursively merges own and
 	 * inherited enumerable string keyed properties of source objects into the
 	 * destination object. Source properties that resolve to `undefined` are
 	 * skipped if a destination value exists. Array and plain object properties
 	 * are merged recursively. Other objects and value types are overridden by
 	 * assignment. Source objects are applied from left to right. Subsequent
@@ -35083,25 +35627,25 @@ var Debugger =
 	var merge = createAssigner(function(object, source, srcIndex) {
 	  baseMerge(object, source, srcIndex);
 	});
 	
 	module.exports = merge;
 
 
 /***/ },
-/* 339 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var Stack = __webpack_require__(340),
-	    assignMergeValue = __webpack_require__(346),
-	    baseFor = __webpack_require__(349),
-	    baseMergeDeep = __webpack_require__(351),
-	    isObject = __webpack_require__(104),
-	    keysIn = __webpack_require__(374);
+/* 343 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var Stack = __webpack_require__(344),
+	    assignMergeValue = __webpack_require__(350),
+	    baseFor = __webpack_require__(353),
+	    baseMergeDeep = __webpack_require__(355),
+	    isObject = __webpack_require__(106),
+	    keysIn = __webpack_require__(378);
 	
 	/**
 	 * The base implementation of `_.merge` without support for multiple sources.
 	 *
 	 * @private
 	 * @param {Object} object The destination object.
 	 * @param {Object} source The source object.
 	 * @param {number} srcIndex The index of `source`.
@@ -35130,25 +35674,25 @@ var Debugger =
 	    }
 	  }, keysIn);
 	}
 	
 	module.exports = baseMerge;
 
 
 /***/ },
-/* 340 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var ListCache = __webpack_require__(115),
-	    stackClear = __webpack_require__(341),
-	    stackDelete = __webpack_require__(342),
-	    stackGet = __webpack_require__(343),
-	    stackHas = __webpack_require__(344),
-	    stackSet = __webpack_require__(345);
+/* 344 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var ListCache = __webpack_require__(117),
+	    stackClear = __webpack_require__(345),
+	    stackDelete = __webpack_require__(346),
+	    stackGet = __webpack_require__(347),
+	    stackHas = __webpack_require__(348),
+	    stackSet = __webpack_require__(349);
 	
 	/**
 	 * Creates a stack cache object to store key-value pairs.
 	 *
 	 * @private
 	 * @constructor
 	 * @param {Array} [entries] The key-value pairs to cache.
 	 */
@@ -35163,20 +35707,20 @@ var Debugger =
 	Stack.prototype.get = stackGet;
 	Stack.prototype.has = stackHas;
 	Stack.prototype.set = stackSet;
 	
 	module.exports = Stack;
 
 
 /***/ },
-/* 341 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var ListCache = __webpack_require__(115);
+/* 345 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var ListCache = __webpack_require__(117);
 	
 	/**
 	 * Removes all key-value entries from the stack.
 	 *
 	 * @private
 	 * @name clear
 	 * @memberOf Stack
 	 */
@@ -35184,17 +35728,17 @@ var Debugger =
 	  this.__data__ = new ListCache;
 	  this.size = 0;
 	}
 	
 	module.exports = stackClear;
 
 
 /***/ },
-/* 342 */
+/* 346 */
 /***/ function(module, exports) {
 
 	/**
 	 * Removes `key` and its value from the stack.
 	 *
 	 * @private
 	 * @name delete
 	 * @memberOf Stack
@@ -35208,17 +35752,17 @@ var Debugger =
 	  this.size = data.size;
 	  return result;
 	}
 	
 	module.exports = stackDelete;
 
 
 /***/ },
-/* 343 */
+/* 347 */
 /***/ function(module, exports) {
 
 	/**
 	 * Gets the stack value for `key`.
 	 *
 	 * @private
 	 * @name get
 	 * @memberOf Stack
@@ -35228,17 +35772,17 @@ var Debugger =
 	function stackGet(key) {
 	  return this.__data__.get(key);
 	}
 	
 	module.exports = stackGet;
 
 
 /***/ },
-/* 344 */
+/* 348 */
 /***/ function(module, exports) {
 
 	/**
 	 * Checks if a stack value for `key` exists.
 	 *
 	 * @private
 	 * @name has
 	 * @memberOf Stack
@@ -35248,22 +35792,22 @@ var Debugger =
 	function stackHas(key) {
 	  return this.__data__.has(key);
 	}
 	
 	module.exports = stackHas;
 
 
 /***/ },
-/* 345 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var ListCache = __webpack_require__(115),
-	    Map = __webpack_require__(123),
-	    MapCache = __webpack_require__(96);
+/* 349 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var ListCache = __webpack_require__(117),
+	    Map = __webpack_require__(125),
+	    MapCache = __webpack_require__(98);
 	
 	/** Used as the size to enable large array optimizations. */
 	var LARGE_ARRAY_SIZE = 200;
 	
 	/**
 	 * Sets the stack `key` to `value`.
 	 *
 	 * @private
@@ -35288,21 +35832,21 @@ var Debugger =
 	  this.size = data.size;
 	  return this;
 	}
 	
 	module.exports = stackSet;
 
 
 /***/ },
-/* 346 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseAssignValue = __webpack_require__(347),
-	    eq = __webpack_require__(119);
+/* 350 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseAssignValue = __webpack_require__(351),
+	    eq = __webpack_require__(121);
 	
 	/**
 	 * This function is like `assignValue` except that it doesn't assign
 	 * `undefined` values.
 	 *
 	 * @private
 	 * @param {Object} object The object to modify.
 	 * @param {string} key The key of the property to assign.
@@ -35314,20 +35858,20 @@ var Debugger =
 	    baseAssignValue(object, key, value);
 	  }
 	}
 	
 	module.exports = assignMergeValue;
 
 
 /***/ },
-/* 347 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var defineProperty = __webpack_require__(348);
+/* 351 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var defineProperty = __webpack_require__(352);
 	
 	/**
 	 * The base implementation of `assignValue` and `assignMergeValue` without
 	 * value checks.
 	 *
 	 * @private
 	 * @param {Object} object The object to modify.
 	 * @param {string} key The key of the property to assign.
@@ -35345,37 +35889,37 @@ var Debugger =
 	    object[key] = value;
 	  }
 	}
 	
 	module.exports = baseAssignValue;
 
 
 /***/ },
-/* 348 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var getNative = __webpack_require__(101);
+/* 352 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var getNative = __webpack_require__(103);
 	
 	var defineProperty = (function() {
 	  try {
 	    var func = getNative(Object, 'defineProperty');
 	    func({}, '', {});
 	    return func;
 	  } catch (e) {}
 	}());
 	
 	module.exports = defineProperty;
 
 
 /***/ },
-/* 349 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var createBaseFor = __webpack_require__(350);
+/* 353 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var createBaseFor = __webpack_require__(354);
 	
 	/**
 	 * The base implementation of `baseForOwn` which iterates over `object`
 	 * properties returned by `keysFunc` and invokes `iteratee` for each property.
 	 * Iteratee functions may exit iteration early by explicitly returning `false`.
 	 *
 	 * @private
 	 * @param {Object} object The object to iterate over.
@@ -35384,17 +35928,17 @@ var Debugger =
 	 * @returns {Object} Returns `object`.
 	 */
 	var baseFor = createBaseFor();
 	
 	module.exports = baseFor;
 
 
 /***/ },
-/* 350 */
+/* 354 */
 /***/ function(module, exports) {
 
 	/**
 	 * Creates a base function for methods like `_.forIn` and `_.forOwn`.
 	 *
 	 * @private
 	 * @param {boolean} [fromRight] Specify iterating from right to left.
 	 * @returns {Function} Returns the new base function.
@@ -35415,33 +35959,33 @@ var Debugger =
 	    return object;
 	  };
 	}
 	
 	module.exports = createBaseFor;
 
 
 /***/ },
-/* 351 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assignMergeValue = __webpack_require__(346),
-	    cloneBuffer = __webpack_require__(352),
-	    cloneTypedArray = __webpack_require__(353),
-	    copyArray = __webpack_require__(356),
-	    initCloneObject = __webpack_require__(357),
-	    isArguments = __webpack_require__(360),
-	    isArray = __webpack_require__(92),
-	    isArrayLikeObject = __webpack_require__(362),
-	    isBuffer = __webpack_require__(365),
-	    isFunction = __webpack_require__(103),
-	    isObject = __webpack_require__(104),
+/* 355 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assignMergeValue = __webpack_require__(350),
+	    cloneBuffer = __webpack_require__(356),
+	    cloneTypedArray = __webpack_require__(357),
+	    copyArray = __webpack_require__(360),
+	    initCloneObject = __webpack_require__(361),
+	    isArguments = __webpack_require__(364),
+	    isArray = __webpack_require__(94),
+	    isArrayLikeObject = __webpack_require__(366),
+	    isBuffer = __webpack_require__(369),
+	    isFunction = __webpack_require__(105),
+	    isObject = __webpack_require__(106),
 	    isPlainObject = __webpack_require__(5),
-	    isTypedArray = __webpack_require__(367),
-	    toPlainObject = __webpack_require__(371);
+	    isTypedArray = __webpack_require__(371),
+	    toPlainObject = __webpack_require__(375);
 	
 	/**
 	 * A specialized version of `baseMerge` for arrays and objects which performs
 	 * deep merges and tracks traversed objects enabling objects with circular
 	 * references to be merged.
 	 *
 	 * @private
 	 * @param {Object} object The destination object.
@@ -35514,20 +36058,20 @@ var Debugger =
 	  }
 	  assignMergeValue(object, key, newValue);
 	}
 	
 	module.exports = baseMergeDeep;
 
 
 /***/ },
-/* 352 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(107);
+/* 356 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(109);
 	
 	/** Detect free variable `exports`. */
 	var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;
 	
 	/** Detect free variable `module`. */
 	var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;
 	
 	/** Detect the popular CommonJS extension `module.exports`. */
@@ -35556,20 +36100,20 @@ var Debugger =
 	  return result;
 	}
 	
 	module.exports = cloneBuffer;
 	
 	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(77)(module)))
 
 /***/ },
-/* 353 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var cloneArrayBuffer = __webpack_require__(354);
+/* 357 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var cloneArrayBuffer = __webpack_require__(358);
 	
 	/**
 	 * Creates a clone of `typedArray`.
 	 *
 	 * @private
 	 * @param {Object} typedArray The typed array to clone.
 	 * @param {boolean} [isDeep] Specify a deep clone.
 	 * @returns {Object} Returns the cloned typed array.
@@ -35578,20 +36122,20 @@ var Debugger =
 	  var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;
 	  return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);
 	}
 	
 	module.exports = cloneTypedArray;
 
 
 /***/ },
-/* 354 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var Uint8Array = __webpack_require__(355);
+/* 358 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var Uint8Array = __webpack_require__(359);
 	
 	/**
 	 * Creates a clone of `arrayBuffer`.
 	 *
 	 * @private
 	 * @param {ArrayBuffer} arrayBuffer The array buffer to clone.
 	 * @returns {ArrayBuffer} Returns the cloned array buffer.
 	 */
@@ -35600,29 +36144,29 @@ var Debugger =
 	  new Uint8Array(result).set(new Uint8Array(arrayBuffer));
 	  return result;
 	}
 	
 	module.exports = cloneArrayBuffer;
 
 
 /***/ },
-/* 355 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var root = __webpack_require__(107);
+/* 359 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var root = __webpack_require__(109);
 	
 	/** Built-in value references. */
 	var Uint8Array = root.Uint8Array;
 	
 	module.exports = Uint8Array;
 
 
 /***/ },
-/* 356 */
+/* 360 */
 /***/ function(module, exports) {
 
 	/**
 	 * Copies the values of `source` to `array`.
 	 *
 	 * @private
 	 * @param {Array} source The array to copy values from.
 	 * @param {Array} [array=[]] The array to copy values to.
@@ -35638,22 +36182,22 @@ var Debugger =
 	  }
 	  return array;
 	}
 	
 	module.exports = copyArray;
 
 
 /***/ },
-/* 357 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseCreate = __webpack_require__(358),
+/* 361 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseCreate = __webpack_require__(362),
 	    getPrototype = __webpack_require__(6),
-	    isPrototype = __webpack_require__(359);
+	    isPrototype = __webpack_require__(363);
 	
 	/**
 	 * Initializes an object clone.
 	 *
 	 * @private
 	 * @param {Object} object The object to clone.
 	 * @returns {Object} Returns the initialized clone.
 	 */
@@ -35662,20 +36206,20 @@ var Debugger =
 	    ? baseCreate(getPrototype(object))
 	    : {};
 	}
 	
 	module.exports = initCloneObject;
 
 
 /***/ },
-/* 358 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isObject = __webpack_require__(104);
+/* 362 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isObject = __webpack_require__(106);
 	
 	/** Built-in value references. */
 	var objectCreate = Object.create;
 	
 	/**
 	 * The base implementation of `_.create` without support for assigning
 	 * properties to the created object.
 	 *
@@ -35698,17 +36242,17 @@ var Debugger =
 	    return result;
 	  };
 	}());
 	
 	module.exports = baseCreate;
 
 
 /***/ },
-/* 359 */
+/* 363 */
 /***/ function(module, exports) {
 
 	/** Used for built-in method references. */
 	var objectProto = Object.prototype;
 	
 	/**
 	 * Checks if `value` is likely a prototype object.
 	 *
@@ -35722,20 +36266,20 @@ var Debugger =
 	
 	  return value === proto;
 	}
 	
 	module.exports = isPrototype;
 
 
 /***/ },
-/* 360 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseIsArguments = __webpack_require__(361),
+/* 364 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseIsArguments = __webpack_require__(365),
 	    isObjectLike = __webpack_require__(8);
 	
 	/** Used for built-in method references. */
 	var objectProto = Object.prototype;
 	
 	/** Used to check objects for own properties. */
 	var hasOwnProperty = objectProto.hasOwnProperty;
 	
@@ -35764,17 +36308,17 @@ var Debugger =
 	  return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&
 	    !propertyIsEnumerable.call(value, 'callee');
 	};
 	
 	module.exports = isArguments;
 
 
 /***/ },
-/* 361 */
+/* 365 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var isObjectLike = __webpack_require__(8);
 	
 	/** `Object#toString` result references. */
 	var argsTag = '[object Arguments]';
 	
 	/** Used for built-in method references. */
@@ -35797,20 +36341,20 @@ var Debugger =
 	function baseIsArguments(value) {
 	  return isObjectLike(value) && objectToString.call(value) == argsTag;
 	}
 	
 	module.exports = baseIsArguments;
 
 
 /***/ },
-/* 362 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isArrayLike = __webpack_require__(363),
+/* 366 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isArrayLike = __webpack_require__(367),
 	    isObjectLike = __webpack_require__(8);
 	
 	/**
 	 * This method is like `_.isArrayLike` except that it also checks if `value`
 	 * is an object.
 	 *
 	 * @static
 	 * @memberOf _
@@ -35836,21 +36380,21 @@ var Debugger =
 	function isArrayLikeObject(value) {
 	  return isObjectLike(value) && isArrayLike(value);
 	}
 	
 	module.exports = isArrayLikeObject;
 
 
 /***/ },
-/* 363 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isFunction = __webpack_require__(103),
-	    isLength = __webpack_require__(364);
+/* 367 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isFunction = __webpack_require__(105),
+	    isLength = __webpack_require__(368);
 	
 	/**
 	 * Checks if `value` is array-like. A value is considered array-like if it's
 	 * not a function and has a `value.length` that's an integer greater than or
 	 * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.
 	 *
 	 * @static
 	 * @memberOf _
@@ -35875,17 +36419,17 @@ var Debugger =
 	function isArrayLike(value) {
 	  return value != null && isLength(value.length) && !isFunction(value);
 	}
 	
 	module.exports = isArrayLike;
 
 
 /***/ },
-/* 364 */
+/* 368 */
 /***/ function(module, exports) {
 
 	/** Used as references for various `Number` constants. */
 	var MAX_SAFE_INTEGER = 9007199254740991;
 	
 	/**
 	 * Checks if `value` is a valid array-like length.
 	 *
@@ -35916,21 +36460,21 @@ var Debugger =
 	  return typeof value == 'number' &&
 	    value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;
 	}
 	
 	module.exports = isLength;
 
 
 /***/ },
-/* 365 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(107),
-	    stubFalse = __webpack_require__(366);
+/* 369 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__(109),
+	    stubFalse = __webpack_require__(370);
 	
 	/** Detect free variable `exports`. */
 	var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;
 	
 	/** Detect free variable `module`. */
 	var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;
 	
 	/** Detect the popular CommonJS extension `module.exports`. */
@@ -35961,17 +36505,17 @@ var Debugger =
 	 */
 	var isBuffer = nativeIsBuffer || stubFalse;
 	
 	module.exports = isBuffer;
 	
 	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(77)(module)))
 
 /***/ },
-/* 366 */
+/* 370 */
 /***/ function(module, exports) {
 
 	/**
 	 * This method returns `false`.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 4.13.0
@@ -35985,22 +36529,22 @@ var Debugger =
 	function stubFalse() {
 	  return false;
 	}
 	
 	module.exports = stubFalse;
 
 
 /***/ },
-/* 367 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseIsTypedArray = __webpack_require__(368),
-	    baseUnary = __webpack_require__(369),
-	    nodeUtil = __webpack_require__(370);
+/* 371 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseIsTypedArray = __webpack_require__(372),
+	    baseUnary = __webpack_require__(373),
+	    nodeUtil = __webpack_require__(374);
 	
 	/* Node.js helper references. */
 	var nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;
 	
 	/**
 	 * Checks if `value` is classified as a typed array.
 	 *
 	 * @static
@@ -36018,20 +36562,20 @@ var Debugger =
 	 * // => false
 	 */
 	var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;
 	
 	module.exports = isTypedArray;
 
 
 /***/ },
-/* 368 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isLength = __webpack_require__(364),
+/* 372 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isLength = __webpack_require__(368),
 	    isObjectLike = __webpack_require__(8);
 	
 	/** `Object#toString` result references. */
 	var argsTag = '[object Arguments]',
 	    arrayTag = '[object Array]',
 	    boolTag = '[object Boolean]',
 	    dateTag = '[object Date]',
 	    errorTag = '[object Error]',
@@ -36093,17 +36637,17 @@ var Debugger =
 	  return isObjectLike(value) &&
 	    isLength(value.length) && !!typedArrayTags[objectToString.call(value)];
 	}
 	
 	module.exports = baseIsTypedArray;
 
 
 /***/ },
-/* 369 */
+/* 373 */
 /***/ function(module, exports) {
 
 	/**
 	 * The base implementation of `_.unary` without support for storing metadata.
 	 *
 	 * @private
 	 * @param {Function} func The function to cap arguments for.
 	 * @returns {Function} Returns the new capped function.
@@ -36113,20 +36657,20 @@ var Debugger =
 	    return func(value);
 	  };
 	}
 	
 	module.exports = baseUnary;
 
 
 /***/ },
-/* 370 */
-/***/ function(module, exports, __webpack_require__) {
-
-	/* WEBPACK VAR INJECTION */(function(module) {var freeGlobal = __webpack_require__(108);
+/* 374 */
+/***/ function(module, exports, __webpack_require__) {
+
+	/* WEBPACK VAR INJECTION */(function(module) {var freeGlobal = __webpack_require__(110);
 	
 	/** Detect free variable `exports`. */
 	var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;
 	
 	/** Detect free variable `module`. */
 	var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;
 	
 	/** Detect the popular CommonJS extension `module.exports`. */
@@ -36142,21 +36686,21 @@ var Debugger =
 	  } catch (e) {}
 	}());
 	
 	module.exports = nodeUtil;
 	
 	/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(77)(module)))
 
 /***/ },
-/* 371 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var copyObject = __webpack_require__(372),
-	    keysIn = __webpack_require__(374);
+/* 375 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var copyObject = __webpack_require__(376),
+	    keysIn = __webpack_require__(378);
 	
 	/**
 	 * Converts `value` to a plain object flattening inherited enumerable string
 	 * keyed properties of `value` to own properties of the plain object.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 3.0.0
@@ -36180,21 +36724,21 @@ var Debugger =
 	function toPlainObject(value) {
 	  return copyObject(value, keysIn(value));
 	}
 	
 	module.exports = toPlainObject;
 
 
 /***/ },
-/* 372 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var assignValue = __webpack_require__(373),
-	    baseAssignValue = __webpack_require__(347);
+/* 376 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var assignValue = __webpack_require__(377),
+	    baseAssignValue = __webpack_require__(351);
 	
 	/**
 	 * Copies properties of `source` to `object`.
 	 *
 	 * @private
 	 * @param {Object} source The object to copy properties from.
 	 * @param {Array} props The property identifiers to copy.
 	 * @param {Object} [object={}] The object to copy properties to.
@@ -36226,21 +36770,21 @@ var Debugger =
 	  }
 	  return object;
 	}
 	
 	module.exports = copyObject;
 
 
 /***/ },
-/* 373 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseAssignValue = __webpack_require__(347),
-	    eq = __webpack_require__(119);
+/* 377 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseAssignValue = __webpack_require__(351),
+	    eq = __webpack_require__(121);
 	
 	/** Used for built-in method references. */
 	var objectProto = Object.prototype;
 	
 	/** Used to check objects for own properties. */
 	var hasOwnProperty = objectProto.hasOwnProperty;
 	
 	/**
@@ -36260,22 +36804,22 @@ var Debugger =
 	    baseAssignValue(object, key, value);
 	  }
 	}
 	
 	module.exports = assignValue;
 
 
 /***/ },
-/* 374 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var arrayLikeKeys = __webpack_require__(375),
-	    baseKeysIn = __webpack_require__(378),
-	    isArrayLike = __webpack_require__(363);
+/* 378 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var arrayLikeKeys = __webpack_require__(379),
+	    baseKeysIn = __webpack_require__(382),
+	    isArrayLike = __webpack_require__(367);
 	
 	/**
 	 * Creates an array of the own and inherited enumerable property names of `object`.
 	 *
 	 * **Note:** Non-object values are coerced to objects.
 	 *
 	 * @static
 	 * @memberOf _
@@ -36298,25 +36842,25 @@ var Debugger =
 	function keysIn(object) {
 	  return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);
 	}
 	
 	module.exports = keysIn;
 
 
 /***/ },
-/* 375 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseTimes = __webpack_require__(376),
-	    isArguments = __webpack_require__(360),
-	    isArray = __webpack_require__(92),
-	    isBuffer = __webpack_require__(365),
-	    isIndex = __webpack_require__(377),
-	    isTypedArray = __webpack_require__(367);
+/* 379 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseTimes = __webpack_require__(380),
+	    isArguments = __webpack_require__(364),
+	    isArray = __webpack_require__(94),
+	    isBuffer = __webpack_require__(369),
+	    isIndex = __webpack_require__(381),
+	    isTypedArray = __webpack_require__(371);
 	
 	/** Used for built-in method references. */
 	var objectProto = Object.prototype;
 	
 	/** Used to check objects for own properties. */
 	var hasOwnProperty = objectProto.hasOwnProperty;
 	
 	/**
@@ -36353,17 +36897,17 @@ var Debugger =
 	  }
 	  return result;
 	}
 	
 	module.exports = arrayLikeKeys;
 
 
 /***/ },
-/* 376 */
+/* 380 */
 /***/ function(module, exports) {
 
 	/**
 	 * The base implementation of `_.times` without support for iteratee shorthands
 	 * or max array length checks.
 	 *
 	 * @private
 	 * @param {number} n The number of times to invoke `iteratee`.
@@ -36379,17 +36923,17 @@ var Debugger =
 	  }
 	  return result;
 	}
 	
 	module.exports = baseTimes;
 
 
 /***/ },
-/* 377 */
+/* 381 */
 /***/ function(module, exports) {
 
 	/** Used as references for various `Number` constants. */
 	var MAX_SAFE_INTEGER = 9007199254740991;
 	
 	/** Used to detect unsigned integer values. */
 	var reIsUint = /^(?:0|[1-9]\d*)$/;
 	
@@ -36407,22 +36951,22 @@ var Debugger =
 	    (typeof value == 'number' || reIsUint.test(value)) &&
 	    (value > -1 && value % 1 == 0 && value < length);
 	}
 	
 	module.exports = isIndex;
 
 
 /***/ },
-/* 378 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var isObject = __webpack_require__(104),
-	    isPrototype = __webpack_require__(359),
-	    nativeKeysIn = __webpack_require__(379);
+/* 382 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var isObject = __webpack_require__(106),
+	    isPrototype = __webpack_require__(363),
+	    nativeKeysIn = __webpack_require__(383);
 	
 	/** Used for built-in method references. */
 	var objectProto = Object.prototype;
 	
 	/** Used to check objects for own properties. */
 	var hasOwnProperty = objectProto.hasOwnProperty;
 	
 	/**
@@ -36446,17 +36990,17 @@ var Debugger =
 	  }
 	  return result;
 	}
 	
 	module.exports = baseKeysIn;
 
 
 /***/ },
-/* 379 */
+/* 383 */
 /***/ function(module, exports) {
 
 	/**
 	 * This function is like
 	 * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)
 	 * except that it includes inherited enumerable properties.
 	 *
 	 * @private
@@ -36472,21 +37016,21 @@ var Debugger =
 	  }
 	  return result;
 	}
 	
 	module.exports = nativeKeysIn;
 
 
 /***/ },
-/* 380 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseRest = __webpack_require__(381),
-	    isIterateeCall = __webpack_require__(389);
+/* 384 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseRest = __webpack_require__(385),
+	    isIterateeCall = __webpack_require__(393);
 	
 	/**
 	 * Creates a function like `_.assign`.
 	 *
 	 * @private
 	 * @param {Function} assigner The function to assign values.
 	 * @returns {Function} Returns the new assigner function.
 	 */
@@ -36515,22 +37059,22 @@ var Debugger =
 	    return object;
 	  });
 	}
 	
 	module.exports = createAssigner;
 
 
 /***/ },
-/* 381 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var identity = __webpack_require__(382),
-	    overRest = __webpack_require__(383),
-	    setToString = __webpack_require__(385);
+/* 385 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var identity = __webpack_require__(386),
+	    overRest = __webpack_require__(387),
+	    setToString = __webpack_require__(389);
 	
 	/**
 	 * The base implementation of `_.rest` which doesn't validate or coerce arguments.
 	 *
 	 * @private
 	 * @param {Function} func The function to apply a rest parameter to.
 	 * @param {number} [start=func.length-1] The start position of the rest parameter.
 	 * @returns {Function} Returns the new function.
@@ -36538,17 +37082,17 @@ var Debugger =
 	function baseRest(func, start) {
 	  return setToString(overRest(func, start, identity), func + '');
 	}
 	
 	module.exports = baseRest;
 
 
 /***/ },
-/* 382 */
+/* 386 */
 /***/ function(module, exports) {
 
 	/**
 	 * This method returns the first argument it receives.
 	 *
 	 * @static
 	 * @since 0.1.0
 	 * @memberOf _
@@ -36565,20 +37109,20 @@ var Debugger =
 	function identity(value) {
 	  return value;
 	}
 	
 	module.exports = identity;
 
 
 /***/ },
-/* 383 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var apply = __webpack_require__(384);
+/* 387 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var apply = __webpack_require__(388);
 	
 	/* Built-in method references for those with the same name as other `lodash` methods. */
 	var nativeMax = Math.max;
 	
 	/**
 	 * A specialized version of `baseRest` which transforms the rest array.
 	 *
 	 * @private
@@ -36607,17 +37151,17 @@ var Debugger =
 	    return apply(func, this, otherArgs);
 	  };
 	}
 	
 	module.exports = overRest;
 
 
 /***/ },
-/* 384 */
+/* 388 */
 /***/ function(module, exports) {
 
 	/**
 	 * A faster alternative to `Function#apply`, this function invokes `func`
 	 * with the `this` binding of `thisArg` and the arguments of `args`.
 	 *
 	 * @private
 	 * @param {Function} func The function to invoke.
@@ -36634,42 +37178,42 @@ var Debugger =
 	  }
 	  return func.apply(thisArg, args);
 	}
 	
 	module.exports = apply;
 
 
 /***/ },
-/* 385 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var baseSetToString = __webpack_require__(386),
-	    shortOut = __webpack_require__(388);
+/* 389 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var baseSetToString = __webpack_require__(390),
+	    shortOut = __webpack_require__(392);
 	
 	/**
 	 * Sets the `toString` method of `func` to return `string`.
 	 *
 	 * @private
 	 * @param {Function} func The function to modify.
 	 * @param {Function} string The `toString` result.
 	 * @returns {Function} Returns `func`.
 	 */
 	var setToString = shortOut(baseSetToString);
 	
 	module.exports = setToString;
 
 
 /***/ },
-/* 386 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var constant = __webpack_require__(387),
-	    defineProperty = __webpack_require__(348),
-	    identity = __webpack_require__(382);
+/* 390 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var constant = __webpack_require__(391),
+	    defineProperty = __webpack_require__(352),
+	    identity = __webpack_require__(386);
 	
 	/**
 	 * The base implementation of `setToString` without support for hot loop shorting.
 	 *
 	 * @private
 	 * @param {Function} func The function to modify.
 	 * @param {Function} string The `toString` result.
 	 * @returns {Function} Returns `func`.
@@ -36682,17 +37226,17 @@ var Debugger =
 	    'writable': true
 	  });
 	};
 	
 	module.exports = baseSetToString;
 
 
 /***/ },
-/* 387 */
+/* 391 */
 /***/ function(module, exports) {
 
 	/**
 	 * Creates a function that returns `value`.
 	 *
 	 * @static
 	 * @memberOf _
 	 * @since 2.4.0
@@ -36714,17 +37258,17 @@ var Debugger =
 	    return value;
 	  };
 	}
 	
 	module.exports = constant;
 
 
 /***/ },
-/* 388 */
+/* 392 */
 /***/ function(module, exports) {
 
 	/** Used to detect hot functions by number of calls within a span of milliseconds. */
 	var HOT_COUNT = 500,
 	    HOT_SPAN = 16;
 	
 	/* Built-in method references for those with the same name as other `lodash` methods. */
 	var nativeNow = Date.now;
@@ -36757,23 +37301,23 @@ var Debugger =
 	    return func.apply(undefined, arguments);
 	  };
 	}
 	
 	module.exports = shortOut;
 
 
 /***/ },
-/* 389 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var eq = __webpack_require__(119),
-	    isArrayLike = __webpack_require__(363),
-	    isIndex = __webpack_require__(377),
-	    isObject = __webpack_require__(104);
+/* 393 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var eq = __webpack_require__(121),
+	    isArrayLike = __webpack_require__(367),
+	    isIndex = __webpack_require__(381),
+	    isObject = __webpack_require__(106);
 	
 	/**
 	 * Checks if the given arguments are from an iteratee call.
 	 *
 	 * @private
 	 * @param {*} value The potential iteratee value argument.
 	 * @param {*} index The potential iteratee index or key argument.
 	 * @param {*} object The potential iteratee object argument.
@@ -36793,22 +37337,22 @@ var Debugger =
 	  }
 	  return false;
 	}
 	
 	module.exports = isIterateeCall;
 
 
 /***/ },
-/* 390 */
+/* 394 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
-	var Tree = React.createFactory(__webpack_require__(391));
-	__webpack_require__(392);
+	var Tree = React.createFactory(__webpack_require__(395));
+	__webpack_require__(396);
 	
 	var ManagedTree = React.createClass({
 	  propTypes: Tree.propTypes,
 	
 	  displayName: "ManagedTree",
 	
 	  getInitialState() {
 	    return { expanded: new Set(),
@@ -36873,17 +37417,17 @@ var Debugger =
 	
 	    return Tree(props);
 	  }
 	});
 	
 	module.exports = ManagedTree;
 
 /***/ },
-/* 391 */
+/* 395 */
 /***/ 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/. */
 	
 	const { DOM: dom, createClass, createFactory, PropTypes } = __webpack_require__(2);
 	// const { ViewHelpers } =
@@ -37475,122 +38019,113 @@ var Debugger =
 	    }
 	
 	    this._focus(parentIndex, parent);
 	  }),
 	});
 
 
 /***/ },
-/* 392 */
+/* 396 */
 /***/ function(module, exports) {
 
 	// removed by extract-text-webpack-plugin
 
 /***/ },
-/* 393 */,
-/* 394 */
+/* 397 */,
+/* 398 */
 /***/ function(module, exports) {
 
 	// removed by extract-text-webpack-plugin
 
 /***/ },
-/* 395 */,
-/* 396 */
+/* 399 */,
+/* 400 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
 	var dom = React.DOM;
 	var PropTypes = React.PropTypes;
 	var createFactory = React.createFactory;
 	
 	
 	var ReactDOM = __webpack_require__(16);
-	var ImPropTypes = __webpack_require__(233);
+	var ImPropTypes = __webpack_require__(235);
 	
 	var _require = __webpack_require__(3);
 	
 	var bindActionCreators = _require.bindActionCreators;
 	
 	var _require2 = __webpack_require__(19);
 	
 	var connect = _require2.connect;
 	
-	var SourceEditor = __webpack_require__(397);
-	var SourceFooter = createFactory(__webpack_require__(398));
-	var EditorSearchBar = createFactory(__webpack_require__(402));
-	
-	var _require3 = __webpack_require__(18);
-	
-	var debugGlobal = _require3.debugGlobal;
-	
-	var _require4 = __webpack_require__(257);
-	
-	var getSourceText = _require4.getSourceText;
-	var getBreakpointsForSource = _require4.getBreakpointsForSource;
-	var getSelectedLocation = _require4.getSelectedLocation;
-	var getSelectedFrame = _require4.getSelectedFrame;
-	var getSelectedSource = _require4.getSelectedSource;
-	
-	var _require5 = __webpack_require__(253);
-	
-	var makeLocationId = _require5.makeLocationId;
-	
-	var actions = __webpack_require__(260);
-	var Breakpoint = React.createFactory(__webpack_require__(406));
-	
-	var _require6 = __webpack_require__(277);
-	
-	var getDocument = _require6.getDocument;
-	var setDocument = _require6.setDocument;
-	
-	var _require7 = __webpack_require__(399);
-	
-	var shouldShowFooter = _require7.shouldShowFooter;
-	
-	var _require8 = __webpack_require__(87);
-	
-	var isEnabled = _require8.isEnabled;
-	
-	
-	__webpack_require__(407);
+	var SourceEditor = __webpack_require__(401);
+	var SourceFooter = createFactory(__webpack_require__(402));
+	var EditorSearchBar = createFactory(__webpack_require__(406));
+	
+	var _require3 = __webpack_require__(411);
+	
+	var renderConditionalPanel = _require3.renderConditionalPanel;
+	
+	var _require4 = __webpack_require__(18);
+	
+	var debugGlobal = _require4.debugGlobal;
+	
+	var _require5 = __webpack_require__(259);
+	
+	var getSourceText = _require5.getSourceText;
+	var getBreakpointsForSource = _require5.getBreakpointsForSource;
+	var getSelectedLocation = _require5.getSelectedLocation;
+	var getSelectedFrame = _require5.getSelectedFrame;
+	var getSelectedSource = _require5.getSelectedSource;
+	
+	var _require6 = __webpack_require__(255);
+	
+	var makeLocationId = _require6.makeLocationId;
+	
+	var actions = __webpack_require__(262);
+	var Breakpoint = React.createFactory(__webpack_require__(412));
+	
+	var _require7 = __webpack_require__(279);
+	
+	var getDocument = _require7.getDocument;
+	var setDocument = _require7.setDocument;
+	
+	var _require8 = __webpack_require__(403);
+	
+	var shouldShowFooter = _require8.shouldShowFooter;
+	
+	var _require9 = __webpack_require__(89);
+	
+	var isFirefox = _require9.isFirefox;
+	
+	var _require10 = __webpack_require__(413);
+	
+	var showMenu = _require10.showMenu;
+	
+	var _require11 = __webpack_require__(89);
+	
+	var isEnabled = _require11.isEnabled;
+	
+	
+	__webpack_require__(414);
 	
 	function isTextForSource(sourceText) {
 	  return !sourceText.get("loading") && !sourceText.get("error");
 	}
 	
 	function breakpointAtLine(breakpoints, line) {
 	  return breakpoints.find(b => {
 	    return b.location.line === line + 1;
 	  });
 	}
 	
-	function renderConditionalBreakpointPanel(_ref) {
-	  var location = _ref.location;
-	  var setBreakpointCondition = _ref.setBreakpointCondition;
-	  var condition = _ref.condition;
-	  var closePanel = _ref.closePanel;
-	
-	  function onKey(e) {
-	    if (e.key != "Enter") {
-	      return;
-	    }
-	
-	    setBreakpointCondition(location, e.target.value);
-	    closePanel();
-	  }
-	
-	  var panel = document.createElement("div");
-	  ReactDOM.render(dom.div({ className: "conditional-breakpoint-panel" }, dom.input({
-	    defaultValue: condition,
-	    placeholder: "This breakpoint will pause when the expression is true",
-	    onKeyPress: onKey
-	  })), panel);
-	
-	  return panel;
+	function getTextForLine(codeMirror, line) {
+	  return codeMirror.getLine(line - 1).trim();
 	}
 	
 	/**
 	 * Forces the breakpoint gutter to be the same size as the line
 	 * numbers gutter. Editor CSS will absolutely position the gutter
 	 * beneath the line numbers. This makes it easy to be flexible with
 	 * how we overlay breakpoints.
 	 */
@@ -37611,63 +38146,95 @@ var Debugger =
 	    removeBreakpoint: PropTypes.func,
 	    setBreakpointCondition: PropTypes.func,
 	    selectedFrame: PropTypes.object
 	  },
 	
 	  displayName: "Editor",
 	
 	  onGutterClick(cm, line, gutter, ev) {
+	    // ignore right clicks in the gutter
+	    if (ev.which === 3) {
+	      return;
+	    }
+	
+	    if (this.isCbPanelOpen()) {
+	      return this.closeConditionalPanel(line);
+	    }
+	
+	    this.toggleBreakpoint(line);
+	  },
+	
+	  onGutterContextMenu(event) {
+	    event.preventDefault();
+	    var line = this.editor.codeMirror.lineAtHeight(event.clientY);
 	    var bp = breakpointAtLine(this.props.breakpoints, line);
+	    this.showGutterMenu(event, line, bp);
+	  },
+	
+	  showConditionalPanel(line) {
+	    if (this.isCbPanelOpen()) {
+	      return;
+	    }
+	
 	    var _props = this.props;
 	    var sourceId = _props.selectedLocation.sourceId;
 	    var setBreakpointCondition = _props.setBreakpointCondition;
-	
-	
+	    var breakpoints = _props.breakpoints;
+	
+	
+	    var bp = breakpointAtLine(breakpoints, line);
 	    var location = { sourceId, line: line + 1 };
-	    var closePanel = () => this.cbPanels[line].clear();
-	
-	    if (isEnabled("conditionalBreakpoints") && bp && ev.metaKey) {
-	      if (!this.state.isCondBPOpen) {
-	        var condition = bp.condition;
-	
-	        var panel = renderConditionalBreakpointPanel({
-	          location, setBreakpointCondition, condition, closePanel
-	        });
-	
-	        this.cbPanels[line] = this.editor.codeMirror.addLineWidget(line, panel);
-	        this.setState({ isCondBPOpen: true, openPanel: this.cbPanels[line] });
-	      } else {
-	        delete this.cbPanels[line];
-	        this.state.openPanel.clear();
-	        this.replaceState({ isCondBPOpen: false });
-	      }
-	      return;
-	    }
-	
-	    this.toggleBreakpoint(bp, line);
-	  },
-	
-	  toggleBreakpoint(bp, line) {
+	    var condition = bp ? bp.condition : "";
+	
+	    var setBreakpoint = value => {
+	      setBreakpointCondition(location, {
+	        condition: value,
+	        getTextForLine: l => getTextForLine(this.editor.codeMirror, l)
+	      });
+	    };
+	
+	    var panel = renderConditionalPanel({
+	      condition,
+	      setBreakpoint,
+	      closePanel: this.closeConditionalPanel
+	    });
+	
+	    this.cbPanel = this.editor.codeMirror.addLineWidget(line, panel);
+	    this.cbPanel.node.querySelector("input").focus();
+	  },
+	
+	  closeConditionalPanel() {
+	    this.cbPanel.clear();
+	    this.cbPanel = null;
+	  },
+	
+	  isCbPanelOpen() {
+	    return !!this.cbPanel;
+	  },
+	
+	  toggleBreakpoint(line) {
+	    var bp = breakpointAtLine(this.props.breakpoints, line);
+	
 	    if (bp && bp.loading) {
 	      return;
 	    }
 	
 	    if (bp) {
 	      this.props.removeBreakpoint({
 	        sourceId: this.props.selectedLocation.sourceId,
 	        line: line + 1
 	      });
 	    } else {
 	      this.props.addBreakpoint({ sourceId: this.props.selectedLocation.sourceId,
 	        line: line + 1 },
 	      // Pass in a function to get line text because the breakpoint
 	      // may slide and it needs to compute the value at the new
 	      // line.
-	      { getTextForLine: l => this.editor.codeMirror.getLine(l - 1).trim() });
+	      { getTextForLine: l => getTextForLine(this.editor.codeMirror, l) });
 	    }
 	  },
 	
 	  clearDebugLine(selectedFrame) {
 	    if (selectedFrame) {
 	      var line = selectedFrame.location.line;
 	      this.editor.codeMirror.removeLineClass(line - 1, "line", "debug-line");
 	    }
@@ -37729,41 +38296,83 @@ var Debugger =
 	      // Use HTML mode for files in which the first non whitespace
 	      // character is `<` regardless of extension.
 	      this.editor.setMode({ name: "htmlmixed" });
 	    } else {
 	      this.editor.setMode({ name: "text" });
 	    }
 	  },
 	
-	  getInitialState() {
-	    return { isCondBPOpen: false };
+	  showGutterMenu(e, line, bp) {
+	    var bpLabel = void 0;
+	    var cbLabel = void 0;
+	    if (!bp) {
+	      bpLabel = L10N.getStr("editor.addBreakpoint");
+	      cbLabel = L10N.getStr("editor.addConditionalBreakpoint");
+	    } else {
+	      bpLabel = L10N.getStr("editor.removeBreakpoint");
+	      cbLabel = L10N.getStr("editor.editBreakpoint");
+	    }
+	
+	    var toggleBreakpoint = {
+	      id: "node-menu-breakpoint",
+	      label: bpLabel,
+	      accesskey: "B",
+	      disabled: false,
+	      click: () => {
+	        this.toggleBreakpoint(line);
+	        if (this.isCbPanelOpen()) {
+	          this.closeConditionalPanel();
+	        }
+	      }
+	    };
+	
+	    var conditionalBreakpoint = {
+	      id: "node-menu-conditional-breakpoint",
+	      label: cbLabel,
+	      accesskey: "C",
+	      disabled: false,
+	      click: () => this.showConditionalPanel(line)
+	    };
+	
+	    showMenu(e, [toggleBreakpoint, conditionalBreakpoint]);
 	  },
 	
 	  componentDidMount() {
-	    var extraKeys = isEnabled("search") ? { "Cmd-F": () => {} } : {};
-	    this.cbPanels = {};
+	    this.cbPanel = null;
 	
 	    this.editor = new SourceEditor({
 	      mode: "javascript",
 	      readOnly: true,
 	      lineNumbers: true,
 	      theme: "mozilla",
 	      lineWrapping: false,
 	      matchBrackets: true,
 	      showAnnotationRuler: true,
 	      enableCodeFolding: false,
 	      gutters: ["breakpoints"],
 	      value: " ",
-	      extraKeys
-	    });
+	      extraKeys: {}
+	    });
+	
+	    // disables the default search shortcuts
+	    if (isEnabled("editorSearch")) {
+	      this.editor._initShortcuts = () => {};
+	    }
 	
 	    this.editor.appendToLocalElement(ReactDOM.findDOMNode(this).querySelector(".editor-mount"));
 	
 	    this.editor.codeMirror.on("gutterClick", this.onGutterClick);
+	
+	    if (!isFirefox()) {
+	      this.editor.codeMirror.on("gutterContextMenu", (cm, line, eventName, event) => this.onGutterContextMenu(event));
+	    } else {
+	      this.editor.codeMirror.getWrapperElement().addEventListener("contextmenu", event => this.onGutterContextMenu(event), false);
+	    }
+	
 	    resizeBreakpointGutter(this.editor.codeMirror);
 	    debugGlobal("cm", this.editor.codeMirror);
 	
 	    if (this.props.sourceText) {
 	      this.setText(this.props.sourceText.get("text"));
 	    }
 	  },
 	
@@ -37900,60 +38509,60 @@ var Debugger =
 	    selectedSource,
 	    sourceText: getSourceText(state, sourceId),
 	    breakpoints: getBreakpointsForSource(state, sourceId),
 	    selectedFrame: getSelectedFrame(state)
 	  };
 	}, dispatch => bindActionCreators(actions, dispatch))(Editor);
 
 /***/ },
-/* 397 */
+/* 401 */
 /***/ function(module, exports) {
 
 	module.exports = devtoolsRequire("devtools/client/sourceeditor/editor");
 
 /***/ },
-/* 398 */
+/* 402 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
 	var dom = React.DOM;
 	var PropTypes = React.PropTypes;
 	
 	var _require = __webpack_require__(19);
 	
 	var connect = _require.connect;
 	
 	var _require2 = __webpack_require__(3);
 	
 	var bindActionCreators = _require2.bindActionCreators;
 	
-	var actions = __webpack_require__(260);
-	
-	var _require3 = __webpack_require__(257);
+	var actions = __webpack_require__(262);
+	
+	var _require3 = __webpack_require__(259);
 	
 	var getSelectedSource = _require3.getSelectedSource;
 	var getSourceText = _require3.getSourceText;
 	var getPrettySource = _require3.getPrettySource;
 	
-	var Svg = __webpack_require__(306);
-	var ImPropTypes = __webpack_require__(233);
-	var classnames = __webpack_require__(209);
-	
-	var _require4 = __webpack_require__(275);
+	var Svg = __webpack_require__(310);
+	var ImPropTypes = __webpack_require__(235);
+	var classnames = __webpack_require__(211);
+	
+	var _require4 = __webpack_require__(277);
 	
 	var isPretty = _require4.isPretty;
 	
-	var _require5 = __webpack_require__(399);
+	var _require5 = __webpack_require__(403);
 	
 	var shouldShowFooter = _require5.shouldShowFooter;
 	var shouldShowPrettyPrint = _require5.shouldShowPrettyPrint;
 	
 	
-	__webpack_require__(400);
+	__webpack_require__(404);
 	
 	function debugBtn(onClick, type) {
 	  var className = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : "active";
 	  var tooltip = arguments[3];
 	
 	  className = `${ type } ${ className }`;
 	  return dom.span({ onClick, className, key: type }, Svg(type, { title: tooltip }));
 	}
@@ -38009,28 +38618,28 @@ var Debugger =
 	  return {
 	    selectedSource,
 	    sourceText: getSourceText(state, selectedId),
 	    prettySource: getPrettySource(state, selectedId)
 	  };
 	}, dispatch => bindActionCreators(actions, dispatch))(SourceFooter);
 
 /***/ },
-/* 399 */
-/***/ function(module, exports, __webpack_require__) {
-
-	var _require = __webpack_require__(275);
+/* 403 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(277);
 	
 	var isPretty = _require.isPretty;
 	
-	var _require2 = __webpack_require__(87);
+	var _require2 = __webpack_require__(89);
 	
 	var isEnabled = _require2.isEnabled;
 	
-	var _require3 = __webpack_require__(262);
+	var _require3 = __webpack_require__(264);
 	
 	var isOriginalId = _require3.isOriginalId;
 	
 	
 	function shouldShowPrettyPrint(selectedSource) {
 	  if (!isEnabled("prettyPrint")) {
 	    return false;
 	  }
@@ -38051,52 +38660,60 @@ var Debugger =
 	}
 	
 	module.exports = {
 	  shouldShowPrettyPrint,
 	  shouldShowFooter
 	};
 
 /***/ },
-/* 400 */
+/* 404 */
 /***/ function(module, exports) {
 
 	// removed by extract-text-webpack-plugin
 
 /***/ },
-/* 401 */,
-/* 402 */
+/* 405 */,
+/* 406 */
 /***/ function(module, exports, __webpack_require__) {
 
 	var React = __webpack_require__(2);
 	var dom = React.DOM;
 	var PropTypes = React.PropTypes;
 	
 	var _require = __webpack_require__(16);
 	
 	var findDOMNode = _require.findDOMNode;
 	
-	var Svg = __webpack_require__(306);
-	
-	var _require2 = __webpack_require__(87);
-	
-	var isEnabled = _require2.isEnabled;
-	
-	var _require3 = __webpack_require__(403);
-	
-	var find = _require3.find;
-	var findNext = _require3.findNext;
-	var findPrev = _require3.findPrev;
-	
-	var classnames = __webpack_require__(209);
-	
-	__webpack_require__(404);
+	var Svg = __webpack_require__(310);
+	
+	var _require2 = __webpack_require__(407);
+	
+	var find = _require2.find;
+	var findNext = _require2.findNext;
+	var findPrev = _require2.findPrev;
+	
+	var classnames = __webpack_require__(211);
+	
+	var _require3 = __webpack_require__(408);
+	
+	var debounce = _require3.debounce;
+	var escapeRegExp = _require3.escapeRegExp;
+	
+	var CloseButton = __webpack_require__(336);
+	
+	var _require4 = __webpack_require__(89);
+	
+	var isEnabled = _require4.isEnabled;
+	
+	
+	__webpack_require__(409);
 	
 	function countMatches(query, text) {
-	  var re = new RegExp(query, "g");
+	  var re = new RegExp(escapeRegExp(query), "g");
 	  var match = text.match(re);
 	  return match ? match.length : 0;
 	}
 	
 	var EditorSearchBar = React.createClass({
 	
 	  propTypes: {
 	    editor: PropTypes.object,
@@ -38115,194 +38732,317 @@ var Debugger =
 	  },
 	
 	  contextTypes: {
 	    shortcuts: PropTypes.object
 	  },
 	
 	  componentWillUnmount() {
 	    var shortcuts = this.context.shortcuts;
-	    if (isEnabled("search")) {
+	    if (isEnabled("editorSearch")) {
 	      shortcuts.off("CmdOrCtrl+F", this.toggleSearch);
 	      shortcuts.off("Escape", this.onEscape);
 	    }
 	  },
 	
 	  componentDidMount() {
 	    var shortcuts = this.context.shortcuts;
-	    if (isEnabled("search")) {
+	    if (isEnabled("editorSearch")) {
 	      shortcuts.on("CmdOrCtrl+F", this.toggleSearch);
 	      shortcuts.on("Escape", this.onEscape);
 	    }
 	  },
 	
+	  componentWillReceiveProps() {
+	    var shortcuts = this.context.shortcuts;
+	    shortcuts.on("CmdOrCtrl+Shift+G", (_, e) => this.traverseResultsPrev(e));
+	    shortcuts.on("CmdOrCtrl+G", (_, e) => this.traverseResultsNext(e));
+	  },
+	
 	  componentDidUpdate() {
 	    if (this.searchInput()) {
 	      this.searchInput().focus();
 	    }
 	  },
 	
 	  onEscape(shortcut, e) {
+	    this.closeSearch(e);
+	  },
+	
+	  closeSearch(e) {
 	    if (this.state.enabled) {
 	      this.setState({ enabled: false });
+	      e.stopPropagation();
 	      e.preventDefault();
 	    }
 	  },
 	
 	  toggleSearch(shortcut, e) {
 	    e.stopPropagation();
 	    e.preventDefault();
 	
 	    this.setState({ enabled: !this.state.enabled });
 	
 	    if (this.state.enabled) {
 	      var node = this.searchInput();
-	      node.setSelectionRange(0, node.value.length);
+	      if (node) {
+	        node.setSelectionRange(0, node.value.length);
+	      }
 	    }
 	  },
 	
 	  searchInput() {
 	    return findDOMNode(this).querySelector("input");
 	  },
 	
 	  onChange(e) {
 	    var query = e.target.value;
-	    var ed = this.props.editor;
-	    var ctx = { ed, cm: ed.codeMirror };
-	
-	    find(ctx, query);
+	
 	    var count = countMatches(query, this.props.sourceText.get("text"));
 	    this.setState({ query, count, index: 0 });
-	  },
-	
-	  onKeyUp(e) {
+	
+	    this.search(query);
+	  },
+	
+	  traverseResultsPrev(e) {
+	    e.stopPropagation();
+	    e.preventDefault();
+	
 	    var ed = this.props.editor;
 	    var ctx = { ed, cm: ed.codeMirror };
 	    var _state = this.state;
 	    var query = _state.query;
 	    var index = _state.index;
 	    var count = _state.count;
 	
 	
+	    findPrev(ctx, query);
+	    var nextIndex = index == 0 ? count - 1 : index - 1;
+	    this.setState({ index: nextIndex });
+	  },
+	
+	  traverseResultsNext(e) {
+	    e.stopPropagation();
+	    e.preventDefault();
+	
+	    var ed = this.props.editor;
+	    var ctx = { ed, cm: ed.codeMirror };
+	    var _state2 = this.state;
+	    var query = _state2.query;
+	    var index = _state2.index;
+	    var count = _state2.count;
+	
+	
+	    findNext(ctx, query);
+	    var nextIndex = index == count - 1 ? 0 : index + 1;
+	    this.setState({ index: nextIndex });
+	  },
+	
+	  onKeyUp(e) {
 	    if (e.key != "Enter") {
 	      return;
 	    }
 	
 	    if (e.shiftKey) {
-	      findPrev(ctx, query);
-	      var nextIndex = index == 0 ? count - 1 : index - 1;
-	      this.setState({ index: nextIndex });
+	      this.traverseResultsPrev(e);
 	    } else {
-	      findNext(ctx, query);
-	      var _nextIndex = index == count - 1 ? 0 : index + 1;
-	      this.setState({ index: _nextIndex });
-	    }
-	  },
+	      this.traverseResultsNext(e);
+	    }
+	  },
+	
+	  search: debounce(function (query) {
+	    var ed = this.props.editor;
+	    var ctx = { ed, cm: ed.codeMirror };
+	
+	    find(ctx, query);
+	  }, 100),
 	
 	  renderSummary() {
-	    var _state2 = this.state;
-	    var count = _state2.count;
-	    var index = _state2.index;
-	    var query = _state2.query;
+	    var _state3 = this.state;
+	    var count = _state3.count;
+	    var index = _state3.index;
+	    var query = _state3.query;
 	
 	
 	    if (query.trim() == "") {
 	      return dom.div({});
 	    } else if (count == 0) {
 	      return dom.div({ className: "summary" }, L10N.getStr("editor.noResults"));
 	    }
 	
 	    return dom.div({ className: "summary" }, L10N.getFormatStr("editor.searchResults", index + 1, count));
 	  },
 	
 	  renderSvg() {
-	    var _state3 = this.state;
-	    var count = _state3.count;
-	    var query = _state3.query;
+	    var _state4 = this.state;
+	    var count = _state4.count;
+	    var query = _state4.query;
 	
 	
 	    if (count == 0 && query.trim() != "") {
 	      return Svg("sad-face");
 	    }
 	
 	    return Svg("magnifying-glass");
 	  },
 	
 	  render() {
-	    if (!isEnabled("search") || !this.state.enabled) {
+	    if (!this.state.enabled) {
 	      return dom.div();
 	    }
 	
-	    var count = this.state.count;
+	    var _state5 = this.state;
+	    var count = _state5.count;
+	    var query = _state5.query;
 	
 	
 	    return dom.div({ className: "search-bar" }, this.renderSvg(), dom.input({
 	      className: classnames({
-	        empty: count == 0
+	        empty: count == 0 && query.trim() != ""
 	      }),
 	      onChange: this.onChange,
 	      onKeyUp: this.onKeyUp,
 	      placeholder: "Search in file...",
 	      value: this.state.query,
 	      spellCheck: false
-	    }), this.renderSummary());
+	    }), this.renderSummary(), CloseButton({
+	      handleClick: this.closeSearch,
+	      buttonClass: "big"
+	    }));
 	  }
 	});
 	
 	module.exports = EditorSearchBar;
 
 /***/ },
-/* 403 */
-/***/ function(module, exports) {
-
-	// These functions implement search within the debugger. Since
-	// search in the debugger is different from other components,
-	// we can't use search.js CodeMirror addon. This is a slightly
-	// modified version of that addon. Depends on searchcursor.js.
+/* 407 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var _require = __webpack_require__(408);
+	
+	var escapeRegExp = _require.escapeRegExp;
+	/**
+	 * These functions implement search within the debugger. Since
+	 * search in the debugger is different from other components,
+	 * we can't use search.js CodeMirror addon. This is a slightly
+	 * modified version of that addon. Depends on searchcursor.js.
+	 * @module utils/source-search
+	 */
+	
+	/**
+	 * @memberof utils/source-search
+	 * @static
+	 */
+	
 	function SearchState() {
 	  this.posFrom = this.posTo = this.query = null;
-	}
-	
+	  this.overlay = null;
+	}
+	
+	/**
+	 * @memberof utils/source-search
+	 * @static
+	 */
 	function getSearchState(cm) {
 	  return cm.state.search || (cm.state.search = new SearchState());
 	}
 	
+	/**
+	 * @memberof utils/source-search
+	 * @static
+	 */
 	function getSearchCursor(cm, query, pos) {
 	  // If the query string is all lowercase, do a case insensitive search.
 	  return cm.getSearchCursor(query, pos, typeof query == "string" && query == query.toLowerCase());
 	}
 	
 	/**
+	 * Ignore doing outline matches for less than 3 whitespaces
+	 *
+	 * @memberof utils/source-search
+	 * @static
+	 */
+	function ignoreWhiteSpace(str) {
+	  return (/^\s{0,2}$/.test(str) ? "(?!\s*.*)" : str
+	  );
+	}
+	
+	/**
+	 * This returns a mode object used by CoeMirror's addOverlay function
+	 * to parse and style tokens in the file.
+	 * The mode object contains a tokenizer function (token) which takes
+	 * a character stream as input, advances it past a token, and returns
+	 * a style for that token. For more details see
+	 * https://codemirror.net/doc/manual.html#modeapi
+	 *
+	 * @memberof utils/source-search
+	 * @static
+	 */
+	function searchOverlay(query) {
+	  query = new RegExp(escapeRegExp(ignoreWhiteSpace(query)), "g");
+	  return {
+	    token: function (stream) {
+	      query.lastIndex = stream.pos;
+	      var match = query.exec(stream.string);
+	      if (match && match.index == stream.pos) {
+	        stream.pos += match[0].length || 1;
+	        return "selecting";
+	      } else if (match) {
+	        stream.pos = match.index;
+	      } else {
+	        stream.skipToEnd();
+	      }
+	    }
+	  };
+	}
+	
+	/**
+	 * @memberof utils/source-search
+	 * @static
+	 */
+	function startSearch(cm, state, query) {
+	  cm.removeOverlay(state.overlay);
+	  state.overlay = searchOverlay(query);
+	  cm.addOverlay(state.overlay, { opaque: true });
+	}
+	
+	/**
 	 * If there's a saved search, selects the next results.
 	 * Otherwise, creates a new search and selects the first
 	 * result.
+	 *
+	 * @memberof utils/source-search
+	 * @static
 	 */
 	function doSearch(ctx, rev, query) {
 	  var cm = ctx.cm;
 	
 	  var state = getSearchState(cm);
 	
 	  if (state.query) {
 	    searchNext(ctx, rev);
 	    return;
 	  }
 	
 	  cm.operation(function () {
 	    if (state.query) {
 	      return;
 	    }
-	
+	    startSearch(cm, state, query);
 	    state.query = query;
 	    state.posFrom = state.posTo = { line: 0, ch: 0 };
 	    searchNext(ctx, rev);
 	  });
 	}
 	
 	/**
 	 * Selects the next result of a saved search.
+	 *
+	 * @memberof utils/source-search
+	 * @static
 	 */
 	function searchNext(ctx, rev) {
 	  var cm = ctx.cm;
 	  var ed = ctx.ed;
 	
 	  cm.operation(function () {
 	    var state = getSearchState(cm);
 	    var cursor = getSearchCursor(cm, state.query, rev ? state.posFrom : state.posTo);
@@ -38318,69 +39058,17109 @@ var Debugger =
 	    cm.setSelection(cursor.from(), cursor.to());
 	    state.posFrom = cursor.from();
 	    state.posTo = cursor.to();
 	  });
 	}
 	
 	/**
 	 * Clears the currently saved search.
+	 *
+	 * @memberof utils/source-search
+	 * @static
 	 */
 	function clearSearch(cm) {
 	  var state = getSearchState(cm);
 	
 	  if (!state.query) {
 	    return;
 	  }
-	
+	  cm.removeOverlay(state.overlay);
 	  state.query = null;
 	}
 	
 	/**
 	 * Starts a new search.
+	 *
+	 * @memberof utils/source-search
+	 * @static
 	 */
 	function find(ctx, query) {
 	  clearSearch(ctx.cm);
 	  doSearch(ctx, false, query);
 	}
 	
 	/**
 	 * Finds the next item based on the currently saved search.
+	 *
+	 * @memberof utils/source-search
+	 * @static
 	 */
 	function findNext(ctx, query) {
 	  doSearch(ctx, false, query);
 	}
 	
 	/**
 	 * Finds the previous item based on the currently saved search.
+	 *
+	 * @memberof utils/source-search
+	 * @static
 	 */
 	function findPrev(ctx, query) {
 	  doSearch(ctx, true, query);
 	}
 	
 	module.exports = { find, findNext, findPrev };
 
 /***/ },
-/* 404 */
+/* 408 */
+/***/ function(module, exports, __webpack_require__) {
+
+	var __WEBPACK_AMD_DEFINE_RESULT__;/* WEBPACK VAR INJECTION */(function(global, module) {/**
+	 * @license
+	 * lodash <https://lodash.com/>
+	 * Copyright jQuery Foundation and other contributors <https://jquery.org/>
+	 * Released under MIT license <https://lodash.com/license>
+	 * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>
+	 * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
+	 */
+	;(function() {
+	
+	  /** Used as a safe reference for `undefined` in pre-ES5 environments. */
+	  var undefined;
+	
+	  /** Used as the semantic version number. */
+	  var VERSION = '4.16.4';
+	
+	  /** Used as the size to enable large array optimizations. */
+	  var LARGE_ARRAY_SIZE = 200;
+	
+	  /** Error message constants. */
+	  var CORE_ERROR_TEXT = 'Unsupported core-js use. Try https://github.com/es-shims.',
+	      FUNC_ERROR_TEXT = 'Expected a function';
+	
+	  /** Used to stand-in for `undefined` hash values. */
+	  var HASH_UNDEFINED = '__lodash_hash_undefined__';
+	
+	  /** Used as the maximum memoize cache size. */
+	  var MAX_MEMOIZE_SIZE = 500;
+	
+	  /** Used as the internal argument placeholder. */
+	  var PLACEHOLDER = '__lodash_placeholder__';
+	
+	  /** Used to compose bitmasks for function metadata. */
+	  var BIND_FLAG = 1,
+	      BIND_KEY_FLAG = 2,
+	      CURRY_BOUND_FLAG = 4,
+	      CURRY_FLAG = 8,
+	      CURRY_RIGHT_FLAG = 16,
+	      PARTIAL_FLAG = 32,
+	      PARTIAL_RIGHT_FLAG = 64,
+	      ARY_FLAG = 128,
+	      REARG_FLAG = 256,
+	      FLIP_FLAG = 512;
+	
+	  /** Used to compose bitmasks for comparison styles. */
+	  var UNORDERED_COMPARE_FLAG = 1,
+	      PARTIAL_COMPARE_FLAG = 2;
+	
+	  /** Used as default options for `_.truncate`. */
+	  var DEFAULT_TRUNC_LENGTH = 30,
+	      DEFAULT_TRUNC_OMISSION = '...';
+	
+	  /** Used to detect hot functions by number of calls within a span of milliseconds. */
+	  var HOT_COUNT = 500,
+	      HOT_SPAN = 16;
+	
+	  /** Used to indicate the type of lazy iteratees. */
+	  var LAZY_FILTER_FLAG = 1,
+	      LAZY_MAP_FLAG = 2,
+	      LAZY_WHILE_FLAG = 3;
+	
+	  /** Used as references for various `Number` constants. */
+	  var INFINITY = 1 / 0,
+	      MAX_SAFE_INTEGER = 9007199254740991,
+	      MAX_INTEGER = 1.7976931348623157e+308,
+	      NAN = 0 / 0;
+	
+	  /** Used as references for the maximum length and index of an array. */
+	  var MAX_ARRAY_LENGTH = 4294967295,
+	      MAX_ARRAY_INDEX = MAX_ARRAY_LENGTH - 1,
+	      HALF_MAX_ARRAY_LENGTH = MAX_ARRAY_LENGTH >>> 1;
+	
+	  /** Used to associate wrap methods with their bit flags. */
+	  var wrapFlags = [
+	    ['ary', ARY_FLAG],
+	    ['bind', BIND_FLAG],
+	    ['bindKey', BIND_KEY_FLAG],
+	    ['curry', CURRY_FLAG],
+	    ['curryRight', CURRY_RIGHT_FLAG],
+	    ['flip', FLIP_FLAG],
+	    ['partial', PARTIAL_FLAG],
+	    ['partialRight', PARTIAL_RIGHT_FLAG],
+	    ['rearg', REARG_FLAG]
+	  ];
+	
+	  /** `Object#toString` result references. */
+	  var argsTag = '[object Arguments]',
+	      arrayTag = '[object Array]',
+	      boolTag = '[object Boolean]',
+	      dateTag = '[object Date]',
+	      errorTag = '[object Error]',
+	      funcTag = '[object Function]',
+	      genTag = '[object GeneratorFunction]',
+	      mapTag = '[object Map]',
+	      numberTag = '[object Number]',
+	      objectTag = '[object Object]',
+	      promiseTag = '[object Promise]',
+	      proxyTag = '[object Proxy]',
+	      regexpTag = '[object RegExp]',
+	      setTag = '[object Set]',
+	      stringTag = '[object String]',
+	      symbolTag = '[object Symbol]',
+	      weakMapTag = '[object WeakMap]',
+	      weakSetTag = '[object WeakSet]';
+	
+	  var arrayBufferTag = '[object ArrayBuffer]',
+	      dataViewTag = '[object DataView]',
+	      float32Tag = '[object Float32Array]',
+	      float64Tag = '[object Float64Array]',
+	      int8Tag = '[object Int8Array]',
+	      int16Tag = '[object Int16Array]',
+	      int32Tag = '[object Int32Array]',
+	      uint8Tag = '[object Uint8Array]',
+	      uint8ClampedTag = '[object Uint8ClampedArray]',
+	      uint16Tag = '[object Uint16Array]',
+	      uint32Tag = '[object Uint32Array]';
+	
+	  /** Used to match empty string literals in compiled template source. */
+	  var reEmptyStringLeading = /\b__p \+= '';/g,
+	      reEmptyStringMiddle = /\b(__p \+=) '' \+/g,
+	      reEmptyStringTrailing = /(__e\(.*?\)|\b__t\)) \+\n'';/g;
+	
+	  /** Used to match HTML entities and HTML characters. */
+	  var reEscapedHtml = /&(?:amp|lt|gt|quot|#39);/g,
+	      reUnescapedHtml = /[&<>"']/g,
+	      reHasEscapedHtml = RegExp(reEscapedHtml.source),
+	      reHasUnescapedHtml = RegExp(reUnescapedHtml.source);
+	
+	  /** Used to match template delimiters. */
+	  var reEscape = /<%-([\s\S]+?)%>/g,
+	      reEvaluate = /<%([\s\S]+?)%>/g,
+	      reInterpolate = /<%=([\s\S]+?)%>/g;
+	
+	  /** Used to match property names within property paths. */