Add config variables for dual-app mode.

Add a config dialog for changing dual-app mode.
Rename timer in Select Window to be more specific.



SVN revision: 44077
This commit is contained in:
Christopher Michael 2009-12-01 05:43:04 +00:00
parent cc05979308
commit 310069f653
7 changed files with 122 additions and 8 deletions

View File

@ -36,7 +36,9 @@ module_la_SOURCES = e_mod_main.h \
e_mod_select_window.h \
e_mod_select_window.c \
e_mod_policy.h \
e_mod_policy.c
e_mod_policy.c \
e_mod_policy_settings.h \
e_mod_policy_settings.c
module_la_LIBADD = @e_libs@ @dlopen_libs@
module_la_LDFLAGS = -module -avoid-version

View File

@ -4,6 +4,7 @@
#include "e_mod_animation.h"
#include "e_mod_windows.h"
#include "e_mod_policy.h"
#include "e_mod_policy_settings.h"
/* local variables */
EAPI Il_Config *il_cfg = NULL;
@ -22,6 +23,8 @@ il_config_init(E_Module *m)
E_CONFIG_VAL(D, T, sliding.kbd.duration, INT);
E_CONFIG_VAL(D, T, sliding.softkey.duration, INT);
E_CONFIG_VAL(D, T, policy.name, STR);
E_CONFIG_VAL(D, T, policy.mode.dual, INT);
E_CONFIG_VAL(D, T, policy.mode.side, INT);
E_CONFIG_VAL(D, T, policy.vkbd.class, STR);
E_CONFIG_VAL(D, T, policy.vkbd.name, STR);
E_CONFIG_VAL(D, T, policy.vkbd.title, STR);
@ -120,6 +123,11 @@ il_config_init(E_Module *m)
il_cfg->policy.indicator.match.title = 1;
il_cfg->policy.indicator.match.win_type = 0;
}
if ((il_cfg->version & 0xffff) < 2)
{
il_cfg->policy.mode.dual = 0;
il_cfg->policy.mode.side = 0;
}
il_cfg->version = (IL_CONFIG_MAJ << 16) | IL_CONFIG_MIN;
}
il_cfg->mod_dir = eina_stringshare_add(m->dir);
@ -135,12 +143,17 @@ il_config_init(E_Module *m)
e_configure_registry_generic_item_add("illume/policy", 0, _("Policy"),
NULL, "enlightenment/policy",
il_config_policy_show);
e_configure_registry_generic_item_add("illume/policy_settings", 0,
_("Policy Settings"),
NULL, "enlightenment/policy",
il_config_policy_settings_show);
return 1;
}
EAPI int
il_config_shutdown(void)
{
e_configure_registry_item_del("illume/policy_settings");
e_configure_registry_item_del("illume/policy");
e_configure_registry_item_del("illume/windows");
e_configure_registry_item_del("illume/animation");

View File

@ -1,7 +1,7 @@
#ifndef E_MOD_CONFIG_H
# define E_MOD_CONFIG_H
# define IL_CONFIG_MIN 1
# define IL_CONFIG_MIN 2
# define IL_CONFIG_MAJ 0
typedef struct _Il_Config Il_Config;
@ -32,6 +32,10 @@ struct _Il_Config
int class, name, title, win_type;
} match;
} vkbd, softkey, home, indicator;
struct
{
int dual, side;
} mode;
} policy;
// Not User Configurable. Placeholders

View File

