blob: cdd1d4b11835554b89e41199ed68db4aa28fcbfe (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
/*
* This file and its contents are supplied under the terms of the
* Common Development and Distribution License ("CDDL"), version 1.0.
* You may only use this file in accordance with the terms of version
* 1.0 of the CDDL.
*
* A full copy of the text of the CDDL should have accompanied this
* source. A copy of the CDDL is also available via the Internet at
* http://www.illumos.org/license/CDDL.
*/
/*
* Copyright 2019 Robert Mustacchi
*/
#include <unistd.h>
#include <err.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdlib.h>
#include <pwd.h>
#include <libgen.h>
#include <locale.h>
#include <libintl.h>
int
main(int argc, char *argv[])
{
char *name;
char uidbuf[32];
(void) setlocale(LC_ALL, "");
#if !defined(TEXT_DOMAIN)
#define TEXT_DOMAIN "SYS_TEST"
#endif
(void) textdomain(TEXT_DOMAIN);
if (argc != 1) {
warnx(gettext("illegal arguments"));
(void) fprintf(stderr, gettext("Usage: %s\n"),
basename(argv[0]));
return (1);
}
/*
* In some cases getlogin() can fail. The most common case is due to
* something like using script(1). Deal with that by falling back to the
* current user ID, which is as accurate as we can be. This is what the
* ksh93 version used to do.
*/
name = getlogin();
if (name == NULL) {
uid_t uid;
struct passwd *pass;
uid = getuid();
pass = getpwuid(uid);
if (pass != NULL) {
name = pass->pw_name;
} else {
(void) snprintf(uidbuf, sizeof (uidbuf), "%u", uid);
name = uidbuf;
}
}
if (printf("%s\n", name) == -1) {
err(EXIT_FAILURE, gettext("failed to write out login name"));
}
return (0);
}
|