Skip to content
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

Remove Type::Error #1590

Merged
merged 1 commit into from
Jun 14, 2023
Merged

Remove Type::Error #1590

merged 1 commit into from
Jun 14, 2023

Conversation

mhammond
Copy link
Member

@mhammond mhammond commented Jun 8, 2023

End goal is to allow other types to be used as errors, but I figured the first and hopefully least controversial step would be to remove Type::Error entirely.

Still needs some thought re the bindings, but I think this is getting into good shape.

@mhammond mhammond changed the title Kill error Remove Type::Error Jun 8, 2023
@mhammond
Copy link
Member Author

mhammond commented Jun 9, 2023

Chatting a little with Ben, we feel that if we want to take this at all, taking it before 0.24 is probably the lest painful thing for people maintaining external bindings, and my intention is to put a PR up for at least go and the external kotlin ones which addresses almost all of the pain we put them through. I believe that the next patch (allowing interfaces as errors) will be far less intrusive than this - at least until they actually want to support that capability. So putting it up for review now.

@mhammond mhammond marked this pull request as ready for review June 9, 2023 13:42
@mhammond mhammond requested a review from a team as a code owner June 9, 2023 13:42
@mhammond mhammond requested review from badboy, jplatte and bendk and removed request for a team and badboy June 9, 2023 13:42
@@ -451,8 +458,25 @@ pub mod filters {
Ok(oracle().enum_variant_name(nm))
}

/// Some of the above filters have different versions to help when the type
/// is used as an error.
pub fn error_type_name(as_type: &impl AsType) -> Result<String, askama::Error> {
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is about the only part of this that I don't think is great! It's OK, but not great, The fact all the filters now use AsType means I can't magically turn an enum into "something else type-ish". This was actually quite a bit cleaner when it was a CodeType or CodeTypeDispatch, but removing CodeTypeDispatch was such a big win everywhere else that I think we made the correct tradeoff.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't really mind this, but one option would be to keep the Type::Error variant, but generalize it as Type::Error(Box<Type>). I'm not sure if that's a net positive or not, but it would remove the need for these extra filter functions.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think that would be a bit of a negative - it would still be a level of abstraction that hurts almost everywhere else IMO, and I think it would mean we'd need to force that level of abstraction - eg, we'd need to insist that, the function like fn throws() -> Option<Type> always was forced to return Type::Error again, which I think isn't ideal. To put it another way - Type::Error is a concept only the bindings need to care about, so having it as a first-class type in bindgen seems wrong.

TBH, I think the above really points more to a weakness in the CodeOracle setup than in uniffi_bindgen::interface, and that while AsType is great as the glue for CodeType, it might not be the correct thing to actually expose in the filters.

Copy link
Contributor

@bendk bendk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks great to me and I'd be fine merging it as-is. I had one question/suggestion around the design of the types that I think is worth exploring a bit, but I don't know if it's an improvement.

@badboy badboy added this to the v0.24.0 milestone Jun 14, 2023
@mhammond mhammond merged commit 2eb3975 into mozilla:main Jun 14, 2023
@mhammond mhammond deleted the kill-error branch June 14, 2023 14:14
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants