]> git.sesse.net Git - kdenlive/commitdiff
Store transcoding profiles in a separate file (kdenlivetranscodingrc)
authorJean-Baptiste Mardelle <jb@kdenlive.org>
Tue, 26 May 2009 13:49:03 +0000 (13:49 +0000)
committerJean-Baptiste Mardelle <jb@kdenlive.org>
Tue, 26 May 2009 13:49:03 +0000 (13:49 +0000)
svn path=/trunk/kdenlive/; revision=3428

src/CMakeLists.txt
src/cliptranscode.cpp
src/kdenlivesettingsdialog.cpp
src/kdenlivesettingsdialog.h
src/kdenlivetranscodingrc [new file with mode: 0644]
src/mainwindow.cpp

index 4d94d276a7e47c097470ea79c7917c125884ee3f..1d13e0b932cc4c94de7ffa5da24a2d5ed462fab0 100644 (file)
@@ -198,7 +198,7 @@ install( FILES kdenliveui.rc kdenlive.notifyrc DESTINATION  ${DATA_INSTALL_DIR}/
 install (FILES kdenlivesettings.kcfg DESTINATION ${KCFG_INSTALL_DIR})
 install (FILES kdenlive.desktop DESTINATION ${XDG_APPS_INSTALL_DIR})
 install (FILES application-x-kdenlive.svgz video-mlt-playlist.svgz DESTINATION ${ICON_INSTALL_DIR}/oxygen/scalable/mimetypes)
-install( FILES kdenlive.knsrc kdenlive_render.knsrc kdenlive_mltprofiles.knsrc DESTINATION  ${CONFIG_INSTALL_DIR} )
+install( FILES kdenlive.knsrc kdenlive_render.knsrc kdenlive_mltprofiles.knsrc kdenlivetranscodingrc DESTINATION  ${CONFIG_INSTALL_DIR} )
 kde4_install_icons( ${ICON_INSTALL_DIR} )
 
 
index adc8fe92ad3e908277f85eea24e7f128263c2879..e9ccc376c2211076579be27210edd84521ccf21b 100644 (file)
@@ -45,7 +45,7 @@ ClipTranscode::ClipTranscode(const KUrl &src, const QString &params, QWidget * p
         m_view.params->setPlainText(params.simplified());
     } else {
         // load Profiles
-        KSharedConfigPtr config = KGlobal::config();
+        KSharedConfigPtr config = KSharedConfig::openConfig("kdenlivetranscodingrc");
         KConfigGroup transConfig(config, "Transcoding");
         // read the entries
         QMap< QString, QString > profiles = transConfig.entryMap();
index 7cd86aad91142f1d989cffcdfbb15a1d55addb88..add9a255109da9d466a44ea8373547c360c849b8 100644 (file)
@@ -27,6 +27,7 @@
 #include <KConfigDialogManager>
 #include <kde_file.h>
 #include <KIO/NetAccess>
+#include <kdeversion.h>
 
 #include <QDir>
 #include <QTimer>
@@ -42,7 +43,8 @@
 
 
 KdenliveSettingsDialog::KdenliveSettingsDialog(QWidget * parent) :
-        KConfigDialog(parent, "settings", KdenliveSettings::self())
+        KConfigDialog(parent, "settings", KdenliveSettings::self()),
+        m_modified(false)
 {
 
     QWidget *p1 = new QWidget;
@@ -96,6 +98,7 @@ KdenliveSettingsDialog::KdenliveSettingsDialog(QWidget * parent) :
     m_page7 = addPage(p7, i18n("Transcode"), "edit-copy");
     connect(m_configTranscode.button_add, SIGNAL(clicked()), this, SLOT(slotAddTranscode()));
     connect(m_configTranscode.button_delete, SIGNAL(clicked()), this, SLOT(slotDeleteTranscode()));
+    connect(m_configTranscode.profiles_list, SIGNAL(itemChanged(QTreeWidgetItem *, int)), this, SLOT(slotDialogModified()));
 
     QStringList actions;
     actions << i18n("Do nothing");
@@ -391,7 +394,8 @@ void KdenliveSettingsDialog::rebuildVideo4Commands()
 
 void KdenliveSettingsDialog::updateSettings()
 {
-    kDebug() << "// // // KCONFIG UPDATE called";
+    //kDebug() << "// // // KCONFIG UPDATE called";
+
     m_defaultProfile = m_configMisc.kcfg_profiles_list->currentText();
     KdenliveSettings::setDefault_profile(m_defaultPath);
 
@@ -445,10 +449,17 @@ void KdenliveSettingsDialog::updateSettings()
         updatePreview = true;
     }
 
-    // TODO: only save profiles if modified
-    saveTranscodeProfiles();
+    if (m_modified) {
+        // The transcoding profiles were modified, save.
+        m_modified = false;
+        saveTranscodeProfiles();
+    }
+
+#if KDE_IS_VERSION(4,3,0)
+    KConfigDialog::settingsChangedSlot();
+#endif
 
-    KConfigDialog::updateSettings();
+    //KConfigDialog::updateSettings();
     if (resetProfile) emit doResetProfile();
     if (updatePreview) emit updatePreviewSettings();
 }
@@ -475,26 +486,24 @@ void KdenliveSettingsDialog::slotCheckAlsaDriver()
 
 void KdenliveSettingsDialog::loadTranscodeProfiles()
 {
-    KSharedConfigPtr config = KGlobal::config();
+    KSharedConfigPtr config = KSharedConfig::openConfig("kdenlivetranscodingrc");
     KConfigGroup transConfig(config, "Transcoding");
     // read the entries
-
+    m_configTranscode.profiles_list->blockSignals(true);
     QMap< QString, QString > profiles = transConfig.entryMap();
-    if (profiles.isEmpty()) {
-        // TODO: find a better way to store defaule transcode profiles
-        profiles.insert("DNxHD 1920x1080", "-s 1920x1080 -r pal -b 220000k -threads 2 -vcodec dnxhd -acodec copy %1.mov");
-    }
     QMapIterator<QString, QString> i(profiles);
     while (i.hasNext()) {
         i.next();
         QTreeWidgetItem *item = new QTreeWidgetItem(m_configTranscode.profiles_list, QStringList() << i.key() << i.value());
         item->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsEditable);
     }
+    m_configTranscode.profiles_list->blockSignals(false);
 }
 
 void KdenliveSettingsDialog::saveTranscodeProfiles()
 {
-    KSharedConfigPtr config = KGlobal::config();
+    KSharedConfigPtr config = KSharedConfig::openConfig("kdenlivetranscodingrc");
+    //KSharedConfigPtr config = KGlobal::config();
     KConfigGroup transConfig(config, "Transcoding");
     // read the entries
     transConfig.deleteGroup();
@@ -510,7 +519,9 @@ void KdenliveSettingsDialog::slotAddTranscode()
 {
     QTreeWidgetItem *item = new QTreeWidgetItem(m_configTranscode.profiles_list, QStringList() << i18n("Name") << i18n("Parameters"));
     item->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsEditable);
+    m_configTranscode.profiles_list->setCurrentItem(item);
     m_configTranscode.profiles_list->editItem(item);
+    slotDialogModified();
 }
 
 void KdenliveSettingsDialog::slotDeleteTranscode()
@@ -518,8 +529,26 @@ void KdenliveSettingsDialog::slotDeleteTranscode()
     QTreeWidgetItem *item = m_configTranscode.profiles_list->currentItem();
     if (item == NULL) return;
     delete item;
+    slotDialogModified();
 }
 
