Nicholas Clark [Fri, 21 May 2010 19:32:28 +0000]
PL_in_load_module only has values 0 and 1, so can be a bool instead of int.
Nicholas Clark [Sat, 13 Mar 2010 11:23:46 +0000]
Perl_hv_fill(), count empty chains down, rather than used chains up.
The assumption is that most chains of a hash are in use.
Suggestion and initial patch by Ruslan Zakirov.
Nicholas Clark [Sun, 24 Jan 2010 15:39:53 +0000]
Eliminate xhv_fill from struct xpvhv.
Nicholas Clark [Sun, 24 Jan 2010 15:07:50 +0000]
Make HvFILL() count the allocated buckets, instead of reading a stored value.
Add a function Perl_hv_fill to perform the count. This will save 1 IV per hash,
and on some systems cause struct xpvhv to become cache aligned.
Nicholas Clark [Sun, 24 Jan 2010 10:50:02 +0000]
Replace boolean use of HvFILL(hv) with HvTOTALKEYS(hv), which is equivalent.
David Mitchell [Fri, 21 May 2010 16:07:40 +0000]
followup to magic/overload fix
6f1401dc2acd2a2b85df22b0a74e5f7e6e0a33aa was over-enthusiastic
on removing redundant code in the comparison ops. This code was only used
on 64-bit #ifdef branches which is why I failed to spot it earlier.
So restore that code!
David Mitchell [Fri, 21 May 2010 13:18:21 +0000]
make overload respect get magic
In most places, ops checked their args for overload *before* doing
mg_get(). This meant that, among other issues, tied vars that
returned overloaded objects wouldn't trigger calling the
overloaded method. (Actually, for tied and arrays and hashes, it
still often would since mg_get gets called beforehand in rvalue
context).
This patch does the following:
Makes sure get magic is called first.
Moves most of the overload code formerly included by macros at the
start of each pp function into the separate helper functions
Perl_try_amagic_bin, Perl_try_amagic_un, S_try_amagic_ftest,
with 3 new wrapper macros:
tryAMAGICbin_MG, tryAMAGICun_MG, tryAMAGICftest_MG.
This made the code 3800 bytes smaller.
Makes sure that FETCH is not called multiple times. Much of this
bit was helped by some earlier work from Father Chrysostomos.
Added new functions and macros sv_inc_nomg(), sv_dec_nomg(),
dPOPnv_nomg, dPOPXiirl_ul_nomg, dPOPTOPnnrl_nomg, dPOPTOPiirl_ul_nomg
dPOPTOPiirl_nomg, SvIV_please_nomg, SvNV_nomg (again, some of
these were based on Father Chrysostomos's work).
Fixed the list version of the repeat operator (x): it now only
calls overloaded methods for the scalar version:
(1,2,$overloaded) x 10
no longer erroneously calls
x_method($overloaded,10))
The only thing I haven't checked/fixed yet is overloading the
iterator operator, <>.
Nicholas Clark [Tue, 26 Jan 2010 17:03:41 +0000]
Remove union _xivu from _XPVCV_COMMON, and hence structs xpvcv and xpvfm
Replaced with xcv_depth and xfm_lines respectively. Both structures might
benefit from some field re-ordering.
Update the descriptive comments in the definition of union _xivu.
Nicholas Clark [Tue, 26 Jan 2010 16:28:59 +0000]
Remove union _xivu from struct regexp - replace it with a non-union paren_names.
This was the only user of xivu_hv in union _xivu, so remove that too.
Nicholas Clark [Mon, 25 Jan 2010 14:28:30 +0000]
Remove union _xivu from struct xpvhv - replace it with a non-union xav_keys.
Nicholas Clark [Mon, 25 Jan 2010 13:55:28 +0000]
Remove union _xivu from struct xpvav - replace it with a non-union xav_alloc.
This was the only user of xivu_p1 in union _xivu, so remove that too.
Nicholas Clark [Mon, 25 Jan 2010 13:30:16 +0000]
Reinstate space optimisations to SV body structures.
Nicholas Clark [Mon, 25 Jan 2010 09:27:56 +0000]
In the SV body, exchange the positions of the NV and stash/magic.
Nicholas Clark [Fri, 22 Jan 2010 15:31:49 +0000]
Remove all space optimisations from SV body structures.
H.Merijn Brand [Fri, 21 May 2010 06:01:54 +0000]
The size of a character in C is per definition 1
Sisyphus [Fri, 21 May 2010 00:56:07 +0000]
Fix CCINCDIR and CCLIBDIR for mingw64 cross compiler
When building perl with the mingw64 x64 cross-compiler 'incpath', 'libpth',
'ldflags', 'lddlflags' and 'ldflags_nolargefiles' values in Config.pm and
Config_heavy.pl are not being set correctly because, with that compiler, the
include and lib directories are not immediately below $(CCHOME).
Zefram [Thu, 20 May 2010 20:48:03 +0000]
fully test package-version-block syntax
Extend the exhaustive package-version tests in t/op/packagev.t
to test each case using package-block syntax in addition to the
package-declaration syntax.
Zefram [Sat, 1 May 2010 16:51:21 +0000]
additional tests for package block syntax
Test that __PACKAGE__ propagates into string eval correctly. Test that
__LINE__ is correct. Test that goto into and out of package blocks
works correctly.
Zefram [Sat, 1 May 2010 16:30:26 +0000]
fix SEGV with eval("package Foo {")
OPs relating to the package name and version were subject to double
freeing during error recovery from an incomplete package block. Fixed by
using the op_latefree mechanism to shift the op free time.
Zefram [Mon, 19 Apr 2010 19:37:25 +0000]
support "package Foo { ... }"
Package block syntax limits the scope of the package declaration to the
attached block. It's cleaner than requiring the declaration to come
inside the block.
Nicholas Clark [Tue, 23 Feb 2010 20:35:29 +0000]
PL_endav can be NULL, so in S_ithread_create() no need to set it to newAV().
Nicholas Clark [Sat, 13 Feb 2010 09:05:18 +0000]
Remove redundant hv_exists() calls from ithread_create()'s spec parser.
hv_fetch(..., 0) won't create the element if it doesn't exist, returning a NULL
pointer, so hv_exists() and hv_fetch() is doing two hash lookups where one would
suffice.
On this machine, reduces the object code by 3K, about 7%. Everyone's a winner.
Nicholas Clark [Sat, 13 Feb 2010 08:31:55 +0000]
Change S_ithread_create() params from a single AV* to a pair of SV** pointers.
This saves creating, duplicating and freeing and AV, which is only ever used for
an internal calling convention.
Nicholas Clark [Sat, 13 Feb 2010 08:01:45 +0000]
In threads.xs, convert thread->params from RV to AV.
Pass around and store the array directly, rather than creating, holding and
dereferencing a reference to it.
Nicholas Clark [Tue, 26 Jan 2010 12:00:56 +0000]
SvIVX() isn't valid on SVt_REGEXP
Nicholas Clark [Mon, 25 Jan 2010 10:53:33 +0000]
In sv.c, _all_ {new,del}_X* macros can be *_body_allocated.
Previously those where bodies_by_type[sv_type].offset was zero were using
{new,del}_body_typed. However, the optimiser can spot this, and generates the
same object code. This allows simplification of the C code, and more
flexibility to rearrange the structures without generating bugs.
Ricardo Signes [Thu, 20 May 2010 14:14:39 +0000]
update Ricardo Signes's email
Rafael Garcia-Suarez [Wed, 19 May 2010 18:36:12 +0000]
Do not try to load a feature bundle when doing "no VERSION"
Ricardo Signes [Thu, 20 May 2010 12:29:40 +0000]
do not check for deprecation of removed lib
Ricardo Signes [Thu, 20 May 2010 11:49:35 +0000]
add the v5.13.1 epigraph
Ricardo Signes [Thu, 20 May 2010 11:47:09 +0000]
remove =over/=back from epigraphs.pod, add empty sections
...even though they are *totally legal* and the suggested way to make a
blockquote-like paragraph. Pod::Checker doesn't like them.
Ricardo Signes [Thu, 20 May 2010 11:25:47 +0000]
add new release to perlhist
Ricardo Signes [Thu, 20 May 2010 11:24:16 +0000]
update MANIFEST, remove delta for uninstalled file
Ricardo Signes [Thu, 20 May 2010 11:18:17 +0000]
further updates to CoreList
Who knew there was a helper to do this, now!
Ricardo Signes [Thu, 20 May 2010 11:06:16 +0000]
Update META.yml
Notice the glorious deletion of Switch from the manifest!
Ricardo Signes [Thu, 20 May 2010 11:01:43 +0000]
bump CoreList version
Ricardo Signes [Thu, 20 May 2010 11:00:42 +0000]
add vertical space to CoreList.pm
This makes it easy to move through the file with { and } in vi.
Yes, this really helps.
Ricardo Signes [Thu, 20 May 2010 04:50:55 +0000]
remove empty perldelta section
Ricardo Signes [Thu, 20 May 2010 04:50:44 +0000]
update change command
Ricardo Signes [Thu, 20 May 2010 04:45:27 +0000]
Bump the perl version in various places for 5.13.1
Ricardo Signes [Thu, 20 May 2010 04:31:11 +0000]
replace 2nd 5.013000 block with 5.013001
Ricardo Signes [Thu, 20 May 2010 04:29:02 +0000]
update CoreList for 5.13.1
Ricardo Signes [Thu, 20 May 2010 04:28:42 +0000]
bump version on modules changed since 5.13.0
Ricardo Signes [Thu, 20 May 2010 04:12:47 +0000]
pass through perl5131delta in prep of release
Vincent Pit [Thu, 20 May 2010 00:44:22 +0000]
Add a note in perl5131delta about given return values
And tweak its documentation.
Curtis Jewell [Mon, 17 May 2010 07:55:28 +0000]
Adding script used for recent perlhist changes.
Curtis Jewell [Mon, 17 May 2010 07:50:19 +0000]
Update perlhist.pod for 5.10.1-5.12.1
David Golden [Wed, 19 May 2010 21:04:35 +0000]
bumped File::Find version to 1.16
Dan Dascalescu [Tue, 18 May 2010 22:12:19 +0000]
Fixed typo: "effecting data" -> "affecting data".
Vincent Pit [Wed, 19 May 2010 20:59:58 +0000]
Merge branch 'vincent/rvalue_stmt_given' into blead
Nicholas Clark [Wed, 19 May 2010 19:02:59 +0000]
perldelta entries for my changes in 5.13.1.
David Golden [Wed, 19 May 2010 16:30:31 +0000]
add reminder about updating epigraphs.pod to RMG
David Golden [Wed, 19 May 2010 16:27:52 +0000]
the proper term is epigraph, not epigram
David Golden [Wed, 19 May 2010 16:20:40 +0000]
document historical release epigrams
Jesse Vincent [Tue, 18 May 2010 16:17:24 +0000]
Actually note that Shell.pm is deprecated for 5.13 and 5.14, so we can
remove it in 5.15 in the Spring of 2011.
Jesse Vincent [Tue, 18 May 2010 16:15:41 +0000]
Shell.pm was missing its deprecation warning in 5.12. So it can't be
removed in 5.14.
Revert "Remove Shell from the core distribution. Get it from CPAN now."
This reverts commit
28d302d426b73ed76fdcc816dd51bb1a8f93332b.
Jesse Vincent [Tue, 18 May 2010 15:55:15 +0000]
Merge branch 'blead' of ssh://perl5.git.perl.org/gitroot/perl into blead
* 'blead' of ssh://perl5.git.perl.org/gitroot/perl:
Fix groups.t test on AIX
further fix for RT #23810
use the correct format codes in warnings from gmtime/localtime
Better perldiag heading for "\cX" deprecation warning
PATCH: Clean up EBCDIC handling of \cX
[perl #41530] s/non-utf8/is-utf8/ fails.
Fix for README.aix and XL C/C++ V11
Jesse Vincent [Tue, 18 May 2010 15:54:01 +0000]
Adding Chris Williams as our November 2010 sucker
Rainer Tammer [Sun, 16 May 2010 09:37:57 +0000]
Fix groups.t test on AIX
'id -a' doesn't work, so try it without the -a if that fails.
David Mitchell [Mon, 17 May 2010 23:54:50 +0000]
further fix for RT #23810
The fix for #23810,
27e904532594b7fb, introduced a regression, spotted by
Nicholas as RT #75146.
Basically, in S_doeval() if the yyparse() fails due to dying (rather than
just bailing out with with a syntax error, say), then the topmost EVAL
context will have been popped. My improved error handling code mostly
understood the difference, but forgot that in the die case, PL_eval_root
will have been restored to its previous value by the CX pop, and thus
its value shouldn't be messed with.
Tony Cook [Tue, 23 Feb 2010 13:35:35 +0000]
use the correct format codes in warnings from gmtime/localtime
Rafael Garcia-Suarez [Mon, 17 May 2010 09:47:48 +0000]
Better perldiag heading for "\cX" deprecation warning
Karl Williamson [Wed, 12 May 2010 17:50:19 +0000]
PATCH: Clean up EBCDIC handling of \cX
The function perl_ebcdic_control() is unnecessary, as the toCTRL macro
that calls it can be changed to just map EBCDIC to ASCII first, and then
doing the normal procedure.
This means that EBCDIC and ASCII will no longer diverge. Currently,
EBCIDIC gives a syntax error for inputs outside its domain, whereas the
ASCII version accepts some of them.
Karl Williamson [Tue, 11 May 2010 16:57:41 +0000]
[perl #41530] s/non-utf8/is-utf8/ fails.
When the replacement is in utf8, there was failure to upgrade the result
when the source and the pattern weren't in utf8. This simply checks
that when there is a match that will lead to the replacement being done.
It then does the upgrade. If this led to changes in the source, we redo
the match because pointers to saved buffers could have changed. There
may be other cases where we don't need to redo the match, but I don't
know the code well-enough to easily figure it out.
Rainer Tammer [Fri, 14 May 2010 07:53:51 +0000]
Fix for README.aix and XL C/C++ V11
Hello,
I have attached a small doc fix for README.aix. It contains information
regarding the new XL C/C++ V11 compiler. This patch is only for bleed.
I have already posted the correct fix for maint-5.12.
Thanks.
Bye
Rainer
From
f66807e32b4c01bb58b61cb3e48d89da9c2c4bd7 Mon Sep 17 00:00:00 2001
From: Rainer Tammer <tammer@tammer.net>
Date: Fri, 14 May 2010 09:48:25 +0200
Subject: [PATCH] FIX to README.aix for V11 compiler
Signed-off-by: H.Merijn Brand <h.m.brand@xs4all.nl>
Jesse Vincent [Thu, 13 May 2010 20:00:26 +0000]
Perl 5.12.1 now includes Safe.pm 2.27. Module::CoreList should say so
Jesse Vincent [Thu, 13 May 2010 19:58:51 +0000]
New release date for 5.12.1 in light of the new RC
Jesse Vincent [Thu, 13 May 2010 17:04:37 +0000]
Merge branch 'blead' of ssh://perl5.git.perl.org/gitroot/perl into blead
* 'blead' of ssh://perl5.git.perl.org/gitroot/perl:
Return 0 (with a warning) for sprintf("%.0g") and sprintf("%.0f")
Updating list of DOSish perls in perlport.pod.
Add Porting/checkpodencoding.pl to MANIFEST
separate the 0755 from the . $TAINT0. this silences the warning "Dot after octal literal is concatenation".
Clarify that mail to perlbug also goes to p5p
Jesse Vincent [Thu, 13 May 2010 17:04:10 +0000]
Correcting the release date of 5.12.1
Nicholas Clark [Thu, 13 May 2010 11:04:55 +0000]
Return 0 (with a warning) for sprintf("%.0g") and sprintf("%.0f")
There is special case code in the sprintf implementation, for simple %f and %g
formats, conditionally compiled in only when NVs are doubles. Under long
doubles, these are handled by the general purpose code, which always returns
0 if the argument is missing. Note that sprintf(" %.0g"), ie a leading space,
sufficient to bypass the special case code, would return the string " 0".
The special case code used to return an empty string, meaning that the
behaviour of sprintf("%.0g") and sprintf("%.0f") was inconsistent between a
perl built with doubles, and a perl with long doubles, and the behaviour of
sprintf("%.0g") and sprintf(" %.0g") was inconsistent.
5b98cd54dff3b163 fixed #62874 - the special case code did not warn, but
changed behaviour to return 0.
d347ad18ecf3da70 undid the behaviour change,
viewing it as a regression. However, the tests added in
5b98cd54dff3b163
expose the inconsistency in behaviour between doubles and long doubles.
There should be no inconsistency, hence the only logically consistent
conclusion is that the special case implementation was wrong - it cannot
give results inconsistent with the general code. Hence this commit changes
it to return 0 (with a warning). This is achieved by simply skipping the
special case code, if there are insufficient arguments.
Curtis Jewell [Wed, 12 May 2010 12:55:56 +0000]
Updating list of DOSish perls in perlport.pod.
H.Merijn Brand [Tue, 11 May 2010 05:54:51 +0000]
Add Porting/checkpodencoding.pl to MANIFEST
Richard Soderberg [Wed, 28 Apr 2010 21:44:47 +0000]
separate the 0755 from the . $TAINT0. this silences the warning "Dot after octal literal is concatenation".
Ævar Arnfjörð Bjarmason [Sun, 9 May 2010 12:38:29 +0000]
Clarify that mail to perlbug also goes to p5p
The wording added in
64a8e22bd3 didn't clarify that mail to perlbug is
also forwarded to perl5-porters. Make this section clearer so that it
now explains that perlbug is just perl5-porters + RT tracking.
See the discussion after Craig A. Berry's comment in RT #73914 for
reference.
Karl Williamson [Sat, 8 May 2010 20:06:10 +0000]
PATCH [perl #74978] dot after } breaks \N{}
The problem is that a dot can come between the braces in \N{foo.bar},
but when searching for it, I didn't stop looking at the right brace, so
it generated an error inappropriately.
This is essentially a minimum patch; efficiency could be improved
slightly with a little more work.
Karl Williamson [Sat, 8 May 2010 19:38:27 +0000]
Note in comment that many \N{...} tests won't work here
Karl Williamson [Sat, 8 May 2010 19:12:53 +0000]
Comment where to find file's format
Zefram [Wed, 5 May 2010 19:41:28 +0000]
perldelta item on PL_restartjmpenv
Zefram [Wed, 5 May 2010 19:35:43 +0000]
perldelta item on $[ usage
Zefram [Wed, 5 May 2010 19:32:33 +0000]
perldelta item on B::Deparse package+label fix
Zefram [Wed, 5 May 2010 19:26:01 +0000]
perldelta item on reliable exception handling
Karl Williamson [Wed, 5 May 2010 18:16:48 +0000]
perlunifaq, uniintro: fix for 80 col display
Karl Williamson [Wed, 5 May 2010 18:15:14 +0000]
perlunicode: fix for 80 col display
Karl Williamson [Wed, 5 May 2010 18:13:02 +0000]
perlreref: missing info, 80 col display
The \p{Posix...} classes had not gotten added yet to the ref pod; there
were some reformattings to make things display properly in an 80 column
window.
Karl Williamson [Wed, 5 May 2010 18:11:02 +0000]
perlrecharclass: Clarify \p{Punct}, fix for 80 col
While not strictly wrong, the hre was missing info for what \p{Punct}
does.
Karl Williamson [Wed, 5 May 2010 18:09:47 +0000]
perlrebackslash: fix for 80 col display
Karl Williamson [Wed, 5 May 2010 18:08:53 +0000]
perlre: fix for 80 col display
Karl Williamson [Wed, 5 May 2010 18:07:42 +0000]
perlport: fix 80 col display; broken link
Karl Williamson [Wed, 5 May 2010 18:06:18 +0000]
Fix to display ok in 80 columns
Karl Williamson [Wed, 5 May 2010 18:03:16 +0000]
Fix perlebcdic for for 80 column tty; fix C<>s
Two C<>'s were unclosed
Ævar Arnfjörð Bjarmason [Tue, 30 Mar 2010 14:09:24 +0000]
Add =encoding utf8 to all core non-ASCII POD files + test script
It's now possible to run:
perl Porting/checkpodencoding.pl
To check if the core contains any naughty POD that uses non-ASCII
without declaring an encoding.
With this patch all the POD in core (except POD tests we're ignoring)
has a correct =encoding directive. The script also flags problems in
lib/* and cpan/* which aren't being fixed as part of this commit.
David Mitchell [Sat, 8 May 2010 20:25:47 +0000]
RT #34604 didn't honour tied overloaded values
A tied hash lookup could return an overloaded object but sort wouldn't
notice that it was overloaded because it checked for overload before doing
mg_get().
David Mitchell [Sat, 8 May 2010 16:23:56 +0000]
add SV_SKIP_OVERLOAD flag to sv_2*v_flags fns
While trying to coerce an SV into a string or whatever, stop if you
suddenly discover it's overloaded (this may not happen until after you've
called it's get magic)
David Mitchell [Sat, 8 May 2010 16:06:45 +0000]
add flags arg to sv_2nv (as sv_2nv_flags)
Chris 'BinGOs' Williams [Sat, 8 May 2010 13:40:24 +0000]
Modify Module::CoreList docs to state the availability of the removed_from() functions.
Chris 'BinGOs' Williams [Sat, 8 May 2010 11:57:00 +0000]
Backport patch from CPANPLUS-0.9004 to cpanp-run-perl
This resolves RT #55964 and RT #57106 relating to the failure to
install distributions that use Module::Install::DSL
The addition of a BEGIN {} block to cpanp-run-perl resolves the
issue.
Jesse Vincent [Fri, 7 May 2010 17:59:36 +0000]
Bump Module::Corelist for cherrypicking to maint-5.12
Vincent Pit [Thu, 6 May 2010 20:20:10 +0000]
Make t/op/sprintf.t test multiple warnings
Vincent Pit [Thu, 6 May 2010 20:14:31 +0000]
Stop returning 0 for sprintf("%.0g")
And also from throwing two "Missing argument" warnings for this construct.
This was a regression introduced by
5b98cd54dff3b16344eab33ce6b09fb6fb1b89c2.
Vincent Pit [Thu, 6 May 2010 20:35:14 +0000]
Really test special sprintf formats