You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
While working on #2265 I would like to use errors defined in external crates. Currently errors in UniFFI for kotlin are defined as with an ErrorHandler returning an instance of UniffiRustCallStatusErrorHandler. However since each crate currently define their own types for everything we have multiple implementations of UniffiRustCallStatusErrorHandler.
This is further complicated by the fact that uniffiRustCallWithError accepts a callback which uses UniffiRustCallStatus. UniffiRustCallStatus defines an error_buf as an instance of RustBuffer. As RustBuffer also have different implementations for each crate it's not easy to share these.
The most straightforward solution to this problem would be to make UniffiRustCallStatus, uniffiRustCallWithError and uniffiCheckCallStatus public. After which you could use uniffiRustCallWithError from the crate that defines the error (and also the RustBuffer implementation. However this diverges fairly significantly from the current design patterns used in UniFFI and feels like a sub-optimal approach.
Details
The generated code for function definitions would look something like this:
- fun uniffi_uniffi_ext_types_proc_macro_lib_fn_func_throw_external_error(uniffi_out_err: UniffiRustCallStatus, + fun uniffi_uniffi_ext_types_proc_macro_lib_fn_func_throw_external_error(uniffi_out_err: uniffi.uniffi_one_ns.UniffiRustCallStatus,
): Unit
@Throws(UniffiOneException::class) fun `throwExternalError`()
=
- uniffiRustCallWithError(UniffiOneException) { _status ->+ uniffi.uniffi_one_ns.uniffiRustCallWithError(UniffiOneException) { _status ->
UniffiLib.INSTANCE.uniffi_uniffi_ext_types_proc_macro_lib_fn_func_throw_external_error(
_status)
After raising the issue in matrix the ideal solution would most likely be to define the common types once, and be able to re-use them across all crates. This would ensure only a single implementation of RustBuffer exists, and potentially also only a single UniffiRustCallStatus removing the need for a workaround.
The text was updated successfully, but these errors were encountered:
This is further complicated by the fact that uniffiRustCallWithError accepts a callback which uses UniffiRustCallStatus. UniffiRustCallStatus defines an error_buf as an instance of RustBuffer. As RustBuffer also have different implementations for each crate it's not easy to share these.
Sorry for the delay here. This has all changed quite a bit recently. I think I agree that we should end up with a single RustBuffer etc, at least for compiled languages - but for now, we're just getting better at using the correct RustBuffer for the type - and ditto for CallStatus etc.
I wouldn't be surprised to find things are improved on main and close to working. It would be great to know your experiences on main, otherwise I'll try and dig into this before the next release.
While working on #2265 I would like to use errors defined in external crates. Currently errors in UniFFI for kotlin are defined as with an
ErrorHandler
returning an instance ofUniffiRustCallStatusErrorHandler
. However since each crate currently define their own types for everything we have multiple implementations ofUniffiRustCallStatusErrorHandler
.This is further complicated by the fact that
uniffiRustCallWithError
accepts a callback which usesUniffiRustCallStatus
.UniffiRustCallStatus
defines anerror_buf
as an instance ofRustBuffer
. AsRustBuffer
also have different implementations for each crate it's not easy to share these.The most straightforward solution to this problem would be to make
UniffiRustCallStatus
,uniffiRustCallWithError
anduniffiCheckCallStatus
public. After which you could useuniffiRustCallWithError
from the crate that defines the error (and also theRustBuffer
implementation. However this diverges fairly significantly from the current design patterns used in UniFFI and feels like a sub-optimal approach.Details
The generated code for function definitions would look something like this:
After raising the issue in matrix the ideal solution would most likely be to define the common types once, and be able to re-use them across all crates. This would ensure only a single implementation of
RustBuffer
exists, and potentially also only a singleUniffiRustCallStatus
removing the need for a workaround.The text was updated successfully, but these errors were encountered: