realised we need to approve if the dialog will close on an ok - as there may

be an error and we need to complain to the user. add some comments too.


SVN revision: 17533
This commit is contained in:
Carsten Haitzler 2005-10-14 09:48:13 +00:00
parent d41a915bf9
commit 510d2b7719
3 changed files with 27 additions and 11 deletions

View File

@ -130,13 +130,14 @@ static void
_e_config_dialog_cb_ok(void *data, E_Dialog *dia) _e_config_dialog_cb_ok(void *data, E_Dialog *dia)
{ {
E_Config_Dialog *cfd; E_Config_Dialog *cfd;
int ok = 0;
cfd = dia->data; cfd = dia->data;
if (cfd->view_type == E_CONFIG_DIALOG_CFDATA_TYPE_BASIC) if (cfd->view_type == E_CONFIG_DIALOG_CFDATA_TYPE_BASIC)
cfd->view.basic.apply_cfdata(cfd, cfd->cfdata); ok = cfd->view.basic.apply_cfdata(cfd, cfd->cfdata);
else else
cfd->view.advanced.apply_cfdata(cfd, cfd->cfdata); ok = cfd->view.advanced.apply_cfdata(cfd, cfd->cfdata);
e_object_del(E_OBJECT(cfd)); if (ok) e_object_del(E_OBJECT(cfd));
} }
static void static void

View File

@ -23,7 +23,7 @@ struct _E_Config_Dialog_View
void *(*create_cfdata) (E_Config_Dialog *cfd); void *(*create_cfdata) (E_Config_Dialog *cfd);
void (*free_cfdata) (E_Config_Dialog *cfd, void *cfdata); void (*free_cfdata) (E_Config_Dialog *cfd, void *cfdata);
struct { struct {
void (*apply_cfdata) (E_Config_Dialog *cfd, void *cfdata); int (*apply_cfdata) (E_Config_Dialog *cfd, void *cfdata);
Evas_Object *(*create_widgets) (E_Config_Dialog *cfd, Evas *evas, void *cfdata); Evas_Object *(*create_widgets) (E_Config_Dialog *cfd, Evas *evas, void *cfdata);
} basic, advanced; } basic, advanced;
}; };

View File

@ -3,16 +3,17 @@
*/ */
#include "e.h" #include "e.h"
/* PROTOTYPES */ /* PROTOTYPES - same all the time */
typedef struct _CFData CFData; typedef struct _CFData CFData;
static void *_create_data(E_Config_Dialog *cfd); static void *_create_data(E_Config_Dialog *cfd);
static void _free_data(E_Config_Dialog *cfd, CFData *cfdata); static void _free_data(E_Config_Dialog *cfd, CFData *cfdata);
static void _basic_apply_data(E_Config_Dialog *cfd, CFData *cfdata); static int _basic_apply_data(E_Config_Dialog *cfd, CFData *cfdata);
static void _advanced_apply_data(E_Config_Dialog *cfd, CFData *cfdata); static int _advanced_apply_data(E_Config_Dialog *cfd, CFData *cfdata);
static Evas_Object *_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata); static Evas_Object *_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata);
static Evas_Object *_advanced_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata); static Evas_Object *_advanced_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata);
/* Actual config data we will be playing with whil the dialog is active */
struct _CFData struct _CFData
{ {
/*- BASIC -*/ /*- BASIC -*/
@ -25,7 +26,9 @@ struct _CFData
int always_click_to_focus; int always_click_to_focus;
}; };
void e_int_config_focus(E_Container *con) /* a nice easy setup function that does the dirty work */
void
e_int_config_focus(E_Container *con)
{ {
E_Config_Dialog *cfd; E_Config_Dialog *cfd;
E_Config_Dialog_View v; E_Config_Dialog_View v;
@ -45,6 +48,10 @@ void e_int_config_focus(E_Container *con)
static void * static void *
_create_data(E_Config_Dialog *cfd) _create_data(E_Config_Dialog *cfd)
{ {
/* Create cfdata - cfdata is a temporary block of config data that this
* dialog will be dealing with while configuring. it will be applied to
* the running systems/config in the apply methods
*/
CFData *cfdata; CFData *cfdata;
cfdata = E_NEW(CFData, 1); cfdata = E_NEW(CFData, 1);
@ -62,13 +69,15 @@ _create_data(E_Config_Dialog *cfd)
static void static void
_free_data(E_Config_Dialog *cfd, CFData *cfdata) _free_data(E_Config_Dialog *cfd, CFData *cfdata)
{ {
/* Free the cfdata */
free(cfdata); free(cfdata);
} }
/**--APPLY--**/ /**--APPLY--**/
static void static int
_basic_apply_data(E_Config_Dialog *cfd, CFData *cfdata) _basic_apply_data(E_Config_Dialog *cfd, CFData *cfdata)
{ {
/* Actually take our cfdata settings and apply them in real life */
e_border_button_bindings_ungrab_all(); e_border_button_bindings_ungrab_all();
if (cfdata->mode == E_FOCUS_CLICK) if (cfdata->mode == E_FOCUS_CLICK)
{ {
@ -96,11 +105,13 @@ _basic_apply_data(E_Config_Dialog *cfd, CFData *cfdata)
} }
e_border_button_bindings_grab_all(); e_border_button_bindings_grab_all();
e_config_save_queue(); e_config_save_queue();
return 1; /* Apply was OK */
} }
static void static int
_advanced_apply_data(E_Config_Dialog *cfd, CFData *cfdata) _advanced_apply_data(E_Config_Dialog *cfd, CFData *cfdata)
{ {
/* Actually take our cfdata settings and apply them in real life */
e_border_button_bindings_ungrab_all(); e_border_button_bindings_ungrab_all();
e_config->focus_policy = cfdata->focus_policy; e_config->focus_policy = cfdata->focus_policy;
e_config->focus_setting = cfdata->focus_setting; e_config->focus_setting = cfdata->focus_setting;
@ -109,14 +120,17 @@ _advanced_apply_data(E_Config_Dialog *cfd, CFData *cfdata)
e_config->always_click_to_focus = cfdata->always_click_to_focus; e_config->always_click_to_focus = cfdata->always_click_to_focus;
e_border_button_bindings_grab_all(); e_border_button_bindings_grab_all();
e_config_save_queue(); e_config_save_queue();
return 1; /* Apply was OK */
} }
/**--GUI--**/ /**--GUI--**/
static Evas_Object * static Evas_Object *
_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata) _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata)
{ {
/* generate the core widget layout for a basic dialog */
Evas_Object *o, *ob; Evas_Object *o, *ob;
E_Radio_Group *rg; E_Radio_Group *rg;
o = e_widget_list_add(evas, 0, 0); o = e_widget_list_add(evas, 0, 0);
rg = e_widget_radio_group_new(&(cfdata->mode)); rg = e_widget_radio_group_new(&(cfdata->mode));
ob = e_widget_radio_add(evas, _("Click Window to Focus"), E_FOCUS_CLICK, rg); ob = e_widget_radio_add(evas, _("Click Window to Focus"), E_FOCUS_CLICK, rg);
@ -131,6 +145,7 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata)
static Evas_Object * static Evas_Object *
_advanced_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata) _advanced_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata)
{ {
/* generate the core widget layout for an advanced dialog */
Evas_Object *o, *ob, *of; Evas_Object *o, *ob, *of;
E_Radio_Group *rg; E_Radio_Group *rg;