remove those, we dont need them anymore

SVN revision: 6047
This commit is contained in:
Till Adam 2002-03-06 21:18:04 +00:00
parent 5ba3515bbe
commit 609b356400
2 changed files with 0 additions and 792 deletions

View File

@ -1,725 +0,0 @@
#include "file.h"
#include "e_view_model.h"
#include "e_view_machine.h"
#include "view.h"
#include "icons.h"
#include "util.h"
#include "libefsd.h"
#include "e_file.h"
#include "globals.h"
static void e_view_model_handle_fs_restart(void *data);
static void e_view_model_handle_fs(EfsdEvent * ev);
static void e_view_model_handle_efsd_event_reply(EfsdEvent * ev);
static void e_view_model_handle_efsd_event_reply_stat(EfsdEvent * ev);
static void e_view_model_handle_efsd_event_reply_readlink(EfsdEvent *
ev);
static void e_view_model_handle_efsd_event_reply_getfiletype(EfsdEvent *
ev);
static void e_view_model_handle_efsd_event_reply_getmeta(EfsdEvent *
ev);
static void e_view_model_cleanup(E_View_Model * m);
static void e_view_model_bg_reload_timeout(int val, void *data);
static void e_view_model_set_default_background(E_View_Model * m);
void
e_view_model_init(void)
{
D_ENTER;
e_fs_add_event_handler(e_view_model_handle_fs);
D_RETURN;
}
static void
e_view_model_cleanup(E_View_Model * m)
{
D_ENTER;
if (!m)
D_RETURN;
efsd_stop_monitor(e_fs_get_connection(), m->dir, TRUE);
if (m->restarter)
e_fs_del_restart_handler(m->restarter);
m->restarter = NULL;
e_view_machine_unregister_view_model(m);
e_object_cleanup(E_OBJECT(m));
D_RETURN;
}
E_View_Model *
e_view_model_new(void)
{
E_View_Model *m;
D_ENTER;
m = NEW(E_View_Model, 1);
ZERO(m, E_View_Model, 1);
m->dir = NULL;
m->views = NULL;
e_object_init(E_OBJECT(m), (E_Cleanup_Func) e_view_model_cleanup);
e_view_machine_register_view_model(m);
D_RETURN_(m);
}
void
e_view_model_register_view(E_View_Model * m, E_View * v)
{
D_ENTER;
v->model = m;
m->views = evas_list_append(m->views, v);
/* dont ref the first time */
if (m->views->next)
e_object_ref(E_OBJECT(v->model));
D_RETURN;
}
void
e_view_model_unregister_view(E_View * v)
{
D_ENTER;
v->model->views = evas_list_remove(v->model->views, v);
e_object_unref(E_OBJECT(v->model));
D_RETURN;
}
static void
e_view_model_set_default_background(E_View_Model * m)
{
char buf[PATH_MAX];
D_ENTER;
if (!m)
D_RETURN;
IF_FREE(m->bg_file);
if (m->is_desktop)
snprintf(buf, PATH_MAX, "%s/default.bg.db", e_config_get("backgrounds"));
else
snprintf(buf, PATH_MAX, "%s/view.bg.db", e_config_get("backgrounds"));
e_strdup(m->bg_file, buf);
snprintf(buf, PATH_MAX, "background_reload:%s", m->dir);
ecore_add_event_timer(buf, 0.5, e_view_model_bg_reload_timeout, 0, m);
D_RETURN;
}
static void
e_view_model_handle_fs_restart(void *data)
{
E_View_Model *m;
D_ENTER;
m = data;
D("e_view_model_handle_fs_restart\n");
if (e_fs_get_connection())
{
EfsdOptions *ops;
/* FIXME restart with metadata pending for views */
ops = efsd_ops(3,
efsd_op_get_stat(),
efsd_op_get_filetype(), efsd_op_list_all());
m->monitor_id = efsd_start_monitor(e_fs_get_connection(), m->dir,
ops, TRUE);
}
D("restarted monitor id (connection = %p), %i for %s\n",
e_fs_get_connection(), m->monitor_id, m->dir);
D_RETURN;
}
void
e_view_model_set_dir(E_View_Model * m, char *dir)
{
D_ENTER;
if (!m)
D_RETURN;
/* stop monitoring old dir */
if ((m->dir) && (m->monitor_id))
{
efsd_stop_monitor(e_fs_get_connection(), m->dir, TRUE);
m->monitor_id = 0;
}
IF_FREE(m->dir);
m->dir = e_file_realpath(dir);
/* start monitoring new dir */
m->restarter = e_fs_add_restart_handler(e_view_model_handle_fs_restart, m);
if (e_fs_get_connection())
{
EfsdOptions *ops;
ops = efsd_ops(3,
efsd_op_get_stat(),
efsd_op_get_filetype(), efsd_op_list_all());
m->monitor_id = efsd_start_monitor(e_fs_get_connection(), m->dir,
ops, TRUE);
D("monitor id for %s = %i\n", m->dir, m->monitor_id);
}
D_RETURN;
}
static void
e_view_model_handle_fs(EfsdEvent * ev)
{
D_ENTER;
if (!ev)
D_RETURN;
switch (ev->type)
{
case EFSD_EVENT_FILECHANGE:
switch (ev->efsd_filechange_event.changetype)
{
case EFSD_FILE_CREATED:
e_view_model_file_added(ev->efsd_filechange_event.id,
ev->efsd_filechange_event.file);
break;
case EFSD_FILE_EXISTS:
e_view_model_file_added(ev->efsd_filechange_event.id,
ev->efsd_filechange_event.file);
break;
case EFSD_FILE_DELETED:
e_view_model_file_deleted(ev->efsd_filechange_event.id,
ev->efsd_filechange_event.file);
break;
case EFSD_FILE_CHANGED:
e_view_model_file_changed(ev->efsd_filechange_event.id,
ev->efsd_filechange_event.file);
break;
case EFSD_FILE_MOVED:
e_view_model_file_moved(ev->efsd_filechange_event.id,
ev->efsd_filechange_event.file);
break;
case EFSD_FILE_END_EXISTS:
break;
default:
break;
}
break;
case EFSD_EVENT_REPLY:
e_view_model_handle_efsd_event_reply(ev);
break;
default:
break;
}
D_RETURN;
}
static void
e_view_model_handle_efsd_event_reply_getfiletype(EfsdEvent * ev)
{
E_File *f;
char *file = NULL;
Evas_List l;
E_View_Model *model;
char *m, *p;
char mime[PATH_MAX], base[PATH_MAX];
D_ENTER;
if (!ev)
D_RETURN;
if (!ev->efsd_reply_event.errorcode == 0)
D_RETURN;
if ((file = efsd_event_filename(ev)))
{
file = e_file_get_file(file);
}
model = e_view_model_find_by_monitor_id(efsd_event_id(ev));
f = e_file_get_by_name(model->files, file);
/* if its not in the list we care about, its filetype is meaningless */
if (!f)
D_RETURN;
m = ev->efsd_reply_event.data;
p = strchr(m, '/');
if (p)
{
strcpy(base, m);
strcpy(mime, p + 1);
p = strchr(base, '/');
*p = 0;
}
else
{
strcpy(base, m);
strcpy(mime, "unknown");
}
e_file_set_mime(f, base, mime);
for (l = model->views; l; l = l->next)
{
E_View *v = (E_View *) l->data;
E_Icon *ic = e_icon_find_by_file(v, f->file);
/* Try to update the GUI.
* It's just a try because we need to have the file's stat
* info as well. --cK.
*/
e_icon_update_state(ic);
e_icon_initial_show(ic);
}
D_RETURN;
}
static void
e_view_model_handle_efsd_event_reply_stat(EfsdEvent * ev)
{
E_View_Model *m;
E_File *f;
Evas_List l;
D_ENTER;
if (!ev)
D_RETURN;
if (!ev->efsd_reply_event.errorcode == 0)
D_RETURN;
m = e_view_model_find_by_monitor_id(efsd_event_id(ev));
f = e_file_get_by_name(m->files, e_file_get_file(efsd_event_filename(ev)));
/* if its not in the list we care about, return */
if (!f)
D_RETURN;
/* When everything went okay and we can find a model,
* set the file stat data for the file and try to update the gui.
* It's just a try because we need to have received the filetype
* info too. --cK. */
f->stat = *((struct stat *)efsd_event_data(ev));
for (l = m->views; l; l = l->next)
{
E_View *v = (E_View *) l->data;
E_Icon *ic = e_icon_find_by_file(v, f->file);
e_icon_update_state(ic);
e_icon_initial_show(ic);
}
D_RETURN;
}
static void
e_view_model_handle_efsd_event_reply_readlink(EfsdEvent * ev)
{
E_View_Model *m;
E_File *f;
Evas_List l;
D_ENTER;
if (!ev)
D_RETURN;
if (!ev->efsd_reply_event.errorcode == 0)
D_RETURN;
m = e_view_model_find_by_monitor_id(efsd_event_id(ev));
f = e_file_get_by_name(m->files, e_file_get_file(efsd_event_filename(ev)));
if (f)
{
e_file_set_link(f, (char *)efsd_event_data(ev));
}
for (l = m->views; l; l = l->next)
{
E_View *v = (E_View *) l->data;
E_Icon *ic = e_icon_find_by_file(v, f->file);
e_icon_update_state(ic);
e_icon_initial_show(ic);
}
D_RETURN;
}
static void
e_view_model_handle_efsd_event_reply_getmeta(EfsdEvent * ev)
{
Evas_List l;
EfsdCmdId cmd;
D_ENTER;
if (!ev)
D_RETURN;
cmd = efsd_event_id(ev);
for (l = VM->views; l; l = l->next)
{
E_View *v;
v = l->data;
/* ignore metadata for desktops */
if (v->model->is_desktop)
continue;
if (v->geom_get.x == cmd)
{
v->geom_get.x = 0;
if (efsd_metadata_get_type(ev) == EFSD_INT)
{
if (ev->efsd_reply_event.errorcode == 0)
efsd_metadata_get_int(ev, &(v->location.x));
else
v->location.x = 0;
}
}
else if (v->geom_get.y == cmd)
{
v->geom_get.y = 0;
if (efsd_metadata_get_type(ev) == EFSD_INT)
{
if (ev->efsd_reply_event.errorcode == 0)
efsd_metadata_get_int(ev, &(v->location.y));
else
v->location.y = 0;
}
}
else if (v->geom_get.w == cmd)
{
v->geom_get.w = 0;
if (efsd_metadata_get_type(ev) == EFSD_INT)
{
if (ev->efsd_reply_event.errorcode == 0)
efsd_metadata_get_int(ev, &(v->size.w));
else
v->size.w = 400;
}
}
else if (v->geom_get.h == cmd)
{
v->geom_get.h = 0;
if (ev->efsd_reply_event.errorcode == 0)
{
if (ev->efsd_reply_event.errorcode == 0)
efsd_metadata_get_int(ev, &(v->size.h));
else
v->size.h = 401;
}
}
/* FIXME currently, the bg info is not set via metadata */
/*
* else if (v->getbg == cmd)
* {
* v->getbg = 0;
* if (efsd_metadata_get_type(ev) == EFSD_STRING)
* {
* if (ev->efsd_reply_event.errorcode == 0)
* {
* char buf[PATH_MAX];
*
* IF_FREE(v->model->bg_file);
* e_strdup(v->model->bg_file, efsd_metadata_get_str(ev));
* snprintf(buf, PATH_MAX, "background_reload:%s", v->model->dir);
* ecore_add_event_timer(buf, 0.5, e_view_model_bg_reload_timeout, 0, v->model);
* }
* else
* e_view_model_set_default_background(v->model);
* }
* }
*/
/* We have received all metadata we need, display the view */
if ((!v->geom_get.x) &&
(!v->geom_get.y) &&
(!v->geom_get.w) && (!v->geom_get.h) && (v->geom_get.busy))
{
E_Border *b;
ecore_window_move_resize(v->win.base, v->location.x, v->location.y,
v->size.w, v->size.h);
ecore_window_set_xy_hints(v->win.base, v->location.x,
v->location.y);
v->size.force = 1;
v->geom_get.busy = 0;
if (v->bg)
e_bg_resize(v->bg, v->size.w, v->size.h);
if (v->options.back_pixmap)
e_view_update(v);
b = e_border_adopt(v->win.base, 1);
b->client.internal = 1;
e_border_remove_click_grab(b);
}
}
D_RETURN;
}
static void
e_view_model_handle_efsd_event_reply(EfsdEvent * ev)
{
D_ENTER;
if (!ev)
D_RETURN;
switch (ev->efsd_reply_event.command.type)
{
case EFSD_CMD_REMOVE:
break;
case EFSD_CMD_MOVE:
break;
case EFSD_CMD_SYMLINK:
break;
case EFSD_CMD_LISTDIR:
break;
case EFSD_CMD_MAKEDIR:
break;
case EFSD_CMD_CHMOD:
break;
case EFSD_CMD_GETFILETYPE:
e_view_model_handle_efsd_event_reply_getfiletype(ev);
break;
case EFSD_CMD_STAT:
e_view_model_handle_efsd_event_reply_stat(ev);
break;
case EFSD_CMD_READLINK:
e_view_model_handle_efsd_event_reply_readlink(ev);
break;
case EFSD_CMD_CLOSE:
break;
case EFSD_CMD_SETMETA:
break;
case EFSD_CMD_GETMETA:
e_view_model_handle_efsd_event_reply_getmeta(ev);
break;
case EFSD_CMD_STARTMON_DIR:
break;
case EFSD_CMD_STARTMON_FILE:
break;
case EFSD_CMD_STOPMON_DIR:
break;
case EFSD_CMD_STOPMON_FILE:
break;
default:
break;
}
D_RETURN;
}
static void
e_view_model_ib_reload_timeout(int val, void *data)
{
Evas_List l;
E_View *v;
E_View_Model *m;
D_ENTER;
m = data;
for (l = m->views; l; l = l->next)
{
v = (E_View *) l->data;
e_view_ib_reload(v);
}
D_RETURN;
UN(val);
}
static void
e_view_model_bg_reload_timeout(int val, void *data)
{
Evas_List l;
E_View *v;
E_View_Model *m;
D_ENTER;
m = data;
for (l = m->views; l; l = l->next)
{
v = (E_View *) l->data;
e_view_bg_reload(v);
}
D_RETURN;
UN(val);
}
void
e_view_model_file_added(int id, char *file)
{
Evas_List l;
E_View_Model *m;
E_View *v;
E_File *f;
char buf[PATH_MAX];
D_ENTER;
/* if we get a path - ignore it - its not a file in the dir */
if (!file || file[0] == '/')
D_RETURN;
m = e_view_model_find_by_monitor_id(id);
if (!strcmp(file, ".e_background.bg.db"))
{
IF_FREE(m->bg_file);
snprintf(buf, PATH_MAX, "%s/%s", m->dir, file);
e_strdup(m->bg_file, buf);
snprintf(buf, PATH_MAX, "background_reload:%s", m->dir);
ecore_add_event_timer(buf, 0.5, e_view_model_bg_reload_timeout, 0, m);
}
/*else if ((!strcmp(".e_iconbar.db", file)) ||
(!strcmp(".e_iconbar.bits.db", file)))
{
snprintf(buf, PATH_MAX, "iconbar_reload:%s", m->dir);
ecore_add_event_timer(buf, 0.5, e_view_model_ib_reload_timeout, 0, m);
}*/
else if (file[0] != '.')
{
f = e_file_new(file);
m->files = evas_list_append(m->files, f);
/* tell all views for this dir about the new file */
for (l = m->views; l; l = l->next)
{
v = l->data;
e_view_file_add(v, f);
}
}
D_RETURN;
}
void
e_view_model_file_deleted(int id, char *file)
{
Evas_List l;
E_File *f;
E_View_Model *m;
D_ENTER;
if (!file || file[0] == '/')
D_RETURN;
m = e_view_model_find_by_monitor_id(id);
f = e_file_get_by_name(m->files, file);
m->files = evas_list_remove(m->files, f);
if (!strcmp(file, ".e_background.bg.db"))
{
e_view_model_set_default_background(m);
}
/*else if ((!strcmp(".e_iconbar.db", file)) ||
(!strcmp(".e_iconbar.bits.db", file)))
{
for (l = m->views; l; l = l->next)
{
E_View *v = (E_View *) l->data;
e_object_unref(E_OBJECT(v->iconbar));
v->iconbar = NULL;
}
}*/
else if (file[0] != '.')
{
for (l = m->views; l; l = l->next)
{
E_View *v = (E_View *) l->data;
e_view_file_delete(v, f);
}
}
D_RETURN;
}
void
e_view_model_file_changed(int id, char *file)
{
Evas_List l;
E_View_Model *m;
E_File *f;
E_View *v;
char buf[PATH_MAX];
D_ENTER;
if (!file || file[0] == '/')
D_RETURN;
m = e_view_model_find_by_monitor_id(id);
f = e_file_get_by_name(m->files, file);
if (!strcmp(file, ".e_background.bg.db"))
{
IF_FREE(m->bg_file);
snprintf(buf, PATH_MAX, "%s/%s", m->dir, file);
e_strdup(m->bg_file, buf);
snprintf(buf, PATH_MAX, "background_reload:%s", m->dir);
ecore_add_event_timer(buf, 0.5, e_view_model_bg_reload_timeout, 0, m);
}
else if ((!strcmp(".e_iconbar.db", file)) ||
(!strcmp(".e_iconbar.bits.db", file)))
{
snprintf(buf, PATH_MAX, "iconbar_reload:%s", m->dir);
ecore_add_event_timer(buf, 0.5, e_view_model_ib_reload_timeout, 0, m);
}
else if (file[0] != '.')
{
for (l = m->views; l; l = l->next)
{
v = l->data;
e_view_file_changed(v, f);
}
}
D_RETURN;
}
void
e_view_model_file_moved(int id, char *file)
{
Evas_List l;
E_View_Model *m;
D_ENTER;
if (!file || file[0] == '/')
D_RETURN;
m = e_view_model_find_by_monitor_id(id);
for (l = m->views; l; l = l->next)
{
E_View *v = (E_View *) l->data;
E_Icon *ic;
ic = e_icon_find_by_file(v, file);
if (ic)
{
}
}
D_RETURN;
}
E_View_Model *
e_view_model_find_by_monitor_id(int id)
{
E_View_Model *m;
Evas_List l;
D_ENTER;
for (l = VM->models; l; l = l->next)
{
m = l->data;
if (m->monitor_id == id)
D_RETURN_(m);;
}
D_RETURN_(NULL);
}

