Added debugging code for plug-in management

This commit is contained in:
Pierre Pronchery 2010-05-17 14:01:13 +00:00
parent 239d4e85ad
commit 5122bb6248

View File

@ -657,6 +657,7 @@ void phone_dialer_hangup(Phone * phone)
/* plugins */ /* plugins */
/* phone_load */
int phone_load(Phone * phone, char const * plugin) int phone_load(Phone * phone, char const * plugin)
{ {
Plugin * p; Plugin * p;
@ -674,12 +675,16 @@ int phone_load(Phone * phone, char const * plugin)
return phone_error(NULL, error_get(), -1); return phone_error(NULL, error_get(), -1);
} }
pp->helper = &phone->helper; pp->helper = &phone->helper;
if((pp->init != NULL && pp->init(pp) != 0) if(pp->init != NULL && pp->init(pp) != 0)
|| (q = realloc(phone->plugins, sizeof(*q)
* (phone->plugins_cnt + 1))) == NULL)
{ {
plugin_delete(p); plugin_delete(p);
return -1; /* XXX report error */ return phone_error(NULL, error_get(), -1);
}
if((q = realloc(phone->plugins, sizeof(*q) * (phone->plugins_cnt + 1)))
== NULL)
{
plugin_delete(p);
return phone_error(NULL, strerror(errno), -1);
} }
phone->plugins = q; phone->plugins = q;
phone->plugins[phone->plugins_cnt].p = p; phone->plugins[phone->plugins_cnt].p = p;
@ -1165,6 +1170,7 @@ static struct
static void _on_debug_gsm_execute(gpointer data); static void _on_debug_gsm_execute(gpointer data);
static void _on_debug_queue_execute(gpointer data); static void _on_debug_queue_execute(gpointer data);
static void _on_debug_plugin_load(gpointer data); static void _on_debug_plugin_load(gpointer data);
static void _on_debug_plugin_unload_all(gpointer data);
void phone_show_debug(Phone * phone, gboolean show) void phone_show_debug(Phone * phone, gboolean show)
{ {
@ -1196,7 +1202,6 @@ void phone_show_debug(Phone * phone, gboolean show)
gtk_combo_box_set_active(GTK_COMBO_BOX(phone->de_gsm), 0); gtk_combo_box_set_active(GTK_COMBO_BOX(phone->de_gsm), 0);
gtk_box_pack_start(GTK_BOX(hbox), phone->de_gsm, TRUE, TRUE, 4); gtk_box_pack_start(GTK_BOX(hbox), phone->de_gsm, TRUE, TRUE, 4);
widget = gtk_button_new_from_stock(GTK_STOCK_EXECUTE); widget = gtk_button_new_from_stock(GTK_STOCK_EXECUTE);
gtk_button_set_relief(GTK_BUTTON(widget), GTK_RELIEF_NONE);
g_signal_connect_swapped(G_OBJECT(widget), "clicked", g_signal_connect_swapped(G_OBJECT(widget), "clicked",
G_CALLBACK(_on_debug_gsm_execute), phone); G_CALLBACK(_on_debug_gsm_execute), phone);
gtk_box_pack_start(GTK_BOX(hbox), widget, FALSE, TRUE, 0); gtk_box_pack_start(GTK_BOX(hbox), widget, FALSE, TRUE, 0);
@ -1212,7 +1217,6 @@ void phone_show_debug(Phone * phone, gboolean show)
gtk_box_pack_start(GTK_BOX(hbox), phone->de_queue, TRUE, TRUE, gtk_box_pack_start(GTK_BOX(hbox), phone->de_queue, TRUE, TRUE,
4); 4);
widget = gtk_button_new_from_stock(GTK_STOCK_EXECUTE); widget = gtk_button_new_from_stock(GTK_STOCK_EXECUTE);
gtk_button_set_relief(GTK_BUTTON(widget), GTK_RELIEF_NONE);
g_signal_connect_swapped(G_OBJECT(widget), "clicked", g_signal_connect_swapped(G_OBJECT(widget), "clicked",
G_CALLBACK(_on_debug_queue_execute), phone); G_CALLBACK(_on_debug_queue_execute), phone);
gtk_box_pack_start(GTK_BOX(hbox), widget, FALSE, TRUE, 0); gtk_box_pack_start(GTK_BOX(hbox), widget, FALSE, TRUE, 0);
@ -1228,10 +1232,13 @@ void phone_show_debug(Phone * phone, gboolean show)
gtk_box_pack_start(GTK_BOX(hbox), phone->de_plugin, TRUE, TRUE, gtk_box_pack_start(GTK_BOX(hbox), phone->de_plugin, TRUE, TRUE,
4); 4);
widget = gtk_button_new_from_stock(GTK_STOCK_EXECUTE); widget = gtk_button_new_from_stock(GTK_STOCK_EXECUTE);
gtk_button_set_relief(GTK_BUTTON(widget), GTK_RELIEF_NONE);
g_signal_connect_swapped(G_OBJECT(widget), "clicked", g_signal_connect_swapped(G_OBJECT(widget), "clicked",
G_CALLBACK(_on_debug_plugin_load), phone); G_CALLBACK(_on_debug_plugin_load), phone);
gtk_box_pack_start(GTK_BOX(hbox), widget, FALSE, TRUE, 0); gtk_box_pack_start(GTK_BOX(hbox), widget, FALSE, TRUE, 0);
widget = gtk_button_new_with_label("Unload all");
g_signal_connect_swapped(G_OBJECT(widget), "clicked",
G_CALLBACK(_on_debug_plugin_unload_all), phone);
gtk_box_pack_start(GTK_BOX(hbox), widget, FALSE, TRUE, 0);
gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, TRUE, 0); gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, TRUE, 0);
/* quit */ /* quit */
hbox = gtk_hbox_new(FALSE, 0); hbox = gtk_hbox_new(FALSE, 0);
@ -1286,6 +1293,23 @@ static void _on_debug_plugin_load(gpointer data)
phone_load(phone, text); /* we can ignore errors */ phone_load(phone, text); /* we can ignore errors */
} }
static void _on_debug_plugin_unload_all(gpointer data)
{
Phone * phone = data;
size_t i;
PhonePlugin * plugin;
for(i = 0; i < phone->plugins_cnt; i++)
{
plugin = phone->plugins[i].pp;
if(plugin->destroy != NULL && plugin->destroy(plugin) != 0)
phone_error(NULL, error_get(), 0);
}
phone->plugins_cnt = 0;
free(phone->plugins);
phone->plugins = NULL;
}
static int _gsm_fetch_message_list_all(GSM * gsm) static int _gsm_fetch_message_list_all(GSM * gsm)
{ {
return gsm_fetch_message_list(gsm, GSM_MESSAGE_LIST_ALL); return gsm_fetch_message_list(gsm, GSM_MESSAGE_LIST_ALL);