AsyncTabSwitcher.sys.mjs |
The tab switcher is responsible for asynchronously switching
tabs in e10s. It waits until the new tab is ready (i.e., the
layer tree is available) before switching to it. Then it
unloads the layer tree for the old tab.
The tab switcher is a state machine. For each tab, it
maintains state about whether the layer tree for the tab is
available, being loaded, being unloaded, or unavailable. It
also keeps track of the tab currently being displayed, the tab
it's trying to load, and the tab the user has asked to switch
to. The switcher object is created upon tab switch. It is
released when there are no pending tabs to load or unload.
The following general principles have guided the design:
1. We only request one layer tree at a time. If the user
switches to a different tab while waiting, we don't request
the new layer tree until the old tab has loaded or timed out.
2. If loading the layers for a tab times out, we show the
spinner and possibly request the layer tree for another tab if
the user has requested one.
3. We discard layer trees on a delay. This way, if the user is
switching among the same tabs frequently, we don't continually
load the same tabs.
It's important that we always show either the spinner or a tab
whose layers are available. Otherwise the compositor will draw
an entirely black frame, which is very jarring. To ensure this
never happens when switching away from a tab, we assume the
old tab might still be drawn until a MozAfterPaint event
occurs. Because layout and compositing happen asynchronously,
we don't have any other way of knowing when the switch
actually takes place. Therefore, we don't unload the old tab
until the next MozAfterPaint event.
|
46981 |
content |
|
|
GroupsList.sys.mjs |
@param {TabGroupStateData} group
@param {object} [options]
@param {boolean} [options.isOpen]
Set to true if the group is currently open, and false if it's saved
@returns {XULElement}
|
5057 |
jar.mn |
|
922 |
metrics.yaml |
|
3861 |
moz.build |
|
665 |
NewTabPagePreloading.sys.mjs |
This module is in charge of preloading 'new tab' pages for use when
the user opens a new tab.
|
6294 |
OpenInTabsUtils.sys.mjs |
Utility functions that can be used when opening multiple tabs, that can be
called without any tabbrowser instance.
|
2331 |
TabsList.sys.mjs |
Populate the popup with menuitems and setup the listeners.
|
18224 |
TabUnloader.sys.mjs |
-*- mode: js; indent-tabs-mode: nil; js-indent-level: 2 -*- |
16430 |
test |
|
|
triage.json |
|
3788 |