summaryrefslogtreecommitdiff
path: root/pod/perldelta.pod
blob: bc9d233fcd4b24dac5853116039600bd41f3db14 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
=encoding utf8

=head1 NAME

perldelta - what is new for perl v5.35.2

=head1 DESCRIPTION

This document describes differences between the 5.35.1 release and the 5.35.2
release.

If you are upgrading from an earlier release such as 5.35.0, first read
L<perl5351delta>, which describes differences between 5.35.0 and 5.35.1.




=head1 Modules and Pragmata

XXX All changes to installed files in F<cpan/>, F<dist/>, F<ext/> and F<lib/>
go here.  If Module::CoreList is updated, generate an initial draft of the
following sections using F<Porting/corelist-perldelta.pl>.  A paragraph summary
for important changes should then be added by hand.  In an ideal world,
dual-life modules would have a F<Changes> file that could be cribbed.

The list of new and updated modules is modified automatically as part of
preparing a Perl release, so the only reason to manually add entries here is if
you're summarising the important changes in the module update. (Also, if the
manually-added details don't match the automatically-generated ones, the
release manager will have to investigate the situation carefully.)

[ Within each section, list entries as an =item entry ]

=head2 New Modules and Pragmata

=over 4

=item *

XXX Remove this section if not applicable.

=back

=head2 Updated Modules and Pragmata

=over 4

=item *

C<perl5db.pl> has been upgraded from version 1.60 to 1.61.

The C<v> command works again, and now has some tests.

=back


=head1 Documentation

=head2 Changes to Existing Documentation

=head3 L<perlintro>

=over 4

=item *

A number of sentences in L<perlintro> have been simplified,
to make things clearer.
Ambiguities were resolved, related to "special variables".

=back


=head1 Platform Support

The :win32 IO layer has been removed. This experimental replacement for the
:unix layer never reached maturity in its nearly two decades of existence.

=head1 Internal Changes

=over 4

=item *

The API constant formerly named C<G_ARRAY>, indicating list context, has now
been renamed to a more accurate C<G_LIST>.  A compatibilty macro C<G_ARRAY> has
been added to allow existing code to work unaffected.  New code should be
written using the new constant instead.  This is supported by C<Devel::PPPort>
version 3.63.

=item *

XXX

=back

=head1 Selected Bug Fixes

=over 4

=item *

The flags on the OPTVAL parameter to setsockopt() were previously
checked before magic was called, possibly treating a numeric value as
a packed buffer or vice versa.  It also ignored the UTF-8 flag,
potentially treating the internal representation of an upgraded SV as
the bytes to supply to the setsockopt() system call.  (github #18660)

=item *

Only set IOKp, not IOK on $) and $(.
This was issue #18955: This will prevent serializers from serializing these
variables as numbers (which loses the additional groups).
This restores behaviour from 5.16

=back


=head1 Acknowledgements

Perl 5.35.2 represents approximately 5 weeks of development since Perl
5.35.1 and contains approximately 27,000 lines of changes across 420 files
from 25 authors.

Excluding auto-generated files, documentation and release tools, there were
approximately 14,000 lines of changes to 200 .pm, .t, .c and .h files.

Perl continues to flourish into its fourth decade thanks to a vibrant
community of users and developers. The following people are known to have
contributed the improvements that became Perl 5.35.2:

Atsushi Sugawara, Ben Cornett, Chris 'BinGOs' Williams, Christian Walde
(Mithaldu), Craig A. Berry, David Golden, David Marshall, Felipe Gasper,
Jakub Wilk, James E Keenan, Karl Williamson, Leam Hall, Leon Timmermans, Max
Maischein, Neil Bowers, Nicholas Clark, Paul Evans, Paul Marquess, Richard
Leach, Sawyer X, Sergey Poznyakoff, Sven Kirmess, Thibault Duponchelle, Todd
Rinaldo, Tony Cook.

The list above is almost certainly incomplete as it is automatically
generated from version control history. In particular, it does not include
the names of the (very much appreciated) contributors who reported issues to
the Perl bug tracker.

Many of the changes included in this version originated in the CPAN modules
included in Perl's core. We're grateful to the entire CPAN community for
helping Perl to flourish.

For a more complete list of all of Perl's historical contributors, please
see the F<AUTHORS> file in the Perl source distribution.


=head1 Reporting Bugs

If you find what you think is a bug, you might check the perl bug database
at L<https://github.com/Perl/perl5/issues>.  There may also be information at
L<http://www.perl.org/>, the Perl Home Page.

If you believe you have an unreported bug, please open an issue at
L<https://github.com/Perl/perl5/issues>.  Be sure to trim your bug down to a
tiny but sufficient test case.

If the bug you are reporting has security implications which make it
inappropriate to send to a public issue tracker, then see
L<perlsec/SECURITY VULNERABILITY CONTACT INFORMATION>
for details of how to report the issue.

=head1 Give Thanks

If you wish to thank the Perl 5 Porters for the work we had done in Perl 5,
you can do so by running the C<perlthanks> program:

    perlthanks

This will send an email to the Perl 5 Porters list with your show of thanks.

=head1 SEE ALSO

The F<Changes> file for an explanation of how to view exhaustive details on
what changed.

The F<INSTALL> file for how to build Perl.

The F<README> file for general stuff.

The F<Artistic> and F<Copying> files for copyright information.

=cut