mirror of
https://bitbucket.org/librepilot/librepilot.git
synced 2025-01-18 03:52:11 +01:00
OP-99 Import/Export: Prepare for version compatibility.
git-svn-id: svn://svn.openpilot.org/OpenPilot/trunk@1598 ebee16cc-31ac-478f-84a7-5cbb03baadba
This commit is contained in:
parent
ba34bb8c24
commit
ddf6ee46ee
@ -61,7 +61,8 @@ SOURCES += mainwindow.cpp \
|
||||
uavgadgetinstancemanager.cpp \
|
||||
uavgadgetoptionspagedecorator.cpp \
|
||||
uavgadgetdecorator.cpp \
|
||||
workspacesettings.cpp
|
||||
workspacesettings.cpp \
|
||||
uavconfiginfo.cpp
|
||||
HEADERS += mainwindow.h \
|
||||
tabpositionindicator.h \
|
||||
fancyactionbar.h \
|
||||
@ -119,7 +120,8 @@ HEADERS += mainwindow.h \
|
||||
uavgadgetinstancemanager.h \
|
||||
uavgadgetoptionspagedecorator.h \
|
||||
uavgadgetdecorator.h \
|
||||
workspacesettings.h
|
||||
workspacesettings.h \
|
||||
uavconfiginfo.h
|
||||
FORMS += dialogs/settingsdialog.ui \
|
||||
dialogs/shortcutsettings.ui \
|
||||
generalsettings.ui \
|
||||
|
186
ground/src/plugins/coreplugin/uavconfiginfo.cpp
Normal file
186
ground/src/plugins/coreplugin/uavconfiginfo.cpp
Normal file
@ -0,0 +1,186 @@
|
||||
/**
|
||||
******************************************************************************
|
||||
*
|
||||
* @file uavconfiginfo.cpp
|
||||
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||
* @addtogroup GCSPlugins GCS Plugins
|
||||
* @{
|
||||
* @addtogroup CorePlugin Core Plugin
|
||||
* @{
|
||||
* @brief The Core GCS plugin
|
||||
*****************************************************************************/
|
||||
/*
|
||||
* 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 3 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 "uavconfiginfo.h"
|
||||
#include <QMessageBox>
|
||||
|
||||
#define VERSION_DEFAULT "0.0.0"
|
||||
|
||||
#define TEXT_MINOR_LOSS_OF_CONFIGURATION tr( \
|
||||
" Some of the configured features might not be supported \
|
||||
by your version of the plugin. You might want to upgrade the plugin.")
|
||||
|
||||
#define TEXT_MISSING_CONFIGURATION tr( \
|
||||
" Some configuration is missing in the imported config and will be replaced \
|
||||
by default settings. It's probably an old config.")
|
||||
|
||||
#define TEXT_MAJOR_LOSS_OF_CONFIGURATION tr( \
|
||||
" Major features can't be imported \
|
||||
by your version of the plugin. You should upgrade the plugin to import these settings.")
|
||||
|
||||
#define TEXT_NOT_COMPATIBLE tr( \
|
||||
" The imported settings are not compatible with this plugin and won't be imported!")
|
||||
|
||||
using namespace Core;
|
||||
|
||||
UAVConfigInfo::UAVConfigInfo(QSettings *qs, QObject *parent) :
|
||||
QObject(parent),
|
||||
m_version(VERSION_DEFAULT)
|
||||
{
|
||||
qs->beginGroup("configInfo");
|
||||
m_version = UAVConfigVersion( qs->value("version", VERSION_DEFAULT ).toString());
|
||||
qs->endGroup();
|
||||
}
|
||||
|
||||
UAVConfigInfo::UAVConfigInfo(UAVConfigVersion version, QString nameOfConfigurable, QObject *parent) :
|
||||
QObject(parent),
|
||||
m_version(version),
|
||||
m_nameOfConfigurable(nameOfConfigurable)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
void UAVConfigInfo::save(QSettings *qs)
|
||||
{
|
||||
qs->beginGroup("configInfo");
|
||||
qs->setValue("version", m_version.toString());
|
||||
qs->endGroup();
|
||||
}
|
||||
|
||||
bool UAVConfigInfo::askToAbort(int compat, QString message)
|
||||
{
|
||||
QMessageBox msgBox;
|
||||
msgBox.setInformativeText(tr("Do you want to continue the import?"));
|
||||
msgBox.setStandardButtons(QMessageBox::Ok | QMessageBox::Cancel);
|
||||
|
||||
int result;
|
||||
|
||||
switch(compat){
|
||||
|
||||
case FullyCompatible:
|
||||
return false;
|
||||
|
||||
case MinorLossOfConfiguration:
|
||||
msgBox.setText(tr("INFO: ") + message + TEXT_MINOR_LOSS_OF_CONFIGURATION);
|
||||
msgBox.setDefaultButton(QMessageBox::Ok);
|
||||
result = msgBox.exec();
|
||||
break;
|
||||
|
||||
case MissingConfiguration:
|
||||
msgBox.setText(tr("WARNING: ") + message + TEXT_MISSING_CONFIGURATION);
|
||||
msgBox.setDefaultButton(QMessageBox::Ok);
|
||||
result = msgBox.exec();
|
||||
break;
|
||||
|
||||
case MajorLossOfConfiguration:
|
||||
msgBox.setText(tr("ERROR: ") + message + TEXT_MAJOR_LOSS_OF_CONFIGURATION);
|
||||
msgBox.setDefaultButton(QMessageBox::Cancel);
|
||||
result = msgBox.exec();
|
||||
break;
|
||||
|
||||
case NotCompatible:
|
||||
msgBox.setText("ERROR: " + message + TEXT_NOT_COMPATIBLE);
|
||||
msgBox.setStandardButtons(QMessageBox::Ok);
|
||||
msgBox.exec();
|
||||
return true;
|
||||
|
||||
default:
|
||||
msgBox.setText("INTERNAL ERROR: " + message + tr("Unknown compatibility level: " + compat));
|
||||
}
|
||||
if ( result == QMessageBox::Ok )
|
||||
return false;
|
||||
else
|
||||
return true;
|
||||
|
||||
}
|
||||
|
||||
void UAVConfigInfo::notifyAbort(QString message)
|
||||
{
|
||||
QMessageBox msgBox;
|
||||
msgBox.setText(message);
|
||||
msgBox.exec();
|
||||
}
|
||||
|
||||
int UAVConfigInfo::checkCompatibilityWith(UAVConfigVersion programVersion)
|
||||
{
|
||||
if ( m_version.majorNr != programVersion.majorNr )
|
||||
return NotCompatible;
|
||||
if ( m_version.minorNr < programVersion.minorNr )
|
||||
return MissingConfiguration;
|
||||
if ( m_version.minorNr > programVersion.minorNr )
|
||||
return MajorLossOfConfiguration;
|
||||
if ( m_version.patchNr > programVersion.patchNr )
|
||||
return MinorLossOfConfiguration;
|
||||
|
||||
return FullyCompatible;
|
||||
}
|
||||
|
||||
bool UAVConfigInfo::standardVersionHandlingIsNotOK(UAVConfigVersion programVersion)
|
||||
{
|
||||
return askToAbort(
|
||||
checkCompatibilityWith(programVersion),
|
||||
"("+m_nameOfConfigurable+")");
|
||||
}
|
||||
|
||||
UAVConfigVersion::UAVConfigVersion(int majorNum, int minorNum, int patchNum)
|
||||
:majorNr(majorNum)
|
||||
,minorNr(minorNum)
|
||||
,patchNr(patchNum)
|
||||
{
|
||||
}
|
||||
|
||||
UAVConfigVersion::UAVConfigVersion(QString versionString)
|
||||
{
|
||||
int begin;
|
||||
int end = 0;
|
||||
|
||||
begin = end;
|
||||
end = versionString.indexOf(".", begin);
|
||||
majorNr = versionString.mid(begin, end-begin).toInt();
|
||||
|
||||
begin = end+1;
|
||||
end = versionString.indexOf(".", begin);
|
||||
minorNr = versionString.mid(begin, end-begin).toInt();
|
||||
|
||||
begin = end+1;
|
||||
patchNr = versionString.mid(begin).toInt();
|
||||
}
|
||||
|
||||
QString UAVConfigVersion::toString() const
|
||||
{
|
||||
return QString("%1.%2.%3").arg(majorNr).arg(minorNr).arg(patchNr);
|
||||
}
|
||||
|
||||
bool UAVConfigVersion::operator==(const UAVConfigVersion &other)
|
||||
{
|
||||
return toString() == other.toString();
|
||||
}
|
||||
|
||||
/**
|
||||
* @}
|
||||
* @}
|
||||
*/
|
83
ground/src/plugins/coreplugin/uavconfiginfo.h
Normal file
83
ground/src/plugins/coreplugin/uavconfiginfo.h
Normal file
@ -0,0 +1,83 @@
|
||||
/**
|
||||
******************************************************************************
|
||||
*
|
||||
* @file uavconfiginfo.h
|
||||
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||
* @addtogroup GCSPlugins GCS Plugins
|
||||
* @{
|
||||
* @addtogroup CorePlugin Core Plugin
|
||||
* @{
|
||||
* @brief The Core GCS plugin
|
||||
*****************************************************************************/
|
||||
/*
|
||||
* 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 3 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
|
||||
*/
|
||||
#ifndef UAVCONFIGINFO_H
|
||||
#define UAVCONFIGINFO_H
|
||||
|
||||
#include <QObject>
|
||||
#include <QString>
|
||||
#include <QSettings>
|
||||
|
||||
namespace Core
|
||||
{
|
||||
|
||||
class UAVConfigVersion{
|
||||
public:
|
||||
UAVConfigVersion(QString versionString = "0.0.0");
|
||||
UAVConfigVersion(int major, int minor, int patch);
|
||||
|
||||
int majorNr;
|
||||
int minorNr;
|
||||
int patchNr;
|
||||
|
||||
QString toString() const;
|
||||
bool operator==(const UAVConfigVersion &other);
|
||||
};
|
||||
|
||||
class UAVConfigInfo : public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
|
||||
UAVConfigInfo(QSettings *qs, QObject *parent = 0);
|
||||
UAVConfigInfo(UAVConfigVersion version, QString nameOfConfigurable, QObject *parent = 0);
|
||||
|
||||
enum Compatibility { FullyCompatible, MinorLossOfConfiguration, MissingConfiguration, MajorLossOfConfiguration, NotCompatible };
|
||||
void setNameOfConfigurable(const QString nameOfConfigurable){m_nameOfConfigurable = nameOfConfigurable;}
|
||||
|
||||
void save(QSettings *qs);
|
||||
|
||||
void setVersion(int major, int minor, int patch){m_version = UAVConfigVersion(major, minor, patch);}
|
||||
void setVersion(const QString version){m_version = UAVConfigVersion(version);}
|
||||
UAVConfigVersion version(){ return m_version;}
|
||||
int checkCompatibilityWith(UAVConfigVersion programVersion);
|
||||
bool askToAbort(int compat, QString message);
|
||||
void notifyAbort(QString message);
|
||||
bool standardVersionHandlingIsNotOK(UAVConfigVersion programVersion);
|
||||
|
||||
signals:
|
||||
|
||||
public slots:
|
||||
|
||||
private:
|
||||
UAVConfigVersion m_version;
|
||||
QString m_nameOfConfigurable;
|
||||
|
||||
};
|
||||
|
||||
} // namespace Core
|
||||
|
||||
#endif // UAVCONFIGINFO_H
|
@ -45,7 +45,8 @@
|
||||
using namespace Core;
|
||||
|
||||
UAVGadgetInstanceManager::UAVGadgetInstanceManager(QObject *parent) :
|
||||
QObject(parent)
|
||||
QObject(parent),
|
||||
m_versionUAVGadgetConfigurations("1.0.0")
|
||||
{
|
||||
m_pm = ExtensionSystem::PluginManager::instance();
|
||||
QList<IUAVGadgetFactory*> factories = m_pm->getObjects<IUAVGadgetFactory>();
|
||||
@ -73,6 +74,24 @@ void UAVGadgetInstanceManager::readConfigurations(QSettings *qs)
|
||||
emit configurationToBeDeleted(m_configurations.takeLast());
|
||||
}
|
||||
qs->beginGroup("UAVGadgetConfigurations");
|
||||
UAVConfigInfo configInfo(qs);
|
||||
configInfo.setNameOfConfigurable("UAVGadgetConfigurations");
|
||||
if ( configInfo.version() == UAVConfigVersion() ){
|
||||
// If version is not set, assume its a old version before readable config.
|
||||
configInfo.setVersion("1.0.0");
|
||||
}
|
||||
if ( configInfo.standardVersionHandlingIsNotOK(m_versionUAVGadgetConfigurations) ){
|
||||
// We are in trouble now. User wants us to quit the import.
|
||||
qs->endGroup();
|
||||
return;
|
||||
}
|
||||
readConfigs_1_0_0(qs);
|
||||
qs->endGroup();
|
||||
createOptionsPages();
|
||||
}
|
||||
|
||||
void UAVGadgetInstanceManager::readConfigs_1_0_0(QSettings *qs)
|
||||
{
|
||||
foreach (QString classId, m_classIds.keys())
|
||||
{
|
||||
IUAVGadgetFactory *f = factory(classId);
|
||||
@ -115,14 +134,14 @@ void UAVGadgetInstanceManager::readConfigurations(QSettings *qs)
|
||||
}
|
||||
qs->endGroup();
|
||||
}
|
||||
qs->endGroup();
|
||||
createOptionsPages();
|
||||
}
|
||||
|
||||
void UAVGadgetInstanceManager::writeConfigurations(QSettings *qs)
|
||||
{
|
||||
qs->beginGroup("UAVGadgetConfigurations");
|
||||
qs->remove(""); // Remove existing configurations
|
||||
UAVConfigInfo configInfo(m_versionUAVGadgetConfigurations, "UAVGadgetConfigurations");
|
||||
configInfo.save(qs);
|
||||
foreach (IUAVGadgetConfiguration *config, m_configurations)
|
||||
{
|
||||
qs->beginGroup(config->classId());
|
||||
|
@ -33,6 +33,7 @@
|
||||
#include <QtCore/QMap>
|
||||
#include <QtCore/QStringList>
|
||||
#include "core_global.h"
|
||||
#include "uavconfiginfo.h"
|
||||
|
||||
namespace ExtensionSystem {
|
||||
class PluginManager;
|
||||
@ -96,9 +97,10 @@ private:
|
||||
QList<IOptionsPage*> m_provisionalOptionsPages;
|
||||
Core::Internal::SettingsDialog *m_settingsDialog;
|
||||
ExtensionSystem::PluginManager *m_pm;
|
||||
UAVConfigVersion m_versionUAVGadgetConfigurations;
|
||||
int indexForConfig(QList<IUAVGadgetConfiguration*> configurations,
|
||||
QString classId, QString configName);
|
||||
|
||||
void readConfigs_1_0_0(QSettings *qs);
|
||||
};
|
||||
|
||||
} // namespace Core
|
||||
|
Loading…
x
Reference in New Issue
Block a user