File indexing completed on 2024-09-08 03:38:46
0001 /* 0002 This file is part of the KDE libraries 0003 SPDX-FileCopyrightText: 2000 Stephan Kulow <coolo@kde.org> 0004 SPDX-FileCopyrightText: 2000-2009 David Faure <faure@kde.org> 0005 0006 SPDX-License-Identifier: LGPL-2.0-or-later 0007 */ 0008 0009 #ifndef KIO_FILECOPYJOB_H 0010 #define KIO_FILECOPYJOB_H 0011 0012 #include "job_base.h" 0013 #include <kio/global.h> // filesize_t 0014 0015 namespace KIO 0016 { 0017 class FileCopyJobPrivate; 0018 /** 0019 * @class KIO::FileCopyJob filecopyjob.h <KIO/FileCopyJob> 0020 * 0021 * The FileCopyJob copies data from one place to another. 0022 * @see KIO::file_copy() 0023 * @see KIO::file_move() 0024 */ 0025 class KIOCORE_EXPORT FileCopyJob : public Job 0026 { 0027 Q_OBJECT 0028 0029 public: 0030 ~FileCopyJob() override; 0031 /** 0032 * If you know the size of the source file, call this method 0033 * to inform this job. It will be displayed in the "resume" dialog. 0034 * @param size the size of the source file 0035 */ 0036 void setSourceSize(KIO::filesize_t size); 0037 0038 /** 0039 * Sets the modification time of the file 0040 * 0041 * Note that this is ignored if a direct copy (WorkerBase::copy) can be done, 0042 * in which case the mtime of the source is applied to the destination (if the protocol 0043 * supports the concept). 0044 */ 0045 void setModificationTime(const QDateTime &mtime); 0046 0047 /** 0048 * Returns the source URL. 0049 * @return the source URL 0050 */ 0051 QUrl srcUrl() const; 0052 0053 /** 0054 * Returns the destination URL. 0055 * @return the destination URL 0056 */ 0057 QUrl destUrl() const; 0058 0059 bool doSuspend() override; 0060 bool doResume() override; 0061 bool doKill() override; 0062 0063 Q_SIGNALS: 0064 /** 0065 * MIME type determined during a file copy. 0066 * This is never emitted during a move, and might not be emitted during 0067 * a file copy, depending on the worker. But when a get and a put are 0068 * being used (which is the common case), this signal forwards the 0069 * MIME type information from the get job. 0070 * 0071 * @param job the job that emitted this signal 0072 * @param mimeType the MIME type 0073 * @since 5.78 0074 */ 0075 void mimeTypeFound(KIO::Job *job, const QString &mimeType); 0076 0077 protected Q_SLOTS: 0078 /** 0079 * Called whenever a subjob finishes. 0080 * @param job the job that emitted this signal 0081 */ 0082 void slotResult(KJob *job) override; 0083 0084 protected: 0085 KIOCORE_NO_EXPORT explicit FileCopyJob(FileCopyJobPrivate &dd); 0086 0087 private: 0088 Q_DECLARE_PRIVATE(FileCopyJob) 0089 }; 0090 0091 /** 0092 * Copy a single file. 0093 * 0094 * Uses either WorkerBase::copy() if the worker supports that 0095 * or get() and put() otherwise. 0096 * 0097 * @param src Where to get the file 0098 * @param dest Where to put the file 0099 * @param permissions the file mode permissions to set on @p dest; if this is -1 0100 * (the default) no special permissions will be set on @p dest, i.e. it'll have 0101 * the default system permissions for newly created files, and the owner and group 0102 * permissions are not preserved. 0103 * @param flags Can be @ref JobFlag::HideProgressInfo, Overwrite and Resume here 0104 * WARNING: Setting @ref JobFlag::Resume means that the data will be appended to 0105 * @p dest if @p dest exists 0106 * @return the job handling the operation 0107 */ 0108 KIOCORE_EXPORT FileCopyJob *file_copy(const QUrl &src, const QUrl &dest, int permissions = -1, JobFlags flags = DefaultFlags); 0109 0110 /** 0111 * Overload for catching code mistakes. Do NOT call this method (it is not implemented), 0112 * insert a value for permissions (-1 by default) before the JobFlags. 0113 */ 0114 FileCopyJob *file_copy(const QUrl &src, const QUrl &dest, JobFlags flags) Q_DECL_EQ_DELETE; // not implemented - on purpose. 0115 0116 /** 0117 * Move a single file. 0118 * 0119 * Use either WorkerBase::rename() if the worker supports that, 0120 * or copy() and del() otherwise, or eventually get() & put() & del() 0121 * 0122 * @param src Where to get the file 0123 * @param dest Where to put the file 0124 * @param permissions the file mode permissions to set on @p dest; if this is -1 0125 * (the default), no special permissions are set on @p dest, i.e. it'll have 0126 * the default system permissions for newly created files, and the owner and group 0127 * permissions are not preserved. 0128 * @param flags Can be HideProgressInfo, Overwrite and Resume here 0129 * WARNING: Setting @ref JobFlag::Resume means that the data will be appended to 0130 * @p dest if @p dest exists 0131 * @return the job handling the operation 0132 */ 0133 KIOCORE_EXPORT FileCopyJob *file_move(const QUrl &src, const QUrl &dest, int permissions = -1, JobFlags flags = DefaultFlags); 0134 0135 /** 0136 * Overload for catching code mistakes. Do NOT call this method (it is not implemented), 0137 * insert a value for permissions (-1 by default) before the JobFlags. 0138 */ 0139 FileCopyJob *file_move(const QUrl &src, const QUrl &dest, JobFlags flags) Q_DECL_EQ_DELETE; // not implemented - on purpose. 0140 0141 } 0142 0143 #endif