+++ /dev/null
-/*
- * 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;
-}
#endif
#include "c.h"
-#include "setproctitle.h"
#include "pathnames.h"
#include "strutils.h"
#include "nls.h"
# 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
}
#endif
-
/*
* Robert Ambrose writes:
* A couple of my users have a problem with login processes hanging around
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) {
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) {
init_environ(&cxt); /* init $HOME, $TERM ... */
- setproctitle("login", cxt.username);
+ process_title_update("login", cxt.username);
log_syslog(&cxt);