🦋 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.
Geth rakudo/main: 612dd255a6 | (Daniel Green)++ | src/Perl6/bootstrap.c/BOOTSTRAP.nqp
Make progress on unbreaking the JVM build

I was a bit too hasty with my earlier commits. It's still broken after this, but gets farther.
01:49
MasterDuke lizmat: any idea about the current jmv error? gist.github.com/MasterDuke17/95bf7...abda6ac228 05:53
*jvm 06:05
i wondered if the line count was off and tried the diff included in that gist, but it didn't change anything 06:06
lizmat .tell MasterDuke no idea :-( 09:33
tellable6 lizmat, I'll pass your message to MasterDuke
Geth rakudo/liz-Possible: b91cea9adb | (Elizabeth Mattijsen)++ | src/Perl6/bootstrap.c/BOOTSTRAP.nqp
Make Routine $!dispatcher a scalarless attribute

As it's only used internally
10:02
MasterDuke lizmat: fwiw, it looks like github.com/rakudo/rakudo/commit/99...a7715f9a06 is the commit that broke the jvm build 12:56
tellable6 2024-03-08T09:33:23Z #raku-dev <lizmat> MasterDuke no idea :-(
MasterDuke lizmat: in the new version there's no equivalent of `$param := nqp::hllizefor($param, 'Raku')` (and then later in the code there are comparisons against $param's type). obviously the new code builds and passes a spectest on moarvm, so i wonder if it's a bug in the jvm implementation? 13:11
lizmat MasterDuke: that is probably it... 13:12
perhaps add it conditionally on the non-MoarVM backend ?
MasterDuke but the new code does seem quite a bit different, i.e., are you sure the different checks are the same?
lizmat pretty sure they do... at least passes all test and spectest 13:13
fwiw, I thought I'd maybe mixed up the DEFINED/UNDEFINED check, but no: if I switch that, the spectest breakage is impressive :-) 13:14
MasterDuke it's this line github.com/rakudo/rakudo/commit/99...d3c53L3865 that i'm wondering about 13:15
because that seems it would matter when it gets down to github.com/rakudo/rakudo/commit/99...3874-L3876 13:16
lizmat github.com/rakudo/rakudo/commit/99...d3c53R3863
later on, only the type is checked, so I thought it make it clearer to make it the type object there already 13:18
it also allowed the if structure to become a ternary
MasterDuke hm. i guess .WHAT is doing the equivalent...
lizmat well, perhaps not: I'd suggest doing the HLLize there to see if it fixes that
MasterDuke hm. i could put all the old code back in an `#?if !moar` block, but maybe i can figure out a smaller change... 13:24
lizmat did you try putting the hllize on github.com/rakudo/rakudo/commit/99...d3c53R3863 ?? 13:27
MasterDuke trying `my $type := nqp::hllizefor($arg, 'Raku').WHAT;` now. however, it takes about 800s to fail, so have to wait a bit to see 13:29
lizmat yeah... it just takes too long on the JVM :-( 13:35
MasterDuke this branch i'm working on is a bit faster, but it's still pretty slow. it seems to be the rakuast stuff. '+++ Generating     gen/jvm/ast.nqp' is where half the total time is going (~450s on my branch). stage parse for core.c is only ~90s (compared to 45s for moarvm) 13:39
on main '+++ Generating     gen/jvm/ast.nqp' takes ~1400s
(i just found out about gnomon and am loving it, makes figuring out these timings so easy) 13:40
heh. now the build dies in a different way, but i think later and maybe because of my branch. now i get to test the *long* build on main... 13:49
lizmat meh... ok, if I push another micro opt in the mean time?
MasterDuke sure
Geth rakudo/main: fda0d13209 | (Elizabeth Mattijsen)++ | src/Perl6/bootstrap.c/BOOTSTRAP.nqp
Don't bother checking natives if no typecheck requested
13:51
MasterDuke heh. '+++ Generating     gen/moar/ast.nqp' is only 12s...i wonder why the jvm is *so* much worse, it's not usually 100x slower 14:25
MasterDuke hm. don't think that change was right. now it's dying with `Ambiguous call to Bool` 14:29
ab5tract I’ve said it before but maybe it’s time to put the JVM implementation out to pasture 14:30
ab5tract I don’t really like that we advertise a backend that is mostly unused, often broken, and without parity. 14:31
It doesn’t help that when people read that Raku runs on the JVM, they imagine that it interoperates with other JVM languages, which it doesn’t 14:33
I don’t mean that to discount your valiant efforts MasterDuke!
lizmat or bartolin's 14:34
Geth rakudo/main: 3e476241be | (Elizabeth Mattijsen)++ | 2 files
Cache dispatch info on Routine object

The dispatch order logic basically stores a list of hashes with condensed information about each dispatchee. And this is kept with the proto, to allow for faster "find_best_dispatchee" logic.
However, the condensed information about a candidate was re-created ... (10 more lines)
19:29
japhb Nice win, lizmat++ 21:41
MasterDuke i agree that the jvm backend is not all that it could be. but generally it doesn't take too much effort to keep it working 23:52
i really wish someone else knew truffle well enough to help out on that branch. even in it's very incomplete state it showed lots of promise 23:53
unfortunately i don't really understand it and pmurias hasn't been able to work on it for a while now