[plasmalnf] Simplify code, reduce copies of lnftool setting
This commit is contained in:
parent
fe8ff3ab05
commit
1de2e94fd0
@ -9,7 +9,6 @@ calamares_add_plugin( plasmalnf
|
|||||||
PlasmaLnfViewStep.cpp
|
PlasmaLnfViewStep.cpp
|
||||||
PlasmaLnfPage.cpp
|
PlasmaLnfPage.cpp
|
||||||
PlasmaLnfJob.cpp
|
PlasmaLnfJob.cpp
|
||||||
PlasmaLnfInfo.cpp
|
|
||||||
UI
|
UI
|
||||||
page_plasmalnf.ui
|
page_plasmalnf.ui
|
||||||
LINK_PRIVATE_LIBRARIES
|
LINK_PRIVATE_LIBRARIES
|
||||||
|
@ -1,58 +0,0 @@
|
|||||||
/* === This file is part of Calamares - <http://github.com/calamares> ===
|
|
||||||
*
|
|
||||||
* Copyright 2017, Adriaan de Groot <groot@kde.org>
|
|
||||||
*
|
|
||||||
* Calamares 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.
|
|
||||||
*
|
|
||||||
* Calamares 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 Calamares. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "PlasmaLnfInfo.h"
|
|
||||||
|
|
||||||
#include <QDateTime>
|
|
||||||
#include <QDir>
|
|
||||||
#include <QProcess>
|
|
||||||
#include <QStandardPaths>
|
|
||||||
#include <QThread>
|
|
||||||
|
|
||||||
#include <KService>
|
|
||||||
#include <KServiceTypeTrader>
|
|
||||||
#include <KPluginLoader> // Future
|
|
||||||
|
|
||||||
#include <Plasma/PluginLoader> // TODO: port to KPluginLoader
|
|
||||||
#include <KPackage/Package>
|
|
||||||
#include <KPackage/PackageLoader>
|
|
||||||
|
|
||||||
#include "utils/Logger.h"
|
|
||||||
|
|
||||||
|
|
||||||
namespace Calamares
|
|
||||||
{
|
|
||||||
|
|
||||||
static QString *p_lnfPath = nullptr;
|
|
||||||
|
|
||||||
QString lnftool()
|
|
||||||
{
|
|
||||||
if ( !p_lnfPath )
|
|
||||||
p_lnfPath = new QString("/usr/bin/lookandfeeltool");
|
|
||||||
|
|
||||||
return *p_lnfPath;
|
|
||||||
}
|
|
||||||
|
|
||||||
void set_lnftool( const QString& lnfPath )
|
|
||||||
{
|
|
||||||
if (p_lnfPath)
|
|
||||||
delete p_lnfPath;
|
|
||||||
p_lnfPath = new QString( lnfPath );
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace Calamares
|
|
@ -1,31 +0,0 @@
|
|||||||
/* === This file is part of Calamares - <http://github.com/calamares> ===
|
|
||||||
*
|
|
||||||
* Copyright 2017, Adriaan de Groot <groot@kde.org>
|
|
||||||
*
|
|
||||||
* Calamares 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.
|
|
||||||
*
|
|
||||||
* Calamares 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 Calamares. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef PLASMALNFINFO_H
|
|
||||||
#define PLASMALNFINFO_H
|
|
||||||
|
|
||||||
#include <QString>
|
|
||||||
#include <QStringList>
|
|
||||||
|
|
||||||
namespace Calamares
|
|
||||||
{
|
|
||||||
QString lnftool();
|
|
||||||
void set_lnftool( const QString& );
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // PLASMALNFINFO_H
|
|
@ -17,7 +17,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "PlasmaLnfPage.h"
|
#include "PlasmaLnfPage.h"
|
||||||
#include "PlasmaLnfInfo.h"
|
|
||||||
|
|
||||||
#include "ui_page_plasmalnf.h"
|
#include "ui_page_plasmalnf.h"
|
||||||
|
|
||||||
@ -74,7 +73,7 @@ PlasmaLnfPage::activated(const QString& name)
|
|||||||
cDebug() << "Changed to" << name;
|
cDebug() << "Changed to" << name;
|
||||||
|
|
||||||
QProcess lnftool;
|
QProcess lnftool;
|
||||||
lnftool.start( Calamares::lnftool(), {"--resetLayout", "--apply", name} );
|
lnftool.start( m_lnfPath, {"--resetLayout", "--apply", name} );
|
||||||
|
|
||||||
if ( lnftool.waitForStarted(1000) && lnftool.waitForFinished( 1000 ) && (lnftool.exitCode() == 0) && (lnftool.exitStatus() == QProcess::NormalExit ) )
|
if ( lnftool.waitForStarted(1000) && lnftool.waitForFinished( 1000 ) && (lnftool.exitCode() == 0) && (lnftool.exitStatus() == QProcess::NormalExit ) )
|
||||||
; // OK
|
; // OK
|
||||||
@ -84,3 +83,9 @@ PlasmaLnfPage::activated(const QString& name)
|
|||||||
|
|
||||||
emit plasmaThemeSelected( name );
|
emit plasmaThemeSelected( name );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
PlasmaLnfPage::setLnfPath(const QString& path)
|
||||||
|
{
|
||||||
|
m_lnfPath = path;
|
||||||
|
}
|
||||||
|
@ -33,6 +33,8 @@ class PlasmaLnfPage : public QWidget
|
|||||||
public:
|
public:
|
||||||
explicit PlasmaLnfPage( QWidget* parent = nullptr );
|
explicit PlasmaLnfPage( QWidget* parent = nullptr );
|
||||||
|
|
||||||
|
void setLnfPath( const QString& path );
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void activated(const QString& name);
|
void activated(const QString& name);
|
||||||
|
|
||||||
@ -41,6 +43,7 @@ signals:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::PlasmaLnfPage* ui;
|
Ui::PlasmaLnfPage* ui;
|
||||||
|
QString m_lnfPath;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif //PLASMALNFPAGE_H
|
#endif //PLASMALNFPAGE_H
|
||||||
|
@ -22,7 +22,6 @@
|
|||||||
#include "utils/CalamaresUtils.h"
|
#include "utils/CalamaresUtils.h"
|
||||||
#include "utils/CalamaresUtilsSystem.h"
|
#include "utils/CalamaresUtilsSystem.h"
|
||||||
|
|
||||||
#include "PlasmaLnfInfo.h"
|
|
||||||
#include "PlasmaLnfJob.h"
|
#include "PlasmaLnfJob.h"
|
||||||
#include "PlasmaLnfPage.h"
|
#include "PlasmaLnfPage.h"
|
||||||
#include "PlasmaLnfViewStep.h"
|
#include "PlasmaLnfViewStep.h"
|
||||||
@ -128,7 +127,7 @@ PlasmaLnfViewStep::setConfigurationMap( const QVariantMap& configurationMap )
|
|||||||
if ( configurationMap.contains( "lnftool" ) && configurationMap.value( "lnftool" ).type() == QVariant::String )
|
if ( configurationMap.contains( "lnftool" ) && configurationMap.value( "lnftool" ).type() == QVariant::String )
|
||||||
lnfPath = configurationMap.value( "lnftool" ).toString();
|
lnfPath = configurationMap.value( "lnftool" ).toString();
|
||||||
m_lnfPath = lnfPath;
|
m_lnfPath = lnfPath;
|
||||||
Calamares::set_lnftool( m_lnfPath );
|
m_widget->setLnfPath( m_lnfPath );
|
||||||
|
|
||||||
if (m_lnfPath.isEmpty())
|
if (m_lnfPath.isEmpty())
|
||||||
cDebug() << "WARNING: no lnftool given for plasmalnf module.";
|
cDebug() << "WARNING: no lnftool given for plasmalnf module.";
|
||||||
|
Loading…
Reference in New Issue
Block a user