🦋 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/fix-negated-junctions: cf867f8da0 | ab5tract++ | src/core.c/OperatorProperties.rakumod
Whitespace
00:42
rakudo/fix-negated-junctions: bc518ee0b8 | ab5tract++ | 8 files
Revision gating is not working with `&infix:<ne>`

I've tried all sorts of things, including moving all the sub declarations into `core_epilogue.rakumod` ... with some approaches the CORE.setting fails due to things happening too early or (as is the case with the current commented out code) using `ne` just causes an infinite hang. ... (7 more lines)
03:15 japhb left 03:17 japhb joined 03:30 librasteve_ left 03:33 japhb left 03:37 japhb joined
Geth rakudo: usev6++ created pull request #5692:
[JVM] Remove workarounds for broken deserialization of nqp::null
07:31
bartolin_ m: my $m = "foobar" ~~ /oo/; say $m.gist 08:54
camelia 「oo」
bartolin_ This fails on the JVM backend with "Cannot dispatch to method chomp on Match because it is not inherited or done by Str"
The backtrace points to github.com/rakudo/rakudo/blob/3f0f...kumod#L397 08:55
m: "foo".Match::chomp ## same error
camelia Cannot dispatch to method chomp on Match because it is not inherited or done by Str
in block <unit> at <tmp> line 1
bartolin_ But now I wonder, why/how this works on Moar. Does it take a different code path and never reaches that line? 08:56
09:00 bartolin_ left, bartolin joined 09:48 sena_kun joined
ab5tract the entire dispatch pipeline differs between the two now. I suspect this is a side effect of this 10:55
Geth rakudo/main: 3470f83867 | (Christian Bartolomäus)++ (committed using GitHub Web editor) | 2 files
[JVM] Remove workarounds for broken deserialization of nqp::null

