-
Notifications
You must be signed in to change notification settings - Fork 220
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
Roadmap for traits removed on 1.0.0 release #357
Comments
To both verify my understanding and hopefully augment the discussion, here are some alternatives we'd have to fully removing them:
Granted, pruning the hard cases is the safest of these, but I'd like to ensure we have thoroughly ruled out the alternatives. |
If we decide to use |
These are no alternatives to remove them, but rather proposals to add them back later. It is pretty clear from the current situation, that the best design is not clear yet. And to no unnecessarily delay a v1.0.0 release, it is better to just remove them for now. But temporary of course, until all agree on a solution. |
I do think that leaving them unconstrained is an option even for now. Comparing the two developments under the assumption that we'll find some trait TAT later that we can constrain the associated type to: a) We remove them now.
b) We leave them unconstarined now.
Eventually, we still get a very similar ecosystem. The upside of option a is that it doesn't need the additional I'm not saying that option b is the ultimately better, but I do prefer it over option a. |
What you are describing in b) is already the situation we have, but it's not really that clear what's the best
If we, assuming "we" is the e-h wg, is recommending the best associated type, but never constrains the type itself, because that is not possible without it being a breaking change, what should be prevented to a) not delay unnecessarily And anything which is not a guarantee for the driver implementation is rather useless. What should a |
What about keeping these traits around, but marking them as deprecated with a link to an issue documenting the context of its deprecation and planned re-introduction? If it's deprecated in v1.0.0, should that still allow it's removal in, say, v1.1.0, without breaking semver? |
No, removing public API is always a breaking change, regardless of whether it was marked as deprecated or not. |
I had a look at the semver documentation, something I really should have done first, sorry. I initially read your response wrong (read it as something like "removal by means of deprecation" rather than "removal of an api-function, whether or not it's ever been marked as deprecated". That's on me), and thought "that couldn't be right", and spent a stupid amount of time going down the rabbit hole, writing a response, before realising my mistake in interpretation... ...but I learned a few things along the way :) Though this is still a v0 crate in its current state, so the normal rules won't apply until 1.0.0, the semver spec is still a valuable guide in the meantime, IMHO. In the FAQ, it makes the recommendation:
(1) is satisfied in How about a 0.3.0 release with the items deprecated, and a note that it's a pre-release deprecation for v1.0.0? Obviously not needed, even if the semver rules are being strictly followed. It does, however, keep with the spirit and intent of the specification. One idea that comes to mind, which I hope isn't as stupid as a fear it might be: Do a deprecation release (0.3.0) now(-ish), and then immediately before releasing 1.0.0, release a 0.4.0 which is essentially the same as 1.0.0, but without completely removing the deprecated items (where they don't conflict too heavily). I'm happy to put in the time to make the 0.3.0 happen, and if the 0.4.0 idea isn't so stupid, I'm happy to help with that as well. |
I do not think publishing a 0.3.0 or 0.4.0 version would help anybody since |
All traits with unconstrained associated types have been removed as we prepare the 1.0.0 release. We are aware that this will be problematic in the short term but agreed it is the best way forward for
embedded-hal
(see the reasoning below).This includes these traits, which are available on the
0.2.x
versions:-
adc::OneShot
-
adc::Channel
-
capture::Capture
-
digital::IoPin
-
pwm::Pwm
-
pwm::PwmPin
-
qei::Qei
-
serial::Read
->embedded-io
-
serial::Write
->embedded-io
-
timer::Cancel
-
timer::CountDown
-
timer::Periodic
-
watchdog::Disable
-
watchdog::Enable
-
watchdog::Watchdog
Why
Traits defined in
embedded-hal
pursue creating an interface for interoperability between generic code (be it generic user code, generic application code, generic device drivers, etc.).When a trait has an unconstrained associated type, it is not possible to write generic code around it. Each side (implementer and user) need to specify which type the associated type will be. If the types match, the both parts can work together, however, this is not truly generic code.
For example, if somebody creates a device driver that receives a
CountDown
struct, it needs to specify what itsTime
type should be. If they choose a type coming fromfugit
, somebody else cannot use this driver if the HAL implementation for the MCU they are using only providesCountDown
withTime
types defined inembedded-time
. It is also not possible for the user to implementCountDown
forTime
types defined byfugit
in a straight-forward way due to the orphan rule.In summary, it is not possible for anybody to start a countdown for a certain duration in a generic way, without it being tied to a particular time implementation and thus forcing everybody to use that one.
In the case of the
digital::IoPin
trait, some problems about it usage have been surfaced (#340) that have moved us to remove it for the 1.0.0 release as well.We want to avoid the need for a semver-incompatible
embedded-hal
release (i.e. 2.0) for as long as possible. As such, the best compromise is to remove the traits before the release and add at least some of them back later.The way forward
As stated above, we have removed these traits ahead of the 1.0.0 release but plan to add at least some of them back in a future semver-compatible release like 1.1.x, once we find suitable bounds for the associated types.
Some problems on these traits have been highlighted as well (see open issues), so removing them also gives us the chance to rethink them.
How to get them back
The most pressing issue is finding suitable bounds for time/duration types which make these traits usable in pretty much any situation.
See: #211, #122, #59, #24.
Please have a look at the issues for each of the removed traits/modules for further details.
What to do in the mean time
HALs that implement these traits, have at least the following options:
Generic code can do their version of these options as well for now.
Issues specific to the removed traits/modules
The text was updated successfully, but these errors were encountered: