aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xchallenge-327/feng-chang/raku/test.raku2
-rwxr-xr-xchallenge-330/feng-chang/raku/ch-1.raku6
-rwxr-xr-xchallenge-330/feng-chang/raku/ch-2.raku5
-rwxr-xr-xchallenge-330/feng-chang/raku/test.raku24
4 files changed, 36 insertions, 1 deletions
diff --git a/challenge-327/feng-chang/raku/test.raku b/challenge-327/feng-chang/raku/test.raku
index 9520ed7c6a..4001c5f219 100755
--- a/challenge-327/feng-chang/raku/test.raku
+++ b/challenge-327/feng-chang/raku/test.raku
@@ -21,4 +21,4 @@ pwc-test './ch-1.raku', <2 2 1>, '3', 'Missing Integers: (2,2,1) =
# Task 2, MAD
pwc-test './ch-2.raku', <4 1 2 3>, '[1,2], [2,3], [3,4]', 'MAD: (4,1,2,3) => [1,2],[2,3],[3,4]';
pwc-test './ch-2.raku', <1 3 7 11 15>, '[1,3]', 'MAD: (1,3,7,11,15) => [1,3]';
-pwc-test './ch-2.raku', <1 5 3 8>, '[1,3], [3,5]', 'MAD: (1,5,3,8) => [1,3], [3,5]';
+pwc-test './ch-2.raku', <1 5 3 8>, '[1,3], [3,5]', 'MAD: (1,5,3,8) => [1,3],[3,5]';
diff --git a/challenge-330/feng-chang/raku/ch-1.raku b/challenge-330/feng-chang/raku/ch-1.raku
new file mode 100755
index 0000000000..47ccaa223c
--- /dev/null
+++ b/challenge-330/feng-chang/raku/ch-1.raku
@@ -0,0 +1,6 @@
+#!/bin/env raku
+
+unit sub MAIN(Str:D $s is copy);
+
+$s .= subst(/<lower><digit>/) while $s.contains(/<lower><digit>/);
+put $s;
diff --git a/challenge-330/feng-chang/raku/ch-2.raku b/challenge-330/feng-chang/raku/ch-2.raku
new file mode 100755
index 0000000000..337796a084
--- /dev/null
+++ b/challenge-330/feng-chang/raku/ch-2.raku
@@ -0,0 +1,5 @@
+#!/bin/env raku
+
+unit sub MAIN(Str:D $s);
+
+put $s.words.map({ .chars == 1|2 ?? .lc !! .tclc }).join(' ');
diff --git a/challenge-330/feng-chang/raku/test.raku b/challenge-330/feng-chang/raku/test.raku
new file mode 100755
index 0000000000..42cb7d8075
--- /dev/null
+++ b/challenge-330/feng-chang/raku/test.raku
@@ -0,0 +1,24 @@
+#!/bin/env raku
+
+# The Weekly Challenge 330
+use Test;
+
+sub pwc-test(Str:D $script, Bool :$deeply? = False, *@input) {
+ my ($expect, $assertion) = @input.splice(*-2, 2);
+ my $p = run $script, |@input, :out;
+ if $deeply {
+ is-deeply $p.out.slurp(:close).chomp.words.Bag, $expect, $assertion;
+ } else {
+ is $p.out.slurp(:close).chomp, $expect, $assertion;
+ }
+}
+
+# Task 1, Clear Digits
+pwc-test './ch-1.raku', 'cab12', 'c', 'Clear Digits: cab12 => c';
+pwc-test './ch-1.raku', 'xy99', '', 'Clear Digits: xy99 => ""';
+pwc-test './ch-1.raku', 'pa1erl', 'perl', 'Clear Digits: pa1erl => perl';
+
+# Task 2, Title Capital
+pwc-test './ch-2.raku', 'PERL IS gREAT', 'Perl is Great', 'Title Capital: PERL IS gREAT => Perl is Great';
+pwc-test './ch-2.raku', 'THE weekly challenge', 'The Weekly Challenge', 'Title Capital: THE weekly challenge => The Weekly Challenge';
+pwc-test './ch-2.raku', 'YoU ARE A stAR', 'You Are a Star', 'Title Capital: YoU ARE A stAR => You Are a Star';