This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
perl5.git
6 years agofix tainting of s/// with overloaded replacement
Zefram [Sun, 19 Nov 2017 09:15:53 +0000 (09:15 +0000)]
fix tainting of s/// with overloaded replacement

The substitution code was trying to track the taintedness of the
replacement string itself, but it didn't account for the replacement
being an untainted object with overloading that returns a tainted
stringification.  It looked at the taintedness of the object value, not
realising that taint could arise during the string concatenation per se.
Change the taint checks to look at the actual TAINT_get flag after string
concatenation.  This may falsely ascribe to the replacement taint that
actually came from somewhere else, but the end result is the same anyway:
there's no visible behaviour that distinguishes taint specifically from
the replacement.  Also remove a related taint check that seems to be
not needed at all.  Fixes [perl #115266].

6 years agofix other pod versions that had become out of date, and add reminder comments
Karen Etheridge [Sun, 19 Nov 2017 04:06:35 +0000 (20:06 -0800)]
fix other pod versions that had become out of date, and add reminder comments

6 years agofix Attribute::Handlers pod to match new $VERSION
Karen Etheridge [Sun, 19 Nov 2017 03:57:57 +0000 (19:57 -0800)]
fix Attribute::Handlers pod to match new $VERSION

..as the comment next to the $VERSION declaration reminds us to do

6 years agoperldelta for perluniprops change
Karl Williamson [Sun, 19 Nov 2017 02:44:47 +0000 (19:44 -0700)]
perldelta for perluniprops change

For commit 9b79e9e3431d11e79a4f85268f70130b7b4369f6

6 years agolocale.c: Use computed length for U+10FFFF
Karl Williamson [Sat, 18 Nov 2017 23:50:48 +0000 (16:50 -0700)]
locale.c: Use computed length for U+10FFFF

The previous commit calculates this and placed the result in a header
file.  This now uses the calculated value instead of a hard-coded "4",
which is incorrect on EBCDIC platforms.

6 years agoregen/unicode_constants.pl: Add U+10FFFF entry
Karl Williamson [Sat, 18 Nov 2017 23:43:40 +0000 (16:43 -0700)]
regen/unicode_constants.pl: Add U+10FFFF entry

We need the length of the UTF-8 for this code point elsewhere, and it
is different between ASCII and EBCDIC.

6 years agoSync cpan/Test-Simple with CPAN version 1.302111.
James E Keenan [Sat, 18 Nov 2017 20:48:18 +0000 (15:48 -0500)]
Sync cpan/Test-Simple with CPAN version 1.302111.

6 years agoUpstream has released Test-Simple with new t/Legacy/Tester/tbt_09do.t.
James E Keenan [Sat, 18 Nov 2017 20:33:32 +0000 (15:33 -0500)]
Upstream has released Test-Simple with new t/Legacy/Tester/tbt_09do.t.

Since that now matches what we have in blead, we no longer need to have a
CUSTOMIZED entry in Porting/Maintainers.pl.

6 years agoRestore ability to build on platforms without snprintf()
Aaron Crane [Sat, 18 Nov 2017 18:07:23 +0000 (18:07 +0000)]
Restore ability to build on platforms without snprintf()

C89 does not in fact define snprintf() or vsnprintf(), and we must therefore
probe for the existence of those functions before trying to use them.

khw++ for pointing out my earlier error.

This reverts part or all of each of the following commits:

13d66b05c6163c3514774d3d11da5f3950e97e98 Rely on C89 vsnprintf()
e791399041815a1a45cea3c7f277c7045b96e51b Rely on C89 snprintf()
adf7d503e55721c500f0bf66560b8f5df7966fe7 pod/perlhacktips.pod: remove some outdated portability notes

6 years agoPorting/checkcfgvar.pl: add missing config-symbol file
Aaron Crane [Sat, 18 Nov 2017 16:37:44 +0000 (16:37 +0000)]
Porting/checkcfgvar.pl: add missing config-symbol file

Cross/config.sh-arm-linux-n770 should probably have been added to the list
of config-symbol files when it was first added, and the fact that it wasn't
means that there are many symbols it doesn't list. In the absence of any
better information, I've defaulted them to the Cross/config.sh-arm-linux
values.

6 years agoRegenerate Porting/Glossary
Aaron Crane [Sat, 18 Nov 2017 15:51:12 +0000 (15:51 +0000)]
Regenerate Porting/Glossary

6 years agoRegenerate sample config files
Aaron Crane [Sat, 18 Nov 2017 15:47:00 +0000 (15:47 +0000)]
Regenerate sample config files

6 years agoRebuild Configure from current metaconfig
Aaron Crane [Sat, 18 Nov 2017 13:40:50 +0000 (13:40 +0000)]
Rebuild Configure from current metaconfig

Commit 46857622bdd8fff9558b66485f86ae4eb019ec55 of the metaconfig repo
reverts to the upstream version of i_sysmman.U, which has a slightly
different comment.

6 years agoPATCH: [perl #132463] perluniprops for \p{Word}
Karl Williamson [Sat, 18 Nov 2017 16:35:25 +0000 (09:35 -0700)]
PATCH: [perl #132463] perluniprops for \p{Word}

perluniprops was not updated to reflect the changes made to what
\p{Word} contains as of 5.18.  What was added was the code points that
have the Join_Control property, which, so far, only contain U+200C and
U+200D.  This commit uses Join Control instead of the hard-coded code
point numbers, so that when Unicode changes it, it automatically will
still be valid.

Thanks for spotting this.

6 years agofix perldelta formatting
Zefram [Fri, 17 Nov 2017 14:08:11 +0000 (14:08 +0000)]
fix perldelta formatting

Documentation changes get =items, not =head3s.

6 years agoclarify perlop description of binary "x"
Zefram [Fri, 17 Nov 2017 14:05:49 +0000 (14:05 +0000)]
clarify perlop description of binary "x"

[perl #132460]

6 years agorestore deparsing style for \&foo
Zefram [Fri, 17 Nov 2017 09:03:46 +0000 (09:03 +0000)]
restore deparsing style for \&foo

When deparsing a reference to a sub in the current package, other than in
a call expression, with "use strict 'vars'" in effect and no lexical sub
of the same name in scope, commit dd6661605fe0a54c602f2e55f875acfdcd330b79
accidentally changed the deparsing from "&main::foo" to "&foo".
Both deparsings are correct, and the short one arguably preferable.
In fact, the deparsing was originally of the short form, but changed to
the long form (probably accidentally) in Perl 5.21.7, when the deparser
started adding the package to distinguish package subs from lexical subs
of the same name.  Nevertheless, it was not the intention to change this
output in that edit, and it broke a CPAN module's tests.  Consequently,
this commit restores the long-form deparsing in this case.

6 years agorip out quicksort and sort algorithm control
Zefram [Fri, 17 Nov 2017 05:28:21 +0000 (05:28 +0000)]
rip out quicksort and sort algorithm control

[perl #119635]

6 years agoembed.fnc: Add X flag to newly private UTF16 fcns
Karl Williamson [Fri, 17 Nov 2017 05:28:49 +0000 (22:28 -0700)]
embed.fnc: Add X flag to newly private UTF16 fcns

The E flag added in cfd95a374972942cba5e8afc019dc6019815b45c needs
either the X flag or be private to its containing file.

Spotted by Craig Berry.

6 years agoSuppress warning in XS-APItest’s sniscow.t
Father Chrysostomos [Fri, 17 Nov 2017 04:07:27 +0000 (20:07 -0800)]
Suppress warning in XS-APItest’s sniscow.t

6 years agocorrectly error on -k "nonexistent" on Windows
Zefram [Fri, 17 Nov 2017 03:26:47 +0000 (03:26 +0000)]
correctly error on -k "nonexistent" on Windows

The file test operators for Unix permission bits were returning a blanket
false result on systems where the bit being tested for doesn't exist.
That's a sensible way to treat a nonexistent bit when statting a file,
but the false result was being returned without checking that the argument
actually refers to a file.  Remove the pre-stat checks for nonexistent
bits, so that we get the correct errors for non-files.  We still get a
blanket false result for nonexistent bits on files.

6 years agoPortability fix for Test::Simple 'do' test.
Craig A. Berry [Thu, 16 Nov 2017 21:01:56 +0000 (15:01 -0600)]
Portability fix for Test::Simple 'do' test.

Prepending './' to what might not be a Unix filespec can't be
relied on to work (and it definitely doesn't on VMS). So use the
functions File::Spec provides to do this portably.

N.B.  File::Spec->catfile() is smart enough not to prepend the
value of curdir() if it's already there.

6 years agoRemove UTF16 functions from public access
Karl Williamson [Wed, 15 Nov 2017 04:41:25 +0000 (21:41 -0700)]
Remove UTF16 functions from public access

See thread starting at
http://nntp.perl.org/group/perl.perl5.porters/247120

I don't believe this needs a perldelta, as the functions weren't
documented, hence are not supposed to be used, and in fact are not used
in cpan.

6 years agoprecise control over order tests are run in TEST
Yves Orton [Wed, 15 Nov 2017 21:27:19 +0000 (22:27 +0100)]
precise control over order tests are run in TEST

6 years agohandy.h: add a comment about perl_assert_ptr()
Yves Orton [Wed, 15 Nov 2017 21:26:48 +0000 (22:26 +0100)]
handy.h: add a comment about perl_assert_ptr()

6 years agoUse strict and warnings in stat.t
Dagfinn Ilmari Mannsåker [Thu, 16 Nov 2017 16:09:27 +0000 (16:09 +0000)]
Use strict and warnings in stat.t

Either one would have caught the error fixed by the previous commit.

6 years agoFix $$ variable usage in stat.t
Dagfinn Ilmari Mannsåker [Thu, 16 Nov 2017 16:08:43 +0000 (16:08 +0000)]
Fix $$ variable usage in stat.t

"$$_TEST" gets parsed as "${$_TEST}", which evaluates to the empty
string, because this test uses neither strict nor warnings.

6 years agoUse safer symlink name in stat.t.
Craig A. Berry [Thu, 16 Nov 2017 15:08:33 +0000 (09:08 -0600)]
Use safer symlink name in stat.t.

The file pattern TEST.symlink.$$ is an ambiguous filename on VMS
because the digits of the $$ could be construed as a version
number or as part of the filename proper, depending on various
environmental settings.  This would not cause stat.t to fail but
could prevent removal of the symlink.  Which would then cause
ext/File-Glob/t/basic.t to fail because it scans the t/ directory
for files match TES* and falls down when it finds files it does
not expect.

In principle this could cause trouble for parallel tests on any
platform if stat.t's detritus happens to be present while the
File::Glob tests are running.

Short of a major rethink of the test suite to stop tests from using
t/ as their personal playground, the safest bet seems to be to use
a filename that is unambiguous on VMS and will not collide with
tests expecting t/TEST to be the only file in that directory that
begins with 'TES'.

6 years agofix lvalue context for 4-arg substr
Zefram [Thu, 16 Nov 2017 14:56:11 +0000 (14:56 +0000)]
fix lvalue context for 4-arg substr

4-arg substr uses its first arg as an lvalue, but wasn't lvaluifying
it properly.  [perl #115258]

6 years agoI18N::Langinfo: Add note to pod
Karl Williamson [Thu, 16 Nov 2017 14:54:46 +0000 (07:54 -0700)]
I18N::Langinfo: Add note to pod

For the last several releases of Perl, the items listed in the note were
always those from the C locale, regardless of the real one.  Before
that, it was even more buggy, whether you got the C locale or the real
one was complicated.

6 years agodeparse trailing-colon barewords carefully
Zefram [Thu, 16 Nov 2017 11:01:34 +0000 (11:01 +0000)]
deparse trailing-colon barewords carefully

A bareword ending in "::" has one "::" suffix stripped upon parsing,
so when deparsing a glob name ending in "::" as a bareword it needs
another "::" added.  But this only applies to barewords, not to glob
names that follow sigils, so the deparser needs to distinguish between
contexts for glob names in some places where it previously did not.
Fixes [perl #113716].

This change supersedes the recent change about deparsing glob names in
the CORE stash.  Those glob names are now handled by suffixing "::",
and this suffix is only added in bareword contexts, making the handling
of the two unusual cases identical.

6 years agoclarify the pod for Perl_utf8_length()
David Mitchell [Thu, 16 Nov 2017 09:32:41 +0000 (09:32 +0000)]
clarify the pod for Perl_utf8_length()

It seemed to imply that the bytes making up the char were s..e; they're
actually s..(e-1).

NPD

6 years agoexpand code comment in perly.y
David Mitchell [Thu, 16 Nov 2017 09:23:53 +0000 (09:23 +0000)]
expand code comment in perly.y

ASSIGNOP includes mutators like += as well as basic assignment

NPD

6 years agodeparse ::CORE::foo barewords carefully
Zefram [Thu, 16 Nov 2017 07:04:32 +0000 (07:04 +0000)]
deparse ::CORE::foo barewords carefully

A bareword such as "::CORE::foo", where it refers to a GV, is liable to be
confused with the "CORE::foo" syntax, which can't refer to a GV but is a
way of supplying a keyword, and is illegal if the keyword doesn't exist.
Make sure to deparse it with the "::" prefix.  Fixes [perl #113714].

6 years agorip out CPAN-release cruft from B::Deparse
Zefram [Thu, 16 Nov 2017 06:51:32 +0000 (06:51 +0000)]
rip out CPAN-release cruft from B::Deparse

B::Deparse is distributed only with the core.  It has no need to be
portable between Perl versions or to have its own change log.

6 years agoadditional tests for registered warning categories
Zefram [Thu, 16 Nov 2017 04:43:17 +0000 (04:43 +0000)]
additional tests for registered warning categories

6 years agoIO::Handle - fix precedence issue
Nicolas R [Wed, 15 Nov 2017 17:23:18 +0000 (11:23 -0600)]
IO::Handle - fix precedence issue

This commits fixes remarks raised
during the 2017 p5h in Amsterdam.

- fix precedence issue with '=~'
- stop using indirect new calls for SelectSaver.

6 years agospelling
Karen Etheridge [Sat, 4 Nov 2017 18:29:25 +0000 (11:29 -0700)]
spelling

6 years agotabs to spaces in RMG
Karen Etheridge [Wed, 1 Nov 2017 21:26:44 +0000 (14:26 -0700)]
tabs to spaces in RMG

6 years agofix handling of registered warning categories
Zefram [Wed, 15 Nov 2017 17:41:29 +0000 (17:41 +0000)]
fix handling of registered warning categories

There were some problems arising from some warning bitsets being shorter
than others, which happens when registration of a new warning category
makes new bitsets longer.  Most obviously, if a scope used "use warnings
'all'" to turn on all warnings and then turned off some specific warnings,
then that scope wouldn't get warnings for subsequently-registered warning
categories, because its bitset doesn't extend to the bit controlling
the new category.  (If just "use warnings 'all'" was used, without any
customisation, then a special hack made that work for new categories.)
It was also possible for a longer bitset to get truncated by a warnings
pragma, because the bitset editing code assumed that all bitsets are
the same length.

To fix this, first the warning bits for the "all" category have to change
meaning.  Unlike all other warning categories, the bits for "all" used to
be set only when there were no warning categories disabled; disabling any
would also clear the "all" bits.  That was supporting the special hack
mentioned above that the all-warnings bitset work for new categories.
This exception is now removed, so the meaning of the "all" bits is now the
more obvious meaning, of indicating the default treatment that the scope
wants for warnings not falling into any category known to the bitset.
In warnings::warnif() et al, if the caller's bitset is found to be too
short to have a bit for the relevant category, then the setting for the
"all" category is used instead.

Because the length of a bitset is an integral number of bytes, but
only two bits are used per category, the length of a bitset doesn't
precisely indicate which categories had been registered by the time it
was constructed.  So the standard bitsets for the "all" category are
now always filled to their byte length, with bits set preemptively for
categories not yet registered that fall within the current bitset length.

When a warnings pragma operates on a bitset, it first expands it to the
preferred length, by duplicating the "all" bits for the categories covered
by the new length.  It is careful to maintain the length when combining
the bitset with the standard bitsets for categories.  When a bitset is
read from ${^WARNING_BITS} or from caller(), the standard pWARN_ALL
setting is no longer expanded by the core to $warnings::Bits{all},
because the core's short WARN_ALLstring will now be expanded correctly
just like any other bitset.

Fixes [perl #108778].

6 years agoProvide option to build with -D__USE_MINGW_ANSI_STDIO
Steve Hay [Wed, 15 Nov 2017 18:17:17 +0000 (18:17 +0000)]
Provide option to build with -D__USE_MINGW_ANSI_STDIO

This commit adapts and extends a patch from sisyphus1@optusnet.com.au on
perl #130447.

Note for the future: One of the MinGW/gcc developers has said that
explicitly defining __USE_MINGW_ANSI_STDIO in this way is not guaranteed
to work in the future, so we may have to pursue other options instead one
day: https://rt.perl.org/Ticket/Display.html?id=130447#txn-1461711

However, we already do this for "nvtype=long double" builds and it's
working fine so far, so it seems acceptable to allow the same thing for
"nvtype=double" builds for now.

6 years agoDynaLoader simplify parsing option rule
Nicolas R [Wed, 15 Nov 2017 16:04:29 +0000 (10:04 -0600)]
DynaLoader simplify parsing option rule

After review, comments & dumb benchmark.
Simply using a substitute for these two
'-L' and '-l' options parsing makes the code
easier to maintain.

The benchmark difference is pretty close, for
matching, non matching (short or long) strings.

6 years agoRemove use vars from B::Deparse
Todd Rinaldo [Sat, 11 Nov 2017 05:01:27 +0000 (23:01 -0600)]
Remove use vars from B::Deparse

RT 132429: This causes a slight change to the output value of ${^WARNING_BITS} due to
warnings::register not polluting introspection for B::Deparse.

6 years agoperldelta for commit 43b354f1e1
Steve Hay [Wed, 15 Nov 2017 17:27:38 +0000 (17:27 +0000)]
perldelta for commit 43b354f1e1

6 years agolib/perl5db.pl: don't dump argless args
David Mitchell [Wed, 15 Nov 2017 15:25:08 +0000 (15:25 +0000)]
lib/perl5db.pl: don't dump argless args

dump_trace() prints a stack backtrace - including caller args - by using
caller() and @DB::args.

However, if a sub is called using the '&foo;' argless mechanism, caller()
doesn't populate @DB::args, so it continues to hold whatever it was set
to previously. This might include SVs which have since been freed or
re-allocated.

So only display args for a particular caller depth if that sub was called
with args.

This was causing smoke failures in lib/perl5db.t when TERM was unset.
It only started failing recently, due I guess to subtle changes in what
SVs were left hanging about in @DB::args from a previous use of caller().

See http://nntp.perl.org/group/perl.perl5.porters/247032
    Subject: Smoke FAIL's for lib/perl5db.t

6 years agolib/perl5db.t: remove debugging code
David Mitchell [Wed, 15 Nov 2017 15:19:51 +0000 (15:19 +0000)]
lib/perl5db.t: remove debugging code

A spurious printf was inadvertently added by me with e05a85b2.

6 years agoImprove cl version detection
Steve Hay [Wed, 15 Nov 2017 14:07:42 +0000 (14:07 +0000)]
Improve cl version detection

Drop the use of the word "Version" so it works on non-English systems.
Instead, simply look for a number of the form X.Y (or X.Y.Z etc) with word
boundaries around it. Thus, we can find numbers like 12.00.8804 or
19.00.24213.1, but not accidentally pick up things like x86 or 1984-1998.

Also, drop the "--version" argument since it doesn't really exist and
causes warnings/errors to be output. A bare "cl" command suffices to get a
usage message including the version number to be output.

Finally, the Windows version detection can be similarly improved.

This fixes perl #132421.

6 years agoperldelta for stat(CLOSED) fix
Zefram [Wed, 15 Nov 2017 08:17:30 +0000 (08:17 +0000)]
perldelta for stat(CLOSED) fix

6 years agoset $! when statting a closed filehandle
Zefram [Wed, 15 Nov 2017 08:11:37 +0000 (08:11 +0000)]
set $! when statting a closed filehandle

When a stat fails because it's on a closed or otherwise invalid
filehandle, $! was often not being set, depending on the operation
and the nature of the invalidity.  Consistently set it to EBADF.
Fixes [perl #108288].

6 years agoPOSIX.pod: Add cautions about locale use
Karl Williamson [Wed, 15 Nov 2017 04:33:43 +0000 (21:33 -0700)]
POSIX.pod: Add cautions about locale use

6 years agolocale.c: Use mnemonic
Karl Williamson [Mon, 13 Nov 2017 05:29:58 +0000 (22:29 -0700)]
locale.c: Use mnemonic

Replace this number by an already existing mnemonic

6 years agoperldelta for the prev. commit
Father Chrysostomos [Wed, 15 Nov 2017 02:58:12 +0000 (18:58 -0800)]
perldelta for the prev. commit

6 years ago[perl #132442] Fix stack with do {my sub l; 1}
Father Chrysostomos [Wed, 15 Nov 2017 02:55:55 +0000 (18:55 -0800)]
[perl #132442] Fix stack with do {my sub l; 1}

A block in perl usually compiles to a leave op with an enter inside
it, followed by the statements:

   leave
     enter
     nextstate
     ... expr ...
     nextstate
     ... expr ...

If a block contains only one statement, and that statement is suffic-
iently innocuous, then the enter/leave pair to create the scope at run
time get skipped, and instead we have a simple scope op which is not
even executed:

   scope
     ex-nextstate
     ... expr ...

The nextstate in this case also gets nulled.

In the case of do { my sub l; 1 } we were getting a variation of the
latter, that looked like this:

   scope
     introcv
     clonecv
     nextstate
     ... expr ...

The problem here is that nextstate resets the stack, even though a new
scope has not been pushed, so we end up with all existing stack items
from the *outer* scope getting clobbered.

One can have fun with this and erase everything pushed on to the stack
so far in a given statement:

$ ./perl -le 'print join "-", 1..10, do {my sub l; ","}, 11..20'
11,12,13,14,15,16,17,18,19,20

Here I replaced the first argument to join() from within the do{}
block, after having cleared the stack.

Why was the op tree was getting muddled up like this?  The ‘my sub’
declaration does not immediately add any ops to the op tree; those ops
get added when the current scope finishing compiling, since those ops
must be inserted at the beginning of the block.

I have not fully looked into the order that things happen, and why the
nextstate op does not get nulled; but it did not matter, because of
the simple fix: Treat lexical sub declarations as ‘not innocuous’ by
setting the HINT_BLOCK_SCOPE flag when a lexical sub is declared.
Thus, we end up with an enter/leave pair, which creates a
proper scope.

6 years agoUpdate experimental.pm from 0.016 to 0.017
Sawyer X [Tue, 14 Nov 2017 20:44:28 +0000 (21:44 +0100)]
Update experimental.pm from 0.016 to 0.017

6 years agoperldelta for 6b93e4bc22a7c06508c3d2ed4590fe8bc2cb4989
James E Keenan [Tue, 14 Nov 2017 19:26:35 +0000 (14:26 -0500)]
perldelta for 6b93e4bc22a7c06508c3d2ed4590fe8bc2cb4989

6 years agoCompress-Raw-Zlib: sync with CPAN version 2.075
Paul Marquess [Tue, 14 Nov 2017 19:15:25 +0000 (14:15 -0500)]
Compress-Raw-Zlib: sync with CPAN version 2.075

https://rt.cpan.org/Ticket/Display.html?id=123245 reports a security
vulnerability in versions zlib 1.2.8 thru 1.2.10 of the zlib library.  Zlib is
bundled with Compress-Raw-Zlib, so any vulnerability reappears once
Compress-Raw-Zlib is shipped with Perl 5.  The vulnerability is present in
production releases up to and including perl-5.26.1.

To address this vulnerability, this commit upgrades us to the latest CPAN version.

6 years agoOP_MULTICONCAT: fix AIX
David Mitchell [Tue, 14 Nov 2017 13:27:59 +0000 (13:27 +0000)]
OP_MULTICONCAT: fix AIX

The OP_MULTICONCAT work broke AIX builds because it turns out that
PerlMemShared_malloc() isn't safe (in the sense of safemalloc());
i.e. on AIX, PerlMemShared_malloc(0) returns NULL.

6 years agoUpgrade libnet from version 3.10 to 3.11
Steve Hay [Tue, 14 Nov 2017 14:06:28 +0000 (14:06 +0000)]
Upgrade libnet from version 3.10 to 3.11

This includes https://github.com/steve-m-hay/perl-libnet/pull/32

6 years agoFix Windows build failure introduced by 7d00a3405c
Steve Hay [Tue, 14 Nov 2017 14:01:33 +0000 (14:01 +0000)]
Fix Windows build failure introduced by 7d00a3405c

6 years agoHandle empty list in Perl_vms_do_aexec.
Craig A. Berry [Tue, 14 Nov 2017 13:13:19 +0000 (07:13 -0600)]
Handle empty list in Perl_vms_do_aexec.

Since 2fcab33080e this is now expected and tested for, so do
what other platforms do.

6 years agomv "Truth and Falsehood" from perlsyn to perldata
Zefram [Tue, 14 Nov 2017 13:14:14 +0000 (13:14 +0000)]
mv "Truth and Falsehood" from perlsyn to perldata

This one-paragraph section didn't belong in perlsyn.  perldata already
had a paragraph on the topic; merge them.  [perl #115650]

6 years agofix newPVOP() doc re freeing of pv
Zefram [Tue, 14 Nov 2017 12:56:35 +0000 (12:56 +0000)]
fix newPVOP() doc re freeing of pv

[perl #127697]

6 years agoperldelta: typo
Aaron Crane [Tue, 14 Nov 2017 12:07:19 +0000 (12:07 +0000)]
perldelta: typo

Ilmari++

6 years agoperldelta: C89 requirement
Aaron Crane [Tue, 14 Nov 2017 11:51:01 +0000 (11:51 +0000)]
perldelta: C89 requirement

6 years agofix naming of some test temp files
Zefram [Tue, 14 Nov 2017 09:49:11 +0000 (09:49 +0000)]
fix naming of some test temp files

The files should be named t/tmp*, to fall under .gitignore and be ignored
by podcheck.

6 years agofix ext/B/t/optree_specials.t
David Mitchell [Tue, 14 Nov 2017 08:55:53 +0000 (08:55 +0000)]
fix ext/B/t/optree_specials.t

recent changes to expected output didn't account for the way nextstate ops
change their hints display when run under

    LC_ALL=en_US.UTF-8 PERL_UNICODE=""

One day we'll make this automatic.

6 years agostop unused-var warnings in ExtUtils-ParseXS tests
Zefram [Tue, 14 Nov 2017 08:49:16 +0000 (08:49 +0000)]
stop unused-var warnings in ExtUtils-ParseXS tests

These are warnings resulting from unusual features of the specific XS
code in the test suite, not from XS compilation in general.

6 years agoavoid unused-var warnings in compiled XS
Zefram [Tue, 14 Nov 2017 08:45:55 +0000 (08:45 +0000)]
avoid unused-var warnings in compiled XS

Code generated by ExtUtils-ParseXS for certain kinds of XS sub
was creating an "items" variable and never using it, resulting in
distracting warnings from the C compiler.  Add "PERL_UNUSED_VAR(items)"
where appropriate.

6 years agorip out Perl version portability from B
Zefram [Tue, 14 Nov 2017 07:48:03 +0000 (07:48 +0000)]
rip out Perl version portability from B

B is distributed only with the core, not dual-life, so has no need to
be portable between Perl versions.

6 years agoin B::Concise, show RV target better
Zefram [Tue, 14 Nov 2017 06:40:15 +0000 (06:40 +0000)]
in B::Concise, show RV target better

Especially show the identity of CVs where possible.  This is important
now that gv ops often point at a coderef rather than a glob.  Fixes [perl

6 years agoIntroduce macros to simplify @INC setting
Nicolas R [Tue, 7 Nov 2017 22:10:45 +0000 (16:10 -0600)]
Introduce macros to simplify @INC setting

Distro trends to customize @INC, and to maintain
patches to change the order of @INC or add custom entries.

The goal of this patch is to abstract calls to 'S_incpush_use_sep'
and simplify reordering @INC.

This commit makes the code from perl.c more comfortable to read
by introducing several 'INCPUSH_*' macros for every
'S_incpush_use_sep' call so we can easily reorder them.

6 years agoStorable: remove Config dependency
Nicolas R [Tue, 7 Nov 2017 18:22:27 +0000 (12:22 -0600)]
Storable: remove Config dependency

RT #132406

Avoid loading Config/Config_heavy from Storable.

Make Storable.pm a template file and check
if the system can use flock at compile time.

__Storable__.pm is the template file to edit,
whereas Storable.pm.PL is the script generating
Storable.pm from __Storable__.pm.

Using a separate file for the template make it
easier to edit.

Also note that Storable.pm is now ignored by git.

6 years agoTime::HiRes disable a flapping test for CI
Nicolas R [Mon, 13 Nov 2017 22:40:31 +0000 (16:40 -0600)]
Time::HiRes disable a flapping test for CI

When running this test under heavy load
we cannot assume the delta between two system calls...
even when using a (nano)sleep

Most Continuous Integration system will fail on this
test at one point or the other.

6 years agoMake perlbug.t forgiving about newlines.
Craig A. Berry [Tue, 14 Nov 2017 00:52:38 +0000 (18:52 -0600)]
Make perlbug.t forgiving about newlines.

On VMS, pipes often introduce extra newlines, so the test
infrastructure deduplicates them, which then makes it impossible
to check for more than one.  So just check for one or more.

6 years agotravis.yaml: fixes for osx
Nicolas R [Mon, 13 Nov 2017 21:04:38 +0000 (15:04 -0600)]
travis.yaml: fixes for osx

run brew update before installing ccache
use TRAVIS_OS_NAME macro to check os

6 years agoAdjust porting/authors.t for travisci
Nicolas R [Mon, 13 Nov 2017 19:54:49 +0000 (13:54 -0600)]
Adjust porting/authors.t for travisci

Add plan to porting/authors.t
skip_plan was used but no plan or tap output was defined.

When the test is run by TravisCI, use a shorten
revision range. We do not want to have a pull request impacted
by the previous state of blead, and we do not want to check
the merge commit from travis which is using the github author
primary email address.

6 years agoRemove win32 logic from t/porting/authors.t
Nicolas R [Mon, 13 Nov 2017 15:34:16 +0000 (09:34 -0600)]
Remove win32 logic from t/porting/authors.t

Remove special logic for windows by using 'qx'.
Allow test to be run from main root directory.

6 years agoSwitch some core modules to XSLoader
Nicolas R [Wed, 13 Sep 2017 17:22:32 +0000 (11:22 -0600)]
Switch some core modules to XSLoader

RT 132080: Remove perl 5.006 compatibilities with DynaLoader and use
XSLoader directly.

The traditional boiler plate to use XSLoader for Perl > 5.006 or
DynaLoader, does not make sense for core modules in perl 5.28+.

6 years agoTrack Unicode-Normalize Changes file so it can be updated as it is changed in Perl
Todd Rinaldo [Mon, 13 Nov 2017 20:08:11 +0000 (14:08 -0600)]
Track Unicode-Normalize Changes file so it can be updated as it is changed in Perl

6 years agoTweak travis.yml: ccache & notifications
Nicolas R [Mon, 13 Nov 2017 19:44:10 +0000 (13:44 -0600)]
Tweak travis.yml: ccache & notifications

- builds are now using ccache
- use multiline syntax for main script
- irc notifications are now enabled and sent to #p5p-qa channel

6 years agoMakefile.SH: factorize install.html target
Nicolas R [Wed, 8 Nov 2017 17:18:51 +0000 (10:18 -0700)]
Makefile.SH: factorize install.html target

Avoid duplicate definition of install.man and install.html
targets. We could then use in a later commit a Configure option
to disable doc installation on demand.

6 years agoUpdate Unicode-Collate to CPAN version 1.23
Chris 'BinGOs' Williams [Mon, 13 Nov 2017 13:45:36 +0000 (13:45 +0000)]
Update Unicode-Collate to CPAN version 1.23

  [DELTA]

1.23  Mon Nov 13 19:10:28 2017
    - Now UCA_Version 36 (for Unicode 10.0.0) is supported.
      * But the default UCA_Version is still 34.
    - added nushu.t in t.

1.22  Sat Nov 11 10:53:35 2017
    - internal: someone suggests using 'exists' for checking the truth of
      $collator->{mapping}{$variable} and $collator->{maxlength}{$variable},
      where $variable may stand for codepoints whose mapping is not defined;
      though such a problem was not reproduced on my environment.

6 years agoFix sentence in perlobj.pod (missing a word)
Matthew Horsfall [Mon, 13 Nov 2017 14:34:02 +0000 (09:34 -0500)]
Fix sentence in perlobj.pod (missing a word)

Reported by geospeck

6 years agolocalise $@ around source filters
Zefram [Mon, 13 Nov 2017 13:30:36 +0000 (13:30 +0000)]
localise $@ around source filters

$@ could be clobbered by source filters, screwing up the reporting of
errors in the filtered source.  Prevent this by localising $@ around
each call to a source filter.  Fixes [perl #38920].

6 years agochange OP_MULTICONCAT nargs from UV to SSize_t
David Mitchell [Mon, 13 Nov 2017 11:50:14 +0000 (11:50 +0000)]
change OP_MULTICONCAT nargs from UV to SSize_t

Change it from unsigned to unsigned since it makes the SP-adjusting code
in pp_multiconcat easier without hitting undefined behaviour (RT #132390);
and change its size from UV to SSize_t since it represents the number
of args  on the stack.

6 years agorename op_aux field from 'size' to 'ssize'
David Mitchell [Mon, 13 Nov 2017 11:03:15 +0000 (11:03 +0000)]
rename op_aux field from 'size' to 'ssize'

This part of the op_aux union was added for OP_MULTICONCAT; its actually
of type SSize_t, so rename it to ssize to better reflect that it's signed.

This should make no functional difference.

6 years agoconfigpm: fix duplicate 'our' declaration
David Mitchell [Mon, 13 Nov 2017 09:18:07 +0000 (09:18 +0000)]
configpm: fix duplicate 'our' declaration

This file of old incorrectly had both

    use vars '$Config_SH_expanded';

and

    our $Config_SH_expanded;

lines. After a recent commit which did s/use vars/our/g, the duplicate
'our' declaration started warning.

6 years agoDo not (attempt to) install man pages when explicitly disabled
H.Merijn Brand [Mon, 13 Nov 2017 08:03:40 +0000 (09:03 +0100)]
Do not (attempt to) install man pages when explicitly disabled

Configure … -Dman1dir=none -Dman3dir=none …



installman1dir=''
installman3dir=''

6 years agoavoid redundant initialisation around Newxz()
Zefram [Mon, 13 Nov 2017 07:52:35 +0000 (07:52 +0000)]
avoid redundant initialisation around Newxz()

Reduce Newxz() to Newx() where all relevant parts of the memory are
being explicitly initialised, and don't explicitly zero memory that was
already zeroed.  [perl #36078]

6 years agoremove unused struct member "is_top_frame"
Zefram [Mon, 13 Nov 2017 07:49:13 +0000 (07:49 +0000)]
remove unused struct member "is_top_frame"

6 years agoduplicate full index for SAVEt_AELEM
Zefram [Mon, 13 Nov 2017 07:45:35 +0000 (07:45 +0000)]
duplicate full index for SAVEt_AELEM

The index in a SAVEt_AELEM save entry is now IV-sized, but only an I32
portion of it was being duplicated.  This would lead to restoring the
wrong element if a pseudfork were done with a localised array element
on the stack, if the array index were above the 32-bit range or on a
big-endian architecture.

6 years agofix sysconf panic
Zefram [Mon, 13 Nov 2017 01:07:00 +0000 (01:07 +0000)]
fix sysconf panic

If sysconf() failed to provide the page size, there was an attempt to
panic with an error message.  But rather than generate an error message
from errno, the code would attempt to read it from ERRSV.  Not only had
nothing put the error message into ERRSV, but the glob behind ERRSV
didn't even exist yet, so attempting to evaluate ERRSV would segv.
Change this to use Strerror() and never touch ERRSV.  [perl #115880]

6 years agoMerge branch 'smoke-me/jkeenan/afresh/132401-file-copy' into blead
James E Keenan [Sun, 12 Nov 2017 23:10:28 +0000 (18:10 -0500)]
Merge branch 'smoke-me/jkeenan/afresh/132401-file-copy' into blead

6 years agoFix sprintf multiconcat on 32bit big-endian systems with use64bitint
Dagfinn Ilmari Mannsåker [Wed, 8 Nov 2017 20:25:56 +0000 (20:25 +0000)]
Fix sprintf multiconcat on 32bit big-endian systems with use64bitint

The sprintf offset calculation was assigning to the 'uv' field of the
aux union, while the code was reading from the 'size' field, which leads
to all zeroes when sizeof(uv) > sizeof(size_t) on a big-endian system.

6 years agobetter document macros taking literal strings
Zefram [Sun, 12 Nov 2017 05:58:36 +0000 (05:58 +0000)]
better document macros taking literal strings

When giving a function-style prototype for a macro taking a literal string
parameter, put a string literal in place of a type for that parameter.
This goofy appearance makes it obvious that this isn't really a function,
and clues the reader in that the parameter can't actually be an arbitrary
expression of the right type.  Also change the nonsensical "NUL-terminated
literal string" to "literal string" to describe these parameters.
Fixes [perl #116286].

6 years agodocument IO::Select error detection
Zefram [Sun, 12 Nov 2017 04:16:13 +0000 (04:16 +0000)]
document IO::Select error detection

6 years agoprevent invalid memory access in S_check_uni (RT #132433)
Lukas Mai [Sun, 12 Nov 2017 01:58:32 +0000 (02:58 +0100)]
prevent invalid memory access in S_check_uni (RT #132433)

6 years agofix do dir returning no $!
Daniel Dragan [Sun, 16 Aug 2015 08:30:23 +0000 (04:30 -0400)]
fix do dir returning no $!

do()ing a directory was returning false/empty string in $!, which isn't
an error, yet documentation says $! should have the error code in it.
Fix this by returning EISDIR for dirs, and EINVAL for block devices.
[perl #125774]

Remove "errno = 0" and comment added in b2da7ead68, since now there is no
scenario where errno is uninitialized, since the dir and block device
failure branches now set errno, where previously they didn't.

6 years agoavoid reading errno twice in a row
Zefram [Sat, 11 Nov 2017 23:58:32 +0000 (23:58 +0000)]
avoid reading errno twice in a row

Reading errno can involve calling a function and indirecting through
its result, so cache the value of errno where possible.  [perl #122096]

6 years agosuppress clang warning in inode number handling
Zefram [Sat, 11 Nov 2017 23:21:48 +0000 (23:21 +0000)]
suppress clang warning in inode number handling

The gcc warning was already suppressed, but clang needs a different
formulation.