31848ac8bd
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@14014 a1c6a512-1295-4272-9138-f99709370657
146 lines
4.6 KiB
C++
146 lines
4.6 KiB
C++
/***************************************************************************
|
|
* __________ __ ___.
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
* \/ \/ \/ \/ \/
|
|
*
|
|
* Copyright (C) 2007 by Dominik Riebeling
|
|
* $Id: installrb.cpp 13990 2007-07-25 22:26:10Z Dominik Wenger $
|
|
*
|
|
* 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.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#include "installrb.h"
|
|
|
|
#include "zip/zip.h"
|
|
#include "zip/unzip.h"
|
|
|
|
RBInstaller::RBInstaller(QObject* parent): QObject(parent)
|
|
{
|
|
|
|
}
|
|
|
|
|
|
void RBInstaller::install(QString url,QString file,QString mountpoint, QUrl proxy,Ui::InstallProgressFrm* dp)
|
|
{
|
|
m_url=url;
|
|
m_mountpoint = mountpoint;
|
|
m_file = file;
|
|
m_dp = dp;
|
|
|
|
m_dp->listProgress->addItem(tr("Downloading file %1.%2")
|
|
.arg(QFileInfo(m_url).baseName(), QFileInfo(m_url).completeSuffix()));
|
|
|
|
// temporary file needs to be opened to get the filename
|
|
downloadFile.open();
|
|
m_file = downloadFile.fileName();
|
|
downloadFile.close();
|
|
// get the real file.
|
|
getter = new HttpGet(this);
|
|
getter->setProxy(proxy);
|
|
getter->setFile(&downloadFile);
|
|
getter->getFile(QUrl(url));
|
|
|
|
connect(getter, SIGNAL(done(bool)), this, SLOT(downloadDone(bool)));
|
|
connect(getter, SIGNAL(downloadDone(int, bool)), this, SLOT(downloadRequestFinished(int, bool)));
|
|
connect(getter, SIGNAL(dataReadProgress(int, int)), this, SLOT(updateDataReadProgress(int, int)));
|
|
|
|
}
|
|
|
|
void RBInstaller::downloadRequestFinished(int id, bool error)
|
|
{
|
|
qDebug() << "Install::downloadRequestFinished" << id << error;
|
|
qDebug() << "error:" << getter->errorString();
|
|
|
|
downloadDone(error);
|
|
}
|
|
|
|
void RBInstaller::downloadDone(bool error)
|
|
{
|
|
qDebug() << "Install::downloadDone, error:" << error;
|
|
|
|
|
|
// update progress bar
|
|
int max = m_dp->progressBar->maximum();
|
|
if(max == 0) {
|
|
max = 100;
|
|
m_dp->progressBar->setMaximum(max);
|
|
}
|
|
m_dp->progressBar->setValue(max);
|
|
if(getter->httpResponse() != 200) {
|
|
m_dp->listProgress->addItem(tr("Download error: received HTTP error %1.").arg(getter->httpResponse()));
|
|
m_dp->buttonAbort->setText(tr("&Ok"));
|
|
emit done(true);
|
|
return;
|
|
}
|
|
if(error) {
|
|
m_dp->listProgress->addItem(tr("Download error: %1").arg(getter->errorString()));
|
|
m_dp->buttonAbort->setText(tr("&Ok"));
|
|
emit done(true);
|
|
return;
|
|
}
|
|
else m_dp->listProgress->addItem(tr("Download finished."));
|
|
|
|
// unzip downloaded file
|
|
qDebug() << "about to unzip the downloaded file" << m_file << "to" << m_mountpoint;
|
|
|
|
m_dp->listProgress->addItem(tr("Extracting file."));
|
|
|
|
qDebug() << "file to unzip: " << m_file;
|
|
UnZip::ErrorCode ec;
|
|
UnZip uz;
|
|
ec = uz.openArchive(m_file);
|
|
if(ec != UnZip::Ok) {
|
|
m_dp->listProgress->addItem(tr("Opening archive failed: %1.")
|
|
.arg(uz.formatError(ec)));
|
|
m_dp->buttonAbort->setText(tr("&Ok"));
|
|
emit done(false);
|
|
return;
|
|
}
|
|
|
|
ec = uz.extractAll(m_mountpoint);
|
|
if(ec != UnZip::Ok) {
|
|
m_dp->listProgress->addItem(tr("Extracting failed: %1.")
|
|
.arg(uz.formatError(ec)));
|
|
m_dp->buttonAbort->setText(tr("&Ok"));
|
|
emit done(false);
|
|
return;
|
|
}
|
|
|
|
m_dp->listProgress->addItem(tr("creating installation log"));
|
|
|
|
QStringList zipContents = uz.fileList();
|
|
|
|
QSettings installlog(m_mountpoint + "/.rockbox/rbutil.log", QSettings::IniFormat, 0);
|
|
|
|
installlog.beginGroup("rockboxbase");
|
|
for(int i = 0; i < zipContents.size(); i++)
|
|
{
|
|
installlog.setValue(zipContents.at(i),installlog.value(zipContents.at(i),0).toInt()+1);
|
|
}
|
|
installlog.endGroup();
|
|
|
|
// remove temporary file
|
|
downloadFile.remove();
|
|
|
|
m_dp->listProgress->addItem(tr("Extraction finished successfully."));
|
|
m_dp->buttonAbort->setText(tr("&Ok"));
|
|
|
|
emit done(false);
|
|
}
|
|
|
|
void RBInstaller::updateDataReadProgress(int read, int total)
|
|
{
|
|
m_dp->progressBar->setMaximum(total);
|
|
m_dp->progressBar->setValue(read);
|
|
qDebug() << "progress:" << read << "/" << total;
|
|
|
|
}
|
|
|