🦋 Welcome to the IRC channel of the core developers of the Raku Programming Language (raku.org #rakulang). This channel is logged for the purpose of history keeping about its development | evalbot usage: 'm: say 3;' or /msg camelia m: ... | Logs available at irclogs.raku.org/raku-dev/live.html | For MoarVM see #moarvm
Set by lizmat on 8 June 2022.
timo we do have things like trait_mod:is<blah> and friends but these have a word between the : and <...> 00:00
and of course the statement:sym<if> and such in the grammar
ab5tract I was thinking along the lines of porting the `%h<key>:kv` behavior 00:01
timo right, that applies to all kinds of operators, so a map operator could be made to take these
ab5tract but maybe it's just as good to provide the candidates you already mentioned
hmm... an infix:<map> ... very intriguing :) 00:04
timo m: multi sub postcircumfix:<🗺️ 🗺️>($on, $with) { $on.map($with) }; multi sub postcircumfix:<🗺️ 🗺️>($on, $with, :$flat!) { $flat ?? $on.flatmap($with) !! $on.map($with) }; multi sub postcircumfix:<🗺️ 🗺️>($on, $with, :$deep!) { $deep ?? $on.deepmap($with) !! $on.map($with) }; .say for [[1, "a"], [2, "b"], [3, "c"]]🗺️ * ~ "lol" 🗺️:flat; .say for [[1, "a"], [2, 00:05
"b"], [3, "c"]]🗺️ * ~ "lol" 🗺️:deep;
camelia ===SORRY!=== Error while compiling <tmp>
Unable to parse expression in array composer; couldn't find final ']' (corresponding starter was at line 1)
at <tmp>:1
------> ~ "lol" 🗺️:flat; .say for [[1, "a"], [2,<HERE><EOL>
expecting any…
timo ah damn too long
ab5tract EOLostThePlot 00:06
timo m: multi sub postcircumfix:<🗺️ 🗺️>($on, $w) { $on.map($w) }; multi sub postcircumfix:<🗺️ 🗺️>($on, $w, :$flat!) { $flat ?? $on.flatmap($w) !! $on.map($w) }; multi sub postcircumfix:<🗺️ 🗺️>($on, $w, :$deep!) { $deep ?? $on.deepmap($w) !! $on.map($w) }; my @a = [1, "a"], [2, "b"], [3, "c"]; .say for @a🗺️ * ~ "lol" 🗺️:flat; .say for @a🗺️ * ~ "lol" 00:07
🗺️:deep;
camelia ===SORRY!=== Error while compiling <tmp>
Unable to parse expression in postcircumfix:sym<🗺️ 🗺️>; couldn't find final '🗺️' (corresponding starter was at line 1)
at <tmp>:1
------> * ~ "lol" 🗺️:flat; .say for @a🗺️ * ~ "lol…
timo nooooo
m: multi sub postcircumfix:<🗺️ 🗺️>($on, $w) {$on.map($w)}; multi sub postcircumfix:<🗺️ 🗺️>($on, $w, :$flat!) {$flat ?? $on.flatmap($w) !! $on.map($w)}; multi sub postcircumfix:<🗺️ 🗺️>($on, $w, :$deep!) {$deep ?? $on.deepmap($w) !! $on.map($w)}; my @a = [1,"a"],[2,"b"],[3,"c"]; .say for @a🗺️ *~"!" 🗺️:flat; .say for @a🗺️ *~"?" 🗺️:deep;
camelia WARNINGS for <tmp>:
1 a!
2 b!
3 c!
[1? a?]
[2? b?]
[3? c?]
Useless use of "~" in expression "*~\"?\"" in sink context (line 1)
Useless use of "~" in expression "*~\"!\"" in sink context (line 1)
00:08
timo i'm not sure why it's behaving like that 00:10
like, it's doing what i expect it to, it's mapping flat first, and deep second, but the warnings though?
ab5tract EEMOJITOOPOWERFULDOWNGRADEORCRY 00:14
which of cours triggers EERRTXT2LNG
timo: does it break that way locally? 00:15
timo m: multi sub postcircumfix:<☺ ☺>($on, $w) {$on.map($w)}; multi sub postcircumfix:<☺ ☺>($on, $w, :$flat!) {$flat ?? $on.flatmap($w) !! $on.map($w)}; multi sub postcircumfix:<☺ ☺>($on, $w, :$deep!) {$deep ?? $on.deepmap($w) !! $on.map($w)}; my @a = [1,"a"],[2,"b"],[3,"c"]; .say for @a☺ *~"!" ☺:flat; .say for @a☺ *~"?" ☺:deep; 00:17
camelia WARNINGS for <tmp>:
1 a!
2 b!
3 c!
[1? a?]
[2? b?]
[3? c?]
Useless use of "~" in expression "*~\"!\"" in sink context (line 1)
Useless use of "~" in expression "*~\"?\"" in sink context (line 1)
timo this should be more copy-paste-friendly 00:18
it doesn't throw "useless use" warnings when i make it a curly block with $_ instead of a WhateverCode 00:21
m: sub postcircumfix:<X[ ]X>($on, $w) { say "yop"; $on.map($w) }; say [1,2,3]X[* ~ "hi"]X 00:23
camelia WARNINGS for <tmp>:
yop
(1hi 2hi 3hi)
Useless use of "~" in expression "* ~ \"hi\"" in sink context (line 1)
timo not related to using silly emoji and stuff, and also triggers without an adverb 00:24
ab5tract m: sub infix:<map>($inv, &block, :$flat!) { $inv.flatmap: &block }; dd [[1,2],[3,4]] map:flat { $_.map(*+1) } 00:26
camelia ===SORRY!=== Error while compiling <tmp>
Unexpected block in infix position (missing statement control word before the expression?)
at <tmp>:1
------> map: &block }; dd [[1,2],[3,4]] map:flat<HERE> { $_.map(*+1) }
expecting any of:
ab5tract ^^ the semantics my druthers dream of 00:27
m: sub infix:<map>($inv, &block, :$flat!) { $inv.flatmap: &block }; dd [[1,2],[3,4]] map { $_.map(*+1) } :flat
camelia (2, 3, 4, 5).Seq
ab5tract ^^ the way it works
m: sub infix:<map>($inv, &block, :$flat!) { $inv.flatmap: &block }; dd [[1,2],[3,4]] map:flat, { $_.map(*+1) }
camelia Type check failed in binding to parameter '&block'; expected Callable but got Pair (:flat)
in sub infix:<map> at <tmp> line 1
in block <unit> at <tmp> line 1
ab5tract That's probably a bit of an infix quirk.. I wonder what it would take to get that functional 00:28
m: Q| sub postcircumfix:<X[ ]X>($on, $w) { say "yop"; $on.map($w) }; say [1,2,3]X[* ~ "hi"]X |.AST.EVAL.say 00:29
camelia ===SORRY!===
Cannot find method 'to-begin-time' on object of type QAST::Op
ab5tract dang, I love it when that just Fixes It 00:30
timo i think it makes sense that it would do that thing with the pair object up there 00:32
you are terminatign the argument sequence with the , so it takes what it can
i imagine if the argument asked for Any $foo it would then complain about the lack of the named argument
ab5tract well my initial example doesn't inclue a `,` 00:33
that was just a stab. the preferred semantics are (1) `@a.map:flat[':'?] &block` or (2) @a map:flat &block 00:34
anyway, I should take an honest try at sleeping :) 00:35
timo best of luck!
01:42 librasteve_ left
Geth PrettyDump/main: 447beb12a1 | (Patrick Böker)++ | lib/PrettyDump.rakumod
Fix `pd` to print the results out, as it should
07:59
PrettyDump/main: 3010484511 | (Patrick Böker)++ | lib/PrettyDump.rakumod
Make `pd` return it's input

