You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
165 lines
6.6 KiB
165 lines
6.6 KiB
4 months ago
|
// © 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_FORMATIMPL_H__
|
||
|
#define __NUMBER_FORMATIMPL_H__
|
||
|
|
||
|
#include "number_types.h"
|
||
|
#include "formatted_string_builder.h"
|
||
|
#include "number_patternstring.h"
|
||
|
#include "number_usageprefs.h"
|
||
|
#include "number_utils.h"
|
||
|
#include "number_patternmodifier.h"
|
||
|
#include "number_longnames.h"
|
||
|
#include "number_compact.h"
|
||
|
#include "number_microprops.h"
|
||
|
#include "number_utypes.h"
|
||
|
|
||
|
U_NAMESPACE_BEGIN namespace number {
|
||
|
namespace impl {
|
||
|
|
||
|
/**
|
||
|
* This is the "brain" of the number formatting pipeline. It ties all the pieces together, taking in a MacroProps and a
|
||
|
* DecimalQuantity and outputting a properly formatted number string.
|
||
|
*/
|
||
|
class NumberFormatterImpl : public UMemory {
|
||
|
public:
|
||
|
/**
|
||
|
* Builds a "safe" MicroPropsGenerator, which is thread-safe and can be used repeatedly.
|
||
|
* The caller owns the returned NumberFormatterImpl.
|
||
|
*/
|
||
|
NumberFormatterImpl(const MacroProps ¯os, UErrorCode &status);
|
||
|
|
||
|
/**
|
||
|
* Builds and evaluates an "unsafe" MicroPropsGenerator, which is cheaper but can be used only once.
|
||
|
*/
|
||
|
static int32_t formatStatic(const MacroProps ¯os, UFormattedNumberData *results,
|
||
|
UErrorCode &status);
|
||
|
|
||
|
/**
|
||
|
* Prints only the prefix and suffix; used for DecimalFormat getters.
|
||
|
*
|
||
|
* @return The index into the output at which the prefix ends and the suffix starts; in other words,
|
||
|
* the prefix length.
|
||
|
*/
|
||
|
static int32_t getPrefixSuffixStatic(const MacroProps& macros, Signum signum,
|
||
|
StandardPlural::Form plural, FormattedStringBuilder& outString,
|
||
|
UErrorCode& status);
|
||
|
|
||
|
/**
|
||
|
* Evaluates the "safe" MicroPropsGenerator created by "fromMacros".
|
||
|
*/
|
||
|
int32_t format(UFormattedNumberData *results, UErrorCode &status) const;
|
||
|
|
||
|
/**
|
||
|
* Like format(), but saves the result into an output MicroProps without additional processing.
|
||
|
*/
|
||
|
void preProcess(DecimalQuantity& inValue, MicroProps& microsOut, UErrorCode& status) const;
|
||
|
|
||
|
/**
|
||
|
* Like getPrefixSuffixStatic() but uses the safe compiled object.
|
||
|
*/
|
||
|
int32_t getPrefixSuffix(Signum signum, StandardPlural::Form plural, FormattedStringBuilder& outString,
|
||
|
UErrorCode& status) const;
|
||
|
|
||
|
const MicroProps& getRawMicroProps() const {
|
||
|
return fMicros;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Synthesizes the output string from a MicroProps and DecimalQuantity.
|
||
|
* This method formats only the main number, not affixes.
|
||
|
*/
|
||
|
static int32_t writeNumber(const MicroProps& micros, DecimalQuantity& quantity,
|
||
|
FormattedStringBuilder& string, int32_t index, UErrorCode& status);
|
||
|
|
||
|
/**
|
||
|
* Adds the affixes. Intended to be called immediately after formatNumber.
|
||
|
*/
|
||
|
static int32_t writeAffixes(const MicroProps& micros, FormattedStringBuilder& string, int32_t start,
|
||
|
int32_t end, UErrorCode& status);
|
||
|
|
||
|
private:
|
||
|
// Head of the MicroPropsGenerator linked list. Subclasses' processQuantity
|
||
|
// methods process this list in a parent-first order, such that the last
|
||
|
// item added, which this points to, typically has its logic executed last.
|
||
|
const MicroPropsGenerator *fMicroPropsGenerator = nullptr;
|
||
|
|
||
|
// Tail of the list:
|
||
|
MicroProps fMicros;
|
||
|
|
||
|
// Other fields possibly used by the number formatting pipeline:
|
||
|
// TODO: Convert more of these LocalPointers to value objects to reduce the number of news?
|
||
|
LocalPointer<const UsagePrefsHandler> fUsagePrefsHandler;
|
||
|
LocalPointer<const UnitConversionHandler> fUnitConversionHandler;
|
||
|
LocalPointer<const DecimalFormatSymbols> fSymbols;
|
||
|
LocalPointer<const PluralRules> fRules;
|
||
|
LocalPointer<const ParsedPatternInfo> fPatternInfo;
|
||
|
LocalPointer<const ScientificHandler> fScientificHandler;
|
||
|
LocalPointer<MutablePatternModifier> fPatternModifier;
|
||
|
LocalPointer<ImmutablePatternModifier> fImmutablePatternModifier;
|
||
|
LocalPointer<LongNameHandler> fLongNameHandler;
|
||
|
// TODO: use a common base class that enables fLongNameHandler,
|
||
|
// fLongNameMultiplexer, and fMixedUnitLongNameHandler to be merged into one
|
||
|
// member?
|
||
|
LocalPointer<MixedUnitLongNameHandler> fMixedUnitLongNameHandler;
|
||
|
LocalPointer<const LongNameMultiplexer> fLongNameMultiplexer;
|
||
|
LocalPointer<const CompactHandler> fCompactHandler;
|
||
|
|
||
|
// Value objects possibly used by the number formatting pipeline:
|
||
|
struct Warehouse {
|
||
|
CurrencySymbols fCurrencySymbols;
|
||
|
} fWarehouse;
|
||
|
|
||
|
|
||
|
NumberFormatterImpl(const MacroProps ¯os, bool safe, UErrorCode &status);
|
||
|
|
||
|
MicroProps& preProcessUnsafe(DecimalQuantity &inValue, UErrorCode &status);
|
||
|
|
||
|
int32_t getPrefixSuffixUnsafe(Signum signum, StandardPlural::Form plural,
|
||
|
FormattedStringBuilder& outString, UErrorCode& status);
|
||
|
|
||
|
/**
|
||
|
* If rulesPtr is non-null, return it. Otherwise, return a PluralRules owned by this object for the
|
||
|
* specified locale, creating it if necessary.
|
||
|
*/
|
||
|
const PluralRules *
|
||
|
resolvePluralRules(const PluralRules *rulesPtr, const Locale &locale, UErrorCode &status);
|
||
|
|
||
|
/**
|
||
|
* Synthesizes the MacroProps into a MicroPropsGenerator. All information, including the locale, is encoded into the
|
||
|
* MicroPropsGenerator, except for the quantity itself, which is left abstract and must be provided to the returned
|
||
|
* MicroPropsGenerator instance.
|
||
|
*
|
||
|
* @see MicroPropsGenerator
|
||
|
* @param macros
|
||
|
* The {@link MacroProps} to consume. This method does not mutate the MacroProps instance.
|
||
|
* @param safe
|
||
|
* If true, the returned MicroPropsGenerator will be thread-safe. If false, the returned value will
|
||
|
* <em>not</em> be thread-safe, intended for a single "one-shot" use only. Building the thread-safe
|
||
|
* object is more expensive.
|
||
|
*/
|
||
|
const MicroPropsGenerator *
|
||
|
macrosToMicroGenerator(const MacroProps ¯os, bool safe, UErrorCode &status);
|
||
|
|
||
|
static int32_t
|
||
|
writeIntegerDigits(const MicroProps µs, DecimalQuantity &quantity, FormattedStringBuilder &string,
|
||
|
int32_t index, UErrorCode &status);
|
||
|
|
||
|
static int32_t
|
||
|
writeFractionDigits(const MicroProps µs, DecimalQuantity &quantity, FormattedStringBuilder &string,
|
||
|
int32_t index, UErrorCode &status);
|
||
|
};
|
||
|
|
||
|
} // namespace impl
|
||
|
} // namespace number
|
||
|
U_NAMESPACE_END
|
||
|
|
||
|
|
||
|
#endif //__NUMBER_FORMATIMPL_H__
|
||
|
|
||
|
#endif /* #if !UCONFIG_NO_FORMATTING */
|