Training courses

Kernel and Embedded Linux

Bootlin training courses

Embedded Linux, kernel,
Yocto Project, Buildroot, real-time,
graphics, boot time, debugging...

Bootlin logo

Elixir Cross Referencer

GETNETENT(3)           FreeBSD Library Functions Manual           GETNETENT(3)

NNAAMMEE
     ggeettnneetteenntt, ggeettnneettbbyyaaddddrr, ggeettnneettbbyynnaammee, sseettnneetteenntt, eennddnneetteenntt -- get net-
     works entry

SSYYNNOOPPSSIISS
     ##iinncclluuddee <<nneettddbb..hh>>

     _s_t_r_u_c_t _n_e_t_e_n_t _*
     ggeettnneetteenntt();

     _s_t_r_u_c_t _n_e_t_e_n_t _*
     ggeettnneettbbyynnaammee(_c_h_a_r _n_a_m_e);

     _s_t_r_u_c_t _n_e_t_e_n_t _*
     ggeettnneettbbyyaaddddrr(_u_n_s_i_g_n_e_d _l_o_n_g _n_e_t, _i_n_t _t_y_p_e);

     _v_o_i_d
     sseettnneetteenntt(_i_n_t _s_t_a_y_o_p_e_n);

     _v_o_i_d
     eennddnneetteenntt();

DDEESSCCRRIIPPTTIIOONN
     The ggeettnneetteenntt(), ggeettnneettbbyynnaammee(), and ggeettnneettbbyyaaddddrr() subroutines each
     return a pointer to an object with the following structure containing the
     broken-out fields of a line in the _n_e_t_w_o_r_k_s database.

           struct  netent {
                   char    *n_name;        /* official name of net */
                   char    **n_aliases;    /* alias list */
                   int     n_addrtype;     /* net number type */
                   long    n_net;          /* net number */
           };

     The members of this structure are:

     n_name      The official name of the network.

     n_aliases   A zero-terminated list of alternate names for the network.

     n_addrtype  The type of the network number returned: AF_INET.

     n_net       The network number.  Network numbers are returned in machine
                 byte order.

     If the _s_t_a_y_o_p_e_n flag on a sseettnneetteenntt() subroutine is NULL, the _n_e_t_w_o_r_k_s
     database is opened.  Otherwise, the sseettnneetteenntt() has the effect of rewind-
     ing the _n_e_t_w_o_r_k_s database.  The eennddnneetteenntt() subroutine may be called to
     close the _n_e_t_w_o_r_k_s database when processing is complete.

     The ggeettnneetteenntt() subroutine simply reads the next line while
     ggeettnneettbbyynnaammee() and ggeettnneettbbyyaaddddrr() search until a matching _n_a_m_e or _n_e_t
     number is found (or until EOF is encountered).  The _t_y_p_e _m_u_s_t _b_e AF_INET.
     The ggeettnneetteenntt() subroutine keeps a pointer in the database, allowing suc-
     cessive calls to be used to search the entire file.

     Before a wwhhiillee loop using ggeettnneetteenntt(), a call to sseettnneetteenntt() must be made
     in order to perform initialization; a call to eennddnneetteenntt() must be used
     after the loop.  Both ggeettnneettbbyynnaammee() and ggeettnneettbbyyaaddddrr() make calls to
     sseettnneetteenntt() and eennddnneetteenntt().

FFIILLEESS
     _/_e_t_c_/_n_e_t_w_o_r_k_s

DDIIAAGGNNOOSSTTIICCSS
     Null pointer (0) returned on EOF or error.

SSEEEE AALLSSOO
     networks(5), RFC 1101.

HHIISSTTOORRYY
     The ggeettnneetteenntt(), ggeettnneettbbyyaaddddrr(), ggeettnneettbbyynnaammee(), sseettnneetteenntt(), and
     eennddnneetteenntt() functions appeared in 4.2BSD.

BBUUGGSS
     The data space used by these functions is static; if future use requires
     the data, it should be copied before any subsequent calls to these func-
     tions overwrite it.  Only Internet network numbers are currently under-
     stood.  Expecting network numbers to fit in no more than 32 bits is prob-
     ably naive.

4th Berkeley Distribution        May 20, 1996        4th Berkeley Distribution