1 /****************************************************************************
3 ** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4 ** All rights reserved.
5 ** Contact: Nokia Corporation (qt-info@nokia.com)
7 ** This file is part of the QtXmlPatterns module of the Qt Toolkit.
9 ** $QT_BEGIN_LICENSE:LGPL$
10 ** GNU Lesser General Public License Usage
11 ** This file may be used under the terms of the GNU Lesser General Public
12 ** License version 2.1 as published by the Free Software Foundation and
13 ** appearing in the file LICENSE.LGPL included in the packaging of this
14 ** file. Please review the following information to ensure the GNU Lesser
15 ** General Public License version 2.1 requirements will be met:
16 ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
18 ** In addition, as a special exception, Nokia gives you certain additional
19 ** rights. These rights are described in the Nokia Qt LGPL Exception
20 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
22 ** GNU General Public License Usage
23 ** Alternatively, this file may be used under the terms of the GNU General
24 ** Public License version 3.0 as published by the Free Software Foundation
25 ** and appearing in the file LICENSE.GPL included in the packaging of this
26 ** file. Please review the following information to ensure the GNU General
27 ** Public License version 3.0 requirements will be met:
28 ** http://www.gnu.org/copyleft/gpl.html.
31 ** Alternatively, this file may be used in accordance with the terms and
32 ** conditions contained in a signed written agreement between you and Nokia.
40 ****************************************************************************/
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.
52 #ifndef Patternist_Decimal_H
53 #define Patternist_Decimal_H
55 #include <private/qschemanumeric_p.h>
62 * Defined in QtCore's qlocale.cpp.
64 Q_CORE_EXPORT char *qdtoa(double d, int mode, int ndigits, int *decpt, int *sign, char **rve, char **resultp);
70 * @short Implements the value instance of the @c xs:decimal type.
72 * @author Frans Englich <frans.englich@nokia.com>
73 * @ingroup Patternist_xdm
74 * @todo Documentation is missing/incomplete
76 class Decimal : public Numeric
80 static Decimal::Ptr fromValue(const xsDecimal num);
83 * Creates a Decimal from the lexical representation of @c xs:decimal stored in
86 * A possible optimization is to create an Integer if the string ends
87 * with ".0". But this is not conformant. For example, the user writes N.0
88 * which according to the specification is an xs:decimal, but where the
89 * expression is, is an xs:integer is required. That would pass with
90 * such an optimization.
92 static AtomicValue::Ptr fromLexical(const QString &strNumeric);
95 * Gets the Effective %Boolean Value of this number.
97 * @returns @c false if the number is 0 or @c NaN, otherwise @c true.
99 bool evaluateEBV(const QExplicitlySharedDataPointer<DynamicContext> &) const;
101 virtual QString stringValue() const;
104 * @returns always BuiltinTypes::xsDecimal
106 virtual ItemType::Ptr type() const;
108 virtual xsDouble toDouble() const;
109 virtual xsInteger toInteger() const;
110 virtual xsFloat toFloat() const;
111 virtual xsDecimal toDecimal() const;
112 virtual qulonglong toUnsignedInteger() const;
114 virtual Numeric::Ptr round() const;
115 virtual Numeric::Ptr roundHalfToEven(const xsInteger scale) const;
116 virtual Numeric::Ptr floor() const;
117 virtual Numeric::Ptr ceiling() const;
118 virtual Numeric::Ptr abs() const;
121 * @returns always @c false, xs:decimal doesn't have
122 * not-a-number in its value space.
124 virtual bool isNaN() const;
127 * @returns always @c false, xs:decimal doesn't have
128 * infinity in its value space.
130 virtual bool isInf() const;
132 virtual Item toNegated() const;
135 * Converts @p value into a canonical string representation for @c xs:decimal. This
136 * function is used internally by various classes. Users probably wants to call
137 * stringValue() which in turn calls this function.
139 static QString toString(const xsDecimal value);
141 virtual bool isSigned() const;
145 Decimal(const xsDecimal num);
148 const xsDecimal m_value;