🦋 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: 52 commits pushed by (Jonathan Worthington)++, (Stefan Seifert)++
review: github.com/rakudo/rakudo/compare/a...3c85e7818a
08:03
nine So, back on fixing spectests :) 08:04
Btw. I did a bit of benchmarking compilation of NativeCall. rakuast-phase-cleanup brings RakuAST compilation time back down to that of the old frontend with the optimizer disabled albeit with about 5 % lower memory usage than the old one. 08:05
lizmat that's really nice! 08:06
nine I'd say that this is a good position to be in, considering that with RakuAST we do things during the actual compile phase that the old frontend leaves to the optimizer and that so far I have not cared about compilation performance at all. 08:07
lizmat right! 08:13
on optimizations: 09:16
m: say Q|foo()|.AST
camelia ===SORRY!=== Error while compiling EVAL_0
Undeclared routine:
foo used at line 1
lizmat I feel that that error is too early: surely one should be able to build synthetic ASTs this way without that error ? 09:17
nine: aka , that check should go in later, do you agree?
nine That error is thrown at CHECK time which is quite appropriate for...well checks 09:35
lizmat sure, but we do allow this: 09:37
m: my &foo; foo()
camelia No such method 'CALL-ME' for invocant of type 'Callable'
in block <unit> at <tmp> line 1
lizmat anyways, it's an annoyance 09:38
perhaps we need to have a way to call .AST and tell it not do CHECKs 09:39
Geth rakudo/main: 87065a329d | (Stefan Seifert)++ | src/Raku/ast/expressions.rakumod
RakuAST: fix inadvertent cyrring of Whatevers when it should only be WhateverCode
10:07
lizmat ooh... I missed the merge! 10:08
t/12-rakuast/highlight.rakutest fails for me, is that correct ? 10:26
ah only first time: suspect some precomp issue 10:27
1068! :-) 10:38
MasterDuke nine++ 15:26
ab5tract m: Q|my &foo; foo()|.AST.say 16:55
camelia RakuAST::StatementList.new(
RakuAST::Statement::Expression.new(
expression => RakuAST::VarDeclaration::Simple.new(
sigil => "\&",
desigilname => RakuAST::Name.from-identifier("foo")
)
),
RakuAST::Statement
ab5tract lizmat: I must be missing something, because it seems fine to me 16:56
Surely it shouldn’t be possible to call a routine before it’s been declared? 16:57
If it’s about generating the ast of the call to use synthetically, one should still expect to be required to obey the rules of the language when doing so? 16:58
m: my &foo; Q|foo()|.AST.say 16:59
camelia RakuAST::StatementList.new(
RakuAST::Statement::Expression.new(
expression => RakuAST::Call::Name.new(
name => RakuAST::Name.from-identifier("foo")
)
)
)
ab5tract Important to consider as well, as has been discussed previously, there’s not even a guarantee that .AST survives into general release 17:01
lizmat well, whatever .AST will be replaced with 17:12
because as a developer, it's really helpful 17:13
nine I bet there will be something to get an AST out of a string, probably with replacements/quasis. But all of that is macro land. We'll think about it when we get there 17:34
Geth rakudo/fix-precomp-build: 6f0201a6c8 | (Patrick Böker)++ | azure-pipelines.yml
Fix precomp build

  mirrorlist.centos.org is discontinued.
  serverfault.com/a/1161847
20:46
rakudo/fix-precomp-build: ba0a144a6b | (Patrick Böker)++ | azure-pipelines.yml
Fix precomp build

  mirrorlist.centos.org is discontinued.
  serverfault.com/a/1161847
20:55
rakudo/fix-precomp-build: 410e54eaeb | (Patrick Böker)++ | azure-pipelines.yml
Fix precomp build

  mirrorlist.centos.org is discontinued.
  serverfault.com/a/1161847
20:58
Geth rakudo/fix-precomp-build: 47e8ff8480 | (Patrick Böker)++ | 2 files
Fix precomp build

  mirrorlist.centos.org is discontinued.
  serverfault.com/a/1161847
21:25
rakudo/fix-precomp-build: 0b21441d4f | (Patrick Böker)++ | 2 files
Fix precomp build

  mirrorlist.centos.org is discontinued.
  serverfault.com/a/1161847
21:28
rakudo: patrickbkr++ created pull request #5614:
Fix precomp build
21:35
patrickb I've finally managed to do the precomp builds. The files are currently uploading. 22:02
ab5tract m: my %h; %h<array>.push: %( i => "d", a => %( b => "c" ), d => %( e => "f" )); say from-json(to-json(%h))<array>[0]; say %h ~~ %( array => [ %( i => "d", a => %( b => "c" ), d => %( e => "f" ))] ) # why? 22:49
camelia {a => {b => c}, d => {e => f}, i => d}
False
ab5tract m: my %h; %h<array>.push: %( i => "d", a => %( b => "c" ), d => %( e => "f" )); say from-json(to-json(%h))<array>[0]; say %h ~~ %( array => [ %( i => "d", a => %( b => "c" ), d => %( e => "f" ))] ); %h<array>[0] ~~ %( array => [ %( i => "d", a => %( b => "c" ), d => %( e => "f" ))] )<array>[0] 22:50
camelia {a => {b => c}, d => {e => f}, i => d}
False
ab5tract m: my %h; %h<array>.push: %( i => "d", a => %( b => "c" ), d => %( e => "f" )); say from-json(to-json(%h))<array>[0]; say %h ~~ %( array => [ %( i => "d", a => %( b => "c" ), d => %( e => "f" ))] ); say %h<array>[0] ~~ my $piece = %( array => [ %( i => "d", a => %( b => "c" ), d => %( e => "f" ))] )<array>[0]; dd :$piece
camelia {a => {b => c}, d => {e => f}, i => d}
:piece(:d(${:e("f")}))
False
True
ab5tract see #raku for the JSON-ification problematics 22:51
Encountering issues like these while trying to prepare a showcase for Raku amongst colleagues is disheartening, I cannot lie 22:53
I guess it’s just a Thing That Is, but I find having a Significant Trailing Comma to be as annoying or more so than when trailing commas are grammatically illegal 23:20
m: my %h; %h<array>.push: %( i => "d", a => %( b => "c" ), d => %( e => "f" )); say from-json(to-json(%h))<array>[0];  say %h ~~ %( array => [ %( i => "d", a => %( b => "c" ), d => %( e => "f" )),] ); say %h<array> ~~ my $piece = %( array => [ %( i => "d", a => %( b => "c" ), d => %( e => "f" ))] )<array>; dd :$piece
camelia {a => {b => c}, d => {e => f}, i => d}
:piece($[:a(${:b("c")}), :d(${:e("f")}), :i("d")])
True
False
ab5tract Argg, paste error
m: my %h; %h<array>.push: %( i => "d", a => %( b => "c" ), d => %( e => "f" )); say from-json(to-json(%h))<array>[0];  say %h ~~ %( array => [ %( i => "d", a => %( b => "c" ), d => %( e => "f" )),] ); say %h<array> ~~ my $piece = %( array => [ %( i => "d", a => %( b => "c" ), d => %( e => "f" )),] )<array>; dd :$piece
camelia {a => {b => c}, d => {e => f}, i => d}
:piece($[{:a(${:b("c")}), :d(${:e("f")}), :i("d")},])
True
True
ab5tract Still unclear to me why this would result in the JSON parser pretending like there isn’t a hash declared as an element of the array.. maybe that will be more clear by morning 23:22
It’s probably slipping when it “shouldn’t” (maybe there is a good reason that I’ll understand later) 23:30