make filepreview for links and removable devices and mountpoints give

fs type, filesystem usage, size etc. etc. much more useful.



SVN revision: 75429
This commit is contained in:
Carsten Haitzler 2012-08-19 13:28:51 +00:00
parent d53e3ee139
commit 9cc281f002
3 changed files with 284 additions and 106 deletions

View File

@ -4880,6 +4880,12 @@ _e_fm2_icon_desktop_url_eval(const char *val)
return s;
}
EAPI const char *
e_fm2_desktop_url_eval(const char *val)
{
return _e_fm2_icon_desktop_url_eval(val);
}
static void
_e_fm2_cb_eio_stat(void *data, Eio_File *handler __UNUSED__, const Eina_Stat *st)
{

View File

@ -189,17 +189,18 @@ EAPI Evas_Object *e_fm2_icon_get(Evas *evas, E_Fm2_Icon *ic, Evas_Smart_Cb g
void *data, int force_gen, const char **type_ret);
EAPI E_Fm2_Icon_Info *e_fm2_icon_file_info_get(E_Fm2_Icon *ic);
EAPI void e_fm2_icon_geometry_get(E_Fm2_Icon *ic, int *x, int *y, int *w, int *h);
EAPI Eina_Bool e_fm2_typebuf_visible_get(Evas_Object *obj);
EAPI Eina_Bool e_fm2_typebuf_visible_get(Evas_Object *obj);
EAPI void e_fm2_typebuf_clear(Evas_Object *obj);
EAPI void e_fm2_overlay_clip_to(Evas_Object *fm, Evas_Object *clip);
EAPI void e_fm2_client_data(Ecore_Ipc_Event_Client_Data *e);
EAPI void e_fm2_client_del(Ecore_Ipc_Event_Client_Del *e);
EAPI E_Fm2_View_Mode e_fm2_view_mode_get(Evas_Object *obj);
EAPI E_Fm2_View_Mode e_fm2_view_mode_get(Evas_Object *obj);
EAPI void e_fm2_optimal_size_calc(Evas_Object *obj, int maxw, int maxh, int *w, int *h);
EAPI const char *e_fm2_real_path_map(const char *dev, const char *path);
EAPI void e_fm2_favorites_init(void);
EAPI unsigned int e_fm2_selected_count(Evas_Object *obj);
EAPI unsigned int e_fm2_selected_count(Evas_Object *obj);
EAPI const char *e_fm2_desktop_url_eval(const char *val);
EAPI int _e_fm2_client_mount(const char *udi, const char *mountpoint);
EAPI int _e_fm2_client_unmount(const char *udi);

View File

@ -1,4 +1,6 @@
#include "e.h"
#include "e_fm_device.h"
#include <sys/statvfs.h>
typedef struct _E_Widget_Data E_Widget_Data;
struct _E_Widget_Data
@ -35,7 +37,7 @@ struct _E_Widget_Data
};
static void _e_wid_fprev_preview_update(void *data, Evas_Object *obj, void *event_info);
static void _e_wid_fprev_preview_file(E_Widget_Data *wd, const char *path);
static void _e_wid_fprev_preview_file(E_Widget_Data *wd);
static char *_e_wid_file_size_get(off_t st_size);
static char *_e_wid_file_user_get(uid_t st_uid);
static char *_e_wid_file_perms_get(mode_t st_mode, uid_t st_uid, gid_t gid);
@ -76,9 +78,9 @@ _e_wid_fprev_preview_update(void *data, Evas_Object *obj, void *event_info __UNU
const char *mime;
Efreet_Desktop *ed = NULL;
unsigned int size;
char group[1024];
char group[1024];
Eina_Bool edj;
wd->mime_icon = EINA_TRUE;
size = wd->w;
mime = e_util_mime_icon_get(wd->mime, size);
@ -118,13 +120,279 @@ _e_wid_fprev_img_update(E_Widget_Data *wd, const char *path, const char *key)
}
static void
_e_wid_fprev_preview_file(E_Widget_Data *wd, const char *path)
_e_wid_fprev_clear_widgets(E_Widget_Data *wd)
{
#define CLRWID(xx) \
do { if (wd->xx) { evas_object_del(wd->xx); wd->xx = NULL; } } while (0)
CLRWID(o_preview_preview_table);
CLRWID(o_preview_properties_table);
CLRWID(o_preview_scroll);
CLRWID(o_preview_extra);
CLRWID(o_preview_extra_entry);
CLRWID(o_preview_size);
CLRWID(o_preview_size_entry);
CLRWID(o_preview_owner);
CLRWID(o_preview_owner_entry);
CLRWID(o_preview_perms);
CLRWID(o_preview_perms_entry);
CLRWID(o_preview_time);
CLRWID(o_preview_time_entry);
CLRWID(o_preview_preview);
CLRWID(o_preview_scrollframe);
}
static void
_e_wid_fprev_preview_fs_widgets(E_Widget_Data *wd)
{
Evas *evas = evas_object_evas_get(wd->obj);
Evas_Object *o;
int mw, mh, y = 0;
_e_wid_fprev_clear_widgets(wd);
o = e_widget_table_add(evas, 0);
e_widget_disabled_set(o, 1);
wd->o_preview_properties_table = o;
#define WIDROW(lab, labob, entob, entw) \
do { \
o = e_widget_label_add(evas, lab); \
e_widget_disabled_set(o, 1); \
wd->labob = o; \
e_widget_table_object_append(wd->o_preview_properties_table, \
wd->labob, \
0, y, 1, 1, 1, 1, 1, 1); \
o = e_widget_entry_add(evas, &(wd->preview_extra_text), NULL, NULL, NULL); \
e_widget_entry_readonly_set(o, 1); \
e_widget_disabled_set(o, 1); \
wd->entob = o; \
e_widget_size_min_set(o, entw, -1); \
e_widget_table_object_append(wd->o_preview_properties_table, \
wd->entob, \
1, y, 1, 1, 1, 1, 1, 1); \
y++; \
} while (0)
WIDROW(_("Used:"), o_preview_extra, o_preview_extra_entry, 100);
WIDROW(_("Size:"), o_preview_size, o_preview_size_entry, 100);
WIDROW(_("Reserved:"), o_preview_owner, o_preview_owner_entry, 100);
WIDROW(_("Mount status:"), o_preview_perms, o_preview_perms_entry, 100);
WIDROW(_("Type:"), o_preview_time, o_preview_time_entry, 100);
e_widget_list_object_append(wd->o_preview_list,
wd->o_preview_properties_table,
1, 1, 0.5);
e_widget_size_min_get(wd->o_preview_list, &mw, &mh);
e_widget_size_min_set(wd->obj, mw, mh);
evas_object_show(wd->o_preview_preview_table);
evas_object_show(wd->o_preview_extra);
evas_object_show(wd->o_preview_extra_entry);
evas_object_show(wd->o_preview_size);
evas_object_show(wd->o_preview_size_entry);
evas_object_show(wd->o_preview_owner);
evas_object_show(wd->o_preview_owner_entry);
evas_object_show(wd->o_preview_perms);
evas_object_show(wd->o_preview_perms_entry);
evas_object_show(wd->o_preview_time);
evas_object_show(wd->o_preview_time_entry);
evas_object_show(wd->o_preview_properties_table);
}
static void
_e_wid_fprev_preview_file_widgets(E_Widget_Data *wd)
{
Evas *evas = evas_object_evas_get(wd->obj);
Evas_Object *o;
int mw, mh, y = 0;
_e_wid_fprev_clear_widgets(wd);
o = e_widget_table_add(evas, 0);
e_widget_disabled_set(o, 1);
wd->o_preview_preview_table = o;
e_widget_size_min_set(o, 32, 32);
e_widget_list_object_append(wd->o_preview_list,
wd->o_preview_preview_table,
0, 1, 0.5);
o = e_widget_table_add(evas, 0);
e_widget_disabled_set(o, 1);
wd->o_preview_properties_table = o;
WIDROW(_("Resolution:"), o_preview_extra, o_preview_extra_entry, 100);
WIDROW(_("Size:"), o_preview_size, o_preview_size_entry, 100);
WIDROW(_("Owner:"), o_preview_owner, o_preview_owner_entry, 100);
WIDROW(_("Permissions:"), o_preview_perms, o_preview_perms_entry, 100);
WIDROW(_("Modified:"), o_preview_time, o_preview_time_entry, 100);
e_widget_list_object_append(wd->o_preview_list,
wd->o_preview_properties_table,
1, 1, 0.5);
e_widget_size_min_get(wd->o_preview_list, &mw, &mh);
e_widget_size_min_set(wd->obj, mw, mh);
evas_object_show(wd->o_preview_preview_table);
evas_object_show(wd->o_preview_extra);
evas_object_show(wd->o_preview_extra_entry);
evas_object_show(wd->o_preview_size);
evas_object_show(wd->o_preview_size_entry);
evas_object_show(wd->o_preview_owner);
evas_object_show(wd->o_preview_owner_entry);
evas_object_show(wd->o_preview_perms);
evas_object_show(wd->o_preview_perms_entry);
evas_object_show(wd->o_preview_time);
evas_object_show(wd->o_preview_time_entry);
evas_object_show(wd->o_preview_properties_table);
}
static void
_e_wid_fprev_preview_file(E_Widget_Data *wd)
{
char *size, *owner, *perms, *mtime;
struct stat st;
int mw, mh;
Eina_Bool is_fs = EINA_FALSE;
if (stat(wd->path, &st) < 0) return;
// if its a desktop file treat is spcially
if (((wd->mime) &&(!strcasecmp(wd->mime, "application/x-desktop"))) ||
(eina_str_has_extension(wd->path, "desktop")))
{
Efreet_Desktop *desktop;
const char *type, *file;
// load it and if its a specual removable or mount point
// desktop file for e, then we want to do something special
desktop = efreet_desktop_new(wd->path);
if ((desktop) && (desktop->url) &&
(desktop->type == EFREET_DESKTOP_TYPE_LINK) &&
(desktop->x) &&
((type = eina_hash_find(desktop->x, "X-Enlightenment-Type"))) &&
((!strcmp(type, "Mount")) || (!strcmp(type, "Removable"))))
{
// find the "mountpoint" or "link" - it's stringshared
if ((file = e_fm2_desktop_url_eval(desktop->url)))
{
struct statvfs stfs;
Eina_Bool ok = EINA_FALSE;
memset(&stfs, 0, sizeof(stfs));
if (statvfs(file, &stfs) == 0) ok = EINA_TRUE;
else
{
E_Volume *v;
v = e_fm2_device_volume_find(file);
if (v)
{
if (statvfs(v->mount_point, &stfs) == 0)
{
ok = EINA_TRUE;
eina_stringshare_del(file);
file = eina_stringshare_add(v->mount_point);
}
}
}
if (ok)
{
unsigned long fragsz;
unsigned long long blknum, blkused, blkres;
double mbsize, mbused, mbres;
Eina_Bool rdonly = EINA_FALSE;
char buf[PATH_MAX], mpoint[4096], fstype[4096];
FILE *f;
fragsz = stfs.f_frsize;
blknum = stfs.f_blocks;
blkused = stfs.f_blocks - stfs.f_bfree;
blkres = stfs.f_bfree - stfs.f_bavail;
fstype[0] = 0;
mpoint[0] = 0;
f = fopen("/etc/mtab", "r");
if (f)
{
while (fgets(buf, sizeof(buf), f))
{
if (sscanf(buf, "%*s %4000s %4000s %*s",
mpoint, fstype) == 2)
{
if (!strcmp(mpoint, file)) break;
}
fstype[0] = 0;
mpoint[0] = 0;
}
fclose(f);
}
if (blknum > blkres)
{
is_fs = EINA_TRUE;
mbres = ((double)blkres * (double)fragsz) /
(double)(1024*1024);
mbsize = ((double)blknum * (double)fragsz) /
(double)(1024*1024);
mbused = (mbsize * (double)blkused) /
(double)blknum;
#ifdef ST_RDONLY
if (stfs.f_flag & ST_RDONLY) rdonly = EINA_TRUE;
#endif
_e_wid_fprev_preview_fs_widgets(wd);
//-------------------
if (mbused > 1024.0)
snprintf(buf, sizeof(buf), "%1.2f Gb", mbused / 1024.0);
else
snprintf(buf, sizeof(buf), "%1.2f Mb", mbused);
e_widget_entry_text_set(wd->o_preview_extra_entry, buf);
//-------------------
if (mbsize > 1024.0)
snprintf(buf, sizeof(buf), "%1.2f Gb", mbsize / 1024.0);
else
snprintf(buf, sizeof(buf), "%1.2f Mb", mbsize);
e_widget_entry_text_set(wd->o_preview_size_entry, buf);
//-------------------
if (mbres > 1024.0)
snprintf(buf, sizeof(buf), "%1.2f Gb", mbres / 1024.0);
else
snprintf(buf, sizeof(buf), "%1.2f Mb", mbres);
e_widget_entry_text_set(wd->o_preview_owner_entry, buf);
//-------------------
if (mpoint[0])
{
if (rdonly)
e_widget_entry_text_set(wd->o_preview_perms_entry, _("Read Only"));
else
e_widget_entry_text_set(wd->o_preview_perms_entry, _("Read / Write"));
}
else
e_widget_entry_text_set(wd->o_preview_perms_entry, _("Unmounted"));
//-------------------
e_widget_entry_text_set(wd->o_preview_time_entry, fstype);
}
}
if (!is_fs)
{
_e_wid_fprev_preview_fs_widgets(wd);
e_widget_entry_text_set(wd->o_preview_extra_entry, _("Unknown"));
e_widget_entry_text_set(wd->o_preview_size_entry, _("Unknown"));
e_widget_entry_text_set(wd->o_preview_owner_entry, _("Unknown"));
e_widget_entry_text_set(wd->o_preview_perms_entry, _("Unmounted"));
e_widget_entry_text_set(wd->o_preview_time_entry, _("Unknown"));
is_fs = EINA_TRUE;
}
eina_stringshare_del(file);
}
}
if (desktop) efreet_desktop_free(desktop);
}
if (is_fs) return;
_e_wid_fprev_preview_file_widgets(wd);
wd->mime_icon = EINA_FALSE;
size = _e_wid_file_size_get(st.st_size);
owner = _e_wid_file_user_get(st.st_uid);
@ -134,7 +402,7 @@ _e_wid_fprev_preview_file(E_Widget_Data *wd, const char *path)
_e_wid_fprev_preview_reset(wd);
_e_wid_fprev_preview_fm(wd);
_e_wid_fprev_img_update(wd, path, NULL);
_e_wid_fprev_img_update(wd, wd->path, NULL);
e_widget_size_min_get(wd->o_preview_list, &mw, &mh);
e_widget_size_min_set(wd->obj, mw, mh);
@ -418,103 +686,6 @@ e_widget_filepreview_add(Evas *evas, int w, int h, int horiz)
e_widget_resize_object_set(obj, o);
e_widget_sub_object_add(obj, o);
o = e_widget_table_add(evas, 0);
e_widget_disabled_set(o, 1);
wd->o_preview_preview_table = o;
e_widget_size_min_set(o, 32, 32);
e_widget_list_object_append(wd->o_preview_list,
wd->o_preview_preview_table,
0, 1, 0.5);
o = e_widget_table_add(evas, 0);
e_widget_disabled_set(o, 1);
wd->o_preview_properties_table = o;
o = e_widget_label_add(evas, _("Resolution:"));
e_widget_disabled_set(o, 1);
wd->o_preview_extra = o;
e_widget_table_object_append(wd->o_preview_properties_table,
wd->o_preview_extra,
0, 0, 1, 1, 1, 1, 1, 1);
o = e_widget_entry_add(evas, &(wd->preview_extra_text), NULL, NULL, NULL);
e_widget_entry_readonly_set(o, 1);
e_widget_disabled_set(o, 1);
wd->o_preview_extra_entry = o;
e_widget_size_min_set(o, 100, -1);
e_widget_table_object_append(wd->o_preview_properties_table,
wd->o_preview_extra_entry,
1, 0, 1, 1, 1, 1, 1, 1);
o = e_widget_label_add(evas, _("Size:"));
e_widget_disabled_set(o, 1);
wd->o_preview_size = o;
e_widget_table_object_append(wd->o_preview_properties_table,
wd->o_preview_size,
0, 1, 1, 1, 1, 1, 1, 1);
o = e_widget_entry_add(evas, &(wd->preview_size_text), NULL, NULL, NULL);
e_widget_entry_readonly_set(o, 1);
e_widget_disabled_set(o, 1);
wd->o_preview_size_entry = o;
e_widget_size_min_set(o, 100, -1);
e_widget_table_object_append(wd->o_preview_properties_table,
wd->o_preview_size_entry,
1, 1, 1, 1, 1, 1, 1, 1);
o = e_widget_label_add(evas, _("Owner:"));
e_widget_disabled_set(o, 1);
wd->o_preview_owner = o;
e_widget_table_object_append(wd->o_preview_properties_table,
wd->o_preview_owner,
0, 2, 1, 1, 1, 1, 1, 1);
o = e_widget_entry_add(evas, &(wd->preview_owner_text), NULL, NULL, NULL);
e_widget_entry_readonly_set(o, 1);
e_widget_disabled_set(o, 1);
wd->o_preview_owner_entry = o;
e_widget_size_min_set(o, 100, -1);
e_widget_table_object_append(wd->o_preview_properties_table,
wd->o_preview_owner_entry,
1, 2, 1, 1, 1, 1, 1, 1);
o = e_widget_label_add(evas, _("Permissions:"));
e_widget_disabled_set(o, 1);
wd->o_preview_perms = o;
e_widget_table_object_append(wd->o_preview_properties_table,
wd->o_preview_perms,
0, 3, 1, 1, 1, 1, 1, 1);
o = e_widget_entry_add(evas, &(wd->preview_perms_text), NULL, NULL, NULL);
e_widget_entry_readonly_set(o, 1);
e_widget_disabled_set(o, 1);
wd->o_preview_perms_entry = o;
e_widget_size_min_set(o, 100, -1);
e_widget_table_object_append(wd->o_preview_properties_table,
wd->o_preview_perms_entry,
1, 3, 1, 1, 1, 1, 1, 1);
o = e_widget_label_add(evas, _("Modified:"));
e_widget_disabled_set(o, 1);
wd->o_preview_time = o;
e_widget_table_object_append(wd->o_preview_properties_table,
wd->o_preview_time,
0, 4, 1, 1, 1, 1, 1, 1);
o = e_widget_entry_add(evas, &(wd->preview_time_text), NULL, NULL, NULL);
e_widget_entry_readonly_set(o, 1);
e_widget_disabled_set(o, 1);
wd->o_preview_time_entry = o;
e_widget_size_min_set(o, 100, -1);
e_widget_table_object_append(wd->o_preview_properties_table,
wd->o_preview_time_entry,
1, 4, 1, 1, 1, 1, 1, 1);
e_widget_list_object_append(wd->o_preview_list,
wd->o_preview_properties_table,
1, 1, 0.5);
e_widget_size_min_get(wd->o_preview_list, &mw, &mh);
e_widget_size_min_set(obj, mw, mh);
evas_object_show(wd->o_preview_preview_table);
@ -544,5 +715,5 @@ e_widget_filepreview_path_set(Evas_Object *obj, const char *path, const char *mi
if (!wd) return;
eina_stringshare_replace(&wd->path, path);
eina_stringshare_replace(&wd->mime, mime);
_e_wid_fprev_preview_file(wd, wd->path);
_e_wid_fprev_preview_file(wd);
}