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