File indexing completed on 2024-09-15 03:38:26

0001 // -*- c++ -*-
0002 /*
0003     This file is part of the KDE libraries
0004     SPDX-FileCopyrightText: 2000 Stephan Kulow <coolo@kde.org>
0005     SPDX-FileCopyrightText: 2000-2006 David Faure <faure@kde.org>
0006 
0007     SPDX-License-Identifier: LGPL-2.0-or-later
0008 */
0009 
0010 #ifndef KIO_DELETEJOB_H
0011 #define KIO_DELETEJOB_H
0012 
0013 #include <QStringList>
0014 
0015 #include "global.h"
0016 #include "kiocore_export.h"
0017 
0018 #include "job_base.h"
0019 
0020 class QTimer;
0021 
0022 namespace KIO
0023 {
0024 class DeleteJobPrivate;
0025 /**
0026  * @class KIO::DeleteJob deletejob.h <KIO/DeleteJob>
0027  *
0028  * A more complex Job to delete files and directories.
0029  * Don't create the job directly, but use KIO::del() instead.
0030  *
0031  * @see KIO::del()
0032  */
0033 class KIOCORE_EXPORT DeleteJob : public Job
0034 {
0035     Q_OBJECT
0036 
0037 public:
0038     ~DeleteJob() override;
0039 
0040     /**
0041      * Returns the list of URLs.
0042      * @return the list of URLs.
0043      */
0044     QList<QUrl> urls() const;
0045 
0046 Q_SIGNALS:
0047 
0048     /**
0049      * Emitted when the total number of files is known.
0050      * @param job the job that emitted this signal
0051      * @param files the total number of files
0052      */
0053     void totalFiles(KJob *job, unsigned long files);
0054     /**
0055      * Emitted when the total number of directories is known.
0056      * @param job the job that emitted this signal
0057      * @param dirs the total number of directories
0058      */
0059     void totalDirs(KJob *job, unsigned long dirs);
0060 
0061     /**
0062      * Sends the number of processed files.
0063      * @param job the job that emitted this signal
0064      * @param files the number of processed files
0065      */
0066     void processedFiles(KIO::Job *job, unsigned long files);
0067     /**
0068      * Sends the number of processed directories.
0069      * @param job the job that emitted this signal
0070      * @param dirs the number of processed dirs
0071      */
0072     void processedDirs(KIO::Job *job, unsigned long dirs);
0073 
0074     /**
0075      * Sends the URL of the file that is currently being deleted.
0076      * @param job the job that emitted this signal
0077      * @param file the URL of the file or directory that is being
0078      *        deleted
0079      */
0080     void deleting(KIO::Job *job, const QUrl &file);
0081 
0082 protected Q_SLOTS:
0083     void slotResult(KJob *job) override;
0084 
0085 protected:
0086     KIOCORE_NO_EXPORT explicit DeleteJob(DeleteJobPrivate &dd);
0087 
0088 private:
0089     Q_DECLARE_PRIVATE(DeleteJob)
0090 };
0091 
0092 /**
0093  * Delete a file or directory.
0094  *
0095  * @param src file to delete
0096  * @param flags We support HideProgressInfo here
0097  * @return the job handling the operation
0098  */
0099 KIOCORE_EXPORT DeleteJob *del(const QUrl &src, JobFlags flags = DefaultFlags);
0100 
0101 /**
0102  * Deletes a list of files or directories.
0103  *
0104  * @param src the files to delete
0105  * @param flags We support HideProgressInfo here
0106  * @return the job handling the operation
0107  */
0108 KIOCORE_EXPORT DeleteJob *del(const QList<QUrl> &src, JobFlags flags = DefaultFlags);
0109 }
0110 
0111 #endif