Merge remote-tracking branch 'origin/pr/183'

* origin/pr/183:
  Sorted kernels in VM settings
This commit is contained in:
Marek Marczykowski-Górecki 2019-06-10 03:49:13 +02:00
commit ccdddc6a7e
No known key found for this signature in database
GPG Key ID: 063938BA42CFA724

View File

@ -112,10 +112,30 @@ def prepare_choice(widget, holder, propname, choice, default,
return choice_list, idx return choice_list, idx
class KernelVersion: # pylint: disable=too-few-public-methods
# Cannot use distutils.version.LooseVersion, because it fails at handling
# versions that have no numbers in them
def __init__(self, string):
self.string = string
self.contents = []
if re.compile(r'\d+.*').match(string):
# the version begins with a number
self.contents = [int(x) for x in re.compile(r'\D+').split(string)]
def __lt__(self, other):
if not self.contents and not other.contents:
return self.string < other.string
if not self.contents or not other.contents:
return len(self.contents) < len(other.contents)
return self.contents < other.contents
def prepare_kernel_choice(widget, holder, propname, default, *args, **kwargs): def prepare_kernel_choice(widget, holder, propname, default, *args, **kwargs):
# TODO get from storage API (pool 'linux-kernel') (suggested by @marmarta) # TODO get from storage API (pool 'linux-kernel') (suggested by @marmarta)
return prepare_choice(widget, holder, propname, kernels = sorted(os.listdir('/var/lib/qubes/vm-kernels'),
os.listdir('/var/lib/qubes/vm-kernels'), default, *args, **kwargs) key=KernelVersion)
return prepare_choice(
widget, holder, propname, kernels, default, *args, **kwargs)
def prepare_label_choice(widget, holder, propname, default, *args, **kwargs): def prepare_label_choice(widget, holder, propname, default, *args, **kwargs):
try: try: