Ver Fonte

Refresh Apps in vm settings now refreshes the vm and template both

requires https://github.com/QubesOS/qubes-desktop-linux-common/commit/e26debfe97b7c252ab9e34611298745e135083c6

fixes QubesOS/qubes-issues#4383
Marta Marczykowska-Górecka há 5 anos atrás
pai
commit
f0357623e6
2 ficheiros alterados com 23 adições e 18 exclusões
  1. 22 18
      qubesmanager/settings.py
  2. 1 0
      rpm_spec/qmgr.spec.in

+ 22 - 18
qubesmanager/settings.py

@@ -93,31 +93,35 @@ class RenameVMThread(QtCore.QThread):
 
 # pylint: disable=too-few-public-methods
 class RefreshAppsVMThread(QtCore.QThread):
-    def __init__(self, vm):
+    def __init__(self, vm, button):
         QtCore.QThread.__init__(self)
         self.vm = vm
+        self.button = button
         self.msg = None
 
     def run(self):
-        try:
+        vms_to_refresh = [self.vm]
+        template = getattr(self.vm, 'template', None)
+        if template:
+            vms_to_refresh.append(template)
+
+        for vm in vms_to_refresh:
+            self.button.setText(
+                self.tr('Refresh in progress (refreshing applications '
+                        'from {})').format(vm.name))
             try:
-                target_vm = self.vm.template
-            except AttributeError:
-                target_vm = self.vm
-
-            if not target_vm.is_running():
-                not_running = True
-                target_vm.start()
-            else:
-                not_running = False
+                if not vm.is_running():
+                    not_running = True
+                    vm.start()
+                else:
+                    not_running = False
 
-            subprocess.check_call(['qvm-sync-appmenus', target_vm.name])
+                subprocess.check_call(['qvm-sync-appmenus', vm.name])
 
-            if not_running:
-                target_vm.shutdown()
-
-        except Exception as ex:  # pylint: disable=broad-except
-            self.msg = ("Refresh failed!", str(ex))
+                if not_running:
+                    vm.shutdown()
+            except Exception as ex:  # pylint: disable=broad-except
+                self.msg = ("Refresh failed!", str(ex))
 
 
 # pylint: disable=too-many-instance-attributes
@@ -982,7 +986,7 @@ class VMSettingsWindow(ui_settingsdlg.Ui_SettingsDialog, QtGui.QDialog):
         self.refresh_apps_button.setEnabled(False)
         self.refresh_apps_button.setText(self.tr('Refresh in progress...'))
 
-        thread = RefreshAppsVMThread(self.vm)
+        thread = RefreshAppsVMThread(self.vm, self.refresh_apps_button)
         thread.finished.connect(self.clear_threads)
         thread.finished.connect(self.refresh_finished)
         self.threads_list.append(thread)

+ 1 - 0
rpm_spec/qmgr.spec.in

@@ -12,6 +12,7 @@ Requires:	python3-PyQt4
 Requires:	python3-inotify
 Requires:	python3-qubesadmin >= 4.0.19
 Requires:	python3-Quamash
+Requires:   qubes-desktop-linux-common >= 4.0.16
 Requires:	qubes-artwork
 Requires:	pmount
 Requires:	cryptsetup