This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
Add the perl581delta manpage.
[perl5.git] / pod / perltoc.pod
1
2 # !!!!!!!   DO NOT EDIT THIS FILE   !!!!!!!
3 # This file is autogenerated by buildtoc from all the other pods.
4 # Edit those files and run buildtoc --build-toc to effect changes.
5
6 =head1 NAME
7
8 perltoc - perl documentation table of contents
9
10 =head1 DESCRIPTION
11
12 This page provides a brief table of contents for the rest of the Perl
13 documentation set.  It is meant to be scanned quickly or grepped
14 through to locate the proper section you're looking for.
15
16 =head1 BASIC DOCUMENTATION
17
18 =head2 perl - Practical Extraction and Report Language
19
20 =over 4
21
22 =item SYNOPSIS
23
24 =over 4
25
26 =item Overview
27
28 =item Tutorials
29
30 =item Reference Manual
31
32 =item Internals and C Language Interface
33
34 =item Miscellaneous
35
36 =item Language-Specific
37
38 =item Platform-Specific
39
40 =back
41
42 =item DESCRIPTION
43
44 =item AVAILABILITY
45
46 =item ENVIRONMENT
47
48 =item AUTHOR
49
50 =item FILES
51
52 =item SEE ALSO
53
54 =item DIAGNOSTICS
55
56 =item BUGS
57
58 =item NOTES
59
60 =back
61
62 =head2 perlintro -- a brief introduction and overview of Perl
63
64 =over 4
65
66 =item DESCRIPTION
67
68 =over 4
69
70 =item What is Perl?
71
72 =item Running Perl programs
73
74 =item Basic syntax overview
75
76 =item Perl variable types
77
78 Scalars, Arrays, Hashes
79
80 =item Variable scoping
81
82 =item Conditional and looping constructs
83
84 if, while, for, foreach
85
86 =item Builtin operators and functions
87
88 Arithmetic, Numeric comparison, String comparison, Boolean logic,
89 Miscellaneous
90
91 =item Files and I/O
92
93 =item Regular expressions
94
95 Simple matching, Simple substitution, More complex regular expressions,
96 Parentheses for capturing, Other regexp features
97
98 =item Writing subroutines
99
100 =item OO Perl
101
102 =item Using Perl modules
103
104 =back
105
106 =item AUTHOR
107
108 =back
109
110 =head2 perlreftut - Mark's very short tutorial about references
111
112 =over 4
113
114 =item DESCRIPTION
115
116 =item Who Needs Complicated Data Structures?
117
118 =item The Solution
119
120 =item Syntax
121
122 =over 4
123
124 =item Making References
125
126 =item Using References
127
128 =item An Example
129
130 =item Arrow Rule
131
132 =back
133
134 =item Solution
135
136 =item The Rest
137
138 =item Summary
139
140 =item Credits
141
142 =over 4
143
144 =item Distribution Conditions
145
146 =back
147
148 =back
149
150 =head2 perldsc - Perl Data Structures Cookbook
151
152 =over 4
153
154 =item DESCRIPTION
155
156 arrays of arrays, hashes of arrays, arrays of hashes, hashes of hashes,
157 more elaborate constructs
158
159 =item REFERENCES
160
161 =item COMMON MISTAKES
162
163 =item CAVEAT ON PRECEDENCE
164
165 =item WHY YOU SHOULD ALWAYS C<use strict>
166
167 =item DEBUGGING
168
169 =item CODE EXAMPLES
170
171 =item ARRAYS OF ARRAYS
172
173 =over 4
174
175 =item Declaration of an ARRAY OF ARRAYS
176
177 =item Generation of an ARRAY OF ARRAYS
178
179 =item Access and Printing of an ARRAY OF ARRAYS
180
181 =back
182
183 =item HASHES OF ARRAYS
184
185 =over 4
186
187 =item Declaration of a HASH OF ARRAYS
188
189 =item Generation of a HASH OF ARRAYS
190
191 =item Access and Printing of a HASH OF ARRAYS
192
193 =back
194
195 =item ARRAYS OF HASHES
196
197 =over 4
198
199 =item Declaration of an ARRAY OF HASHES
200
201 =item Generation of an ARRAY OF HASHES
202
203 =item Access and Printing of an ARRAY OF HASHES
204
205 =back
206
207 =item HASHES OF HASHES
208
209 =over 4
210
211 =item Declaration of a HASH OF HASHES
212
213 =item Generation of a HASH OF HASHES
214
215 =item Access and Printing of a HASH OF HASHES
216
217 =back
218
219 =item MORE ELABORATE RECORDS
220
221 =over 4
222
223 =item Declaration of MORE ELABORATE RECORDS
224
225 =item Declaration of a HASH OF COMPLEX RECORDS
226
227 =item Generation of a HASH OF COMPLEX RECORDS
228
229 =back
230
231 =item Database Ties
232
233 =item SEE ALSO
234
235 =item AUTHOR
236
237 =back
238
239 =head2 perllol - Manipulating Arrays of Arrays in Perl
240
241 =over 4
242
243 =item DESCRIPTION
244
245 =over 4
246
247 =item Declaration and Access of Arrays of Arrays
248
249 =item Growing Your Own
250
251 =item Access and Printing
252
253 =item Slices
254
255 =back
256
257 =item SEE ALSO
258
259 =item AUTHOR
260
261 =back
262
263 =head2 perlrequick - Perl regular expressions quick start
264
265 =over 4
266
267 =item DESCRIPTION
268
269 =item The Guide
270
271 =over 4
272
273 =item Simple word matching
274
275 =item Using character classes
276
277 =item Matching this or that
278
279 =item Grouping things and hierarchical matching
280
281 =item Extracting matches
282
283 =item Matching repetitions
284
285 =item More matching
286
287 =item Search and replace
288
289 =item The split operator
290
291 =back
292
293 =item BUGS
294
295 =item SEE ALSO
296
297 =item AUTHOR AND COPYRIGHT
298
299 =over 4
300
301 =item Acknowledgments
302
303 =back
304
305 =back
306
307 =head2 perlretut - Perl regular expressions tutorial
308
309 =over 4
310
311 =item DESCRIPTION
312
313 =item Part 1: The basics
314
315 =over 4
316
317 =item Simple word matching
318
319 =item Using character classes
320
321 =item Matching this or that
322
323 =item Grouping things and hierarchical matching
324
325 =item Extracting matches
326
327 =item Matching repetitions
328
329 =item Building a regexp
330
331 =item Using regular expressions in Perl
332
333 =back
334
335 =item Part 2: Power tools
336
337 =over 4
338
339 =item More on characters, strings, and character classes
340
341 =item Compiling and saving regular expressions
342
343 =item Embedding comments and modifiers in a regular expression
344
345 =item Non-capturing groupings
346
347 =item Looking ahead and looking behind
348
349 =item Using independent subexpressions to prevent backtracking
350
351 =item Conditional expressions
352
353 =item A bit of magic: executing Perl code in a regular expression
354
355 =item Pragmas and debugging
356
357 =back
358
359 =item BUGS
360
361 =item SEE ALSO
362
363 =item AUTHOR AND COPYRIGHT
364
365 =over 4
366
367 =item Acknowledgments
368
369 =back
370
371 =back
372
373 =head2 perlboot - Beginner's Object-Oriented Tutorial
374
375 =over 4
376
377 =item DESCRIPTION
378
379 =over 4
380
381 =item If we could talk to the animals...
382
383 =item Introducing the method invocation arrow
384
385 =item Invoking a barnyard
386
387 =item The extra parameter of method invocation
388
389 =item Calling a second method to simplify things
390
391 =item Inheriting the windpipes
392
393 =item A few notes about @ISA
394
395 =item Overriding the methods
396
397 =item Starting the search from a different place
398
399 =item The SUPER way of doing things
400
401 =item Where we're at so far...
402
403 =item A horse is a horse, of course of course -- or is it?
404
405 =item Invoking an instance method
406
407 =item Accessing the instance data
408
409 =item How to build a horse
410
411 =item Inheriting the constructor
412
413 =item Making a method work with either classes or instances
414
415 =item Adding parameters to a method
416
417 =item More interesting instances
418
419 =item A horse of a different color
420
421 =item Summary
422
423 =back
424
425 =item SEE ALSO
426
427 =item COPYRIGHT
428
429 =back
430
431 =head2 perltoot - Tom's object-oriented tutorial for perl
432
433 =over 4
434
435 =item DESCRIPTION
436
437 =item Creating a Class
438
439 =over 4
440
441 =item Object Representation
442
443 =item Class Interface
444
445 =item Constructors and Instance Methods
446
447 =item Planning for the Future: Better Constructors
448
449 =item Destructors
450
451 =item Other Object Methods
452
453 =back
454
455 =item Class Data
456
457 =over 4
458
459 =item Accessing Class Data
460
461 =item Debugging Methods
462
463 =item Class Destructors
464
465 =item Documenting the Interface
466
467 =back
468
469 =item Aggregation
470
471 =item Inheritance
472
473 =over 4
474
475 =item Overridden Methods
476
477 =item Multiple Inheritance
478
479 =item UNIVERSAL: The Root of All Objects
480
481 =back
482
483 =item Alternate Object Representations
484
485 =over 4
486
487 =item Arrays as Objects
488
489 =item Closures as Objects
490
491 =back
492
493 =item AUTOLOAD: Proxy Methods
494
495 =over 4
496
497 =item Autoloaded Data Methods
498
499 =item Inherited Autoloaded Data Methods
500
501 =back
502
503 =item Metaclassical Tools
504
505 =over 4
506
507 =item Class::Struct
508
509 =item Data Members as Variables
510
511 =back
512
513 =item NOTES
514
515 =over 4
516
517 =item Object Terminology
518
519 =back
520
521 =item SEE ALSO
522
523 =item AUTHOR AND COPYRIGHT
524
525 =item COPYRIGHT
526
527 =over 4
528
529 =item Acknowledgments
530
531 =back
532
533 =back
534
535 =head2 perltooc - Tom's OO Tutorial for Class Data in Perl
536
537 =over 4
538
539 =item DESCRIPTION
540
541 =item Class Data in a Can
542
543 =item Class Data as Package Variables
544
545 =over 4
546
547 =item Putting All Your Eggs in One Basket
548
549 =item Inheritance Concerns
550
551 =item The Eponymous Meta-Object
552
553 =item Indirect References to Class Data
554
555 =item Monadic Classes
556
557 =item Translucent Attributes
558
559 =back
560
561 =item Class Data as Lexical Variables
562
563 =over 4
564
565 =item Privacy and Responsibility 
566
567 =item File-Scoped Lexicals
568
569 =item More Inheritance Concerns
570
571 =item Locking the Door and Throwing Away the Key
572
573 =item Translucency Revisited
574
575 =back
576
577 =item NOTES
578
579 =item SEE ALSO
580
581 =item AUTHOR AND COPYRIGHT
582
583 =item ACKNOWLEDGEMENTS
584
585 =item HISTORY
586
587 =back
588
589 =head2 perlbot - Bag'o Object Tricks (the BOT)
590
591 =over 4
592
593 =item DESCRIPTION
594
595 =item OO SCALING TIPS
596
597 =item INSTANCE VARIABLES
598
599 =item SCALAR INSTANCE VARIABLES
600
601 =item INSTANCE VARIABLE INHERITANCE
602
603 =item OBJECT RELATIONSHIPS
604
605 =item OVERRIDING SUPERCLASS METHODS
606
607 =item USING RELATIONSHIP WITH SDBM
608
609 =item THINKING OF CODE REUSE
610
611 =item CLASS CONTEXT AND THE OBJECT
612
613 =item INHERITING A CONSTRUCTOR
614
615 =item DELEGATION
616
617 =item SEE ALSO
618
619 =back
620
621 =head2 perlstyle - Perl style guide
622
623 =over 4
624
625 =item DESCRIPTION
626
627 =back
628
629 =head2 perlcheat - Perl 5 Cheat Sheet
630
631 =over 4
632
633 =item DESCRIPTION
634
635 =over 4
636
637 =item The sheet
638
639 =back
640
641 =item ACKNOWLEDGEMENTS
642
643 =item AUTHOR
644
645 =item SEE ALSO
646
647 =back
648
649 =head2 perltrap - Perl traps for the unwary
650
651 =over 4
652
653 =item DESCRIPTION
654
655 =over 4
656
657 =item Awk Traps
658
659 =item C/C++ Traps
660
661 =item Sed Traps
662
663 =item Shell Traps
664
665 =item Perl Traps
666
667 =item Perl4 to Perl5 Traps
668
669 Discontinuance, Deprecation, and BugFix traps, Parsing Traps, Numerical
670 Traps, General data type traps, Context Traps - scalar, list contexts,
671 Precedence Traps, General Regular Expression Traps using s///, etc,
672 Subroutine, Signal, Sorting Traps, OS Traps, DBM Traps, Unclassified Traps
673
674 =item Discontinuance, Deprecation, and BugFix traps
675
676 Discontinuance, Deprecation, BugFix, Discontinuance, Discontinuance,
677 Discontinuance, BugFix, Discontinuance, Discontinuance, BugFix,
678 Discontinuance, Deprecation, Discontinuance, Discontinuance
679
680 =item Parsing Traps
681
682 Parsing, Parsing, Parsing, Parsing, Parsing
683
684 =item Numerical Traps
685
686 Numerical, Numerical, Numerical, Bitwise string ops
687
688 =item General data type traps
689
690 (Arrays), (Arrays), (Hashes), (Globs), (Globs), (Scalar String),
691 (Constants), (Scalars), (Variable Suicide)
692
693 =item Context Traps - scalar, list contexts
694
695 (list context), (scalar context), (scalar context), (list, builtin)
696
697 =item Precedence Traps
698
699 Precedence, Precedence, Precedence, Precedence, Precedence, Precedence,
700 Precedence
701
702 =item General Regular Expression Traps using s///, etc.
703
704 Regular Expression, Regular Expression, Regular Expression, Regular
705 Expression, Regular Expression, Regular Expression, Regular Expression,
706 Regular Expression, Regular Expression
707
708 =item Subroutine, Signal, Sorting Traps
709
710 (Signals), (Sort Subroutine), warn() won't let you specify a filehandle
711
712 =item OS Traps
713
714 (SysV), (SysV)
715
716 =item Interpolation Traps
717
718 Interpolation, Interpolation, Interpolation, Interpolation, Interpolation,
719 Interpolation, Interpolation, Interpolation, Interpolation
720
721 =item DBM Traps
722
723 DBM, DBM
724
725 =item Unclassified Traps
726
727 C<require>/C<do> trap using returned value, C<split> on empty string with
728 LIMIT specified
729
730 =back
731
732 =back
733
734 =head2 perldebtut - Perl debugging tutorial
735
736 =over 4
737
738 =item DESCRIPTION
739
740 =item use strict
741
742 =item Looking at data and -w and v
743
744 =item help
745
746 =item Stepping through code
747
748 =item Placeholder for a, w, t, T
749
750 =item REGULAR EXPRESSIONS
751
752 =item OUTPUT TIPS
753
754 =item CGI
755
756 =item GUIs
757
758 =item SUMMARY
759
760 =item SEE ALSO
761
762 =item AUTHOR
763
764 =item CONTRIBUTORS
765
766 =back
767
768 =head2 perlfaq - frequently asked questions about Perl ($Date: 2003/01/31
769 17:37:17 $)
770
771 =over 4
772
773 =item DESCRIPTION
774
775 =over 4
776
777 =item Where to get the perlfaq
778
779 =item How to contribute to the perlfaq
780
781 =item What will happen if you mail your Perl programming problems to the
782 authors
783
784 =back
785
786 =item Credits
787
788 =item Author and Copyright Information
789
790 =over 4
791
792 =item Bundled Distributions
793
794 =item Disclaimer
795
796 =back
797
798 =item Table of Contents
799
800 perlfaq  - this document, perlfaq1 - General Questions About Perl, perlfaq2
801 - Obtaining and Learning about Perl, perlfaq3 - Programming Tools, perlfaq4
802 - Data Manipulation, perlfaq5 - Files and Formats, perlfaq6 - Regular
803 Expressions, perlfaq7 - General Perl Language Issues, perlfaq8 - System
804 Interaction, perlfaq9 - Networking
805
806 =item The Questions
807
808 =over 4
809
810 =item L<perlfaq1>: General Questions About Perl
811
812 =item L<perlfaq2>: Obtaining and Learning about Perl
813
814 =item L<perlfaq3>: Programming Tools
815
816 =item L<perlfaq4>: Data Manipulation
817
818 =item L<perlfaq5>: Files and Formats
819
820 =item L<perlfaq6>: Regular Expressions
821
822 =item L<perlfaq7>: General Perl Language Issues
823
824 =item L<perlfaq8>: System Interaction
825
826 =item L<perlfaq9>: Networking
827
828 =back
829
830 =back
831
832 =head2 perlfaq1 - General Questions About Perl ($Revision: 1.12 $, $Date:
833 2003/07/09 15:47:28 $)
834
835 =over 4
836
837 =item DESCRIPTION
838
839 =over 4
840
841 =item What is Perl?
842
843 =item Who supports Perl?  Who develops it?  Why is it free?
844
845 =item Which version of Perl should I use?
846
847 =item What are perl4 and perl5?
848
849 =item What is Ponie?
850
851 =item What is perl6?
852
853 =item How stable is Perl?
854
855 =item Is Perl difficult to learn?
856
857 =item How does Perl compare with other languages like Java, Python, REXX,
858 Scheme, or Tcl?
859
860 =item Can I do [task] in Perl?
861
862 =item When shouldn't I program in Perl?
863
864 =item What's the difference between "perl" and "Perl"?
865
866 =item Is it a Perl program or a Perl script?
867
868 =item What is a JAPH?
869
870 =item Where can I get a list of Larry Wall witticisms?
871
872 =item How can I convince my sysadmin/supervisor/employees to use version
873 5/5.6.1/Perl instead of some other language?
874
875 =back
876
877 =item AUTHOR AND COPYRIGHT
878
879 =back
880
881 =head2 perlfaq2 - Obtaining and Learning about Perl ($Revision: 1.20 $,
882 $Date: 2003/01/26 17:50:56 $)
883
884 =over 4
885
886 =item DESCRIPTION
887
888 =over 4
889
890 =item What machines support Perl?  Where do I get it?
891
892 =item How can I get a binary version of Perl?
893
894 =item I don't have a C compiler on my system.  How can I compile perl?
895
896 =item I copied the Perl binary from one machine to another, but scripts
897 don't work.
898
899 =item I grabbed the sources and tried to compile but gdbm/dynamic
900 loading/malloc/linking/... failed.  How do I make it work?
901
902 =item What modules and extensions are available for Perl?  What is CPAN? 
903 What does CPAN/src/... mean?
904
905 =item Is there an ISO or ANSI certified version of Perl?
906
907 =item Where can I get information on Perl?
908
909 =item What are the Perl newsgroups on Usenet?  Where do I post questions?
910
911 =item Where should I post source code?
912
913 =item Perl Books
914
915 References, Tutorials, Task-Oriented, Special Topics
916
917 =item Perl in Magazines
918
919 =item Perl on the Net: FTP and WWW Access
920
921 =item What mailing lists are there for Perl?
922
923 =item Archives of comp.lang.perl.misc
924
925 =item Where can I buy a commercial version of Perl?
926
927 =item Where do I send bug reports?
928
929 =item What is perl.com? Perl Mongers? pm.org? perl.org? cpan.org?
930
931 =back
932
933 =item AUTHOR AND COPYRIGHT
934
935 =back
936
937 =head2 perlfaq3 - Programming Tools ($Revision: 1.35 $, $Date: 2003/08/24
938 05:26:59 $)
939
940 =over 4
941
942 =item DESCRIPTION
943
944 =over 4
945
946 =item How do I do (anything)?
947
948 =item How can I use Perl interactively?
949
950 =item Is there a Perl shell?
951
952 =item How do I find which modules are installed on my system?
953
954 =item How do I debug my Perl programs?
955
956 =item How do I profile my Perl programs?
957
958 =item How do I cross-reference my Perl programs?
959
960 =item Is there a pretty-printer (formatter) for Perl?
961
962 =item Is there a ctags for Perl?
963
964 =item Is there an IDE or Windows Perl Editor?
965
966 Komodo, The Object System, Open Perl IDE, PerlBuilder, visiPerl+, OptiPerl,
967 GNU Emacs, MicroEMACS, XEmacs, Jed, Elvis, Vile, Vim, Codewright,
968 MultiEdit, SlickEdit, Bash, Ksh, Tcsh, Zsh, BBEdit and BBEdit Lite, Alpha
969
970 =item Where can I get Perl macros for vi?
971
972 =item Where can I get perl-mode for emacs?
973
974 =item How can I use curses with Perl?
975
976 =item How can I use X or Tk with Perl?
977
978 =item How can I generate simple menus without using CGI or Tk?
979
980 =item How can I make my Perl program run faster?
981
982 =item How can I make my Perl program take less memory?
983
984 Don't slurp!, Use map and grep selectively, Avoid unnecessary quotes and
985 stringification, Pass by reference, Tie large variables to disk
986
987 =item Is it safe to return a reference to local or lexical data?
988
989 =item How can I free an array or hash so my program shrinks?
990
991 =item How can I make my CGI script more efficient?
992
993 =item How can I hide the source for my Perl program?
994
995 =item How can I compile my Perl program into byte code or C?
996
997 =item How can I compile Perl into Java?
998
999 =item How can I get C<#!perl> to work on [MS-DOS,NT,...]?
1000
1001 =item Can I write useful Perl programs on the command line?
1002
1003 =item Why don't Perl one-liners work on my DOS/Mac/VMS system?
1004
1005 =item Where can I learn about CGI or Web programming in Perl?
1006
1007 =item Where can I learn about object-oriented Perl programming?
1008
1009 =item Where can I learn about linking C with Perl? [h2xs, xsubpp]
1010
1011 =item I've read perlembed, perlguts, etc., but I can't embed perl in
1012 my C program; what am I doing wrong?
1013
1014 =item When I tried to run my script, I got this message. What does it mean?
1015
1016 =item What's MakeMaker?
1017
1018 =back
1019
1020 =item AUTHOR AND COPYRIGHT
1021
1022 =back
1023
1024 =head2 perlfaq4 - Data Manipulation ($Revision: 1.49 $, $Date: 2003/09/20
1025 06:37:43 $)
1026
1027 =over 4
1028
1029 =item DESCRIPTION
1030
1031 =item Data: Numbers
1032
1033 =over 4
1034
1035 =item Why am I getting long decimals (eg, 19.9499999999999) instead of the
1036 numbers I should be getting (eg, 19.95)?
1037
1038 =item Why is int() broken?
1039
1040 =item Why isn't my octal data interpreted correctly?
1041
1042 =item Does Perl have a round() function?  What about ceil() and floor()? 
1043 Trig functions?
1044
1045 =item How do I convert between numeric representations/bases/radixes?
1046
1047 How do I convert hexadecimal into decimal, How do I convert from decimal to
1048 hexadecimal, How do I convert from octal to decimal, How do I convert from
1049 decimal to octal, How do I convert from binary to decimal, How do I convert
1050 from decimal to binary
1051
1052 =item Why doesn't & work the way I want it to?
1053
1054 =item How do I multiply matrices?
1055
1056 =item How do I perform an operation on a series of integers?
1057
1058 =item How can I output Roman numerals?
1059
1060 =item Why aren't my random numbers random?
1061
1062 =item How do I get a random number between X and Y?
1063
1064 =back
1065
1066 =item Data: Dates
1067
1068 =over 4
1069
1070 =item How do I find the day or week of the year?
1071
1072 =item How do I find the current century or millennium?
1073
1074 =item How can I compare two dates and find the difference?
1075
1076 =item How can I take a string and turn it into epoch seconds?
1077
1078 =item How can I find the Julian Day?
1079
1080 =item How do I find yesterday's date?
1081
1082 =item Does Perl have a Year 2000 problem?  Is Perl Y2K compliant?
1083
1084 =back
1085
1086 =item Data: Strings
1087
1088 =over 4
1089
1090 =item How do I validate input?
1091
1092 =item How do I unescape a string?
1093
1094 =item How do I remove consecutive pairs of characters?
1095
1096 =item How do I expand function calls in a string?
1097
1098 =item How do I find matching/nesting anything?
1099
1100 =item How do I reverse a string?
1101
1102 =item How do I expand tabs in a string?
1103
1104 =item How do I reformat a paragraph?
1105
1106 =item How can I access or change N characters of a string?
1107
1108 =item How do I change the Nth occurrence of something?
1109
1110 =item How can I count the number of occurrences of a substring within a
1111 string?
1112
1113 =item How do I capitalize all the words on one line?
1114
1115 =item How can I split a [character] delimited string except when inside
1116 [character]?
1117
1118 =item How do I strip blank space from the beginning/end of a string?
1119
1120 =item How do I pad a string with blanks or pad a number with zeroes?
1121
1122 =item How do I extract selected columns from a string?
1123
1124 =item How do I find the soundex value of a string?
1125
1126 =item How can I expand variables in text strings?
1127
1128 =item What's wrong with always quoting "$vars"?
1129
1130 =item Why don't my E<lt>E<lt>HERE documents work?
1131
1132 There must be no space after the E<lt>E<lt> part, There (probably) should
1133 be a semicolon at the end, You can't (easily) have any space in front of
1134 the tag
1135
1136 =back
1137
1138 =item Data: Arrays
1139
1140 =over 4
1141
1142 =item What is the difference between a list and an array?
1143
1144 =item What is the difference between $array[1] and @array[1]?
1145
1146 =item How can I remove duplicate elements from a list or array?
1147
1148 a), b), c), d), e)
1149
1150 =item How can I tell whether a certain element is contained in a list or
1151 array?
1152
1153 =item How do I compute the difference of two arrays?  How do I compute the
1154 intersection of two arrays?
1155
1156 =item How do I test whether two arrays or hashes are equal?
1157
1158 =item How do I find the first array element for which a condition is true?
1159
1160 =item How do I handle linked lists?
1161
1162 =item How do I handle circular lists?
1163
1164 =item How do I shuffle an array randomly?
1165
1166 =item How do I process/modify each element of an array?
1167
1168 =item How do I select a random element from an array?
1169
1170 =item How do I permute N elements of a list?
1171
1172 =item How do I sort an array by (anything)?
1173
1174 =item How do I manipulate arrays of bits?
1175
1176 =item Why does defined() return true on empty arrays and hashes?
1177
1178 =back
1179
1180 =item Data: Hashes (Associative Arrays)
1181
1182 =over 4
1183
1184 =item How do I process an entire hash?
1185
1186 =item What happens if I add or remove keys from a hash while iterating over
1187 it?
1188
1189 =item How do I look up a hash element by value?
1190
1191 =item How can I know how many entries are in a hash?
1192
1193 =item How do I sort a hash (optionally by value instead of key)?
1194
1195 =item How can I always keep my hash sorted?
1196
1197 =item What's the difference between "delete" and "undef" with hashes?
1198
1199 =item Why don't my tied hashes make the defined/exists distinction?
1200
1201 =item How do I reset an each() operation part-way through?
1202
1203 =item How can I get the unique keys from two hashes?
1204
1205 =item How can I store a multidimensional array in a DBM file?
1206
1207 =item How can I make my hash remember the order I put elements into it?
1208
1209 =item Why does passing a subroutine an undefined element in a hash create
1210 it?
1211
1212 =item How can I make the Perl equivalent of a C structure/C++ class/hash or
1213 array of hashes or arrays?
1214
1215 =item How can I use a reference as a hash key?
1216
1217 =back
1218
1219 =item Data: Misc
1220
1221 =over 4
1222
1223 =item How do I handle binary data correctly?
1224
1225 =item How do I determine whether a scalar is a number/whole/integer/float?
1226
1227 =item How do I keep persistent data across program calls?
1228
1229 =item How do I print out or copy a recursive data structure?
1230
1231 =item How do I define methods for every class/object?
1232
1233 =item How do I verify a credit card checksum?
1234
1235 =item How do I pack arrays of doubles or floats for XS code?
1236
1237 =back
1238
1239 =item AUTHOR AND COPYRIGHT
1240
1241 =back
1242
1243 =head2 perlfaq5 - Files and Formats ($Revision: 1.28 $, $Date: 2003/01/26
1244 17:45:46 $)
1245
1246 =over 4
1247
1248 =item DESCRIPTION
1249
1250 =over 4
1251
1252 =item How do I flush/unbuffer an output filehandle?  Why must I do this?
1253
1254 =item How do I change one line in a file/delete a line in a file/insert a
1255 line in the middle of a file/append to the beginning of a file?
1256
1257 =item How do I count the number of lines in a file?
1258
1259 =item How can I use Perl's C<-i> option from within a program?
1260
1261 =item How do I make a temporary file name?
1262
1263 =item How can I manipulate fixed-record-length files?
1264
1265 =item How can I make a filehandle local to a subroutine?  How do I pass
1266 filehandles between subroutines?  How do I make an array of filehandles?
1267
1268 =item How can I use a filehandle indirectly?
1269
1270 =item How can I set up a footer format to be used with write()?
1271
1272 =item How can I write() into a string?
1273
1274 =item How can I output my numbers with commas added?
1275
1276 =item How can I translate tildes (~) in a filename?
1277
1278 =item How come when I open a file read-write it wipes it out?
1279
1280 =item Why do I sometimes get an "Argument list too long" when I use
1281 E<lt>*E<gt>?
1282
1283 =item Is there a leak/bug in glob()?
1284
1285 =item How can I open a file with a leading ">" or trailing blanks?
1286
1287 =item How can I reliably rename a file?
1288
1289 =item How can I lock a file?
1290
1291 =item Why can't I just open(FH, "E<gt>file.lock")?
1292
1293 =item I still don't get locking.  I just want to increment the number in
1294 the file.  How can I do this?
1295
1296 =item All I want to do is append a small amount of text to the end of a
1297 file.  Do I still have to use locking?
1298
1299 =item How do I randomly update a binary file?
1300
1301 =item How do I get a file's timestamp in perl?
1302
1303 =item How do I set a file's timestamp in perl?
1304
1305 =item How do I print to more than one file at once?
1306
1307 =item How can I read in an entire file all at once?
1308
1309 =item How can I read in a file by paragraphs?
1310
1311 =item How can I read a single character from a file?  From the keyboard?
1312
1313 =item How can I tell whether there's a character waiting on a filehandle?
1314
1315 =item How do I do a C<tail -f> in perl?
1316
1317 =item How do I dup() a filehandle in Perl?
1318
1319 =item How do I close a file descriptor by number?
1320
1321 =item Why can't I use "C:\temp\foo" in DOS paths?  Why doesn't
1322 `C:\temp\foo.exe` work?
1323
1324 =item Why doesn't glob("*.*") get all the files?
1325
1326 =item Why does Perl let me delete read-only files?  Why does C<-i> clobber
1327 protected files?  Isn't this a bug in Perl?
1328
1329 =item How do I select a random line from a file?
1330
1331 =item Why do I get weird spaces when I print an array of lines?
1332
1333 =back
1334
1335 =item AUTHOR AND COPYRIGHT
1336
1337 =back
1338
1339 =head2 perlfaq6 - Regular Expressions ($Revision: 1.20 $, $Date: 2003/01/03
1340 20:05:28 $)
1341
1342 =over 4
1343
1344 =item DESCRIPTION
1345
1346 =over 4
1347
1348 =item How can I hope to use regular expressions without creating illegible
1349 and unmaintainable code?
1350
1351 Comments Outside the Regex, Comments Inside the Regex, Different Delimiters
1352
1353 =item I'm having trouble matching over more than one line.  What's wrong?
1354
1355 =item How can I pull out lines between two patterns that are themselves on
1356 different lines?
1357
1358 =item I put a regular expression into $/ but it didn't work. What's wrong?
1359
1360 =item How do I substitute case insensitively on the LHS while preserving
1361 case on the RHS?
1362
1363 =item How can I make C<\w> match national character sets?
1364
1365 =item How can I match a locale-smart version of C</[a-zA-Z]/>?
1366
1367 =item How can I quote a variable to use in a regex?
1368
1369 =item What is C</o> really for?
1370
1371 =item How do I use a regular expression to strip C style comments from a
1372 file?
1373
1374 =item Can I use Perl regular expressions to match balanced text?
1375
1376 =item What does it mean that regexes are greedy?  How can I get around it?
1377
1378 =item How do I process each word on each line?
1379
1380 =item How can I print out a word-frequency or line-frequency summary?
1381
1382 =item How can I do approximate matching?
1383
1384 =item How do I efficiently match many regular expressions at once?
1385
1386 =item Why don't word-boundary searches with C<\b> work for me?
1387
1388 =item Why does using $&, $`, or $' slow my program down?
1389
1390 =item What good is C<\G> in a regular expression?
1391
1392 =item Are Perl regexes DFAs or NFAs?  Are they POSIX compliant?
1393
1394 =item What's wrong with using grep in a void context?
1395
1396 =item How can I match strings with multibyte characters?
1397
1398 =item How do I match a pattern that is supplied by the user?
1399
1400 =back
1401
1402 =item AUTHOR AND COPYRIGHT
1403
1404 =back
1405
1406 =head2 perlfaq7 - General Perl Language Issues ($Revision: 1.15 $, $Date:
1407 2003/07/24 02:17:21 $)
1408
1409 =over 4
1410
1411 =item DESCRIPTION
1412
1413 =over 4
1414
1415 =item Can I get a BNF/yacc/RE for the Perl language?
1416
1417 =item What are all these $@%&* punctuation signs, and how do I know when to
1418 use them?
1419
1420 =item Do I always/never have to quote my strings or use semicolons and
1421 commas?
1422
1423 =item How do I skip some return values?
1424
1425 =item How do I temporarily block warnings?
1426
1427 =item What's an extension?
1428
1429 =item Why do Perl operators have different precedence than C operators?
1430
1431 =item How do I declare/create a structure?
1432
1433 =item How do I create a module?
1434
1435 =item How do I create a class?
1436
1437 =item How can I tell if a variable is tainted?
1438
1439 =item What's a closure?
1440
1441 =item What is variable suicide and how can I prevent it?
1442
1443 =item How can I pass/return a {Function, FileHandle, Array, Hash, Method,
1444 Regex}?
1445
1446 Passing Variables and Functions, Passing Filehandles, Passing Regexes,
1447 Passing Methods
1448
1449 =item How do I create a static variable?
1450
1451 =item What's the difference between dynamic and lexical (static) scoping? 
1452 Between local() and my()?
1453
1454 =item How can I access a dynamic variable while a similarly named lexical
1455 is in scope?
1456
1457 =item What's the difference between deep and shallow binding?
1458
1459 =item Why doesn't "my($foo) = E<lt>FILEE<gt>;" work right?
1460
1461 =item How do I redefine a builtin function, operator, or method?
1462
1463 =item What's the difference between calling a function as &foo and foo()?
1464
1465 =item How do I create a switch or case statement?
1466
1467 =item How can I catch accesses to undefined variables, functions, or
1468 methods?
1469
1470 =item Why can't a method included in this same file be found?
1471
1472 =item How can I find out my current package?
1473
1474 =item How can I comment out a large block of perl code?
1475
1476 =item How do I clear a package?
1477
1478 =item How can I use a variable as a variable name?
1479
1480 =item What does "bad interpreter" mean?
1481
1482 =back
1483
1484 =item AUTHOR AND COPYRIGHT
1485
1486 =back
1487
1488 =head2 perlfaq8 - System Interaction ($Revision: 1.17 $, $Date: 2003/01/26
1489 17:44:04 $)
1490
1491 =over 4
1492
1493 =item DESCRIPTION
1494
1495 =over 4
1496
1497 =item How do I find out which operating system I'm running under?
1498
1499 =item How come exec() doesn't return?
1500
1501 =item How do I do fancy stuff with the keyboard/screen/mouse?
1502
1503 Keyboard, Screen, Mouse
1504
1505 =item How do I print something out in color?
1506
1507 =item How do I read just one key without waiting for a return key?
1508
1509 =item How do I check whether input is ready on the keyboard?
1510
1511 =item How do I clear the screen?
1512
1513 =item How do I get the screen size?
1514
1515 =item How do I ask the user for a password?
1516
1517 =item How do I read and write the serial port?
1518
1519 lockfiles, open mode, end of line, flushing output, non-blocking input
1520
1521 =item How do I decode encrypted password files?
1522
1523 =item How do I start a process in the background?
1524
1525 STDIN, STDOUT, and STDERR are shared, Signals, Zombies
1526
1527 =item How do I trap control characters/signals?
1528
1529 =item How do I modify the shadow password file on a Unix system?
1530
1531 =item How do I set the time and date?
1532
1533 =item How can I sleep() or alarm() for under a second?
1534
1535 =item How can I measure time under a second?
1536
1537 =item How can I do an atexit() or setjmp()/longjmp()? (Exception handling)
1538
1539 =item Why doesn't my sockets program work under System V (Solaris)?  What
1540 does the error message "Protocol not supported" mean?
1541
1542 =item How can I call my system's unique C functions from Perl?
1543
1544 =item Where do I get the include files to do ioctl() or syscall()?
1545
1546 =item Why do setuid perl scripts complain about kernel problems?
1547
1548 =item How can I open a pipe both to and from a command?
1549
1550 =item Why can't I get the output of a command with system()?
1551
1552 =item How can I capture STDERR from an external command?
1553
1554 =item Why doesn't open() return an error when a pipe open fails?
1555
1556 =item What's wrong with using backticks in a void context?
1557
1558 =item How can I call backticks without shell processing?
1559
1560 =item Why can't my script read from STDIN after I gave it EOF (^D on Unix,
1561 ^Z on MS-DOS)?
1562
1563 =item How can I convert my shell script to perl?
1564
1565 =item Can I use perl to run a telnet or ftp session?
1566
1567 =item How can I write expect in Perl?
1568
1569 =item Is there a way to hide perl's command line from programs such as
1570 "ps"?
1571
1572 =item I {changed directory, modified my environment} in a perl script.  How
1573 come the change disappeared when I exited the script?  How do I get my
1574 changes to be visible?
1575
1576 Unix
1577
1578 =item How do I close a process's filehandle without waiting for it to
1579 complete?
1580
1581 =item How do I fork a daemon process?
1582
1583 =item How do I find out if I'm running interactively or not?
1584
1585 =item How do I timeout a slow event?
1586
1587 =item How do I set CPU limits?
1588
1589 =item How do I avoid zombies on a Unix system?
1590
1591 =item How do I use an SQL database?
1592
1593 =item How do I make a system() exit on control-C?
1594
1595 =item How do I open a file without blocking?
1596
1597 =item How do I install a module from CPAN?
1598
1599 =item What's the difference between require and use?
1600
1601 =item How do I keep my own module/library directory?
1602
1603 =item How do I add the directory my program lives in to the module/library
1604 search path?
1605
1606 =item How do I add a directory to my include path (@INC) at runtime?
1607
1608 =item What is socket.ph and where do I get it?
1609
1610 =back
1611
1612 =item AUTHOR AND COPYRIGHT
1613
1614 =back
1615
1616 =head2 perlfaq9 - Networking ($Revision: 1.15 $, $Date: 2003/01/31 17:36:57
1617 $)
1618
1619 =over 4
1620
1621 =item DESCRIPTION
1622
1623 =over 4
1624
1625 =item What is the correct form of response from a CGI script?
1626
1627 =item My CGI script runs from the command line but not the browser.  (500
1628 Server Error)
1629
1630 =item How can I get better error messages from a CGI program?
1631
1632 =item How do I remove HTML from a string?
1633
1634 =item How do I extract URLs?
1635
1636 =item How do I download a file from the user's machine?  How do I open a
1637 file on another machine?
1638
1639 =item How do I make a pop-up menu in HTML?
1640
1641 =item How do I fetch an HTML file?
1642
1643 =item How do I automate an HTML form submission?
1644
1645 =item How do I decode or create those %-encodings on the web?
1646
1647 =item How do I redirect to another page?
1648
1649 =item How do I put a password on my web pages?
1650
1651 =item How do I edit my .htpasswd and .htgroup files with Perl?
1652
1653 =item How do I make sure users can't enter values into a form that cause my
1654 CGI script to do bad things?
1655
1656 =item How do I parse a mail header?
1657
1658 =item How do I decode a CGI form?
1659
1660 =item How do I check a valid mail address?
1661
1662 =item How do I decode a MIME/BASE64 string?
1663
1664 =item How do I return the user's mail address?
1665
1666 =item How do I send mail?
1667
1668 =item How do I use MIME to make an attachment to a mail message?
1669
1670 =item How do I read mail?
1671
1672 =item How do I find out my hostname/domainname/IP address?
1673
1674 =item How do I fetch a news article or the active newsgroups?
1675
1676 =item How do I fetch/put an FTP file?
1677
1678 =item How can I do RPC in Perl?
1679
1680 =back
1681
1682 =item AUTHOR AND COPYRIGHT
1683
1684 =back
1685
1686 =head2 perlsyn - Perl syntax
1687
1688 =over 4
1689
1690 =item DESCRIPTION
1691
1692 =over 4
1693
1694 =item Declarations
1695
1696 =item Comments
1697
1698 =item Simple Statements
1699
1700 =item Compound Statements
1701
1702 =item Loop Control
1703
1704 =item For Loops
1705
1706 =item Foreach Loops
1707
1708 =item Basic BLOCKs and Switch Statements
1709
1710 =item Goto
1711
1712 =item PODs: Embedded Documentation
1713
1714 =item Plain Old Comments (Not!)
1715
1716 =back
1717
1718 =back
1719
1720 =head2 perldata - Perl data types
1721
1722 =over 4
1723
1724 =item DESCRIPTION
1725
1726 =over 4
1727
1728 =item Variable names
1729
1730 =item Context
1731
1732 =item Scalar values
1733
1734 =item Scalar value constructors
1735
1736 =item List value constructors
1737
1738 =item Subscripts
1739
1740 =item Slices
1741
1742 =item Typeglobs and Filehandles
1743
1744 =back
1745
1746 =item SEE ALSO
1747
1748 =back
1749
1750 =head2 perlop - Perl operators and precedence
1751
1752 =over 4
1753
1754 =item SYNOPSIS
1755
1756 =item DESCRIPTION
1757
1758 =over 4
1759
1760 =item Terms and List Operators (Leftward)
1761
1762 =item The Arrow Operator
1763
1764 =item Auto-increment and Auto-decrement
1765
1766 =item Exponentiation
1767
1768 =item Symbolic Unary Operators
1769
1770 =item Binding Operators
1771
1772 =item Multiplicative Operators
1773
1774 =item Additive Operators
1775
1776 =item Shift Operators
1777
1778 =item Named Unary Operators
1779
1780 =item Relational Operators
1781
1782 =item Equality Operators
1783
1784 =item Bitwise And
1785
1786 =item Bitwise Or and Exclusive Or
1787
1788 =item C-style Logical And
1789
1790 =item C-style Logical Or
1791
1792 =item C-style Logical Defined-Or
1793
1794 =item Range Operators
1795
1796 =item Conditional Operator
1797
1798 =item Assignment Operators
1799
1800 =item Comma Operator
1801
1802 =item List Operators (Rightward)
1803
1804 =item Logical Not
1805
1806 =item Logical And
1807
1808 =item Logical or, Defined or, and Exclusive Or
1809
1810 =item C Operators Missing From Perl
1811
1812 unary &, unary *, (TYPE)
1813
1814 =item Quote and Quote-like Operators
1815
1816 =item Regexp Quote-Like Operators
1817
1818 ?PATTERN?, m/PATTERN/cgimosx, /PATTERN/cgimosx, q/STRING/, C<'STRING'>,
1819 qq/STRING/, "STRING", qr/STRING/imosx, qx/STRING/, `STRING`, qw/STRING/,
1820 s/PATTERN/REPLACEMENT/egimosx, tr/SEARCHLIST/REPLACEMENTLIST/cds,
1821 y/SEARCHLIST/REPLACEMENTLIST/cds, <<EOF
1822
1823 =item Gory details of parsing quoted constructs
1824
1825 Finding the end, Removal of backslashes before delimiters, Interpolation,
1826 C<<<'EOF'>, C<m''>, C<s'''>, C<tr///>, C<y///>, C<''>, C<q//>, C<"">,
1827 C<``>, C<qq//>, C<qx//>, C<< <file*glob> >>, C<?RE?>, C</RE/>, C<m/RE/>,
1828 C<s/RE/foo/>,, Interpolation of regular expressions, Optimization of
1829 regular expressions
1830
1831 =item I/O Operators
1832
1833 =item Constant Folding
1834
1835 =item Bitwise String Operators
1836
1837 =item Integer Arithmetic
1838
1839 =item Floating-point Arithmetic
1840
1841 =item Bigger Numbers
1842
1843 =back
1844
1845 =back
1846
1847 =head2 perlsub - Perl subroutines
1848
1849 =over 4
1850
1851 =item SYNOPSIS
1852
1853 =item DESCRIPTION
1854
1855 =over 4
1856
1857 =item Private Variables via my()
1858
1859 =item Persistent Private Variables
1860
1861 =item Temporary Values via local()
1862
1863 =item Lvalue subroutines
1864
1865 Lvalue subroutines are EXPERIMENTAL
1866
1867 =item Passing Symbol Table Entries (typeglobs)
1868
1869 =item When to Still Use local()
1870
1871 =item Pass by Reference
1872
1873 =item Prototypes
1874
1875 =item Constant Functions
1876
1877 =item Overriding Built-in Functions
1878
1879 =item Autoloading
1880
1881 =item Subroutine Attributes
1882
1883 =back
1884
1885 =item SEE ALSO
1886
1887 =back
1888
1889 =head2 perlfunc - Perl builtin functions
1890
1891 =over 4
1892
1893 =item DESCRIPTION
1894
1895 =over 4
1896
1897 =item Perl Functions by Category
1898
1899 Functions for SCALARs or strings, Regular expressions and pattern matching,
1900 Numeric functions, Functions for real @ARRAYs, Functions for list data,
1901 Functions for real %HASHes, Input and output functions, Functions for fixed
1902 length data or records, Functions for filehandles, files, or directories,
1903 Keywords related to the control flow of your perl program, Keywords related
1904 to scoping, Miscellaneous functions, Functions for processes and process
1905 groups, Keywords related to perl modules, Keywords related to classes and
1906 object-orientedness, Low-level socket functions, System V interprocess
1907 communication functions, Fetching user and group info, Fetching network
1908 info, Time-related functions, Functions new in perl5, Functions obsoleted
1909 in perl5
1910
1911 =item Portability
1912
1913 =item Alphabetical Listing of Perl Functions
1914
1915 -I<X> FILEHANDLE, -I<X> EXPR, -I<X>, abs VALUE, abs, accept
1916 NEWSOCKET,GENERICSOCKET, alarm SECONDS, alarm, atan2 Y,X, bind SOCKET,NAME,
1917 binmode FILEHANDLE, LAYER, binmode FILEHANDLE, bless REF,CLASSNAME, bless
1918 REF, caller EXPR, caller, chdir EXPR, chmod LIST, chomp VARIABLE, chomp(
1919 LIST ), chomp, chop VARIABLE, chop( LIST ), chop, chown LIST, chr NUMBER,
1920 chr, chroot FILENAME, chroot, close FILEHANDLE, close, closedir DIRHANDLE,
1921 connect SOCKET,NAME, continue BLOCK, cos EXPR, cos, crypt PLAINTEXT,SALT,
1922 dbmclose HASH, dbmopen HASH,DBNAME,MASK, defined EXPR, defined, delete
1923 EXPR, die LIST, do BLOCK, do SUBROUTINE(LIST), do EXPR, dump LABEL, dump,
1924 each HASH, eof FILEHANDLE, eof (), eof, eval EXPR, eval BLOCK, exec LIST,
1925 exec PROGRAM LIST, exists EXPR, exit EXPR, exp EXPR, exp, fcntl
1926 FILEHANDLE,FUNCTION,SCALAR, fileno FILEHANDLE, flock FILEHANDLE,OPERATION,
1927 fork, format, formline PICTURE,LIST, getc FILEHANDLE, getc, getlogin,
1928 getpeername SOCKET, getpgrp PID, getppid, getpriority WHICH,WHO, getpwnam
1929 NAME, getgrnam NAME, gethostbyname NAME, getnetbyname NAME, getprotobyname
1930 NAME, getpwuid UID, getgrgid GID, getservbyname NAME,PROTO, gethostbyaddr
1931 ADDR,ADDRTYPE, getnetbyaddr ADDR,ADDRTYPE, getprotobynumber NUMBER,
1932 getservbyport PORT,PROTO, getpwent, getgrent, gethostent, getnetent,
1933 getprotoent, getservent, setpwent, setgrent, sethostent STAYOPEN, setnetent
1934 STAYOPEN, setprotoent STAYOPEN, setservent STAYOPEN, endpwent, endgrent,
1935 endhostent, endnetent, endprotoent, endservent, getsockname SOCKET,
1936 getsockopt SOCKET,LEVEL,OPTNAME, glob EXPR, glob, gmtime EXPR, goto LABEL,
1937 goto EXPR, goto &NAME, grep BLOCK LIST, grep EXPR,LIST, hex EXPR, hex,
1938 import, index STR,SUBSTR,POSITION, index STR,SUBSTR, int EXPR, int, ioctl
1939 FILEHANDLE,FUNCTION,SCALAR, join EXPR,LIST, keys HASH, kill SIGNAL, LIST,
1940 last LABEL, last, lc EXPR, lc, lcfirst EXPR, lcfirst, length EXPR, length,
1941 link OLDFILE,NEWFILE, listen SOCKET,QUEUESIZE, local EXPR, localtime EXPR,
1942 lock THING, log EXPR, log, lstat EXPR, lstat, m//, map BLOCK LIST, map
1943 EXPR,LIST, mkdir FILENAME,MASK, mkdir FILENAME, msgctl ID,CMD,ARG, msgget
1944 KEY,FLAGS, msgrcv ID,VAR,SIZE,TYPE,FLAGS, msgsnd ID,MSG,FLAGS, my EXPR, my
1945 TYPE EXPR, my EXPR : ATTRS, my TYPE EXPR : ATTRS, next LABEL, next, no
1946 Module VERSION LIST, no Module VERSION, no Module LIST, no Module, oct
1947 EXPR, oct, open FILEHANDLE,EXPR, open FILEHANDLE,MODE,EXPR, open
1948 FILEHANDLE,MODE,EXPR,LIST, open FILEHANDLE,MODE,REFERENCE, open FILEHANDLE,
1949 opendir DIRHANDLE,EXPR, ord EXPR, ord, our EXPR, our EXPR TYPE, our EXPR :
1950 ATTRS, our TYPE EXPR : ATTRS, pack TEMPLATE,LIST, package NAMESPACE,
1951 package, pipe READHANDLE,WRITEHANDLE, pop ARRAY, pop, pos SCALAR, pos,
1952 print FILEHANDLE LIST, print LIST, print, printf FILEHANDLE FORMAT, LIST,
1953 printf FORMAT, LIST, prototype FUNCTION, push ARRAY,LIST, q/STRING/,
1954 qq/STRING/, qr/STRING/, qx/STRING/, qw/STRING/, quotemeta EXPR, quotemeta,
1955 rand EXPR, rand, read FILEHANDLE,SCALAR,LENGTH,OFFSET, read
1956 FILEHANDLE,SCALAR,LENGTH, readdir DIRHANDLE, readline EXPR, readlink EXPR,
1957 readlink, readpipe EXPR, recv SOCKET,SCALAR,LENGTH,FLAGS, redo LABEL, redo,
1958 ref EXPR, ref, rename OLDNAME,NEWNAME, require VERSION, require EXPR,
1959 require, reset EXPR, reset, return EXPR, return, reverse LIST, rewinddir
1960 DIRHANDLE, rindex STR,SUBSTR,POSITION, rindex STR,SUBSTR, rmdir FILENAME,
1961 rmdir, s///, scalar EXPR, seek FILEHANDLE,POSITION,WHENCE, seekdir
1962 DIRHANDLE,POS, select FILEHANDLE, select, select RBITS,WBITS,EBITS,TIMEOUT,
1963 semctl ID,SEMNUM,CMD,ARG, semget KEY,NSEMS,FLAGS, semop KEY,OPSTRING, send
1964 SOCKET,MSG,FLAGS,TO, send SOCKET,MSG,FLAGS, setpgrp PID,PGRP, setpriority
1965 WHICH,WHO,PRIORITY, setsockopt SOCKET,LEVEL,OPTNAME,OPTVAL, shift ARRAY,
1966 shift, shmctl ID,CMD,ARG, shmget KEY,SIZE,FLAGS, shmread ID,VAR,POS,SIZE,
1967 shmwrite ID,STRING,POS,SIZE, shutdown SOCKET,HOW, sin EXPR, sin, sleep
1968 EXPR, sleep, socket SOCKET,DOMAIN,TYPE,PROTOCOL, socketpair
1969 SOCKET1,SOCKET2,DOMAIN,TYPE,PROTOCOL, sort SUBNAME LIST, sort BLOCK LIST,
1970 sort LIST, splice ARRAY,OFFSET,LENGTH,LIST, splice ARRAY,OFFSET,LENGTH,
1971 splice ARRAY,OFFSET, splice ARRAY, split /PATTERN/,EXPR,LIMIT, split
1972 /PATTERN/,EXPR, split /PATTERN/, split, sprintf FORMAT, LIST, format
1973 parameter index, flags, vector flag, (minimum) width, precision, or maximum
1974 width, size, order of arguments, sqrt EXPR, sqrt, srand EXPR, srand, stat
1975 FILEHANDLE, stat EXPR, stat, study SCALAR, study, sub NAME BLOCK, sub NAME
1976 (PROTO) BLOCK, sub NAME : ATTRS BLOCK, sub NAME (PROTO) : ATTRS BLOCK,
1977 substr EXPR,OFFSET,LENGTH,REPLACEMENT, substr EXPR,OFFSET,LENGTH, substr
1978 EXPR,OFFSET, symlink OLDFILE,NEWFILE, syscall NUMBER, LIST, sysopen
1979 FILEHANDLE,FILENAME,MODE, sysopen FILEHANDLE,FILENAME,MODE,PERMS, sysread
1980 FILEHANDLE,SCALAR,LENGTH,OFFSET, sysread FILEHANDLE,SCALAR,LENGTH, sysseek
1981 FILEHANDLE,POSITION,WHENCE, system LIST, system PROGRAM LIST, syswrite
1982 FILEHANDLE,SCALAR,LENGTH,OFFSET, syswrite FILEHANDLE,SCALAR,LENGTH,
1983 syswrite FILEHANDLE,SCALAR, tell FILEHANDLE, tell, telldir DIRHANDLE, tie
1984 VARIABLE,CLASSNAME,LIST, tied VARIABLE, time, times, tr///, truncate
1985 FILEHANDLE,LENGTH, truncate EXPR,LENGTH, uc EXPR, uc, ucfirst EXPR,
1986 ucfirst, umask EXPR, umask, undef EXPR, undef, unlink LIST, unlink, unpack
1987 TEMPLATE,EXPR, unpack TEMPLATE, untie VARIABLE, unshift ARRAY,LIST, use
1988 Module VERSION LIST, use Module VERSION, use Module LIST, use Module, use
1989 VERSION, utime LIST, values HASH, vec EXPR,OFFSET,BITS, wait, waitpid
1990 PID,FLAGS, wantarray, warn LIST, write FILEHANDLE, write EXPR, write, y///
1991
1992 =back
1993
1994 =back
1995
1996 =head2 perlopentut - tutorial on opening things in Perl
1997
1998 =over 4
1999
2000 =item DESCRIPTION
2001
2002 =item Open E<agrave> la shell
2003
2004 =over 4
2005
2006 =item Simple Opens
2007
2008 =item Indirect Filehandles
2009
2010 =item Pipe Opens
2011
2012 =item The Minus File
2013
2014 =item Mixing Reads and Writes
2015
2016 =item Filters 
2017
2018 =back
2019
2020 =item Open E<agrave> la C
2021
2022 =over 4
2023
2024 =item Permissions E<agrave> la mode
2025
2026 =back
2027
2028 =item Obscure Open Tricks
2029
2030 =over 4
2031
2032 =item Re-Opening Files (dups)
2033
2034 =item Dispelling the Dweomer
2035
2036 =item Paths as Opens
2037
2038 =item Single Argument Open
2039
2040 =item Playing with STDIN and STDOUT
2041
2042 =back
2043
2044 =item Other I/O Issues
2045
2046 =over 4
2047
2048 =item Opening Non-File Files
2049
2050 =item Opening Named Pipes
2051
2052 =item Opening Sockets
2053
2054 =item Binary Files
2055
2056 =item File Locking
2057
2058 =item IO Layers
2059
2060 =back
2061
2062 =item SEE ALSO 
2063
2064 =item AUTHOR and COPYRIGHT
2065
2066 =item HISTORY
2067
2068 =back
2069
2070 =head2 perlpacktut - tutorial on C<pack> and C<unpack>
2071
2072 =over 4
2073
2074 =item DESCRIPTION
2075
2076 =item The Basic Principle
2077
2078 =item Packing Text
2079
2080 =item Packing Numbers
2081
2082 =over 4
2083
2084 =item Integers
2085
2086 =item Unpacking a Stack Frame
2087
2088 =item How to Eat an Egg on a Net
2089
2090 =item Floating point Numbers
2091
2092 =back
2093
2094 =item Exotic Templates
2095
2096 =over 4
2097
2098 =item Bit Strings
2099
2100 =item Uuencoding
2101
2102 =item Doing Sums
2103
2104 =item  Unicode
2105
2106 =item Another Portable Binary Encoding
2107
2108 =back
2109
2110 =item Template Grouping
2111
2112 =item Lengths and Widths
2113
2114 =over 4
2115
2116 =item String Lengths
2117
2118 =item Dynamic Templates
2119
2120 =item Counting Repetitions
2121
2122 =back
2123
2124 =item Packing and Unpacking C Structures
2125
2126 =over 4
2127
2128 =item The Alignment Pit
2129
2130 =item Alignment, Take 2
2131
2132 =item Alignment, Take 3
2133
2134 =item Pointers for How to Use Them
2135
2136 =back
2137
2138 =item Pack Recipes
2139
2140 =item Funnies Section
2141
2142 =item Authors
2143
2144 =back
2145
2146 =head2 perlpod - the Plain Old Documentation format
2147
2148 =over 4
2149
2150 =item DESCRIPTION
2151
2152 =over 4
2153
2154 =item Ordinary Paragraph
2155
2156 =item Verbatim Paragraph
2157
2158 =item Command Paragraph
2159
2160 C<=head1 I<Heading Text>>, C<=head2 I<Heading Text>>, C<=head3 I<Heading
2161 Text>>, C<=head4 I<Heading Text>>, C<=over I<indentlevel>>, C<=item
2162 I<stuff...>>, C<=back>, C<=cut>, C<=pod>, C<=begin I<formatname>>, C<=end
2163 I<formatname>>, C<=for I<formatname> I<text...>>, C<=encoding
2164 I<encodingname>>
2165
2166 =item Formatting Codes
2167
2168 C<IE<lt>textE<gt>> -- italic text, C<BE<lt>textE<gt>> -- bold text,
2169 C<CE<lt>codeE<gt>> -- code text, C<LE<lt>nameE<gt>> -- a hyperlink,
2170 C<EE<lt>escapeE<gt>> -- a character escape, C<FE<lt>filenameE<gt>> -- used
2171 for filenames, C<SE<lt>textE<gt>> -- text contains non-breaking spaces,
2172 C<XE<lt>topic nameE<gt>> -- an index entry, C<ZE<lt>E<gt>> -- a null
2173 (zero-effect) formatting code
2174
2175 =item The Intent
2176
2177 =item Embedding Pods in Perl Modules
2178
2179 =item Hints for Writing Pod
2180
2181 =back
2182
2183 =item SEE ALSO
2184
2185 =item AUTHOR
2186
2187 =back
2188
2189 =head2 perlpodspec - Plain Old Documentation: format specification and
2190 notes
2191
2192 =over 4
2193
2194 =item DESCRIPTION
2195
2196 =item Pod Definitions
2197
2198 =item Pod Commands
2199
2200 "=head1", "=head2", "=head3", "=head4", "=pod", "=cut", "=over", "=item",
2201 "=back", "=begin formatname", "=end formatname", "=for formatname text...",
2202 "=encoding encodingname"
2203
2204 =item Pod Formatting Codes
2205
2206 C<IE<lt>textE<gt>> -- italic text, C<BE<lt>textE<gt>> -- bold text,
2207 C<CE<lt>codeE<gt>> -- code text, C<FE<lt>filenameE<gt>> -- style for
2208 filenames, C<XE<lt>topic nameE<gt>> -- an index entry, C<ZE<lt>E<gt>> -- a
2209 null (zero-effect) formatting code, C<LE<lt>nameE<gt>> -- a hyperlink,
2210 C<EE<lt>escapeE<gt>> -- a character escape, C<SE<lt>textE<gt>> -- text
2211 contains non-breaking spaces
2212
2213 =item Notes on Implementing Pod Processors
2214
2215 =item About LE<lt>...E<gt> Codes
2216
2217 First:, Second:, Third:, Fourth:, Fifth:, Sixth:
2218
2219 =item About =over...=back Regions
2220
2221 =item About Data Paragraphs and "=begin/=end" Regions
2222
2223 =item SEE ALSO
2224
2225 =item AUTHOR
2226
2227 =back
2228
2229 =head2 perlrun - how to execute the Perl interpreter
2230
2231 =over 4
2232
2233 =item SYNOPSIS
2234
2235 =item DESCRIPTION
2236
2237 =over 4
2238
2239 =item #! and quoting on non-Unix systems
2240
2241 OS/2, MS-DOS, Win95/NT, Macintosh, VMS
2242
2243 =item Location of Perl
2244
2245 =item Command Switches
2246
2247 B<-0>[I<octal/hexadecimal>], B<-A [I<assertions>]>, B<-a>, B<-C
2248 [I<number/list>]>, B<-c>, B<-d>, B<-d:>I<foo[=bar,baz]>, B<-D>I<letters>,
2249 B<-D>I<number>, B<-e> I<commandline>, B<-F>I<pattern>, B<-h>,
2250 B<-i>[I<extension>], B<-I>I<directory>, B<-l>[I<octnum>],
2251 B<-m>[B<->]I<module>, B<-M>[B<->]I<module>, B<-M>[B<->]I<'module ...'>,
2252 B<-[mM]>[B<->]I<module=arg[,arg]...>, B<-n>, B<-p>, B<-P>, B<-s>, B<-S>,
2253 B<-t>, B<-T>, B<-u>, B<-U>, B<-v>, B<-V>, B<-V:>I<name>, B<-w>, B<-W>,
2254 B<-X>, B<-x> I<directory>
2255
2256 =back
2257
2258 =item ENVIRONMENT
2259
2260 HOME, LOGDIR, PATH, PERL5LIB, PERL5OPT, PERLIO, :bytes, :crlf, :mmap,
2261 :perlio, :pop, :raw, :stdio, :unix, :utf8, :win32, PERLIO_DEBUG, PERLLIB,
2262 PERL5DB, PERL5SHELL (specific to the Win32 port), PERL_DEBUG_MSTATS,
2263 PERL_DESTRUCT_LEVEL, PERL_ENCODING, PERL_HASH_SEED, PERL_HASH_SEED_DEBUG,
2264 PERL_ROOT (specific to the VMS port), PERL_SIGNALS, PERL_UNICODE, SYS$LOGIN
2265 (specific to the VMS port)
2266
2267 =back
2268
2269 =head2 perldiag - various Perl diagnostics
2270
2271 =over 4
2272
2273 =item DESCRIPTION
2274
2275 =back
2276
2277 =head2 perllexwarn - Perl Lexical Warnings
2278
2279 =over 4
2280
2281 =item DESCRIPTION
2282
2283 =over 4
2284
2285 =item Default Warnings and Optional Warnings
2286
2287 =item What's wrong with B<-w> and C<$^W>
2288
2289 =item Controlling Warnings from the Command Line
2290
2291 B<-w>, B<-W>, B<-X>
2292
2293 =item Backward Compatibility
2294
2295 =item Category Hierarchy
2296
2297 =item Fatal Warnings
2298
2299 =item Reporting Warnings from a Module
2300
2301 =back
2302
2303 =item TODO
2304
2305 =item SEE ALSO
2306
2307 =item AUTHOR
2308
2309 =back
2310
2311 =head2 perldebug - Perl debugging
2312
2313 =over 4
2314
2315 =item DESCRIPTION
2316
2317 =item The Perl Debugger
2318
2319 =over 4
2320
2321 =item Debugger Commands
2322
2323 h, h [command], h h, p expr, x [maxdepth] expr, V [pkg [vars]], X [vars], y
2324 [level [vars]], T, s [expr], n [expr], r, <CR>, c [line|sub], l, l
2325 min+incr, l min-max, l line, l subname, -, v [line], f filename, /pattern/,
2326 ?pattern?, L [abw], S [[!]regex], t, t expr, b, b [line] [condition], b
2327 subname [condition], b postpone subname [condition], b load filename, b
2328 compile subname, B line, B *, a [line] command, A line, A *, w expr, W
2329 expr, W *, o, o booloption .., o anyoption? .., o option=value .., < ?, < [
2330 command ], < *, << command, > ?, > command, > *, >> command, { ?, { [
2331 command ], { *, {{ command, ! number, ! -number, ! pattern, !! cmd, source
2332 file, H -number, q or ^D, R, |dbcmd, ||dbcmd, command, m expr, M, man
2333 [manpage]
2334
2335 =item Configurable Options
2336
2337 C<recallCommand>, C<ShellBang>, C<pager>, C<tkRunning>, C<signalLevel>,
2338 C<warnLevel>, C<dieLevel>, C<AutoTrace>, C<LineInfo>, C<inhibit_exit>,
2339 C<PrintRet>, C<ornaments>, C<frame>, C<maxTraceLen>, C<windowSize>,
2340 C<arrayDepth>, C<hashDepth>, C<dumpDepth>, C<compactDump>, C<veryCompact>,
2341 C<globPrint>, C<DumpDBFiles>, C<DumpPackages>, C<DumpReused>, C<quote>,
2342 C<HighBit>, C<undefPrint>, C<UsageOnly>, C<TTY>, C<noTTY>, C<ReadLine>,
2343 C<NonStop>
2344
2345 =item Debugger input/output
2346
2347 Prompt, Multiline commands, Stack backtrace, Line Listing Format, Frame
2348 listing
2349
2350 =item Debugging compile-time statements
2351
2352 =item Debugger Customization
2353
2354 =item Readline Support
2355
2356 =item Editor Support for Debugging
2357
2358 =item The Perl Profiler
2359
2360 =back
2361
2362 =item Debugging regular expressions
2363
2364 =item Debugging memory usage
2365
2366 =item SEE ALSO
2367
2368 =item BUGS
2369
2370 =back
2371
2372 =head2 perlvar - Perl predefined variables
2373
2374 =over 4
2375
2376 =item DESCRIPTION
2377
2378 =over 4
2379
2380 =item Predefined Names
2381
2382 $ARG, $_, $a, $b, $<I<digits>>, $MATCH, $&, $PREMATCH, $`, $POSTMATCH, $',
2383 $LAST_PAREN_MATCH, $+, $^N, @LAST_MATCH_END, @+,
2384 HANDLE->input_line_number(EXPR), $INPUT_LINE_NUMBER, $NR, $,
2385 IO::Handle->input_record_separator(EXPR), $INPUT_RECORD_SEPARATOR, $RS, $/,
2386 HANDLE->autoflush(EXPR), $OUTPUT_AUTOFLUSH, $|,
2387 IO::Handle->output_field_separator EXPR, $OUTPUT_FIELD_SEPARATOR, $OFS, $,,
2388 IO::Handle->output_record_separator EXPR, $OUTPUT_RECORD_SEPARATOR, $ORS,
2389 $\, $LIST_SEPARATOR, $", $SUBSCRIPT_SEPARATOR, $SUBSEP, $;, $#,
2390 HANDLE->format_page_number(EXPR), $FORMAT_PAGE_NUMBER, $%,
2391 HANDLE->format_lines_per_page(EXPR), $FORMAT_LINES_PER_PAGE, $=,
2392 HANDLE->format_lines_left(EXPR), $FORMAT_LINES_LEFT, $-, @LAST_MATCH_START,
2393 @-, C<$`> is the same as C<substr($var, 0, $-[0])>, C<$&> is the same as
2394 C<substr($var, $-[0], $+[0] - $-[0])>, C<$'> is the same as C<substr($var,
2395 $+[0])>, C<$1> is the same as C<substr($var, $-[1], $+[1] - $-[1])>, C<$2>
2396 is the same as C<substr($var, $-[2], $+[2] - $-[2])>, C<$3> is the same as
2397 C<substr $var, $-[3], $+[3] - $-[3])>, HANDLE->format_name(EXPR),
2398 $FORMAT_NAME, $~, HANDLE->format_top_name(EXPR), $FORMAT_TOP_NAME, $^,
2399 IO::Handle->format_line_break_characters EXPR,
2400 $FORMAT_LINE_BREAK_CHARACTERS, $:, IO::Handle->format_formfeed EXPR,
2401 $FORMAT_FORMFEED, $^L, $ACCUMULATOR, $^A, $CHILD_ERROR, $?, ${^ENCODING},
2402 $OS_ERROR, $ERRNO, $!, %!, $EXTENDED_OS_ERROR, $^E, $EVAL_ERROR, $@,
2403 $PROCESS_ID, $PID, $$, $REAL_USER_ID, $UID, $<, $EFFECTIVE_USER_ID, $EUID,
2404 $>, $REAL_GROUP_ID, $GID, $(, $EFFECTIVE_GROUP_ID, $EGID, $),
2405 $PROGRAM_NAME, $0, $[, $], $COMPILING, $^C, $DEBUGGING, $^D,
2406 $SYSTEM_FD_MAX, $^F, $^H, %^H, $INPLACE_EDIT, $^I, $^M, $OSNAME, $^O,
2407 ${^OPEN}, $PERLDB, $^P, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80,
2408 0x100, 0x200, 0x400, $LAST_REGEXP_CODE_RESULT, $^R,
2409 $EXCEPTIONS_BEING_CAUGHT, $^S, $BASETIME, $^T, ${^TAINT}, ${^UNICODE},
2410 $PERL_VERSION, $^V, $WARNING, $^W, ${^WARNING_BITS}, $EXECUTABLE_NAME, $^X,
2411 ARGV, $ARGV, @ARGV, ARGVOUT, @F, @INC, @_, %INC, %ENV, $ENV{expr}, %SIG,
2412 $SIG{expr}
2413
2414 =item Error Indicators
2415
2416 =item Technical Note on the Syntax of Variable Names
2417
2418 =back
2419
2420 =item BUGS
2421
2422 =back
2423
2424 =head2 perlre - Perl regular expressions
2425
2426 =over 4
2427
2428 =item DESCRIPTION
2429
2430 i, m, s, x
2431
2432 =over 4
2433
2434 =item Regular Expressions
2435
2436 [1], [2], [3], cntrl, graph, print, punct, xdigit
2437
2438 =item Extended Patterns
2439
2440 C<(?#text)>, C<(?imsx-imsx)>, C<(?:pattern)>, C<(?imsx-imsx:pattern)>,
2441 C<(?=pattern)>, C<(?!pattern)>, C<(?<=pattern)>, C<(?<!pattern)>, C<(?{
2442 code })>, C<(??{ code })>, C<< (?>pattern) >>,
2443 C<(?(condition)yes-pattern|no-pattern)>, C<(?(condition)yes-pattern)>
2444
2445 =item Backtracking
2446
2447 =item Version 8 Regular Expressions
2448
2449 =item Warning on \1 vs $1
2450
2451 =item Repeated patterns matching zero-length substring
2452
2453 =item Combining pieces together
2454
2455 C<ST>, C<S|T>, C<S{REPEAT_COUNT}>, C<S{min,max}>, C<S{min,max}?>, C<S?>,
2456 C<S*>, C<S+>, C<S??>, C<S*?>, C<S+?>, C<< (?>S) >>, C<(?=S)>, C<(?<=S)>,
2457 C<(?!S)>, C<(?<!S)>, C<(??{ EXPR })>,
2458 C<(?(condition)yes-pattern|no-pattern)>
2459
2460 =item Creating custom RE engines
2461
2462 =back
2463
2464 =item BUGS
2465
2466 =item SEE ALSO
2467
2468 =back
2469
2470 =head2 perlreref - Perl Regular Expressions Reference
2471
2472 =over 4
2473
2474 =item DESCRIPTION
2475
2476 =over 4
2477
2478 =item OPERATORS
2479
2480 =item SYNTAX
2481
2482 =item ESCAPE SEQUENCES
2483
2484 =item CHARACTER CLASSES
2485
2486 =item ANCHORS
2487
2488 =item QUANTIFIERS
2489
2490 =item EXTENDED CONSTRUCTS
2491
2492 =item VARIABLES
2493
2494 =item FUNCTIONS
2495
2496 =item TERMINOLOGY
2497
2498 =back
2499
2500 =item AUTHOR
2501
2502 =item SEE ALSO
2503
2504 =item THANKS
2505
2506 =back
2507
2508 =head2 perlref - Perl references and nested data structures
2509
2510 =over 4
2511
2512 =item NOTE
2513
2514 =item DESCRIPTION
2515
2516 =over 4
2517
2518 =item Making References
2519
2520 =item Using References
2521
2522 =item Symbolic references
2523
2524 =item Not-so-symbolic references
2525
2526 =item Pseudo-hashes: Using an array as a hash
2527
2528 =item Function Templates
2529
2530 =back
2531
2532 =item WARNING
2533
2534 =item SEE ALSO
2535
2536 =back
2537
2538 =head2 perlform - Perl formats
2539
2540 =over 4
2541
2542 =item DESCRIPTION
2543
2544 =over 4
2545
2546 =item Format Variables
2547
2548 =back
2549
2550 =item NOTES
2551
2552 =over 4
2553
2554 =item Footers
2555
2556 =item Accessing Formatting Internals
2557
2558 =back
2559
2560 =item WARNINGS
2561
2562 =back
2563
2564 =head2 perlobj - Perl objects
2565
2566 =over 4
2567
2568 =item DESCRIPTION
2569
2570 =over 4
2571
2572 =item An Object is Simply a Reference
2573
2574 =item A Class is Simply a Package
2575
2576 =item A Method is Simply a Subroutine
2577
2578 =item Method Invocation
2579
2580 =item Indirect Object Syntax
2581
2582 =item Default UNIVERSAL methods
2583
2584 isa(CLASS), can(METHOD), VERSION( [NEED] )
2585
2586 =item Destructors
2587
2588 =item Summary
2589
2590 =item Two-Phased Garbage Collection
2591
2592 =back
2593
2594 =item SEE ALSO
2595
2596 =back
2597
2598 =head2 perltie - how to hide an object class in a simple variable
2599
2600 =over 4
2601
2602 =item SYNOPSIS
2603
2604 =item DESCRIPTION
2605
2606 =over 4
2607
2608 =item Tying Scalars
2609
2610 TIESCALAR classname, LIST, FETCH this, STORE this, value, UNTIE this,
2611 DESTROY this
2612
2613 =item Tying Arrays
2614
2615 TIEARRAY classname, LIST, FETCH this, index, STORE this, index, value,
2616 FETCHSIZE this, STORESIZE this, count, EXTEND this, count, EXISTS this,
2617 key, DELETE this, key, CLEAR this, PUSH this, LIST, POP this, SHIFT this,
2618 UNSHIFT this, LIST, SPLICE this, offset, length, LIST, UNTIE this, DESTROY
2619 this
2620
2621 =item Tying Hashes
2622
2623 USER, HOME, CLOBBER, LIST, TIEHASH classname, LIST, FETCH this, key, STORE
2624 this, key, value, DELETE this, key, CLEAR this, EXISTS this, key, FIRSTKEY
2625 this, NEXTKEY this, lastkey, UNTIE this, DESTROY this
2626
2627 =item Tying FileHandles
2628
2629 TIEHANDLE classname, LIST, WRITE this, LIST, PRINT this, LIST, PRINTF this,
2630 LIST, READ this, LIST, READLINE this, GETC this, CLOSE this, UNTIE this,
2631 DESTROY this
2632
2633 =item UNTIE this
2634
2635 =item The C<untie> Gotcha
2636
2637 =back
2638
2639 =item SEE ALSO
2640
2641 =item BUGS
2642
2643 =item AUTHOR
2644
2645 =back
2646
2647 =head2 perldbmfilter - Perl DBM Filters
2648
2649 =over 4
2650
2651 =item SYNOPSIS
2652
2653 =item DESCRIPTION
2654
2655 B<filter_store_key>, B<filter_store_value>, B<filter_fetch_key>,
2656 B<filter_fetch_value>
2657
2658 =over 4
2659
2660 =item The Filter
2661
2662 =item An Example -- the NULL termination problem.
2663
2664 =item Another Example -- Key is a C int.
2665
2666 =back
2667
2668 =item SEE ALSO
2669
2670 =item AUTHOR
2671
2672 =back
2673
2674 =head2 perlipc - Perl interprocess communication (signals, fifos, pipes,
2675 safe subprocesses, sockets, and semaphores)
2676
2677 =over 4
2678
2679 =item DESCRIPTION
2680
2681 =item Signals
2682
2683 =over 4
2684
2685 =item Handling the SIGHUP Signal in Daemons
2686
2687 =back
2688
2689 =item Named Pipes
2690
2691 =over 4
2692
2693 =item Deferred Signals (Safe Signals)
2694
2695 Long running opcodes, Interrupting IO, Restartable system calls, Signals as
2696 "faults", Signals triggered by operating system state
2697
2698 =back
2699
2700 =item Using open() for IPC
2701
2702 =over 4
2703
2704 =item Filehandles
2705
2706 =item Background Processes
2707
2708 =item Complete Dissociation of Child from Parent
2709
2710 =item Safe Pipe Opens
2711
2712 =item Bidirectional Communication with Another Process
2713
2714 =item Bidirectional Communication with Yourself
2715
2716 =back
2717
2718 =item Sockets: Client/Server Communication
2719
2720 =over 4
2721
2722 =item Internet Line Terminators
2723
2724 =item Internet TCP Clients and Servers
2725
2726 =item Unix-Domain TCP Clients and Servers
2727
2728 =back
2729
2730 =item TCP Clients with IO::Socket
2731
2732 =over 4
2733
2734 =item A Simple Client
2735
2736 C<Proto>, C<PeerAddr>, C<PeerPort>
2737
2738 =item A Webget Client
2739
2740 =item Interactive Client with IO::Socket
2741
2742 =back
2743
2744 =item TCP Servers with IO::Socket
2745
2746 Proto, LocalPort, Listen, Reuse
2747
2748 =item UDP: Message Passing
2749
2750 =item SysV IPC
2751
2752 =item NOTES
2753
2754 =item BUGS
2755
2756 =item AUTHOR
2757
2758 =item SEE ALSO
2759
2760 =back
2761
2762 =head2 perlfork - Perl's fork() emulation
2763
2764 =over 4
2765
2766 =item SYNOPSIS
2767
2768 =item DESCRIPTION
2769
2770 =over 4
2771
2772 =item Behavior of other Perl features in forked pseudo-processes
2773
2774 $$ or $PROCESS_ID, %ENV, chdir() and all other builtins that accept
2775 filenames, wait() and waitpid(), kill(), exec(), exit(), Open handles to
2776 files, directories and network sockets
2777
2778 =item Resource limits
2779
2780 =item Killing the parent process
2781
2782 =item Lifetime of the parent process and pseudo-processes
2783
2784 =item CAVEATS AND LIMITATIONS
2785
2786 BEGIN blocks, Open filehandles, Forking pipe open() not yet implemented,
2787 Global state maintained by XSUBs, Interpreter embedded in larger
2788 application, Thread-safety of extensions
2789
2790 =back
2791
2792 =item BUGS
2793
2794 =item AUTHOR
2795
2796 =item SEE ALSO
2797
2798 =back
2799
2800 =head2 perlnumber - semantics of numbers and numeric operations in Perl
2801
2802 =over 4
2803
2804 =item SYNOPSIS
2805
2806 =item DESCRIPTION
2807
2808 =item Storing numbers
2809
2810 =item Numeric operators and numeric conversions
2811
2812 =item Flavors of Perl numeric operations
2813
2814 Arithmetic operators, ++, Arithmetic operators during C<use integer>, Other
2815 mathematical operators, Bitwise operators, Bitwise operators during C<use
2816 integer>, Operators which expect an integer, Operators which expect a
2817 string
2818
2819 =item AUTHOR
2820
2821 =item SEE ALSO
2822
2823 =back
2824
2825 =head2 perlthrtut - tutorial on threads in Perl
2826
2827 =over 4
2828
2829 =item DESCRIPTION
2830
2831 =item Status
2832
2833 =item What Is A Thread Anyway?
2834
2835 =item Threaded Program Models
2836
2837 =over 4
2838
2839 =item Boss/Worker
2840
2841 =item Work Crew
2842
2843 =item Pipeline
2844
2845 =back
2846
2847 =item What kind of threads are Perl threads?
2848
2849 =item Thread-Safe Modules
2850
2851 =item Thread Basics
2852
2853 =over 4
2854
2855 =item Basic Thread Support
2856
2857 =item A Note about the Examples
2858
2859 =item Creating Threads
2860
2861 =item Waiting For A Thread To Exit
2862
2863 =item Ignoring A Thread
2864
2865 =back
2866
2867 =item Threads And Data
2868
2869 =over 4
2870
2871 =item Shared And Unshared Data
2872
2873 =item Thread Pitfalls: Races
2874
2875 =back
2876
2877 =item Synchronization and control
2878
2879 =over 4
2880
2881 =item Controlling access: lock()
2882
2883 =item A Thread Pitfall: Deadlocks
2884
2885 =item Queues: Passing Data Around
2886
2887 =item Semaphores: Synchronizing Data Access
2888
2889 =item Basic semaphores
2890
2891 =item Advanced Semaphores
2892
2893 =item cond_wait() and cond_signal()
2894
2895 =item Giving up control
2896
2897 =back
2898
2899 =item General Thread Utility Routines
2900
2901 =over 4
2902
2903 =item What Thread Am I In?
2904
2905 =item Thread IDs
2906
2907 =item Are These Threads The Same?
2908
2909 =item What Threads Are Running?
2910
2911 =back
2912
2913 =item A Complete Example
2914
2915 =item Different implementations of threads
2916
2917 =item Performance considerations
2918
2919 =item Process-scope Changes
2920
2921 =item Thread-Safety of System Libraries
2922
2923 =item Conclusion
2924
2925 =item Bibliography
2926
2927 =over 4
2928
2929 =item Introductory Texts
2930
2931 =item OS-Related References
2932
2933 =item Other References
2934
2935 =back
2936
2937 =item Acknowledgements
2938
2939 =item AUTHOR
2940
2941 =item Copyrights
2942
2943 =back
2944
2945 =head2 perlothrtut - old tutorial on threads in Perl
2946
2947 =over 4
2948
2949 =item DESCRIPTION
2950
2951 =item What Is A Thread Anyway?
2952
2953 =item Threaded Program Models
2954
2955 =over 4
2956
2957 =item Boss/Worker
2958
2959 =item Work Crew
2960
2961 =item Pipeline
2962
2963 =back
2964
2965 =item Native threads
2966
2967 =item What kind of threads are perl threads?
2968
2969 =item Threadsafe Modules
2970
2971 =item Thread Basics
2972
2973 =over 4
2974
2975 =item Basic Thread Support
2976
2977 =item Creating Threads
2978
2979 =item Giving up control
2980
2981 =item Waiting For A Thread To Exit
2982
2983 =item Errors In Threads
2984
2985 =item Ignoring A Thread
2986
2987 =back
2988
2989 =item Threads And Data
2990
2991 =over 4
2992
2993 =item Shared And Unshared Data
2994
2995 =item Thread Pitfall: Races
2996
2997 =item Controlling access: lock()
2998
2999 =item Thread Pitfall: Deadlocks
3000
3001 =item Queues: Passing Data Around
3002
3003 =back
3004
3005 =item Threads And Code
3006
3007 =over 4
3008
3009 =item Semaphores: Synchronizing Data Access
3010
3011 Basic semaphores, Advanced Semaphores
3012
3013 =item Attributes: Restricting Access To Subroutines
3014
3015 =item Subroutine Locks
3016
3017 =item Methods
3018
3019 =item Locking A Subroutine
3020
3021 =back
3022
3023 =item General Thread Utility Routines
3024
3025 =over 4
3026
3027 =item What Thread Am I In?
3028
3029 =item Thread IDs
3030
3031 =item Are These Threads The Same?
3032
3033 =item What Threads Are Running?
3034
3035 =back
3036
3037 =item A Complete Example
3038
3039 =item Conclusion
3040
3041 =item Bibliography
3042
3043 =over 4
3044
3045 =item Introductory Texts
3046
3047 =item OS-Related References
3048
3049 =item Other References
3050
3051 =back
3052
3053 =item Acknowledgements
3054
3055 =item AUTHOR
3056
3057 =item Copyrights
3058
3059 =back
3060
3061 =head2 perlport - Writing portable Perl
3062
3063 =over 4
3064
3065 =item DESCRIPTION
3066
3067 Not all Perl programs have to be portable, Nearly all of Perl already I<is>
3068 portable
3069
3070 =item ISSUES
3071
3072 =over 4
3073
3074 =item Newlines
3075
3076 =item Numbers endianness and Width
3077
3078 =item Files and Filesystems
3079
3080 =item System Interaction
3081
3082 =item Command names versus file pathnames
3083
3084 =item Networking
3085
3086 =item Interprocess Communication (IPC)
3087
3088 =item External Subroutines (XS)
3089
3090 =item Standard Modules
3091
3092 =item Time and Date
3093
3094 =item Character sets and character encoding
3095
3096 =item Internationalisation
3097
3098 =item System Resources
3099
3100 =item Security
3101
3102 =item Style
3103
3104 =back
3105
3106 =item CPAN Testers
3107
3108 Mailing list: cpan-testers@perl.org, Testing results:
3109 http://testers.cpan.org/
3110
3111 =item PLATFORMS
3112
3113 =over 4
3114
3115 =item Unix
3116
3117 =item DOS and Derivatives
3118
3119 =item S<Mac OS>
3120
3121 =item VMS
3122
3123 =item VOS
3124
3125 =item EBCDIC Platforms
3126
3127 =item Acorn RISC OS
3128
3129 =item Other perls
3130
3131 =back
3132
3133 =item FUNCTION IMPLEMENTATIONS
3134
3135 =over 4
3136
3137 =item Alphabetical Listing of Perl Functions
3138
3139 -I<X> FILEHANDLE, -I<X> EXPR, -I<X>, alarm SECONDS, alarm, binmode
3140 FILEHANDLE, chmod LIST, chown LIST, chroot FILENAME, chroot, crypt
3141 PLAINTEXT,SALT, dbmclose HASH, dbmopen HASH,DBNAME,MODE, dump LABEL, exec
3142 LIST, exit EXPR, exit, fcntl FILEHANDLE,FUNCTION,SCALAR, flock
3143 FILEHANDLE,OPERATION, fork, getlogin, getpgrp PID, getppid, getpriority
3144 WHICH,WHO, getpwnam NAME, getgrnam NAME, getnetbyname NAME, getpwuid UID,
3145 getgrgid GID, getnetbyaddr ADDR,ADDRTYPE, getprotobynumber NUMBER,
3146 getservbyport PORT,PROTO, getpwent, getgrent, gethostbyname, gethostent,
3147 getnetent, getprotoent, getservent, sethostent STAYOPEN, setnetent
3148 STAYOPEN, setprotoent STAYOPEN, setservent STAYOPEN, endpwent, endgrent,
3149 endhostent, endnetent, endprotoent, endservent, getsockopt
3150 SOCKET,LEVEL,OPTNAME, glob EXPR, glob, ioctl FILEHANDLE,FUNCTION,SCALAR,
3151 kill SIGNAL, LIST, link OLDFILE,NEWFILE, lstat FILEHANDLE, lstat EXPR,
3152 lstat, msgctl ID,CMD,ARG, msgget KEY,FLAGS, msgsnd ID,MSG,FLAGS, msgrcv
3153 ID,VAR,SIZE,TYPE,FLAGS, open FILEHANDLE,EXPR, open FILEHANDLE, pipe
3154 READHANDLE,WRITEHANDLE, readlink EXPR, readlink, select
3155 RBITS,WBITS,EBITS,TIMEOUT, semctl ID,SEMNUM,CMD,ARG, semget
3156 KEY,NSEMS,FLAGS, semop KEY,OPSTRING, setgrent, setpgrp PID,PGRP,
3157 setpriority WHICH,WHO,PRIORITY, setpwent, setsockopt
3158 SOCKET,LEVEL,OPTNAME,OPTVAL, shmctl ID,CMD,ARG, shmget KEY,SIZE,FLAGS,
3159 shmread ID,VAR,POS,SIZE, shmwrite ID,STRING,POS,SIZE, sockatmark SOCKET,
3160 socketpair SOCKET1,SOCKET2,DOMAIN,TYPE,PROTOCOL, stat FILEHANDLE, stat
3161 EXPR, stat, symlink OLDFILE,NEWFILE, syscall LIST, sysopen
3162 FILEHANDLE,FILENAME,MODE,PERMS, system LIST, times, truncate
3163 FILEHANDLE,LENGTH, truncate EXPR,LENGTH, umask EXPR, umask, utime LIST,
3164 wait, waitpid PID,FLAGS
3165
3166 =back
3167
3168 =item CHANGES
3169
3170 v1.49, 12 August 2002, v1.48, 02 February 2001, v1.47, 22 March 2000,
3171 v1.46, 12 February 2000, v1.45, 20 December 1999, v1.44, 19 July 1999,
3172 v1.43, 24 May 1999, v1.42, 22 May 1999, v1.41, 19 May 1999, v1.40, 11 April
3173 1999, v1.39, 11 February 1999, v1.38, 31 December 1998, v1.37, 19 December
3174 1998, v1.36, 9 September 1998, v1.35, 13 August 1998, v1.33, 06 August
3175 1998, v1.32, 05 August 1998, v1.30, 03 August 1998, v1.23, 10 July 1998
3176
3177 =item Supported Platforms
3178
3179 =item SEE ALSO
3180
3181 =item AUTHORS / CONTRIBUTORS
3182
3183 =back
3184
3185 =head2 perllocale - Perl locale handling (internationalization and
3186 localization)
3187
3188 =over 4
3189
3190 =item DESCRIPTION
3191
3192 =item PREPARING TO USE LOCALES
3193
3194 =item USING LOCALES
3195
3196 =over 4
3197
3198 =item The use locale pragma
3199
3200 =item The setlocale function
3201
3202 =item Finding locales
3203
3204 =item LOCALE PROBLEMS
3205
3206 =item Temporarily fixing locale problems
3207
3208 =item Permanently fixing locale problems
3209
3210 =item Permanently fixing your system's locale configuration
3211
3212 =item Fixing system locale configuration
3213
3214 =item The localeconv function
3215
3216 =item I18N::Langinfo
3217
3218 =back
3219
3220 =item LOCALE CATEGORIES
3221
3222 =over 4
3223
3224 =item Category LC_COLLATE: Collation
3225
3226 =item Category LC_CTYPE: Character Types
3227
3228 =item Category LC_NUMERIC: Numeric Formatting
3229
3230 =item Category LC_MONETARY: Formatting of monetary amounts
3231
3232 =item LC_TIME
3233
3234 =item Other categories
3235
3236 =back
3237
3238 =item SECURITY
3239
3240 =item ENVIRONMENT
3241
3242 PERL_BADLANG, LC_ALL, LANGUAGE, LC_CTYPE, LC_COLLATE, LC_MONETARY,
3243 LC_NUMERIC, LC_TIME, LANG
3244
3245 =item NOTES
3246
3247 =over 4
3248
3249 =item Backward compatibility
3250
3251 =item I18N:Collate obsolete
3252
3253 =item Sort speed and memory use impacts
3254
3255 =item write() and LC_NUMERIC
3256
3257 =item Freely available locale definitions
3258
3259 =item I18n and l10n
3260
3261 =item An imperfect standard
3262
3263 =back
3264
3265 =item Unicode and UTF-8
3266
3267 =item BUGS
3268
3269 =over 4
3270
3271 =item Broken systems
3272
3273 =back
3274
3275 =item SEE ALSO
3276
3277 =item HISTORY
3278
3279 =back
3280
3281 =head2 perluniintro - Perl Unicode introduction
3282
3283 =over 4
3284
3285 =item DESCRIPTION
3286
3287 =over 4
3288
3289 =item Unicode
3290
3291 =item Perl's Unicode Support
3292
3293 =item Perl's Unicode Model
3294
3295 =item Unicode and EBCDIC
3296
3297 =item Creating Unicode
3298
3299 =item Handling Unicode
3300
3301 =item Legacy Encodings
3302
3303 =item Unicode I/O
3304
3305 =item Displaying Unicode As Text
3306
3307 =item Special Cases
3308
3309 =item Advanced Topics
3310
3311 =item Miscellaneous
3312
3313 =item Questions With Answers
3314
3315 =item Hexadecimal Notation
3316
3317 =item Further Resources
3318
3319 =back
3320
3321 =item UNICODE IN OLDER PERLS
3322
3323 =item SEE ALSO
3324
3325 =item ACKNOWLEDGMENTS
3326
3327 =item AUTHOR, COPYRIGHT, AND LICENSE
3328
3329 =back
3330
3331 =head2 perlunicode - Unicode support in Perl
3332
3333 =over 4
3334
3335 =item DESCRIPTION
3336
3337 =over 4
3338
3339 =item Important Caveats
3340
3341 Input and Output Layers, Regular Expressions, C<use utf8> still needed to
3342 enable UTF-8/UTF-EBCDIC in scripts
3343
3344 =item Byte and Character Semantics
3345
3346 =item Effects of Character Semantics
3347
3348 =item Scripts
3349
3350 =item Blocks
3351
3352 =item User-Defined Character Properties
3353
3354 =item Character Encodings for Input and Output
3355
3356 =item Unicode Regular Expression Support Level
3357
3358 =item Unicode Encodings
3359
3360 =item Security Implications of Unicode
3361
3362 =item Unicode in Perl on EBCDIC
3363
3364 =item Locales
3365
3366 =item When Unicode Does Not Happen
3367
3368 =item Forcing Unicode in Perl (Or Unforcing Unicode in Perl)
3369
3370 =item Using Unicode in XS
3371
3372 =back
3373
3374 =item BUGS
3375
3376 =over 4
3377
3378 =item Interaction with Locales
3379
3380 =item Interaction with Extensions
3381
3382 =item Speed
3383
3384 =item Porting code from perl-5.6.X
3385
3386 =back
3387
3388 =item SEE ALSO
3389
3390 =back
3391
3392 =head2 perlebcdic - Considerations for running Perl on EBCDIC platforms
3393
3394 =over 4
3395
3396 =item DESCRIPTION
3397
3398 =item COMMON CHARACTER CODE SETS
3399
3400 =over 4
3401
3402 =item ASCII
3403
3404 =item ISO 8859
3405
3406 =item Latin 1 (ISO 8859-1)
3407
3408 =item EBCDIC
3409
3410 =item 13 variant characters
3411
3412 =item 0037
3413
3414 =item 1047
3415
3416 =item POSIX-BC
3417
3418 =item Unicode code points versus EBCDIC code points
3419
3420 =item Remaining Perl Unicode problems in EBCDIC
3421
3422 =item Unicode and UTF
3423
3424 =item Using Encode
3425
3426 =back
3427
3428 =item SINGLE OCTET TABLES
3429
3430 recipe 0, recipe 1, recipe 2, recipe 3, recipe 4, recipe 5, recipe 6
3431
3432 =item IDENTIFYING CHARACTER CODE SETS
3433
3434 =item CONVERSIONS
3435
3436 =over 4
3437
3438 =item tr///
3439
3440 =item iconv
3441
3442 =item C RTL
3443
3444 =back
3445
3446 =item OPERATOR DIFFERENCES
3447
3448 =item FUNCTION DIFFERENCES
3449
3450 chr(), ord(), pack(), print(), printf(), sort(), sprintf(), unpack()
3451
3452 =item REGULAR EXPRESSION DIFFERENCES
3453
3454 =item SOCKETS
3455
3456 =item SORTING
3457
3458 =over 4
3459
3460 =item Ignore ASCII vs. EBCDIC sort differences.
3461
3462 =item MONO CASE then sort data.
3463
3464 =item Convert, sort data, then re convert.
3465
3466 =item Perform sorting on one type of machine only.
3467
3468 =back
3469
3470 =item TRANSFORMATION FORMATS
3471
3472 =over 4
3473
3474 =item URL decoding and encoding
3475
3476 =item uu encoding and decoding
3477
3478 =item Quoted-Printable encoding and decoding
3479
3480 =item Caesarian ciphers
3481
3482 =back
3483
3484 =item Hashing order and checksums
3485
3486 =item I18N AND L10N
3487
3488 =item MULTI OCTET CHARACTER SETS
3489
3490 =item OS ISSUES
3491
3492 =over 4
3493
3494 =item OS/400
3495
3496 PASE, IFS access
3497
3498 =item OS/390, z/OS
3499
3500 chcp, dataset access, OS/390, z/OS iconv, locales
3501
3502 =item VM/ESA?
3503
3504 =item POSIX-BC?
3505
3506 =back
3507
3508 =item BUGS
3509
3510 =item SEE ALSO
3511
3512 =item REFERENCES
3513
3514 =item HISTORY
3515
3516 =item AUTHOR
3517
3518 =back
3519
3520 =head2 perlsec - Perl security
3521
3522 =over 4
3523
3524 =item DESCRIPTION
3525
3526 =over 4
3527
3528 =item Laundering and Detecting Tainted Data
3529
3530 =item Switches On the "#!" Line
3531
3532 =item Cleaning Up Your Path
3533
3534 =item Security Bugs
3535
3536 =item Protecting Your Programs
3537
3538 =item Unicode
3539
3540 =item Algorithmic Complexity Attacks
3541
3542 =back
3543
3544 =item SEE ALSO
3545
3546 =back
3547
3548 =head2 perlmod - Perl modules (packages and symbol tables)
3549
3550 =over 4
3551
3552 =item DESCRIPTION
3553
3554 =over 4
3555
3556 =item Packages
3557
3558 =item Symbol Tables
3559
3560 =item Package Constructors and Destructors
3561
3562 =item Perl Classes
3563
3564 =item Perl Modules
3565
3566 =item Making your module threadsafe
3567
3568 =back
3569
3570 =item SEE ALSO
3571
3572 =back
3573
3574 =head2 perlmodlib - constructing new Perl modules and finding existing ones
3575
3576 =over 4
3577
3578 =item THE PERL MODULE LIBRARY
3579
3580 =over 4
3581
3582 =item Pragmatic Modules
3583
3584 assertions, assertions::activate, attributes, attrs, autouse, base, bigint,
3585 bignum, bigrat, blib, bytes, charnames, constant, diagnostics, encoding,
3586 fields, filetest, if, integer, less, lib, locale, open, ops, overload, re,
3587 sigtrap, sort, strict, subs, threads, threads::shared, utf8, vars, version,
3588 vmsish, warnings, warnings::register
3589
3590 =item Standard Modules
3591
3592 AnyDBM_File, Attribute::Handlers, AutoLoader, AutoSplit, B, B::Asmdata,
3593 B::Assembler, B::Bblock, B::Bytecode, B::C, B::CC, B::Concise, B::Debug,
3594 B::Deparse, B::Disassembler, B::Lint, B::Showlex, B::Stackobj, B::Stash,
3595 B::Terse, B::Xref, Benchmark, ByteLoader, CGI, CGI::Apache, CGI::Carp,
3596 CGI::Cookie, CGI::Fast, CGI::Pretty, CGI::Push, CGI::Switch, CGI::Util,
3597 CPAN, CPAN::FirstTime, CPAN::Nox, Carp, Carp::Heavy, Class::ISA,
3598 Class::Struct, Config, Cwd, DB, DB_File, Data::Dumper, Devel::DProf,
3599 Devel::PPPort, Devel::Peek, Devel::SelfStubber, Digest, Digest::MD5,
3600 DirHandle, Dumpvalue, DynaLoader, Encode, Encode::Alias, Encode::Byte,
3601 Encode::CJKConstants, Encode::CN, Encode::CN::HZ, Encode::Config,
3602 Encode::EBCDIC, Encode::Encoder, Encode::Encoding, Encode::Guess,
3603 Encode::JP, Encode::JP::H2Z, Encode::JP::JIS7, Encode::KR,
3604 Encode::KR::2022_KR, Encode::MIME::Header, Encode::PerlIO,
3605 Encode::Supported, Encode::Symbol, Encode::TW, Encode::Unicode,
3606 Encode::Unicode::UTF7, English, Env, Errno, Exporter, Exporter::Heavy,
3607 ExtUtils::Command, ExtUtils::Command::MM, ExtUtils::Constant,
3608 ExtUtils::Embed, ExtUtils::Install, ExtUtils::Installed, ExtUtils::Liblist,
3609 ExtUtils::MM, ExtUtils::MM_Any, ExtUtils::MM_BeOS, ExtUtils::MM_Cygwin,
3610 ExtUtils::MM_DOS, ExtUtils::MM_MacOS, ExtUtils::MM_NW5, ExtUtils::MM_OS2,
3611 ExtUtils::MM_UWIN, ExtUtils::MM_Unix, ExtUtils::MM_VMS, ExtUtils::MM_Win32,
3612 ExtUtils::MM_Win95, ExtUtils::MY, ExtUtils::MakeMaker,
3613 ExtUtils::MakeMaker::FAQ, ExtUtils::MakeMaker::Tutorial,
3614 ExtUtils::MakeMaker::bytes, ExtUtils::MakeMaker::vmsish,
3615 ExtUtils::Manifest, ExtUtils::Mkbootstrap, ExtUtils::Mksymlists,
3616 ExtUtils::Packlist, ExtUtils::testlib, Fatal, Fcntl, File::Basename,
3617 File::CheckTree, File::Compare, File::Copy, File::DosGlob, File::Find,
3618 File::Glob, File::Path, File::Spec, File::Spec::Cygwin, File::Spec::Epoc,
3619 File::Spec::Functions, File::Spec::Mac, File::Spec::OS2, File::Spec::Unix,
3620 File::Spec::VMS, File::Spec::Win32, File::Temp, File::stat, FileCache,
3621 FileHandle, Filter::Simple, Filter::Util::Call, FindBin, GDBM_File,
3622 Getopt::Long, Getopt::Std, Hash::Util, I18N::Collate, I18N::LangTags,
3623 I18N::LangTags::List, I18N::Langinfo, IO, IO::Dir, IO::File, IO::Handle,
3624 IO::Pipe, IO::Poll, IO::Seekable, IO::Select, IO::Socket, IO::Socket::INET,
3625 IO::Socket::UNIX, IPC::Open2, IPC::Open3, IPC::SysV, IPC::SysV::Msg,
3626 IPC::SysV::Semaphore, List::Util, Locale::Constants, Locale::Country,
3627 Locale::Currency, Locale::Language, Locale::Maketext,
3628 Locale::Maketext::TPJ13, Locale::Script, MIME::Base64,
3629 MIME::Base64::QuotedPrint, Math::BigFloat, Math::BigInt,
3630 Math::BigInt::Calc, Math::BigInt::Scalar, Math::BigRat, Math::Complex,
3631 Math::Trig, Memoize, Memoize::AnyDBM_File, Memoize::Expire,
3632 Memoize::ExpireFile, Memoize::ExpireTest, Memoize::NDBM_File,
3633 Memoize::SDBM_File, Memoize::Storable, NDBM_File, NEXT, Net::Cmd,
3634 Net::Config, Net::Domain, Net::FTP, Net::NNTP, Net::Netrc, Net::POP3,
3635 Net::Ping, Net::SMTP, Net::Time, Net::hostent, Net::libnetFAQ, Net::netent,
3636 Net::protoent, Net::servent, O, ODBM_File, Opcode, POSIX, PerlIO,
3637 PerlIO::encoding, PerlIO::scalar, PerlIO::via, PerlIO::via::QuotedPrint,
3638 Pod::Checker, Pod::Find, Pod::Functions, Pod::Html, Pod::InputObjects,
3639 Pod::LaTeX, Pod::Man, Pod::ParseLink, Pod::ParseUtils, Pod::Parser,
3640 Pod::Perldoc::ToChecker, Pod::Perldoc::ToMan, Pod::Perldoc::ToNroff,
3641 Pod::Perldoc::ToPod, Pod::Perldoc::ToRtf, Pod::Perldoc::ToText,
3642 Pod::Perldoc::ToTk, Pod::Perldoc::ToXml, Pod::PlainText, Pod::Plainer,
3643 Pod::Select, Pod::Text, Pod::Text::Color, Pod::Text::Overstrike,
3644 Pod::Text::Termcap, Pod::Usage, SDBM_File, Safe, Scalar::Util,
3645 Search::Dict, SelectSaver, SelfLoader, Shell, Socket, Storable, Switch,
3646 Symbol, Sys::Hostname, Sys::Syslog, Term::ANSIColor, Term::Cap,
3647 Term::Complete, Term::ReadLine, Test, Test::Builder, Test::Harness,
3648 Test::Harness::Assert, Test::Harness::Iterator, Test::Harness::Straps,
3649 Test::More, Test::Simple, Test::Tutorial, Text::Abbrev, Text::Balanced,
3650 Text::ParseWords, Text::Soundex, Text::Tabs, Text::Wrap, Thread,
3651 Thread::Queue, Thread::Semaphore, Thread::Signal, Thread::Specific,
3652 Tie::Array, Tie::File, Tie::Handle, Tie::Hash, Tie::Memoize, Tie::RefHash,
3653 Tie::Scalar, Tie::SubstrHash, Time::HiRes, Time::Local, Time::gmtime,
3654 Time::localtime, Time::tm, UNIVERSAL, Unicode::Collate, Unicode::Normalize,
3655 Unicode::UCD, User::grent, User::pwent, Win32, XS::APItest, XS::Typemap,
3656 XSLoader
3657
3658 =item Extension Modules
3659
3660 =back
3661
3662 =item CPAN
3663
3664 =over 4
3665
3666 =item Africa
3667
3668 South Africa
3669
3670 =item Asia
3671
3672 China, Indonesia, Israel, Japan, Malaysia, Russian Federation, Saudi
3673 Arabia, Singapore, South Korea, Taiwan, Thailand
3674
3675 =item Central America
3676
3677 Costa Rica
3678
3679 =item Europe
3680
3681 Austria, Belgium, Bosnia and Herzegovina, Bulgaria, Croatia, Czech
3682 Republic, Denmark, Estonia, Finland, France, Germany, Greece, Hungary,
3683 Iceland, Ireland, Italy, Latvia, Lithuania, Netherlands, Norway, Poland,
3684 Portugal, Romania, Russia, Slovakia, Slovenia, Spain, Sweden, Switzerland,
3685 Turkey, Ukraine, United Kingdom
3686
3687 =item North America
3688
3689 Canada, Alberta, Manitoba, Nova Scotia, Ontario, Mexico, United States,
3690 Alabama, California, Colorado, Delaware, District of Columbia, Florida,
3691 Indiana, Kentucky, Massachusetts, Michigan, Nevada, New Jersey, New York,
3692 North Carolina, Oklahoma, Oregon, Pennsylvania, Tennessee, Texas, Utah,
3693 Virginia, Washington, Wisconsin
3694
3695 =item Oceania
3696
3697 Australia, New Zealand, United States
3698
3699 =item South America
3700
3701 Argentina, Brazil, Chile
3702
3703 =item RSYNC Mirrors
3704
3705 =back
3706
3707 =item Modules: Creation, Use, and Abuse
3708
3709 =over 4
3710
3711 =item Guidelines for Module Creation
3712
3713 =item Guidelines for Converting Perl 4 Library Scripts into Modules
3714
3715 =item Guidelines for Reusing Application Code
3716
3717 =back
3718
3719 =item NOTE
3720
3721 =back
3722
3723 =head2 perlmodstyle - Perl module style guide
3724
3725 =over 4
3726
3727 =item INTRODUCTION
3728
3729 =item QUICK CHECKLIST
3730
3731 =over 4
3732
3733 =item Before you start
3734
3735 =item The API
3736
3737 =item Stability
3738
3739 =item Documentation
3740
3741 =item Release considerations
3742
3743 =back
3744
3745 =item BEFORE YOU START WRITING A MODULE
3746
3747 =over 4
3748
3749 =item Has it been done before?
3750
3751 =item Do one thing and do it well
3752
3753 =item What's in a name?
3754
3755 =back
3756
3757 =item DESIGNING AND WRITING YOUR MODULE
3758
3759 =over 4
3760
3761 =item To OO or not to OO?
3762
3763 =item Designing your API
3764
3765 Write simple routines to do simple things, Separate functionality from
3766 output, Provide sensible shortcuts and defaults, Naming conventions,
3767 Parameter passing
3768
3769 =item Strictness and warnings
3770
3771 =item Backwards compatibility
3772
3773 =item Error handling and messages
3774
3775 =back
3776
3777 =item DOCUMENTING YOUR MODULE
3778
3779 =over 4
3780
3781 =item POD
3782
3783 =item README, INSTALL, release notes, changelogs
3784
3785 perl Makefile.PL, make, make test, make install, perl Build.PL, perl Build,
3786 perl Build test, perl Build install
3787
3788 =back
3789
3790 =item RELEASE CONSIDERATIONS
3791
3792 =over 4
3793
3794 =item Version numbering
3795
3796 =item Pre-requisites
3797
3798 =item Testing
3799
3800 =item Packaging
3801
3802 =item Licensing
3803
3804 =back
3805
3806 =item COMMON PITFALLS
3807
3808 =over 4
3809
3810 =item Reinventing the wheel
3811
3812 =item Trying to do too much
3813
3814 =item Inappropriate documentation
3815
3816 =back
3817
3818 =item SEE ALSO
3819
3820 L<perlstyle>, L<perlnewmod>, L<perlpod>, L<podchecker>, Packaging Tools,
3821 Testing tools, http://pause.perl.org/, Any good book on software
3822 engineering
3823
3824 =item AUTHOR
3825
3826 =back
3827
3828 =head2 perlmodinstall - Installing CPAN Modules
3829
3830 =over 4
3831
3832 =item DESCRIPTION
3833
3834 =over 4
3835
3836 =item PREAMBLE
3837
3838 B<DECOMPRESS> the file, B<UNPACK> the file into a directory, B<BUILD> the
3839 module (sometimes unnecessary), B<INSTALL> the module
3840
3841 =back
3842
3843 =item PORTABILITY
3844
3845 =item HEY
3846
3847 =item AUTHOR
3848
3849 =item COPYRIGHT
3850
3851 =back
3852
3853 =head2 perlnewmod - preparing a new module for distribution
3854
3855 =over 4
3856
3857 =item DESCRIPTION
3858
3859 =over 4
3860
3861 =item Warning
3862
3863 =item What should I make into a module?
3864
3865 =item Step-by-step: Preparing the ground
3866
3867 Look around, Check it's new, Discuss the need, Choose a name, Check again
3868
3869 =item Step-by-step: Making the module
3870
3871 Start with F<h2xs>, Use L<strict|strict> and L<warnings|warnings>, Use
3872 L<Carp|Carp>, Use L<Exporter|Exporter> - wisely!, Use L<plain old
3873 documentation|perlpod>, Write tests, Write the README
3874
3875 =item Step-by-step: Distributing your module
3876
3877 Get a CPAN user ID, C<perl Makefile.PL; make test; make dist>, Upload the
3878 tarball, Announce to the modules list, Announce to clpa, Fix bugs!
3879
3880 =back
3881
3882 =item AUTHOR
3883
3884 =item SEE ALSO
3885
3886 =back
3887
3888 =head2 perlutil - utilities packaged with the Perl distribution
3889
3890 =over 4
3891
3892 =item DESCRIPTION
3893
3894 =over 4
3895
3896 =item DOCUMENTATION
3897
3898 L<perldoc|perldoc>, L<pod2man|pod2man> and L<pod2text|pod2text>,
3899 L<pod2html|pod2html> and L<pod2latex|pod2latex>, L<pod2usage|pod2usage>,
3900 L<podselect|podselect>, L<podchecker|podchecker>, L<splain|splain>,
3901 L<roffitall|roffitall>
3902
3903 =item CONVERTORS
3904
3905 L<a2p|a2p>, L<s2p|s2p>, L<find2perl|find2perl>
3906
3907 =item Administration
3908
3909 L<libnetcfg|libnetcfg>
3910
3911 =item Development
3912
3913 L<perlbug|perlbug>, L<h2ph|h2ph>, L<c2ph|c2ph> and L<pstruct|pstruct>,
3914 L<h2xs|h2xs>, L<dprofpp|dprofpp>, L<perlcc|perlcc>
3915
3916 =item SEE ALSO
3917
3918 =back
3919
3920 =back
3921
3922 =head2 perlcompile - Introduction to the Perl Compiler-Translator 
3923
3924 =over 4
3925
3926 =item DESCRIPTION
3927
3928 =over 4
3929
3930 =item Layout
3931
3932 B::Bytecode, B::C, B::CC, B::Lint, B::Deparse, B::Xref
3933
3934 =back
3935
3936 =item Using The Back Ends
3937
3938 =over 4
3939
3940 =item The Cross Referencing Back End
3941
3942 i, &, s, r
3943
3944 =item The Decompiling Back End
3945
3946 =item The Lint Back End
3947
3948 =item The Simple C Back End
3949
3950 =item The Bytecode Back End
3951
3952 =item The Optimized C Back End
3953
3954 =back
3955
3956 =item Module List for the Compiler Suite
3957
3958 B, O, B::Asmdata, B::Assembler, B::Bblock, B::Bytecode, B::C, B::CC,
3959 B::Concise, B::Debug, B::Deparse, B::Disassembler, B::Lint, B::Showlex,
3960 B::Stackobj, B::Stash, B::Terse, B::Xref
3961
3962 =item KNOWN PROBLEMS
3963
3964 =item AUTHOR
3965
3966 =back
3967
3968 =head2 perlfilter - Source Filters
3969
3970 =over 4
3971
3972 =item DESCRIPTION
3973
3974 =item CONCEPTS
3975
3976 =item USING FILTERS
3977
3978 =item WRITING A SOURCE FILTER
3979
3980 =item WRITING A SOURCE FILTER IN C
3981
3982 B<Decryption Filters>
3983
3984 =item CREATING A SOURCE FILTER AS A SEPARATE EXECUTABLE
3985
3986 =item WRITING A SOURCE FILTER IN PERL
3987
3988 =item USING CONTEXT: THE DEBUG FILTER
3989
3990 =item CONCLUSION
3991
3992 =item THINGS TO LOOK OUT FOR
3993
3994 Some Filters Clobber the C<DATA> Handle
3995
3996 =item REQUIREMENTS
3997
3998 =item AUTHOR
3999
4000 =item Copyrights
4001
4002 =back
4003
4004 =head2 perlembed - how to embed perl in your C program
4005
4006 =over 4
4007
4008 =item DESCRIPTION
4009
4010 =over 4
4011
4012 =item PREAMBLE
4013
4014 B<Use C from Perl?>, B<Use a Unix program from Perl?>, B<Use Perl from
4015 Perl?>, B<Use C from C?>, B<Use Perl from C?>
4016
4017 =item ROADMAP
4018
4019 =item Compiling your C program
4020
4021 =item Adding a Perl interpreter to your C program
4022
4023 =item Calling a Perl subroutine from your C program
4024
4025 =item Evaluating a Perl statement from your C program
4026
4027 =item Performing Perl pattern matches and substitutions from your C program
4028
4029 =item Fiddling with the Perl stack from your C program
4030
4031 =item Maintaining a persistent interpreter
4032
4033 =item Execution of END blocks
4034
4035 =item Maintaining multiple interpreter instances
4036
4037 =item Using Perl modules, which themselves use C libraries, from your C
4038 program
4039
4040 =back
4041
4042 =item Embedding Perl under Win32
4043
4044 =item Hiding Perl_
4045
4046 =item MORAL
4047
4048 =item AUTHOR
4049
4050 =item COPYRIGHT
4051
4052 =back
4053
4054 =head2 perldebguts - Guts of Perl debugging 
4055
4056 =over 4
4057
4058 =item DESCRIPTION
4059
4060 =item Debugger Internals
4061
4062 =over 4
4063
4064 =item Writing Your Own Debugger
4065
4066 =back
4067
4068 =item Frame Listing Output Examples
4069
4070 =item Debugging regular expressions
4071
4072 =over 4
4073
4074 =item Compile-time output
4075
4076 C<anchored> I<STRING> C<at> I<POS>, C<floating> I<STRING> C<at>
4077 I<POS1..POS2>, C<matching floating/anchored>, C<minlen>, C<stclass>
4078 I<TYPE>, C<noscan>, C<isall>, C<GPOS>, C<plus>, C<implicit>, C<with eval>,
4079 C<anchored(TYPE)>
4080
4081 =item Types of nodes
4082
4083 =item Run-time output
4084
4085 =back
4086
4087 =item Debugging Perl memory usage
4088
4089 =over 4
4090
4091 =item Using C<$ENV{PERL_DEBUG_MSTATS}>
4092
4093 C<buckets SMALLEST(APPROX)..GREATEST(APPROX)>, Free/Used, C<Total sbrk():
4094 SBRKed/SBRKs:CONTINUOUS>, C<pad: 0>, C<heads: 2192>, C<chain: 0>, C<tail:
4095 6144>
4096
4097 =item Example of using B<-DL> switch
4098
4099 C<717>, C<002>, C<054>, C<602>, C<702>, C<704>
4100
4101 =item B<-DL> details
4102
4103 C<!!!>, C<!!>, C<!>
4104
4105 =item Limitations of B<-DL> statistics
4106
4107 =back
4108
4109 =item SEE ALSO
4110
4111 =back
4112
4113 =head2 perlxstut, perlXStut - Tutorial for writing XSUBs
4114
4115 =over 4
4116
4117 =item DESCRIPTION
4118
4119 =item SPECIAL NOTES
4120
4121 =over 4
4122
4123 =item make
4124
4125 =item Version caveat
4126
4127 =item Dynamic Loading versus Static Loading
4128
4129 =back
4130
4131 =item TUTORIAL
4132
4133 =over 4
4134
4135 =item EXAMPLE 1
4136
4137 =item EXAMPLE 2
4138
4139 =item What has gone on?
4140
4141 =item Writing good test scripts
4142
4143 =item EXAMPLE 3
4144
4145 =item What's new here?
4146
4147 =item Input and Output Parameters
4148
4149 =item The XSUBPP Program
4150
4151 =item The TYPEMAP file
4152
4153 =item Warning about Output Arguments
4154
4155 =item EXAMPLE 4
4156
4157 =item What has happened here?
4158
4159 =item Anatomy of .xs file
4160
4161 =item Getting the fat out of XSUBs
4162
4163 =item More about XSUB arguments
4164
4165 =item The Argument Stack
4166
4167 =item Extending your Extension
4168
4169 =item Documenting your Extension
4170
4171 =item Installing your Extension
4172
4173 =item EXAMPLE 5
4174
4175 =item New Things in this Example
4176
4177 =item EXAMPLE 6
4178
4179 =item New Things in this Example
4180
4181 =item EXAMPLE 7 (Coming Soon)
4182
4183 =item EXAMPLE 8 (Coming Soon)
4184
4185 =item EXAMPLE 9 Passing open files to XSes
4186
4187 =item Troubleshooting these Examples
4188
4189 =back
4190
4191 =item See also
4192
4193 =item Author
4194
4195 =over 4
4196
4197 =item Last Changed
4198
4199 =back
4200
4201 =back
4202
4203 =head2 perlxs - XS language reference manual
4204
4205 =over 4
4206
4207 =item DESCRIPTION
4208
4209 =over 4
4210
4211 =item Introduction
4212
4213 =item On The Road
4214
4215 =item The Anatomy of an XSUB
4216
4217 =item The Argument Stack
4218
4219 =item The RETVAL Variable
4220
4221 =item The MODULE Keyword
4222
4223 =item The PACKAGE Keyword
4224
4225 =item The PREFIX Keyword
4226
4227 =item The OUTPUT: Keyword
4228
4229 =item The NO_OUTPUT Keyword
4230
4231 =item The CODE: Keyword
4232
4233 =item The INIT: Keyword
4234
4235 =item The NO_INIT Keyword
4236
4237 =item Initializing Function Parameters
4238
4239 =item Default Parameter Values
4240
4241 =item The PREINIT: Keyword
4242
4243 =item The SCOPE: Keyword
4244
4245 =item The INPUT: Keyword
4246
4247 =item The IN/OUTLIST/IN_OUTLIST/OUT/IN_OUT Keywords
4248
4249 =item The C<length(NAME)> Keyword
4250
4251 =item Variable-length Parameter Lists
4252
4253 =item The C_ARGS: Keyword
4254
4255 =item The PPCODE: Keyword
4256
4257 =item Returning Undef And Empty Lists
4258
4259 =item The REQUIRE: Keyword
4260
4261 =item The CLEANUP: Keyword
4262
4263 =item The POSTCALL: Keyword
4264
4265 =item The BOOT: Keyword
4266
4267 =item The VERSIONCHECK: Keyword
4268
4269 =item The PROTOTYPES: Keyword
4270
4271 =item The PROTOTYPE: Keyword
4272
4273 =item The ALIAS: Keyword
4274
4275 =item The OVERLOAD: Keyword
4276
4277 =item The FALLBACK: Keyword
4278
4279 =item The INTERFACE: Keyword
4280
4281 =item The INTERFACE_MACRO: Keyword
4282
4283 =item The INCLUDE: Keyword
4284
4285 =item The CASE: Keyword
4286
4287 =item The & Unary Operator
4288
4289 =item Inserting POD, Comments and C Preprocessor Directives
4290
4291 =item Using XS With C++
4292
4293 =item Interface Strategy
4294
4295 =item Perl Objects And C Structures
4296
4297 =item The Typemap
4298
4299 =item Safely Storing Static Data in XS
4300
4301 MY_CXT_KEY, typedef my_cxt_t, START_MY_CXT, MY_CXT_INIT, dMY_CXT, MY_CXT
4302
4303 =back
4304
4305 =item EXAMPLES
4306
4307 =item XS VERSION
4308
4309 =item AUTHOR
4310
4311 =back
4312
4313 =head2 perlclib - Internal replacements for standard C library functions
4314
4315 =over 4
4316
4317 =item DESCRIPTION
4318
4319 =over 4
4320
4321 =item Conventions
4322
4323 C<t>, C<p>, C<n>, C<s>
4324
4325 =item File Operations
4326
4327 =item File Input and Output
4328
4329 =item File Positioning
4330
4331 =item Memory Management and String Handling
4332
4333 =item Character Class Tests
4334
4335 =item F<stdlib.h> functions
4336
4337 =item Miscellaneous functions
4338
4339 =back
4340
4341 =item SEE ALSO
4342
4343 =back
4344
4345 =head2 perlguts - Introduction to the Perl API
4346
4347 =over 4
4348
4349 =item DESCRIPTION
4350
4351 =item Variables
4352
4353 =over 4
4354
4355 =item Datatypes
4356
4357 =item What is an "IV"?
4358
4359 =item Working with SVs
4360
4361 =item Offsets
4362
4363 =item What's Really Stored in an SV?
4364
4365 =item Working with AVs
4366
4367 =item Working with HVs
4368
4369 =item Hash API Extensions
4370
4371 =item AVs, HVs and undefined values
4372
4373 =item References
4374
4375 =item Blessed References and Class Objects
4376
4377 =item Creating New Variables
4378
4379 GV_ADDMULTI, GV_ADDWARN
4380
4381 =item Reference Counts and Mortality
4382
4383 =item Stashes and Globs
4384
4385 =item Double-Typed SVs
4386
4387 =item Magic Variables
4388
4389 =item Assigning Magic
4390
4391 =item Magic Virtual Tables
4392
4393 =item Finding Magic
4394
4395 =item Understanding the Magic of Tied Hashes and Arrays
4396
4397 =item Localizing changes
4398
4399 C<SAVEINT(int i)>, C<SAVEIV(IV i)>, C<SAVEI32(I32 i)>, C<SAVELONG(long i)>,
4400 C<SAVESPTR(s)>, C<SAVEPPTR(p)>, C<SAVEFREESV(SV *sv)>, C<SAVEMORTALIZESV(SV
4401 *sv)>, C<SAVEFREEOP(OP *op)>, C<SAVEFREEPV(p)>, C<SAVECLEARSV(SV *sv)>,
4402 C<SAVEDELETE(HV *hv, char *key, I32 length)>,
4403 C<SAVEDESTRUCTOR(DESTRUCTORFUNC_NOCONTEXT_t f, void *p)>,
4404 C<SAVEDESTRUCTOR_X(DESTRUCTORFUNC_t f, void *p)>, C<SAVESTACK_POS()>, C<SV*
4405 save_scalar(GV *gv)>, C<AV* save_ary(GV *gv)>, C<HV* save_hash(GV *gv)>,
4406 C<void save_item(SV *item)>, C<void save_list(SV **sarg, I32 maxsarg)>,
4407 C<SV* save_svref(SV **sptr)>, C<void save_aptr(AV **aptr)>, C<void
4408 save_hptr(HV **hptr)>
4409
4410 =back
4411
4412 =item Subroutines
4413
4414 =over 4
4415
4416 =item XSUBs and the Argument Stack
4417
4418 =item Calling Perl Routines from within C Programs
4419
4420 =item Memory Allocation
4421
4422 =item PerlIO
4423
4424 =item Putting a C value on Perl stack
4425
4426 =item Scratchpads
4427
4428 =item Scratchpads and recursion
4429
4430 =back
4431
4432 =item Compiled code
4433
4434 =over 4
4435
4436 =item Code tree
4437
4438 =item Examining the tree
4439
4440 =item Compile pass 1: check routines
4441
4442 =item Compile pass 1a: constant folding
4443
4444 =item Compile pass 2: context propagation
4445
4446 =item Compile pass 3: peephole optimization
4447
4448 =item Pluggable runops
4449
4450 =back
4451
4452 =item Examining internal data structures with the C<dump> functions
4453
4454 =item How multiple interpreters and concurrency are supported
4455
4456 =over 4
4457
4458 =item Background and PERL_IMPLICIT_CONTEXT
4459
4460 =item So what happened to dTHR?
4461
4462 =item How do I use all this in extensions?
4463
4464 =item Should I do anything special if I call perl from multiple threads?
4465
4466 =item Future Plans and PERL_IMPLICIT_SYS
4467
4468 =back
4469
4470 =item Internal Functions
4471
4472 A, p, d, s, n, r, f, M, o, j, x
4473
4474 =over 4
4475
4476 =item Formatted Printing of IVs, UVs, and NVs
4477
4478 =item Pointer-To-Integer and Integer-To-Pointer
4479
4480 =item Source Documentation
4481
4482 =back
4483
4484 =item Unicode Support
4485
4486 =over 4
4487
4488 =item What B<is> Unicode, anyway?
4489
4490 =item How can I recognise a UTF-8 string?
4491
4492 =item How does UTF-8 represent Unicode characters?
4493
4494 =item How does Perl store UTF-8 strings?
4495
4496 =item How do I convert a string to UTF-8?
4497
4498 =item Is there anything else I need to know?
4499
4500 =back
4501
4502 =item Custom Operators
4503
4504 =item AUTHORS
4505
4506 =item SEE ALSO
4507
4508 =back
4509
4510 =head2 perlcall - Perl calling conventions from C
4511
4512 =over 4
4513
4514 =item DESCRIPTION
4515
4516 An Error Handler, An Event Driven Program
4517
4518 =item THE CALL_ FUNCTIONS
4519
4520 call_sv, call_pv, call_method, call_argv
4521
4522 =item FLAG VALUES
4523
4524 =over 4
4525
4526 =item  G_VOID
4527
4528 =item  G_SCALAR
4529
4530 =item G_ARRAY
4531
4532 =item G_DISCARD
4533
4534 =item G_NOARGS
4535
4536 =item G_EVAL
4537
4538 =item G_KEEPERR
4539
4540 =item Determining the Context
4541
4542 =back
4543
4544 =item KNOWN PROBLEMS
4545
4546 =item EXAMPLES
4547
4548 =over 4
4549
4550 =item No Parameters, Nothing returned
4551
4552 =item Passing Parameters
4553
4554 =item Returning a Scalar
4555
4556 =item Returning a list of values
4557
4558 =item Returning a list in a scalar context
4559
4560 =item Returning Data from Perl via the parameter list
4561
4562 =item Using G_EVAL
4563
4564 =item Using G_KEEPERR
4565
4566 =item Using call_sv
4567
4568 =item Using call_argv
4569
4570 =item Using call_method
4571
4572 =item Using GIMME_V
4573
4574 =item Using Perl to dispose of temporaries
4575
4576 =item Strategies for storing Callback Context Information
4577
4578 1. Ignore the problem - Allow only 1 callback, 2. Create a sequence of
4579 callbacks - hard wired limit, 3. Use a parameter to map to the Perl
4580 callback
4581
4582 =item Alternate Stack Manipulation
4583
4584 =item Creating and calling an anonymous subroutine in C
4585
4586 =back
4587
4588 =item SEE ALSO
4589
4590 =item AUTHOR
4591
4592 =item DATE
4593
4594 =back
4595
4596 =head2 perlapi - autogenerated documentation for the perl public API
4597
4598 =over 4
4599
4600 =item DESCRIPTION
4601
4602 =item "Gimme" Values
4603
4604 GIMME, GIMME_V, G_ARRAY, G_DISCARD, G_EVAL, G_NOARGS, G_SCALAR, G_VOID
4605
4606 =item Array Manipulation Functions
4607
4608 AvFILL, av_clear, av_delete, av_exists, av_extend, av_fetch, av_fill,
4609 av_len, av_make, av_pop, av_push, av_shift, av_store, av_undef, av_unshift,
4610 get_av, newAV, Nullav, sortsv
4611
4612 =item Callback Functions
4613
4614 call_argv, call_method, call_pv, call_sv, ENTER, eval_pv, eval_sv,
4615 FREETMPS, LEAVE, SAVETMPS
4616
4617 =item Character classes
4618
4619 isALNUM, isALPHA, isDIGIT, isLOWER, isSPACE, isUPPER, toLOWER, toUPPER
4620
4621 =item Cloning an interpreter
4622
4623 perl_clone
4624
4625 =item CV Manipulation Functions
4626
4627 CvSTASH, get_cv, Nullcv
4628
4629 =item Embedding Functions
4630
4631 cv_undef, load_module, nothreadhook, perl_alloc, perl_construct,
4632 perl_destruct, perl_free, perl_parse, perl_run, require_pv
4633
4634 =item Functions in file pp_pack.c
4635
4636 packlist, pack_cat, unpackstring, unpack_str
4637
4638 =item Global Variables
4639
4640 PL_modglobal, PL_na, PL_sv_no, PL_sv_undef, PL_sv_yes
4641
4642 =item GV Functions
4643
4644 GvSV, gv_fetchmeth, gv_fetchmethod, gv_fetchmethod_autoload,
4645 gv_fetchmeth_autoload, gv_stashpv, gv_stashsv
4646
4647 =item Handy Values
4648
4649 HEf_SVKEY, Nullch, Nullsv
4650
4651 =item Hash Manipulation Functions
4652
4653 get_hv, HeHASH, HeKEY, HeKLEN, HePV, HeSVKEY, HeSVKEY_force, HeSVKEY_set,
4654 HeVAL, HvNAME, hv_clear, hv_delete, hv_delete_ent, hv_exists,
4655 hv_exists_ent, hv_fetch, hv_fetch_ent, hv_iterinit, hv_iterkey,
4656 hv_iterkeysv, hv_iternext, hv_iternextsv, hv_iternext_flags, hv_iterval,
4657 hv_magic, hv_store, hv_store_ent, hv_undef, newHV, Nullhv
4658
4659 =item Magical Functions
4660
4661 mg_clear, mg_copy, mg_find, mg_free, mg_get, mg_length, mg_magical, mg_set,
4662 SvGETMAGIC, SvLOCK, SvSETMAGIC, SvSetMagicSV, SvSetMagicSV_nosteal,
4663 SvSetSV, SvSetSV_nosteal, SvSHARE
4664
4665 =item Memory Management
4666
4667 Copy, Move, New, Newc, NEWSV, Newz, Poison, Renew, Renewc, Safefree,
4668 savepv, savepvn, savesharedpv, StructCopy, Zero
4669
4670 =item Miscellaneous Functions
4671
4672 fbm_compile, fbm_instr, form, getcwd_sv, new_version, scan_version, strEQ,
4673 strGE, strGT, strLE, strLT, strNE, strnEQ, strnNE, sv_nolocking,
4674 sv_nosharing, sv_nounlocking, upg_version, vcmp, vnumify, vstringify
4675
4676 =item Numeric functions
4677
4678 grok_bin, grok_hex, grok_number, grok_numeric_radix, grok_oct, scan_bin,
4679 scan_hex, scan_oct
4680
4681 =item Optree Manipulation Functions
4682
4683 cv_const_sv, newCONSTSUB, newXS
4684
4685 =item Pad Data Structures
4686
4687 pad_sv
4688
4689 =item Stack Manipulation Macros
4690
4691 dMARK, dORIGMARK, dSP, EXTEND, MARK, ORIGMARK, POPi, POPl, POPn, POPp,
4692 POPpbytex, POPpx, POPs, PUSHi, PUSHMARK, PUSHn, PUSHp, PUSHs, PUSHu,
4693 PUTBACK, SP, SPAGAIN, XPUSHi, XPUSHn, XPUSHp, XPUSHs, XPUSHu, XSRETURN,
4694 XSRETURN_IV, XSRETURN_NO, XSRETURN_NV, XSRETURN_PV, XSRETURN_UNDEF,
4695 XSRETURN_UV, XSRETURN_YES, XST_mIV, XST_mNO, XST_mNV, XST_mPV, XST_mUNDEF,
4696 XST_mYES
4697
4698 =item SV Flags
4699
4700 svtype, SVt_IV, SVt_NV, SVt_PV, SVt_PVAV, SVt_PVCV, SVt_PVHV, SVt_PVMG
4701
4702 =item SV Manipulation Functions
4703
4704 get_sv, looks_like_number, newRV_inc, newRV_noinc, newSV, newSViv, newSVnv,
4705 newSVpv, newSVpvf, newSVpvn, newSVpvn_share, newSVrv, newSVsv, newSVuv,
4706 SvCUR, SvCUR_set, SvEND, SvGROW, SvIOK, SvIOKp, SvIOK_notUV, SvIOK_off,
4707 SvIOK_on, SvIOK_only, SvIOK_only_UV, SvIOK_UV, SvIsCOW,
4708 SvIsCOW_shared_hash, SvIV, SvIVX, SvIVx, SvLEN, SvNIOK, SvNIOKp,
4709 SvNIOK_off, SvNOK, SvNOKp, SvNOK_off, SvNOK_on, SvNOK_only, SvNV, SvNVx,
4710 SvNVX, SvOK, SvOOK, SvPOK, SvPOKp, SvPOK_off, SvPOK_on, SvPOK_only,
4711 SvPOK_only_UTF8, SvPV, SvPVbyte, SvPVbytex, SvPVbytex_force,
4712 SvPVbyte_force, SvPVbyte_nolen, SvPVutf8, SvPVutf8x, SvPVutf8x_force,
4713 SvPVutf8_force, SvPVutf8_nolen, SvPVX, SvPVx, SvPV_force, SvPV_force_nomg,
4714 SvPV_nolen, SvREFCNT, SvREFCNT_dec, SvREFCNT_inc, SvROK, SvROK_off,
4715 SvROK_on, SvRV, SvSTASH, SvTAINT, SvTAINTED, SvTAINTED_off, SvTAINTED_on,
4716 SvTRUE, SvTYPE, SvUNLOCK, SvUOK, SvUPGRADE, SvUTF8, SvUTF8_off, SvUTF8_on,
4717 SvUV, SvUVX, SvUVx, SvVOK, sv_2bool, sv_2cv, sv_2io, sv_2iv, sv_2mortal,
4718 sv_2nv, sv_2pvbyte, sv_2pvbyte_nolen, sv_2pvutf8, sv_2pvutf8_nolen,
4719 sv_2pv_flags, sv_2pv_nolen, sv_2uv, sv_backoff, sv_bless, sv_catpv,
4720 sv_catpvf, sv_catpvf_mg, sv_catpvn, sv_catpvn_flags, sv_catpvn_mg,
4721 sv_catpv_mg, sv_catsv, sv_catsv_flags, sv_catsv_mg, sv_chop, sv_clear,
4722 sv_cmp, sv_cmp_locale, sv_collxfrm, sv_copypv, sv_dec, sv_derived_from,
4723 sv_eq, sv_force_normal, sv_force_normal_flags, sv_free, sv_gets, sv_grow,
4724 sv_inc, sv_insert, sv_isa, sv_isobject, sv_iv, sv_len, sv_len_utf8,
4725 sv_magic, sv_magicext, sv_mortalcopy, sv_newmortal, sv_newref, sv_nv,
4726 sv_pos_b2u, sv_pos_u2b, sv_pv, sv_pvbyte, sv_pvbyten, sv_pvbyten_force,
4727 sv_pvn, sv_pvn_force, sv_pvn_force_flags, sv_pvutf8, sv_pvutf8n,
4728 sv_pvutf8n_force, sv_reftype, sv_replace, sv_report_used, sv_reset,
4729 sv_rvweaken, sv_setiv, sv_setiv_mg, sv_setnv, sv_setnv_mg, sv_setpv,
4730 sv_setpvf, sv_setpvf_mg, sv_setpviv, sv_setpviv_mg, sv_setpvn,
4731 sv_setpvn_mg, sv_setpv_mg, sv_setref_iv, sv_setref_nv, sv_setref_pv,
4732 sv_setref_pvn, sv_setref_uv, sv_setsv, sv_setsv_flags, sv_setsv_mg,
4733 sv_setuv, sv_setuv_mg, sv_taint, sv_tainted, sv_true, sv_unmagic, sv_unref,
4734 sv_unref_flags, sv_untaint, sv_upgrade, sv_usepvn, sv_usepvn_mg,
4735 sv_utf8_decode, sv_utf8_downgrade, sv_utf8_encode, sv_utf8_upgrade,
4736 sv_utf8_upgrade_flags, sv_uv, sv_vcatpvfn, sv_vsetpvfn
4737
4738 =item Unicode Support
4739
4740 bytes_from_utf8, bytes_to_utf8, ibcmp_utf8, is_utf8_char, is_utf8_string,
4741 is_utf8_string_loc, pv_uni_display, sv_cat_decode, sv_recode_to_utf8,
4742 sv_uni_display, to_utf8_case, to_utf8_fold, to_utf8_lower, to_utf8_title,
4743 to_utf8_upper, utf8n_to_uvchr, utf8n_to_uvuni, utf8_distance, utf8_hop,
4744 utf8_length, utf8_to_bytes, utf8_to_uvchr, utf8_to_uvuni, uvchr_to_utf8,
4745 uvuni_to_utf8_flags
4746
4747 =item Variables created by C<xsubpp> and C<xsubpp> internal functions
4748
4749 ax, CLASS, dAX, dITEMS, dXSARGS, dXSI32, items, ix, newXSproto, RETVAL, ST,
4750 THIS, XS, XSRETURN_EMPTY, XS_VERSION, XS_VERSION_BOOTCHECK
4751
4752 =item Warning and Dieing
4753
4754 croak, warn
4755
4756 =item AUTHORS
4757
4758 =item SEE ALSO
4759
4760 =back
4761
4762 =head2 perlintern - autogenerated documentation of purely B<internal>
4763                  Perl functions
4764
4765 =over 4
4766
4767 =item DESCRIPTION
4768
4769 =item CV reference counts and CvOUTSIDE
4770
4771 CvWEAKOUTSIDE
4772
4773 =item Functions in file pad.h
4774
4775 CX_CURPAD_SAVE, CX_CURPAD_SV, PAD_BASE_SV, PAD_CLONE_VARS,
4776 PAD_COMPNAME_FLAGS, PAD_COMPNAME_GEN, PAD_COMPNAME_OURSTASH,
4777 PAD_COMPNAME_PV, PAD_COMPNAME_TYPE, PAD_DUP, PAD_RESTORE_LOCAL,
4778 PAD_SAVE_LOCAL, PAD_SAVE_SETNULLPAD, PAD_SETSV, PAD_SET_CUR, PAD_SV,
4779 PAD_SVl, SAVECLEARSV, SAVECOMPPAD, SAVEPADSV
4780
4781 =item Functions in file pp_ctl.c
4782
4783 find_runcv
4784
4785 =item Global Variables
4786
4787 PL_DBsingle, PL_DBsub, PL_DBtrace, PL_dowarn, PL_last_in_gv, PL_ofs_sv,
4788 PL_rs
4789
4790 =item GV Functions
4791
4792 is_gv_magical
4793
4794 =item IO Functions
4795
4796 start_glob
4797
4798 =item Pad Data Structures
4799
4800 CvPADLIST, cv_clone, cv_dump, do_dump_pad, intro_my, pad_add_anon,
4801 pad_add_name, pad_alloc, pad_block_start, pad_check_dup, pad_findlex,
4802 pad_findmy, pad_fixup_inner_anons, pad_free, pad_leavemy, pad_new,
4803 pad_push, pad_reset, pad_setsv, pad_swipe, pad_tidy, pad_undef
4804
4805 =item Stack Manipulation Macros
4806
4807 djSP, LVRET
4808
4809 =item SV Manipulation Functions
4810
4811 report_uninit, sv_add_arena, sv_clean_all, sv_clean_objs, sv_free_arenas
4812
4813 =item AUTHORS
4814
4815 =item SEE ALSO
4816
4817 =back
4818
4819 =head2 perliol - C API for Perl's implementation of IO in Layers.
4820
4821 =over 4
4822
4823 =item SYNOPSIS
4824
4825 =item DESCRIPTION
4826
4827 =over 4
4828
4829 =item History and Background
4830
4831 =item Basic Structure
4832
4833 =item Layers vs Disciplines
4834
4835 =item Data Structures
4836
4837 =item Functions and Attributes
4838
4839 =item Per-instance Data
4840
4841 =item Layers in action.
4842
4843 =item Per-instance flag bits
4844
4845 PERLIO_F_EOF, PERLIO_F_CANWRITE,  PERLIO_F_CANREAD, PERLIO_F_ERROR,
4846 PERLIO_F_TRUNCATE, PERLIO_F_APPEND, PERLIO_F_CRLF, PERLIO_F_UTF8,
4847 PERLIO_F_UNBUF, PERLIO_F_WRBUF, PERLIO_F_RDBUF, PERLIO_F_LINEBUF,
4848 PERLIO_F_TEMP, PERLIO_F_OPEN, PERLIO_F_FASTGETS
4849
4850 =item Methods in Detail
4851
4852 fsize, name, size, kind, PERLIO_K_BUFFERED, PERLIO_K_RAW, PERLIO_K_CANCRLF,
4853 PERLIO_K_FASTGETS, PERLIO_K_MULTIARG, Pushed, Popped, Open, Binmode,
4854 Getarg, Fileno, Dup, Read, Write, Seek, Tell, Close, Flush, Fill, Eof,
4855 Error,  Clearerr, Setlinebuf, Get_base, Get_bufsiz, Get_ptr, Get_cnt,
4856 Set_ptrcnt
4857
4858 =item Utilities
4859
4860 =item Implementing PerlIO Layers
4861
4862 C implementations, Perl implementations
4863
4864 =item Core Layers
4865
4866 "unix", "perlio", "stdio", "crlf", "mmap", "pending", "raw", "utf8"
4867
4868 =item Extension Layers
4869
4870 ":encoding", ":scalar", ":via"
4871
4872 =back
4873
4874 =item TODO
4875
4876 =back
4877
4878 =head2 perlapio - perl's IO abstraction interface.
4879
4880 =over 4
4881
4882 =item SYNOPSIS
4883
4884 =item DESCRIPTION
4885
4886 1. USE_STDIO, 2. USE_SFIO, 3. USE_PERLIO, B<PerlIO_stdin()>,
4887 B<PerlIO_stdout()>, B<PerlIO_stderr()>, B<PerlIO_open(path, mode)>,
4888 B<PerlIO_fdopen(fd,mode)>, B<PerlIO_reopen(path,mode,f)>,
4889 B<PerlIO_printf(f,fmt,...)>, B<PerlIO_vprintf(f,fmt,a)>,
4890 B<PerlIO_stdoutf(fmt,...)>, B<PerlIO_read(f,buf,count)>,
4891 B<PerlIO_write(f,buf,count)>, B<PerlIO_close(f)>, B<PerlIO_puts(f,s)>,
4892 B<PerlIO_putc(f,c)>, B<PerlIO_ungetc(f,c)>, B<PerlIO_getc(f)>,
4893 B<PerlIO_eof(f)>, B<PerlIO_error(f)>, B<PerlIO_fileno(f)>,
4894 B<PerlIO_clearerr(f)>, B<PerlIO_flush(f)>, B<PerlIO_seek(f,offset,whence)>,
4895 B<PerlIO_tell(f)>, B<PerlIO_getpos(f,p)>, B<PerlIO_setpos(f,p)>,
4896 B<PerlIO_rewind(f)>, B<PerlIO_tmpfile()>, B<PerlIO_setlinebuf(f)>
4897
4898 =over 4
4899
4900 =item Co-existence with stdio
4901
4902 B<PerlIO_importFILE(f,mode)>, B<PerlIO_exportFILE(f,mode)>,
4903 B<PerlIO_releaseFILE(p,f)>, B<PerlIO_findFILE(f)>
4904
4905 =item "Fast gets" Functions
4906
4907 B<PerlIO_fast_gets(f)>, B<PerlIO_has_cntptr(f)>, B<PerlIO_get_cnt(f)>,
4908 B<PerlIO_get_ptr(f)>, B<PerlIO_set_ptrcnt(f,p,c)>, B<PerlIO_canset_cnt(f)>,
4909 B<PerlIO_set_cnt(f,c)>, B<PerlIO_has_base(f)>, B<PerlIO_get_base(f)>,
4910 B<PerlIO_get_bufsiz(f)>
4911
4912 =item Other Functions
4913
4914 PerlIO_apply_layers(f,mode,layers), PerlIO_binmode(f,ptype,imode,layers),
4915 'E<lt>' read, 'E<gt>' write, '+' read/write, PerlIO_debug(fmt,...)
4916
4917 =back
4918
4919 =back
4920
4921 =head2 perlhack - How to hack at the Perl internals
4922
4923 =over 4
4924
4925 =item DESCRIPTION
4926
4927 Does concept match the general goals of Perl?, Where is the
4928 implementation?, Backwards compatibility, Could it be a module instead?, Is
4929 the feature generic enough?, Does it potentially introduce new bugs?, Does
4930 it preclude other desirable features?, Is the implementation robust?, Is
4931 the implementation generic enough to be portable?, Is the implementation
4932 tested?, Is there enough documentation?, Is there another way to do it?,
4933 Does it create too much work?, Patches speak louder than words
4934
4935 =over 4
4936
4937 =item Keeping in sync
4938
4939 rsync'ing the source tree, Using rsync over the LAN, Using pushing over the
4940 NFS, rsync'ing the patches
4941
4942 =item Why rsync the source tree
4943
4944 It's easier to rsync the source tree, It's more reliable
4945
4946 =item Why rsync the patches
4947
4948 It's easier to rsync the patches, It's a good reference, Finding a start
4949 point, Finding how to fix a bug, Finding the source of misbehaviour
4950
4951 =item Perlbug administration
4952
4953 =item Submitting patches
4954
4955 L<perlguts>, L<perlxstut> and L<perlxs>, L<perlapi>,
4956 F<Porting/pumpkin.pod>, The perl5-porters FAQ
4957
4958 =item Finding Your Way Around
4959
4960 Core modules, Tests, Documentation, Configure, Interpreter
4961
4962 =item Elements of the interpreter
4963
4964 Startup, Parsing, Optimization, Running
4965
4966 =item Internal Variable Types
4967
4968 =item Op Trees
4969
4970 =item Stacks
4971
4972 Argument stack, Mark stack, Save stack
4973
4974 =item Millions of Macros
4975
4976 =item The .i Targets
4977
4978 =item Poking at Perl
4979
4980 =item Using a source-level debugger
4981
4982 run [args], break function_name, break source.c:xxx, step, next, continue,
4983 finish, 'enter', print
4984
4985 =item gdb macro support
4986
4987 =item Dumping Perl Data Structures
4988
4989 =item Patching
4990
4991 =item Patching a core module
4992
4993 =item Adding a new function to the core
4994
4995 =item Writing a test
4996
4997 F<t/base/>, F<t/cmd/>, F<t/comp/>, F<t/io/>, F<t/lib/>, F<t/op/>,
4998 F<t/pod/>, F<t/run/>, F<t/uni/>, F<t/win32/>, F<t/x2p>, t/base t/comp,
4999 t/cmd t/run t/io t/op, t/lib ext lib
5000
5001 =item Special Make Test Targets
5002
5003 coretest, test.deparse, minitest, test.valgrind check.valgrind
5004 utest.valgrind ucheck.valgrind, test.third check.third utest.third
5005 ucheck.third, test.torture torturetest, utest ucheck test.utf8 check.utf8,
5006 test_harness
5007
5008 =item Running tests by hand
5009
5010 PERL_CORE=1, PERL_DESTRUCT_LEVEL=2, PERL, PERL_SKIP_TTY_TEST
5011
5012 =back
5013
5014 =item EXTERNAL TOOLS FOR DEBUGGING PERL
5015
5016 =over 4
5017
5018 =item Rational Software's Purify
5019
5020 =item Purify on Unix
5021
5022 -Accflags=-DPURIFY, -Doptimize='-g', -Uusemymalloc, -Dusemultiplicity
5023
5024 =item Purify on NT
5025
5026 DEFINES, USE_MULTI = define, #PERL_MALLOC = define, CFG = Debug
5027
5028 =item valgrind
5029
5030 =item Compaq's/Digital's/HP's Third Degree
5031
5032 =item PERL_DESTRUCT_LEVEL
5033
5034 =item Profiling
5035
5036 =item Gprof Profiling
5037
5038 -a, -b, -e routine, -f routine, -s, -z
5039
5040 =item GCC gcov Profiling
5041
5042 =item Pixie Profiling
5043
5044 -h, -l, -p[rocedures], -h[eavy], -i[nvocations], -l[ines], -testcoverage,
5045 -z[ero]
5046
5047 =item Miscellaneous tricks
5048
5049 =item CONCLUSION
5050
5051 I<The Road goes ever on and on, down from the door where it began.>
5052
5053 =back
5054
5055 =item AUTHOR
5056
5057 =back
5058
5059 =head2 perlbook - Perl book information
5060
5061 =over 4
5062
5063 =item DESCRIPTION
5064
5065 =back
5066
5067 =head2 perltodo - Perl TO-DO List
5068
5069 =over 4
5070
5071 =item DESCRIPTION
5072
5073 =item To do during 5.6.x
5074
5075 =over 4
5076
5077 =item Support for I/O disciplines
5078
5079 =item Autoload bytes.pm
5080
5081 =item Make "\u{XXXX}" et al work
5082
5083 =item Create a char *sv_pvprintify(sv, STRLEN *lenp, UV flags)
5084
5085 =item Overloadable regex assertions
5086
5087 =item Unicode
5088
5089 =item Work out exit/die semantics for threads
5090
5091 =item Better support for nonpreemptive threading systems like GNU pth
5092
5093 =item Typed lexicals for compiler
5094
5095 =item Compiler workarounds for Win32
5096
5097 =item AUTOLOADing in the compiler
5098
5099 =item Fixing comppadlist when compiling
5100
5101 =item Cleaning up exported namespace
5102
5103 =item Complete signal handling
5104
5105 =item Out-of-source builds
5106
5107 =item POSIX realtime support
5108
5109 =item UNIX98 support
5110
5111 =item IPv6 Support
5112
5113 =item Long double conversion
5114
5115 =item Locales
5116
5117 =item Arithmetic on non-Arabic numerals
5118
5119 =item POSIX Unicode character classes
5120
5121 =item Factoring out common suffices/prefices in regexps (trie optimization)
5122
5123 =item Security audit shipped utilities
5124
5125 =item Sort out the uid-setting mess
5126
5127 =item Custom opcodes
5128
5129 =item DLL Versioning
5130
5131 =item Introduce @( and @)
5132
5133 =item Floating point handling
5134
5135 =item IV/UV preservation
5136
5137 =item Replace pod2html with something using Pod::Parser
5138
5139 =item Automate module testing on CPAN
5140
5141 =item sendmsg and recvmsg
5142
5143 =item Rewrite perlre documentation
5144
5145 =item Convert example code to IO::Handle filehandles
5146
5147 =item Document Win32 choices
5148
5149 =item Check new modules
5150
5151 =item Make roffitall find pods and libs itself
5152
5153 =back
5154
5155 =item To do at some point
5156
5157 =over 4
5158
5159 =item Remove regular expression recursion
5160
5161 =item Memory leaks after failed eval
5162
5163 =item bitfields in pack
5164
5165 =item Cross compilation
5166
5167 =item Perl preprocessor / macros
5168
5169 =item Perl lexer in Perl
5170
5171 =item Using POSIX calls internally
5172
5173 =item -i rename file when changed
5174
5175 =item All ARGV input should act like E<lt>E<gt>
5176
5177 =item Support for rerunning debugger
5178
5179 =item Test Suite for the Debugger
5180
5181 =item my sub foo { }
5182
5183 =item One-pass global destruction
5184
5185 =item Rewrite regexp parser
5186
5187 =item Cache recently used regexps
5188
5189 =item Cross-compilation support
5190
5191 =item Bit-shifting bitvectors
5192
5193 =item debugger pragma
5194
5195 =item use less pragma
5196
5197 =item switch structures
5198
5199 =item Cache eval tree
5200
5201 =item rcatmaybe
5202
5203 =item Shrink opcode tables
5204
5205 =item Optimize away @_
5206
5207 =item Prototypes versus indirect objects
5208
5209 =item Install HTML
5210
5211 =item Prototype method calls
5212
5213 =item Return context prototype declarations
5214
5215 =item magic_setisa
5216
5217 =item Garbage collection
5218
5219 =item IO tutorial
5220
5221 =item Rewrite perldoc
5222
5223 =item Install .3p manpages
5224
5225 =item Unicode tutorial
5226
5227 =item Update POSIX.pm for 1003.1-2
5228
5229 =item Retargetable installation
5230
5231 =item POSIX emulation on non-POSIX systems
5232
5233 =item Rename Win32 headers
5234
5235 =item Finish off lvalue functions
5236
5237 =item Update sprintf documentation
5238
5239 =item Use fchown/fchmod internally
5240
5241 =item Make v-strings overloaded objects
5242
5243 =item Allow restricted hash assignment
5244
5245 =item Should overload be inheritable?
5246
5247 =item Taint rethink
5248
5249 =item Perform correctly when XSUBs call subroutines that exit via
5250 goto(LABEL) and friends
5251
5252 =back
5253
5254 =item Vague ideas
5255
5256 =over 4
5257
5258 =item ref() in list context
5259
5260 =item Make tr/// return histogram of characters in list context
5261
5262 =item Compile to real threaded code
5263
5264 =item Structured types
5265
5266 =item Modifiable $1 et al.
5267
5268 =item Procedural interfaces for IO::*, etc.
5269
5270 =item RPC modules
5271
5272 =item Attach/detach debugger from running program
5273
5274 =item GUI::Native
5275
5276 =item foreach(reverse ...)
5277
5278 =item Constant function cache
5279
5280 =item Approximate regular expression matching
5281
5282 =back
5283
5284 =item Ongoing
5285
5286 =over 4
5287
5288 =item Update guts documentation
5289
5290 =item Add more tests
5291
5292 =item Update auxiliary tools
5293
5294 =item Create debugging macros
5295
5296 =item truncate to the people
5297
5298 =item Unicode in Filenames
5299
5300 =back
5301
5302 =item Unicode in %ENV
5303
5304 =item Recently done things
5305
5306 =over 4
5307
5308 =item Alternative RE syntax module
5309
5310 =item Safe signal handling
5311
5312 =item Tie Modules
5313
5314 =item gettimeofday
5315
5316 =item setitimer and getimiter
5317
5318 =item Testing __DIE__ hook
5319
5320 =item CPP equivalent in Perl
5321
5322 =item Explicit switch statements
5323
5324 =item autocroak
5325
5326 =item UTF/EBCDIC
5327
5328 =item UTF Regexes
5329
5330 =item perlcc to produce executable
5331
5332 =item END blocks saved in compiled output
5333
5334 =item Secure temporary file module
5335
5336 =item Integrate Time::HiRes
5337
5338 =item Turn Cwd into XS
5339
5340 =item Mmap for input
5341
5342 =item Byte to/from UTF-8 and UTF-8 to/from local conversion
5343
5344 =item Add sockatmark support
5345
5346 =item Mailing list archives
5347
5348 =item Bug tracking
5349
5350 =item Integrate MacPerl
5351
5352 =item Web "nerve center" for Perl
5353
5354 =item Regular expression tutorial
5355
5356 =item Debugging Tutorial
5357
5358 =item Integrate new modules
5359
5360 =item Integrate profiler
5361
5362 =item Y2K error detection
5363
5364 =item Regular expression debugger
5365
5366 =item POD checker
5367
5368 =item "Dynamic" lexicals
5369
5370 =item Cache precompiled modules
5371
5372 =back
5373
5374 =item Deprecated Wishes
5375
5376 =over 4
5377
5378 =item Loop control on do{}
5379
5380 =item Lexically scoped typeglobs
5381
5382 =item format BOTTOM
5383
5384 =item report HANDLE
5385
5386 =item Generalised want()/caller())
5387
5388 =item Named prototypes
5389
5390 =item Built-in globbing
5391
5392 =item Regression tests for suidperl
5393
5394 =item Cached hash values
5395
5396 =item Add compression modules
5397
5398 =item Reorganise documentation into tutorials/references
5399
5400 =item Remove distinction between functions and operators
5401
5402 =item Make XS easier to use
5403
5404 =item Make embedding easier to use
5405
5406 =item man for perl
5407
5408 =item my $Package::variable
5409
5410 =item "or" tests defined, not truth
5411
5412 =item "class"-based lexicals
5413
5414 =item byteperl
5415
5416 =item Lazy evaluation / tail recursion removal
5417
5418 =item Make "use utf8" the default
5419
5420 =item Unicode collation and normalization
5421
5422 =item pack/unpack tutorial
5423
5424 =back
5425
5426 =back
5427
5428 =head2 perldoc - Look up Perl documentation in Pod format.
5429
5430 =over 4
5431
5432 =item SYNOPSIS
5433
5434 =item DESCRIPTION
5435
5436 =item OPTIONS
5437
5438 B<-h>, B<-v>, B<-t>, B<-u>, B<-m> I<module>, B<-l>, B<-F>, B<-f>
5439 I<perlfunc>, B<-q> I<perlfaq-search-regexp>, B<-T>, B<-d>
5440 I<destination-filename>, B<-o> I<output-formatname>, B<-M> I<module-name>,
5441 B<-w> I<option:value> or B<-w> I<option>, B<-X>,
5442 B<PageName|ModuleName|ProgramName>, B<-n> I<some-formatter>, B<-r>, B<-i>,
5443 B<-V>
5444
5445 =item SECURITY
5446
5447 =item ENVIRONMENT
5448
5449 =item AUTHOR
5450
5451 =back
5452
5453 =head2 perlhist - the Perl history records
5454
5455 =over 4
5456
5457 =item DESCRIPTION
5458
5459 =item INTRODUCTION
5460
5461 =item THE KEEPERS OF THE PUMPKIN
5462
5463 =over 4
5464
5465 =item PUMPKIN?
5466
5467 =back
5468
5469 =item THE RECORDS
5470
5471 =over 4
5472
5473 =item SELECTED RELEASE SIZES
5474
5475 =item SELECTED PATCH SIZES
5476
5477 =back
5478
5479 =item THE KEEPERS OF THE RECORDS
5480
5481 =back
5482
5483 =head2 perldelta - what is new for perl v5.9.0
5484
5485 =over 4
5486
5487 =item DESCRIPTION
5488
5489 =item Incompatible Changes
5490
5491 =over 4
5492
5493 =item The C<$*> variable has been removed
5494
5495 =back
5496
5497 =item Core Enhancements
5498
5499 =over 4
5500
5501 =item Tied Arrays with Negative Array Indices
5502
5503 =back
5504
5505 =item Modules and Pragmata
5506
5507 =item Utility Changes
5508
5509 =item New Documentation
5510
5511 =item Performance Enhancements
5512
5513 =item Installation and Configuration Improvements
5514
5515 =item Selected Bug Fixes
5516
5517 =item New or Changed Diagnostics
5518
5519 =item Changed Internals
5520
5521 =item New Tests
5522
5523 =item Known Problems
5524
5525 =item Platform Specific Problems
5526
5527 =item Reporting Bugs
5528
5529 =item SEE ALSO
5530
5531 =back
5532
5533 =head2 perl58delta, perldelta - what is new for perl v5.8.0
5534
5535 =over 4
5536
5537 =item DESCRIPTION
5538
5539 =item Highlights In 5.8.0
5540
5541 =item Incompatible Changes
5542
5543 =over 4
5544
5545 =item Binary Incompatibility
5546
5547 =item 64-bit platforms and malloc
5548
5549 =item AIX Dynaloading
5550
5551 =item Attributes for C<my> variables now handled at run-time
5552
5553 =item Socket Extension Dynamic in VMS
5554
5555 =item IEEE-format Floating Point Default on OpenVMS Alpha
5556
5557 =item New Unicode Semantics (no more C<use utf8>, almost)
5558
5559 =item New Unicode Properties
5560
5561 =item REF(...) Instead Of SCALAR(...)
5562
5563 =item pack/unpack D/F recycled
5564
5565 =item glob() now returns filenames in alphabetical order
5566
5567 =item Deprecations
5568
5569 =back
5570
5571 =item Core Enhancements
5572
5573 =over 4
5574
5575 =item Unicode Overhaul
5576
5577 =item PerlIO is Now The Default
5578
5579 =item ithreads
5580
5581 =item Restricted Hashes
5582
5583 =item Safe Signals
5584
5585 =item Understanding of Numbers
5586
5587 =item Arrays now always interpolate into double-quoted strings [561]
5588
5589 =item Miscellaneous Changes
5590
5591 =back
5592
5593 =item Modules and Pragmata
5594
5595 =over 4
5596
5597 =item New Modules and Pragmata
5598
5599 =item Updated And Improved Modules and Pragmata
5600
5601 =back
5602
5603 =item Utility Changes
5604
5605 =item New Documentation
5606
5607 =item Performance Enhancements
5608
5609 =item Installation and Configuration Improvements
5610
5611 =over 4
5612
5613 =item Generic Improvements
5614
5615 =item New Or Improved Platforms
5616
5617 =back
5618
5619 =item Selected Bug Fixes
5620
5621 =over 4
5622
5623 =item Platform Specific Changes and Fixes
5624
5625 =back
5626
5627 =item New or Changed Diagnostics
5628
5629 =item Changed Internals
5630
5631 =item Security Vulnerability Closed [561]
5632
5633 =item New Tests
5634
5635 =item Known Problems
5636
5637 =over 4
5638
5639 =item The Compiler Suite Is Still Very Experimental
5640
5641 =item Localising Tied Arrays and Hashes Is Broken
5642
5643 =item Building Extensions Can Fail Because Of Largefiles
5644
5645 =item Modifying $_ Inside for(..)
5646
5647 =item mod_perl 1.26 Doesn't Build With Threaded Perl
5648
5649 =item lib/ftmp-security tests warn 'system possibly insecure'
5650
5651 =item libwww-perl (LWP) fails base/date #51
5652
5653 =item PDL failing some tests
5654
5655 =item Perl_get_sv
5656
5657 =item Self-tying Problems
5658
5659 =item ext/threads/t/libc
5660
5661 =item Failure of Thread (5.005-style) tests
5662
5663 =item Timing problems
5664
5665 =item Tied/Magical Array/Hash Elements Do Not Autovivify
5666
5667 =item Unicode in package/class and subroutine names does not work
5668
5669 =back
5670
5671 =item Platform Specific Problems
5672
5673 =over 4
5674
5675 =item AIX
5676
5677 =item Alpha systems with old gccs fail several tests
5678
5679 =item AmigaOS
5680
5681 =item BeOS
5682
5683 =item Cygwin "unable to remap"
5684
5685 =item Cygwin ndbm tests fail on FAT
5686
5687 =item DJGPP Failures
5688
5689 =item FreeBSD built with ithreads coredumps reading large directories
5690
5691 =item FreeBSD Failing locale Test 117 For ISO 8859-15 Locales
5692
5693 =item IRIX fails ext/List/Util/t/shuffle.t or Digest::MD5
5694
5695 =item HP-UX lib/posix Subtest 9 Fails When LP64-Configured
5696
5697 =item Linux with glibc 2.2.5 fails t/op/int subtest #6 with -Duse64bitint
5698
5699 =item Linux With Sfio Fails op/misc Test 48
5700
5701 =item Mac OS X
5702
5703 =item Mac OS X dyld undefined symbols
5704
5705 =item OS/2 Test Failures
5706
5707 =item op/sprintf tests 91, 129, and 130
5708
5709 =item SCO
5710
5711 =item Solaris 2.5
5712
5713 =item Solaris x86 Fails Tests With -Duse64bitint
5714
5715 =item SUPER-UX (NEC SX)
5716
5717 =item Term::ReadKey not working on Win32
5718
5719 =item UNICOS/mk
5720
5721 =item UTS
5722
5723 =item VOS (Stratus)
5724
5725 =item VMS
5726
5727 =item Win32
5728
5729 =item XML::Parser not working
5730
5731 =item z/OS (OS/390)
5732
5733 =item Unicode Support on EBCDIC Still Spotty
5734
5735 =item Seen In Perl 5.7 But Gone Now
5736
5737 =back
5738
5739 =item Reporting Bugs
5740
5741 =item SEE ALSO
5742
5743 =item HISTORY
5744
5745 =back
5746
5747 =head2 perl581delta, perldelta - what is new for perl v5.8.1
5748
5749 =over 4
5750
5751 =item DESCRIPTION
5752
5753 =item Incompatible Changes
5754
5755 =over 4
5756
5757 =item Hash Randomisation
5758
5759 =item UTF-8 On Filehandles No Longer Activated By Locale
5760
5761 =item Single-number v-strings are no longer v-strings before "=>"
5762
5763 =item (Win32) The -C Switch Has Been Repurposed
5764
5765 =item (Win32) The /d Switch Of cmd.exe
5766
5767 =back
5768
5769 =item Core Enhancements
5770
5771 =over 4
5772
5773 =item UTF-8 no longer default under UTF-8 locales
5774
5775 =item Unsafe signals again available
5776
5777 =item Tied Arrays with Negative Array Indices
5778
5779 =item local ${$x}
5780
5781 =item Unicode Character Database 4.0.0
5782
5783 =item Deprecation Warnings
5784
5785 =item Miscellaneous Enhancements
5786
5787 =back
5788
5789 =item Modules and Pragmata
5790
5791 =over 4
5792
5793 =item Updated Modules And Pragmata
5794
5795 base, B::Bytecode, B::Concise, B::Deparse, Benchmark, ByteLoader, bytes,
5796 CGI, charnames, CPAN, Data::Dumper, DB_File, Devel::PPPort, Digest::MD5,
5797 Encode, fields, libnet, Math::BigInt, MIME::Base64, NEXT, Net::Ping,
5798 PerlIO::scalar, podlators, Pod::LaTeX, PodParsers, Pod::Perldoc,
5799 Scalar::Util, Storable, strict, Term::ANSIcolor, Test::Harness, Test::More,
5800 Test::Simple, Text::Balanced, Time::HiRes, threads, threads::shared,
5801 Unicode::Collate, Unicode::Normalize, Win32::GetFolderPath,
5802 Win32::GetOSVersion
5803
5804 =back
5805
5806 =item Utility Changes
5807
5808 =item New Documentation
5809
5810 =item Installation and Configuration Improvements
5811
5812 =over 4
5813
5814 =item Platform-specific enhancements
5815
5816 =back
5817
5818 =item Selected Bug Fixes
5819
5820 =over 4
5821
5822 =item Closures, eval and lexicals
5823
5824 =item Generic fixes
5825
5826 =item Platform-specific fixes
5827
5828 =back
5829
5830 =item New or Changed Diagnostics
5831
5832 =over 4
5833
5834 =item Changed "A thread exited while %d threads were running"
5835
5836 =item Removed "Attempt to clear a restricted hash"
5837
5838 =item New "Illegal declaration of anonymous subroutine"
5839
5840 =item Changed "Invalid range "%s" in transliteration operator"
5841
5842 =item New "Missing control char name in \c"
5843
5844 =item New "Newline in left-justified string for %s"
5845
5846 =item New "Possible precedence problem on bitwise %c operator"
5847
5848 =item New "Pseudo-hashes are deprecated"
5849
5850 =item New "read() on %s filehandle %s"
5851
5852 =item New "5.005 threads are deprecated"
5853
5854 =item New "Tied variable freed while still in use"
5855
5856 =item New "To%s: illegal mapping '%s'"
5857
5858 =item New "Use of freed value in iteration"
5859
5860 =back
5861
5862 =item Changed Internals
5863
5864 =item New Tests
5865
5866 =item Known Problems
5867
5868 =over 4
5869
5870 =item Tied hashes in scalar context
5871
5872 =item Net::Ping 450_service and 510_ping_udp failures
5873
5874 =item B::C