diff --git a/src/bin/ui.c b/src/bin/ui.c index 294f120..756bafc 100644 --- a/src/bin/ui.c +++ b/src/bin/ui.c @@ -620,43 +620,31 @@ _sort_by_state(const void *p1, const void *p2) return strcmp(inf1->state, inf2->state); } -static char * -_entry_trim_text(Evas_Object *entry, const char *text) +static void +_text_fields_init(Ui *ui) { - char *result; - unsigned int max; - int w, cw; - - result = strdup(text); - - evas_object_geometry_get(entry, NULL, NULL, &w, NULL); - - Evas_Object *textblock = elm_entry_textblock_get(entry); - if (textblock && w > 0) + for (int i = 0; i < PROCESS_INFO_FIELDS; i++) { - Evas_Textblock_Cursor *cursor = evas_object_textblock_cursor_get(textblock); - if ((evas_textblock_cursor_char_geometry_get(cursor, NULL, NULL, &cw, NULL)) != -1) - { - if (cw > 0) - { - max = (w / cw) - 3; - if (strlen(result) > max) - result[max] = '\0'; - } - } + ui->text_fields[i] = malloc(TEXT_FIELD_MAX * sizeof(char)); + ui->text_fields[i][0] = '\0'; } - - return result; } static void -_text_fields_init(Ui *ui) +_entry_cmd_size_set(Ui *ui) { - for (int i = 0; i < PROCESS_INFO_FIELDS; i++) + static Evas_Coord minw = 0, minh = 0; + Evas_Coord w, h; + + evas_object_geometry_get(ui->btn_cmd, NULL, NULL, NULL, &h); + evas_object_geometry_get(ui->entry_cmd, NULL, NULL, &w, NULL); + + if ((!minw && !minh) || (w >= minw && h > minh)) { - ui->text_fields[i] = malloc(TEXT_FIELD_MAX * sizeof(char)); - ui->text_fields[i][0] = '\0'; + minw = w; minh = h; } + + evas_object_size_hint_min_set(ui->btn_cmd, minw, minh); } static void @@ -690,12 +678,7 @@ _text_fields_append(Ui *ui, Proc_Stats *proc) eina_strlcat(ui->text_fields[PROCESS_INFO_FIELD_UID], eina_slstr_printf("%d
", proc->uid), TEXT_FIELD_MAX); eina_strlcat(ui->text_fields[PROCESS_INFO_FIELD_SIZE], eina_slstr_printf("%lld %c
", mem_size, ui->data_unit), TEXT_FIELD_MAX); eina_strlcat(ui->text_fields[PROCESS_INFO_FIELD_RSS], eina_slstr_printf("%lld %c
", mem_rss, ui->data_unit), TEXT_FIELD_MAX); - - // Make sure we don't wrap text if widget is too small. - char *cmd = _entry_trim_text(ui->entry_cmd, proc->command); - eina_strlcat(ui->text_fields[PROCESS_INFO_FIELD_COMMAND], eina_slstr_printf("%s
", cmd), TEXT_FIELD_MAX); - free(cmd); - + eina_strlcat(ui->text_fields[PROCESS_INFO_FIELD_COMMAND], eina_slstr_printf("%s
", proc->command), TEXT_FIELD_MAX); eina_strlcat(ui->text_fields[PROCESS_INFO_FIELD_STATE], eina_slstr_printf("%s
", proc->state), TEXT_FIELD_MAX); eina_strlcat(ui->text_fields[PROCESS_INFO_FIELD_CPU_USAGE], eina_slstr_printf("%.1f%%
", proc->cpu_usage), TEXT_FIELD_MAX); } @@ -824,6 +807,8 @@ _process_list_feedback_cb(void *data, Ecore_Thread *thread EINA_UNUSED, void *ms if (list) eina_list_free(list); + _entry_cmd_size_set(ui); + _text_fields_show(ui); _text_fields_clear(ui); @@ -1369,10 +1354,7 @@ _ui_tab_system_add(Ui *ui) evas_object_size_hint_weight_set(scroller, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND); evas_object_size_hint_align_set(scroller, EVAS_HINT_FILL, EVAS_HINT_FILL); elm_scroller_policy_set(scroller, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_ON); - elm_scroller_bounce_set(scroller, EINA_FALSE, EINA_FALSE); - elm_scroller_gravity_set(scroller, 0.0, 0.0); - elm_scroller_wheel_disabled_set(scroller, 1); - elm_scroller_page_relative_set(scroller, 1, 0); + elm_scroller_wheel_disabled_set(scroller, EINA_FALSE); evas_object_show(scroller); elm_object_content_set(scroller, table); @@ -1395,8 +1377,8 @@ _ui_tab_system_add(Ui *ui) elm_entry_text_style_user_push(entry, "DEFAULT='align=center'"); evas_object_size_hint_weight_set(entry, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND); evas_object_size_hint_align_set(entry, EVAS_HINT_FILL, 0); - elm_entry_scrollable_set(entry, 0); - elm_entry_editable_set(entry, 0); + elm_entry_scrollable_set(entry, EINA_FALSE); + elm_entry_editable_set(entry, EINA_FALSE); evas_object_show(entry); elm_table_pack(table, entry, 0, 0, 1, 1); @@ -1459,6 +1441,7 @@ _ui_tab_system_add(Ui *ui) evas_object_size_hint_align_set(entry, EVAS_HINT_FILL, 0); elm_entry_scrollable_set(entry, 0); elm_entry_editable_set(entry, 0); + elm_entry_line_wrap_set(entry, ELM_WRAP_NONE); evas_object_show(entry); elm_table_pack(table, entry, 4, 0, 1, 1);