Get event_t off of halloc (!)

This commit is contained in:
ridiculousfish 2012-02-08 19:02:25 -08:00
parent b3d0561c09
commit b6bc4381fb
8 changed files with 110 additions and 186 deletions

View file

@ -1081,10 +1081,9 @@ static void functions_def( wchar_t *name, string_buffer_t *out )
const wchar_t *desc = function_get_desc( name ); const wchar_t *desc = function_get_desc( name );
const wchar_t *def = function_get_definition(name); const wchar_t *def = function_get_definition(name);
event_t search; event_t search(EVENT_ANY);
search.function_name = name; search.function_name = name;
search.type = EVENT_ANY;
std::vector<event_t *> ev; std::vector<event_t *> ev;
event_get( &search, &ev ); event_get( &search, &ev );
@ -1120,7 +1119,7 @@ static void functions_def( wchar_t *name, string_buffer_t *out )
case EVENT_VARIABLE: case EVENT_VARIABLE:
{ {
sb_printf( out, L" --on-variable %ls", next->param1.variable ); sb_printf( out, L" --on-variable %ls", next->str_param1.c_str() );
break; break;
} }
@ -1143,7 +1142,7 @@ static void functions_def( wchar_t *name, string_buffer_t *out )
case EVENT_GENERIC: case EVENT_GENERIC:
{ {
sb_printf( out, L" --on-event %ls", next->param1.param ); sb_printf( out, L" --on-event %ls", next->str_param1.c_str() );
break; break;
} }
@ -1456,7 +1455,7 @@ static int builtin_function( parser_t &parser, wchar_t **argv )
int argc = builtin_count_args( argv ); int argc = builtin_count_args( argv );
int res=STATUS_BUILTIN_OK; int res=STATUS_BUILTIN_OK;
wchar_t *desc=0; wchar_t *desc=0;
std::vector<event_t *> events; std::vector<event_t> events;
array_list_t *named_arguments=0; array_list_t *named_arguments=0;
wchar_t *name = 0; wchar_t *name = 0;
int shadows = 1; int shadows = 1;
@ -1542,7 +1541,6 @@ static int builtin_function( parser_t &parser, wchar_t **argv )
case 's': case 's':
{ {
int sig = wcs2sig( woptarg ); int sig = wcs2sig( woptarg );
event_t *e;
if( sig < 0 ) if( sig < 0 )
{ {
@ -1553,21 +1551,12 @@ static int builtin_function( parser_t &parser, wchar_t **argv )
res=1; res=1;
break; break;
} }
events.push_back(event_t::signal_event(sig));
e = (event_t *)halloc( parser.current_block, sizeof(event_t));
if( !e )
DIE_MEM();
e->type = EVENT_SIGNAL;
e->param1.signal = sig;
e->function_name=0;
events.push_back(e);
break; break;
} }
case 'v': case 'v':
{ {
event_t *e;
if( wcsvarname( woptarg ) ) if( wcsvarname( woptarg ) )
{ {
sb_printf( sb_err, sb_printf( sb_err,
@ -1578,26 +1567,14 @@ static int builtin_function( parser_t &parser, wchar_t **argv )
break; break;
} }
e = (event_t *)halloc( parser.current_block, sizeof(event_t)); events.push_back(event_t::variable_event(woptarg));
e->type = EVENT_VARIABLE;
e->param1.variable = halloc_wcsdup( parser.current_block, woptarg );
e->function_name=0;
events.push_back(e);
break; break;
} }
case 'e': case 'e':
{ {
event_t *e; events.push_back(event_t::generic_event(woptarg));
e = (event_t *)halloc( parser.current_block, sizeof(event_t));
e->type = EVENT_GENERIC;
e->param1.param = halloc_wcsdup( parser.current_block, woptarg );
e->function_name=0;
events.push_back(e);
break; break;
} }
@ -1606,11 +1583,7 @@ static int builtin_function( parser_t &parser, wchar_t **argv )
{ {
pid_t pid; pid_t pid;
wchar_t *end; wchar_t *end;
event_t *e; event_t e(EVENT_ANY);
e = (event_t *)halloc( parser.current_block, sizeof(event_t));
if( !e )
DIE_MEM();
if( ( opt == 'j' ) && if( ( opt == 'j' ) &&
( wcscasecmp( woptarg, L"caller" ) == 0 ) ) ( wcscasecmp( woptarg, L"caller" ) == 0 ) )
@ -1643,8 +1616,8 @@ static int builtin_function( parser_t &parser, wchar_t **argv )
} }
else else
{ {
e->type = EVENT_JOB_ID; e.type = EVENT_JOB_ID;
e->param1.job_id = job_id; e.param1.job_id = job_id;
} }
} }
@ -1663,16 +1636,15 @@ static int builtin_function( parser_t &parser, wchar_t **argv )
} }
e->type = EVENT_EXIT; e.type = EVENT_EXIT;
e->param1.pid = (opt=='j'?-1:1)*abs(pid); e.param1.pid = (opt=='j'?-1:1)*abs(pid);
} }
if( res ) if( res )
{ {
free( e ); /* nothing */
} }
else else
{ {
e->function_name=0;
events.push_back(e); events.push_back(e);
} }
break; break;
@ -1800,14 +1772,14 @@ static int builtin_function( parser_t &parser, wchar_t **argv )
d->name=halloc_wcsdup( parser.current_block, name); d->name=halloc_wcsdup( parser.current_block, name);
d->description=desc?halloc_wcsdup( parser.current_block, desc):0; d->description=desc?halloc_wcsdup( parser.current_block, desc):0;
d->events = events; d->events.swap(events);
d->named_arguments = named_arguments; d->named_arguments = named_arguments;
d->shadows = shadows; d->shadows = shadows;
for( size_t i=0; i<events.size(); i++ ) for( size_t i=0; i<d->events.size(); i++ )
{ {
event_t *e = events.at(i); event_t &e = d->events.at(i);
e->function_name = d->name; e.function_name = d->name;
} }
parser.current_block->function_data.reset(d); parser.current_block->function_data.reset(d);

