Request for Comments:  652                   D. Crocker (UCLA-NMC)
                                                        25 Oct. 74
NIC #31155
Online file:  [ISI]<DCROCKER>NAOCRD.TXT




      Telnet Output Carriage-Return Disposition Option



1.  Command name and code

    NAOCRD     10   (Negotiate About Output Carriage-Return Disposition)

2.  Command meanings

        In the following, we are discussing  a  simplex  connection,  as
    described in the NAOL and NAOP Telnet options.

    IAC DO NAOCRD        The data sender requests or agrees to negotiate
                         about    output    carriage-return    character
                         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
                         carriage-returns.

    IAC DON'T NAOCRD     The data  sender  refuses  to  negotiate  about
                         output  carriage-return  disposition  with  the
                         data receiver,  or  demands  a  return  to  the
                         unnegotiated default mode.

    IAC WILL NAOCRD      The  data  receiver  requests  or   agrees   to
                         negotiate    about    output    carriage-return
                         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
                         carriage-returns.

    IAC WON'T NAOCRD     The data receiver refuses  to  negotiate  about
                         output  carriage-return disposition, or demands
                         a return to the unnegotiated default mode.

    IAC SB NAOCRD DS <8-bit value> IAC SE
                         The  data  sender  specifies,  with  the  8-bit
                         value,     which     party     should    handle
                         carriage-returns  and  what  their  disposition
                         should be.  The code for DS is 1.

Telnet NAOCRD Option                                Page   2



    IAC SB NAOCRD DR <8-bit value> IAC SE        The    data    receiver
                         specifies,  with  the  8-bit value, which party
                         should handle carriage-returns and  what  their
                         disposition should be.  The code for DR is 0.



3.  Default


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


4.  Motivation for the Option

        Please refer to section 4 of the NAOL and  of  the  NAOP  Telnet
    option descriptions.


5.  Description of the Option

        The data sender and the data receiver use the 8-bit value  along
    with the NAOCRD SB commands as follows:

    8-bit value          Meaning

    0                    Command sender  suggests  that  he  alone  will
                         handle carriage-returns, for the connection. 

    1 to 250             Command sender suggests that  the  other  party
                         alone   should   handle  carriage-returns,  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   qualification,
                         below.) 

    251                  Not allowed, in order  to  be  compatible  with
                         related Telnet options.

    252                  Command sender suggests that  the  other  party
                         alone  handle  carriage-returns,  but  suggests
                         that they be discarded.

    253                  Not allowed, in order  to  be  compatible  with
                         related Telnet options. 

Telnet NAOCRD Option                                Page   3



    254                  Command sender suggests that  the  other  party
                         alone   should   handle   carriage-returns  but
                         suggests  waiting  for  a   character   to   be
                         transmitted  (on  the other simplex connection)
                         before sending more data.  (See  qualification,
                         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   carriage-returns  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
        carriage-returns, the data receiver must do it, and

        (2) if both  data  receiver  and  data  sender  want  to  handle
        carriage-returns, 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 NAOCRD 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.

        Note that carriage-return delays, controlled by the data sender,
    must  consist  of  NUL  characters  inserted  immediately  after the
    character in question.  This is necessary due to the assynchrony  of
    network  transmissions.   Due  to the Telnet end-of-line convention,
    with carriage-returns followed by a linefeed, any  NULs  that  would
    otherwise  be  placed after the carriage-return must be placed after
    the linefeed, regardless of any modifications that may  additionally
    be made to the line feed (see NAOLFD 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 NAOCRD or DON'T NAOCRD command.