From 6926725e0210923e9eb9e3f365c027d4b6e96c89 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?= Date: Wed, 10 May 2017 01:29:10 +0200 Subject: [PATCH] Fixes for devices API See comments in #98 --- qubes/devices.py | 16 ++++------------ 1 file changed, 4 insertions(+), 12 deletions(-) diff --git a/qubes/devices.py b/qubes/devices.py index bd5f885d..0ee01133 100644 --- a/qubes/devices.py +++ b/qubes/devices.py @@ -223,11 +223,11 @@ class DeviceCollection(object): persistent=persistent) result = [] for dev, options in devices: - if dev in self._set and persistent is False: + if dev in self._set and not persistent: continue elif dev in self._set: result.append(self._set.get(dev)) - elif dev not in self._set and persistent is True: + elif dev not in self._set and persistent: continue else: result.append( @@ -374,20 +374,12 @@ class PersistentCollection(object): del self._dict[key] def __contains__(self, device) -> bool: - vm = device.backend_domain - ident = device.ident - key = (vm, ident) - return key in self._dict + return (device.backend_domain, device.ident) in self._dict def get(self, device: DeviceInfo) -> DeviceAssignment: ''' Returns the corresponding `qubes.devices.DeviceAssignment` for the device. ''' - vm = device.backend_domain - ident = device.ident - key = (vm, ident) - if key not in self._dict: - raise KeyError - return self._dict[key] + return self._dict[(device.backend_domain, device.ident)] def __iter__(self): return self._dict.values().__iter__()