mirror of
https://github.com/xcat2/confluent.git
synced 2025-01-28 03:48:35 +00:00
Fix kernel selection on pack
Make a specialized sort for kernel versions to more reliably identify the latest version.
This commit is contained in:
parent
065d0585ea
commit
8ab6fef632
@ -453,23 +453,36 @@ class ElHandler(OsHandler):
|
||||
subprocess.check_call(['yum'] + self.yumargs)
|
||||
|
||||
|
||||
def naturalize_string(key):
|
||||
def versionize_string(key):
|
||||
"""Analyzes string in a human way to enable natural sort
|
||||
|
||||
:param nodename: The node name to analyze
|
||||
:returns: A structure that can be consumed by 'sorted'
|
||||
"""
|
||||
return [int(text) if text.isdigit() else text.lower()
|
||||
for text in re.split(numregex, key)]
|
||||
versionlist = []
|
||||
patchlist = []
|
||||
addto = versionlist
|
||||
for part in re.split(numregex, key):
|
||||
if part in ('', '.'):
|
||||
continue
|
||||
if part == '-':
|
||||
addto = patchlist
|
||||
continue
|
||||
if not part.isdigit():
|
||||
break
|
||||
addto.append(int(part))
|
||||
return [versionlist, patchlist]
|
||||
|
||||
def natural_sort(iterable):
|
||||
|
||||
|
||||
def version_sort(iterable):
|
||||
"""Return a sort using natural sort if possible
|
||||
|
||||
:param iterable:
|
||||
:return:
|
||||
"""
|
||||
try:
|
||||
return sorted(iterable, key=naturalize_string)
|
||||
return sorted(iterable, key=versionize_string)
|
||||
except TypeError:
|
||||
# The natural sort attempt failed, fallback to ascii sort
|
||||
return sorted(iterable)
|
||||
@ -769,7 +782,7 @@ def pack_image(opts, args):
|
||||
if 'rescue' in kern:
|
||||
continue
|
||||
kvermap[get_kern_version(kern)] = kern
|
||||
mostrecent = list(natural_sort(kvermap))[-1]
|
||||
mostrecent = list(version_sort(kvermap))[-1]
|
||||
initrdname = os.path.join(args[0], 'boot/initramfs-{0}.img'.format(mostrecent))
|
||||
if not os.path.exists(initrdname):
|
||||
initrdname = os.path.join(args[0], 'boot/initrd-{0}'.format(mostrecent))
|
||||
|
Loading…
x
Reference in New Issue
Block a user