summaryrefslogtreecommitdiff
path: root/src/download.h
blob: 001c90f39f16c92a6dbe707425ef72c955cf2964 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
/* ============================================================
*
* 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.
 *
 * @author Lukas Appelhans <l.appelhans@gmx.de>
 * @author Andrea Diamantini <adjam7@gmail.com>
 *
 */
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