ShellPkg/UefiShellLib: Accept "0 " as valid numeric string

InternalShellIsHexOrDecimalNumber() would fail to interpret e.g. "0 " or
"00 " as valid numeric strings. After skipping the "0" digits as
leading zeroes, it would check if the next character is a valid hex or
decimal digit, which would then fail on the terminating character.

Therefore return success if "leading" zeroes have been consumed and
there are no more characters.

InternalShellStrHexToUint64() would fail to interpret e.g. "0 " or "00 "
as valid numeric strings. After skipping the "0" digits as leading
zeroes, it would find itself surprised by the following space.

Restrict the "bad space" check to the case where it had just consumed
the "x" or "X" marker. Otherwise the space is fine (depending on
StopAtSpace either end of number or interspersed space) since there
were only zeroes so far.

REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3080

Signed-off-by: Tormod Volden <debian.tormod@gmail.com>
This commit is contained in:
Tormod Volden 2024-07-24 00:22:29 +02:00 committed by mergify[bot]
parent d63d5884d7
commit e99d532fd7

View File

@ -3894,6 +3894,10 @@ InternalShellIsHexOrDecimalNumber (
Hex = FALSE;
}
if ((*String == CHAR_NULL) && LeadingZero) {
return (TRUE);
}
//
// loop through the remaining characters and use the lib function
//
@ -4041,17 +4045,17 @@ InternalShellStrHexToUint64 (
// Skip the 'X'
//
String++;
//
// there is a space where there should't be
//
if (*String == L' ') {
return (EFI_INVALID_PARAMETER);
}
}
Result = 0;
//
// there is a space where there should't be
//
if (*String == L' ') {
return (EFI_INVALID_PARAMETER);
}
while (ShellIsHexaDecimalDigitCharacter (*String)) {
//
// If the Hex Number represented by String overflows according