mirror of
https://github.com/9fans/plan9port.git
synced 2025-01-24 11:41:58 +00:00
977b25a76a
The overloading of IR emits magic \X'...' sequences that turn into HTML manual links. But not all such IR invocations should be manual links; those had to be written to avoid the IR macro before. Worse, the \X'...' ending the IR causes troff to emit only a single space after a period. Defining a new IM macro for manual references fixes both problems. Fixes #441.
109 lines
2.4 KiB
Text
109 lines
2.4 KiB
Text
.TH FLUSH 9P
|
|
.SH NAME
|
|
flush \- abort a message
|
|
.SH SYNOPSIS
|
|
.ta \w'\fLTflush 'u
|
|
.IR size [4]
|
|
.B Tflush
|
|
.IR tag [2]
|
|
.IR oldtag [2]
|
|
.br
|
|
.IR size [4]
|
|
.B Rflush
|
|
.IR tag [2]
|
|
.SH DESCRIPTION
|
|
When the response to a request is no longer needed, such as when
|
|
a user interrupts a process doing a
|
|
.IR read (9p),
|
|
a
|
|
.B Tflush
|
|
request is sent to the server to purge the pending response.
|
|
The message being flushed is identified by
|
|
.IR oldtag .
|
|
The semantics of
|
|
.B flush
|
|
depends on messages arriving in order.
|
|
.PP
|
|
The server should answer the
|
|
.B flush
|
|
message immediately.
|
|
If it recognizes
|
|
.I oldtag
|
|
as the tag of a pending transaction, it should abort any pending response
|
|
and discard that tag.
|
|
In either case, it should respond with an
|
|
.B Rflush
|
|
echoing the
|
|
.I tag
|
|
(not
|
|
.IR oldtag )
|
|
of the
|
|
.B Tflush
|
|
message.
|
|
A
|
|
.B Tflush
|
|
can never be responded to by an
|
|
.B Rerror
|
|
message.
|
|
.PP
|
|
The server may respond to the pending request before
|
|
responding to the
|
|
.BR Tflush .
|
|
It is possible for a client to send multiple
|
|
.B Tflush
|
|
messages for a particular pending request. Each
|
|
subsequent
|
|
.B Tflush
|
|
must contain as
|
|
.I oldtag
|
|
the tag of the pending request (not a previous
|
|
.BR Tflush ).
|
|
Should multiple
|
|
.BR Tflush es
|
|
be received for a pending request, they must be answered in
|
|
order. A
|
|
.B Rflush
|
|
for any of the multiple
|
|
.BR Tflush es
|
|
implies an answer for all previous ones. Therefore, should
|
|
a server receive a request and then multiple flushes for that
|
|
request, it need respond only to the last flush.
|
|
.PP
|
|
When the client sends a
|
|
.BR Tflush ,
|
|
it must wait to receive the corresponding
|
|
.B Rflush
|
|
before reusing
|
|
.I oldtag
|
|
for subsequent messages.
|
|
If a response to the flushed request is received before the
|
|
.BR Rflush ,
|
|
the client must honor the response
|
|
as if it had not been flushed,
|
|
since the completed request may signify a state change in the server.
|
|
For instance,
|
|
.B Tcreate
|
|
may have created a file and
|
|
.B Twalk
|
|
may have allocated a fid.
|
|
If no response is received before the
|
|
.BR Rflush ,
|
|
the flushed transaction is considered to have been canceled,
|
|
and should be treated as though it had never been sent.
|
|
.PP
|
|
Several exceptional conditions are handled correctly by the above specification:
|
|
sending multiple flushes for a single tag,
|
|
flushing after a transaction is completed,
|
|
flushing a
|
|
.BR Tflush ,
|
|
and flushing an invalid tag.
|
|
.SH ENTRY POINTS
|
|
The
|
|
.IM 9pclient (3)
|
|
library does not generate
|
|
.B flush
|
|
transactions..
|
|
.IM 9pserve (4)
|
|
generates
|
|
.B flush
|
|
transactions to cancel transactions pending when a client hangs up.
|