perldelta nits.
[p5sagit/p5-mst-13.2.git] / pod / perldelta.pod
CommitLineData
cc0fca54 1=head1 NAME
2
53080bb1 3perldelta - what's new for perl v5.7.0
cc0fca54 4
5=head1 DESCRIPTION
6
53080bb1 7This document describes differences between the 5.6.0 release and
8the 5.7.0 release.
cc0fca54 9
43b92eec 10=head1 Security Vulnerability Closed
d4ad863d 11
12A potential security vulnerability in the optional suidperl component
ce72e97c 13of Perl has been identified. suidperl is neither built nor installed
14by default. As of August the 20th, 2000, the only known vulnerable
15platform is Linux, most likely all Linux distributions. CERT and
16various vendors have been alerted about the vulnerability.
d4ad863d 17
18The problem was caused by Perl trying to report a suspected security
ce72e97c 19exploit attempt using an external program, /bin/mail. On Linux
d4ad863d 20platforms the /bin/mail program had an undocumented feature which gave
ce72e97c 21access to a root shell, resulting in a serious compromise instead of
22reporting the exploit attempt. If you don't have /bin/mail, or if you
23have 'safe setuid scripts', or if suidperl is not installed, you
d4ad863d 24are safe.
25
26The exploit attempt reporting feature has been completely removed from
27the Perl 5.7.0 release, so that particular vulnerability isn't there
562628a3 28anymore. However, further security vulnerabilities are,
29unfortunately, always possible. The suidperl code is being reviewed
30and if deemed too risky to continue to be supported, it may be
31completely removed from future releases. In any case, suidperl should
32only be used by security experts who know exactly what they are doing
33and why they are using suidperl instead of some other solution such as
34sudo (see http://www.courtesan.com/sudo/).
d4ad863d 35
36=head1 Incompatible Changes
37
ce72e97c 38=over 4
39
40=item *
d4ad863d 41
ce72e97c 42Arrays now always interpolate into double-quoted strings:
43constructs like "foo@bar" now always assume C<@bar> is an array,
44whether or not the compiler has seen use of C<@bar>.
d4ad863d 45
ce72e97c 46=item *
d4ad863d 47
48The semantics of bless(REF, REF) were unclear and until someone proves
49it to make some sense, it is forbidden.
50
ce72e97c 51=item *
d4ad863d 52
53The very dusty examples in the eg/ directory have been removed.
54Suggestions for new shiny examples welcome but the main issue is that
ce72e97c 55the examples need to be documented, tested and (most importantly)
56maintained.
d4ad863d 57
ce72e97c 58=item *
d4ad863d 59
60The obsolete chat2 library that should never have been allowed
61to escape the laboratory has been decommissioned.
62
ce72e97c 63=item *
d4ad863d 64
65The unimplemented POSIX regex features [[.cc.]] and [[=c=]] are still
43b92eec 66recognised but now cause fatal errors. The previous behaviour of
d4ad863d 67ignoring them by default and warning if requested was unacceptable
68since it, in a way, falsely promised that the features could be used.
69
ce72e97c 70=item *
d4ad863d 71
72lstat(FILEHANDLE) now gives a warning because the operation makes no sense.
73In future releases this may become a fatal error.
74
ce72e97c 75=item *
d4ad863d 76
ce72e97c 77The long deprecated uppercase aliases for the string comparison
d4ad863d 78operators (EQ, NE, LT, LE, GE, GT) have now been removed.
79
ce72e97c 80=item *
d4ad863d 81
82The regular expression captured submatches ($1, $2, ...) are now
ce72e97c 83more consistently unset if the match fails, instead of leaving false
d4ad863d 84data lying around in them.
85
ce72e97c 86=item *
d4ad863d 87
88The tr///C and tr///U features have been removed and will not return;
89the interface was a mistake. Sorry about that. For similar
90functionality, see pack('U0', ...) and pack('C0', ...).
91
ce72e97c 92=back
93
cc0fca54 94=head1 Core Enhancements
95
53080bb1 96=over 4
97
98=item *
99
100C<perl -d:Module=arg,arg,arg> now works (previously one couldn't pass
101in multiple arguments.)
102
103=item *
104
53080bb1 105my __PACKAGE__ now works.
106
107=item *
108
ce72e97c 109C<no Module;> now works even if there is no "sub unimport" in the Module.
53080bb1 110
111=item *
112
d4ad863d 113The numerical comparison operators return C<undef> if either operand
114is a NaN. Previously the behaviour was unspecified.
53080bb1 115
116=item *
117
43b92eec 118C<pack('U0a*', ...)> can now be used to force a string to UTF8.
53080bb1 119
120=item *
121
122prototype(\&) is now available.
123
53080bb1 124=back
125
cc0fca54 126=head1 Modules and Pragmata
127
53080bb1 128=head2 New Modules
129
d4ad863d 130=over 4
131
132=item *
133
ce72e97c 134File::Temp allows one to create temporary files and directories in an
135easy, portable, and secure way.
d4ad863d 136
137=item *
138
ce72e97c 139Storable gives persistence to Perl data structures by allowing the
140storage and retrieval of Perl data to and from files in a fast and
141compact binary format.
d4ad863d 142
143=back
53080bb1 144
145=head2 Updated And Improved Modules and Pragmata
146
147=over 4
148
149=item *
150
ce72e97c 151The following independently supported modules have been updated to
152newer versions from CPAN: CGI, CPAN, DB_File, File::Spec, Getopt::Long,
153the podlators bundle, Pod::LaTeX, Pod::Parser, Term::ANSIColor, Test.
53080bb1 154
155=item *
156
ce72e97c 157Bug fixes and minor enhancements have been applied to B::Deparse,
158Data::Dumper, IO::Poll, IO::Socket::INET, Math::BigFloat, Math::Complex,
159re, SelfLoader, Sys::SysLog, Test::Harness, Text::Wrap, UNIVERSAL.
53080bb1 160
161=item *
162
ce72e97c 163The attributes::reftype() now works on tied arguments.
53080bb1 164
165=item *
166
ce72e97c 167AutoLoader can now be disabled with C<no AutoLoader;>,
53080bb1 168
169=item *
170
171The English module can now be used without the infamous performance
172hit by saying
173
174 use English '-no_performance_hit';
175
176(Assuming, of course, that one doesn't need the troublesome variables
177C<$`>, C<$&>, or C<$'>.) Also, introduce C<@LAST_MATCH_START> and
178C<@LAST_MATCH_END> English aliases for C<@-> and C<@+>.
179
180=item *
181
ce72e97c 182File::Find now has pre- and post-processing callbacks. It also
183correctly changes directories when chasing symbolic links. Callbacks
184(naughtily) exiting with "next;" instead of "return;" now work.
53080bb1 185
186=item *
187
d4ad863d 188File::Glob::glob() renamed to File::Glob::bsd_glob() to avoid
53080bb1 189prototype mismatch with CORE::glob().
190
191=item *
192
ce72e97c 193IPC::Open3 now allows the use of numeric file descriptors.
53080bb1 194
195=item *
196
ce72e97c 197use lib now works identically to @INC. Removing directories
198with 'no lib' now works.
53080bb1 199
200=item *
201
ce72e97c 202C<%INC> now localised in a Safe compartment so that use/require work.
53080bb1 203
204=item *
205
ce72e97c 206The Shell module now has an OO interface.
53080bb1 207
ce72e97c 208=back
53080bb1 209
ce72e97c 210=head1 Utility Changes
53080bb1 211
ce72e97c 212=over 4
53080bb1 213
214=item *
215
ce72e97c 216The Emacs perl mode (emacs/cperl-mode.el) has been updated to version 4.31.
53080bb1 217
218=item *
219
ce72e97c 220The long-dormant perl bytecompiler has been added to the list of
221installed utilities since the bytecompiler backend has been improved.
222The bytecompiler is still very much experimental, though.
53080bb1 223
224=item *
225
ce72e97c 226Perlbug is now much more robust. It also sends the bug report to perl.org,
227not perl.com.
53080bb1 228
229=item *
230
ce72e97c 231The perlcc utility has been rewritten and its user interface (that is,
232command line) is much more like that of the UNIX C compiler, cc.
53080bb1 233
234=item *
235
ce72e97c 236The xsubpp utility for extension writers now understands POD
237documentation embedded in the *.xs files.
53080bb1 238
ce72e97c 239=back
53080bb1 240
ce72e97c 241=head1 New Documentation
53080bb1 242
ce72e97c 243=over 4
53080bb1 244
245=item *
246
ce72e97c 247perl56delta details the changes between the 5.005 release and the
2485.6.0 release.
53080bb1 249
250=item *
251
ce72e97c 252perldebtut is a Perl debugging tutorial.
53080bb1 253
254=item *
255
ce72e97c 256perlebcdic contains considerations for running Perl on EBCDIC platforms.
257Note that unfortunately EBCDIC platforms that used to supported back in
258Perl 5.005 are still unsupported by Perl 5.7.0; the plan, however, is to
259bring them back to the fold.
53080bb1 260
261=item *
262
ce72e97c 263perlnewmod tells about writing and submitting a new module.
53080bb1 264
265=item *
266
ce72e97c 267perlposix-bc explains using Perl on the POSIX-BC platform
562628a3 268(an EBCDIC mainframe platform).
53080bb1 269
270=item *
271
ce72e97c 272perlretut is a regular expression tutorial.
53080bb1 273
274=item *
275
ce72e97c 276perlrequick is a regular expressions quick-start guide.
277Yes, much quicker than perlretut.
53080bb1 278
279=item *
280
ce72e97c 281perlutil explains the command line utilities packaged with the Perl
282distribution.
53080bb1 283
284=back
285
ce72e97c 286=head1 Performance Enhancements
53080bb1 287
562628a3 288=over 4
289
290=item *
291
ce72e97c 292map() that changes the size of the list should now work faster.
53080bb1 293
562628a3 294=back
295
ce72e97c 296=head1 Installation and Configuration Improvements
53080bb1 297
ce72e97c 298=head2 Generic Improvements
cc0fca54 299
53080bb1 300=over 4
301
302=item *
303
ce72e97c 304INSTALL now explains how you can configure perl to use 64-bit
305integers even on non-64-bit platforms.
53080bb1 306
307=item *
308
ce72e97c 309Policy.sh policy change: if you are reusing a Policy.sh file (see
310INSTALL) and you use Configure -Dprefix=/foo/bar and in the old
311Policy $prefix eq $siteprefix and $prefix eq $vendorprefix, all of
312them will now be changed to the new prefix, /foo/bar. (Previously
313only $prefix changed.) If you do not like this new behaviour,
314specify prefix, siteprefix, and vendorprefix explicitly.
53080bb1 315
316=item *
317
ce72e97c 318A new optional location for Perl libraries, otherlibdirs, is available.
319It can be used for example for vendor add-ons without disturbing Perl's
320own library directories.
53080bb1 321
322=item *
323
ce72e97c 324In many platforms the vendor-supplied 'cc' is too stripped-down to
325build Perl (basically, 'cc' doesn't do ANSI C). If this seems
326to be the case and 'cc' does not seem to be the GNU C compiler
327'gcc', an automatic attempt is made to find and use 'gcc' instead.
53080bb1 328
329=item *
330
ce72e97c 331gcc needs to closely track the operating system release to avoid
332build problems. If Configure finds that gcc was built for a different
333operating system release than is running, it now gives a clearly visible
334warning that there may be trouble ahead.
53080bb1 335
336=item *
337
ce72e97c 338If binary compatibility with the 5.005 release is not wanted, Configure
339no longer suggests including the 5.005 modules in @INC.
53080bb1 340
341=item *
342
ce72e97c 343Configure C<-S> can now run non-interactively.
53080bb1 344
345=item *
346
ce72e97c 347configure.gnu now works with options with whitespace in them.
53080bb1 348
349=item *
350
ce72e97c 351installperl now outputs everything to STDERR.
53080bb1 352
353=item *
354
ce72e97c 355$Config{byteorder} is now computed dynamically (this is more robust
356with "fat binaries" where an executable image contains binaries for
357more than one binary platform.)
53080bb1 358
ce72e97c 359=back
53080bb1 360
ce72e97c 361=head1 Selected Bug Fixes
53080bb1 362
ce72e97c 363=over 4
53080bb1 364
365=item *
366
ce72e97c 367Several debugger fixes: exit code now reflects the script exit code,
368condition C<"0"> now treated correctly, the C<d> command now checks
369line number, the C<$.> no longer gets corrupted, all debugger output now
370goes correctly to the socket if RemotePort is set.
53080bb1 371
372=item *
373
ce72e97c 374C<*foo{FORMAT}> now works.
53080bb1 375
376=item *
377
ce72e97c 378Lexical warnings now propagating correctly between scopes.
53080bb1 379
380=item *
381
ce72e97c 382Line renumbering with eval and C<#line> now works.
53080bb1 383
384=item *
385
ce72e97c 386Fixed numerous memory leaks, especially in eval "".
53080bb1 387
388=item *
389
ce72e97c 390Modulus of unsigned numbers now works (4063328477 % 65535 used to
391return 27406, instead of 27047).
53080bb1 392
393=item *
394
ce72e97c 395Some "not a number" warnings introduced in 5.6.0 eliminated to be
396more compatible with 5.005. Infinity is now recognised as a number.
53080bb1 397
398=item *
399
ce72e97c 400our() variables will not cause "will not stay shared" warnings.
53080bb1 401
402=item *
403
ce72e97c 404pack "Z" now correctly terminates the string with "\0".
53080bb1 405
406=item *
407
ce72e97c 408Fix password routines which in some shadow password platforms
409(e.g. HP-UX) caused getpwent() to return every other entry.
53080bb1 410
411=item *
412
ce72e97c 413printf() no longer resets the numeric locale to "C".
53080bb1 414
415=item *
416
ce72e97c 417C<q(a\\b)> now parses correctly as C<'a\\b'>.
53080bb1 418
419=item *
420
ce72e97c 421Printing quads (64-bit integers) with printf/sprintf now works
562628a3 422without the q L ll prefixes (assuming you are on a quad-capable platform).
53080bb1 423
424=item *
425
ce72e97c 426Regular expressions on references and overloaded scalars now work.
53080bb1 427
428=item *
429
ce72e97c 430scalar() now forces scalar context even when used in void context.
53080bb1 431
432=item *
ce72e97c 433
434sort() arguments are now compiled in the right wantarray context
435(they were accidentally using the context of the sort() itself).
53080bb1 436
437=item *
438
ce72e97c 439Changed the POSIX character class C<[[:space:]]> to include the (very
440rare) vertical tab character. Added a new POSIX-ish character class
441C<[[:blank:]]> which stands for horizontal whitespace (currently,
442the space and the tab).
53080bb1 443
444=item *
445
ce72e97c 446$AUTOLOAD, sort(), lock(), and spawning subprocesses
447in multiple threads simultaneously are now thread-safe.
53080bb1 448
449=item *
450
ce72e97c 451Allow read-only string on left hand side of non-modifying tr///.
53080bb1 452
453=item *
454
ce72e97c 455Several Unicode fixes (but still not perfect).
53080bb1 456
ce72e97c 457=over 8
53080bb1 458
459=item *
460
ce72e97c 461BOMs (byte order marks) in the beginning of Perl files
462(scripts, modules) should now be transparently skipped.
463UTF16 encoded Perl files should now be read correctly.
53080bb1 464
465=item *
466
ce72e97c 467The character tables have been updated to new Unicode 3.0 features.
53080bb1 468
ce72e97c 469=item *
53080bb1 470
ce72e97c 471chr() for values greater than 127 now create utf8 when under use
472utf8.
53080bb1 473
ce72e97c 474=item *
53080bb1 475
ce72e97c 476Comparing with utf8 data does not magically upgrade non-utf8 data into
477utf8.
53080bb1 478
479=item *
480
ce72e97c 481C<IsAlnum>, C<IsAlpha>, and C<IsWord> now match titlecase.
53080bb1 482
483=item *
484
ce72e97c 485Concatenation with the C<.> operator or via variable interpolation,
486C<eq>, C<substr>, C<reverse>, C<quotemeta>, the C<x> operator,
487substitution with C<s///>, single-quoted UTF8, should now work--in
488theory.
53080bb1 489
490=item *
491
ce72e97c 492The C<tr///> operator now works I<slightly> better but is still rather
493broken. Note that the C<tr///CU> functionality has been removed (but
494see pack('U0', ...)).
53080bb1 495
496=item *
497
ce72e97c 498Zero entries were missing from the Unicode classes like C<IsDigit>.
53080bb1 499
500=back
501
ce72e97c 502=item *
53080bb1 503
ce72e97c 504UNIVERSAL::isa no longer caches methods incorrectly. (This broke
505the Tk extension with 5.6.0.)
53080bb1 506
ce72e97c 507=back
53080bb1 508
ce72e97c 509=head2 Platform Specific Changes and Fixes
53080bb1 510
511=over 4
512
513=item *
514
ce72e97c 515BSDI 4.*
53080bb1 516
ce72e97c 517Perl now works on post-4.0 BSD/OSes.
53080bb1 518
ce72e97c 519=item *
53080bb1 520
ce72e97c 521All BSDs
53080bb1 522
ce72e97c 523Setting C<$0> now works (as much as possible; see perlvar for details).
53080bb1 524
ce72e97c 525=item *
53080bb1 526
ce72e97c 527Cygwin
53080bb1 528
ce72e97c 529Numerous updates; currently synchronised with Cygwin 1.1.4.
53080bb1 530
531=item *
532
ce72e97c 533EPOC
53080bb1 534
ce72e97c 535EPOC update after Perl 5.6.0. See README.epoc.
53080bb1 536
ce72e97c 537=item *
53080bb1 538
ce72e97c 539FreeBSD 3.*
53080bb1 540
ce72e97c 541Perl now works on post-3.0 FreeBSDs.
53080bb1 542
543=item *
544
ce72e97c 545HP-UX
53080bb1 546
ce72e97c 547README.hpux updated; C<Configure -Duse64bitall> now almost works.
53080bb1 548
ce72e97c 549=item *
53080bb1 550
ce72e97c 551IRIX
53080bb1 552
ce72e97c 553Numerous compilation flag and hint enhancements; accidental mixing
554of 32-bit and 64-bit libraries (a doomed attempt) made much harder.
53080bb1 555
556=item *
557
ce72e97c 558Linux
53080bb1 559
ce72e97c 560Long doubles should now work (see INSTALL).
53080bb1 561
562=item *
563
ce72e97c 564MacOS Classic
565
53080bb1 566Compilation of the standard Perl distribution in MacOS Classic should
ce72e97c 567now work if you have the Metrowerks development environment and
568the missing Mac-specific toolkit bits. Contact the macperl mailing
53080bb1 569list for details.
570
ce72e97c 571=item *
53080bb1 572
ce72e97c 573MPE/iX
53080bb1 574
ce72e97c 575MPE/iX update after Perl 5.6.0. See README.mpeix.
53080bb1 576
ce72e97c 577=item *
53080bb1 578
ce72e97c 579NetBSD/sparc
53080bb1 580
ce72e97c 581Perl now works on NetBSD/sparc.
53080bb1 582
583=item *
584
ce72e97c 585OS/2
53080bb1 586
ce72e97c 587Now works with usethreads (see INSTALL).
53080bb1 588
589=item *
590
ce72e97c 591Solaris
53080bb1 592
ce72e97c 59364-bitness using the Sun Workshop compiler now works.
53080bb1 594
595=item *
596
ce72e97c 597Tru64 (aka Digital UNIX, aka DEC OSF/1)
598
599The operating system version letter now recorded in $Config{osvers}.
53080bb1 600Allow compiling with gcc (previously explicitly forbidden). Compiling
601with gcc still not recommended because buggy code results, even with
602gcc 2.95.2.
603
604=item *
605
ce72e97c 606Unicos
53080bb1 607
608Fixed various alignment problems that lead into core dumps either
ce72e97c 609during build or later; no longer dies on math errors at runtime;
610now using full quad integers (64 bits), previously was using
b84d4f81 611only 46 bit integers for speed.
53080bb1 612
53080bb1 613=item *
614
ce72e97c 615VMS
53080bb1 616
ce72e97c 617chdir() now works better despite a CRT bug; now works with MULTIPLICITY
618(see INSTALL); now works with Perl's malloc.
53080bb1 619
620=item *
621
ce72e97c 622Windows
53080bb1 623
ce72e97c 624=over 8
53080bb1 625
626=item *
627
d4ad863d 628accept() no longer leaks memory.
53080bb1 629
630=item *
631
632Better chdir() return value for a non-existent directory.
633
634=item *
635
636New %ENV entries now propagate to subprocesses.
637
638=item *
639
640$ENV{LIB} now used to search for libs under Visual C.
641
642=item *
643
644A failed (pseudo)fork now returns undef and sets errno to EAGAIN.
645
646=item *
647
648Allow REG_EXPAND_SZ keys in the registry.
649
650=item *
651
652Can now send() from all threads, not just the first one.
653
654=item *
655
656Fake signal handling reenabled, bugs and all.
657
658=item *
659
660Less stack reserved per thread so that more threads can run
661concurrently. (still 16M perl thread)
662
663=item *
664
665C<File::Spec->tmpdir()> now prefers C:/temp over /tmp
666(works better when perl running as service).
667
668=item *
669
670Better UNC path handling under ithreads.
671
672=item *
673
674wait() and waitpid() now work much better.
675
676=item *
677
678winsock handle leak fixed.
679
680=back
681
cc0fca54 682=head1 New or Changed Diagnostics
683
53080bb1 684All regular expression compilation error messages are now hopefully
685easier to understand both because the error message now comes before
686the failed regex and because the point of failure is now clearly
687marked.
688
689The various "opened only for", "on closed", "never opened" warnings
690drop the C<main::> prefix for filehandles in the C<main> package,
562628a3 691for example C<STDIN> instead of <main::STDIN>.
53080bb1 692
d4ad863d 693The "Unrecognized escape" warning has been extended to include C<\8>,
694C<\9>, and C<\_>. There is no need to escape any of the C<\w> characters.
53080bb1 695
53080bb1 696=head1 Changed Internals
697
ce72e97c 698=over 4
699
700=item *
53080bb1 701
d4ad863d 702perlapi.pod (a companion to perlguts) now attempts to document the
703internal API.
53080bb1 704
ce72e97c 705=item *
53080bb1 706
ce72e97c 707You can now build a really minimal perl called microperl.
d4ad863d 708Building microperl does not require even running Configure;
709C<make -f Makefile.micro> should be enough. Beware: microperl makes
710many assumptions, some of which may be too bold; the resulting
711executable may crash or otherwise misbehave in wondrous ways. For
712careful hackers only.
53080bb1 713
ce72e97c 714=item *
53080bb1 715
43b92eec 716Added rsignal(), whichsig(), do_join() to the publicised API.
53080bb1 717
ce72e97c 718=item *
53080bb1 719
43b92eec 720Made possible to propagate customised exceptions via croak()ing.
53080bb1 721
ce72e97c 722=item *
53080bb1 723
724Added is_utf8_char(), is_utf8_string(), bytes_to_utf8(), and utf8_to_bytes().
725
ce72e97c 726=item *
53080bb1 727
728Now xsubs can have attributes just like subs.
729
ce72e97c 730=back
731
cc0fca54 732=head1 Known Problems
733
53080bb1 734=head2 Unicode Support Still Far From Perfect
735
736We're working on it. Stay tuned.
737
738=head2 EBCDIC Still A Lost Platform
739
740The plan is to bring them back.
741
742=head2 Building Extensions Can Fail Because Of Largefiles
743
744Certain extensions like mod_perl and BSD::Resource are known to have
ce72e97c 745issues with `largefiles', a change brought by Perl 5.6.0 in which file
746offsets default to 64 bits wide where supported. Modules may fail to
747compile at all or compile and work incorrectly. Currently there is no
748good solution for the problem, but Configure now stores the relevant
749flags and libraries in the %Config hash so the extensions that are having
53080bb1 750problems can try configuring themselves without the largefileness.
751This is admittedly not a clean solution.
752
10d9c778 753=over 4
754
755=item In string, @%s now must be written as \@%s
756
757(F) It used to be that Perl would try to guess whether you wanted an
758array interpolated or a literal @. It did this when the string was
759first used at runtime. Now strings are parsed at compile time, and
760ambiguous instances of @ must be disambiguated, either by prepending a
761backslash to indicate a literal, or by declaring (or using) the array
762within the program before the string (lexically). (I<Someday it will
763simply assume that an unbackslashed @ interpolates an array.>)
764
765=back
766
767That day has arrived.
768
cc0fca54 769=head1 Reporting Bugs
770
d4ad863d 771If you find what you think is a bug, you might check the articles
772recently posted to the comp.lang.perl.misc newsgroup and the perl
773bug database at http://bugs.perl.org. There may also be
774information at http://www.perl.com/perl/, the Perl Home Page.
cc0fca54 775
776If you believe you have an unreported bug, please run the B<perlbug>
777program included with your release. Be sure to trim your bug down
778to a tiny but sufficient test case. Your bug report, along with the
d4ad863d 779output of C<perl -V>, will be sent off to perlbug@perl.org to be
cc0fca54 780analysed by the Perl porting team.
781
782=head1 SEE ALSO
783
784The F<Changes> file for exhaustive details on what changed.
785
786The F<INSTALL> file for how to build Perl.
787
788The F<README> file for general stuff.
789
790The F<Artistic> and F<Copying> files for copyright information.
791
792=head1 HISTORY
793
53080bb1 794Written by Jarkko Hietaniemi <F<jhi@iki.fi>>, with many contributions
795from The Perl Porters and Perl Users submitting feedback and patches.
cc0fca54 796
d4ad863d 797Send omissions or corrections to <F<perlbug@perl.org>>.
cc0fca54 798
799=cut