@ -9,6 +9,7 @@ static void _il_config_policy_free(E_Config_Dialog *cfd, E_Config_Dialog_Data *c
static Evas_Object *_il_config_policy_ui(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata);
static void _il_config_policy_list_changed(void *data);
static int _il_config_policy_change_timeout(void *data);
static Evas_Object *_il_config_policy_settings_ui(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata);
/* local variables */
Ecore_Timer *_policy_change_timer = NULL;
@ -20,7 +21,7 @@ il_config_policy_show(E_Container *con, const char *params)
E_Config_Dialog *cfd;
E_Config_Dialog_View *v;
if (e_config_dialog_find("E", "_config_illume_policy_settings")) return;
if (e_config_dialog_find("E", "_config_illume_policy")) return;
v = E_NEW(E_Config_Dialog_View, 1);
v->create_cfdata = _il_config_policy_create;
v->free_cfdata = _il_config_policy_free;
@ -29,7 +30,7 @@ il_config_policy_show(E_Container *con, const char *params)
v->normal_win = 1;
v->scroll = 1;
cfd = e_config_dialog_new(con, _("Policy"), "E",
"_config_illume_policy_settings",
"_config_illume_policy",
"enlightenment/policy", 0, v, NULL);
e_dialog_resizable_set(cfd->dia, 1);
}
@ -102,3 +103,21 @@ _il_config_policy_change_timeout(void *data)
_policy_change_timer = NULL;
return 0;
}
static Evas_Object *
_il_config_policy_settings_ui(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
{
Evas_Object *list, *of, *ow;
E_Radio_Group *rg;
list = e_widget_list_add(evas, 0, 0);
of = e_widget_framelist_add(evas, _("Mode"), 0);
rg = e_widget_radio_group_new(&(il_cfg->policy.mode.dual));
ow = e_widget_radio_add(evas, _("Single App Mode"), 0, rg);
e_widget_framelist_object_append(of, ow);
ow = e_widget_radio_add(evas, _("Dual App Mode"), 1, rg);
e_widget_framelist_object_append(of, ow);
e_widget_list_object_append(list, of, 1, 0, 0.0);
return list;
}

View File

@ -0,0 +1,70 @@
#include "e.h"
#include "e_mod_config.h"
#include "e_mod_policy_settings.h"
/* local function prototypes */
static void *_il_config_policy_settings_create(E_Config_Dialog *cfd);
static void _il_config_policy_settings_free(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
static Evas_Object *_il_config_policy_settings_ui(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata);
/* local variables */
Ecore_Timer *_ps_change_timer = NULL;
void
il_config_policy_settings_show(E_Container *con, const char *params)
{
E_Config_Dialog *cfd;
E_Config_Dialog_View *v;
if (e_config_dialog_find("E", "_config_illume_policy_settings")) return;
v = E_NEW(E_Config_Dialog_View, 1);
v->create_cfdata = _il_config_policy_settings_create;
v->free_cfdata = _il_config_policy_settings_free;
v->basic.create_widgets = _il_config_policy_settings_ui;
v->basic_only = 1;
v->normal_win = 1;
v->scroll = 1;
cfd = e_config_dialog_new(con, _("Policy Settings"), "E",
"_config_illume_policy_settings",
"enlightenment/policy_settings", 0, v, NULL);
e_dialog_resizable_set(cfd->dia, 1);
}
/* local function prototypes */
static void *
_il_config_policy_settings_create(E_Config_Dialog *cfd)
{
return NULL;
}
static void
_il_config_policy_settings_free(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
{
if (_ps_change_timer) ecore_timer_del(_ps_change_timer);
}
static Evas_Object *
_il_config_policy_settings_ui(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
{
Evas_Object *list, *of, *ow;
E_Radio_Group *rg;
list = e_widget_list_add(evas, 0, 0);
of = e_widget_framelist_add(evas, _("Mode"), 0);
rg = e_widget_radio_group_new(&(il_cfg->policy.mode.dual));
ow = e_widget_radio_add(evas, _("Single App Mode"), 0, rg);
e_widget_framelist_object_append(of, ow);
ow = e_widget_radio_add(evas, _("Dual App Mode"), 1, rg);
e_widget_framelist_object_append(of, ow);
e_widget_list_object_append(list, of, 1, 0, 0.0);
of = e_widget_framelist_add(evas, _("Window Layout"), 0);
rg = e_widget_radio_group_new(&(il_cfg->policy.mode.side));
ow = e_widget_radio_add(evas, _("Top/Bottom"), 0, rg);
e_widget_framelist_object_append(of, ow);
ow = e_widget_radio_add(evas, _("Left/Right"), 1, rg);
e_widget_framelist_object_append(of, ow);
e_widget_list_object_append(list, of, 1, 0, 0.0);
return list;
}

View File

@ -0,0 +1,6 @@
#ifndef E_MOD_POLICY_SETTINGS_H
# define E_MOD_POLICY_SETTINGS_H
void il_config_policy_settings_show(E_Container *con, const char *params);
#endif

View File

@ -13,7 +13,7 @@ static int _il_config_select_window_match(E_Border *bd);
/* local variables */
Il_Select_Window_Type stype;
Ecore_Timer *_change_timer = NULL;
Ecore_Timer *_sw_change_timer = NULL;
/* public functions */
void
@ -154,8 +154,8 @@ _il_config_select_window_list_changed(void *data)
if (name) free(name);
if (class) free(class);
if (_change_timer) ecore_timer_del(_change_timer);
_change_timer =
if (_sw_change_timer) ecore_timer_del(_sw_change_timer);
_sw_change_timer =
ecore_timer_add(0.5, _il_config_select_window_change_timeout, data);
}
@ -163,7 +163,7 @@ static int
_il_config_select_window_change_timeout(void *data)
{
e_config_save_queue();
_change_timer = NULL;
_sw_change_timer = NULL;
return 0;
}