8354 sync regcomp(3C) with upstream (fix make catalog)
[unleashed/tickless.git] / usr / src / lib / libast / common / man / fmt.3
blobdbe1aab2ecb4b11dd3f84431b0ac9b904834acb9
1 .fp 5 CW
2 .de Af
3 .ds ;G \\*(;G\\f\\$1\\$3\\f\\$2
4 .if !\a\\$4\a\a .Af \\$2 \\$1 "\\$4" "\\$5" "\\$6" "\\$7" "\\$8" "\\$9"
5 ..
6 .de aF
7 .ie \a\\$3\a\a .ft \\$1
8 .el \{\
9 .ds ;G \&
10 .nr ;G \\n(.f
11 .Af "\\$1" "\\$2" "\\$3" "\\$4" "\\$5" "\\$6" "\\$7" "\\$8" "\\$9"
12 \\*(;G
13 .ft \\n(;G \}
15 .de L
16 .aF 5 \\n(.f "\\$1" "\\$2" "\\$3" "\\$4" "\\$5" "\\$6" "\\$7"
18 .de LR
19 .aF 5 1 "\\$1" "\\$2" "\\$3" "\\$4" "\\$5" "\\$6" "\\$7"
21 .de RL
22 .aF 1 5 "\\$1" "\\$2" "\\$3" "\\$4" "\\$5" "\\$6" "\\$7"
24 .de EX          \" start example
25 .ta 1i 2i 3i 4i 5i 6i
26 .PP
27 .RS 
28 .PD 0
29 .ft 5
30 .nf
32 .de EE          \" end example
33 .fi
34 .ft
35 .PD
36 .RE
37 .PP
39 .TH FMT 3
40 .SH NAME
41 fmt \- string formatting routines
42 .SH SYNOPSIS
43 .EX
44 #include <ast.h>
45 #include <ls.h>
47 char*      fmtbase(long \fInumber\fP, int \fIbase\fP, int \fIprefix\fP);
48 char*      fmtdev(struct stat* \fIst\fP);
49 char*      fmtelapsed(unsigned long \fIcount\fP, int \fIpersec\fP)
50 char*      fmterror(int \fIerrno\fP);
51 char*      fmtesc(const char* \fIstring\fP);
52 char*      fmtfs(struct stat* \fIst\fP);
53 char*      fmtgid(int \fIgid\fP);
54 char*      fmtmatch(const char* \fIre\fP);
55 char*      fmtmode(int \fImode\fP, int \fIexternal\fP);
56 char*      fmtperm(int \fIperm\fP);
57 char*      fmtre(const char* \fIpattern\fP);
58 char*      fmtsignal(int \fIsig\fP);
59 char*      fmttime(const char* \fIformat\fP, time_t \fItm\fP);
60 char*      fmtuid(int \fIuid\fP);
61 .EE
62 .SH DESCRIPTION
63 These routines return a pointer to a formatted string for various numeric
64 and string entities.
65 Some routines may cache information to speed up the next call.
66 Most of the routines return a pointer to a private buffer, the
67 contents of which are overwritten on the next call to that routine.
68 Most
69 .L fmt
70 routines have a corresponding
71 .L str
72 routine that converts in the other direction.
73 There is nothing spectacular about this collection other than that
74 it provides a single place where the exact format is spelled out.
75 .PP
76 .L fmtbase
77 formats a base
78 .I base
79 representation for
80 .IR number .
82 .I "prefix != 0"
83 then the base prefix is included in the formatted string.
85 .I "number == 0"
87 .I "base == 0"
88 then the output is signed base 10.
89 .PP
90 .L fmtdev
91 returns the device handle name specified by the
92 .L stat
93 structure
94 .IR st .
95 This is the device information displayed by
96 .IR "ls \-l" .
97 .PP
98 .L fmtelapsed
99 formats the elapsed time for
100 .I (count/persec)
101 seconds.
102 The two largest time units are used, limiting the return value length
103 to at most 6 characters.
104 The units are:
107 .B s
108 seconds
110 .B m
111 minutes
113 .B h
114 hours
116 .B days
118 .B weeks
120 .B M
121 months
123 .B Y
124 years
126 .B S
127 scores
130 .L fmterror
131 returns the system error message text for the error number
132 .IR errno .
134 .L fmtesc
135 formats non-ASCII characters in
136 .I string
137 into C-style
138 .B \e
139 sequences.
140 These sequences are understood by
141 .L chresc
143 .LR chrtoi .
145 .L fmtfs
146 returns the file system type name corresponding to the
147 .L stat
148 structure
149 .IR st .
151 .L fmtgid
152 returns the group name for
153 .IR gid .
155 .L fmtmatch
156 returns the
157 .L strmatch
158 equivalent pattern for the regular expression pattern
159 .IR re .
160 0 is returned for invalid
161 .IR re .
163 .L fmtmode
164 returns the
165 .I "ls \-l"
166 mode string for the file mode bits in
167 .IR mode .
169 .I "external != 0"
170 then 
171 .I mode
173 .IR modecanon (3)
174 canonical.
176 .L fmtperm
177 returns the
178 .I chmod
179 permission string for the permission bits in
180 .IR perm .
182 .L fmtre
183 returns the regular expression
184 equivalent pattern for the
185 .L strmatch
186 pattern
187 .IR pattern .
188 0 is returned for invalid
189 .IR pattern .
191 .L fmtsignal
192 returns the signal name, sans
193 .LR SIG ,
194 for the signal number 
195 .IR sig .
197 .I "sig < 0"
198 then the description text for
199 .I \-sig
200 is returned.
202 .L fmttime
203 returns the results of
204 .I "tmfmt(buf,sizeof(buf),format,tm)"
205 in the private buffer
206 .IR buf .
208 .L fmtuid
209 returns the user name for
210 .IR uid .
211 .SH "SEE ALSO"
212 modecanon(3),
213 str(3)