diff options
author | Andinus <andinus@nand.sh> | 2021-03-03 23:13:35 +0530 |
---|---|---|
committer | Andinus <andinus@nand.sh> | 2021-03-03 23:13:35 +0530 |
commit | 4c77f3376020ea13754b2f635ce07094cdc4a226 (patch) | |
tree | b9ddc29123b47aa515ac26defea624f88f2a5c06 /lib/Octans/Puzzle | |
parent | edf8a7290888977ff0bc625f02a81abbc37fb984 (diff) | |
download | octans-4c77f3376020ea13754b2f635ce07094cdc4a226.tar.gz |
Make class Puzzle, remove fancy chars, make module for get-puzzle
- Puzzle is a class that provides the grids & gray-squares. - Fancy chars were removed for ASCII characters. - get-puzzle is now in its own module.
Diffstat (limited to 'lib/Octans/Puzzle')
-rw-r--r-- | lib/Octans/Puzzle/Get.rakumod | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/lib/Octans/Puzzle/Get.rakumod b/lib/Octans/Puzzle/Get.rakumod new file mode 100644 index 0000000..1783796 --- /dev/null +++ b/lib/Octans/Puzzle/Get.rakumod @@ -0,0 +1,39 @@ +use WWW; +use Octans::Puzzle; + +# get-puzzle returns Puzzle.new() given input path. +sub get-puzzle ( + Str $path +) is export { + my @grids; + + # $url will hold the url that we'll call to get the toot data. + my Str $url; + + # User can pass 2 types of links, either it will be the one + # when they view it from their local instance or the one they + # get from Algot's profile. We set $url from it. + if $path.match("web/statuses") -> $match { + $url = $match.replace-with("api/v1/statuses"); + } else { + $url = "https://mastodon.art/api/v1/statuses/" ~ $path.split("/")[*-1]; + } + + # grids capture grids of a row. + my token grids { \S \*? } + # rows capture rows of the puzzle. + my token rows { <grids> ** 2..* % \h } + + # jget just get's the url & decodes the json. We access the + # description field of 1st media attachment. + if (jget($url)<media_attachments>[0]<description> ~~ + / \n\n <rows>+ % \n / + ) -> $match { + for 0 .. $match<rows>.end -> $y { + for 0 .. $match<rows>[$y]<grids>.end -> $x { + @grids[$y][$x] = $match<rows>[$y]<grids>[$x].lc; + } + } + } + return Puzzle.new(grids => @grids); +} |