This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
perl5.git
4 years agoDocument SvTRUEx() macro
Pali [Mon, 17 Jun 2019 12:09:08 +0000 (14:09 +0200)]
Document SvTRUEx() macro

4 years agoperldelta for bc26d2e6b287
Tony Cook [Wed, 19 Jun 2019 00:12:01 +0000 (10:12 +1000)]
perldelta for bc26d2e6b287

bc26d2e6b287 changes the behaviour introduced by the original commit
and there's been no release, so there's no need for a new delta
entry

4 years ago(perl #133936) make send() a bit saner
Tony Cook [Tue, 18 Jun 2019 04:59:00 +0000 (14:59 +1000)]
(perl #133936) make send() a bit saner

This undoes some of the effect of f1000aa2d in that TO will always
be supplied to CORE::send() if it's supplied, otherwise whether
TO is supplied to CORE::send() is based on whether the socket is
connected.

On Linux you appear to be able to sendto() to a different address on
a connected UDP socket, but this doesn't appear to be portable,
failing on darwin, and presumably on other BSDs.

4 years agoThe Windows CE Chainsaw Massacre
Steve Hay [Thu, 13 Jun 2019 07:24:33 +0000 (08:24 +0100)]
The Windows CE Chainsaw Massacre

Remove WinCE support as agreed in the thread starting here:
https://www.nntp.perl.org/group/perl.perl5.porters/2018/07/msg251683.html

4 years agoperldelta for a8e0c1fd5ade
Tony Cook [Mon, 17 Jun 2019 05:24:04 +0000 (15:24 +1000)]
perldelta for a8e0c1fd5ade

4 years ago(perl #133989) scalar() the argument to readline, if any
Tony Cook [Wed, 12 Jun 2019 05:21:47 +0000 (15:21 +1000)]
(perl #133989) scalar() the argument to readline, if any

C< readline @foo > would treat @foo as array.  If the array was empty
this would push zero items and readline() would then pop one item,
possibly underflowing the stack.

4 years agoMichael Haardt is now perl author
Tony Cook [Mon, 17 Jun 2019 00:51:22 +0000 (10:51 +1000)]
Michael Haardt is now  perl author

4 years agoIncrease cpp macro space for HP-UX 11.00 ANSI compiler
Michael Haardt [Mon, 22 Apr 2019 10:44:42 +0000 (12:44 +0200)]
Increase cpp macro space for HP-UX 11.00 ANSI compiler

4 years agoperldelta for f1000aa2d58f, 229dff1ea726, 1d9630e7857d
Tony Cook [Mon, 17 Jun 2019 00:17:46 +0000 (10:17 +1000)]
perldelta for f1000aa2d58f229dff1ea7261d9630e7857d

4 years ago(perl #133936) document differences between IO::Socket::* and builtin
Tony Cook [Mon, 18 Mar 2019 05:02:33 +0000 (16:02 +1100)]
(perl #133936) document differences between IO::Socket::* and builtin

4 years agobump $IO::VERSION
Tony Cook [Mon, 18 Mar 2019 04:48:04 +0000 (15:48 +1100)]
bump $IO::VERSION

4 years ago(perl #133936) ensure TO is honoured for UDP $sock->send()
Tony Cook [Mon, 18 Mar 2019 04:05:32 +0000 (15:05 +1100)]
(perl #133936) ensure TO is honoured for UDP $sock->send()

4 years agoperldelta for 368ac47cccd4
Tony Cook [Thu, 13 Jun 2019 06:08:32 +0000 (16:08 +1000)]
perldelta for 368ac47cccd4

4 years ago(perl #134035) ensure sv_gets() handles a signal handler modifying sv
Tony Cook [Wed, 17 Apr 2019 05:45:15 +0000 (15:45 +1000)]
(perl #134035) ensure sv_gets() handles a signal handler modifying sv

At a very basic level at least.

In the ticket cases, a signal handler is modifying (and reallocating
PVX) the sv, while sv_gets() retained a pointer to the inside of the
SV.

This still has some problems, like if the signal handler ends up
shortening SV, there may be old data left between the old position
and the new position, but I think that's a case of user error.

4 years agoperldelta for 40258daf9899
Tony Cook [Wed, 12 Jun 2019 02:07:14 +0000 (12:07 +1000)]
perldelta for 40258daf9899

4 years ago(perl #134072) allow \&foo = \&bar to work in main::
Tony Cook [Wed, 15 May 2019 05:59:49 +0000 (15:59 +1000)]
(perl #134072) allow \&foo = \&bar to work in main::

subs in main:: are stored as a RV referring to a CV as a space
optimization, but the pp_refassign code expected to find a glob,
which made the assignment a no-op.

Fix this by upgrading the reference to a glob in the refassign check
function.

Note that this would be an issue in other packages if 1e2cfe157ca
was reverted (allowing the space savings in other packages too.)

4 years agoperldelta for 69afcc21edd2
Tony Cook [Wed, 12 Jun 2019 01:40:29 +0000 (11:40 +1000)]
perldelta for 69afcc21edd2

4 years ago(perl #130585) prevent a spurious ) in a subparse confusing the parser
Tony Cook [Tue, 12 Feb 2019 05:30:34 +0000 (16:30 +1100)]
(perl #130585) prevent a spurious ) in a subparse confusing the parser

When doing a subparse, the tokenizer opens up the subexpression
with a '(' token, expecting the logic in yylex() to generate a ')'
once it sees the end of the subparsed string.

If the subparsed string includes an unmatched ')', this could confuse
the parser into finishing the expression and effectively exiting the
subparse without cleaning up (including popping the context)

To avoid that, create special bracketing tokens only generated for
a subparse and update the grammar to use those tokens in the cases
they might be used in a subparse.

This is an updated version of the patch that moves the FUNC rule
to where the original rule was and adds a test for non-regexp
subparses.

4 years agoperldelta for 7259f4194f31
Tony Cook [Wed, 12 Jun 2019 00:17:26 +0000 (10:17 +1000)]
perldelta for 7259f4194f31

4 years ago(perl #134125) accept only complete hex and binary literals
Tony Cook [Tue, 4 Jun 2019 06:35:35 +0000 (16:35 +1000)]
(perl #134125) accept only complete hex and binary literals

4 years agoperldelta for eec88220688f, 10724e88639b, be9b05102160, 82de236bf4d8
Tony Cook [Tue, 11 Jun 2019 06:45:50 +0000 (16:45 +1000)]
perldelta for eec88220688f10724e88639bbe9b0510216082de236bf4d8

4 years ago(perl #133850) allow attributes in sub-parses
Tony Cook [Wed, 29 May 2019 04:37:25 +0000 (14:37 +1000)]
(perl #133850) allow attributes in sub-parses

4 years ago(perl #133850) allow @x{...} with space in sub-parse
Tony Cook [Wed, 29 May 2019 03:47:36 +0000 (13:47 +1000)]
(perl #133850) allow @x{...} with space in sub-parse

4 years ago(perl #133850) warn on ${time} even in sub-parse
Tony Cook [Wed, 29 May 2019 01:46:01 +0000 (11:46 +1000)]
(perl #133850) warn on ${time} even in sub-parse

Code like:

  $a = ${time}

warns with:

  Ambiguous use of ${time} resolved to $time at ...

but:

  s/^/ ${time} /e

didn't, since the parser is in a special state in sub-parses.

4 years ago(perl #133850) fix parsing hints for print $fh "foo" in s///e
Tony Cook [Tue, 19 Feb 2019 04:38:39 +0000 (15:38 +1100)]
(perl #133850) fix parsing hints for print $fh "foo" in s///e

The replacement code in s///e is parsed using a sublex, similarly
to double-quotish replacement.

The code that handles C< $id > tries to detect what the next token
should be, but only special cased code similar to C< print $fh ... >
in a non-sublex, so s/../print $fh $1/e set PL_expect to XOPERATOR
which caused the parser to complain when the $1 wasn't an operator.

The fix here handles two cases:

 s/.../code here/e

In this case the code is inserted into a do {} block like:

  do { code here }

so PL_lex_brackets ends up non-zero.

The second case is code like:

  "xxx${code here}"

which had the same problem, which this also fixes.

4 years ago(perl #122112) remove some interfering debug output
Tony Cook [Tue, 11 Jun 2019 04:59:23 +0000 (14:59 +1000)]
(perl #122112) remove some interfering debug output

4 years agoperldelta for 16f2ddb79488, 5afa8ffbdf01
Tony Cook [Tue, 11 Jun 2019 01:26:43 +0000 (11:26 +1000)]
perldelta for 16f2ddb794885afa8ffbdf01

4 years agobump $Storable::VERSION
Tony Cook [Mon, 10 Jun 2019 00:42:45 +0000 (10:42 +1000)]
bump $Storable::VERSION

and update Changes

4 years ago(perl #134179) include regexps in the seen objects table on retrieve
Tony Cook [Mon, 10 Jun 2019 00:17:20 +0000 (10:17 +1000)]
(perl #134179) include regexps in the seen objects table on retrieve

Also, bless the regexp object, so freezing/thawing bless qr//, "Foo"
returns a "Foo" blesses regexp.

4 years agoRevert "Fix edge case test failure in ext/POSIX/t/mb.t" origin/jkeenan/134182-xyz
James E Keenan [Sat, 8 Jun 2019 21:45:24 +0000 (17:45 -0400)]
Revert "Fix edge case test failure in ext/POSIX/t/mb.t"

This reverts commit 69b89a0f0bb2cbb4c1607e78c3b414bf45244bea.

This commit generated two test failures on Linux when perl was built
with config_args like these:

'-des -Dusedevel -Dcc=clang -Accflags=-Werror=declaration-after-statement -g -fno-omit-frame-pointer -fsanitize=address  -fno-common -fsanitize-blacklist=/home/jkeenan/gitwork/perl/asan_ignore -Aldflags=-fsanitize=address'

See: https://rt.perl.org/Ticket/Display.html?id=134182#txn-1639258

Reverting from blead; will create branch for testing.

Signed-off-by: James E Keenan <jkeenan@cpan.org>
4 years agoFix upcoming release schedule
Sawyer X [Sat, 8 Jun 2019 13:40:01 +0000 (16:40 +0300)]
Fix upcoming release schedule

4 years agoFix edge case test failure in ext/POSIX/t/mb.t
Dominic Hargreaves [Fri, 7 Jun 2019 09:04:26 +0000 (10:04 +0100)]
Fix edge case test failure in ext/POSIX/t/mb.t

This new test fails in an environment where LANG is set to one thing and
LC_ALL is set to another, and where LANG is set to a locale which is
not installed in the environment in question.

Such a test environment is arguably broken, but appears in common
chroot setups such as Debian's sbuild tool where LANG is inherited from
the parent environment, and LC_ALL is used to override it.

Committer: removed one non-printing character from patch

For: RT # 134182

4 years agoperldelta for 0f4fe36327e6, 1768639d6db2
Tony Cook [Wed, 5 Jun 2019 04:37:32 +0000 (14:37 +1000)]
perldelta for 0f4fe36327e61768639d6db2

4 years ago(perl #134175) tests for eval_pv rethrowing objects
Tony Cook [Wed, 5 Jun 2019 01:59:17 +0000 (11:59 +1000)]
(perl #134175) tests for eval_pv rethrowing objects

4 years agoIn Perl_eval_pv rethrow error via croak_sv()
Pali [Tue, 4 Jun 2019 10:28:09 +0000 (12:28 +0200)]
In Perl_eval_pv rethrow error via croak_sv()

This would allow to rethrow object exceptions.

4 years agoPrevent hostname() from accepting arguments
James E Keenan [Sat, 25 May 2019 02:37:40 +0000 (22:37 -0400)]
Prevent hostname() from accepting arguments

Previously deprecated; now fatal.

Incorporate feedback from Tony Cook and Richard Leach as to wording of
exception and how it is invoked.

For: RT 134137

4 years agoBump Devel-PPPort for next release
Nicolas R [Tue, 4 Jun 2019 19:28:50 +0000 (13:28 -0600)]
Bump Devel-PPPort for next release

4 years agoFix compilation issues with version older than 5.010
Nicolas R [Wed, 15 May 2019 14:53:26 +0000 (08:53 -0600)]
Fix compilation issues with version older than 5.010

By adding more Perl versions to the Travis CI configuration
file we discovered that versions earlier 5.010 are broken.

Note that the uv.t does not raise the overflow warning
as expected by the test and we probably want to fix this in
a short future.

The test uv.t is simply not passing with 5.006 versions and
has several failures. I've currently disabled it.

Patch provided by Pali

(cherry picked from commit a09f79fbc2455b7ea72a49f6627a639101ba35a2)
Signed-off-by: Nicolas R <atoomic@cpan.org>
4 years agoRename PPPort_xs.PL to RealPPPort_xs.PL
Nicolas R [Tue, 14 May 2019 19:53:45 +0000 (13:53 -0600)]
Rename PPPort_xs.PL to RealPPPort_xs.PL

Fixes Devel-PPPort GH #21

To avoid confusion rename the template for RealPPPort.xs
file as RealPPPort_xs.PL so it's now clear what file
it generates.

(cherry picked from commit 0f14f67985491207f4a0e3936307f4c565717fd6)
Signed-off-by: Nicolas R <atoomic@cpan.org>
4 years agoFix builds after EUMM update
Chris 'BinGOs' Williams [Tue, 4 Jun 2019 12:52:58 +0000 (13:52 +0100)]
Fix builds after EUMM update

4 years agoClarify documentation for bisect runner.
James E Keenan [Sun, 2 Jun 2019 01:29:22 +0000 (21:29 -0400)]
Clarify documentation for bisect runner.

The -D, -A and -U switches should be spelled as if you were normally
giving them to ./Configure.

For: RT # 134164

4 years agoAndroid can pass eintr_print.t
Richard Leach [Mon, 3 Jun 2019 17:03:17 +0000 (17:03 +0000)]
Android can pass eintr_print.t

4 years agopodcheck.t: Don't output warnings when extracting pod
Karl Williamson [Mon, 3 Jun 2019 19:10:51 +0000 (13:10 -0600)]
podcheck.t: Don't output warnings when extracting pod

This turns off warnings while we are extracting pod.  If we are
reporting problems, these will be output at the end.

4 years agoUpdate DB_File to CPAN version 1.852
Chris 'BinGOs' Williams [Mon, 3 Jun 2019 17:57:27 +0000 (18:57 +0100)]
Update DB_File to CPAN version 1.852

  [DELTA]

1.852 21 April Feb 2019

   * ParseOpenInfo() leaks if it croaks
     DB_File_type memory not freed when ParseOpenInfo croaks.
     https://github.com/pmqs/DB_File/issues/1

   * Fix whitespace in DB_File.xs

1.851 4 April Feb 2019

   * Fix typo in MANIFEST with .travis.yml file

1.850 10 Feb 2019

   * Added soure to github
     https://github.com/pmqs/DB_File

   * Added .travis.yml

   * Added t/meta-json.t & t/meta-yaml.t

4 years agoUpdate Test-Simple to CPAN version 1.302164
Chris 'BinGOs' Williams [Mon, 3 Jun 2019 14:11:38 +0000 (15:11 +0100)]
Update Test-Simple to CPAN version 1.302164

  [DELTA]

1.302164  2019-04-27 01:43:44-07:00 America/Los_Angeles

1.302163  2019-04-25 05:45:47-07:00 America/Los_Angeles (TRIAL RELEASE)

    - Do not use threads::Shared in Test::Tester::Capture (#826)
    - Add missing version info to Info/Table
    - Fix event in global destruction bug (#827)
    - Proper fix for todo = '' (#812, #829)

4 years agoUpdate CPAN to CPAN version 2.26
Chris 'BinGOs' Williams [Mon, 3 Jun 2019 12:38:43 +0000 (13:38 +0100)]
Update CPAN to CPAN version 2.26

  [DELTA]

2019-03-19  k  <andk@cpan.org>

  * release 2.26

  * testfix release, no functional change

  * 97-run.t is now skipped when test is run by root user because
  perldoc often fails for root user (thanks to Binarus for
  reporting)

  * small additions to distroprefs and to the Makefile.PL

2019-03-03  k  <andk@cpan.org>

  * release 2.25

  * two weeks after the TRIAL release cpantesters have produced 298
  pass and 2 fail reports on 108 different configurations; the two
  fails are outliers I don't understand

  * no functional change over 2.25-TRIAL; only a couple in the
  distroprefs directory which is not used per default

2019-02-16  k  <andk@cpan.org>

  * release 2.25-TRIAL

  * fix: Avoid a warning when prompting install_help intro (Nicolas
  R/atoomic)

  * testfix: load the tested module early, before juggling with @INC

  * testfix: replace an exec with system and exit (greetings to Windows)

  * two more distroprefs lines

2019-02-14  k  <andk@cpan.org>

  * release 2.24-TRIAL

  * fix: set internal error state on writemakefile=NO in a rare case
  without any output

  * test fix: avoid a so far unreflected dependency on perldoc

  * a few more distroprefs

2019-02-10  k  <andk@cpan.org>

  * release 2.23-TRIAL

  * fix: when option cleanup_after_install is active, prevent
  rerunning make install after a cleanup; allow it only with the
  help of force; also prevent that it is triggered too early

  * fix: address #121162: support distroprefs for install.env

  * fix: the option h on cpan script now really ignores all other
  options and arguments

  * fix: Local::Null::Logger on cpan script did not honour
  CPANSCRIPT_LOGLEVEL

  * address #122520: exit 1 on unknown options on cpan script

  * address #94941: refuse to generate reports with CPAN::Reporter
  lower than 1.2011

  * fix: distropref method "goto" now inherits CALLED_FOR and other
  attributes from caller

  * fix: correct a buggy version comparison when testing version of
  Net::Ping

  * portability fix: ensure that Compress::Zlib supports gzopen()

  * internal fix: never overwrite internal attribute CALLED_FOR (no
  known user-relevant implications)

  * tiny test fixed uncovered by cpantesters, various tiny typo
  corrections

  * a couple of new and updated distroprefs files

4 years agoUpdate IO-Compress to CPAN version 2.086
Chris 'BinGOs' Williams [Mon, 3 Jun 2019 12:07:59 +0000 (13:07 +0100)]
Update IO-Compress to CPAN version 2.086

  [DELTA]

  2.086 31 March 2019

      * IO::Compress::Zip & IO::Uncompress::Unzip
        Added support for Language Encoding Flag via the EFS option.
        Starting point was pull request https://github.com/pmqs/IO-Compress/pull/1

      * zipdetails - some support for MVS (Z390) zip files

      * IO::Uncompress::Base
        Issue with trailing data after zip archive
        #128626 for IO-Compress: mainframe zip archive

      * t/cz-14gzopen.t
        cperl error found in http://www.cpantesters.org/cpan/report/448cafc4-3108-11e9-9b6b-d3d33d7b1231
        Perl has this: "Not enough arguments for Compress::Zlib::gzopen"
        cperl uses this: "Not enough arguments for subroutine entry Compress::Zlib::gzopen"

      * Handlers being called when optional modules are not installed
        #128538:  $SIG{__DIE__}

      *  #128194: Beef up diag when system returns error

      * Moved source to github https://github.com/pmqs/IO-Compress

      * Add META_MERGE to Makefile.PL

      * Added meta-json.t & meta-yaml.t

4 years agoUpdate Compress-Raw-Bzip2 to CPAN version 2.086
Chris 'BinGOs' Williams [Mon, 3 Jun 2019 12:05:30 +0000 (13:05 +0100)]
Update Compress-Raw-Bzip2 to CPAN version 2.086

  [DELTA]

  2.086 31 March 2019

      * Moved source to github https://github.com/pmqs/Compress-Raw-Bzip2

      * Add META_MERGE to Makefile.PL

      * Added meta-json.t & meta-yaml.t

4 years agoUpdate Compress-Raw-Zlib to CPAN version 2.086
Chris 'BinGOs' Williams [Mon, 3 Jun 2019 12:03:49 +0000 (13:03 +0100)]
Update Compress-Raw-Zlib to CPAN version 2.086

   [DELTA]

2.086 31 March 2019

      * Moved source to github https://github.com/pmqs/Compress-Raw-Zlib

      * Add META_MERGE to Makefile.PL

      * Added meta-json.t & meta-yaml.t

4 years agoUpdate podlators to CPAN version 4.12
Chris 'BinGOs' Williams [Mon, 3 Jun 2019 11:15:03 +0000 (12:15 +0100)]
Update podlators to CPAN version 4.12

  [DELTA]

podlators 4.12 (2019-05-31)

    Skip the man/no-encode.t test if Encode is already loaded while
    running the test suite, which seems to happen sometimes with CPAN
    Testers tests.

4 years agoUpdate Pod-Simple to CPAN version 3.38
Chris 'BinGOs' Williams [Mon, 3 Jun 2019 11:12:07 +0000 (12:12 +0100)]
Update Pod-Simple to CPAN version 3.38

  [DELTA]

  * Release 3.38
2019-05-30 Karl Williamson <khw@cpan.org>
  Removed some alien files that somehow got in the tar, including a copy
  of Pod::Escapes.  Spotted by Petr Pisar++

  * Release 3.37
2019-05-30 Karl Williamson <khw@cpan.org>
  Suppressed some expected diagnostics under harness
  Pod::Simple now depends on the 'if' module

4 years agoperldelta for 027471cf1095
Tony Cook [Mon, 3 Jun 2019 06:16:49 +0000 (16:16 +1000)]
perldelta for 027471cf1095

4 years ago(perl #133913) limit numeric format results to INT_MAX
Tony Cook [Wed, 20 Mar 2019 05:47:49 +0000 (16:47 +1100)]
(perl #133913) limit numeric format results to INT_MAX

The return value of v?snprintf() is int, and we pay attention to that
return value, so limit the expected size of numeric formats to
INT_MAX.

4 years agoperldelta for 94a2f6a3c87a
Tony Cook [Mon, 3 Jun 2019 05:33:07 +0000 (15:33 +1000)]
perldelta for 94a2f6a3c87a

4 years ago(perl #134048) prevent an erroneous assertion on OP_SCALAR
Tony Cook [Wed, 24 Apr 2019 01:05:21 +0000 (11:05 +1000)]
(perl #134048) prevent an erroneous assertion on OP_SCALAR

4 years agoperldelta for 9dfe0a3438ae, b0f5b1daacb2
Tony Cook [Mon, 3 Jun 2019 05:09:13 +0000 (15:09 +1000)]
perldelta for 9dfe0a3438aeb0f5b1daacb2

4 years ago(perl #134008) an alternative test
Tony Cook [Mon, 3 Jun 2019 04:34:17 +0000 (14:34 +1000)]
(perl #134008) an alternative test

4 years ago[#134008] More carefully ignore negative precision in sprintf
Hugo van der Sanden [Tue, 9 Apr 2019 13:27:41 +0000 (14:27 +0100)]
[#134008] More carefully ignore negative precision in sprintf

Check has_precis more consistently; ensure precis is left as 0 if provided
as a negative number.

4 years agoPorting/bisect-runner.pl: Add doc clarification
Karl Williamson [Mon, 3 Jun 2019 01:05:55 +0000 (19:05 -0600)]
Porting/bisect-runner.pl: Add doc clarification

4 years ago/\p{InFoo} should only match blocks, or be user-defined
Karl Williamson [Mon, 3 Jun 2019 00:51:21 +0000 (18:51 -0600)]
/\p{InFoo} should only match blocks, or be user-defined

For a property \p{Block=Foo}, we allow the synonym  \p{InFoo} as
documented variously, including perluniprops, even though this usage is
discouraged, as a new Unicode release used in a new version of Perl
could cause the synonym to no longer work.

Prior to this commit, we erroneously allowed the synonym for other
properties, such as \p{InKana} or \p{InS}.

4 years agoUpdate ExtUtils-MakeMaker to CPAN version 7.36
Chris 'BinGOs' Williams [Sun, 2 Jun 2019 08:41:35 +0000 (09:41 +0100)]
Update ExtUtils-MakeMaker to CPAN version 7.36

  [DELTA]

7.36  Sun Apr 28 16:28:20 BST 2019

    No changes since v7.35_14

    This release was made possible by the kind
    sponsors of the 2019 Perl Toolchain Summit
    held in Marlow, UK:

    Booking.com, cPanel, MaxMind, FastMail, ZipRecruiter,
    Cogendo, Elastic, OpenCage Data, Bluehost, Perl Services,
    Zoopla, Archer Education, OpusVL, Oetiker+Partner, YEF

7.35_14 Sun Apr 28 14:12:22 BST 2019

    Win32 fixes:
    - Add ExtUtils::PL2Bat path to pl2bat when PERL_CORE

7.35_13 Sun Apr 28 11:57:57 BST 2019

    Bug fixes:
    - Suppress warnings from EUMM::Locale code page workaround

7.35_12 Sat Apr 27 22:37:26 BST 2019

    Enhancements:
    - add AppVeyor CI configuration
      see <https://github.com/rivy/CI.AppVeyor.helpers-perl> for more information

    Bug fixes:
    - Resolve RTs 127028 && 127316 on Mojave system perl
    - Honour man page disablement under INSTALL_BASE
    - fix `dmake` warning by removing dmake-superfluous ".NOTPARALLEL" target
    - suppress inherited AUTOLOAD warning for 'Win32::ConsoleCP()'
    - fix perl image (aka, executable) quoting for `dmake` builds
    - skip broken test for Win32 strawberry perl v5.10 (and some earlier versions)
    - add workaround to ExtUtils::MakeMaker::Locale for code pages 'cp65000' and 'cp65001'

7.35_11 Thu Apr 25 11:53:59 BST 2019

    Bug fixes:
    - Fix RT#128004 gcc AIX builds broken

7.35_10 Wed Feb 20 10:03:50 GMT 2019

    Test fixes:
    - Skip "merged /usr" tests on MSWin32

7.35_09 Mon Feb 18 10:05:42 GMT 2019

    Bug fixes:
    - stringify version before comparing

    Test fixes:
    - Changed wording of skip message for xsstatic

    QA fixes:
    - travis is deprecating container-based environments

7.35_08 Thu Dec  6 10:22:02 GMT 2018

    Enhancements:
    - propagate all variables used by Buildroot to subdirs

7.35_07 Fri Nov 23 11:34:27 GMT 2018

    Bug fixes:
    - Avoid mangling /bin non-perl shebangs on merged-/usr systems

    VMS fixes:
    - Handle PERL_ARCHLIBDEP and DESTINSTALL... macros on VMS.
    - Remove trailing space from multi-in.PL in PL_FILES.t
    - Skip "merged /usr" tests on VMS.

7.35_06 Thu Jul 19 20:30:55 BST 2018

    Enhancements:
    - Override shebang with PERL_MM_SHEBANG=relocatable env var

    Bug fixes:
    - Refactored Liblist::Kid tests, enabling UNIX testing

7.35_05 Tue Jul 10 09:44:25 BST 2018

    Win32 fixes:
    -  add Visual C parallel building support

7.35_04 Mon Jul  9 10:21:59 BST 2018

    Bug fixes:
    - Fix manification on MSWin32

    Doc fixes:
    - Mention manifypods target in FAQ for
      man creation on non-un*x OS

7.35_03 Fri Apr 27 14:28:21 BST 2018

    Enhancements:
    - Allow specifying extra inputs for PL_FILES scripts

7.35_02 Tue Apr 24 11:38:39 BST 2018

    Core fixes:
    - Win32 fixes for gmake 4.2.1 in quoting literals

7.35_01 Thu Apr 19 13:17:35 BST 2018

    Core fixes:
    - use tr instead of eval on $VERSION
    - Fix PUREPERL_ONLY warnings

4 years agoUse of code points over 0xFF in string bitwise operators
James E Keenan [Mon, 27 May 2019 17:18:10 +0000 (13:18 -0400)]
Use of code points over 0xFF in string bitwise operators

Implement complete fatalization.  Some instances of these were fatalized
in 5.28.  However, in cases where the wide characters did not affect the
end result, no deprecation notice was raised.  So they remained legal,
though deprecated.  Now, all occurrences are fatal (as of 5.32).

Modify source code in doop.c.  Adapt test file.  Update perldiag and
perldeprecation.

For:  RT 134140

(Commiter changed a verb to past tense in the pod)

4 years agorefer Time::HiRes RT queue to perl core
Graham Knop [Fri, 20 Apr 2018 13:17:58 +0000 (15:17 +0200)]
refer Time::HiRes RT queue to perl core

4 years agoAdd unit test for compiled once RegExp
Nicolas R [Fri, 31 May 2019 15:42:32 +0000 (09:42 -0600)]
Add unit test for compiled once RegExp

Make sure that when using a Regexp with /o
the RegExp is frozen as expected.

Using a BEGIN block to freeze the RegExp
is also providing extra code coverage for the
perl compiler.

4 years agoregcomp.c: White-space only
Karl Williamson [Fri, 31 May 2019 14:13:05 +0000 (08:13 -0600)]
regcomp.c: White-space only

Outdent since previous commit removed an enclosing block

4 years agoSplit ANYOFH regnode into two types
Karl Williamson [Sun, 31 Mar 2019 00:45:20 +0000 (18:45 -0600)]
Split ANYOFH regnode into two types

ANYOFHb will be for nodes where all the matching code points share the
frst UTF-8 byte.  ANYOFH will be for all others.  Neither of these has a
bitmap.

I noticed that we can omit some execution conditionals by splitting the
nodes.

4 years ago[PATCH] Remove vestiges of mpeix support (removed in 5.17.x)
Richard Leach [Fri, 31 May 2019 01:06:19 +0000 (21:06 -0400)]
[PATCH] Remove vestiges of mpeix support (removed in 5.17.x)

4 years agoMerge branch 'autodoc' into blead
Karl Williamson [Fri, 31 May 2019 00:14:00 +0000 (18:14 -0600)]
Merge branch 'autodoc' into blead

This branch cleans up a bunch of the autodoc handling.

It had its genesis in an obscure warning from Devel::PPPort:

    mysterious name

It turns out that the pod entry for the macros the warnings are for are
improper.  My guess is that it was a kludge by someone looking for a
quick way to get their usage point across, when the underlying
infrastructure was deficient in allowing it.  But it looked to be fairly
easy to enhance that infrastructure.

But then I noticed that some of the flags in the embed.fnc entries have
different meanings than the equivalent =for apidoc entries in the
source.

Here are most of the conflicts:
Flag embed.fnc =for apidoc
n no pTHX don't output empty parens for no arguments
s S_ static fcn output a semi-colon at the end of the usage entry
x Don't export experimental

I imagine that they started out the same, and diverged over the years,
as there was no unified place where they were documented.  Devel::PPPort
was unaware of this divergence, and so got some things wrong, and had
some code expecting one flag, and other code expecting the other.

This branch changes the flags in embed.fnc to correspond with what
autdoc wants, and brings everything else that uses them into
conformance.  embed.fnc is a more contained place to change, and I
couldn't find anything in CPAN that would be bothered by this.  And
also, if D:P were to be regenerated on an older perl, it still would use
the new embed.fnc shipped with it, but would be using the flags from the
older perl source code, so it had to be embed.fnc that changed.

The O flag in embed.fnc can then be used instead of having another flag
in the =for apidoc entries for the situation of having deprecated
'perl_' prefixes, removing the need for autodoc to have to try to figure
it out, and there were places where it had been getting it wrong.

Once that was done, the flags in embed.fnc could override the ones in
the =for api entries, as every flag has the same meaning in both places.
Doing so showed a bunch of errors, mostly missing 'const's in the
parameters, but, besides the 'perl_' prefix errors, some functions were
not listed as needing to be called with the 'Perl_' prefix.  The flags
in embed.fnc have to be pretty accurate, or perl won't compile.

I then removed about 150 redundant =for apidoc entries.  It is a waste
having them in the code twice, and they do get out of sync.  Note that
there does need to be an entry like

    =for apidoc FOO

for the autodoc facility to know where the actual pod for a given
function is.  And the entry needs to have the flags, return value, and
argument list detailed if and only if FOO isn't in embed.fnc.  I myself
didn't know that if omitted, the values in embed.fnc were used, so I
wasted time in the past duplicating these.  Now, if there's duplication
autodoc will warn.

autodoc did check for a couple of discrepancies if there were two
entries, but that code is now unnecessary and has been ripped out.

I added a flag so that something that isn't a straight name can be
documented, and will rip out the code in D:P that special-cased the few
existing entries that were like this.  Now there is a warning from
autodoc, unless the flag is present, when this happens, so that
'mysterious name' won't show up again.

I added another flag to make it easier to deal with functions that have
become wrappers for others, and there is a macro that bypasses the
original one, but for back compat, we still have the original.

autodoc did not realize that you could have things like
Perl_sprintf_nocontext() without a pTHX.  That flag already is in
embed.fnc, and now autodoc uses it.

Finally, I added extensive comments to embed.fnc to document all the
flags, and removed other outdated comments elsewhere in favor of a
pointer to the comments in embed.fnc

4 years agoperlguts: Remove documentation about embed.fnc flags
Karl Williamson [Thu, 30 May 2019 01:11:04 +0000 (19:11 -0600)]
perlguts: Remove documentation about embed.fnc flags

embed.fnc now has sufficient comments within it.  Anyone changing that
file will see those comments first.  Having them redundantly explained
here adds little value, and is out-of-date.  So just remove them, with a
ptr to embed.fnc

4 years agoembed.fnc: Add more extensive comments
Karl Williamson [Thu, 30 May 2019 01:10:19 +0000 (19:10 -0600)]
embed.fnc: Add more extensive comments

This revises the comments significantly to better inform the reader.

4 years agoRemove redundant info on =for apidoc lines
Karl Williamson [Thu, 30 May 2019 00:33:25 +0000 (18:33 -0600)]
Remove redundant info on =for apidoc lines

This information is already in embed.fnc, and we know it compiles.  Some
of this information is now out-of-date.  Get rid of it.

There was one bit of information that was (apparently) wrong in
embed.fnc.  The apidoc line asked that there be no usage example
generated for newXS.  I added that flag to the embed.fnc entry.

4 years agoautodoc.pl: Use embed.fnc entry when available
Karl Williamson [Wed, 29 May 2019 22:06:51 +0000 (16:06 -0600)]
autodoc.pl: Use embed.fnc entry when available

Having two different pod definitions for the same function leads to
things being out of sync.  This commit ignores the one in the '=for
apidoc' line if there is one in embed.fnc.

Doing so led to a bunch of changes in perlapi, showing that the apidoc
lines were inaccurate.  The ones in embed.fnc must be accurate enough to
get perl to compile.

I added a warning for when there's a redundant entry, and in the next
commit I will remove the many such.

4 years agoautodoc.pl: Add N flag
Karl Williamson [Wed, 29 May 2019 22:01:34 +0000 (16:01 -0600)]
autodoc.pl: Add N flag

This adds a check that the macro or function name for the pod entry is a
legitimate name, as almost all are.  If this had been in effect, the bug
fixed by the previous commit would not have been necessary.

But there are a very few things that are documented that aren't strict
names.  This adds a flag so that autodoc can be notified to not warn on
them.  This will allow Devel::PPPort to not have to special case
situations like this, which it now does.

4 years agoautodoc.pl: Check for misuse of the 'n' flag
Karl Williamson [Wed, 29 May 2019 21:58:20 +0000 (15:58 -0600)]
autodoc.pl: Check for misuse of the 'n' flag

This flag indicates that the macro has no arguments.  It makes no sense
to use in some situations, which are now checked for.

This commit also documents the long existing 'n' flag.

4 years agoautodoc.pl: Make 's' flag independent of 'n'
Karl Williamson [Wed, 29 May 2019 21:50:45 +0000 (15:50 -0600)]
autodoc.pl: Make 's' flag independent of 'n'

The 's' flag is used by autodoc.pl to add a semi-colon to the end of a
usage example.  This commit allows that to happen even if the macro has
parameters.

This allows two macros in scope.c to be properly documented.  Previously
they weren't, and caused warnings in Devel::PPPort as a result.

This commit adds documentation to embed.fnc for the 's' flag, which has
long existed, undocumented.

4 years agoautodoc.pl: Notice the no-thread context flag
Karl Williamson [Wed, 29 May 2019 21:41:23 +0000 (15:41 -0600)]
autodoc.pl: Notice the no-thread context flag

I realized reading the code that it would be possible for a function
definition to be wrongly output if it isn't called with a thread context
variable.  The information for that is already in embed.fnc, and so we
just have to use it to avoid printing the variable if not present

4 years agoembed.fnc: Add flag for bypass macro existence
Karl Williamson [Wed, 29 May 2019 21:28:44 +0000 (15:28 -0600)]
embed.fnc: Add flag for bypass macro existence

Sometimes a function is reduced to be a wrapper, and we want for code to
directly call the underlying one, but we retain the old 'Perl_foo'
function to avoid breaking code that used that form.  I've tried various
kludges around that, but this seems more promising.

4 years agoautodoc.pl: Use O flag from embed.fnc for warning
Karl Williamson [Wed, 29 May 2019 21:05:05 +0000 (15:05 -0600)]
autodoc.pl: Use O flag from embed.fnc for warning

This is for ancient 'perl_' forms of function calls, which is
deprecated.  It turns out that there were a couple of entries that were
getting this warning when that form doesn't even exist.

4 years agoLet embed.fnc define the my_str_foo() fcns
Karl Williamson [Wed, 29 May 2019 20:49:57 +0000 (14:49 -0600)]
Let embed.fnc define the my_str_foo() fcns

We don't always define a Perl_ form for these, expecting all calls to be
made through the macro, which will use the native form on the systems
that have one.

Removing these extra #defines helps future commits

4 years agoembed.fnc: Change M flag to x
Karl Williamson [Wed, 29 May 2019 16:14:55 +0000 (10:14 -0600)]
embed.fnc: Change M flag to x

The M flag in embed.fnc and the x flag in the '=for apidoc' lines both
mean the same, thing, the entity may change, it is experimental.
Devel::PPPort in places uses the M flag, and in other places, the x.
That will be fixed in a separate commit.

This commit changes the 'M' in embed.fnc to be 'x'.  Changing embed.fnc
and makedef.pl keeps the changes more contained, and lessens the chance
that some module will be adversely affected (I didn't see anything
likely in grepping cpan).

4 years agoembed.fnc: Change x flag to e
Karl Williamson [Wed, 29 May 2019 04:02:57 +0000 (22:02 -0600)]
embed.fnc: Change x flag to e

autodoc.pl has the x flag in the '=for apidoc' lines mean something
completely different, but Devel::PPPort combines both these lines and
the contents of embed.fnc into one file, expecting the flags to be
consistent.

This commit changes the 'x' in embed.fnc to be 'e', which means to not
export this function.  Changing embed.fnc and makedef.pl keeps the
changes more contained, and lessens the chance that some module will be
adversely affected (I didn't see anything likely in grepping cpan).

4 years agoembed.fnc: Change s flag to S
Karl Williamson [Wed, 29 May 2019 02:28:07 +0000 (20:28 -0600)]
embed.fnc: Change s flag to S

autodoc.pl has the s flag in the '=for apidoc' lines mean something
completely different, but Devel::PPPort combines both these lines and
the contents of embed.fnc into one file, expecting the flags to be
consistent.

This commit changes the 's' in embed.fnc to be 'S', which means the
function is static and has an 'S_' prefix.  Changing embed.fnc keeps the
changes more contained, and lessens the chance that some module will be
adversely affected (I didn't see anything likely in grepping cpan).

4 years agocroak_memory_wrap is an inline function.
Karl Williamson [Wed, 29 May 2019 02:52:07 +0000 (20:52 -0600)]
croak_memory_wrap is an inline function.

Update embed.fnc to correspond

4 years agoembed.fnc: Change n flag to T
Karl Williamson [Wed, 29 May 2019 02:03:58 +0000 (20:03 -0600)]
embed.fnc: Change n flag to T

autodoc.pl has the n flag in the '=for apidoc' lines mean something
completely different, but Devel::PPPort combines both these lines and
the contents of embed.fnc into one file, expecting the flags to be
consistent.

This commit changes the 'n' in embed.fnc to be 'T', which means no
thread context passed.  Changing embed.fnc keeps the changes more
contained, and lessens the chance that some module will be adversely
affected (I didn't see anything likely in grepping cpan).

4 years agoAdd 'n' flag to various =for apidoc lines
Karl Williamson [Tue, 28 May 2019 18:55:19 +0000 (12:55 -0600)]
Add 'n' flag to various =for apidoc lines

This indicates to not output the macro with parentheses for parameters.
Currently that doesn't happen anyway, but a future commit will change
things so this is required (so that a bug can be fixed)

4 years agoautodoc.pl: Strip, lead/trail space from =for apidoc
Karl Williamson [Tue, 28 May 2019 17:02:42 +0000 (11:02 -0600)]
autodoc.pl: Strip, lead/trail space from =for apidoc

The components of a =for apidoc entry can have spaces between the '|'
separators.  Ignore them.

4 years agoautodoc.pl: White-space only
Karl Williamson [Tue, 28 May 2019 16:42:21 +0000 (10:42 -0600)]
autodoc.pl: White-space only

This indents to correspond with the new block formed by the previous
commit.

4 years agoautodoc.pl: Refactor slightly
Karl Williamson [Tue, 28 May 2019 16:35:57 +0000 (10:35 -0600)]
autodoc.pl: Refactor slightly

This breaks a chain of 'elsif' lines so that they are all now part of an
'else' from the first 'if'.  This is in preparation for a later commit.

4 years agoautodoc.pl: Change name of variable
Karl Williamson [Tue, 28 May 2019 16:21:56 +0000 (10:21 -0600)]
autodoc.pl: Change name of variable

This makes it clear that the source for the lines being processed is
embed.fnc

4 years agoUse of strings with code points over 0xFF as arguments to "vec"
James E Keenan [Mon, 27 May 2019 02:30:40 +0000 (22:30 -0400)]
Use of strings with code points over 0xFF as arguments to "vec"

Implement scheduled fatalization.  Adapt existing tests in t/op/vec.t.
Eliminate t/lib/warnings/doop and move one test to t/op/vec.t.

Document this fatalization in perldiag and perlfunc.

Documentation improvement recommended by Karl Williamson.

For: RT # 134139

4 years agoPATCH: [perl #119439] Remove Pod::Parser from core
Karl Williamson [Thu, 30 May 2019 18:42:19 +0000 (12:42 -0600)]
PATCH: [perl #119439] Remove Pod::Parser from core

Pod::Simple now has the needed capabilities to completely replace
Pod::Parser.

4 years agopod/perlpod: Add advice about Z<> uses
Karl Williamson [Fri, 1 Jun 2018 17:31:12 +0000 (11:31 -0600)]
pod/perlpod: Add advice about Z<> uses

4 years agopodcheck.t: Stop using Pod::Parser
Karl Williamson [Sat, 19 May 2018 20:58:37 +0000 (14:58 -0600)]
podcheck.t: Stop using Pod::Parser

There now exists a replacement for the one remaining use of Pod::Parser
in this file, Pod::Simple::JustPod.

4 years agopodcheck.t: Sort some output for consistency
Karl Williamson [Thu, 10 May 2018 01:29:09 +0000 (19:29 -0600)]
podcheck.t: Sort some output for consistency

4 years agopodcheck.t: Typos, white-space, comment
Karl Williamson [Thu, 10 May 2018 01:28:24 +0000 (19:28 -0600)]
podcheck.t: Typos, white-space, comment

4 years agoperldelta for fb5e77103dd4, 35608a1658fe
Tony Cook [Thu, 30 May 2019 00:33:40 +0000 (10:33 +1000)]
perldelta for fb5e77103dd435608a1658fe

4 years ago(perl #122112) a simpler fix for pclose() aborted by a signal
Tony Cook [Wed, 8 May 2019 23:52:30 +0000 (09:52 +1000)]
(perl #122112) a simpler fix for pclose() aborted by a signal

This change results in a zombie child process for the lifetime of
the process, but I think that's the responsibility of the signal
handler that aborted pclose().

We could add some magic to retry (and retry and retry) waiting on
child process as we rewind (since there's no other way to remove
the zombie), but the program has chosen implicitly to abort the
wait() done by pclose() and it's best to honor that.

If we do choose to retry the wait() we might be blocking an attempt
by the process to terminate, whether by exit() or die().

If a program does need more flexible handling there's always
pipe()/fork()/exec() and/or the various event-driven frameworks on
CPAN.

4 years ago(perl #122112) test for signal handler death in pclose
Tony Cook [Wed, 30 May 2018 04:03:04 +0000 (14:03 +1000)]
(perl #122112) test for signal handler death in pclose

4 years agoMake sv_mortalcopy_flags() public
Pali [Thu, 7 Feb 2019 13:22:55 +0000 (14:22 +0100)]
Make sv_mortalcopy_flags() public

4 years agoRemove remaining assignments to SvCUR and SvLEN in core
Dagfinn Ilmari Mannsåker [Thu, 19 Oct 2017 09:48:49 +0000 (10:48 +0100)]
Remove remaining assignments to SvCUR and SvLEN in core

Also make the macros non-lvalues under PERL_CORE