This reverts commit 9f41d2c61a14ce468128c17334ca663ef8765c98.
The bandaid is no longer needed, because now nqp::null gets deserialized correctly: github.com/Raku/nqp/pull/829
This reverts commit 555f4b0049c58bf89301bdc06d9cbce0dbff1958.
The bandaid is no longer needed, because now nqp::null gets deserialized correctly: github.com/Raku/nqp/pull/829
11:06
nqp/main: 033ffd3a08 | ab5tract++ (committed using GitHub Web editor) | src/HLL/Compiler.nqp
Add is-interactive to HLL::Compiler (#827)

This commit nukes the hard-to-grok distinction of
  `interactive` vs `non-interactive` repl-modes and
replaces it with the following options:
   - `tty`
... (21 more lines)
11:49
rakudo/main: 167d1dd9a8 | (Elizabeth Mattijsen)++ | tools/templates/NQP_REVISION
Bump NQP to get new REPL mode settings ab5tract++
12:03
rakudo/fail-gracefully-outside-of-supported-terminal-emulator: 3470f83867 | (Christian Bartolomäus)++ (committed using GitHub Web editor) | 2 files
[JVM] Remove workarounds for broken deserialization of nqp::null

This reverts commit 9f41d2c61a14ce468128c17334ca663ef8765c98.
The bandaid is no longer needed, because now nqp::null gets deserialized correctly: github.com/Raku/nqp/pull/829
This reverts commit 555f4b0049c58bf89301bdc06d9cbce0dbff1958.
The bandaid is no longer needed, because now nqp::null gets deserialized correctly: github.com/Raku/nqp/pull/829
12:04
rakudo/fail-gracefully-outside-of-supported-terminal-emulator: 167d1dd9a8 | (Elizabeth Mattijsen)++ | tools/templates/NQP_REVISION
Bump NQP to get new REPL mode settings ab5tract++
rakudo/fail-gracefully-outside-of-supported-terminal-emulator: 03394c72d8 | (Elizabeth Mattijsen)++ (committed using GitHub Web editor) | 3 files
Merge branch 'main' into fail-gracefully-outside-of-supported-terminal-emulator
rakudo/main: 6c088c8cfc | ab5tract++ (committed using GitHub Web editor) | 5 files
Fail gracefully when REPL is initialized without TTY

This patch was originally intended to address R#4378 (#4378)[^1], but that problem is actually unresolvable as long as starting
  `raku` outside of a TTY automatically engages the wait-until-EOF
mode (the same behavior as calling `perl` without `-e`).
... (11 more lines)
12:05
linkable6 R#4378 [closed]: github.com/rakudo/rakudo/issues/4378 [Windows] `Git for Bash` has no TTY, so raku opens in "non-interactive" mode
bartolin lizmat: Could you maybe shed some light on my earlier question regarding the usage of "Match::chomp" in github.com/rakudo/rakudo/blob/3f0f...umod#L397? I'd like to understand how that works with Moar. 12:28
lizmat normally, method lookup starts with the class of the invocant 12:29
bartolin This would be Str in this case, right? 12:30
lizmat with a fully qualified method call, you're letting the method lookup start with the given class
yeah, looks like 12:31
bartolin ok, that's what I thought as well. But why doesn't it blow up?
m: "foo".Match::chomp
camelia Cannot dispatch to method chomp on Match because it is not inherited or done by Str
in block <unit> at <tmp> line 1
lizmat because .chomp is Cool ?
12:32 donaldh_ joined
lizmat and Match is as well ? 12:32
bartolin So it takes the implementation from Cool::chomp? That makes some sense to me.
But why doesn't it do the for the above evaluation? 12:33
lizmat the proto for .chomp lives in Cool
m: say 42.chomp 12:34
camelia 42
lizmat m: say 42.Match::chomp
camelia Cannot dispatch to method chomp on Match because it is not inherited or done by Int
in block <unit> at <tmp> line 1
lizmat hmmm
m: "foo" ~~ / foo /; dd $/.Match::chomp 12:35
camelia "foo"
12:35 donaldh left
lizmat m: "foo" ~~ / foo /; dd $/.chomp 12:35
camelia "foo"
lizmat m: "foo\n" ~~ / .* /; dd $/.chomp 12:36
camelia "foo"
lizmat m: "foo\n" ~~ / .* /; dd $/.Match::chomp
camelia "foo"
lizmat ok, I have no idea why the Match:: is there
bartolin It first came in with github.com/rakudo/rakudo/commit/f2c394120f where you qualified a lot of methods. Maybe it was just an oversight that in this case the invocant was not of type Match? 12:38
bartolin is still puzzled why it "just works" there, but not if one does "foo".Match::chomp 12:39
lizmat is now also confuse 12:40
d
apparently in b64e683 I once tried to clean up that mess... but it broke stuff
please feel free to remove the Match:: there
and see if that fixes / breaks things 12:41
bartolin ok, I'll try that out. Thanks for looking 12:42
lizmat maybe in MoarVM the type hierarchy is subtly different.. dunno 12:43
12:50 sena_kun left
ab5tract It could be something subtle that happens in the dispatcher too 13:13
bartolin I'll take a look there as well. but first my spectest for the JVM needs to finish ;) 13:17
Geth rakudo/main: 238e313ebf | (Elizabeth Mattijsen)++ | src/Perl6/Compiler.nqp
Fix typo in help
13:40
rakudo: usev6++ created pull request #5693:
Don't use Match::chomp on string
16:16
ab5tract I think I've been overthinking the necessary changes for revising &METAOP_NEGATE 17:58
I've been doing `$op.($op.(|c), False)` 17:59
but I don't think there's any actual cases where `$op.(|c) == False` wouldn't work 18:00
18:00 librasteve_ joined 18:07 sena_kun joined 18:13 Geth left, Geth joined
Geth nqp/main: 5a04b6411a | (Christian Bartolomäus)++ (committed using GitHub Web editor) | 2 files
[JVM] Fix nqp::attrinited for attribute set to null

It was wrong to use nqp::isnull for this check with ba4dc47799. An attribute that has been set to nqp::null is still initialized.
18:14
rakudo/main: b1f741f308 | (Elizabeth Mattijsen)++ | tools/templates/NQP_REVISION
[JVM] Bump NQP to get bartolin++ attrinited fixes
18:34
ab5tract The most major open question is whether `ne` can be adjusted in base, because revision gating is not working for it 18:51
m: say do if 1 ne 1|3|4 { 0 } else { 1 } 18:56
camelia 1
ab5tract I'll have to dig into how discussions evolved into deciding that this was the behavior to go with 18:58
lizmat there have been many 19:00
have at least 1 closed PR that tried to address this 19:01
ab5tract I'm hoping that revision gating in general will make it more palatable 19:09
FWIW, I personally do not think that `unless $foo eq $bar` --> `if $foo ne $bar` is more valuable than having `ne` DWIM for junctions, but this is obviously a controversial topic 19:31
Geth roast: 3c50d427e4 | (Christian Bartolomäus)++ | 13 files
[JVM] Fudge some failing tests

Hopefully we can get back these tests. But for now it's better to fudge them, so that regressions can be noticed.
Unfortunately there are more failing tests, but those look harder to fudge from a first glance. I'll try to further look into them.
19:37
lizmat bisectable6: $/ = 42; say "cow cow">>.match(:global, /co(.)/); say $/ 20:01
bisectable6 lizmat, Will bisect the whole range automagically because no endpoints were provided, hang tight
lizmat, ¦6c (85 commits): «((「cow」␤ 0 => 「w」 「cow」␤ 0 => 「w」))␤42␤» 20:02
lizmat, Nothing to bisect!
lizmat bisectable6: old=2023.04 $/ = 42; say "cow cow">>.match(:global, /co(.)/); say $/ 20:10
bisectable6 lizmat, On both starting points (old=2023.04 new=b1f741f) the exit code is 0 and the output is identical as well
lizmat, Output on both points: «((「cow」␤ 0 => 「w」 「cow」␤ 0 => 「w」))␤42␤»
lizmat bisectable6: old=2020.01 $/ = 42; say "cow cow">>.match(:global, /co(.)/); say $/ 20:11
bisectable6 lizmat, On both starting points (old=2020.01 new=b1f741f) the exit code is 0 and the output is identical as well
lizmat, Output on both points: «((「cow」␤ 0 => 「w」 「cow」␤ 0 => 「w」))␤42␤»
Geth nqp: usev6++ created pull request #831:
[JVM] Restore size of curlonglit array
20:13
rakudo: usev6++ created pull request #5695:
[JVM] Unbreak usage of "hash" with named args
20:42
rakudo/main: d3d08962a0 | (Christian Bartolomäus)++ (committed using GitHub Web editor) | src/core.c/Hash.rakumod
[JVM] Unbreak usage of "hash" with named args

A couple of spectests were failing when "hash" was used with named arguments, like so:
   $ ./rakudo-j -e 'say hash(a => 1)'
   Unexpected named argument 'a' passed
... (5 more lines)
20:46
nqp/main: c4b44e979a | (Christian Bartolomäus)++ | src/vm/jvm/runtime/org/raku/nqp/runtime/ThreadContext.java
[JVM] Restore size of curlonglit array

This was reduced in github.com/Raku/nqp/commit/f02dbe4c9b, but I'm now seeing ArrayIndexOutOfBoundsExceptions in a variety of
   spectests.
One evaluation that died with this error was the following (from roast's ... (7 more lines)
21:07
roast: 298aaac4d4 | (Christian Bartolomäus)++ | 2 files
[JVM] Unfudge tests for "hash" with named arg

This works again (faster than I thought). Fixed with
  github.com/rakudo/rakudo/commit/d3d08962a0
21:19
bartolin Hh, I just noticed github.com/rakudo/rakudo/commit/aca5e4c129. So ab5tract++ already digged into that, nice. I'm seeing test failures in that direction, but the commit should give me a good start. (But not today.) 21:38
22:47 sena_kun left