Merge branch 'dev' into main
This commit is contained in:
commit
a4300091d1
4 changed files with 1 additions and 17 deletions
|
@ -10,7 +10,6 @@ use alloc::vec::Vec;
|
||||||
use spin::Mutex;
|
use spin::Mutex;
|
||||||
use super::File;
|
use super::File;
|
||||||
use crate::mm::UserBuffer;
|
use crate::mm::UserBuffer;
|
||||||
use core::any::Any;
|
|
||||||
|
|
||||||
pub struct OSInode {
|
pub struct OSInode {
|
||||||
readable: bool,
|
readable: bool,
|
||||||
|
@ -157,5 +156,4 @@ impl File for OSInode {
|
||||||
}
|
}
|
||||||
total_write_size
|
total_write_size
|
||||||
}
|
}
|
||||||
fn as_any_ref(&self) -> &dyn Any { self }
|
|
||||||
}
|
}
|
|
@ -3,21 +3,12 @@ mod stdio;
|
||||||
mod inode;
|
mod inode;
|
||||||
|
|
||||||
use crate::mm::UserBuffer;
|
use crate::mm::UserBuffer;
|
||||||
use core::any::Any;
|
|
||||||
|
|
||||||
pub trait File : Any + Send + Sync {
|
pub trait File : Send + Sync {
|
||||||
fn readable(&self) -> bool;
|
fn readable(&self) -> bool;
|
||||||
fn writable(&self) -> bool;
|
fn writable(&self) -> bool;
|
||||||
fn read(&self, buf: UserBuffer) -> usize;
|
fn read(&self, buf: UserBuffer) -> usize;
|
||||||
fn write(&self, buf: UserBuffer) -> usize;
|
fn write(&self, buf: UserBuffer) -> usize;
|
||||||
fn as_any_ref(&self) -> &dyn Any;
|
|
||||||
}
|
|
||||||
|
|
||||||
impl dyn File {
|
|
||||||
#[allow(unused)]
|
|
||||||
pub fn downcast_ref<T: File>(&self) -> Option<&T> {
|
|
||||||
self.as_any_ref().downcast_ref::<T>()
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub use pipe::{Pipe, make_pipe};
|
pub use pipe::{Pipe, make_pipe};
|
||||||
|
|
|
@ -5,7 +5,6 @@ use crate::mm::{
|
||||||
UserBuffer,
|
UserBuffer,
|
||||||
};
|
};
|
||||||
use crate::task::suspend_current_and_run_next;
|
use crate::task::suspend_current_and_run_next;
|
||||||
use core::any::Any;
|
|
||||||
|
|
||||||
pub struct Pipe {
|
pub struct Pipe {
|
||||||
readable: bool,
|
readable: bool,
|
||||||
|
@ -165,5 +164,4 @@ impl File for Pipe {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fn as_any_ref(&self) -> &dyn Any { self }
|
|
||||||
}
|
}
|
|
@ -2,7 +2,6 @@ use super::File;
|
||||||
use crate::mm::{UserBuffer};
|
use crate::mm::{UserBuffer};
|
||||||
use crate::sbi::console_getchar;
|
use crate::sbi::console_getchar;
|
||||||
use crate::task::suspend_current_and_run_next;
|
use crate::task::suspend_current_and_run_next;
|
||||||
use core::any::Any;
|
|
||||||
|
|
||||||
pub struct Stdin;
|
pub struct Stdin;
|
||||||
|
|
||||||
|
@ -31,7 +30,6 @@ impl File for Stdin {
|
||||||
fn write(&self, _user_buf: UserBuffer) -> usize {
|
fn write(&self, _user_buf: UserBuffer) -> usize {
|
||||||
panic!("Cannot write to stdin!");
|
panic!("Cannot write to stdin!");
|
||||||
}
|
}
|
||||||
fn as_any_ref(&self) -> &dyn Any { self }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl File for Stdout {
|
impl File for Stdout {
|
||||||
|
@ -46,5 +44,4 @@ impl File for Stdout {
|
||||||
}
|
}
|
||||||
user_buf.len()
|
user_buf.len()
|
||||||
}
|
}
|
||||||
fn as_any_ref(&self) -> &dyn Any { self }
|
|
||||||
}
|
}
|
Loading…
Add table
Add a link
Reference in a new issue