🦋 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. |
|||
04:13
bartolin left
04:24
bartolin joined
|
|||
ab5tract | Sure, but that’s more options not less., and there is no way to output a file name that doesn’t conform to that | 06:24 | |
Or isn’t affected by that, rather | 06:26 | ||
Geth | rakudo: usev6++ created pull request #5714: [JVM] Reduce backend-specific code in find_best_dispatchee |
07:40 | |
nqp/main: 5b86eef601 | (Elizabeth Mattijsen)++ | tools/templates/MOAR_REVISION Bump MoarVM to get MasterDuke++ fast path comparison fix |
09:19 | ||
09:19
japhb left
09:26
japhb joined
|
|||
Geth | rakudo/main: 936c356935 | (Elizabeth Mattijsen)++ | tools/templates/NQP_REVISION Bump NQP to get MasterDuke++ fast path comparison fix |
09:31 | |
09:37
sena_kun joined
10:07
sena_kun left
|
|||
lizmat | hmmm I just noticed there are quite a few tags in the ecosystem that consist of multple words | 11:52 | |
shouldn't a tag be a single word ? | 11:53 | ||
(without any spaces?) | |||
ab5tract | Is there a canonical source for these tags or can devs add them Freeform? | 14:00 | |
lizmat | freeform, in the META6.json | ||
14:20
vrurg joined
|
|||
ugexe | I’m not sure I follow. You asked how someone might find themselves using a command that wouldn’t work anymore if we normalized named. The scenario I described is just that: if the names were normalized and they were using e.g. Zef instead of zef then it would no longer work | 14:35 | |
At least I think that’s what you asked | 14:43 | ||
patrickb | I think I don't understand. As long as we stay on a case insensitive FS, all variants of "zEf" should continue to work, irrespective of how we choose to name the script file (as long as the letters making up the word stay zZeEfF), right? | 15:30 | |
timo | is it really freeform if we limit them to strings, and not arrays, objects, floats, ints, booleans, or null? :P | 15:31 | |
patrickb | Just to be sure I don't miss a point here: There is nothing we can do about FSes limiting how scripts could be named, apart from maybe converting unsupported chars to some fallback. Right? | 15:32 | |
lizmat | ah, ok, well, strings and arrays of strings are allowed afaik | ||
patrickb wonders whether the lack of comments on ps#455 is a good or a bad sign. | 15:35 | ||
linkable6 | PS#455 [open]: github.com/Raku/problem-solving/issues/455 [rakudo] Revamping wrapper scripts in CURI | ||
patrickb | Wow. It understood that ps referred to problem-solving?!? | 15:36 | |
timo | we do have a little map of prefixes for issue numbers in there, yeah | ||
i think | |||
linkable6: source | |||
linkable6 | timo, github.com/Raku/whateverable | ||
timo | github.com/Raku/whateverable/blob/...ble.p6#L30 | 15:37 | |
ugexe | patrickb: the problem is zef, Zef, zEF, etc would all shadow the same name on some systems and not others. that is not the case for installed modules because we sha1 them | 16:17 | |
timo | if not everything that generates sha1s from names uses NFG (or equivalent), we might also get differences there when there's unicode normalization differences | 16:19 | |
just a random thought | 16:20 | ||
ugexe | we could punyencode to handle unicode stuff but case-sensitivity is a problem because both upper and lowercase letters are very common in names which means all names would need some normalization marker in their name | ||
yeah i think we explicitly use latin-1 for sha1ing source but we don't do anything like that for names | 16:21 | ||
patrickb | ugexe: I think I understand now. You are describing a case where a user would be used to typing in "Zef" and then won't be able to do so anymore when they moved to a case-sensitive FS. | 16:22 | |
But this has nothing to do with a name normalization we might (not) perform, correct? | |||
ugexe | yeah, or they might tell people to use "Zef" and those people listening may be on a case sensitive file system | ||
it sort of does: if we normalized names then "Zef" shouldnt work anymore | 16:23 | ||
lizmat | if someone moved from a case-insensitive to a case-sensitive FS, raku would only be one of the muscle memory errors | ||
patrickb | ugexe: Can you elaborate how normalizing names would make a difference? Maybe an example of name before and after normalization would help me understand. | 16:24 | |
Geth | rakudo/main: 5ff3eafef4 | (Elizabeth Mattijsen)++ | src/Perl6/bootstrap.c/BOOTSTRAP.nqp Restore error message on Junction sub-sig binding error |
17:02 | |
rakudo/main: 8765d61725 | (Timo Paulssen)++ | lib/NativeCall/Types.rakumod Have to make sure scalars don't make it into nativecallcast. Fixes #5682 |
17:18 | ||
rakudo/main: 10397f1613 | (Patrick Böker)++ (committed using GitHub Web editor) | lib/NativeCall/Types.rakumod Merge pull request #5684 from rakudo/missing_decont_in_typedpointer_at-pos Have to make sure scalars don't make it into nativecallcast |
|||
18:53
sena_kun joined
|
|||
ugexe | i'm not sure it matters in the context of raku I guess. `curl` works the same as `CuRl` on macos | 18:54 | |
lizmat | m: my %h; %h<a> = %h; put %h # heh, .Str needs the same protection that .gist / .raku have | 19:01 | |
timo | oh no :) | ||
camelia | (timeout) | ||
lizmat | m: my %h; %h<a> = %h; say %h | 19:02 | |
camelia | (\Hash_5074152274656 = {a => Hash_5074152274656}) | ||
timo | m: my %h{Any}; %h{%h} = 5; say %h.raku | ||
camelia | (my Any %{Any}) | ||
timo | m: my %h{Any}; %h<a> = 99; %h{%h} = 5; say %h.raku | ||
camelia | (my Any %{Any} = :a(99), (:a(99)) => 5) | ||
timo | m: my %h{Any}; %h<a> = 99; %h{%h} = 5; say %h.raku; %h<b> = 100; say %h.raku | ||
camelia | (my Any %{Any} = :a(99), (:a(99)) => 5) (my Any %{Any} = :a(99), (:a(99)) => 5, :b(100)) |
||
timo | oh? | 19:03 | |
i guess that's what i get for using postcircumfix:<{ }> with an Associative? | |||
m: my %h{Any}; %h<a> = 99; %h{$%h} = 5; say %h.raku; %h<b> = 100; say %h.raku | |||
camelia | (timeout) | ||
timo | ^- nobody expected recursion inside the hash keys huh? :) :) :) | ||
that doesn't go through .Str, right? | 19:04 | ||
m: my %h{Any}; %h<a> = 99; %h{$%h} = 5; say %h.gist; | |||
lizmat | object hashes uses the .WHICH as keys under the hood | ||
camelia | (timeout) | 19:05 | |
timo | yeah, and the output has to get the object back for display | ||
19:14
librasteve_ joined
|
|||
patrickb | ugexe: Sticking to the curl example. The current executable name is "curl". How would a normalized version that prevents other capitalizations from working look? | 19:20 | |
(I think there is some misunderstanding here. The above question seems to be rhetoric (or I really miss some really obvious point). I do hope that this question reveals where the misunderstanding lies.) | 19:27 | ||
Geth | rakudo/no_rebless_in_every_statement: a2aa5a712d | (Timo Paulssen)++ | src/Perl6/Grammar.nqp don't call nqp::rebless on every statement it causes a full deoptimization up the entire stack, even when it has no effect otherwise. |
19:29 | |
rakudo: timo++ created pull request #5716: don't call nqp::rebless on every statement |
19:30 | ||
rakudo/main: 38e655f470 | timo++ (committed using GitHub Web editor) | src/Perl6/Grammar.nqp don't call nqp::rebless on every statement it causes a full deoptimization up the entire stack, even when it has no effect otherwise. |
19:46 | ||
ugexe | i can't give an example for curl. for raku it theoretically can be done via something like BEGIN { my $basename = 'foo'; die unless $*PROGRAM.basename eq $basename } in the wrapper | 19:55 | |
but since non-raku scripts don't do that i don't think we should either | |||
i'm actually surprised that zEf works on macos. I thought github.com/rakudo/rakudo/blob/38e6...kumod#L311 would do a case sensitive match | 19:56 | ||
Geth | rakudo/main: 1340c2b08e | (Elizabeth Mattijsen)++ | 8 files Fix .Str / .gist / .raku on self-referencing QuantHashes The mutable versions could become self-referential with a simple my %s is SetHash; %s ,= 1; and then infiniloop if .Str / .gist / .raku was called on them ... (5 more lines) |
19:57 | |
ugexe | ah nevermind $script will always be whatever was in the meta.json, i.e. what it was seen as on the file system since it is templated into the wrapper script | ||
timo | so i've looked at R#5715 and a quick "perf record" with a jit perf map shows nfa's optimizer taking a very high spot | 20:25 | |
linkable6 | R#5715 [open]: github.com/rakudo/rakudo/issues/5715 [performance][grammar and actions][operators][Will be addressed in RakuAST] Defining a custom postcircumfix operator cases multisecond hang | ||
timo | the call path towards the optimizer being invoked goes through NQPClassHOW's caches, which are flushed when a mixin is generated, which we do so that old NFAs don't stick around and make our parses be incorrect | 20:27 | |
that means after we create a new variant of Perl6::Grammar, every time we hit an NFA "for the first time" it has to be re-generated, which includes a pass through the optimizer | 20:28 | ||
an alternative could be to do smarter tracking of what goes into an NFA at creation time, to see which entries in the cache have to be invalidated when a new regex is added to a grammar, or an existing one is overwritten | 20:30 | ||
that is potentially difficult to get right, famously cache invalidation is one of the tricky problems in compsci | |||
another alternative could be to see if what we generate before creating the NFA matches what we generated in our parent class, and if it's the same, we could re-use the optimized result from the parent | 20:31 | ||
then the difficulty could be how to actually compare a newly generated NFA to whatever we used to have before we ran the optimizer on another NFA. maybe hashing is correct here | 20:32 | ||
another way forward could be to put some effort into optimizing the optimizer for faster run time? | 20:33 | ||
ab5tract | regarding my question about normalization, it's been mostly elaborated on by patrickb earlier. I'll only add that I didn't realize that the discussion involved producing wrapper scripts, though that is pretty obvious in retrospect. The macOS example seemed very confusing though as it related to the idea of users losing muscle memory related to previously working invocations | 21:13 | |
Losing that muscle memory when switching platforms makes sense, but in terms of the user experience before and after normalization-to-inscrutable-shas+wrapper-scripts, I don't see how there can reasonably be any UX delta whatsoever, as our naming capabilities on any given platform will remain exactly the same | 21:15 | ||
I'll also add one overlapping anecdote, which is that I just about threw this macbook out of a window in Iceland in the rain after discovering that its 2024 and I was computing on a half-year old laptop of considerable expense... | 21:18 | ||
... that is completely incapable of differentiating files by case | |||
It honestly did not occur to me on any level to expect that or factor that in as a consideration when buying into the macos ecosystem | |||
I guess it's a bit of a testament to some latent reality that case insensitivty is kind of cool but a bit of a YAGNI in practice that I've never encountered an issue with it outside of specifically investigating Raku issue reports related to it | 21:19 | ||
ugexe | you can make macos case sensitive, it just isnt by default | 21:29 | |
[Coke] | I have a case sensitive drive on my intel mac so I can more easily do some stuff. I have a few git repos checked out there | 21:32 | |
Was very easy to setup and carve out space from the main drive. | |||
ab5tract | I'm aware that it's an option. I was just remarking on both the shocking nature of the revelation of case-insensitivity in 2023 (which is when this occurred) as well as the fact that literally nothing in terms of personal computing since then has given my reason to bother with enabling case sensitivity | 21:37 | |
ugexe | it does seem bizarre in that it would seem like it would be more difficult to implement / maintain a case insensitive file system than a case sensitive one. windows is the same. | 21:41 | |
i personally don't set my file systems as case sensitive on windows or macos because it breaks Steam. On worktop where I don't have Steam it is mandated I use the default file system | 21:42 | ||
ab5tract | indeed! That's basically what I decided after looking into it. I figured I would take a few deep breaths.. "you didn't notice this until you looked into a Rakudo ticket specifically related to this.. why not just let it sit for a bit and see if it every actually gets in your way?" | 21:49 | |
there's a bizarre, unexpected ninth-degree irony that converting my laptop's drive to case-sensitive would result in **more** inconsistency and usability issues than not doing so | 21:50 | ||
Geth | rakudo/main: aa385bb948 | (Justin DeVuyst)++ | 2 files Update release guide and Akefile to align with current practice. |
22:21 | |
jdv | [Coke]: there you go ^ | 22:22 | |
[Coke] | Thanks, will give those a shot. | ||
22:23
librasteve_ left
|
|||
ab5tract | jdv++ | 22:40 | |
patrickb | Where in a rakudo installation would I place data files? (The template data used to generate the runner programs on Windows) share/perl6/lib/resources/win-runner.exetmpl? | 22:59 | |
23:02
sena_kun left
|
|||
Geth | roast: 1b14e5eb27 | (Elizabeth Mattijsen)++ | 3 files Add tests for #4678 |
23:25 | |
ugexe | patrickb: will your plan work with a rakudo that is upgraded while continuing to work with installed scripts? or would we need to add more upgrade-repository logic (github.com/rakudo/rakudo/blob/aa38...umod#L183) | 23:34 |