-
Notifications
You must be signed in to change notification settings - Fork 185
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Make
armv6m-atomic-hack
less annoying (#1635)
Currently, the `armv6m-atomic-hack` crate is, to use a technical term, *annoying*. Its extension traits only exist when `#[cfg(armv6m)]` is set. This means that, in downstream crates that wish to _use_ `armv6m-atomic-hack` to support v6m targets, the extension traits may only be imported when `#[cfg(armv6m)]` is set. Because `RUSTFLAGS` cfgs don't propagate across dependency boundaries, this means that _each_ dependent of `armv6m-atomic-hack` must add a build script with a call to `build_utils::expose_m_profile()` so that the cfg is set properly when building for a v6m board. This is, as previously stated, annoying --- especially when using crates like `counters`, whose `#[derive(Count)]` attribute expands to a use of `AtomicU32Ext`, and thus requires any crate that derives `Count` to add a build script. This branch changes `armv6m-atomic-hack` so that the extension traits `AtomicU32Ext` and `AtomicBoolExt` are always defined, regardless of whether `#[cfg(armv6m)]` is set. Now, only the *implementation* of those traits differs based on the presence of the `armv6m` cfg --- if it is not set, an implementation is provided that simply forwards to the corresponding methods on the `AtomicU32` and `AtomicBool` types in libcore. This way, dependents of `armv6m-atomic-hack` can just import the extension traits without needing to add a build script with `expose_m_profile()`; now, only `armv6m-atomic-hack` itself needs the build script. Now, the `armv6m-atomic-hack` crate can no longer be considered annoying.
- Loading branch information
Showing
14 changed files
with
37 additions
and
46 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters