nine Xliff: actually I was wondering how an unmodified rakudo master does for you without any parallel compile. If you see any changes there 07:08
tellable6 nine, I'll pass your message to Xliff
nine NativeCall tests fail consistently: t/04-nativecall/00-misc.t ....................................... Dubious, test returned 1 (wstat 256, 0x100) 07:21
tellable6 2020-02-25T22:38:05Z #raku-dev <lizmat> nine github.com/rakudo/rakudo/blob/mast...e.pm6#L144 feels like the last .add is in the wrong set of params
2020-02-25T22:39:49Z #raku-dev <lizmat> nine nvm, figured it
nine got: "\x[1B]===\x[1B]SORRY!\x[1B]===\x[1B] Error while compiling -e\n\x[1B]===\x[1B]SORRY!\x[1B]===\x[1B] Error while compiling /tmp/perl6_roast_00_misc_t_line31_0_354507043518361151582701714/Foo.pm6 (Foo)\nCould not find NativeCall in:\n file#/tmp/perl6_roast_00_misc_t_line31_0_354507043518361151582701714\n inst#/home/nine/.raku\n 07:22
inst#/home/nine/rakudo/gen/build_rakudo_home/site\n inst#/home/nine/rakudo/gen/build_rakudo_home/vendor\n inst#/home/nine/rakudo/gen/build_rakudo_home/core\n ap#\n nqp#\n perl5#\nat /tmp/perl6_roast_00_misc_t_line31_0_354507043518361151582701714/Foo.pm6 (Foo):2\n\nat -e:1\n"
lizmat: 8ac2eecc239c1c9c7eba71becf68e8e7e4087cd4 is the first bad commit 07:35
lizmat: I'm pretty sure assigning Nil into a slot in an nqp::hash will not do what we want 07:37
Geth rakudo: atroxaper++ created pull request #3513:
Fix run() with :out(Handle:D) and :merge
08:37
roast: atroxaper++ created pull request #622:
Add test for run with :out(Handle:D) and :merge
08:38
rakudo: atroxaper++ created pull request #3514:
#1882 Fix run() with :out(Handle:D) and :merge
08:47
linkable6 RAKUDO#1882 [open]: github.com/rakudo/rakudo/issues/1882 [Hacktoberfest][easy to resolve][good first issue] run(..., :$out, :merge) does not redirect stderr to the $out file handle
Geth roast: atroxaper++ created pull request #623:
Add test for run with :out(Handle:D) and :merge
lizmat Files=1303, Tests=111207, 211 wallclock secs (28.57 usr 8.29 sys + 2945.81 cusr 277.67 csys = 3260.34 CPU) 09:17
Geth rakudo: 6c7ffbdbbf | (Elizabeth Mattijsen)++ | src/core.c/CompUnit/PrecompilationStore/File.pm6
Potentially fix problem

  nine++ reported that 8ac2eecc239c1c9c7eba71becf68e8e7e4087cd4 broke
t/04-nativecall/00-misc.t , which I cannot reproduce. However, that commit did change the semantics slightly: instead of an Any, a Nil would be returned for a non-existing path. But since the check used //= , any subsequent attemopt would run the same code ... (5 more lines)
09:40
lizmat nine: I can not reproduce the error you've seen... 09:41
Geth rakudo: 1f838791e3 | (Mikhail Khorkov)++ | src/core.c/Proc.pm6
#1882 Fix run() with :out(Handle:D) and :merge

Previously, the run routine with :merge and :out(Handle:D) arguments did not write output to the :out argument. Now both stderr and stdout will be written to the :out argument in such case.
09:42
rakudo: b6851c3e7e | (Elizabeth Mattijsen)++ (committed using GitHub Web editor) | src/core.c/Proc.pm6
Merge pull request #3514 from atroxaper/mkhorkov-1882

  #1882 Fix run() with :out(Handle:D) and :merge
linkable6 RAKUDO#1882 [open]: github.com/rakudo/rakudo/issues/1882 [Hacktoberfest][easy to resolve][good first issue] run(..., :$out, :merge) does not redirect stderr to the $out file handle
roast: 1af0b27a22 | (Mikhail Khorkov)++ | S32-io/pipe.t
Add test for run with :out(Handle:D) and :merge
roast: e7a0707d27 | (Elizabeth Mattijsen)++ (committed using GitHub Web editor) | S32-io/pipe.t
Merge pull request #623 from atroxaper/mkhorkov-1882

