• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2 *******************************************************************************
3 * Copyright (C) 1997-2014, International Business Machines
4 * Corporation and others. All Rights Reserved.
5 *******************************************************************************
6 */
7 
8 #ifndef NFRULE_H
9 #define NFRULE_H
10 
11 #include "unicode/rbnf.h"
12 
13 #if U_HAVE_RBNF
14 
15 #include "unicode/utypes.h"
16 #include "unicode/uobject.h"
17 #include "unicode/unistr.h"
18 #include "putilimp.h"
19 
20 U_NAMESPACE_BEGIN
21 
22 class FieldPosition;
23 class Formattable;
24 class NFRuleList;
25 class NFRuleSet;
26 class NFSubstitution;
27 class ParsePosition;
28 class PluralFormat;
29 class RuleBasedNumberFormat;
30 class UnicodeString;
31 
32 class NFRule : public UMemory {
33 public:
34 
35     enum ERuleType {
36         kNoBase = 0,
37         kNegativeNumberRule = -1,
38         kImproperFractionRule = -2,
39         kProperFractionRule = -3,
40         kMasterRule = -4,
41         kOtherRule = -5
42     };
43 
44     static void makeRules(UnicodeString& definition,
45                           const NFRuleSet* ruleSet,
46                           const NFRule* predecessor,
47                           const RuleBasedNumberFormat* rbnf,
48                           NFRuleList& ruleList,
49                           UErrorCode& status);
50 
51     NFRule(const RuleBasedNumberFormat* rbnf);
52     ~NFRule();
53 
54     UBool operator==(const NFRule& rhs) const;
55     UBool operator!=(const NFRule& rhs) const { return !operator==(rhs); }
56 
getType()57     ERuleType getType() const { return (ERuleType)(baseValue <= kNoBase ? (ERuleType)baseValue : kOtherRule); }
setType(ERuleType ruleType)58     void setType(ERuleType ruleType) { baseValue = (int32_t)ruleType; }
59 
getBaseValue()60     int64_t getBaseValue() const { return baseValue; }
61     void setBaseValue(int64_t value, UErrorCode& status);
62 
getDivisor()63     double getDivisor() const { return uprv_pow(radix, exponent); }
64 
65     void doFormat(int64_t number, UnicodeString& toAppendTo, int32_t pos, UErrorCode& status) const;
66     void doFormat(double  number, UnicodeString& toAppendTo, int32_t pos, UErrorCode& status) const;
67 
68     UBool doParse(const UnicodeString& text,
69                   ParsePosition& pos,
70                   UBool isFractional,
71                   double upperBound,
72                   Formattable& result) const;
73 
74     UBool shouldRollBack(double number) const;
75 
76     void _appendRuleText(UnicodeString& result) const;
77 
78     int32_t findTextLenient(const UnicodeString& str, const UnicodeString& key,
79                      int32_t startingAt, int32_t* resultCount) const;
80 
81 private:
82     void parseRuleDescriptor(UnicodeString& descriptor, UErrorCode& status);
83     void extractSubstitutions(const NFRuleSet* ruleSet, const UnicodeString &ruleText, const NFRule* predecessor, UErrorCode& status);
84     NFSubstitution* extractSubstitution(const NFRuleSet* ruleSet, const NFRule* predecessor, UErrorCode& status);
85 
86     int16_t expectedExponent() const;
87     int32_t indexOfAny(const UChar* const strings[]) const;
88     double matchToDelimiter(const UnicodeString& text, int32_t startPos, double baseValue,
89                             const UnicodeString& delimiter, ParsePosition& pp, const NFSubstitution* sub,
90                             double upperBound) const;
91     void stripPrefix(UnicodeString& text, const UnicodeString& prefix, ParsePosition& pp) const;
92 
93     int32_t prefixLength(const UnicodeString& str, const UnicodeString& prefix, UErrorCode& status) const;
94     UBool allIgnorable(const UnicodeString& str, UErrorCode& status) const;
95     int32_t findText(const UnicodeString& str, const UnicodeString& key,
96                      int32_t startingAt, int32_t* resultCount) const;
97 
98 private:
99     int64_t baseValue;
100     int32_t radix;
101     int16_t exponent;
102     UnicodeString ruleText;
103     NFSubstitution* sub1;
104     NFSubstitution* sub2;
105     const RuleBasedNumberFormat* formatter;
106     const PluralFormat* rulePatternFormat;
107 
108     NFRule(const NFRule &other); // forbid copying of this class
109     NFRule &operator=(const NFRule &other); // forbid copying of this class
110 };
111 
112 U_NAMESPACE_END
113 
114 /* U_HAVE_RBNF */
115 #endif
116 
117 // NFRULE_H
118 #endif
119 
120