From: David Dyck Date: Wed, 4 Apr 2001 13:27:15 +0000 (-0700) Subject: bleadperl / hex ignores variable length and/or tr doesn't null terminate ( with... X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=6f894eade1cb03fcc18e4faa9e39f693bad68f34;p=p5sagit%2Fp5-mst-13.2.git bleadperl / hex ignores variable length and/or tr doesn't null terminate ( with patch) Message-ID: p4raw-id: //depot/perl@9573 --- diff --git a/pp.c b/pp.c index fde8473..9d96b94 100644 --- a/pp.c +++ b/pp.c @@ -2667,11 +2667,11 @@ PP(pp_hex) dSP; dTARGET; char *tmps; STRLEN argtype; - STRLEN n_a; + STRLEN len; - tmps = POPpx; + tmps = (SvPVx(POPs, len)); argtype = 1; /* allow underscores */ - XPUSHn(scan_hex(tmps, 99, &argtype)); + XPUSHn(scan_hex(tmps, len, &argtype)); RETURN; } @@ -2681,20 +2681,20 @@ PP(pp_oct) NV value; STRLEN argtype; char *tmps; - STRLEN n_a; + STRLEN len; - tmps = POPpx; - while (*tmps && isSPACE(*tmps)) - tmps++; + tmps = (SvPVx(POPs, len)); + while (*tmps && len && isSPACE(*tmps)) + tmps++, len--; if (*tmps == '0') - tmps++; + tmps++, len--; argtype = 1; /* allow underscores */ if (*tmps == 'x') - value = scan_hex(++tmps, 99, &argtype); + value = scan_hex(++tmps, --len, &argtype); else if (*tmps == 'b') - value = scan_bin(++tmps, 99, &argtype); + value = scan_bin(++tmps, --len, &argtype); else - value = scan_oct(tmps, 99, &argtype); + value = scan_oct(tmps, len, &argtype); XPUSHn(value); RETURN; }