+void KdenliveSettingsDialog::slotDialogModified()
+{
+    m_modified = true;
+#if KDE_IS_VERSION(4,3,0)
+    KConfigDialog::updateButtons();
+#endif
+}
+
+//virtual
+bool KdenliveSettingsDialog::hasChanged()
+{
+    if (m_modified) return true;
+    return KConfigDialog::hasChanged();
+}
+
+
+
 #include "kdenlivesettingsdialog.moc"
 
 
index 3266c98faee7a5d651de8052e5c8de9301650d5f..971036111294fbfd9312f070a99e25c367b600bc 100644 (file)
@@ -46,7 +46,7 @@ public:
 
 protected slots:
     void updateSettings();
-
+    virtual bool hasChanged();
 
 private slots:
     void slotUpdateDisplay();
@@ -63,6 +63,7 @@ private slots:
     void slotCheckAlsaDriver();
     void slotAddTranscode();
     void slotDeleteTranscode();
+    void slotDialogModified();
 
 private:
     KPageWidgetItem *m_page1;
@@ -82,6 +83,7 @@ private:
     QString m_defaultProfile;
     QString m_defaultPath;
     KProcess m_readProcess;
+    bool m_modified;
     void initDevices();
     void loadTranscodeProfiles();
     void saveTranscodeProfiles();
diff --git a/src/kdenlivetranscodingrc b/src/kdenlivetranscodingrc
new file mode 100644 (file)
index 0000000..5159490
--- /dev/null
@@ -0,0 +1,2 @@
+[Transcoding]
+DNxHD 1920x1080=-s 1920x1080 -r pal -b 220000k -threads 2 -vcodec dnxhd -acodec copy %1.mov
index 7975f0a921ba3bbc42d449a12f3cc461ecff45ca..59fbf3e847ab758926e96b650eb23bb365856770 100644 (file)
@@ -1943,6 +1943,9 @@ void MainWindow::updateConfiguration()
     }
     m_buttonAudioThumbs->setChecked(KdenliveSettings::audiothumbnails());
     m_buttonVideoThumbs->setChecked(KdenliveSettings::videothumbnails());
+
+    // Update list of transcoding profiles
+    loadTranscoders();
 #ifndef NO_JOGSHUTTLE
     activateShuttleDevice();
 #endif /* NO_JOGSHUTTLE */
@@ -2661,7 +2664,8 @@ void MainWindow::loadTranscoders()
 {
     QMenu *transMenu = static_cast<QMenu*>(factory()->container("transcoders", this));
     transMenu->clear();
-    KSharedConfigPtr config = KGlobal::config();
+
+    KSharedConfigPtr config = KSharedConfig::openConfig("kdenlivetranscodingrc");
     KConfigGroup transConfig(config, "Transcoding");
     // read the entries
     QMap< QString, QString > profiles = transConfig.entryMap();