Merge CV, ver=5.1; ops/methods from HV, and interface from CV where possible
[goodguy/history.git] / cinelerra-5.0 / cinelerra / awindowgui.C
diff --git a/cinelerra-5.0/cinelerra/awindowgui.C b/cinelerra-5.0/cinelerra/awindowgui.C
deleted file mode 100644 (file)
index f7fd1c6..0000000
+++ /dev/null
@@ -1,1936 +0,0 @@
-
-/*
- * CINELERRA
- * Copyright (C) 1997-2012 Adam Williams <broadcast at earthling dot net>
- * 
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- * 
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- * 
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
- * 
- */
-
-#include "asset.h"
-#include "assetedit.h"
-#include "assetpopup.h"
-#include "assets.h"
-#include "awindowgui.h"
-#include "awindowgui.inc"
-#include "awindow.h"
-#include "awindowmenu.h"
-#include "bcsignals.h"
-#include "bchash.h"
-#include "cache.h"
-#include "bccmodels.h"
-#include "cursors.h"
-#include "cwindowgui.h"
-#include "cwindow.h"
-#include "edl.h"
-#include "edlsession.h"
-#include "file.h"
-#include "filesystem.h"
-#include "indexable.h"
-#include "keys.h"
-#include "language.h"
-#include "localsession.h"
-#include "mainmenu.h"
-#include "mainsession.h"
-#include "mwindowgui.h"
-#include "mwindow.h"
-#include "nestededls.h"
-#include "newfolder.h"
-#include "preferences.h"
-#include "theme.h"
-#include "vframe.h"
-#include "vicon.h"
-#include "vwindowgui.h"
-#include "vwindow.h"
-
-#include "data/lad_picon_png.h"
-#include "data/ff_audio_png.h"
-#include "data/ff_video_png.h"
-
-#include<stdio.h>
-#include<unistd.h>
-#include<fcntl.h>
-
-
-
-AssetVIcon::AssetVIcon(AssetPicon *picon, int w, int h, double framerate, int64_t length)
- : VIcon(w, h, framerate)
-{
-       this->picon = picon;
-       this->length = length;
-       temp = 0;
-}
-
-AssetVIcon::~AssetVIcon()
-{
-       delete temp;
-}
-
-VFrame *AssetVIcon::frame()
-{
-       if( seq_no >= images.size() ) {
-               MWindow *mwindow = picon->mwindow;
-               Asset *asset = (Asset *)picon->indexable;
-               File *file = mwindow->video_cache->check_out(asset, mwindow->edl, 1);
-               if( !file ) return 0;
-               if( temp && (temp->get_w() != asset->width || temp->get_h() != asset->height) ) {
-                       delete temp;  temp = 0;
-               }
-               if( !temp )
-                       temp = new VFrame(asset->width, asset->height, BC_RGB888);
-               int ww = picon->gui->vicon_thread->view_w;
-               int hh = picon->gui->vicon_thread->view_h;
-               while( seq_no >= images.size() ) {
-                       file->set_layer(0);
-                       int64_t pos = images.size() / picon->gui->vicon_thread->refresh_rate * frame_rate;
-                       file->set_video_position(pos,0);
-                       file->read_frame(temp);
-                       add_image(temp, ww, hh, BC_RGB8);
-               }
-               mwindow->video_cache->check_in(asset);
-       }
-       return *images[seq_no];
-}
-
-int64_t AssetVIcon::set_seq_no(int64_t no)
-{
-       if( no >= length ) no = 0;
-       return seq_no = no;
-}
-
-int AssetVIcon::get_vx()
-{
-       BC_ListBox *lbox = picon->gui->asset_list;
-       return lbox->get_item_x(picon);
-}
-int AssetVIcon::get_vy()
-{
-       BC_ListBox *lbox = picon->gui->asset_list;
-       return lbox->get_item_y(picon) + lbox->get_title_h();
-}
-
-AssetPicon::AssetPicon(MWindow *mwindow, 
-       AWindowGUI *gui, 
-       Indexable *indexable)
- : BC_ListBoxItem()
-{
-       reset();
-       this->mwindow = mwindow;
-       this->gui = gui;
-       this->indexable = indexable;
-       indexable->add_user();
-       this->id = indexable->id;
-}
-
-AssetPicon::AssetPicon(MWindow *mwindow, 
-       AWindowGUI *gui, 
-       EDL *edl)
- : BC_ListBoxItem()
-{
-       reset();
-       this->mwindow = mwindow;
-       this->gui = gui;
-       this->edl = edl;
-       edl->add_user();
-       this->id = edl->id;
-}
-
-AssetPicon::AssetPicon(MWindow *mwindow, 
-       AWindowGUI *gui, 
-       const char *folder)
- : BC_ListBoxItem(folder, gui->folder_icon)
-{
-       reset();
-       this->mwindow = mwindow;
-       this->gui = gui;
-}
-
-AssetPicon::AssetPicon(MWindow *mwindow, 
-       AWindowGUI *gui, 
-       PluginServer *plugin)
- : BC_ListBoxItem()
-{
-       reset();
-       this->mwindow = mwindow;
-       this->gui = gui;
-       this->plugin = plugin;
-}
-
-
-AssetPicon::~AssetPicon()
-{
-       if( vicon )
-               gui->vicon_thread->del_vicon(vicon);
-       if(indexable) indexable->remove_user();
-       if(edl) edl->remove_user();
-       if( icon && !gui->protected_pixmap(icon) ) {
-               delete icon;
-               if( !plugin ) delete icon_vframe;
-       }
-}
-
-void AssetPicon::reset()
-{
-       plugin = 0;
-       indexable = 0;
-       edl = 0;
-       icon = 0;
-       icon_vframe = 0;
-       vicon = 0;
-       in_use = 1;
-       id = 0;
-       persistent = 0;
-}
-
-void AssetPicon::create_objects()
-{
-       FileSystem fs;
-       char name[BCTEXTLEN];
-       int pixmap_w, pixmap_h;
-       const int debug = 0;
-
-       pixmap_h = 50 * BC_WindowBase::get_resources()->icon_scale;
-
-       if(debug) printf("AssetPicon::create_objects %d\n", __LINE__);
-       if(indexable)
-       {
-               fs.extract_name(name, indexable->path);
-               set_text(name);
-       }
-       
-       if(indexable && indexable->is_asset)
-       {
-               if(debug) printf("AssetPicon::create_objects %d\n", __LINE__);
-               Asset *asset = (Asset*)indexable;
-               if(asset->video_data)
-               {
-                       if(mwindow->preferences->use_thumbnails)
-                       {
-                               gui->unlock_window();
-                               if(debug) printf("AssetPicon::create_objects %d\n", __LINE__);
-                               File *file = mwindow->video_cache->check_out(asset, 
-                                       mwindow->edl,
-                                       1);
-                               if(debug) printf("AssetPicon::create_objects %d\n", __LINE__);
-
-                               if(file)
-                               {
-                                       int height = asset->height > 0 ? asset->height : 1;
-                                       pixmap_w = pixmap_h * asset->width / height;
-
-                                       file->set_layer(0);
-                                       file->set_video_position(0, 0);
-
-                                       if(gui->temp_picon && 
-                                               (gui->temp_picon->get_w() != asset->width ||
-                                               gui->temp_picon->get_h() != asset->height))
-                                       {
-                                               delete gui->temp_picon;
-                                               gui->temp_picon = 0;
-                                       }
-
-                                       if(!gui->temp_picon)
-                                       {
-                                               gui->temp_picon = new VFrame(0, -1,
-                                                       asset->width, asset->height, 
-                                                       BC_RGB888, -1);
-                                       }
-
-                                       file->read_frame(gui->temp_picon);
-                                       if(debug) printf("AssetPicon::create_objects %d\n", __LINE__);
-                                       mwindow->video_cache->check_in(asset);
-
-                                       gui->lock_window("AssetPicon::create_objects 1");
-                                       icon = new BC_Pixmap(gui, pixmap_w, pixmap_h);
-                                       icon->draw_vframe(gui->temp_picon,
-                                               0, 0, pixmap_w, pixmap_h, 0, 0);
-//printf("%d %d\n", gui->temp_picon->get_w(), gui->temp_picon->get_h());
-                                       icon_vframe = new VFrame(0,
-                                               -1, pixmap_w, pixmap_h, BC_RGB888, -1);
-                                       icon_vframe->transfer_from(gui->temp_picon);
-// vicon images
-                                       double framerate = asset->get_frame_rate();
-                                       if( !framerate ) framerate = VICON_RATE;
-                                       int64_t frames = asset->get_video_frames();
-                                       double secs = frames / framerate;
-                                       if( secs > 5 ) secs = 5;
-                                       int64_t length = secs * gui->vicon_thread->refresh_rate;
-                                       vicon = new AssetVIcon(this, pixmap_w, pixmap_h, framerate, length);
-                                       gui->vicon_thread->add_vicon(vicon);
-                                       if(debug) printf("AssetPicon::create_objects %d\n", __LINE__);
-
-                               }
-                               else
-                               {
-                                       gui->lock_window("AssetPicon::create_objects 2");
-                                       icon = gui->video_icon;
-                                       icon_vframe = BC_WindowBase::get_resources()->type_to_icon[ICON_FILM];
-                               }
-                       }
-                       else
-                       {
-                               icon = gui->video_icon;
-                               icon_vframe = BC_WindowBase::get_resources()->type_to_icon[ICON_FILM];                  
-                       }
-               }
-               else
-               if(asset->audio_data)
-               {
-                       icon = gui->audio_icon;
-                       icon_vframe = BC_WindowBase::get_resources()->type_to_icon[ICON_SOUND];
-               }
-//printf("AssetPicon::create_objects 2\n");
-
-               if(debug) printf("AssetPicon::create_objects %d\n", __LINE__);
-       }
-       else
-       if(indexable && !indexable->is_asset)
-       {
-               icon = gui->video_icon;
-               icon_vframe = BC_WindowBase::get_resources()->type_to_icon[ICON_FILM];
-       }
-       else
-       if(edl)
-       {
-//printf("AssetPicon::create_objects 4 %s\n", edl->local_session->clip_title);
-               set_text(strcpy(name, edl->local_session->clip_title));
-               icon = gui->clip_icon;
-               icon_vframe = mwindow->theme->get_image("clip_icon");
-       }
-       else
-       if(plugin)
-       {
-               strcpy(name, _(plugin->title));
-               set_text(name);
-               icon_vframe = plugin->get_picon();
-               if( icon_vframe )
-                       icon = gui->create_pixmap(icon_vframe);
-               else if( plugin->audio ) {
-                       if( plugin->transition ) {
-                               icon = gui->atransition_icon;
-                               icon_vframe = gui->atransition_vframe;
-                       }
-                       else if( plugin->is_ffmpeg() ) {
-                               icon = gui->ff_aud_icon;
-                               icon_vframe = gui->ff_aud_vframe;
-                       }
-                       else if( plugin->is_ladspa() ) {
-                               icon = gui->ladspa_icon;
-                               icon_vframe = gui->ladspa_vframe;
-                       }
-                       else {
-                               icon = gui->aeffect_icon;
-                               icon_vframe = gui->aeffect_vframe;
-                       }
-               }
-               else if( plugin->video ) {
-                       if( plugin->transition ) {
-                               icon = gui->vtransition_icon;
-                               icon_vframe = gui->vtransition_vframe;
-                       }
-                       else if( plugin->is_ffmpeg() ) {
-                               icon = gui->ff_vid_icon;
-                               icon_vframe = gui->ff_vid_vframe;
-                       }
-                       else {
-                               icon = gui->veffect_icon;
-                               icon_vframe = gui->veffect_vframe;
-                       }
-               }
-       }
-       if( !icon ) {
-               icon = gui->file_icon;
-               icon_vframe = BC_WindowBase::get_resources()->type_to_icon[ICON_UNKNOWN];
-       }
-       set_icon(icon);
-       set_icon_vframe(icon_vframe);
-
-       if(debug) printf("AssetPicon::create_objects %d\n", __LINE__);
-}
-
-
-
-
-
-
-AWindowGUI::AWindowGUI(MWindow *mwindow, AWindow *awindow)
- : BC_Window(PROGRAM_NAME ": Resources",
-       mwindow->session->awindow_x, 
-    mwindow->session->awindow_y, 
-    mwindow->session->awindow_w, 
-    mwindow->session->awindow_h,
-    100,
-    100,
-    1,
-    1,
-    1)
-{
-// printf("AWindowGUI::AWindowGUI %d %d %d %d\n",
-// mwindow->session->awindow_x, 
-// mwindow->session->awindow_y, 
-// mwindow->session->awindow_w, 
-// mwindow->session->awindow_h);
-       this->mwindow = mwindow;
-       this->awindow = awindow;
-       file_icon = 0;
-       audio_icon = 0;
-       video_icon = 0;
-       folder_icon = 0;
-       clip_icon = 0;
-       atransition_icon = 0;  atransition_vframe = 0;
-       vtransition_icon = 0;  vtransition_vframe = 0;
-       aeffect_icon = 0;      aeffect_vframe = 0;
-       ladspa_icon = 0;       ladspa_vframe = 0;
-       veffect_icon = 0;      veffect_vframe = 0;
-       ff_aud_icon = 0;       ff_aud_vframe = 0;
-       ff_vid_icon = 0;       ff_vid_vframe = 0;
-       plugin_visibility = ((uint64_t)1<<(8*sizeof(uint64_t)-1))-1;
-       newfolder_thread = 0;
-       asset_menu = 0;
-       assetlist_menu = 0;
-       folderlist_menu = 0;
-       temp_picon = 0;
-       remove_plugin = 0;
-       vicon_thread = 0;
-       vicon_drawing = 1;
-}
-
-AWindowGUI::~AWindowGUI()
-{
-       assets.remove_all_objects();
-       folders.remove_all_objects();
-       aeffects.remove_all_objects();
-       veffects.remove_all_objects();
-       atransitions.remove_all_objects();
-       vtransitions.remove_all_objects();
-       displayed_assets[1].remove_all_objects();
-
-       delete vicon_thread;
-       delete file_icon;
-       delete audio_icon;
-       delete video_icon;
-       delete folder_icon;
-       delete clip_icon;
-       delete atransition_icon;
-       delete vtransition_icon;
-       delete aeffect_icon;
-       delete ladspa_icon;
-       delete ladspa_vframe;
-       delete ff_aud_icon;
-       delete ff_aud_vframe;
-       delete ff_vid_icon;
-       delete ff_vid_vframe;
-       delete veffect_icon;
-       delete newfolder_thread;
-       delete asset_menu;
-       delete assetlist_menu;
-       delete folderlist_menu;
-       if(temp_picon) delete temp_picon;
-       delete remove_plugin;
-}
-
-bool AWindowGUI::protected_pixmap(BC_Pixmap *icon)
-{
-       return  icon == file_icon ||
-               icon == folder_icon ||
-               icon == audio_icon ||
-               icon == video_icon ||
-               icon == clip_icon ||
-               icon == vtransition_icon ||
-               icon == atransition_icon ||
-               icon == veffect_icon ||
-               icon == aeffect_icon ||
-               icon == ladspa_icon ||
-               icon == ff_aud_icon ||
-               icon == ff_vid_icon;
-}
-
-void AWindowGUI::create_objects()
-{
-       AssetPicon *picon;
-
-       lock_window("AWindowGUI::create_objects");
-SET_TRACE
-//printf("AWindowGUI::create_objects 1\n");
-       asset_titles[0] = _("Title");
-       asset_titles[1] = _("Comments");
-
-SET_TRACE
-
-       set_icon(mwindow->theme->get_image("awindow_icon"));
-       file_icon = new BC_Pixmap(this, 
-               BC_WindowBase::get_resources()->type_to_icon[ICON_UNKNOWN],
-               PIXMAP_ALPHA);
-
-       folder_icon = new BC_Pixmap(this, 
-               BC_WindowBase::get_resources()->type_to_icon[ICON_FOLDER],
-               PIXMAP_ALPHA);
-
-       audio_icon = new BC_Pixmap(this, 
-               BC_WindowBase::get_resources()->type_to_icon[ICON_SOUND],
-               PIXMAP_ALPHA);
-
-       video_icon = new BC_Pixmap(this, 
-               BC_WindowBase::get_resources()->type_to_icon[ICON_FILM],
-               PIXMAP_ALPHA);
-
-SET_TRACE
-
-       clip_vframe = mwindow->theme->get_image("clip_icon");
-       clip_icon = new BC_Pixmap(this, clip_vframe, PIXMAP_ALPHA);
-       atransition_vframe = mwindow->theme->get_image("atransition_icon");
-       atransition_icon = new BC_Pixmap(this, atransition_vframe, PIXMAP_ALPHA);
-       vtransition_vframe = mwindow->theme->get_image("vtransition_icon");
-       vtransition_icon = new BC_Pixmap(this, vtransition_vframe, PIXMAP_ALPHA);
-       aeffect_vframe = mwindow->theme->get_image("aeffect_icon");
-       aeffect_icon = new BC_Pixmap(this, aeffect_vframe, PIXMAP_ALPHA);
-       ladspa_vframe = new VFramePng(lad_picon_png);
-       ladspa_icon = new BC_Pixmap(this, ladspa_vframe, PIXMAP_ALPHA);
-       ff_aud_vframe = new VFramePng(ff_audio_png);
-       ff_aud_icon = new BC_Pixmap(this, ff_aud_vframe, PIXMAP_ALPHA);
-       ff_vid_vframe = new VFramePng(ff_video_png);
-       ff_vid_icon = new BC_Pixmap(this, ff_vid_vframe, PIXMAP_ALPHA);
-       veffect_vframe = mwindow->theme->get_image("veffect_icon");
-       veffect_icon = new BC_Pixmap(this, veffect_vframe, PIXMAP_ALPHA);
-
-SET_TRACE
-
-// Mandatory folders
-       folders.append(picon = new AssetPicon(mwindow,
-               this,
-               AEFFECT_FOLDER));
-       picon->persistent = 1;
-       folders.append(picon = new AssetPicon(mwindow,
-               this,
-               VEFFECT_FOLDER));
-       picon->persistent = 1;
-       folders.append(picon = new AssetPicon(mwindow,
-               this,
-               ATRANSITION_FOLDER));
-       picon->persistent = 1;
-       folders.append(picon = new AssetPicon(mwindow,
-               this,
-               VTRANSITION_FOLDER));
-       picon->persistent = 1;
-SET_TRACE
-
-       mwindow->theme->get_awindow_sizes(this);
-       load_defaults(mwindow->defaults);
-
-SET_TRACE
-       add_subwindow(asset_list = new AWindowAssets(mwindow,
-               this,
-               mwindow->theme->alist_x, 
-               mwindow->theme->alist_y, 
-               mwindow->theme->alist_w, 
-               mwindow->theme->alist_h));
-
-       vicon_thread = new VIconThread(asset_list);
-       vicon_thread->start();
-
-SET_TRACE
-       add_subwindow(divider = new AWindowDivider(mwindow,
-               this,
-               mwindow->theme->adivider_x,
-               mwindow->theme->adivider_y,
-               mwindow->theme->adivider_w,
-               mwindow->theme->adivider_h));
-
-SET_TRACE
-       divider->set_cursor(HSEPARATE_CURSOR, 0, 0);
-
-SET_TRACE
-       int fx = mwindow->theme->afolders_x, fy = mwindow->theme->afolders_y;
-       int fw = mwindow->theme->afolders_w, fh = mwindow->theme->afolders_h;
-       VFrame **images = mwindow->theme->get_image_set("playpatch_data");
-       AVIconDrawing::calculate_geometry(this, images, &avicon_w, &avicon_h);
-       add_subwindow(avicon_drawing = new AVIconDrawing(this, fw-avicon_w, fy, images));
-       add_subwindow(add_tools = new AddTools(mwindow, this, fx, fy, "Visibility"));
-       add_tools->create_objects();
-       fy += add_tools->get_h();  fh -= add_tools->get_h();
-SET_TRACE
-       add_subwindow(folder_list = new AWindowFolders(mwindow,
-               this, fx, fy, fw, fh));
-SET_TRACE
-       update_effects();
-SET_TRACE
-
-       //int x = mwindow->theme->abuttons_x;
-       //int y = mwindow->theme->abuttons_y;
-
-SET_TRACE
-
-       newfolder_thread = new NewFolderThread(mwindow, this);
-
-       add_subwindow(asset_menu = new AssetPopup(mwindow, this));
-       asset_menu->create_objects();
-
-SET_TRACE
-
-       add_subwindow(assetlist_menu = new AssetListMenu(mwindow, this));
-
-SET_TRACE
-       assetlist_menu->create_objects();
-
-SET_TRACE
-
-       add_subwindow(folderlist_menu = new FolderListMenu(mwindow, this));
-       folderlist_menu->create_objects();
-//printf("AWindowGUI::create_objects 2\n");
-
-SET_TRACE
-       unlock_window();
-}
-
-int AWindowGUI::resize_event(int w, int h)
-{
-       mwindow->session->awindow_x = get_x();
-       mwindow->session->awindow_y = get_y();
-       mwindow->session->awindow_w = w;
-       mwindow->session->awindow_h = h;
-
-       mwindow->theme->get_awindow_sizes(this);
-       mwindow->theme->draw_awindow_bg(this);
-       reposition_objects();
-       
-//     int x = mwindow->theme->abuttons_x;
-//     int y = mwindow->theme->abuttons_y;
-//     new_bin->reposition_window(x, y);
-//     x += new_bin->get_w();
-//     delete_bin->reposition_window(x, y);
-//     x += delete_bin->get_w();
-//     rename_bin->reposition_window(x, y);
-//     x += rename_bin->get_w();
-//     delete_disk->reposition_window(x, y);
-//     x += delete_disk->get_w();
-//     delete_project->reposition_window(x, y);
-//     x += delete_project->get_w();
-//     info->reposition_window(x, y);
-//     x += info->get_w();
-//     redraw_index->reposition_window(x, y);
-//     x += redraw_index->get_w();
-//     paste->reposition_window(x, y);
-//     x += paste->get_w();
-//     append->reposition_window(x, y);
-//     x += append->get_w();
-//     view->reposition_window(x, y);
-
-       BC_WindowBase::resize_event(w, h);
-       return 1;
-}
-
-int AWindowGUI::translation_event()
-{
-       mwindow->session->awindow_x = get_x();
-       mwindow->session->awindow_y = get_y();
-       return 0;
-}
-
-void AWindowGUI::reposition_objects()
-{
-       mwindow->theme->get_awindow_sizes(this);
-       asset_list->reposition_window(
-               mwindow->theme->alist_x, mwindow->theme->alist_y, 
-               mwindow->theme->alist_w, mwindow->theme->alist_h);
-       divider->reposition_window(
-               mwindow->theme->adivider_x, mwindow->theme->adivider_y,
-               mwindow->theme->adivider_w, mwindow->theme->adivider_h);
-       int fx = mwindow->theme->afolders_x, fy = mwindow->theme->afolders_y;
-       int fw = mwindow->theme->afolders_w, fh = mwindow->theme->afolders_h;
-       add_tools->resize_event(fw-avicon_w, add_tools->get_h());
-       avicon_drawing->reposition_window(fw-avicon_w, fy);
-       fy += add_tools->get_h();  fh -= add_tools->get_h();
-       folder_list->reposition_window(fx, fy, fw, fh);
-}
-
-int AWindowGUI::save_defaults(BC_Hash *defaults)
-{
-       defaults->update("PLUGIN_VISIBILTY", plugin_visibility);
-       defaults->update("VICON_DRAWING", vicon_drawing);
-       return 0;
-}
-
-int AWindowGUI::load_defaults(BC_Hash *defaults)
-{
-       plugin_visibility = defaults->get("PLUGIN_VISIBILTY", plugin_visibility);
-       vicon_drawing = defaults->get("VICON_DRAWING", vicon_drawing);
-       return 0;
-}
-
-
-int AWindowGUI::close_event()
-{
-       hide_window();
-       mwindow->session->show_awindow = 0;
-       unlock_window();
-
-       mwindow->gui->lock_window("AWindowGUI::close_event");
-       mwindow->gui->mainmenu->show_awindow->set_checked(0);
-       mwindow->gui->unlock_window();
-
-       lock_window("AWindowGUI::close_event");
-       save_defaults(mwindow->defaults);
-       mwindow->save_defaults();
-       return 1;
-}
-
-void AWindowGUI::start_vicon_drawing()
-{
-       if( !vicon_drawing ) return;
-       if( strcmp(mwindow->edl->session->current_folder, MEDIA_FOLDER) ) return;
-       if( mwindow->edl->session->assetlist_format != ASSETS_ICONS ) return;
-       vicon_thread->start_drawing();
-}
-
-void AWindowGUI::stop_vicon_drawing()
-{
-       vicon_thread->stop_drawing();
-}
-
-AWindowRemovePluginGUI::
-AWindowRemovePluginGUI(AWindow *awindow, AWindowRemovePlugin *thread,
-       int x, int y, PluginServer *plugin)
- : BC_Window(PROGRAM_NAME ": Remove plugin", x,y, 500,200, 50, 50, 1, 0, 1, -1, "", 1)
-{
-       this->awindow = awindow;
-       this->thread = thread;
-       this->plugin = plugin;
-       VFrame *vframe = plugin->get_picon();
-       icon = vframe ? create_pixmap(vframe) : 0;
-       plugin_list.append(new BC_ListBoxItem(plugin->title, icon));
-}
-
-AWindowRemovePluginGUI::
-~AWindowRemovePluginGUI()
-{
-       if( !awindow->gui->protected_pixmap(icon) )
-               delete icon;
-       plugin_list.remove_all();
-}
-
-void AWindowRemovePluginGUI::create_objects()
-{
-       BC_Button *ok_button = new BC_OKButton(this);
-       add_subwindow(ok_button);
-       BC_Button *cancel_button = new BC_CancelButton(this);
-       add_subwindow(cancel_button);
-       int x = 10, y = 10;
-       BC_Title *title = new BC_Title(x, y, _("remove plugin?"));
-       add_subwindow(title);
-       y += title->get_h() + 5;
-       list = new BC_ListBox(x, y,
-                get_w() - 20, ok_button->get_y() - y - 5, LISTBOX_TEXT, &plugin_list,
-                0, 0, 1, 0, 0, LISTBOX_SINGLE, ICON_LEFT, 0);
-       add_subwindow(list);
-       show_window();
-}
-
-int AWindowRemovePlugin::remove_plugin(PluginServer *plugin, ArrayList<BC_ListBoxItem*> &folder)
-{
-       int ret = 0;
-       for( int i=0; i<folder.size(); ) {
-               AssetPicon *picon = (AssetPicon *)folder[i];
-               if( picon->plugin == plugin ) {
-                       folder.remove_object_number(i);
-                       ++ret;
-                       continue;
-               }
-               ++i;
-       }
-       return ret;
-}
-
-void AWindowRemovePlugin::handle_close_event(int result)
-{
-       if( !result ) {
-               printf("remove %s\n", plugin->path);
-               ArrayList<BC_ListBoxItem*> *folder = 
-                       plugin->audio ? plugin->transition ?
-                               &awindow->gui->atransitions :
-                               &awindow->gui->aeffects :
-                       plugin->video ?  plugin->transition ?
-                               &awindow->gui->vtransitions :
-                               &awindow->gui->veffects :
-                       0;
-               if( folder ) remove_plugin(plugin, *folder);
-               awindow->gui->update_assets();
-               char plugin_path[BCTEXTLEN];
-               strcpy(plugin_path, plugin->path);
-               MWindow *mwindow = awindow->mwindow;
-               mwindow->plugindb->remove(plugin);
-               delete plugin;  plugin = 0;
-               remove(plugin_path);
-               char index_path[BCTEXTLEN];
-               sprintf(index_path, "%s/%s", mwindow->preferences->plugin_dir, PLUGIN_FILE);
-               remove(index_path);
-               char png_path[BCTEXTLEN];
-               if( plugin->get_theme_png_path(png_path, mwindow->preferences->theme) )
-                       remove(png_path);
-               if( plugin->get_theme_png_path(png_path, "picon") )
-                       remove(png_path);
-       }
-}
-
-AWindowRemovePlugin::
-AWindowRemovePlugin(AWindow *awindow, PluginServer *plugin)
- : BC_DialogThread()
-{
-       this->awindow = awindow;
-       this->plugin = plugin;
-}
-
-AWindowRemovePlugin::
-~AWindowRemovePlugin()
-{
-       close_window();
-}
-
-BC_Window* AWindowRemovePlugin::new_gui()
-{
-       int x = awindow->gui->get_abs_cursor_x(0);
-       int y = awindow->gui->get_abs_cursor_y(0);
-       AWindowRemovePluginGUI *gui = new AWindowRemovePluginGUI(awindow, this, x, y, plugin);
-       gui->create_objects();
-       return gui;
-}
-
-int AWindowGUI::keypress_event()
-{
-       switch(get_keypress()) {
-       case 'w': case 'W':
-               if(ctrl_down()) {
-                       close_event();
-                       return 1;
-               }
-               break;
-       case DELETE:
-               if(shift_down()) {
-                       PluginServer* plugin = selected_plugin();
-                       if( !plugin ) break;
-                       remove_plugin = new AWindowRemovePlugin(awindow, plugin);
-                       unlock_window();
-                       remove_plugin->start();
-                       lock_window();
-               }
-       }
-       return 0;
-}
-
-void AWindowGUI::update_folder_list()
-{
-       stop_vicon_drawing();
-//printf("AWindowGUI::update_folder_list 1\n");
-       for(int i = 0; i < folders.total; i++)
-       {
-               AssetPicon *picon = (AssetPicon*)folders.values[i];
-               picon->in_use--;
-       }
-//printf("AWindowGUI::update_folder_list 1\n");
-
-// Search assets for folders
-       for(int i = 0; i < mwindow->edl->folders.total; i++)
-       {
-               char *folder = mwindow->edl->folders.values[i];
-               int exists = 0;
-//printf("AWindowGUI::update_folder_list 1.1\n");
-
-               for(int j = 0; j < folders.total; j++)
-               {
-                       AssetPicon *picon = (AssetPicon*)folders.values[j];
-                       if(!strcasecmp(picon->get_text(), folder))
-                       {
-                               exists = 1;
-                               picon->in_use = 1;
-                               break;
-                       }
-               }
-
-               if(!exists)
-               {
-                       AssetPicon *picon = new AssetPicon(mwindow, this, folder);
-                       picon->create_objects();
-                       folders.append(picon);
-               }
-//printf("AWindowGUI::update_folder_list 1.3\n");
-       }
-//printf("AWindowGUI::update_folder_list 1\n");
-//for(int i = 0; i < folders.total; i++)
-//     printf("AWindowGUI::update_folder_list %s\n", folders.values[i]->get_text());
-
-// Delete excess
-       for(int i = folders.total - 1; i >= 0; i--)
-       {
-               AssetPicon *picon = (AssetPicon*)folders.values[i];
-               if(!picon->in_use && !picon->persistent)
-               {
-                       delete picon;
-                       folders.remove_number(i);
-               }
-       }
-//for(int i = 0; i < folders.total; i++)
-//     printf("AWindowGUI::update_folder_list %s\n", folders.values[i]->get_text());
-//printf("AWindowGUI::update_folder_list 2\n");
-       start_vicon_drawing();
-}
-
-void AWindowGUI::create_persistent_folder(ArrayList<BC_ListBoxItem*> *output, 
-       int do_audio, int do_video, int is_realtime, int is_transition)
-{
-       ArrayList<PluginServer*> plugin_list;
-// Get pointers to plugindb entries
-       mwindow->search_plugindb(do_audio, do_video, is_realtime, is_transition,
-                       0, plugin_list);
-
-       for(int i = 0; i < plugin_list.total; i++) {
-               PluginServer *server = plugin_list.values[i];
-               int visible = plugin_visibility & (1<<server->dir_idx);
-               if(!visible) continue;
-// Create new listitem
-               AssetPicon *picon = new AssetPicon(mwindow, this, server);
-               picon->create_objects();
-               output->append(picon);
-       }
-}
-
-void AWindowGUI::update_asset_list()
-{
-//printf("AWindowGUI::update_asset_list 1\n");
-       for(int i = 0; i < assets.total; i++)
-       {
-               AssetPicon *picon = (AssetPicon*)assets.values[i];
-               picon->in_use--;
-       }
-
-
-
-
-
-//printf("AWindowGUI::update_asset_list 2\n");
-
-
-// Synchronize EDL clips
-       for(int i = 0; i < mwindow->edl->clips.total; i++)
-       {
-               int exists = 0;
-               
-// Look for clip in existing listitems
-               for(int j = 0; j < assets.total && !exists; j++)
-               {
-                       AssetPicon *picon = (AssetPicon*)assets.values[j];
-                       
-                       if(picon->id == mwindow->edl->clips.values[i]->id)
-                       {
-                               picon->edl = mwindow->edl->clips.values[i];
-                               picon->set_text(mwindow->edl->clips.values[i]->local_session->clip_title);
-                               exists = 1;
-                               picon->in_use = 1;
-                       }
-               }
-
-// Create new listitem
-               if(!exists)
-               {
-                       AssetPicon *picon = new AssetPicon(mwindow, 
-                               this, 
-                               mwindow->edl->clips.values[i]);
-                       picon->create_objects();
-                       assets.append(picon);
-               }
-       }
-
-
-
-
-
-//printf("AWindowGUI::update_asset_list %d\n", __LINE__);
-
-
-// Synchronize EDL assets
-       for(Asset *current = mwindow->edl->assets->first; 
-               current; 
-               current = NEXT)
-       {
-               int exists = 0;
-
-// Look for asset in existing listitems
-               for(int j = 0; j < assets.total && !exists; j++)
-               {
-                       AssetPicon *picon = (AssetPicon*)assets.values[j];
-
-                       if(picon->id == current->id)
-                       {
-                               picon->indexable = current;
-                               exists = 1;
-                               picon->in_use = 1;
-                               break;
-                       }
-               }
-
-// Create new listitem
-               if(!exists)
-               {
-//printf("AWindowGUI::update_asset_list %d\n", __LINE__);
-                       AssetPicon *picon = new AssetPicon(mwindow, this, current);
-//printf("AWindowGUI::update_asset_list %d\n", __LINE__);
-                       picon->create_objects();
-//printf("AWindowGUI::update_asset_list %d\n", __LINE__);
-                       assets.append(picon);
-               }
-       }
-
-
-
-//printf("AWindowGUI::update_asset_list %d\n", __LINE__);
-
-
-// Synchronize nested EDLs
-       for(int i = 0; i < mwindow->edl->nested_edls->size(); i++)
-       {
-               int exists = 0;
-               Indexable *indexable = mwindow->edl->nested_edls->get(i);
-
-// Look for asset in existing listitems
-               for(int j = 0; j < assets.total && !exists; j++)
-               {
-                       AssetPicon *picon = (AssetPicon*)assets.values[j];
-
-                       if(picon->id == indexable->id)
-                       {
-                               picon->indexable = indexable;
-                               exists = 1;
-                               picon->in_use = 1;
-                               break;
-                       }
-               }
-
-// Create new listitem
-               if(!exists)
-               {
-                       AssetPicon *picon = new AssetPicon(mwindow, 
-                               this, 
-                               indexable);
-                       picon->create_objects();
-                       assets.append(picon);
-               }
-       }
-
-
-
-
-
-
-
-
-
-//printf("AWindowGUI::update_asset_list %d\n", __LINE__);
-       for(int i = assets.size() - 1; i >= 0; i--)
-       {
-               AssetPicon *picon = (AssetPicon*)assets.get(i);
-//printf("AWindowGUI::update_asset_list %s %d\n", picon->asset->path, picon->in_use);
-               if(!picon->in_use)
-               {
-                       delete picon;
-                       assets.remove_number(i);
-               }
-       }
-//printf("AWindowGUI::update_asset_list 7 %d\n", assets.total);
-}
-
-
-
-
-
-void AWindowGUI::sort_assets()
-{
-//printf("AWindowGUI::sort_assets 1 %s\n", mwindow->edl->session->current_folder);
-       if(!strcasecmp(mwindow->edl->session->current_folder, AEFFECT_FOLDER))
-               sort_picons(&aeffects, 
-                       0);
-       else
-       if(!strcasecmp(mwindow->edl->session->current_folder, VEFFECT_FOLDER))
-               sort_picons(&veffects, 
-                       0);
-       else
-       if(!strcasecmp(mwindow->edl->session->current_folder, ATRANSITION_FOLDER))
-               sort_picons(&atransitions, 
-                       0);
-       else
-       if(!strcasecmp(mwindow->edl->session->current_folder, VTRANSITION_FOLDER))
-               sort_picons(&vtransitions, 
-                       0);
-       else
-               sort_picons(&assets, 
-                       mwindow->edl->session->current_folder);
-
-       update_assets();
-}
-
-
-
-
-
-
-
-
-
-
-
-void AWindowGUI::collect_assets()
-{
-       int i = 0;
-       mwindow->session->drag_assets->remove_all();
-       mwindow->session->drag_clips->remove_all();
-       while(1)
-       {
-               AssetPicon *result = (AssetPicon*)asset_list->get_selection(0, i++);
-               if(!result) break;
-
-               if(result->indexable) mwindow->session->drag_assets->append(result->indexable);
-               if(result->edl) mwindow->session->drag_clips->append(result->edl);
-       }
-}
-
-void AWindowGUI::copy_picons(ArrayList<BC_ListBoxItem*> *dst, 
-       ArrayList<BC_ListBoxItem*> *src, 
-       char *folder)
-{
-// Remove current pointers
-       dst[0].remove_all();
-       dst[1].remove_all_objects();
-
-// Create new pointers
-//if(folder) printf("AWindowGUI::copy_picons 1 %s\n", folder);
-       for(int i = 0; i < src->total; i++)
-       {
-               AssetPicon *picon = (AssetPicon*)src->values[i];
-//printf("AWindowGUI::copy_picons 2 %s\n", picon->asset->folder);
-               if(!folder ||
-                       (folder && picon->indexable && !strcasecmp(picon->indexable->folder, folder)) ||
-                       (folder && picon->edl && !strcasecmp(picon->edl->local_session->folder, folder)))
-               {
-                       BC_ListBoxItem *item2, *item1;
-                       dst[0].append(item1 = picon);
-                       if(picon->edl)
-                               dst[1].append(item2 = new BC_ListBoxItem(picon->edl->local_session->clip_notes));
-                       else
-                               dst[1].append(item2 = new BC_ListBoxItem(""));
-                       item1->set_autoplace_text(1);
-                       item2->set_autoplace_text(1);
-//printf("AWindowGUI::copy_picons 3 %s\n", picon->get_text());
-               }
-       }
-}
-
-void AWindowGUI::sort_picons(ArrayList<BC_ListBoxItem*> *src, 
-               char *folder)
-{
-//printf("AWindowGUI::sort_picons 1\n")
-       int done = 0;
-       while(!done)
-       {
-               done = 1;
-               for(int i = 0; i < src->total - 1; i++)
-               {
-                       BC_ListBoxItem *item1 = src->values[i];
-                       BC_ListBoxItem *item2 = src->values[i + 1];
-                       item1->set_autoplace_icon(1);
-                       item2->set_autoplace_icon(1);
-                       item1->set_autoplace_text(1);
-                       item2->set_autoplace_text(1);
-                       if(strcmp(item1->get_text(), item2->get_text()) > 0)
-                       {
-                               src->values[i + 1] = item1;
-                               src->values[i] = item2;
-                               done = 0;
-                       }
-               }
-       }
-}
-
-
-void AWindowGUI::filter_displayed_assets()
-{
-       if(!strcasecmp(mwindow->edl->session->current_folder, AEFFECT_FOLDER))
-               copy_picons(displayed_assets, 
-                       &aeffects, 
-                       0);
-       else
-       if(!strcasecmp(mwindow->edl->session->current_folder, VEFFECT_FOLDER))
-               copy_picons(displayed_assets, 
-                       &veffects, 
-                       0);
-       else
-       if(!strcasecmp(mwindow->edl->session->current_folder, ATRANSITION_FOLDER))
-               copy_picons(displayed_assets, 
-                       &atransitions, 
-                       0);
-       else
-       if(!strcasecmp(mwindow->edl->session->current_folder, VTRANSITION_FOLDER))
-               copy_picons(displayed_assets, 
-                       &vtransitions, 
-                       0);
-       else
-               copy_picons(displayed_assets, 
-                       &assets, 
-                       mwindow->edl->session->current_folder);
-}
-
-
-void AWindowGUI::update_assets()
-{
-//printf("AWindowGUI::update_assets 1\n");
-       update_folder_list();
-//printf("AWindowGUI::update_assets 2\n");
-       update_asset_list();
-//printf("AWindowGUI::update_assets 3\n");
-       filter_displayed_assets();
-
-//for(int i = 0; i < folders.total; i++)
-//printf("AWindowGUI::update_assets 4\n");
-//     printf("AWindowGUI::update_assets %s\n", folders.values[i]->get_text());
-       if(mwindow->edl->session->folderlist_format != folder_list->get_format())
-               folder_list->update_format(mwindow->edl->session->folderlist_format, 0);
-       folder_list->update(&folders,
-               0,
-               0,
-               1,
-               folder_list->get_xposition(),
-               folder_list->get_yposition(),
-               -1);
-//printf("AWindowGUI::update_assets 5\n");
-
-       if(mwindow->edl->session->assetlist_format != asset_list->get_format())
-               asset_list->update_format(mwindow->edl->session->assetlist_format, 0);
-
-
-//printf("AWindowGUI::update_assets 6 %d\n", displayed_assets[0].total);
-       asset_list->update(displayed_assets,
-               asset_titles,
-               mwindow->edl->session->asset_columns,
-               ASSET_COLUMNS, 
-               asset_list->get_xposition(),
-               asset_list->get_yposition(),
-               -1,
-               0);
-//printf("AWindowGUI::update_assets 7\n");
-
-       flush();
-//printf("AWindowGUI::update_assets 8\n");
-       return;
-}
-
-void AWindowGUI::update_effects()
-{
-       aeffects.remove_all_objects();
-       create_persistent_folder(&aeffects, 1, 0, 1, 0);
-       veffects.remove_all_objects();
-       create_persistent_folder(&veffects, 0, 1, 1, 0);
-       atransitions.remove_all_objects();
-       create_persistent_folder(&atransitions, 1, 0, 0, 1);
-       vtransitions.remove_all_objects();
-       create_persistent_folder(&vtransitions, 0, 1, 0, 1);
-}
-
-int AWindowGUI::current_folder_number()
-{
-       int result = -1;
-       for(int i = 0; i < folders.total; i++)
-       {
-               if(!strcasecmp(folders.values[i]->get_text(), mwindow->edl->session->current_folder))
-               {
-                       result = i;
-                       break;
-               }
-       }
-       return result;
-}
-
-int AWindowGUI::drag_motion()
-{
-       if(get_hidden()) return 0;
-
-       int result = 0;
-       return result;
-}
-
-int AWindowGUI::drag_stop()
-{
-       if(get_hidden()) return 0;
-
-       return 0;
-}
-
-Indexable* AWindowGUI::selected_asset()
-{
-       AssetPicon *picon = (AssetPicon*)asset_list->get_selection(0, 0);
-       return picon ? picon->indexable : 0;
-}
-
-PluginServer* AWindowGUI::selected_plugin()
-{
-       AssetPicon *picon = (AssetPicon*)asset_list->get_selection(0, 0);
-       return picon ? picon->plugin : 0;
-}
-
-AssetPicon* AWindowGUI::selected_folder()
-{
-       AssetPicon *picon = (AssetPicon*)folder_list->get_selection(0, 0);
-       return picon;
-}
-
-
-
-
-
-
-
-
-AWindowDivider::AWindowDivider(MWindow *mwindow, AWindowGUI *gui, int x, int y, int w, int h)
- : BC_SubWindow(x, y, w, h)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-}
-AWindowDivider::~AWindowDivider()
-{
-}
-
-int AWindowDivider::button_press_event()
-{
-       if(is_event_win() && cursor_inside())
-       {
-               mwindow->session->current_operation = DRAG_PARTITION;
-               return 1;
-       }
-       return 0;
-}
-
-int AWindowDivider::cursor_motion_event()
-{
-       if(mwindow->session->current_operation == DRAG_PARTITION)
-       {
-               mwindow->session->afolders_w = gui->get_relative_cursor_x();
-               gui->reposition_objects();
-               gui->flush();
-       }
-       return 0;
-}
-
-int AWindowDivider::button_release_event()
-{
-       if(mwindow->session->current_operation == DRAG_PARTITION)
-       {
-               mwindow->session->current_operation = NO_OPERATION;
-               return 1;
-       }
-       return 0;
-}
-
-
-
-
-
-
-AWindowFolders::AWindowFolders(MWindow *mwindow, AWindowGUI *gui, int x, int y, int w, int h)
- : BC_ListBox(x, 
-               y, 
-               w, 
-               h,
-               mwindow->edl->session->folderlist_format == FOLDERS_ICONS ? 
-                       LISTBOX_ICONS : LISTBOX_TEXT, 
-               &gui->folders, // Each column has an ArrayList of BC_ListBoxItems.
-               0,             // Titles for columns.  Set to 0 for no titles
-               0,                // width of each column
-               1,                      // Total columns.
-               0,                    // Pixel of top of window.
-               0,                        // If this listbox is a popup window
-               LISTBOX_SINGLE,  // Select one item or multiple items
-               ICON_TOP,        // Position of icon relative to text of each item
-               1)               // Allow drags
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_drag_scroll(0);
-}
-
-AWindowFolders::~AWindowFolders()
-{
-}
-       
-int AWindowFolders::selection_changed()
-{
-       AssetPicon *picon = (AssetPicon*)get_selection(0, 0);
-       if(picon)
-       {
-               gui->stop_vicon_drawing();
-
-               if(get_button_down() && get_buttonpress() == 3)
-               {
-                       gui->folderlist_menu->update_titles();
-                       gui->folderlist_menu->activate_menu();
-               }
-
-               strcpy(mwindow->edl->session->current_folder, picon->get_text());
-//printf("AWindowFolders::selection_changed 1\n");
-               gui->asset_list->draw_background();
-               gui->update_assets();
-
-               gui->start_vicon_drawing();
-       }
-       return 1;
-}
-
-int AWindowFolders::button_press_event()
-{
-       int result = 0;
-
-       result = BC_ListBox::button_press_event();
-
-       if(!result)
-       {
-               if(get_buttonpress() == 3 && is_event_win() && cursor_inside())
-               {
-                       gui->folderlist_menu->update_titles();
-                       gui->folderlist_menu->activate_menu();
-                       result = 1;
-               }
-       }
-
-
-       return result;
-}
-
-
-
-
-
-
-
-AWindowAssets::AWindowAssets(MWindow *mwindow, AWindowGUI *gui, int x, int y, int w, int h)
- : BC_ListBox(x, 
-               y, 
-               w, 
-               h,
-               mwindow->edl->session->assetlist_format == ASSETS_ICONS ? 
-                       LISTBOX_ICONS : LISTBOX_TEXT,
-               &gui->assets,     // Each column has an ArrayList of BC_ListBoxItems.
-               gui->asset_titles,             // Titles for columns.  Set to 0 for no titles
-               mwindow->edl->session->asset_columns,                // width of each column
-               1,                      // Total columns.
-               0,                    // Pixel of top of window.
-               0,                        // If this listbox is a popup window
-               LISTBOX_MULTIPLE,  // Select one item or multiple items
-               ICON_TOP,        // Position of icon relative to text of each item
-               1)               // Allow drag
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_drag_scroll(0);
-}
-
-AWindowAssets::~AWindowAssets()
-{
-}
-
-int AWindowAssets::button_press_event()
-{
-       int result = 0;
-
-       result = BC_ListBox::button_press_event();
-
-       if(!result && get_buttonpress() == 3 && is_event_win() && cursor_inside())
-       {
-               BC_ListBox::deactivate_selection();
-               gui->assetlist_menu->update_titles();
-               gui->assetlist_menu->activate_menu();
-               result = 1;
-       }
-
-
-       return result;
-}
-
-
-int AWindowAssets::handle_event()
-{
-//printf("AWindowAssets::handle_event 1 %d %d\n", get_buttonpress(), get_selection(0, 0));
-       if(get_selection(0, 0))
-       {
-               if(!strcasecmp(mwindow->edl->session->current_folder, AEFFECT_FOLDER))
-               {
-               }
-               else
-               if(!strcasecmp(mwindow->edl->session->current_folder, VEFFECT_FOLDER))
-               {
-               }
-               else
-               if(!strcasecmp(mwindow->edl->session->current_folder, ATRANSITION_FOLDER))
-               {
-               }
-               else
-               if(!strcasecmp(mwindow->edl->session->current_folder, VTRANSITION_FOLDER))
-               {
-               }
-               else
-               if(mwindow->vwindows.size())
-               {
-//printf("AWindowAssets::handle_event 2 %d %d\n", get_buttonpress(), get_selection(0, 0));
-                       mwindow->vwindows.get(DEFAULT_VWINDOW)->gui->lock_window("AWindowAssets::handle_event");
-                       
-                       if(((AssetPicon*)get_selection(0, 0))->indexable)
-                               mwindow->vwindows.get(DEFAULT_VWINDOW)->change_source(((AssetPicon*)get_selection(0, 0))->indexable);
-                       else
-                       if(((AssetPicon*)get_selection(0, 0))->edl)
-                               mwindow->vwindows.get(DEFAULT_VWINDOW)->change_source(((AssetPicon*)get_selection(0, 0))->edl);
-
-                       mwindow->vwindows.get(DEFAULT_VWINDOW)->gui->unlock_window();
-               }
-               return 1;
-       }
-
-       return 0;
-}
-
-int AWindowAssets::selection_changed()
-{
-// Show popup window
-       if(get_button_down() && get_buttonpress() == 3 && get_selection(0, 0))
-       {
-               if(!strcasecmp(mwindow->edl->session->current_folder, AEFFECT_FOLDER) || 
-                       !strcasecmp(mwindow->edl->session->current_folder, VEFFECT_FOLDER) ||
-                       !strcasecmp(mwindow->edl->session->current_folder, ATRANSITION_FOLDER) ||
-                       !strcasecmp(mwindow->edl->session->current_folder, VTRANSITION_FOLDER))
-               {
-                       gui->assetlist_menu->update_titles();
-                       gui->assetlist_menu->activate_menu();
-               }
-               else
-               {
-                       if(((AssetPicon*)get_selection(0, 0))->indexable)
-                               gui->asset_menu->update();
-                       else
-                       if(((AssetPicon*)get_selection(0, 0))->edl)
-                               gui->asset_menu->update();
-
-
-
-                       gui->asset_menu->activate_menu();
-               }
-
-               BC_ListBox::deactivate_selection();
-               return 1;
-       }
-       else if( get_button_down() && get_buttonpress() == 1 && get_selection(0, 0) ) {
-               VIcon *vicon = 0;
-               if( !gui->vicon_thread->viewing ) {
-                       AssetPicon *picon = (AssetPicon*)get_selection(0, 0);
-                       vicon = picon->vicon;
-               }
-               gui->vicon_thread->set_view_popup(vicon);
-
-       }
-       return 0;
-}
-
-void AWindowAssets::draw_background()
-{
-       clear_box(0,0,get_w(),get_h(),get_bg_surface());
-       set_color(RED);
-       set_font(LARGEFONT);
-       draw_text(get_w() - 
-                       get_text_width(LARGEFONT, mwindow->edl->session->current_folder) - 4, 
-               30, 
-               mwindow->edl->session->current_folder, 
-               -1, 
-               get_bg_surface());
-}
-
-int AWindowAssets::drag_start_event()
-{
-       int collect_pluginservers = 0;
-       int collect_assets = 0;
-
-       if(BC_ListBox::drag_start_event())
-       {
-               if(!strcasecmp(mwindow->edl->session->current_folder, AEFFECT_FOLDER))
-               {
-                       mwindow->session->current_operation = DRAG_AEFFECT;
-                       collect_pluginservers = 1;
-               }
-               else
-               if(!strcasecmp(mwindow->edl->session->current_folder, VEFFECT_FOLDER))
-               {
-                       mwindow->session->current_operation = DRAG_VEFFECT;
-                       collect_pluginservers = 1;
-               }
-               else
-               if(!strcasecmp(mwindow->edl->session->current_folder, ATRANSITION_FOLDER))
-               {
-                       mwindow->session->current_operation = DRAG_ATRANSITION;
-                       collect_pluginservers = 1;
-               }
-               else
-               if(!strcasecmp(mwindow->edl->session->current_folder, VTRANSITION_FOLDER))
-               {
-                       mwindow->session->current_operation = DRAG_VTRANSITION;
-                       collect_pluginservers = 1;
-               }
-               else
-               {
-                       mwindow->session->current_operation = DRAG_ASSET;
-                       collect_assets = 1;
-               }
-               
-               
-               if(collect_pluginservers)
-               {
-                       int i = 0;
-                       mwindow->session->drag_pluginservers->remove_all();
-                       while(1)
-                       {
-                               AssetPicon *result = (AssetPicon*)get_selection(0, i++);
-                               if(!result) break;
-                               
-                               mwindow->session->drag_pluginservers->append(result->plugin);
-                       }
-               }
-               
-               if(collect_assets)
-               {
-                       gui->collect_assets();
-               }
-
-               return 1;
-       }
-       return 0;
-}
-
-int AWindowAssets::drag_motion_event()
-{
-       BC_ListBox::drag_motion_event();
-       unlock_window();
-
-       mwindow->gui->lock_window("AWindowAssets::drag_motion_event");
-       mwindow->gui->drag_motion();
-       mwindow->gui->unlock_window();
-
-       for(int i = 0; i < mwindow->vwindows.size(); i++)
-       {
-               VWindow *vwindow = mwindow->vwindows.get(i);
-               vwindow->gui->lock_window("AWindowAssets::drag_motion_event");
-               vwindow->gui->drag_motion();
-               vwindow->gui->unlock_window();
-       }
-
-       mwindow->cwindow->gui->lock_window("AWindowAssets::drag_motion_event");
-       mwindow->cwindow->gui->drag_motion();
-       mwindow->cwindow->gui->unlock_window();
-
-       lock_window("AWindowAssets::drag_motion_event");
-       return 0;
-}
-
-int AWindowAssets::drag_stop_event()
-{
-       int result = 0;
-
-       result = gui->drag_stop();
-
-       unlock_window();
-
-       if(!result)
-       {
-               mwindow->gui->lock_window("AWindowAssets::drag_stop_event");
-               result = mwindow->gui->drag_stop();
-               mwindow->gui->unlock_window();
-       }
-
-       if(!result) 
-       {
-               for(int i = 0; i < mwindow->vwindows.size(); i++)
-               {
-                       VWindow *vwindow = mwindow->vwindows.get(i);
-                       vwindow->gui->lock_window("AWindowAssets::drag_stop_event");
-                       result = vwindow->gui->drag_stop();
-                       vwindow->gui->unlock_window();
-               }
-       }
-
-       if(!result) 
-       {
-               mwindow->cwindow->gui->lock_window("AWindowAssets::drag_stop_event");
-               result = mwindow->cwindow->gui->drag_stop();
-               mwindow->cwindow->gui->unlock_window();
-       }
-
-       lock_window("AWindowAssets::drag_stop_event");
-
-       if(result) get_drag_popup()->set_animation(0);
-
-       BC_ListBox::drag_stop_event();
-       mwindow->session->current_operation = ::NO_OPERATION; // since NO_OPERATION is also defined in listbox, we have to reach for global scope...
-       return 0;
-}
-
-int AWindowAssets::column_resize_event()
-{
-       mwindow->edl->session->asset_columns[0] = get_column_width(0);
-       mwindow->edl->session->asset_columns[1] = get_column_width(1);
-       return 1;
-}
-
-int AWindowAssets::cursor_enter_event()
-{
-       int ret = BC_ListBox::cursor_enter_event();
-       gui->start_vicon_drawing();
-       return ret;
-}
-
-int AWindowAssets::cursor_leave_event()
-{
-       gui->stop_vicon_drawing();
-       return BC_ListBox::cursor_leave_event();
-}
-
-
-
-
-
-
-
-
-
-
-
-
-AWindowNewFolder::AWindowNewFolder(MWindow *mwindow, AWindowGUI *gui, int x, int y)
- : BC_Button(x, y, mwindow->theme->newbin_data)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_tooltip(_("New bin"));
-}
-
-int AWindowNewFolder::handle_event()
-{
-       gui->newfolder_thread->start_new_folder();
-       return 1;
-}
-
-AWindowDeleteFolder::AWindowDeleteFolder(MWindow *mwindow, AWindowGUI *gui, int x, int y)
- : BC_Button(x, y, mwindow->theme->deletebin_data)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_tooltip(_("Delete bin"));
-}
-
-int AWindowDeleteFolder::handle_event()
-{
-       if(gui->folder_list->get_selection(0, 0))
-       {
-               BC_ListBoxItem *folder = gui->folder_list->get_selection(0, 0);
-               mwindow->delete_folder(folder->get_text());
-       }
-       return 1;
-}
-
-AWindowRenameFolder::AWindowRenameFolder(MWindow *mwindow, AWindowGUI *gui, int x, int y)
- : BC_Button(x, y, mwindow->theme->renamebin_data)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_tooltip(_("Rename bin"));
-}
-
-int AWindowRenameFolder::handle_event()
-{
-       return 1;
-}
-
-AWindowDeleteDisk::AWindowDeleteDisk(MWindow *mwindow, AWindowGUI *gui, int x, int y)
- : BC_Button(x, y, mwindow->theme->deletedisk_data)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_tooltip(_("Delete asset from disk"));
-}
-
-int AWindowDeleteDisk::handle_event()
-{
-       return 1;
-}
-
-AWindowDeleteProject::AWindowDeleteProject(MWindow *mwindow, AWindowGUI *gui, int x, int y)
- : BC_Button(x, y, mwindow->theme->deleteproject_data)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_tooltip(_("Delete asset from project"));
-}
-
-int AWindowDeleteProject::handle_event()
-{
-       return 1;
-}
-
-AWindowInfo::AWindowInfo(MWindow *mwindow, AWindowGUI *gui, int x, int y)
- : BC_Button(x, y, mwindow->theme->infoasset_data)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_tooltip(_("Edit information on asset"));
-}
-
-int AWindowInfo::handle_event()
-{
-       gui->awindow->asset_edit->edit_asset(gui->selected_asset());
-       return 1;
-}
-
-AWindowRedrawIndex::AWindowRedrawIndex(MWindow *mwindow, AWindowGUI *gui, int x, int y)
- : BC_Button(x, y, mwindow->theme->redrawindex_data)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_tooltip(_("Redraw index"));
-}
-
-int AWindowRedrawIndex::handle_event()
-{
-       return 1;
-}
-
-AWindowPaste::AWindowPaste(MWindow *mwindow, AWindowGUI *gui, int x, int y)
- : BC_Button(x, y, mwindow->theme->pasteasset_data)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_tooltip(_("Paste asset on recordable tracks"));
-}
-
-int AWindowPaste::handle_event()
-{
-       return 1;
-}
-
-AWindowAppend::AWindowAppend(MWindow *mwindow, AWindowGUI *gui, int x, int y)
- : BC_Button(x, y, mwindow->theme->appendasset_data)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_tooltip(_("Append asset in new tracks"));
-}
-
-int AWindowAppend::handle_event()
-{
-       return 1;
-}
-
-AWindowView::AWindowView(MWindow *mwindow, AWindowGUI *gui, int x, int y)
- : BC_Button(x, y, mwindow->theme->viewasset_data)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-       set_tooltip(_("View asset"));
-}
-
-int AWindowView::handle_event()
-{
-       return 1;
-}
-
-AddTools::AddTools(MWindow *mwindow, AWindowGUI *gui, int x, int y, const char *title)
- : BC_PopupMenu(x, y, BC_Title::calculate_w(gui, title, MEDIUMFONT)+8, title, -1, 0, 4)
-{
-       this->mwindow = mwindow;
-       this->gui = gui;
-}
-
-void AddTools::create_objects()
-{
-       uint64_t vis = 0;
-       add_item(new AddPluginItem(this, "ladspa", PLUGIN_LADSPA_ID));
-       vis |= 1 << PLUGIN_LADSPA_ID;
-       add_item(new AddPluginItem(this, "ffmpeg", PLUGIN_FFMPEG_ID));
-       vis |= 1 << PLUGIN_FFMPEG_ID;
-       for( int i=0; i<MWindow::plugindb->size(); ++i ) {
-               PluginServer *plugin = MWindow::plugindb->get(i);
-               if( !plugin->audio && !plugin->video ) continue;
-               int idx = plugin->dir_idx;
-               uint32_t msk = 1 << idx;
-               if( (msk & vis) != 0 ) continue;
-               vis |= msk;
-               char parent[BCTEXTLEN];
-               strcpy(parent, plugin->path);
-               char *bp = strrchr(parent, '/');
-               if( bp ) { *bp = 0;  bp = strrchr(parent, '/'); }
-               if( !bp ) bp = parent; else ++bp;
-               add_item(new AddPluginItem(this, bp, idx));
-       }
-}
-
-AddPluginItem::AddPluginItem(AddTools *menu, char const *text, int idx)
- : BC_MenuItem(text)
-{
-       this->menu = menu;
-       this->idx = idx;
-       uint64_t msk = (uint64_t)1 << idx, vis = menu->gui->plugin_visibility;
-       int chk = (msk & vis) ? 1 : 0;
-        set_checked(chk);
-}
-
-int AddPluginItem::handle_event()
-{
-        int chk = get_checked() ^ 1;
-        set_checked(chk);
-       uint64_t msk = (uint64_t)1 << idx, vis = menu->gui->plugin_visibility;
-       menu->gui->plugin_visibility = chk ? vis | msk : vis & ~msk;
-       menu->gui->update_effects();
-       menu->gui->update_assets();
-       menu->gui->save_defaults(menu->mwindow->defaults);
-       return 1;
-}
-
-AVIconDrawing::AVIconDrawing(AWindowGUI *agui, int x, int y, VFrame **images)
- : BC_Toggle(x, y, images, agui->vicon_drawing)
-{
-       this->agui = agui;
-       set_tooltip(_("draw vicons"));
-}
-
-void AVIconDrawing::calculate_geometry(AWindowGUI *agui, VFrame **images, int *ww, int *hh)
-{
-       int text_line = -1, toggle_x = -1, toggle_y = -1;
-       int text_x = -1, text_y = -1, text_w = -1, text_h = -1;
-       BC_Toggle::calculate_extents(agui, images, 1, 
-               &text_line, ww, hh, &toggle_x, &toggle_y,
-               &text_x, &text_y, &text_w, &text_h, "", MEDIUMFONT);
-}
-
-AVIconDrawing::~AVIconDrawing()
-{
-}
-
-int AVIconDrawing::handle_event()
-{
-       agui->vicon_drawing = get_value();
-       if( agui->vicon_drawing )
-               agui->start_vicon_drawing();
-       else
-               agui->stop_vicon_drawing();
-       return 1;
-}
-