Blame


1 058b0118 2005-01-03 devnull .TH ACME 4
2 058b0118 2005-01-03 devnull .SH NAME
3 058b0118 2005-01-03 devnull acme \- control files for text windows
4 058b0118 2005-01-03 devnull .SH SYNOPSIS
5 058b0118 2005-01-03 devnull .B acme
6 058b0118 2005-01-03 devnull [
7 058b0118 2005-01-03 devnull .B -f
8 058b0118 2005-01-03 devnull .I varfont
9 058b0118 2005-01-03 devnull ] [
10 058b0118 2005-01-03 devnull .B -F
11 058b0118 2005-01-03 devnull .I fixfont
12 058b0118 2005-01-03 devnull ]
13 058b0118 2005-01-03 devnull [
14 058b0118 2005-01-03 devnull .I file
15 058b0118 2005-01-03 devnull \&... ]
16 058b0118 2005-01-03 devnull .SH DESCRIPTION
17 058b0118 2005-01-03 devnull The text window system
18 058b0118 2005-01-03 devnull .IR acme (1)
19 058b0118 2005-01-03 devnull serves a variety of files for reading, writing, and controlling
20 058b0118 2005-01-03 devnull windows.
21 058b0118 2005-01-03 devnull Some of them are virtual versions of system files for dealing
22 058b0118 2005-01-03 devnull with the virtual console; others control operations
23 058b0118 2005-01-03 devnull of
24 058b0118 2005-01-03 devnull .I acme
25 058b0118 2005-01-03 devnull itself.
26 058b0118 2005-01-03 devnull When a command is run under
27 058b0118 2005-01-03 devnull .IR acme ,
28 058b0118 2005-01-03 devnull a directory holding these files is mounted on
29 058b0118 2005-01-03 devnull .B /mnt/acme
30 058b0118 2005-01-03 devnull (also bound to
31 058b0118 2005-01-03 devnull .BR /mnt/wsys )
32 058b0118 2005-01-03 devnull and also
33 058b0118 2005-01-03 devnull .BR /dev ;
34 058b0118 2005-01-03 devnull the files mentioned here
35 058b0118 2005-01-03 devnull appear in both those directories.
36 058b0118 2005-01-03 devnull .PP
37 058b0118 2005-01-03 devnull Some of these files supply virtual versions of services available from the underlying
38 058b0118 2005-01-03 devnull environment, in particular the character terminal files in Plan 9's
39 058b0118 2005-01-03 devnull \fIcons\fR(3).
40 058b0118 2005-01-03 devnull (Unlike in Plan 9's \fIrio\fR(1),
41 058b0118 2005-01-03 devnull each command under
42 058b0118 2005-01-03 devnull .I acme
43 058b0118 2005-01-03 devnull sees the same set of files; there is not a distinct
44 058b0118 2005-01-03 devnull .B /dev/cons
45 058b0118 2005-01-03 devnull for each window.)
46 058b0118 2005-01-03 devnull Other files are unique to
47 058b0118 2005-01-03 devnull .IR acme .
48 058b0118 2005-01-03 devnull .TP
49 058b0118 2005-01-03 devnull .B acme
50 058b0118 2005-01-03 devnull is a subdirectory used by
51 058b0118 2005-01-03 devnull .B win
52 058b0118 2005-01-03 devnull (see
53 058b0118 2005-01-03 devnull .IR acme (1))
54 058b0118 2005-01-03 devnull as a mount point for the
55 058b0118 2005-01-03 devnull .I acme
56 058b0118 2005-01-03 devnull files associated with the window in which
57 058b0118 2005-01-03 devnull .B win
58 058b0118 2005-01-03 devnull is running.
59 058b0118 2005-01-03 devnull It has no specific function under
60 058b0118 2005-01-03 devnull .I acme
61 058b0118 2005-01-03 devnull itself.
62 058b0118 2005-01-03 devnull .TP
63 058b0118 2005-01-03 devnull .B cons
64 058b0118 2005-01-03 devnull is the standard and diagnostic output file for all commands
65 058b0118 2005-01-03 devnull run under
66 058b0118 2005-01-03 devnull .IR acme .
67 058b0118 2005-01-03 devnull (Input for commands is redirected to
68 058b0118 2005-01-03 devnull .BR /dev/null .)
69 058b0118 2005-01-03 devnull Text written to
70 058b0118 2005-01-03 devnull .B cons
71 058b0118 2005-01-03 devnull appears in a window labeled
72 058b0118 2005-01-03 devnull .IB dir /+Errors\f1,
73 058b0118 2005-01-03 devnull where
74 058b0118 2005-01-03 devnull .I dir
75 058b0118 2005-01-03 devnull is the directory in which the command
76 058b0118 2005-01-03 devnull was run.
77 058b0118 2005-01-03 devnull The window is created if necessary, but not until text is actually written.
78 058b0118 2005-01-03 devnull .TP
79 058b0118 2005-01-03 devnull .B consctl
80 058b0118 2005-01-03 devnull Is an empty unwritable file present only for compatibility; there is no way
81 058b0118 2005-01-03 devnull to turn off `echo', for example, under
82 058b0118 2005-01-03 devnull .IR acme .
83 058b0118 2005-01-03 devnull .TP
84 058b0118 2005-01-03 devnull .B index
85 058b0118 2005-01-03 devnull holds a sequence of lines of text, one per window. Each line has 5 decimal numbers,
86 058b0118 2005-01-03 devnull each formatted in 11 characters plus a blank\(emthe window ID;
87 058b0118 2005-01-03 devnull number of characters (runes) in the tag;
88 058b0118 2005-01-03 devnull number of characters in the body;
89 058b0118 2005-01-03 devnull a 1 if the window is a directory, 0 otherwise;
90 058b0118 2005-01-03 devnull and a 1 if the window is modified, 0
91 058b0118 2005-01-03 devnull otherwise\(emfollowed by the tag up to a newline if present.
92 058b0118 2005-01-03 devnull Thus at character position 5×12 starts the name of the window.
93 058b0118 2005-01-03 devnull If a file has multiple zeroxed windows open,
94 058b0118 2005-01-03 devnull only the most recently used will appear in the
95 058b0118 2005-01-03 devnull .B index
96 058b0118 2005-01-03 devnull file.
97 058b0118 2005-01-03 devnull .TP
98 058b0118 2005-01-03 devnull .B label
99 058b0118 2005-01-03 devnull is an empty file, writable without effect, present only for compatibility with
100 058b0118 2005-01-03 devnull .BR rio .
101 058b0118 2005-01-03 devnull .TP
102 058b0118 2005-01-03 devnull .B new
103 058b0118 2005-01-03 devnull A directory analogous to the numbered directories
104 058b0118 2005-01-03 devnull .RI ( q.v. ).
105 058b0118 2005-01-03 devnull Accessing any
106 058b0118 2005-01-03 devnull file in
107 058b0118 2005-01-03 devnull .B new
108 058b0118 2005-01-03 devnull creates a new window. Thus to cause text to appear in a new window,
109 058b0118 2005-01-03 devnull write it to
110 058b0118 2005-01-03 devnull .BR /dev/new/body .
111 058b0118 2005-01-03 devnull For more control, open
112 058b0118 2005-01-03 devnull .BR /dev/new/ctl
113 058b0118 2005-01-03 devnull and use the interface described below.
114 058b0118 2005-01-03 devnull .LP
115 058b0118 2005-01-03 devnull .PP
116 058b0118 2005-01-03 devnull Each
117 058b0118 2005-01-03 devnull .I acme
118 058b0118 2005-01-03 devnull window has associated a directory numbered by its ID.
119 058b0118 2005-01-03 devnull Window IDs are chosen sequentially and may be discovered by the
120 058b0118 2005-01-03 devnull .B ID
121 058b0118 2005-01-03 devnull command, by
122 058b0118 2005-01-03 devnull reading the
123 058b0118 2005-01-03 devnull .B ctl
124 058b0118 2005-01-03 devnull file, or
125 058b0118 2005-01-03 devnull indirectly through the
126 058b0118 2005-01-03 devnull .B index
127 058b0118 2005-01-03 devnull file. The files in the numbered directories are as follows.
128 058b0118 2005-01-03 devnull .TP
129 058b0118 2005-01-03 devnull .B addr
130 058b0118 2005-01-03 devnull may be written with any textual address (line number, regular expression, etc.),
131 058b0118 2005-01-03 devnull in the format understood by button 3 but without the initial colon, including compound addresses,
132 058b0118 2005-01-03 devnull to set the address for text accessed through the
133 058b0118 2005-01-03 devnull .B data
134 058b0118 2005-01-03 devnull file.
135 058b0118 2005-01-03 devnull When read, it returns the value of the address that would next be read
136 058b0118 2005-01-03 devnull or written through the
137 058b0118 2005-01-03 devnull .B data
138 058b0118 2005-01-03 devnull file, in the format
139 058b0118 2005-01-03 devnull .BI # m ,# n
140 058b0118 2005-01-03 devnull where
141 058b0118 2005-01-03 devnull .I m
142 058b0118 2005-01-03 devnull and
143 058b0118 2005-01-03 devnull .I n
144 058b0118 2005-01-03 devnull are character (not byte) offsets. If
145 058b0118 2005-01-03 devnull .I m
146 058b0118 2005-01-03 devnull and
147 058b0118 2005-01-03 devnull .I n
148 058b0118 2005-01-03 devnull are identical, the format is just
149 058b0118 2005-01-03 devnull .BI # m\f1.
150 058b0118 2005-01-03 devnull Thus a regular expression may be evaluated by writing it to
151 058b0118 2005-01-03 devnull .B addr
152 058b0118 2005-01-03 devnull and reading it back.
153 058b0118 2005-01-03 devnull The
154 058b0118 2005-01-03 devnull .B addr
155 058b0118 2005-01-03 devnull address has no effect on the user's selection of text.
156 058b0118 2005-01-03 devnull .TP
157 058b0118 2005-01-03 devnull .B body
158 058b0118 2005-01-03 devnull holds contents of the window body. It may be read at any byte offset.
159 058b0118 2005-01-03 devnull Text written to
160 058b0118 2005-01-03 devnull .B body
161 058b0118 2005-01-03 devnull is always appended; the file offset is ignored.
162 058b0118 2005-01-03 devnull .TP
163 058b0118 2005-01-03 devnull .B ctl
164 058b0118 2005-01-03 devnull may be read to recover the five numbers as held in the
165 058b0118 2005-01-03 devnull .B index
166 058b0118 2005-01-03 devnull file, described above, plus two more fields: the width of the
167 058b0118 2005-01-03 devnull window in pixels and the name of the font used in the window.
168 058b0118 2005-01-03 devnull Text messages may be written to
169 058b0118 2005-01-03 devnull .B ctl
170 058b0118 2005-01-03 devnull to affect the window.
171 058b0118 2005-01-03 devnull Each message is terminated by a newline and multiple
172 058b0118 2005-01-03 devnull messages may be sent in a single write.
173 058b0118 2005-01-03 devnull .RS .5i
174 058b0118 2005-01-03 devnull .TF limit=addr
175 058b0118 2005-01-03 devnull .TP
176 058b0118 2005-01-03 devnull .B addr=dot
177 058b0118 2005-01-03 devnull Set the
178 058b0118 2005-01-03 devnull .B addr
179 058b0118 2005-01-03 devnull address to that of the user's selected text in the window.
180 058b0118 2005-01-03 devnull .TP
181 058b0118 2005-01-03 devnull .B clean
182 058b0118 2005-01-03 devnull Mark the window clean as though it has just been written.
183 058b0118 2005-01-03 devnull .TP
184 058b0118 2005-01-03 devnull .B dirty
185 058b0118 2005-01-03 devnull Mark the window dirty, the opposite of clean.
186 058b0118 2005-01-03 devnull .TP
187 058b0118 2005-01-03 devnull .B cleartag
188 058b0118 2005-01-03 devnull Remove all text in the tag after the vertical bar.
189 058b0118 2005-01-03 devnull .TP
190 058b0118 2005-01-03 devnull .B del
191 058b0118 2005-01-03 devnull Equivalent to the
192 058b0118 2005-01-03 devnull .B Del
193 058b0118 2005-01-03 devnull interactive command.
194 058b0118 2005-01-03 devnull .TP
195 058b0118 2005-01-03 devnull .B delete
196 058b0118 2005-01-03 devnull Equivalent to the
197 058b0118 2005-01-03 devnull .B Delete
198 058b0118 2005-01-03 devnull interactive command.
199 058b0118 2005-01-03 devnull .TP
200 058b0118 2005-01-03 devnull .B dot=addr
201 058b0118 2005-01-03 devnull Set the user's selected text in the window to the text addressed by the
202 058b0118 2005-01-03 devnull .B addr
203 058b0118 2005-01-03 devnull address.
204 058b0118 2005-01-03 devnull .TP
205 058b0118 2005-01-03 devnull .BI dump " command
206 058b0118 2005-01-03 devnull Set the command string to recreate the window from a dump file.
207 058b0118 2005-01-03 devnull .TP
208 058b0118 2005-01-03 devnull .BI dumpdir " directory
209 058b0118 2005-01-03 devnull Set the directory in which to run the command to recreate the window from a dump file.
210 058b0118 2005-01-03 devnull .TP
211 058b0118 2005-01-03 devnull .B get
212 058b0118 2005-01-03 devnull Equivalent to the
213 058b0118 2005-01-03 devnull .B Get
214 058b0118 2005-01-03 devnull interactive command with no arguments; accepts no arguments.
215 058b0118 2005-01-03 devnull .TP
216 058b0118 2005-01-03 devnull .B limit=addr
217 058b0118 2005-01-03 devnull When the
218 058b0118 2005-01-03 devnull .B ctl
219 058b0118 2005-01-03 devnull file is first opened, regular expression context searches in
220 058b0118 2005-01-03 devnull .B addr
221 058b0118 2005-01-03 devnull addresses examine the whole file; this message restricts subsequent
222 058b0118 2005-01-03 devnull searches to the current
223 058b0118 2005-01-03 devnull .B addr
224 058b0118 2005-01-03 devnull address.
225 058b0118 2005-01-03 devnull .TP
226 058b0118 2005-01-03 devnull .B mark
227 058b0118 2005-01-03 devnull Cancel
228 058b0118 2005-01-03 devnull .BR nomark ,
229 058b0118 2005-01-03 devnull returning the window to the usual state wherein each modification to the
230 058b0118 2005-01-03 devnull body must be undone individually.
231 058b0118 2005-01-03 devnull .TP
232 058b0118 2005-01-03 devnull .BI name " name
233 058b0118 2005-01-03 devnull Set the name of the window to
234 058b0118 2005-01-03 devnull .IR name .
235 058b0118 2005-01-03 devnull .TP
236 058b0118 2005-01-03 devnull .B nomark
237 058b0118 2005-01-03 devnull Turn off automatic `marking' of changes, so a set of related changes
238 058b0118 2005-01-03 devnull may be undone in a single
239 058b0118 2005-01-03 devnull .B Undo
240 058b0118 2005-01-03 devnull interactive command.
241 058b0118 2005-01-03 devnull .TP
242 058b0118 2005-01-03 devnull .B noscroll
243 058b0118 2005-01-03 devnull Turn off automatic `scrolling' of the window to show text written to the body.
244 058b0118 2005-01-03 devnull .TP
245 058b0118 2005-01-03 devnull .B put
246 058b0118 2005-01-03 devnull Equivalent to the
247 058b0118 2005-01-03 devnull .B Put
248 058b0118 2005-01-03 devnull interactive command with no arguments; accepts no arguments.
249 058b0118 2005-01-03 devnull .TP
250 058b0118 2005-01-03 devnull .B scroll
251 058b0118 2005-01-03 devnull Cancel a
252 058b0118 2005-01-03 devnull .B noscroll
253 058b0118 2005-01-03 devnull message, returning the window to the default state wherein each write
254 058b0118 2005-01-03 devnull to the
255 058b0118 2005-01-03 devnull .B body
256 058b0118 2005-01-03 devnull file causes the window to `scroll' to display the new text.
257 058b0118 2005-01-03 devnull .TP
258 058b0118 2005-01-03 devnull .B show
259 058b0118 2005-01-03 devnull Guarantee at least some of the selected text is visible on the display.
260 058b0118 2005-01-03 devnull .RE
261 058b0118 2005-01-03 devnull .PD
262 058b0118 2005-01-03 devnull .TP
263 058b0118 2005-01-03 devnull .B data
264 058b0118 2005-01-03 devnull is used in conjunction with
265 058b0118 2005-01-03 devnull .B addr
266 058b0118 2005-01-03 devnull for random access to the contents of the body.
267 058b0118 2005-01-03 devnull The file offset is ignored when writing the
268 058b0118 2005-01-03 devnull .B data
269 058b0118 2005-01-03 devnull file; instead the location of the data to be read or written is determined by the state of the
270 058b0118 2005-01-03 devnull .B addr
271 058b0118 2005-01-03 devnull file.
272 058b0118 2005-01-03 devnull Text, which must contain only whole characters (no `partial runes'),
273 058b0118 2005-01-03 devnull written to
274 058b0118 2005-01-03 devnull .B data
275 058b0118 2005-01-03 devnull replaces the characters addressed by the
276 058b0118 2005-01-03 devnull .B addr
277 058b0118 2005-01-03 devnull file and sets the address to the null string at the end of the written text.
278 058b0118 2005-01-03 devnull A read from
279 058b0118 2005-01-03 devnull .B data
280 058b0118 2005-01-03 devnull returns as many whole characters as the read count will permit starting
281 058b0118 2005-01-03 devnull at the beginning of the
282 058b0118 2005-01-03 devnull .B addr
283 058b0118 2005-01-03 devnull address (the end of the address has no effect)
284 058b0118 2005-01-03 devnull and sets the address to the null string at the end of the returned
285 058b0118 2005-01-03 devnull characters.
286 058b0118 2005-01-03 devnull .TP
287 058b0118 2005-01-03 devnull .B event
288 058b0118 2005-01-03 devnull When a window's
289 058b0118 2005-01-03 devnull .B event
290 058b0118 2005-01-03 devnull file is open, changes to the window occur as always but the
291 058b0118 2005-01-03 devnull actions are also reported as
292 058b0118 2005-01-03 devnull messages to the reader of the file. Also, user actions with buttons 2 and 3
293 058b0118 2005-01-03 devnull (other than chorded
294 058b0118 2005-01-03 devnull .B Cut
295 058b0118 2005-01-03 devnull and
296 058b0118 2005-01-03 devnull .BR Paste ,
297 058b0118 2005-01-03 devnull which behave normally) have no immediate effect on the window;
298 058b0118 2005-01-03 devnull it is expected that the program reading the
299 058b0118 2005-01-03 devnull .B event
300 058b0118 2005-01-03 devnull file will interpret them.
301 058b0118 2005-01-03 devnull The messages have a fixed format:
302 058b0118 2005-01-03 devnull a character indicating the origin or cause of the action,
303 058b0118 2005-01-03 devnull a character indicating the type of the action,
304 058b0118 2005-01-03 devnull four free-format blank-terminated decimal numbers,
305 058b0118 2005-01-03 devnull optional text, and a newline.
306 058b0118 2005-01-03 devnull The first and second numbers are the character addresses of the action,
307 058b0118 2005-01-03 devnull the third is a flag,
308 058b0118 2005-01-03 devnull and the final is a count of the characters in the optional text, which
309 058b0118 2005-01-03 devnull may itself contain newlines.
310 058b0118 2005-01-03 devnull The origin characters are
311 058b0118 2005-01-03 devnull .B E
312 058b0118 2005-01-03 devnull for writes to the
313 058b0118 2005-01-03 devnull .B body
314 058b0118 2005-01-03 devnull or
315 058b0118 2005-01-03 devnull .B tag
316 058b0118 2005-01-03 devnull file,
317 058b0118 2005-01-03 devnull .B F
318 058b0118 2005-01-03 devnull for actions through the window's other files,
319 058b0118 2005-01-03 devnull .B K
320 058b0118 2005-01-03 devnull for the keyboard, and
321 058b0118 2005-01-03 devnull .B M
322 058b0118 2005-01-03 devnull for the mouse.
323 058b0118 2005-01-03 devnull The type characters are
324 058b0118 2005-01-03 devnull .B D
325 058b0118 2005-01-03 devnull for text deleted from the body,
326 058b0118 2005-01-03 devnull .B d
327 058b0118 2005-01-03 devnull for text deleted from the tag,
328 058b0118 2005-01-03 devnull .B I
329 058b0118 2005-01-03 devnull for text inserted to the body,
330 058b0118 2005-01-03 devnull .B i
331 058b0118 2005-01-03 devnull for text inserted to the tag,
332 058b0118 2005-01-03 devnull .B L
333 058b0118 2005-01-03 devnull for a button 3 action in the body,
334 058b0118 2005-01-03 devnull .B l
335 058b0118 2005-01-03 devnull for a button 3 action in the tag,
336 058b0118 2005-01-03 devnull .B X
337 058b0118 2005-01-03 devnull for a button 2 action in the body, and
338 058b0118 2005-01-03 devnull .B x
339 058b0118 2005-01-03 devnull for a button 2 action in the tag.
340 058b0118 2005-01-03 devnull .IP
341 058b0118 2005-01-03 devnull If the relevant text has less than 256 characters, it is included in the message;
342 058b0118 2005-01-03 devnull otherwise it is elided, the fourth number is 0, and the program must read
343 058b0118 2005-01-03 devnull it from the
344 058b0118 2005-01-03 devnull .B data
345 058b0118 2005-01-03 devnull file if needed. No text is sent on a
346 058b0118 2005-01-03 devnull .B D
347 058b0118 2005-01-03 devnull or
348 058b0118 2005-01-03 devnull .B d
349 058b0118 2005-01-03 devnull message.
350 058b0118 2005-01-03 devnull .IP
351 058b0118 2005-01-03 devnull For
352 058b0118 2005-01-03 devnull .BR D ,
353 058b0118 2005-01-03 devnull .BR d ,
354 058b0118 2005-01-03 devnull .BR I ,
355 058b0118 2005-01-03 devnull and
356 058b0118 2005-01-03 devnull .BR i
357 058b0118 2005-01-03 devnull the flag is always zero.
358 058b0118 2005-01-03 devnull For
359 058b0118 2005-01-03 devnull .BR X
360 058b0118 2005-01-03 devnull and
361 058b0118 2005-01-03 devnull .BR x ,
362 058b0118 2005-01-03 devnull the flag is a bitwise OR (reported decimally) of the following:
363 058b0118 2005-01-03 devnull 1 if the text indicated is recognized as an
364 058b0118 2005-01-03 devnull .I acme
365 058b0118 2005-01-03 devnull built-in command;
366 058b0118 2005-01-03 devnull 2 if the text indicated is a null string that has a non-null expansion;
367 058b0118 2005-01-03 devnull if so, another complete message will follow describing the expansion
368 058b0118 2005-01-03 devnull exactly as if it had been indicated explicitly (its flag will always be 0);
369 058b0118 2005-01-03 devnull 8 if the command has an extra (chorded) argument; if so,
370 058b0118 2005-01-03 devnull two more complete messages will follow reporting the argument (with
371 058b0118 2005-01-03 devnull all numbers 0 except the character count) and where it originated, in the form of
372 058b0118 2005-01-03 devnull a fully-qualified button 3 style address.
373 058b0118 2005-01-03 devnull .IP
374 058b0118 2005-01-03 devnull For
375 058b0118 2005-01-03 devnull .B L
376 058b0118 2005-01-03 devnull and
377 058b0118 2005-01-03 devnull .BR l ,
378 058b0118 2005-01-03 devnull the flag is the bitwise OR of the following:
379 058b0118 2005-01-03 devnull 1 if
380 058b0118 2005-01-03 devnull .I acme
381 058b0118 2005-01-03 devnull can interpret the action without loading a new file;
382 058b0118 2005-01-03 devnull 2 if a second (post-expansion) message follows, analogous to that with
383 058b0118 2005-01-03 devnull .B X
384 058b0118 2005-01-03 devnull messages;
385 058b0118 2005-01-03 devnull 4 if the text is a file or window name (perhaps with address) rather than
386 058b0118 2005-01-03 devnull plain literal text.
387 058b0118 2005-01-03 devnull .IP
388 058b0118 2005-01-03 devnull For messages with the 1 bit on in the flag,
389 058b0118 2005-01-03 devnull writing the message back to the
390 058b0118 2005-01-03 devnull .B event
391 058b0118 2005-01-03 devnull file, but with the flag, count, and text omitted,
392 058b0118 2005-01-03 devnull will cause the action to be applied to the file exactly as it would
393 058b0118 2005-01-03 devnull have been if the
394 058b0118 2005-01-03 devnull .B event
395 058b0118 2005-01-03 devnull file had not been open.
396 058b0118 2005-01-03 devnull .TP
397 058b0118 2005-01-03 devnull .B tag
398 058b0118 2005-01-03 devnull holds contents of the window tag. It may be read at any byte offset.
399 058b0118 2005-01-03 devnull Text written to
400 058b0118 2005-01-03 devnull .B tag
401 058b0118 2005-01-03 devnull is always appended; the file offset is ignored.
402 058b0118 2005-01-03 devnull .SH SOURCE
403 058b0118 2005-01-03 devnull .B /usr/local/plan9/src/cmd/acme
404 058b0118 2005-01-03 devnull .SH SEE ALSO
405 058b0118 2005-01-03 devnull .IR rio (1),
406 058b0118 2005-01-03 devnull .IR acme (1)