mount_setattr.2: Further tweaks after feedback from Christian Brauner
[man-pages.git] / man3 / getttyent.3
blobc9fbe7c70045f2fccc1f416db0cf6d10fd2b40de
1 .\"  Copyright 2002 walter harms (walter.harms@informatik.uni-oldenburg.de)
2 .\"
3 .\" %%%LICENSE_START(GPL_NOVERSION_ONELINE)
4 .\" Distributed under GPL
5 .\" %%%LICENSE_END
6 .\"
7 .TH GETTTYENT 3 2021-03-22  "GNU" "Linux Programmer's Manual"
8 .SH NAME
9 getttyent, getttynam, setttyent, endttyent \- get ttys file entry
10 .SH SYNOPSIS
11 .nf
12 .B "#include <ttyent.h>"
13 .PP
14 .B "struct ttyent *getttyent(void);"
15 .BI "struct ttyent *getttynam(const char *" name );
16 .PP
17 .B "int setttyent(void);"
18 .B "int endttyent(void);"
19 .fi
20 .SH DESCRIPTION
21 These functions provide an interface to the file
22 .B _PATH_TTYS
23 (e.g.,
24 .IR /etc/ttys ).
25 .PP
26 The function
27 .BR setttyent ()
28 opens the file or rewinds it if already open.
29 .PP
30 The function
31 .BR endttyent ()
32 closes the file.
33 .PP
34 The function
35 .BR getttynam ()
36 searches for a given terminal name in the file.
37 It returns a pointer to a
38 .I ttyent
39 structure (description below).
40 .PP
41 The function
42 .BR getttyent ()
43 opens the file
44 .B _PATH_TTYS
45 (if necessary) and returns the first entry.
46 If the file is already open, the next entry.
47 The
48 .I ttyent
49 structure has the form:
50 .PP
51 .in +4n
52 .EX
53 struct ttyent {
54     char *ty_name;     /* terminal device name */
55     char *ty_getty;    /* command to execute, usually getty */
56     char *ty_type;     /* terminal type for termcap */
57     int   ty_status;   /* status flags */
58     char *ty_window;   /* command to start up window manager */
59     char *ty_comment;  /* comment field */
61 .EE
62 .in
63 .PP
64 .I ty_status
65 can be:
66 .PP
67 .in +4n
68 .EX
69 #define TTY_ON     0x01  /* enable logins (start ty_getty program) */
70 #define TTY_SECURE 0x02  /* allow UID 0 to login */
71 .EE
72 .in
73 .SH ATTRIBUTES
74 For an explanation of the terms used in this section, see
75 .BR attributes (7).
76 .ad l
77 .nh
78 .TS
79 allbox;
80 lbx lb lb
81 l l l.
82 Interface       Attribute       Value
84 .BR getttyent (),
85 .BR setttyent (),
86 .BR endttyent (),
87 .BR getttynam ()
88 T}      Thread safety   MT-Unsafe race:ttyent
89 .TE
90 .hy
91 .ad
92 .sp 1
93 .SH CONFORMING TO
94 Not in POSIX.1.
95 Present on the BSDs, and perhaps other systems.
96 .SH NOTES
97 Under Linux, the file
98 .IR /etc/ttys ,
99 and the functions described above, are not used.
100 .SH SEE ALSO
101 .BR ttyname (3),
102 .BR ttyslot (3)