mirror of
https://github.com/unicode-org/icu.git
synced 2025-04-06 14:05:32 +00:00
ICU-21174 Increase safety of Measure and writeAffixes.
Measure: initialize unit to nullptr, and don't dereference it if it is nullptr. NumberFormatterImpl::writeAffixes: U_ASSERT not-null, instead of segfaulting for coding mistakes.
This commit is contained in:
parent
ee2d8b0103
commit
5d97c9f13e
2 changed files with 8 additions and 3 deletions
|
@ -23,7 +23,7 @@ U_NAMESPACE_BEGIN
|
|||
|
||||
UOBJECT_DEFINE_RTTI_IMPLEMENTATION(Measure)
|
||||
|
||||
Measure::Measure() {}
|
||||
Measure::Measure() : unit(nullptr) {}
|
||||
|
||||
Measure::Measure(const Formattable& _number, MeasureUnit* adoptedUnit,
|
||||
UErrorCode& ec) :
|
||||
|
@ -35,7 +35,7 @@ Measure::Measure(const Formattable& _number, MeasureUnit* adoptedUnit,
|
|||
}
|
||||
|
||||
Measure::Measure(const Measure& other) :
|
||||
UObject(other), unit(0) {
|
||||
UObject(other), unit(nullptr) {
|
||||
*this = other;
|
||||
}
|
||||
|
||||
|
@ -43,7 +43,11 @@ Measure& Measure::operator=(const Measure& other) {
|
|||
if (this != &other) {
|
||||
delete unit;
|
||||
number = other.number;
|
||||
unit = other.unit->clone();
|
||||
if (other.unit != nullptr) {
|
||||
unit = other.unit->clone();
|
||||
} else {
|
||||
unit = nullptr;
|
||||
}
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
|
|
|
@ -417,6 +417,7 @@ NumberFormatterImpl::resolvePluralRules(const PluralRules* rulesPtr, const Local
|
|||
|
||||
int32_t NumberFormatterImpl::writeAffixes(const MicroProps& micros, FormattedStringBuilder& string,
|
||||
int32_t start, int32_t end, UErrorCode& status) {
|
||||
U_ASSERT(micros.modOuter != nullptr);
|
||||
// Always apply the inner modifier (which is "strong").
|
||||
int32_t length = micros.modInner->apply(string, start, end, status);
|
||||
if (micros.padding.isValid()) {
|
||||
|
|
Loading…
Add table
Reference in a new issue