blob: 22140a09afc95b09d148b9dc58e4732fe2ccb0fc (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
// © 2017 and later: Unicode, Inc. and others.
// License & terms of use: http://www.unicode.org/copyright.html
#include "unicode/utypes.h"
#if !UCONFIG_NO_FORMATTING
#ifndef __NUMBER_SCIENTIFIC_H__
#define __NUMBER_SCIENTIFIC_H__
#include "number_types.h"
U_NAMESPACE_BEGIN namespace number {
namespace impl {
// Forward-declare
class ScientificHandler;
class U_I18N_API ScientificModifier : public UMemory, public Modifier {
public:
ScientificModifier();
void set(int32_t exponent, const ScientificHandler *handler);
int32_t apply(FormattedStringBuilder &output, int32_t leftIndex, int32_t rightIndex,
UErrorCode &status) const override;
int32_t getPrefixLength() const override;
int32_t getCodePointCount() const override;
bool isStrong() const override;
bool containsField(Field field) const override;
void getParameters(Parameters& output) const override;
bool semanticallyEquivalent(const Modifier& other) const override;
private:
int32_t fExponent;
const ScientificHandler *fHandler;
};
class ScientificHandler : public UMemory, public MicroPropsGenerator, public MultiplierProducer {
public:
ScientificHandler(const Notation *notation, const DecimalFormatSymbols *symbols,
const MicroPropsGenerator *parent);
void
processQuantity(DecimalQuantity &quantity, MicroProps µs, UErrorCode &status) const override;
int32_t getMultiplier(int32_t magnitude) const override;
private:
const Notation::ScientificSettings fSettings;
const DecimalFormatSymbols *fSymbols;
const MicroPropsGenerator *fParent;
friend class ScientificModifier;
};
} // namespace impl
} // namespace number
U_NAMESPACE_END
#endif //__NUMBER_SCIENTIFIC_H__
#endif /* #if !UCONFIG_NO_FORMATTING */
|