Indenting.

SVN revision: 55329
This commit is contained in:
Gustavo Lima Chaves 2010-12-06 12:46:16 +00:00
parent e2b7c27106
commit eae9d6b81c
2 changed files with 277 additions and 248 deletions

View File

@ -67,24 +67,24 @@ struct _Fonts_Data
} \
while (0)
#define LABEL_FRAME_ADD(label) \
do \
{ \
pd = elm_frame_add(win); \
evas_object_size_hint_weight_set(pd, EVAS_HINT_EXPAND, 0.0); \
evas_object_size_hint_align_set(pd, EVAS_HINT_FILL, 0.5); \
elm_object_style_set(pd, "pad_medium"); \
elm_box_pack_end(bx, pd); \
evas_object_show(pd); \
\
lb = elm_label_add(win); \
evas_object_size_hint_weight_set(lb, EVAS_HINT_EXPAND, 0.0); \
evas_object_size_hint_align_set(lb, EVAS_HINT_FILL, 0.5); \
elm_label_label_set(lb, label); \
elm_frame_content_set(pd, lb); \
evas_object_show(lb); \
} \
while (0)
#define LABEL_FRAME_ADD(label) \
do \
{ \
pd = elm_frame_add(win); \
evas_object_size_hint_weight_set(pd, EVAS_HINT_EXPAND, 0.0); \
evas_object_size_hint_align_set(pd, EVAS_HINT_FILL, 0.5); \
elm_object_style_set(pd, "pad_medium"); \
elm_box_pack_end(bx, pd); \
evas_object_show(pd); \
\
lb = elm_label_add(win); \
evas_object_size_hint_weight_set(lb, EVAS_HINT_EXPAND, 0.0); \
evas_object_size_hint_align_set(lb, EVAS_HINT_FILL, 0.5); \
elm_label_label_set(lb, label); \
elm_frame_content_set(pd, lb); \
evas_object_show(lb); \
} \
while (0)
static int quiet = 0;
static int interactive = 1;
@ -138,9 +138,9 @@ config_exit(void *data __UNUSED__,
}
static void
sb_change(void *data __UNUSED__,
Evas_Object *obj,
void *event_info __UNUSED__)
sb_change(void *data __UNUSED__,
Evas_Object *obj,
void *event_info __UNUSED__)
{
Eina_Bool val = elm_check_state_get(obj);
Eina_Bool sb = elm_scroll_bounce_enabled_get();
@ -248,9 +248,9 @@ zf_change(void *data __UNUSED__,
}
static void
ts_change(void *data __UNUSED__,
Evas_Object *obj,
void *event_info __UNUSED__)
ts_change(void *data __UNUSED__,
Evas_Object *obj,
void *event_info __UNUSED__)
{
Eina_Bool val = elm_check_state_get(obj);
Eina_Bool sb = elm_scroll_bounce_enabled_get();
@ -847,7 +847,7 @@ _profile_change_do(Evas_Object *win,
{
int flush_interval, font_c, image_c, edje_file_c, edje_col_c, ts_threshould;
double scale, s_bounce_friction, ts_momentum_threshold, ts_friction,
ts_border_friction, page_friction, bring_in_friction, zoom_friction;
ts_border_friction, page_friction, bring_in_friction, zoom_friction;
const char *curr_theme, *curr_engine;
const Eina_List *l_items, *l;
Eina_Bool s_bounce, ts;
@ -902,7 +902,7 @@ _profile_change_do(Evas_Object *win,
elm_scroll_bounce_enabled_all_set(s_bounce);
elm_check_state_set(evas_object_data_get(win, "scroll_bounce_check"),
s_bounce);
s_bounce);
elm_scroll_bounce_friction_all_set(s_bounce_friction);
elm_slider_value_set(evas_object_data_get(win, "bounce_friction_slider"),
s_bounce_friction);
@ -1691,8 +1691,7 @@ _fonts_data_fill(Evas *evas)
{
tc_data->font = eina_stringshare_add(efp->name);
/* we're sure we recorded with only 1 style selected */
tc_data->style =
eina_stringshare_add(efp->styles->data);
tc_data->style = eina_stringshare_add(efp->styles->data);
elm_font_properties_free(efp);
}
}
@ -2168,8 +2167,8 @@ _profiles_list_fill(Evas_Object *l_widget,
static void
_profiles_list_unselect_cb(void *data __UNUSED__,
Evas_Object *obj,
void *event_info __UNUSED__)
Evas_Object *obj,
void *event_info __UNUSED__)
{
if (elm_list_selected_item_get(obj)) return;
elm_object_disabled_set(evas_object_data_get(obj, "prof_del_btn"),
@ -2340,8 +2339,8 @@ _status_config_scrolling(Evas_Object *win,
ck = elm_check_add(win);
elm_object_tooltip_text_set(ck, "Set whether scrollers should bounce<br>"
"when they reach their viewport's edge<br>"
"during a scroll");
"when they reach their viewport's edge<br>"
"during a scroll");
elm_check_label_set(ck, "Enable scroll bounce");
evas_object_data_set(win, "scroll_bounce_check", ck);
evas_object_size_hint_weight_set(ck, EVAS_HINT_EXPAND, 0.0);
@ -2356,7 +2355,7 @@ _status_config_scrolling(Evas_Object *win,
sl = elm_slider_add(win);
elm_object_tooltip_text_set(sl, "This is the amount of inertia a <br>"
"scroller will impose at bounce animations");
"scroller will impose at bounce animations");
evas_object_data_set(win, "bounce_friction_slider", sl);
evas_object_size_hint_weight_set(sl, EVAS_HINT_EXPAND, 0.0);
evas_object_size_hint_align_set(sl, EVAS_HINT_FILL, 0.5);
@ -2380,7 +2379,7 @@ _status_config_scrolling(Evas_Object *win,
ck = elm_check_add(win);
elm_object_tooltip_text_set(ck, "Set whether scrollers should be<br>"
"draggable from any point in their views");
"draggable from any point in their views");
elm_check_label_set(ck, "Enable thumb scroll");
evas_object_data_set(win, "thumbscroll_check", ck);
evas_object_size_hint_weight_set(ck, EVAS_HINT_EXPAND, 0.0);
@ -2395,8 +2394,8 @@ _status_config_scrolling(Evas_Object *win,
sl = elm_slider_add(win);
elm_object_tooltip_text_set(sl, "This is the number of pixels one should<br>"
"travel while dragging a scroller's view to<br>"
"actually trigger scrolling");
"travel while dragging a scroller's view<br>"
"to actually trigger scrolling");
evas_object_data_set(win, "thumbscroll_threshold_slider", sl);
evas_object_size_hint_weight_set(sl, EVAS_HINT_EXPAND, 0.0);
evas_object_size_hint_align_set(sl, EVAS_HINT_FILL, 0.5);
@ -2415,9 +2414,9 @@ _status_config_scrolling(Evas_Object *win,
sl = elm_slider_add(win);
elm_object_tooltip_text_set(sl, "This is the minimum speed of mouse <br>"
"cursor movement which will trigger<br>"
"list self scrolling animation after a<br>"
"mouse up event (pixels/second)");
"cursor movement which will trigger<br>"
"list self scrolling animation after a<br>"
"mouse up event (pixels/second)");
evas_object_data_set(win, "ts_momentum_threshold_slider", sl);
evas_object_size_hint_weight_set(sl, EVAS_HINT_EXPAND, 0.0);
evas_object_size_hint_align_set(sl, EVAS_HINT_FILL, 0.5);
@ -2437,8 +2436,8 @@ _status_config_scrolling(Evas_Object *win,
sl = elm_slider_add(win);
elm_object_tooltip_text_set(sl, "This is the amount of inertia a<br>"
"scroller will impose at self scrolling<br>"
"animations");
"scroller will impose at self scrolling<br>"
"animations");
evas_object_data_set(win, "thumbscroll_friction_slider", sl);
evas_object_size_hint_weight_set(sl, EVAS_HINT_EXPAND, 0.0);
evas_object_size_hint_align_set(sl, EVAS_HINT_FILL, 0.5);
@ -2457,9 +2456,10 @@ _status_config_scrolling(Evas_Object *win,
sl = elm_slider_add(win);
elm_object_tooltip_text_set(sl, "This is the amount of lag between your<br>"
"actual mouse cursor dragging movement and<br>"
"a scroller's view movement itself, while<br>"
"pushing it into bounce state manually");
"actual mouse cursor dragging movement<br>"
"and a scroller's view movement itself,<br>"
"while pushing it into bounce state<br>"
"manually");
evas_object_data_set(win, "ts_border_friction_slider", sl);
evas_object_size_hint_weight_set(sl, EVAS_HINT_EXPAND, 0.0);
evas_object_size_hint_align_set(sl, EVAS_HINT_FILL, 0.5);
@ -2485,8 +2485,8 @@ _status_config_scrolling(Evas_Object *win,
sl = elm_slider_add(win);
elm_object_tooltip_text_set(sl, "This is the amount of inertia a<br>"
"paged scroller will impose at<br>"
"page fitting animations");
"paged scroller will impose at<br>"
"page fitting animations");
evas_object_data_set(win, "page_scroll_friction_slider", sl);
evas_object_size_hint_weight_set(sl, EVAS_HINT_EXPAND, 0.0);
evas_object_size_hint_align_set(sl, EVAS_HINT_FILL, 0.5);
@ -2505,8 +2505,8 @@ _status_config_scrolling(Evas_Object *win,
sl = elm_slider_add(win);
elm_object_tooltip_text_set(sl, "This is the amount of inertia a<br>"
"scroller will impose at region bring<br>"
"animations");
"scroller will impose at region bring<br>"
"animations");
evas_object_data_set(win, "bring_in_scroll_friction_slider", sl);
evas_object_size_hint_weight_set(sl, EVAS_HINT_EXPAND, 0.0);
evas_object_size_hint_align_set(sl, EVAS_HINT_FILL, 0.5);
@ -2525,8 +2525,9 @@ _status_config_scrolling(Evas_Object *win,
sl = elm_slider_add(win);
elm_object_tooltip_text_set(sl, "This is the amount of inertia inertia<br>"
"scrollers will impose at animations<br>"
"triggered by Elementary widgets' zooming API");
"scrollers will impose at animations<br>"
"triggered by Elementary widgets'<br>"
"zooming API");
evas_object_data_set(win, "zoom_scroll_friction_slider", sl);
evas_object_size_hint_weight_set(sl, EVAS_HINT_EXPAND, 0.0);
evas_object_size_hint_align_set(sl, EVAS_HINT_FILL, 0.5);

View File

@ -46,18 +46,24 @@ static const Elm_Text_Class _elm_text_classes[] = {
{NULL, NULL}
};
static void _desc_init(void);
static void _desc_shutdown(void);
static void _profile_fetch_from_conf(void);
static void _config_free(void);
static void _config_apply(void);
static Elm_Config * _config_user_load(void);
static Elm_Config * _config_system_load(void);
static void _config_load(void);
static void _config_update(void);
static void _env_get(void);
static size_t _elm_data_dir_snprintf(char *dst, size_t size, const char *fmt, ...) EINA_PRINTF(3 ,4);
static size_t _elm_user_dir_snprintf(char *dst, size_t size, const char *fmt, ...) EINA_PRINTF(3 ,4);
static void _desc_init(void);
static void _desc_shutdown(void);
static void _profile_fetch_from_conf(void);
static void _config_free(void);
static void _config_apply(void);
static Elm_Config *_config_user_load(void);
static Elm_Config *_config_system_load(void);
static void _config_load(void);
static void _config_update(void);
static void _env_get(void);
static size_t _elm_data_dir_snprintf(char *dst,
size_t size,
const char *fmt, ...)
EINA_PRINTF(3, 4);
static size_t _elm_user_dir_snprintf(char *dst,
size_t size,
const char *fmt, ...)
EINA_PRINTF(3, 4);
#define ELM_CONFIG_VAL(edd, type, member, dtype) \
EET_DATA_DESCRIPTOR_ADD_BASIC(edd, type, #member, member, dtype)
@ -71,53 +77,55 @@ static Ecore_X_Window _root_1st = 0;
static Ecore_X_Atom _atom[ATOM_COUNT];
static Ecore_X_Atom _atom_config = 0;
static const char *_atom_names[ATOM_COUNT] =
{
"ENLIGHTENMENT_SCALE",
"ENLIGHTENMENT_FINGER_SIZE",
"ENLIGHTENMENT_THEME",
"ENLIGHTENMENT_PROFILE",
"ENLIGHTENMENT_FONT_OVERLAY",
"ENLIGHTENMENT_CACHE_FLUSH_INTERVAL",
"ENLIGHTENMENT_FONT_CACHE",
"ENLIGHTENMENT_IMAGE_CACHE",
"ENLIGHTENMENT_EDJE_FILE_CACHE",
"ENLIGHTENMENT_EDJE_COLLECTION_CACHE",
"ENLIGHTENMENT_THUMBSCROLL_BOUNCE_ENABLE",
"ENLIGHTENMENT_THUMBSCROLL_BOUNCE_FRICTION",
"ENLIGHTENMENT_THUMBSCROLL_ENABLE",
"ENLIGHTENMENT_THUMBSCROLL_THRESHOLD",
"ENLIGHTENMENT_THUMBSCROLL_MOMENTUM_THRESHOLD",
"ENLIGHTENMENT_THUMBSCROLL_FRICTION",
"ENLIGHTENMENT_THUMBSCROLL_BORDER_FRICTION",
"ENLIGHTENMENT_THUMBSCROLL_PAGE_SCROLL_FRICTION",
"ENLIGHTENMENT_THUMBSCROLL_BRING_IN_SCROLL_FRICTION",
"ENLIGHTENMENT_THUMBSCROLL_ZOOM_FRICTION",
"ENLIGHTENMENT_CONFIG"
};
#define ATOM_E_SCALE 0
#define ATOM_E_FINGER_SIZE 1
#define ATOM_E_THEME 2
#define ATOM_E_PROFILE 3
#define ATOM_E_FONT_OVERLAY 4
#define ATOM_E_CACHE_FLUSH_INTERVAL 5
#define ATOM_E_FONT_CACHE 6
#define ATOM_E_IMAGE_CACHE 7
#define ATOM_E_EDJE_FILE_CACHE 8
#define ATOM_E_EDJE_COLLECTION_CACHE 9
#define ATOM_E_THUMBSCROLL_BOUNCE_ENABLE 10
#define ATOM_E_THUMBSCROLL_BOUNCE_FRICTION 11
#define ATOM_E_THUMBSCROLL_ENABLE 12
#define ATOM_E_THUMBSCROLL_THRESHOLD 13
#define ATOM_E_THUMBSCROLL_MOMENTUM_THRESHOLD 14
#define ATOM_E_THUMBSCROLL_FRICTION 15
#define ATOM_E_THUMBSCROLL_BORDER_FRICTION 16
#define ATOM_E_THUMBSCROLL_PAGE_SCROLL_FRICTION 17
{
"ENLIGHTENMENT_SCALE",
"ENLIGHTENMENT_FINGER_SIZE",
"ENLIGHTENMENT_THEME",
"ENLIGHTENMENT_PROFILE",
"ENLIGHTENMENT_FONT_OVERLAY",
"ENLIGHTENMENT_CACHE_FLUSH_INTERVAL",
"ENLIGHTENMENT_FONT_CACHE",
"ENLIGHTENMENT_IMAGE_CACHE",
"ENLIGHTENMENT_EDJE_FILE_CACHE",
"ENLIGHTENMENT_EDJE_COLLECTION_CACHE",
"ENLIGHTENMENT_THUMBSCROLL_BOUNCE_ENABLE",
"ENLIGHTENMENT_THUMBSCROLL_BOUNCE_FRICTION",
"ENLIGHTENMENT_THUMBSCROLL_ENABLE",
"ENLIGHTENMENT_THUMBSCROLL_THRESHOLD",
"ENLIGHTENMENT_THUMBSCROLL_MOMENTUM_THRESHOLD",
"ENLIGHTENMENT_THUMBSCROLL_FRICTION",
"ENLIGHTENMENT_THUMBSCROLL_BORDER_FRICTION",
"ENLIGHTENMENT_THUMBSCROLL_PAGE_SCROLL_FRICTION",
"ENLIGHTENMENT_THUMBSCROLL_BRING_IN_SCROLL_FRICTION",
"ENLIGHTENMENT_THUMBSCROLL_ZOOM_FRICTION",
"ENLIGHTENMENT_CONFIG"
};
#define ATOM_E_SCALE 0
#define ATOM_E_FINGER_SIZE 1
#define ATOM_E_THEME 2
#define ATOM_E_PROFILE 3
#define ATOM_E_FONT_OVERLAY 4
#define ATOM_E_CACHE_FLUSH_INTERVAL 5
#define ATOM_E_FONT_CACHE 6
#define ATOM_E_IMAGE_CACHE 7
#define ATOM_E_EDJE_FILE_CACHE 8
#define ATOM_E_EDJE_COLLECTION_CACHE 9
#define ATOM_E_THUMBSCROLL_BOUNCE_ENABLE 10
#define ATOM_E_THUMBSCROLL_BOUNCE_FRICTION 11
#define ATOM_E_THUMBSCROLL_ENABLE 12
#define ATOM_E_THUMBSCROLL_THRESHOLD 13
#define ATOM_E_THUMBSCROLL_MOMENTUM_THRESHOLD 14
#define ATOM_E_THUMBSCROLL_FRICTION 15
#define ATOM_E_THUMBSCROLL_BORDER_FRICTION 16
#define ATOM_E_THUMBSCROLL_PAGE_SCROLL_FRICTION 17
#define ATOM_E_THUMBSCROLL_BRING_IN_SCROLL_FRICTION 18
#define ATOM_E_THUMBSCROLL_ZOOM_FRICTION 19
#define ATOM_E_CONFIG 20
#define ATOM_E_THUMBSCROLL_ZOOM_FRICTION 19
#define ATOM_E_CONFIG 20
static Eina_Bool _prop_config_get(void);
static Eina_Bool _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev);
static Eina_Bool _prop_change(void *data __UNUSED__,
int ev_type __UNUSED__,
void *ev);
static Eina_Bool
_prop_config_get(void)
@ -173,7 +181,9 @@ _prop_config_get(void)
}
static Eina_Bool
_prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
_prop_change(void *data __UNUSED__,
int ev_type __UNUSED__,
void *ev)
{
Ecore_X_Event_Window_Property *event = ev;
@ -192,10 +202,10 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
pscale = _elm_config->scale;
if (val > 0) _elm_config->scale = (double)val / 1000.0;
if (pscale != _elm_config->scale)
{
_elm_rescale();
_elm_recache();
}
{
_elm_rescale();
_elm_recache();
}
}
}
else if (event->atom == _atom[ATOM_E_FINGER_SIZE])
@ -211,10 +221,10 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
pfinger_size = _elm_config->finger_size;
_elm_config->finger_size = val;
if (pfinger_size != _elm_config->finger_size)
{
_elm_rescale();
_elm_recache();
}
{
_elm_rescale();
_elm_recache();
}
}
}
else if (event->atom == _atom[ATOM_E_THEME])
@ -287,7 +297,7 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
int cache_flush_interval;
cache_flush_interval = _elm_config->cache_flush_poll_interval;
_elm_config->cache_flush_poll_interval = val;
_elm_config->cache_flush_poll_interval = val;
if (cache_flush_interval !=
_elm_config->cache_flush_poll_interval)
_elm_recache();
@ -304,7 +314,7 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
int font_cache;
font_cache = _elm_config->font_cache;
_elm_config->font_cache = val;
_elm_config->font_cache = val;
if (font_cache != _elm_config->font_cache)
_elm_recache();
}
@ -320,7 +330,7 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
int image_cache;
image_cache = _elm_config->image_cache;
_elm_config->image_cache = val;
_elm_config->image_cache = val;
if (image_cache != _elm_config->image_cache)
_elm_recache();
}
@ -336,7 +346,7 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
int edje_file_cache;
edje_file_cache = _elm_config->edje_cache;
_elm_config->edje_cache = val;
_elm_config->edje_cache = val;
if (edje_file_cache != _elm_config->edje_cache)
_elm_recache();
}
@ -352,7 +362,7 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
int edje_collection_cache;
edje_collection_cache = _elm_config->edje_collection_cache;
_elm_config->edje_collection_cache = val;
_elm_config->edje_collection_cache = val;
if (edje_collection_cache !=
_elm_config->edje_collection_cache)
_elm_recache();
@ -378,8 +388,8 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
&val, 1) > 0)
{
if (val > 0)
_elm_config->thumbscroll_bounce_friction =
(double)val / 1000.0;
_elm_config->thumbscroll_bounce_friction =
(double)val / 1000.0;
}
}
else if (event->atom == _atom[ATOM_E_THUMBSCROLL_ENABLE])
@ -413,8 +423,8 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
&val, 1) > 0)
{
if (val > 0)
_elm_config->thumbscroll_momentum_threshold =
(double)val / 1000.0;
_elm_config->thumbscroll_momentum_threshold =
(double)val / 1000.0;
}
}
else if (event->atom == _atom[ATOM_E_THUMBSCROLL_FRICTION])
@ -438,8 +448,8 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
&val, 1) > 0)
{
if (val > 0)
_elm_config->thumbscroll_border_friction =
(double)val / 1000.0;
_elm_config->thumbscroll_border_friction =
(double)val / 1000.0;
}
}
else if (event->atom == _atom[ATOM_E_THUMBSCROLL_PAGE_SCROLL_FRICTION])
@ -451,8 +461,8 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
&val, 1) > 0)
{
if (val > 0)
_elm_config->page_scroll_friction =
(double)val / 1000.0;
_elm_config->page_scroll_friction =
(double)val / 1000.0;
}
}
else if (event->atom ==
@ -465,8 +475,8 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
&val, 1) > 0)
{
if (val > 0)
_elm_config->bring_in_scroll_friction =
(double)val / 1000.0;
_elm_config->bring_in_scroll_friction =
(double)val / 1000.0;
}
}
else if (event->atom ==
@ -479,7 +489,7 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
&val, 1) > 0)
{
if (val > 0)
_elm_config->zoom_friction = (double)val / 1000.0;
_elm_config->zoom_friction = (double)val / 1000.0;
}
}
else if (((_atom_config > 0) && (event->atom == _atom_config)) ||
@ -490,6 +500,7 @@ _prop_change(void *data __UNUSED__, int ev_type __UNUSED__, void *ev)
}
return ECORE_CALLBACK_PASS_ON;
}
#endif
static void
@ -520,13 +531,13 @@ _desc_init(void)
eet_data_descriptor_free(_config_edd);
return;
}
#define T_INT EET_T_INT
#define T_INT EET_T_INT
#define T_DOUBLE EET_T_DOUBLE
#define T_STRING EET_T_STRING
#define T_UCHAR EET_T_UCHAR
#define T_UCHAR EET_T_UCHAR
#define T Elm_Font_Overlay
#define D _config_font_overlay_edd
#define T Elm_Font_Overlay
#define D _config_font_overlay_edd
ELM_CONFIG_VAL(D, T, text_class, EET_T_STRING);
ELM_CONFIG_VAL(D, T, font, EET_T_STRING);
ELM_CONFIG_VAL(D, T, size, EET_T_INT);
@ -596,7 +607,8 @@ _desc_shutdown(void)
}
static int
_sort_files_cb(const void *f1, const void *f2)
_sort_files_cb(const void *f1,
const void *f2)
{
return strcmp(f1, f2);
}
@ -604,11 +616,14 @@ _sort_files_cb(const void *f1, const void *f2)
const char *
_elm_config_current_profile_get(void)
{
return _elm_profile;
return _elm_profile;
}
static size_t
_elm_data_dir_snprintf(char *dst, size_t size, const char *fmt, ...)
_elm_data_dir_snprintf(char *dst,
size_t size,
const char *fmt,
...)
{
size_t data_dir_len, off;
va_list ap;
@ -625,12 +640,15 @@ _elm_data_dir_snprintf(char *dst, size_t size, const char *fmt, ...)
off = off + vsnprintf(dst + off, size - off, fmt, ap);
va_end(ap);
end:
end:
return off;
}
static size_t
_elm_user_dir_snprintf(char *dst, size_t size, const char *fmt, ...)
_elm_user_dir_snprintf(char *dst,
size_t size,
const char *fmt,
...)
{
const char *home;
size_t user_dir_len, off;
@ -653,12 +671,13 @@ _elm_user_dir_snprintf(char *dst, size_t size, const char *fmt, ...)
off = off + vsnprintf(dst + off, size - off, fmt, ap);
va_end(ap);
end:
end:
return off;
}
const char *
_elm_config_profile_dir_get(const char *prof, Eina_Bool is_user)
_elm_config_profile_dir_get(const char *prof,
Eina_Bool is_user)
{
char buf[PATH_MAX];
@ -672,7 +691,7 @@ _elm_config_profile_dir_get(const char *prof, Eina_Bool is_user)
return NULL;
not_user:
not_user:
snprintf(buf, sizeof(buf), "%s/config/%s", _elm_data_dir, prof);
if (ecore_file_is_dir(buf))
@ -1104,7 +1123,8 @@ _config_load(void)
}
static const char *
_elm_config_eet_close_error_get(Eet_File *ef, char *file)
_elm_config_eet_close_error_get(Eet_File *ef,
char *file)
{
Eet_Error err;
const char *erstr = NULL;
@ -1113,49 +1133,54 @@ _elm_config_eet_close_error_get(Eet_File *ef, char *file)
switch (err)
{
case EET_ERROR_WRITE_ERROR:
erstr = "An error occurred while saving Elementary's "
"settings to disk. The error could not be "
"deterimined. The file where the error occurred was: "
"%s. This file has been deleted to avoid corrupt data.";
break;
erstr = "An error occurred while saving Elementary's "
"settings to disk. The error could not be "
"deterimined. The file where the error occurred was: "
"%s. This file has been deleted to avoid corrupt data.";
break;
case EET_ERROR_WRITE_ERROR_FILE_TOO_BIG:
erstr = "Elementary's settings files are too big "
"for the file system they are being saved to. "
"This error is very strange as the files should "
"be extremely small. Please check the settings "
"for your home directory. "
"The file where the error occurred was: %s ."
"This file has been deleted to avoid corrupt data.";
break;
erstr = "Elementary's settings files are too big "
"for the file system they are being saved to. "
"This error is very strange as the files should "
"be extremely small. Please check the settings "
"for your home directory. "
"The file where the error occurred was: %s ."
"This file has been deleted to avoid corrupt data.";
break;
case EET_ERROR_WRITE_ERROR_IO_ERROR:
erstr = "An output error occurred when writing the settings "
"files for Elementary. Your disk is having troubles "
"and possibly needs replacement. "
"The file where the error occurred was: %s ."
"This file has been deleted to avoid corrupt data.";
break;
erstr = "An output error occurred when writing the settings "
"files for Elementary. Your disk is having troubles "
"and possibly needs replacement. "
"The file where the error occurred was: %s ."
"This file has been deleted to avoid corrupt data.";
break;
case EET_ERROR_WRITE_ERROR_OUT_OF_SPACE:
erstr = "Elementary cannot write its settings file "
"because it ran out of space to write the file. "
"You have either run out of disk space or have "
"gone over your quota limit. "
"The file where the error occurred was: %s ."
"This file has been deleted to avoid corrupt data.";
break;
erstr = "Elementary cannot write its settings file "
"because it ran out of space to write the file. "
"You have either run out of disk space or have "
"gone over your quota limit. "
"The file where the error occurred was: %s ."
"This file has been deleted to avoid corrupt data.";
break;
case EET_ERROR_WRITE_ERROR_FILE_CLOSED:
erstr = "Elementary unexpectedly had the settings file "
"it was writing closed on it. This is very unusual. "
"The file where the error occurred was: %s "
"This file has been deleted to avoid corrupt data.";
break;
erstr = "Elementary unexpectedly had the settings file "
"it was writing closed on it. This is very unusual. "
"The file where the error occurred was: %s "
"This file has been deleted to avoid corrupt data.";
break;
default:
break;
break;
}
if (erstr)
{
/* delete any partially-written file */
ecore_file_unlink(file);
return strdup(erstr);
/* delete any partially-written file */
ecore_file_unlink(file);
return strdup(erstr);
}
return NULL;
@ -1174,7 +1199,7 @@ _elm_config_profile_save(void)
if (len + 1 >= sizeof(buf))
return EINA_FALSE;
len = _elm_user_dir_snprintf(buf2, sizeof(buf2), "config/profile.cfg.tmp");
len = _elm_user_dir_snprintf(buf2, sizeof(buf2), "config/profile.cfg.tmp");
if (len + 1 >= sizeof(buf2))
return EINA_FALSE;
@ -1189,22 +1214,22 @@ _elm_config_profile_save(void)
err = _elm_config_eet_close_error_get(ef, buf2);
if (err)
{
ERR("%s", err);
free((void *)err);
goto err;
ERR("%s", err);
free((void *)err);
goto err;
}
ret = ecore_file_mv(buf2, buf);
if (!ret)
{
ERR("Error saving Elementary's configuration file");
goto err;
ERR("Error saving Elementary's configuration file");
goto err;
}
ecore_file_unlink(buf2);
return EINA_TRUE;
err:
err:
ecore_file_unlink(buf2);
return EINA_FALSE;
}
@ -1225,9 +1250,9 @@ _elm_config_save(void)
ok = ecore_file_mkpath(buf);
if (!ok)
{
ERR("Problem acessing Elementary's user configuration directory: %s",
buf);
return EINA_FALSE;
ERR("Problem acessing Elementary's user configuration directory: %s",
buf);
return EINA_FALSE;
}
if (!_elm_config_profile_save())
@ -1259,22 +1284,22 @@ _elm_config_save(void)
err = _elm_config_eet_close_error_get(ef, buf2);
if (err)
{
ERR("%s", err);
free((void *)err);
goto err;
ERR("%s", err);
free((void *)err);
goto err;
}
ret = ecore_file_mv(buf2, buf);
if (!ret)
{
ERR("Error saving Elementary's configuration file");
goto err;
ERR("Error saving Elementary's configuration file");
goto err;
}
ecore_file_unlink(buf2);
return EINA_TRUE;
err:
err:
ecore_file_unlink(buf2);
return EINA_FALSE;
}
@ -1289,22 +1314,22 @@ _config_update(void)
{
/* weird profile or something? We should probably fill
* with hardcoded defaults, or get from default previx */
return;
return;
}
#define IFCFG(v) if ((_elm_config->config_version & 0xffff) < (v)) {
#define IFCFG(v) if ((_elm_config->config_version & 0xffff) < (v)) {
#define IFCFGELSE } else {
#define IFCFGEND }
#define COPYVAL(x) do {_elm_config->x = tcfg->x;} while(0)
#define IFCFGEND }
#define COPYVAL(x) do {_elm_config->x = tcfg->x; } while(0)
#define COPYPTR(x) do {_elm_config->x = tcfg->x; tcfg->x = NULL; } while(0)
#define COPYSTR(x) COPYPTR(x)
/* we also need to update for property changes in the root window
* if needed, but that will be dependent on new properties added
* with each version */
/* we also need to update for property changes in the root window
* if needed, but that will be dependent on new properties added
* with each version */
IFCFG(0x0003);
COPYVAL(longpress_timeout);
IFCFGEND;
IFCFG(0x0003);
COPYVAL(longpress_timeout);
IFCFGEND;
#undef COPYSTR
#undef COPYPTR
@ -1313,7 +1338,7 @@ _config_update(void)
#undef IFCFGELSE
#undef IFCFG
/* after updating user config, we must save */
/* after updating user config, we must save */
}
static void
@ -1417,9 +1442,11 @@ _env_get(void)
s = getenv("ELM_FONT_HINTING");
if (s)
{
if (!strcasecmp(s, "none")) _elm_config->font_hinting = 0;
else if (!strcasecmp(s, "auto")) _elm_config->font_hinting = 1;
else if (!strcasecmp(s, "bytecode")) _elm_config->font_hinting = 2;
if (!strcasecmp(s, "none")) _elm_config->font_hinting = 0;
else if (!strcasecmp(s, "auto"))
_elm_config->font_hinting = 1;
else if (!strcasecmp(s, "bytecode"))
_elm_config->font_hinting = 2;
}
s = getenv("ELM_FONT_PATH");
@ -1436,7 +1463,7 @@ _env_get(void)
buf2 = alloca(strlen(s) + 1);
p = s;
pp = p;
for (;;)
for (;; )
{
if ((*p == ':') || (*p == 0))
{
@ -1509,11 +1536,11 @@ _env_get(void)
s = getenv("ELM_ICON_SIZE");
if (s) _elm_config->icon_size = atoi(s);
s = getenv("ELM_LONGPRESS_TIMEOUT");
if (s) _elm_config->longpress_timeout = atof(s);
if (_elm_config->longpress_timeout < 0.0)
_elm_config->longpress_timeout = 0.0;
_elm_config->longpress_timeout = 0.0;
}
void
@ -1532,10 +1559,10 @@ void
_elm_config_sub_init(void)
{
#define ENGINE_COMPARE(name) (!strcmp(_elm_config->engine, name))
if (ENGINE_COMPARE(ELM_SOFTWARE_X11) ||
ENGINE_COMPARE(ELM_SOFTWARE_16_X11) ||
ENGINE_COMPARE(ELM_XRENDER_X11) ||
ENGINE_COMPARE(ELM_OPENGL_X11))
if (ENGINE_COMPARE(ELM_SOFTWARE_X11) ||
ENGINE_COMPARE(ELM_SOFTWARE_16_X11) ||
ENGINE_COMPARE(ELM_XRENDER_X11) ||
ENGINE_COMPARE(ELM_OPENGL_X11))
#undef ENGINE_COMPARE
{
#ifdef HAVE_ELEMENTARY_X
@ -1555,7 +1582,7 @@ _elm_config_sub_init(void)
ecore_x_event_mask_set(_root_1st,
ECORE_X_EVENT_MASK_WINDOW_PROPERTY);
_prop_change_handler = ecore_event_handler_add
(ECORE_X_EVENT_WINDOW_PROPERTY, _prop_change, NULL);
(ECORE_X_EVENT_WINDOW_PROPERTY, _prop_change, NULL);
if (!getenv("ELM_SCALE"))
{
if (ecore_x_window_prop_card32_get(_root_1st,
@ -1565,7 +1592,7 @@ _elm_config_sub_init(void)
if (val > 0)
{
_elm_config->scale = (double)val / 1000.0;
// FIXME: hack until e export finger size too
// FIXME: hack until e export finger size too
if (!getenv("ELM_FINGER_SIZE"))
{
_elm_config->finger_size = 40.0 * _elm_config->scale;
@ -1626,56 +1653,56 @@ _elm_config_sub_init(void)
void
_elm_config_reload(void)
{
_config_free();
_config_load();
_config_apply();
_elm_config_font_overlay_apply();
_elm_rescale();
_elm_recache();
_config_free();
_config_load();
_config_apply();
_elm_config_font_overlay_apply();
_elm_rescale();
_elm_recache();
}
void
_elm_config_engine_set(const char *engine)
{
if (_elm_config->engine && strcmp(_elm_config->engine, engine))
eina_stringshare_del(_elm_config->engine);
if (_elm_config->engine && strcmp(_elm_config->engine, engine))
eina_stringshare_del(_elm_config->engine);
_elm_config->engine = eina_stringshare_add(engine);
_elm_config->engine = eina_stringshare_add(engine);
}
void
_elm_config_profile_set(const char *profile)
{
Eina_Bool changed = EINA_FALSE;
Eina_Bool changed = EINA_FALSE;
if (_elm_profile)
{
if (strcmp(_elm_profile, profile))
changed = 1;
free(_elm_profile);
}
if (_elm_profile)
{
if (strcmp(_elm_profile, profile))
changed = 1;
free(_elm_profile);
}
_elm_profile = strdup(profile);
_elm_profile = strdup(profile);
if (changed)
{
_config_free();
_config_load();
_config_apply();
_elm_config_font_overlay_apply();
_elm_rescale();
_elm_recache();
}
if (changed)
{
_config_free();
_config_load();
_config_apply();
_elm_config_font_overlay_apply();
_elm_rescale();
_elm_recache();
}
}
void
_elm_config_shutdown(void)
{
#define ENGINE_COMPARE(name) (!strcmp(_elm_config->engine, name))
if (ENGINE_COMPARE(ELM_SOFTWARE_X11) ||
ENGINE_COMPARE(ELM_SOFTWARE_16_X11) ||
ENGINE_COMPARE(ELM_XRENDER_X11) ||
ENGINE_COMPARE(ELM_OPENGL_X11))
if (ENGINE_COMPARE(ELM_SOFTWARE_X11) ||
ENGINE_COMPARE(ELM_SOFTWARE_16_X11) ||
ENGINE_COMPARE(ELM_XRENDER_X11) ||
ENGINE_COMPARE(ELM_OPENGL_X11))
#undef ENGINE_COMPARE
{
#ifdef HAVE_ELEMENTARY_X
@ -1691,3 +1718,4 @@ _elm_config_shutdown(void)
}
_desc_shutdown();
}