Add test for run with :out(Handle:D) and :merge
lizmat afk for a few hours& 10:04
|Tux| Rakudo version 2020.02-51-gb6851c3e7 - MoarVM version 2020.02-4-gfee45b9b4
csv-ip5xs0.697 - 0.705
csv-ip5xs-205.716 - 5.773
csv-parser22.379 - 22.858
csv-test-xs-200.363 - 0.365
test7.281 - 7.328
test-t1.768 - 1.797
test-t --race0.776 - 0.803
test-t-2030.244 - 30.395
test-t-20 --race8.568 - 8.777
10:21
sena_kun 10:27
hankache hello * 12:21
.seen rba 12:24
tellable6 hankache, I saw rba 2020-02-25T20:18:29Z in #raku-dev: <rba> I will ask around if someone of my organiser friends like to take the chance.
hankache .tell rba I have an MSI for Rakudo Star 2020.01. Unfortunately I lost access to scp files once the old infra died. Would you be able to grant me access again? Thanks 12:25
tellable6 hankache, I'll pass your message to rba
hankache Meanwhile the files can be found here for testing: hankache.com/files/ 12:31
rba hankache: give me a sec. I will let you know how to scp. 12:33
hankache thanks rba
rba hankache: scp <file> rakudo.org@lavm-perl6infra-1.atiko...oads/star/ 12:39
hankache: let me know if it works. 12:41
hankache rba: connection refused 12:43
rba hankache: may you send me your ssh keys? pm or let should I take the one from github? 12:46
hankache rba both the ones I use are on github 12:53
rba hankache: quickly afk for lunch. will do in 20 minutes. 12:54
hankache rba: take your time
rba: or if you prefer I can mail them to you
rba hankache: added both keys from github. May you try again? 13:22
hankache rba: still getting connection refused 13:23
rba hankache: Grr. Same error again. Use "scp -P 2222"
hankache rba: same error 13:24
ssh: connect to host lavm-perl6infra-1.atikon.io port 2222: Connection refused 13:25
rba hankache: scp -P 2222 LICENSE rakudo.org@lavm-perl6infra-1.atiko...oads/star/ 13:27
hankache: worked for me and your keys are there. 13:28
hankache rba let me check the other machine 13:30
rba hankache: If you like I grab the file from URL. 13:33
hankache: Feb 26 13:32:30 lavm-perl6infra-1 sshd[22579]: Connection closed by 46.101.89.150 port 33021 [preauth] 13:34
hankache rba same on the second machine 13:37
hankache scp -P 2222 "rakudo-star-2020.01-x86_64 (JIT).msi" rakudo.org@lavm-perl6infra-1.atiko...oads/star/ 13:37
am I doing something wrong?
rba hankache: no. Please send me your ssh public keys again. 13:38
hankache_ rba sorry my bad, it's working correctly. it seems the issue was the network. Bloody fortinet 13:40
rba++
rba hankache_: Hmm. May you upload the three files again? I have to rename them to fit the new naming scheme. 13:43
hankache_ rba sure
Xliff nine: You were asking for compile times? Sorry for the delay: gist.github.com/Xliff/476f61268a45...37f8c1ef5e 13:44
tellable6 2020-02-26T07:08:41Z #raku-dev <nine> Xliff: actually I was wondering how an unmodified rakudo master does for you without any parallel compile. If you see any changes there
Xliff .tell nine Unmodified rakudo compile comparison for GLib --> gist.github.com/Xliff/476f61268a45...37f8c1ef5e 13:45
tellable6 Xliff, I'll pass your message to nine
hankache_ rba I'll rename and upload 13:47
rba hankache_: May you let me know how to build on windows? 13:55
hankache_ rba done. renamed and uploaded
rba hankache_++ 13:56
hankache_ rba sure. The old build process was failing on windows, I had to patch something really quick to make it work. I'll commit my changes to the Star repo 13:57
rba hankache_: sounds great!
hankache_ rba thanks for your help 13:58
rba hankache_: I'm curious if we would be able to automate this using Azure DevOps Piplines.
So, this means the Rakudo Star 2020.01 is complete. Source/MacOSX and Windows are available for download 13:59
hankache_ rba: I know nothing about Azure DevOps Pipelines, but I managed to write a quick and dirty cmd script to do the build. I don't see why it shouldn't be feasible 14:00
Yes they are finally available. It has been a while 14:02
lizmat .ask Xliff could you also do a timing on the 2020.02 release ? 14:19
tellable6 lizmat, I'll pass your message to Xliff
nine So it became slower?! 14:29
tellable6 2020-02-26T13:45:29Z #raku-dev <Xliff> nine Unmodified rakudo compile comparison for GLib --> gist.github.com/Xliff/476f61268a45...37f8c1ef5e
nine Xliff: that's from 0 to working. Are compile times after modifying some source file better now? 14:30
tellable6 nine, I'll pass your message to Xliff
lizmat nine: apparently from 2020.01 something to HEAD 14:31
that's why I would like to know timing for the 2020.02 release, because there I didn't touch any of the Repo stuff yet
nine: BTW, is the nativecall test still failing for you ?
nine lizmat: seems to be fixed now! lizmat++ 14:39
lizmat nine: I'm surprised that last patch made a difference 14:40
but glad that it solved it for you
nine: two questions: is there a reason not to make CompUnit::PrecompilationId a subclass of Str ? 14:45
nine lizmat: before that fix, we wrote Nil into $!loaded{$key} so the next nqp::ifnull(nqp::atkey($!loaded, $key)) would take the wrong turn, because a Nil object is not NULL 14:46
lizmat and secondly: a precomp ID is a 40digit hexadecimal number, no ?
nine: ah, right, still don't understand why that didn't show up in my tests
nine Yes a precomp ID is actually a number, but we usually deal with it in a stringified form 14:48
lizmat so why is this check: 2 < $id.chars < 64 && $id ~~ /^<[A..Za..z0..9._-]>+$/ ? 14:52
specifically I find the ._- suspect ? 14:53
nine It's because....well...you know...I think... jnthn said so! github.com/rakudo/rakudo/blame/mas...nt.md#L331 14:54
Well the compiler's ID did include a build time stamp 14:55
lizmat ah, so the . and - are obsolete 14:56
nine I don't know if other users of the PrecompilationRepository use those 14:57
lizmat m: use nqp; class A is Str { method new(str $a) { nqp::p6bindattrinvres(nqp::create(self),Str,q/$!value/,$a) } }; dd A.new("foo") # why doesn't this work ? 15:08
evalable6 (exit code 1) P6opaque: representation mismatch when storing value (of type Str) to attribute (of type str)
in method new at /tmp/RkCmbCzYrF line 1
in block <unit> at /tmp/RkCmbCzYrF line 1
jnthn have to use bindattr_s 15:11
lizmat aaah... and we don't have a p6bindattrunvres_s
moritz nine: Hi. Do you have any Python 3 plans for Inline::Python? 15:12
github.com/niner/Inline-Python/issues/37 suggest dropping 2.7 compat and switching to Python 3 entirely 15:13
jnthn lizmat: no, though just write ; self :)
lizmat: It's not really a performance op, just a convenience one
moritz I'm asking because I'm revising the "Perl 6 Fundamentals" book (then "Raku Fundamentals"), and its chapter 12 relies heavily on Inline::Python 15:14
moritz and I don't think it's acceptable if I release a new revision of a book that relies on a deprecated language verison, even if it's the python language :-) 15:14
nine moritz: yeah, Inline::Python needs updating. I'd actually like to keep 2.7 compatibility but honestly, the chance of someone using Inline::Python to actually migrate a Python code base to Raku seems tiny 15:17
lizmat would be cool if you could have an Inline::Python 2 and an Inline::Python 3 15:19
so Python people could use Raku to access the best of both Python worlds :-)
nine That's impossible for the same reasons that it's impossible to use a Python 2 lib in a Python 3 program 15:20
Well it's impossible in the same process. It would always have been possible to use multiple processes
lizmat weird... I mean, you can use Inline::Perl5 and Inline::Python in the same process? 15:22
are Python 2 and Python 3 not different libraries ?
rba patrickb: Playing around with Azure DevOps Pipelines. May this be something we like to have a look together?
tellable6 rba, I'll pass your message to patrickb
nine Python 2 and 3 are too similar. You get conflicting symbols when you try to load both
The clean cut and fresh start with Perl 6 is what made Inline::Perl5 possible 15:23
Geth rakudo: 17c45d89d1 | (Elizabeth Mattijsen)++ | src/core.c/CompUnit/PrecompilationUnit.pm6
Make CompUnit::PrecompilationId a Str

  - simplifies treating it as a string, because now it is one
  - no need for extra Stringy methods, such as Str, substr
  - automatically makes it a value type
  - allows all occurrences of .Str on precompilation ID's to be removed
