cb267a4858d2e51c06854006e239d2c8e31a383b
[mdictionary] / src / plugins / stardict / StarDictReader.h
1 /*******************************************************************************
2
3     This file is part of mDictionary.
4
5     mDictionary is free software: you can redistribute it and/or modify
6     it under the terms of the GNU General Public License as published by
7     the Free Software Foundation, either version 3 of the License, or
8     (at your option) any later version.
9
10     mDictionary is distributed in the hope that it will be useful,
11     but WITHOUT ANY WARRANTY; without even the implied warranty of
12     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13     GNU General Public License for more details.
14
15     You should have received a copy of the GNU General Public License
16     along with mDictionary.  If not, see <http://www.gnu.org/licenses/>.
17
18     Copyright 2010 Comarch S.A.
19
20 *******************************************************************************/
21 /*!
22     \file StarDictReader.h
23     \author Mateusz Półrola <mateusz.polrola@comarch.pl>
24  */
25
26 #ifndef STARDICTREADER_H
27 #define STARDICTREADER_H
28
29 #include <QObject>
30
31 /*!
32     Abstract class used for reading stardict dict and idx files.
33     It allows to read all necessary data types used in parsing stardict files.
34 */
35 class StarDictReader : public QObject {
36     Q_OBJECT
37 public:
38     StarDictReader(QObject *parent = 0) : QObject(parent) {}
39     virtual ~StarDictReader() {}
40
41     /*!
42         Reads translations text from dict file.
43         \param offset 64-bit offset of translation in file, readed from idx file
44         \param len length of translation, readed from idx file too
45     */
46     virtual QByteArray readString(qint64 offset, qint32 len)=0;
47
48     /*!
49         Reads 32-bits integer value from file and convert it from BigEndian
50         to Little Endian
51     */
52     virtual qint32 readInt32BigEndian()=0;
53
54     /*!
55         Reads 64-bits integer value from file and convert it from BigEndian
56         to Little Endian
57     */
58     virtual qint64 readInt64BigEndian()=0;
59
60     //! Reads single string from file, end of string is marked as '\0' in file.
61     virtual QString readKeyword()=0;
62
63
64     //! Closing file;
65     virtual void close()=0;
66
67 protected:
68     /*!
69         Opens file
70         \returns true if file is opened or false otherwise
71     */
72     virtual bool open(QString file)=0;
73
74     //! Reads single char from file.
75     virtual QChar readChar()=0;
76
77 };
78
79 #endif // STARDICTREADER_H