🦋 Welcome to Raku! raku.org/ | evalbot usage: 'p6: say 3;' or /msg camelia p6: ... | irclog: colabti.org/irclogger/irclogger_log/raku
Set by ChanServ on 14 October 2019.
00:04 pmurias left
rjt_pl Is there a Raku equivalent to p5's s/match/repl/r , important part being the /r (non-destructive substitution and returns result)? 00:04
00:04 patrickz joined
Xliff m: $_ = "Pear"; my $s = S/P/R/; $s.say; 00:05
evalable6 Rear
Xliff ^^ rjt_pl ?
m: $_ = "Pear"; my $s = S/P/R/; $s.say; .say; 00:06
evalable6 Rear
Pear
rjt_pl Oh wow, ok. That explains why I couldn't find an adverb for that. ;-) Thanks!
Xliff Be aware that S/// only works on $_. 00:07
rjt_pl Right, perfect for what I'm doing.
Xliff If you want to do something with arbitrary strings, use Str.replace
Actually... that would be .subst 00:08
docs.perl6.org/routine/subst
00:08 patrickb left 00:14 patrickz left 00:17 pmurias joined
guifa note that Str.subst will (temporarily) likely be faster if you’re not replacing regexen 00:41
(or at least, for a while things like starts-with(‘foo’) and ends-with(‘foo’) were much faster than ~~ /^foo/ and ~~ /foo$/ and the recommended route — and even if regex gets faster, it’s cleaner code IMO) 00:42
rjt_pl Good to know. 00:49
01:03 Doc_Holliwould left
guifa Eventually they should end up being the same speed (regex optimizations should recognize a simple anchor + static string) but there have been bigger fish to fry elsewhere in the core 01:06
01:23 AlexDani` joined 01:24 AlexDaniel left 01:32 cognomin_ left, AlexDani` is now known as AlexDaniel, AlexDaniel left, AlexDaniel joined 01:39 benjif joined 01:54 pmurias left 02:07 wildtrees left 02:29 lucasb left
cpan-raku New module released to CPAN! AttrX::Mooish (0.7.0) by 03VRURG 02:42
02:45 Guest38485 left, skyl4rk left 02:46 Guest38485 joined, skyl4rk joined 03:12 cpan-raku left 03:13 cpan-raku joined, cpan-raku left, cpan-raku joined
Xliff Is there a more up-to-date version of perl6-all-modules from moritz? 03:21
AlexDaniel? 03:32
AlexDaniel Xliff: no
Xliff Whyyyyyy? 03:33
AlexDaniel perl6-all-modules is stuck for some reason and needs fixing
Xliff Oh. nvm
AlexDaniel: What's the best way for me to get a bisectable installation going?
ZzZombo How can I express "this variable/property" is supposed to be initialized with defined strings" w/o also giving it an immediate value, like `my Str:D $a = ''`?
AlexDaniel Xliff: what for?
Xliff I do NOT want to continue compiling rakudo everytime I need to check something 03:34
Compiling GTK is bad enough.
AlexDaniel Xliff: what about this? github.com/perl6/whateverable/wiki/Shareable
Xliff Was looking at that.
AlexDaniel Xliff: you can get any build from whateverable server
I think modern rakudo versions are relocatable so you should have even less issues using this 03:35
Xliff Is there a script that will download a nice subset?
AlexDaniel shareable6: HEAD
shareable6 AlexDaniel, whateverable.6lang.org/HEAD
AlexDaniel Xliff: well, if you replace HEAD with anything else it'll give you the build 03:36
so as long as you can define your own subset, sure
Xliff Hm. OK. This means I need to script downloads via that link, then undo them, then run via that new executable, correct?
I was hoping there was a CLI version of bisectable. 03:37
AlexDaniel there is Blin, yes
which you can use as exactly that
Xliff *sigh*
OK. I've been misunderstanding the purpose of some of these bots, then. 03:38
Let me gain some altitude and explain.
AlexDaniel to be honest I don't entirely understand what problem you're trying to solve :)
Xliff I want to see if I can find the largest perl6 module in the ecosystem. What's the best method to do that?
AlexDaniel hmm, what's largest? 03:39
ZzZombo If you omit the `:D`, then it's possible to assign undefined values, on the other hand, assigning some half-assed default value also kinda works against the design.
Xliff Yes
AlexDaniel I mean, what's your definiton of “largest” 03:40
Xliff Either compunit count or line count. Don't care which.
Line count would be the best one.
That directly translates to "size of repo"
m: class A { method b (Str:D $name) { say 'Defined' }; }; A.new.b() 03:41
evalable6 (exit code 1) Too few positionals passed; expected 2 arguments but got 1
in method b at /tmp/bKbzLRuIn5 line 1
in block <unit> at /tmp/bKbzLRuIn5 line 1
Xliff m: class A { method b (Str:D $name) { say 'Defined' }; }; my $c; A.new.b($c)
evalable6 (exit code 1) Type check failed in binding to parameter '$name'; expected Str but got Any (Any)
in method b at /tmp/NtQI9pcDxH line 1
in block <unit> at /tmp/NtQI9pcDxH line 1
Xliff m: class A { method b (Str:D $name) { say 'Defined' }; }; my $c; A.new.b('')
evalable6 Defined
Xliff m: class A { method b (Str:D $name) { say 'Defined' }; }; my $c; A.new.b(Str)
evalable6 (exit code 1) Parameter '$name' of routine 'b' …
Xliff, Full output: gist.github.com/f770353c2e68e86810...0aacf5a4dd
Xliff ZzZombo: ^^^
ZzZombo What? 03:42
How does that answer my question?
Xliff I don't know. Can you tell me why it doesn't?
ZzZombo Maybe because you involve parameters rather than variables and properties? 03:43
Xliff I don't think I got the mid bit of your explanation...
Can you gist?
AlexDaniel ah, I understand the question
so you want to declare `my Str:D $a;` but assign to it later 03:44
ZzZombo Yep.
Xliff Yeah. That was the mid bit I missed.
ZzZombo Especially in a class, why can't the initialization be deferred to `BUILD\TWEAK`, etc? 03:45
AlexDaniel ZzZombo: well, I don't think you can or should be able to. Before you assign to it, it'll be undefined, meaning it'll be violating the constraint
Xliff class A { has Str $!a is required }; A.new
m: class A { has Str $!a is required }; A.new
evalable6 (exit code 1) The attribute '$!a' is required, but you did not provide a value for it.
in block <unit> at /tmp/bw27leLZ9W line 1
Xliff m: class A { has Str $!a is required; submethod BUILD (:$!a) { }; }; A.new(a => '42') 03:46
evalable6
ZzZombo Good, looks fine.
AlexDaniel Xliff: I can't come up with a very easy way to do it, you'll have to implement it somehow 03:47
Xliff AlexDaniel: *sigh* -- Was hoping I wouldn't need to go through and download every module.
OK. Thanks!@
AlexDaniel Xliff: as for fetching every module, it's also a bit… complicated 03:48
Xliff: first of all, there are two lists: github.com/perl6/Blin/blob/0b12bc0...p6#L36-L37
then there's this issue with source urls being something other than https links… 03:49
then there are different versions of the same module
Xliff Yeek! Looks like massive amounts of data normalization. 04:18
04:54 squashable6 left 04:55 squashable6 joined
guifa .tell jmerelo Sent you an e-mail to your university account. Sorry for the delay! 04:56
tellable6 guifa, I'll pass your message to jmerelo
Xliff Hrm. How can I make a hash slice into another hash... 05:11
m: my %h = ( a=>1, b=>2, c=>3, e=>4 ); %h<b c e>
evalable6
Xliff m: my %h = ( a=>1, b=>2, c=>3, e=>4 ); %h<b c e>.gist.say 05:12
evalable6 (2 3 4)
Xliff m: my %h = ( a=>1, b=>2, c=>3, e=>4 ); %h<b c e>.pairs.map( *.key eq <b c e>.any ).Hash.gist.say 05:13
evalable6 (exit code 1) Died with X::Hash::Store::OddNumber
in block <unit> at /tmp/K0_oczdUtI line 1
Xliff m: my %h = ( a=>1, b=>2, c=>3, e=>4 ); %h<b c e>.pairs.grep( *.key eq <b c e>.any ).Hash.gist.say
evalable6 {}
Xliff m: my %h = ( a=>1, b=>2, c=>3, e=>4 ); %h<b c e>.pairs.grep( *.key eq <b c e>.any ).gist.say 05:14
evalable6 ()
Xliff m: my %h = ( a=>1, b=>2, c=>3, e=>4 ); %h<b c e>.pairs.grep({.key eq <b c e>.any }).gist.say
evalable6 ()
Xliff m: my %h = ( a=>1, b=>2, c=>3, e=>4 ); %h<b c e>.pairs.grep({ .key eq <b c>.any }).gist.say
evalable6 ()
Xliff m: my %h = ( a=>1, b=>2, c=>3, e=>4 ); %h.pairs.grep({ .key eq <b b c>.any }).gist.say
evalable6 (b => 2 c => 3)
Xliff m: my %h = ( a=>1, b=>2, c=>3, e=>4 ); %h.pairs.grep({ .key eq <b c e>.any }).gist.say
evalable6 (e => 4 c => 3 b => 2)
Xliff Hrm.
guifa Xliff: sounds like the time for a custom circumscript 05:31
ZzZombo m: role R[**%h]{method m{%h}};say R[:a<f>, :1b].new.m 05:32
evalable6 (exit code 1) ===SORRY!===
No appropriate parametric role variant available for 'R'
ZzZombo Why?
m: role R[**%h]{method m{%h}};say R[%(:a<f>, :1b)].new.m 05:33
evalable6 {a => f, b => 1}
ZzZombo WTF??
m: role R[**%h]{method m{%h}};say R[a=>'asd', b=>123].new.m 05:34
evalable6 (exit code 1) ===SORRY!===
No appropriate parametric role variant available for 'R'
guifa m: role R[+%h]{method m{%h}};say R[:a<f>, :1b].new.m
evalable6 (exit code 1) Could not instantiate role 'R':

