various stdio fixes
This commit is contained in:
@@ -44,7 +44,6 @@ impl WasiFile for Stdin {
|
|||||||
}
|
}
|
||||||
fn get_filestat(&self) -> Result<Filestat, Error> {
|
fn get_filestat(&self) -> Result<Filestat, Error> {
|
||||||
let meta = self.0.as_file_view().metadata()?;
|
let meta = self.0.as_file_view().metadata()?;
|
||||||
// XXX can unsafe-io give a way to get metadata?
|
|
||||||
Ok(Filestat {
|
Ok(Filestat {
|
||||||
device_id: 0,
|
device_id: 0,
|
||||||
inode: 0,
|
inode: 0,
|
||||||
@@ -57,8 +56,7 @@ impl WasiFile for Stdin {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
fn set_filestat_size(&self, _size: u64) -> Result<(), Error> {
|
fn set_filestat_size(&self, _size: u64) -> Result<(), Error> {
|
||||||
// XXX is this the right error?
|
Err(Error::Badf)
|
||||||
Err(Error::Perm)
|
|
||||||
}
|
}
|
||||||
fn advise(&self, _offset: u64, _len: u64, _advice: Advice) -> Result<(), Error> {
|
fn advise(&self, _offset: u64, _len: u64, _advice: Advice) -> Result<(), Error> {
|
||||||
Err(Error::Badf)
|
Err(Error::Badf)
|
||||||
@@ -124,7 +122,7 @@ macro_rules! wasi_file_write_impl {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
fn get_filetype(&self) -> Result<FileType, Error> {
|
fn get_filetype(&self) -> Result<FileType, Error> {
|
||||||
Ok(FileType::CharacterDevice) // XXX wrong
|
Ok(FileType::Unknown)
|
||||||
}
|
}
|
||||||
fn get_fdflags(&self) -> Result<FdFlags, Error> {
|
fn get_fdflags(&self) -> Result<FdFlags, Error> {
|
||||||
// XXX get_fdflags is not implemented but lets lie rather than panic:
|
// XXX get_fdflags is not implemented but lets lie rather than panic:
|
||||||
@@ -134,21 +132,20 @@ macro_rules! wasi_file_write_impl {
|
|||||||
Err(Error::Badf)
|
Err(Error::Badf)
|
||||||
}
|
}
|
||||||
fn get_filestat(&self) -> Result<Filestat, Error> {
|
fn get_filestat(&self) -> Result<Filestat, Error> {
|
||||||
// XXX can unsafe-io give a way to get metadata?
|
let meta = self.0.as_file_view().metadata()?;
|
||||||
Ok(Filestat {
|
Ok(Filestat {
|
||||||
device_id: 0,
|
device_id: 0,
|
||||||
inode: 0,
|
inode: 0,
|
||||||
filetype: self.get_filetype()?,
|
filetype: self.get_filetype()?,
|
||||||
nlink: 0,
|
nlink: 0,
|
||||||
size: 0,
|
size: meta.len(),
|
||||||
atim: None,
|
atim: meta.accessed().ok(),
|
||||||
mtim: None,
|
mtim: meta.modified().ok(),
|
||||||
ctim: None,
|
ctim: meta.created().ok(),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
fn set_filestat_size(&self, _size: u64) -> Result<(), Error> {
|
fn set_filestat_size(&self, _size: u64) -> Result<(), Error> {
|
||||||
// XXX is this the right error?
|
Err(Error::Badf)
|
||||||
Err(Error::Perm)
|
|
||||||
}
|
}
|
||||||
fn advise(&self, _offset: u64, _len: u64, _advice: Advice) -> Result<(), Error> {
|
fn advise(&self, _offset: u64, _len: u64, _advice: Advice) -> Result<(), Error> {
|
||||||
Err(Error::Badf)
|
Err(Error::Badf)
|
||||||
|
|||||||
Reference in New Issue
Block a user