forked from enlightenment/enlightenment
Remove module menu from gadget code since it is no longer used.
Include face count to ease matching config data to a face. SVN revision: 20036
This commit is contained in:
parent
4e7e5fa0cc
commit
eebec166ca
|
@ -17,11 +17,9 @@
|
|||
*/
|
||||
|
||||
static E_Gadget_Face *_e_gadget_face_new(E_Gadget *gad, E_Container *con, E_Zone *zone);
|
||||
static void _e_gadget_menu_init(E_Gadget *gad);
|
||||
static void _e_gadget_cb_menu_edit(void *data, E_Menu *m, E_Menu_Item *mi);
|
||||
static void _e_gadget_free(E_Gadget *gad);
|
||||
static void _e_gadget_face_cb_gmc_change(void * data, E_Gadman_Client *gmc, E_Gadman_Change change);
|
||||
static void _e_gadget_menu_init(E_Gadget *gad);
|
||||
static void _e_gadget_face_menu_init(E_Gadget_Face *face);
|
||||
static void _e_gadget_cb_mouse_down(void *data, Evas *e, Evas_Object *obj, void *event_info);
|
||||
|
||||
|
@ -32,20 +30,24 @@ static void _e_gadget_cb_mouse_down(void *data, Evas *e, Evas_Object *obj, void
|
|||
* func_face_free should be defined. The possible fields api fields are:
|
||||
*
|
||||
* E_Module *module - the module that contains this gadget
|
||||
*
|
||||
* char *name - a unique name for this module
|
||||
*
|
||||
* void (*func_face_init) (void *data, E_Gadget_Face *gadget_face) -
|
||||
* A function that initializes the gadget's face. All evas objects should
|
||||
* be drawn on gadget_face->evas.
|
||||
*
|
||||
* void (*func_face_free) (void *data, E_Gadget_Face *gadget_face) -
|
||||
* A function that frees all memory allocated in func_face_init
|
||||
*
|
||||
* void (*func_change) (void *data, E_Gadget_Face *gadget_face,
|
||||
* E_Gadman_Client *gmc, E_Gadman_Change change) -
|
||||
* A function that is called whenever the gadget is resized.
|
||||
* void (*func_menu_init) (void *data, E_Gadget *gadget) -
|
||||
* A function that initializes the gadget's main menu.
|
||||
*
|
||||
* void (*func_face_menu_init) (void *data, E_Gadget_Face *gadget_face) -
|
||||
* A function that initializes the gadget's face menu. This is displayed
|
||||
* when the user right clicks on the gadget's face.
|
||||
*
|
||||
* void *data - a pointer to some data to be passed to all callbacks.
|
||||
*
|
||||
*/
|
||||
|
@ -69,11 +71,9 @@ e_gadget_new(E_Gadget_Api *api)
|
|||
gad->funcs.face_init = api->func_face_init;
|
||||
gad->funcs.face_free = api->func_face_free;
|
||||
gad->funcs.change = api->func_change;
|
||||
gad->funcs.menu_init = api->func_menu_init;
|
||||
gad->funcs.face_menu_init = api->func_face_menu_init;
|
||||
gad->data = api->data;
|
||||
|
||||
|
||||
/* get all desktop evases, and call init function on them */
|
||||
managers = e_manager_list();
|
||||
for(l = managers; l; l = l->next)
|
||||
|
@ -103,7 +103,6 @@ e_gadget_new(E_Gadget_Api *api)
|
|||
}
|
||||
}
|
||||
}
|
||||
_e_gadget_menu_init(gad);
|
||||
|
||||
return gad;
|
||||
}
|
||||
|
@ -142,20 +141,7 @@ _e_gadget_face_new(E_Gadget *gad, E_Container *con, E_Zone *zone)
|
|||
snprintf(buf, sizeof(buf), "module.%s", gad->name);
|
||||
face->gmc = e_gadman_client_new(con->gadman);
|
||||
e_gadman_client_zone_set(face->gmc, face->zone);
|
||||
e_gadman_client_domain_set(face->gmc, buf, evas_list_count(gad->faces));
|
||||
|
||||
/* call the user init */
|
||||
if (gad->funcs.face_init) (gad->funcs.face_init)(gad->data, face);
|
||||
|
||||
_e_gadget_face_menu_init(face);
|
||||
|
||||
change = E_NEW(E_Gadget_Change, 1);
|
||||
if (change)
|
||||
{
|
||||
printf("set change func\n");
|
||||
change->gadget = gad;
|
||||
change->face = face;
|
||||
}
|
||||
e_gadman_client_domain_set(face->gmc, buf, gad->num_faces);
|
||||
|
||||
/* set up some gadman defaults */
|
||||
e_gadman_client_policy_set(face->gmc,
|
||||
|
@ -169,11 +155,27 @@ _e_gadget_face_new(E_Gadget *gad, E_Container *con, E_Zone *zone)
|
|||
e_gadman_client_auto_size_set(face->gmc, 40, 40);
|
||||
e_gadman_client_align_set(face->gmc, 1.0, 1.0);
|
||||
e_gadman_client_resize(face->gmc, 40, 40);
|
||||
|
||||
change = E_NEW(E_Gadget_Change, 1);
|
||||
if (change)
|
||||
{
|
||||
change->gadget = gad;
|
||||
change->face = face;
|
||||
}
|
||||
e_gadman_client_change_func_set(face->gmc, _e_gadget_face_cb_gmc_change, change);
|
||||
|
||||
gad->faces = evas_list_append(gad->faces, face);
|
||||
face->face_num = gad->num_faces;
|
||||
gad->num_faces++;
|
||||
|
||||
/* call the user init */
|
||||
if (gad->funcs.face_init) (gad->funcs.face_init)(gad->data, face);
|
||||
|
||||
_e_gadget_face_menu_init(face);
|
||||
|
||||
e_gadman_client_load(face->gmc);
|
||||
evas_event_thaw(face->evas);
|
||||
|
||||
gad->faces = evas_list_append(gad->faces, face);
|
||||
|
||||
return face;
|
||||
}
|
||||
|
@ -190,13 +192,6 @@ e_gadget_face_theme_set(E_Gadget_Face *face, char *category, char *group)
|
|||
evas_object_show(o);
|
||||
}
|
||||
|
||||
static void
|
||||
_e_gadget_menu_init(E_Gadget *gad)
|
||||
{
|
||||
gad->module->config_menu = gad->menu = e_menu_new();
|
||||
if (gad->funcs.menu_init) (gad->funcs.menu_init)(gad->data, gad);
|
||||
}
|
||||
|
||||
static void
|
||||
_e_gadget_face_menu_init(E_Gadget_Face *face)
|
||||
{
|
||||
|
@ -242,7 +237,6 @@ _e_gadget_free(E_Gadget *gad)
|
|||
evas_list_free(gad->faces);
|
||||
gad->module->config_menu = NULL;
|
||||
e_object_unref(E_OBJECT(gad->module));
|
||||
e_object_del(E_OBJECT(gad->menu));
|
||||
if (gad->name) evas_stringshare_del(gad->name);
|
||||
free(gad);
|
||||
|
||||
|
@ -303,7 +297,7 @@ _e_gadget_cb_mouse_down(void *data, Evas *e, Evas_Object *obj, void *event_info)
|
|||
face = data;
|
||||
if (!face) return;
|
||||
|
||||
if (ev->button == 3 && face->gad->menu)
|
||||
if (ev->button == 3 && face->menu)
|
||||
{
|
||||
e_menu_activate_mouse(face->menu, e_zone_current_get(face->con),
|
||||
ev->output.x, ev->output.y, 1, 1,
|
||||
|
|
|
@ -18,9 +18,8 @@ struct _E_Gadget_Api
|
|||
int per_zone; /* 1 - one face per zone, 0 - one per container */
|
||||
void (*func_face_init) (void *data, E_Gadget_Face *gadget_face);
|
||||
void (*func_face_free) (void *data, E_Gadget_Face *gadget_face);
|
||||
void (*func_change) (void *data, E_Gadget_Face *gadget_face, E_Gadman_Client *gmc, E_Gadman_Change change);
|
||||
void (*func_menu_init) (void *data, E_Gadget *gadget);
|
||||
void (*func_face_menu_init) (void *data, E_Gadget_Face *gadget_face);
|
||||
void (*func_change) (void *data, E_Gadget_Face *gadget_face, E_Gadman_Client *gmc, E_Gadman_Change change);
|
||||
void *data;
|
||||
};
|
||||
|
||||
|
@ -31,16 +30,17 @@ struct _E_Gadget
|
|||
|
||||
E_Module *module;
|
||||
const char *name;
|
||||
E_Menu *menu;
|
||||
|
||||
struct {
|
||||
void (*face_init) (void *data, E_Gadget_Face *gadget_face);
|
||||
void (*face_free) (void *data, E_Gadget_Face *gadget_face);
|
||||
void (*change) (void *data, E_Gadget_Face *gadget_face, E_Gadman_Client *gmc, E_Gadman_Change change);
|
||||
void (*menu_init) (void *data, E_Gadget *gadget);
|
||||
void (*face_menu_init) (void *data, E_Gadget_Face *gadget_face);
|
||||
void (*change) (void *data, E_Gadget_Face *gadget_face, E_Gadman_Client *gmc, E_Gadman_Change change);
|
||||
} funcs;
|
||||
|
||||
int num_faces;
|
||||
|
||||
void *conf;
|
||||
void *data;
|
||||
};
|
||||
|
||||
|
@ -50,6 +50,7 @@ struct _E_Gadget_Face
|
|||
E_Container *con;
|
||||
E_Zone *zone;
|
||||
Evas *evas;
|
||||
int face_num;
|
||||
|
||||
E_Menu *menu;
|
||||
void *conf;
|
||||
|
|
|
@ -13,7 +13,6 @@ EAPI E_Module_Api e_modapi =
|
|||
static void _test_face_init(void *data, E_Gadget_Face *face);
|
||||
static void _test_face_free(void *data, E_Gadget_Face *face);
|
||||
static void _test_face_change(void *data, E_Gadget_Face *face, E_Gadman_Client *gmc, E_Gadman_Change change);
|
||||
static void _test_menu_init(void *data, E_Gadget *gad);
|
||||
static void _test_face_menu_init(void *data, E_Gadget_Face *face);
|
||||
|
||||
|
||||
|
@ -39,11 +38,11 @@ e_modapi_init(E_Module *m)
|
|||
api->func_face_init = _test_face_init;
|
||||
api->func_face_free = _test_face_free;
|
||||
api->func_change = _test_face_change;
|
||||
api->func_menu_init = _test_menu_init;
|
||||
api->func_face_menu_init = _test_face_menu_init;
|
||||
api->data = t;
|
||||
|
||||
gad = e_gadget_new(api);
|
||||
E_FREE(api);
|
||||
|
||||
return gad;
|
||||
}
|
||||
|
@ -99,15 +98,6 @@ _test_face_change(void *data, E_Gadget_Face *face, E_Gadman_Client *gmc, E_Gadma
|
|||
printf("change face!\n");
|
||||
}
|
||||
|
||||
static void
|
||||
_test_menu_init(void *data, E_Gadget *gad)
|
||||
{
|
||||
E_Menu_Item *mi;
|
||||
|
||||
mi = e_menu_item_new(gad->menu);
|
||||
e_menu_item_label_set(mi, _("Test Menu Item"));
|
||||
}
|
||||
|
||||
static void
|
||||
_test_face_menu_init(void *data, E_Gadget_Face *face)
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue