The perl executable, normally installed in /usr/bin or /usr/local/bin on your machine, is also called the perl interpreter . Every Perl program must be passed through the Perl interpreter in order to execute. The first line in many Perl programs is something like:
#!/usr/bin/perl
For Unix systems, this
#!
(hash-bang or shebang) line tells the shell to look for the
/usr/bin/perl
program and pass the rest of the file to that program for execution. Sometimes you'll see different pathnames to the Perl executable, such as
/usr/local/bin/perl
. You might see
perl5
instead of
perl
on sites that still depend on older versions of Perl. Or you'll see command-line options tacked on the end, such as the notorious
-w
switch, which produces warning messages. But almost all Perl programs on Unix start with some variation of this line.
If you get a mysterious "Command not found" error on a Perl program, it's often because the path to the Perl executable is wrong. When you download Perl programs off the Internet, copy them from one machine to another, or copy them out of a book (like this one!), the first thing you should do is make sure that the
#!
line points to the location of the Perl interpreter on your system.
So what does the Perl interpreter do? It compiles the program internally into a parse tree and then executes it immediately. Perl is commonly known as an interpreted language, but this is not strictly true. Since the interpreter actually does convert the program into byte code before executing it, it is sometimes called an interpreter/compiler , if anything at all. [ 1 ] Although the compiled form is not stored as a file, release 5.005 of Perl includes a working version of a standalone Perl compiler.
[1] So do you call something a Perl "script" or a Perl "program"? Typically, the word "program" is used to describe something that needs to be compiled into assembler or byte code before executing, as in the C language, and the word "script" is used to describe something that runs through an interpreter, as in the Bourne shell. For Perl, you can use either phrase and not worry about offending anyone.
What does all this brouhaha mean for you? When you write a Perl program, you can just give it a correct
#!
line at the top of the script, make it executable with
chmod +x
, and run it. For 95% of Perl programmers in this world, that's all you'll care about.
In addition to specifying a
#!
line, you can also specify a short script directly on the command line. Here are some of the possible ways to run Perl:
Issue the perl command, writing your script line by line via -e switches on the command line:
perl -e 'print "Hello, world\n"' #Unix perl -e "print \"Hello, world\n\"" #Win32
Issue the perl command, passing Perl the name of your script as the first parameter (after any switches):
perl testpgm
On Unix systems that support the
#!
notation, specify the Perl command on the
#!
line, make your script executable, and invoke it from the shell (as described above).
Pass your script to Perl via standard input. For example, under Unix:
echo "print 'Hello, world'" | perl -
or (unless
ignoreeof
is set):
% perl print "Hello, world\n"; ^D
On Win32 systems, you can associate an extension (e.g., .plx ) with a file type and double-click on the icon for a Perl script with that file type. If you are using the ActiveState version of Win32 Perl, the installation script normally prompts you to create the association.
On Win32 systems, if you double-click on the icon for the Perl executable, you'll find yourself in a command-prompt window, with a blinking cursor. You can enter your Perl commands, indicating the end of your input with CTRL-Z, and Perl will compile and execute your script.
Perl parses the input file from the beginning, unless you've specified the
-x
switch (see the section "Command-Line Options" below). If there is a
#!
line, it is always examined for switches as the line is being parsed. Thus, switches behave consistently regardless of how Perl was invoked.
After locating your script, Perl compiles the entire script into an internal form. If there are any compilation errors, execution of the script is not attempted. If the script is syntactically correct, it is executed. If the script runs off the end without hitting an
exit
or
die
operator, an implicit
exit(0)
is provided to indicate successful completion.