// Allow implicit conversion from char16_t* to UnicodeString for this file: // Helpful in toString methods and elsewhere. #define UNISTR_FROM_STRING_EXPLICIT
bool ScientificMatcher::match(StringSegment& segment, ParsedNumber& result, UErrorCode& status) const { // Only accept scientific notation after the mantissa. if (!result.seenNumber()) { returnfalse;
}
// Only accept one exponent per string. if (0 != (result.flags & FLAG_HAS_EXPONENT)) { returnfalse;
}
// First match the scientific separator, and then match another number after it. // NOTE: This is guarded by the smoke test; no need to check fExponentSeparatorString length again.
int32_t initialOffset = segment.getOffset();
int32_t overlap = segment.getCommonPrefixLength(fExponentSeparatorString); if (overlap == fExponentSeparatorString.length()) { // Full exponent separator match.
// First attempt to get a code point, returning true if we can't get one. if (segment.length() == overlap) { returntrue;
}
segment.adjustOffset(overlap);
// Allow ignorables before the sign. // Note: call site is guarded by the segment.length() check above. // Note: the ignorables matcher should not touch the result.
fIgnorablesMatcher.match(segment, result, status); if (segment.length() == 0) {
segment.setOffset(initialOffset); returntrue;
}
// Allow a sign, and then try to match digits.
int8_t exponentSign = 1; if (segment.startsWith(minusSignSet())) {
exponentSign = -1;
segment.adjustOffsetByCodePoint();
} elseif (segment.startsWith(plusSignSet())) {
segment.adjustOffsetByCodePoint();
} elseif (segment.startsWith(fCustomMinusSign)) {
overlap = segment.getCommonPrefixLength(fCustomMinusSign); if (overlap != fCustomMinusSign.length()) { // Partial custom sign match
segment.setOffset(initialOffset); returntrue;
}
exponentSign = -1;
segment.adjustOffset(overlap);
} elseif (segment.startsWith(fCustomPlusSign)) {
overlap = segment.getCommonPrefixLength(fCustomPlusSign); if (overlap != fCustomPlusSign.length()) { // Partial custom sign match
segment.setOffset(initialOffset); returntrue;
}
segment.adjustOffset(overlap);
}
// Return true if the segment is empty. if (segment.length() == 0) {
segment.setOffset(initialOffset); returntrue;
}
// Allow ignorables after the sign. // Note: call site is guarded by the segment.length() check above. // Note: the ignorables matcher should not touch the result.
fIgnorablesMatcher.match(segment, result, status); if (segment.length() == 0) {
segment.setOffset(initialOffset); returntrue;
}
// We are supposed to accept E0 after NaN, so we need to make sure result.quantity is available. bool wasBogus = result.quantity.bogus;
result.quantity.bogus = false; int digitsOffset = segment.getOffset(); bool digitsReturnValue = fExponentMatcher.match(segment, result, exponentSign, status);
result.quantity.bogus = wasBogus;
if (segment.getOffset() != digitsOffset) { // At least one exponent digit was matched.
result.flags |= FLAG_HAS_EXPONENT;
} else { // No exponent digits were matched
segment.setOffset(initialOffset);
} return digitsReturnValue;
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.