source: trunk/src/xmlpatterns/expr/qcombinenodes.cpp@ 98

Last change on this file since 98 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.5 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#include "qcommonsequencetypes_p.h"
43#include "qexceptiterator_p.h"
44#include "qgenericsequencetype_p.h"
45#include "qintersectiterator_p.h"
46#include "qitemmappingiterator_p.h"
47#include "qnodesort_p.h"
48#include "qunioniterator_p.h"
49
50#include "qcombinenodes_p.h"
51
52QT_BEGIN_NAMESPACE
53
54using namespace QPatternist;
55
56CombineNodes::CombineNodes(const Expression::Ptr &operand1,
57 const Operator op,
58 const Expression::Ptr &operand2) : PairContainer(operand1, operand2),
59 m_operator(op)
60{
61 Q_ASSERT(op == Union ||
62 op == Except ||
63 op == Intersect);
64}
65
66Item::Iterator::Ptr CombineNodes::evaluateSequence(const DynamicContext::Ptr &context) const
67{
68 const Item::Iterator::Ptr op1(m_operand1->evaluateSequence(context));
69 const Item::Iterator::Ptr op2(m_operand2->evaluateSequence(context));
70
71 switch(m_operator)
72 {
73 case Intersect:
74 return Item::Iterator::Ptr(new IntersectIterator(op1, op2));
75 case Except:
76 return Item::Iterator::Ptr(new ExceptIterator(op1, op2));
77 default:
78 {
79 Q_ASSERT(m_operator == Union);
80 return Item::Iterator::Ptr(new UnionIterator(op1, op2));
81 }
82 }
83}
84
85Item CombineNodes::evaluateSingleton(const DynamicContext::Ptr &context) const
86{
87 return evaluateSequence(context)->next();
88}
89
90Expression::Ptr CombineNodes::typeCheck(const StaticContext::Ptr &context,
91 const SequenceType::Ptr &reqType)
92{
93
94 const Expression::Ptr me(PairContainer::typeCheck(context, reqType));
95
96 m_operand1 = NodeSortExpression::wrapAround(m_operand1, context);
97 m_operand2 = NodeSortExpression::wrapAround(m_operand2, context);
98
99 return me;
100}
101
102bool CombineNodes::evaluateEBV(const DynamicContext::Ptr &context) const
103{
104 /* If it's the union operator, we can possibly avoid
105 * evaluating the second operand. */
106
107 if(m_operator == Union)
108 {
109 return m_operand1->evaluateEBV(context) ||
110 m_operand2->evaluateEBV(context);
111 }
112 else
113 return PairContainer::evaluateEBV(context);
114}
115
116QString CombineNodes::displayName(const Operator op)
117{
118 switch(op)
119 {
120 case Intersect:
121 return QLatin1String("intersect");
122 case Except:
123 return QLatin1String("except");
124 default:
125 {
126 Q_ASSERT(op == Union);
127 return QLatin1String("union");
128 }
129 }
130}
131
132SequenceType::Ptr CombineNodes::staticType() const
133{
134 const SequenceType::Ptr t1(m_operand1->staticType());
135 const SequenceType::Ptr t2(m_operand2->staticType());
136
137 Cardinality card;
138
139 /* Optimization: the cardinality can be better inferred for
140 * Intersect and Except, although it's not trivial code. */
141 if(m_operator == Union)
142 card = t1->cardinality() | t2->cardinality();
143 else /* Except. */
144 card = Cardinality::zeroOrMore();
145
146 return makeGenericSequenceType(t1->itemType() | t2->itemType(), card);
147}
148
149SequenceType::List CombineNodes::expectedOperandTypes() const
150{
151 SequenceType::List result;
152 result.append(CommonSequenceTypes::ZeroOrMoreNodes);
153 result.append(CommonSequenceTypes::ZeroOrMoreNodes);
154 return result;
155}
156
157CombineNodes::Operator CombineNodes::operatorID() const
158{
159 return m_operator;
160}
161
162ExpressionVisitorResult::Ptr CombineNodes::accept(const ExpressionVisitor::Ptr &visitor) const
163{
164 return visitor->visit(this);
165}
166
167Expression::ID CombineNodes::id() const
168{
169 return IDCombineNodes;
170}
171
172QT_END_NAMESPACE
Note: See TracBrowser for help on using the repository browser.