D. Crocker (UCLA-NMC) RFC 658, NIC 31161 (Oct. 25, 1974) Online file: [ISI]<DCROCKER>NAOLFD.TXT
TELNET OUTPUT LINEFEED DISPOSITION
1. Command name and code NAOLFD 16 (Negotiate About Output Linefeed Disposition)
2. Command meanings In the following, we are discussing a simplex connection, as described in the NAOL and NAOP Telnet Options. IAC DO NAOLFD The data sender requests or agrees to negotiate about output linefeed disposition with the data receiver. In the case where agreement has been reached and in the absence of further subnegotiations, the data receiver is assumed to be handling output linefeed considerations. IAC DON'T NAOLFD The data sender refuses to negotiate about output linefeed disposition with the data receiver, or demands a return to the unnegotiated default mode. IAC WILL NAOLFD The data receiver requests or agrees to negotiate about output linefeed disposition with the sender. In the case where agreement has been reached and in the absence of further subnegotiations, the data receiver alone is assumed to be handling output linefeed considerations. IAC WON'T NAOLFD The data receiver refuses to negotiate about output linefeed disposition, or demands a return to the unnegotiated default mode. IAC SB NAOLFD DS <8-bit value> IAC SE The data sender specifies, with the 8-bit value, which party should handle output linefeeds and what their disposition should be. The code for DS is 1. IAC SB NAOLFD DR <8-bit value> IAC SE The data receiver specifies, with the 8-bit value, which party should handle output linefeeds and what their disposition should be. The code for DR is 0.
3. Default DON'T NAOLFD/WON'T NAOLFD. In the default absence of negotiations concerning which party, data under or data receiver, is handling output linefeed considerations, neither party is required nor prohibited from handling linefeeds; but it is appropriate if at least the data receiver handles them, albeit primitively.
4. Motivation for the Option Please refer to section 4 of the NAOL and of the NAOLFD Telnet option descriptions.
5. Description of the Option The data sender and the data receiver use the 8-bit value along with DS and DR SB commands as follows:
8-bit value Meaning
0 Command sender suggests that he alone will handle linefeeds, for the connection. 1 to 250 Command sender suggests that the other party alone should handle linefeeds, but suggests that a delay of the indicated value be used. The value is the number of character-times to wait or number of NULs to insert in the data stream before sending the next data character. (See qualifications, below.) 251 Not allowed, in order to be compatible with related Telnet options. 252 Command sender suggests that the other party alone handle linefeeds, but suggests that they be discarded. 253 Command sender suggests that the other party alone should handle linefeeds, but suggests that linefeeds be simulated. 254 Command sender suggests that the other party alone should handle output linefeeds but suggests waiting for a character to be transmitted (on the other simplex connection) before sending more data. (See qualifications, below.) Note that, due to the assynchrony of the two simplex connections, phase problems can occur with this option. 255 Command sender suggests that the other party alone should handle output linefeeds and suggests nothing about how it should be done.
The guiding rules are that:
1) if neither data receiver nor data sender wants to handle output linefeeds, the data receiver must do it, and 2) if both data receiver and data sender want to handle output linefeed disposition, the data sender gets to do it.
The reasoning for the former rule is that if neither wants to do it, then the default in the NAOLFD option dominates. If both want to do it, the sender, who is presumed to have special knowledge about the data, should be allowed to do it, taking into account any suggestions the receiver may make. Simulation is defined as the replacement of the linefeed character by new-line (see following) and enough blanks to move the print head (or line pointer) to the same lateral position it occupied just prior to receiving the linefeed. To avoid infinite recursion, such simulation is allowed only for linefeed characters that are not immediately preceded by carriage-returns (that is, part of a Telnet new-line combination). It is assumed that linefeed simulation will be necessary for printers that do not have a separate linefeed (like the IBM 2741); in this case, end-of-line character padding can be specified through NAOCRD. Any padding (0 < <8-bit-value> < 251) of linefeed characters is to be done for ALL linefeed characters.
NOTE: Delays, controlled by the data sender, must consist of NUL characters inserted immediately after the character. This is necessary due to the assynchrony of network transmissions. Additionally, due to the presence of the Telnet end-of-line convention, it may be necessary to add carriage-return padding or delay after the associated linefeed (see NAOCRD Telnet option). As with all option negotiations, neither party should suggest a state already in effect except to refuse to negotiate; changes should be acknowledged; and once refused, an option should not be resuggested until "something changes" (e.g., another process starts). At any time, either party can disable further negotiation by giving the appropriate WON'T NAOLFD or DON'T NAOLFD command.