/* ============================================================ * * This file is a part of the rekonq project * * Copyright (C) 2007 Lukas Appelhans <l.appelhans@gmx.de> * Copyright (C) 2008 by Andrea Diamantini <adjam7 at gmail dot com> * * * 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 2, 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. * * ============================================================ */ #ifndef DOWNLOAD_H #define DOWNLOAD_H // KDE Includes #include <KUrl> #include <kio/job.h> // Qt Includes #include <QObject> #include <QByteArray> /** * This class lets rekonq to download an object from the network. * Creating a new object, you can continue downloading a file also * when rekonq is closed. * */ class Download : public QObject { Q_OBJECT public: /** * Class constructor. This is the unique method we need to * use this class. In fact Download class needs to know just * "where" catch the file to download and where it has to put it * * @param srcUrl the source url * * @param destUrl the destination url * */ Download(const KUrl &srcUrl, const KUrl &destUrl); /** * class destructor */ ~Download(); private slots: void slotResult(KJob * job); void slotData(KIO::Job *job, const QByteArray& data); private: KIO::TransferJob *m_copyJob; KUrl m_srcUrl; KUrl m_destUrl; KUrl m_destFile; QByteArray m_data; }; #endif