summaryrefslogtreecommitdiffstats
path: root/docs/nspr/reference/pr_acceptread.rst
blob: d0e8fca61b2cd8c6bbf52b29c6211247ae49161f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
PR_AcceptRead
=============

Accepts a new connection and receives a block of data.


Syntax
------

.. code::

   #include <prio.h>

   PRInt32 PR_AcceptRead(
     PRFileDesc *listenSock,
     PRFileDesc **acceptedSock,
     PRNetAddr **peerAddr,
     void *buf,
     PRInt32 amount,
     PRIntervalTime timeout);


Parameters
~~~~~~~~~~

The function has the following parameters:

``listenSock``
   A pointer to a :ref:`PRFileDesc` object representing a socket descriptor
   that has been called with the :ref:`PR_Listen` function, also known as
   the rendezvous socket.
``acceptedSock``
   A pointer to a pointer to a :ref:`PRFileDesc` object. On return,
   ``*acceptedSock`` points to the :ref:`PRFileDesc` object for the newly
   connected socket. This parameter is valid only if the function return
   does not indicate failure.
``peerAddr``
   A pointer a pointer to a :ref:`PRNetAddr` object. On return,
   ``peerAddr`` points to the address of the remote socket. The
   :ref:`PRNetAddr` object that ``peerAddr`` points to will be in the
   buffer pointed to by ``buf``. This parameter is valid only if the
   function return does not indicate failure.
``buf``
   A pointer to a buffer to hold data sent by the peer and the peer's
   address. This buffer must be large enough to receive ``amount`` bytes
   of data and two :ref:`PRNetAddr` structures (thus allowing the runtime
   to align the addresses as needed).
``amount``
   The number of bytes of data to receive. Does not include the size of
   the :ref:`PRNetAddr` structures. If 0, no data will be read from the
   peer.
``timeout``
   The timeout interval only applies to the read portion of the
   operation. :ref:`PR_AcceptRead` blocks indefinitely until the connection
   is accepted; the read will time out after the timeout interval
   elapses.


Returns
~~~~~~~

-  A positive number indicates the number of bytes read from the peer.
-  The value -1 indicates a failure. The reason for the failure can be
   obtained by calling :ref:`PR_GetError`.


Description
-----------

:ref:`PR_AcceptRead` accepts a new connection and retrieves the newly
created socket's descriptor and the connecting peer's address. Also, as
its name suggests, :ref:`PR_AcceptRead` receives the first block of data
sent by the peer.