diff options
-rw-r--r-- | src/channel.rs | 6 | ||||
-rw-r--r-- | tests/all/channel.rs | 7 |
2 files changed, 13 insertions, 0 deletions
diff --git a/src/channel.rs b/src/channel.rs index 1169a65..82ac981 100644 --- a/src/channel.rs +++ b/src/channel.rs @@ -14,6 +14,12 @@ struct ChannelInner { read_limit: Mutex<Option<u64>>, } +// ChannelInner is both Send and Sync; the compiler can't see it because it +// is pessimistic about the raw pointer. We use Arc/Mutex to guard accessing +// the raw pointer so we are safe for both. +unsafe impl Send for ChannelInner {} +unsafe impl Sync for ChannelInner {} + struct LockedChannel<'a> { raw: *mut raw::LIBSSH2_CHANNEL, sess: MutexGuard<'a, SessionInner>, diff --git a/tests/all/channel.rs b/tests/all/channel.rs index 8b624ac..2f14d01 100644 --- a/tests/all/channel.rs +++ b/tests/all/channel.rs @@ -24,6 +24,13 @@ fn consume_stdio(channel: &mut Channel) -> (String, String) { fn smoke() { let sess = ::authed_session(); let mut channel = sess.channel_session().unwrap(); + + fn must_be_send<T: Send>(_: &T) -> bool { + true + } + assert!(must_be_send(&channel)); + assert!(must_be_send(&channel.stream(0))); + channel.flush().unwrap(); channel.exec("true").unwrap(); consume_stdio(&mut channel); |