c085d819a8
virt-manager-1.5.0.tar.bz2 * python3 prep work (Radostin Stoyanov, Cole Robinson, Cédric Bosdonnat) * Switch –location ISO to use isoinfo (Andrew Wong) * virt-install: add –cpu numa distance handling (Menno Lageman) * virt-install: fix –disk for rbd volumes with auth (Rauno Väli) * virt-install: add –cputune vcpupin handling (Wim ten Have) * details ui: Showing attached scsi devices per controller (Lin Ma) * network ui: Show details about SR-IOV VF pool (Lin Ma) * Greatly expand UI test suite coverage - Dropped patches 0001-Improve-container-image-url-example.patch 0001-py3-store-exception-variables-for-use-outside-except.patch 0002-create-wizard-fix-alignment-in-os-container-page.patch 0003-oscontainer-ask-root-password-in-the-wizard.patch 0004-Harmonize-invisible_char-values.patch 083dfcc8-Show-details-about-the-network-of-SR-IOV-VF-pool.patch 08a58d61-pycodestyle-remove-description-of-fixed-errors.patch 0c6bcb09-fix-bytes-string-mess-in-serial-console.patch 0e812e3c-dont-skip-authentication-for-listen-type-none-with-fixed-QEMU.patch 23aaf852-network-Set-bridge-name-to-None-instead-of-blank.patch 2d276ebe-progress-dont-overwrite-format.patch 2eb455c9-correctly-calculate-virtio-scsi-controller-index.patch 374a3779-urlfetcher-write-test-file-as-binary-content.patch 37ea5207-replace-StandardError-with-Exception.patch 3b769643-dont-add-URI-into-params-for-tunneled-migration.patch 3be78d1f-addhardware-dont-allow-panic-option-where-not-supported.patch 44de92b7-use-reload-from-imp-module.patch 63fce081-pycodestyle-Use-isinstance-for-type-checking.patch 67122615-python2to3-division-compatability.patch OBS-URL: https://build.opensuse.org/package/show/Virtualization/virt-manager?expand=0&rev=406
821 lines
30 KiB
Diff
821 lines
30 KiB
Diff
Index: virt-manager-1.5.0/virt-manager
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virt-manager
|
|
+++ virt-manager-1.5.0/virt-manager
|
|
@@ -1,4 +1,4 @@
|
|
-#!/usr/bin/env python2
|
|
+#!/usr/bin/python3
|
|
#
|
|
# Copyright (C) 2006, 2014 Red Hat, Inc.
|
|
# Copyright (C) 2006 Daniel P. Berrange <berrange@redhat.com>
|
|
@@ -81,7 +81,7 @@ def _import_gtk(leftovers):
|
|
print("gtk3 3.14.0 or later is required.")
|
|
sys.exit(1)
|
|
|
|
- if os.environ.has_key('DISPLAY') and os.environ['DISPLAY']:
|
|
+ if 'DISPLAY' in os.environ and os.environ['DISPLAY']:
|
|
# This will error if Gtk wasn't correctly initialized
|
|
Gtk.Window()
|
|
else:
|
|
Index: virt-manager-1.5.0/virtManager/network.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/network.py
|
|
+++ virt-manager-1.5.0/virtManager/network.py
|
|
@@ -103,7 +103,7 @@ class vmmNetwork(vmmLibvirtObject):
|
|
def set_qos(self, **kwargs):
|
|
xmlobj = self._make_xmlobj_to_define()
|
|
q = xmlobj.bandwidth
|
|
- for key, val in kwargs.items():
|
|
+ for key, val in list(kwargs.items()):
|
|
setattr(q, key, val)
|
|
|
|
self._redefine_xmlobj(xmlobj)
|
|
Index: virt-manager-1.5.0/virtManager/inspection.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/inspection.py
|
|
+++ virt-manager-1.5.0/virtManager/inspection.py
|
|
@@ -17,8 +17,9 @@
|
|
# MA 02110-1301 USA.
|
|
#
|
|
|
|
-from Queue import Queue
|
|
+from queue import Queue
|
|
from threading import Thread
|
|
+import functools
|
|
import logging
|
|
|
|
from guestfs import GuestFS # pylint: disable=import-error
|
|
@@ -212,7 +213,7 @@ class vmmInspection(vmmGObject):
|
|
return 0
|
|
else:
|
|
return -1
|
|
- mps.sort(compare)
|
|
+ mps.sort(key=functools.cmp_to_key(compare))
|
|
|
|
for mp_dev in mps:
|
|
try:
|
|
@@ -263,7 +264,7 @@ class vmmInspection(vmmGObject):
|
|
data.product_name = str(product_name)
|
|
data.product_variant = str(product_variant)
|
|
data.icon = icon
|
|
- data.applications = list(apps)
|
|
+ data.applications = apps if apps is None else list(apps)
|
|
data.error = False
|
|
|
|
return data
|
|
Index: virt-manager-1.5.0/virtManager/systray.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/systray.py
|
|
+++ virt-manager-1.5.0/virtManager/systray.py
|
|
@@ -199,13 +199,13 @@ class vmmSystray(vmmGObject):
|
|
|
|
def repopulate_menu_list(self):
|
|
# Build sorted connection list
|
|
- connsort = self.conn_menuitems.keys()
|
|
+ connsort = list(self.conn_menuitems.keys())
|
|
connsort.sort()
|
|
connsort.reverse()
|
|
|
|
# Empty conn list
|
|
for child in self.systray_menu.get_children():
|
|
- if child in self.conn_menuitems.values():
|
|
+ if child in list(self.conn_menuitems.values()):
|
|
self.systray_menu.remove(child)
|
|
|
|
# Build sorted conn list
|
|
@@ -265,7 +265,7 @@ class vmmSystray(vmmGObject):
|
|
for vm in conn.list_vms():
|
|
vm_mappings[vm.get_name()] = vm.get_connkey()
|
|
|
|
- vm_names = vm_mappings.keys()
|
|
+ vm_names = list(vm_mappings.keys())
|
|
vm_names.sort()
|
|
|
|
if len(vm_names) == 0:
|
|
Index: virt-manager-1.5.0/virtManager/console.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/console.py
|
|
+++ virt-manager-1.5.0/virtManager/console.py
|
|
@@ -35,7 +35,7 @@ from .viewers import SpiceViewer, VNCVie
|
|
(_CONSOLE_PAGE_UNAVAILABLE,
|
|
_CONSOLE_PAGE_AUTHENTICATE,
|
|
_CONSOLE_PAGE_SERIAL,
|
|
- _CONSOLE_PAGE_VIEWER) = range(4)
|
|
+ _CONSOLE_PAGE_VIEWER) = list(range(4))
|
|
|
|
|
|
class _TimedRevealer(vmmGObject):
|
|
Index: virt-manager-1.5.0/virtManager/connection.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/connection.py
|
|
+++ virt-manager-1.5.0/virtManager/connection.py
|
|
@@ -198,7 +198,7 @@ class vmmConnection(vmmGObject):
|
|
|
|
(_STATE_DISCONNECTED,
|
|
_STATE_CONNECTING,
|
|
- _STATE_ACTIVE) = range(1, 4)
|
|
+ _STATE_ACTIVE) = list(range(1, 4))
|
|
|
|
def __init__(self, uri):
|
|
vmmGObject.__init__(self)
|
|
@@ -1215,35 +1215,35 @@ class vmmConnection(vmmGObject):
|
|
def _update_nets(self, dopoll):
|
|
keymap = dict((o.get_connkey(), o) for o in self.list_nets())
|
|
if not dopoll or not self.is_network_capable():
|
|
- return [], [], keymap.values()
|
|
+ return [], [], list(keymap.values())
|
|
return pollhelpers.fetch_nets(self._backend, keymap,
|
|
(lambda obj, key: vmmNetwork(self, obj, key)))
|
|
|
|
def _update_pools(self, dopoll):
|
|
keymap = dict((o.get_connkey(), o) for o in self.list_pools())
|
|
if not dopoll or not self.is_storage_capable():
|
|
- return [], [], keymap.values()
|
|
+ return [], [], list(keymap.values())
|
|
return pollhelpers.fetch_pools(self._backend, keymap,
|
|
(lambda obj, key: vmmStoragePool(self, obj, key)))
|
|
|
|
def _update_interfaces(self, dopoll):
|
|
keymap = dict((o.get_connkey(), o) for o in self.list_interfaces())
|
|
if not dopoll or not self.is_interface_capable():
|
|
- return [], [], keymap.values()
|
|
+ return [], [], list(keymap.values())
|
|
return pollhelpers.fetch_interfaces(self._backend, keymap,
|
|
(lambda obj, key: vmmInterface(self, obj, key)))
|
|
|
|
def _update_nodedevs(self, dopoll):
|
|
keymap = dict((o.get_connkey(), o) for o in self.list_nodedevs())
|
|
if not dopoll or not self.is_nodedev_capable():
|
|
- return [], [], keymap.values()
|
|
+ return [], [], list(keymap.values())
|
|
return pollhelpers.fetch_nodedevs(self._backend, keymap,
|
|
(lambda obj, key: vmmNodeDevice(self, obj, key)))
|
|
|
|
def _update_vms(self, dopoll):
|
|
keymap = dict((o.get_connkey(), o) for o in self.list_vms())
|
|
if not dopoll:
|
|
- return [], [], keymap.values()
|
|
+ return [], [], list(keymap.values())
|
|
return pollhelpers.fetch_vms(self._backend, keymap,
|
|
(lambda obj, key: vmmDomain(self, obj, key)))
|
|
|
|
Index: virt-manager-1.5.0/virtManager/addhardware.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/addhardware.py
|
|
+++ virt-manager-1.5.0/virtManager/addhardware.py
|
|
@@ -57,7 +57,7 @@ from .addstorage import vmmAddStorage
|
|
PAGE_USBREDIR,
|
|
PAGE_TPM,
|
|
PAGE_RNG,
|
|
- PAGE_PANIC) = range(0, 17)
|
|
+ PAGE_PANIC) = list(range(0, 17))
|
|
|
|
|
|
class vmmAddHardware(vmmGObjectUI):
|
|
@@ -1164,7 +1164,7 @@ class vmmAddHardware(vmmGObjectUI):
|
|
self._dev = VirtualTPMDevice(self.conn.get_backend())
|
|
self._dev.type = devtype
|
|
|
|
- for param_name, widget_name in tpm_widget_mappings.items():
|
|
+ for param_name, widget_name in list(tpm_widget_mappings.items()):
|
|
make_visible = self._dev.supports_property(param_name)
|
|
uiutil.set_grid_row_visible(self.widget(widget_name + "-label"),
|
|
make_visible)
|
|
@@ -1218,7 +1218,7 @@ class vmmAddHardware(vmmGObjectUI):
|
|
self._dev = char_class(self.conn.get_backend())
|
|
self._dev.type = devtype
|
|
|
|
- for param_name, widget_name in char_widget_mappings.items():
|
|
+ for param_name, widget_name in list(char_widget_mappings.items()):
|
|
make_visible = self._dev.supports_property(param_name)
|
|
uiutil.set_grid_row_visible(self.widget(widget_name + "-label"),
|
|
make_visible)
|
|
@@ -1671,7 +1671,7 @@ class vmmAddHardware(vmmGObjectUI):
|
|
try:
|
|
self._dev = devclass
|
|
|
|
- for param_name, val in value_mappings.items():
|
|
+ for param_name, val in list(value_mappings.items()):
|
|
if self._dev.supports_property(param_name) and val is not None:
|
|
setattr(self._dev, param_name, val)
|
|
|
|
@@ -1752,7 +1752,7 @@ class vmmAddHardware(vmmGObjectUI):
|
|
try:
|
|
self._dev = VirtualTPMDevice(conn)
|
|
self._dev.type = typ
|
|
- for param_name, val in value_mappings.items():
|
|
+ for param_name, val in list(value_mappings.items()):
|
|
if self._dev.supports_property(param_name):
|
|
setattr(self._dev, param_name, val)
|
|
except Exception as e:
|
|
@@ -1856,7 +1856,7 @@ class vmmAddHardware(vmmGObjectUI):
|
|
try:
|
|
self._dev = virtinst.VirtualRNGDevice(self.conn.get_backend())
|
|
self._dev.type = rtype
|
|
- for param_name, val in value_mappings.items():
|
|
+ for param_name, val in list(value_mappings.items()):
|
|
if self._dev.supports_property(param_name):
|
|
setattr(self._dev, param_name, val)
|
|
except Exception as e:
|
|
Index: virt-manager-1.5.0/virtManager/createinterface.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/createinterface.py
|
|
+++ virt-manager-1.5.0/virtManager/createinterface.py
|
|
@@ -387,7 +387,7 @@ class vmmCreateInterface(vmmGObjectUI):
|
|
Interface.INTERFACE_TYPE_VLAN: "vlan",
|
|
}
|
|
|
|
- for key, value in type_dict.items():
|
|
+ for key, value in list(type_dict.items()):
|
|
do_show = (key == itype)
|
|
self.widget("%s-label" % value).set_visible(do_show)
|
|
self.widget("%s-box" % value).set_visible(do_show)
|
|
@@ -544,7 +544,7 @@ class vmmCreateInterface(vmmGObjectUI):
|
|
active, None, iface.get_mac()]
|
|
row_dict[name] = row
|
|
|
|
- for name, row in nodedevs.items():
|
|
+ for name, row in list(nodedevs.items()):
|
|
try:
|
|
key = Interface(self.conn.get_backend())
|
|
key.type = Interface.INTERFACE_TYPE_ETHERNET
|
|
@@ -556,12 +556,12 @@ class vmmCreateInterface(vmmGObjectUI):
|
|
row[INTERFACE_ROW_KEY] = key
|
|
row_dict[name] = row
|
|
|
|
- for row in row_dict.values():
|
|
+ for row in list(row_dict.values()):
|
|
name = row[INTERFACE_ROW_NAME]
|
|
row[INTERFACE_ROW_IN_USE_BY] = self.iface_in_use_by(self.conn,
|
|
name)
|
|
|
|
- for row in row_dict.values():
|
|
+ for row in list(row_dict.values()):
|
|
model.append(row)
|
|
|
|
def get_default_name(self):
|
|
Index: virt-manager-1.5.0/virtManager/snapshots.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/snapshots.py
|
|
+++ virt-manager-1.5.0/virtManager/snapshots.py
|
|
@@ -44,7 +44,7 @@ mimemap = {
|
|
|
|
|
|
def _mime_to_ext(val, reverse=False):
|
|
- for m, e in mimemap.items():
|
|
+ for m, e in list(mimemap.items()):
|
|
if val == m and not reverse:
|
|
return e
|
|
if val == e and reverse:
|
|
@@ -507,7 +507,7 @@ class vmmSnapshotPage(vmmGObjectUI):
|
|
basesn = os.path.join(cachedir, "snap-screenshot-%s" % name)
|
|
|
|
# Remove any pre-existing screenshots so we don't show stale data
|
|
- for ext in mimemap.values():
|
|
+ for ext in list(mimemap.values()):
|
|
p = basesn + "." + ext
|
|
if os.path.exists(basesn + "." + ext):
|
|
os.unlink(p)
|
|
Index: virt-manager-1.5.0/virtManager/graphwidgets.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/graphwidgets.py
|
|
+++ virt-manager-1.5.0/virtManager/graphwidgets.py
|
|
@@ -25,8 +25,8 @@ from gi.repository import Gtk
|
|
|
|
def rect_print(name, rect):
|
|
# For debugging
|
|
- print("%s: height=%d, width=%d, x=%d, y=%d" %
|
|
- (name, rect.height, rect.width, rect.x, rect.y))
|
|
+ print(("%s: height=%d, width=%d, x=%d, y=%d" %
|
|
+ (name, rect.height, rect.width, rect.x, rect.y)))
|
|
|
|
|
|
def _line_helper(cairo_ct, x, y, w, h, points, for_fill=False):
|
|
Index: virt-manager-1.5.0/virtManager/host.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/host.py
|
|
+++ virt-manager-1.5.0/virtManager/host.py
|
|
@@ -43,11 +43,11 @@ EDIT_NET_IDS = (
|
|
EDIT_NET_NAME,
|
|
EDIT_NET_AUTOSTART,
|
|
EDIT_NET_QOS,
|
|
-) = range(3)
|
|
+) = list(range(3))
|
|
|
|
EDIT_INTERFACE_IDS = (
|
|
EDIT_INTERFACE_STARTMODE,
|
|
-) = range(200, 201)
|
|
+) = list(range(200, 201))
|
|
|
|
|
|
class vmmHost(vmmGObjectUI):
|
|
Index: virt-manager-1.5.0/virtManager/sshtunnels.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/sshtunnels.py
|
|
+++ virt-manager-1.5.0/virtManager/sshtunnels.py
|
|
@@ -20,7 +20,7 @@
|
|
import functools
|
|
import logging
|
|
import os
|
|
-import Queue
|
|
+import queue
|
|
import socket
|
|
import signal
|
|
import threading
|
|
@@ -125,7 +125,7 @@ class _TunnelScheduler(object):
|
|
"""
|
|
def __init__(self):
|
|
self._thread = None
|
|
- self._queue = Queue.Queue()
|
|
+ self._queue = queue.Queue()
|
|
self._lock = threading.Lock()
|
|
|
|
def _handle_queue(self):
|
|
Index: virt-manager-1.5.0/virtManager/engine.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/engine.py
|
|
+++ virt-manager-1.5.0/virtManager/engine.py
|
|
@@ -20,7 +20,7 @@
|
|
|
|
import logging
|
|
import re
|
|
-import Queue
|
|
+import queue
|
|
import threading
|
|
import traceback
|
|
|
|
@@ -60,7 +60,7 @@ DETAILS_CONFIG = 2
|
|
DETAILS_CONSOLE = 3
|
|
|
|
(PRIO_HIGH,
|
|
- PRIO_LOW) = range(1, 3)
|
|
+ PRIO_LOW) = list(range(1, 3))
|
|
|
|
|
|
class vmmEngine(vmmGObject):
|
|
@@ -105,7 +105,7 @@ class vmmEngine(vmmGObject):
|
|
target=self._handle_tick_queue,
|
|
args=())
|
|
self._tick_thread.daemon = True
|
|
- self._tick_queue = Queue.PriorityQueue(100)
|
|
+ self._tick_queue = queue.PriorityQueue(100)
|
|
|
|
self.inspection = None
|
|
self._create_inspection_thread()
|
|
@@ -154,7 +154,7 @@ class vmmEngine(vmmGObject):
|
|
self._application.add_action(action)
|
|
|
|
def _default_startup(self, skip_autostart, cliuri):
|
|
- uris = self.conns.keys()
|
|
+ uris = list(self.conns.keys())
|
|
if not uris:
|
|
logging.debug("No stored URIs found.")
|
|
else:
|
|
@@ -282,15 +282,15 @@ class vmmEngine(vmmGObject):
|
|
"""
|
|
We serialize conn autostart, so polkit/ssh-askpass doesn't spam
|
|
"""
|
|
- queue = Queue.Queue()
|
|
+ local_queue = queue.Queue()
|
|
auto_conns = [uri for uri in self.conns
|
|
if self.conns[uri]["conn"].get_autoconnect()]
|
|
|
|
def add_next_to_queue():
|
|
if not auto_conns:
|
|
- queue.put(None)
|
|
+ local_queue.put(None)
|
|
else:
|
|
- queue.put(auto_conns.pop(0))
|
|
+ local_queue.put(auto_conns.pop(0))
|
|
|
|
def state_change_cb(conn):
|
|
if conn.is_active():
|
|
@@ -302,7 +302,7 @@ class vmmEngine(vmmGObject):
|
|
|
|
def handle_queue():
|
|
while True:
|
|
- uri = queue.get()
|
|
+ uri = local_queue.get()
|
|
if uri is None:
|
|
return
|
|
if uri not in self.conns:
|
|
@@ -339,7 +339,7 @@ class vmmEngine(vmmGObject):
|
|
|
|
hvuri = conn.get_uri()
|
|
|
|
- for connkey in self.conns[hvuri]["windowDetails"].keys():
|
|
+ for connkey in list(self.conns[hvuri]["windowDetails"].keys()):
|
|
self.conns[hvuri]["windowDetails"][connkey].cleanup()
|
|
del(self.conns[hvuri]["windowDetails"][connkey])
|
|
|
|
@@ -524,10 +524,10 @@ class vmmEngine(vmmGObject):
|
|
focus, and use that
|
|
"""
|
|
windowlist = [self.windowManager]
|
|
- for conndict in self.conns.values():
|
|
- windowlist.extend(conndict["windowDetails"].values())
|
|
+ for conndict in list(self.conns.values()):
|
|
+ windowlist.extend(list(conndict["windowDetails"].values()))
|
|
windowlist.extend(
|
|
- [conndict["windowHost"] for conndict in self.conns.values()])
|
|
+ [conndict["windowHost"] for conndict in list(self.conns.values())])
|
|
|
|
use_win = None
|
|
for window in windowlist:
|
|
@@ -603,7 +603,7 @@ class vmmEngine(vmmGObject):
|
|
self.conns[uri]["windowClone"].cleanup()
|
|
|
|
details = self.conns[uri]["windowDetails"]
|
|
- for win in details.values():
|
|
+ for win in list(details.values()):
|
|
win.cleanup()
|
|
|
|
self.conns[uri]["conn"].cleanup()
|
|
@@ -623,7 +623,7 @@ class vmmEngine(vmmGObject):
|
|
handle_id = vmmGObject.connect(self, name, callback, *args)
|
|
|
|
if name == "conn-added":
|
|
- for conn_dict in self.conns.values():
|
|
+ for conn_dict in list(self.conns.values()):
|
|
self.emit("conn-added", conn_dict["conn"])
|
|
|
|
return handle_id
|
|
@@ -773,7 +773,7 @@ class vmmEngine(vmmGObject):
|
|
return self.connect_to_uri(uri, autoconnect, probe=True)
|
|
|
|
def cancelled(src):
|
|
- if len(self.conns.keys()) == 0:
|
|
+ if len(list(self.conns.keys())) == 0:
|
|
self.exit_app(src)
|
|
|
|
obj = vmmConnect()
|
|
Index: virt-manager-1.5.0/virtManager/mediacombo.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/mediacombo.py
|
|
+++ virt-manager-1.5.0/virtManager/mediacombo.py
|
|
@@ -33,7 +33,7 @@ class vmmMediaCombo(vmmGObjectUI):
|
|
(OPTICAL_DEV_PATH,
|
|
OPTICAL_LABEL,
|
|
OPTICAL_HAS_MEDIA,
|
|
- OPTICAL_DEV_KEY) = range(OPTICAL_FIELDS)
|
|
+ OPTICAL_DEV_KEY) = list(range(OPTICAL_FIELDS))
|
|
|
|
def __init__(self, conn, builder, topwin, media_type):
|
|
vmmGObjectUI.__init__(self, None, None, builder=builder, topwin=topwin)
|
|
Index: virt-manager-1.5.0/virtManager/clone.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/clone.py
|
|
+++ virt-manager-1.5.0/virtManager/clone.py
|
|
@@ -336,7 +336,7 @@ class vmmCloneVM(vmmGObjectUI):
|
|
|
|
build_net_row(label, mac, newmac)
|
|
|
|
- no_net = bool(len(self.net_list.keys()) == 0)
|
|
+ no_net = bool(len(list(self.net_list.keys())) == 0)
|
|
self.widget("clone-network-box").set_visible(not no_net)
|
|
self.widget("clone-no-net").set_visible(no_net)
|
|
|
|
@@ -460,7 +460,7 @@ class vmmCloneVM(vmmGObjectUI):
|
|
if cd.clone_name == newname:
|
|
return
|
|
|
|
- for row in self.storage_list.values():
|
|
+ for row in list(self.storage_list.values()):
|
|
origpath = row[STORAGE_INFO_ORIG_PATH]
|
|
if row[STORAGE_INFO_MANUAL_PATH]:
|
|
continue
|
|
@@ -599,7 +599,7 @@ class vmmCloneVM(vmmGObjectUI):
|
|
# If any storage cannot be cloned or shared, don't allow cloning
|
|
clone = True
|
|
tooltip = ""
|
|
- for row in self.storage_list.values():
|
|
+ for row in list(self.storage_list.values()):
|
|
can_clone = row[STORAGE_INFO_CAN_CLONE]
|
|
can_share = row[STORAGE_INFO_CAN_SHARE]
|
|
if not (can_clone or can_share):
|
|
Index: virt-manager-1.5.0/virtManager/netlist.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/netlist.py
|
|
+++ virt-manager-1.5.0/virtManager/netlist.py
|
|
@@ -197,7 +197,7 @@ class vmmNetworkList(vmmGObjectUI):
|
|
for slave in slave_names:
|
|
netdevs.pop(slave, None)
|
|
|
|
- for name, is_bridge, slave_names in netdevs.values():
|
|
+ for name, is_bridge, slave_names in list(netdevs.values()):
|
|
if ((name in vnet_taps) or
|
|
(name in [v + "-nic" for v in vnet_bridges]) or
|
|
(name in skip_ifaces)):
|
|
Index: virt-manager-1.5.0/virtManager/manager.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/manager.py
|
|
+++ virt-manager-1.5.0/virtManager/manager.py
|
|
@@ -48,7 +48,7 @@ ROW_IS_CONN_CONNECTED,
|
|
ROW_IS_VM,
|
|
ROW_IS_VM_RUNNING,
|
|
ROW_COLOR,
|
|
-ROW_INSPECTION_OS_ICON) = range(11)
|
|
+ROW_INSPECTION_OS_ICON) = list(range(11))
|
|
|
|
# Columns in the tree view
|
|
(COL_NAME,
|
|
@@ -56,7 +56,7 @@ COL_GUEST_CPU,
|
|
COL_HOST_CPU,
|
|
COL_MEM,
|
|
COL_DISK,
|
|
-COL_NETWORK) = range(6)
|
|
+COL_NETWORK) = list(range(6))
|
|
|
|
|
|
def _style_get_prop(widget, propname):
|
|
Index: virt-manager-1.5.0/virtManager/keyring.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/keyring.py
|
|
+++ virt-manager-1.5.0/virtManager/keyring.py
|
|
@@ -110,10 +110,10 @@ class vmmKeyring(object):
|
|
label = iface.get_cached_property("Label").unpack().strip("'")
|
|
dbusattrs = iface.get_cached_property("Attributes").unpack()
|
|
|
|
- secret = u"".join([unichr(c) for c in secretbytes])
|
|
+ secret = "".join([chr(c) for c in secretbytes])
|
|
|
|
attrs = {}
|
|
- for key, val in dbusattrs.items():
|
|
+ for key, val in list(dbusattrs.items()):
|
|
if key not in ["hvuri", "uuid"]:
|
|
continue
|
|
attrs["%s" % key] = "%s" % val
|
|
Index: virt-manager-1.5.0/virtManager/addstorage.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/addstorage.py
|
|
+++ virt-manager-1.5.0/virtManager/addstorage.py
|
|
@@ -162,7 +162,7 @@ class vmmAddStorage(vmmGObjectUI):
|
|
errmsg = _("Errors were encountered changing permissions for the "
|
|
"following directories:")
|
|
details = ""
|
|
- for p, error in errors.items():
|
|
+ for p, error in list(errors.items()):
|
|
if p not in broken_paths:
|
|
continue
|
|
details += "%s : %s\n" % (p, error)
|
|
@@ -174,7 +174,7 @@ class vmmAddStorage(vmmGObjectUI):
|
|
_("Don't ask about these directories again."))
|
|
|
|
if chkres:
|
|
- src.config.add_perms_fix_ignore(errors.keys())
|
|
+ src.config.add_perms_fix_ignore(list(errors.keys()))
|
|
|
|
def reset_state(self):
|
|
self._update_host_space()
|
|
Index: virt-manager-1.5.0/virtManager/details.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/details.py
|
|
+++ virt-manager-1.5.0/virtManager/details.py
|
|
@@ -106,7 +106,7 @@ from .graphwidgets import Sparkline
|
|
|
|
EDIT_FS,
|
|
|
|
- EDIT_HOSTDEV_ROMBAR) = range(1, 49)
|
|
+ EDIT_HOSTDEV_ROMBAR) = list(range(1, 49))
|
|
|
|
|
|
# Columns in hw list model
|
|
@@ -114,7 +114,7 @@ from .graphwidgets import Sparkline
|
|
HW_LIST_COL_ICON_NAME,
|
|
HW_LIST_COL_ICON_SIZE,
|
|
HW_LIST_COL_TYPE,
|
|
- HW_LIST_COL_DEVICE) = range(5)
|
|
+ HW_LIST_COL_DEVICE) = list(range(5))
|
|
|
|
# Types for the hw list model: numbers specify what order they will be listed
|
|
(HW_LIST_TYPE_GENERAL,
|
|
@@ -138,7 +138,7 @@ from .graphwidgets import Sparkline
|
|
HW_LIST_TYPE_REDIRDEV,
|
|
HW_LIST_TYPE_TPM,
|
|
HW_LIST_TYPE_RNG,
|
|
- HW_LIST_TYPE_PANIC) = range(22)
|
|
+ HW_LIST_TYPE_PANIC) = list(range(22))
|
|
|
|
remove_pages = [HW_LIST_TYPE_NIC, HW_LIST_TYPE_INPUT,
|
|
HW_LIST_TYPE_GRAPHICS, HW_LIST_TYPE_SOUND, HW_LIST_TYPE_CHAR,
|
|
@@ -153,12 +153,12 @@ remove_pages = [HW_LIST_TYPE_NIC, HW_LIS
|
|
BOOT_LABEL,
|
|
BOOT_ICON,
|
|
BOOT_ACTIVE,
|
|
- BOOT_CAN_SELECT) = range(5)
|
|
+ BOOT_CAN_SELECT) = list(range(5))
|
|
|
|
# Main tab pages
|
|
(DETAILS_PAGE_DETAILS,
|
|
DETAILS_PAGE_CONSOLE,
|
|
- DETAILS_PAGE_SNAPSHOTS) = range(3)
|
|
+ DETAILS_PAGE_SNAPSHOTS) = list(range(3))
|
|
|
|
_remove_tooltip = _("Remove this device from the virtual machine")
|
|
|
|
@@ -744,7 +744,7 @@ class vmmDetails(vmmGObjectUI):
|
|
rmHW.connect("activate", self.remove_xml_dev)
|
|
|
|
self._addhwmenuitems = {"add": addHW, "remove": rmHW}
|
|
- for i in self._addhwmenuitems.values():
|
|
+ for i in list(self._addhwmenuitems.values()):
|
|
self.addhwmenu.add(i)
|
|
|
|
self.widget("hw-panel").set_show_tabs(False)
|
|
@@ -1519,7 +1519,7 @@ class vmmDetails(vmmGObjectUI):
|
|
'tEXt::Generator Version': self.config.get_appversion(),
|
|
}
|
|
|
|
- ret = image.save_to_bufferv('png', metadata.keys(), metadata.values())
|
|
+ ret = image.save_to_bufferv('png', list(metadata.keys()), list(metadata.values()))
|
|
# On Fedora 19, ret is (bool, str)
|
|
# Someday the bindings might be fixed to just return the str, try
|
|
# and future proof it a bit
|
|
@@ -2835,7 +2835,7 @@ class vmmDetails(vmmGObjectUI):
|
|
set_visible("rng-bind-host", is_egd and (udp or bind))
|
|
set_visible("rng-bind-service", is_egd and (udp or bind))
|
|
|
|
- for k, prop in values.items():
|
|
+ for k, prop in list(values.items()):
|
|
val = "-"
|
|
if dev.supports_property(prop):
|
|
val = getattr(dev, prop) or "-"
|
|
@@ -3229,7 +3229,7 @@ class vmmDetails(vmmGObjectUI):
|
|
for dev in self.vm.get_panic_devices():
|
|
update_hwlist(HW_LIST_TYPE_PANIC, dev)
|
|
|
|
- devs = range(len(hw_list_model))
|
|
+ devs = list(range(len(hw_list_model)))
|
|
devs.reverse()
|
|
for i in devs:
|
|
_iter = hw_list_model.iter_nth_child(None, i)
|
|
Index: virt-manager-1.5.0/virtManager/create.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/create.py
|
|
+++ virt-manager-1.5.0/virtManager/create.py
|
|
@@ -55,7 +55,7 @@ DEFAULT_MEM = 1024
|
|
PAGE_INSTALL,
|
|
PAGE_MEM,
|
|
PAGE_STORAGE,
|
|
- PAGE_FINISH) = range(5)
|
|
+ PAGE_FINISH) = list(range(5))
|
|
|
|
(INSTALL_PAGE_ISO,
|
|
INSTALL_PAGE_URL,
|
|
@@ -63,13 +63,13 @@ DEFAULT_MEM = 1024
|
|
INSTALL_PAGE_IMPORT,
|
|
INSTALL_PAGE_CONTAINER_APP,
|
|
INSTALL_PAGE_CONTAINER_OS,
|
|
- INSTALL_PAGE_VZ_TEMPLATE) = range(7)
|
|
+ INSTALL_PAGE_VZ_TEMPLATE) = list(range(7))
|
|
|
|
# Column numbers for os type/version list models
|
|
(OS_COL_ID,
|
|
OS_COL_LABEL,
|
|
OS_COL_IS_SEP,
|
|
- OS_COL_IS_SHOW_ALL) = range(4)
|
|
+ OS_COL_IS_SHOW_ALL) = list(range(4))
|
|
|
|
|
|
#####################
|
|
@@ -953,7 +953,7 @@ class vmmCreate(vmmGObjectUI):
|
|
model.clear()
|
|
|
|
default = -1
|
|
- for c in self.engine.conns.values():
|
|
+ for c in list(self.engine.conns.values()):
|
|
connobj = c["conn"]
|
|
if not connobj.is_active():
|
|
continue
|
|
@@ -2587,7 +2587,7 @@ class vmmCreate(vmmGObjectUI):
|
|
'insecure': self._get_config_oscontainer_isecure,
|
|
'root_password': self._get_config_oscontainer_root_password,
|
|
}
|
|
- for key, getter in bootstrap_arg_keys.items():
|
|
+ for key, getter in list(bootstrap_arg_keys.items()):
|
|
bootstrap_args[key] = getter()
|
|
|
|
parentobj = self._customize_window or self
|
|
Index: virt-manager-1.5.0/virtManager/preferences.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/preferences.py
|
|
+++ virt-manager-1.5.0/virtManager/preferences.py
|
|
@@ -121,7 +121,7 @@ class vmmPreferences(vmmGObjectUI):
|
|
}
|
|
model.append([-1, _("System default (%s)") %
|
|
vals[self.config.default_console_resizeguest]])
|
|
- for key, val in vals.items():
|
|
+ for key, val in list(vals.items()):
|
|
model.append([key, val])
|
|
combo.set_model(model)
|
|
uiutil.init_combo_text_column(combo, 1)
|
|
Index: virt-manager-1.5.0/virtManager/migrate.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/migrate.py
|
|
+++ virt-manager-1.5.0/virtManager/migrate.py
|
|
@@ -36,7 +36,7 @@ from .domain import vmmDomain
|
|
NUM_COLS = 3
|
|
(COL_LABEL,
|
|
COL_URI,
|
|
- COL_CAN_MIGRATE) = range(NUM_COLS)
|
|
+ COL_CAN_MIGRATE) = list(range(NUM_COLS))
|
|
|
|
|
|
class vmmMigrateDialog(vmmGObjectUI):
|
|
@@ -313,7 +313,7 @@ class vmmMigrateDialog(vmmGObjectUI):
|
|
model.clear()
|
|
|
|
rows = []
|
|
- for conn in self._conns.values():
|
|
+ for conn in list(self._conns.values()):
|
|
rows.append(self._build_dest_row(conn))
|
|
|
|
if not any([row[COL_CAN_MIGRATE] for row in rows]):
|
|
Index: virt-manager-1.5.0/virtManager/connect.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/connect.py
|
|
+++ virt-manager-1.5.0/virtManager/connect.py
|
|
@@ -22,7 +22,7 @@ import glob
|
|
import os
|
|
import logging
|
|
import socket
|
|
-import urllib
|
|
+import urllib.request, urllib.parse, urllib.error
|
|
|
|
from gi.repository import Gio
|
|
from gi.repository import GObject
|
|
@@ -37,11 +37,11 @@ HV_LXC,
|
|
HV_QEMU_SESSION,
|
|
HV_BHYVE,
|
|
HV_VZ,
|
|
-HV_CUSTOM) = range(7)
|
|
+HV_CUSTOM) = list(range(7))
|
|
|
|
(CONN_SSH,
|
|
CONN_TCP,
|
|
-CONN_TLS) = range(3)
|
|
+CONN_TLS) = list(range(3))
|
|
|
|
|
|
def current_user():
|
|
@@ -409,7 +409,7 @@ class vmmConnect(vmmGObjectUI):
|
|
|
|
addrstr = ""
|
|
if user:
|
|
- addrstr += urllib.quote(user) + "@"
|
|
+ addrstr += urllib.parse.quote(user) + "@"
|
|
|
|
if host.count(":") > 1:
|
|
host = "[%s]" % host
|
|
@@ -467,7 +467,7 @@ class vmmConnect(vmmGObjectUI):
|
|
if host.startswith("linux-"):
|
|
tmphost = host[6:]
|
|
try:
|
|
- long(tmphost)
|
|
+ int(tmphost)
|
|
host = ""
|
|
except ValueError:
|
|
pass
|
|
Index: virt-manager-1.5.0/virtManager/storagelist.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/storagelist.py
|
|
+++ virt-manager-1.5.0/virtManager/storagelist.py
|
|
@@ -36,7 +36,7 @@ from .createvol import vmmCreateVolume
|
|
EDIT_POOL_IDS = (
|
|
EDIT_POOL_NAME,
|
|
EDIT_POOL_AUTOSTART,
|
|
-) = range(2)
|
|
+) = list(range(2))
|
|
|
|
VOL_NUM_COLUMNS = 7
|
|
(VOL_COLUMN_KEY,
|
|
@@ -45,13 +45,13 @@ VOL_NUM_COLUMNS = 7
|
|
VOL_COLUMN_SIZESTR,
|
|
VOL_COLUMN_FORMAT,
|
|
VOL_COLUMN_INUSEBY,
|
|
- VOL_COLUMN_SENSITIVE) = range(VOL_NUM_COLUMNS)
|
|
+ VOL_COLUMN_SENSITIVE) = list(range(VOL_NUM_COLUMNS))
|
|
|
|
POOL_NUM_COLUMNS = 4
|
|
(POOL_COLUMN_CONNKEY,
|
|
POOL_COLUMN_LABEL,
|
|
POOL_COLUMN_ISACTIVE,
|
|
- POOL_COLUMN_PERCENT) = range(POOL_NUM_COLUMNS)
|
|
+ POOL_COLUMN_PERCENT) = list(range(POOL_NUM_COLUMNS))
|
|
|
|
ICON_RUNNING = "state_running"
|
|
ICON_SHUTOFF = "state_shutoff"
|
|
Index: virt-manager-1.5.0/virtManager/createnet.py
|
|
===================================================================
|
|
--- virt-manager-1.5.0.orig/virtManager/createnet.py
|
|
+++ virt-manager-1.5.0/virtManager/createnet.py
|
|
@@ -35,7 +35,7 @@ from .baseclass import vmmGObjectUI
|
|
(PAGE_NAME,
|
|
PAGE_IPV4,
|
|
PAGE_IPV6,
|
|
-PAGE_MISC) = range(4)
|
|
+PAGE_MISC) = list(range(4))
|
|
|
|
PAGE_MAX = PAGE_MISC
|
|
|