diff options
Diffstat (limited to 'src/modules/sysinfo/netstatus/netstatus.c')
-rw-r--r-- | src/modules/sysinfo/netstatus/netstatus.c | 509 |
1 files changed, 0 insertions, 509 deletions
diff --git a/src/modules/sysinfo/netstatus/netstatus.c b/src/modules/sysinfo/netstatus/netstatus.c deleted file mode 100644 index 045724ea8f..0000000000 --- a/src/modules/sysinfo/netstatus/netstatus.c +++ /dev/null @@ -1,509 +0,0 @@ -#include "netstatus.h" - -typedef struct _Thread_Config Thread_Config; - -struct _Thread_Config -{ - int interval; - Instance *inst; - Eina_Bool automax; - time_t checktime; - int inpercent; - unsigned long in; - unsigned long incurrent; - unsigned long inmax; - Eina_Stringshare *instring; - int outpercent; - unsigned long out; - unsigned long outcurrent; - unsigned long outmax; - Eina_Stringshare *outstring; - E_Powersave_Sleeper *sleeper; -}; - -static void -_netstatus_face_update(Thread_Config *thc) -{ - Edje_Message_Int_Set *msg; - - msg = malloc(sizeof(Edje_Message_Int_Set) + 6 * sizeof(int)); - EINA_SAFETY_ON_NULL_RETURN(msg); - msg->count = 6; - msg->val[0] = thc->incurrent; - msg->val[1] = thc->inpercent; - msg->val[2] = thc->inmax; - msg->val[3] = thc->outcurrent; - msg->val[4] = thc->outpercent; - msg->val[5] = thc->outmax; - edje_object_message_send(elm_layout_edje_get(thc->inst->cfg->netstatus.o_gadget), - EDJE_MESSAGE_INT_SET, 1, msg); - E_FREE(msg); - - if (thc->inst->cfg->netstatus.popup) - { - char buf[4096]; - snprintf(buf, sizeof(buf), "%s (%d %%%%)", - thc->inst->cfg->netstatus.instring, - thc->inst->cfg->netstatus.inpercent); - elm_progressbar_unit_format_set(thc->inst->cfg->netstatus.popup_inpbar, buf); - elm_progressbar_value_set(thc->inst->cfg->netstatus.popup_inpbar, - (float)thc->inst->cfg->netstatus.inpercent / 100); - memset(buf, 0x00, sizeof(buf)); - snprintf(buf, sizeof(buf), "%s (%d %%%%)", - thc->inst->cfg->netstatus.outstring, - thc->inst->cfg->netstatus.outpercent); - elm_progressbar_unit_format_set(thc->inst->cfg->netstatus.popup_outpbar, buf); - elm_progressbar_value_set(thc->inst->cfg->netstatus.popup_outpbar, - (float)thc->inst->cfg->netstatus.outpercent / 100); - } -} - -static Evas_Object * -_netstatus_configure_cb(Evas_Object *g) -{ - Instance *inst = evas_object_data_get(g, "Instance"); - - if (!sysinfo_config) return NULL; - return netstatus_configure(inst); -} - -static void -_netstatus_popup_dismissed(void *data, Evas_Object *obj, void *event_info EINA_UNUSED) -{ - Instance *inst = data; - E_FREE_FUNC(obj, evas_object_del); - inst->cfg->netstatus.popup = NULL; -} - -static void -_netstatus_popup_deleted(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED) -{ - Instance *inst = data; - inst->cfg->netstatus.popup = NULL; -} - -static void -_netstatus_mouse_up_cb(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_data) -{ - Evas_Object *label, *popup, *table, *pbar; - Evas_Event_Mouse_Up *ev = event_data; - Instance *inst = data; - char text[4096], buf[4096]; - - if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD) return; - if (ev->button == 1) - { - if (inst->cfg->netstatus.popup) - { - elm_ctxpopup_dismiss(inst->cfg->netstatus.popup); - return; - } - popup = elm_ctxpopup_add(e_comp->elm); - elm_object_style_set(popup, "noblock"); - evas_object_smart_callback_add(popup, "dismissed", _netstatus_popup_dismissed, inst); - evas_object_event_callback_add(popup, EVAS_CALLBACK_DEL, _netstatus_popup_deleted, inst); - - table = elm_table_add(popup); - E_EXPAND(table); - E_FILL(table); - elm_object_content_set(popup, table); - evas_object_show(table); - - snprintf(text, sizeof(text), "<big><b>%s</b></big>", _("Network Throughput")); - - label = elm_label_add(table); - E_EXPAND(label); E_ALIGN(label, 0.5, 0.5); - elm_object_text_set(label, text); - elm_table_pack(table, label, 0, 0, 2, 1); - evas_object_show(label); - - label = elm_label_add(table); - E_ALIGN(label, 0.0, 0.5); - elm_object_text_set(label, _("Receiving")); - elm_table_pack(table, label, 0, 1, 1, 1); - evas_object_show(label); - - snprintf(buf, sizeof(buf), "%s (%d %%%%)", - inst->cfg->netstatus.instring, - inst->cfg->netstatus.inpercent); - - pbar = elm_progressbar_add(table); - E_EXPAND(pbar); - E_FILL(pbar); - elm_progressbar_span_size_set(pbar, 200 * e_scale); - elm_progressbar_unit_format_set(pbar, buf); - elm_progressbar_value_set(pbar, (float)inst->cfg->netstatus.inpercent / 100); - elm_table_pack(table, pbar, 1, 1, 1, 1); - evas_object_show(pbar); - inst->cfg->netstatus.popup_inpbar = pbar; - - label = elm_label_add(table); - E_ALIGN(label, 0.0, 0.5); - elm_object_text_set(label, _("Sending")); - elm_table_pack(table, label, 0, 2, 1, 1); - evas_object_show(label); - - memset(buf, 0x00, sizeof(buf)); - snprintf(buf, sizeof(buf), "%s (%d %%%%)", - inst->cfg->netstatus.outstring, - inst->cfg->netstatus.outpercent); - - pbar = elm_progressbar_add(table); - E_EXPAND(pbar); - E_FILL(pbar); - elm_progressbar_span_size_set(pbar, 200 * e_scale); - elm_progressbar_unit_format_set(pbar, buf); - elm_progressbar_value_set(pbar, (float)inst->cfg->netstatus.outpercent / 100); - elm_table_pack(table, pbar, 1, 2, 1, 1); - evas_object_show(pbar); - inst->cfg->netstatus.popup_outpbar = pbar; - - e_gadget_util_ctxpopup_place(inst->o_main, popup, - inst->cfg->netstatus.o_gadget); - evas_object_show(popup); - inst->cfg->netstatus.popup = popup; - } -} - -static void -_netstatus_resize_cb(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_data EINA_UNUSED) -{ - Evas_Coord w, h; - Instance *inst = data; - - edje_object_parts_extends_calc(elm_layout_edje_get(inst->cfg->netstatus.o_gadget), 0, 0, &w, &h); - if (w < 1) w = 1; - if (h < 1) h = 1; - if (inst->cfg->esm == E_SYSINFO_MODULE_NETSTATUS) - evas_object_size_hint_aspect_set(inst->o_main, EVAS_ASPECT_CONTROL_BOTH, w, h); - else - evas_object_size_hint_aspect_set(inst->cfg->netstatus.o_gadget, EVAS_ASPECT_CONTROL_BOTH, w, h); -} - -static void -_netstatus_cb_usage_check_main(void *data, Ecore_Thread *th) -{ - Thread_Config *thc = data; - for (;; ) - { - char rin[4096], rout[4096]; - - if (ecore_thread_check(th)) break; -#if defined(__FreeBSD__) || defined(__DragonFly__) || defined(__OpenBSD__) - _netstatus_sysctl_getstatus(thc->automax, &thc->checktime, &thc->in, &thc->incurrent, - &thc->inmax, &thc->inpercent, &thc->out, &thc->outcurrent, &thc->outmax, - &thc->outpercent); -#else - _netstatus_proc_getstatus(thc->automax, &thc->checktime, &thc->in, &thc->incurrent, - &thc->inmax, &thc->inpercent, &thc->out, &thc->outcurrent, &thc->outmax, - &thc->outpercent); -#endif - if (!thc->incurrent) - { - snprintf(rin, sizeof(rin), "0 B/s"); - } - else - { - if (thc->incurrent > 1048576) - snprintf(rin, sizeof(rin), "%.2f MB/s", ((float)thc->incurrent / 1048576)); - else if ((thc->incurrent > 1024) && (thc->incurrent < 1048576)) - snprintf(rin, sizeof(rin), "%lu KB/s", (thc->incurrent / 1024)); - else - snprintf(rin, sizeof(rin), "%lu B/s", thc->incurrent); - } - eina_stringshare_replace(&thc->instring, rin); - if (!thc->outcurrent) - { - snprintf(rout, sizeof(rout), "0 B/s"); - } - else - { - if (thc->outcurrent > 1048576) - snprintf(rout, sizeof(rout), "%.2f MB/s", ((float)thc->outcurrent / 1048576)); - else if ((thc->outcurrent > 1024) && (thc->outcurrent < 1048576)) - snprintf(rout, sizeof(rout), "%lu KB/s", (thc->outcurrent / 1024)); - else - snprintf(rout, sizeof(rout), "%lu B/s", thc->outcurrent); - } - eina_stringshare_replace(&thc->outstring, rout); - ecore_thread_feedback(th, NULL); - if (ecore_thread_check(th)) break; - e_powersave_sleeper_sleep(thc->sleeper, thc->interval); - if (ecore_thread_check(th)) break; - } -} - -static void -_netstatus_cb_usage_check_notify(void *data, - Ecore_Thread *th EINA_UNUSED, - void *msg EINA_UNUSED) -{ - Thread_Config *thc = data; - - if (!thc->inst->cfg) return; - if (thc->inst->cfg->esm != E_SYSINFO_MODULE_NETSTATUS && thc->inst->cfg->esm != E_SYSINFO_MODULE_SYSINFO) return; - - eina_stringshare_replace(&thc->inst->cfg->netstatus.instring, thc->instring); - eina_stringshare_replace(&thc->inst->cfg->netstatus.outstring, thc->outstring); - thc->inst->cfg->netstatus.inpercent = thc->inpercent; - thc->inst->cfg->netstatus.outpercent = thc->outpercent; - _netstatus_face_update(thc); -} - -static void -_netstatus_cb_usage_check_end(void *data, Ecore_Thread *th EINA_UNUSED) -{ - Thread_Config *thc = data; - e_powersave_sleeper_free(thc->sleeper); - E_FREE_FUNC(thc->instring, eina_stringshare_del); - E_FREE_FUNC(thc->outstring, eina_stringshare_del); - E_FREE(thc); -} - -static Eina_Bool -_screensaver_on(void *data) -{ - Instance *inst = data; - - if (inst->cfg->netstatus.usage_check_thread) - { - ecore_thread_cancel(inst->cfg->netstatus.usage_check_thread); - inst->cfg->netstatus.usage_check_thread = NULL; - } - return ECORE_CALLBACK_RENEW; -} - -static Eina_Bool -_screensaver_off(void *data) -{ - Instance *inst = data; - - _netstatus_config_updated(inst); - - return ECORE_CALLBACK_RENEW; -} - -void -_netstatus_config_updated(Instance *inst) -{ - Thread_Config *thc; - - if (inst->cfg->id == -1) - { - thc = E_NEW(Thread_Config, 1); - if (thc) - { - thc->inst = inst; - thc->inpercent = 75; - thc->outpercent = 30; - _netstatus_face_update(thc); - E_FREE(thc); - } - return; - } - if (inst->cfg->netstatus.usage_check_thread) - { - ecore_thread_cancel(inst->cfg->netstatus.usage_check_thread); - inst->cfg->netstatus.usage_check_thread = NULL; - } - thc = E_NEW(Thread_Config, 1); - if (thc) - { - thc->inst = inst; - thc->sleeper = e_powersave_sleeper_new(); - thc->interval = inst->cfg->netstatus.poll_interval; - thc->in = 0; - thc->inmax = inst->cfg->netstatus.inmax; - thc->incurrent = 0; - thc->inpercent = 0; - thc->instring = NULL; - thc->out = 0; - thc->outmax = inst->cfg->netstatus.outmax; - thc->outcurrent = 0; - thc->outpercent = 0; - thc->outstring = NULL; - thc->automax = inst->cfg->netstatus.automax; - inst->cfg->netstatus.usage_check_thread = - ecore_thread_feedback_run(_netstatus_cb_usage_check_main, - _netstatus_cb_usage_check_notify, - _netstatus_cb_usage_check_end, - _netstatus_cb_usage_check_end, thc, EINA_TRUE); - } - e_config_save_queue(); -} - -static void -_netstatus_removed_cb(void *data, Evas_Object *obj EINA_UNUSED, void *event_data) -{ - Instance *inst = data; - Ecore_Event_Handler *handler; - - if (inst->o_main != event_data) return; - - if (inst->cfg->netstatus.popup) - E_FREE_FUNC(inst->cfg->netstatus.popup, evas_object_del); - if (inst->cfg->netstatus.configure) - E_FREE_FUNC(inst->cfg->netstatus.configure, evas_object_del); - evas_object_smart_callback_del_full(e_gadget_site_get(inst->o_main), "gadget_removed", - _netstatus_removed_cb, inst); - evas_object_event_callback_del_full(inst->o_main, EVAS_CALLBACK_DEL, sysinfo_netstatus_remove, data); - EINA_LIST_FREE(inst->cfg->netstatus.handlers, handler) - ecore_event_handler_del(handler); - if (inst->cfg->netstatus.usage_check_thread) - { - ecore_thread_cancel(inst->cfg->netstatus.usage_check_thread); - inst->cfg->netstatus.usage_check_thread = NULL; - } - E_FREE_FUNC(inst->cfg->netstatus.instring, eina_stringshare_del); - E_FREE_FUNC(inst->cfg->netstatus.outstring, eina_stringshare_del); - - sysinfo_config->items = eina_list_remove(sysinfo_config->items, inst->cfg); - if (inst->cfg->id >= 0) - sysinfo_instances = eina_list_remove(sysinfo_instances, inst); - E_FREE(inst->cfg); - E_FREE(inst); -} - -void -sysinfo_netstatus_remove(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_data EINA_UNUSED) -{ - Instance *inst = data; - Ecore_Event_Handler *handler; - - if (inst->cfg->netstatus.popup) - E_FREE_FUNC(inst->cfg->netstatus.popup, evas_object_del); - if (inst->cfg->netstatus.configure) - E_FREE_FUNC(inst->cfg->netstatus.configure, evas_object_del); - EINA_LIST_FREE(inst->cfg->netstatus.handlers, handler) - ecore_event_handler_del(handler); - if (inst->cfg->netstatus.usage_check_thread) - { - ecore_thread_cancel(inst->cfg->netstatus.usage_check_thread); - inst->cfg->netstatus.usage_check_thread = NULL; - return; - } - E_FREE_FUNC(inst->cfg->netstatus.instring, eina_stringshare_del); - E_FREE_FUNC(inst->cfg->netstatus.outstring, eina_stringshare_del); -} - -static void -_netstatus_created_cb(void *data, Evas_Object *obj, void *event_data EINA_UNUSED) -{ - Instance *inst = data; - E_Gadget_Site_Orient orient = e_gadget_site_orient_get(e_gadget_site_get(inst->o_main)); - - e_gadget_configure_cb_set(inst->o_main, _netstatus_configure_cb); - - inst->cfg->netstatus.popup = NULL; - inst->cfg->netstatus.instring = NULL; - inst->cfg->netstatus.outstring = NULL; - inst->cfg->netstatus.inpercent = 0; - inst->cfg->netstatus.outpercent = 0; - - inst->cfg->netstatus.o_gadget = elm_layout_add(inst->o_main); - if (orient == E_GADGET_SITE_ORIENT_VERTICAL) - e_theme_edje_object_set(inst->cfg->netstatus.o_gadget, - "base/theme/gadget/netstatus", - "e/gadget/netstatus/main_vert"); - else - e_theme_edje_object_set(inst->cfg->netstatus.o_gadget, "base/theme/gadget/netstatus", - "e/gadget/netstatus/main"); - E_EXPAND(inst->cfg->netstatus.o_gadget); - E_FILL(inst->cfg->netstatus.o_gadget); - elm_box_pack_end(inst->o_main, inst->cfg->netstatus.o_gadget); - evas_object_event_callback_add(inst->cfg->netstatus.o_gadget, EVAS_CALLBACK_MOUSE_UP, _netstatus_mouse_up_cb, inst); - evas_object_event_callback_add(inst->cfg->netstatus.o_gadget, EVAS_CALLBACK_RESIZE, _netstatus_resize_cb, inst); - evas_object_show(inst->cfg->netstatus.o_gadget); - evas_object_smart_callback_del_full(obj, "gadget_created", _netstatus_created_cb, data); - - E_LIST_HANDLER_APPEND(inst->cfg->netstatus.handlers, E_EVENT_SCREENSAVER_ON, _screensaver_on, inst); - E_LIST_HANDLER_APPEND(inst->cfg->netstatus.handlers, E_EVENT_SCREENSAVER_OFF, _screensaver_off, inst); - - _netstatus_config_updated(inst); -} - -Evas_Object * -sysinfo_netstatus_create(Evas_Object *parent, Instance *inst) -{ - inst->cfg->netstatus.popup = NULL; - inst->cfg->netstatus.instring = NULL; - inst->cfg->netstatus.outstring = NULL; - inst->cfg->netstatus.inpercent = 0; - inst->cfg->netstatus.outpercent = 0; - - inst->cfg->netstatus.o_gadget = elm_layout_add(parent); - e_theme_edje_object_set(inst->cfg->netstatus.o_gadget, "base/theme/gadget/netstatus", - "e/gadget/netstatus/main"); - E_EXPAND(inst->cfg->netstatus.o_gadget); - E_FILL(inst->cfg->netstatus.o_gadget); - evas_object_event_callback_add(inst->cfg->netstatus.o_gadget, EVAS_CALLBACK_MOUSE_UP, _netstatus_mouse_up_cb, inst); - evas_object_event_callback_add(inst->cfg->netstatus.o_gadget, EVAS_CALLBACK_RESIZE, _netstatus_resize_cb, inst); - evas_object_show(inst->cfg->netstatus.o_gadget); - - E_LIST_HANDLER_APPEND(inst->cfg->netstatus.handlers, E_EVENT_SCREENSAVER_ON, _screensaver_on, inst); - E_LIST_HANDLER_APPEND(inst->cfg->netstatus.handlers, E_EVENT_SCREENSAVER_OFF, _screensaver_off, inst); - - _netstatus_config_updated(inst); - - return inst->cfg->netstatus.o_gadget; -} - -static Config_Item * -_conf_item_get(int *id) -{ - Config_Item *ci; - Eina_List *l; - - if (*id > 0) - { - EINA_LIST_FOREACH(sysinfo_config->items, l, ci) - if (*id == ci->id && ci->esm == E_SYSINFO_MODULE_NETSTATUS) return ci; - } - - ci = E_NEW(Config_Item, 1); - - if (*id != -1) - ci->id = eina_list_count(sysinfo_config->items) + 1; - else - ci->id = -1; - - ci->esm = E_SYSINFO_MODULE_NETSTATUS; - ci->netstatus.poll_interval = 32; - ci->netstatus.automax = EINA_TRUE; - ci->netstatus.receive_units = NETSTATUS_UNIT_BYTES; - ci->netstatus.send_units = NETSTATUS_UNIT_BYTES; - ci->netstatus.instring = NULL; - ci->netstatus.outstring = NULL; - ci->netstatus.popup = NULL; - ci->netstatus.configure = NULL; - sysinfo_config->items = eina_list_append(sysinfo_config->items, ci); - - return ci; -} - -Evas_Object * -netstatus_create(Evas_Object *parent, int *id, E_Gadget_Site_Orient orient EINA_UNUSED) -{ - Instance *inst; - - inst = E_NEW(Instance, 1); - inst->cfg = _conf_item_get(id); - *id = inst->cfg->id; - inst->cfg->netstatus.instring = NULL; - inst->cfg->netstatus.outstring = NULL; - inst->cfg->netstatus.popup = NULL; - inst->o_main = elm_box_add(parent); - evas_object_data_set(inst->o_main, "Instance", inst); - evas_object_smart_callback_add(parent, "gadget_created", _netstatus_created_cb, inst); - evas_object_smart_callback_add(parent, "gadget_removed", _netstatus_removed_cb, inst); - evas_object_event_callback_add(inst->o_main, EVAS_CALLBACK_DEL, sysinfo_netstatus_remove, inst); - evas_object_show(inst->o_main); - - if (inst->cfg->id < 0) return inst->o_main; - - sysinfo_instances = - eina_list_append(sysinfo_instances, inst); - - return inst->o_main; -} - |