1
0
mirror of https://github.com/systemd/systemd.git synced 2025-01-05 13:18:06 +03:00

meson,ukify: hook up ukify, add --version option

The option is added because we have a similar one for kernel-install. This
program requires python, and some people might want to skip it because of this.

The tool is installed in /usr/lib/systemd for now, since the interface might
change.

A template file is used, but there is no .in suffix.
The problem is that we'll later want to import the file as a module
for tests, but recent Python versions make it annoyingly hard to import
a module from a file without a .py suffix. imp.load_sources() works, but it
is deprecated and throws warnings.
importlib.machinery.SourceFileLoader().load_module() works, but is also
deprecated. And the documented replacements are a maze of twisted little
callbacks that result in an empty module.
So let's take the easy way out, and skip the suffix which makes it easy
to import the template as a module after adding the directory to sys.path.
This commit is contained in:
Zbigniew Jędrzejewski-Szmek 2022-11-16 15:52:47 +01:00
parent f4780cbe30
commit 30ec2eaef5
3 changed files with 31 additions and 0 deletions

View File

@ -712,6 +712,17 @@ if run_command(python, '-c', 'import jinja2', check : false).returncode() != 0
error('python3 jinja2 missing') error('python3 jinja2 missing')
endif endif
python_310 = run_command(python, '-c',
'import sys; sys.exit(0 if sys.version_info >= (3,10) else 1)',
check : false).returncode() == 0
if get_option('ukify') == 'auto'
want_ukify = python_310
elif get_option('ukify') == 'true' and not python310
error('ukify requires Python >= 3.10')
else
want_ukify = get_option('ukify') == 'true'
endif
############################################################ ############################################################
gperf = find_program('gperf') gperf = find_program('gperf')
@ -3991,6 +4002,18 @@ if want_tests != 'false' and want_kernel_install
args : [exe.full_path(), loaderentry_install]) args : [exe.full_path(), loaderentry_install])
endif endif
if want_ukify
exe = custom_target(
'ukify',
input : 'src/ukify/ukify.py',
output : 'ukify',
command : [jinja2_cmdline, '@INPUT@', '@OUTPUT@'],
install : true,
install_mode : 'rwxr-xr-x',
install_dir : rootlibexecdir)
public_programs += exe
endif
############################################################ ############################################################
runtest_env = custom_target( runtest_env = custom_target(

View File

@ -501,6 +501,8 @@ option('llvm-fuzz', type : 'boolean', value : false,
description : 'build against LLVM libFuzzer') description : 'build against LLVM libFuzzer')
option('kernel-install', type: 'boolean', value: true, option('kernel-install', type: 'boolean', value: true,
description : 'install kernel-install and associated files') description : 'install kernel-install and associated files')
option('ukify', type : 'combo', choices : ['auto', 'true', 'false'],
description : 'install ukify')
option('analyze', type: 'boolean', value: true, option('analyze', type: 'boolean', value: true,
description : 'install systemd-analyze') description : 'install systemd-analyze')

View File

@ -22,6 +22,8 @@ import typing
import pefile import pefile
__version__ = '{{GIT_VERSION}}'
EFI_ARCH_MAP = { EFI_ARCH_MAP = {
# host_arch glob : [efi_arch, 32_bit_efi_arch if mixed mode is supported] # host_arch glob : [efi_arch, 32_bit_efi_arch if mixed mode is supported]
'x86_64' : ['x64', 'ia32'], 'x86_64' : ['x64', 'ia32'],
@ -519,6 +521,10 @@ usage: ukify [options…] linux initrd
action=argparse.BooleanOptionalAction, action=argparse.BooleanOptionalAction,
help='print systemd-measure output for the UKI') help='print systemd-measure output for the UKI')
p.add_argument('--version',
action='version',
version=f'ukify {__version__}')
opts = p.parse_args(args) opts = p.parse_args(args)
if opts.cmdline and opts.cmdline.startswith('@'): if opts.cmdline and opts.cmdline.startswith('@'):