This is a live mirror of the Perl 5 development currently hosted at
5 years agoadd the new stat(@array) diagnostic to perldiag
Tony Cook [Wed, 30 Mar 2016 05:48:40 +0000 (16:48 +1100)]
add the new stat(@array) diagnostic to perldiag

5 years ago(perl #126162) warn if stat() is called on an array
Dan Collins [Wed, 30 Mar 2016 05:42:39 +0000 (16:42 +1100)]
(perl #126162) warn if stat() is called on an array

5 years ago5.22.2 should appear this month, starting with RC1 on Sunday 10th
Steve Hay [Thu, 7 Apr 2016 08:01:30 +0000 (09:01 +0100)]
5.22.2 should appear this month, starting with RC1 on Sunday 10th

5 years agoAdd SILENT_NO_TAINT_SUPPORT to S_Internals_V ()
Yves Orton [Wed, 6 Apr 2016 09:33:15 +0000 (11:33 +0200)]

NO_TAINT_SUPPORT was added in 3b0e4ee2077, but SILENT_NO_TAINT_SUPPORT was overlooked.

5 years agoGet -Accflags=-DPERL_MEM_LOG compiling again
Matthew Horsfall [Fri, 1 Apr 2016 16:44:49 +0000 (12:44 -0400)]
Get -Accflags=-DPERL_MEM_LOG compiling again

It had rotted a bit Well, more than one probably.

Move the declarations of the functions Perl_mem_log_alloc etc from handy.h
into embed.fnc where whey belong, and where Malloc_t will have already
been defined.

5 years agoss_dup: make new savestack have SS_MAXPUSH extra
David Mitchell [Tue, 5 Apr 2016 08:26:21 +0000 (09:26 +0100)]
ss_dup: make new savestack have SS_MAXPUSH extra

This fixes RT #perl #127799

My commit v5.23.7-261-g3caf026 made PL_savestack_max claim to have
allocated less than had actually been claimed (by a margin of SS_MAXPUSH).
This made the 'check whether the stack needs extending code' slightly
simpler, and errs on the side of safety. Except:

Perl_ss_dup(), when duplicating the savestack, makes the new stack
PL_savestack_max in size, which is large enough to duplicate the existing
stack, but the new stack no longer has a SS_MAXPUSH margin at the top.

The dSS_ADD family of macros work by assuming there is always such a
margin: they push their args onto the stack and only then check whether
the stack needs growing. This makes the code much more efficient, but of
course breaks if no margin is present.

5 years agoFollow-up to previous Solaris/S_regmatch commit
David Mitchell [Mon, 4 Apr 2016 13:51:40 +0000 (14:51 +0100)]
Follow-up to previous Solaris/S_regmatch commit

PL_charclass is the thing being temporarily #defined to something else, so
it's the thing that needs #undeffing at the end, not pl_charclass_dup.

Doesn't make any difference at the moment, but would if at some point
a function following S_regmatch() started making use of PL_charclass.

5 years agoS_regmatch(): work around Solaris optimiser bug
David Mitchell [Mon, 4 Apr 2016 12:27:35 +0000 (13:27 +0100)]
S_regmatch(): work around Solaris optimiser bug

Recently these test scripts started failing on Solaris i386 with


The first failure is due to a Solaris Studio optimiser bug; this commit
works around that failure. It may or may not also fix the other failures
(all tests pass now on the development box I was using, but I didn't
confirm whether the other tests failed before the fix).

The basic problem is that within the main while loop in S_regmatch(),
the expression PL_charclass['\n'] returns the wrong value.

Looking at the disassembled code, it appears that looking up this value
just before the while loop correctly does it by getting the address of the
global array PL_charclass, adding 40 to it (ord('\n')*sizeof(U32)), then
dereffing it.

Within the loop however, it just reads the value from a local var. The
optimiser is under the misapprehension that this value has previously been
read in and assigned to a local var, but it certainly hasn't been at the
point where the while loop is first entered.

This commit works round the problem on builds with -Duse64bitall and the
bad version of Solaris Studio compiler (12.3), by making a copy of
PL_charclass's address.

This is a bit of hack. For one thing, I don't know whether other versions
of the compiler also need this workaround.

The failures were seen on a 32-bit system with -Duse64bitall: this created
a 64-bit executable (i.e. with 64-bit pointers) with the -m64 compiler
flag. I would speculate that the bug in the compiler relates to to
this particular circumstance (i.e. the bug might not appear for a build
done on a 64-bit OS host with or without -Duse64bitall).

5 years agoepigraphs.pod - Add missing link, plus minor formatting corrections
Steve Hay [Mon, 4 Apr 2016 12:35:55 +0000 (13:35 +0100)]
epigraphs.pod - Add missing link, plus minor formatting corrections

5 years ago[perl #127760] add CUSTOMIZED for File-Path
Tony Cook [Mon, 4 Apr 2016 04:52:21 +0000 (14:52 +1000)]
[perl #127760] add CUSTOMIZED for File-Path

5 years ago[perl #127760] skip the Win32 UNC path tests on Win2k and older
Tony Cook [Wed, 30 Mar 2016 04:39:11 +0000 (15:39 +1100)]
[perl #127760] skip the Win32 UNC path tests on Win2k and older

Windows 2000 doesn't seem to support a UNC path as a current
directory - setting the current directory to a UNC path and then
trying to stat(".") results in a file not found or similar error.

This does work on Windows XP and later.

5 years agoavoid mis-mangled name references on threaded C++ builds
Tony Cook [Mon, 4 Apr 2016 02:03:58 +0000 (12:03 +1000)]
avoid mis-mangled name references on threaded C++ builds

g++ on recent darwin appears to be clang++ in disguise, and so
supports the TSA decorations, but the wrappers we define don't have
explicit extern "C" linkage (which perlapi.h does have).

Under C++ Time::HiRes wraps its includes in extern "C" { }, and
so references unmangled names for the perl_tsa_mutex_*() wrappers,
but since util.c never sees an extern "C" for those functions it
produces mangled names, causing undefined references in Time::HiRes.

Detected by a smoke run againt a smoke-me branch:

Longer term the TSA decorations should probably be probed for in Configure
and the wrapper declarations moved to embed.fnc

5 years agonote for detecting crypt() on Cygwin
Tony Cook [Mon, 4 Apr 2016 00:26:15 +0000 (10:26 +1000)]
note for detecting crypt() on Cygwin

5 years agodon't test crypt()s tied fetch count if we don't have crypt()
Tony Cook [Sun, 3 Apr 2016 23:52:57 +0000 (09:52 +1000)]
don't test crypt()s tied fetch count if we don't have crypt()

As of libcrypt 1.3, crypt() isn't detected on cygwin unless you install
libcrypt-devel, and this test failed.

5 years agorestore incorrectly deleted note
Yves Orton [Sun, 3 Apr 2016 08:50:22 +0000 (10:50 +0200)]
restore incorrectly deleted note

5 years agofix debug sprintf issue
Yves Orton [Sat, 26 Mar 2016 11:22:06 +0000 (12:22 +0100)]
fix debug sprintf issue

5 years agoExport lround() from POSIX
Aaron Crane [Fri, 1 Apr 2016 17:53:35 +0000 (18:53 +0100)]
Export lround() from POSIX

This function was implemented as of 5.21.4, but not exported (even by
request). It's too late in the 5.24 freeze for it to be exported by default,
or as part of a tag, but we can at least make it available to those who want
to import it by name.

5 years agorun regen/
David Mitchell [Fri, 1 Apr 2016 11:41:07 +0000 (12:41 +0100)]
run regen/

For some reason when the memmem probe was added, uconfig.h wasn't
regenerated correctly. Probably because it doesn't get run by default
with 'perl' - which in turn is because it requires a shell
to run.

5 years agoImprove code comments for some ctx stuff
David Mitchell [Wed, 30 Mar 2016 14:11:26 +0000 (15:11 +0100)]
Improve code comments for some ctx stuff

* in pp_return(), some comments were out of date about how
  leave_adjust_stacks() is called ;
* add a comment to all the functions that pp_return() tail-calls to the
  effect that they can be tail-called;
* make it clearer when/why OPf_SPECIAL is set on OP_LEAVE;
* CXt_LOOP_PLAIN can be a while loop as well as a plain block.

5 years agoRT #127786: assertion failure with eval in DB pkg.
David Mitchell [Mon, 28 Mar 2016 14:36:42 +0000 (15:36 +0100)]
RT #127786: assertion failure with eval in DB pkg.

Normally a cloned anon sud has a NULL CvOUTSIDE(), unless that
sub can contain code that will do an eval.
However, calling eval from within the DB package pretends that the eval
was done in the caller's scope. which then trips up on the NULL


5 years agore_exec_indentf,re_indentf: silence warnings
David Mitchell [Mon, 28 Mar 2016 08:59:10 +0000 (09:59 +0100)]
re_exec_indentf,re_indentf: silence warnings

Pass the right types to printf.

For re_exec_indentf(), really the type of the depth arg should be changed
so that it and the depth var are consistent throughout regexec.c, but
that's probably something for post-5.24.

5 years agosilence -Wparentheses-equality
David Mitchell [Mon, 28 Mar 2016 09:52:18 +0000 (10:52 +0100)]
silence -Wparentheses-equality

Clang has taken it upon itself to warn when an equality is wrapped in
double parentheses, e.g.

    ((foo == bar))

Which is a bit dumb, as any code along the lines of

    #define isBAR (foo == BAR)
    if (isBAR) {}

will trigger the warning.

This commit shuts clang up by putting in a harmless cast:

    #define isBAR cBOOL(foo == BAR)

5 years agosilence warnings in inline.h on Win64 VC build
Daniel Dragan [Sat, 26 Mar 2016 17:44:30 +0000 (13:44 -0400)]
silence warnings in inline.h on Win64 VC build

c:\p523\src\inline.h(211) : warning C4267: 'function' : conversion from 'size_t'
 to 'I32', possible loss of data
c:\p523\src\inline.h(212) : warning C4267: 'function' : conversion from 'size_t'
 to 'I32', possible loss of data
c:\p523\src\inline.h(421) : warning C4244: '=' : conversion from '__int64' to 'I
32', possible loss of data
c:\p523\src\inline.h(423) : warning C4244: '=' : conversion from '__int64' to 'I
32', possible loss of data

To fix the warnings at line 211 and 212, change the func to use a signed
ptr length type. Although on x64, a 64b to 64b move instruction is 1 byte
longer than a 32b to 32b move, so this commit adds a couple more bytes of
machine code to the interp, but PVs len and cur are STRLEN, which is 64b
on 64b OS, so something bad would happen if a very large off arg was
passed to Perl_utf8_hop that was trucated to 32b, hence casting to silence
the warning isn't appropriate, instead a bigger type is needed.

S_cx_pushblock, a 8*(2^32), or 32 GB long perl stack malloc block is
unrealistic. A 32 GB mark stack is infinite recursion. Cast away the

5 years agoMove the zeroing back before the dladdr() call.
Jarkko Hietaniemi [Sun, 27 Mar 2016 15:11:18 +0000 (11:11 -0400)]
Move the zeroing back before the dladdr() call.

5 years ago[perl #127773: Assertion failure in perl built with Dusecbacktrace]
Vladimir Timofeev [Fri, 25 Mar 2016 12:41:25 +0000 (08:41 -0400)]
[perl #127773: Assertion failure in perl built with Dusecbacktrace]

5 years agoODBM_File version bump
Jarkko Hietaniemi [Sun, 27 Mar 2016 14:50:51 +0000 (10:50 -0400)]
ODBM_File version bump

5 years ago[perl #127751] error building ODBM_File on Windows, perl 5.23.9
Jarkko Hietaniemi [Thu, 24 Mar 2016 11:12:51 +0000 (07:12 -0400)]
[perl #127751] error building ODBM_File on Windows, perl 5.23.9

No POSIX open in Win32, broken by ed6087adbd9c90b59cf3f08af7c23a947c00bf69

Use the PerlLIO_open3 as suggested by Tony Cook, use the same trick as POSIX.xs

5 years agoRevert " update for newlocale, freelocale, and uselocale."
Craig A. Berry [Sat, 26 Mar 2016 13:56:15 +0000 (08:56 -0500)]
Revert " update for newlocale, freelocale, and uselocale."

This reverts commit f0e3aef8abfe33645e0b9682e5f5ec7090de749f.

The changes had actually already been done by a regen at
0f2b45c74307980ff2, so these were duplicates.

5 years agoimprove perldiag implicit close text still further
Aristotle Pagaltzis [Fri, 25 Mar 2016 23:55:21 +0000 (00:55 +0100)]
improve perldiag implicit close text still further

5 years agoSuppress another empty \N{} warning in pat_advanced.t.
Craig A. Berry [Fri, 25 Mar 2016 21:48:35 +0000 (16:48 -0500)]
Suppress another empty \N{} warning in pat_advanced.t.

Follow-up to d8d26cacf9f6b2fbd476.

5 years agoAdd probe for memmem
H.Merijn Brand [Fri, 25 Mar 2016 15:14:18 +0000 (16:14 +0100)]
Add probe for memmem

5 years agoSuggest having the previous release ready.
Abigail [Fri, 25 Mar 2016 12:36:28 +0000 (13:36 +0100)]
Suggest having the previous release ready.

Each time I do a release, I find myself scrambling to download the
tarball of the previous release, and install it so it can be compared
to the release that's worked on. Added a paragraph as a reminder to
that before the day of the release.

5 years agoAdd 's' and 'S' to list of ANSI C portable filename characters.
James E Keenan [Fri, 25 Mar 2016 12:13:00 +0000 (08:13 -0400)]
Add 's' and 'S' to list of ANSI C portable filename characters.

For: RT #127783.  Thanks to Jim Davis for report.

5 years agoimprove perldiag implicit close text further
Aristotle Pagaltzis [Fri, 25 Mar 2016 11:02:44 +0000 (12:02 +0100)]
improve perldiag implicit close text further

5 years agoPATCH: [perl #123417] Deprecate empty \N{}
Karl Williamson [Fri, 25 Mar 2016 01:45:24 +0000 (19:45 -0600)]
PATCH: [perl #123417] Deprecate empty \N{}

5 years agot/re/re_tests: Add missing \ escape to a test
Karl Williamson [Tue, 22 Mar 2016 17:03:51 +0000 (11:03 -0600)]
t/re/re_tests: Add missing \ escape to a test

This just happened to work, but the backslash should be escaped, as it
is evaluated in qq context

5 years agostop lc() etc accidentally modifying in-place.
David Mitchell [Sun, 20 Mar 2016 17:12:13 +0000 (17:12 +0000)]
stop lc() etc accidentally modifying in-place.

As an optimisation, [ul]c() and [ul]cfirst() sometimes modify their
argument in-place rather than returning a modified copy.

This should only be done when there is no possibility that the arg is
going to be reused. However, this fails:

    use List::Util qw{ first };
    my %hash = ( ASD => 1, ZXC => 2, QWE => 3, TYU => 4);
    print first { lc $_ eq 'qwe' } keys %hash;

which prints "qwe" rather than "QWE".

Bascally everything in perl that sets $_ or $a/$b and calls a code block
or function, such as map, grep, for and, sort, either copies any PADTMPs,
turns off SvTEMP, and/or bumps the reference count.

List::Util doesn't do this, and it is likely that other CPAN modules
which do "set $_ and call a block" don't either.

This has been failing since 5.20.0: perl has been in-placing if the arg is
(SvTEMP && RC==1 && !mg) (due to v5.19.7-112-g5cd5e2d).

Make the optimisation critera stricter by always copying SvTEMPs.
It still allows the optimisation if the arg is a PADTMP - I don't know
whether this is unsafe too.

Perhaps we can think of something better after 5.24?

5 years agoimprove perldiag implicit close text
David Mitchell [Wed, 23 Mar 2016 16:11:01 +0000 (16:11 +0000)]
improve perldiag implicit close text

5 years agoMark unexpectedly passing TEST -deparse tests
David Mitchell [Wed, 23 Mar 2016 16:30:54 +0000 (16:30 +0000)]
Mark unexpectedly passing TEST -deparse tests

About 270 test files formerly marked as "expected to fail under
"./TEST -deparse" now pass. We must be doing something right :-)

Remove them from the list of expected failures.

Conversely, there are also 174 failing tests that are aren't marked
as expected to fail, so we're probably doing something wrong too :-(.

5 years agoList in the RMG regarding smoke reports.
Matthew Horsfall [Wed, 23 Mar 2016 00:12:12 +0000 (20:12 -0400)]
List in the RMG regarding smoke reports.

5 years ago[perl #127764] Perl with '-Dusecbacktrace' doesn't compile on darwin
Jarkko Hietaniemi [Tue, 22 Mar 2016 23:43:21 +0000 (19:43 -0400)]
[perl #127764] Perl with '-Dusecbacktrace' doesn't compile on darwin

Fix a thinko in 22ff3130.

5 years ago[perl #127765] Fix bogus $File::Spec::AmigaOS::VERSION
Dagfinn Ilmari Mannsåker [Tue, 22 Mar 2016 21:07:38 +0000 (21:07 +0000)]
[perl #127765] Fix bogus $File::Spec::AmigaOS::VERSION

';' a single bitflip away from '3', which must have happened before
e46aa1dd got committed, since the SHA-1 hashes are all consistent.

5 years agoPoint out that at some stage, porting tests will fail.
Abigail [Mon, 21 Mar 2016 16:56:51 +0000 (17:56 +0100)]
Point out that at some stage, porting tests will fail.

This trips me each and every time I make a release. Whenever the
release manager guide calls for a compile/make test cycle, I run
"make test_harness", and this fails at this stage, because Module::CoreList
has not been updated yet (the next action described in the release
managers guide is updating Module::CoreList).

I also removed some suboptimal advice I've written here in the past.

5 years updates
Chris 'BinGOs' Williams [Mon, 21 Mar 2016 15:09:21 +0000 (15:09 +0000)] updates

5 years agoIntegrate podlators 4.07
David Mitchell [Mon, 21 Mar 2016 08:45:13 +0000 (08:45 +0000)]
Integrate podlators 4.07

5 years agoBump version in various places
Abigail [Sun, 20 Mar 2016 17:54:17 +0000 (18:54 +0100)]
Bump version in various places

5 years agoNew perldelta
Abigail [Sun, 20 Mar 2016 17:25:14 +0000 (18:25 +0100)]
New perldelta

5 years agoRemove vutil.c from list of customized files
Leon Timmermans [Sun, 20 Mar 2016 17:18:44 +0000 (18:18 +0100)]
Remove vutil.c from list of customized files

5 years agoTick off releases
Abigail [Sun, 20 Mar 2016 17:00:54 +0000 (18:00 +0100)]
Tick off releases

5 years agoEpigraph for 5.23.9.
Abigail [Sun, 20 Mar 2016 16:56:57 +0000 (17:56 +0100)]
Epigraph for 5.23.9.

The missing capital in the book title is not a typo. The book is titled
using lowercase letters only.

5 years agoMerge branch 'release-5.23.9' into blead
Abigail [Sun, 20 Mar 2016 16:49:46 +0000 (17:49 +0100)]
Merge branch 'release-5.23.9' into blead

5 years agoperldelta: Clarify a statement
Karl Williamson [Sun, 20 Mar 2016 15:50:45 +0000 (09:50 -0600)]
perldelta: Clarify a statement

This was misleading and gave unnecessary detail about an internal-only
function.  I'm sorry I forgot to make an entry about this earlier.

5 years agoAdd new release to perlhist v5.23.9
Abigail [Sun, 20 Mar 2016 13:53:00 +0000 (14:53 +0100)]
Add new release to perlhist

5 years agoChanged modules section for perldelta.pod
Abigail [Sun, 20 Mar 2016 13:25:31 +0000 (14:25 +0100)]
Changed modules section for perldelta.pod

5 years agoAdded Acknowledgements
Abigail [Sun, 20 Mar 2016 12:45:33 +0000 (13:45 +0100)]
Added Acknowledgements

5 years agoUpdate Module::CoreList for 5.23.9
Abigail [Sun, 20 Mar 2016 12:25:37 +0000 (13:25 +0100)]
Update Module::CoreList for 5.23.9

5 years agoMention (relative) path to Module::CoreList's Changes file.
Abigail [Sun, 20 Mar 2016 12:21:42 +0000 (13:21 +0100)]
Mention (relative) path to Module::CoreList's Changes file.

So we can easily copy-and-paste it.

5 years agoImprison at_tindex_nomg()
Karl Williamson [Sun, 20 Mar 2016 04:48:54 +0000 (22:48 -0600)]
Imprison at_tindex_nomg()

This name is controversial.  Use #ifdef's to keep it from being exposed
outside of the places that already use it.  And don't publicize that it

5 years agoregcomp.c: Fix -Dr output.
Karl Williamson [Sun, 20 Mar 2016 04:02:32 +0000 (22:02 -0600)]
regcomp.c: Fix -Dr output.

I got things slightly wroing in
b77aba85f6ec3b2a2341077b14f39261c5753cea.  It did not properly handle
the case for inversion /d of complemented classes, such as \W.  Two
examples being [^\W0-9] and [^\S\wa].

5 years agoDocument the changes for perl 5.23.9
Abigail [Sat, 19 Mar 2016 23:29:26 +0000 (00:29 +0100)]
Document the changes for perl 5.23.9

We still need to take care of the automated parts (new/changed/delete module,
and the Acknowledgements.

5 years update for newlocale, freelocale, and uselocale.
Craig A. Berry [Sat, 19 Mar 2016 23:39:52 +0000 (18:39 -0500)] update for newlocale, freelocale, and uselocale.

Follow-up to ecb44b8e4ad52.

5 years agoSort perldiag
Father Chrysostomos [Sat, 19 Mar 2016 20:30:39 +0000 (13:30 -0700)]
Sort perldiag

It’s nice that people leave things for me to clean up! :-)

5 years agoregcomp.c, perl.c: Use 'VOL' not 'volatile'
Karl Williamson [Sat, 19 Mar 2016 15:10:41 +0000 (09:10 -0600)]
regcomp.c, perl.c: Use 'VOL' not 'volatile'

I presume that VOL is so perl can at least compile on compilers that lack
'volatile'.  (It was added by Larry in 1991 by 352d5a3ab; there were
probably a lot more compilers like that back then.)  But VOL is used
consistently in the core, with these being the two exceptions.

5 years agoregen
H.Merijn Brand [Sat, 19 Mar 2016 14:58:17 +0000 (15:58 +0100)]

5 years agoAdd Configure probes for newlocale, freelocale, and uselocale
H.Merijn Brand [Sat, 19 Mar 2016 14:01:58 +0000 (15:01 +0100)]
Add Configure probes for newlocale, freelocale, and uselocale

5 years agoUpdate version to 0.9916
John Peacock [Sat, 19 Mar 2016 01:43:52 +0000 (21:43 -0400)]
Update version to 0.9916

5 years agoUpgrade Win32API::File from version 0.1202 to 0.1203
Steve Hay [Sat, 19 Mar 2016 01:28:40 +0000 (01:28 +0000)]
Upgrade Win32API::File from version 0.1202 to 0.1203

Fixes perl #125303.

(Includes a regen for the moved

5 years ago[MERGE] dtrace linking fixups
David Mitchell [Sat, 19 Mar 2016 00:01:51 +0000 (00:01 +0000)]
[MERGE] dtrace linking fixups

5 years agofix up dtrace compile/link for Solaris
David Mitchell [Tue, 8 Mar 2016 11:31:22 +0000 (11:31 +0000)]
fix up dtrace compile/link for Solaris

[perl #127543]

On some platforms, the use of dtrace / SystemTap requires generating an
extra .o file from a list of .o files before linking. For example,

    cc -o foo a.o b.o c.o

has to be replaced with

    dtrace -G -s dtrace.d -o dtrace.o  a.o b.o c.o # creates dtrace.o
    cc -o foo                dtrace.o  a.o b.o c.o

On Solaris in particular, "dtrace -G" modifies the *.o files that it's
passed as well as creating dtrace.o, and all the new/updated .o files need
to be linked together at the same time from the same single use of "dtrace

This complicates matters when building all of miniperl, libperl and perl,
and the reason for this commit is that once a dtrace probe made its way
into an inline static function via the recent context work, Solaris
stopped building under -Dusedtrace -Duseshrplib.

The fix that seems to work under both Solaris and Linux, for all
4 permutations of -Dusedtrace +/- -Duseshrplib, is (approx):

    # compile all the *.o's, then:

    # build miniperl:

    $ dtrace ...  -o dtrace_mini.o  a.o b.o c.o perlminimain.o
    $ cc -o miniperl dtrace_mini.o  a.o b.o c.o perlminimain.o

    # build libperl.a or .so:

    $ dtrace ...    -o dtrace_perllib.o  a.o b.o c.o
    $ ar rcu libperl.a dtrace_perllib.o  a.o b.o c.o

    # build perl:

    $ dtrace ...  -o dtrace_main.o  perlmain.o
    $ cc -o perl     dtrace_main.o  -lperl

This is has only recently arisen because we switched from PUSHSUB()
etc macros to S_cx_pushsub() etc inline functions, which contain
probes. Since the inline static functions, and hence the probes, are now
included in every source file, and since Solaris isn't smart enough to
remove inline static fns that aren't used in a particular compilation
unit, the probes end up getting used in every source file (at least where
PERL_CORE is true).

It also required fixing up XS-APItest's Makefile.PL, since one object
file is compiled using PERL_CORE.

5 years agoMakefile.SH: rationalise object list variables
David Mitchell [Mon, 7 Mar 2016 11:55:11 +0000 (11:55 +0000)]
Makefile.SH: rationalise object list variables

There are a number of variables in the generated Makefile, such as
'obj' and 'minindt_obj', that enumerate various subsets of the object
files that need to be compiled and linked.

Rename and reorganise these vars slightly, to make the next commit
simpler. In particular it now splits the object files in into 3 sets:
common (av.o etc), those used just by miniperl (opmini.o etc)
and those used just by perl (op.o etc).

Should be no functional changes.

The changes to os2/Makefile.SHs have been done blind. Does anyone still
use OS2?

5 years agorename and function-ise dtrace macros
David Mitchell [Mon, 15 Feb 2016 13:48:24 +0000 (13:48 +0000)]
rename and function-ise dtrace macros

This commit:

1. Renames the various dtrace probe macros into a consistent and
self-documenting pattern, e.g.


Since they're supposed to be defined only under PERL_CORE, this shouldn't
break anything that's not being naughty.

2. Implement the main body of these macros using a real function.

They were formerly defined along the lines of


The PERL_SUB_ENTRY() part is a macro generated by the dtrace system, which
for example on linux expands to a large bunch of assembly directives.
Replace the direct macro with a function wrapper, e.g.

        Perl_dtrace_probe_call(aTHX_ cv, TRUE);

This reduces to once the number of times the macro is expanded.

The new functions also take simpler args and then process the values they
need using intermediate temporary vars to avoid huge macro expansions.

For example

                    ? HEK_KEY(CvNAME_HEK(cv))
                    : GvENAME(CvGV(cv)),
                CopFILE((const COP *)CvSTART(cv)),
                CopLINE((const COP *)CvSTART(cv)),
                CopSTASHPV((const COP *)CvSTART(cv)));

is now


This reduces the executable size by 1K on -O2 -Dusedtrace builds,
and by 45K on -DDEBUGGING -Dusedtrace builds.

5 years agoConfigure: silence 'dtrace -G' probe
David Mitchell [Fri, 18 Mar 2016 23:29:44 +0000 (23:29 +0000)]
Configure: silence 'dtrace -G' probe

When built with -Dusedtrace, Configure checks to see whether 'dtrace -G'
is supported, by running it. If it fails, it may spew error messages
to stderr, so use >/dev/null 2>&1.

5 years agoregex sets: fix Solaris optimiser bug (2nd attempt)
David Mitchell [Fri, 18 Mar 2016 22:36:40 +0000 (22:36 +0000)]
regex sets: fix Solaris optimiser bug (2nd attempt)

[perl #127455]

My first fix for this, (v5.23.7-586-gd9cb841) didn't actually fix it.
The diagnosis was correct, but somewhere during fixing and testing I went
wrong, and the optimiser bug was still being triggered without me spotting

The new approach, based on a suggestion by Tony C, is simply to
declare the errant local var 'fence' to be volatile. This stops the
compiler from optimising away its value.

5 years agoregcomp.c: Avoid a memory leak
Karl Williamson [Mon, 7 Mar 2016 22:37:11 +0000 (15:37 -0700)]
regcomp.c: Avoid a memory leak

I spotted this in code reading.  The chances of it happening are quite
small.  It could happen under tainting with a user-defined \p{}
property, and /i matching.

5 years agoregcomp.c: Comment enhancements
Karl Williamson [Mon, 7 Mar 2016 17:49:17 +0000 (10:49 -0700)]
regcomp.c: Comment enhancements

The text of one of these comments was furnished to me by Yves Orton some
time ago.

5 years agoMake instr() a macro
Karl Williamson [Fri, 11 Mar 2016 23:22:49 +0000 (16:22 -0700)]
Make instr() a macro

... thus avoiding a function call overhead

5 years agoperlapi: Further clarification for term "Latin1"
Karl Williamson [Fri, 18 Mar 2016 02:57:48 +0000 (20:57 -0600)]
perlapi: Further clarification for term "Latin1"

This is a follow on for 14d32fa99f736009ef63a8b17d164cd8f6e967d9

5 years agohandy.h: Add synonyms for macros
Karl Williamson [Fri, 11 Mar 2016 03:34:17 +0000 (20:34 -0700)]
handy.h: Add synonyms for macros

I realized that we have inconsistent naming conventions for the
isFOO_uni() macros, like isALPHA_uni().  The "_uni" suffix elsewhere
refers to official Unicode code point numbers; whereas, for these macros
it refers to the native code point numbers for code points below 256.
And elsewhere, there are in some cases a _uni() and a uvchr() which mean
different things.

This commit adds '_uvchr' suffix equivalents for these macros, while
dropping mention in the documentation of the '_uni' forms.  Thus code
following the new paradigm will not be confusing, while existing code
will function unchanged.

5 years agoCarp: Fix .t failure to compile in v5.6
Karl Williamson [Thu, 17 Mar 2016 22:45:47 +0000 (16:45 -0600)]
Carp: Fix .t failure to compile in v5.6

This doesn't guarantee the tests pass in that release; just that it will
actually get to testing.

5 years agoVarious fixups for 0.9914
Leon Timmermans [Fri, 18 Mar 2016 00:44:41 +0000 (01:44 +0100)]
Various fixups for 0.9914

5 years agoRemove no longer valid tests
John Peacock [Thu, 18 Feb 2016 14:23:08 +0000 (08:23 -0600)]
Remove no longer valid tests

5 years agoImport 0.9914 from CPAN
John Peacock [Wed, 17 Feb 2016 03:34:52 +0000 (21:34 -0600)]
Import 0.9914 from CPAN

5 years agoperldelta: document exception thrown when -i output close fails
Ricardo Signes [Thu, 17 Mar 2016 23:49:28 +0000 (19:49 -0400)]
perldelta: document exception thrown when -i output close fails

5 years agocroak on failure to close an in-place edit output file
Tony Cook [Thu, 5 Nov 2015 04:06:00 +0000 (15:06 +1100)]
croak on failure to close an in-place edit output file

5 years agoreport an error and fail if we can't flush stdout
Tony Cook [Wed, 4 Nov 2015 05:52:37 +0000 (16:52 +1100)]
report an error and fail if we can't flush stdout

5 years agoperldelta for 22e30cb2a3, 6156385671 and a28fff5120
Steve Hay [Thu, 17 Mar 2016 23:28:29 +0000 (23:28 +0000)]
perldelta for 22e30cb2a36156385671 and a28fff5120

5 years agolocale.c: Add comment
Karl Williamson [Thu, 17 Mar 2016 22:11:04 +0000 (16:11 -0600)]
locale.c: Add comment

5 years agoregen/ Revamp so works on earlier Unicodes
Karl Williamson [Tue, 15 Mar 2016 02:49:00 +0000 (20:49 -0600)]
regen/ Revamp so works on earlier Unicodes

The code that generates the tables for the \b{foo} handling (in
regexec.c) did not correctly work when compiled on an earlier Unicode.
This fixes things up to do that, consolidating some common code into a
common function and making the generated hdr file look nice, with the
tables taking fewer columns of screen space

5 years agomktables: Use correct structure to look up data
Karl Williamson [Thu, 17 Mar 2016 21:25:09 +0000 (15:25 -0600)]
mktables: Use correct structure to look up data

There are two types of tables in mktables: Map tables map code points
to the values a property have for those code points; and match tables
which are booleans, give "does a code point match a given property
value?".  There are different data structures to encapsulate each.  This
code was using the wrong structure to look something up.  Usually this
failed, and a fall-back value was used instead.  When compiling an early
Unicode release, I discovered that there could be a conflict.

5 years agomktables: Fix bug with early Unicode versions
Karl Williamson [Thu, 17 Mar 2016 20:27:34 +0000 (14:27 -0600)]
mktables: Fix bug with early Unicode versions

An array had 2 optional elements at the end.  I got confused about
handling them.  This change first deals with the final one, pops it and
saves it separately if found.  Then only one optional element needs to
be dealt with in the course of the code.

This only gets executed for very early Unicode versions

5 years agomktables: Unicode 1.5 only had 2**16 code points
Karl Williamson [Tue, 15 Mar 2016 22:19:30 +0000 (16:19 -0600)]
mktables: Unicode 1.5 only had 2**16 code points

Therefore, we shouldn't add any above that.

5 years agoThe public_html directory on dromedary is working again.
Abigail [Thu, 17 Mar 2016 11:30:32 +0000 (12:30 +0100)]
The public_html directory on dromedary is working again.

So, I removed the references that it wasn't working in December 2015.

5 years agoAdd contributing info to Carp.
Shlomi Fish [Thu, 10 Mar 2016 19:32:41 +0000 (21:32 +0200)]
Add contributing info to Carp.

It lacked a link to the VCS repository so I had to ask rjbs about it on
the #p5p IRC channel. And one should always fix a problem twice:

* .

5 years agoharmonize S_dump_exec_pos()'s last arg type
David Mitchell [Mon, 14 Mar 2016 19:11:08 +0000 (19:11 +0000)]
harmonize S_dump_exec_pos()'s last arg type

embed.fnc declared it as "U32 depth", while it was defined as "const U32

5 years agoavoid generating an empty statement outside a function on non-clang
Tony Cook [Tue, 15 Mar 2016 00:26:26 +0000 (11:26 +1100)]
avoid generating an empty statement outside a function on non-clang

On non-clang compilers, the code:


outside a function generated a simple empty statement (or empty
declaration), which is invalid syntax outside a function in C,
causing a warning from the solaris studio compiler.

5 years agofix "bad match" issue reported in perl #127705
Yves Orton [Mon, 14 Mar 2016 22:30:02 +0000 (23:30 +0100)]
fix "bad match" issue reported in perl #127705

In 24be310237a0f8f19cfdb71de1b068b4ce9572a0 I reworked how
we stored the close_paren info in the regexp match state
structure. Unfortunately I missed a subtle aspect of the
logic which meant that in certain cases we were relying
on close_paren being true to avoid comparing it against
a false ARG value for things like CURLYX, which meant that
sometimes we would exit an stack frame prematurely. This
patch fixes that logic and makes it more clear (via macros)
what is going on.

5 years agofix perl #127705, incorrect restoration of state during EVAL/GOSUB
Yves Orton [Mon, 14 Mar 2016 19:03:22 +0000 (20:03 +0100)]
fix perl #127705, incorrect restoration of state during EVAL/GOSUB

We were not restoring the cur_curlyx property properly during our funky
stack traversal when we really need to. This was a longstanding bug in this
code which my patches appear to have "tickled", although I am not sure why.

5 years agoadd consistency with other union members
Yves Orton [Mon, 14 Mar 2016 18:58:33 +0000 (19:58 +0100)]
add consistency with other union members

In most cases the curlyx member is the first thing after the yes state
member, but eval was reversed. While debugging perl #127705 I switched
them to see what would happen, which changed the bug, and ultimately
revealed the cause of the problem. So I am going to leave them in the
"consistent" order.

5 years agofixup broken diagnostic
Yves Orton [Mon, 14 Mar 2016 17:10:19 +0000 (18:10 +0100)]
fixup broken diagnostic

we shouldnt show this in normal re debug mode, just when debugging the stack,
also the macro wasnt using the STR argument like it should

5 years agoamigaos4: avoid PerlIO_findFILE() in popen/plcose
Andy Broad [Mon, 14 Mar 2016 21:43:30 +0000 (17:43 -0400)]
amigaos4: avoid PerlIO_findFILE() in popen/plcose

Merges amigaos_popen / amigaos_pclose with the amigaos specific
version of the Perl_my_popen / Perl_my_pclose functions and uses PerlIO
directly for the perl facing end of the PIPE:s thus avoid the issues
of PerlIO_findFILE() completely.

Also fixes a couple of warnings.