Skip to content

Commit

Permalink
feat: Mark StackSlot as Sync
Browse files Browse the repository at this point in the history
Since it has no interior mutability it should be safe to share between
threads.

Signed-off-by: John Nunley <dev@notgull.net>
  • Loading branch information
notgull authored Feb 26, 2024
1 parent 3a49a00 commit c9d736a
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 2 deletions.
10 changes: 9 additions & 1 deletion src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@
//!
//! [`portable-atomic`]: https://crates.io/crates/portable-atomic
#![cfg_attr(all(not(feature = "std"), not(test)), no_std)]
#![cfg_attr(not(feature = "std"), no_std)]
#![warn(missing_docs, missing_debug_implementations, rust_2018_idioms)]
#![doc(
html_favicon_url = "https://raw.githubusercontent.com/smol-rs/smol/master/assets/images/logo_fullsize_transparent.png"
Expand All @@ -76,14 +76,18 @@
html_logo_url = "https://raw.githubusercontent.com/smol-rs/smol/master/assets/images/logo_fullsize_transparent.png"
)]

#[cfg(not(feature = "std"))]
extern crate alloc;
#[cfg(feature = "std")]
extern crate std as alloc;

#[cfg_attr(feature = "std", path = "std.rs")]
#[cfg_attr(not(feature = "std"), path = "no_std.rs")]
mod sys;

mod notify;

#[cfg(not(feature = "std"))]
use alloc::boxed::Box;

use core::borrow::Borrow;
Expand Down Expand Up @@ -1365,6 +1369,9 @@ fn __test_send_and_sync() {
fn _assert_sync<T: Sync>() {}

_assert_send::<crate::__private::StackSlot<'_, ()>>();
_assert_sync::<crate::__private::StackSlot<'_, ()>>();
_assert_send::<crate::__private::StackListener<'_, '_, ()>>();
_assert_sync::<crate::__private::StackListener<'_, '_, ()>>();
_assert_send::<Event<()>>();
_assert_sync::<Event<()>>();
_assert_send::<EventListener<()>>();
Expand Down Expand Up @@ -1410,6 +1417,7 @@ pub mod __private {
impl<T> core::panic::UnwindSafe for StackSlot<'_, T> {}
impl<T> core::panic::RefUnwindSafe for StackSlot<'_, T> {}
unsafe impl<T> Send for StackSlot<'_, T> {}
unsafe impl<T> Sync for StackSlot<'_, T> {}

impl<'ev, T> StackSlot<'ev, T> {
/// Create a new `StackSlot` on the stack.
Expand Down
1 change: 0 additions & 1 deletion src/no_std.rs
Original file line number Diff line number Diff line change
Expand Up @@ -832,7 +832,6 @@ unsafe impl<T: Send> Sync for Mutex<T> {}
#[cfg(test)]
mod tests {
use super::*;
use crate::Task;

#[cfg(target_family = "wasm")]
use wasm_bindgen_test::wasm_bindgen_test as test;
Expand Down

0 comments on commit c9d736a

Please sign in to comment.