This allows putting pd in the middle of a pipeline.
PrettyDump/main: 0aa97642af | (Patrick Böker)++ (committed using GitHub Web editor) | lib/PrettyDump.rakumod
Merge pull request #2 from raku-community-modules/pd-fix-and-improvement

Pd fix and improvement
09:40 sena_kun joined
Geth PrettyDump/refs/tags/1.2.3: 53652f96c3 | (Patrick Böker)++ | 2 files
1.2.3
09:56
09:57 sjn joined
Geth PrettyDump/main: 8831aa6de3 | (Patrick Böker)++ | 2 files
1.2.3
09:58
timo MasterDuke, the graph for the sorted_keys timings is a bit silly, since you can't really see any values except for the 1M one on the left and the 10M on the right ad just the linear connection between the two makes up 99% of the plot :D 10:42
indexingoptimized has the drawback of allocating new storage for the string ... i wonder though if we should re-do the heuristic for when we should and shouldn't be using strands for a concatenated string; in the lowered_lex + _ + 12345 case for example. we are re-using the initial string, and i assume also the string of the _ in between. so strand storage is pointer + two int for start and end + 10:49
32bit repetition count
sizeof tells me it's 24 bytes 10:50
and we'll also have a string for the number but those are likely always in_situ_8 10:51
an MVMString is 48 bytes, which includes its header 10:52
i should double-check if the _ in the middle really is a string of its own or not 10:53
patrickb ugexe, MasterDuke, timo, nine, whoever else is interested: I'd like your feedback on github.com/Raku/problem-solving/issues/455 - "Revamping wrapper scripts in CURI" (It's a long one, sorry!) 13:26
ugexe patrickb: just to be sure we're on the same page, you are aware you can do `zef install 'ABC:ver<0.6.13>:auth<zef:colomon>'` on windows by using double quotes right? 15:45
which i would agree is not ideal either 15:46
patrickb did you try that and managed to make it work? 15:51
(I did not)
I tried in a powershell 15:52
timo surely powershell is able to represent < and > inside of strings 16:12
patrickb it is. but "zef" is a goodctually "zef.bat" And that's where the horrors are. 16:15
*actually
timo badctually? 16:16
patrickb androidorected 16:18
ugexe patrickb: ah ok it does not work. i was thinking of when i use bin/zef, not an installed zef 16:31
i.e. raku -I. bin/zef 'ABC:ver<0.6.13>:auth<zef:colomon>' 16:32
patrickb Yes that works (because it skips the bat/COM part). 16:33
And replacing those bat files is one of the key points I want to work towards. :-) 16:37
ugexe i think im just realizing (or re-realizing) that bin scripts do not get the naming "benefits" of modules that we sha1 18:40
since the installed wrapper still has to retain the original file name
patrickb Right. But I think it's not that bad. Scripts are usually at the end of the line. If we have to normalize the script file names some time in the future we'll mostly only break the muscle memory of the users, not much more. I guess we'll just I've with that. 19:13
ugexe over the years i've actually gone in the opposite direction: i wish we would have never tried to rename files 20:02
lizmat m: my str $a = "foo"; my str $a = "foo"; say $a 20:21
camelia Potential difficulties:
Redeclaration of symbol '$a'.
at <tmp>:1
------> my str $a = "foo"; my str $a<HERE> = "foo"; say $a
Cannot assign to an immutable value
in block <unit> at <tmp> line 1
lizmat m: no worries; my str $a = "foo"; my str $a = "foo"
camelia Cannot assign to an immutable value
in block <unit> at <tmp> line 1
lizmat this happens in the dispatcher
fortunately, this does not happen (yet) in RakuAST 20:22
ab5tract patrickb: what do you mean by breaking the muscle memory of users? How are they supposed to invoke scripts if we have renamed the script files? 21:09
patrickb They'll have to adapt. I.e. relearn that the script has a slightly different name (because their filesystem doesn't support the actual name). 21:27
I'd guess that a typical human user will typically figure it out. 21:28
22:06 kjp left, kjp_ joined 22:43 kjp_ left, kjp joined 22:58 sena_kun left
ab5tract That does sound misty read If their file system doesn’t support the actual name, how would they have gotten used to typing that name in? 23:46
*misty read = mostly reasonable
gah, the whole message is poorly worded 23:48
Rather than the question of typing the name, I am curious how they would have gotten used to referring to a script that cannot exist as a file in their FS 23:50
ugexe the easiest way to think of ways to hit problems is case insensitive file systems 23:52
for example on macOS you can use `ZEF`, `Zef`, etc instead of `zef` because by default the file system is not case sensitive 23:54