~oif-team/ubuntu/natty/qt4-x11/xi2.1

« back to all changes in this revision

Viewing changes to src/xmlpatterns/type/qschematype_p.h

  • Committer: Bazaar Package Importer
  • Author(s): Alessandro Ghersi
  • Date: 2009-11-02 18:30:08 UTC
  • mfrom: (1.2.2 upstream)
  • mto: (15.2.5 experimental)
  • mto: This revision was merged to the branch mainline in revision 88.
  • Revision ID: james.westby@ubuntu.com-20091102183008-b6a4gcs128mvfb3m
Tags: upstream-4.6.0~beta1
ImportĀ upstreamĀ versionĀ 4.6.0~beta1

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
/****************************************************************************
2
2
**
3
3
** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
 
4
** All rights reserved.
4
5
** Contact: Nokia Corporation (qt-info@nokia.com)
5
6
**
6
7
** This file is part of the QtXmlPatterns module of the Qt Toolkit.
7
8
**
8
9
** $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.
 
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.
14
15
**
15
16
** GNU Lesser General Public License Usage
16
17
** Alternatively, this file may be used under the terms of the GNU Lesser
20
21
** ensure the GNU Lesser General Public License version 2.1 requirements
21
22
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22
23
**
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 http://www.qtsoftware.com/contact.
 
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.
 
27
**
 
28
** If you have questions regarding the use of this file, please contact
 
29
** Nokia at qt-info@nokia.com.
 
30
**
 
31
**
 
32
**
 
33
**
 
34
**
 
35
**
 
36
**
 
37
**
38
38
** $QT_END_LICENSE$
39
39
**
40
40
****************************************************************************/
57
57
#include "qxmlname.h"
58
58
 
59
59
template<typename N, typename M> class QHash;
 
60
template<typename N> class QList;
60
61
 
61
62
QT_BEGIN_HEADER
62
63
 
72
73
     * This is the base class of all data types in a W3C XML Schema.
73
74
     *
74
75
     * @ingroup Patternist_types
75
 
     * @author Frans Englich <fenglich@trolltech.com>
 
76
     * @author Frans Englich <frans.englich@nokia.com>
76
77
     */
77
78
    class SchemaType : public SchemaComponent
78
79
    {
80
81
 
81
82
        typedef QExplicitlySharedDataPointer<SchemaType> Ptr;
82
83
        typedef QHash<QXmlName, SchemaType::Ptr> Hash;
 
84
        typedef QList<SchemaType::Ptr> List;
83
85
 
84
86
        /**
85
87
         * Schema types are divided into different categories such as
117
119
            NoDerivation            = 16
118
120
        };
119
121
 
 
122
        /**
 
123
         * Describes the derivation constraints that are given by the 'final' or 'block' attributes.
 
124
         */
 
125
        enum DerivationConstraint
 
126
        {
 
127
            RestrictionConstraint = 1,
 
128
            ExtensionConstraint = 2,
 
129
            ListConstraint = 4,
 
130
            UnionConstraint = 8
 
131
        };
 
132
        Q_DECLARE_FLAGS(DerivationConstraints, DerivationConstraint)
 
133
 
120
134
        SchemaType();
121
135
        virtual ~SchemaType();
122
136
 
137
151
        virtual DerivationMethod derivationMethod() const = 0;
138
152
 
139
153
        /**
 
154
         * Determines what derivation constraints exists for the type.
 
155
         */
 
156
        virtual DerivationConstraints derivationConstraints() const = 0;
 
157
 
 
158
        /**
140
159
         * Determines whether the type is an abstract type.
141
160
         *
142
161
         * @note It is important a correct value is returned, since
202
221
         * @note Do not re-implement this function, but instead override category()
203
222
         * and let it return an appropriate value.
204
223
         */
205
 
        bool isSimpleType() const;
 
224
        virtual bool isSimpleType() const;
206
225
 
207
226
        /**
208
227
         * Determines whether the type is a complex type, by introspecting
211
230
         * @note Do not re-implement this function, but instead override category()
212
231
         * and let it return an appropriate value.
213
232
         */
214
 
        bool isComplexType() const;
 
233
        virtual bool isComplexType() const;
 
234
 
 
235
        /**
 
236
         * Returns whether the value has been defined by a schema (is not a built in type).
 
237
         */
 
238
        virtual bool isDefinedBySchema() const;
215
239
    };
 
240
 
 
241
    Q_DECLARE_OPERATORS_FOR_FLAGS(SchemaType::DerivationConstraints)
216
242
}
217
243
 
218
244
QT_END_NAMESPACE