legacy/experimental/ecdb/trunk/src/ecdb_burn_data_gui.c

745 lines
26 KiB
C

/* vim: set sw=3 ts=3 sts=3 expandtab: */
#include "ecdb.h"
static void _button_cb_return(void *data, Evas_Object *obj,
const char *emission,
const char *source);
static void _button_cb_begin(void *data, Evas_Object *obj,
const char *emission,
const char *source);
static void _page_del(void *data, Evas *e, Evas_Object *obj, void *ev);
static void _combo_cb_clicked(void *data, Evas_Object *obj, void *event_info);
static void _update_capacity(Ewl_Widget *w, void *ev_info, void *data);
// Config inwin updates
static void _joliet_clicked(void *data, Evas_Object *obj, const char *emission,
const char *source);
static void _rockridge_clicked(void *data, Evas_Object *obj,
const char *emission,
const char *source);
static void _symlinks_clicked(void *data, Evas_Object *obj,
const char *emission,
const char *source);
static void _hidden_clicked(void *data, Evas_Object *obj, const char *emission,
const char *source);
static void _multi_clicked(void *data, Evas_Object *obj, const char *emission,
const char *source);
static void _sim_clicked(void *data, Evas_Object *obj, const char *emission,
const char *source);
static void _underrun_clicked(void *data, Evas_Object *obj,
const char *emission,
const char *source);
static void _apply_clicked(void *data, Evas_Object *obj, const char *emission,
const char *source);
static void _proj_name(void *data, Evas *e, Evas_Object *obj, void *event_info);
static void _settings_clicked(void *data, Evas_Object *obj,
const char *emission,
const char *source);
// Update on showing to proper values
static void _joliet_config(void *data, Evas_Object *obj, void *event_info);
static void _rockridge_config(void *data, Evas_Object *obj, void *event_info);
static void _symlinks_config(void *data, Evas_Object *obj, void *event_info);
static void _hidden_config(void *data, Evas_Object *obj, void *event_info);
static void _multi_config(void *data, Evas_Object *obj, void *event_info);
static void _sim_config(void *data, Evas_Object *obj, void *event_info);
static void _underrun_config(void *data, Evas_Object *obj, void *event_info);
static void _proj_config(void *data, Evas_Object *obj, void *event_info);
static void _page_hide_finished(void *data, Evas_Object *o,
const char *emission,
const char *source);
static void
_page_del(void *data, Evas *e __UNUSED__, Evas_Object *obj, void *ev __UNUSED__)
{
Ecdb_Data_Project *proj;
Ecdb_Source *src;
src = data;
proj = evas_object_data_get(obj, "proj");
if (proj)
ecdb_data_project_destroy(proj);
}
static void
_page_hide_finished(void *data, Evas_Object *o,
const char *emission __UNUSED__,
const char *source __UNUSED__)
{
Ecdb_Page *page = data;
Ecdb_Data_Project *proj;
proj = evas_object_data_get(page->data, "proj");
edje_object_part_unswallow(page->gui, page->data);
evas_object_hide(page->data);
ewl_widget_hide(proj->filelist);
}
static void
_update_capacity(Ewl_Widget *w, void *ev_info, void *data)
{
Ecdb_Page *page;
Ecdb_Source *src;
Ecdb_Data_Project *proj;
Ecdb_Project *base_proj;
float val;
page = data;
proj = evas_object_data_get(page->data, "proj");
base_proj = ECDB_PROJECT(proj);
src = data;
/* Find our topmost source */
while ((src) && (src->parent))
src = src->parent;
if ((base_proj->drive) && (base_proj->drive->capacity > 0))
{
EINA_ERROR_PDBG("drive capacity: %lld, src->size: %lld\n",
base_proj->drive->capacity, src->size);
val = (float)src->size / (float)base_proj->drive->capacity;
}
else
{
// Default to a nice, small size
val = (float)src->size / 1048576.0 / 700.0;
}
if (val > 1.0)
{
EINA_ERROR_PDBG("OVER SIZE LIMIT!\n");
edje_object_signal_emit(proj->capacity, "ecdb,capacity,exceeded", "ecdb");
edje_object_signal_emit(page->data, "ecdb,capacity, exceeded", "ecdb");
}
ecdb_capacity_float_set(proj->capacity, val);
EINA_ERROR_PDBG("%lld\n", src->size);
}
static void
_button_cb_return(void *data, Evas_Object *obj,
const char *emission __UNUSED__,
const char *source __UNUSED__)
{
Ecdb_Page *page;
page = data;
edje_object_signal_emit(page->data, "ecdb,burn_data_page,hide", "ecdb");
ecdb_welcome_page_show(page);
/* Hide the filelist to be nice */
edje_object_signal_emit(page->gui, "ecdb,filelist,hide", "ecdb");
}
static void
_button_cb_begin(void *data, Evas_Object *obj __UNUSED__,
const char *emission __UNUSED__,
const char *source __UNUSED__)
{
Ecdb_Data_Project *proj;
Ecdb_Page *page;
char buf[1024];
Ecdb_Burn_Result burn_result;
int drive, speed, idx;
page = data;
proj = evas_object_data_get(page->data, "proj");
drive = ecdb_combo_selected_get(ECDB_PROJECT(proj)->drive_combo);
if (drive < 0)
{
EINA_ERROR_PINFO("Choose a drive!\n");
edje_object_part_text_set(page->data, "progress_text", "Choose a Drive!");
return;
}
speed = ecdb_speed_convert(eina_list_nth(em->drives, drive),
ecdb_combo_selected_get(ECDB_BURN(proj)->speed_combo));
if (speed < 0)
ECDB_BURN(proj)->speed = 0;
else
ECDB_BURN(proj)->speed = speed;
ECDB_BURN(proj)->files = ewl_widget_data_get(proj->filelist, "source");
while (ECDB_BURN(proj)->files->parent)
ECDB_BURN(proj)->files = ECDB_BURN(proj)->files->parent;
snprintf(buf, sizeof(buf), "Commencing...");
edje_object_part_text_set(page->data, "progress_text", buf);
if (!ecdb_aquire_drive(ECDB_PROJECT(proj), drive))
{
EINA_ERROR_PWARN("Couldn't grab drive!\n");
edje_object_part_text_set(page->data, "progress_text",
"Couldn't grab the drive!");
return;
}
burn_result = ecdb_burn_project(ECDB_BURN(proj), page);
switch (burn_result)
{
case ECDB_ERROR_NONE:
edje_object_signal_emit(page->gui, "ecdb,filelist,hide", "ecdb");
edje_object_signal_emit(page->data, "ecdb,burn_data,start", "ecdb");
Evas_Object *objs[] = {proj->capacity, proj->settings,
proj->filelist_swallow, ECDB_BURN(proj)->speed_combo,
ECDB_PROJECT(proj)->ret, ECDB_PROJECT(proj)->begin,
NULL};
for (idx = 0; objs[idx] != NULL; idx++)
{
edje_object_signal_emit(objs[idx], "ecdb,disable", "ecdb");
printf("disabling controls...\n");
}
return;
case ECDB_ERROR_IMAGE_CREATE:
snprintf(buf, sizeof(buf), "Invalid file!");
break;
case ECDB_ERROR_SOURCE_ATTACH:
snprintf(buf, sizeof(buf), "Couldn't attach source data!");
break;
case ECDB_ERROR_WRITE_MODE:
snprintf(buf, sizeof(buf), "No suitable burn mode!");
break;
default:
snprintf(buf, sizeof(buf), "Unknown error :-(");
}
edje_object_part_text_set(page->data, "progress_text", buf);
burn_drive_release(ECDB_PROJECT(proj)->drive->tangible[0].drive, 1);
burn_drive_info_free(ECDB_PROJECT(proj)->drive->tangible);
}
static void
_combo_cb_clicked(void *data, Evas_Object *obj __UNUSED__,
void *event_info __UNUSED__)
{
Evas_Object *b;
Ecdb_Data_Project *proj;
Ecdb_Project *base_proj;
int sel, i, num_speeds, speed;
char buf[1024];
proj = data;
if (!proj)
return;
base_proj = ECDB_PROJECT(proj);
sel = ecdb_combo_selected_get(base_proj->drive_combo);
if (sel < 0)
return;
base_proj->drive = eina_list_nth(em->drives, sel);
/* Don't keep adding items to the combo if the drive hasn't changed */
if (base_proj->drive == ecdb_combo_data_get(ECDB_BURN(proj)->speed_combo))
return;
// Update the capacity here, as our capacity could change with the drive
ewl_callback_call_with_event_data(proj->filelist, ECDB_FILELIST_SIZE_CHANGED,
ECDB_BURN(proj)->files);
num_speeds = base_proj->drive->write_speeds[0];
ecdb_combo_data_set(ECDB_BURN(proj)->speed_combo, base_proj->drive);
for (i = 1; i < num_speeds; i++)
{
if (base_proj->drive->write_speeds[i] <= 0)
continue;
b = ecdb_combo_item_add(ECDB_BURN(proj)->speed_combo, NULL);
if ((base_proj->drive->profile_name) &&
(base_proj->drive->profile_name[0] != '\0'))
{
if (base_proj->drive->profile_name[0] == 'C')
speed = base_proj->drive->write_speeds[i] / 150;
else if (base_proj->drive->profile_name[0] == 'D')
speed = base_proj->drive->write_speeds[i] / 1352;
else
speed = base_proj->drive->write_speeds[i] / 4500;
}
else
{
speed = 0;
}
snprintf(buf, sizeof(buf), "%dX (%dkb/s)", speed,
base_proj->drive->write_speeds[i]);
ecdb_combo_item_label_set(b, buf);
ecdb_combo_append(ECDB_BURN(proj)->speed_combo, b);
evas_object_show(b);
}
}
static void
_joliet_clicked(void *data, Evas_Object *obj, const char *emission __UNUSED__,
const char *source __UNUSED__)
{
int state;
Ecdb_Data_Project *proj;
proj = data;
proj->use_joliet = !proj->use_joliet;
state = ecdb_check_checked_get(obj);
if (state != proj->use_joliet)
ecdb_check_checked_set(obj, proj->use_joliet);
}
static void
_joliet_config(void *data, Evas_Object *obj, void *event_info __UNUSED__)
{
Ecdb_Data_Project *proj;
proj = data;
ecdb_check_checked_set(obj, proj->use_joliet);
}
static void
_rockridge_clicked(void *data, Evas_Object *obj,
const char *emission __UNUSED__,
const char *source __UNUSED__)
{
int state;
Ecdb_Data_Project *proj;
proj = data;
proj->use_rockridge = !proj->use_rockridge;
state = ecdb_check_checked_get(obj);
if (state != proj->use_rockridge)
ecdb_check_checked_set(obj, proj->use_rockridge);
}
static void
_rockridge_config(void *data, Evas_Object *obj, void *event_info __UNUSED__)
{
Ecdb_Data_Project *proj;
proj = data;
ecdb_check_checked_set(obj, proj->use_rockridge);
}
static void
_symlinks_clicked(void *data, Evas_Object *obj, const char *emission __UNUSED__,
const char *source __UNUSED__)
{
int state;
Ecdb_Data_Project *proj;
proj = data;
proj->follow_symlinks = !proj->follow_symlinks;
state = ecdb_check_checked_get(obj);
if (state != proj->follow_symlinks)
ecdb_check_checked_set(obj, proj->follow_symlinks);
}
static void
_symlinks_config(void *data, Evas_Object *obj, void *event_info __UNUSED__)
{
Ecdb_Data_Project *proj;
proj = data;
ecdb_check_checked_set(obj, proj->follow_symlinks);
}
static void
_hidden_clicked(void *data, Evas_Object *obj, const char *emission __UNUSED__,
const char *source __UNUSED__)
{
int state;
Ecdb_Data_Project *proj;
proj = data;
proj->ignore_hidden = !proj->ignore_hidden;
state = ecdb_check_checked_get(obj);
if (state != proj->ignore_hidden)
ecdb_check_checked_set(obj, proj->ignore_hidden);
}
static void
_hidden_config(void *data, Evas_Object *obj, void *event_info __UNUSED__)
{
Ecdb_Data_Project *proj;
proj = data;
ecdb_check_checked_set(obj, proj->ignore_hidden);
}
static void
_multi_clicked(void *data, Evas_Object *obj, const char *emission __UNUSED__,
const char *source __UNUSED__)
{
int state;
Ecdb_Burn_Project *proj;
proj = data;
proj->multi = !proj->multi;
state = ecdb_check_checked_get(obj);
if (state != proj->multi)
ecdb_check_checked_set(obj, proj->multi);
}
static void
_multi_config(void *data, Evas_Object *obj, void *event_info __UNUSED__)
{
Ecdb_Burn_Project *proj;
proj = data;
ecdb_check_checked_set(obj, proj->multi);
}
static void
_sim_clicked(void *data, Evas_Object *obj, const char *emission __UNUSED__,
const char *source __UNUSED__)
{
int state;
Ecdb_Burn_Project *proj;
proj = data;
proj->simulate = !proj->simulate;
state = ecdb_check_checked_get(obj);
if (state != proj->simulate)
ecdb_check_checked_set(obj, proj->simulate);
}
static void
_sim_config(void *data, Evas_Object *obj, void *event_info __UNUSED__)
{
Ecdb_Burn_Project *proj;
proj = data;
ecdb_check_checked_set(obj, proj->simulate);
}
static void
_underrun_clicked(void *data, Evas_Object *obj, const char *emission __UNUSED__,
const char *source __UNUSED__)
{
int state;
Ecdb_Burn_Project *proj;
proj = data;
proj->underrun_proof = !proj->underrun_proof;
state = ecdb_check_checked_get(obj);
if (state != proj->underrun_proof)
ecdb_check_checked_set(obj, proj->underrun_proof);
}
static void
_underrun_config(void *data, Evas_Object *obj, void *event_info __UNUSED__)
{
Ecdb_Burn_Project *proj;
proj = data;
ecdb_check_checked_set(obj, proj->underrun_proof);
}
static void
_apply_clicked(void *data, Evas_Object *obj, const char *emission __UNUSED__,
const char *source __UNUSED__)
{
ecdb_config_inwin_hide(data);
}
static void
_proj_name(void *data, Evas *e, Evas_Object *obj, void *event_info __UNUSED__)
{
char *name;
Ecdb_Data_Project *proj;
proj = data;
name = ecdb_entry_text_get(obj);
if (proj->volume_id)
free(proj->volume_id);
proj->volume_id = name;
}
static void
_proj_config(void *data, Evas_Object *obj, void *event_info __UNUSED__)
{
Ecdb_Data_Project *proj;
proj = data;
if (proj->volume_id)
ecdb_entry_text_set(obj, proj->volume_id);
else
ecdb_entry_text_set(obj, "Project Name");
}
static void
_settings_clicked(void *data, Evas_Object *obj __UNUSED__,
const char *emission __UNUSED__,
const char *source __UNUSED__)
{
Eina_Iterator *it;
const Evas_Object *table;
Evas_Object *o;
table = edje_object_part_object_get(data, "ecdb.table");
it = evas_object_table_iterator_new(table);
if (!it)
{
EINA_ERROR_PWARN("_settings_clicked: NULL iterator!\n");
return;
}
while (eina_iterator_next(it, (void **)&o))
evas_object_smart_callback_call(o, "proj_config", NULL);
eina_iterator_free(it);
ecdb_config_inwin_show(data);
}
void
ecdb_burn_data_page_show(Ecdb_Page *page)
{
if (!page->data)
{
Evas_Object *b, *t;
Eina_List *l;
Ecdb_Drive_Info *drive;
Evas_Coord x, y, w, h;
Ewl_Widget *embed;
Ecdb_Data_Project *proj;
Ecdb_Burn_Project *bup;
Ecdb_Project *bp;
page->data = edje_object_add(ecore_evas_get(em->main_win_ee));
edje_object_file_set(page->data, em->theme_path, "ecdb/burn_data_page");
edje_object_part_geometry_get(page->gui, "active_area", &x, &y, &w, &h);
evas_object_move(page->data, x, y);
evas_object_resize(page->data, w, h);
edje_object_part_swallow(page->gui, "action_area", page->data);
edje_object_signal_callback_add(page->data, "hide,finished",
"burn_data_page",
_page_hide_finished, page);
evas_object_show(page->data);
proj = ecdb_data_project_new();
bp = ECDB_PROJECT(proj);
bup = ECDB_BURN(proj);
evas_object_data_set(page->data, "proj", proj);
bp->ret = ecdb_button_add(page->data, "ecdb/burn_data/return");
ecdb_button_label_set(bp->ret, "Return to Main Page");
edje_object_signal_callback_add(page->data, "mouse,clicked,1",
"ecdb/burn_data/return", _button_cb_return, page);
evas_object_show(bp->ret);
ecdb_button_icon_set(bp->ret, "ecdb/burn_data/return");
bp->begin = ecdb_button_add(page->data, "ecdb/burn_data/begin");
ecdb_button_label_set(bp->begin, "Start Burn");
edje_object_signal_callback_add(page->data, "mouse,clicked,1",
"ecdb/burn_data/begin", _button_cb_begin, page);
evas_object_show(bp->begin);
ecdb_button_icon_set(bp->begin, "ecdb/burn_data/begin");
bp->drive_combo = ecdb_combo_add(page->data, "ecdb/burn_data/drive");
ecdb_combo_header_set(bp->drive_combo, "Drive");
ecdb_combo_header_create_set(bp->drive_combo,
ecdb_gui_combo_header_from_drive);
evas_object_show(bp->drive_combo);
bup->speed_combo = ecdb_combo_add(page->data, "ecdb/burn_data/speed");
ecdb_combo_header_create_set(bup->speed_combo,
ecdb_gui_combo_header_from_speeds);
ecdb_combo_header_set(bup->speed_combo, "Max Speed");
evas_object_show(bup->speed_combo);
EINA_LIST_FOREACH(em->drives, l, drive)
{
b = ecdb_combo_item_add(bp->drive_combo, NULL);
ecdb_combo_item_label_set(b, drive->product);
evas_object_smart_callback_add(b, "clicked", _combo_cb_clicked, proj);
ecdb_combo_append(bp->drive_combo, b);
evas_object_show(b);
}
embed = ewl_embed_new();
ewl_object_fill_policy_set(EWL_OBJECT(embed), EWL_FLAG_FILL_ALL);
proj->filelist_swallow = ewl_embed_canvas_set(EWL_EMBED(embed),
evas_object_evas_get(bp->drive_combo),
(void *)(long)ecore_evas_software_x11_window_get(em->main_win_ee));
ewl_embed_focus_set(EWL_EMBED(embed), TRUE);
ewl_widget_show(embed);
proj->filelist = ecdb_custom_filelist_new();
ewl_container_child_append(EWL_CONTAINER(embed), proj->filelist);
ewl_callback_append(proj->filelist, ECDB_FILELIST_SIZE_CHANGED,
_update_capacity, page);
ewl_widget_show(proj->filelist);
/* Add a delete callback so we can correctly free data that won't get
* handled automatically
*/
evas_object_event_callback_add(page->data, EVAS_CALLBACK_DEL, _page_del,
bup->files);
edje_object_part_geometry_get(page->data, "ecdb/burn_data/filelist",
&x, &y, &w, &h);
evas_object_move(proj->filelist_swallow, x, y);
evas_object_resize(proj->filelist_swallow, w, h);
edje_object_part_swallow(page->data, "ecdb/burn_data/filelist",
proj->filelist_swallow);
ecdb_widget_focus_callback_add(proj->filelist_swallow,
"ecdb/burn_data/filelist");
evas_object_show(proj->filelist_swallow);
proj->capacity = ecdb_capacity_add(page->data, "ecdb/burn_data/capacity");
evas_object_data_set(proj->capacity, "src", bup->files);
evas_object_show(proj->capacity);
t = ecdb_config_inwin_add(page->data, NULL);
b = ecdb_check_add(t, NULL);
ecdb_check_label_set(b, "Use Joliet");
edje_object_signal_callback_add(b, "ecdb,check,*checked", "ecdb",
_joliet_clicked, proj);
evas_object_smart_callback_add(b, "proj_config", _joliet_config, proj);
ecdb_config_inwin_child_add(t, b, 0, 0, 1, 1);
evas_object_show(b);
b = ecdb_check_add(t, NULL);
ecdb_check_label_set(b, "Use Rockridge");
edje_object_signal_callback_add(b, "ecdb,check,*checked", "ecdb",
_rockridge_clicked, proj);
evas_object_smart_callback_add(b, "proj_config", _rockridge_config, proj);
ecdb_config_inwin_child_add(t, b, 0, 1, 1, 1);
evas_object_show(b);
b = ecdb_check_add(t, NULL);
ecdb_check_label_set(b, "Follow Symlinks");
edje_object_signal_callback_add(b, "ecdb,check,*checked", "ecdb",
_symlinks_clicked, proj);
evas_object_smart_callback_add(b, "proj_config", _symlinks_config, proj);
ecdb_config_inwin_child_add(t, b, 0, 2, 1, 1);
evas_object_show(b);
b = ecdb_check_add(t, NULL);
ecdb_check_label_set(b, "Ignore Hidden Files");
edje_object_signal_callback_add(b, "ecdb,check,*checked", "ecdb",
_hidden_clicked, proj);
evas_object_smart_callback_add(b, "proj_config", _hidden_config, proj);
ecdb_config_inwin_child_add(t, b, 0, 3, 1, 1);
evas_object_show(b);
b = ecdb_check_add(t, NULL);
ecdb_check_label_set(b, "Multi-session");
edje_object_signal_callback_add(b, "ecdb,check,*checked", "ecdb",
_multi_clicked, proj);
evas_object_smart_callback_add(b, "proj_config", _multi_config, proj);
ecdb_config_inwin_child_add(t, b, 1, 0, 1, 1);
evas_object_show(b);
b = ecdb_check_add(t, NULL);
ecdb_check_label_set(b, "Simulate");
edje_object_signal_callback_add(b, "ecdb,check,*checked", "ecdb",
_sim_clicked, proj);
evas_object_smart_callback_add(b, "proj_config", _sim_config, proj);
ecdb_config_inwin_child_add(t, b, 1, 1, 1, 1);
evas_object_show(b);
b = ecdb_check_add(t, NULL);
ecdb_check_label_set(b, "Use Underrun Proof");
edje_object_signal_callback_add(b, "ecdb,check,*checked", "ecdb",
_underrun_clicked, proj);
evas_object_smart_callback_add(b, "proj_config", _underrun_config, proj);
ecdb_config_inwin_child_add(t, b, 1, 2, 1, 1);
evas_object_show(b);
b = ecdb_entry_add(t, NULL);
ecdb_entry_text_set(b, "Volume Name");
evas_object_event_callback_add(b, EVAS_CALLBACK_FOCUS_OUT,
_proj_name, proj);
evas_object_smart_callback_add(b, "proj_config", _proj_config, proj);
ecdb_config_inwin_child_add(t, b, 1, 3, 1, 1);
evas_object_show(b);
b = ecdb_button_add(t, NULL);
ecdb_button_label_set(b, "Apply");
edje_object_signal_callback_add(b, "mouse,down,1", "*", _apply_clicked,
t);
ecdb_config_inwin_child_add(t, b, 0, 4, 2, 1);
evas_object_show(b);
// At the end so t is a valid pointer
b = ecdb_button_add(page->data, "ecdb/burn_data/settings");
ecdb_button_label_set(b, "Settings");
edje_object_signal_callback_add(page->data, "mouse,clicked,1",
"ecdb/burn_data/settings", _settings_clicked, t);
evas_object_show(b);
}
else if (edje_object_part_swallow_get(page->gui, "action_area") !=
page->data)
{
edje_object_part_swallow(page->gui, "action_area", page->data);
evas_object_show(page->data);
ewl_widget_show(ECDB_DATA(evas_object_data_get(page->data, "proj"))
->filelist);
}
edje_object_signal_emit(page->gui, "ecdb,burn_data_page,visible", "ecdb");
edje_object_signal_emit(page->data, "ecdb,burn_data_page,visible", "ecdb");
}
void
ecdb_burn_data_cleanup(Ecdb_Page *page)
{
Ewl_Widget *filelist;
Ecdb_Source *src, *t;
Ecdb_Data_Project *proj;
int i;
if (!page)
{
EINA_ERROR_PWARN("ecdb_burn_data_cleanup: NULL page!\n");
return;
}
proj = evas_object_data_get(page->data, "proj");
if (!proj)
{
EINA_ERROR_PWARN("ecdb_burn_data_cleanup: NULL proj!\n");
return;
}
Evas_Object *objs[] = {proj->capacity, proj->settings,
proj->filelist_swallow, ECDB_BURN(proj)->speed_combo,
ECDB_PROJECT(proj)->ret, ECDB_PROJECT(proj)->begin,
NULL};
for (i = 0; objs[i] != NULL; i++)
edje_object_signal_emit(objs[i], "ecdb,enable", "ecdb");
edje_object_signal_emit(page->data, "ecdb,burn_data,start", "ecdb");
edje_object_part_text_set(page->data, "progress_text", "Burn Complete!");
edje_object_signal_emit(page->data, "ecdb,burn_data,done", "ecdb");
filelist = proj->filelist;
src = ewl_widget_data_get(filelist, "source");
while (src->parent)
src = src->parent;
for (i = 0; i < src->num_children; i++)
{
t = src->children[i];
ecdb_source_child_remove(src, t);
ecdb_source_destroy(t);
}
/* Make sure, of course, to refresh the capacity and the filelist
* after finishing the burn
*/
ewl_mvc_dirty_set(EWL_MVC(EWL_FILELIST(proj->filelist)->controller), TRUE);
ewl_callback_call_with_event_data(proj->filelist, ECDB_FILELIST_SIZE_CHANGED,
src);
}