in any protect at gen/moar/stage2/NQPCORE.setting line 1216
in block <unit> at /tmp/nEIoojWBeO line 1
guifa m: role R[*%h]{method m{%h}};say R[:a<f>, :1b].new.m
evalable6 {a => f, b => 1}
guifa wonders why single argument rule isn’t available for hashes
In any case, you need to use a single star slurpy 05:35
ZzZombo Yea, thanks for pointing that out.
BTW, Comma apparently doesn't know about `return` and `fail`... 05:36
guifa it normally does … but sometimes if you have fairly complex syntax it might lose track of the context and it can get screwy
Xliff m: Version.new( 05:38
evalable6 (exit code 1) 04===SORRY!04=== Er…
Xliff, Full output: gist.github.com/1a2d93786b10e34ebd...95f4d78ed1
05:38 Doc_Holliwould joined
Xliff m: my $a = Version.new("0.9.6"); my #b = Version.new("0.9.16"); say $a > $b 05:38
evalable6 (exit code 1) 04===SORRY!04=== Error while compiling /tmp/H4np3pCf6f
Malformed my
at /tmp/H4np3pCf6f:1
------> 03 #b = Version.new("0.9.16"); say $a > $b08⏏04<EOL>
Xliff m: my $a = Version.new("0.9.6"); my $b = Version.new("0.9.16"); say $a > $b
evalable6 False
Xliff m: my $a = Version.new("0.9.6"); my $b = Version.new("0.9.16"); say $a < $b 05:39
evalable6 True
ZzZombo m: my SetHash:D[Str:D] $h = 'asd', 'foo', 'bra';say $h<asd>
evalable6 (exit code 1) WARNINGS for /tmp/SaLT1tFQHx:
Use…
ZzZombo, Full output: gist.github.com/697f088d6d7e69d016...346269f13d
ZzZombo m: my SetHash:D[Str:D] $h = 'asd', 'foo', 'bra';say $h
evalable6 (exit code 1) WARNINGS for /tmp/FdsclHTCBr:
Use…
ZzZombo, Full output: gist.github.com/9a1cdf0ca9924dda51...bd6d766d86
ZzZombo perlbot: eval: my SetHash:D[Str:D] $h = 'asd', 'foo', 'bra';say $h
perlbot ZzZombo: WARNINGS for /tmp/sk2rrAZ_ht:␤Useless use of constant string "foo" in sink context (lines 1, 1)␤Useless use of constant string "bra" in sink context (lines 1, 1)␤Type check failed in assignment to $h; expected SetHash:D but got Str ("asd")␤ in block <unit> at /tmp/sk2rrAZ_ht line 1␤␤[Exited 1]
ZzZombo perlbot: eval: my SetHash:D[Str:D] $h = ('asd', 'foo', 'bra');say $h
perlbot ZzZombo: Type check failed in assignment to $h; expected SetHash:D but got List ($("asd", "foo", "bra"))␤ in block <unit> at /tmp/C356VWIQn6 line 1␤␤[Exited 1]
ZzZombo perlbot: eval: my SetHash:D[Str:D] $h .= new('asd', 'foo', 'bra');say $h
perlbot ZzZombo: SetHash(asd bra foo)␤
ZzZombo Is there a shorter version of `sub x (--> 42){}` w/o the empty body at all? 05:41
guifa constant &term:<x> = 42; 05:43
Xliff how does this work?
m: sub postcircumfix:<{_ _}>(%h,@v) { %( do for @v { $_ => %h{$_} } ) }; my %a = a => 1, b => 2, c => 3, d => 4; say %a{_ "a", "b" _} 05:44
evalable6 {a => 1, b => 2}
Xliff m: Version.new("0.9.42").say 05:47
evalable6 v0.9.42
ZzZombo It can't be a constant, it actually returns an expression, like `@a.elems`; I'm probably too used to one-liners for such occasions in other languages.
guifa I just wouldn’t use —> then, it’s not obligatory. sub x { @_.elems }  would return the elements of the array passed 05:48
Xliff Grabs cpan.json and turns it into something I can use... 05:53
perl6 -e 'use URI; use JSON::Fast; my $cpan = from-json("cpan.json".IO.slurp); $cpan .= map({ my %h = .pairs.grep( *.key eq <source-url version name auth>.any).Hash; unless %h<auth>:exists { %h<auth> = URI.new(.<source-url>).path.Str.split("/")[5].lc }; if %h<auth>:exists { %h<auth> ~~ s/^ ["github:" | "cpan:" | "CPAN:" | "bitbucket:" | "gitlab:"]//; %h<auth> .= lc if %h<auth>; }; %h }); my %p; for $cpan.Array -> $c { 05:54
%p{$c<auth>}{$c<name>}{$c<version>} = $c<source-url> }; for %p.values -> $a { for $a.values -> $p { my @s = $p.keys.map({ Version.new($_) }).Array.sort; $p<versions> = @s.reverse; }; }; "cpan-parsed.json".IO.spurt: to-json(%p)'
Bwahahaha!
guifa Xliff BTW if you ever do for @a -> $a { for @b -> $b { , etc 06:07
use the X operator
for @a X @b -> $a, $b {  06:09
it’s even more effective when you have to embed 3 or more
err oops forgot you hve to deconstruct 06:14
for @a X @b -> ($a, $b) { 06:15
06:18 sauvin left 06:24 jmerelo joined
jmerelo .seen tmtvl 06:24
tellable6 jmerelo, I saw tmtvl 2019-12-02T18:04:10Z in #raku: <tmtvl> Shall I share the latest Weekly on the Facebook?
jmerelo .seen kaiepi 06:25
tellable6 jmerelo, I saw kaiepi 2019-12-08T10:52:18Z in #raku-dev: <Kaiepi> ah there you are
ZzZombo .seen ZzZombo
tellable6 ZzZombo, I saw ZzZombo 2019-12-10T05:47:23Z in #raku: <ZzZombo> It can't be a constant, it actually returns an expression, like `@a.elems`; I'm probably too used to one-liners for such occasions in other languages.
ZzZombo .seen tellable6
tellable6 ZzZombo, I haven't seen tellable6 around, did you mean evalable6?
ZzZombo LOL
AlexDaniel hah 06:26
you can add some easter egg for that :)
Voldenet uh, but it's not @a X @b, it's %a.values -> $b { $b.values … } 06:28
guifa Voldenet: good point. Um… 06:30
%a.values X %a.values».values.flat
:D
Voldenet in this case tho: for %p.map(*.values).flat.map(*.values).flat { $_<versions> = $_.keys.map({ Version.new($_) }).Array.sort.reverse }; 06:32
06:34 sauvin joined
Voldenet uh, maybe %p.values>>.values.flat, but I'm not very good at golf 06:36
06:56 rindolf joined
Xliff HAH! 07:04
I try to sleep and you marvelous people fiddle with my not-golf. 07:05
07:05 wamba joined
Xliff Of course, you all are missing the assignment to %p, which preclues the X. 07:06
Hmmm... or not...
SmokeMachine m: my %h = ( a=>1, b=>2, c=>3, e=>4 ); (%h<b c e>:p).Hash.say 07:12
evalable6 {b => 2, c => 3, e => 4}
Xliff SmokeMachine++ 07:13
07:23 jmerelo left 07:58 stoned75 left
ZzZombo SmokeMachine: I kinda got how to declare, but how do I use a custom metaclass? 08:06
SmokeMachine ZzZombo: github.com/FCO/Red/blob/master/lib/Red.pm6#L39 08:13
ZzZombo: github.com/FCO/Red/blob/master/exa...son.pm6#L3 08:17
Xliff m: "filename.tar.gs".IO.extension.basename.say 08:23
evalable6 (exit code 1) No such method 'basename' for invocant of type 'Str'
in block <unit> at /tmp/tonL6J9NmD line 1
Xliff m: "filename.tar.gs".IO.extension('').basename.say
evalable6 filename.tar
Xliff m: "filename.tar.gs".IO.extension('', :parts(3)).basename.say 08:24
evalable6 filename.tar.gs
Xliff m: "filename.tar.gs".IO.extension('', :parts(2)).basename.say
evalable6 filename
Xliff m: "filename.tar.gs".IO.extension('', :parts(^5)).basename.say 08:25
evalable6 filename
08:34 wamba left 08:35 xinming_ joined 08:37 chloekek joined
chloekek p6: say set(1, 2, 3) R(elem) 1 08:37
evalable6 True
chloekek Ah, camelia was renamed.
Didn’t work in DM. :þ
08:38 xinming left
rindolf .seen TimToady 08:47
tellable6 rindolf, I saw TimToady 2019-07-22T20:38:55Z in #perl6-dev: * TimToady had the power company swapping his electric meter, and it broke my / key
ZzZombo Yea, where is Camelia? 08:51
I want it back!
cpan-raku New module released to CPAN! Gnome::N (0.15.1.1) by 03MARTIMM 08:53
08:56 sena_kun joined
sarna camelia was renamed? 09:03
09:04 Doc_Holliwould left
sena_kun sarna: hmm? the mascot? 09:04
sarna sena_kun: oh, I think chloekek meant the bot 09:05
chloekek Absolutely.
09:06 SyrupThinker left
sarna can I get rakudo on ARM? like, a rasp pi 09:08
09:11 wamba joined 09:22 patrickb joined 09:33 Doc_Holliwould joined
sarna ha, you can! stackoverflow.com/questions/516048...berry-pi-3 09:36
very nice :D
09:43 wamba left, wamba joined 09:51 knoop joined 09:53 knoop left, knoop joined
knoop hello raku... glad about the new name... I'm looking for a language that makes sense like Perl does but with simpler dependency management... am I in the right place? 09:54
sarna knoop: what do you mean by "simpler dependency management"? 09:55
knoop well I find npm easy to use
cpan not so much
benjif I find zef pretty simple to use 09:56
sarna ah, raku's cli tool is called zef and the modules live at modules.raku.org/
tadzik huh
knoop I guess before I delve in I was wondering if this was a specific area where raku tries to make it simpler than it was with perl 5 09:57
interested in your views
but will read up on zef 09:58
too
thanks!
tadzik knoop: if you like npm then you might like metacpan.org/pod/distribution/App-...script/cpm
raku has nothing quite like it though afaik
sarna knoop: I haven't used perl, but I've heard OO is more convenient in raku 09:59
there are new regexes that are definitely simpler and make more sense, but they take a bit of time to get used to
I've also heard raku's treatment of sigils is way simpler than perl's, not sure if that's true though 10:00
SmokeMachine knoop: 6pm should be a clone of npm for raku... 10:01
knoop Ah yeah oo was the other point but I already knew that was tackled from the ground up in raku
sarna I think overall raku should make more sense than perl, but :) as I said, I have no prior perl experience 10:02
SmokeMachine knoop: github.com/FCO/6pm
knoop thanks for the pointers guys 10:03
sarna you're welcome!
chloekek The way lists work in Perl 5 and Raku is significant when considering sigil variance. 10:06
$xs[$i] and @xs[$i] in Perl 5 are both valid but the former evaluates to a scalar whereas the latter evaluates to a single-element list. 10:10
In Raku what you get when you write @xs[$i] depends on what $i is at runtime.
p6: my @xs = qw「a b c」; my $i = 0; my $j := (0, 1); @xs[$i].perl.say; @xs[$j].perl.say; 10:12
evalable6 "a"
("a", "b")
10:21 Xliff left 10:29 wamba left
ZzZombo m: role R {...};class C does R {};say C.new 10:46
evalable6 (exit code 1) 04===SORRY!04=== Error while compiling /tmp/KtpVOo3VEc
No appropriate parametric role variant available for 'R'
at /tmp/KtpVOo3VEc:1
ZzZombo m: role R {...};class C does R {};role R {};say C.new 10:47
evalable6 (exit code 1) 04===SORRY!04=== Error while compiling /tmp/1RCl0jKe0u
No appropriate parametric role variant available for 'R'
at /tmp/1RCl0jKe0u:1
ZzZombo WTF?
This makes forward declaration useless for roles.
chloekek m: role R {...};class C does R {};role R { method m {...}; };say C.new 10:49
evalable6 (exit code 1) 04===SORRY!04=== Error while compiling /tmp/as6oscVBp9
No appropriate parametric role variant available for 'R'
at /tmp/as6oscVBp9:1
10:49 chloekek left
ZzZombo m: role R {...};class C does R {};role R {};dd R 10:50
evalable6 (exit code 1) 04===SORRY!04=== Error while compiling /tmp/Vk6S2tFSEC
No appropriate parametric role variant available for 'R'
at /tmp/Vk6S2tFSEC:1
ZzZombo m: role R {...};dd R;role R {}
evalable6 R
ZzZombo m: role R {...};dd R;role R {};dd R 10:51
evalable6 R
R
ZzZombo m: role R {...};dd R.HOW;role R {};dd R.HOW
evalable6 Perl6::Metamodel::ParametricRoleGroupHOW.new
Perl6::Metamodel::ParametricRoleGroupHOW.new
ZzZombo WTF??
Why is it parametric all of sudden? 10:52
jnthn All roles are parametric
Stubbing a role is like declaring a proto with no multi candidates
10:53 wamba joined, sena_kun left
jnthn You can't actually `does` a stubbed role, because composition happens at the time the closing `}` of the class is reached. 10:53
And composition is flattening
So the definition of the role must be available by the point it is composed. 10:54
nine ZzZombo: forward declarations of roles can still be useful for type constraints 10:58
11:00 wamba left 11:07 sena_kun joined 11:09 wamba joined, Doc_Holliwould left 11:14 abraxxa left, abraxxa joined 11:20 Doc_Holliwould joined
tbrowder .tell ab6tract when i actually started designing a check-file sub it was not as simple as i first imagined, but, for my use cases, it's becoming clearer 11:42
tellable6 tbrowder, I'll pass your message to ab6tract
11:54 wamba left 12:08 wamba joined 12:22 scimon joined 12:23 joule joined 12:30 pmurias joined
pmurias vrurg: should I merge in: github.com/perl6/nqp/pull/590 12:32
vrurg: I'm not sure if it's waiting for code review before being merged or something else? 12:33
12:36 lucasb joined 12:37 wamba left 12:38 wamba joined 12:39 wamba left, wamba joined 12:40 wamba left, wamba joined 12:43 scimon left 12:45 wamba left 12:47 scimon joined
ZzZombo m: say 1.'succ()' #?? 12:48
evalable6 (exit code 1) 04===SORRY!04=== Er…
ZzZombo, Full output: gist.github.com/72259a769daa4cedca...60e1734c3c
ZzZombo What am I doing wrong again?
12:49 Doc_Holliwould left 12:50 wamba joined
lizmat m: say 1.succ 12:53
evalable6 2
sarna m: say 1.'succ'()
evalable6 2
lizmat ah, ok
sarna ZzZombo 12:54
12:54 sena_kun left 12:55 wamba left
ZzZombo OK, thanks. 12:56
12:57 knoop left, knoop_ joined 13:00 knoop joined 13:04 knoop_ left 13:08 sena_kun joined
ZzZombo rkeval: my method m(Positional:D \SELF: ){SELF.grep: * % 2 == 0};(1,2,3,4).&m.say 13:08
rkeval: my method m(Positional:D \SELF: ){SELF.grep: * % 2 == 0};(1,2,3,4).'m'().say
perlbot ZzZombo: (2 4)␤
ZzZombo: No such method 'm' for invocant of type 'List'␤ in block <unit> at /tmp/uNJsFyQQq6 line 1␤␤[Exited 1]
ZzZombo Why does the second not work?
scimon Hi all 13:09
lizmat because it does a method lookup for method "m", which List does not have
&m is a direct Callable, so (1,2,3,4).&m basically forces the use of the Callable, without any further checks 13:10
ZzZombo rkeval: say ''.&Int 13:11
perlbot ZzZombo: 5===SORRY!5=== Error while compiling /tmp/UqJaV0v4TL␤Illegally post-declared type:␤ Int used at line 1␤␤[Exited 1]
ZzZombo rkeval: say ''.&say
perlbot ZzZombo: ␤True␤
13:14 cpan-raku left 13:16 cpan-raku joined, cpan-raku left, cpan-raku joined 13:18 maettu left 13:22 pmurias left 13:26 wamba joined
cpan-raku New module released to CPAN! Gnome::Gdk3 (0.15.0.1) by 03MARTIMM 13:33
13:34 xinming_ left 13:35 xinming_ joined 13:40 squashable6 left 13:41 squashable6 joined 13:49 pmurias joined 14:09 Summertime left 14:10 maettu joined 14:15 Summertime joined
Geth doc: McSinyx++ created pull request #3126:
Substitute Perl 6 with Raku
14:22
sarna tyil: thanks for the very nice advent posts :D I learned a lot about grammars 14:25
I even managed to write my own rule for multiline comments 14:26
tyil sarna: nice 14:32
grammars have been one of the hardest (raku) topics to get into for me 14:33
I have a book on grammars, and it's very helpful in my experience, if you want to get better at them
14:36 hungrydonkey joined
sarna tyil: what is it called? 14:36
tyil "Parsing with Perl 6 Regexes and Grammars"
sarna also, how to match anything but some string of characters? something like `-[\n]` but I'd like to do `-["foo"]` 14:37
I'll check it out, thanks!
tyil I do not have an answer on your question, but perhaps you're looking for negative lookahead/behind 14:38
sarna yeah, seems to be it. thanks! 14:40
jnthn I know nothing about what you're trying to parse, but: if that's for keyword handling, it's often more natural to express it in terms of an alternation or protoregexes, and let LTM and the longest literal disambiguation sort it out. 14:44
14:47 hungrydonkey left 14:50 hungrydonkey joined 14:53 sena_kun left 14:55 chloekek joined 14:59 hungrydonkey left 15:03 hungrydonkey joined 15:07 zby joined, sena_kun joined
sarna jnthn: I just think my multiline comment rule is too greedy :D it works fine on small strings but in a real file it matches until the end of the last multiline comment (I think) 15:09
15:11 hungrydonkey left
sarna it’s `‘/*’ <( .* )> ‘*/‘` 15:12
chloekek p6: say '/* foo */ /* bar */' ~~ /‘/*’ <( .* )> ‘*/’/ 15:13
evalable6 「 foo */ /* bar 」
chloekek p6: say '/* foo */ /* bar */' ~~ /‘/*’ <( .*? )> ‘*/’/
evalable6 「 foo 」
sarna oh nice! why does that work? 15:15
does ? make it not greedy?
15:15 hungrydonkey joined
chloekek .*? is not the same as [.*]?. Instead, *? is special syntax for a non-greedy match. 15:15
You can also use a negative lookahead: 15:16
p6: say '/* foo */ /* bar */' ~~ /‘/*’ <( [. <!before ‘*/’>]* )> ‘*/’/
evalable6 Nil
15:19 Doc_Holliwould joined
sarna awesome, thanks chloekek :) 15:20
chloekek p6: say '/* foo */ /* bar */' ~~ /‘/*’ <( [<!before ‘*/’> .]* )> ‘*/’/
evalable6 「 foo 」
chloekek p6: say '/* foo /* bar */ */ /* baz */' ~~ /‘/*’ <( .*? )> ‘*/’/ 15:22
evalable6 「 foo /* bar 」
15:25 wamba left, wamba joined, hungrydonkey left
sarna oh, that’s why I was getting Nil with !before 15:28
I put the dot before <> too :D
15:29 pmurias left, pmurias joined
chloekek . already matches * <!before> wouldn’t get to see it. 15:29
15:29 hungrydonkey joined
sarna right 15:30
15:49 hungrydonkey left 15:51 wamba1 joined, wamba left 16:10 pmurias left 16:11 chloekek left 16:38 jmerelo joined
Geth doc: b4db2e6616 | (Nguyễn Gia Phong)++ | doc/Type/Cool.pod6
Substitute Perl 6 with Raku

Handle irregular cases (pun intended) and whitespace to complete #3054
16:39
doc: a81f8c0d22 | (Juan Julián Merelo Guervós)++ (committed using GitHub Web editor) | doc/Type/Cool.pod6
Merge pull request #3126 from McSinyx/master

Substitute Perl 6 with Raku
16:44 patrickb left, mscha joined
mscha m: my $a = 5+i; my $step = -1+i; for $a+$step, $a+2×$step ... * -> $b { say $b; last if ++$ ≥ 10; } 16:44
evalable6 4+2i
3+3i
2+3i
1+3i
0+3i
-1+3i
-2+3i
-3+3i
-4+3i
-5+3i
mscha Huh? 16:45
my $a = 5+i; my $step = -1+i; say ($a+$step, $a+2×$step ... *)[^10]; # Simpler, still broken 16:48
evalable6 (4+2i 3+3i 2+3i 1+3i 0+3i -1+3i -2+3i -3+3i -4+3i -5+3i)
16:52 scimon left
mscha github.com/rakudo/rakudo/issues/3344 16:52
16:53 sena_kun left
mscha m: my $a = 5+i; my $step = -1+i; loop (my $b = $a+$step; ; $b += $step) { say $b; last if ++$ ≥ 10; } 16:54
evalable6 4+2i
3+3i
2+4i
1+5i
0+6i
-1+7i
-2+8i
-3+9i
-4+10i
-5+11i
Geth advent: tmtvl++ created pull request #43:
Update drafts
16:56
advent: a013579013 | (Tom Browder)++ (committed using GitHub Web editor) | raku-advent-2019/schedule
update schedule
17:04
17:07 wamba1 left 17:08 sena_kun joined
Geth advent: be05891746 | (Tim Van den Langenbergh)++ (committed using GitHub Web editor) | raku-advent-2019/drafts
Update drafts
17:18
advent: 14201a542a | (Juan Julián Merelo Guervós)++ (committed using GitHub Web editor) | raku-advent-2019/drafts
Merge pull request #43 from tmtvl/patch-1

Update drafts
lizmat clickbaits rakudoweekly.blog/2019/12/09/2019-...-starring/ 17:33
Geth whateverable: f645470099 | (Aleks-Daniel Jakimenko-Aleksejev)++ | META6.json
Depend on “sake” instead of “Sake”

See #370 and github.com/ugexe/zef/issues/327.
17:54
18:10 stoned75 joined 18:20 chloekek joined 18:23 wildtrees joined 18:24 wildtrees left 18:27 knoop left 18:28 wamba joined, xinming_ left, knoop joined 18:29 xinming_ joined 18:39 wamba left, wamba joined 18:45 wildtrees joined 18:54 sena_kun left 19:08 sena_kun joined
sena_kun m: { :a, {{ True ?? :prefix<42> !! hash }} } 19:11
evalable6 (exit code 1) Odd number of elements found wher…
sena_kun, Full output: gist.github.com/85bc553f3ff505b36f...974739e3f6 19:12
sena_kun any ideas how to DWIM?
oops 19:14
m: { :a, |{ True ?? :prefix<42> !! hash } }
evalable6 (exit code 1) Odd number of elements found wher…
sena_kun, Full output: gist.github.com/f8b814e93a1f1551df...3e70f9f252
jmerelo Search results for Raku going up: binary input output Raku gets the official documentation in third place www.google.com/search?client=ubunt...p;oe=utf-8 19:46
tellable6 2019-12-10T04:56:21Z #raku <guifa> jmerelo Sent you an e-mail to your university account. Sorry for the delay!
jmerelo Still not the first, but we're getting there...
El_Che jmerelo: lo 19:54
19:58 jmerelo left 20:12 mscha left 20:14 daxim left 20:21 daxim joined 20:47 chloekek left 20:53 sena_kun left 20:59 joule left 21:03 thundergnat joined
thundergnat m: my $a = 5+i; my $step = -1+i; say ({$a + ++$ × $step} ... *)[^10] 21:04