View File

@ -1,67 +0,0 @@
#ifndef E_VIEW_MODEL_H
#define E_VIEW_MODEL_H
#include "fs.h"
#include "iconbar.h"
#include <Evas.h>
#ifndef E_VIEW_TYPEDEF
#define E_VIEW_TYPEDEF
typedef struct _E_View E_View;
#endif
#ifndef E_ICON_TYPEDEF
#define E_ICON_TYPEDEF
typedef struct _E_Icon E_Icon;
#endif
#ifndef E_VIEW_MODEL_TYPEDEF
#define E_VIEW_MODEL_TYPEDEF
typedef struct _E_View_Model E_View_Model;
#endif
struct _E_View_Model
{
E_Object o;
/* The realpath of the view's directory */
char *dir;
Evas_List files;
Evas_Object obj_bg;
char *bg_file;
E_FS_Restarter *restarter;
int monitor_id;
/* A list of all the views for which a model is sharing data */
Evas_List views;
int is_desktop;
};
/**
* e_view_model_set_dir - Assigns a directory to a view model
* @m: The view model to set the dir for
* @dir: The directory
*
* Set the directory for a view_model and starts monitoring it via efsd.
*/
void e_view_model_set_dir(E_View_Model * m, char *dir);
E_View_Model *e_view_model_new(void);
void e_view_model_init(void);
void e_view_model_register_view(E_View_Model * m, E_View * v);
void e_view_model_unregister_view(E_View * v);
E_View_Model *e_view_model_find_by_monitor_id(int id);
/* Deal with incoming file events */
void e_view_model_file_added(int id, char *file);
void e_view_model_file_deleted(int id, char *file);
void e_view_model_file_changed(int id, char *file);
void e_view_model_file_moved(int id, char *file);
#endif