[gnome-shell] Network Menu: update the UI only when really needed
- From: Giovanni Campagna <gcampagna src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-shell] Network Menu: update the UI only when really needed
- Date: Fri, 16 Dec 2011 07:58:28 +0000 (UTC)
commit f3cb9d0443e02da17dca6cec57e38e5721fe894c
Author: Giovanni Campagna <gcampagna src gnome org>
Date: Tue Nov 15 18:22:24 2011 +0100
Network Menu: update the UI only when really needed
By using Main.queueDeferredWork, we can ensure that most of the
menu contents (in particular, the heaviest parts like the list of
wifi networks) are not updated immediately as we receive signals
from NetworkManager. Instead, the menu is rebuilt some time later,
or as soon as the user opens the menu.
This means that it is no longer needed to optimize for the
access-point-added case, replacing a lot of buggy code with a safer
call to _queueCreateSection, which in turn should ensure that the
more menu, if existing, is always at the end and that at most 5 networks
are visible outside it.
https://bugzilla.gnome.org/show_bug.cgi?id=664124
js/ui/status/network.js | 91 +++++++++++++++++++++-------------------------
1 files changed, 42 insertions(+), 49 deletions(-)
---
diff --git a/js/ui/status/network.js b/js/ui/status/network.js
index e22cdd8..863792d 100644
--- a/js/ui/status/network.js
+++ b/js/ui/status/network.js
@@ -329,7 +329,7 @@ const NMDevice = new Lang.Class({
}
this.section = new PopupMenu.PopupMenuSection();
- this._createSection();
+ this._deferredWorkId = Main.initializeDeferredWork(this.section.actor, Lang.bind(this, this._createSection));
},
destroy: function() {
@@ -396,16 +396,29 @@ const NMDevice = new Lang.Class({
this._activeConnection = activeConnection;
this._clearSection();
- this._createSection();
+ this._queueCreateSection();
},
checkConnection: function(connection) {
- let exists = this._findConnection(connection._uuid) != -1;
+ let pos = this._findConnection(connection._uuid);
+ let exists = pos != -1;
let valid = this.connectionValid(connection);
+
if (exists && !valid)
this.removeConnection(connection);
else if (!exists && valid)
this.addConnection(connection);
+ else if (exists && valid) {
+ // propagate changes and update the UI
+
+ if (this._connections[pos].timestamp != connection._timestamp) {
+ this._connections[pos].timestamp = connection._timestamp;
+ this._connections.sort(this._connectionSortFunction);
+
+ this._clearSection();
+ this._queueCreateSection();
+ }
+ }
},
addConnection: function(connection) {
@@ -420,7 +433,7 @@ const NMDevice = new Lang.Class({
this._connections.sort(this._connectionSortFunction);
this._clearSection();
- this._createSection();
+ this._queueCreateSection();
},
removeConnection: function(connection) {
@@ -444,7 +457,7 @@ const NMDevice = new Lang.Class({
// (or in the case of NMDeviceWired, we want to hide
// the only explicit connection)
this._clearSection();
- this._createSection();
+ this._queueCreateSection();
}
},
@@ -528,6 +541,11 @@ const NMDevice = new Lang.Class({
return -1;
},
+ _queueCreateSection: function() {
+ this._clearSection();
+ Main.queueDeferredWork(this._deferredWorkId);
+ },
+
_clearSection: function() {
// Clear everything
this.section.removeAll();
@@ -622,7 +640,7 @@ const NMDevice = new Lang.Class({
this._updateStatusItem();
this._clearSection();
- this._createSection();
+ this._queueCreateSection();
this.emit('state-changed');
},
@@ -866,7 +884,12 @@ const NMDeviceBluetooth = new Lang.Class({
this._autoConnectionName = this._makeConnectionName(this.device);
this._clearSection();
- this._createSection();
+ this._queueCreateSection();
+ this._updateStatusItem();
+ },
+
+ _getDescription: function() {
+ return this.device.name || _("Bluetooth");
}
});
@@ -1227,36 +1250,8 @@ const NMDeviceWireless = new Lang.Class({
}
if (needsupdate) {
- if (apObj.item)
- apObj.item.destroy();
-
- if (pos != -1)
- this._networks.splice(pos, 1);
-
- if (this._networks.length == 0) {
- // only network in the list
- this._networks.push(apObj);
- this._clearSection();
- this._createSection();
- return;
- }
-
- // skip networks that should appear earlier
- let menuPos = 0;
- for (pos = 0;
- pos < this._networks.length &&
- this._networkSortFunction(this._networks[pos], apObj) < 0; ++pos) {
- if (this._networks[pos] != this._activeNetwork)
- menuPos++;
- }
-
- // (re-)add the network
- this._networks.splice(pos, 0, apObj);
-
- if (this._shouldShowConnectionList()) {
- menuPos += (this._activeConnectionItem ? 1 : 0);
- this._createNetworkItem(apObj, menuPos);
- }
+ this._clearSection();
+ this._queueCreateSection();
}
},
@@ -1343,7 +1338,7 @@ const NMDeviceWireless = new Lang.Class({
let obj = this._connections[pos];
this._connections.splice(pos, 1);
- let anyauto = false, forceupdate = false;
+ let forceupdate = false;
for (let i = 0; i < this._networks.length; i++) {
let apObj = this._networks[i];
let connections = apObj.connections;
@@ -1351,16 +1346,14 @@ const NMDeviceWireless = new Lang.Class({
if (connections[k]._uuid == connection._uuid) {
// remove the connection from the access point group
connections.splice(k);
- anyauto = connections.length == 0;
+ forceupdate = forceupdate || connections.length == 0;
- if (anyauto) {
- // this potentially changes the sorting order
- forceupdate = true;
+ if (forceupdate)
break;
- }
+
if (apObj.item) {
if (apObj.item instanceof PopupMenu.PopupSubMenuMenuItem) {
- let items = apObj.item.menu.getMenuItems();
+ let items = apObj.item.menu._getMenuItems();
if (items.length == 2) {
// we need to update the connection list to convert this to a normal item
forceupdate = true;
@@ -1382,10 +1375,10 @@ const NMDeviceWireless = new Lang.Class({
}
}
- if (forceupdate || anyauto) {
+ if (forceupdate) {
this._networks.sort(this._networkSortFunction);
this._clearSection();
- this._createSection();
+ this._queueCreateSection();
}
},
@@ -1418,13 +1411,13 @@ const NMDeviceWireless = new Lang.Class({
if (forceupdate) {
this._networks.sort(this._networkSortFunction);
this._clearSection();
- this._createSection();
+ this._queueCreateSection();
}
},
_createActiveConnectionItem: function() {
let icon, title;
- if (this._activeConnection._connection) {
+ if (this._activeConnection && this._activeConnection._connection) {
let connection = this._activeConnection._connection;
if (this._activeNetwork)
this._activeConnectionItem = new NMNetworkMenuItem(this._activeNetwork.accessPoints, undefined,
@@ -1517,7 +1510,7 @@ const NMDeviceWireless = new Lang.Class({
if (!this._shouldShowConnectionList())
return;
- if(this._activeConnection) {
+ if (this._activeNetwork) {
this._createActiveConnectionItem();
this.section.addMenuItem(this._activeConnectionItem);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]