15:28
lizmat nine: ah, I see....
Geth rakudo: 895038096d | (Elizabeth Mattijsen)++ | src/core.c/CompUnit/PrecompilationUnit.pm6
De-hllize CompUnit::PrecompilationId cache
15:44
rakudo: 747a35ba0b | (Elizabeth Mattijsen)++ | src/core.c/CompUnit/PrecompilationStore/File.pm6
Remove now superfluous .Str coercions
15:55
Geth star/master: 89 commits pushed by (Patrick Spek)++, tyil++, (Naoum Hankache)++
review: github.com/rakudo/star/compare/139...253c2b1095
17:14
hankache Highly subjective question: What is the preferred way to run raku from the command line raku or rakudo ? 17:22
lizmat uses "raku", or a "r" alias for "raku -e" 17:23
Altai-man_ raku?
japhb I use raku 17:24
hankache We have a winner 17:25
Altai-man_ it actually depends on purpose, I think. if you just wanna generally execute a program written in raku, then raku. if you care about some specific implementation (imaging there are more options than just rakudo), in this specific case you call specific implementation you want.
hankache thanks
Geth star: 65f8cd4611 | (Naoum Hankache)++ (committed using GitHub Web editor) | README.md
README update Windows link
17:28
lizmat is there a specific reason why a nqp::atkey on a non-existing key on a BOOTContext throws, rather than return nqp::null ? 17:33
m: sub a() { use nqp; dd nqp::atkey(nqp::getattr(CALLER::LEXICAL::,Map,q/$!storage/),q/$a/) }; $! = 42; a 17:34
evalable6 (exit code 1) Lexical with name '$a' does not exist in this frame
in sub a at /tmp/3sz21aYPVG line 1
in block <unit> at /tmp/3sz21aYPVG line 1
jnthn m: dd CALLER::LEXICAL::<$a> 17:35
evalable6 Nil
jnthn Hm, it doesn't even seem to match the semantics we want for Raku, so I guess we end up having to handler wrap it? 17:35
lizmat yeah, I think the Stash.AT-KEY handles that
lizmat it first does an existskey 17:36
vrurg CALLER and LEXICAL are pseudos, so PseudoStash does it in AT-KEY
lizmat so we have 2 lookups
jmerelo I'm having lots of trouble with Documentable and the latest versions of Raku. Boils down to: it hangs when I try to a say $object. 17:37
jnthn jmerelo: Released version or HEAD? 17:37
MasterDuke jnthn: github.com/rakudo/rakudo/commit/bd...3a1498351d works for all the things i've tried, but actually slows down the only-types case (since they're no longer a chain of nqp::istype, though i guess i could do nqp::istype in that case and .ACCEPTS otherwise) and is a very minimal speedup for a bunch of concretes
jmerelo jnthn: Released version. Again, I find it almost impossible to golf it. Here's the code github.com/Raku/Documentable/issues 17:38
Main issue now is this one github.com/Raku/Documentable/issues/84
In here: github.com/Raku/Documentable/blob/...m6#L31-L59 doing a say self hangs, simply stops. It does the last call of a self method... 17:40
... but after the object is built, any call to any method of the object hangs.
jnthn Hangs using CPU or not?
Growing memory use or not?
jmerelo jnthn: will check
MasterDuke something i noticed about junctions (not caused by my optimization work) is that they blow up profiles
m: sub a($a where 1|2|3|4|5|6|7|8|9|0|"abc") { $a }; my $b; my $c = "a" ~ "bc".comb[0] ~ "c"; my $s = now; $b = a($c) for ^5_000; say now - $s; say $b 17:41
evalable6 5.1551609
abc
jnthn If using CPU and growing memory, it can be an infinite recursion somewhere
jmerelo jnthn: yep, it's doing both.
100% CPU, growing memory little by little... 17:42
MasterDuke if you set that loop count to anything over ~150 the profiles start getting gigantic
jmerelo jnthn: the only funky thing we do is using precompilation, but that should not be a problem... I guess. I mean, it's a problem, but a different kind of problem (the one that got me here in the first place) 17:44
MasterDuke oh right, it's not junctions themselves, its .ACCEPTS 17:45
m: my $a; $a = 1.ACCEPTS("abc") for ^1_000; say $a
evalable6 False
MasterDuke that creates a 6mb profiles
vrurg jnthn: I requested for review on #3500, but basically the only reason for that if you happen to mind of implementing .wrap via changing $!do on Code.
jnthn vrurg: Hm, how were we doing it before? I forget exactly... 17:51
MasterDuke: wow, that sounds odd
vrurg jnthn: does Wrapper role with a CALL-ME handler. This was causing 'cannot invoke handler' error in some cases. 17:52
jnthn Well, that's more working around a VM limitation if anything... How does unwrapping work now? 17:53
vrurg jnthn: In general, it wrapping does it similar to multi, using a list of Code objects. The first one is a stub to initiate WrapDispatcher, the last one is the original routine. 17:54
Total unwrap results in restoring the original static code.
jnthn Original $!do? 17:55
vrurg So, the good about it: unwrap doesn't leave behind an altered sub object.
Yes, original $!do.
The last one is not totally the original, it's a clone. But it has the original $!do.
All spectests are passing. 17:56
jnthn It's probably OK
Hm, where does `unwrap` come from now? I think that was carried by the role now? 17:57
*before, i mean
Sorry, long tiring bug hunt today...
vrurg jnthn: I know how it is, it was same hunt for me yesterday. :) unwrap was always a method on Routine. Now it does all the work. 17:58
The handler .wrap returns has .restore but it eventually calls .unwrap and is there for spec compatibility only.
I also wonder if it makes sense to unwrap totally if used without a handle argument: &foo.unwrap(). A spec mention this behavior, but there no even todo for it. 18:00
jnthn I'm not sure how strict we were about unwrap ordering before now, and if that'll have changed?
Though arguably if you haven't broken spectest you've not changed anything that matters ;) 18:01
lizmat ,oO( and Blin ? )
I guess we should ask sena_kun for a Blin run after this gets merged ?
vrurg Nah. I thought that unwrapping in the middle should strip off all later applied wraps, but it doesn't and specs are specific about this.
jnthn Ah, OK, if there were spectests on this then fine. 18:02
It's been considered and handled.
vrurg lizmat: would be nice. But from a user perspective nothing should be changed.
sena_kun lizmat, my routine is usually running blin each weekend, so no problem
jnthn OK, I don't really have anything more to add
lizmat okidoki!
vrurg But I can't not to brag about it: with new dispatchers it is possible to wrap a candidate of a multi method with a multi sub. And it works.
jnthn Wow 18:03
Nice :)
sena_kun by the way, anyone wants to cherry-pick dyncall commits with musl fixes?
jnthn I saw your question about MoarVM dispatcher support stuff; will have to take a look, but...
jnthn ...currently callsame/nextsame etc. perform pretty awfully 18:03
Geth rakudo: 8b70bfb843 | (Elizabeth Mattijsen)++ | src/core.c/Any.pm6
Add support for BOOTContext to dd

