2000-10-17 02:51:03 +00:00
|
|
|
.\" Copyright (c) 2000 Josef Karthauser <joe@FreeBSD.org>
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL [your name] OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
|
|
|
.\" $FreeBSD$
|
|
|
|
.\"
|
|
|
|
.Dd October 16, 2000
|
|
|
|
.Dt STYLE.PERL 7
|
|
|
|
.Os FreeBSD
|
|
|
|
.Sh NAME
|
|
|
|
.Nm style.perl 7
|
|
|
|
.Nd "FreeBSD Perl source file style guide"
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
This file specifies the preferred style for perl scripts in the
|
|
|
|
.Tn FreeBSD
|
|
|
|
source tree.
|
|
|
|
.Bd -literal -offset 0i
|
|
|
|
#
|
|
|
|
# Style guide for Perl. Based on the kernel style guide.
|
|
|
|
#
|
|
|
|
|
|
|
|
#
|
|
|
|
# VERY important single-line comments look like this.
|
|
|
|
#
|
|
|
|
|
|
|
|
# Most single-line comments look like this.
|
|
|
|
|
|
|
|
# Multi-line comments look like this. Make them real sentences.
|
|
|
|
# Fill them so they look like real paragraphs.
|
|
|
|
.Ed
|
|
|
|
.Pp
|
2000-10-17 15:32:57 +00:00
|
|
|
All scripts should use the
|
|
|
|
.Fa strict
|
|
|
|
module and run without warnings. For example:
|
2000-10-17 02:51:03 +00:00
|
|
|
.Bd -literal -offset 0i
|
|
|
|
#!/usr/bin/perl -w
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
...
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Where possible run the script with taint mode switched on. This
|
|
|
|
is documented in
|
|
|
|
.Xr perlsec 1 .
|
|
|
|
.Bd -literal -offset 0i
|
|
|
|
#!/usr/bin/perl -wT
|
|
|
|
.Ed
|
|
|
|
.Pp
|
2000-10-18 17:21:54 +00:00
|
|
|
The main program should be placed in a block labeled MAIN:. This
|
|
|
|
makes it easier to identify the entry point in a large perl script,
|
|
|
|
and provides a scope for variables which are used in the main
|
|
|
|
program but nowhere else.
|
|
|
|
.Bd -literal -offset 0i
|
|
|
|
MAIN:{
|
|
|
|
print(foo("/usr/bin/man", "7", "style.perl"));
|
|
|
|
exit(0);
|
|
|
|
}
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
All subroutines should be defined using argument prototypes as defined in
|
|
|
|
.Xr perlsub 1 .
|
|
|
|
.Bd -literal -offset 0i
|
|
|
|
sub foo($@) {
|
|
|
|
my $cmd = shift;
|
|
|
|
my @args = @_;
|
|
|
|
}
|
|
|
|
.Ed
|
|
|
|
.Pp
|
2000-10-17 15:32:57 +00:00
|
|
|
All variables should be defined before use; this is enforced if operating
|
|
|
|
under
|
|
|
|
.Fa use strict .
|
2000-10-17 02:51:03 +00:00
|
|
|
.Pp
|
2000-10-17 15:32:57 +00:00
|
|
|
Scope local variables should be defined using
|
|
|
|
.Fa my
|
|
|
|
.Va $variable
|
|
|
|
and not
|
|
|
|
.Fa local
|
|
|
|
.Va $variable .
|
|
|
|
The
|
|
|
|
.Fa local
|
|
|
|
declaration should only be used when it is required, and not by
|
|
|
|
default. Lots of perl4 scripts use
|
|
|
|
.Fa local
|
|
|
|
because the
|
|
|
|
.Fa my
|
|
|
|
definition didn't exist prior to perl5.
|
2000-10-17 02:51:03 +00:00
|
|
|
.Pp
|
2000-10-17 15:32:57 +00:00
|
|
|
In most cases globals should be defined at the top of the code
|
|
|
|
using a
|
2000-10-18 17:12:07 +00:00
|
|
|
.Fa vars
|
2000-10-17 15:32:57 +00:00
|
|
|
definition block:
|
|
|
|
.Bd -literal -offset 0i
|
2000-10-17 15:50:22 +00:00
|
|
|
use vars qw($globalscalar @globalarray %globalhash);
|
2000-10-17 15:32:57 +00:00
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
In some cases it may be appropriate to use
|
|
|
|
.Fa my
|
|
|
|
statements at the top of the script as an alternative to using
|
2000-10-18 17:12:07 +00:00
|
|
|
.Fa vars
|
2000-10-17 15:32:57 +00:00
|
|
|
declarations.
|
|
|
|
.Pp
|
2000-10-18 17:25:59 +00:00
|
|
|
All variables should be commented.
|
|
|
|
.Bd -literal -offset 0i
|
|
|
|
sub foo($@) {
|
|
|
|
my $cmd = shift; # Command to run
|
|
|
|
my @args = @_; # Arguments to $cmd
|
|
|
|
}
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Local variables should be separated from function arguments by a
|
|
|
|
blank line:
|
|
|
|
.Bd -literal -offset 0i
|
|
|
|
sub foo($@) {
|
|
|
|
my $cmd = shift; # Command to run
|
|
|
|
my @args = @_; # Arguments to command
|
|
|
|
|
|
|
|
my $pid; # Child PID
|
|
|
|
local *PIPE; # Pipe
|
|
|
|
my $output; # Output from command
|
2000-10-18 17:48:10 +00:00
|
|
|
}
|
2000-10-18 17:25:59 +00:00
|
|
|
.Ed
|
|
|
|
.Pp
|
2000-10-17 15:32:57 +00:00
|
|
|
Whenever possible code should be run through the code checker
|
|
|
|
.Nm perl
|
|
|
|
.Ar -wc
|
|
|
|
.Ar script.pl
|
|
|
|
or
|
|
|
|
.Nm perl
|
|
|
|
.Ar -wcT
|
|
|
|
.Ar script.pl
|
|
|
|
and produce no warnings.
|
|
|
|
.Pp
|
2000-10-18 17:48:10 +00:00
|
|
|
Opening braces should be at the end of the controlling line. Else
|
|
|
|
and elsif belong on the same line as the closing brace for the
|
|
|
|
previous if or elsif block:
|
|
|
|
.Bd -literal -offset 0i
|
|
|
|
sub foo($@) {
|
|
|
|
my $cmd = shift; # Command to run
|
|
|
|
my @args = @_; # Arguments to command
|
|
|
|
|
|
|
|
my $pid; # Child PID
|
|
|
|
local *PIPE; # Pipe
|
|
|
|
my $output; # Output from command
|
|
|
|
|
|
|
|
unless (defined($pid = open(PIPE, "-|"))) {
|
|
|
|
die("open(): $!\\n");
|
|
|
|
} elsif ($pid == 0) {
|
|
|
|
exec($cmd, @args);
|
|
|
|
die("exec(): $!\\n");
|
|
|
|
}
|
|
|
|
$output = "";
|
|
|
|
while (<PIPE>) {
|
|
|
|
$output .= $_;
|
|
|
|
}
|
|
|
|
waitpid($pid, 0);
|
|
|
|
if ($? & 0xff) {
|
|
|
|
die("$cmd caught a signal " . ($? & 0x7f) . "\\n");
|
|
|
|
} elsif ($?) {
|
|
|
|
die("$cmd returned exit code " . ($? >> 8) . "\\n");
|
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
.Ed
|
|
|
|
.Pp
|
2000-10-17 15:32:57 +00:00
|
|
|
Indentation and block style should follow
|
|
|
|
.Xr style 9
|
|
|
|
where applicable.
|
|
|
|
.Pp
|
|
|
|
Where possible scripts should use standard modules instead of
|
|
|
|
rewriting the code inline. It may be appropriate in some cases to
|
|
|
|
import a CPAN module into the base system to facilitate this.
|
|
|
|
.Pp
|
|
|
|
Use
|
|
|
|
.Fa chomp
|
|
|
|
instead of
|
|
|
|
.Fa chop
|
|
|
|
where appropriate.
|
2000-10-17 02:51:03 +00:00
|
|
|
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr perlsec 1 ,
|
|
|
|
.Xr style 9
|
|
|
|
.Sh HISTORY
|
|
|
|
This man page is largely based on the
|
|
|
|
.Xr style 9
|
|
|
|
man-page in
|
|
|
|
.Tn FreeBSD .
|