Top |
GSocketConnection is a GIOStream for a connected socket. They can be created either by GSocketClient when connecting to a host, or by GSocketListener when accepting a new client.
The type of the GSocketConnection object returned from these calls depends on the type of the underlying socket that is in use. For instance, for a TCP/IP connection it will be a GTcpConnection.
Choosing what type of object to construct is done with the socket
connection factory, and it is possible for 3rd parties to register
custom socket connection types for specific combination of socket
family/type/protocol using g_socket_connection_factory_register_type()
.
To close a GSocketConnection, use g_io_stream_close()
. Closing both
substreams of the GIOStream separately will not close the underlying
GSocket.
gboolean g_socket_connection_connect (GSocketConnection *connection
,GSocketAddress *address
,GCancellable *cancellable
,GError **error
);
Connect connection
to the specified remote address.
connection |
||
address |
a GSocketAddress specifying the remote address. |
|
cancellable |
a |
[allow-none] |
error |
Since: 2.32
void g_socket_connection_connect_async (GSocketConnection *connection
,GSocketAddress *address
,GCancellable *cancellable
,GAsyncReadyCallback callback
,gpointer user_data
);
Asynchronously connect connection
to the specified remote address.
This clears the “blocking” flag on connection
's underlying
socket if it is currently set.
Use g_socket_connection_connect_finish()
to retrieve the result.
connection |
||
address |
a GSocketAddress specifying the remote address. |
|
cancellable |
a |
[allow-none] |
callback |
[scope async] | |
user_data |
user data for the callback. |
[closure] |
Since: 2.32
gboolean g_socket_connection_connect_finish (GSocketConnection *connection
,GAsyncResult *result
,GError **error
);
Gets the result of a g_socket_connection_connect_async()
call.
Since: 2.32
gboolean
g_socket_connection_is_connected (GSocketConnection *connection
);
Checks if connection
is connected. This is equivalent to calling
g_socket_is_connected()
on connection
's underlying GSocket.
Since: 2.32
GSocketAddress * g_socket_connection_get_local_address (GSocketConnection *connection
,GError **error
);
Try to get the local address of a socket connection.
a GSocketAddress or NULL
on error.
Free the returned object with g_object_unref()
.
[transfer full]
Since: 2.22
GSocketAddress * g_socket_connection_get_remote_address (GSocketConnection *connection
,GError **error
);
Try to get the remote address of a socket connection.
Since GLib 2.40, when used with g_socket_client_connect()
or
g_socket_client_connect_async()
, during emission of
G_SOCKET_CLIENT_CONNECTING
, this function will return the remote
address that will be used for the connection. This allows
applications to print e.g. "Connecting to example.com
(10.42.77.3)...".
a GSocketAddress or NULL
on error.
Free the returned object with g_object_unref()
.
[transfer full]
Since: 2.22
GSocket *
g_socket_connection_get_socket (GSocketConnection *connection
);
Gets the underlying GSocket object of the connection. This can be useful if you want to do something unusual on it not supported by the GSocketConnection APIs.
Since: 2.22
GSocketConnection *
g_socket_connection_factory_create_connection
(GSocket *socket
);
Creates a GSocketConnection subclass of the right type for
socket
.
Since: 2.22
GType g_socket_connection_factory_lookup_type (GSocketFamily family
,GSocketType type
,gint protocol_id
);
Looks up the GType to be used when creating socket connections on
sockets with the specified family
, type
and protocol_id
.
If no type is registered, the GSocketConnection base type is returned.
Since: 2.22
void g_socket_connection_factory_register_type (GType g_type
,GSocketFamily family
,GSocketType type
,gint protocol
);
Looks up the GType to be used when creating socket connections on
sockets with the specified family
, type
and protocol
.
If no type is registered, the GSocketConnection base type is returned.
g_type |
a GType, inheriting from |
|
family |
||
type |
||
protocol |
a protocol id |
Since: 2.22
typedef struct _GSocketConnection GSocketConnection;
A socket connection GIOStream object for connection-oriented sockets.
Since: 2.22
“socket”
property“socket” GSocket *
The underlying GSocket.
Flags: Read / Write / Construct Only