summaryrefslogtreecommitdiffhomepage
path: root/perl6.html.markdown
diff options
context:
space:
mode:
authorC. Bess <cbess@cfaulks-air.pk5001z>2014-09-02 18:52:04 -0500
committerC. Bess <cbess@cfaulks-air.pk5001z>2014-09-02 18:52:04 -0500
commit313c0daf05ccb5624ae5009565eb01c5ddeaa022 (patch)
tree5f40a62e42e3a00fbe255328558dfcca7c3dd989 /perl6.html.markdown
parentb50d4443cdca87e3342e2364c9e6afd2d7fce7d2 (diff)
parent0b3f3e01e245ab2f73226fe4ba09d567ca76aa98 (diff)
- fix merge swift conflict
- Merge master
Diffstat (limited to 'perl6.html.markdown')
-rw-r--r--perl6.html.markdown9
1 files changed, 8 insertions, 1 deletions
diff --git a/perl6.html.markdown b/perl6.html.markdown
index 4ab90914..fe5b197c 100644
--- a/perl6.html.markdown
+++ b/perl6.html.markdown
@@ -488,6 +488,7 @@ sub truthy-array(@array) {
# (it'll stop at the furthest operator in the current expression)
my @arrayplus3 = map(*+3, @array); # `*+3` is the same as `{ $_ + 3 }`
my @arrayplus3 = map(*+*+3, @array); # Same as `-> $a, $b { $a + $b + 3 }`
+ # also `sub ($a, $b) { $a + $b + 3 }`
say (*/2)(4); #=> 2
# Immediatly execute the function Whatever created.
say ((*+3)/5)(5); #=> 1.6
@@ -496,7 +497,8 @@ say ((*+3)/5)(5); #=> 1.6
# But if you need to have more than one argument (`$_`)
# in a block (without wanting to resort to `-> {}`),
# you can also use the implicit argument syntax, `$^` :
-map({ $^a + $^b + 3 }, @array); # same as the above
+map({ $^a + $^b + 3 }, @array); # equivalent to following:
+map(sub ($a, $b) { $a + $b + 3 }, @array); # (here with `sub`)
# Note : those are sorted lexicographically.
# `{ $^b / $^a }` is like `-> $a, $b { $b / $a }`
@@ -1072,6 +1074,11 @@ my @list = 1, 3, 9 ... { $_ > 30 }; # (equivalent to the above)
my @fib = 1, 1, *+* ... *; # lazy infinite list of prime numbers,
# computed using a closure!
my @fib = 1, 1, -> $a, $b { $a + $b } ... *; # (equivalent to the above)
+my @fib = 1, 1, { $^a + $^b } ... *; #(... also equivalent to the above)
+# $a and $b will always take the previous values, meaning here
+# they'll start with $a = 1 and $b = 1 (values we set by hand).
+# then $a = 1 and $b = 2 (result from previous $a+$b), and so on.
+
say @fib[^10]; #=> 1 1 2 3 5 8 13 21 34 55
# (using a range as the index)
# Note : as for ranges, once reified, elements aren't re-calculated.