It just makes life easier for some core devs :-)
18:04
jnthn I suspect we need to think through the overall approach
vrurg jnthn: BTW, I left a feature request for moar. To have it work, I utilize a $*NEXT-DISPATCHER to report subsquent dispatchers where to pass control when they're exhausted. But that'd be better to have an op similar to setdispatcerfor
jnthn iirc there's also some slightly icky C code in the Rakudo-specific ops involving dispatchers too
Yes, that feature request is what I'm talking about :) 18:05
vrurg Unfortunately, I don't have time to get deeper into moar, so not much help there. Only used the code to understand the basics of how dispatcher is obtained. 18:06
jnthn If we need to revisit those ops, probably we want to think the whole thing through from a performance angle and provide something good for it, so you can use callsame/nextsame - at least in straightforward cases - without fearing the slowdown.
It's a slight pity that a self.Foo::Bar::baz is going to be way faster than a nextsame :) 18:07
(They used to both be bad, but the former was comparatively easy to tackle with a spesh plugin)
vrurg Besides, some expect nextsame to do tail optimization which it doesn't. But would be nice if it is. 18:08
vrurg is away to finish a spectest for the new functionality. 18:08
japhb jnthn: Yeah, the slowdowns for callwith etc. was quite noticeable in one of my apps, as was runtime multi-dispatch. It also made tracing through using the profiler UI really annoying, because of the extra normally-hidden layers of anonymous dispatch bits. I eventually just hardcoded fast paths for my most common cases, with all the (re-)dispatch magic stripped away, and performance was much improved. 18:22
Geth roast: vrurg++ created pull request #624:
Additional tests for dispatching
18:27
jmerelo sena_kun: can you help here? github.com/perl6/Pod-To-Cached/issues/16 18:29
sena_kun: the problem seems to be here: github.com/perl6/Pod-To-Cached/blo...#L127-L130 That "compilation" does not seem to work until next instance of the program. So somehow the actual storing is in exit 18:30
MasterDuke jnthn: sorry, the junction optimization not being so great, or .ACCEPTS creating large profiles? 18:31
tbrowder shouldn't the current env var RAKUDOLIB be changed to RAKULIB? (at least add RAKULIB to be equivalent to PERL6LIB) 18:32
jmerelo tbrowder: pprobably
jnthn MasterDuke: the profiles 18:33
tbrowder i'm reluctant to change PERL6LIB in the docs to RAKUDOLIB because it doesn't quite track (IMHO) with changing 'perl6' to 'raku' 18:34
vrurg tbrowder: RAKULIB is planned but not implemented yet. 18:35
tbrowder ok, thnx. 18:36
jmerelo: that's why i didn't make those changes
vrurg: do you know if anyone is working on the change? 18:37
vrurg tbrowder: No yet, afaik. patrickb is mostly the one fixing the env variables. But basically, it should be simple most of the time: just dup what is there for PERL6LIB. Then choose the one which is defined and has higher prio. 18:38
tbrowder roger 18:39
jmerelo tbrowder: OK. Anyway, it's a good amount of work you're doing, and I appreciate that. 18:40
tbrowder thnx, i was getting tired of doing one file at at time and tried to take a short cut i knew wasn't a good idea! 18:41
Geth rakudo/master: 4 commits pushed by (Vadim Belman)++ 18:43
roast: e6351921d0 | (Vadim Belman)++ | 2 files
Add tests for dispatcher interaction

