blob: e3b16280ceb1805387a8ff9f666e3dcf4efabf82 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
/**********************************************************************
** Copyright (C) 2000-2002 Trolltech AS. All rights reserved.
**
** This file is part of the Qtopia Environment.
**
** This file may be distributed and/or modified under the terms of the
** GNU General Public License version 2 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL included in the
** packaging of this file.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
** See http://www.trolltech.com/gpl/ for GPL licensing information.
**
** Contact info@trolltech.com if any conditions of this licensing are
** not clear to you.
**
**********************************************************************/
#ifndef QDAWG_H
#define QDAWG_H
#include <qstringlist.h>
class QIODevice;
class QDawgPrivate;
class QDawg {
public:
QDawg();
~QDawg();
bool readFile(const QString&); // may mmap
bool read(QIODevice* dev);
bool write(QIODevice* dev) const;
bool createFromWords(QIODevice* dev);
void createFromWords(const QStringList&);
QStringList allWords() const;
bool contains(const QString&) const;
int countWords() const;
// Unicode 0..3FFF; an offset can be used for other ranges
static const int nodebits=18;
class Node {
friend class QDawgPrivate;
uint let:(30-nodebits);
uint isword:1;
uint islast:1;
int offset:nodebits;
Node() { }
public:
QChar letter() const { return QChar((ushort)let); }
bool isWord() const { return isword; }
bool isLast() const { return islast; }
const Node* next() const { return islast ? 0 : this+1; }
const Node* jump() const { return offset ? this+offset : 0; }
};
const Node* root() const;
void dump() const; // debug
private:
friend class QDawgPrivate;
QDawgPrivate* d;
};
#endif
|