Fixed padding bug of sprintf function

(cherry picked from commit 9f2cdfea82)
This commit is contained in:
Serhat 2020-10-01 23:06:12 +03:00 committed by Rémi Verschelde
parent 1a71792655
commit 09a8dd7b3b
No known key found for this signature in database
GPG key ID: C3336907360768E1
2 changed files with 4 additions and 3 deletions

View file

@ -4182,11 +4182,12 @@ String String::sprintf(const Array &values, bool *error) const {
int number_len = str.length(); int number_len = str.length();
// Padding. // Padding.
int pad_chars_count = (value < 0 || show_sign) ? min_chars - 1 : min_chars;
String pad_char = pad_with_zeroes ? String("0") : String(" "); String pad_char = pad_with_zeroes ? String("0") : String(" ");
if (left_justified) { if (left_justified) {
str = str.rpad(min_chars, pad_char); str = str.rpad(pad_chars_count, pad_char);
} else { } else {
str = str.lpad(min_chars, pad_char); str = str.lpad(pad_chars_count, pad_char);
} }
// Sign. // Sign.

View file

@ -767,7 +767,7 @@
Returns the integer modulus of [code]a/b[/code] that wraps equally in positive and negative. Returns the integer modulus of [code]a/b[/code] that wraps equally in positive and negative.
[codeblock] [codeblock]
for i in range(-3, 4): for i in range(-3, 4):
print("%2.0f %2.0f %2.0f" % [i, i % 3, posmod(i, 3)]) print("%2d %2d %2d" % [i, i % 3, posmod(i, 3)])
[/codeblock] [/codeblock]
Produces: Produces:
[codeblock] [codeblock]