XQuilla/include/xqilla/items/impl/ATFloatOrDerivedImpl.hpp

162 lines
5.5 KiB
C++
Raw Normal View History

2020-02-17 21:05:20 +00:00
/*
2020-02-17 21:12:51 +00:00
* Copyright (c) 2001-2007
2020-02-17 21:05:20 +00:00
* DecisionSoft Limited. All rights reserved.
2020-02-17 21:12:51 +00:00
* Copyright (c) 2004-2007
2020-02-17 21:05:20 +00:00
* Oracle. All rights reserved.
*
2020-02-17 21:12:51 +00:00
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
2020-02-17 21:05:20 +00:00
*
2020-02-17 21:12:51 +00:00
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* $Id: ATFloatOrDerivedImpl.hpp,v 1.14 2007/11/28 13:13:24 jpcs Exp $
2020-02-17 21:05:20 +00:00
*/
#ifndef _ATFLOATORDERIVEDIMPL_HPP
#define _ATFLOATORDERIVEDIMPL_HPP
#include <xercesc/util/XercesDefs.hpp>
#include <xqilla/items/ATFloatOrDerived.hpp>
#include <xqilla/mapm/m_apm.h>
#include <xqilla/framework/XQillaExport.hpp>
class XQILLA_API ATFloatOrDerivedImpl : public ATFloatOrDerived
{
public:
/* constructor */
ATFloatOrDerivedImpl(const XMLCh* typeURI, const XMLCh* typeName, const XMLCh* value, const StaticContext* context);
/* constructor */
ATFloatOrDerivedImpl(const XMLCh* typeURI, const XMLCh* typeName, const MAPM value, const StaticContext* context);
/** destructor -- do nothing*/
virtual ~ATFloatOrDerivedImpl() { };
virtual void *getInterface(const XMLCh *name) const;
/* Get the name of the primitive type (basic type) of this type
* (ie "decimal" for xs:decimal) */
virtual const XMLCh* getPrimitiveTypeName() const;
/* Get the namespace URI for this type */
virtual const XMLCh* getTypeURI() const;
/* Get the name of this type (ie "integer" for xs:integer) */
virtual const XMLCh* getTypeName() const;
/* returns the XMLCh* (canonical) representation of this type */
virtual const XMLCh* asString(const DynamicContext* context) const;
/* Promote this to the given type, if possible */
2020-02-17 21:11:31 +00:00
virtual Numeric::Ptr promoteTypeIfApplicable(AnyAtomicType::AtomicObjectType typeIndex,
const DynamicContext* context) const;
2020-02-17 21:05:20 +00:00
/** Returns a Numeric object which is the sum of this and other */
virtual Numeric::Ptr add(const Numeric::Ptr &other, const DynamicContext* context) const;
/** Returns a Numeric object which is the difference of this and
* other */
virtual Numeric::Ptr subtract(const Numeric::Ptr &other, const DynamicContext* context) const;
/** Returns a Numeric object which is the product of this and other */
virtual Numeric::Ptr multiply(const Numeric::Ptr &other, const DynamicContext* context) const;
/** Returns a Numeric object which is the quotient of this and other */
virtual Numeric::Ptr divide(const Numeric::Ptr &other, const DynamicContext* context) const;
/** Returns the arithmetic product of its operands as a Numeric */
virtual Numeric::Ptr mod(const Numeric::Ptr &other, const DynamicContext* context) const;
/** Returns the floor of this Numeric */
virtual Numeric::Ptr floor(const DynamicContext* context) const;
/** Returns the ceiling of this Numeric */
virtual Numeric::Ptr ceiling(const DynamicContext* context) const;
/** Rounds this Numeric */
virtual Numeric::Ptr round(const DynamicContext* context) const;
/** Rounds this Numeric to the given precision, and rounds a half to even */
virtual Numeric::Ptr roundHalfToEven(const Numeric::Ptr &precision, const DynamicContext* context) const;
/** Returns the Additive inverse of this Numeric */
virtual Numeric::Ptr invert(const DynamicContext* context) const;
/** Does this Numeric have value 0? */
virtual bool isZero() const;
/** Is this Numeric negative? */
virtual bool isNegative() const;
/** Is this Numeric positive? */
virtual bool isPositive() const;
/* Is this xs:float not a number */
virtual bool isNaN() const;
/* Is this xs:float infinite? */
virtual bool isInfinite() const;
/* Get the primitive index associated with this type */
virtual AnyAtomicType::AtomicObjectType getPrimitiveTypeIndex() const;
/* Get the primitive index associated with this type */
static AnyAtomicType::AtomicObjectType getTypeIndex();
/* Get the primitive type name */
static const XMLCh* getPrimitiveName();
virtual const MAPM &asMAPM() const { return _float; }
virtual State getState() const { return _state; }
/* The significant digits */
static int g_nSignificantDigits;
static MAPM parseFloat(const XMLCh* const value, State &state);
private:
/* set the value of this decimal */
void setFloat(const XMLCh* const value);
/* returns a new infinity ATFloatOrDerived*/
ATFloatOrDerived::Ptr infinity(const DynamicContext* context) const;
/* returns a new negative infinity ATFloatOrDerived*/
ATFloatOrDerived::Ptr negInfinity(const DynamicContext* context) const;
/* returns a NaN ATFloatOrDerived*/
ATFloatOrDerived::Ptr notANumber(const DynamicContext* context) const;
/* returns a -0 ATFloatOrDerived*/
ATFloatOrDerived::Ptr negZero(const DynamicContext* context) const;
/*returns a ATFloatOrDerived of value value*/
ATFloatOrDerived::Ptr newFloat(MAPM value, const DynamicContext* context) const;
/*The value of this float*/
MAPM _float;
/* is it NaN, INF, NegINF, or just a float (NUM) */
State _state;
/* the name of this type */
const XMLCh* _typeName;
/* the uri of this type */
const XMLCh* _typeURI;
};
#endif // _ATFLOATORDERIVEDIMPL_HPP