diff options
author | metamuffin <metamuffin@disroot.org> | 2023-05-16 19:12:10 +0200 |
---|---|---|
committer | metamuffin <metamuffin@disroot.org> | 2023-05-16 19:12:10 +0200 |
commit | 1f6108199dbe307c1dc84f70cc3df6b096467eff (patch) | |
tree | 2dab97df18d5f8bbb2971bed55b1754fab9d7d02 /server | |
parent | 7a64fd8111d348bd7df5dfb4de69b58090135ce0 (diff) | |
download | jellything-1f6108199dbe307c1dc84f70cc3df6b096467eff.tar jellything-1f6108199dbe307c1dc84f70cc3df6b096467eff.tar.bz2 jellything-1f6108199dbe307c1dc84f70cc3df6b096467eff.tar.zst |
use fiile extension for item defs
Diffstat (limited to 'server')
-rw-r--r-- | server/src/library.rs | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/server/src/library.rs b/server/src/library.rs index ea8b095..6e6e13d 100644 --- a/server/src/library.rs +++ b/server/src/library.rs @@ -7,7 +7,9 @@ use anyhow::{anyhow, bail, Context, Ok}; use jellycommon::{DirectoryInfo, ItemInfo}; use log::info; use std::{ + ffi::OsStr, fs::File, + os::unix::prelude::OsStrExt, path::{Path, PathBuf}, sync::Arc, }; @@ -107,12 +109,14 @@ impl Node { lib_path = lib_path.join(identifier.clone()); } + info!("scanning directory {:?}", path); let children = path .read_dir()? .filter_map(|e| { let e = e.unwrap(); - if (e.path().extension().is_none() || e.metadata().unwrap().is_dir()) - && !e.path().ends_with("directory.json") + eprintln!("{:?}", e.path()); + if e.path().extension() == Some(&OsStr::from_bytes(b"jelly")) + || e.metadata().unwrap().is_dir() { Some(e.path()) } else { @@ -140,11 +144,12 @@ impl Node { let datafile = File::open(path.clone()).context("cant load metadata")?; let data: ItemInfo = serde_json::from_reader(datafile).context("invalid metadata")?; let identifier = path - .with_extension("") .file_name() .unwrap() .to_str() .unwrap() + .strip_suffix(".jelly") + .unwrap() .to_string(); Ok(Some( Node::Item(Arc::new(Item { |