Merge branch 'master' of scm.dev.nokia.troll.no:qt/oslo-staging-1 into master-integration
[qt-netbsd.git] / tools / qdoc3 / codechunk.h
blobe78873cf950a9ea4fc7e8a1ac924137bf0ae8ef1
1 /****************************************************************************
2 **
3 ** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
4 ** All rights reserved.
5 ** Contact: Nokia Corporation (qt-info@nokia.com)
6 **
7 ** This file is part of the tools applications of the Qt Toolkit.
8 **
9 ** $QT_BEGIN_LICENSE:LGPL$
10 ** No Commercial Usage
11 ** This file contains pre-release code and may not be distributed.
12 ** You may use this file in accordance with the terms and conditions
13 ** contained in the Technology Preview License Agreement accompanying
14 ** this package.
16 ** GNU Lesser General Public License Usage
17 ** Alternatively, this file may be used under the terms of the GNU Lesser
18 ** General Public License version 2.1 as published by the Free Software
19 ** Foundation and appearing in the file LICENSE.LGPL included in the
20 ** packaging of this file. Please review the following information to
21 ** ensure the GNU Lesser General Public License version 2.1 requirements
22 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
24 ** In addition, as a special exception, Nokia gives you certain additional
25 ** rights. These rights are described in the Nokia Qt LGPL Exception
26 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
28 ** If you have questions regarding the use of this file, please contact
29 ** Nokia at qt-info@nokia.com.
38 ** $QT_END_LICENSE$
40 ****************************************************************************/
43 codechunk.h
46 #ifndef CODECHUNK_H
47 #define CODECHUNK_H
49 #include <qstring.h>
51 QT_BEGIN_NAMESPACE
53 // ### get rid of that class
56 The CodeChunk class represents a tiny piece of C++ code.
58 The class provides convertion between a list of lexemes and a string. It adds
59 spaces at the right place for consistent style. The tiny pieces of code it
60 represents are data types, enum values, and default parameter values.
62 Apart from the piece of code itself, there are two bits of metainformation
63 stored in CodeChunk: the base and the hotspot. The base is the part of the
64 piece that may be a hypertext link. The base of
66 QMap<QString, QString>
68 is QMap.
70 The hotspot is the place the variable name should be inserted in the case of a
71 variable (or parameter) declaration. The base of
73 char * []
75 is between '*' and '[]'.
77 class CodeChunk
79 public:
80 CodeChunk();
81 CodeChunk( const QString& str );
83 void append( const QString& lexeme );
84 void appendHotspot();
86 bool isEmpty() const { return s.isEmpty(); }
87 QString toString() const;
88 QStringList toPath() const;
89 QString left() const { return s.left(hotspot == -1 ? s.length() : hotspot); }
90 QString right() const { return s.mid(hotspot == -1 ? s.length() : hotspot); }
92 private:
93 QString s;
94 int hotspot;
97 inline bool operator==( const CodeChunk& c, const CodeChunk& d ) {
98 return c.toString() == d.toString();
101 inline bool operator!=( const CodeChunk& c, const CodeChunk& d ) {
102 return !( c == d );
105 inline bool operator<( const CodeChunk& c, const CodeChunk& d ) {
106 return c.toString() < d.toString();
109 inline bool operator>( const CodeChunk& c, const CodeChunk& d ) {
110 return d < c;
113 inline bool operator<=( const CodeChunk& c, const CodeChunk& d ) {
114 return !( c > d );
117 inline bool operator>=( const CodeChunk& c, const CodeChunk& d ) {
118 return !( c < d );
121 QT_END_NAMESPACE
123 #endif