source: trunk/src/xmlpatterns/functions/qpatternplatform_p.h@ 117

Last change on this file since 117 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 5.7 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information ([email protected])
5**
6** This file is part of the QtXmlPatterns module of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at [email protected].
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42//
43// W A R N I N G
44// -------------
45//
46// This file is not part of the Qt API. It exists purely as an
47// implementation detail. This header file may change from version to
48// version without notice, or even be removed.
49//
50// We mean it.
51
52#ifndef Patternist_PatternPlatform_H
53#define Patternist_PatternPlatform_H
54
55#include <QFlags>
56#include <QRegExp>
57
58#include "qfunctioncall_p.h"
59
60QT_BEGIN_HEADER
61
62QT_BEGIN_NAMESPACE
63
64namespace QPatternist
65{
66 /**
67 * @short Contains functionality for functions and expressions that
68 * uses regular expressions.
69 *
70 * @ingroup Patternist_utils
71 * @author Frans Englich <[email protected]>
72 */
73 class PatternPlatform : public FunctionCall
74 {
75 public:
76 /**
77 * @see <a href="http://www.w3.org/TR/xpath-functions/#flags">XQuery 1.0 and
78 * XPath 2.0 Functions and Operators, 7.6.1.1 Flags</a>
79 */
80 enum Flag
81 {
82 /**
83 * No flags are set. Default behavior is used.
84 */
85 NoFlags = 0,
86
87 /**
88 * Flag @c s
89 */
90 DotAllMode = 1,
91
92 /**
93 * Flag @c m
94 */
95 MultiLineMode = 2,
96
97 /**
98 * Flag @c i
99 */
100 CaseInsensitive = 4,
101
102 /**
103 * Flag @c x
104 */
105 SimplifyWhitespace = 8
106 };
107 typedef QFlags<Flag> Flags;
108
109 virtual Expression::Ptr compress(const StaticContext::Ptr &context);
110
111 /**
112 * Retrieves the pattern supplied in the arguments, taking care of compiling it,
113 * settings its flags, and everything else required for getting it ready to use. If an error
114 * occurs, an appropriate error is raised via @p context.
115 */
116 const QRegExp pattern(const DynamicContext::Ptr &context) const;
117
118 /**
119 * @returns the number of captures, also called parenthesized sub-expressions, the pattern has.
120 *
121 * If the pattern isn't precompiled, -1 is returned.
122 */
123 inline int captureCount() const;
124
125 protected:
126 /**
127 * @short This constructor is protected, because this class is supposed to be sub-classed.
128 *
129 * @param flagsPosition an index position specifying the operand containing the pattern
130 * flags.
131 */
132 PatternPlatform(const qint8 flagsPosition);
133
134 private:
135 /**
136 * Enum telling whether the flags, pattern, or both
137 * have been compiled at compile time.
138 */
139 enum PreCompiledPart
140 {
141 NoPart = 0,
142 PatternPrecompiled = 1,
143 FlagsPrecompiled = 2,
144 FlagsAndPattern = PatternPrecompiled | FlagsPrecompiled
145
146 };
147 typedef QFlags<PreCompiledPart> PreCompiledParts;
148
149 Q_DISABLE_COPY(PatternPlatform)
150
151 Flags parseFlags(const QString &flags,
152 const DynamicContext::Ptr &context) const;
153
154 QRegExp parsePattern(const QString &pattern,
155 const DynamicContext::Ptr &context) const;
156
157 static void applyFlags(const Flags flags, QRegExp &pattern);
158
159 /**
160 * The parts that have been pre-compiled at compile time.
161 */
162 PreCompiledParts m_compiledParts;
163 Flags m_flags;
164 QRegExp m_pattern;
165 const qint8 m_flagsPosition;
166 };
167
168 inline int PatternPlatform::captureCount() const
169 {
170 if(m_compiledParts.testFlag(PatternPrecompiled))
171 return m_pattern.numCaptures();
172 else
173 return -1;
174 }
175
176 Q_DECLARE_OPERATORS_FOR_FLAGS(PatternPlatform::Flags)
177}
178
179QT_END_NAMESPACE
180
181QT_END_HEADER
182
183#endif
Note: See TracBrowser for help on using the repository browser.