From 5db2af887d5c50bc400bab2e1d6d15d88ba6e0d7 Mon Sep 17 00:00:00 2001 From: Arne Sommer Date: Fri, 18 Jul 2025 22:51:35 +0200 Subject: week 330 Arne Sommer --- challenge-330/arne-sommer/blog.txt | 1 + challenge-330/arne-sommer/raku/ch-1.raku | 22 ++++++++++++++++++++++ challenge-330/arne-sommer/raku/ch-2.raku | 14 ++++++++++++++ challenge-330/arne-sommer/raku/clear-digits | 22 ++++++++++++++++++++++ challenge-330/arne-sommer/raku/title-capital | 14 ++++++++++++++ 5 files changed, 73 insertions(+) create mode 100644 challenge-330/arne-sommer/blog.txt create mode 100755 challenge-330/arne-sommer/raku/ch-1.raku create mode 100755 challenge-330/arne-sommer/raku/ch-2.raku create mode 100755 challenge-330/arne-sommer/raku/clear-digits create mode 100755 challenge-330/arne-sommer/raku/title-capital diff --git a/challenge-330/arne-sommer/blog.txt b/challenge-330/arne-sommer/blog.txt new file mode 100644 index 0000000000..edc217b149 --- /dev/null +++ b/challenge-330/arne-sommer/blog.txt @@ -0,0 +1 @@ +https://raku-musings.com/clearly-capital.html \ No newline at end of file diff --git a/challenge-330/arne-sommer/raku/ch-1.raku b/challenge-330/arne-sommer/raku/ch-1.raku new file mode 100755 index 0000000000..462f51d87a --- /dev/null +++ b/challenge-330/arne-sommer/raku/ch-1.raku @@ -0,0 +1,22 @@ +#! /usr/bin/env raku + +unit sub MAIN ($str where $str ~~ /^<[ a..z 0 .. 9 ]>+$/, + :v(:$verbose)); + +my @output; + +for $str.comb -> $current +{ + if $current eq any(0..9) + { + @output.pop; + say ": Digit $current; Remove letter -> { @output.join}" if $verbose; + } + else + { + @output.push: $current; + say ": Letter $current; Added -> { @output.join}" if $verbose; + } +} + +say @output.join; \ No newline at end of file diff --git a/challenge-330/arne-sommer/raku/ch-2.raku b/challenge-330/arne-sommer/raku/ch-2.raku new file mode 100755 index 0000000000..358f7bc08c --- /dev/null +++ b/challenge-330/arne-sommer/raku/ch-2.raku @@ -0,0 +1,14 @@ +#! /usr/bin/env raku + +unit sub MAIN ($str where $str.chars > 0, + :v(:$verbose)); + +say $str.words.map( *.&tica ).join(" "); + +sub tica ($word) +{ + say ": Word: $word" if $verbose; + + return $word.lc if $word.chars <= 2; + return $word.lc.tc; +} diff --git a/challenge-330/arne-sommer/raku/clear-digits b/challenge-330/arne-sommer/raku/clear-digits new file mode 100755 index 0000000000..462f51d87a --- /dev/null +++ b/challenge-330/arne-sommer/raku/clear-digits @@ -0,0 +1,22 @@ +#! /usr/bin/env raku + +unit sub MAIN ($str where $str ~~ /^<[ a..z 0 .. 9 ]>+$/, + :v(:$verbose)); + +my @output; + +for $str.comb -> $current +{ + if $current eq any(0..9) + { + @output.pop; + say ": Digit $current; Remove letter -> { @output.join}" if $verbose; + } + else + { + @output.push: $current; + say ": Letter $current; Added -> { @output.join}" if $verbose; + } +} + +say @output.join; \ No newline at end of file diff --git a/challenge-330/arne-sommer/raku/title-capital b/challenge-330/arne-sommer/raku/title-capital new file mode 100755 index 0000000000..358f7bc08c --- /dev/null +++ b/challenge-330/arne-sommer/raku/title-capital @@ -0,0 +1,14 @@ +#! /usr/bin/env raku + +unit sub MAIN ($str where $str.chars > 0, + :v(:$verbose)); + +say $str.words.map( *.&tica ).join(" "); + +sub tica ($word) +{ + say ": Word: $word" if $verbose; + + return $word.lc if $word.chars <= 2; + return $word.lc.tc; +} -- cgit