Front page | perl.perl5.porters |
Postings from December 2009
[perl #70938] octal version number funny parsing in use
Thread Next
From:
Zefram
Date:
December 1, 2009 00:41
Subject:
[perl #70938] octal version number funny parsing in use
Message ID:
rt-3.6.HEAD-12359-1259603204-1235.70938-75-0@perl.org
# New Ticket Created by Zefram
# Please include the string: [perl #70938]
# in the subject line of all future correspondence about this issue.
# <URL: http://rt.perl.org/rt3/Ticket/Display.html?id=70938 >
This is a bug report for perl from zefram@fysh.org,
generated with the help of perlbug 1.36 running under perl 5.10.0.
-----------------------------------------------------------------
[Please enter your report here]
$ perl -lwe 'use Time::HiRes 01.99; print "ok"'
ok
This is a funny result considering that Time::HiRes is at version 1.9719
on this system. Look at some related version numbers:
$ perl -lwe 'use Time::HiRes 1.99; print "ok"'
Time::HiRes version 1.99 required--this is only version 1.9719 at -e line 1.
BEGIN failed--compilation aborted at -e line 1.
$ perl -lwe 'use Time::HiRes 010.99; print "ok"'
Time::HiRes version 8 required--this is only version 1.9719 at -e line 1.
BEGIN failed--compilation aborted at -e line 1.
$ perl -lwe 'use Time::HiRes +01.99; print "ok"'
Time::HiRes version 199 required--this is only version 1.9719 at /usr/local/share/perl/5.10.0/Exporter/Heavy.pm line 123.
BEGIN failed--compilation aborted at -e line 1.
$ perl -lwe 'use Time::HiRes 1,99; print "ok"'
Time::HiRes version 99 required--this is only version 1.9719 at /usr/local/share/perl/5.10.0/Exporter/Heavy.pm line 123.
BEGIN failed--compilation aborted at -e line 1.
Apparently, in "01.99", the "01" is being interpreted as an octal number,
and the ".99" is being interpreted as "0.99" and being passed to import.
(You can't see the effect of the 0.99 in this sequence, but it's visible
if you write your own import.) This is unlike the parsing of "01.99"
in ordinary code, where it parses like "(01).(99)" and results in the
string "199". It's a confusing difference. Bug? Not sure.
[Please do not change anything below this line]
-----------------------------------------------------------------
---
Flags:
category=core
severity=low
---
Site configuration information for perl 5.10.0:
Configured by Debian Project at Fri Aug 28 22:30:10 UTC 2009.
Summary of my perl5 (revision 5 version 10 subversion 0) configuration:
Platform:
osname=linux, osvers=2.6.26-2-amd64, archname=i486-linux-gnu-thread-multi
uname='linux puccini 2.6.26-2-amd64 #1 smp fri aug 14 07:12:04 utc 2009 i686 gnulinux '
config_args='-Dusethreads -Duselargefiles -Dccflags=-DDEBIAN -Dcccdlflags=-fPIC -Darchname=i486-linux-gnu -Dprefix=/usr -Dprivlib=/usr/share/perl/5.10 -Darchlib=/usr/lib/perl/5.10 -Dvendorprefix=/usr -Dvendorlib=/usr/share/perl5 -Dvendorarch=/usr/lib/perl5 -Dsiteprefix=/usr/local -Dsitelib=/usr/local/share/perl/5.10.0 -Dsitearch=/usr/local/lib/perl/5.10.0 -Dman1dir=/usr/share/man/man1 -Dman3dir=/usr/share/man/man3 -Dsiteman1dir=/usr/local/man/man1 -Dsiteman3dir=/usr/local/man/man3 -Dman1ext=1 -Dman3ext=3perl -Dpager=/usr/bin/sensible-pager -Uafs -Ud_csh -Ud_ualarm -Uusesfio -Uusenm -DDEBUGGING=-g -Doptimize=-O2 -Duseshrplib -Dlibperl=libperl.so.5.10.0 -Dd_dosuid -des'
hint=recommended, useposix=true, d_sigaction=define
useithreads=define, usemultiplicity=define
useperlio=define, d_sfio=undef, uselargefiles=define, usesocks=undef
use64bitint=undef, use64bitall=undef, uselongdouble=undef
usemymalloc=n, bincompat5005=undef
Compiler:
cc='cc', ccflags ='-D_REENTRANT -D_GNU_SOURCE -DDEBIAN -fno-strict-aliasing -pipe -I/usr/local/include -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64',
optimize='-O2 -g',
cppflags='-D_REENTRANT -D_GNU_SOURCE -DDEBIAN -fno-strict-aliasing -pipe -I/usr/local/include'
ccversion='', gccversion='4.3.2', gccosandvers=''
intsize=4, longsize=4, ptrsize=4, doublesize=8, byteorder=1234
d_longlong=define, longlongsize=8, d_longdbl=define, longdblsize=12
ivtype='long', ivsize=4, nvtype='double', nvsize=8, Off_t='off_t', lseeksize=8
alignbytes=4, prototype=define
Linker and Libraries:
ld='cc', ldflags =' -L/usr/local/lib'
libpth=/usr/local/lib /lib /usr/lib /usr/lib64
libs=-lgdbm -lgdbm_compat -ldb -ldl -lm -lpthread -lc -lcrypt
perllibs=-ldl -lm -lpthread -lc -lcrypt
libc=/lib/libc-2.7.so, so=so, useshrplib=true, libperl=libperl.so.5.10.0
gnulibc_version='2.7'
Dynamic Linking:
dlsrc=dl_dlopen.xs, dlext=so, d_dlsymun=undef, ccdlflags='-Wl,-E'
cccdlflags='-fPIC', lddlflags='-shared -O2 -g -L/usr/local/lib'
Locally applied patches:
---
@INC for perl 5.10.0:
/etc/perl
/usr/local/lib/perl/5.10.0
/usr/local/share/perl/5.10.0
/usr/lib/perl5
/usr/share/perl5
/usr/lib/perl/5.10
/usr/share/perl/5.10
/usr/local/lib/site_perl
.
---
Environment for perl 5.10.0:
HOME=/home/zefram
LANG (unset)
LANGUAGE (unset)
LD_LIBRARY_PATH (unset)
LOGDIR (unset)
PATH=/home/zefram/pub/i686-pc-linux-gnu/bin:/home/zefram/pub/common/bin:/usr/bin:/usr/X11R6/bin:/bin:/usr/local/bin:/usr/games
PERL_BADLANG (unset)
SHELL=/usr/bin/zsh
Thread Next
-
[perl #70938] octal version number funny parsing in use
by Zefram