From dff024256295c15e49888ad9d5fef74a7746edd7 Mon Sep 17 00:00:00 2001 From: Gian Mario Tagliaretti Date: Wed, 30 Dec 2009 23:44:25 +0100 Subject: Wrap gio.SocketAddressEnumerator.next_async() and add a test --- gio/gsocket.override | 42 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) (limited to 'gio') diff --git a/gio/gsocket.override b/gio/gsocket.override index 4bf3a6b..95e6527 100644 --- a/gio/gsocket.override +++ b/gio/gsocket.override @@ -66,6 +66,48 @@ _wrap_g_socket_condition_wait(PyGObject *self, return PyBool_FromLong(ret); } +%% +override g_socket_address_enumerator_next_async kwargs +static PyObject * +_wrap_g_socket_address_enumerator_next_async(PyGObject *self, + PyObject *args, + PyObject *kwargs) +{ + static char *kwlist[] = { "callback", "cancellable", "user_data", NULL }; + PyGIONotify *notify; + PyGObject *py_cancellable = NULL; + GCancellable *cancellable; + + notify = pygio_notify_new(); + + if (!PyArg_ParseTupleAndKeywords(args, kwargs, + "O|OO:gio.SocketAddressEnumerator.next_async", + kwlist, + ¬ify->callback, + &py_cancellable, + ¬ify->data)) + goto error; + + if (!pygio_notify_callback_is_valid(notify)) + goto error; + + if (!pygio_check_cancellable(py_cancellable, &cancellable)) + goto error; + + pygio_notify_reference_callback(notify); + + g_socket_address_enumerator_next_async(G_SOCKET_ADDRESS_ENUMERATOR(self->obj), + cancellable, + (GAsyncReadyCallback) async_result_callback_marshal, + notify); + + Py_INCREF(Py_None); + return Py_None; + + error: + pygio_notify_free(notify); + return NULL; +} /* Could not write method GSocket.receive_from: No ArgType for GSocketAddress** */ /* Could not write method GSocket.receive_message: No ArgType for GSocketAddress** */ -- cgit