|
@@ -4637,15 +4637,18 @@ String String::sprintf(const Array &values, bool *error) const {
|
|
double value = values[value_index];
|
|
double value = values[value_index];
|
|
bool is_negative = (value < 0);
|
|
bool is_negative = (value < 0);
|
|
String str = String::num(ABS(value), min_decimals);
|
|
String str = String::num(ABS(value), min_decimals);
|
|
|
|
+ bool not_numeric = isinf(value) || isnan(value);
|
|
|
|
|
|
// Pad decimals out.
|
|
// Pad decimals out.
|
|
- str = str.pad_decimals(min_decimals);
|
|
|
|
|
|
+ if (!not_numeric) {
|
|
|
|
+ str = str.pad_decimals(min_decimals);
|
|
|
|
+ }
|
|
|
|
|
|
int initial_len = str.length();
|
|
int initial_len = str.length();
|
|
|
|
|
|
// Padding. Leave room for sign later if required.
|
|
// Padding. Leave room for sign later if required.
|
|
int pad_chars_count = (is_negative || show_sign) ? min_chars - 1 : min_chars;
|
|
int pad_chars_count = (is_negative || show_sign) ? min_chars - 1 : min_chars;
|
|
- String pad_char = pad_with_zeros ? String("0") : String(" ");
|
|
|
|
|
|
+ String pad_char = (pad_with_zeros && !not_numeric) ? String("0") : String(" "); // Never pad NaN or inf with zeros
|
|
if (left_justified) {
|
|
if (left_justified) {
|
|
str = str.rpad(pad_chars_count, pad_char);
|
|
str = str.rpad(pad_chars_count, pad_char);
|
|
} else {
|
|
} else {
|
|
@@ -4695,14 +4698,19 @@ String String::sprintf(const Array &values, bool *error) const {
|
|
String str = "(";
|
|
String str = "(";
|
|
for (int i = 0; i < count; i++) {
|
|
for (int i = 0; i < count; i++) {
|
|
double val = vec[i];
|
|
double val = vec[i];
|
|
|
|
+ String number_str = String::num(ABS(val), min_decimals);
|
|
|
|
+ bool not_numeric = isinf(val) || isnan(val);
|
|
|
|
+
|
|
// Pad decimals out.
|
|
// Pad decimals out.
|
|
- String number_str = String::num(ABS(val), min_decimals).pad_decimals(min_decimals);
|
|
|
|
|
|
+ if (!not_numeric) {
|
|
|
|
+ number_str = number_str.pad_decimals(min_decimals);
|
|
|
|
+ }
|
|
|
|
|
|
int initial_len = number_str.length();
|
|
int initial_len = number_str.length();
|
|
|
|
|
|
// Padding. Leave room for sign later if required.
|
|
// Padding. Leave room for sign later if required.
|
|
int pad_chars_count = val < 0 ? min_chars - 1 : min_chars;
|
|
int pad_chars_count = val < 0 ? min_chars - 1 : min_chars;
|
|
- String pad_char = pad_with_zeros ? String("0") : String(" ");
|
|
|
|
|
|
+ String pad_char = (pad_with_zeros && !not_numeric) ? String("0") : String(" "); // Never pad NaN or inf with zeros
|
|
if (left_justified) {
|
|
if (left_justified) {
|
|
number_str = number_str.rpad(pad_chars_count, pad_char);
|
|
number_str = number_str.rpad(pad_chars_count, pad_char);
|
|
} else {
|
|
} else {
|