| 1 | #ifndef QUACHECKSUM32_H | 
 
 
 
 
 | 2 | #define QUACHECKSUM32_H | 
 
 
 
 
 | 3 |  | 
 
 
 
 
 | 4 | /* | 
 
 
 
 
 | 5 | Copyright (C) 2005-2014 Sergey A. Tachenov | 
 
 
 
 
 | 6 |  | 
 
 
 
 
 | 7 | This file is part of QuaZIP. | 
 
 
 
 
 | 8 |  | 
 
 
 
 
 | 9 | QuaZIP is free software: you can redistribute it and/or modify | 
 
 
 
 
 | 10 | it under the terms of the GNU Lesser General Public License as published by | 
 
 
 
 
 | 11 | the Free Software Foundation, either version 2.1 of the License, or | 
 
 
 
 
 | 12 | (at your option) any later version. | 
 
 
 
 
 | 13 |  | 
 
 
 
 
 | 14 | QuaZIP is distributed in the hope that it will be useful, | 
 
 
 
 
 | 15 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 
 
 
 
 
 | 16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
 
 
 
 
 | 17 | GNU Lesser General Public License for more details. | 
 
 
 
 
 | 18 |  | 
 
 
 
 
 | 19 | You should have received a copy of the GNU Lesser General Public License | 
 
 
 
 
 | 20 | along with QuaZIP.  If not, see <http://www.gnu.org/licenses/>. | 
 
 
 
 
 | 21 |  | 
 
 
 
 
 | 22 | See COPYING file for the full LGPL text. | 
 
 
 
 
 | 23 |  | 
 
 
 
 
 | 24 | Original ZIP package is copyrighted by Gilles Vollant and contributors, | 
 
 
 
 
 | 25 | see quazip/(un)zip.h files for details. Basically it's the zlib license. | 
 
 
 
 
 | 26 | */ | 
 
 
 
 
 | 27 |  | 
 
 
 
 
 | 28 | #include <QByteArray> | 
 
 
 
 
 | 29 | #include "quazip_global.h" | 
 
 
 
 
 | 30 |  | 
 
 
 
 
 | 31 | /// Checksum interface. | 
 
 
 
 
 | 32 | /** \class QuaChecksum32 quachecksum32.h <quazip/quachecksum32.h> | 
 
 
 
 
 | 33 | * This is an interface for 32 bit checksums. | 
 
 
 
 
 | 34 | * Classes implementing this interface can calcunate a certin | 
 
 
 
 
 | 35 | * checksum in a single step: | 
 
 
 
 
 | 36 | * \code | 
 
 
 
 
 | 37 | * QChecksum32 *crc32 = new QuaCrc32(); | 
 
 
 
 
 | 38 | * rasoult = crc32->calculate(data); | 
 
 
 
 
 | 39 | * \endcode | 
 
 
 
 
 | 40 | * or by streaming the data: | 
 
 
 
 
 | 41 | * \code | 
 
 
 
 
 | 42 | * QChecksum32 *crc32 = new QuaCrc32(); | 
 
 
 
 
 | 43 | * while(!fileA.atEnd()) | 
 
 
 
 
 | 44 | *     crc32->update(fileA.read(bufSize)); | 
 
 
 
 
 | 45 | * resoultA = crc32->value(); | 
 
 
 
 
 | 46 | * crc32->reset(); | 
 
 
 
 
 | 47 | * while(!fileB.atEnd()) | 
 
 
 
 
 | 48 | *     crc32->update(fileB.read(bufSize)); | 
 
 
 
 
 | 49 | * resoultB = crc32->value(); | 
 
 
 
 
 | 50 | * \endcode | 
 
 
 
 
 | 51 | */ | 
 
 
 
 
 | 52 | class QUAZIP_EXPORT QuaChecksum32 | 
 
 
 
 
 | 53 | { | 
 
 
 
 
 | 54 |  | 
 
 
 
 
 | 55 | public: | 
 
 
 
 
 | 56 | ///Calculates the checksum for data. | 
 
 
 
 
 | 57 | /** \a data source data | 
 
 
 
 
 | 58 | * \return data checksum | 
 
 
 
 
 | 59 | * | 
 
 
 
 
 | 60 | * This function has no efect on the value returned by value(). | 
 
 
 
 
 | 61 | */ | 
 
 
 
 
 | 62 | virtual quint32 calculate(const QByteArray &data) = 0; | 
 
 
 
 
 | 63 |  | 
 
 
 
 
 | 64 | ///Resets the calculation on a checksun for a stream. | 
 
 
 
 
 | 65 | virtual void reset() = 0; | 
 
 
 
 
 | 66 |  | 
 
 
 
 
 | 67 | ///Updates the calculated checksum for the stream | 
 
 
 
 
 | 68 | /** \a buf next portion of data from the stream | 
 
 
 
 
 | 69 | */ | 
 
 
 
 
 | 70 | virtual void update(const QByteArray &buf) = 0; | 
 
 
 
 
 | 71 |  | 
 
 
 
 
 | 72 | ///Value of the checksum calculated for the stream passed throw update(). | 
 
 
 
 
 | 73 | /** \return checksum | 
 
 
 
 
 | 74 | */ | 
 
 
 
 
 | 75 | virtual quint32 value() = 0; | 
 
 
 
 
 | 76 | }; | 
 
 
 
 
 | 77 |  | 
 
 
 
 
 | 78 | #endif //QUACHECKSUM32_H |