summaryrefslogtreecommitdiffstats
path: root/docs/nspr/reference/pr_connect.rst
blob: 10978df792b902cd7dbd2957bd31050f5de532b4 (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
PR_Connect
==========

Initiates a connection on a specified socket.


Syntax
------

.. code::

   #include <prio.h>

   PRStatus PR_Connect(
     PRFileDesc *fd,
     const PRNetAddr *addr,
     PRIntervalTime timeout);


Parameters
~~~~~~~~~~

The function has the following parameters:

``fd``
   A pointer to a :ref:`PRFileDesc` object representing a socket.
``addr``
   A pointer to the address of the peer to which the socket is to be
   connected.
``timeout``
   A value of type :ref:`PRIntervalTime` specifying the time limit for
   completion of the connect operation.


Returns
~~~~~~~

The function returns one of the following values:

-  Upon successful completion of connection setup, ``PR_SUCCESS``.
-  If unsuccessful, ``PR_FAILURE``. Further information can be obtained
   by calling :ref:`PR_GetError`.


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

:ref:`PR_Connect` is usually invoked on a TCP socket, but it may also be
invoked on a UDP socket. Both cases are discussed here.

If the socket is a TCP socket, :ref:`PR_Connect` establishes a TCP
connection to the peer. If the socket is not bound, it will be bound to
an arbitrary local address.

:ref:`PR_Connect` blocks until either the connection is successfully
established or an error occurs. The function uses the lesser of the
provided timeout and the OS's connect timeout. In particular, if you
specify ``PR_INTERVAL_NO_TIMEOUT`` as the timeout, the OS's connection
time limit will be used.

If the socket is a UDP socket, there is no connection setup to speak of,
since UDP is connectionless. If :ref:`PR_Connect` is invoked on a UDP
socket, it has an overloaded meaning: :ref:`PR_Connect` merely saves the
specified address as the default peer address for the socket, so that
subsequently one can send and receive datagrams from the socket using
:ref:`PR_Send` and :ref:`PR_Recv` instead of the usual :ref:`PR_SendTo` and
:ref:`PR_RecvFrom`.