File indexing completed on 2025-10-19 04:21:02
0001 /* 0002 * Copyright (C) 2015 Dan Leinir Turthra Jensen <admin@leinir.dk> 0003 * 0004 * This library is free software; you can redistribute it and/or 0005 * modify it under the terms of the GNU Lesser General Public 0006 * License as published by the Free Software Foundation; either 0007 * version 2.1 of the License, or (at your option) version 3, or any 0008 * later version accepted by the membership of KDE e.V. (or its 0009 * successor approved by the membership of KDE e.V.), which shall 0010 * act as a proxy defined in Section 6 of version 3 of the license. 0011 * 0012 * This library is distributed in the hope that it will be useful, 0013 * but WITHOUT ANY WARRANTY; without even the implied warranty of 0014 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 0015 * Lesser General Public License for more details. 0016 * 0017 * You should have received a copy of the GNU Lesser General Public 0018 * License along with this library. If not, see <http://www.gnu.org/licenses/>. 0019 * 0020 */ 0021 0022 #ifndef KRARFILEENTRY_H 0023 #define KRARFILEENTRY_H 0024 0025 #include "KRar.h" 0026 /** 0027 * A KRarFileEntry represents a file in a rar archive. 0028 */ 0029 class KRarFileEntry : public KArchiveFile 0030 { 0031 public: 0032 /** 0033 * Creates a new rar file entry. Do not call this, KRar takes care of it. 0034 */ 0035 KRarFileEntry(KRar *rar, const QString &name, int access, const QDateTime &date, 0036 const QString &user, const QString &group, const QString &symlink, 0037 const QString &path, qint64 start, qint64 uncompressedSize, struct ar_archive_s* archive); 0038 0039 /** 0040 * Destructor. Do not call this. 0041 */ 0042 ~KRarFileEntry() override; 0043 0044 /// Header start: only used when writing, consequently not used (as we don't support writing) 0045 void setHeaderStart(qint64 headerstart); 0046 qint64 headerStart() const; 0047 0048 /// CRC: only used when writing, consequently not used (as we don't support writing) 0049 unsigned long crc32() const; 0050 void setCRC32(unsigned long crc32); 0051 0052 /// Name with complete path - KArchiveFile::name() is the filename only (no path) 0053 const QString &path() const; 0054 0055 /** 0056 * @return the content of this file. 0057 * Call data() with care (only once per file), this data isn't cached. 0058 */ 0059 QByteArray data() const override; 0060 0061 /** 0062 * This method returns a QIODevice to read the file contents. 0063 * This is obviously for reading only. 0064 * Note that the ownership of the device is being transferred to the caller, 0065 * who will have to delete it. 0066 * The returned device auto-opens (in readonly mode), no need to open it. 0067 */ 0068 QIODevice *createDevice() const override; 0069 0070 private: 0071 class Private; 0072 Private *const d; 0073 }; 0074 0075 #endif//KRARFILEENTRY_H 0076