src/client/pxar_backup_stream.rs: switch to async
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
This commit is contained in:
parent
2107bb40c1
commit
369a87e3a2
@ -1,12 +1,13 @@
|
|||||||
use failure::*;
|
use std::collections::HashSet;
|
||||||
use std::io::{Write, Seek};
|
use std::io::{Seek, Write};
|
||||||
use std::thread;
|
|
||||||
use std::sync::{Arc, Mutex};
|
|
||||||
use std::os::unix::io::FromRawFd;
|
use std::os::unix::io::FromRawFd;
|
||||||
use std::path::{Path, PathBuf};
|
use std::path::{Path, PathBuf};
|
||||||
use std::collections::HashSet;
|
use std::pin::Pin;
|
||||||
|
use std::sync::{Arc, Mutex};
|
||||||
|
use std::task::{Context, Poll};
|
||||||
|
use std::thread;
|
||||||
|
|
||||||
use futures::Poll;
|
use failure::*;
|
||||||
use futures::stream::Stream;
|
use futures::stream::Stream;
|
||||||
|
|
||||||
use nix::fcntl::OFlag;
|
use nix::fcntl::OFlag;
|
||||||
@ -38,6 +39,7 @@ impl Drop for PxarBackupStream {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl PxarBackupStream {
|
impl PxarBackupStream {
|
||||||
|
pin_utils::unsafe_pinned!(stream: Option<WrappedReaderStream<std::fs::File>>);
|
||||||
|
|
||||||
pub fn new<W: Write + Seek + Send + 'static>(
|
pub fn new<W: Write + Seek + Send + 'static>(
|
||||||
mut dir: Dir,
|
mut dir: Dir,
|
||||||
@ -93,16 +95,22 @@ impl PxarBackupStream {
|
|||||||
|
|
||||||
impl Stream for PxarBackupStream {
|
impl Stream for PxarBackupStream {
|
||||||
|
|
||||||
type Item = Vec<u8>;
|
type Item = Result<Vec<u8>, Error>;
|
||||||
type Error = Error;
|
|
||||||
|
|
||||||
fn poll(&mut self) -> Poll<Option<Vec<u8>>, Error> {
|
fn poll_next(mut self: Pin<&mut Self>, cx: &mut Context) -> Poll<Option<Self::Item>> {
|
||||||
{ // limit lock scope
|
{ // limit lock scope
|
||||||
let error = self.error.lock().unwrap();
|
let error = self.error.lock().unwrap();
|
||||||
if let Some(ref msg) = *error {
|
if let Some(ref msg) = *error {
|
||||||
return Err(format_err!("{}", msg));
|
return Poll::Ready(Some(Err(format_err!("{}", msg))));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
self.stream.as_mut().unwrap().poll().map_err(Error::from)
|
let res = self.as_mut()
|
||||||
|
.stream()
|
||||||
|
.as_pin_mut()
|
||||||
|
.unwrap()
|
||||||
|
.poll_next(cx);
|
||||||
|
Poll::Ready(futures::ready!(res)
|
||||||
|
.map(|v| v.map_err(Error::from))
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user