mirror of
https://github.com/apple/pkl.git
synced 2026-01-11 22:30:54 +01:00
Rust language bingings/code generation #51
Reference in New Issue
Block a user
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Originally created by @WeetHet on GitHub (Feb 11, 2024).
I'm really interested in using this in my rust projects, any plans on supporting serde/code generation?
@jclmnop commented on GitHub (Feb 12, 2024):
+1 for this
In the meantime we'd have to just use
serde_jsonand export the.pklto.json, then manually define all the types/structs etc again in code (which I guess is what we do with JSON/YAML anyway). Would be nice to just write the config and have it generate the types for us.@holzensp commented on GitHub (Feb 13, 2024):
This is a totally valid ask and you're not the first to ask. The core team lacks bandwidth at the moment, so we can't make any promises about this in the foreseeable future. That said, community contributed Typescript bindings are approaching done after little more than a week.
If anyone wants to pick this up, I'm sure
pol-communitywill be happy to host it (cc @jasongwartz, @jackkleeman). Support has been readily available on the discord channel they opened for this.@jackkleeman commented on GitHub (Feb 13, 2024):
I think I will probably work on this after Typescript
@linux-china commented on GitHub (Mar 1, 2024):
Vote for Rusting binding:
@jackkleeman commented on GitHub (Mar 1, 2024):
This would require actually building a Pkl JIT interpreter in Rust. This is a much larger task. The goal with bindings is to create a type safe way to interact with the pkl binary (in server mode). In time, the bindings will be changed to use Pkl as a linked library instead of over exec - but this may still be quite large, and GraalVM based!
If someone wants to try and build a new interpreter for Pkl in Rust, they should absolutely go ahead, but it's definitely beyond me!
@SmolPatches commented on GitHub (Jun 17, 2024):
I'm brand new to PKL so take this with a sizable pile of salt but what would a binding to Rust entail? I am quite interested in knowing what goes in to making a typesafe / production language binding.
I imagine PKL could be made to leverage json serde to encode the Pkl types into rust at runtime, obviously this could fail if the structure of the JSON is not capable of being ingested by the particular structs / enums in Rust but is that not alright, we would just need errors to provide details on the problematic code.
@z-jxy commented on GitHub (Jun 19, 2024):
This does work, sort of. You could technically call
pkl eval file.pkl --format jsonand deserialize that output, but that would be more of a wrapper around the pkl binary than a binding.The binding should be parsing the evaluator responses according to the spec. The task is mainly turning the binary encoding into a format that can be deserialized, which would include doing most of the work serde json does.
For example, evaluating this pkl file:
would produce an output like this.
A good reference for how this is implemented is pkl-go. I also have a working binding for Rust