Method, multi, and wrapper dispatchers must not break each other and return control to the previous dispatching when exhausted.
roast: 32581b3c4d | (Vadim Belman)++ (committed using GitHub Web editor) | 2 files
Merge pull request #624 from vrurg/rakudo_3499

Additional tests for dispatching
tbrowder thanks for putting on the brakes! i also want to change file extensions '.p6' and 'pm6' to '.raku' and '.rakumod' if that is acceptable in the lastest raku (i have only tested .raku which hasn't caused any problems yet). 18:45
vrurg tbrowder: I only use .rakumod for new files. No problem. 18:49
.seen Kaiepi 18:50
tellable6 vrurg, I saw Kaiepi 2020-02-19T13:13:43Z in #raku-dev: <Kaiepi> can someone review github.com/rakudo/rakudo/pull/3491 ? i want to get it in before people start using unix socket support
sena_kun encourages reviewing of socket-related things
tbrowder ok, thnx, sounds like it's ok to change the docs. in docs changes so far, i've been eliminating things like ".perl is being deprecated. new code should use .raku" and just making it read ".raku"; otherwise, imho, we have an ongoing doc maintenance problem trying to fine tune them constantly during some long but indefinite time. what say you folks? 18:54
maybe ensure we keep things like those old names in the glossary for a very long time. 18:55
jmerelo tbrowder: glossary is OK 19:05
m: say 3.perl; say 3.raku
evalable6 3
3
jmerelo The thing is .perl still works. It's not deprecated. We should at least mention it. 19:06
tbrowder right, but i think only in the glossary. and maybe also in just ONE place in the docs--somewhere where the perl6 => raku name change is mentioned. 19:07
lizmat I would be in favour of mentioning .perl in a single place, as deprecated 19:13
tbrowder how about a new para in "intro.pod6" where we can mention language deprecations and new terms related to the name change. make a table of them "Rake term <=> Perl 6 term" and a note that all Perl 6 terms are deprecated? 19:51
*Raku
MasterDuke it's the failure path that creates the giant profiles. `1.ACCEPTS("1")` creates tiny profiles, even for 1m iterations, but `1.ACCEPTS("abc")` creates giant ones around 1k iterations 19:54
jmerelo tbrowder: that would be OK, I think. 20:04
tbrowder take a look at my doc pr #3252 for a start 20:07
rba tyil: Strange. Looks like in the tar archive each file is twice. check rakudo.org/dl/star/rakudo-star-2020.01.tar.gz 20:08
vrurg Altai-man_: do you plan to run blin any time soon? 20:14
jnthn vrurg: He mentioned earlier every weekend 20:15
Altai-man_ vrurg, my routine is weekends, but I don't mind doing it today
Geth rakudo: f2cc20c6ed | (Elizabeth Mattijsen)++ | 4 files
Some Perl 6 -> Raku changes in docs
vrurg Altai-man_: no rush. weekly is ok.
Thanks!
Altai-man_ as I have a server, it's very easy to run one each night, though I don't have enough time lately to do any automation... or really anything else...
vrurg would rather stick to his ignorance for a few days to shift focus to another task. :) 20:16
Otherwise I would have to work on fixes and I'd rather not for some time. 20:17
japhb Given that jnthn++ merged the derived-specializations branch in MoarVM, maybe time for a bumping? 20:24
tyil rba: that's... very odd 20:27
I'll need to check that out
tbrowder, jmerelo: I think it's good for the docs to present the raku options without too much baggage, users rarely if ever need to know it used to be .perl for instance 20:31
also, keeping many referals to Perl 6 everywhere just makes it harder to continue forward as Raku 20:32
tbrowder that's my opinion, too ;-)
tyil on FOSDEM, I saw the most interest when I just told people Raku is a programming language, instead of going out of my to include the history all the time about it being Perl 6 but then being renamed
it's Raku, that's what we should document it as, and how we should present it to the world 20:33
MasterDuke why does this !SET-SELF take arguments it does nothing with? github.com/rakudo/rakudo/blob/mast...ce.pm6#L12 20:34
tyil MasterDuke: I think those arguments are always passed 20:35
if you dont specify them being accepted, it will generate an error that there's no sub accepting the params given
also, it uses the code argument, no?
MasterDuke yeah, but this one doesn't github.com/rakudo/rakudo/blob/mast...ce.pm6#L89 20:36
is it just binding the given arguments to the private members? implicitly instead of explicitly 20:37
i.e., instead of taking `$bt, $bt-next` and doing `$!bt = $bg; $!bt-next = $bt-next` in the body? 20:38
rba hankache: Still like to know what you fixed to build Rakudo Star on Windows. As I'm getting the same error. 21:10
tellable6 rba, I'll pass your message to hankache
lizmat japhb: did he ? 21:14
aaah... yes... will bump now! 21:15
Geth nqp: 1e88914d9a | (Elizabeth Mattijsen)++ | tools/templates/MOAR_REVISION
Bump NQP to get the new derived specialization improvements
21:20
lizmat japhb: I'm seeing some issues so need additional time to see whether it is the MoarVM bump, or stuff that vrurg or I did today 21:50
or that it is something that has been borked a little longer 21:51
vrurg lizmat: I found a problem with nextcallee. Will take care of it a bit later.
though will be afk for a while. 21:52
lizmat could you verify that Text::CSV installs for you with zef ?
can anyone confirm that Text::CSV installs on HEAD ? 21:53
vrurg lizmat: installs for me. Considering that I didn't pull the bump yet, it's the likely cause. 21:54
Ok, afk. bbl
Geth rakudo: 9e494c8379 | (Elizabeth Mattijsen)++ | src/Perl6/Metamodel/Dispatchers.nqp
Revert "Inline a method"

