fix tricky regression noticed by Vyacheslav Tokarev on Google Reader.
[kdelibs.git] / kio / kio / deletejob.h
blobeaba4be128f6d74d821537d8cc5a75208c4d8999
1 // -*- c++ -*-
2 /* This file is part of the KDE libraries
3 Copyright 2000 Stephan Kulow <coolo@kde.org>
4 Copyright 2000-2006 David Faure <faure@kde.org>
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Library General Public
8 License as published by the Free Software Foundation; either
9 version 2 of the License, or (at your option) any later version.
11 This library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Library General Public License for more details.
16 You should have received a copy of the GNU Library General Public License
17 along with this library; see the file COPYING.LIB. If not, write to
18 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
19 Boston, MA 02110-1301, USA.
22 #ifndef KIO_DELETEJOB_H
23 #define KIO_DELETEJOB_H
25 #include <QtCore/QStringList>
27 #include <kurl.h>
28 #include "global.h"
30 #include "jobclasses.h"
32 class QTimer;
34 namespace KIO {
36 class DeleteJobPrivate;
37 /**
38 * A more complex Job to delete files and directories.
39 * Don't create the job directly, but use KIO::del() instead.
41 * @see KIO::del()
43 class KIO_EXPORT DeleteJob : public Job {
44 Q_OBJECT
46 public:
47 virtual ~DeleteJob();
49 /**
50 * Returns the list of URLs.
51 * @return the list of URLs.
53 KUrl::List urls() const;
55 Q_SIGNALS:
57 /**
58 * Emitted when the total number of files is known.
59 * @param job the job that emitted this signal
60 * @param files the total number of files
62 void totalFiles( KJob *job, unsigned long files );
63 /**
64 * Emitted when the toal number of direcotries is known.
65 * @param job the job that emitted this signal
66 * @param dirs the total number of directories
68 void totalDirs( KJob *job, unsigned long dirs );
70 /**
71 * Sends the number of processed files.
72 * @param job the job that emitted this signal
73 * @param files the number of processed files
75 void processedFiles( KIO::Job *job, unsigned long files );
76 /**
77 * Sends the number of processed directories.
78 * @param job the job that emitted this signal
79 * @param dirs the number of processed dirs
81 void processedDirs( KIO::Job *job, unsigned long dirs );
83 /**
84 * Sends the URL of the file that is currently being deleted.
85 * @param job the job that emitted this signal
86 * @param file the URL of the file or directory that is being
87 * deleted
89 void deleting( KIO::Job *job, const KUrl& file );
91 protected Q_SLOTS:
92 virtual void slotResult( KJob *job );
94 protected:
95 DeleteJob(DeleteJobPrivate &dd);
97 private:
98 Q_PRIVATE_SLOT(d_func(), void slotStart())
99 Q_PRIVATE_SLOT(d_func(), void slotEntries( KIO::Job*, const KIO::UDSEntryList& list ))
100 Q_PRIVATE_SLOT(d_func(), void slotReport())
101 Q_DECLARE_PRIVATE(DeleteJob)
105 * Delete a file or directory.
107 * @param src file to delete
108 * @param flags: We support HideProgressInfo here
109 * @return the job handling the operation
111 KIO_EXPORT DeleteJob *del( const KUrl& src, JobFlags flags = DefaultFlags );
114 * Deletes a list of files or directories.
116 * @param src the files to delete
117 * @param flags: We support HideProgressInfo here
118 * @return the job handling the operation
120 KIO_EXPORT DeleteJob *del( const KUrl::List& src, JobFlags flags = DefaultFlags );
123 #endif