🦋 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. |
|||
[Coke] | regarding Blin - what do folks think of having a "known bad" list of modules? (There are currently a large percentage where we test the new one, it fails, then we test the old one to see if the failure is new). We could save a bunch of processing time if we instead tested only new, saw it was already failing, and then reported "StilLFailing" etc. | 00:28 | |
Depending on how old these failures are/how unresponsive the author is, maybe we just stop testing them even on new. | |||
(github.com/Raku/ecosystem-unbitrot/issues has 210 open issues that are at least as old as 2019, as a place to start looking for unfixed issues) | 00:30 | ||
.ask AlexDaniel Question on raku/ecosystem-unbitrot - says tickets are closed automatically, how? Why a GPL license? | 00:32 | ||
tellable6 | [Coke], I'll pass your message to AlexDaniel | ||
timo | [Coke]: have you already looked at the scripts in the repo? | 00:34 | |
could someone `wget moarvm.org/releases/MoarVM-2024.08...gz{,.asc}; gpg --recv-keys 59E634736AFDCF9C6DBAC382602D51EACA887C01; gpg --verify MoarVM-2024.08.tar.gz{.asc,}` and tell me if it gives a "BAD" signature? | 00:43 | ||
with 07 it works fine tho | 00:47 | ||
MasterDuke | `gpg: Can't check signature: No public key` | 01:04 | |
timo | did you receive a key from the --recv-keys command? | 01:07 | |
i *think* i successfully received a key from the keyservers there, or maybe it didn't even look at the keyservers because i gpg --import'ed it from a file before? | 01:14 | ||
`wget -O moarvm_signing_key.asc salsa.debian.org/perl6-team/moarvm...ine=false; gpg --import < moarvm_signing_key.asc` | 01:16 | ||
MasterDuke | `Good signature from "Justin DeVuyst <justin@devuyst.com>" [unknown]` | 01:18 | |
timo | huh? what am i doing wrong then? | ||
`sha1sum moarvm.org/releases/MoarVM-2024.08...gz{,.asc}` please? | |||
i have ba7857eb1937384ec2075a6e08c7487701b0bf47 and cca8a9f07c88200d4f9d26a2c8590e958c23ba69 | 01:19 | ||
MasterDuke | oh wait, those were 07 | 01:27 | |
a4bf190c96a78ca7c6863d5f6c5a8aeabf852a2b MoarVM-2024.08.tar.gz | 01:28 | ||
Good signature from "Justin DeVuyst <justin@devuyst.com>" [unknown] | |||
cca8a9f07c88200d4f9d26a2c8590e958c23ba69 MoarVM-2024.08.tar.gz.asc | 01:29 | ||
timo | oh thank goodness so my tarball was just b0rked during transfer somehow | 01:30 | |
yeah i just had to retry ok that's good | 01:32 | ||
06:21
kjp left
06:22
kjp joined
06:24
kjp left,
kjp joined
08:13
sena_kun joined
|
|||
Geth | ¦ problem-solving: lizmat unassigned from samcv Issue `uniprop` and friends are buggy, inconsistent, and potentially replaceable github.com/Raku/problem-solving/issues/437 | 11:38 | |
13:33
vrurg_ left,
vrurg joined
13:34
vrurg_ joined,
vrurg left
13:36
vrurg joined
13:39
vrurg_ left
13:46
vrurg left
13:48
vrurg joined
14:10
vrurg_ joined
14:13
vrurg left
14:18
vrurg joined
14:22
vrurg_ left
14:24
vrurg_ joined
14:28
vrurg left
14:37
vrurg_ left,
vrurg joined
|
|||
[Coke] | Blin - no regresssions on the run, but several failures-that-shouldn't-be. they failed old and new, so they don't show as a problem. | 14:43 | |
uploaded the raw output files here: gist.github.com/coke/239e6906a0a31...8bcf6666c4 | |||
didn't get an .md file output presumably because we're "clean" | 14:45 | ||
nine | What does dba mean in grammars? | 14:51 | |
lizmat | doing business as | ||
nine | Ok...what does that mean? :D | 14:52 | |
lizmat | i think it's meant as an indicator of some general function being used for a particular case? | ||
it's basically an annotation | 14:54 | ||
Geth | rakudo/main: 60dbc2016e | (Elizabeth Mattijsen)++ | 2 files Micro-opt for non-existing keys in hash By using a native string, the bytecode size of !AT_KEY_CONTAINER is reduced from 320 to 260, allowing for better inlining |
14:56 | |
[Coke] | ugexe: in Blin, every time we start, we do a 'zef update', but I'm getting "Must specify a non-empty string as a path" | 15:03 | |
(Looks like we're starting with the config file shown in 'zef --help', then updating it to change "RootDir", "TempDir", and "StoreDir" (but the original doesn't have a RootDir) | 15:08 | ||
ugexe | github.com/ugexe/zef/commit/8cf40e...6f3c41af40 | 15:19 | |
[Coke] | ah, blin just not keeping up. | ||
ugexe | RootDir was removed some time ago, but not sure why you'd see that error | ||
Geth | Blin: 6312a557e5 | (Will Coleda)++ | lib/Blin/Tester/Zef.rakumod Remove RootDir - Removed from zef in github.com/ugexe/zef/commit/8cf40e...6f3c41af40 |
15:20 | |
[Coke] | also shutting off the auto-update on all the repo types. | 15:21 | |
15:53
vrurg_ joined
|
|||
Geth | rakudo/main: dd66162a40 | (Elizabeth Mattijsen)++ | src/core.c/hash_slice.rakumod Micro-opt for %h<a>:exists Reduces the bytecode size of postcircumfix:<{ }>(:$exists!) from 216 to 92 bytes, allowing for easier inlining |
15:53 | |
15:55
vrurg left
15:59
vrurg_ left
|
|||
lizmat | meh: just found out that using "given" in a sub, will prevent it from being inlined | 16:17 | |
m: sub a($a) { 42 given $a }; a(666) for ^100000 | |||
camelia | ( no output ) | ||
lizmat | a BB(2, 196 bytes) -> BB(3): | ||
target has a :noinline instruction - ins: takeclosure | |||
timo | oh, that seems optimize-away-able unless we require it for the way we make $_ "mean something else" for the duration of the block? | 16:31 | |
lizmat | perhaps, hope so :-) | 16:37 | |
timo | i wonder if we already compile "given" differently in rakuast in some way and it's better there? | 16:38 | |
lizmat | hmmm lemme check | 16:39 | |
looks like, indeed... it does get inlined then | |||
not sure whether that's a bug or a feature of RakuAST though | 16:40 | ||
Geth | rakudo/main: 83d7a7ffea | (Elizabeth Mattijsen)++ | src/core.c/hash_slice.rakumod Micro-opt %h<a>:exists:p by adding a dedicated candidate for it, makes it 10+x as fast |
16:43 | |
lizmat | afk& | ||
ab5tract | [Coke]: A successful blin run! awesome :D | 16:54 | |
17:41
finanalyst joined
|
|||
[Coke] | ugexe: anything look weird about this one? gitlab.com/pheix/raku-node-ethereu...type=heads | 18:04 | |
... nevermind, that was the last *good* one in this run, it's the next one that's giving the error, oops | 18:05 | ||
github.com/khalidelborai/raku-SOD/...META6.json - I think it's the resources: [ "libraries/" ] | 18:08 | ||
yup, can duplicate the error with 'zef install SOD' on another box. | 18:09 | ||
[Coke] opens github.com/khalidelborai/raku-SOD/issues/2 | 18:13 | ||
So hopefully, worst case, that error is going to cause badly constructed distros to not install. | 18:14 | ||
(and therefore AlwaysFail) | |||
... It may also prevent Blin from updating the copies of the repo, though (since trying to update this one bad module seems to kill the update) | 18:15 | ||
If so, this *might* mean that previous blin runs by jdv have been done on an outdated copy of the ecosystem. Not sure. | 18:16 | ||
ugexe: should a bad resource like that be a warning instead of a stop the world error? | |||
(or perhaps caught and then complained on as a stop the world error about the META6.json file instead of an IO error) | 18:17 | ||
18:58
vrurg joined
|
|||
Geth | rakudo/main: cc194cdcd1 | (Elizabeth Mattijsen)++ | src/core.c/hash_slice.rakumod Micro-opt %h<a>:exists:kv by adding a dedicated candidate for it, makes it 10+x as fast. Also fix :exists:!p, apparently this isn't tested for single keys |
18:59 | |
ugexe | A bad anything should prevent something drkm | 19:10 | |
from Being installed | |||
lizmat | bisectable6: my %h = a => 42; dd %h<a b>:!kv | 19:12 | |
bisectable6 | lizmat, Will bisect the whole range automagically because no endpoints were provided, hang tight | ||
ugexe | I’m not sure if that error is from zef or rakudo but indeed the error could be better | ||
bisectable6 | lizmat, ¦6c (83 commits): «("a", 42, "b", Any)» | ||
lizmat, Nothing to bisect! | |||
lizmat | heh | ||
[Coke] | ugexe: zef tries to do something with the file name in "libraries/" (which is empty), then rakudo says "that's not IO::Path-able" | 19:15 | |
19:55
doomslord joined
|
|||
doomslord | God, I hate copy on write so much | 19:55 | |
They sell it as a performance enhancement | 19:57 | ||
But it’s just a nest of surprises | |||
Suddenly, write = copy + write | 19:58 | ||
All behind your back | |||
Of course, it fits the Unix principle since you 99.9% of the time fork and then just wipe out everything to exec | 19:59 | ||
All other use cases are clearly less obvious | |||
timo | ah you're refering to copy-on-write after fork in linux primarily? | 20:00 | |
doomslord | Yes, that is the only sane use case I can think of | ||
timo | cp or rsync with reflinks for example | 20:01 | |
snapshots of file systems or subtrees of filesystems, snapshots of VMs | |||
writable overlay filesystems over read-only filesystems | 20:02 | ||
doomslord | Sorry, I prefer multiple copies | ||
And I would rather share read only filesystems | |||
Just a personal preference | 20:03 | ||
I can think of many situations where having multiple copies, on different continents, saved my job | 20:04 | ||
Worse thing is the use of copy on write buffers to share data with the kernel, as was done on many old os to save a copy | 20:06 | ||
You would write your buffer, get cowd with the kernel, next time you write over your buffer you fault | 20:07 | ||
Basically twice the number of syscalls to not even save a copy | 20:08 | ||
Linux got it right with ring-buffers | |||
timo | you mean io_uring or something else? | 20:09 | |
doomslord | yes, io_uring | ||
But before io_using it was all copy. Linux never implemented cow on this usecase | |||
Basically, if you share data with an opaque actor such as the kernel, you need to rely on a clear contract. COW is not as clear | 20:11 | ||
timo | content-addressed storage like git uses for its data could also be called copy-on-write | 20:13 | |
since changing an object necessarily causes its address to change | |||
doomslord | Indeed, but since you know what you are doing I don’t see it as an issue | 20:16 | |
What I see as an issue is when you have something that looks like normal but is in fact backed by a cow mechanism | 20:17 | ||
20:29
doomslord left
20:30
sena_kun left
20:57
sena_kun joined
20:58
sena_kun left
21:06
sena_kun joined
21:21
sena_kun left
|
|||
Geth | rakudo/windows_latest_azure_pipeline: 5d1e0a8c6b | (Timo Paulssen)++ | azure-pipelines.yml use windows-latest for windows builds on azure |
22:59 | |
rakudo/windows_latest_azure_pipeline: 3ba8b91c9b | (Timo Paulssen)++ | azure-pipelines.yml disable mac and linux build for now |
|||
rakudo: timo++ created pull request #5639: Try using "windows-latest" in the azure pipeline |
23:05 | ||
rakudo/windows_latest_azure_pipeline: 0ee9cdf867 | (Timo Paulssen)++ | azure-pipelines.yml fix typo in image name |
23:08 | ||
rakudo/windows_latest_azure_pipeline: 1e8ac61d09 | (Timo Paulssen)++ | azure-pipelines.yml skip JVM build on windows as well |
|||
23:13
finanalyst left
|
|||
Geth | rakudo/windows_latest_azure_pipeline: 141b0b510a | (Timo Paulssen)++ | src/vm/moar/ops/perl6_ops.c try to get a stacktrace when a rakudo process exits |
23:56 |