🦋 Welcome to the MAIN() IRC channel of the Raku Programming Language (raku.org). Log available at irclogs.raku.org/raku/live.html . If you're a beginner, you can also check out the #raku-beginner channel! Set by lizmat on 6 September 2022. |
|||
00:00
reportable6 left,
reportable6 joined
00:05
eroux left
00:07
eroux joined
00:12
eroux left
00:22
eroux joined
00:43
jpn left
00:46
jpn joined
00:51
jpn left
01:04
eroux left
01:11
rf joined
01:13
razetime joined
01:31
eroux joined
02:19
jpn joined
02:24
jpn left
02:26
rf left
|
|||
antononcube | @Coke Did you present at the The Perl and Raku conference two weeks ago? | 02:41 | |
[Coke] | Nope, I didn't attend | 02:42 | |
antononcube | Ah, for some reason I though you were going to... | 02:43 | |
02:51
Xliff left
02:58
andydude joined
03:58
unicodable6 left,
nativecallable6 left,
bisectable6 left,
quotable6 left,
reportable6 left,
greppable6 left,
statisfiable6 left,
releasable6 left,
sourceable6 left,
notable6 left,
shareable6 left,
squashable6 left,
tellable6 left,
benchable6 left,
evalable6 left,
bloatable6 left,
coverable6 left,
linkable6 left,
committable6 left,
benchable6 joined,
quotable6 joined,
linkable6 joined,
evalable6 joined
03:59
bisectable6 joined,
bloatable6 joined,
releasable6 joined,
nativecallable6 joined,
squashable6 joined,
sourceable6 joined,
tellable6 joined
04:00
statisfiable6 joined,
notable6 joined,
shareable6 joined,
coverable6 joined,
reportable6 joined
04:01
unicodable6 joined,
committable6 joined,
greppable6 joined
04:07
jpn joined
04:12
jpn left
04:16
razetime left
|
|||
guifa__ | m: subset X of Str() where *.so; class A { method a (X $x) { $x.say }; }; my A $a .= new; (1..10).hyper(:batch(1), :degree(2)).map({ $a.a($_); }); | 04:18 | |
camelia | 1 2 3 4 5 6 7 8 9 10 |
||
guifa__ | xinming: you can also make it a coercing type, to handle the conversion from int to string automatically if it´s not a string | 04:19 | |
04:41
teatwo joined
|
|||
[Coke] | ended up going to CT and getting covid instead, not an upgrade | 04:42 | |
04:42
teatwo left
04:43
teatwo joined
04:44
teatime left
04:56
razetime joined
05:02
jpn joined
05:06
jpn left
05:27
jpn joined
06:00
reportable6 left
06:02
reportable6 joined
|
|||
xinming | guifa__: So there is diff between subset X of Str and subset X of Str() | 06:22 | |
What are the subtle diff between them? | |||
This worked, But It's quite confusing then, Why will `subset X of Str where ..` worked without hyper | 06:23 | ||
m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where * (elem) %m.keys.Set; sub a (X $x) { $x.say }; ("a" .. "c").hyper(:batch(1), :degree(2)).map({ a($_); }); | 06:26 | ||
camelia | A worker in a parallel iteration (hyper or race) initiated here: in block <unit> at <tmp> line 1 Died at: Type check failed in binding to parameter '$x'; expected X but got Str ("a") in sub a at <tmp> line 1 in block at… |
||
xinming | guifa__: with coercing type, it still fails. | ||
I believe this is a bug | |||
07:03
linkable6_ joined,
evalable6_ joined
07:11
jpn left,
andydude left,
eroux left,
Sgeo left,
tejr left,
m_athias left,
nine_ left,
reportable6 left,
committable6 left,
unicodable6 left,
coverable6 left,
shareable6 left,
notable6 left,
tellable6 left,
squashable6 left,
nativecallable6 left,
releasable6 left,
bisectable6 left,
evalable6 left,
linkable6 left,
benchable6 left,
PipStuart left,
andinus left,
kjp left,
ProperN[out] left,
daxim left,
summerisle left,
perlmaros left,
guifa__ left,
mjgardner left,
SmokeMachine left,
gabiruh left,
samcv left,
jetchisel left,
tobs left,
patrickb left,
atweedie left,
corwin left,
ugexe left,
zostay left,
slu left,
hexology left,
Ekho left,
hellwolf left,
discord-raku-bot left,
Util left,
greppable6 left,
statisfiable6 left,
sourceable6 left,
bloatable6 left,
quotable6 left,
Scotteh_ left,
human-blip left,
RonaldR34g4m left,
samebchase left,
jast left,
ilogger2 left,
polettix left,
uzl[m] left,
tbrowder_ left,
xkr47 left,
tailgate left,
rypervenche left,
justache left,
mark22k left,
Sevalecan left,
amenonsen left,
DarthGandalf left,
oodani left,
perryprog left,
mtj left,
PotatoGim left,
askmeaboutloom left,
cm left,
GreaseMonkey left,
Altreus left,
clarkema left,
xinming left,
kst left,
jgaz left,
jrjsmrtn left,
gfldex left,
elcaro left,
Voldenet left,
dg left,
Aedil left,
simcop2387 left,
avuserow left,
tinita left,
timo left,
charsbar left,
dutchie left,
donpdonp|z_ left,
nicole left,
vrurg left,
tonyo left,
zups left,
silug left,
thowe left,
esh left,
kawaii left,
Matthew|m left,
MitarashiDango[m left,
Orbstheorem left,
moritz left
07:12
jpn left,
Vyrus joined,
clarkema joined,
atweedie joined,
patrickb joined
07:17
tobs joined,
jetchisel joined,
samcv joined,
gabiruh joined,
SmokeMachine joined,
mjgardner joined,
samebchase joined,
human-blip joined,
Scotteh_ joined,
quotable6 joined,
bloatable6 joined,
sourceable6 joined,
statisfiable6 joined,
greppable6 joined,
rypervenche joined,
tailgate joined,
xkr47 joined,
tbrowder_ joined,
nicole joined,
donpdonp|z_ joined,
dutchie joined,
charsbar joined,
timo joined,
tinita joined,
avuserow joined,
simcop2387 joined,
Aedil joined,
dg joined,
Voldenet joined,
elcaro joined,
gfldex joined,
jrjsmrtn joined,
jgaz joined,
kst joined,
xinming joined,
moritz joined,
Util joined,
discord-raku-bot joined,
hellwolf joined,
kawaii joined,
esh joined,
thowe joined,
silug joined,
zups joined,
tonyo joined,
vrurg joined,
nine_ joined,
m_athias joined,
tejr joined,
Sgeo joined,
andydude joined,
jpn joined,
corwin joined,
ugexe joined,
zostay joined,
slu joined,
hexology joined
07:18
reportable6 joined,
committable6 joined,
unicodable6 joined,
coverable6 joined,
shareable6 joined,
notable6 joined,
tellable6 joined,
squashable6 joined,
nativecallable6 joined,
releasable6 joined,
bisectable6 joined,
benchable6 joined,
PipStuart joined,
andinus joined,
kjp joined,
ProperN[out] joined,
daxim joined,
summerisle joined,
perlmaros joined,
guifa__ joined
07:19
tib is now known as 020AAC0DL,
guifa__ joined,
perlmaros joined,
summerisle joined,
daxim joined,
ProperN[out] joined,
kjp joined,
andinus joined,
PipStuart joined,
benchable6 joined,
bisectable6 joined,
releasable6 joined,
nativecallable6 joined,
squashable6 joined,
tellable6 joined,
notable6 joined,
shareable6 joined,
coverable6 joined,
unicodable6 joined,
committable6 joined,
reportable6 joined,
hexology joined,
slu joined,
zostay joined,
ugexe joined,
corwin joined,
polettix joined,
ilogger2 joined,
jast joined,
tobs joined,
jetchisel joined,
samcv joined,
gabiruh joined,
SmokeMachine joined,
mjgardner joined,
samebchase joined,
human-blip joined,
Scotteh_ joined,
quotable6 joined,
bloatable6 joined,
sourceable6 joined,
statisfiable6 joined,
greppable6 joined,
rypervenche joined,
tailgate joined,
xkr47 joined,
tbrowder_ joined,
nicole joined,
donpdonp|z_ joined,
dutchie joined,
charsbar joined,
timo joined,
tinita joined,
avuserow joined,
simcop2387 joined,
Aedil joined,
dg joined,
Voldenet joined,
elcaro joined,
gfldex joined,
jrjsmrtn joined,
jgaz joined,
kst joined,
xinming joined,
moritz joined,
Util joined,
discord-raku-bot joined,
hellwolf joined,
kawaii joined,
esh joined,
thowe joined,
silug joined,
zups joined,
tonyo joined,
vrurg joined,
nine_ joined,
m_athias joined,
tejr joined,
Sgeo joined,
andydude joined,
jpn joined,
dustinm` left,
jmcgnh left
|
|||
xinming | my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where * (elem) %m; sub a (X $x) { $x.say }; ("a" .. "c").hyper(:batch(1), :degree(2)).map({ a($_); }); | 07:20 | |
m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where * (elem) %m; sub a (X $x) { $x.say }; ("a" .. "c").hyper(:batch(1), :degree(2)).map({ a($_); }); | |||
camelia | A worker in a parallel iteration (hyper or race) initiated here: in block <unit> at <tmp> line 1 Died at: Type check failed in binding to parameter '$x'; expected X but got Str ("a") in sub a at <tmp> line 1 in block at… |
||
07:20
dustinm` joined
07:21
Altreus joined,
GreaseMonkey joined,
cm joined,
mtj joined,
PotatoGim joined,
perryprog joined,
askmeaboutloom joined,
oodani joined,
DarthGandalf joined,
amenonsen joined,
Sevalecan joined,
mark22k joined,
justache joined
07:24
sivoais left,
Orbstheorem joined
07:25
sivoais joined
07:27
eroux joined
07:31
jpn left,
jmcgnh joined
07:34
squashable6 left
07:35
Ekho joined
07:37
squashable6 joined
08:09
dakkar joined
08:10
sena_kun joined,
andydude left
|
|||
xinming | I think I found where the bug is | 08:14 | |
08:14
Matthew|m joined
|
|||
xinming | m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where { $_ (elem) %m }; sub a (X $x) { $x.say }; ("a" .. "c").hyper(:batch(1), :degree(2)).map({ a($_); }); | 08:14 | |
camelia | a b c |
||
08:15
MitarashiDango[m joined
|
|||
xinming | m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where * (elem) %m; sub a (X $x) { $x.say }; ("a" .. "c").hyper(:batch(1), :degree(2)).map({ a($_); }); | 08:15 | |
camelia | A worker in a parallel iteration (hyper or race) initiated here: in block <unit> at <tmp> line 1 Died at: Type check failed in binding to parameter '$x'; expected X but got Str ("a") in sub a at <tmp> line 1 in block at… |
||
08:15
uzl[m] joined
|
|||
xinming | `where * (elem) %m` will raise error, But `where { $_ (elem) %m }` will work | 08:15 | |
So anyone here could explaiin this please? :-) | 08:16 | ||
I feel this bug is greater than I thought, on my program, It still raises error with `where { $_ (elem) %m }` version, But the test oneliner works | 08:22 | ||
08:22
razetime left
08:25
Sgeo left
09:07
razetime joined
09:14
razetime left
09:26
jpn joined
09:31
jpn left,
jpn joined
|
|||
SmokeMachine | m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where * (elem) %m; sub a (X $x) { $x.say }; ("a" .. "c").map({ a($_); }); | 09:47 | |
camelia | a b c |
||
SmokeMachine | m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where * (elem) %m; sub a (X $x) { $x.say }; for "a" .. "c" { start say a($_) } | 09:49 | |
camelia | ( no output ) | ||
SmokeMachine | m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where * (elem) %m; sub a (X $x) { $x.say }; await do for "a" .. "c" { start say a($_) } | 09:50 | |
camelia | An operation first awaited: in block <unit> at <tmp> line 1 Died with the exception: Type check failed in binding to parameter '$x'; expected X but got Str ("a") in sub a at <tmp> line 1 in code at <tmp> line 1 |
||
09:50
razetime joined
|
|||
SmokeMachine | m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where { $_ (elem) %m }; sub a (X $x) { $x.say }; await do for "a" .. "c" { start say a($_) } | 09:50 | |
camelia | a True b True c True |
||
SmokeMachine | m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where * (elem) %m; sub a (X $x) { $x.say }; await (start({ a(“a”) }), start { a “b” }) | 09:52 | |
camelia | ===SORRY!=== Error while compiling <tmp> Undeclared routine: start used at line 1. Did you mean 'spurt', 'sqrt', 'sort'? |
||
SmokeMachine | 10:52 <SmokeMachine> m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where * (elem) %m; sub a (X $x) { $x.say }; await (start { a(“a”) }, start { a “b” }) | 09:53 | |
m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where * (elem) %m; sub a (X $x) { $x.say }; await (start { a(“a”) }, start { a “b” }) | |||
camelia | An operation first awaited: in block <unit> at <tmp> line 1 Died with the exception: Type check failed in binding to parameter '$x'; expected X but got Str ("a") in sub a at <tmp> line 1 in block at <tmp> line 1 |
||
SmokeMachine | xinming: I agree… that looks like a bug… | 09:54 | |
09:57
guifa__ left
09:58
guifa joined
|
|||
SmokeMachine | m: my %m = ("a" => 1, "b" => 2, "c" => 3); subset X of Str() where { $_ (elem) %m }; sub a (X $x) { $x.say }; await (start { a(“a”) }, start { a “b” }) | 10:02 | |
camelia | a b |
||
xinming | there is a small diff between `where { $_ (elem) %m }` and `where * (elem) %m` | 10:26 | |
without .hyper it works fine, with hyper, we can see the differences. | 10:27 | ||
nemokosch | not even surprised | 10:35 | |
not gonna lie, I have high hopes for RakuAST to eliminate WhateverCode weirdnesses | 10:42 | ||
10:44
NemokoschKiwi joined
|
|||
xinming | nemokosch, When will RakuAst merged then? | 10:49 | |
lizmat | xinming: there's two things here: | 10:50 | |
the RakuAST classes for building ASTs: these are available now when doing either "use experimental :rakuast" or "use v6.e.PREVIEW" | |||
the new Raku grammar that uses RakuAST classes to build AST from code: this can be activated with RAKUDO_RAKUAST=1 | 10:51 | ||
nemokosch | I'm thinking of the RakuAST based grammar, for that matter | 10:52 | |
lizmat | this will be ready when it can a: pass all spectests, and b: can build the setting | 10:54 | |
that's when we can start thinking about releasing a 6.e language level | |||
xinming | lizmat: just tried with `use experimental :rakuast`, that bug is gone. | ||
lizmat: when is it possible to happen according to your guess? | 10:55 | ||
lizmat | *that* shouldn't have made any difference with that bug | ||
10:55
jpn_ joined
|
|||
nemokosch | yeah sounds weird | 10:56 | |
also, I noticed that the RakuAST representation is not what I assumed it to become | |||
I checked on that pick xx 5 situation | 10:57 | ||
and the AST representation downright contained a thunk wrapper on the left handside | |||
xinming | lizmat: Yea, My mistake, I tested on the wrong example. | ||
lizmat | nemokosch some bugs may have been ported :-) | ||
10:58
jpn left
|
|||
nemokosch | hm, I'm not sure | 10:58 | |
my point is that apparently the parsing process examined the operator semantically | |||
and I would have assumed that was not the task of it, quite the contrary | |||
11:00
jpn joined
11:01
jpn_ left
|
|||
I'd have expected (^10).pick + 5 and (^10).pick xx 5 to look the same, except for the one node of the operator on top | 11:01 | ||
lizmat | if the left side there wouldn't get thunked, you would get 5x the same random value | 11:02 | |
so xx does need special grammar handling] | |||
nemokosch | I'm not sure if it needs special grammar handling with RakuAST - and more importantly, thunking doesn't affect the syntax so it would be weird to call something an AST that already investigates the behavior of certain operators | 11:04 | |
anyway, when you evaluate the node of operator xx, you still have access to the expressions constructed as its operands, so why couldn't thunking only happen then? | 11:05 | ||
xinming | lizmat: BTW, is the bug `where * (elem) ..` vs `where { $_ (elem) .. }` easy to fix? | 11:06 | |
lizmat | so I guess you'd be ok with needing to specify | ||
{ (^10).pick } xx 5 | |||
then? | |||
xinming: I have *no* idea | |||
I would have to dive into that part of the grammar, and that is currently not on my shortlist of things to do | 11:07 | ||
I suggest you make an issue for it so that it doesn't fall through the cracks | |||
nemokosch | I think that shouldn't be needed with proper RakuAST evalling at all, quite the opposite | ||
I think by now it should be possible to let users define thunkiness for operators, instead of compiler hacking | |||
if a RakuAST expression is evaluated starting from the root node, there seems to be no problem to decide if a subtree needs to be thunked or not | 11:09 | ||
lizmat | I think by now more people should be involved in making RakuAST work | ||
so: well volunteered :-) | |||
xinming | lizmat: Ok, Will fire a bug so this can be fixed. | 11:10 | |
lizmat | xinming: thanks, and please a nice, short golf :-) | ||
nemokosch | I think it's hard to expect people to work on something that is nowhere explained or written down | 11:11 | |
11:11
jpn left
|
|||
lizmat | nemokosch that goes for all involved | 11:11 | |
nemokosch | and frankly, Jonathan Worthington has responsibility | ||
lizmat | well, technically, the RSC has responsibility nowadays | 11:12 | |
nemokosch | that's why it was so weird when he summarized it as "oh it's so nice that people found my work worthy of continuing" | ||
duh, like that was meant to be "the big thing" | |||
lizmat | that goes for all open source projects | 11:13 | |
nemokosch | I don't think it goes for all open source projects that somebody initiates a monstrous task that is meant to be "the next big thing" | ||
completes it to 20% and then leaves it behind with little to no resource about it | 11:14 | ||
it's not just whether you are personally okay with it; it's just this mindset is overwhelmingly prone to failure | |||
and of course if the one who invented the whole thing won't leave anything technical behind, how could one expect the poor others who just try to figure something out on their own and make it happen "whatever it takes" | 11:15 | ||
this goes for basically all of Rakudo - you need have enough fanatism to compensate for your lack of knowledge, and the less you know, the more fanatism you need | 11:17 | ||
lizmat | github.com/rakudo/rakudo/blob/main.../README.md | 11:18 | |
nemokosch | Yes, I said it aware of this file | 11:24 | |
take one example: what about the gazillion of FULL-UPPERCASE-MAGIC-METHODS? | 11:25 | ||
the architecture is strongly based on this assumption that you are going to inherit/mix in stuff that provides a service, and some services inherit even from each other | 11:27 | ||
jast | I don't see how this could be done better in the early phases of something highly speculative | 11:28 | |
nemokosch | outlining the speculations would also help | ||
jast | you can't start making something without assumptions and you usually for some time won't know which assumptions are the right ones | ||
nemokosch | anyway, if you are a design architect, this is not the kind of documentations you should provide for the people who will do the work | 11:29 | |
if you only compare it to vrurg's presentations on Rakudo, you can already see the layers of difference | |||
jast | I mean... you don't really know ahead of time how a project like this will develop, right? | ||
I mean... you don't really know ahead of time how a project like this will develop, right? | 11:30 | ||
nemokosch | by the way, it's really said there was no continuation of that | ||
jast | I'm not saying that this was done optimally, but I understand how it came to be this way | ||
nemokosch | I do think it's a problem that we have a bunch of friends, or comrades at least, who will just stand for each other, whether some serious mistake has been made objectively, or not | 11:31 | |
nobody dares to say that the way RakuAST was left behind for the rest was unmanageable | |||
and therefore there is no urge to improve on the situation, the mistakes are simply denied | 11:32 | ||
jast | I don't know jnthn at all | ||
nemokosch | if you are not fanatic enough, you are out, basically | ||
or you are useless at least | |||
jast | well I think we exchanged about two lines in IRC once | 11:33 | |
mainly I just don't see how blaming someone will change anything | 11:34 | ||
nemokosch | It's rather the other way around imo | ||
if you can't even agree that some action, or lack of action, is harmful for the project, how can you be dedicated to do it right? | 11:35 | ||
jast | "harmful" is a big word | ||
nemokosch | not too big in this case, I don't thinkso | ||
and here in this situation, the problem is pretty much that nobody is willing to claim to know RakuAST enough to teach others | |||
teach as in, post some documents about the architecture or make a couple of hours presentation | 11:36 | ||
jast | clearly this project didn't turn out so well if it's been in "early design phase" for over a year | 11:38 | |
but the time we're spending in this discussion you could have spent digging into it instead if it matters this much to you :) | |||
nemokosch | Yeah this is a common one | 11:39 | |
jast | well, you seem to be saying jnthn has an obligation to put in his spare time... and you don't | ||
nemokosch | the sad truth is, I still have higher hopes that one day the project gets better managed, than that I will single-handedly solve the RakuAST issue | ||
well, if a so called "language in production" depended on solely my judgement, I would probably be more careful | 11:40 | ||
especially if this situation emerged mostly my lack of knowledge-sharing | |||
because of* | |||
jast | well, nobody is perfect | 11:41 | |
nemokosch | and really, I'm not saying that jnthn should keep doing XYZ stuff | 11:42 | |
I'm saying that if you leave a project for a larger amount of time that depends so much on your knowledge, at least do take the effort to share it so someone else can pick up | |||
that's a one-time effort | |||
and this is something people would expect from you, and you would expect from others, for any non-toy project | 11:43 | ||
jast | I don't really know his circumstances, but it's quite possible that things simply happened in such a way that that didn't work out so well | ||
lizmat feels like this discussion has been had many times already and will now recuse herself | 11:44 | ||
jast | but we could turn this around just as well: nobody else stepped up to get involved just as deeply | ||
nemokosch | also, I don't know how it is for you but now that we are at it, I did bother to fix a couple of Rakudo bugs, to trace others' problems back in the core, to explain how things work, I did watch the Rakudo-related presentations in the last couple of years, and so on | 11:46 | |
jast | I'd like to think I could do a great job of documenting things if I had been in a similar position, but I can't be certain really | ||
nemokosch | so fair enough, I'm not up there with lizmat and the likes but I do think I did more than an average potential contributor would | 11:47 | |
jast | which is great but entirely irrelevant to this topic | ||
nemokosch | not if you are framing it as "duh you are just lazy to do it yourself" | 11:48 | |
jast | that's not what I'm saying | ||
nemokosch | then I really see no point in beating the dead horse with this "if this matters so much for you..." sentiment | ||
and this seems to be the big difference between what I think would be healthy and what the very few knowledgeable and influential people are doing in this community | 11:50 | ||
jast | I'm saying that well, jnthn didn't do everything, and nobody else filled the gap (to your satisfaction). you seem to be putting the responsibility entirely on him. I see it as the collective responsibility of everyone who cares about the project. if nobody cares "enough", that still doesn't make it their fault... it just means the project has an issue that is not exclusively one person, but the sum of what ever | 11:51 | |
yone is doing | |||
(or not doing) | |||
I'm not blaming you, either. I'm blaming no single person. | |||
nor a specific group of people | |||
nemokosch | they seem to think that it all boils down to fanatism. If you have enough fanatism, you can lift mountains. But what if you can't have enough fanatism to start working without a direction, without any knowledge or substantial help? | 11:52 | |
well, then you will stay an outsider, and the few fanatics will always just say "cheer up and get to work" | 11:53 | ||
11:54
jpn joined
|
|||
jast | so, the community is lacking someone who can do extensive mentoring. which is a shame, but whose fault is that? no one's if you ask me | 11:55 | |
nemokosch | I do think that in the particular situation with RakuAST (and probably the lack of contributors to MoarVM for example), predominantly Jonathan Worthington is at fault (which is a big taboo in itself) - however, that is not the "systemic" problem | 11:57 | |
the real problem is this need to always put the blame on the people for not contributing enough, and never thinking about providing better circumstances for the contributors | 11:58 | ||
jast | creating those circumstances is a lot of work | 11:59 | |
12:00
reportable6 left
|
|||
jast | nobody is putting in the work to dive in by themselves, understandable | 12:00 | |
well, "nobody" is a bit strong a word maybe, simply used for illustration purposes | |||
nemokosch | then it is just as understandable for people to not rush to work on an underdocumented, obscure system | ||
jast | OTOH nobody is putting in the work to make it substantially easier to become a strong contributor | 12:01 | |
both are understandable IMO | |||
which is also why I'm not blaming *anyone* | |||
12:01
reportable6 joined,
jpn left
|
|||
jast | it's possible that some existing contributors feel like the barrier to entry is much smaller than it is. I wouldn't know, I haven't been very involved in this topic (or anything really) | 12:02 | |
if that's the case and you're criticizing that, fine by me. I just wouldn't go as far as blaming people for not putting the type of effort that you wanted them to put in, if that makes sense | 12:04 | ||
nemokosch | For what it's worth, I think the entry point for the core library is not particularly high, and that's why I start to show CoreHackers::Sourcery around, or the usefulness ot the --target flag. I don't know how much it helps in and of itself | 12:05 | |
Anyway, I don't think I will ever empathize with this... well, downplaying that you also seem to present here. Like no, if you have a sufficiently large and important project, it's common sense to leave it in a state that willing others can continue. It's not something "I want XY to put in" | 12:07 | ||
jast | well, I have no idea why jnthn stopped being so active. maybe other things got in the way unexpectedly. | 12:11 | |
nemokosch | And I have this bitter feeling that if one drew a metaphor or just hid the name, suddenly everybody would agree that it's common sense... | 12:12 | |
jast | I can empathize | ||
12:12
jpn joined
|
|||
nemokosch | and like this is the thing. In an ideal world, a lot of situations would never arise. However, when they do arise in reality, there needs to be some sort of relation or response to it. The "blaming" is not the important part - and frankly, it wouldn't be necessary in the first place if somebody just acknowledged the mistake or provided an explanation, instead of this weird "oh I'm so happy they picked up on my | 12:19 | |
little nuance I made in my freetime" lol | |||
The important part would be to simply conclude that "if we don't provide some introduction or assistance to potential contributors, they will never be of help" | |||
and this is an actionable thought | 12:20 | ||
lizmat | nemokosch how about this for an actionable thought: | 12:25 | |
RAKUDO_RAKUAST=1 raku t/spec/S02-names/is_default.rakudo.moar | |||
has 1 failing test. | |||
How about you try to figure out why that is failing, and I'll be around to answer any questions you might have | 12:26 | ||
nemokosch | as you wish | 12:30 | |
12:30
NemokoschKiwi left
|
|||
xinming | m: (1..3).map({ last if $_ > 2; .raku.say; }) | 12:36 | |
camelia | 1 2 |
||
xinming | I'm a bit confused, is that internally, .map is treated as a for loop internally? | 12:37 | |
lizmat | xinming: no, it's actually the other way around. | ||
a for is internally a .map that does a .sink-all on the iterator | 12:38 | ||
xinming | when I try to convert for into .hyper.map, I forgot to comment the last statement, and suprisingly, It works. | ||
lizmat: thanks, got it. | |||
lizmat | now, the semantics "next" and "last" and "redo" within a hyper are really undefined at the moment | 12:39 | |
*of | |||
xinming | I think we need to implement "leave" statement. | ||
jast | what would that do? | 12:40 | |
lizmat | it's like return for blocks | ||
thought has gone into that | |||
but the workaround atm is so simple that it was deemed not necessary to implement "leave" | |||
nemokosch | what is the workaround? | 12:41 | |
lizmat | instead of a block, use a nameless sub | ||
xinming | nameless sub will add another indention to the code. | ||
lizmat | so "sub { }" instead of { } | ||
xinming | lizmat: Is there performance difference between block and sub? | 12:42 | |
lizmat | xinming: that's only if you have an IDE maybe, that's not a parser requirement ? | ||
nemokosch | so I guess make spectest will create the spec folder | 12:43 | |
lizmat | nemokosch indeed | ||
m: my $a = sub { Nil }; $a() for ^1000000; say now - INIT now | 12:44 | ||
camelia | 0.01582713 | ||
lizmat | m: my $a = { Nil }; $a() for ^1000000; say now - INIT now | ||
camelia | 0.015122427 | ||
lizmat | I'd say: marginally so | ||
xinming ^^ | |||
not something I think you'd need to worry about | |||
xinming: also, part of the overhead is setting up a return point for the "return" statement | 12:45 | ||
xinming | lizmat: Yea, That's why I think why do we have block then. :-) | ||
lizmat | if we would implement "leave", this would need to be done for each block | ||
xinming | So, probably in the future, leave statement will be removed I guess | 12:46 | |
lizmat | well, the design documents are frozen, so "leave" will continue to be mentioned in there | ||
nemokosch | okay, perhaps I don't want to wait for all tests to complete :DD | 12:47 | |
lizmat | but at some point I guess we will remove the TODOd tests from roast | ||
nemokosch | anyway, it claims that there was 1 failing test but even without counting subtests I see like 5 | 12:49 | |
lizmat | maybe some of them are TODOd ? | 12:50 | |
nemokosch | true but why do comments matter for this? | ||
lizmat | ? | 12:52 | |
in any case: in that test, the failing subtests all have the same error: lang-call cannot invoke object of type 'VMNull' belonging to no language | 12:53 | ||
which points to something being Mu when it shouldn't | |||
12:53
eroux left
13:10
eroux joined
|
|||
nemokosch | is there anything wrt variable declarations with the of trait that works? | 13:14 | |
lizmat | I'm not sure, you'd have to try | 13:20 | |
you know of the .AST method on strings, right? | |||
nemokosch | not really but I know --target=ast | 13:24 | |
however, for something as mundane as my $foo of Int, even --target=parse explodes (which is weird, like why would parse care about the underlying semantic problem) | |||
lizmat | m: say Q|my $foo of Int|.AST | 13:25 | |
camelia | ===SORRY!=== lang-call cannot invoke object of type 'VMNull' belonging to no language |
||
lizmat | ok, so it goes wrong there already | ||
m: say Q|my Int $foo|.AST | |||
camelia | RakuAST::StatementList.new( RakuAST::Statement::Expression.new( expression => RakuAST::VarDeclaration::Simple.new( type => RakuAST::Type::Simple.new( RakuAST::Name.from-identifier("Int") ), sigil … |
||
lizmat | so, the other syntax already appears to work | 13:26 | |
m: say Q|my Int $foo; $foo = "bar"|.AST.EVAL | |||
camelia | Type check failed in assignment to $foo; expected Int but got Str ("bar") in block <unit> at <tmp> line 1 |
||
lizmat | so you'd need to find the "of" handling of variable definition in the grammar, and hook that up correctly | 13:27 | |
in the associated action | |||
nemokosch | the thing is, variable-declarator describes a declaration like that, and that already accounts for traits, and of already has the same rule as in the old grammar | 13:29 | |
github.com/rakudo/rakudo/blob/52f4....nqp#L1860 then there is this part but I have no clue what $decl actually contains | 13:30 | ||
well, probably the type attribute is not set on the trait, that's what the error message implies | 13:34 | ||
13:41
xinming left
|
|||
lizmat | he... it looks like some debugging code is causing the error | 13:42 | |
nqp::gethllsym('nqp', 'note')($_.type.dump); | |||
13:43
xinming joined
|
|||
lizmat | and the test in question now passes! | 13:43 | |
nemokosch | okkay but... | 13:44 | |
how was the debugging code wrong? xD | |||
lizmat | I'd say that the nqp::gethllsym('nqp', 'note') yielded VMNull | 13:45 | |
nemokosch | oof | 13:46 | |
anyway, why wasn't it just nqp::note? | |||
lizmat | yeah, no idea why that was written that way | 13:48 | |
anyways, +3 spectest files, so I'd call that a win :-) | |||
nemokosch so I'd run the spectest again, and select a file that has only 1 or just a few failing tests | 13:50 | ||
and look at that then | |||
nemokosch | I know that but truth be told, I also have preferences, it's much more interesting to fix something that is an improvement over the current grammar than to just catch up to it. This is why I wanted to fix the &-sigil declaration | 13:52 | |
Now I see that it works the same way as the old grammar but I have no idea what the modification was | |||
and the way it works in the old grammar is still kind of wrong, it doesn't account for typing with the default value | 13:53 | ||
so my Int &foo will have the value (Callable), even though it could (and should) be (Callable[Int]) | |||
lizmat | well... the legacy grammar is a source of inspiration in almost all cases | 13:54 | |
so some bugs *will* have been ported that way as well | 13:55 | ||
now, if you can fix the Int &foo case in RakuAST, that would be a good thing | |||
so if you feel you'd want to sink your teeth in that, by all means! | |||
13:56
razetime left
|
|||
nemokosch | oh, my mistake, & declarations still don't work well | 13:56 | |
well, then I guess I can't ask how you nailed the resolution of Callable | 13:57 | ||
or this other thing. I know it's not measurable progress but I think it's a pretty essential question whether RakuAST incorporates semantic elements or not, back to thunkiness | 13:59 | ||
thunkiness is not visible syntax and it would be good to make it transparent so that users can define things like that on their own; after all, that's almost literally a kind of macro | 14:00 | ||
lizmat | well, e.g. "a","b" is handled as a an infix in the grammar | ||
well, thinking on that, the problem is that we don't have syntax for indicating that an argument should be evaluated *before* other arguments | 14:02 | ||
that's why we don't have an "infix:<||>" or "infix:<??>" with the correct short-cicuiting syntax | |||
I wonder if we could introduce a trait "is shortcut" | 14:03 | ||
nemokosch | yes, that's true. But then it could be that I don't know what RakuAST is meant to serve as. I thought it was meant to be an AST, both in the sense that it's only based on parsing syntax, and in the sense that it will be used for generating the actual bytecode | ||
given such an AST, I would think that the nodes are traversed (at least hit) from root to leaves and when you visit a root node, you could investigate how the subtrees need to be handled | 14:04 | ||
and therefore it wouldn't be late to thunkify one subtree | |||
lizmat | sub infix:<&&>($a is shortcut({ return False unless $a }), $b) { $b } | 14:05 | |
sub infix:<&&>($a is shortcut({ return $a unless $a }), $b) { $b } | 14:06 | ||
*shortcircuit | |||
nemokosch | this is also a part of the complexity. There are several compiler phases that do several steps, it's not the kind of topic you just read a couple of pages about - and there is quite little substance on it anyway | 14:07 | |
lizmat | well, in a lot of ways we're bleeding edge in compiler development, using a grammar to create a compiler to run the grammar to compile code | 14:09 | |
nemokosch | or another thing with a high-level AST. Once you have such a thing and start to investigate the semantics of the nodes, you can do immense amounts of optimization, relatively easily. A lot of dead-code removal possibilities there. However, if you always do that at runtime, it will hit back heavily, so it would be good to move more towards the compiled nature, and have some more stable ABI for precompiled stuff | 14:10 | |
lizmat | "the semantics of the nodes, you can do immense amounts of optimization, relatively easily" that was one of the reasons for RakuAST in the first place | ||
it's the intent that static optimization will happen at CHECK time, or in a dedicated phaser | 14:11 | ||
constant folding should be done with the .literalize method | 14:12 | ||
*could | |||
nemokosch | I imagine it as something similar to the gcc -O flag. Some optimizations might take some time to catch, like you need to traverse the tree deep, multiple times. If the only/predominant use-case is that "CHECK time" happens "when I want to run the program", that may not be worth it. However, if you can do it once and then run the optimized program as many times as you wish, that's a much better investment | 14:16 | |
lizmat | that's why we haz precompilation :-) | 14:17 | |
nemokosch | well, better than nothing at all but a lot of things need to click for it to work as things stand. It's not really persistent or portable, doesn't work for standalone scripts, doesn't work with use lib ... | 14:19 | |
it's not really what I would think of when I hear about this option, and maybe I'm not alone with that... | 14:20 | ||
the common theme is that these ambitious and motivating goals require a lot of planning and collaboration is inevitable because it won't just affect a couple of people | 14:22 | ||
anyways, let's be less vague; I'm going to look up this operator thunkiness situation | 14:24 | ||
lizmat | please :-) | ||
nemokosch | so that I can at least ask a technical question about it :DD | ||
lizmat | :-) | 14:29 | |
14:39
jpn left
14:47
jpn joined
14:54
razetime joined
15:26
Sgeo joined
|
|||
nemokosch | damn, there are just so many IMPL-THIS-AND-THAT methods... | 15:37 | |
anyway, the infix does something similar to what I'm thinking of, except not with the output bytecode but with the RakuAST structure... | 15:38 | ||
by the way, what's the apparent infix with and without operator? | 15:40 | ||
cue github.com/rakudo/rakudo/blob/66d5...kumod#L202 | |||
lizmat | feels more like condition-modifier handling ? | 15:47 | |
nemokosch | can be but what is it doing among infix operators? | 15:48 | |
lizmat | I haz no idea | ||
nemokosch | nine did this bit | 15:51 | |
lizmat | that doesn't necessarily mean much if the legacy grammar / actions did the same | ||
nemokosch | "with and without will probably need special handling, along with metaoperators" | ||
what does PERFORM-BEGIN produce? | 15:52 | ||
lizmat | an object that does the RakuAST::BeginTime role needs to supply a PERFORM-BEGIN method | 16:00 | |
16:00
jpn left
|
|||
nemokosch | well, this is an example for what I miss... For the RakuAST grammar, PERFORM-BEGIN seems to be a very important method. I must assume it still produces some RakuAST structure but it would really make a difference to have some documentation that you can at least grep | 16:00 | |
lizmat | it doesn't produce anything | ||
it needs to do whatever is necessary for that object at BEGIN time | 16:01 | ||
basically, if a class does RakuAST::BeginTime | |||
it means that it needs to do something at BEGIN time | |||
all of the PERFORM-xxx methods are basically callbacks being called at some point during compilation | 16:02 | ||
e.g. PERFORM-CHECK methods are being called during the CHECK phaser phase | |||
*at CHECK time | |||
nemokosch | well, then this thunking of expressions within an infix operator happens at BEGIN time, in such a callback | 16:09 | |
that's quite a heavyweight unstructured intervention | |||
lizmat | anything that needs special grammar handling, is probably pretty unstructured | 16:11 | |
and ad-hoc | |||
because there is currently no way to indicate thunkiness in args | |||
nemokosch | what is the phase when the RakuAST structure is ready and QAST emission may start? | ||
lizmat | after the CHECK phase | 16:12 | |
when method RakuAST::CompUnit.IMPL-TO-QAST-COMP-UNIT is called | 16:14 | ||
I think :-) | |||
nemokosch | so yeah... if it was up to me, I would rather push that whole IMPL-THUNK-XXX macroverse into the corresponding IMPL-QAST-XXX method | 16:16 | |
lizmat | nine | 16:17 | |
sadly nine is on holiday atm... he'd probably lecture us about the timing of actions :-) | 16:18 | ||
nemokosch | there is also IMPL-CHECK | ||
PERFORM-BEGIN on one node can fire off IMPL-CHECK on another | |||
I mean, apparently | |||
lizmat | I think the IMPL-CHECK method is the actual CHECK phaser handling ? | 16:20 | |
that's the whole thing about phasers: | |||
m: INIT { say "running"; CHECK { BEGIN say "compiling"; say "checking" } | 16:21 | ||
camelia | compiling ===SORRY!=== Error while compiling <tmp> Missing block at <tmp>:1 ------> BEGIN say "compiling"; say "checking" }⏏<EOL> expecting any of: postfix statement end |
||
lizmat | m: INIT { say "running"; CHECK { BEGIN say "compiling"; say "checking" } } | ||
camelia | compiling checking running |
||
lizmat | m: INIT { say "running"; CHECK { BEGIN { say "compiling"; END say "the end" } say "checking" } } | 16:22 | |
camelia | compiling ===SORRY!=== Error while compiling <tmp> Strange text after block (missing semicolon or comma?) at <tmp>:1 ------> N { say "compiling"; END say "the end" }⏏ say "checking" } } expecting any of: infix … |
||
lizmat | m: INIT { say "running"; CHECK { BEGIN { say "compiling"; END say "the end" }; say "checking" } } | ||
camelia | compiling checking running the end |
||
lizmat | note the END phaser inside the BEGIN phaser ? | ||
anyways, it feels this is getting rather too technical for #raku, maybe move this to #raku-dev ? | 16:23 | ||
nemokosch | sure | 16:24 | |
[Coke] | can someone construct a bisectable to get github.com/jonathanstowe/META6/issues/30 ? | 16:33 | |
lizmat | I thought we already had a bisect on that | 16:34 | |
? | |||
[Coke] | wasnt that the unmarshal bug? | ||
there was no ticket on META6 repo until I just opened one yesterday, failure I got after the unmarshal fix was merged. | |||
lizmat | vrurg ? | 16:35 | |
[Coke] | (I'm trying to stay on bleed, building with rakudobrew, this was the latest failure when trying to install my repo's deps) | ||
m: my $v = Version.new("6.*"); say Version.new($v.parts.join(".")).Str | 16:36 | ||
camelia | 6.e.PREVIEW | ||
[Coke] | Apparently that used to return just 6.* | ||
lizmat | he,,, well, that would have been incorrect | 16:37 | |
[Coke] | m: my $v = Version.new("6.c"); say Version.new($v.parts.join(".")).Str | ||
camelia | 6.c | ||
lizmat | confirmed it isn't installable | ||
[Coke] | so if that's a bug in META6, need a new release on that before the next rakudo release, at least (sooner the better) | 16:38 | |
lizmat | my understanding was that some module would need an update, | ||
not sure which one, only that Jonathan Stowe would do it ? | |||
16:41
tea3po joined
|
|||
[Coke] | Again, I thought that was relating to the previous bug, and he seemed surprised by this report. | 16:42 | |
16:45
teatwo left
|
|||
lizmat | it wasn't 73d07b4b58c804d1bbd161b | 16:48 | |
hmmm... maybe 4f07e0e1a9280595c9a7 | 16:49 | ||
16:50
linkable6_ left
16:53
linkable6 joined
|
|||
lizmat | [Coke]: testing a fix now | 16:53 | |
[Coke]: github.com/rakudo/rakudo/commit/8e394fad08 | 17:01 |
|