summaryrefslogtreecommitdiff
path: root/pod/perlsyn.pod
diff options
context:
space:
mode:
authorVincent Pit <perl@profvince.com>2010-05-20 02:44:22 +0200
committerVincent Pit <perl@profvince.com>2010-05-20 02:44:29 +0200
commit06b608b9d959950f68f610528bce502e1a0f4362 (patch)
treefe9358fbb619b2e8fc3313e531813a54b9a4ef98 /pod/perlsyn.pod
parent6a23a794407f48284e219ad5f67a95bebc011e8c (diff)
downloadperl-06b608b9d959950f68f610528bce502e1a0f4362.tar.gz
Add a note in perl5131delta about given return values
And tweak its documentation.
Diffstat (limited to 'pod/perlsyn.pod')
-rw-r--r--pod/perlsyn.pod19
1 files changed, 11 insertions, 8 deletions
diff --git a/pod/perlsyn.pod b/pod/perlsyn.pod
index 3a65b4e9d0..29db5dafd5 100644
--- a/pod/perlsyn.pod
+++ b/pod/perlsyn.pod
@@ -677,28 +677,31 @@ case to the next:
=head3 Return value
When a C<given> statement is also a valid expression (e.g.
-when it's the last statement of a block), it returns :
+when it's the last statement of a block), it evaluates to :
=over 4
=item *
-An empty list as soon as an explicit C<break> is encountered.
+an empty list as soon as an explicit C<break> is encountered.
=item *
-The value of the last evaluated expression of the successful
+the value of the last evaluated expression of the successful
C<when>/C<default> clause, if there's one.
=item *
-The value of the last evaluated expression of the C<given> block if no
-condition was true.
+the value of the last evaluated expression of the C<given> block if no
+condition is true.
=back
-Note that, unlike C<if> and C<unless>, both C<when> and C<default> always
-themselves return an empty list.
+In both last cases, the last expression is evaluated in the context that
+was applied to the C<given> block.
+
+Note that, unlike C<if> and C<unless>, failed C<when> statements always
+evaluate to an empty list.
my $price = do { given ($item) {
when ([ 'pear', 'apple' ]) { 1 }
@@ -707,7 +710,7 @@ themselves return an empty list.
'unknown';
} };
-C<given> blocks can't currently be used as proper expressions. This
+Currently, C<given> blocks can't always be used as proper expressions. This
may be addressed in a future version of perl.
=head3 Switching in a loop