-
Notifications
You must be signed in to change notification settings - Fork 56
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support &[CustomType] #520
Comments
How do you envision this working over FFI? We do support output iterables, and could support input iterables, and that's probably the cleanest way to do it. But any type that has its own ownership that needs to be converted across the boundary is a lot of extra cost. So it really depends on what you're trying to do. It would be helpful if we could see the shape of the APIs you're trying to expose. It is possible to implement your own wrapping type that is internally a |
Edited the topic and my post to better express intent. Sorry for any confusion, I'm still coming up on Rust. I'm trying to construct a FFI wrapper around a custom serialization format, a little like FlexBuffers. We have one layer that operates on a pointer to data & a runtime loaded schema, and another using generated code to move a lot of the offsets to compile time. One thing we allow is that that structs may contain one of 2 different custom containers (Map/Vec equivalents our own stable ABI & in-memory layout), but there's no way to express this in diplomat. Considering it, I think what we really need is the ability to support custom container types, not just slices of user defined types. |
I'll write more later but to highlight: Are you specifically looking for common stdlib types to work with this, or the ability for a custom collection to implement something that allows it to be passed to Rust? The former is not that hard to design, the latter needs callback support which we might get at some point but don't currently have. |
The more I think about it the more I think we'll probably need custom generic collection support, which is gonna be a heck of a thing to generate automatically no matter what. I may wind up just using cbindgen and writing custom language specific stuff, since we mostly only care about rust, c++, and python as potential target languages |
To be clear we're already able to get some custom collection support with how we handle outputting strings: we're able to support different language string types and our older c++ backend even supported custom types that fit a template trait. So it may not be that hard but I'd really need to know what the precise functionality is. |
I'm starting to dig into this and hack together support in a private branch. The use case is being able to return something equivalent to a Vec<Box>, or to accept a &[StructType]. Over FFI, the former would wind up working a lot like the DiplomatWritable type, except without the terminating 0 byte & an alignment field. Then in any language with template support, the alignment field gets set to be sizeof(T) and the underlying DiplomatVecRaw type gets coerced into DiplomatVec. DiplomateWrite then becomes almost a special case of DiplomatVec. For the latter, The requirement should be to accept &[StructType] or &[Box]. The function I'm interested in takes a slice of tuple of f64s, and returns a dynamically sized array of OpaqueTypes (It's a 2d geomtetric lookup table) |
For returning a vector; have you considered using the now-existing iterator support? This would involve returning an iterable, which the caller can collect into a vector. I'd be in favor of additional annotations that can be applied to iterator methods to add a companion "make a vector" method? Which language are you primarily targeting? Before you spend too much time on this: we may or may not wish to accept patches for this depending on the complexity introduced and the nature of this design. Maintaining a fork, is, of course, fine. |
Oh! I hadn't found the iterator support. That's probably a viable option, I'll give that a shot. We're primarily targeting C, C++ and Python (I've written a kinda hacky backend that spits out a nanobind.cpp file). We're also interested in a Rust binding as well, odd as that may sound, so that we can ship a .dll with a .rs file. |
Looking at it, Iterator support could likely work for this case, but I'd need to add support to the c/++ generators. It's also a little clunky because I'd need to write a custom iterable type for every T I wanted to return, which is a bit cumbersome. |
Yep,
It would be acceptable to add Diplomat support for |
Yes please! I don't have time to write code for features you need but I can advise on implementation strategies that will end up with something we can upstream. We'd also love to upstream Python and Rust support. The DLL case is one we do care about, and have thought about doing something similar in the past. |
Unfortunately nightly is a no-go for use, so we're stuck with stable only for the time being. I'm making good headway on replacing DiplomatWrite with DiplomatVec, which will solve my use case a little better here I think. It's entirely possible to create stl compliant iterators that don't require contiguous memory & work basically like generators, so I think adding that support should be possible though it'll need some runtime library support I think |
I'm going to close this & replace it with several separate but related tickets to clarify the different specific use cases desired |
I'm working on a project where I need to expose a multi-language API, and I love diplomat's approach. However, the one big hole in Diplomat that makes it unusable for us is exposing `&[UserDefinedStruct]. Is this within scope and do you have any suggestions on how it might be integrated?
The text was updated successfully, but these errors were encountered: