TELNET OUTPUT FORMFEED DISPOSITION OPTION
RFC 655, NIC 31158 (Oct. 25, 1974)
D. Crocker (UCLA-NMC)
Online file: [ISI]<DCROCKER>NAOFFD.TXT

              TELNET OUTPUT FORMFEED DISPOSITION OPTION

1. Command name and code
   NAOFFD - 13
      (Negotiate About Output Formfeed Disposition)

2. Command meanings
   In the following, we are discussing a simplex connection, as described in
   the NAOL and NAOP Telnet Options specifications.
      IAC DO NAOFFD
         The data sender requests or agrees to negotiate about output
         formfeed 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 formfeeds.
      IAC DON'T NAOFFD
         The data sender refuses to negotiate about output formfeed
         disposition with the data receiver, or demands a return to
         the unnegotiated default mode.
      IAC WILL NAOFFD
         The data receiver requests or agrees to negotiate about
         output formfeed 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 formfeeds.
      IAC WON'T NAOFFD
         The data receiver refuses to negotiate about output formfeed
         disposition, or demands a return to the unnegotiated default
         mode.
      IAC SB NAOFFD DS <8-bit value> IAC SE
         The data sender specifies, with the 8-bit value, which party
         should handle formfeeds and what their disposition should be.
         The code for DS is 1.
      IAC SB NAOFFD DR <8-bit value> IAC SE
         The data receiver specifies, with the 8-bit value, which
         party should handle formfeeds and what their disposition
         should be.  The code for DR is 0.

3. Default
   DON'T NAOFFD/WON'T NAOFFD
      In the default absence of negotiations concerning which party, data
      sender or data receiver, is handling output formfeeds, neither party
      is required to handle formfeeds and neither party is prohibited from
      handling them; but it is appropriate if at least the data receiver
      handles formfeed considerations, albeit primitively.

4. Motivation for the Option
   Please refer to section 4 of the NAOL and of the NAOFFD Telnet option
   descriptions.

5. Description of the Option
   The data sender and the data receiver use the 8-bit value along with the
   DS and DR SB commands as follows:

      8-bit value                      Meaning

      0            Command sender suggests that he alone will handle
                   formfeeds, for the connection.
      1 to 250     Command sender suggests that the other party alone
                   should handle formfeeds, but suggests that 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.
      251          Command sender suggests that the other party alone
                   handle formfeeds, but suggests that each
                   occurrence of the character be replaced by
                   carriage-return/line-feed.
      252          Command sender suggests that the other party alone
                   handle formfeeds, but suggests that they be
                   discarded.
      253          Command sender suggests that the other party alone
                   should handle formfeeds, but suggests that
                   formfeeds be simulated.
      254          Command sender suggests that the other party alone
                   should handle output formfeeds but suggests
                   waiting for a character to be transmitted (on the
                   other simplex connection) before sending more
                   data. 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 formfeeds 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
      formfeeds, the data receiver must do it, and
      2) if both data receiver and data sender want to handle output
      formfeeds, 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 NAOFFD 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 formfeed character by enough line-feeds (only)
   to advance the paper (or line-pointer) to the top of the next page
   (or to the top of the terminal screen).  Note that delays,
   controlled by the data sender, must consist of NUL characters
   inserted immediately after the formfeed character.  This is
   necessary due to the assynchrony of network transmission.  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 NAOFFD or DON'T NAOFFD command.