Enlightenment CVS committal Author : devilhorns Project : e17 Module : apps/e
Dir : e17/apps/e/src/bin Modified Files: e_about.c Log Message: Fix E About window so it only shows one instance. Handled like Config Panel so it will move to current zone/desk if it's open & on a different one. =================================================================== RCS file: /cvs/e/e17/apps/e/src/bin/e_about.c,v retrieving revision 1.17 retrieving revision 1.18 diff -u -3 -r1.17 -r1.18 --- e_about.c 28 Jan 2007 17:43:54 -0000 1.17 +++ e_about.c 15 Mar 2007 17:51:54 -0000 1.18 @@ -8,6 +8,8 @@ static void _e_about_cb_delete(E_Win *win); static void _e_about_cb_close(void *data, Evas_Object *obj, const char *emission, const char *source); +static E_About *_e_about = NULL; + /* local subsystem globals */ /* externally accessible functions */ @@ -15,9 +17,31 @@ EAPI E_About * e_about_new(E_Container *con) { - E_About *about; E_Manager *man; Evas_Object *o; + E_About *about; + + if (_e_about) + { + E_Zone *z, *z2; + + about = _e_about; + z = e_util_zone_current_get(e_manager_current_get()); + z2 = about->win->border->zone; + e_win_show(about->win); + e_win_raise(about->win); + if (z->container == z2->container) + e_border_desk_set(about->win->border, e_desk_current_get(z)); + else + { + if (!about->win->border->sticky) + e_desk_show(about->win->border->desk); + ecore_x_pointer_warp(z2->container->win, + z2->x + (z2->w / 2), z2->y + (z2->h / 2)); + } + e_border_unshade(about->win->border, E_DIRECTION_DOWN); + return NULL; + } if (!con) { @@ -43,8 +67,7 @@ o = edje_object_add(e_win_evas_get(about->win)); about->bg_object = o; - e_theme_edje_object_set(o, "base/theme/about", - "e/widgets/about/main"); + e_theme_edje_object_set(o, "base/theme/about", "e/widgets/about/main"); evas_object_move(o, 0, 0); evas_object_show(o); @@ -122,6 +145,7 @@ } } e_win_centered_set(about->win, 1); + _e_about = about; return about; } @@ -152,6 +176,7 @@ static void _e_about_free(E_About *about) { + _e_about = NULL; if (about->bg_object) evas_object_del(about->bg_object); e_object_del(E_OBJECT(about->win)); free(about); @@ -163,6 +188,7 @@ E_About *about; about = win->data; + if (!about) return; e_object_del(E_OBJECT(about)); } @@ -172,5 +198,6 @@ E_About *about; about = data; + if (!about) return; e_object_del(E_OBJECT(about)); } ------------------------------------------------------------------------- Take Surveys. Earn Cash. Influence the Future of IT Join SourceForge.net's Techsay panel and you'll get the chance to share your opinions on IT & business topics through brief surveys-and earn cash http://www.techsay.com/default.php?page=join.php&p=sourceforge&CID=DEVDEV _______________________________________________ enlightenment-cvs mailing list enlightenment-cvs@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/enlightenment-cvs