From 50b775851ad4cdae41b05bd133683f8894500674 Mon Sep 17 00:00:00 2001 From: matz Date: Fri, 20 Feb 2004 10:03:47 +0000 Subject: * lib/irb/init.rb (IRB::IRB.parse_opts): add -I option to irb. [ruby-dev:39243] * sprintf.c (rb_f_sprintf): sign bit extension should not be done if FPLUS flag is specified. [ruby-list:39224] * sprintf.c (rb_f_sprintf): do not prepend dots for negative numbers if FZERO is specified. [ruby-dev:39218] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@5793 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- sprintf.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) (limited to 'sprintf.c') diff --git a/sprintf.c b/sprintf.c index 73282b88a2..6de45618c8 100644 --- a/sprintf.c +++ b/sprintf.c @@ -544,7 +544,7 @@ rb_f_sprintf(argc, argv) if (base == 10) { rb_warning("negative number for %%u specifier"); } - else if (!(flags&FPREC)) { + else if (!(flags&(FPREC|FZERO))) { strcpy(s, ".."); s += 2; } @@ -602,7 +602,7 @@ rb_f_sprintf(argc, argv) remove_sign_bits(++s, base); tmp = rb_str_new(0, 3+strlen(s)); t = RSTRING(tmp)->ptr; - if (!(flags&FPREC)) { + if (!(flags&(FPREC|FZERO))) { strcpy(t, ".."); t += 2; } @@ -660,7 +660,7 @@ rb_f_sprintf(argc, argv) else { char c; - if (bignum && !RBIGNUM(val)->sign) + if (!sign && bignum && !RBIGNUM(val)->sign) c = sign_bits(base, p); else c = '0'; -- cgit v1.2.3