login: move proctitle code to login.c

The functions are used only by login(1), let's keep the code in
login.c only.

Signed-off-by: Karel Zak <kzak@redhat.com>
This commit is contained in:
Karel Zak 2020-10-06 15:13:29 +02:00
parent 3836cd2d21
commit b21d741c21
5 changed files with 64 additions and 88 deletions

View File

@ -57,7 +57,6 @@ dist_noinst_HEADERS += \
include/rpmatch.h \
include/sha1.h \
include/signames.h \
include/setproctitle.h \
include/statfs_magic.h \
include/strutils.h \
include/strv.h \

View File

@ -1,7 +0,0 @@
#ifndef UTIL_LINUX_SETPROCTITLE_H
#define UTIL_LINUX_SETPROCTITLE_H
extern void initproctitle (int argc, char **argv);
extern void setproctitle (const char *prog, const char *txt);
#endif

View File

@ -31,7 +31,6 @@ libcommon_la_SOURCES = \
lib/procutils.c \
lib/pwdutils.c \
lib/randutils.c \
lib/setproctitle.c \
lib/strutils.c \
lib/timeutils.c \
lib/ttyutils.c \

View File

@ -1,75 +0,0 @@
/*
* set process title for ps (from sendmail)
*
* Clobbers argv of our main procedure so ps(1) will display the title.
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdarg.h>
#include "setproctitle.h"
#ifndef SPT_BUFSIZE
# define SPT_BUFSIZE 2048
#endif
extern char **environ;
static char **argv0;
static size_t argv_lth;
void initproctitle (int argc, char **argv)
{
int i;
char **envp = environ;
/*
* Move the environment so we can reuse the memory.
* (Code borrowed from sendmail.)
* WARNING: ugly assumptions on memory layout here;
* if this ever causes problems, #undef DO_PS_FIDDLING
*/
for (i = 0; envp[i] != NULL; i++)
continue;
environ = malloc(sizeof(char *) * (i + 1));
if (environ == NULL)
return;
for (i = 0; envp[i] != NULL; i++)
if ((environ[i] = strdup(envp[i])) == NULL)
return;
environ[i] = NULL;
if (i > 0)
argv_lth = envp[i-1] + strlen(envp[i-1]) - argv[0];
else
argv_lth = argv[argc-1] + strlen(argv[argc-1]) - argv[0];
if (argv_lth > 1)
argv0 = argv;
}
void setproctitle (const char *prog, const char *txt)
{
size_t i;
char buf[SPT_BUFSIZE];
if (!argv0)
return;
if (strlen(prog) + strlen(txt) + 5 > SPT_BUFSIZE)
return;
sprintf(buf, "%s -- %s", prog, txt);
i = strlen(buf);
if (i > argv_lth - 2) {
i = argv_lth - 2;
buf[i] = '\0';
}
memset(argv0[0], '\0', argv_lth); /* clear the memory area */
strcpy(argv0[0], buf);
argv0[1] = NULL;
}

View File

@ -68,7 +68,6 @@
#endif
#include "c.h"
#include "setproctitle.h"
#include "pathnames.h"
#include "strutils.h"
#include "nls.h"
@ -94,6 +93,13 @@
# define TTY_MODE 0600
#endif
#ifndef SPT_BUFSIZE
# define SPT_BUFSIZE 2048
#endif
static char **argv0;
static size_t argv_lth;
#define TTYGRPNAME "tty" /* name of group to own ttys */
#define VCS_PATH_MAX 64
@ -166,7 +172,6 @@ static int is_consoletty(int fd)
}
#endif
/*
* Robert Ambrose writes:
* A couple of my users have a problem with login processes hanging around
@ -226,6 +231,61 @@ static void __attribute__ ((__noreturn__)) sleepexit(int eval)
exit(eval);
}
static void process_title_init (int argc, char **argv)
{
int i;
char **envp = environ;
/*
* Move the environment so we can reuse the memory.
* (Code borrowed from sendmail.)
* WARNING: ugly assumptions on memory layout here;
* if this ever causes problems, #undef DO_PS_FIDDLING
*/
for (i = 0; envp[i] != NULL; i++)
continue;
environ = malloc(sizeof(char *) * (i + 1));
if (environ == NULL)
return;
for (i = 0; envp[i] != NULL; i++)
if ((environ[i] = strdup(envp[i])) == NULL)
return;
environ[i] = NULL;
if (i > 0)
argv_lth = envp[i-1] + strlen(envp[i-1]) - argv[0];
else
argv_lth = argv[argc-1] + strlen(argv[argc-1]) - argv[0];
if (argv_lth > 1)
argv0 = argv;
}
static void process_title_update (const char *prog, const char *txt)
{
size_t i;
char buf[SPT_BUFSIZE];
if (!argv0)
return;
if (strlen(prog) + strlen(txt) + 5 > SPT_BUFSIZE)
return;
sprintf(buf, "%s -- %s", prog, txt);
i = strlen(buf);
if (i > argv_lth - 2) {
i = argv_lth - 2;
buf[i] = '\0';
}
memset(argv0[0], '\0', argv_lth); /* clear the memory area */
strcpy(argv0[0], buf);
argv0[1] = NULL;
}
static const char *get_thishost(struct login_context *cxt, const char **domain)
{
if (!cxt->thishost) {
@ -1245,7 +1305,7 @@ int main(int argc, char **argv)
signal(SIGINT, SIG_IGN);
setpriority(PRIO_PROCESS, 0, 0);
initproctitle(argc, argv);
process_title_init(argc, argv);
while ((c = getopt_long(argc, argv, "fHh:pV", longopts, NULL)) != -1)
switch (c) {
@ -1375,7 +1435,7 @@ int main(int argc, char **argv)
init_environ(&cxt); /* init $HOME, $TERM ... */
setproctitle("login", cxt.username);
process_title_update("login", cxt.username);
log_syslog(&cxt);