2012-06-26 16:41:25 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
*
|
|
|
|
* Copyright (C) 2012 by Dominik Riebeling
|
|
|
|
*
|
|
|
|
* All files in this archive are subject to the GNU General Public License.
|
|
|
|
* See the file COPYING in the source tree root for full license agreement.
|
|
|
|
*
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2013-01-27 11:01:56 +00:00
|
|
|
#include <QWidget>
|
|
|
|
#include <QMessageBox>
|
|
|
|
#include <QFileDialog>
|
2012-06-26 16:41:25 +00:00
|
|
|
#include "selectiveinstallwidget.h"
|
|
|
|
#include "ui_selectiveinstallwidgetfrm.h"
|
|
|
|
#include "serverinfo.h"
|
|
|
|
#include "rbsettings.h"
|
|
|
|
#include "rockboxinfo.h"
|
|
|
|
#include "systeminfo.h"
|
|
|
|
#include "progressloggergui.h"
|
|
|
|
#include "bootloaderinstallbase.h"
|
|
|
|
#include "bootloaderinstallhelper.h"
|
|
|
|
#include "themesinstallwindow.h"
|
|
|
|
#include "utils.h"
|
2013-11-03 10:08:18 +00:00
|
|
|
#include "Logger.h"
|
2012-06-26 16:41:25 +00:00
|
|
|
|
|
|
|
SelectiveInstallWidget::SelectiveInstallWidget(QWidget* parent) : QWidget(parent)
|
|
|
|
{
|
|
|
|
ui.setupUi(this);
|
|
|
|
ui.rockboxCheckbox->setChecked(RbSettings::value(RbSettings::InstallRockbox).toBool());
|
|
|
|
ui.fontsCheckbox->setChecked(RbSettings::value(RbSettings::InstallFonts).toBool());
|
|
|
|
ui.themesCheckbox->setChecked(RbSettings::value(RbSettings::InstallThemes).toBool());
|
|
|
|
ui.gamefileCheckbox->setChecked(RbSettings::value(RbSettings::InstallGamefiles).toBool());
|
|
|
|
|
|
|
|
// check if Rockbox is installed by looking after rockbox-info.txt.
|
|
|
|
// If installed uncheck bootloader installation.
|
|
|
|
RockboxInfo info(m_mountpoint);
|
|
|
|
ui.bootloaderCheckbox->setChecked(!info.success());
|
|
|
|
|
|
|
|
m_logger = NULL;
|
|
|
|
m_zipinstaller = NULL;
|
|
|
|
m_themesinstaller = NULL;
|
|
|
|
|
|
|
|
connect(ui.installButton, SIGNAL(clicked()), this, SLOT(startInstall()));
|
|
|
|
connect(this, SIGNAL(installSkipped(bool)), this, SLOT(continueInstall(bool)));
|
|
|
|
connect(ui.themesCustomize, SIGNAL(clicked()), this, SLOT(customizeThemes()));
|
|
|
|
connect(ui.selectedVersion, SIGNAL(currentIndexChanged(int)),
|
|
|
|
this, SLOT(selectedVersionChanged(int)));
|
|
|
|
// update version information. This also handles setting the previously
|
|
|
|
// selected build type and bootloader disabling.
|
|
|
|
updateVersion();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::selectedVersionChanged(int index)
|
|
|
|
{
|
|
|
|
QString current = ui.selectedVersion->itemData(index).toString();
|
|
|
|
if(current == "release")
|
|
|
|
ui.selectedDescription->setText(tr("This is the latest stable "
|
|
|
|
"release available."));
|
2012-07-01 13:02:32 +00:00
|
|
|
if(current == "development")
|
2012-06-26 16:41:25 +00:00
|
|
|
ui.selectedDescription->setText(tr("The development version is "
|
|
|
|
"updated on every code change. Last update was on %1").arg(
|
|
|
|
ServerInfo::value(ServerInfo::BleedingDate).toString()));
|
|
|
|
if(current == "rc")
|
|
|
|
ui.selectedDescription->setText(tr("This will eventually become the "
|
|
|
|
"next Rockbox version. Install it to help testing."));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::updateVersion(void)
|
|
|
|
{
|
|
|
|
// get some configuration values globally
|
|
|
|
m_mountpoint = RbSettings::value(RbSettings::Mountpoint).toString();
|
|
|
|
m_target = RbSettings::value(RbSettings::CurrentPlatform).toString();
|
|
|
|
m_blmethod = SystemInfo::platformValue(m_target,
|
|
|
|
SystemInfo::CurBootloaderMethod).toString();
|
|
|
|
|
|
|
|
if(m_logger != NULL) {
|
|
|
|
delete m_logger;
|
|
|
|
m_logger = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
// re-populate all version items
|
|
|
|
m_versions.clear();
|
|
|
|
m_versions.insert("release", ServerInfo::value(ServerInfo::CurReleaseVersion).toString());
|
2012-07-01 13:02:32 +00:00
|
|
|
m_versions.insert("development", ServerInfo::value(ServerInfo::BleedingRevision).toString());
|
2012-06-26 16:41:25 +00:00
|
|
|
m_versions.insert("rc", ServerInfo::value(ServerInfo::RelCandidateVersion).toString());
|
|
|
|
|
|
|
|
ui.selectedVersion->clear();
|
|
|
|
if(!m_versions["release"].isEmpty()) {
|
|
|
|
ui.selectedVersion->addItem(tr("Stable Release (Version %1)").arg(
|
|
|
|
m_versions["release"]), "release");
|
|
|
|
}
|
2012-07-01 13:02:32 +00:00
|
|
|
if(!m_versions["development"].isEmpty()) {
|
2012-06-26 16:41:25 +00:00
|
|
|
ui.selectedVersion->addItem(tr("Development Version (Revison %1)").arg(
|
2012-07-01 13:02:32 +00:00
|
|
|
m_versions["development"]), "development");
|
2012-06-26 16:41:25 +00:00
|
|
|
}
|
|
|
|
if(!m_versions["rc"].isEmpty()) {
|
|
|
|
ui.selectedVersion->addItem(tr("Release Candidate (Revison %1)").arg(
|
|
|
|
m_versions["rc"]), "rc");
|
|
|
|
}
|
|
|
|
|
|
|
|
// select previously selected version
|
|
|
|
int index = ui.selectedVersion->findData(RbSettings::value(RbSettings::Build).toString());
|
|
|
|
if(index != -1) {
|
|
|
|
ui.selectedVersion->setCurrentIndex(index);
|
|
|
|
}
|
2012-07-01 10:21:20 +00:00
|
|
|
else if(!m_versions["release"].isEmpty()) {
|
2012-06-26 16:41:25 +00:00
|
|
|
index = ui.selectedVersion->findData("release");
|
|
|
|
ui.selectedVersion->setCurrentIndex(index);
|
|
|
|
}
|
2012-07-01 10:21:20 +00:00
|
|
|
else {
|
2012-07-01 13:02:32 +00:00
|
|
|
index = ui.selectedVersion->findData("development");
|
2012-07-01 10:21:20 +00:00
|
|
|
ui.selectedVersion->setCurrentIndex(index);
|
|
|
|
}
|
2012-06-26 16:41:25 +00:00
|
|
|
// check if Rockbox is installed. If it is untick the bootloader option, as
|
|
|
|
// well as if the selected player doesn't need a bootloader.
|
|
|
|
if(m_blmethod == "none") {
|
|
|
|
ui.bootloaderCheckbox->setEnabled(false);
|
2012-09-02 20:30:19 +00:00
|
|
|
ui.bootloaderCheckbox->setChecked(false);
|
2012-06-26 16:41:25 +00:00
|
|
|
ui.bootloaderLabel->setEnabled(false);
|
|
|
|
ui.bootloaderLabel->setText(tr("The selected player doesn't need a bootloader."));
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
ui.bootloaderCheckbox->setEnabled(true);
|
|
|
|
ui.bootloaderLabel->setEnabled(true);
|
|
|
|
ui.bootloaderLabel->setText(tr("The bootloader is required for starting "
|
|
|
|
"Rockbox. Installation of the bootloader is only necessary "
|
|
|
|
"on first time installation."));
|
2012-09-02 20:30:19 +00:00
|
|
|
// check if Rockbox is installed by looking after rockbox-info.txt.
|
|
|
|
// If installed uncheck bootloader installation.
|
|
|
|
RockboxInfo info(m_mountpoint);
|
|
|
|
ui.bootloaderCheckbox->setChecked(!info.success());
|
2012-06-26 16:41:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::saveSettings(void)
|
|
|
|
{
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "saving current settings";
|
2012-06-26 16:41:25 +00:00
|
|
|
|
|
|
|
RbSettings::setValue(RbSettings::InstallRockbox, ui.rockboxCheckbox->isChecked());
|
|
|
|
RbSettings::setValue(RbSettings::InstallFonts, ui.fontsCheckbox->isChecked());
|
|
|
|
RbSettings::setValue(RbSettings::InstallThemes, ui.themesCheckbox->isChecked());
|
|
|
|
RbSettings::setValue(RbSettings::InstallGamefiles, ui.gamefileCheckbox->isChecked());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::startInstall(void)
|
|
|
|
{
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "starting installation";
|
2012-06-26 16:41:25 +00:00
|
|
|
saveSettings();
|
2012-08-19 08:49:53 +00:00
|
|
|
|
2012-06-26 16:41:25 +00:00
|
|
|
m_installStage = 0;
|
|
|
|
if(m_logger != NULL) delete m_logger;
|
|
|
|
m_logger = new ProgressLoggerGui(this);
|
2012-08-19 08:49:53 +00:00
|
|
|
QString warning = Utils::checkEnvironment(false);
|
|
|
|
if(!warning.isEmpty())
|
|
|
|
{
|
|
|
|
warning += "<br/>" + tr("Continue with installation?");
|
|
|
|
if(QMessageBox::warning(this, tr("Really continue?"), warning,
|
|
|
|
QMessageBox::Ok | QMessageBox::Abort, QMessageBox::Abort)
|
|
|
|
== QMessageBox::Abort)
|
|
|
|
{
|
|
|
|
emit installSkipped(true);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-06-26 16:41:25 +00:00
|
|
|
m_logger->show();
|
|
|
|
if(!QFileInfo(m_mountpoint).isDir()) {
|
|
|
|
m_logger->addItem(tr("Mountpoint is wrong"), LOGERROR);
|
|
|
|
m_logger->setFinished();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// start installation. No errors until now.
|
|
|
|
continueInstall(false);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::continueInstall(bool error)
|
|
|
|
{
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "continuing install with stage" << m_installStage;
|
2012-06-26 16:41:25 +00:00
|
|
|
if(error) {
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_ERROR() << "Last part returned error.";
|
2012-06-26 16:41:25 +00:00
|
|
|
m_logger->setFinished();
|
|
|
|
m_installStage = 7;
|
|
|
|
}
|
|
|
|
m_installStage++;
|
|
|
|
switch(m_installStage) {
|
2013-11-03 10:08:18 +00:00
|
|
|
case 0: LOG_ERROR() << "Something wrong!"; break;
|
2012-06-26 16:41:25 +00:00
|
|
|
case 1: installBootloader(); break;
|
|
|
|
case 2: installRockbox(); break;
|
|
|
|
case 3: installFonts(); break;
|
|
|
|
case 4: installThemes(); break;
|
|
|
|
case 5: installGamefiles(); break;
|
|
|
|
case 6: installBootloaderPost(); break;
|
|
|
|
default: break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(m_installStage > 6) {
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "All install stages done.";
|
2012-06-26 16:41:25 +00:00
|
|
|
m_logger->setFinished();
|
2012-09-02 20:30:19 +00:00
|
|
|
if(m_blmethod != "none") {
|
|
|
|
// check if Rockbox is installed by looking after rockbox-info.txt.
|
|
|
|
// If installed uncheck bootloader installation.
|
|
|
|
RockboxInfo info(m_mountpoint);
|
|
|
|
ui.bootloaderCheckbox->setChecked(!info.success());
|
|
|
|
}
|
2012-06-26 16:41:25 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::installBootloader(void)
|
|
|
|
{
|
|
|
|
if(ui.bootloaderCheckbox->isChecked()) {
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "installing bootloader";
|
2012-06-26 16:41:25 +00:00
|
|
|
|
|
|
|
QString platform = RbSettings::value(RbSettings::Platform).toString();
|
|
|
|
QString backupDestination = "";
|
|
|
|
|
|
|
|
// create installer
|
|
|
|
BootloaderInstallBase *bl =
|
|
|
|
BootloaderInstallHelper::createBootloaderInstaller(this,
|
|
|
|
SystemInfo::value(SystemInfo::CurBootloaderMethod).toString());
|
|
|
|
if(bl == NULL) {
|
|
|
|
m_logger->addItem(tr("No install method known."), LOGERROR);
|
|
|
|
m_logger->setFinished();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// the bootloader install class does NOT use any GUI stuff.
|
|
|
|
// All messages are passed via signals.
|
|
|
|
connect(bl, SIGNAL(done(bool)), m_logger, SLOT(setFinished()));
|
|
|
|
connect(bl, SIGNAL(done(bool)), this, SLOT(continueInstall(bool)));
|
|
|
|
connect(bl, SIGNAL(logItem(QString, int)), m_logger, SLOT(addItem(QString, int)));
|
|
|
|
connect(bl, SIGNAL(logProgress(int, int)), m_logger, SLOT(setProgress(int, int)));
|
|
|
|
|
|
|
|
// set bootloader filename. Do this now as installed() needs it.
|
|
|
|
QStringList blfile = SystemInfo::value(SystemInfo::CurBootloaderFile).toStringList();
|
|
|
|
QStringList blfilepath;
|
|
|
|
for(int a = 0; a < blfile.size(); a++) {
|
|
|
|
blfilepath.append(RbSettings::value(RbSettings::Mountpoint).toString()
|
|
|
|
+ blfile.at(a));
|
|
|
|
}
|
|
|
|
bl->setBlFile(blfilepath);
|
|
|
|
QUrl url(SystemInfo::value(SystemInfo::BootloaderUrl).toString()
|
|
|
|
+ SystemInfo::value(SystemInfo::CurBootloaderName).toString());
|
|
|
|
bl->setBlUrl(url);
|
|
|
|
bl->setLogfile(RbSettings::value(RbSettings::Mountpoint).toString()
|
|
|
|
+ "/.rockbox/rbutil.log");
|
|
|
|
|
|
|
|
if(bl->installed() == BootloaderInstallBase::BootloaderRockbox) {
|
|
|
|
if(QMessageBox::question(this, tr("Bootloader detected"),
|
|
|
|
tr("Bootloader already installed. Do you want to reinstall the bootloader?"),
|
|
|
|
QMessageBox::Yes | QMessageBox::No) == QMessageBox::No) {
|
|
|
|
// keep m_logger open for auto installs.
|
|
|
|
// don't consider abort as error in auto-mode.
|
|
|
|
m_logger->addItem(tr("Bootloader installation skipped"), LOGINFO);
|
|
|
|
delete bl;
|
|
|
|
emit installSkipped(true);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if(bl->installed() == BootloaderInstallBase::BootloaderOther
|
|
|
|
&& bl->capabilities() & BootloaderInstallBase::Backup)
|
|
|
|
{
|
|
|
|
QString targetFolder = SystemInfo::value(SystemInfo::CurPlatformName).toString()
|
|
|
|
+ " Firmware Backup";
|
|
|
|
// remove invalid character(s)
|
|
|
|
targetFolder.remove(QRegExp("[:/]"));
|
|
|
|
if(QMessageBox::question(this, tr("Create Bootloader backup"),
|
|
|
|
tr("You can create a backup of the original bootloader "
|
|
|
|
"file. Press \"Yes\" to select an output folder on your "
|
|
|
|
"computer to save the file to. The file will get placed "
|
|
|
|
"in a new folder \"%1\" created below the selected folder.\n"
|
|
|
|
"Press \"No\" to skip this step.").arg(targetFolder),
|
|
|
|
QMessageBox::Yes | QMessageBox::No) == QMessageBox::Yes) {
|
|
|
|
backupDestination = QFileDialog::getExistingDirectory(this,
|
|
|
|
tr("Browse backup folder"), QDir::homePath());
|
|
|
|
if(!backupDestination.isEmpty())
|
|
|
|
backupDestination += "/" + targetFolder;
|
|
|
|
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "backing up to" << backupDestination;
|
2012-06-26 16:41:25 +00:00
|
|
|
// backup needs to be done after the m_logger has been set up.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(bl->capabilities() & BootloaderInstallBase::NeedsOf)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
ret = QMessageBox::information(this, tr("Prerequisites"),
|
|
|
|
bl->ofHint(),QMessageBox::Ok | QMessageBox::Abort);
|
|
|
|
if(ret != QMessageBox::Ok) {
|
|
|
|
// consider aborting an error to close window / abort automatic
|
|
|
|
// installation.
|
|
|
|
m_logger->addItem(tr("Bootloader installation aborted"), LOGINFO);
|
|
|
|
m_logger->setFinished();
|
|
|
|
emit installSkipped(true);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// open dialog to browse to of file
|
|
|
|
QString offile;
|
|
|
|
QString filter
|
|
|
|
= SystemInfo::value(SystemInfo::CurBootloaderFilter).toString();
|
|
|
|
if(!filter.isEmpty()) {
|
|
|
|
filter = tr("Bootloader files (%1)").arg(filter) + ";;";
|
|
|
|
}
|
|
|
|
filter += tr("All files (*)");
|
|
|
|
offile = QFileDialog::getOpenFileName(this,
|
|
|
|
tr("Select firmware file"), QDir::homePath(), filter);
|
|
|
|
if(!QFileInfo(offile).isReadable()) {
|
|
|
|
m_logger->addItem(tr("Error opening firmware file"), LOGERROR);
|
|
|
|
m_logger->setFinished();
|
|
|
|
emit installSkipped(true);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if(!bl->setOfFile(offile, blfile)) {
|
|
|
|
m_logger->addItem(tr("Error reading firmware file"), LOGERROR);
|
|
|
|
m_logger->setFinished();
|
|
|
|
emit installSkipped(true);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// start install.
|
|
|
|
if(!backupDestination.isEmpty()) {
|
|
|
|
if(!bl->backup(backupDestination)) {
|
|
|
|
if(QMessageBox::warning(this, tr("Backup error"),
|
|
|
|
tr("Could not create backup file. Continue?"),
|
|
|
|
QMessageBox::No | QMessageBox::Yes)
|
|
|
|
== QMessageBox::No) {
|
|
|
|
m_logger->setFinished();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
bl->install();
|
|
|
|
|
|
|
|
}
|
|
|
|
else {
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "Bootloader install disabled.";
|
2012-06-26 16:41:25 +00:00
|
|
|
emit installSkipped(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::installBootloaderPost()
|
|
|
|
{
|
|
|
|
// don't do anything if no bootloader install has been done.
|
|
|
|
if(ui.bootloaderCheckbox->isChecked()) {
|
|
|
|
QString msg = BootloaderInstallHelper::postinstallHints(
|
|
|
|
RbSettings::value(RbSettings::Platform).toString());
|
|
|
|
if(!msg.isEmpty()) {
|
|
|
|
QMessageBox::information(this, tr("Manual steps required"), msg);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
emit installSkipped(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::installRockbox(void)
|
|
|
|
{
|
|
|
|
if(ui.rockboxCheckbox->isChecked()) {
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "installing Rockbox";
|
2012-06-26 16:41:25 +00:00
|
|
|
QString url;
|
|
|
|
|
|
|
|
QString selected = ui.selectedVersion->itemData(ui.selectedVersion->currentIndex()).toString();
|
|
|
|
RbSettings::setValue(RbSettings::Build, selected);
|
|
|
|
RbSettings::sync();
|
|
|
|
|
|
|
|
if(selected == "release") url = ServerInfo::platformValue(m_target,
|
|
|
|
ServerInfo::CurReleaseUrl).toString();
|
2012-07-01 13:02:32 +00:00
|
|
|
else if(selected == "development") url = ServerInfo::platformValue(m_target,
|
2012-06-26 16:41:25 +00:00
|
|
|
ServerInfo::CurDevelUrl).toString();
|
|
|
|
else if(selected == "rc") url = ServerInfo::platformValue(m_target,
|
|
|
|
ServerInfo::RelCandidateUrl).toString();
|
|
|
|
|
|
|
|
//! install build
|
2013-03-09 18:31:35 +00:00
|
|
|
if(m_zipinstaller != NULL) m_zipinstaller->deleteLater();
|
2012-06-26 16:41:25 +00:00
|
|
|
m_zipinstaller = new ZipInstaller(this);
|
|
|
|
m_zipinstaller->setUrl(url);
|
|
|
|
m_zipinstaller->setLogSection("Rockbox (Base)");
|
|
|
|
if(!RbSettings::value(RbSettings::CacheDisabled).toBool())
|
|
|
|
m_zipinstaller->setCache(true);
|
|
|
|
m_zipinstaller->setLogVersion(m_versions[selected]);
|
|
|
|
m_zipinstaller->setMountPoint(m_mountpoint);
|
|
|
|
|
|
|
|
connect(m_zipinstaller, SIGNAL(done(bool)), this, SLOT(continueInstall(bool)));
|
|
|
|
|
|
|
|
connect(m_zipinstaller, SIGNAL(logItem(QString, int)), m_logger, SLOT(addItem(QString, int)));
|
|
|
|
connect(m_zipinstaller, SIGNAL(logProgress(int, int)), m_logger, SLOT(setProgress(int, int)));
|
|
|
|
connect(m_logger, SIGNAL(aborted()), m_zipinstaller, SLOT(abort()));
|
|
|
|
m_zipinstaller->install();
|
|
|
|
|
|
|
|
}
|
|
|
|
else {
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "Rockbox install disabled.";
|
2012-06-26 16:41:25 +00:00
|
|
|
emit installSkipped(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::installFonts(void)
|
|
|
|
{
|
|
|
|
if(ui.fontsCheckbox->isChecked()) {
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "installing Fonts";
|
2012-06-26 16:41:25 +00:00
|
|
|
|
|
|
|
RockboxInfo installInfo(m_mountpoint);
|
|
|
|
QString fontsurl;
|
|
|
|
QString logversion;
|
|
|
|
QString relversion = installInfo.release();
|
|
|
|
if(relversion.isEmpty()) {
|
|
|
|
// release is empty for non-release versions (i.e. daily / current)
|
|
|
|
fontsurl = SystemInfo::value(SystemInfo::DailyFontUrl).toString();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
fontsurl = SystemInfo::value(SystemInfo::ReleaseFontUrl).toString();
|
|
|
|
logversion = installInfo.release();
|
|
|
|
}
|
|
|
|
fontsurl.replace("%RELEASEVER%", relversion);
|
|
|
|
|
|
|
|
// create new zip installer
|
2013-03-09 18:31:35 +00:00
|
|
|
if(m_zipinstaller != NULL) m_zipinstaller->deleteLater();
|
2012-06-26 16:41:25 +00:00
|
|
|
m_zipinstaller = new ZipInstaller(this);
|
|
|
|
m_zipinstaller->setUrl(fontsurl);
|
|
|
|
m_zipinstaller->setLogSection("Fonts");
|
|
|
|
m_zipinstaller->setLogVersion(logversion);
|
|
|
|
m_zipinstaller->setMountPoint(m_mountpoint);
|
|
|
|
if(!RbSettings::value(RbSettings::CacheDisabled).toBool())
|
|
|
|
m_zipinstaller->setCache(true);
|
|
|
|
|
|
|
|
connect(m_zipinstaller, SIGNAL(done(bool)), this, SLOT(continueInstall(bool)));
|
|
|
|
connect(m_zipinstaller, SIGNAL(logItem(QString, int)), m_logger, SLOT(addItem(QString, int)));
|
|
|
|
connect(m_zipinstaller, SIGNAL(logProgress(int, int)), m_logger, SLOT(setProgress(int, int)));
|
|
|
|
connect(m_logger, SIGNAL(aborted()), m_zipinstaller, SLOT(abort()));
|
|
|
|
m_zipinstaller->install();
|
|
|
|
}
|
|
|
|
else {
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "Fonts install disabled.";
|
2012-06-26 16:41:25 +00:00
|
|
|
emit installSkipped(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::customizeThemes(void)
|
|
|
|
{
|
|
|
|
if(m_themesinstaller == NULL)
|
|
|
|
m_themesinstaller = new ThemesInstallWindow(this);
|
|
|
|
|
|
|
|
m_themesinstaller->setSelectOnly(true);
|
|
|
|
m_themesinstaller->show();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::installThemes(void)
|
|
|
|
{
|
|
|
|
if(ui.themesCheckbox->isChecked()) {
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "installing themes";
|
2012-06-26 16:41:25 +00:00
|
|
|
if(m_themesinstaller == NULL)
|
|
|
|
m_themesinstaller = new ThemesInstallWindow(this);
|
|
|
|
|
2012-07-01 12:58:39 +00:00
|
|
|
connect(m_themesinstaller, SIGNAL(done(bool)), this, SLOT(continueInstall(bool)));
|
2012-06-26 16:41:25 +00:00
|
|
|
m_themesinstaller->setLogger(m_logger);
|
|
|
|
m_themesinstaller->setModal(true);
|
|
|
|
m_themesinstaller->install();
|
|
|
|
}
|
|
|
|
else {
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "Themes install disabled.";
|
2012-06-26 16:41:25 +00:00
|
|
|
emit installSkipped(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SelectiveInstallWidget::installGamefiles(void)
|
|
|
|
{
|
|
|
|
if(ui.gamefileCheckbox->isChecked()) {
|
|
|
|
// check if installed Rockbox has doom plugin. If not disable doom.
|
|
|
|
if(!QFileInfo(m_mountpoint + "/.rockbox/rocks/games/doom.rock").exists()) {
|
|
|
|
m_logger->addItem(tr("Your installation doesn't require game files, skipping."), LOGINFO);
|
|
|
|
emit installSkipped(false);
|
|
|
|
}
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "installing gamefiles";
|
2012-06-26 16:41:25 +00:00
|
|
|
// create new zip installer
|
2013-03-09 18:31:35 +00:00
|
|
|
if(m_zipinstaller != NULL) m_zipinstaller->deleteLater();
|
2012-06-26 16:41:25 +00:00
|
|
|
m_zipinstaller = new ZipInstaller(this);
|
|
|
|
|
|
|
|
m_zipinstaller->setUrl(SystemInfo::value(SystemInfo::DoomUrl).toString());
|
|
|
|
m_zipinstaller->setLogSection("Game Addons");
|
|
|
|
m_zipinstaller->setLogVersion();
|
|
|
|
m_zipinstaller->setMountPoint(m_mountpoint);
|
|
|
|
if(!RbSettings::value(RbSettings::CacheDisabled).toBool())
|
|
|
|
m_zipinstaller->setCache(true);
|
|
|
|
connect(m_zipinstaller, SIGNAL(done(bool)), this, SLOT(continueInstall(bool)));
|
|
|
|
connect(m_zipinstaller, SIGNAL(logItem(QString, int)), m_logger, SLOT(addItem(QString, int)));
|
|
|
|
connect(m_zipinstaller, SIGNAL(logProgress(int, int)), m_logger, SLOT(setProgress(int, int)));
|
|
|
|
connect(m_logger, SIGNAL(aborted()), m_zipinstaller, SLOT(abort()));
|
|
|
|
m_zipinstaller->install();
|
|
|
|
}
|
|
|
|
else {
|
2013-11-03 10:08:18 +00:00
|
|
|
LOG_INFO() << "Gamefile install disabled.";
|
2012-06-26 16:41:25 +00:00
|
|
|
emit installSkipped(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-06-30 08:50:28 +00:00
|
|
|
void SelectiveInstallWidget::changeEvent(QEvent *e)
|
|
|
|
{
|
|
|
|
if(e->type() == QEvent::LanguageChange) {
|
|
|
|
ui.retranslateUi(this);
|
|
|
|
} else {
|
|
|
|
QWidget::changeEvent(e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|