ICU 72.1 72.1
dcfmtsym.h
Go to the documentation of this file.
1// © 2016 and later: Unicode, Inc. and others.
2// License & terms of use: http://www.unicode.org/copyright.html
3/*
4********************************************************************************
5* Copyright (C) 1997-2016, International Business Machines
6* Corporation and others. All Rights Reserved.
7********************************************************************************
8*
9* File DCFMTSYM.H
10*
11* Modification History:
12*
13* Date Name Description
14* 02/19/97 aliu Converted from java.
15* 03/18/97 clhuang Updated per C++ implementation.
16* 03/27/97 helena Updated to pass the simple test after code review.
17* 08/26/97 aliu Added currency/intl currency symbol support.
18* 07/22/98 stephen Changed to match C++ style
19* currencySymbol -> fCurrencySymbol
20* Constants changed from CAPS to kCaps
21* 06/24/99 helena Integrated Alan's NF enhancements and Java2 bug fixes
22* 09/22/00 grhoten Marked deprecation tags with a pointer to replacement
23* functions.
24********************************************************************************
25*/
26
27#ifndef DCFMTSYM_H
28#define DCFMTSYM_H
29
30#include "unicode/utypes.h"
31
32#if U_SHOW_CPLUSPLUS_API
33
34#if !UCONFIG_NO_FORMATTING
35
36#include "unicode/uchar.h"
37#include "unicode/uobject.h"
38#include "unicode/locid.h"
39#include "unicode/numsys.h"
40#include "unicode/unum.h"
41#include "unicode/unistr.h"
42
49U_NAMESPACE_BEGIN
50
87public:
172#ifndef U_HIDE_INTERNAL_API
177#endif /* U_HIDE_INTERNAL_API */
179 kFormatSymbolCount = kExponentMultiplicationSymbol + 2
180 };
181
190 DecimalFormatSymbols(const Locale& locale, UErrorCode& status);
191
208 DecimalFormatSymbols(const Locale& locale, const NumberingSystem& ns, UErrorCode& status);
209
221
238
244
250
256
264 bool operator==(const DecimalFormatSymbols& other) const;
265
273 bool operator!=(const DecimalFormatSymbols& other) const { return !operator==(other); }
274
284 inline UnicodeString getSymbol(ENumberFormatSymbol symbol) const;
285
298 void setSymbol(ENumberFormatSymbol symbol, const UnicodeString &value, const UBool propagateDigits);
299
300#ifndef U_HIDE_INTERNAL_API
308 void setCurrency(const UChar* currency, UErrorCode& status);
309#endif // U_HIDE_INTERNAL_API
310
315 inline Locale getLocale() const;
316
323
341 UBool beforeCurrency,
342 UErrorCode& status) const;
354 UBool beforeCurrency,
355 const UnicodeString& pattern);
356
362 virtual UClassID getDynamicClassID() const override;
363
369 static UClassID U_EXPORT2 getStaticClassID();
370
371private:
373
386 void initialize(const Locale& locale, UErrorCode& success,
387 UBool useLastResortData = false, const NumberingSystem* ns = nullptr);
388
392 void initialize();
393
394public:
395
396#ifndef U_HIDE_INTERNAL_API
401 return fIsCustomCurrencySymbol;
402 }
403
408 return fIsCustomIntlCurrencySymbol;
409 }
410
414 inline UChar32 getCodePointZero() const {
415 return fCodePointZero;
416 }
417#endif /* U_HIDE_INTERNAL_API */
418
434 inline const UnicodeString& getConstSymbol(ENumberFormatSymbol symbol) const;
435
436#ifndef U_HIDE_INTERNAL_API
452 inline const UnicodeString& getConstDigitSymbol(int32_t digit) const;
453
458 inline const char16_t* getCurrencyPattern(void) const;
459#endif /* U_HIDE_INTERNAL_API */
460
461private:
476 UnicodeString fSymbols[kFormatSymbolCount];
477
481 UnicodeString fNoSymbol;
482
497 UChar32 fCodePointZero;
498
499 Locale locale;
500
501 char actualLocale[ULOC_FULLNAME_CAPACITY];
502 char validLocale[ULOC_FULLNAME_CAPACITY];
503 const char16_t* currPattern;
504
505 UnicodeString currencySpcBeforeSym[UNUM_CURRENCY_SPACING_COUNT];
506 UnicodeString currencySpcAfterSym[UNUM_CURRENCY_SPACING_COUNT];
507 UBool fIsCustomCurrencySymbol;
508 UBool fIsCustomIntlCurrencySymbol;
509};
510
511// -------------------------------------
512
513inline UnicodeString
514DecimalFormatSymbols::getSymbol(ENumberFormatSymbol symbol) const {
515 const UnicodeString *strPtr;
516 if(symbol < kFormatSymbolCount) {
517 strPtr = &fSymbols[symbol];
518 } else {
519 strPtr = &fNoSymbol;
520 }
521 return *strPtr;
522}
523
524// See comments above for this function. Not hidden with #ifdef U_HIDE_INTERNAL_API
525inline const UnicodeString &
526DecimalFormatSymbols::getConstSymbol(ENumberFormatSymbol symbol) const {
527 const UnicodeString *strPtr;
528 if(symbol < kFormatSymbolCount) {
529 strPtr = &fSymbols[symbol];
530 } else {
531 strPtr = &fNoSymbol;
532 }
533 return *strPtr;
534}
535
536#ifndef U_HIDE_INTERNAL_API
537inline const UnicodeString& DecimalFormatSymbols::getConstDigitSymbol(int32_t digit) const {
538 if (digit < 0 || digit > 9) {
539 digit = 0;
540 }
541 if (digit == 0) {
542 return fSymbols[kZeroDigitSymbol];
543 }
544 ENumberFormatSymbol key = static_cast<ENumberFormatSymbol>(kOneDigitSymbol + digit - 1);
545 return fSymbols[key];
546}
547#endif /* U_HIDE_INTERNAL_API */
548
549// -------------------------------------
550
551inline void
552DecimalFormatSymbols::setSymbol(ENumberFormatSymbol symbol, const UnicodeString &value, const UBool propagateDigits = true) {
553 if (symbol == kCurrencySymbol) {
554 fIsCustomCurrencySymbol = true;
555 }
556 else if (symbol == kIntlCurrencySymbol) {
557 fIsCustomIntlCurrencySymbol = true;
558 }
559 if(symbol<kFormatSymbolCount) {
560 fSymbols[symbol]=value;
561 }
562
563 // If the zero digit is being set to a known zero digit according to Unicode,
564 // then we automatically set the corresponding 1-9 digits
565 // Also record updates to fCodePointZero. Be conservative if in doubt.
566 if (symbol == kZeroDigitSymbol) {
567 UChar32 sym = value.char32At(0);
568 if ( propagateDigits && u_charDigitValue(sym) == 0 && value.countChar32() == 1 ) {
569 fCodePointZero = sym;
570 for ( int8_t i = 1 ; i<= 9 ; i++ ) {
571 sym++;
572 fSymbols[(int)kOneDigitSymbol+i-1] = UnicodeString(sym);
573 }
574 } else {
575 fCodePointZero = -1;
576 }
577 } else if (symbol >= kOneDigitSymbol && symbol <= kNineDigitSymbol) {
578 fCodePointZero = -1;
579 }
580}
581
582// -------------------------------------
583
584inline Locale
585DecimalFormatSymbols::getLocale() const {
586 return locale;
587}
588
589#ifndef U_HIDE_INTERNAL_API
590inline const char16_t*
591DecimalFormatSymbols::getCurrencyPattern() const {
592 return currPattern;
593}
594#endif /* U_HIDE_INTERNAL_API */
595
596U_NAMESPACE_END
597
598#endif /* #if !UCONFIG_NO_FORMATTING */
599
600#endif /* U_SHOW_CPLUSPLUS_API */
601
602#endif // _DCFMTSYM
603//eof
This class represents the set of symbols needed by DecimalFormat to format numbers.
Definition: dcfmtsym.h:86
void setPatternForCurrencySpacing(UCurrencySpacing type, UBool beforeCurrency, const UnicodeString &pattern)
Set pattern string for 'CurrencySpacing' that can be applied to currency format.
UBool isCustomCurrencySymbol() const
Definition: dcfmtsym.h:400
bool operator==(const DecimalFormatSymbols &other) const
Return true if another object is semantically equal to this one.
virtual ~DecimalFormatSymbols()
Destructor.
ENumberFormatSymbol
Constants for specifying a number format symbol.
Definition: dcfmtsym.h:92
@ kDecimalSeparatorSymbol
The decimal separator.
Definition: dcfmtsym.h:94
@ kPlusSignSymbol
The plus sign.
Definition: dcfmtsym.h:108
@ kMinusSignSymbol
The minus sign.
Definition: dcfmtsym.h:106
@ kExponentMultiplicationSymbol
Multiplication sign.
Definition: dcfmtsym.h:171
@ kInfinitySymbol
Infinity symbol.
Definition: dcfmtsym.h:122
@ kExponentialSymbol
The exponential symbol.
Definition: dcfmtsym.h:116
@ kPerMillSymbol
Per mill symbol - replaces kPermillSymbol.
Definition: dcfmtsym.h:118
@ kPatternSeparatorSymbol
The pattern separator.
Definition: dcfmtsym.h:98
@ kCurrencySymbol
The currency symbol.
Definition: dcfmtsym.h:110
@ kSignificantDigitSymbol
Significant digit symbol.
Definition: dcfmtsym.h:127
@ kIntlCurrencySymbol
The international currency symbol.
Definition: dcfmtsym.h:112
@ kMonetaryGroupingSeparatorSymbol
The monetary grouping separator.
Definition: dcfmtsym.h:131
@ kPadEscapeSymbol
Escape padding character.
Definition: dcfmtsym.h:120
@ kPercentSymbol
The percent sign.
Definition: dcfmtsym.h:100
@ kNaNSymbol
Nan symbol.
Definition: dcfmtsym.h:124
@ kApproximatelySignSymbol
Approximately sign.
Definition: dcfmtsym.h:176
@ kDigitSymbol
Character representing a digit in the pattern.
Definition: dcfmtsym.h:104
@ kMonetarySeparatorSymbol
The monetary separator.
Definition: dcfmtsym.h:114
@ kGroupingSeparatorSymbol
The grouping separator.
Definition: dcfmtsym.h:96
Locale getLocale(ULocDataLocaleType type, UErrorCode &status) const
Returns the locale for this object.
virtual UClassID getDynamicClassID() const override
ICU "poor man's RTTI", returns a UClassID for the actual class.
static UClassID getStaticClassID()
ICU "poor man's RTTI", returns a UClassID for this class.
DecimalFormatSymbols(UErrorCode &status)
Create a DecimalFormatSymbols object for the default locale.
const UnicodeString & getPatternForCurrencySpacing(UCurrencySpacing type, UBool beforeCurrency, UErrorCode &status) const
Get pattern string for 'CurrencySpacing' that can be applied to currency format.
DecimalFormatSymbols(const Locale &locale, UErrorCode &status)
Create a DecimalFormatSymbols object for the given locale.
DecimalFormatSymbols(const DecimalFormatSymbols &)
Copy constructor.
bool operator!=(const DecimalFormatSymbols &other) const
Return true if another object is semantically unequal to this one.
Definition: dcfmtsym.h:273
UChar32 getCodePointZero() const
Definition: dcfmtsym.h:414
DecimalFormatSymbols & operator=(const DecimalFormatSymbols &)
Assignment operator.
static DecimalFormatSymbols * createWithLastResortData(UErrorCode &status)
Creates a DecimalFormatSymbols object with last-resort data.
DecimalFormatSymbols(const Locale &locale, const NumberingSystem &ns, UErrorCode &status)
Creates a DecimalFormatSymbols instance for the given locale with digits and symbols corresponding to...
UBool isCustomIntlCurrencySymbol() const
Definition: dcfmtsym.h:407
void setCurrency(const UChar *currency, UErrorCode &status)
Loads symbols for the specified currency into this instance.
A Locale object represents a specific geographical, political, or cultural region.
Definition: locid.h:195
Defines numbering systems.
Definition: numsys.h:60
UObject is the common ICU "boilerplate" class.
Definition: uobject.h:223
UnicodeString is a string class that stores Unicode characters directly and provides similar function...
Definition: unistr.h:296
UChar32 char32At(int32_t offset) const
Return the code point that contains the code unit at offset offset.
int32_t countChar32(int32_t start=0, int32_t length=INT32_MAX) const
Count Unicode code points in the length char16_t code units of the string.
C++ API: Locale ID object.
U_EXPORT UBool operator==(const StringPiece &x, const StringPiece &y)
Global operator == for StringPiece.
C++ API: NumberingSystem object.
C API: Unicode Properties.
U_CAPI int32_t u_charDigitValue(UChar32 c)
Returns the decimal digit value of a decimal digit character.
#define ULOC_FULLNAME_CAPACITY
Useful constant for the maximum size of the whole locale ID (including the terminating NULL and all k...
Definition: uloc.h:264
ULocDataLocaleType
Constants for *_getLocale() Allow user to select whether she wants information on requested,...
Definition: uloc.h:338
int32_t UChar32
Define UChar32 as a type for single Unicode code points.
Definition: umachine.h:461
int8_t UBool
The ICU boolean type, a signed-byte integer.
Definition: umachine.h:269
char16_t UChar
The base type for UTF-16 code units and pointers.
Definition: umachine.h:412
C++ API: Unicode String.
C API: Compatibility APIs for number formatting.
UCurrencySpacing
Constants for specifying currency spacing.
Definition: unum.h:349
@ UNUM_CURRENCY_SPACING_COUNT
One more than the highest normal UCurrencySpacing value.
Definition: unum.h:364
C++ API: Common ICU base class UObject.
void * UClassID
UClassID is used to identify classes without using the compiler's RTTI.
Definition: uobject.h:96
Basic definitions for ICU, for both C and C++ APIs.
UErrorCode
Standard ICU4C error code type, a substitute for exceptions.
Definition: utypes.h:415
#define U_I18N_API
Set to export library symbols from inside the i18n library, and to import them from outside.
Definition: utypes.h:301