--- qsampler/trunk/src/qsamplerOptions.cpp 2015/01/18 20:25:22 2712 +++ qsampler/trunk/src/qsamplerOptions.cpp 2019/07/01 10:53:41 3520 @@ -1,8 +1,8 @@ // qsamplerOptions.cpp // /**************************************************************************** - Copyright (C) 2004-2014, rncbc aka Rui Nuno Capela. All rights reserved. - Copyright (C) 2007, Christian Schoenebeck + Copyright (C) 2004-2019, rncbc aka Rui Nuno Capela. All rights reserved. + Copyright (C) 2007,2008,2015 Christian Schoenebeck This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License @@ -97,6 +97,9 @@ bMessagesLimit = m_settings.value("/MessagesLimit", true).toBool(); iMessagesLimitLines = m_settings.value("/MessagesLimitLines", 1000).toInt(); bConfirmRemove = m_settings.value("/ConfirmRemove", true).toBool(); + bConfirmReset = m_settings.value("/ConfirmReset", true).toBool(); + bConfirmRestart = m_settings.value("/ConfirmRestart", true).toBool(); + bConfirmError = m_settings.value("/ConfirmError", true).toBool(); bKeepOnTop = m_settings.value("/KeepOnTop", true).toBool(); bStdoutCapture = m_settings.value("/StdoutCapture", true).toBool(); bCompletePath = m_settings.value("/CompletePath", true).toBool(); @@ -159,7 +162,7 @@ { // Make program version available in the future. m_settings.beginGroup("/Program"); - m_settings.setValue("/Version", QSAMPLER_VERSION); + m_settings.setValue("/Version", CONFIG_BUILD_VERSION); m_settings.endGroup(); // And go into general options group. @@ -192,6 +195,9 @@ m_settings.setValue("/MessagesLimit", bMessagesLimit); m_settings.setValue("/MessagesLimitLines", iMessagesLimitLines); m_settings.setValue("/ConfirmRemove", bConfirmRemove); + m_settings.setValue("/ConfirmReset", bConfirmReset); + m_settings.setValue("/ConfirmRestart", bConfirmRestart); + m_settings.setValue("/ConfirmError", bConfirmError); m_settings.setValue("/KeepOnTop", bKeepOnTop); m_settings.setValue("/StdoutCapture", bStdoutCapture); m_settings.setValue("/CompletePath", bCompletePath); @@ -293,7 +299,7 @@ } QString sArg = args.at(i); - QString sVal = QString::null; + QString sVal; const int iEqual = sArg.indexOf("="); if (iEqual >= 0) { sVal = sArg.right(sArg.length() - iEqual - 1); @@ -331,7 +337,11 @@ return false; } else if (sArg == "-v" || sArg == "--version") { - out << QObject::tr("Qt: %1\n").arg(qVersion()); + out << QString("Qt: %1\n") + .arg(qVersion()); + out << QString("%1: %2\n") + .arg(QSAMPLER_TITLE) + .arg(CONFIG_BUILD_VERSION); #ifdef CONFIG_LIBGIG out << QString("%1: %2\n") .arg(gig::libraryName().c_str()) @@ -340,7 +350,6 @@ out << QString("%1: %2\n") .arg(::lscp_client_package()) .arg(::lscp_client_version()); - out << QObject::tr(QSAMPLER_TITLE ": %1\n").arg(QSAMPLER_VERSION); return false; } else { @@ -363,25 +372,34 @@ { // Try to restore old form window positioning. if (pWidget) { + // if (bVisible) pWidget->show(); -- force initial exposure? + m_settings.beginGroup("/Geometry/" + pWidget->objectName()); + #if QT_VERSION >= QT_VERSION_CHECK(5, 0, 0) + const QByteArray& geometry + = m_settings.value("/geometry").toByteArray(); + if (!geometry.isEmpty()) + pWidget->restoreGeometry(geometry); + #else//--LOAD_OLD_GEOMETRY QPoint wpos; QSize wsize; - m_settings.beginGroup("/Geometry/" + pWidget->objectName()); wpos.setX(m_settings.value("/x", -1).toInt()); wpos.setY(m_settings.value("/y", -1).toInt()); wsize.setWidth(m_settings.value("/width", -1).toInt()); wsize.setHeight(m_settings.value("/height", -1).toInt()); - if (!bVisible) bVisible = m_settings.value("/visible", false).toBool(); - m_settings.endGroup(); if (wpos.x() > 0 && wpos.y() > 0) pWidget->move(wpos); if (wsize.width() > 0 && wsize.height() > 0) pWidget->resize(wsize); + #endif // else - // pWidget->adjustSize(); + // pWidget->adjustSize(); + if (!bVisible) + bVisible = m_settings.value("/visible", false).toBool(); if (bVisible) pWidget->show(); - // else - // pWidget->hide(); + else + pWidget->hide(); + m_settings.endGroup(); } } @@ -393,13 +411,17 @@ // only save the form geometry while its up and visible) if (pWidget) { m_settings.beginGroup("/Geometry/" + pWidget->objectName()); + #if QT_VERSION >= QT_VERSION_CHECK(5, 0, 0) + m_settings.setValue("/geometry", pWidget->saveGeometry()); + #else//--SAVE_OLD_GEOMETRY const QPoint& wpos = pWidget->pos(); const QSize& wsize = pWidget->size(); - if (!bVisible) bVisible = pWidget->isVisible(); m_settings.setValue("/x", wpos.x()); m_settings.setValue("/y", wpos.y()); m_settings.setValue("/width", wsize.width()); m_settings.setValue("/height", wsize.height()); + #endif + if (!bVisible) bVisible = pWidget->isVisible(); m_settings.setValue("/visible", bVisible); m_settings.endGroup(); } @@ -411,6 +433,8 @@ void Options::loadComboBoxHistory ( QComboBox *pComboBox, int iLimit ) { + const bool bBlockSignals = pComboBox->blockSignals(true); + // Load combobox list from configuration settings file... m_settings.beginGroup("/History/" + pComboBox->objectName()); @@ -418,7 +442,7 @@ pComboBox->setUpdatesEnabled(false); pComboBox->setDuplicatesEnabled(false); pComboBox->clear(); - for (int i = 0; i < iLimit; i++) { + for (int i = 0; i < iLimit; ++i) { const QString& sText = m_settings.value( "/Item" + QString::number(i + 1)).toString(); if (sText.isEmpty()) @@ -429,38 +453,46 @@ } m_settings.endGroup(); + + pComboBox->blockSignals(bBlockSignals); } void Options::saveComboBoxHistory ( QComboBox *pComboBox, int iLimit ) { + const bool bBlockSignals = pComboBox->blockSignals(true); + // Add current text as latest item... - const QString& sCurrentText = pComboBox->currentText(); + const QString sCurrentText = pComboBox->currentText(); int iCount = pComboBox->count(); for (int i = 0; i < iCount; i++) { const QString& sText = pComboBox->itemText(i); if (sText == sCurrentText) { pComboBox->removeItem(i); - iCount--; + --iCount; break; } } while (iCount >= iLimit) pComboBox->removeItem(--iCount); pComboBox->insertItem(0, sCurrentText); - iCount++; + pComboBox->setCurrentIndex(0); + ++iCount; // Save combobox list to configuration settings file... m_settings.beginGroup("/History/" + pComboBox->objectName()); - for (int i = 0; i < iCount; i++) { + for (int i = 0; i < iCount; ++i) { const QString& sText = pComboBox->itemText(i); if (sText.isEmpty()) break; m_settings.setValue("/Item" + QString::number(i + 1), sText); } m_settings.endGroup(); + + pComboBox->blockSignals(bBlockSignals); } + int Options::getMaxVoices() { #ifndef CONFIG_MAX_VOICES return -1; @@ -558,3 +590,4 @@ // end of qsamplerOptions.cpp +