🦋 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.
00:23 vrurg_ joined, vrurg left 01:09 MasterDuke joined
timo m: my @*ARGS = ":"; sub MAIN(*@, *%) { }; 02:41
camelia MVMArray: Can't shift from an empty array
in block <unit> at <tmp> line 1
timo my $split := nqp::split("=",$optstring); 02:42
$optstring = nqp::shift($split);
explodes here
m: my @*ARGS = "-"; sub MAIN(*@, *%) { }; 02:43
camelia ( no output )
timo m: my @*ARGS = "/"; sub MAIN(*@, *%) { };
camelia ( no output ) 02:44
timo ah, right. neither of these hit that code path, because just - is explicitly filtered out, and the / has to go after a - or :, not in the same position 02:48
m: use nqp; say nqp::split("=", "")
camelia ()
timo m: use nqp; say nqp::split("=", "a") 02:49
camelia (a)
timo m: use nqp; dd nqp::split("=", "a"); dd nqp::split("=", "")
camelia ("a",)
()
timo literally an empty array that we're trying to shift from
m: say "".split("=").raku; say "a".split("=").raku 02:50
camelia ("",).Seq
("a",).Seq
timo different behaviour in the raku split from the nqp split
03:54 MasterDuke left
bartolin because we spoke about null checks yesterday. It looks like MoarVM has its own problems in that area. The first evaluation I ran this morning resulted in a segmentation fault. 'use nqp; say nqp::atkey({}, "foo")' 06:46
I'm sceptical that it is a good approach to try to make the JVM backend behave the same regarding to null handling. It feels cleaner to check before and just not doing the action on null objects. 06:52
one example that's still fresh in my mind would be github.com/rakudo/rakudo/pull/5379...2493004275 06:53
luckily there is no segmentation fault, but it's still nqp::atkey on a null object. (Unless I miss something.)
sorry for the rambling. maybe I should open an issue in the problem solving repo? 07:00
btw, my example with the segmentation fault wasn't a good one. 'use nqp; nqp::existskey({}, "foo")' also results in a segfault on MoarVM. And it gives a NullPointerException on the JVMbackend. 07:05
I've created github.com/rakudo/rakudo/issues/5697 for the problem with nqp::existskey. 07:44
09:32 sena_kun joined 10:13 sena_kun left
timo ok, that comes from the object at the associative delegation slot being null 13:06
how should we behave here, i wonder. maybe get_object_at_offset that pulls stuff out of a P6opaque's body should give VMNull instead of real null when there's a null at that offset 13:08
nine Wouldn't the correct thing be to auto-vivify if absent? 13:50
lizmat m: use nqp; say nqp::existskey(%(), "foo") 13:53
camelia 0
lizmat looks like Hash.new is taken a shortcut
multi method new(Map: --> Map:D) { 13:55
nqp::create(self)
}
yup
timo do we use getattr + atkey/bindkey/existskey everywhere we have a Map? 14:00
or do we directly point the atkey/bindkey/existskey at the Map object?
lizmat the former afaik
Geth rakudo/main: ba3b24cff2 | (Elizabeth Mattijsen)++ | src/core.c/Map.rakumod
Make sure Map.new has an NQP hash always

