diff options
Diffstat (limited to 'contrib/perl5/pod/perlfaq.pod')
-rw-r--r-- | contrib/perl5/pod/perlfaq.pod | 1430 |
1 files changed, 0 insertions, 1430 deletions
diff --git a/contrib/perl5/pod/perlfaq.pod b/contrib/perl5/pod/perlfaq.pod deleted file mode 100644 index bc29c69..0000000 --- a/contrib/perl5/pod/perlfaq.pod +++ /dev/null @@ -1,1430 +0,0 @@ -=head1 NAME - -perlfaq - frequently asked questions about Perl ($Date: 1999/05/23 20:38:02 $) - -=head1 DESCRIPTION - -The perlfaq is structured into the following documents: - - -=head2 perlfaq: Structural overview of the FAQ. - -This document. - -=head2 L<perlfaq1>: General Questions About Perl - -Very general, high-level information about Perl. - -=over 4 - -=item * - -What is Perl? - -=item * - -Who supports Perl? Who develops it? Why is it free? - -=item * - -Which version of Perl should I use? - -=item * - -What are perl4 and perl5? - -=item * - -What is perl6? - -=item * - -How stable is Perl? - -=item * - -Is Perl difficult to learn? - -=item * - -How does Perl compare with other languages like Java, Python, REXX, Scheme, or Tcl? - -=item * - -Can I do [task] in Perl? - -=item * - -When shouldn't I program in Perl? - -=item * - -What's the difference between "perl" and "Perl"? - -=item * - -Is it a Perl program or a Perl script? - -=item * - -What is a JAPH? - -=item * - -Where can I get a list of Larry Wall witticisms? - -=item * - -How can I convince my sysadmin/supervisor/employees to use version 5/5.005/Perl instead of some other language? - -=back - - -=head2 L<perlfaq2>: Obtaining and Learning about Perl - -Where to find source and documentation to Perl, support, -and related matters. - -=over 4 - -=item * - -What machines support Perl? Where do I get it? - -=item * - -How can I get a binary version of Perl? - -=item * - -I don't have a C compiler on my system. How can I compile perl? - -=item * - -I copied the Perl binary from one machine to another, but scripts don't work. - -=item * - -I grabbed the sources and tried to compile but gdbm/dynamic loading/malloc/linking/... failed. How do I make it work? - -=item * - -What modules and extensions are available for Perl? What is CPAN? What does CPAN/src/... mean? - -=item * - -Is there an ISO or ANSI certified version of Perl? - -=item * - -Where can I get information on Perl? - -=item * - -What are the Perl newsgroups on Usenet? Where do I post questions? - -=item * - -Where should I post source code? - -=item * - -Perl Books - -=item * - -Perl in Magazines - -=item * - -Perl on the Net: FTP and WWW Access - -=item * - -What mailing lists are there for Perl? - -=item * - -Archives of comp.lang.perl.misc - -=item * - -Where can I buy a commercial version of Perl? - -=item * - -Where do I send bug reports? - -=item * - -What is perl.com? Perl Mongers? pm.org? perl.org? - -=back - - -=head2 L<perlfaq3>: Programming Tools - -Programmer tools and programming support. - -=over 4 - -=item * - -How do I do (anything)? - -=item * - -How can I use Perl interactively? - -=item * - -Is there a Perl shell? - -=item * - -How do I debug my Perl programs? - -=item * - -How do I profile my Perl programs? - -=item * - -How do I cross-reference my Perl programs? - -=item * - -Is there a pretty-printer (formatter) for Perl? - -=item * - -Is there a ctags for Perl? - -=item * - -Is there an IDE or Windows Perl Editor? - -=item * - -Where can I get Perl macros for vi? - -=item * - -Where can I get perl-mode for emacs? - -=item * - -How can I use curses with Perl? - -=item * - -How can I use X or Tk with Perl? - -=item * - -How can I generate simple menus without using CGI or Tk? - -=item * - -What is undump? - -=item * - -How can I make my Perl program run faster? - -=item * - -How can I make my Perl program take less memory? - -=item * - -Is it unsafe to return a pointer to local data? - -=item * - -How can I free an array or hash so my program shrinks? - -=item * - -How can I make my CGI script more efficient? - -=item * - -How can I hide the source for my Perl program? - -=item * - -How can I compile my Perl program into byte code or C? - -=item * - -How can I compile Perl into Java? - -=item * - -How can I get C<#!perl> to work on [MS-DOS,NT,...]? - -=item * - -Can I write useful Perl programs on the command line? - -=item * - -Why don't Perl one-liners work on my DOS/Mac/VMS system? - -=item * - -Where can I learn about CGI or Web programming in Perl? - -=item * - -Where can I learn about object-oriented Perl programming? - -=item * - -Where can I learn about linking C with Perl? [h2xs, xsubpp] - -=item * - -I've read perlembed, perlguts, etc., but I can't embed perl in -my C program; what am I doing wrong? - -=item * - -When I tried to run my script, I got this message. What does it -mean? - -=item * - -What's MakeMaker? - -=back - - -=head2 L<perlfaq4>: Data Manipulation - -Manipulating numbers, dates, strings, arrays, hashes, and -miscellaneous data issues. - -=over 4 - -=item * - -Why am I getting long decimals (eg, 19.9499999999999) instead of the numbers I should be getting (eg, 19.95)? - -=item * - -Why isn't my octal data interpreted correctly? - -=item * - -Does Perl have a round() function? What about ceil() and floor()? Trig functions? - -=item * - -How do I convert bits into ints? - -=item * - -Why doesn't & work the way I want it to? - -=item * - -How do I multiply matrices? - -=item * - -How do I perform an operation on a series of integers? - -=item * - -How can I output Roman numerals? - -=item * - -Why aren't my random numbers random? - -=item * - -How do I find the week-of-the-year/day-of-the-year? - -=item * - -How do I find the current century or millennium? - -=item * - -How can I compare two dates and find the difference? - -=item * - -How can I take a string and turn it into epoch seconds? - -=item * - -How can I find the Julian Day? - -=item * - -How do I find yesterday's date? - -=item * - -Does Perl have a Year 2000 problem? Is Perl Y2K compliant? - -=item * - -How do I validate input? - -=item * - -How do I unescape a string? - -=item * - -How do I remove consecutive pairs of characters? - -=item * - -How do I expand function calls in a string? - -=item * - -How do I find matching/nesting anything? - -=item * - -How do I reverse a string? - -=item * - -How do I expand tabs in a string? - -=item * - -How do I reformat a paragraph? - -=item * - -How can I access/change the first N letters of a string? - -=item * - -How do I change the Nth occurrence of something? - -=item * - -How can I count the number of occurrences of a substring within a string? - -=item * - -How do I capitalize all the words on one line? - -=item * - -How can I split a [character] delimited string except when inside -[character]? (Comma-separated files) - -=item * - -How do I strip blank space from the beginning/end of a string? - -=item * - -How do I pad a string with blanks or pad a number with zeroes? - -=item * - -How do I extract selected columns from a string? - -=item * - -How do I find the soundex value of a string? - -=item * - -How can I expand variables in text strings? - -=item * - -What's wrong with always quoting "$vars"? - -=item * - -Why don't my <<HERE documents work? - -=item * - -What is the difference between a list and an array? - -=item * - -What is the difference between $array[1] and @array[1]? - -=item * - -How can I remove duplicate elements from a list or array? - -=item * - -How can I tell whether a list or array contains a certain element? - -=item * - -How do I compute the difference of two arrays? How do I compute the intersection of two arrays? - -=item * - -How do I test whether two arrays or hashes are equal? - -=item * - -How do I find the first array element for which a condition is true? - -=item * - -How do I handle linked lists? - -=item * - -How do I handle circular lists? - -=item * - -How do I shuffle an array randomly? - -=item * - -How do I process/modify each element of an array? - -=item * - -How do I select a random element from an array? - -=item * - -How do I permute N elements of a list? - -=item * - -How do I sort an array by (anything)? - -=item * - -How do I manipulate arrays of bits? - -=item * - -Why does defined() return true on empty arrays and hashes? - -=item * - -How do I process an entire hash? - -=item * - -What happens if I add or remove keys from a hash while iterating over it? - -=item * - -How do I look up a hash element by value? - -=item * - -How can I know how many entries are in a hash? - -=item * - -How do I sort a hash (optionally by value instead of key)? - -=item * - -How can I always keep my hash sorted? - -=item * - -What's the difference between "delete" and "undef" with hashes? - -=item * - -Why don't my tied hashes make the defined/exists distinction? - -=item * - -How do I reset an each() operation part-way through? - -=item * - -How can I get the unique keys from two hashes? - -=item * - -How can I store a multidimensional array in a DBM file? - -=item * - -How can I make my hash remember the order I put elements into it? - -=item * - -Why does passing a subroutine an undefined element in a hash create it? - -=item * - -How can I make the Perl equivalent of a C structure/C++ class/hash or array of hashes or arrays? - -=item * - -How can I use a reference as a hash key? - -=item * - -How do I handle binary data correctly? - -=item * - -How do I determine whether a scalar is a number/whole/integer/float? - -=item * - -How do I keep persistent data across program calls? - -=item * - -How do I print out or copy a recursive data structure? - -=item * - -How do I define methods for every class/object? - -=item * - -How do I verify a credit card checksum? - -=item * - -How do I pack arrays of doubles or floats for XS code? - -=back - - -=head2 L<perlfaq5>: Files and Formats - -I/O and the "f" issues: filehandles, flushing, formats and footers. - -=over 4 - -=item * - -How do I flush/unbuffer an output filehandle? Why must I do this? - -=item * - -How 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? - -=item * - -How do I count the number of lines in a file? - -=item * - -How do I make a temporary file name? - -=item * - -How can I manipulate fixed-record-length files? - -=item * - -How can I make a filehandle local to a subroutine? How do I pass filehandles between subroutines? How do I make an array of filehandles? - -=item * - -How can I use a filehandle indirectly? - -=item * - -How can I set up a footer format to be used with write()? - -=item * - -How can I write() into a string? - -=item * - -How can I output my numbers with commas added? - -=item * - -How can I translate tildes (~) in a filename? - -=item * - -How come when I open a file read-write it wipes it out? - -=item * - -Why do I sometimes get an "Argument list too long" when I use <*>? - -=item * - -Is there a leak/bug in glob()? - -=item * - -How can I open a file with a leading ">" or trailing blanks? - -=item * - -How can I reliably rename a file? - -=item * - -How can I lock a file? - -=item * - -Why can't I just open(FH, ">file.lock")? - -=item * - -I still don't get locking. I just want to increment the number in the file. How can I do this? - -=item * - -How do I randomly update a binary file? - -=item * - -How do I get a file's timestamp in perl? - -=item * - -How do I set a file's timestamp in perl? - -=item * - -How do I print to more than one file at once? - -=item * - -How can I read in an entire file all at once? - -=item * - -How can I read in a file by paragraphs? - -=item * - -How can I read a single character from a file? From the keyboard? - -=item * - -How can I tell whether there's a character waiting on a filehandle? - -=item * - -How do I do a C<tail -f> in perl? - -=item * - -How do I dup() a filehandle in Perl? - -=item * - -How do I close a file descriptor by number? - -=item * - -Why can't I use "C:\temp\foo" in DOS paths? What doesn't `C:\temp\foo.exe` work? - -=item * - -Why doesn't glob("*.*") get all the files? - -=item * - -Why does Perl let me delete read-only files? Why does C<-i> clobber protected files? Isn't this a bug in Perl? - -=item * - -How do I select a random line from a file? - -=item * - -Why do I get weird spaces when I print an array of lines? - -=back - - -=head2 L<perlfaq6>: Regexps - -Pattern matching and regular expressions. - -=over 4 - -=item * - -How can I hope to use regular expressions without creating illegible and unmaintainable code? - -=item * - -I'm having trouble matching over more than one line. What's wrong? - -=item * - -How can I pull out lines between two patterns that are themselves on different lines? - -=item * - -I put a regular expression into $/ but it didn't work. What's wrong? - -=item * - -How do I substitute case insensitively on the LHS while preserving case on the RHS? - -=item * - -How can I make C<\w> match national character sets? - -=item * - -How can I match a locale-smart version of C</[a-zA-Z]/>? - -=item * - -How can I quote a variable to use in a regex? - -=item * - -What is C</o> really for? - -=item * - -How do I use a regular expression to strip C style comments from a file? - -=item * - -Can I use Perl regular expressions to match balanced text? - -=item * - -What does it mean that regexes are greedy? How can I get around it? - -=item * - -How do I process each word on each line? - -=item * - -How can I print out a word-frequency or line-frequency summary? - -=item * - -How can I do approximate matching? - -=item * - -How do I efficiently match many regular expressions at once? - -=item * - -Why don't word-boundary searches with C<\b> work for me? - -=item * - -Why does using $&, $`, or $' slow my program down? - -=item * - -What good is C<\G> in a regular expression? - -=item * - -Are Perl regexes DFAs or NFAs? Are they POSIX compliant? - -=item * - -What's wrong with using grep or map in a void context? - -=item * - -How can I match strings with multibyte characters? - -=item * - -How do I match a pattern that is supplied by the user? - -=back - - -=head2 L<perlfaq7>: General Perl Language Issues - -General Perl language issues that don't clearly fit into any of the -other sections. - -=over 4 - -=item * - -Can I get a BNF/yacc/RE for the Perl language? - -=item * - -What are all these $@%&* punctuation signs, and how do I know when to use them? - -=item * - -Do I always/never have to quote my strings or use semicolons and commas? - -=item * - -How do I skip some return values? - -=item * - -How do I temporarily block warnings? - -=item * - -What's an extension? - -=item * - -Why do Perl operators have different precedence than C operators? - -=item * - -How do I declare/create a structure? - -=item * - -How do I create a module? - -=item * - -How do I create a class? - -=item * - -How can I tell if a variable is tainted? - -=item * - -What's a closure? - -=item * - -What is variable suicide and how can I prevent it? - -=item * - -How can I pass/return a {Function, FileHandle, Array, Hash, Method, Regex}? - -=item * - -How do I create a static variable? - -=item * - -What's the difference between dynamic and lexical (static) scoping? Between local() and my()? - -=item * - -How can I access a dynamic variable while a similarly named lexical is in scope? - -=item * - -What's the difference between deep and shallow binding? - -=item * - -Why doesn't "my($foo) = <FILE>;" work right? - -=item * - -How do I redefine a builtin function, operator, or method? - -=item * - -What's the difference between calling a function as &foo and foo()? - -=item * - -How do I create a switch or case statement? - -=item * - -How can I catch accesses to undefined variables/functions/methods? - -=item * - -Why can't a method included in this same file be found? - -=item * - -How can I find out my current package? - -=item * - -How can I comment out a large block of perl code? - -=item * - -How do I clear a package? - -=item * - -How can I use a variable as a variable name? - -=back - - -=head2 L<perlfaq8>: System Interaction - -Interprocess communication (IPC), control over the user-interface -(keyboard, screen and pointing devices). - -=over 4 - -=item * - -How do I find out which operating system I'm running under? - -=item * - -How come exec() doesn't return? - -=item * - -How do I do fancy stuff with the keyboard/screen/mouse? - -=item * - -How do I print something out in color? - -=item * - -How do I read just one key without waiting for a return key? - -=item * - -How do I check whether input is ready on the keyboard? - -=item * - -How do I clear the screen? - -=item * - -How do I get the screen size? - -=item * - -How do I ask the user for a password? - -=item * - -How do I read and write the serial port? - -=item * - -How do I decode encrypted password files? - -=item * - -How do I start a process in the background? - -=item * - -How do I trap control characters/signals? - -=item * - -How do I modify the shadow password file on a Unix system? - -=item * - -How do I set the time and date? - -=item * - -How can I sleep() or alarm() for under a second? - -=item * - -How can I measure time under a second? - -=item * - -How can I do an atexit() or setjmp()/longjmp()? (Exception handling) - -=item * - -Why doesn't my sockets program work under System V (Solaris)? What does the error message "Protocol not supported" mean? - -=item * - -How can I call my system's unique C functions from Perl? - -=item * - -Where do I get the include files to do ioctl() or syscall()? - -=item * - -Why do setuid perl scripts complain about kernel problems? - -=item * - -How can I open a pipe both to and from a command? - -=item * - -Why can't I get the output of a command with system()? - -=item * - -How can I capture STDERR from an external command? - -=item * - -Why doesn't open() return an error when a pipe open fails? - -=item * - -What's wrong with using backticks in a void context? - -=item * - -How can I call backticks without shell processing? - -=item * - -Why can't my script read from STDIN after I gave it EOF (^D on Unix, ^Z on MS-DOS)? - -=item * - -How can I convert my shell script to perl? - -=item * - -Can I use perl to run a telnet or ftp session? - -=item * - -How can I write expect in Perl? - -=item * - -Is there a way to hide perl's command line from programs such as "ps"? - -=item * - -I {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? - -=item * - -How do I close a process's filehandle without waiting for it to complete? - -=item * - -How do I fork a daemon process? - -=item * - -How do I find out if I'm running interactively or not? - -=item * - -How do I timeout a slow event? - -=item * - -How do I set CPU limits? - -=item * - -How do I avoid zombies on a Unix system? - -=item * - -How do I use an SQL database? - -=item * - -How do I make a system() exit on control-C? - -=item * - -How do I open a file without blocking? - -=item * - -How do I install a module from CPAN? - -=item * - -What's the difference between require and use? - -=item * - -How do I keep my own module/library directory? - -=item * - -How do I add the directory my program lives in to the module/library search path? - -=item * - -How do I add a directory to my include path at runtime? - -=item * - -What is socket.ph and where do I get it? - -=back - - -=head2 L<perlfaq9>: Networking - -Networking, the Internet, and a few on the web. - -=over 4 - -=item * - -My CGI script runs from the command line but not the browser. (500 Server Error) - -=item * - -How can I get better error messages from a CGI program? - -=item * - -How do I remove HTML from a string? - -=item * - -How do I extract URLs? - -=item * - -How do I download a file from the user's machine? How do I open a file on another machine? - -=item * - -How do I make a pop-up menu in HTML? - -=item * - -How do I fetch an HTML file? - -=item * - -How do I automate an HTML form submission? - -=item * - -How do I decode or create those %-encodings on the web? - -=item * - -How do I redirect to another page? - -=item * - -How do I put a password on my web pages? - -=item * - -How do I edit my .htpasswd and .htgroup files with Perl? - -=item * - -How do I make sure users can't enter values into a form that cause my CGI script to do bad things? - -=item * - -How do I parse a mail header? - -=item * - -How do I decode a CGI form? - -=item * - -How do I check a valid mail address? - -=item * - -How do I decode a MIME/BASE64 string? - -=item * - -How do I return the user's mail address? - -=item * - -How do I send mail? - -=item * - -How do I read mail? - -=item * - -How do I find out my hostname/domainname/IP address? - -=item * - -How do I fetch a news article or the active newsgroups? - -=item * - -How do I fetch/put an FTP file? - -=item * - -How can I do RPC in Perl? - -=back - - -=head1 About the perlfaq documents - -=head2 Where to get the perlfaq - -This document is posted regularly to comp.lang.perl.announce and -several other related newsgroups. It is available in a variety of -formats from CPAN in the /CPAN/doc/FAQs/FAQ/ directory or on the web -at http://www.perl.com/perl/faq/ . - -=head2 How to contribute to the perlfaq - -You may mail corrections, additions, and suggestions to -perlfaq-suggestions@perl.com . This alias should not be -used to I<ask> FAQs. It's for fixing the current FAQ. -Send questions to the comp.lang.perl.misc newsgroup. - -=head2 What will happen if you mail your Perl programming problems to the authors - -Your questions will probably go unread, unless they're suggestions of -new questions to add to the FAQ, in which case they should have gone -to the perlfaq-suggestions@perl.com instead. - -You should have read section 2 of this faq. There you would have -learned that comp.lang.perl.misc is the appropriate place to go for -free advice. If your question is really important and you require a -prompt and correct answer, you should hire a consultant. - -=head1 Credits - -When I first began the Perl FAQ in the late 80s, I never realized it -would have grown to over a hundred pages, nor that Perl would ever become -so popular and widespread. This document could not have been written -without the tremendous help provided by Larry Wall and the rest of the -Perl Porters. - -=head1 Author and Copyright Information - -Copyright (c) 1997-1999 Tom Christiansen and Nathan Torkington. -All rights reserved. - -=head2 Bundled Distributions - -When included as part of the Standard Version of Perl or as part of -its complete documentation whether printed or otherwise, this work -may be distributed only under the terms of Perl's Artistic License. -Any distribution of this file or derivatives thereof I<outside> -of that package requires that special arrangements be made with -copyright holder. - -Irrespective of its distribution, all code examples in these files -are hereby placed into the public domain. You are permitted and -encouraged to use this code in your own programs for fun -or for profit as you see fit. A simple comment in the code giving -credit would be courteous but is not required. - -=head2 Disclaimer - -This information is offered in good faith and in the hope that it may -be of use, but is not guaranteed to be correct, up to date, or suitable -for any particular purpose whatsoever. The authors accept no liability -in respect of this information or its use. - -=head1 Changes - -=over 4 - -=item 1/November/2000 - -A few grammatical fixes and updates implemented by John Borwick. - -=item 23/May/99 - -Extensive updates from the net in preparation for 5.6 release. - -=item 13/April/99 - -More minor touch-ups. Added new question at the end -of perlfaq7 on variable names within variables. - -=item 7/January/99 - -Small touchups here and there. Added all questions in this -document as a sort of table of contents. - -=item 22/June/98 - -Significant changes throughout in preparation for the 5.005 -release. - -=item 24/April/97 - -Style and whitespace changes from Chip, new question on reading one -character at a time from a terminal using POSIX from Tom. - -=item 23/April/97 - -Added http://www.oasis.leo.org/perl/ to L<perlfaq2>. Style fix to -L<perlfaq3>. Added floating point precision, fixed complex number -arithmetic, cross-references, caveat for Text::Wrap, alternative -answer for initial capitalizing, fixed incorrect regexp, added example -of Tie::IxHash to L<perlfaq4>. Added example of passing and storing -filehandles, added commify to L<perlfaq5>. Restored variable suicide, -and added mass commenting to L<perlfaq7>. Added Net::Telnet, fixed -backticks, added reader/writer pair to telnet question, added FindBin, -grouped module questions together in L<perlfaq8>. Expanded caveats -for the simple URL extractor, gave LWP example, added CGI security -question, expanded on the mail address answer in L<perlfaq9>. - -=item 25/March/97 - -Added more info to the binary distribution section of L<perlfaq2>. -Added Net::Telnet to L<perlfaq6>. Fixed typos in L<perlfaq8>. Added -mail sending example to L<perlfaq9>. Added Merlyn's columns to -L<perlfaq2>. - -=item 18/March/97 - -Added the DATE to the NAME section, indicating which sections have -changed. - -Mentioned SIGPIPE and L<perlipc> in the forking open answer in -L<perlfaq8>. - -Fixed description of a regular expression in L<perlfaq4>. - -=item 17/March/97 Version - -Various typos fixed throughout. - -Added new question on Perl BNF on L<perlfaq7>. - -=item Initial Release: 11/March/97 - -This is the initial release of version 3 of the FAQ; consequently there -have been no changes since its initial release. - -=back |