Update Changes.
[p5sagit/p5-mst-13.2.git] / pod / perlfaq.pod
CommitLineData
68dc0745 1=head1 NAME
2
ae3d0b9f 3perlfaq - frequently asked questions about Perl ($Date: 2002/01/31 04:27:54 $)
68dc0745 4
5=head1 DESCRIPTION
6
40d4dc3e 7The perlfaq is structured into the following documents:
68dc0745 8
68dc0745 9
40d4dc3e 10=head2 perlfaq: Structural overview of the FAQ.
68dc0745 11
12This document.
13
40d4dc3e 14=head2 L<perlfaq1>: General Questions About Perl
68dc0745 15
ae3d0b9f 16Very general, high-level questions about Perl.
68dc0745 17
65acb1b1 18=over 4
19
40d4dc3e 20=item *
21
22What is Perl?
23
24=item *
25
26Who supports Perl? Who develops it? Why is it free?
27
28=item *
29
30Which version of Perl should I use?
31
32=item *
33
34What are perl4 and perl5?
35
36=item *
37
38What is perl6?
65acb1b1 39
40d4dc3e 40=item *
65acb1b1 41
40d4dc3e 42How stable is Perl?
65acb1b1 43
40d4dc3e 44=item *
65acb1b1 45
40d4dc3e 46Is Perl difficult to learn?
65acb1b1 47
40d4dc3e 48=item *
65acb1b1 49
40d4dc3e 50How does Perl compare with other languages like Java, Python, REXX, Scheme, or Tcl?
65acb1b1 51
40d4dc3e 52=item *
65acb1b1 53
40d4dc3e 54Can I do [task] in Perl?
65acb1b1 55
40d4dc3e 56=item *
65acb1b1 57
40d4dc3e 58When shouldn't I program in Perl?
65acb1b1 59
40d4dc3e 60=item *
65acb1b1 61
40d4dc3e 62What's the difference between "perl" and "Perl"?
65acb1b1 63
40d4dc3e 64=item *
65acb1b1 65
40d4dc3e 66Is it a Perl program or a Perl script?
67
68=item *
69
70What is a JAPH?
71
72=item *
73
74Where can I get a list of Larry Wall witticisms?
75
76=item *
77
ae3d0b9f 78How can I convince my sysadmin/supervisor/employees to use version 5/5.6.1/Perl instead of some other language?
65acb1b1 79
80=back
81
82
40d4dc3e 83=head2 L<perlfaq2>: Obtaining and Learning about Perl
68dc0745 84
ae3d0b9f 85Where to find source and documentation for Perl, support,
68dc0745 86and related matters.
87
65acb1b1 88=over 4
89
40d4dc3e 90=item *
91
92What machines support Perl? Where do I get it?
93
94=item *
95
96How can I get a binary version of Perl?
65acb1b1 97
40d4dc3e 98=item *
65acb1b1 99
40d4dc3e 100I don't have a C compiler on my system. How can I compile perl?
65acb1b1 101
40d4dc3e 102=item *
65acb1b1 103
40d4dc3e 104I copied the Perl binary from one machine to another, but scripts don't work.
65acb1b1 105
40d4dc3e 106=item *
65acb1b1 107
40d4dc3e 108I grabbed the sources and tried to compile but gdbm/dynamic loading/malloc/linking/... failed. How do I make it work?
65acb1b1 109
40d4dc3e 110=item *
65acb1b1 111
40d4dc3e 112What modules and extensions are available for Perl? What is CPAN? What does CPAN/src/... mean?
65acb1b1 113
40d4dc3e 114=item *
65acb1b1 115
40d4dc3e 116Is there an ISO or ANSI certified version of Perl?
65acb1b1 117
40d4dc3e 118=item *
65acb1b1 119
40d4dc3e 120Where can I get information on Perl?
65acb1b1 121
40d4dc3e 122=item *
65acb1b1 123
40d4dc3e 124What are the Perl newsgroups on Usenet? Where do I post questions?
65acb1b1 125
40d4dc3e 126=item *
65acb1b1 127
40d4dc3e 128Where should I post source code?
65acb1b1 129
40d4dc3e 130=item *
131
132Perl Books
133
134=item *
135
136Perl in Magazines
137
138=item *
139
140Perl on the Net: FTP and WWW Access
141
142=item *
143
144What mailing lists are there for Perl?
145
146=item *
147
148Archives of comp.lang.perl.misc
149
150=item *
151
152Where can I buy a commercial version of Perl?
153
154=item *
155
156Where do I send bug reports?
157
158=item *
159
ae3d0b9f 160What is perl.com? Perl Mongers? pm.org? perl.org? cpan.org?
65acb1b1 161
162=back
163
164
40d4dc3e 165=head2 L<perlfaq3>: Programming Tools
68dc0745 166
167Programmer tools and programming support.
168
65acb1b1 169=over 4
170
40d4dc3e 171=item *
172
173How do I do (anything)?
174
175=item *
176
177How can I use Perl interactively?
178
179=item *
65acb1b1 180
40d4dc3e 181Is there a Perl shell?
65acb1b1 182
40d4dc3e 183=item *
65acb1b1 184
40d4dc3e 185How do I debug my Perl programs?
65acb1b1 186
40d4dc3e 187=item *
65acb1b1 188
40d4dc3e 189How do I profile my Perl programs?
65acb1b1 190
40d4dc3e 191=item *
65acb1b1 192
40d4dc3e 193How do I cross-reference my Perl programs?
65acb1b1 194
40d4dc3e 195=item *
65acb1b1 196
40d4dc3e 197Is there a pretty-printer (formatter) for Perl?
65acb1b1 198
40d4dc3e 199=item *
65acb1b1 200
40d4dc3e 201Is there a ctags for Perl?
65acb1b1 202
40d4dc3e 203=item *
65acb1b1 204
40d4dc3e 205Is there an IDE or Windows Perl Editor?
65acb1b1 206
40d4dc3e 207=item *
65acb1b1 208
40d4dc3e 209Where can I get Perl macros for vi?
65acb1b1 210
40d4dc3e 211=item *
65acb1b1 212
40d4dc3e 213Where can I get perl-mode for emacs?
65acb1b1 214
40d4dc3e 215=item *
65acb1b1 216
40d4dc3e 217How can I use curses with Perl?
65acb1b1 218
40d4dc3e 219=item *
65acb1b1 220
40d4dc3e 221How can I use X or Tk with Perl?
65acb1b1 222
40d4dc3e 223=item *
65acb1b1 224
40d4dc3e 225How can I generate simple menus without using CGI or Tk?
65acb1b1 226
40d4dc3e 227=item *
65acb1b1 228
40d4dc3e 229How can I make my Perl program run faster?
65acb1b1 230
40d4dc3e 231=item *
65acb1b1 232
40d4dc3e 233How can I make my Perl program take less memory?
234
235=item *
236
237Is it unsafe to return a pointer to local data?
238
239=item *
240
241How can I free an array or hash so my program shrinks?
242
243=item *
244
245How can I make my CGI script more efficient?
246
247=item *
248
249How can I hide the source for my Perl program?
250
251=item *
252
253How can I compile my Perl program into byte code or C?
254
255=item *
256
257How can I compile Perl into Java?
258
259=item *
260
261How can I get C<#!perl> to work on [MS-DOS,NT,...]?
262
263=item *
264
265Can I write useful Perl programs on the command line?
266
267=item *
268
269Why don't Perl one-liners work on my DOS/Mac/VMS system?
270
271=item *
272
273Where can I learn about CGI or Web programming in Perl?
274
275=item *
276
277Where can I learn about object-oriented Perl programming?
278
279=item *
280
281Where can I learn about linking C with Perl? [h2xs, xsubpp]
282
283=item *
284
285I've read perlembed, perlguts, etc., but I can't embed perl in
a6dd486b 286my C program; what am I doing wrong?
65acb1b1 287
40d4dc3e 288=item *
289
ae3d0b9f 290When I tried to run my script, I got this message. What does it mean?
65acb1b1 291
40d4dc3e 292=item *
293
294What's MakeMaker?
65acb1b1 295
296=back
297
298
40d4dc3e 299=head2 L<perlfaq4>: Data Manipulation
68dc0745 300
301Manipulating numbers, dates, strings, arrays, hashes, and
302miscellaneous data issues.
303
65acb1b1 304=over 4
305
40d4dc3e 306=item *
307
308Why am I getting long decimals (eg, 19.9499999999999) instead of the numbers I should be getting (eg, 19.95)?
309
310=item *
311
312Why isn't my octal data interpreted correctly?
313
314=item *
315
316Does Perl have a round() function? What about ceil() and floor()? Trig functions?
317
318=item *
319
ae3d0b9f 320How do I convert between numeric representations?
40d4dc3e 321
322=item *
323
324Why doesn't & work the way I want it to?
65acb1b1 325
40d4dc3e 326=item *
65acb1b1 327
40d4dc3e 328How do I multiply matrices?
65acb1b1 329
40d4dc3e 330=item *
65acb1b1 331
40d4dc3e 332How do I perform an operation on a series of integers?
65acb1b1 333
40d4dc3e 334=item *
65acb1b1 335
40d4dc3e 336How can I output Roman numerals?
65acb1b1 337
40d4dc3e 338=item *
65acb1b1 339
40d4dc3e 340Why aren't my random numbers random?
65acb1b1 341
40d4dc3e 342=item *
65acb1b1 343
40d4dc3e 344How do I find the week-of-the-year/day-of-the-year?
d92eb7b0 345
40d4dc3e 346=item *
65acb1b1 347
40d4dc3e 348How do I find the current century or millennium?
65acb1b1 349
40d4dc3e 350=item *
65acb1b1 351
40d4dc3e 352How can I compare two dates and find the difference?
65acb1b1 353
40d4dc3e 354=item *
65acb1b1 355
40d4dc3e 356How can I take a string and turn it into epoch seconds?
65acb1b1 357
40d4dc3e 358=item *
65acb1b1 359
40d4dc3e 360How can I find the Julian Day?
65acb1b1 361
40d4dc3e 362=item *
65acb1b1 363
40d4dc3e 364How do I find yesterday's date?
65acb1b1 365
40d4dc3e 366=item *
65acb1b1 367
40d4dc3e 368Does Perl have a Year 2000 problem? Is Perl Y2K compliant?
65acb1b1 369
40d4dc3e 370=item *
65acb1b1 371
40d4dc3e 372How do I validate input?
65acb1b1 373
40d4dc3e 374=item *
65acb1b1 375
40d4dc3e 376How do I unescape a string?
65acb1b1 377
40d4dc3e 378=item *
65acb1b1 379
40d4dc3e 380How do I remove consecutive pairs of characters?
381
382=item *
383
384How do I expand function calls in a string?
385
386=item *
387
388How do I find matching/nesting anything?
389
390=item *
391
392How do I reverse a string?
393
394=item *
395
396How do I expand tabs in a string?
397
398=item *
399
400How do I reformat a paragraph?
401
402=item *
403
404How can I access/change the first N letters of a string?
405
406=item *
407
408How do I change the Nth occurrence of something?
409
410=item *
411
412How can I count the number of occurrences of a substring within a string?
413
414=item *
415
416How do I capitalize all the words on one line?
417
418=item *
419
420How can I split a [character] delimited string except when inside
65acb1b1 421[character]? (Comma-separated files)
422
40d4dc3e 423=item *
424
425How do I strip blank space from the beginning/end of a string?
426
427=item *
428
429How do I pad a string with blanks or pad a number with zeroes?
430
431=item *
432
433How do I extract selected columns from a string?
434
435=item *
436
437How do I find the soundex value of a string?
438
439=item *
440
441How can I expand variables in text strings?
442
443=item *
444
445What's wrong with always quoting "$vars"?
446
447=item *
448
449Why don't my <<HERE documents work?
450
451=item *
452
453What is the difference between a list and an array?
454
455=item *
456
457What is the difference between $array[1] and @array[1]?
458
459=item *
65acb1b1 460
40d4dc3e 461How can I remove duplicate elements from a list or array?
65acb1b1 462
40d4dc3e 463=item *
65acb1b1 464
ae3d0b9f 465How can I tell whether a certain element is contained in a list or array?
65acb1b1 466
40d4dc3e 467=item *
65acb1b1 468
40d4dc3e 469How do I compute the difference of two arrays? How do I compute the intersection of two arrays?
65acb1b1 470
40d4dc3e 471=item *
65acb1b1 472
40d4dc3e 473How do I test whether two arrays or hashes are equal?
65acb1b1 474
40d4dc3e 475=item *
65acb1b1 476
40d4dc3e 477How do I find the first array element for which a condition is true?
65acb1b1 478
40d4dc3e 479=item *
65acb1b1 480
40d4dc3e 481How do I handle linked lists?
65acb1b1 482
40d4dc3e 483=item *
65acb1b1 484
40d4dc3e 485How do I handle circular lists?
65acb1b1 486
40d4dc3e 487=item *
65acb1b1 488
40d4dc3e 489How do I shuffle an array randomly?
65acb1b1 490
40d4dc3e 491=item *
65acb1b1 492
40d4dc3e 493How do I process/modify each element of an array?
65acb1b1 494
40d4dc3e 495=item *
65acb1b1 496
40d4dc3e 497How do I select a random element from an array?
65acb1b1 498
40d4dc3e 499=item *
65acb1b1 500
40d4dc3e 501How do I permute N elements of a list?
65acb1b1 502
40d4dc3e 503=item *
65acb1b1 504
40d4dc3e 505How do I sort an array by (anything)?
65acb1b1 506
40d4dc3e 507=item *
65acb1b1 508
40d4dc3e 509How do I manipulate arrays of bits?
65acb1b1 510
40d4dc3e 511=item *
65acb1b1 512
40d4dc3e 513Why does defined() return true on empty arrays and hashes?
65acb1b1 514
40d4dc3e 515=item *
65acb1b1 516
40d4dc3e 517How do I process an entire hash?
65acb1b1 518
40d4dc3e 519=item *
65acb1b1 520
40d4dc3e 521What happens if I add or remove keys from a hash while iterating over it?
65acb1b1 522
40d4dc3e 523=item *
65acb1b1 524
40d4dc3e 525How do I look up a hash element by value?
65acb1b1 526
40d4dc3e 527=item *
65acb1b1 528
40d4dc3e 529How can I know how many entries are in a hash?
65acb1b1 530
40d4dc3e 531=item *
65acb1b1 532
40d4dc3e 533How do I sort a hash (optionally by value instead of key)?
65acb1b1 534
40d4dc3e 535=item *
65acb1b1 536
40d4dc3e 537How can I always keep my hash sorted?
65acb1b1 538
40d4dc3e 539=item *
65acb1b1 540
40d4dc3e 541What's the difference between "delete" and "undef" with hashes?
65acb1b1 542
40d4dc3e 543=item *
65acb1b1 544
40d4dc3e 545Why don't my tied hashes make the defined/exists distinction?
65acb1b1 546
40d4dc3e 547=item *
548
549How do I reset an each() operation part-way through?
550
551=item *
552
553How can I get the unique keys from two hashes?
554
555=item *
556
557How can I store a multidimensional array in a DBM file?
558
559=item *
560
561How can I make my hash remember the order I put elements into it?
562
563=item *
564
565Why does passing a subroutine an undefined element in a hash create it?
566
567=item *
568
569How can I make the Perl equivalent of a C structure/C++ class/hash or array of hashes or arrays?
570
571=item *
572
573How can I use a reference as a hash key?
574
575=item *
576
577How do I handle binary data correctly?
578
579=item *
580
581How do I determine whether a scalar is a number/whole/integer/float?
582
583=item *
584
585How do I keep persistent data across program calls?
586
587=item *
588
589How do I print out or copy a recursive data structure?
590
591=item *
592
593How do I define methods for every class/object?
594
595=item *
596
597How do I verify a credit card checksum?
598
599=item *
600
601How do I pack arrays of doubles or floats for XS code?
65acb1b1 602
603=back
604
605
40d4dc3e 606=head2 L<perlfaq5>: Files and Formats
68dc0745 607
ae3d0b9f 608I/O and the "f" issues: filehandles, flushing, formats, and footers.
68dc0745 609
65acb1b1 610=over 4
611
40d4dc3e 612=item *
613
614How do I flush/unbuffer an output filehandle? Why must I do this?
615
616=item *
617
618How do I change one line in a file/delete a line in a file/insert a line in the middle of a file/append to the beginning of a file?
619
620=item *
621
622How do I count the number of lines in a file?
623
624=item *
625
626How do I make a temporary file name?
627
628=item *
629
630How can I manipulate fixed-record-length files?
631
632=item *
65acb1b1 633
40d4dc3e 634How can I make a filehandle local to a subroutine? How do I pass filehandles between subroutines? How do I make an array of filehandles?
65acb1b1 635
40d4dc3e 636=item *
65acb1b1 637
40d4dc3e 638How can I use a filehandle indirectly?
65acb1b1 639
40d4dc3e 640=item *
65acb1b1 641
40d4dc3e 642How can I set up a footer format to be used with write()?
65acb1b1 643
40d4dc3e 644=item *
65acb1b1 645
40d4dc3e 646How can I write() into a string?
65acb1b1 647
40d4dc3e 648=item *
65acb1b1 649
40d4dc3e 650How can I output my numbers with commas added?
65acb1b1 651
40d4dc3e 652=item *
65acb1b1 653
40d4dc3e 654How can I translate tildes (~) in a filename?
65acb1b1 655
40d4dc3e 656=item *
65acb1b1 657
40d4dc3e 658How come when I open a file read-write it wipes it out?
65acb1b1 659
40d4dc3e 660=item *
65acb1b1 661
40d4dc3e 662Why do I sometimes get an "Argument list too long" when I use <*>?
65acb1b1 663
40d4dc3e 664=item *
65acb1b1 665
40d4dc3e 666Is there a leak/bug in glob()?
65acb1b1 667
40d4dc3e 668=item *
65acb1b1 669
40d4dc3e 670How can I open a file with a leading ">" or trailing blanks?
65acb1b1 671
40d4dc3e 672=item *
65acb1b1 673
40d4dc3e 674How can I reliably rename a file?
65acb1b1 675
40d4dc3e 676=item *
65acb1b1 677
40d4dc3e 678How can I lock a file?
d92eb7b0 679
40d4dc3e 680=item *
65acb1b1 681
40d4dc3e 682Why can't I just open(FH, ">file.lock")?
65acb1b1 683
40d4dc3e 684=item *
65acb1b1 685
40d4dc3e 686I still don't get locking. I just want to increment the number in the file. How can I do this?
65acb1b1 687
40d4dc3e 688=item *
65acb1b1 689
f52f3be2 690All I want to do is append a small amount of text to the end of a file. Do I still have to use locking?
05caf3a7 691
692=item *
693
40d4dc3e 694How do I randomly update a binary file?
65acb1b1 695
40d4dc3e 696=item *
65acb1b1 697
40d4dc3e 698How do I get a file's timestamp in perl?
65acb1b1 699
40d4dc3e 700=item *
65acb1b1 701
40d4dc3e 702How do I set a file's timestamp in perl?
65acb1b1 703
40d4dc3e 704=item *
705
706How do I print to more than one file at once?
707
708=item *
709
710How can I read in an entire file all at once?
711
712=item *
713
714How can I read in a file by paragraphs?
715
716=item *
717
718How can I read a single character from a file? From the keyboard?
719
720=item *
721
722How can I tell whether there's a character waiting on a filehandle?
723
724=item *
725
726How do I do a C<tail -f> in perl?
727
728=item *
729
730How do I dup() a filehandle in Perl?
731
732=item *
733
734How do I close a file descriptor by number?
735
736=item *
737
738Why can't I use "C:\temp\foo" in DOS paths? What doesn't `C:\temp\foo.exe` work?
739
740=item *
741
742Why doesn't glob("*.*") get all the files?
743
744=item *
745
746Why does Perl let me delete read-only files? Why does C<-i> clobber protected files? Isn't this a bug in Perl?
747
748=item *
749
750How do I select a random line from a file?
751
752=item *
753
754Why do I get weird spaces when I print an array of lines?
65acb1b1 755
756=back
757
758
ae3d0b9f 759=head2 L<perlfaq6>: Regular Expressions
68dc0745 760
761Pattern matching and regular expressions.
762
65acb1b1 763=over 4
764
40d4dc3e 765=item *
766
767How can I hope to use regular expressions without creating illegible and unmaintainable code?
768
769=item *
770
771I'm having trouble matching over more than one line. What's wrong?
772
773=item *
774
775How can I pull out lines between two patterns that are themselves on different lines?
776
777=item *
778
779I put a regular expression into $/ but it didn't work. What's wrong?
780
781=item *
782
783How do I substitute case insensitively on the LHS while preserving case on the RHS?
784
785=item *
786
787How can I make C<\w> match national character sets?
788
789=item *
790
791How can I match a locale-smart version of C</[a-zA-Z]/>?
65acb1b1 792
40d4dc3e 793=item *
65acb1b1 794
40d4dc3e 795How can I quote a variable to use in a regex?
65acb1b1 796
40d4dc3e 797=item *
65acb1b1 798
40d4dc3e 799What is C</o> really for?
65acb1b1 800
40d4dc3e 801=item *
65acb1b1 802
40d4dc3e 803How do I use a regular expression to strip C style comments from a file?
65acb1b1 804
40d4dc3e 805=item *
65acb1b1 806
40d4dc3e 807Can I use Perl regular expressions to match balanced text?
65acb1b1 808
40d4dc3e 809=item *
65acb1b1 810
40d4dc3e 811What does it mean that regexes are greedy? How can I get around it?
65acb1b1 812
40d4dc3e 813=item *
65acb1b1 814
40d4dc3e 815How do I process each word on each line?
65acb1b1 816
40d4dc3e 817=item *
65acb1b1 818
40d4dc3e 819How can I print out a word-frequency or line-frequency summary?
65acb1b1 820
40d4dc3e 821=item *
65acb1b1 822
40d4dc3e 823How can I do approximate matching?
65acb1b1 824
40d4dc3e 825=item *
65acb1b1 826
40d4dc3e 827How do I efficiently match many regular expressions at once?
65acb1b1 828
40d4dc3e 829=item *
65acb1b1 830
40d4dc3e 831Why don't word-boundary searches with C<\b> work for me?
65acb1b1 832
40d4dc3e 833=item *
65acb1b1 834
40d4dc3e 835Why does using $&, $`, or $' slow my program down?
836
837=item *
838
839What good is C<\G> in a regular expression?
840
841=item *
842
843Are Perl regexes DFAs or NFAs? Are they POSIX compliant?
844
845=item *
846
847What's wrong with using grep or map in a void context?
848
849=item *
850
851How can I match strings with multibyte characters?
852
853=item *
854
855How do I match a pattern that is supplied by the user?
65acb1b1 856
857=back
858
859
40d4dc3e 860=head2 L<perlfaq7>: General Perl Language Issues
68dc0745 861
862General Perl language issues that don't clearly fit into any of the
863other sections.
864
65acb1b1 865=over 4
866
40d4dc3e 867=item *
868
869Can I get a BNF/yacc/RE for the Perl language?
870
871=item *
872
873What are all these $@%&* punctuation signs, and how do I know when to use them?
874
875=item *
876
877Do I always/never have to quote my strings or use semicolons and commas?
878
879=item *
880
881How do I skip some return values?
882
883=item *
884
885How do I temporarily block warnings?
886
887=item *
888
889What's an extension?
890
891=item *
892
893Why do Perl operators have different precedence than C operators?
894
895=item *
896
897How do I declare/create a structure?
898
899=item *
900
901How do I create a module?
902
903=item *
904
905How do I create a class?
906
907=item *
908
909How can I tell if a variable is tainted?
910
911=item *
912
913What's a closure?
914
915=item *
916
917What is variable suicide and how can I prevent it?
918
919=item *
920
921How can I pass/return a {Function, FileHandle, Array, Hash, Method, Regex}?
65acb1b1 922
40d4dc3e 923=item *
65acb1b1 924
40d4dc3e 925How do I create a static variable?
65acb1b1 926
40d4dc3e 927=item *
65acb1b1 928
40d4dc3e 929What's the difference between dynamic and lexical (static) scoping? Between local() and my()?
65acb1b1 930
40d4dc3e 931=item *
65acb1b1 932
40d4dc3e 933How can I access a dynamic variable while a similarly named lexical is in scope?
65acb1b1 934
40d4dc3e 935=item *
65acb1b1 936
40d4dc3e 937What's the difference between deep and shallow binding?
65acb1b1 938
40d4dc3e 939=item *
65acb1b1 940
40d4dc3e 941Why doesn't "my($foo) = <FILE>;" work right?
65acb1b1 942
40d4dc3e 943=item *
65acb1b1 944
40d4dc3e 945How do I redefine a builtin function, operator, or method?
65acb1b1 946
40d4dc3e 947=item *
65acb1b1 948
40d4dc3e 949What's the difference between calling a function as &foo and foo()?
65acb1b1 950
40d4dc3e 951=item *
65acb1b1 952
40d4dc3e 953How do I create a switch or case statement?
65acb1b1 954
40d4dc3e 955=item *
65acb1b1 956
40d4dc3e 957How can I catch accesses to undefined variables/functions/methods?
65acb1b1 958
40d4dc3e 959=item *
65acb1b1 960
40d4dc3e 961Why can't a method included in this same file be found?
65acb1b1 962
40d4dc3e 963=item *
65acb1b1 964
40d4dc3e 965How can I find out my current package?
65acb1b1 966
40d4dc3e 967=item *
65acb1b1 968
40d4dc3e 969How can I comment out a large block of perl code?
65acb1b1 970
40d4dc3e 971=item *
65acb1b1 972
40d4dc3e 973How do I clear a package?
65acb1b1 974
40d4dc3e 975=item *
976
977How can I use a variable as a variable name?
d92eb7b0 978
65acb1b1 979=back
980
981
40d4dc3e 982=head2 L<perlfaq8>: System Interaction
68dc0745 983
984Interprocess communication (IPC), control over the user-interface
985(keyboard, screen and pointing devices).
986
65acb1b1 987=over 4
988
40d4dc3e 989=item *
990
991How do I find out which operating system I'm running under?
992
993=item *
994
995How come exec() doesn't return?
996
997=item *
998
999How do I do fancy stuff with the keyboard/screen/mouse?
1000
1001=item *
1002
1003How do I print something out in color?
1004
1005=item *
1006
1007How do I read just one key without waiting for a return key?
1008
1009=item *
1010
1011How do I check whether input is ready on the keyboard?
1012
1013=item *
1014
1015How do I clear the screen?
1016
1017=item *
1018
1019How do I get the screen size?
1020
1021=item *
1022
1023How do I ask the user for a password?
1024
1025=item *
1026
1027How do I read and write the serial port?
1028
1029=item *
1030
1031How do I decode encrypted password files?
1032
1033=item *
1034
1035How do I start a process in the background?
1036
1037=item *
1038
1039How do I trap control characters/signals?
1040
1041=item *
1042
1043How do I modify the shadow password file on a Unix system?
1044
1045=item *
1046
1047How do I set the time and date?
1048
1049=item *
1050
1051How can I sleep() or alarm() for under a second?
1052
1053=item *
1054
1055How can I measure time under a second?
1056
1057=item *
1058
1059How can I do an atexit() or setjmp()/longjmp()? (Exception handling)
1060
1061=item *
1062
1063Why doesn't my sockets program work under System V (Solaris)? What does the error message "Protocol not supported" mean?
65acb1b1 1064
40d4dc3e 1065=item *
65acb1b1 1066
40d4dc3e 1067How can I call my system's unique C functions from Perl?
65acb1b1 1068
40d4dc3e 1069=item *
65acb1b1 1070
40d4dc3e 1071Where do I get the include files to do ioctl() or syscall()?
65acb1b1 1072
40d4dc3e 1073=item *
65acb1b1 1074
40d4dc3e 1075Why do setuid perl scripts complain about kernel problems?
65acb1b1 1076
40d4dc3e 1077=item *
65acb1b1 1078
40d4dc3e 1079How can I open a pipe both to and from a command?
65acb1b1 1080
40d4dc3e 1081=item *
65acb1b1 1082
40d4dc3e 1083Why can't I get the output of a command with system()?
65acb1b1 1084
40d4dc3e 1085=item *
65acb1b1 1086
40d4dc3e 1087How can I capture STDERR from an external command?
65acb1b1 1088
40d4dc3e 1089=item *
65acb1b1 1090
40d4dc3e 1091Why doesn't open() return an error when a pipe open fails?
65acb1b1 1092
40d4dc3e 1093=item *
65acb1b1 1094
40d4dc3e 1095What's wrong with using backticks in a void context?
65acb1b1 1096
40d4dc3e 1097=item *
65acb1b1 1098
40d4dc3e 1099How can I call backticks without shell processing?
65acb1b1 1100
40d4dc3e 1101=item *
65acb1b1 1102
40d4dc3e 1103Why can't my script read from STDIN after I gave it EOF (^D on Unix, ^Z on MS-DOS)?
65acb1b1 1104
40d4dc3e 1105=item *
65acb1b1 1106
40d4dc3e 1107How can I convert my shell script to perl?
65acb1b1 1108
40d4dc3e 1109=item *
65acb1b1 1110
40d4dc3e 1111Can I use perl to run a telnet or ftp session?
65acb1b1 1112
40d4dc3e 1113=item *
65acb1b1 1114
40d4dc3e 1115How can I write expect in Perl?
65acb1b1 1116
40d4dc3e 1117=item *
65acb1b1 1118
40d4dc3e 1119Is there a way to hide perl's command line from programs such as "ps"?
65acb1b1 1120
40d4dc3e 1121=item *
65acb1b1 1122
40d4dc3e 1123I {changed directory, modified my environment} in a perl script. How come the change disappeared when I exited the script? How do I get my changes to be visible?
65acb1b1 1124
40d4dc3e 1125=item *
65acb1b1 1126
40d4dc3e 1127How do I close a process's filehandle without waiting for it to complete?
65acb1b1 1128
40d4dc3e 1129=item *
65acb1b1 1130
40d4dc3e 1131How do I fork a daemon process?
65acb1b1 1132
40d4dc3e 1133=item *
65acb1b1 1134
40d4dc3e 1135How do I find out if I'm running interactively or not?
65acb1b1 1136
40d4dc3e 1137=item *
65acb1b1 1138
40d4dc3e 1139How do I timeout a slow event?
65acb1b1 1140
40d4dc3e 1141=item *
65acb1b1 1142
40d4dc3e 1143How do I set CPU limits?
65acb1b1 1144
40d4dc3e 1145=item *
65acb1b1 1146
40d4dc3e 1147How do I avoid zombies on a Unix system?
65acb1b1 1148
40d4dc3e 1149=item *
65acb1b1 1150
40d4dc3e 1151How do I use an SQL database?
65acb1b1 1152
40d4dc3e 1153=item *
65acb1b1 1154
40d4dc3e 1155How do I make a system() exit on control-C?
65acb1b1 1156
40d4dc3e 1157=item *
65acb1b1 1158
40d4dc3e 1159How do I open a file without blocking?
1160
1161=item *
1162
1163How do I install a module from CPAN?
1164
1165=item *
1166
1167What's the difference between require and use?
1168
1169=item *
1170
1171How do I keep my own module/library directory?
1172
1173=item *
1174
1175How do I add the directory my program lives in to the module/library search path?
1176
1177=item *
1178
1179How do I add a directory to my include path at runtime?
1180
1181=item *
1182
1183What is socket.ph and where do I get it?
65acb1b1 1184
1185=back
1186
1187
40d4dc3e 1188=head2 L<perlfaq9>: Networking
68dc0745 1189
ae3d0b9f 1190Networking, the internet, and a few on the web.
68dc0745 1191
65acb1b1 1192=over 4
1193
40d4dc3e 1194=item *
65acb1b1 1195
ae3d0b9f 1196What is the correct form of response from a CGI script?
1197
1198=item *
1199
40d4dc3e 1200My CGI script runs from the command line but not the browser. (500 Server Error)
65acb1b1 1201
40d4dc3e 1202=item *
65acb1b1 1203
40d4dc3e 1204How can I get better error messages from a CGI program?
65acb1b1 1205
40d4dc3e 1206=item *
65acb1b1 1207
40d4dc3e 1208How do I remove HTML from a string?
65acb1b1 1209
40d4dc3e 1210=item *
65acb1b1 1211
40d4dc3e 1212How do I extract URLs?
65acb1b1 1213
40d4dc3e 1214=item *
65acb1b1 1215
40d4dc3e 1216How do I download a file from the user's machine? How do I open a file on another machine?
65acb1b1 1217
40d4dc3e 1218=item *
65acb1b1 1219
40d4dc3e 1220How do I make a pop-up menu in HTML?
65acb1b1 1221
40d4dc3e 1222=item *
65acb1b1 1223
40d4dc3e 1224How do I fetch an HTML file?
65acb1b1 1225
40d4dc3e 1226=item *
65acb1b1 1227
40d4dc3e 1228How do I automate an HTML form submission?
65acb1b1 1229
40d4dc3e 1230=item *
65acb1b1 1231
40d4dc3e 1232How do I decode or create those %-encodings on the web?
65acb1b1 1233
40d4dc3e 1234=item *
65acb1b1 1235
40d4dc3e 1236How do I redirect to another page?
65acb1b1 1237
40d4dc3e 1238=item *
65acb1b1 1239
40d4dc3e 1240How do I put a password on my web pages?
65acb1b1 1241
40d4dc3e 1242=item *
65acb1b1 1243
40d4dc3e 1244How do I edit my .htpasswd and .htgroup files with Perl?
65acb1b1 1245
40d4dc3e 1246=item *
1247
1248How do I make sure users can't enter values into a form that cause my CGI script to do bad things?
1249
1250=item *
1251
1252How do I parse a mail header?
1253
1254=item *
1255
1256How do I decode a CGI form?
1257
1258=item *
65acb1b1 1259
40d4dc3e 1260How do I check a valid mail address?
1261
1262=item *
1263
1264How do I decode a MIME/BASE64 string?
1265
1266=item *
1267
1268How do I return the user's mail address?
1269
1270=item *
1271
1272How do I send mail?
1273
1274=item *
1275
ae3d0b9f 1276How do I use MIME to make an attachment to a mail message?
1277
1278=item *
1279
40d4dc3e 1280How do I read mail?
1281
1282=item *
1283
1284How do I find out my hostname/domainname/IP address?
1285
1286=item *
1287
1288How do I fetch a news article or the active newsgroups?
1289
1290=item *
1291
1292How do I fetch/put an FTP file?
1293
1294=item *
1295
1296How can I do RPC in Perl?
65acb1b1 1297
68dc0745 1298=back
1299
40d4dc3e 1300
1301=head1 About the perlfaq documents
1302
1303=head2 Where to get the perlfaq
68dc0745 1304
1305This document is posted regularly to comp.lang.perl.announce and
06a5f41f 1306several other related newsgroups. It is available on many
1307web sites: http://www.perldoc.com/ and http://perlfaq.cpan.org/ .
68dc0745 1308
40d4dc3e 1309=head2 How to contribute to the perlfaq
68dc0745 1310
1311You may mail corrections, additions, and suggestions to
06a5f41f 1312perlfaq-workers@perl.org . This alias should not be
c8db1d39 1313used to I<ask> FAQs. It's for fixing the current FAQ.
65acb1b1 1314Send questions to the comp.lang.perl.misc newsgroup.
68dc0745 1315
1316=head2 What will happen if you mail your Perl programming problems to the authors
1317
1318Your questions will probably go unread, unless they're suggestions of
1319new questions to add to the FAQ, in which case they should have gone
06a5f41f 1320to the perlfaq-workers@perl.org instead.
68dc0745 1321
1322You should have read section 2 of this faq. There you would have
1323learned that comp.lang.perl.misc is the appropriate place to go for
1324free advice. If your question is really important and you require a
1325prompt and correct answer, you should hire a consultant.
1326
1327=head1 Credits
1328
1329When I first began the Perl FAQ in the late 80s, I never realized it
1330would have grown to over a hundred pages, nor that Perl would ever become
1331so popular and widespread. This document could not have been written
1332without the tremendous help provided by Larry Wall and the rest of the
1333Perl Porters.
1334
1335=head1 Author and Copyright Information
1336
0bc0ad85 1337Copyright (c) 1997-2002 Tom Christiansen and Nathan Torkington.
68dc0745 1338All rights reserved.
1339
c8db1d39 1340=head2 Bundled Distributions
68dc0745 1341
5a7beb56 1342This documentation is free; you can redistribute it and/or modify it
1343under the same terms as Perl itself.
68dc0745 1344
c8db1d39 1345Irrespective of its distribution, all code examples in these files
1346are hereby placed into the public domain. You are permitted and
1347encouraged to use this code in your own programs for fun
1348or for profit as you see fit. A simple comment in the code giving
1349credit would be courteous but is not required.
68dc0745 1350
1351=head2 Disclaimer
1352
1353This information is offered in good faith and in the hope that it may
1354be of use, but is not guaranteed to be correct, up to date, or suitable
1355for any particular purpose whatsoever. The authors accept no liability
1356in respect of this information or its use.
1357
1358=head1 Changes
1359
1360=over 4
1361
a6dd486b 1362=item 1/November/2000
1363
1364A few grammatical fixes and updates implemented by John Borwick.
1365
d92eb7b0 1366=item 23/May/99
1367
87275199 1368Extensive updates from the net in preparation for 5.6 release.
d92eb7b0 1369
1370=item 13/April/99
1371
1372More minor touch-ups. Added new question at the end
1373of perlfaq7 on variable names within variables.
1374
65acb1b1 1375=item 7/January/99
1376
8305e449 1377Small touch ups here and there. Added all questions in this
65acb1b1 1378document as a sort of table of contents.
1379
707102d0 1380=item 22/June/98
c8db1d39 1381
1382Significant changes throughout in preparation for the 5.005
1383release.
1384
fc36a67e 1385=item 24/April/97
1386
1387Style and whitespace changes from Chip, new question on reading one
1388character at a time from a terminal using POSIX from Tom.
1389
46fc3d4c 1390=item 23/April/97
1391
1392Added http://www.oasis.leo.org/perl/ to L<perlfaq2>. Style fix to
1393L<perlfaq3>. Added floating point precision, fixed complex number
1394arithmetic, cross-references, caveat for Text::Wrap, alternative
1395answer for initial capitalizing, fixed incorrect regexp, added example
1396of Tie::IxHash to L<perlfaq4>. Added example of passing and storing
1397filehandles, added commify to L<perlfaq5>. Restored variable suicide,
1398and added mass commenting to L<perlfaq7>. Added Net::Telnet, fixed
1399backticks, added reader/writer pair to telnet question, added FindBin,
1400grouped module questions together in L<perlfaq8>. Expanded caveats
1401for the simple URL extractor, gave LWP example, added CGI security
5a964f20 1402question, expanded on the mail address answer in L<perlfaq9>.
46fc3d4c 1403
3fe9a6f1 1404=item 25/March/97
1405
1406Added more info to the binary distribution section of L<perlfaq2>.
1407Added Net::Telnet to L<perlfaq6>. Fixed typos in L<perlfaq8>. Added
1408mail sending example to L<perlfaq9>. Added Merlyn's columns to
1409L<perlfaq2>.
1410
46fc3d4c 1411=item 18/March/97
3fe9a6f1 1412
1413Added the DATE to the NAME section, indicating which sections have
1414changed.
1415
1416Mentioned SIGPIPE and L<perlipc> in the forking open answer in
1417L<perlfaq8>.
1418
1419Fixed description of a regular expression in L<perlfaq4>.
1420
68dc0745 1421=item 17/March/97 Version
1422
1423Various typos fixed throughout.
1424
1425Added new question on Perl BNF on L<perlfaq7>.
1426
1427=item Initial Release: 11/March/97
1428
1429This is the initial release of version 3 of the FAQ; consequently there
1430have been no changes since its initial release.
1431
1432=back