🦋 Welcome to the MAIN() IRC channel of the Raku Programming Language (raku.org). Log available at irclogs.raku.org/raku/live.html . If you're a beginner, you can also check out the #raku-beginner channel!
Set by lizmat on 6 September 2022.
00:19 zenmov joined
Geth advent/main: b3ea66ac69 | (Hillel Wayne)++ (committed using GitHub Web editor) | raku-advent-2024/authors.md
Add RAC article (#120)
00:33
01:25 guifa joined 01:29 Manifest0 left 02:03 zenmov left 02:11 zenmov joined 02:30 hulk joined, kylese left 02:33 _________ left 03:00 yewscion joined, kjp left 03:01 kjp joined 03:03 kjp left, kjp joined 03:06 yewscion left 03:15 hulk left, kylese joined 03:27 yewscion joined 03:33 yewscion left 05:23 zenmov left 06:20 Aedil joined 06:21 _________ joined 07:10 zenmov joined 08:43 kst joined
Geth advent/main: 136146c433 | ab5tract++ (committed using GitHub Web editor) | raku-advent-2024/authors.md
Add article on revision gating
08:53
Voldenet m: {} 09:04
camelia ( no output )
Voldenet also short, maybe not as short as 0
09:05 Manifest0 joined
Voldenet and empty does work with `raku -e ''` 09:05
09:20 dakkar joined 09:52 sena_kun joined 10:10 sena_kun left 10:17 MoC joined
Geth raku.org: pelanaut++ created pull request #226:
Atikon-Logo aktualisiert und mit www.atikon.com/ verlinkt
10:23
raku.org/main: 1ed6abbe5a | (Peter Lang)++ (committed by Elizabeth Mattijsen) | 2 files
Atikon-Logo aktualisiert und mit www.atikon.com/ verlinkt
10:24
11:44 Sgeo left 12:20 finanalyst joined 13:07 finanalyst left 14:46 librasteve_ joined
antononcube @lizmat I will play with "App::Ecosystems" soon. Should produce interesting package-dependency graphs. 15:35
Here is a such graph from 2022: imgur.com/33P7QmG 15:38
15:42 donaldh left 15:43 donaldh joined 15:44 pierrot left 15:45 pierrot joined, Ekho left, guifa left
I just filed a (low priority) metadata documentation issue to GitHub's repository for "App::Rak", which, I think, is a good idea to follow for all Raku package Git repositories. See: github.com/lizmat/App-Rak/issues/63 . 15:47
15:50 bdju left 15:51 bdju joined 15:53 Ekho joined
timo finanalyst.github.io/ModuleCitation/ do you know about this yet? 15:55
16:01 zenmov left
ugexe the graphs end in 2019 lol 16:20
timo there's a "fork me on github" button near the middle, presumably you can find a CI job there with some output or so? 16:22
16:47 MoC left
antononcube @ugexe I might have used some old or obsolete repository. 16:48
timo is REA a good primary source for this kind of information, or would the fez ecosystem be better? 16:54
antononcube @timo That kind of questions is why I proclaimed my anticipated use of lizmat's (new) "App::Ecosystems". 17:06
I.e. I hope that package to give "up to date" information. 17:07
timo makes sense, yeah 17:17
doing some analysis of historical data could be interesting at some point, too
antononcube I did such rudimentary analysis for a TRC-2022 presentation, but I was mostly focused on making/demoing a recommender for Raku packages. 17:21
17:32 dakkar left
botato I really like the interactive style of development supported by common lisp, or even to a decent extent python with autoreload/importlib.reload, where you can make changes to your code and run the new version without restarting the whole program and losing any state 18:55
it seems rakudo doesn't support reloading a module, is that something that long-term could be added, or just not possible for rakudo? 18:56
19:01 sena_kun joined
timo at first look, it seems tricky 19:01
but it depends a lot on what depth of "replacement" you expect from reloading a module
under what circumstances is it okay to abort and say "the before and after for $thing are not compatible enough for a hot reload"? 19:03
our metaobject protocol allows a fair bit of shenanigans, and if you are okay with "if you break it you get to keep the pieces" you can poke around in some internals with the ops that start with "nqp::" 19:06
ab5tract I wonde, how much of an obstacle is our current lack of a mechanism for parent classes to "inform" their child classes of augmentation? 19:07
in the broader context of hot reloading, I mean 19:08
timo right. okay, imagine we already had that, because i can think of a hacky way to do that that is very not fast and very not a good idea for production ...
ab5tract I think there might be interest in this even in the face of those concerns 19:09
I also wonder if we could leverage `:ver<>` in hot reloading efforts ... 19:12
timo m: class A:ver<1> { has $.foo }; class A:ver<2> { has Int $.foo }; say A.new(foo=>"hi"); 19:13
camelia ===SORRY!=== Error while compiling <tmp>
Redeclaration of symbol 'A'.
at <tmp>:1
------> s A:ver<1> { has $.foo }; class A:ver<2><HERE> { has Int $.foo }; say A.new(foo=>"hi")
expecting any of:
generic role
timo m: package First { class A:ver<1> { has $.foo }; }; package Second { class A:ver<2> { has Int $.foo }; }; say First::A.new(foo=>"hi"); say First::A.new() ~~ Second::A
camelia First::A.new(foo => "hi")
False
timo m: class PretendyClassHOW is Perl6::Metamodel::ClassHOW does Perl6::Metamodel::TypePretense { }; my $before_a := Perl6::Metamodel::ClassHOW.new_type(:1ver, :name("A")); $before_a.compose(); my $after_a := PretendyClassHOW.new_type(:2ver, :name("A")); $after_a.pretend_to_be([$before_a<>]); $after_a.compose(); say $before_a.new() ~~ $after_a; say $after_a.new() ~~ $before_a; 19:23
camelia ===SORRY!=== Error while compiling <tmp>
Invalid typename 'Perl6::Metamodel::TypePretense'
at <tmp>:1
------> sHOW does Perl6::Metamodel::TypePretense<HERE> { }; my $before_a := Perl6::Metamodel::
timo ah?
ab5tract could it be a bootstrap order issue? 19:24
timo i think that package is just not in scope
19:24 Aedil left
timo this is probably going to become too long for a single line of irc very fast 19:24
m: use Perl6::Metamodel:from<NQP>; class PretendyClassHOW is Perl6::Metamodel::ClassHOW does Perl6::Metamodel::TypePretense { }; my $before_a := Perl6::Metamodel::ClassHOW.new_type(:1ver, :name("A")); $before_a.compose(); my $after_a := PretendyClassHOW.new_type(:2ver, :name("A")); $after_a.pretend_to_be([$before_a<>]); $after_a.compose(); say $before_a.new() ~~ $after_a; say $after_a.new() ~~ 19:25
camelia ===SORRY!=== Error while compiling <tmp>
Missing required term after infix
at <tmp>:1
------> new() ~~ $after_a; say $after_a.new() ~~<HERE><EOL>
expecting any of:
prefix
term
timo $before_a;
dangit
that really was very fast
m: use Perl6::Metamodel:from<NQP>; class PCH is Perl6::Metamodel::ClassHOW does Perl6::Metamodel::TypePretense { }; my $a := Perl6::Metamodel::ClassHOW.new_type(:1ver, :name("A")); $a^.compose(); my $b := PretendyClassHOW.new_type(:2ver, :name("A")); $b.pretend_to_be([$a<>]); $b.^compose(); say $a.new() ~~ $b; say $b.new() ~~ $a; 19:27
camelia ===SORRY!=== Error while compiling <tmp>
Undeclared name:
PretendyClassHOW used at line 1
timo m: use Perl6::Metamodel:from<NQP>; class PCH is Perl6::Metamodel::ClassHOW does Perl6::Metamodel::TypePretense { }; my $a := Perl6::Metamodel::ClassHOW.new_type(:1ver, :name("A")); $a^.compose(); my $b := PCH.new_type(:2ver, :name("A")); $b.pretend_to_be([$a<>]); $b.^compose(); say $a.new() ~~ $b; say $b.new() ~~ $a;
camelia WARNINGS for <tmp>:
Useless use of "^" in expression "$a^.compose()" in sink context (line 1)
No such method 'compose' for invocant of type 'Any'
in block <unit> at <tmp> line 1
timo oops
m: use Perl6::Metamodel:from<NQP>; class PCH is Perl6::Metamodel::ClassHOW does Perl6::Metamodel::TypePretense { }; my $a := Perl6::Metamodel::ClassHOW.new_type(:1ver, :name("A")); $a.^compose(); my $b := PCH.new_type(:2ver, :name("A")); $b.pretend_to_be([$a<>]); $b.^compose(); say $a.new() ~~ $b; say $b.new() ~~ $a;
camelia Method A.pretend_to_be not found
in block <unit> at <tmp> line 1
timo m: use Perl6::Metamodel:from<NQP>; class PCH is Perl6::Metamodel::ClassHOW does Perl6::Metamodel::TypePretense { }; my $a := Perl6::Metamodel::ClassHOW.new_type(:1ver, :name("A")); $a.^compose(); my $b := PCH.new_type(:2ver, :name("A")); $b.^pretend_to_be([$a<>]); $b.^compose(); say $a.new() ~~ $b; say $b.new() ~~ $a; 19:28
camelia Too many positionals passed; expected 2 arguments but got 3
in block <unit> at <tmp> line 1
timo silly. 19:29
m: use Perl6::Metamodel:from<NQP>; class PCH is Perl6::Metamodel::ClassHOW does Perl6::Metamodel::TypePretense { }; my $a := Perl6::Metamodel::ClassHOW.new_type(:1ver, :name("A")); $a.^compose(); my $b := PCH.new_type(:2ver, :name("A")); $b.HOW.pretend_to_be([$a<>]); $b.^compose(); say $a.new() ~~ $b; say $b.new() ~~ $a;
camelia False
False
timo well, that's not HOW to do that
ab5tract :D 19:30
timo this is an area of the metamodel that i haven't touched before, i don't think 19:31
antononcube weekly: youtu.be/S_3e7liz4KM 19:32
notable6 antononcube, Noted! (weekly)
ab5tract antononcube++
REPL food for thought: "A problem with REPLs is that they embed an iterative design process, and potentially the only way to get back to a guaranteed state is to rerun the entire code history" 19:33
timo bpython has this cool "undo" feature where it actually reruns the whole history up until the previous line you executed :D 19:37
if there's side-effects in your code so far, well, tough luck ;) ;) 19:38
ok, i'm not feeling up to MOP noodling right now, I think 19:51
20:03 Sgeo joined
ab5tract that's fair :) 20:31
xinming With Cache::Async module, Is it possible to do .get-if-present("$key"), if not found, let Cache::Async handle the build in the background automatically? 20:47
Something like: my $d = $cache.get-if-present("$key"); unless $d { $cache.build("$key"); return "default" }; $cache.get("$key"); 20:49
Xliff Happy Turkey Day for those of you celebrating!
xinming What I mean is, when the data is not in cache, We return 'default' and build cache in the background. if cache is expired, We return stale cached value, also build in the background. 20:51
When I read the doc, it returns a Promise, I think I may need to hold the promise and wait for it to finish somewhere. otherwise, if I early return, The promise var goes out of scope, probably be aborted. 20:52
21:17 dustinm` left 21:20 dustinm` joined
ab5tract xinming: Maybe you can return the promise always? If the cache gives back the default (use a sentinel), then you give back the promise that will produce the result. If the cache has the value, you can create a Promise, create a Vow from that promise, then keep the vow with the value from the cache before returning the promise 22:01
I hope that makes sense and/or helps :)
22:22 sena_kun left 23:36 cm left 23:42 xinming left 23:45 cm joined