forked from Orchid/orchid
redid the parser, patched up the project too.
This commit is contained in:
47
src/project/file_loader.rs
Normal file
47
src/project/file_loader.rs
Normal file
@@ -0,0 +1,47 @@
|
||||
use std::io;
|
||||
use std::rc::Rc;
|
||||
use std::fs::read_to_string;
|
||||
use std::path::PathBuf;
|
||||
|
||||
use super::loaded::Loaded;
|
||||
|
||||
#[derive(Clone, Debug)]
|
||||
pub enum LoadingError {
|
||||
IOErr(Rc<io::Error>),
|
||||
UnknownNode(String),
|
||||
Missing(String)
|
||||
}
|
||||
|
||||
impl From<io::Error> for LoadingError {
|
||||
fn from(inner: io::Error) -> Self {
|
||||
LoadingError::IOErr(Rc::new(inner))
|
||||
}
|
||||
}
|
||||
|
||||
pub fn file_loader(proj: PathBuf) -> impl FnMut(Vec<String>) -> Result<Loaded, LoadingError> + 'static {
|
||||
move |path| {
|
||||
let dirpath = proj.join(path.join("/"));
|
||||
if dirpath.is_dir() || dirpath.is_symlink() {
|
||||
return Ok(Loaded::Namespace(
|
||||
dirpath.read_dir()?
|
||||
.filter_map(|entr| {
|
||||
let ent = entr.ok()?;
|
||||
let typ = ent.file_type().ok()?;
|
||||
let path = ent.path();
|
||||
if typ.is_dir() || typ.is_symlink() {
|
||||
Some(ent.file_name().to_string_lossy().into_owned())
|
||||
} else if typ.is_file() && path.extension()? == "orc" {
|
||||
Some(path.file_stem()?.to_string_lossy().into_owned())
|
||||
} else { None }
|
||||
})
|
||||
.collect()
|
||||
))
|
||||
}
|
||||
let orcfile = dirpath.with_extension("orc");
|
||||
if orcfile.is_file() {
|
||||
read_to_string(orcfile).map(Loaded::Module).map_err(LoadingError::from)
|
||||
} else if dirpath.exists() {
|
||||
Err(LoadingError::UnknownNode(dirpath.to_string_lossy().into_owned()))
|
||||
} else { Err(LoadingError::Missing(dirpath.to_string_lossy().into_owned())) }
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user