🦋 Welcome to the MAIN() IRC channel of the Raku Programming Language (raku.org). 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 6 September 2022.
00:25 xinming left 00:27 xinming joined 00:35 xinming left 00:37 xinming joined 00:47 xinming left 00:49 xinming joined 00:55 xinming left 00:57 xinming joined
ky is there a lazy regex/match? something that provides incremental matches on a very long stream of characters? 01:02
i'm using m:g/ ... / maybe that's it? but the $/ is a list, not a seq. 01:06
nm 01:08
timo i wonder if anyone has tried to switch out the string that's being matched against during the matching ...
it's probably not that hard to do one match at a time and just increase the starting offset parameter and appeding to the string and/or cutting parts off the start as you match past them? 01:09
01:09 kylese left 01:10 hulk joined
tonyo the least efficient way might be to split the string into overlapping lengths of the longest possible match and then run the regex against all of them 01:26
02:06 xinming_ left 02:15 hulk left, kylese joined 03:54 Aedil joined 05:30 Sgeo left 05:45 [Coke]_ left 05:59 [Coke]_ joined 06:03 [Coke]_ left 06:13 xinming left 06:15 [Coke]_ joined 06:20 [Coke]_ left 06:49 [Coke]_ joined 06:54 [Coke]_ left 07:07 wayland joined 07:08 wayland left 07:23 [Coke]_ joined
antononcube @tonyo “your module needs to export your resources for your test to see them” — Yes, this is how I did it : github.com/antononcube/Raku-LLM-Re...kutest#L11 07:50
07:52 [Coke]_ left 08:03 sena_kun joined 08:21 [Coke]_ joined 08:26 [Coke]_ left 08:49 PaulW2U joined 08:57 [Coke]_ joined 09:06 Guest44 joined
Guest44 Hi, I want to invite you to a new free social network! 09:07
The network does not collect personal data, you can find out more on the website dkonapp.github.io/start
Thanks for your attention!
09:14 Guest44 left 10:07 [Coke]_ left 10:13 [Coke]_ joined
[Coke] seen lucs 10:14
.seen lucs
tellable6 [Coke], I saw lucs 2024-08-28T21:30:52Z in #raku: <lucs> And can that be changed?
10:37 MoC joined 12:57 patrickb left 12:58 greenfork left, atweedie left, atweedie joined, greenfork joined, snonux left, snonux joined
lizmat github.com/Raku/problem-solving/issues/438 12:59
13:01 snonux left, snonux joined 13:08 snonux left 13:09 snonux joined, samebchase left
tbrowder [Coke]: i'll rm my comment ... having login probs at the moment 13:10
13:12 BooK joined
ugexe antononcube: why are you using ‘use lib’ in your test? 13:27
See stackoverflow.com/a/55940571/1772220 13:29
antononcube @ugexe I assume(d) that might be bad. I try not to have them in the released packages that “stable.” The reason is that I start the testing both from CommaIDE and terminal. If I do not have use lib I get inconsistent results.
@ugexe Thanks!
ugexe Using use lib in tests is generally bad form. Using ‘use lib . lib’ is *always* bad form 13:30
antononcube Ok, I will gradually remove those from all of my packages. 13:33
13:33 lichtkind joined
Is there an explanation or discussion why using use lib <. lib> is bad form? I think I saw a comment about that from lizmat a few years ago. 13:35
ugexe I’ve made that explanation many times over the years so they exists somewhere. Alas I’m on a phone and don’t have the means to find one. I mentioned in example in that SO post but more generally it can cause extra precompilation 13:38
13:39 hudo_ left
ugexe using lib lib specifically is particularly bad because it hides issues with the meta6.json that cause code to fail on install even though it tests fine 13:40
such as failing to list a module in the provides section
13:41 samebchase joined
ugexe use -I. when invoking a test from the terminal. Use whatever mechanism Comma presumably has to set the lib path for testing 13:42
For tests “use lib” should be reserved for including libraries only for testing such as t/my-test-libs that won’t be installed 13:45
13:47 samebchase left, samebchase joined 13:50 clarkema left 13:51 snonux left 13:52 samebchase left, greenfork left, atweedie left 13:57 snonux joined 13:59 samebchase joined
[Coke] tbrowder: thanks, not trying to be a jerk about it - I agree that priorities need to be set, but in-ticket doesn't work (I had so many of these kinds of things in raku/docs) - I tried using discussions there, but that is bad for different reasons. You should definitely track those asks though. 14:00
tbrowder: I hope now that I have an azure box running Blin I can also get one running raku.land for dev work. (getting it working on mac osx was... challenging) 14:01
14:02 samebchase left, snonux left 14:07 clarkema joined, patrickb joined, snonux joined 14:08 Sgeo joined 14:10 samebchase joined 14:14 atweedie joined
antononcube @ugexe Thanks -- I will search / investigate explanations. 14:14
14:15 greenfork joined 14:52 xinming joined 15:07 MoC left 15:15 itaipu left
[Coke] m: with Date.today { say "WHEE" if .day-of-week==5 && .day==13} 15:29
camelia WHEE
15:30 itaipu joined 15:43 discord-raku-bot left, discord-raku-bot joined 15:47 bdju left 15:49 bdju joined 15:59 xinming left 16:01 xinming joined
lucs [Coke]: meep 16:02
[Coke] hey - thanks for the docs fix. 16:04
16:06 xinming left
lucs Sure thing. Um, luckily (just saw your message in raku-doc), those colons had nothing to do with ratcheting (I hadn't considered such a possibility at all). 16:06
16:09 xinming joined 17:02 Xliff joined
Xliff \o 17:02
tellable6 2024-08-29T20:49:15Z #raku <ab5tract> Xliff: looks reasonable
Xliff Has anyone been able to get C++ Templates (ala Generics) working with NativeCall?
17:23 xinming_ joined 17:40 swaggboi left
ab5tract Even though we have support for C++ name mangling, I think it’s still only really possible to do much binding based on extern functions 17:45
17:45 swaggboi joined
ab5tract That is to say, I don’t know if any OO or fancy type stuff is directly accessible:( 17:46
I would love to be proven wrong though 17:47
librasteve i am slowly weaning myself off use lib in my tests .... largely by going zef install . --force-install --/test each time 18:28
Xliff ab5tract: Yeah, it looks like most Generic handling will h ave to be done with POPs (plain ole pointers), while actual generic classes will have to be Madlib handled ahead of time. Which defeats the point of Generics in the first place. 18:37
C++ has VERY limited reuse potential for generics EXCEPT for C++. 18:38
That is unless support for them is directly implemented by Moar.
ab5tract There is a tentative long term goal of studying whatever Swift is doing, as they are reportedly having some success at more direct integration with C++ 18:40
18:45 Aedil left
ab5tract That seems like the holy grail. Probably by the time we get there everything will be rewritten in Rust. At least we can hope for a robust Rust ABI by that point :) 18:46
Xliff Pah! Rust. 19:15
I mean, if we can steal it for MoarVM, great!
But after what I've read on NativeCall, I don't know if what they are doing will translate. 19:16
Really, what Generics will need is macros.
19:34 kaskal- joined 19:35 kaskal left 19:36 xinming left 19:46 lichtkind left
ab5tract “they” meaning Swift? 19:52
If Rust proves to be just as opaque a target for binding as C++ is, it hopefully won’t be so taboo to mock the Rewrite in Rust movement 19:55
On the other hand, if they can deliver a smooth. next generation ABI, I’ll welcome and encourage their replacement efforts 19:56
Xliff Oh, so will I. I'll just be biased. 20:06
ab5tract imagine a binding layer that can tell you what it offers 20:09
*what is offered
timo C++ generics require either a C++ compiler or a C++ interpreter to work with 20:15
if you already had a c++ compiler build the instantiations of all the templates for you before, you can just load the .so that has them and use the code that way 20:16
at that point they "are no longer generic", they are now "specific"
ab5tract I'm not sure what Xliff had in mind, but in Java you have access to parameterized types when you load the .jar 20:20
or maybe I mean un-parameterized types which take parameters
this is what I tend to understand as "generics" 20:21
20:24 thaewrapt joined
ab5tract Here's a reference to what the Swift folks are thinking on the topic: forums.swift.org/t/c-function-temp...ft/42016/6 20:24
patrickb I think there is a fundamental difference in how generics work in Java an C++. Java has type erasure, where generics actually work with type "object" under the hood. While in C++ the compiler makes a copy of the templates class, replaces the placeholders with actual types and compiles the result whenever you specialize some template. 20:52
timo yes, with type erasure it's easy to support everything with just one set of bytecode 21:06
C++ on the other hand allows you to put objects with different memory layouts in and the code it compiles is then correct for whatever you put in 21:07
think of this example - i don't know cpp template syntax by heart, so pseudocode: `template<struct A, struct B> add_as(A a, B b) { return A.a + B.a }` 21:08
now make a set of structs: `struct one { uint64_t pad[1]; uint64_t a }; struct two { uint64_t pad[2]; uint64_t a }; struuct three { uint64_t pad[3]; uint64_t a }; /* and so on and so forth */` 21:09
every combination of A and B generates different assembly 21:10
on the JVM i'm not sure exactly but it would have just one set of bytecode that would be interpreted, and if it becomes worthwhile the JIT will make whatever native code at run time 21:13
with templates, what you get is C++ source code, on the JVM you get bytecode
if you want to have NativeCall work with templates, you have to, at some point, parse the C++ source code where the template is defined
there is no built-in "reflection" in C++ where you can ask "where in this struct is the field named a placed?" 21:14
you need the source code, the header files. that's also why for every generic that shows up, you compile a full set of needed methods and functions for all parameters that are used anywhere 21:15
21:18 sena_kun left
leont Yeah, C++ templates really are macro-like. That's why it breaks some people's heads. I love the feature I just hate what a lot of people are doing with it. 21:18
21:19 sena_kun joined
ab5tract I _think_ you can make an endrun around at least some of that via llvm but even C++ without templates is a damn tough nut to bind 21:21
timo i mean, llvm also has a c++ parser and compiler
i wonder what you can get out of dwarf debug symbols when it comes to templates 21:23
ab5tract Yes, it does. As well as some “above and beyond” introspection tooling, iiuc. 21:24
But timo++ made some important points that highlight how templates probably are not particularly useful in the wrapper library context. 21:25
timo i guess it's time to realize why projects like swig exist 21:26
21:29 sorenson left 21:33 sena_kun left 21:35 sena_kun joined
ab5tract "if your application somehow involves the instantiation of 50000 template classes, your mileage might vary." 21:37
I've always appreciated swig as a legendary and seemingly unsurpassed bindings generator. at the same time, I'm not sure if I've ever encountered it as a dependency on any binding source I've encountered... 21:40
21:54 sena_kun left 21:55 sena_kun joined 21:59 [Coke]_ left 22:00 sena_kun left
tonyo antoncube: that looks like your test is requesting the resources, not like your module exposing them 22:07
maybe the resource access has changed though, idk
22:20 jjido joined 22:26 [Coke]_ joined 22:31 [Coke]_ left
tonyo oops, disregard - 22:32
22:39 ian47 joined 23:14 [Coke]_ joined 23:16 wayland76 joined
wayland76 o/ 23:17
Does anyone know why XDG::BaseDirectory (either 0.0.14 or 0.0.13) is giving me "required attribute 'perl-version' is not defined"? 23:18
Is it because my raku version is too old, or is there something else going on?
23:19 ian47 left 23:21 [Coke]_ left
wayland76 For timo, ab5tract, and vendethiel, regarding the "leave" discussion earlier this week, see github.com/rakudo/rakudo/issues/5577 23:22
.tell vendethiel regarding the "leave" discussion earlier this week, see github.com/rakudo/rakudo/issues/5577 23:23
tellable6 wayland76, I'll pass your message to vendethiel
23:44 _________ left 23:45 _________ joined 23:47 bdju left, bdju joined
antononcube @wayland76 I have a good, useful MVP of the LLM RAG package. 23:51
I want to implant a few more features then I will release it.
*implement (not “implant.”) 23:53