X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=pod%2Fperlsyn.pod;h=aabd65d21268a984953d39cd4e796c7c259a36e7;hb=1bf2966364b6356e9050b17d8920dd4a8ce27d97;hp=257938ce5310434b5062b93cdbf2fd2e6d0ba6a3;hpb=110b9c83de6ca99faf93da8a9079d29a08f75f22;p=p5sagit%2Fp5-mst-13.2.git diff --git a/pod/perlsyn.pod b/pod/perlsyn.pod index 257938c..aabd65d 100644 --- a/pod/perlsyn.pod +++ b/pod/perlsyn.pod @@ -28,16 +28,16 @@ see L for information about how they differ. =head2 Declarations -The only things you need to declare in Perl are report formats -and subroutines--and even undefined subroutines can be handled -through AUTOLOAD. A variable holds the undefined value (C) -until it has been assigned a defined value, which is anything -other than C. When used as a number, C is treated -as C<0>; when used as a string, it is treated the empty string, -C<"">; and when used as a reference that isn't being assigned -to, it is treated as an error. If you enable warnings, you'll -be notified of an uninitialized value whenever you treat C -as a string or a number. Well, usually. Boolean contexts, such as: +The only things you need to declare in Perl are report formats and +subroutines (and sometimes not even subroutines). A variable holds +the undefined value (C) until it has been assigned a defined +value, which is anything other than C. When used as a number, +C is treated as C<0>; when used as a string, it is treated as +the empty string, C<"">; and when used as a reference that isn't being +assigned to, it is treated as an error. If you enable warnings, +you'll be notified of an uninitialized value whenever you treat +C as a string or a number. Well, usually. Boolean contexts, +such as: my $a; if ($a) {} @@ -94,11 +94,19 @@ expression. The only kind of simple statement is an expression evaluated for its side effects. Every simple statement must be terminated with a semicolon, unless it is the final statement in a block, in which case -the semicolon is optional. (A semicolon is still encouraged there if the -block takes up more than one line, because you may eventually add another line.) -Note that there are some operators like C and C that look -like compound statements, but aren't (they're just TERMs in an expression), -and thus need an explicit termination if used as the last item in a statement. +the semicolon is optional. (A semicolon is still encouraged if the +block takes up more than one line, because you may eventually add +another line.) Note that there are some operators like C and +C that look like compound statements, but aren't (they're just +TERMs in an expression), and thus need an explicit termination if used +as the last item in a statement. + +=head2 Truth and Falsehood + +The number 0, the strings C<'0'> and C<''>, the empty list C<()>, and +C are all false in a boolean context. All other values are true. + +=head2 Statement Modifiers Any simple statement may optionally be followed by a I modifier, just before the terminating semicolon (or block ending). The possible @@ -108,16 +116,36 @@ modifiers are: unless EXPR while EXPR until EXPR - foreach EXPR - -The C and C modifiers have the expected semantics, -presuming you're a speaker of English. The C modifier is an -iterator: For each value in EXPR, it aliases C<$_> to the value and -executes the statement. The C and C modifiers have the -usual "C loop" semantics (conditional evaluated first), except -when applied to a C-BLOCK (or to the deprecated C-SUBROUTINE -statement), in which case the block executes once before the -conditional is evaluated. This is so that you can write loops like: + foreach LIST + +The C following the modifier is referred to as the "condition". +Its truth or falsehood determines how the modifier will behave. + +C executes the statement once I and only if the condition is +true. C is the opposite, it executes the statement I +the condition is true (i.e., if the condition is false). + + print "Basset hounds got long ears" if length $ear >= 10; + go_outside() and play() unless $is_raining; + +The C modifier is an iterator: it executes the statement once +for each item in the LIST (with C<$_> aliased to each item in turn). + + print "Hello $_!\n" foreach qw(world Dolly nurse); + +C repeats the statement I the condition is true. +C does the opposite, it repeats the statement I the +condition is true (or while the condition is false): + + # Both of these count from 0 to 10. + print $i++ while $i <= 10; + print $j++ until $j > 10; + +The C and C modifiers have the usual "C loop" +semantics (conditional evaluated first), except when applied to a +C-BLOCK (or to the deprecated C-SUBROUTINE statement), in +which case the block executes once before the conditional is +evaluated. This is so that you can write loops like: do { $line = ;