This channel is intended for people just starting with the Raku Programming Language (raku.org). Logs are available at irclogs.raku.org/raku-beginner/live.html
Set by lizmat on 8 June 2022.
01:29 Manifest0 left 03:00 kjp left 03:01 kjp joined 03:03 kjp left, kjp joined
rcmlz I have API access - for using Jupyter::Chatbook - but no Plus or Pro account. Will check if I can switch the model to „reasoning“ to find out why I get Raku Code examples on generic CS questions. 04:42
09:05 Manifest0 joined 09:20 dakkar joined
pro1dream hello everybody. I have a question, is it possible to delegate all methods of a role to an attribute in a class? I tried it like this, but it doesn't work: class Foo does Positional { has @.real-list handles *; } my @l = [^5]; my $foo = Foo.new(real-list => @l); say $foo[1]; the documentation says that when I pass Whatever to the trait it should delegate to delegate all methods that the attribute 13:22
can call and: say so @l.WHAT.^can("AT-POS"); prints true. Am I missing something?
lizmat feels like you found a bug in dispatch :-( 13:31
m: liz@M1Mini CLI-Ecosystem % r 'class Foo { has @.real handles * }; my @l = ^5; my $foo := Foo.new(real => @l); say $foo.AT-POS(3)
class Foo { has @.real handles * }; my @l = ^5; my $foo := Foo.new(real => @l); say $foo.AT-POS(3) 13:32
camelia ===SORRY!=== Error while compiling <tmp>
Two terms in a row
at <tmp>:1
------> liz<HERE>@M1Mini CLI-Ecosystem % r 'class Foo { h
expecting any of:
infix
infix stopper
statement end
statement modifier…
lizmat m: class Foo { has @.real handles * }; my @l = ^5; my $foo := Foo.new(real => @l); say $foo.AT-POS(3)
camelia Index out of range. Is: 3, should be in 0..0
in block <unit> at <tmp> line 1
lizmat so, that does not dispatch to @!real
but this does:
m: class Foo { has @.real handles * }; my @l = ^5; my $foo := Foo.new(real => @l); say $foo.contains(3)
camelia Calling '.contains' on a Array, did you mean '$item (elem) @list'?
True
in block <unit> at <tmp> line 1
lizmat this is probably because: 13:33
m: dd Any.contains(3)
camelia No such method 'contains' for invocant of type 'Any'
in block <unit> at <tmp> line 1
lizmat so it looks like the "handles" applies only to methods that weren't provided already by inheritance 13:34
although the documentation is vague about this functionality: 13:35
"a Whatever (to delegate all methods that the attribute can call), or a HyperWhatever (to delegate all method calls, even ones that will lead to the attribute's FALLBACK method)"
pro1dream maybe raku.land/zef:lizmat/InterceptAllMethods is what you're looking for 13:36
and a use case to peruse: github.com/lizmat/Object-Trampolin...ne.rakumod 13:38
pro1dream aah, makes sense 13:44
yes, the documentation doesn't explicitly talk about this case 13:47
that's really interesting, I'll look into it, thanks!
lizmat so it *could* be a documentation issue
m: class Foo { has @.real handles <AT-POS> }; my @l = ^5; my $foo := Foo.new(real => @l); say $foo.contains(3) 13:48
camelia No such method 'contains' for invocant of type 'Foo'
in block <unit> at <tmp> line 1
lizmat m: class Foo { has @.real handles <AT-POS> }; my @l = ^5; my $foo := Foo.new(real => @l); say $foo[3]
camelia 3
lizmat as you can see, you *can* override specific methods that are already provided
pro1dream oh yes, I forgot to mention, I tried specifying the names of all methods from Positional and then it works 13:52
but I was trying to do it in a way that I didn't have to write all of them every time 13:53
lizmat ah, in that case, define a constant with the method names:\ 13:55
my constant methods = <AT-POS EXISTS-POS>
then specify that constant with the "handles" trait: 13:56
class Foo { has @.real handles methods }
you could put that constant specification in a separate module and export that, for wider usability 13:57
pro1dream that's a good idea, I noticed that I can also introspect a role or class if I need. It won't work in this case and I don't know about the performance but it's nice to know it's possible 14:03
class Foo does Positional { has @.real-list handles(Positional.^methods(:local)); } my @l = [^5]; my $foo = Foo.new(real-list => @l); say $foo.of(); 14:04
the only method in Positional is of but if I have my own role it might work
lizmat as long as the argument you give to "handles" has a compile-time value, you should be ok 14:05
pro1dream understood, thanks for the help! 14:06
lizmat yw 14:08
14:46 librasteve_ joined 17:32 dakkar left