From: Zbigniew Jędrzejewski-Szmek Date: Wed, 22 Jun 2022 12:26:55 +0000 (+0200) Subject: udevadm info: implement --no-pager X-Git-Tag: v252-rc1~784^2~1 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=b6ec23a01aa12d44722771f48b0b32d6a40a9dad;p=thirdparty%2Fsystemd.git udevadm info: implement --no-pager --- diff --git a/man/udevadm.xml b/man/udevadm.xml index 3a9b133d304..ba80e623829 100644 --- a/man/udevadm.xml +++ b/man/udevadm.xml @@ -218,6 +218,7 @@ + The generated output shows the current device database entry in a terse format. Each line shown diff --git a/src/udev/udevadm-info.c b/src/udev/udevadm-info.c index d76dda95f16..b9af7769dad 100644 --- a/src/udev/udevadm-info.c +++ b/src/udev/udevadm-info.c @@ -51,6 +51,7 @@ static bool arg_export = false; static bool arg_value = false; static const char *arg_export_prefix = NULL; static usec_t arg_wait_for_initialization_timeout = 0; +PagerFlags arg_pager_flags = 0; /* Put a limit on --tree descent level to not exhaust our stack */ #define TREE_DEPTH_MAX 64 @@ -496,7 +497,8 @@ static int help(void) { " -e --export-db Export the content of the udev database\n" " -c --cleanup-db Clean up the udev database\n" " -w --wait-for-initialization[=SECONDS]\n" - " Wait for device to be initialized\n", + " Wait for device to be initialized\n" + " --no-pager Do not pipe output into a pager\n", program_invocation_short_name); return 0; @@ -667,6 +669,7 @@ int info_main(int argc, char *argv[], void *userdata) { enum { ARG_PROPERTY = 0x100, ARG_VALUE, + ARG_NO_PAGER, }; static const struct option options[] = { @@ -686,6 +689,7 @@ int info_main(int argc, char *argv[], void *userdata) { { "value", no_argument, NULL, ARG_VALUE }, { "version", no_argument, NULL, 'V' }, { "wait-for-initialization", optional_argument, NULL, 'w' }, + { "no-pager", no_argument, NULL, ARG_NO_PAGER }, {} }; @@ -779,6 +783,9 @@ int info_main(int argc, char *argv[], void *userdata) { return print_version(); case 'h': return help(); + case ARG_NO_PAGER: + arg_pager_flags |= PAGER_DISABLE; + break; case '?': return -EINVAL; default: @@ -810,7 +817,7 @@ int info_main(int argc, char *argv[], void *userdata) { if (strv_isempty(devices)) { assert(action == ACTION_TREE); - pager_open(0); + pager_open(arg_pager_flags); return print_tree(NULL); }