🦋 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.
02:10 coleman left 02:12 coleman joined 02:14 guifa joined 03:05 guifa left 08:00 samebchase left 10:11 [Coke] left 10:57 [Coke] joined 11:30 sena_kun joined 15:30 bartolin left
ugexe perl is putting TLS in core 16:22
lizmat interesting... from XS I assume, not written in pure perl 16:23
in that respect: I think we should make JSON support public as well (and update it so that :immutable can be used) 16:24
ugexe we could but that still would require some thinking about what to do about non-standard types. i.e. Version 16:36
which we have to think about because our current implementation works with Version but technically the way it does so is not round-trippable and thus potentially confusing for something exposed to general users
hence why languages often allow some type of TO-JSON() interface for objects (similar to providing your own raku method) 16:37
regardless, TLS is probably being put in the core for the package manager and less so to make having http servers require less dependencies 16:39
ab5tract lizmat: I support that. I guess as long as we are good with the current interface (from-json / to-json), attempts could be made later to provide VM-speficic fast path encoders/decoders
ugexe and even then further we probably then need to figure out rakus dual-life strategy 16:40
i mention all of this because the very last thing one would do to implement all of that is actually move the JSON module into the public space, it would not be anywhere near the first thing 16:41
ab5tract I'm a bit confused about your Version concern, for instance. Are you referencing marshalling of objects to and from JSON? Because that is somewhat separate from being able to import and export JSON datastructures 16:43
ugexe yes, the behavior and user expectations of to-json and from-json 16:44
ab5tract Then what does that have to do with Version or any other Raku type?
ugexe because 99% of users will not expect v12341234 to marshal to something
ab5tract JSON supports dictionaries, arrays, a few numerics, strings, booleans, and null
ugexe i may very well expect that to be a json parsing error
"v1234123" is ambiguous and would just be treated as a string i guess, but v1234123 is not the same 16:45
ab5tract it should be the same, because all the JSON encoder should do is call .Str on objects 16:46
ugexe that isnt how other languages do it
ab5tract (objects that haven't handled themselves)
ugexe Str and whatever the json representation are are usually provided by different methods
ab5tract Other languages mostly require you to have a complete type reference
in the form of a class or struct or what have you 16:47
ugexe and they will error if it encounters a type that 1) json does not know how to marshal and 2) does not have a custom marshaler provided by the user to declare how they want it done 16:48
in Go you have interface{} / any for instance
ab5tract or 3) provide a option to just stringify a field, or numify it, or whatever 16:49
lizmat is this about from-json? or also about to-json ?
ugexe mostly from-json 16:50
im not aware of any such option as 3 in Go
ab5tract for these languages, it's both. you are always marshalling out of and back into the same reference classes (which are the objects you are serializing in the first place)
ugexe: I expect it is covered by number 2 16:51
ugexe ok so what im saying is the user would need to provide such a custom marshaler
as users will have different expectations 16:52
ab5tract and I'm saying that it is more Raku-ish to allow both that as well as a toggleable default behavior
but neither of these things genuinely make sense to me inasmuch as there have been no complaints that I'm aware of about the JSON::Fast way of doing things 16:53
ugexe i guess fundamentally i just don't think that is good and leads to a php-like language of lots of weird gotchas and footguns you need to be aware of
ab5tract Well I would hate to see Raku become a language where you can't load a random JSON stream without defining 100% of the potential fields for 100% of the hash structures in that stream 16:54
ugexe there being no complaints in something that is yet to see widespread use does not mean it was designed in a way that widespread use would desire
ab5tract JSON::Fast is about as widespread as it gets for a Raku dependency 16:55
lizmat it is the #1 reverse dependency
ugexe the version serialization as it exists in JSON::Fast exists *only* because the core json parser does it and that *only* does it because we were passing raw version objects to CURI erroniously
lizmat rea > river 16:56
Top 3 distributions and number of dependees
Add 'verbose' to also see the actual dependees
JSON::Fast (405)
File::Directory::Tree (253)
MIME::Base64 (234)
ab5tract okay, so maybe there is some misunderstanding.. I think. marshalling a la JSON::Marshall / JSON::Unmarshall is out of scope for a core JSON
ugexe reverse dependencies are not indicative of the usage of something. lets be real: not a lot of people are using raku right now 16:57
so we lack a lot of the feedback and cases that come with widespread use
ab5tract if there is any marshalling behavior (ie reading JSON into an object of an acutal Raku class that is not a sane mapping of a JSON type) is out of scope 16:58
(imo)
so this Version situation is a non-feature that should not be part of an actual release 17:00
ugexe m: say Rakudo::Internals::JSON.to-json(q|{"foo":v112+}|)
ab5tract I think that widespread use amonst the community is obviously as good as it gets in gauaging the degree of developer acceptance 17:01
camelia "{\"foo\":v112+}"
ugexe oops that isn't right
m: say Rakudo::Internals::JSON.to-json({foo => v112+})
camelia {"foo":"112+"}
ab5tract didn't you say that this use was wrong to begin with?
lizmat m: put v112 17:02
camelia 112
lizmat m: put v112+
camelia 112+
lizmat so it's just stringifying
ugexe yes, and as ive mentioned i don't think that is sufficient
and why e.g. perl classes often provide TO-JSON type methods 17:03
lizmat well, what's stopping us from doing that as well?
ugexe which is a fine thing to do, but again that requires forethought and design decisions to take place
lizmat with sub Mu.TO-JSON(\x) { x.Str } 17:04
ugexe my original blurb was that moving the module to e.g. lib/ is the literal last thing to do
lizmat no... it should be in core setting *not* in lib
Geth rakudo/ugexe/deprecate-multi-file-operations: 1ea61d5a24 | ab5tract++ | 2 files
Simplify candidates by going with IO() only
ugexe hence the e.g. 17:05
but i disagree and would put it in lib/ 17:06
lizmat but we need it for module loading ? 17:07
ugexe yeah that is unfortunate 17:10
17:22 bartolin joined
lizmat re unmarshalling, is there a reason why we just shouldn't invoke.new on the class, and flattening the hash as named arguments ? 17:35
or related: create a Mu.from-hash method that would call self.new(:%_) by default 17:36
timo the reason is the json doesn't tell us what class to use 17:37
and json doesn't have a standardised way to specify that
lizmat giving a class the option to provide their own .from-hash method for unmarshalling
ab5tract I like the way the community libraries work
lizmat you mean raku.land/zef:raku-community-modul...:Unmarshal ? 17:38
ab5tract yeah
lizmat I was just looking at that also
timo when you have just ["v44", "v1.2"] where does it say it should use Version.new and not Str or IO::Path or HLL::Compiler or Stash or ...
lizmat actually to push a tweak in a mo
ab5tract and the related and also excellent raku.land/zef:vrurg/JSON::Class 17:39
timo alternatively, raku.land/zef:jonathanstowe/JSON::Class
ab5tract right
timo that's the one you get on debian for the name
ab5tract marshalling is cool, but what really sets Raku apart is that it is a flexible enough language to be able to do a lot JSON juggling *without* pre-declaraing the JSON structure 17:41
marshalling / un-marshalling is much more "traditional" in that it absolutely requires pre-determined schemas of the JSON data 17:42
it's a neat idea to work our a core solution for that stuff, but I think we might find greater success based on getting really fast parsing of arbitrary JSON into core more than we can with "hey look, you can spend the same amount of up-front time doing JSON parsing as you can in just about any other language" 17:45
tl;dr -- I do not agree that you need to solve marshalling of classes in order to ship useful improvements to core JSON handling and I also think that matching the behavior of "other" JSON serde options is a decent goal but ultimately an impossible one because the amount of incongruity between JSON parsers is legendary and every language has similar-but-unique approaches to JSON for the simple reason that it Just Makes Sense to do so 17:48
coleman wouldn't any strongly typed marshaling solution need to be built on a lower level parser that deals with map<str>object; 17:52
timo btw should we offer a mode for our json parsers where large integers get scrungled by first being put into a floating point number and then back? you know, how javascript does it? :P 17:53
Geth rakudo/ugexe/deprecate-multi-file-operations: 3ce0ee9684 | ab5tract++ | 2 files
Simplify candidates by going with IO() only
17:54
coleman I like this API, fwiw github.com/tidwall/gjson?tab=readm...esult-type
Geth rakudo/ugexe/deprecate-multi-file-operations: a5a4ac2545 | ab5tract++ | 2 files
Simplify candidates by going with IO() only
17:59
ugexe ab5tract: to me that is arguing top-down vs bottom-up, which is going to be a matter of opinion for most people. personally i generally lean towards top-down design when a clear vision of the end product/system can be achieved, although in practice im usually blending both top down and bottom up 18:02
ab5tract I can dig that, but only when it doesn't preclude implementing the bottom portions that actually don't require any of that top-level design to be in place. see coleman++'s point 18:03
the other side of this is that top-down design can be slow to begin with, and when it's combined with mostly/only async text chat, it can get demotivating or suffer from constant re-treading as conversations re-occur but with a slightly altered roster of participants 18:06
that's not an actual mark against it as a design philosophy, but rather a reflection on the obstacles we are facing when reaching for it
ugexe a bottom-up approach might be something like "Let’s just parse JSON into a hash right now" and only later try to figure out how it needs to do versioning, validation, or error-handling consistently across the system. which can lead to rewrites or major refactors once you realize your bottom-up implementation doesn’t fit the eventual top-level needs. maybe that is fine, but often that can 18:07
result in having some core logic that has to maintain bug compatibility
ab5tract The best a VM can do is put it into the right 6model type though, right? 18:08
The rest is up the HLL
timo the VM can also invoke code that it's been passed, so there's kind of a lot it could do 18:10
ab5tract Getting an API perfect in the first go-round. Has it ever happened? 18:15
ugexe perfect is the enemy of good enough. what we want to avoid is obviously bad apis like unlink(*@paths) etc
lizmat fwiw, I think there's a lot of experience to build on
ab5tract To distill my point a bit, top-down design can be really powerful. In order for us to pull it off -- my feeling is that -- we would need to change our way of working a bit. Maybe setting up a committee dedicated to evolving that design that meets regularly-ish and chips away at it? I don't know the specifics, only that without some sort of formal effort to grind the design into existence, it will likely to serve more as a deterrent to trying 18:18
anything at all than as a finish line we are working towards.
s/it will likely to/I fear that it will/ 18:20
ugexe yes that would be good. i also admit that with our current number of developers it can often be hard to get feedback. however, just creating a design outline before implementing something even without feedback is a giant step in the right direction as it shows thoughts/considerations were given to things rather than what might be described as prototyping 18:25
ab5tract fair point 18:27
timo one thing i can think of is we don't want to make it impossible to get at things that are under the same hash key in a json dictionary 18:30
some low-level parser bits are implemented as a stream of events. "dictionary opened", "dictionary key 'foo'", "True value", "dictionary closed", "end of document" 18:32
just thought i'd mention it as one possible piece for an implementation near the bottom end of the design 18:33
for handling especially big documents it might be desirable to not create any "object hierarchy" bits for things we might not ever access, so a hypothetical parser could record offsets into the source at strategic points so a lazy deserializer could pick parsing back up 18:34
but that doesn't have to be part of the "initial offering", it could go in a module instead for example 18:35
19:08 finanalyst left 22:07 finanalyst joined 22:52 sena_kun left
Geth rakudo/ugexe/deprecate-multi-file-operations: bad6872834 | (Nick Logan)++ | src/core.c/io_operators.rakumod
Remove calls to .IO on IO::Path objects
23:28
ugexe So github.com/rakudo/rakudo/pull/5485 is green, but when i run the spectest it fails. i do not think we are running spectests in the CI anymore 23:53
Geth roast/ugexe/use-existing-utils: cbb5c3fbcc | (Nick Logan)++ | S32-io/child-secure.t
Use existing util functions
23:56
roast: ugexe++ created pull request #867:
Use existing util functions
23:59