🦋 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. |
|||
ugexe | dev.azure.com/Rakudo/rakudo/_build...f7aca1e5fb | 00:10 | |
we are barely running and of the spectests. for example nothing from S16-* is shown | |||
s/and/any/ | |||
lizmat | Files=122, Tests=23900 | 00:12 | |
ugexe | at $work we have a CI test that fails of the number of successful tests is reduced by some large percentage | ||
lizmat | should be: Files=1359, Tests=119769 | 00:13 | |
I wonder whether the fudging messes up ? | |||
ugexe | dev.azure.com/Rakudo/rakudo/_build...b&l=47 | 00:14 | |
echo "making spectest.data smaller" | 00:15 | ||
cp t/spec/spectest.data t/spec/spectest.data.backup | |||
head -n 150 t/spec/spectest.data.backup > t/spec/spectest.data | |||
lizmat | wtf ? | ||
timo | haha, that's a fun thing to leave in there | 00:16 | |
presumably a left-over from redeveloping the CI | |||
so that it finishes faster while you're still making tens of changes per day | |||
lizmat | heh | ||
sleep& | |||
Geth | rakudo/ugexe-patch-2: a47c630618 | (Nick Logan)++ (committed using GitHub Web editor) | azure-pipelines.yml Run full spectest in CI |
00:21 | |
rakudo/main: ebecbeafa0 | (Nick Logan)++ (committed using GitHub Web editor) | azure-pipelines.yml Run full spectest in CI (#5747) |
00:51 | ||
rakudo/ugexe/deprecate-multi-file-operations: 4 commits pushed by (Nick Logan)++, ab5tract++ | 00:53 | ||
timo | ugexe++ well spotted | 01:04 | |
01:16
finanalyst left
01:44
guifa joined
|
|||
SmokeMachine | I wasn’t able to continue trying to fix the cromponent roblem today… :( | 01:52 | |
timo | last code block of docs.raku.org/language/modules#is_export shows a Rainbow bug again i think. the `sub foo() is export(:foo :s2 :net) {}` line has :s2 highlighted as REGEX_DELIMITER and the stuff after that, including the following line, as REGEX_LITERAL and REGEX_SPECIAL, and then somehow the end of the code block is interpreted as REGEX_DELIMITER, STRING, and REGEX_DELIMITER | 01:58 | |
ab5tract | SmokeMachine: me either :( | 02:46 | |
guifa | Ugh, looks like I'll really need to make that two exta args for handling multicast | 05:36 | |
source-specific host, and interface (though I was loathe to do that, there's no way to specify an interface with a hostname, only for IPv6 literals) | 05:37 | ||
default will be 0 which is (afaict) perfectly cromulent on all systems except Mac .... my dev system :) | |||
06:05
guifa left
06:42
samebchase joined
|
|||
Geth | rakudo/main: e7f9223c59 | (Christian Bartolomäus)++ (committed using GitHub Web editor) | src/core.c/stubs.rakumod [JVM] Add extra check for GLOBAL being null (#5710) This fixes a NullPointerException on the JVM backend for code like use v6.c.UNKNOWN That code does not blow up on MoarVM, which handles calling "WHO" on a null object gracefully. |
07:56 | |
08:52
sena_kun joined
09:05
Xliff left
|
|||
patrickb | ugexe, timo: The CI spec test mess up is on me. I was the one trying to take the PR from in dev to prod. Sorry for that... | 09:59 | |
timo | I'm not angry or anything | 11:24 | |
i'm still very happy about the improvements of the CI stuff | |||
do you think it's worth trying to split the spectest.data into two, three, or four parts / slices / partitions and run multiple jobs in parallel on azure? the test results should be merged together by the "publish test results" task i imagine, and it would possibly get us from commit to spec test results quicker? even if it will probably make newer commits have to wait a little longer for the | 11:27 | ||
simultaneous job limit to allow more to happen | |||
lizmat | doesn't it already run with TEST_JOBS=number of CPUS - 1 ? | 11:28 | |
timo | yeah but the VMs our stuff runs in doesn't have many CPUs ... not sure if it has more than one | ||
patrickb: can i consider the report of the Rainbow bug from ~12 hours ago "delivered" / "received"? | 12:02 | ||
patrickb did not see yet | |||
timo | here in irc | ||
> "last code block of docs.raku.org/language/modules#is_export shows [...]" | 12:03 | ||
patrickb | timo: Got it. Thanks! (I created todo.sr.ht/~patrickb/Rainbow/5) | 12:07 | |
timo | ladies and gentlemen ... this is rainbow number five! | 12:08 | |
lizmat | .oO( next to cloud #9 ) |
||
and yet another Rakudo Weekly News hits the Net: rakudoweekly.blog/2024/12/30/2024-...ate-rings/ | 12:38 | ||
14:21
finanalyst joined
|
|||
timo | i think we have multiple cases in the docs where we have both four space indentation and also =code mixed together, which the rendering makes into a block nested inside a block, which we probably don't want in almost all cases? | 15:04 | |
do we have like a trivial way to run a .grep or .map over all the RakuDoc that makes up the docs.raku.org data? | 15:05 | ||
finanalyst | timo: is this an issue with the current renderer, or the new Rakuast one? | 15:07 | |
care needs to be taken as the new AST parser is deceptively neutral about leading whitespace | 15:09 | ||
if the Rakudoc source has space and / or tab in the leading white space, the AST parser includes them as is | 15:10 | ||
so its possible to get problems when both are used to imply a code block. Is this the issue you mean? | 15:11 | ||
.tell leont I solved my module inside prove6 problem. Turns out it was a path spelling error on my part. Everything fine now | 15:12 | ||
tellable6 | finanalyst, I'll pass your message to leont | ||
timo | that sounds kind of like what i mean yeah | 15:15 | |
just the other day i pushed a commit that fixes such a situation | |||
maybe the patch wasn't correct and instead the rakudoc parser wants a change instead? | |||
docs.raku.org/language/regexes#Alternation:_|| don't have a screenshot of what it was before | 15:17 | ||
i think a search for \s+ followed by =code should find most examples of what i mean though | 15:18 | ||
no need to go at the rakudoc data structures necessarily | |||
finanalyst | timo: it is not the rakudoc parser but the Rakudo parser. I asked lizmat about this and the problem is there is a fierce difference of opinion about whether or not and how much a tab is worth in spaces | 15:31 | |
so the rakudo parser does not take a stance. But if your editor gives you four spaces to a tab, then you may not see it. | 15:32 | ||
Also leading whitespace in rakudoc is important, and this issue is mentioned. see raku.github.io/rakudoc for a much fuller explanation of indent | 15:33 | ||
but the thing you are suggesting is for there to be a check of all RakuDoc sources to find errors | 15:34 | ||
Geth | roast: 0905a199d0 | (Christian Bartolomäus)++ | integration/error-reporting.t [JVM] Unfudge passing test Fixed with github.com/rakudo/rakudo/commit/e7f9223c59. |
16:30 | |
18:08
finanalyst left
18:09
Altai-man joined
18:11
bartolin left
18:12
bartolin joined,
sena_kun left,
[Tux] left,
rypervenche left
18:13
rypervenche joined
18:26
[Tux] joined
|
|||
SmokeMachine | I was simplitying the code to try to figure out the problem and got a different error, have anyone seen this one? | 19:29 | |
www.irccloud.com/pastebin/eOcTo3Fc/ | |||
timo | looks like you're leaking some object that has a condition variable in it that goes into a serialization somewhere | 19:40 | |
SmokeMachine | it seems to be related to Cro::WebApp::Template::ASTBuilder | 19:43 | |
timo | probably a "monitor" class? | ||
SmokeMachine | not sure: github.com/croservices/cro-webapp/...rakumod#L3 | 19:45 | |
timo | a Promise might have a CondVar in it? | 19:47 | |
SmokeMachine | I'll try to search for it... | 19:51 | |
I created a new branch whith the minimal code to replicate it... | |||
20:00
Altai-man left
20:03
sena_kun joined
|
|||
SmokeMachine | with this github.com/FCO/Cromponent/blob/min...nt.rakumod and this github.com/FCO/Cromponent/blob/min...t.rakumod, if I run: `raku -Ilib -Ibin/lib -MSimpleTest -e'say SimpleTest.new.Str'` I get: usercontent.irccloud-cdn.com/file/.../image.png | 20:08 | |
and if I comment this line (github.com/FCO/Cromponent/blob/min...kumod#L19) it "works": usercontent.irccloud-cdn.com/file/.../image.png | 20:09 | ||
And if I add a cal to `$ast.compile`, it gives the original error... www.irccloud.com/pastebin/Ugluln8p/diff.diff | 20:15 | ||
usercontent.irccloud-cdn.com/file/.../image.png | 20:16 | ||
the odd thing is that without the `$ast.compile` it returns from the function,prints the `%compiled` and just then dies... | 20:19 | ||
I suppose that dies when the role ends being composed... | |||
just to point out that if I remove everything related to Cro templates, it works correctly... www.irccloud.com/pastebin/WKfuAYTU/diff.diff | 20:21 | ||
usercontent.irccloud-cdn.com/file/.../image.png | 20:22 | ||
timo | ah, the block in the map you're returning is closing over these lexicals | 20:36 | |
try moving that outside, or all the cro template stuff into its own block | 20:37 | ||
it could be the condvar comes from the template repository | 20:39 | ||
... hmm ... class Cro::Template::Repository is impossible-to-serialize { ... } | 20:44 | ||
21:20
guifa joined
|
|||
SmokeMachine | timo: but it is inside its own block (the sub compile-cromponent, no?) | 21:21 | |
timo | but that's the outer of the sub that you're returning | 21:24 | |
closures close over all their outers, that's how that captures these variables | 21:27 | ||
SmokeMachine | do you mean something like this? www.irccloud.com/pastebin/deeaFhZ0/ | 21:29 | |
timo | there the repository is still being closed over by the renderer sub | 21:31 | |
SmokeMachine | sorry, I don't get it... :( | 22:07 | |
timo | try moving the `sub (|) { return 42 }` all the way to the top of the code and make sure it doesn't have any Very Special things in the same block / scope it's in | 22:08 | |
SmokeMachine | but on the real code that will not exist... it should return the return of $ast.compile... | 22:10 | |
timo | right, then make something silly like | 22:11 | |
sub make-returner($value) { return sub (|) { $value } } | |||
that would then go all the way outside | |||
SmokeMachine | but the $ast.compile already returns a func... :( | 22:13 | |
timo | oh, ok | 22:15 | |
but does doing that make the error about CondVar being serialized go away though? | |||
SmokeMachine | you mean something like this? this still gives the same error www.irccloud.com/pastebin/EUESSTaT/a.raku | 22:17 | |
this too: www.irccloud.com/pastebin/gPSG2CCe/a.raku | 22:18 | ||
timo | ok, if i want to run your code, i just need to zef install Cro::WebApp::Template ? | 22:21 | |
SmokeMachine | yes, I think so... | ||
timo | Missing or wrong version of dependency 'EVAL_0' (from '/var/home/timo/raku/ecosystem/bughunt/cromponent/bin/lib/SimpleTest.rakumod (SimpleTest)') | 22:26 | |
:D | |||
SmokeMachine | 👍 | ||
timo | right now i have the two files from your message ~2.5h ago | 22:27 | |
SmokeMachine | would you like if I commit my current files? | ||
timo | i'm not sure. the error i'm getting, that's not the error you were getting, right? | 22:29 | |
SmokeMachine | that's one of them... | 22:30 | |
I pushed the current one... | 22:31 | ||
running : `raku -I. -Ibin/lib -MSimpleTest -e'say SimpleTest.new.Str'` gives this: | 22:32 | ||
www.irccloud.com/pastebin/LtERpdHz/ | |||
timo | ok good i now get the "cannot invoke" error | 22:33 | |
SmokeMachine | the intention here is to have a role that when added to a Class it will run the method RENDER from that class, compile it as a cro template (that returns a sub) and add that sub as a method to the class. That method receives the object it self as the only parameter and it is used as the data on the template... and I'm adding that with .^add_method to that exist inside the class itself and not have to compile it every call | 22:38 | |
timo | ok, so the explosion happens in a spot where we're trying to call &DYNAMIC with '$*TEMPLATE-REPOSITORY', that makes the "can't invoke an object belonging to blah blah" | 22:40 | |
the attempt to get &DYNAMIC returns a null | 22:41 | ||
SmokeMachine | how did you find it? | ||
timo | the magic of rr | 22:42 | |
SmokeMachine | rr? | 22:43 | |
timo | record and reply, from the mozilla project | ||
replay* | |||
i recorded the execution that exploded with "rr record raku -I blabla", then i grabbed the right PID and event number before the explosion with "rr replay -a -M" and jumped into a gdb nearby with "rr replay -f the-pid -g the-event" | 22:44 | ||
then i set up a breakpoint in MVM_exception_throw_adhoc and let it run | |||
from there i could just get the currently-being-executed bytecode with MVM_dump_bytecode(tc) and the values in the registers in question from tc->cur_frame->work[3].o and ->work[4].o | 22:45 | ||
one of them was a Str object, so i took the contents with MVM_repr_get_str(tc, $bla) and MVM_string_utf8_encode_C_string(tc, $blubb) | |||
the other was just a VMNull | |||
SmokeMachine | great, thank you very much! | 22:46 | |
timo | you need linux for rr :| | 22:47 | |
SmokeMachine | I'll try to findout that DYNAMIC | ||
22:48
finanalyst joined
|
|||
timo | i'm not sure why it's not able to find the TEMPLATE-REPOSITORY dynamic variable. i thought it would first try to getdynlex and only if that doesn't work even try to call DYNAMIC | 22:51 | |
22:53
sena_kun left
|
|||
timo | gist.github.com/timo/3972f33fe9683...c317f0627c this is a full backtrace | 22:54 | |
guifa | SWEET | ||
finally have it working | |||
multicast via syscal | |||
timo | it could very well be that one of the frames in the middle between compile-cromponent and the corresponding statement_prefix:sym<BEGIN> is acting as a wall through which no dynamic variables can go | 22:55 | |
guifa | method bind-udp(IO::Socket::Async:U: Str() $host, Int() $port where Port-Number, :$broadcast, :$multicast, Int() :$interface = 0, Str() :$only-from, :$loop-back, :$enc = 'utf-8', :$scheduler = $*SCHEDULER) { ... } is the final signature in Raku | 22:56 | |
SmokeMachine | oh! it's trying to get $*TEMPLATE-REPOSITORY | ||
timo | i'm also not 100% sure it's necessary to have a BEGIN in between for the case when you're already at begin time because you're running code in role composition, but that might just not be possible to skip without changes to Cro::WebApp::Template? | 22:57 | |
guifa: that's cool :) | |||
congrats on the breakthrough | 22:58 | ||
guifa | I still don't like that some of the options are ... less relevant when combined | ||
maybe it would be opportune on the Raku side to have bind-udp-multicast and bind-udp-broadcast | 22:59 | ||
timo | could having a bunch of multi candidates be an option? | ||
guifa | yeah | 23:00 | |
multi method bind-udp( .... :$broadcast); | |||
multi method bind-udp( ... , :$multicast!, Str() :$only-from, :$loop-back, :$interface ) | 23:01 | ||
actually could make the broadcast one separate too. it doesn't require anything handled diffferently on the backend really, but its IP should always be 255.255.255.255 | 23:05 | ||
would also automagically take care of the :broadcast, :multicast by tossing a no matching signature error | 23:07 | ||
lizmat | timo: re i thought it would first try to getdynlex and only if that doesn't work even try to call DYNAMIC | 23:46 | |
no, that's incorrect | |||
$*FOO is codegenned as &DYNAMIC('$*FOO') |