🦋 Welcome to the MAIN() IRC channel of the Raku Programming Language (raku.org). This channel is logged for the purpose of keeping a history about its development | evalbot usage: 'm: say 3;' or /msg camelia m: ... | 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 8 June 2022.
xinming releasable6: status 04:51
releasable6 xinming, Next release in ≈1 day and ≈14 hours. 1 blocker. 0 out of 67 commits logged (⚠ 89 warnings)
xinming, Details: gist.github.com/e99fd407cfcea9f446...52ca72a060
tonyo my toml module also has a grammar in the repo 06:14
jjatria tonyo: which one? TOML? I thought that was written in NQP, not with a grammar 10:27
[Coke] . 14:54
[Coke] m: dd (90..100).one 15:40
camelia one(90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100)
[Coke] it is very convenient, but should dd be showing junction guts?
m: say (90..100).one; #ok, not just dd 15:41
camelia one(90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100)
Voldenet m: say (1..*).one 15:43
as expected
camelia (timeout) 15:44
younder Is anyone working on LSP support for Raku? 15:50
moritz_ what is LSP? 15:52
dutchie language server protocol 15:53
the idea is to solve the m×n problem for languages/editors
younder Language ervert protokol is developed by Microsoft to better allow interaction between the editor and the  compiler. Things like getting compile errors highligted. Mocst of this works in Comma, but it should also work in other editors like Visual Studio Code or EMACS. 15:54
moritz_ github.com/azawawi/app-perl6langserver last committed 4 years ago 16:00
younder thx, though it looks a bit stale.. 16:02
Nemokosch Someone got a working plugin for VSC iirc 16:10
patrickb There is also github.com/bscan/RakuNavigator 17:01
Last change 2022-06-04 17:02
tonyo jjatria: there's also a 1.0 compliant toml grammar in there 17:41
i rewrote in nqp because the grammar was so slow as to be unusable on large files
github.com/tony-o/raku-toml/blob/b...ar.rakumod 17:43
there's an Actions.rakumod in that same dir in that commit
dunno if rakuast would speed it up or not, kind of out of the loop on that development 17:44
leont Is there some way to just configure fez once, so I don't have to deal with logging in again? 18:39
japhb leont: You have to log in monthly, IIRC. It's probably a security measure, to reduce the chance that someone will get hold of old login tokens and impersonate you. 18:50
leont Sounds hateful 18:51
japhb is used to it from corporate systems
Google required a fresh login every 20 hours. 18:52
Which, BTW, is hell of annoying if you are in a pager rotation and thus can get woken up 21 hours after you last logged in ...
leont Yeah, I've seen it in such places too. Especially annoying if you have to re-login multiple devices -_- 18:53
japhb One of my tech leads would habitually log in every time he came back to his desk, just on the principle that if everything fell apart, he wanted that token to last as long as it could. 18:54
leont Frankly I consider it security theather
japhb At one point, someone transfered into a peer team of mine from Google [X], and he had weird extra security devices attached to his laptop and was like "Yeah, normal Google isn't sufficiently paranoid for the [X] folk." 18:56
I was a little surprised they let him keep the [X] laptop when he transfered, actually. 18:57
leont The threat model doesn't really make sense. I much prefer a ssh-style setup where even leaking the keyfiles doesn't automatically compromise the security of the system (because they're encrypted) 19:02
ab5tract Considering that I was able to create a fez representation of a module without any kind of authentication that I owned the module, it does seem a bit like security theater 19:20
not sure how such authentication would be performed, mind you 19:21
just that it seems important to register any modules you own on fez before someone else does
ugexe at some point the p6c ecosystem will be turned off and you won't be able to have that happen. although note if it was in the fez ecosystem already it would get chosen over the identical auth in p6c 19:31
github.com/Raku/problem-solving/bl...6c-cpan.md 19:33
jjatria But that's not really how auth works. Even if you released Foo:auth<zef:ab5tract> I can release Foo:auth<zef:jjatria> and there's no name conflict, and there's no current way to make it so Foo:auth<cpan:ab5tract> points to some "authoritative" version on zef (although I think there was some proposed META field that would do something like that?) 19:56
tonyo japhb: i can put in an update to refresh the token expiry time to refresh when used 20:37
need to think more on the side effects of that though
.tell ab5tract `Considering that I was able to create a fez representation of a module without any kind of authentication that I owned the module` - what does this mean? 20:38
tellable6 tonyo, I'll pass your message to ab5tract
tonyo jjatria: i think the goal is eventually to turn off p6c and have people use stuff like `use Foo:<zef:jjatria>` rather than the open ended `use Foo` 20:40
`use Foo` leads to less predictable behavior
ugexe jjatria: if you use untrusted ecosystems then yes anything is possible 20:47
basically module authors dont get to say where you get to download some given identity, which hard couples systems to actual implementation of whatever ecosystems (which may disappear one day). instead you should configure e.g. zef to use trusted ecosystems (disable p6c/cpan for example) until such a time where that can be the default 20:50
at its most basic level a trusted ecosystem is one that can and does enforce namespace rules 20:52
Nemokosch `use Foo:<zef:jjatria>` looks rather ugly, on the other hand, predictable or not 21:01
if this is the cost of modules with the same name that it's rather not worth it...
if this is the cost of modules with the same name then it's rather not worth it...
ugexe then don't install other versions of Foo 21:14
name your module Foo::JJAtria or whatever 21:15
its really no different
the production-ness of the adverbs stands regardless of auth if for no other reason than pinning versions 21:17
so if you want to avoid adverbs you already have thrown caution to the wind 21:18
Nemokosch again, if the cost is that you will end up with mandatory longer names with metadata in them, it would have been just better if there was no name collision allowed in the first place; that's all my point 21:32
ugexe and what we've been saying is once untrusted ecosystems are no longer default enabled then there won't be name collision 21:51
ugexe if we want the shortest names possible though we should disallow multiple versions too 21:54
no more installing version 1 and version 2 of some thing
because then people have to `use Foo:ver<1>` and `use Foo:ver<2>` 21:55
jjatria ugexe: my examples were not using an untrusted ecosystem, unless you consider zef to also be "untrusted" 22:22
ugexe if you only use the fez ecosystem, the only trusted ecosystem atm, then i dont understand your complaint
jjatria I'm not the one complaining 22:23
jjatria All I'm saying is that ab5tract's suggestion of "register your modules on zef before somebody else does" won't make a difference 22:24
ugexe yeah that is correct 22:26
jjatria That said, I'm not sure what you mean by "once untrusted ecosystems are no longer default enabled then there won't be name collision", unless you consider the auth (and version?) to be part of the name 22:28
jjatria Because even when only zef (fez?) is around, `use Foo` will still be ambiguous if both `zef:a` and `zef:b` have released a `Foo` module 22:29
ugexe yes, you have to be aware of raku environment. if zef is only installing from trusted sources then i doesn't matter if those are ambiguous 22:30
however it would still be best practice to use them (ver, auth, etc) regardless 22:31
jjatria Still not sure I quite get what you mean. I'm thinking of a point where zef only ever installs from zef. Or what do you mean by "trusted sources" there?
ugexe yeah sorry i mispoke, i was thinking collisions with identical identities in different ecosystems 22:36
jjatria > "name your module Foo::JJAtria or whatever, it really is no different" Except that `zef:notjjatria` can also release Foo::JJAtria, but only `zef:jjatria` can release `Foo:auth<zef:jjatria>`
Now I feel strange being used as the example :P
guifa_ So one thing is you need to think historically 22:45
Perl had CPAN, which enforced only one module with any given name 22:46
(and actually, once you first published a module in Foo::Bar namespace, you OWNED the Foo::Bar:: subnamespace. The Foo:: namespace too if no one had published in it before)
And it could cause problems when you'd have ecosystem rot, for instance. Imagine I had Intl::Format::DateTime. I stopped updating it. Someone wanted to create a drop in replacement. BEst they could do is make l12n::Format::DateTime, or i18n::Format::DateTime or Intl::Fmt::DateTime 22:47
jjatria This might have been discussed before, but maybe there should be an opt-in way to make bare `use` statements (without adverbs) a compile time error if the resolution is ambiguous? 22:48
Or maybe warn?
guifa_ Would be super easy as a slang ha 22:50
tonyo i'd reckon the best way is just forcing the META6 to be specific and the loader to reference that 22:52
jjatria As in, forcing adverbs in the `depends` section of the meta? And in that case, which adverbs are you thinking of? `auth` only? Or `ver`, `api`, and friends? 22:56
Also: "forcing the loader to reference that" -> how would this look? 22:57
ugexe it cant really work since a single distribution could depend on multiple versions 23:00
tonyo then the loader should complain if the loading statement is not specific enough 23:01
jjatria ^ That I can get behind. A warning at least would be welcome methinks 23:02
tonyo which is a minor inconvenience given that use case
jjatria Anyway, bedtime for me 👋
ugexe considering that "updating" a module means just installing a newer version of it, warning on ambigious use would be extremely annoying 23:03
tonyo the loader'd have to be aware of the META at load time, and if you have in your meta `depends: [ "Foo:auth<zef:xxxx>"` then when you `use Foo` you should be reasonably sure you're getting `Foo:auth<zef:xxxx>`
habere-et-disper m: sqrt(2) 23:05
camelia WARNINGS for <tmp>:
Useless use of "sqrt(2)" in expression "sqrt(2)" in sink context (line 1)
habere-et-disper m: sqrt: 2
camelia WARNINGS for <tmp>:
Useless use of constant integer 2 in sink context (line 1)
habere-et-disper m: sqrt(2).say 23:06
camelia 1.4142135623730951
ugexe depends parsing is also pretty convoluted, such that parsing it to load modules would probably be less than awesome
habere-et-disper m: sqrt: 2 andthen .say
camelia 2
tonyo it'd be a time suck but still ideal 23:07
there must be some tradeoff but not sure what
habere-et-disper What is happening with `sqrt: 2` versus sqrt(2)
ugexe the code already bends over backwards to not have to parse meta data on load. it could serialize it on install to a more fast format. but even still, handling a) one-of / optional depends and b) declarative logic depends seem nothing short of inefficient no matter what 23:10
github.com/ugexe/zef/blob/7c46ca2d....t#L52-L64
like i dont see how that can be fast 23:11
tonyo i don't either 23:13
guifa_ habere-et-disper so two things 23:31
sqrt: 2 is just a label with the int 2
so sqrt: 2 andthen .say is equivalent to
LABEL: 2 andthen .say 23:32
which is to say it's just `2 andthen .say`. `andthen` checks the truthy value of the previous expression (2 is truthy), and topicalizes it ($_ = 2)
(in other words `if temp $_ = 2 { .say }`) 23:34
now, for method calls, the colon syntax is just a way to get rid of parentheses 23:35
`$foo.bar(5)` is the same as `$foo.bar: 5`, is the same as `bar $foo: 5`
habere-et-disper guifa_ Thank you. I was looking to loose the parentheses, but it looks like I can't with sqrt? I take it doesn't have a method call. 23:52
guifa_ you can just lose parentheses entirely 23:57
`sqrt 2` is the same as `sqrt(2)`, assuming there is nothing following it
(well, very low precedence stuff like andthen would actually be okay)
m: sqrt 2 andthen .say 23:58
camelia 1.4142135623730951
guifa_ m: say sqrt 2
camelia 1.4142135623730951
habere-et-disper guifa_ Thank you again, rather helpful. :) 23:59