2 **********************************************************************
3 * Copyright (c) 2004-2014, International Business Machines
4 * Corporation and others. All Rights Reserved.
5 **********************************************************************
7 * Created: April 26, 2004
9 **********************************************************************
11 #ifndef __CURRENCYUNIT_H__
12 #define __CURRENCYUNIT_H__
14 #include "unicode/utypes.h"
16 #if !UCONFIG_NO_FORMATTING
18 #include "unicode/measunit.h"
22 * \brief C++ API: Currency Unit Information.
28 * A unit of currency, such as USD (U.S. dollars) or JPY (Japanese
29 * yen). This class is a thin wrapper over a UChar string that
30 * subclasses MeasureUnit, for use with Measure and MeasureFormat.
35 class U_I18N_API CurrencyUnit
: public MeasureUnit
{
38 * Construct an object with the given ISO currency code.
39 * @param isoCode the 3-letter ISO 4217 currency code; must not be
40 * NULL and must have length 3
41 * @param ec input-output error code. If the isoCode is invalid,
42 * then this will be set to a failing value.
45 CurrencyUnit(const UChar
* isoCode
, UErrorCode
&ec
);
51 CurrencyUnit(const CurrencyUnit
& other
);
57 CurrencyUnit
& operator=(const CurrencyUnit
& other
);
60 * Return a polymorphic clone of this object. The result will
61 * have the same class as returned by getDynamicClassID().
64 virtual UObject
* clone() const;
70 virtual ~CurrencyUnit();
73 * Returns a unique class ID for this object POLYMORPHICALLY.
74 * This method implements a simple form of RTTI used by ICU.
75 * @return The class ID for this object. All objects of a given
76 * class have the same class ID. Objects of other classes have
77 * different class IDs.
80 virtual UClassID
getDynamicClassID() const;
83 * Returns the class ID for this class. This is used to compare to
84 * the return value of getDynamicClassID().
85 * @return The class ID for all objects of this class.
88 static UClassID U_EXPORT2
getStaticClassID();
91 * Return the ISO currency code of this object.
94 inline const UChar
* getISOCurrency() const;
98 * The ISO 4217 code of this object.
103 inline const UChar
* CurrencyUnit::getISOCurrency() const {
109 #endif // !UCONFIG_NO_FORMATTING
110 #endif // __CURRENCYUNIT_H__