🦋 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. |
|||
09:16
sena_kun joined
09:30
sena_kun left
|
|||
Geth | rakudo/main: c81d9cfe86 | (Elizabeth Mattijsen)++ | 3 files Re-imagine .polymod as an iterator rather than a loop with "gather". Advantages: - is about 1.8x as fast - actual iterator lives in the Rakudo::Iterator class - a value of 1 (aka mod identity) also stops the .polymod, instead of continuing and potentially hanging Fixes #4523 |
09:30 | |
roast: bd0d3e068a | (Elizabeth Mattijsen)++ | S32-num/polymod.t Add tests for #4523 And a test for non-integer .polymod, which apparently didn't exist yet |
09:31 | ||
patrickb | PSA: I'm moving this weekend. I'm pretty sure I can't do the binary release today or tomorrow. | 14:21 | |
lizmat | patrickb: understood, safe moving! | 15:58 | |
Geth | rakudo/main: da291b5501 | (Elizabeth Mattijsen)++ | src/core.c/Cool.rakumod Simplify Cool.substr-eq candidates Because new-disp is much better at handling these cases and it will make it easier to add new Str.substr-eq candidates |
16:29 | |
[Coke] | jdv++ | 17:11 | |
Geth | rakudo/main: c32cb4f6a3 | (Elizabeth Mattijsen)++ | src/core.c/Str.rakumod Allow *-x (aka a Callable) for position in .substr-eq As suggested in #1720 |
17:14 | |
18:07
sena_kun joined
19:07
dogbert11 left
|
|||
ab5tract | I need a little help figuring out how to resolve core-provided libraries to their contents | 19:42 | |
Here's what I have so far: | |||
m: my $repo = CompUnit::RepositoryRegistry.repository-for-name("core"); my $test = $repo.candidates("Test").head; dd repo-files => $repo.files("lib/Test.rakumod"); $repo.distribution($test.id).meta<provides><Test><lib/Test.rakumod><file>.IO.e ==> say() | |||
camelia | :repo-files(Empty) False |
||
ab5tract | m: my $repo = CompUnit::RepositoryRegistry.repository-for-name("core"); my $test = $repo.candidates("Test").head; dd repo-files => $repo.files("lib/Test.rakumod"); $repo.distribution($test.id).meta<provides><Test><lib/Test.rakumod><file>.IO ==> say() | 19:43 | |
camelia | :repo-files(Empty) "72A28666F10B17ED5620989C3CAF776808C14EA3".IO |
||
ab5tract | Sorry, this is a better example: | 19:46 | |
m: my $repo = CompUnit::RepositoryRegistry.repository-for-name("core"); my $test = $repo.candidates("Test").head; dd repo-files => $repo.files("lib/Test.rakumod"); dd source => $test.meta<source>, :try-read((try $test.read-dist()($test.meta<source>)) // "ERROR") | |||
camelia | :repo-files(Empty) :source("72A28666F10B17ED5620989C3CAF776808C14EA3") :try-read("ERROR") |
||
ab5tract | in the stacktrace for `$test.read-dist`, it's clear that it is resolving `source` to an actual path, even though it's only outputting the id here | 19:47 | |
an actual nonexistent path, rather | |||
ugexe | it won't be entirely simple because whatever is backing a CUR might not be a file, it could be a socket for instance. so the code is written as such | 19:48 | |
source is the sha1 part of the path | |||
it needs to be prefixed with the CURI prefix and /source or some such | |||
ab5tract | This is an example exception from read-dist: | ||
Failed to open file /home/camelia/rakudo-m-inst-2/share/perl6/core/dist/72A28666F10B17ED5620989C3CAF776808C14EA3: No such file or directory | 19:49 | ||
there's nothing that matches the sha1 inside of `./share/perl6` locally either | |||
ugexe | i guess the first thing that im thinking is i dont know what read-dist is so i assume its an implementation detail as well | ||
$.prefix.add('sources').add($source-file-name); | 19:51 | ||
i guess i would have expected it there | |||
ab5tract | repo.prefix.add("/sources").add($test.meta<source>).IO.slurp.say | 19:52 | |
this seems to work | |||
thanks ugexe | |||
ugexe | my $repo = CompUnit::RepositoryRegistry.repository-for-name("core"); my @files = $repo.installed.map(-> $d { $d.meta<provides>.values.map(-> $v { $v.keys[0] => $d.content($v.keys[0]).IO.absolute }) }).flat; for @files { say $_.raku } | 20:01 | |
evalable6 | "lib/RakuDoc/To/Text.rakumod" => "/tmp/whatever… | ||
ugexe, Full output: gist.github.com/57c43b55602ca7f185...ddf236ffa5 | |||
ugexe | I'd probably write it more like that, although as i mentioned extracting a path from the results of $dist.content(...) isn't specced and won't work for e.g. CompUnit::Repository::Github | 20:02 | |
also having to do the .keys[0] thing isn't ideal. it is unfortunate we mutate the meta data on install in away that changes the data structure | 20:03 | ||
(see github.com/rakudo/rakudo/pull/2778 for an attempt I made to fix that) | 20:05 | ||
ab5tract | www.irccloud.com/pastebin/PxfgDP5C/ | 20:30 | |
though I guess `CompUnit::*` don't live in core or else don't work this way because they don't resolve | 20:32 | ||
Let me try with your version | |||
thanks for the snippet ugexe, that's way nicer than keeping track of an a priori list of modules | 20:34 | ||
ugexe | my snippet should continue working if we split the core modules into cohesive distributions as well | 20:49 | |
the distribution stuff only works for modules/distributions, i.e. things under lib/. there is nothing for looking up stuff in src/core* | 20:50 | ||
you cant `use IO::Path;` for instance | 20:51 | ||
ab5tract | right, that will require a different approach. but I think it won't be too much work to offer the option of adding a rakudo src directory for looking up files under `src/` | 21:17 | |
ugexe | what are you trying to do more precisely that would need to know about stuff in src? | 21:18 | |
ab5tract | just as an option. It's probably not super-helpful for an end user, but it should also be mostly trivial to wire up. | 21:49 | |
Wiring up the docs is probably more useful, ultimately | |||
23:26
sena_kun left
|