aboutsummaryrefslogtreecommitdiff
path: root/src/activate.rs
diff options
context:
space:
mode:
authorAndreas Fuchs2020-12-13 23:29:21 -0500
committernotgne22020-12-15 13:00:01 -0700
commit7d4020f1300f076341627785c53dd151fc7d1a61 (patch)
treeecf214479e1b3afa159fa0e07a94a9923dc1038c /src/activate.rs
parent4ed33219a94943177296ff99368d9ee1dbbcf275 (diff)
Simplify the types involved a little
The cursed match is still cursed, but at least we're not sending useless data across channels anymore.
Diffstat (limited to 'src/activate.rs')
-rw-r--r--src/activate.rs8
1 files changed, 4 insertions, 4 deletions
diff --git a/src/activate.rs b/src/activate.rs
index 00b637d..84d4b12 100644
--- a/src/activate.rs
+++ b/src/activate.rs
@@ -161,7 +161,7 @@ pub enum ActivationConfirmationError {
CreateWatcherError(notify::Error),
#[error("Error forking process: {0}")]
ForkError(i32),
- #[error("Could not watch for activation sentinel")]
+ #[error("Could not watch for activation sentinel: {0}")]
WatcherError(#[from] notify::Error),
}
@@ -176,13 +176,13 @@ pub enum DangerZoneError {
}
async fn danger_zone(
- mut events: mpsc::Receiver<Result<notify::event::Event, notify::Error>>,
+ mut events: mpsc::Receiver<Result<(), notify::Error>>,
confirm_timeout: u16,
) -> Result<(), DangerZoneError> {
info!("Waiting for confirmation event...");
match timeout(Duration::from_secs(confirm_timeout as u64), events.recv()).await {
- Ok(Some(Ok(_))) => Ok(()),
+ Ok(Some(Ok(()))) => Ok(()),
Ok(Some(Err(e))) => Err(DangerZoneError::WatchError(e)),
Ok(None) => Err(DangerZoneError::NoConfirmation),
Err(_) => Err(DangerZoneError::TimesUp),
@@ -213,7 +213,7 @@ pub async fn activation_confirmation(
Watcher::new_immediate(move |res: Result<notify::event::Event, notify::Error>| {
let send_result = match res {
Ok(e) if e.kind == notify::EventKind::Remove(notify::event::RemoveKind::File) => {
- deleted.blocking_send(Ok(e))
+ deleted.blocking_send(Ok(()))
}
Ok(_) => Ok(()), // ignore non-removal events
Err(e) => deleted.blocking_send(Err(e)),