NS(3) BSD Programmer's Manual NS(3)
n
\bns
\bs_
\b_a
\bad
\bdd
\bdr
\br, n
\bns
\bs_
\b_n
\bnt
\bto
\boa
\ba - Xerox NS(tm) address conversion routines
S
\bSY
\bYN
\bNO
\bOP
\bPS
\bSI
\bIS
\bS
#
\b#i
\bin
\bnc
\bcl
\blu
\bud
\bde
\be <
\b<s
\bsy
\bys
\bs/
\b/t
\bty
\byp
\bpe
\bes
\bs.
\b.h
\bh>
\b>
#
\b#i
\bin
\bnc
\bcl
\blu
\bud
\bde
\be <
\b<n
\bne
\bet
\btn
\bns
\bs/
\b/n
\bns
\bs.
\b.h
\bh>
\b>
_
\bs_
\bt_
\br_
\bu_
\bc_
\bt _
\bn_
\bs_
\b__
\ba_
\bd_
\bd_
\br
n
\bns
\bs_
\b_a
\bad
\bdd
\bdr
\br(_
\bc_
\bh_
\ba_
\br _
\b*_
\bc_
\bp);
n
\bns
\bs_
\b_n
\bnt
\bto
\boa
\ba(_
\bs_
\bt_
\br_
\bu_
\bc_
\bt _
\bn_
\bs_
\b__
\ba_
\bd_
\bd_
\br _
\bn_
\bs);
D
\bDE
\bES
\bSC
\bCR
\bRI
\bIP
\bPT
\bTI
\bIO
\bON
\bN
The routine n
\bns
\bs_
\b_a
\bad
\bdd
\bdr
\br() interprets character strings representing XNS ad-
dresses, returning binary information suitable for use in system calls.
The routine n
\bns
\bs_
\b_n
\bnt
\bto
\boa
\ba() takes XNS addresses and returns ASCII strings rep-
resenting the address in a notation in common use in the Xerox Develop-
<network number>.<host number>.<port number>
Trailing zero fields are suppressed, and each number is printed in hex-
adecimal, in a format suitable for input to n
\bns
\bs_
\b_a
\bad
\bdd
\bdr
\br(). Any fields lack-
ing super-decimal digits will have a trailing `H' appended.
Unfortunately, no universal standard exists for representing XNS address-
es. An effort has been made to insure that n
\bns
\bs_
\b_a
\bad
\bdd
\bdr
\br() be compatible with
most formats in common use. It will first separate an address into 1 to
3 fields using a single delimiter chosen from period `.', colon `:' or
pound-sign `#'. Each field is then examined for byte separators (colon or
period). If there are byte separators, each subfield separated is taken
to be a small hexadecimal number, and the entirety is taken as a network-
byte-ordered quantity to be zero extended in the high-network-order
bytes. Next, the field is inspected for hyphens, in which case the field
is assumed to be a number in decimal notation with hyphens separating the
millenia. Next, the field is assumed to be a number: It is interpreted
as hexadecimal if there is a leading `0x' (as in C), a trailing `H' (as
in Mesa), or there are any super-decimal digits present. It is inter-
preted as octal is there is a leading `0' and there are no super-octal
digits. Otherwise, it is converted as a decimal number.
R
\bRE
\bET
\bTU
\bUR
\bRN
\bN V
\bVA
\bAL
\bLU
\bUE
\bES
\bS
None. (See _
\bB_
\bU_
\bG_
\bS.)
S
\bSE
\bEE
\bE A
\bAL
\bLS
\bSO
\bO
H
\bHI
\bIS
\bST
\bTO
\bOR
\bRY
\bY
The n
\bns
\bs_
\b_a
\bad
\bdd
\bdr
\br() and n
\bns
\bs_
\b_t
\bto
\boa
\ba() functions appeared in 4.3BSD.
The string returned by n
\bns
\bs_
\b_n
\bnt
\bto
\boa
\ba() resides in a static memory area. The
function n
\bns
\bs_
\b_a
\bad
\bdd
\bdr
\br() should diagnose improperly formed input, and there
should be an unambiguous way to recognize this.
4.3 Berkeley Distribution June 4, 1993 1