]> git.sesse.net Git - kdenlive/blobdiff - src/projectlist.cpp
Reindent all source files
[kdenlive] / src / projectlist.cpp
index 08c1582fb37fc99a3098ddc12da4f37df4cf9525..b2ee5011eb5d18e6de3bd3ccb14b5e6dea03fe55 100644 (file)
 #include <QtGui>
 
 ProjectList::ProjectList(QWidget *parent)
-    : QWidget(parent), m_render(NULL), m_fps(-1), m_commandStack(NULL)
-{
-
-  QWidget *vbox = new QWidget;
-  listView = new ProjectListView(this);;
-  QVBoxLayout *layout = new QVBoxLayout;
-  m_clipIdCounter = 0;
-
-  // setup toolbar
-  searchView = new KTreeWidgetSearchLine (this);
-  m_toolbar = new QToolBar("projectToolBar", this);
-  m_toolbar->addWidget (searchView);
-
-  QToolButton *addButton = new QToolButton( m_toolbar );
-  QMenu *addMenu = new QMenu(this);
-  addButton->setMenu( addMenu );
-  addButton->setPopupMode(QToolButton::MenuButtonPopup);
-  m_toolbar->addWidget (addButton);
-
-  QAction *addClipButton = addMenu->addAction (KIcon("document-new"), i18n("Add Clip"));
-  connect(addClipButton, SIGNAL(triggered()), this, SLOT(slotAddClip()));
-
-  QAction *addColorClip = addMenu->addAction (KIcon("document-new"), i18n("Add Color Clip"));
-  connect(addColorClip, SIGNAL(triggered()), this, SLOT(slotAddColorClip()));
-       
-       QAction *addTitleClip = addMenu->addAction (KIcon("document-new"), i18n("Add Title Clip"));
-       connect(addTitleClip, SIGNAL(triggered()), this, SLOT(slotAddTitleClip()));
-
-  m_deleteAction = m_toolbar->addAction (KIcon("edit-delete"), i18n("Delete Clip"));
-  connect(m_deleteAction, SIGNAL(triggered()), this, SLOT(slotRemoveClip()));
-
-  m_editAction = m_toolbar->addAction (KIcon("document-properties"), i18n("Edit Clip"));
-  connect(m_editAction, SIGNAL(triggered()), this, SLOT(slotEditClip()));
-
-  QAction *addFolderButton = addMenu->addAction (KIcon("folder-new"), i18n("Create Folder"));
-  connect(addFolderButton, SIGNAL(triggered()), this, SLOT(slotAddFolder()));
-
-  addButton->setDefaultAction( addClipButton );
-
-  layout->addWidget( m_toolbar );
-  layout->addWidget( listView );
-  setLayout( layout );
-  //m_toolbar->setEnabled(false);
-
-  searchView->setTreeWidget(listView);
-  listView->setColumnCount(3);
-  QStringList headers;
-  headers<<i18n("Thumbnail")<<i18n("Filename")<<i18n("Description");
-  listView->setHeaderLabels(headers);
-  listView->sortByColumn(1, Qt::AscendingOrder);
-
-  m_menu = new QMenu();        
-  m_menu->addAction(addClipButton);
-  m_menu->addAction(addColorClip);
-  m_menu->addAction(addTitleClip);
-  m_menu->addAction(m_editAction);
-  m_menu->addAction(m_deleteAction);
-  m_menu->addAction(addFolderButton);
-  m_menu->insertSeparator(m_deleteAction);
-
-  connect(listView, SIGNAL(itemSelectionChanged()), this, SLOT(slotClipSelected()));
-  connect(listView, SIGNAL(requestMenu ( const QPoint &, QTreeWidgetItem * )), this, SLOT(slotContextMenu(const QPoint &, QTreeWidgetItem *)));
-  connect(listView, SIGNAL(addClip ()), this, SLOT(slotAddClip()));
-  connect(listView, SIGNAL(addClip (QUrl, const QString &)), this, SLOT(slotAddClip(QUrl, const QString &)));
-  connect(listView, SIGNAL (itemChanged ( QTreeWidgetItem *, int )), this, SLOT(slotUpdateItemDescription(QTreeWidgetItem *, int )));
-
-  m_listViewDelegate = new ItemDelegate(listView);
-  listView->setItemDelegate(m_listViewDelegate);
-  listView->setIconSize(QSize(60, 40));
-  listView->setSortingEnabled (true);
+        : QWidget(parent), m_render(NULL), m_fps(-1), m_commandStack(NULL) {
+
+    QWidget *vbox = new QWidget;
+    listView = new ProjectListView(this);;
+    QVBoxLayout *layout = new QVBoxLayout;
+    m_clipIdCounter = 0;
+
+    // setup toolbar
+    searchView = new KTreeWidgetSearchLine(this);
+    m_toolbar = new QToolBar("projectToolBar", this);
+    m_toolbar->addWidget(searchView);
+
+    QToolButton *addButton = new QToolButton(m_toolbar);
+    QMenu *addMenu = new QMenu(this);
+    addButton->setMenu(addMenu);
+    addButton->setPopupMode(QToolButton::MenuButtonPopup);
+    m_toolbar->addWidget(addButton);
+
+    QAction *addClipButton = addMenu->addAction(KIcon("document-new"), i18n("Add Clip"));
+    connect(addClipButton, SIGNAL(triggered()), this, SLOT(slotAddClip()));
+
+    QAction *addColorClip = addMenu->addAction(KIcon("document-new"), i18n("Add Color Clip"));
+    connect(addColorClip, SIGNAL(triggered()), this, SLOT(slotAddColorClip()));
+
+    QAction *addTitleClip = addMenu->addAction(KIcon("document-new"), i18n("Add Title Clip"));
+    connect(addTitleClip, SIGNAL(triggered()), this, SLOT(slotAddTitleClip()));
+
+    m_deleteAction = m_toolbar->addAction(KIcon("edit-delete"), i18n("Delete Clip"));
+    connect(m_deleteAction, SIGNAL(triggered()), this, SLOT(slotRemoveClip()));
+
+    m_editAction = m_toolbar->addAction(KIcon("document-properties"), i18n("Edit Clip"));
+    connect(m_editAction, SIGNAL(triggered()), this, SLOT(slotEditClip()));
+
+    QAction *addFolderButton = addMenu->addAction(KIcon("folder-new"), i18n("Create Folder"));
+    connect(addFolderButton, SIGNAL(triggered()), this, SLOT(slotAddFolder()));
+
+    addButton->setDefaultAction(addClipButton);
+
+    layout->addWidget(m_toolbar);
+    layout->addWidget(listView);
+    setLayout(layout);
+    //m_toolbar->setEnabled(false);
+
+    searchView->setTreeWidget(listView);
+    listView->setColumnCount(3);
+    QStringList headers;
+    headers << i18n("Thumbnail") << i18n("Filename") << i18n("Description");
+    listView->setHeaderLabels(headers);
+    listView->sortByColumn(1, Qt::AscendingOrder);
+
+    m_menu = new QMenu();
+    m_menu->addAction(addClipButton);
+    m_menu->addAction(addColorClip);
+    m_menu->addAction(addTitleClip);
+    m_menu->addAction(m_editAction);
+    m_menu->addAction(m_deleteAction);
+    m_menu->addAction(addFolderButton);
+    m_menu->insertSeparator(m_deleteAction);
+
+    connect(listView, SIGNAL(itemSelectionChanged()), this, SLOT(slotClipSelected()));
+    connect(listView, SIGNAL(requestMenu(const QPoint &, QTreeWidgetItem *)), this, SLOT(slotContextMenu(const QPoint &, QTreeWidgetItem *)));
+    connect(listView, SIGNAL(addClip()), this, SLOT(slotAddClip()));
+    connect(listView, SIGNAL(addClip(QUrl, const QString &)), this, SLOT(slotAddClip(QUrl, const QString &)));
+    connect(listView, SIGNAL(itemChanged(QTreeWidgetItem *, int)), this, SLOT(slotUpdateItemDescription(QTreeWidgetItem *, int)));
+
+    m_listViewDelegate = new ItemDelegate(listView);
+    listView->setItemDelegate(m_listViewDelegate);
+    listView->setIconSize(QSize(60, 40));
+    listView->setSortingEnabled(true);
 }
 
-ProjectList::~ProjectList()
-{
-  delete m_menu;
-  delete m_toolbar;
+ProjectList::~ProjectList() {
+    delete m_menu;
+    delete m_toolbar;
 }
 
-void ProjectList::setRenderer(Render *projectRender)
-{
-  m_render = projectRender;
+void ProjectList::setRenderer(Render *projectRender) {
+    m_render = projectRender;
 }
 
-void ProjectList::slotClipSelected()
-{
-  ProjectItem *item = (ProjectItem*) listView->currentItem();
-  if (item && !item->isGroup()) emit clipSelected(item->toXml());
+void ProjectList::slotClipSelected() {
+    ProjectItem *item = (ProjectItem*) listView->currentItem();
+    if (item && !item->isGroup()) emit clipSelected(item->toXml());
 }
 
-void ProjectList::slotUpdateItemDescription( QTreeWidgetItem *item, int column)
-{
-  if (column != 2) return;
-  ProjectItem *clip = (ProjectItem*) item;
-  CLIPTYPE type = clip->clipType(); 
-  if (type == AUDIO || type == VIDEO || type == AV || type == IMAGE || type == PLAYLIST) {
-    // Use Nepomuk system to store clip description
-    Nepomuk::Resource f( clip->clipUrl().path() );
-    f.setDescription(item->text(2));
-    kDebug()<<"NEPOMUK, SETTING CLIP: "<<clip->clipUrl().path()<<", TO TEXT: "<<item->text(2);
-  }
+void ProjectList::slotUpdateItemDescription(QTreeWidgetItem *item, int column) {
+    if (column != 2) return;
+    ProjectItem *clip = (ProjectItem*) item;
+    CLIPTYPE type = clip->clipType();
+    if (type == AUDIO || type == VIDEO || type == AV || type == IMAGE || type == PLAYLIST) {
+        // Use Nepomuk system to store clip description
+        Nepomuk::Resource f(clip->clipUrl().path());
+        f.setDescription(item->text(2));
+        kDebug() << "NEPOMUK, SETTING CLIP: " << clip->clipUrl().path() << ", TO TEXT: " << item->text(2);
+    }
 }
 
-void ProjectList::slotEditClip()
-{
-  kDebug()<<"////////////////////////////////////////   DBL CLK";
+void ProjectList::slotEditClip() {
+    kDebug() << "////////////////////////////////////////   DBL CLK";
 }
 
 
-void ProjectList::slotEditClip(QTreeWidgetItem *item, int column)
-{
-  kDebug()<<"////////////////////////////////////////   DBL CLK";
+void ProjectList::slotEditClip(QTreeWidgetItem *item, int column) {
+    kDebug() << "////////////////////////////////////////   DBL CLK";
 }
 
-void ProjectList::slotContextMenu( const QPoint &pos, QTreeWidgetItem *item )
-{
-  bool enable = false;
-  if (item) {
-    QFrame *w = new QFrame;
-    w->setFrameShape(QFrame::StyledPanel);
-    w->setLineWidth(2);
-    w->setAutoFillBackground(true);
-    QHBoxLayout *layout = new QHBoxLayout;
-    layout->addWidget( new QLabel(i18n("Color:")));
-    layout->addWidget( new KColorButton());
-    layout->addWidget( new QLabel(i18n("Duration:")));
-    layout->addWidget( new KRestrictedLine());
-    w->setLayout( layout );
-    m_listViewDelegate->extendItem(w, listView->currentIndex());
-    enable = true;
-  }
-  m_editAction->setEnabled(enable);
-  m_deleteAction->setEnabled(enable);
-
-  m_menu->popup(pos);
+void ProjectList::slotContextMenu(const QPoint &pos, QTreeWidgetItem *item) {
+    bool enable = false;
+    if (item) {
+        QFrame *w = new QFrame;
+        w->setFrameShape(QFrame::StyledPanel);
+        w->setLineWidth(2);
+        w->setAutoFillBackground(true);
+        QHBoxLayout *layout = new QHBoxLayout;
+        layout->addWidget(new QLabel(i18n("Color:")));
+        layout->addWidget(new KColorButton());
+        layout->addWidget(new QLabel(i18n("Duration:")));
+        layout->addWidget(new KRestrictedLine());
+        w->setLayout(layout);
+        m_listViewDelegate->extendItem(w, listView->currentIndex());
+        enable = true;
+    }
+    m_editAction->setEnabled(enable);
+    m_deleteAction->setEnabled(enable);
+
+    m_menu->popup(pos);
 }
 
-void ProjectList::slotRemoveClip()
-{
+void ProjectList::slotRemoveClip() {
 
-  if (!m_commandStack) kDebug()<<"!!!!!!!!!!!!!!!!  NO CMD STK";
-  if (!listView->currentItem()) return;
-  ProjectItem *item = ((ProjectItem *)listView->currentItem());
-  if (item->numReferences() > 0) {
-    if (KMessageBox::questionYesNo(this, i18n("Delete clip <b>%1</b> ?<br>This will also remove its %2 clips in timeline").arg(item->names().at(1)).arg(item->numReferences()), i18n("Delete Clip")) != KMessageBox::Yes) return;
-  }
-  m_doc->deleteProjectClip(item->clipId());
+    if (!m_commandStack) kDebug() << "!!!!!!!!!!!!!!!!  NO CMD STK";
+    if (!listView->currentItem()) return;
+    ProjectItem *item = ((ProjectItem *)listView->currentItem());
+    if (item->numReferences() > 0) {
+        if (KMessageBox::questionYesNo(this, i18n("Delete clip <b>%1</b> ?<br>This will also remove its %2 clips in timeline").arg(item->names().at(1)).arg(item->numReferences()), i18n("Delete Clip")) != KMessageBox::Yes) return;
+    }
+    m_doc->deleteProjectClip(item->clipId());
 }
 
-void ProjectList::selectItemById(const int clipId)
-{
-  ProjectItem *item = getItemById(clipId);
-  if (item) listView->setCurrentItem(item);
+void ProjectList::selectItemById(const int clipId) {
+    ProjectItem *item = getItemById(clipId);
+    if (item) listView->setCurrentItem(item);
 }
 
-void ProjectList::addClip(const QStringList &name, const QDomElement &elem, const int clipId, const KUrl &url, const QString &group, int parentId)
-{
-  kDebug()<<"/////////  ADDING VCLIP=: "<<name;
-  ProjectItem *item;
-  ProjectItem *groupItem = NULL;
-  QString groupName;
-  if (group.isEmpty()) groupName = elem.attribute("group", QString::null);
-  else groupName = group;
-  if (elem.isNull() && url.isEmpty()) {
-    // this is a folder
-    groupName = name.at(1);
-    QList<QTreeWidgetItem *> groupList = listView->findItems(groupName, Qt::MatchExactly, 1);
-    if (groupList.isEmpty())  {
-       (void) new ProjectItem(listView, name, clipId);
+void ProjectList::addClip(const QStringList &name, const QDomElement &elem, const int clipId, const KUrl &url, const QString &group, int parentId) {
+    kDebug() << "/////////  ADDING VCLIP=: " << name;
+    ProjectItem *item;
+    ProjectItem *groupItem = NULL;
+    QString groupName;
+    if (group.isEmpty()) groupName = elem.attribute("group", QString::null);
+    else groupName = group;
+    if (elem.isNull() && url.isEmpty()) {
+        // this is a folder
+        groupName = name.at(1);
+        QList<QTreeWidgetItem *> groupList = listView->findItems(groupName, Qt::MatchExactly, 1);
+        if (groupList.isEmpty())  {
+            (void) new ProjectItem(listView, name, clipId);
+        }
+        return;
     }
-    return;
-  }
-
-  if (parentId != -1) {
-    groupItem = getItemById(parentId);
-  }
-  else if (!groupName.isEmpty()) {
-    // Clip is in a group
-    QList<QTreeWidgetItem *> groupList = listView->findItems(groupName, Qt::MatchExactly, 1);
-
-    if (groupList.isEmpty())  {
-       QStringList itemName;
-       itemName<<QString::null<<groupName;
-       kDebug()<<"-------  CREATING NEW GRP: "<<itemName;
-       groupItem = new ProjectItem(listView, itemName, m_clipIdCounter++);
-    }
-    else groupItem = (ProjectItem *) groupList.first();
-  }
-  if (groupItem) item = new ProjectItem(groupItem, name, elem, clipId);
-  else item = new ProjectItem(listView, name, elem, clipId);
-  if (!url.isEmpty()) {
-    // if file has Nepomuk comment, use it
-    Nepomuk::Resource f( url.path() );
-    QString annotation = f.description();
-    if (!annotation.isEmpty()) item->setText(2, annotation);
-    QString resource = url.path();
-    if (resource.endsWith("westley") || resource.endsWith("kdenlive")) {
-       QString tmpfile;
-       QDomDocument doc;
-       if (KIO::NetAccess::download(url, tmpfile, 0)) {
-           QFile file(tmpfile);
-           if (file.open(QIODevice::ReadOnly)) {
-             doc.setContent(&file, false);
-             file.close();
-           }
-           KIO::NetAccess::removeTempFile(tmpfile);
-
-           QDomNodeList subProds = doc.elementsByTagName("producer");
-           int ct = subProds.count();
-           for (int i = 0; i <  ct ; i++)
-           {
-             QDomElement e = subProds.item(i).toElement();
-             if (!e.isNull()) {
-               addProducer(e, clipId);
-             }
-           }  
-         }
+
+    if (parentId != -1) {
+        groupItem = getItemById(parentId);
+    } else if (!groupName.isEmpty()) {
+        // Clip is in a group
+        QList<QTreeWidgetItem *> groupList = listView->findItems(groupName, Qt::MatchExactly, 1);
+
+        if (groupList.isEmpty())  {
+            QStringList itemName;
+            itemName << QString::null << groupName;
+            kDebug() << "-------  CREATING NEW GRP: " << itemName;
+            groupItem = new ProjectItem(listView, itemName, m_clipIdCounter++);
+        } else groupItem = (ProjectItem *) groupList.first();
     }
+    if (groupItem) item = new ProjectItem(groupItem, name, elem, clipId);
+    else item = new ProjectItem(listView, name, elem, clipId);
+    if (!url.isEmpty()) {
+        // if file has Nepomuk comment, use it
+        Nepomuk::Resource f(url.path());
+        QString annotation = f.description();
+        if (!annotation.isEmpty()) item->setText(2, annotation);
+        QString resource = url.path();
+        if (resource.endsWith("westley") || resource.endsWith("kdenlive")) {
+            QString tmpfile;
+            QDomDocument doc;
+            if (KIO::NetAccess::download(url, tmpfile, 0)) {
+                QFile file(tmpfile);
+                if (file.open(QIODevice::ReadOnly)) {
+                    doc.setContent(&file, false);
+                    file.close();
+                }
+                KIO::NetAccess::removeTempFile(tmpfile);
+
+                QDomNodeList subProds = doc.elementsByTagName("producer");
+                int ct = subProds.count();
+                for (int i = 0; i <  ct ; i++) {
+                    QDomElement e = subProds.item(i).toElement();
+                    if (!e.isNull()) {
+                        addProducer(e, clipId);
+                    }
+                }
+            }
+        }
 
-  }
+    }
 
-  if (elem.isNull() ) {
-    QDomDocument doc;
-    QDomElement element = doc.createElement("producer");
-    element.setAttribute("resource", url.path());
-    emit getFileProperties(element, clipId);
-  }
-  else emit getFileProperties(elem, clipId);
-  selectItemById(clipId);
+    if (elem.isNull()) {
+        QDomDocument doc;
+        QDomElement element = doc.createElement("producer");
+        element.setAttribute("resource", url.path());
+        emit getFileProperties(element, clipId);
+    } else emit getFileProperties(elem, clipId);
+    selectItemById(clipId);
 }
 
-void ProjectList::slotDeleteClip( int clipId)
-{
-  ProjectItem *item = getItemById(clipId);
-  if (item) delete item;
+void ProjectList::slotDeleteClip(int clipId) {
+    ProjectItem *item = getItemById(clipId);
+    if (item) delete item;
 }
 
-void ProjectList::slotAddFolder()
-{
-/*
-  QString folderName = KInputDialog::getText(i18n("New Folder"), i18n("Enter new folder name: "));
-  if (folderName.isEmpty()) return;
-  QStringList itemEntry;
-  itemEntry.append(QString::null);
-  itemEntry.append(folderName);
-  AddClipCommand *command = new AddClipCommand(this, itemEntry, QDomElement(), m_clipIdCounter++, KUrl(), folderName, true);
-  m_commandStack->push(command);*/
+void ProjectList::slotAddFolder() {
+    /*
+      QString folderName = KInputDialog::getText(i18n("New Folder"), i18n("Enter new folder name: "));
+      if (folderName.isEmpty()) return;
+      QStringList itemEntry;
+      itemEntry.append(QString::null);
+      itemEntry.append(folderName);
+      AddClipCommand *command = new AddClipCommand(this, itemEntry, QDomElement(), m_clipIdCounter++, KUrl(), folderName, true);
+      m_commandStack->push(command);*/
 }
 
-void ProjectList::slotAddClip(DocClipBase *clip)
-{
-  ProjectItem *item = new ProjectItem(listView, clip);
-  listView->setCurrentItem(item);
-  emit getFileProperties(clip->toXML(), clip->getId());
+void ProjectList::slotAddClip(DocClipBase *clip) {
+    ProjectItem *item = new ProjectItem(listView, clip);
+    listView->setCurrentItem(item);
+    emit getFileProperties(clip->toXML(), clip->getId());
 }
 
-void ProjectList::slotUpdateClip(int id)
-{
-  ProjectItem *item = getItemById(id);
-  item->setData(1, UsageRole, QString::number(item->numReferences()));
+void ProjectList::slotUpdateClip(int id) {
+    ProjectItem *item = getItemById(id);
+    item->setData(1, UsageRole, QString::number(item->numReferences()));
 }
 
-void ProjectList::slotAddClip(QUrl givenUrl, const QString &group)
-{
-  if (!m_commandStack) kDebug()<<"!!!!!!!!!!!!!!!!  NO CMD STK";
-  KUrl::List list;
-  if (givenUrl.isEmpty())
-         list = KFileDialog::getOpenUrls( KUrl(), "application/vnd.kde.kdenlive application/vnd.westley.scenelist application/flv application/vnd.rn-realmedia video/x-dv video/x-msvideo video/mpeg video/x-ms-wmv audio/mpeg audio/x-mp3 audio/x-wav application/ogg *.m2t *.dv video/mp4 video/quicktime image/gif image/jpeg image/png image/x-bmp image/svg+xml image/tiff image/x-xcf-gimp image/x-vnd.adobe.photoshop image/x-pcx image/x-exr");
-  else list.append(givenUrl);
-  if (list.isEmpty()) return;
-  KUrl::List::Iterator it;
-
-  for (it = list.begin(); it != list.end(); it++) {
-      m_doc->slotAddClipFile(*it, group);
-  }
+void ProjectList::slotAddClip(QUrl givenUrl, const QString &group) {
+    if (!m_commandStack) kDebug() << "!!!!!!!!!!!!!!!!  NO CMD STK";
+    KUrl::List list;
+    if (givenUrl.isEmpty())
+        list = KFileDialog::getOpenUrls(KUrl(), "application/vnd.kde.kdenlive application/vnd.westley.scenelist application/flv application/vnd.rn-realmedia video/x-dv video/x-msvideo video/mpeg video/x-ms-wmv audio/mpeg audio/x-mp3 audio/x-wav application/ogg *.m2t *.dv video/mp4 video/quicktime image/gif image/jpeg image/png image/x-bmp image/svg+xml image/tiff image/x-xcf-gimp image/x-vnd.adobe.photoshop image/x-pcx image/x-exr");
+    else list.append(givenUrl);
+    if (list.isEmpty()) return;
+    KUrl::List::Iterator it;
+
+    for (it = list.begin(); it != list.end(); it++) {
+        m_doc->slotAddClipFile(*it, group);
+    }
 }
 
-void ProjectList::slotAddColorClip()
-{
-  if (!m_commandStack) kDebug()<<"!!!!!!!!!!!!!!!!  NO CMD STK";
-  QDialog *dia = new QDialog;
-  Ui::ColorClip_UI *dia_ui = new Ui::ColorClip_UI();
-  dia_ui->setupUi(dia);
-  dia_ui->clip_name->setText(i18n("Color Clip"));
-  dia_ui->clip_duration->setText(KdenliveSettings::color_duration());
-  if (dia->exec() == QDialog::Accepted)
-  {
-    QString color = dia_ui->clip_color->color().name();
-    color = color.replace(0, 1, "0x") + "ff";
-    m_doc->slotAddColorClipFile(dia_ui->clip_name->text(), color, dia_ui->clip_duration->text(), QString::null);
-  }
-  delete dia_ui;
-  delete dia;
+void ProjectList::slotAddColorClip() {
+    if (!m_commandStack) kDebug() << "!!!!!!!!!!!!!!!!  NO CMD STK";
+    QDialog *dia = new QDialog;
+    Ui::ColorClip_UI *dia_ui = new Ui::ColorClip_UI();
+    dia_ui->setupUi(dia);
+    dia_ui->clip_name->setText(i18n("Color Clip"));
+    dia_ui->clip_duration->setText(KdenliveSettings::color_duration());
+    if (dia->exec() == QDialog::Accepted) {
+        QString color = dia_ui->clip_color->color().name();
+        color = color.replace(0, 1, "0x") + "ff";
+        m_doc->slotAddColorClipFile(dia_ui->clip_name->text(), color, dia_ui->clip_duration->text(), QString::null);
+    }
+    delete dia_ui;
+    delete dia;
 }
 
-void ProjectList::slotAddTitleClip()
-{
-
-       if (!m_commandStack) kDebug()<<"!!!!!!!!!!!!!!!!  NO CMD STK";
-       //QDialog *dia = new QDialog;
-       
-       TitleWidget *dia_ui = new TitleWidget();
-       //dia_ui->setupUi(dia);
-       //dia_ui->clip_name->setText(i18n("Title Clip"));
-       //dia_ui->clip_duration->setText(KdenliveSettings::color_duration());
-       if (dia_ui->exec() == QDialog::Accepted)
-       {
-               //QString color = dia_ui->clip_color->color().name();
-               //color = color.replace(0, 1, "0x") + "ff";
-               //m_doc->slotAddColorClipFile(dia_ui->clip_name->text(), color, dia_ui->clip_duration->text(), QString::null);
-       }
-       delete dia_ui;
-       //delete dia;
+void ProjectList::slotAddTitleClip() {
+
+    if (!m_commandStack) kDebug() << "!!!!!!!!!!!!!!!!  NO CMD STK";
+    //QDialog *dia = new QDialog;
+
+    TitleWidget *dia_ui = new TitleWidget();
+    //dia_ui->setupUi(dia);
+    //dia_ui->clip_name->setText(i18n("Title Clip"));
+    //dia_ui->clip_duration->setText(KdenliveSettings::color_duration());
+    if (dia_ui->exec() == QDialog::Accepted) {
+        //QString color = dia_ui->clip_color->color().name();
+        //color = color.replace(0, 1, "0x") + "ff";
+        //m_doc->slotAddColorClipFile(dia_ui->clip_name->text(), color, dia_ui->clip_duration->text(), QString::null);
+    }
+    delete dia_ui;
+    //delete dia;
 }
-void ProjectList::setDocument(KdenliveDoc *doc)
-{
-  m_fps = doc->fps();
-  m_timecode = doc->timecode();
-  m_commandStack = doc->commandStack();
-  m_doc = doc;
-  QDomNodeList prods = doc->producersList();
-  int ct = prods.count();
-  kDebug()<<"////////////  SETTING DOC, FOUND CLIPS: "<<prods.count();
-  listView->clear();
-  for (int i = 0; i <  ct ; i++)
-  {
-    QDomElement e = prods.item(i).toElement();
-    kDebug()<<"// IMPORT: "<<i<<", :"<<e.attribute("id", "non")<<", NAME: "<<e.attribute("name", "non");
-    if (!e.isNull()) addProducer(e);
-  }
-  QTreeWidgetItem *first = listView->topLevelItem(0);
-  if (first) listView->setCurrentItem(first);
-  m_toolbar->setEnabled(true);
+void ProjectList::setDocument(KdenliveDoc *doc) {
+    m_fps = doc->fps();
+    m_timecode = doc->timecode();
+    m_commandStack = doc->commandStack();
+    m_doc = doc;
+    QDomNodeList prods = doc->producersList();
+    int ct = prods.count();
+    kDebug() << "////////////  SETTING DOC, FOUND CLIPS: " << prods.count();
+    listView->clear();
+    for (int i = 0; i <  ct ; i++) {
+        QDomElement e = prods.item(i).toElement();
+        kDebug() << "// IMPORT: " << i << ", :" << e.attribute("id", "non") << ", NAME: " << e.attribute("name", "non");
+        if (!e.isNull()) addProducer(e);
+    }
+    QTreeWidgetItem *first = listView->topLevelItem(0);
+    if (first) listView->setCurrentItem(first);
+    m_toolbar->setEnabled(true);
 }
 
-QDomElement ProjectList::producersList()
-{
-  QDomDocument doc;
-  QDomElement prods = doc.createElement("producerlist");
-  doc.appendChild(prods);
-  kDebug()<<"////////////  PRO LIST BUILD PRDSLIST ";
+QDomElement ProjectList::producersList() {
+    QDomDocument doc;
+    QDomElement prods = doc.createElement("producerlist");
+    doc.appendChild(prods);
+    kDebug() << "////////////  PRO LIST BUILD PRDSLIST ";
     QTreeWidgetItemIterator it(listView);
-     while (*it) {
-         if (!((ProjectItem *)(*it))->isGroup())
-         prods.appendChild(doc.importNode(((ProjectItem *)(*it))->toXml(), true));
-         ++it;
-     }
-  return prods;
+    while (*it) {
+        if (!((ProjectItem *)(*it))->isGroup())
+            prods.appendChild(doc.importNode(((ProjectItem *)(*it))->toXml(), true));
+        ++it;
+    }
+    return prods;
 }
 
 
-void ProjectList::slotReplyGetFileProperties(int clipId, const QMap < QString, QString > &properties, const QMap < QString, QString > &metadata)
-{
-  ProjectItem *item = getItemById(clipId);
-  if (item) {
-    item->setProperties(properties, metadata);
-    emit receivedClipDuration(clipId, item->clipMaxDuration());
-  }
+void ProjectList::slotReplyGetFileProperties(int clipId, const QMap < QString, QString > &properties, const QMap < QString, QString > &metadata) {
+    ProjectItem *item = getItemById(clipId);
+    if (item) {
+        item->setProperties(properties, metadata);
+        emit receivedClipDuration(clipId, item->clipMaxDuration());
+    }
 }
 
 
 
-void ProjectList::slotReplyGetImage(int clipId, int pos, const QPixmap &pix, int w, int h)
-{
-  ProjectItem *item = getItemById(clipId);
-  if (item) item->setIcon(0, pix);
+void ProjectList::slotReplyGetImage(int clipId, int pos, const QPixmap &pix, int w, int h) {
+    ProjectItem *item = getItemById(clipId);
+    if (item) item->setIcon(0, pix);
 }
 
-ProjectItem *ProjectList::getItemById(int id)
-{
+ProjectItem *ProjectList::getItemById(int id) {
     QTreeWidgetItemIterator it(listView);
-     while (*it) {
-         if (((ProjectItem *)(*it))->clipId() == id)
-         break;
-         ++it;
-     }
-  return ((ProjectItem *)(*it));
+    while (*it) {
+        if (((ProjectItem *)(*it))->clipId() == id)
+            break;
+        ++it;
+    }
+    return ((ProjectItem *)(*it));
 }
 
 
-void ProjectList::addProducer(QDomElement producer, int parentId)
-{
-  if (!m_commandStack) kDebug()<<"!!!!!!!!!!!!!!!!  NO CMD STK";
-  CLIPTYPE type = (CLIPTYPE) producer.attribute("type").toInt();
+void ProjectList::addProducer(QDomElement producer, int parentId) {
+    if (!m_commandStack) kDebug() << "!!!!!!!!!!!!!!!!  NO CMD STK";
+    CLIPTYPE type = (CLIPTYPE) producer.attribute("type").toInt();
 
     /*QDomDocument doc;
     QDomElement prods = doc.createElement("list");
     doc.appendChild(prods);
     prods.appendChild(doc.importNode(producer, true));*/
-    
-
-  //kDebug()<<"//////  ADDING PRODUCER:\n "<<doc.toString()<<"\n+++++++++++++++++";
-  int id = producer.attribute("id").toInt();
-  QString groupName = producer.attribute("group");
-  if (id >= m_clipIdCounter) m_clipIdCounter = id + 1;
-  else if (id == 0) id = m_clipIdCounter++;
-
-  if (parentId != -1) {
-    // item is a westley playlist, adjust subproducers ids 
-    id = (parentId + 1) * 10000 + id;
-  }
-  if (type == AUDIO || type == VIDEO || type == AV || type == IMAGE  || type == PLAYLIST)
-  {
-    KUrl resource = KUrl(producer.attribute("resource"));
-    if (!resource.isEmpty()) {
-      QStringList itemEntry;
-      itemEntry.append(QString::null);
-      itemEntry.append(resource.fileName());
-      addClip(itemEntry, producer, id, resource, groupName, parentId);  
+
+
+    //kDebug()<<"//////  ADDING PRODUCER:\n "<<doc.toString()<<"\n+++++++++++++++++";
+    int id = producer.attribute("id").toInt();
+    QString groupName = producer.attribute("group");
+    if (id >= m_clipIdCounter) m_clipIdCounter = id + 1;
+    else if (id == 0) id = m_clipIdCounter++;
+
+    if (parentId != -1) {
+        // item is a westley playlist, adjust subproducers ids
+        id = (parentId + 1) * 10000 + id;
+    }
+    if (type == AUDIO || type == VIDEO || type == AV || type == IMAGE  || type == PLAYLIST) {
+        KUrl resource = KUrl(producer.attribute("resource"));
+        if (!resource.isEmpty()) {
+            QStringList itemEntry;
+            itemEntry.append(QString::null);
+            itemEntry.append(resource.fileName());
+            addClip(itemEntry, producer, id, resource, groupName, parentId);
+        }
+    } else if (type == COLOR) {
+        QString colour = producer.attribute("colour");
+        QPixmap pix(60, 40);
+        colour = colour.replace(0, 2, "#");
+        pix.fill(QColor(colour.left(7)));
+        QStringList itemEntry;
+        itemEntry.append(QString::null);
+        itemEntry.append(producer.attribute("name", i18n("Color clip")));
+        addClip(itemEntry, producer, id, KUrl(), groupName, parentId);
     }
-  }
-  else if (type == COLOR) {
-    QString colour = producer.attribute("colour");
-    QPixmap pix(60, 40);
-    colour = colour.replace(0, 2, "#");
-    pix.fill(QColor(colour.left(7)));
-    QStringList itemEntry;
-    itemEntry.append(QString::null);
-    itemEntry.append(producer.attribute("name", i18n("Color clip")));
-    addClip(itemEntry, producer, id, KUrl(), groupName, parentId);
-  }
-      
+
 }
 
 #include "projectlist.moc"