2010-09-23 16:50:36 -07:00
/*
2010-09-23 14:28:02 -07:00
Unix SMB / CIFS implementation .
Python bindings for tevent
Copyright ( C ) Jelmer Vernooij 2010
* * NOTE ! The following LGPL license applies to the tevent
* * library . This does NOT imply that all of Samba is released
* * under the LGPL
This library is free software ; you can redistribute it and / or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation ; either
version 3 of the License , or ( at your option ) any later version .
This library is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
Lesser General Public License for more details .
You should have received a copy of the GNU Lesser General Public
License along with this library ; if not , see < http : //www.gnu.org/licenses/>.
*/
# include <Python.h>
2015-06-11 09:50:35 +02:00
# include "replace.h"
2010-09-23 14:28:02 -07:00
# include <tevent.h>
2015-05-22 11:47:56 +02:00
# if PY_MAJOR_VERSION >= 3
# define PyStr_Check PyUnicode_Check
# define PyStr_FromString PyUnicode_FromString
# define PyStr_AsUTF8 PyUnicode_AsUTF8
# define PyInt_FromLong PyLong_FromLong
# else
# define PyStr_Check PyString_Check
# define PyStr_FromString PyString_FromString
# define PyStr_AsUTF8 PyString_AsString
# endif
2011-03-19 00:46:08 +01:00
void init_tevent ( void ) ;
2010-09-23 14:28:02 -07:00
typedef struct {
PyObject_HEAD
struct tevent_context * ev ;
} TeventContext_Object ;
2010-09-23 16:50:36 -07:00
typedef struct {
PyObject_HEAD
struct tevent_queue * queue ;
} TeventQueue_Object ;
typedef struct {
PyObject_HEAD
struct tevent_req * req ;
} TeventReq_Object ;
typedef struct {
PyObject_HEAD
struct tevent_signal * signal ;
} TeventSignal_Object ;
typedef struct {
PyObject_HEAD
struct tevent_timer * timer ;
2015-05-26 13:25:12 +02:00
PyObject * callback ;
2010-09-23 16:50:36 -07:00
} TeventTimer_Object ;
typedef struct {
PyObject_HEAD
struct tevent_fd * fd ;
} TeventFd_Object ;
2014-12-03 13:59:58 +01:00
static PyTypeObject TeventContext_Type ;
static PyTypeObject TeventReq_Type ;
static PyTypeObject TeventQueue_Type ;
static PyTypeObject TeventSignal_Type ;
static PyTypeObject TeventTimer_Type ;
static PyTypeObject TeventFd_Type ;
2010-09-23 16:50:36 -07:00
2010-09-23 14:28:02 -07:00
static int py_context_init ( struct tevent_context * ev )
{
/* FIXME */
2010-09-23 17:40:35 -07:00
return 0 ;
2010-09-23 14:28:02 -07:00
}
static struct tevent_fd * py_add_fd ( struct tevent_context * ev ,
TALLOC_CTX * mem_ctx ,
int fd , uint16_t flags ,
tevent_fd_handler_t handler ,
void * private_data ,
const char * handler_name ,
const char * location )
{
/* FIXME */
2010-09-23 17:40:35 -07:00
return NULL ;
2010-09-23 14:28:02 -07:00
}
static void py_set_fd_close_fn ( struct tevent_fd * fde ,
tevent_fd_close_fn_t close_fn )
{
/* FIXME */
}
2011-03-19 00:46:08 +01:00
static uint16_t py_get_fd_flags ( struct tevent_fd * fde )
2010-09-23 14:28:02 -07:00
{
/* FIXME */
2010-09-23 17:40:35 -07:00
return 0 ;
2010-09-23 14:28:02 -07:00
}
static void py_set_fd_flags ( struct tevent_fd * fde , uint16_t flags )
{
/* FIXME */
}
/* timed_event functions */
static struct tevent_timer * py_add_timer ( struct tevent_context * ev ,
TALLOC_CTX * mem_ctx ,
struct timeval next_event ,
tevent_timer_handler_t handler ,
void * private_data ,
const char * handler_name ,
const char * location )
{
/* FIXME */
2010-09-23 17:40:35 -07:00
return NULL ;
2010-09-23 14:28:02 -07:00
}
/* immediate event functions */
static void py_schedule_immediate ( struct tevent_immediate * im ,
struct tevent_context * ev ,
tevent_immediate_handler_t handler ,
void * private_data ,
const char * handler_name ,
const char * location )
{
/* FIXME */
}
/* signal functions */
static struct tevent_signal * py_add_signal ( struct tevent_context * ev ,
TALLOC_CTX * mem_ctx ,
int signum , int sa_flags ,
tevent_signal_handler_t handler ,
void * private_data ,
const char * handler_name ,
const char * location )
{
/* FIXME */
2010-09-23 17:40:35 -07:00
return NULL ;
2010-09-23 14:28:02 -07:00
}
/* loop functions */
static int py_loop_once ( struct tevent_context * ev , const char * location )
{
/* FIXME */
2010-09-23 17:40:35 -07:00
return 0 ;
2010-09-23 14:28:02 -07:00
}
static int py_loop_wait ( struct tevent_context * ev , const char * location )
{
/* FIXME */
2010-09-23 17:40:35 -07:00
return 0 ;
2010-09-23 14:28:02 -07:00
}
const static struct tevent_ops py_tevent_ops = {
. context_init = py_context_init ,
. add_fd = py_add_fd ,
. set_fd_close_fn = py_set_fd_close_fn ,
. get_fd_flags = py_get_fd_flags ,
. set_fd_flags = py_set_fd_flags ,
. add_timer = py_add_timer ,
. schedule_immediate = py_schedule_immediate ,
. add_signal = py_add_signal ,
. loop_wait = py_loop_wait ,
. loop_once = py_loop_once ,
} ;
static PyObject * py_register_backend ( PyObject * self , PyObject * args )
{
2010-09-23 16:50:36 -07:00
PyObject * name , * py_backend ;
if ( ! PyArg_ParseTuple ( args , " O " , & py_backend ) )
return NULL ;
name = PyObject_GetAttrString ( py_backend , " name " ) ;
if ( name = = NULL ) {
PyErr_SetNone ( PyExc_AttributeError ) ;
return NULL ;
}
2015-05-22 11:47:56 +02:00
if ( ! PyStr_Check ( name ) ) {
2010-09-23 16:50:36 -07:00
PyErr_SetNone ( PyExc_TypeError ) ;
2014-12-04 12:44:56 +01:00
Py_DECREF ( name ) ;
2010-09-23 16:50:36 -07:00
return NULL ;
}
2015-05-22 11:47:56 +02:00
if ( ! tevent_register_backend ( PyStr_AsUTF8 ( name ) , & py_tevent_ops ) ) { /* FIXME: What to do with backend */
2010-09-23 16:50:36 -07:00
PyErr_SetNone ( PyExc_RuntimeError ) ;
2014-12-04 12:44:56 +01:00
Py_DECREF ( name ) ;
2010-09-23 16:50:36 -07:00
return NULL ;
}
2014-12-04 12:44:56 +01:00
Py_DECREF ( name ) ;
2010-09-23 16:50:36 -07:00
Py_RETURN_NONE ;
2010-09-23 14:28:02 -07:00
}
2010-09-23 16:50:36 -07:00
static PyObject * py_tevent_context_reinitialise ( TeventContext_Object * self )
2010-09-23 14:28:02 -07:00
{
2010-09-23 16:50:36 -07:00
int ret = tevent_re_initialise ( self - > ev ) ;
if ( ret ! = 0 ) {
PyErr_SetNone ( PyExc_RuntimeError ) ;
return NULL ;
}
2010-09-23 14:28:02 -07:00
Py_RETURN_NONE ;
}
2010-09-23 16:50:36 -07:00
static PyObject * py_tevent_queue_stop ( TeventQueue_Object * self )
2010-09-23 14:28:02 -07:00
{
2010-09-23 16:50:36 -07:00
tevent_queue_stop ( self - > queue ) ;
2010-09-23 14:28:02 -07:00
Py_RETURN_NONE ;
}
2010-09-23 16:50:36 -07:00
static PyObject * py_tevent_queue_start ( TeventQueue_Object * self )
2010-09-23 14:28:02 -07:00
{
2010-09-23 16:50:36 -07:00
tevent_queue_start ( self - > queue ) ;
2010-09-23 14:28:02 -07:00
Py_RETURN_NONE ;
}
2010-09-23 16:50:36 -07:00
static void py_queue_trigger ( struct tevent_req * req , void * private_data )
2010-09-23 14:28:02 -07:00
{
2010-09-23 17:40:35 -07:00
PyObject * callback = private_data , * ret ;
2010-09-23 16:50:36 -07:00
2015-06-11 09:50:35 +02:00
ret = PyObject_CallFunction ( callback , discard_const_p ( char , " " ) ) ;
2010-09-23 16:50:36 -07:00
Py_XDECREF ( ret ) ;
}
static PyObject * py_tevent_queue_add ( TeventQueue_Object * self , PyObject * args )
{
TeventContext_Object * py_ev ;
TeventReq_Object * py_req ;
PyObject * trigger ;
bool ret ;
if ( ! PyArg_ParseTuple ( args , " O!O!O " ,
& TeventContext_Type , & py_ev ,
& TeventReq_Type , & py_req ,
& trigger ) )
return NULL ;
Py_INCREF ( trigger ) ;
ret = tevent_queue_add ( self - > queue , py_ev - > ev , py_req - > req ,
py_queue_trigger , trigger ) ;
if ( ! ret ) {
PyErr_SetString ( PyExc_RuntimeError , " queue add failed " ) ;
Py_DECREF ( trigger ) ;
return NULL ;
}
2010-09-23 14:28:02 -07:00
Py_RETURN_NONE ;
}
static PyMethodDef py_tevent_queue_methods [ ] = {
{ " stop " , ( PyCFunction ) py_tevent_queue_stop , METH_NOARGS ,
" S.stop() " } ,
{ " start " , ( PyCFunction ) py_tevent_queue_start , METH_NOARGS ,
" S.start() " } ,
{ " add " , ( PyCFunction ) py_tevent_queue_add , METH_VARARGS ,
" S.add(ctx, req, trigger, baton) " } ,
{ NULL } ,
} ;
static PyObject * py_tevent_context_wakeup_send ( PyObject * self , PyObject * args )
{
/* FIXME */
2010-09-23 16:50:36 -07:00
2010-09-23 14:28:02 -07:00
Py_RETURN_NONE ;
}
2010-09-23 16:50:36 -07:00
static PyObject * py_tevent_context_loop_wait ( TeventContext_Object * self )
2010-09-23 14:28:02 -07:00
{
2010-09-23 16:50:36 -07:00
if ( tevent_loop_wait ( self - > ev ) ! = 0 ) {
PyErr_SetNone ( PyExc_RuntimeError ) ;
return NULL ;
}
2010-09-23 14:28:02 -07:00
Py_RETURN_NONE ;
}
2010-09-23 16:50:36 -07:00
static PyObject * py_tevent_context_loop_once ( TeventContext_Object * self )
2010-09-23 14:28:02 -07:00
{
2010-09-23 16:50:36 -07:00
if ( tevent_loop_once ( self - > ev ) ! = 0 ) {
PyErr_SetNone ( PyExc_RuntimeError ) ;
return NULL ;
}
2010-09-23 14:28:02 -07:00
Py_RETURN_NONE ;
}
2010-09-23 16:50:36 -07:00
static void py_tevent_signal_handler ( struct tevent_context * ev ,
struct tevent_signal * se ,
int signum ,
int count ,
void * siginfo ,
void * private_data )
2010-09-23 14:28:02 -07:00
{
2010-09-23 16:50:36 -07:00
PyObject * callback = ( PyObject * ) private_data , * ret ;
2015-06-11 09:50:35 +02:00
ret = PyObject_CallFunction ( callback , discard_const_p ( char , " ii " ) , signum , count ) ;
2010-09-23 16:50:36 -07:00
Py_XDECREF ( ret ) ;
}
2010-09-23 17:13:56 -07:00
static void py_tevent_signal_dealloc ( TeventSignal_Object * self )
{
talloc_free ( self - > signal ) ;
PyObject_Del ( self ) ;
}
static PyTypeObject TeventSignal_Type = {
2012-02-01 00:58:32 +11:00
. tp_name = " tevent.Signal " ,
2010-09-23 17:13:56 -07:00
. tp_basicsize = sizeof ( TeventSignal_Object ) ,
. tp_dealloc = ( destructor ) py_tevent_signal_dealloc ,
. tp_flags = Py_TPFLAGS_DEFAULT ,
} ;
2010-09-23 16:50:36 -07:00
static PyObject * py_tevent_context_add_signal ( TeventContext_Object * self , PyObject * args )
{
int signum , sa_flags ;
PyObject * handler ;
struct tevent_signal * sig ;
TeventSignal_Object * ret ;
if ( ! PyArg_ParseTuple ( args , " iiO " , & signum , & sa_flags , & handler ) )
return NULL ;
Py_INCREF ( handler ) ;
sig = tevent_add_signal ( self - > ev , NULL , signum , sa_flags ,
py_tevent_signal_handler , handler ) ;
ret = PyObject_New ( TeventSignal_Object , & TeventSignal_Type ) ;
if ( ret = = NULL ) {
PyErr_NoMemory ( ) ;
talloc_free ( sig ) ;
return NULL ;
}
ret - > signal = sig ;
return ( PyObject * ) ret ;
}
static void py_timer_handler ( struct tevent_context * ev ,
struct tevent_timer * te ,
struct timeval current_time ,
void * private_data )
{
2015-05-26 13:25:12 +02:00
TeventTimer_Object * self = private_data ;
PyObject * ret ;
2015-06-11 09:50:35 +02:00
ret = PyObject_CallFunction ( self - > callback , discard_const_p ( char , " l " ) , te ) ;
2015-05-26 13:25:12 +02:00
if ( ret = = NULL ) {
/* No Python stack to propagate exception to; just print traceback */
PyErr_PrintEx ( 0 ) ;
}
2010-09-23 16:50:36 -07:00
Py_XDECREF ( ret ) ;
}
2015-05-26 13:25:12 +02:00
static void py_tevent_timer_dealloc ( TeventTimer_Object * self )
2010-09-23 16:50:36 -07:00
{
2015-05-26 13:25:12 +02:00
if ( self - > timer ) {
talloc_free ( self - > timer ) ;
2010-09-23 16:50:36 -07:00
}
2015-05-26 13:25:12 +02:00
Py_DECREF ( self - > callback ) ;
PyObject_Del ( self ) ;
}
static int py_tevent_timer_traverse ( TeventTimer_Object * self , visitproc visit , void * arg )
{
Py_VISIT ( self - > callback ) ;
return 0 ;
}
static PyObject * py_tevent_timer_get_active ( TeventTimer_Object * self ) {
return PyBool_FromLong ( self - > timer ! = NULL ) ;
}
struct PyGetSetDef py_tevent_timer_getset [ ] = {
{
2015-06-11 09:50:35 +02:00
. name = discard_const_p ( char , " active " ) ,
2015-05-26 13:25:12 +02:00
. get = ( getter ) py_tevent_timer_get_active ,
2015-06-11 09:50:35 +02:00
. doc = discard_const_p ( char , " true if the timer is scheduled to run " ) ,
2015-05-26 13:25:12 +02:00
} ,
{ NULL } ,
} ;
static PyTypeObject TeventTimer_Type = {
. tp_name = " tevent.Timer " ,
. tp_basicsize = sizeof ( TeventTimer_Object ) ,
. tp_dealloc = ( destructor ) py_tevent_timer_dealloc ,
. tp_traverse = ( traverseproc ) py_tevent_timer_traverse ,
. tp_getset = py_tevent_timer_getset ,
. tp_flags = Py_TPFLAGS_DEFAULT ,
} ;
2015-06-11 09:51:19 +02:00
struct TeventTimer_Object_ref {
TeventTimer_Object * obj ;
} ;
static int TeventTimer_Object_ref_destructor ( struct TeventTimer_Object_ref * ref )
2015-05-26 13:25:12 +02:00
{
2015-06-11 09:51:19 +02:00
ref - > obj - > timer = NULL ;
Py_DECREF ( ref - > obj ) ;
2015-05-26 13:25:12 +02:00
return 0 ;
}
static PyObject * py_tevent_context_add_timer_internal ( TeventContext_Object * self ,
struct timeval next_event ,
PyObject * callback )
{
/* Ownership notes:
*
* There are 5 pieces in play ; two tevent contexts and 3 Python objects :
* - The tevent timer
* - The tevent context
* - The Python context - - " self "
* - The Python timer ( TeventTimer_Object ) - - " ret "
* - The Python callback function - - " callback "
*
* We only use the Python context for getting the tevent context ,
* afterwards it can be destroyed .
*
* The tevent context owns the tevent timer .
*
* The tevent timer holds a reference to the Python timer , so the Python
* timer must always outlive the tevent timer .
* The Python timer has a pointer to the tevent timer ; a destructor is
* used to set this to NULL when the tevent timer is deallocated .
*
* The tevent timer can be deallocated in these cases :
* 1 ) when the context is destroyed
* 2 ) after the event fires
* Posssibly , API might be added to cancel ( free the tevent timer ) .
*
* The Python timer holds a reference to the callback .
*/
TeventTimer_Object * ret ;
2015-06-11 09:51:19 +02:00
struct TeventTimer_Object_ref * ref ;
2010-09-23 16:50:36 -07:00
ret = PyObject_New ( TeventTimer_Object , & TeventTimer_Type ) ;
if ( ret = = NULL ) {
PyErr_NoMemory ( ) ;
return NULL ;
}
2015-05-26 13:25:12 +02:00
Py_INCREF ( callback ) ;
ret - > callback = callback ;
ret - > timer = tevent_add_timer ( self - > ev , NULL , next_event , py_timer_handler ,
ret ) ;
if ( ret - > timer = = NULL ) {
Py_DECREF ( ret ) ;
PyErr_SetString ( PyExc_RuntimeError , " Could not initialize timer " ) ;
return NULL ;
}
2015-06-11 09:51:19 +02:00
ref = talloc ( ret - > timer , struct TeventTimer_Object_ref ) ;
if ( ref = = NULL ) {
2015-05-26 13:25:12 +02:00
talloc_free ( ret - > timer ) ;
Py_DECREF ( ret ) ;
PyErr_SetString ( PyExc_RuntimeError , " Could not initialize timer " ) ;
return NULL ;
}
Py_INCREF ( ret ) ;
2015-06-11 09:51:19 +02:00
ref - > obj = ret ;
talloc_set_destructor ( ref , TeventTimer_Object_ref_destructor ) ;
2010-09-23 16:50:36 -07:00
return ( PyObject * ) ret ;
}
2015-05-26 13:25:12 +02:00
static PyObject * py_tevent_context_add_timer ( TeventContext_Object * self , PyObject * args )
{
struct timeval next_event ;
PyObject * callback ;
if ( ! PyArg_ParseTuple ( args , " lO " , & next_event , & callback ) )
return NULL ;
return py_tevent_context_add_timer_internal ( self , next_event , callback ) ;
}
static PyObject * py_tevent_context_add_timer_offset ( TeventContext_Object * self , PyObject * args )
{
struct timeval next_event ;
double offset ;
int seconds ;
PyObject * callback ;
if ( ! PyArg_ParseTuple ( args , " dO " , & offset , & callback ) )
return NULL ;
seconds = offset ;
offset - = seconds ;
next_event = tevent_timeval_current_ofs ( seconds , ( int ) ( offset * 1000000 ) ) ;
return py_tevent_context_add_timer_internal ( self , next_event , callback ) ;
}
2010-09-23 16:50:36 -07:00
static void py_fd_handler ( struct tevent_context * ev ,
struct tevent_fd * fde ,
uint16_t flags ,
void * private_data )
{
PyObject * callback = private_data , * ret ;
2015-06-11 09:50:35 +02:00
ret = PyObject_CallFunction ( callback , discard_const_p ( char , " i " ) , flags ) ;
2010-09-23 16:50:36 -07:00
Py_XDECREF ( ret ) ;
}
2015-05-22 13:29:11 +02:00
static void py_tevent_fp_dealloc ( TeventFd_Object * self )
{
talloc_free ( self - > fd ) ;
PyObject_Del ( self ) ;
}
static PyTypeObject TeventFd_Type = {
. tp_name = " tevent.Fd " ,
. tp_basicsize = sizeof ( TeventFd_Object ) ,
. tp_dealloc = ( destructor ) py_tevent_fp_dealloc ,
. tp_flags = Py_TPFLAGS_DEFAULT ,
} ;
2010-09-23 16:50:36 -07:00
static PyObject * py_tevent_context_add_fd ( TeventContext_Object * self , PyObject * args )
{
int fd , flags ;
PyObject * handler ;
struct tevent_fd * tfd ;
TeventFd_Object * ret ;
if ( ! PyArg_ParseTuple ( args , " iiO " , & fd , & flags , & handler ) )
return NULL ;
tfd = tevent_add_fd ( self - > ev , NULL , fd , flags , py_fd_handler , handler ) ;
if ( tfd = = NULL ) {
PyErr_SetNone ( PyExc_RuntimeError ) ;
return NULL ;
}
ret = PyObject_New ( TeventFd_Object , & TeventFd_Type ) ;
if ( ret = = NULL ) {
talloc_free ( tfd ) ;
return NULL ;
}
ret - > fd = tfd ;
return ( PyObject * ) ret ;
}
2010-09-23 14:28:02 -07:00
static PyMethodDef py_tevent_context_methods [ ] = {
{ " reinitialise " , ( PyCFunction ) py_tevent_context_reinitialise , METH_NOARGS ,
" S.reinitialise() " } ,
{ " wakeup_send " , ( PyCFunction ) py_tevent_context_wakeup_send ,
METH_VARARGS , " S.wakeup_send(wakeup_time) -> req " } ,
{ " loop_wait " , ( PyCFunction ) py_tevent_context_loop_wait ,
METH_NOARGS , " S.loop_wait() " } ,
{ " loop_once " , ( PyCFunction ) py_tevent_context_loop_once ,
METH_NOARGS , " S.loop_once() " } ,
{ " add_signal " , ( PyCFunction ) py_tevent_context_add_signal ,
METH_VARARGS , " S.add_signal(signum, sa_flags, handler) -> signal " } ,
{ " add_timer " , ( PyCFunction ) py_tevent_context_add_timer ,
METH_VARARGS , " S.add_timer(next_event, handler) -> timer " } ,
2015-05-26 13:25:12 +02:00
{ " add_timer_offset " , ( PyCFunction ) py_tevent_context_add_timer_offset ,
METH_VARARGS , " S.add_timer(offset_seconds, handler) -> timer " } ,
2010-09-23 14:28:02 -07:00
{ " add_fd " , ( PyCFunction ) py_tevent_context_add_fd ,
METH_VARARGS , " S.add_fd(fd, flags, handler) -> fd " } ,
{ NULL } ,
} ;
static PyObject * py_tevent_req_wakeup_recv ( PyObject * self )
{
/* FIXME */
Py_RETURN_NONE ;
}
static PyObject * py_tevent_req_received ( PyObject * self )
{
/* FIXME */
Py_RETURN_NONE ;
}
static PyObject * py_tevent_req_is_error ( PyObject * self )
{
/* FIXME */
Py_RETURN_NONE ;
}
static PyObject * py_tevent_req_poll ( PyObject * self )
{
/* FIXME */
Py_RETURN_NONE ;
}
static PyObject * py_tevent_req_is_in_progress ( PyObject * self )
{
/* FIXME */
Py_RETURN_NONE ;
}
static PyGetSetDef py_tevent_req_getsetters [ ] = {
2015-06-11 09:50:35 +02:00
{
. name = discard_const_p ( char , " in_progress " ) ,
. get = ( getter ) py_tevent_req_is_in_progress ,
. doc = discard_const_p ( char , " Whether the request is in progress " ) ,
} ,
2010-09-23 14:28:02 -07:00
{ NULL }
} ;
static PyObject * py_tevent_req_post ( PyObject * self , PyObject * args )
{
/* FIXME */
Py_RETURN_NONE ;
}
static PyObject * py_tevent_req_set_error ( PyObject * self , PyObject * args )
{
/* FIXME */
Py_RETURN_NONE ;
}
static PyObject * py_tevent_req_done ( PyObject * self )
{
/* FIXME */
Py_RETURN_NONE ;
}
static PyObject * py_tevent_req_notify_callback ( PyObject * self )
{
/* FIXME */
Py_RETURN_NONE ;
}
static PyObject * py_tevent_req_set_endtime ( PyObject * self , PyObject * args )
{
/* FIXME */
Py_RETURN_NONE ;
}
2010-09-23 16:50:36 -07:00
static PyObject * py_tevent_req_cancel ( TeventReq_Object * self )
2010-09-23 14:28:02 -07:00
{
2010-09-23 16:50:36 -07:00
if ( ! tevent_req_cancel ( self - > req ) ) {
PyErr_SetNone ( PyExc_RuntimeError ) ;
return NULL ;
}
2010-09-23 14:28:02 -07:00
Py_RETURN_NONE ;
}
static PyMethodDef py_tevent_req_methods [ ] = {
{ " wakeup_recv " , ( PyCFunction ) py_tevent_req_wakeup_recv , METH_NOARGS ,
" Wakeup received " } ,
{ " received " , ( PyCFunction ) py_tevent_req_received , METH_NOARGS ,
" Receive finished " } ,
{ " is_error " , ( PyCFunction ) py_tevent_req_is_error , METH_NOARGS ,
" is_error() -> (error, state) " } ,
{ " poll " , ( PyCFunction ) py_tevent_req_poll , METH_VARARGS ,
" poll(ctx) " } ,
{ " post " , ( PyCFunction ) py_tevent_req_post , METH_VARARGS ,
" post(ctx) -> req " } ,
{ " set_error " , ( PyCFunction ) py_tevent_req_set_error , METH_VARARGS ,
" set_error(error) " } ,
{ " done " , ( PyCFunction ) py_tevent_req_done , METH_NOARGS ,
" done() " } ,
{ " notify_callback " , ( PyCFunction ) py_tevent_req_notify_callback ,
METH_NOARGS , " notify_callback() " } ,
{ " set_endtime " , ( PyCFunction ) py_tevent_req_set_endtime ,
METH_VARARGS , " set_endtime(ctx, endtime) " } ,
{ " cancel " , ( PyCFunction ) py_tevent_req_cancel ,
METH_NOARGS , " cancel() " } ,
{ NULL }
} ;
2010-09-23 16:50:36 -07:00
static void py_tevent_req_dealloc ( TeventReq_Object * self )
2010-09-23 14:28:02 -07:00
{
2010-09-23 16:50:36 -07:00
talloc_free ( self - > req ) ;
PyObject_DEL ( self ) ;
}
static PyTypeObject TeventReq_Type = {
. tp_name = " tevent.Request " ,
. tp_basicsize = sizeof ( TeventReq_Object ) ,
. tp_methods = py_tevent_req_methods ,
. tp_dealloc = ( destructor ) py_tevent_req_dealloc ,
2010-09-23 17:40:35 -07:00
. tp_getset = py_tevent_req_getsetters ,
2010-09-23 16:50:36 -07:00
/* FIXME: .tp_new = py_tevent_req_new, */
} ;
static PyObject * py_tevent_queue_get_length ( TeventQueue_Object * self )
{
return PyInt_FromLong ( tevent_queue_length ( self - > queue ) ) ;
2010-09-23 14:28:02 -07:00
}
static PyGetSetDef py_tevent_queue_getsetters [ ] = {
2015-06-11 09:50:35 +02:00
{
. name = discard_const_p ( char , " length " ) ,
. get = ( getter ) py_tevent_queue_get_length ,
. doc = discard_const_p ( char , " The number of elements in the queue. " ) ,
} ,
2010-09-23 14:28:02 -07:00
{ NULL } ,
} ;
2010-09-23 16:50:36 -07:00
static void py_tevent_queue_dealloc ( TeventQueue_Object * self )
2010-09-23 14:28:02 -07:00
{
2010-09-23 16:50:36 -07:00
talloc_free ( self - > queue ) ;
PyObject_Del ( self ) ;
2010-09-23 14:28:02 -07:00
}
2010-09-23 16:50:36 -07:00
static PyTypeObject TeventQueue_Type = {
. tp_name = " tevent.Queue " ,
. tp_basicsize = sizeof ( TeventQueue_Object ) ,
. tp_dealloc = ( destructor ) py_tevent_queue_dealloc ,
. tp_flags = Py_TPFLAGS_DEFAULT ,
. tp_getset = py_tevent_queue_getsetters ,
. tp_methods = py_tevent_queue_methods ,
} ;
2010-09-23 14:28:02 -07:00
2010-09-23 16:50:36 -07:00
static PyObject * py_tevent_context_signal_support ( PyObject * _self )
2010-09-23 14:28:02 -07:00
{
2010-09-23 16:50:36 -07:00
TeventContext_Object * self = ( TeventContext_Object * ) _self ;
return PyBool_FromLong ( tevent_signal_support ( self - > ev ) ) ;
2010-09-23 14:28:02 -07:00
}
static PyGetSetDef py_tevent_context_getsetters [ ] = {
2015-06-11 09:50:35 +02:00
{
. name = discard_const_p ( char , " signal_support " ) ,
. get = ( getter ) py_tevent_context_signal_support ,
. doc = discard_const_p ( char , " if this platform and tevent context support signal handling " ) ,
} ,
2010-09-23 14:28:02 -07:00
{ NULL }
} ;
2010-09-23 16:50:36 -07:00
static void py_tevent_context_dealloc ( TeventContext_Object * self )
{
talloc_free ( self - > ev ) ;
2010-09-23 17:13:56 -07:00
PyObject_Del ( self ) ;
2010-09-23 16:50:36 -07:00
}
static PyObject * py_tevent_context_new ( PyTypeObject * type , PyObject * args , PyObject * kwargs )
{
2010-11-10 16:21:41 +01:00
const char * const kwnames [ ] = { " name " , NULL } ;
2010-09-23 16:50:36 -07:00
char * name = NULL ;
struct tevent_context * ev ;
TeventContext_Object * ret ;
2015-06-11 09:50:35 +02:00
if ( ! PyArg_ParseTupleAndKeywords ( args , kwargs , " |s " , discard_const_p ( char * , kwnames ) , & name ) )
2010-09-23 16:50:36 -07:00
return NULL ;
if ( name = = NULL ) {
ev = tevent_context_init ( NULL ) ;
} else {
ev = tevent_context_init_byname ( NULL , name ) ;
}
if ( ev = = NULL ) {
PyErr_SetNone ( PyExc_RuntimeError ) ;
return NULL ;
}
ret = PyObject_New ( TeventContext_Object , type ) ;
if ( ret = = NULL ) {
PyErr_NoMemory ( ) ;
talloc_free ( ev ) ;
return NULL ;
}
ret - > ev = ev ;
return ( PyObject * ) ret ;
}
2010-09-23 14:28:02 -07:00
static PyTypeObject TeventContext_Type = {
2012-02-01 00:58:32 +11:00
. tp_name = " tevent.Context " ,
2010-09-23 16:50:36 -07:00
. tp_new = py_tevent_context_new ,
. tp_basicsize = sizeof ( TeventContext_Object ) ,
. tp_dealloc = ( destructor ) py_tevent_context_dealloc ,
2010-09-23 14:28:02 -07:00
. tp_methods = py_tevent_context_methods ,
. tp_getset = py_tevent_context_getsetters ,
2010-09-23 16:50:36 -07:00
. tp_flags = Py_TPFLAGS_DEFAULT ,
2010-09-23 14:28:02 -07:00
} ;
static PyObject * py_set_default_backend ( PyObject * self , PyObject * args )
{
2010-09-23 16:50:36 -07:00
char * backend_name ;
if ( ! PyArg_ParseTuple ( args , " s " , & backend_name ) )
return NULL ;
tevent_set_default_backend ( backend_name ) ;
2010-09-23 14:28:02 -07:00
Py_RETURN_NONE ;
}
static PyObject * py_backend_list ( PyObject * self )
{
2014-12-04 12:44:56 +01:00
PyObject * ret = NULL ;
PyObject * string = NULL ;
int i , result ;
const char * * backends = NULL ;
2010-09-23 16:50:36 -07:00
ret = PyList_New ( 0 ) ;
if ( ret = = NULL ) {
return NULL ;
}
backends = tevent_backend_list ( NULL ) ;
if ( backends = = NULL ) {
PyErr_SetNone ( PyExc_RuntimeError ) ;
2014-12-04 12:44:56 +01:00
goto err ;
2010-09-23 16:50:36 -07:00
}
for ( i = 0 ; backends [ i ] ; i + + ) {
2015-05-22 11:47:56 +02:00
string = PyStr_FromString ( backends [ i ] ) ;
2014-12-04 12:44:56 +01:00
if ( ! string ) {
goto err ;
}
result = PyList_Append ( ret , string ) ;
if ( result ) {
goto err ;
}
Py_DECREF ( string ) ;
string = NULL ;
2010-09-23 16:50:36 -07:00
}
talloc_free ( backends ) ;
return ret ;
2014-12-04 12:44:56 +01:00
err :
Py_XDECREF ( ret ) ;
Py_XDECREF ( string ) ;
talloc_free ( backends ) ;
return NULL ;
2010-09-23 14:28:02 -07:00
}
static PyMethodDef tevent_methods [ ] = {
{ " register_backend " , ( PyCFunction ) py_register_backend , METH_VARARGS ,
" register_backend(backend) " } ,
{ " set_default_backend " , ( PyCFunction ) py_set_default_backend ,
METH_VARARGS , " set_default_backend(backend) " } ,
{ " backend_list " , ( PyCFunction ) py_backend_list ,
METH_NOARGS , " backend_list() -> list " } ,
{ NULL } ,
} ;
2015-05-22 11:47:56 +02:00
# define MODULE_DOC PyDoc_STR("Python wrapping of talloc-maintained objects.")
# if PY_MAJOR_VERSION >= 3
static struct PyModuleDef moduledef = {
PyModuleDef_HEAD_INIT ,
. m_name = " _tevent " ,
. m_doc = MODULE_DOC ,
. m_size = - 1 ,
. m_methods = tevent_methods ,
} ;
# endif
PyObject * module_init ( void ) ;
PyObject * module_init ( void )
2010-09-23 14:28:02 -07:00
{
PyObject * m ;
2010-09-23 16:50:36 -07:00
if ( PyType_Ready ( & TeventContext_Type ) < 0 )
2015-05-22 11:47:56 +02:00
return NULL ;
2010-09-23 16:50:36 -07:00
if ( PyType_Ready ( & TeventQueue_Type ) < 0 )
2015-05-22 11:47:56 +02:00
return NULL ;
2010-09-23 16:50:36 -07:00
if ( PyType_Ready ( & TeventReq_Type ) < 0 )
2015-05-22 11:47:56 +02:00
return NULL ;
2010-09-23 16:50:36 -07:00
if ( PyType_Ready ( & TeventSignal_Type ) < 0 )
2015-05-22 11:47:56 +02:00
return NULL ;
2010-09-23 16:50:36 -07:00
if ( PyType_Ready ( & TeventTimer_Type ) < 0 )
2015-05-22 11:47:56 +02:00
return NULL ;
2010-09-23 16:50:36 -07:00
if ( PyType_Ready ( & TeventFd_Type ) < 0 )
2015-05-22 11:47:56 +02:00
return NULL ;
2010-09-23 16:50:36 -07:00
2015-05-22 11:47:56 +02:00
# if PY_MAJOR_VERSION >= 3
m = PyModule_Create ( & moduledef ) ;
# else
m = Py_InitModule3 ( " _tevent " , tevent_methods , MODULE_DOC ) ;
# endif
2010-09-23 14:28:02 -07:00
if ( m = = NULL )
2015-05-22 11:47:56 +02:00
return NULL ;
2010-09-23 16:50:36 -07:00
Py_INCREF ( & TeventContext_Type ) ;
PyModule_AddObject ( m , " Context " , ( PyObject * ) & TeventContext_Type ) ;
Py_INCREF ( & TeventQueue_Type ) ;
PyModule_AddObject ( m , " Queue " , ( PyObject * ) & TeventQueue_Type ) ;
Py_INCREF ( & TeventReq_Type ) ;
PyModule_AddObject ( m , " Request " , ( PyObject * ) & TeventReq_Type ) ;
Py_INCREF ( & TeventSignal_Type ) ;
PyModule_AddObject ( m , " Signal " , ( PyObject * ) & TeventSignal_Type ) ;
Py_INCREF ( & TeventTimer_Type ) ;
PyModule_AddObject ( m , " Timer " , ( PyObject * ) & TeventTimer_Type ) ;
Py_INCREF ( & TeventFd_Type ) ;
PyModule_AddObject ( m , " Fd " , ( PyObject * ) & TeventFd_Type ) ;
2011-12-07 11:57:57 +01:00
2015-05-22 11:47:56 +02:00
PyModule_AddStringConstant ( m , " __version__ " , PACKAGE_VERSION ) ;
return m ;
}
# if PY_MAJOR_VERSION >= 3
PyMODINIT_FUNC PyInit__tevent ( void ) ;
PyMODINIT_FUNC PyInit__tevent ( void )
{
return module_init ( ) ;
}
# else
void init_tevent ( void ) ;
void init_tevent ( void )
{
module_init ( ) ;
2010-09-23 14:28:02 -07:00
}
2015-05-22 11:47:56 +02:00
# endif