35
env.cpp
View file

@ -393,21 +393,15 @@ static void universal_callback( int type,
if( str ) if( str )
{ {
event_t ev;
has_changed=1; has_changed=1;
ev.type=EVENT_VARIABLE; event_t ev = event_t::variable_event(name);
ev.param1.variable=name; ev.arguments.reset(new wcstring_list_t());
ev.function_name=0;
ev.arguments = new wcstring_list_t();
ev.arguments->push_back(L"VARIABLE"); ev.arguments->push_back(L"VARIABLE");
ev.arguments->push_back(str); ev.arguments->push_back(str);
ev.arguments->push_back(name); ev.arguments->push_back(name);
event_fire( &ev ); event_fire( &ev );
delete ev.arguments; ev.arguments.reset(NULL);
ev.arguments = NULL;
} }
} }
@ -760,7 +754,6 @@ int env_set( const wchar_t *key,
var_entry_t *e=0; var_entry_t *e=0;
int done=0; int done=0;
event_t ev;
int is_universal = 0; int is_universal = 0;
CHECK( key, ENV_INVALID ); CHECK( key, ENV_INVALID );
@ -981,11 +974,8 @@ int env_set( const wchar_t *key,
if( !is_universal ) if( !is_universal )
{ {
ev.type=EVENT_VARIABLE; event_t ev = event_t::variable_event(key);
ev.param1.variable = key; ev.arguments.reset(new wcstring_list_t);
ev.function_name = 0;
ev.arguments = new wcstring_list_t;
ev.arguments->push_back(L"VARIABLE"); ev.arguments->push_back(L"VARIABLE");
ev.arguments->push_back(L"SET"); ev.arguments->push_back(L"SET");
ev.arguments->push_back(key); ev.arguments->push_back(key);
@ -993,8 +983,7 @@ int env_set( const wchar_t *key,
// debug( 1, L"env_set: fire events on variable %ls", key ); // debug( 1, L"env_set: fire events on variable %ls", key );
event_fire( &ev ); event_fire( &ev );
// debug( 1, L"env_set: return from event firing" ); // debug( 1, L"env_set: return from event firing" );
delete ev.arguments; ev.arguments.reset(NULL);
ev.arguments = NULL;
} }
if( is_locale( key ) ) if( is_locale( key ) )
@ -1085,21 +1074,15 @@ int env_remove( const wchar_t *key, int var_mode )
if( try_remove( first_node, key, var_mode ) ) if( try_remove( first_node, key, var_mode ) )
{ {
event_t ev; event_t ev = event_t::variable_event(key);
ev.arguments.reset(new wcstring_list_t);
ev.type=EVENT_VARIABLE;
ev.param1.variable=key;
ev.function_name=0;
ev.arguments = new wcstring_list_t;
ev.arguments->push_back(L"VARIABLE"); ev.arguments->push_back(L"VARIABLE");
ev.arguments->push_back(L"ERASE"); ev.arguments->push_back(L"ERASE");
ev.arguments->push_back(key); ev.arguments->push_back(key);
event_fire( &ev ); event_fire( &ev );
delete ev.arguments; ev.arguments.reset(NULL);
ev.arguments = NULL;
erased = 1; erased = 1;
} }
} }

106
event.cpp
View file

@ -88,9 +88,9 @@ static event_list_t blocked;
static int event_match( event_t *classv, event_t *instance ) static int event_match( event_t *classv, event_t *instance )
{ {
if( classv->function_name && instance->function_name ) if( ! classv->function_name.empty() && ! instance->function_name.empty() )
{ {
if( wcscmp( classv->function_name, instance->function_name ) != 0 ) if( classv->function_name == instance->function_name )
return 0; return 0;
} }
@ -110,8 +110,7 @@ static int event_match( event_t *classv, event_t *instance )
return classv->param1.signal == instance->param1.signal; return classv->param1.signal == instance->param1.signal;
case EVENT_VARIABLE: case EVENT_VARIABLE:
return wcscmp( instance->param1.variable, return instance->str_param1 == classv->str_param1;
classv->param1.variable )==0;
case EVENT_EXIT: case EVENT_EXIT:
if( classv->param1.pid == EVENT_ANY_PID ) if( classv->param1.pid == EVENT_ANY_PID )
@ -122,8 +121,7 @@ static int event_match( event_t *classv, event_t *instance )
return classv->param1.job_id == instance->param1.job_id; return classv->param1.job_id == instance->param1.job_id;
case EVENT_GENERIC: case EVENT_GENERIC:
return wcscmp( instance->param1.param, return instance->str_param1 == classv->str_param1;
classv->param1.param )==0;
} }
@ -140,23 +138,10 @@ static int event_match( event_t *classv, event_t *instance )
*/ */
static event_t *event_copy( event_t *event, int copy_arguments ) static event_t *event_copy( event_t *event, int copy_arguments )
{ {
event_t *e = (event_t *)malloc( sizeof( event_t ) ); event_t *e = new event_t(*event);
if( !e ) e->arguments.reset(new wcstring_list_t);
DIE_MEM(); if( copy_arguments && event->arguments.get() != NULL )
memcpy( e, event, sizeof(event_t));
if( e->function_name )
e->function_name = wcsdup( e->function_name );
if( e->type == EVENT_VARIABLE )
e->param1.variable = wcsdup( e->param1.variable );
else if( e->type == EVENT_GENERIC )
e->param1.param = wcsdup( e->param1.param );
e->arguments = new wcstring_list_t;
if( copy_arguments && event->arguments )
{ {
*(e->arguments) = *(event->arguments); *(e->arguments) = *(event->arguments);
} }
@ -193,7 +178,7 @@ wcstring event_get_desc( event_t *e )
break; break;
case EVENT_VARIABLE: case EVENT_VARIABLE:
result = format_string(_(L"handler for variable '%ls'"), e->param1.variable ); result = format_string(_(L"handler for variable '%ls'"), e->str_param1.c_str() );
break; break;
case EVENT_EXIT: case EVENT_EXIT:
@ -224,7 +209,7 @@ wcstring event_get_desc( event_t *e )
} }
case EVENT_GENERIC: case EVENT_GENERIC:
result = format_string(_(L"handler for generic event '%ls'"), e->param1.param ); result = format_string(_(L"handler for generic event '%ls'"), e->str_param1.c_str() );
break; break;
default: default:
@ -257,7 +242,6 @@ void event_remove( event_t *criterion )
{ {
size_t i; size_t i;
event_list_t new_list; event_list_t new_list;
event_t e;
CHECK( criterion, ); CHECK( criterion, );
@ -287,10 +271,7 @@ void event_remove( event_t *criterion )
*/ */
if( n->type == EVENT_SIGNAL ) if( n->type == EVENT_SIGNAL )
{ {
e.type = EVENT_SIGNAL; event_t e = event_t::signal_event(n->param1.signal);
e.param1.signal = n->param1.signal;
e.function_name = 0;
if( event_get( &e, 0 ) == 1 ) if( event_get( &e, 0 ) == 1 )
{ {
signal_handle( e.param1.signal, 0 ); signal_handle( e.param1.signal, 0 );
@ -410,7 +391,7 @@ static void event_fire_internal( event_t *event )
*/ */
wcstring buffer = criterion->function_name; wcstring buffer = criterion->function_name;
if (event->arguments) if (event->arguments.get())
{ {
for( j=0; j< event->arguments->size(); j++ ) for( j=0; j< event->arguments->size(); j++ )
{ {
@ -482,8 +463,6 @@ static void event_fire_delayed()
while( sig_list[active_list].count > 0 ) while( sig_list[active_list].count > 0 )
{ {
signal_list_t *lst; signal_list_t *lst;
event_t e;
e.arguments = new wcstring_list_t(1); //one element
/* /*
Switch signal lists Switch signal lists
@ -495,9 +474,8 @@ static void event_fire_delayed()
/* /*
Set up Set up
*/ */
e.type=EVENT_SIGNAL; event_t e = event_t::signal_event(0);
e.function_name=0; e.arguments.reset(new wcstring_list_t(1)); //one element
lst = &sig_list[1-active_list]; lst = &sig_list[1-active_list];
if( lst->overflow ) if( lst->overflow )
@ -522,7 +500,7 @@ static void event_fire_delayed()
} }
} }
delete e.arguments; e.arguments.reset(NULL);
} }
} }
@ -586,39 +564,20 @@ void event_destroy()
void event_free( event_t *e ) void event_free( event_t *e )
{ {
CHECK( e, ); CHECK( e, );
delete e;
/*
When apropriate, we clear the argument vector
*/
if (e->arguments) delete e->arguments;
e->arguments = NULL;
free( (void *)e->function_name );
if( e->type == EVENT_VARIABLE )
{
free( (void *)e->param1.variable );
}
else if( e->type == EVENT_GENERIC )
{
free( (void *)e->param1.param );
}
free( e );
} }
void event_fire_generic_internal(const wchar_t *name, ...) void event_fire_generic_internal(const wchar_t *name, ...)
{ {
event_t ev;
va_list va; va_list va;
wchar_t *arg; wchar_t *arg;
CHECK( name, ); CHECK( name, );
ev.type = EVENT_GENERIC; event_t ev(EVENT_GENERIC);
ev.param1.param = name; ev.str_param1 = name;
ev.function_name=0; ev.arguments.reset(new wcstring_list_t);
ev.arguments = new wcstring_list_t;
va_start( va, name ); va_start( va, name );
while( (arg=va_arg(va, wchar_t *) )!= 0 ) while( (arg=va_arg(va, wchar_t *) )!= 0 )
{ {
@ -627,9 +586,34 @@ void event_fire_generic_internal(const wchar_t *name, ...)
va_end( va ); va_end( va );
event_fire( &ev ); event_fire( &ev );
delete ev.arguments; ev.arguments.reset(NULL);
ev.arguments = NULL;
} }
event_t event_t::signal_event(int sig) {
event_t event(EVENT_SIGNAL);
event.param1.signal = sig;
return event;
}
event_t event_t::variable_event(const wcstring &str) {
event_t event(EVENT_VARIABLE);
event.str_param1 = str;
return event;
}
event_t event_t::generic_event(const wcstring &str) {
event_t event(EVENT_GENERIC);
event.str_param1 = str;
return event;
}
event_t::event_t(const event_t &x) :
type(x.type),
param1(x.param1),
str_param1(x.str_param1),
function_name(x.function_name)
{
const wcstring_list_t *ptr = x.arguments.get();
if (ptr)
arguments.reset(new wcstring_list_t(*ptr));
}

58
event.h
View file

@ -53,47 +53,45 @@ struct event_t
*/ */
int type; int type;
/** /** The type-specific parameter. The int types are one of the following:
The type-specific parameter
*/
union
{
/**
Signal number for signal-type events.Use EVENT_ANY_SIGNAL
to match any signal
*/
int signal;
/**
Variable name for variable-type events.
*/
const wchar_t *variable;
/**
Process id for process-type events. Use EVENT_ANY_PID to
match any pid.
*/
pid_t pid;
/**
Job id for EVENT_JOB_ID type events
*/
int job_id;
/**
The parameter describing this generic event
*/
const wchar_t *param;
} param1; signal: Signal number for signal-type events.Use EVENT_ANY_SIGNAL to match any signal
pid: Process id for process-type events. Use EVENT_ANY_PID to match any pid.
job_id: Job id for EVENT_JOB_ID type events
*/
union {
int signal;
int job_id;
pid_t pid;
} param1;
/** The string types are one of the following:
variable: Variable name for variable-type events.
param: The parameter describing this generic event.
*/
wcstring str_param1;
/** /**
The name of the event handler function The name of the event handler function
*/ */
const wchar_t *function_name; wcstring function_name;
/** /**
The argument list. Only used when sending a new event using The argument list. Only used when sending a new event using
event_fire. In all other situations, the value of this variable event_fire. In all other situations, the value of this variable
is ignored. is ignored.
*/ */
wcstring_list_t *arguments; std::auto_ptr<wcstring_list_t> arguments;
event_t(int t) : type(t), param1() { }
/** Copy constructor */
event_t(const event_t &x);
static event_t signal_event(int sig);
static event_t variable_event(const wcstring &str);
static event_t generic_event(const wcstring &str);
}; };
/** /**

View file

@ -191,7 +191,7 @@ void function_add( function_data_t *data, const parser_t &parser )
for( size_t i=0; i< data->events.size(); i++ ) for( size_t i=0; i< data->events.size(); i++ )
{ {
event_add_handler( data->events.at(i) ); event_add_handler( &data->events.at(i) );
} }
} }
@ -220,8 +220,7 @@ static bool function_remove_ignore_autoload(const wcstring &name)
bool erased = (loaded_functions.erase(name) > 0); bool erased = (loaded_functions.erase(name) > 0);
if (erased) { if (erased) {
event_t ev; event_t ev(EVENT_ANY);
ev.type=EVENT_ANY;
ev.function_name=name.c_str(); ev.function_name=name.c_str();
event_remove( &ev ); event_remove( &ev );
} }

View file

@ -46,7 +46,7 @@ struct function_data_t
/** /**
List of all event handlers for this function List of all event handlers for this function
*/ */
std::vector<event_t *> events; std::vector<event_t> events;
/** /**
List of all named arguments for this function List of all named arguments for this function
*/ */

View file

@ -117,7 +117,7 @@ int no_exec=0;
/** /**
The event variable used to send all process event The event variable used to send all process event
*/ */
static event_t event; static event_t event(0);
/** /**
Stringbuffer used to create arguments when firing events Stringbuffer used to create arguments when firing events
@ -138,7 +138,7 @@ void proc_init()
{ {
interactive_stack = al_halloc( global_context ); interactive_stack = al_halloc( global_context );
proc_push_interactive( 0 ); proc_push_interactive( 0 );
event.arguments = new wcstring_list_t; event.arguments.reset(new wcstring_list_t);
sb_init( &event_pid ); sb_init( &event_pid );
sb_init( &event_status ); sb_init( &event_status );
} }
@ -210,8 +210,7 @@ void process_t::set_argv(const wcstring_list_t &argv) {
void proc_destroy() void proc_destroy()
{ {
delete event.arguments; event.arguments.reset(NULL);
event.arguments = NULL;
sb_destroy( &event_pid ); sb_destroy( &event_pid );
sb_destroy( &event_status ); sb_destroy( &event_status );
job_list_t &jobs = job_list(); job_list_t &jobs = job_list();

View file

@ -427,15 +427,9 @@ const wchar_t *signal_get_desc( int sig )
*/ */
static void default_handler(int signal, siginfo_t *info, void *context) static void default_handler(int signal, siginfo_t *info, void *context)
{ {
event_t e; event_t e = event_t::signal_event(signal);
e.type=EVENT_SIGNAL;
e.param1.signal = signal;
e.function_name=0;
if( event_get( &e, 0 ) ) if( event_get( &e, 0 ) )
{ {
event_fire( &e ); event_fire( &e );
} }
} }
@ -455,12 +449,7 @@ static void handle_winch( int sig, siginfo_t *info, void *context )
*/ */
static void handle_hup( int sig, siginfo_t *info, void *context ) static void handle_hup( int sig, siginfo_t *info, void *context )
{ {
event_t e; event_t e = event_t::signal_event(SIGHUP);
e.type=EVENT_SIGNAL;
e.param1.signal = SIGHUP;
e.function_name=0;
if( event_get( &e, 0 ) ) if( event_get( &e, 0 ) )
{ {
default_handler( sig, 0, 0 ); default_handler( sig, 0, 0 );