This reverts commit 899929674f0350ae04d778633189caad0f043b9e.
This breaks installation of Text::CSV, and potentially (many) other modules. So revert for now.
22:13
rakudo: a27005b374 | (Elizabeth Mattijsen)++ | 3 files
Revert "Big rewrite of dispatchers and wrapping"

This reverts commit 502fd7fd144277a37b71f0580ba19b561c172741.
lizmat .tell vrurg sorry, but the big rewrite broke Text::CSV, so I've reverted them :-( 22:14
tellable6 lizmat, I'll pass your message to vrurg
lizmat grrr... looks like this wasn't the reason after all... but unclear what the problem is 22:20
===SORRY!=== Error while compiling /Users/liz/Github/zef/bin/zef
===SORRY!=== Error while compiling /Users/liz/Github/zef/site#sources/092D7DA0185CE0F1584F42452CD1E526B4B9DE17 (Zef::CLI)
New type Perl6::Metamodel::ClassHOW for NQPRoutine is not a mixin type
afk for a bit& 22:23
travis-ci Rakudo build failed. Elizabeth Mattijsen 'Some Perl 6 -> Raku changes in docs' 22:26
travis-ci.com/tbrowder/rakudo/builds/150733224 github.com/tbrowder/rakudo/compare...cc20c6ed34
MasterDuke hm. if i have it create nqp::istype ops for type objects, but .ACCEPTS for concrete objects, it slows it way way down 22:36
m: sub a($a where Int|Hash|Array|Complex|Real|Numeric|IO|Rat|Str) { $a }; my $b; my $c = "a" ~ "bc".comb[0] ~ "c"; my $s = now; $b = a($c) for ^10_000; say now - $s; say $b
evalable6 0.035689
abc
MasterDuke if i add a 2 before the Str, it slows to .7 22:37
japhb MasterDuke: Why *before* the Str? A junction doesn't have an intrinsic order, so you ought to be able to put all the heavy checks last without loss of generality. 22:40
MasterDuke it doesn't have an order by spec, but it does by implementation
i'm not trying to find an ordering that makes that code run faster, but to optimize that heavy check to be less heavy. so it need it to be hit to test 22:42
japhb MasterDuke: I guess I mean that nothing in the spec stops you from collecting a list of fast checks and a separate list of slow checks in the optimizer, and then doing them in that order.
Ah, I see what you mean
MasterDuke but yeah, that could be another optimization 22:43
re-ordering the checks 22:44
Geth rakudo: tbrowder++ created pull request #3516:
Enable env var RAKULIB
japhb Especially since you can assume that any concrete type that is reached in that case is definitely *not* one of the types you already checked for, you can through out some impossible checks. And the remainder you can first check whether the argument type matches the concrete test type exactly (and if so emitting a faster custom check), before falling back to the slow .ACCEPTS 22:45
*throw out
*concrete test value's type
sheesh, can't type
So: `$a where "boo"|Str|Int` can emit just checks for Str|Int, because if it's not a Str, then it's not "boo" 22:47
And `$a where "bar"|"foo"` can check if $a istype Str, and if so just emit a pair of fast string equality check, rather than a pair of slow .ACCEPTS calls 22:49
MasterDuke: ^^
Or actually, sorry, it can do -- `if nqp::istype($a, Str) { <check string equality } else { <check ACCEPTS }` 22:50
MasterDuke japhb: not quite. i thought so too, but jnthn pointed out that `$a where 1|2` should accept "1"
ah, yes, that would probably be possible
vrurg lizmat: As I told you, Text::CSV did install for me and my local version is before the last NQP bump. 22:56
lizmat undoes the revert and builds again 22:57
vrurg Don't commit the undo, I'll get nextcallee fixed and open a new PR. 22:59
lizmat gist.github.com/lizmat/f79faa3a433...1a1dcea710 with the revert reverted 23:00
Geth roast/RAKULIB: 55651cd89e | (Tom Browder)++ | S11-modules/perl6lib.t
Test new env var RAKULIB
23:05
vrurg lizmat: is it for Text::CSV?
lizmat I found that zef itself doesn't install with the problem, see gist 23:06
Geth roast: tbrowder++ created pull request #625:
Test new env var RAKULIB
23:07
lizmat now, the odd thing is that if I bump NQP to get jnthn's latest fixes, it dies with the same error :-(
vrurg Then it's about the bump, I guess? Or do I miss something? 23:08
lizmat a bump, with your commits reverted, creates the same problem as not bumped but with your commits
at least for me :-(
I'm getting too tired now... need some sleep 23:09
will look again tomorrow, hoping someone will have fixed this
sleep&
vrurg Do full cleanup of the installation directory each time. Sounds as if moar or nqp are not updated at some steps.
lizmat: g'night!
MasterDuke japhb: jnthn did say he didn't want the generated code to get to big though...but maybe i'll give it a try and see what it looks like 23:29
Geth ¦ problem-solving: ToddAndMargo assigned to jnthn Issue qqx not picking up quotes in Windows 7 github.com/Raku/problem-solving/issues/166 23:36
nqp: tinmarino++ created pull request #600:
More explicit error when more than one --target is provided
23:43