Bernhard Reutner-Fischer schrieb:
> text data bss dec hex filename
> 81 0 0 81 51 miscutils/wall.o
>
> Signed-off-by: Bernhard Reutner-Fischer <[email protected]>
> ---
> include/applets.h | 1 +
> include/usage.h | 8 ++++++++
> miscutils/Config.in | 6 ++++++
> miscutils/Kbuild | 1 +
> miscutils/wall.c | 37 +++++++++++++++++++++++++++++++++++++
> scripts/defconfig | 1 +
> 6 files changed, 54 insertions(+), 0 deletions(-)
> create mode 100644 miscutils/wall.c
>
> diff --git a/include/applets.h b/include/applets.h
> index 134f21e..9683f1e 100644
> --- a/include/applets.h
> +++ b/include/applets.h
> @@ -417,6 +417,7 @@ IF_VCONFIG(APPLET(vconfig, _BB_DIR_SBIN, _BB_SUID_DROP))
> IF_VI(APPLET(vi, _BB_DIR_BIN, _BB_SUID_DROP))
> IF_VLOCK(APPLET(vlock, _BB_DIR_USR_BIN, _BB_SUID_REQUIRE))
> IF_VOLNAME(APPLET(volname, _BB_DIR_USR_BIN, _BB_SUID_DROP))
> +IF_WALL(APPLET(wall, _BB_DIR_USR_BIN, _BB_SUID_REQUIRE))
> IF_WATCH(APPLET(watch, _BB_DIR_BIN, _BB_SUID_DROP))
> IF_WATCHDOG(APPLET(watchdog, _BB_DIR_SBIN, _BB_SUID_DROP))
> IF_WC(APPLET(wc, _BB_DIR_USR_BIN, _BB_SUID_DROP))
> diff --git a/include/usage.h b/include/usage.h
> index d03ec22..2cc548e 100644
> --- a/include/usage.h
> +++ b/include/usage.h
> @@ -4943,6 +4943,14 @@
> #define volname_full_usage "\n\n" \
> "Show CD volume name of the DEVICE (default /dev/cdrom)"
>
> +#define wall_trivial_usage \
> + "[file]"
> +#define wall_full_usage "\n\n" \
> + "Write content of file or standard-input to all logged-in users"
> +#define wall_sample_usage \
> + "echo foo | wall\n" \
> + "wall ./mymessage"
> +
> #define watch_trivial_usage \
> "[-n seconds] [-t] PROG [ARGS]"
> #define watch_full_usage "\n\n" \
> diff --git a/miscutils/Config.in b/miscutils/Config.in
> index 9b80488..842f7f9 100644
> --- a/miscutils/Config.in
> +++ b/miscutils/Config.in
> @@ -612,6 +612,12 @@ config VOLNAME
> help
> Prints a CD-ROM volume name.
>
> +config WALL
> + bool "wall"
> + default n
> + help
> + Write a message to all users that are logged in.
> +
> config WATCHDOG
> bool "watchdog"
> default n
> diff --git a/miscutils/Kbuild b/miscutils/Kbuild
> index d88cb39..22a9adb 100644
> --- a/miscutils/Kbuild
> +++ b/miscutils/Kbuild
> @@ -42,4 +42,5 @@ lib-$(CONFIG_TIME) += time.o
> lib-$(CONFIG_TIMEOUT) += timeout.o
> lib-$(CONFIG_TTYSIZE) += ttysize.o
> lib-$(CONFIG_VOLNAME) += volname.o
> +lib-$(CONFIG_WALL) += wall.o
> lib-$(CONFIG_WATCHDOG) += watchdog.o
> diff --git a/miscutils/wall.c b/miscutils/wall.c
> new file mode 100644
> index 0000000..ecd3484
> --- /dev/null
> +++ b/miscutils/wall.c
> @@ -0,0 +1,37 @@
> +/* vi: set sw=4 ts=4: */
> +/*
> + * wall - write a message to all logged-in users
> + * Copyright (c) 2009 Bernhard Reutner-Fischer
> + *
> + * Licensed under GPLv2 or later, see file LICENSE in this tarball for
> details.
> + */
> +
> +#include "libbb.h"
> +#include <utmp.h>
> +
> +int wall_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
> +int wall_main(int argc UNUSED_PARAM, char **argv)
> +{
> + struct utmp *ut;
> + char *msg;
> + int fd = argv[1] ? xopen(argv[1], O_RDONLY) : STDIN_FILENO;
> +
i did not try; but what will happen if argc==1 ?
argv[1] should be undefined.
perhaps this is more save
(argc > 1) ? xopen(argv[1], O_RDONLY) : STDIN_FILENO;
re,
wh
> + msg = xmalloc_read(fd, NULL);
> + if (ENABLE_FEATURE_CLEAN_UP && argv[1])
> + close(fd);
> + setutent();
> + while ((ut = getutent()) != NULL) {
> + char *line;
> + if (ut->ut_type != USER_PROCESS)
> + continue;
> + line = concat_path_file("/dev", ut->ut_line);
> + xopen_xwrite_close(line, msg);
> + if (ENABLE_FEATURE_CLEAN_UP)
> + free(line);
> + }
> + if (ENABLE_FEATURE_CLEAN_UP) {
> + endutent();
> + free(msg);
> + }
> + return EXIT_SUCCESS;
> +}
> diff --git a/scripts/defconfig b/scripts/defconfig
> index 797f275..f8a92d4 100644
> --- a/scripts/defconfig
> +++ b/scripts/defconfig
> @@ -638,6 +638,7 @@ CONFIG_TIME=y
> CONFIG_TIMEOUT=y
> CONFIG_TTYSIZE=y
> CONFIG_VOLNAME=y
> +CONFIG_WALL=y
> CONFIG_WATCHDOG=y
>
> #
_______________________________________________
busybox mailing list
[email protected]
http://lists.busybox.net/mailman/listinfo/busybox