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

Support for embedded-hal 1.0.0 and async #5

Open
wants to merge 9 commits into
base: master
Choose a base branch
from

Conversation

bbustin
Copy link

@bbustin bbustin commented Mar 19, 2024

This pull request starts with the changes made by @madmo in his pull request (#3).

It then takes ideas from the pull request @tazz4843 has for adding async support (#2). It differs in two main ways:

  • The async feature is used as a toggle instead of having a blocking feature and an async feature
  • The signature is now the same due to @madmo's work updating it to embedded-hal 1.0.0. This allowed for putting blocking and async code in the same impl. This should make it easier to maintain in the future as each async fn is right next to its blocking counterpart.

I hope this is helpful. I initially created a pull request into @madmo's branch, but I have not heard back and it kind of muddies the intent of his pull request as its scope was only embedded-hal 1.0.0 and not async.

madmo and others added 5 commits February 20, 2024 10:32
…n the work by @tazz4843. The reason I did not use his branch is that I wanted this to be based on embedded-hal-1.0.0. Since the signatures changed, this allowed for puttign all the methods in the same impl block and then feature gating them.
- information about async feature
- use of embedded-hal 1.0.0
- updated the example
@bbustin
Copy link
Author

bbustin commented Sep 5, 2024

@sirhcell, is there anything you'd like changed? I'd love to get this pull request merged in, if you think it is ok.

@dylif
Copy link

dylif commented Sep 28, 2024

@sirhcel It would be great if you could approve this PR and get this merged in. Thank you for your consideration!

@bbustin
Copy link
Author

bbustin commented Sep 29, 2024

I have temporarily forked this project and published crate sht4x-ng.

That means the cargo.toml in this pull request would need to be edited to put back the original name. I would still love to see these changes upstreamed.

@sirhcel
Copy link
Owner

sirhcel commented Oct 13, 2024

Thank you very much for your PR! I finally managed to also look into the async part of it.

It took me a while because adding async support to an existing driver still feels a bit alienating. The support for it got better with maybe-async and maybe-async-cfg since I looked at #1 and #2 last time. But neither of the two buys us out for an embedded-hal driver yet as far as I can tell.

I really don't like the code duplication associated with it. But massaging maybe-async-cfg into working with the type parameters of the drivers struct is beyond my current schedule and "pay grade" - and so it looks like duplicating code is the way to go in the short term.

@sirhcell, is there anything you'd like changed? I'd love to get this pull request merged in, if you think it is ok.

To my understanding, Cargo features should be additive. A feature switching between sync and async will break in a dependency tree where both variants are used. So I would prefer always providing sync support and enabling async support with the feature async and providing the async variant of the driver as Sht4xAsync. Which at a first glance boils the changes down to #7.

What are your points for the toggling feature flag?

I definitely see the benefit of having sync and async methods spatially next to each other. But from my experience with dependency trees, this would be payed with a lot of potential hassle in dependency trees. And the latter will be "payed" by the users and not the authors of this crate.

@bbustin
Copy link
Author

bbustin commented Oct 14, 2024 via email

@bbustin
Copy link
Author

bbustin commented Dec 14, 2024

Hi @sirhcel.

I have not been able to work on this further. Life has gotten pretty busy. :-(

Do you have any example libraries I could look at which use the techniques you are discussing? I do not particularly like the duplication either.

My main rationale for doing it the way I did is that it:

  • was a way I was able to figure out
  • kept the duplicated methods near each other

I figured keeping them near each other would make it less likely someone would only update the synchronous or asynchronous code. Not having two sets of code; however, would make it impossible to forget. It could also lead to less lines of code.

I think you are on to something. I just don't really know where to begin and have been pressed for time.

I think the downside to #7 is that it might be easy to forget to update methods in one or the other. The flip side is that it is probably unlikely the logic for the sensor would change much over time. It is likely going to be more about tracking changes to esp-hal and esp-hal-async. It would be easier to sort those changes with the implementations being separated as they are in #7.

I still would like to get some version of async into your code as I would prefer to abandon my fork and put a note in it pointing back to this original one. At the same time, the way I coded it seems sub optimal, and perhaps a bit hacky. It makes sense not to accept this pull request in light of that. #7 might be a good option instead, if you feel it is a better direction to go in.

Thanks and Happy Holidays / Happy New Year!

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.

4 participants