clean up preview code - remove leak

SVN revision: 25117
This commit is contained in:
Carsten Haitzler 2006-08-26 09:00:17 +00:00
parent e3cdd6d2fa
commit fcfc736e73
1 changed files with 25 additions and 56 deletions

View File

@ -479,7 +479,7 @@ _e_wid_fsel_preview_update(void *data, Evas_Object *obj, void *event_info)
static void
_e_wid_fsel_preview_file(E_Widget_Data *wd)
{
char *size, *owner, *perms, *time;
char *size, *owner, *perms, *mtime;
struct stat st;
stat(wd->path, &st);
@ -487,7 +487,7 @@ _e_wid_fsel_preview_file(E_Widget_Data *wd)
size = _e_wid_file_size_get(st.st_size);
owner = _e_wid_file_user_get(st.st_uid);
perms = _e_wid_file_perms_get(st.st_mode, st.st_uid, st.st_gid);
time = _e_wid_file_time_get(st.st_mtime);
mtime = _e_wid_file_time_get(st.st_mtime);
e_widget_preview_thumb_set(wd->o_preview_preview, wd->path,
"background", 128, 128);
@ -499,19 +499,19 @@ _e_wid_fsel_preview_file(E_Widget_Data *wd)
e_widget_entry_text_set(wd->o_preview_size_entry, size);
e_widget_entry_text_set(wd->o_preview_owner_entry, owner);
e_widget_entry_text_set(wd->o_preview_perms_entry, perms);
e_widget_entry_text_set(wd->o_preview_time_entry, time);
e_widget_entry_text_set(wd->o_preview_time_entry, mtime);
free(size);
free(owner);
free(perms);
free(time);
free(mtime);
}
static char *
_e_wid_file_size_get(off_t st_size)
{
double dsize;
char size[1024];
char size[256];
dsize = (double)st_size;
if (dsize < 1024.0)
@ -558,8 +558,7 @@ _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 st_gid)
{
char *perm;
char perms[PATH_MAX];
char perms[256];
int access = 0;
int owner = 0;
int group = 0;
@ -576,82 +575,52 @@ _e_wid_file_perms_get(mode_t st_mode, uid_t st_uid, gid_t st_gid)
if (getgid() == st_gid)
group = 1;
perm = (char *)malloc(sizeof(char) * 10);
for (i = 0; i < 9; i++)
perm[i] = '-';
perm[9] = '\0';
if ((S_IRUSR & st_mode) == S_IRUSR)
{
perm[0] = 'r';
user_read = 1;
}
user_read = 1;
if ((S_IWUSR & st_mode) == S_IWUSR)
{
perm[1] = 'w';
user_write = 1;
}
if ((S_IXUSR & st_mode) == S_IXUSR)
perm[2] = 'x';
user_write = 1;
if ((S_IRGRP & st_mode) == S_IRGRP)
{
perm[3] = 'r';
group_read = 1;
}
group_read = 1;
if ((S_IWGRP & st_mode) == S_IWGRP)
{
perm[4] = 'w';
group_write = 1;
}
if ((S_IXGRP & st_mode) == S_IXGRP)
perm[5] = 'x';
group_write = 1;
if ((S_IROTH & st_mode) == S_IROTH)
{
perm[5] = 'r';
other_read = 1;
}
other_read = 1;
if ((S_IWOTH & st_mode) == S_IWOTH)
{
perm[6] = 'w';
other_write = 1;
}
if ((S_IXOTH & st_mode) == S_IXOTH)
perm[8] = 'x';
other_write = 1;
if (owner)
{
if ((!user_read) && (!user_write))
snprintf(perms, sizeof(perms), _("Protected"));
snprintf(perms, sizeof(perms), _("Protected"));
else if ((user_read) && (!user_write))
snprintf(perms, sizeof(perms), _("Read Only"));
snprintf(perms, sizeof(perms), _("Read Only"));
else if ((user_read) && (user_write))
access = 1;
access = 1;
}
else if (group)
{
if ((!group_read) && (!group_write))
snprintf(perms, sizeof(perms), _("Forbidden"));
snprintf(perms, sizeof(perms), _("Forbidden"));
else if ((group_read) && (!group_write))
snprintf(perms, sizeof(perms), _("Read Only"));
snprintf(perms, sizeof(perms), _("Read Only"));
else if ((group_read) && (group_write))
access = 1;
access = 1;
}
else if ((!owner) && (!group))
else
{
if ((!other_read) && (!other_write))
snprintf(perms, sizeof(perms), _("Forbidden"));
snprintf(perms, sizeof(perms), _("Forbidden"));
else if ((other_read) && (!other_write))
snprintf(perms, sizeof(perms), _("Read Only"));
snprintf(perms, sizeof(perms), _("Read Only"));
else if ((other_read) && (other_write))
access = 1;
access = 1;
}
if (!access)
return strdup(perms);
return strdup(perms);
else
return strdup("Read-Write");
return strdup("Read-Write");
}
static char *
@ -659,7 +628,7 @@ _e_wid_file_time_get(time_t st_modtime)
{
float diff;
time_t ltime;
char modtime[PATH_MAX];
char modtime[256];
char *motime;
ltime = time(NULL);