.\" -*- mode: troff; coding: utf-8 -*-
.\" Automatically generated by Pod::Man 5.01 (Pod::Simple 3.43)
.\"
.\" Standard preamble:
.\" ========================================================================
.de Sp \" Vertical space (when we can't use .PP)
.if t .sp .5v
.if n .sp
..
.de Vb \" Begin verbatim text
.ft CW
.nf
.ne \\$1
..
.de Ve \" End verbatim text
.ft R
.fi
..
.\" \*(C` and \*(C' are quotes in nroff, nothing in troff, for use with C<>.
.ie n \{\
. ds C` ""
. ds C' ""
'br\}
.el\{\
. ds C`
. ds C'
'br\}
.\"
.\" Escape single quotes in literal strings from groff's Unicode transform.
.ie \n(.g .ds Aq \(aq
.el .ds Aq '
.\"
.\" If the F register is >0, we'll generate index entries on stderr for
.\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index
.\" entries marked with X<> in POD. Of course, you'll have to process the
.\" output yourself in some meaningful fashion.
.\"
.\" Avoid warning from groff about undefined register 'F'.
.de IX
..
.nr rF 0
.if \n(.g .if rF .nr rF 1
.if (\n(rF:(\n(.g==0)) \{\
. if \nF \{\
. de IX
. tm Index:\\$1\t\\n%\t"\\$2"
..
. if !\nF==2 \{\
. nr % 0
. nr F 2
. \}
. \}
.\}
.rr rF
.\" ========================================================================
.\"
.IX Title "PERLFAQ2 1"
.TH PERLFAQ2 1 2024-01-12 "perl v5.38.2" "Perl Programmers Reference Guide"
.\" For nroff, turn off justification. Always turn off hyphenation; it makes
.\" way too many mistakes in technical documents.
.if n .ad l
.nh
.SH NAME
perlfaq2 \- Obtaining and Learning about Perl
.SH VERSION
.IX Header "VERSION"
version 5.20210520
.SH DESCRIPTION
.IX Header "DESCRIPTION"
This section of the FAQ answers questions about where to find
source and documentation for Perl, support, and
related matters.
.SS "What machines support Perl? Where do I get it?"
.IX Subsection "What machines support Perl? Where do I get it?"
The standard release of Perl (the one maintained by the Perl
development team) is distributed only in source code form. You
can find the latest releases at .
.PP
Perl builds and runs on a bewildering number of platforms. Virtually
all known and current Unix derivatives are supported (perl's native
platform), as are other systems like VMS, DOS, OS/2, Windows,
QNX, BeOS, OS X, MPE/iX and the Amiga.
.PP
Binary distributions for some proprietary platforms can be found
directory. Because these are not part of
the standard distribution, they may and in fact do differ from the
base perl port in a variety of ways. You'll have to check their
respective release notes to see just what the differences are. These
differences can be either positive (e.g. extensions for the features
of the particular platform that are not supported in the source
release of perl) or negative (e.g. might be based upon a less current
source release of perl).
.SS "How can I get a binary version of Perl?"
.IX Subsection "How can I get a binary version of Perl?"
See CPAN Ports
.SS "I don't have a C compiler. How can I build my own Perl interpreter?"
.IX Subsection "I don't have a C compiler. How can I build my own Perl interpreter?"
For Windows, use a binary version of Perl,
Strawberry Perl and
ActivePerl come with a
bundled C compiler.
.PP
Otherwise if you really do want to build Perl, you need to get a
binary version of \f(CW\*(C`gcc\*(C'\fR for your system first. Use a search
engine to find out how to do this for your operating system.
.SS "I copied the Perl binary from one machine to another, but scripts don't work."
.IX Subsection "I copied the Perl binary from one machine to another, but scripts don't work."
That's probably because you forgot libraries, or library paths differ.
You really should build the whole distribution on the machine it will
eventually live on, and then type \f(CW\*(C`make install\*(C'\fR. Most other
approaches are doomed to failure.
.PP
One simple way to check that things are in the right place is to print out
the hard-coded \f(CW@INC\fR that perl looks through for libraries:
.PP
.Vb 1
\& % perl \-le \*(Aqprint for @INC\*(Aq
.Ve
.PP
If this command lists any paths that don't exist on your system, then you
may need to move the appropriate libraries to these locations, or create
symbolic links, aliases, or shortcuts appropriately. \f(CW@INC\fR is also printed as
part of the output of
.PP
.Vb 1
\& % perl \-V
.Ve
.PP
You might also want to check out
"How do I keep my own module/library directory?" in perlfaq8.
.SS "I grabbed the sources and tried to compile but gdbm/dynamic loading/malloc/linking/... failed. How do I make it work?"
.IX Subsection "I grabbed the sources and tried to compile but gdbm/dynamic loading/malloc/linking/... failed. How do I make it work?"
Read the \fIINSTALL\fR file, which is part of the source distribution.
It describes in detail how to cope with most idiosyncrasies that the
\&\f(CW\*(C`Configure\*(C'\fR script can't work around for any given system or
architecture.
.SS "What modules and extensions are available for Perl? What is CPAN?"
.IX Subsection "What modules and extensions are available for Perl? What is CPAN?"
CPAN stands for Comprehensive Perl Archive Network, a multi-gigabyte
archive replicated on hundreds of machines all over the world. CPAN
contains tens of thousands of modules and extensions, source code
and documentation, designed for \fIeverything\fR from commercial
database interfaces to keyboard/screen control and running large web sites.
.PP
You can search CPAN on .
.PP
The master web site for CPAN is ,
lists all mirrors.
.PP
See the CPAN FAQ at for answers
to the most frequently asked questions about CPAN.
.PP
The Task::Kensho module has a list of recommended modules which
you should review as a good starting point.
.SS "Where can I get information on Perl?"
.IX Subsection "Where can I get information on Perl?"
.IP \(bu 4
.IP \(bu 4
.IP \(bu 4
.PP
The complete Perl documentation is available with the Perl distribution.
If you have Perl installed locally, you probably have the documentation
installed as well: type \f(CW\*(C`perldoc perl\*(C'\fR in a terminal or
view online .
.PP
(Some operating system distributions may ship the documentation in a different
package; for instance, on Debian, you need to install the \f(CW\*(C`perl\-doc\*(C'\fR package.)
.PP
Many good books have been written about Perl\-\-see the section later in
perlfaq2 for more details.
.SS "What is perl.com? Perl Mongers? pm.org? perl.org? cpan.org?"
.IX Subsection "What is perl.com? Perl Mongers? pm.org? perl.org? cpan.org?"
Perl.com used to be part of the O'Reilly
Network, a subsidiary of O'Reilly Media. Although it retains most of
the original content from its O'Reilly Network, it is now hosted by
The Perl Foundation .
.PP
The Perl Foundation is an advocacy organization for the Perl language
which maintains the web site as a general
advocacy site for the Perl language. It uses the domain to provide
general support services to the Perl community, including the hosting
of mailing lists, web sites, and other services. There are also many
other sub-domains for special topics like learning Perl and jobs in Perl,
such as:
.IP \(bu 4
.IP \(bu 4
.IP \(bu 4
.IP \(bu 4
.PP
Perl Mongers uses the pm.org domain for services
related to local Perl user groups, including the hosting of mailing lists
and web sites. See the Perl Mongers web site for more
information about joining, starting, or requesting services for a
Perl user group.
.PP
CPAN, or the Comprehensive Perl Archive Network ,
is a replicated, worldwide repository of Perl software.
See What is CPAN?.
.SS "Where can I post questions?"
.IX Subsection "Where can I post questions?"
There are many Perl mailing lists for various
topics, specifically the beginners list
may be of use.
.PP
Other places to ask questions are on the
PerlMonks site or
stackoverflow .
.SS "Perl Books"
.IX Subsection "Perl Books"
There are many good books on Perl .
.SS "Which magazines have Perl content?"
.IX Subsection "Which magazines have Perl content?"
There's also \fR\f(CI$foo\fR\fI Magazin\fR, a German magazine dedicated to Perl, at
( ). The \fIPerl-Zeitung\fR is another
German-speaking magazine for Perl beginners (see
).
.PP
Several Unix/Linux related magazines frequently include articles on Perl.
.SS "Which Perl blogs should I read?"
.IX Subsection "Which Perl blogs should I read?"
Perl News covers some of the major events in the Perl
world, Perl Weekly is a weekly e\-mail
(and RSS feed) of hand-picked Perl articles.
.PP
hosts many Perl blogs, there are also
several blog aggregators: Perlsphere and
IronMan are two of them.
.SS "What mailing lists are there for Perl?"
.IX Subsection "What mailing lists are there for Perl?"
A comprehensive list of Perl-related mailing lists can be found at
.SS "Where can I buy a commercial version of Perl?"
.IX Subsection "Where can I buy a commercial version of Perl?"
Perl already \fIis\fR commercial software: it has a license
that you can grab and carefully read to your manager. It is distributed
in releases and comes in well-defined packages. There is a very large
and supportive user community and an extensive literature.
.PP
If you still need commercial support
ActiveState offers
this.
.SS "Where do I send bug reports?"
.IX Subsection "Where do I send bug reports?"
(contributed by brian d foy)
.PP
First, ensure that you've found an actual bug. Second, ensure you've
found an actual bug.
.PP
If you've found a bug with the perl interpreter or one of the modules
in the standard library (those that come with Perl), you can submit a
bug report to the GitHub issue tracker at
.
.PP
To determine if a module came with your version of Perl, you can
install and use the Module::CoreList module. It has the information
about the modules (with their versions) included with each release
of Perl.
.PP
Every CPAN module has a bug tracker set up in RT, .
You can submit bugs to RT either through its web interface or by
email. To email a bug report, send it to
bug\-@rt.cpan.org . For example, if you
wanted to report a bug in Business::ISBN, you could send a message to
bug\-Business\-ISBN@rt.cpan.org .
.PP
Some modules might have special reporting requirements, such as a
GitHub or Google Code tracking system, so you should check the
module documentation too.
.SH "AUTHOR AND COPYRIGHT"
.IX Header "AUTHOR AND COPYRIGHT"
Copyright (c) 1997\-2010 Tom Christiansen, Nathan Torkington, and
other authors as noted. All rights reserved.
.PP
This documentation is free; you can redistribute it and/or modify it
under the same terms as Perl itself.
.PP
Irrespective of its distribution, all code examples here are in the public
domain. You are permitted and encouraged to use this code and any
derivatives thereof in your own programs for fun or for profit as you
see fit. A simple comment in the code giving credit to the FAQ would
be courteous but is not required.