Fixes #5697
14:05
timo that doesn't feel like the right fix
lizmat why? how many times do you call Hash.new without arguments? 14:07
without making further changes to that hash later on ?
afk for a few hours&
timo i imagine there's a few situations where you have a datastructure where "named" stuff is optional, but it has a Hash in it anyway because of a "has %.foo"? or does that also delay initialisation with autoviv? 14:15
if there's no way to get rakudo to try to atkey/bindkey/existskey on the hash object directly, then trying to make nqp::blahkey work correctly is not crucial, because if you "use nqp", you get what you get (but not segfaults. ideally, never segfaults) 14:16
nine Because the underlying bug is still not fixed: 14:30
m: use nqp; my \A := Metamodel::ClassHOW.new_type(:name<A>); A.^add_attribute(Attribute.new(:name<$!a>, :type(Mu), :package(A), :auto_viv_primitive(nqp::hash), :associative_delegate)); A.^compose; nqp::existskey(A.new, "a")'
camelia ===SORRY!=== Error while compiling <tmp>
Two terms in a row
at <tmp>:1
------> ; A.^compose; nqp::existskey(A.new, "a")<HERE>'
expecting any of:
infix
infix stopper
statement end
statement modifier…
nine m: use nqp; my \A := Metamodel::ClassHOW.new_type(:name<A>); A.^add_attribute(Attribute.new(:name<$!a>, :type(Mu), :package(A), :auto_viv_primitive(nqp::hash), :associative_delegate)); A.^compose; nqp::existskey(A.new, "a")
camelia (signal SEGV)
timo m: use nqp; my \A := Metamodel::ClassHOW.new_type(:name<A>); A.^add_attribute(Attribute.new(:name<$!a>, :type(Mu), :package(A), :associative_delegate)); A.^compose; nqp::existskey(A.new, "a") 14:55
camelia (signal SEGV)
timo ^- unless we also error during composition when there's no auto viv on the associative delegate slot, just doing autoviv when accessing things through the associative delegate won't help unless we also grab VMNull instead of real-null with get_obj_at_offset 14:56
same kind of error presumably happens for pos delegate and atpos/existspos/bindpos 15:11
does existspos exist?
ugexe I use Hash.new without arguments and without potentially changing the hash later on 15:13
since {} is often ambiguous
that being said i'm not sure i use it anywhere that i need it to be highly optimized 15:17
timo i would suggest counting the number of objects created during a spec test run with some tracing tool and comparing a run or three with and without that change 15:41
nine I think that's missing the point. MoarVM must not segfault because of simply running some HLL code. We put much effort into preventing segfaults even when users do really wrong things like sharing totally unprotected hashes between threads. This case here is way more straight forward than that. 16:11
16:55 donaldh_ is now known as donaldh 18:36 sena_kun joined
[Coke] jdv: let's plan something mid December to go through a fake release so I'm up to speed? 18:46
(and have all the privs I might need, etc.)
19:02 sena_kun left
ab5tract #TeamNoSegfault 21:06
[Coke] (I can go through the motions on the release myself and just yell if I get stuck on something) 21:09
patrickb I currently try to get the long paths PR working on Windows. Looking good so far. Unrelated to those changes, I did notice though that the nativecall tests randomly fail when run with via the rest harness. It' always entire files that fail. About a third of t/04-nativecall fails, different files every time. 21:34
I can't get it to fail when I run a file manually.
Did anyone observe the same effect in the past? Is this a known issue?
ugexe from what i can recall the issue was with masterdukes complimenting PR that uses libuv for some other file operations. specifically something with mkdir was off i think 21:37
[Coke] patrickb: that sounds right on nativecall.
thought I hd a ticket on that but cannot find it. 21:40
patrickb ugexe: So it might actually be related to the path changes! 21:45
patrickb tries with a vanilla rakudo 21:46
ugexe gist.github.com/ugexe/0b48f8ebd7d0...03729071ab 22:23
that generates a raku program with 10k deep for loops
it seems to never finish running
(the generated program) 22:24
with 1000 instead of 10,000 the generated program finished almost instantly
patrickb Nope, it's unrelated to the long path PR. 22:28
It sucks that the problem only surfaces when running through TAP::Harness... 22:29
ugexe is it running tests in parallel? 22:30
patrickb I don't think so.
ow, actually it does 22:31
succeeds with --jobs=1 22:32
Found and fixed. Only happens when having compiled moar with debugging enabled. 23:08
ugexe: Do you remember which test was failing? I can't repro right away locally. 23:15
ugexe no, and it might have only been for mingw 23:16
patrickb Ok. I'll skim through the issues again. 23:17
ISTR MinGW was a build error, and the test failure was some mkdir test issue. 23:18
[Coke] patrickb++ 23:44