2008-06-14 19:23:31 +04:00
/*
Unix SMB / CIFS implementation .
Copyright ( C ) Andrew Tridgell 2003
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation ; either version 3 of the License , or
( at your option ) any later version .
This program 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 General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
# include "includes.h"
2008-12-26 16:09:02 +03:00
# include <events.h>
# include <events_internal.h>
2008-06-14 19:23:31 +04:00
2008-06-14 21:00:53 +04:00
/*
this is used to catch debug messages from events
*/
static void ev_wrap_debug ( void * context , enum ev_debug_level level ,
const char * fmt , va_list ap ) PRINTF_ATTRIBUTE ( 3 , 0 ) ;
static void ev_wrap_debug ( void * context , enum ev_debug_level level ,
const char * fmt , va_list ap )
{
int samba_level = - 1 ;
char * s = NULL ;
switch ( level ) {
case EV_DEBUG_FATAL :
samba_level = 0 ;
break ;
case EV_DEBUG_ERROR :
samba_level = 1 ;
break ;
case EV_DEBUG_WARNING :
samba_level = 2 ;
break ;
case EV_DEBUG_TRACE :
samba_level = 5 ;
break ;
} ;
vasprintf ( & s , fmt , ap ) ;
if ( ! s ) return ;
DEBUG ( samba_level , ( " events: %s \n " , s ) ) ;
free ( s ) ;
}
/*
create a event_context structure . This must be the first events
call , and all subsequent calls pass this event_context as the first
element . Event handlers also receive this as their first argument .
This samba4 specific call sets the samba4 debug handler .
*/
2008-12-29 22:24:57 +03:00
struct tevent_context * s4_event_context_init ( TALLOC_CTX * mem_ctx )
2008-06-14 21:00:53 +04:00
{
2008-12-29 22:24:57 +03:00
struct tevent_context * ev ;
2008-06-14 21:00:53 +04:00
ev = event_context_init_byname ( mem_ctx , NULL ) ;
if ( ev ) {
ev_set_debug ( ev , ev_wrap_debug , NULL ) ;
}
return ev ;
}
2009-01-02 14:06:39 +03:00
/*
find an event context that is a parent of the given memory context ,
or create a new event context as a child of the given context if
none is found
This should be used in preference to event_context_init ( ) in places
where you would prefer to use the existing event context if possible
( which is most situations )
*/
struct tevent_context * event_context_find ( TALLOC_CTX * mem_ctx )
{
struct tevent_context * ev = talloc_find_parent_bytype ( mem_ctx , struct tevent_context ) ;
if ( ev = = NULL ) {
ev = event_context_init ( mem_ctx ) ;
}
return ev ;
}