diff options
author | Benedikt Peetz <benedikt.peetz@b-peetz.de> | 2024-05-05 14:02:09 +0200 |
---|---|---|
committer | Benedikt Peetz <benedikt.peetz@b-peetz.de> | 2024-05-05 14:02:09 +0200 |
commit | 47e3b82d0f8c9c4abcaf8588764fa934446dbdc8 (patch) | |
tree | 807f4874f1b945b82c00ec5cd666b4173bd09aab /sys/nixpkgs/pkgs/lf-make-map/src/generator | |
parent | feat(pkgs/lf-make-map): Init (diff) | |
download | nixos-config-47e3b82d0f8c9c4abcaf8588764fa934446dbdc8.tar.gz nixos-config-47e3b82d0f8c9c4abcaf8588764fa934446dbdc8.zip |
feat(pkgs/lf-make-map): Change the key to custom type and add visuals
Diffstat (limited to 'sys/nixpkgs/pkgs/lf-make-map/src/generator')
-rw-r--r-- | sys/nixpkgs/pkgs/lf-make-map/src/generator/mod.rs | 16 | ||||
-rw-r--r-- | sys/nixpkgs/pkgs/lf-make-map/src/generator/mod.rs.old | 165 |
2 files changed, 11 insertions, 170 deletions
diff --git a/sys/nixpkgs/pkgs/lf-make-map/src/generator/mod.rs b/sys/nixpkgs/pkgs/lf-make-map/src/generator/mod.rs index 48df027f..c03b33dc 100644 --- a/sys/nixpkgs/pkgs/lf-make-map/src/generator/mod.rs +++ b/sys/nixpkgs/pkgs/lf-make-map/src/generator/mod.rs @@ -1,10 +1,10 @@ use std::path::PathBuf; use anyhow::{Context, Result}; -use log::{debug, info, trace}; +use log::trace; use walkdir::{DirEntry, WalkDir}; -use crate::mapping::{map_tree::MappingTree, Mapping}; +use crate::mapping::{map_tree::MappingTree, MapKey, Mapping}; pub struct MappingsGenerator { mappings: MappingTree, @@ -35,9 +35,15 @@ impl MappingsGenerator { trace!("Processed '{}'..", directory.path().display()); let mapping = Mapping::new(&home_path, directory.path().to_path_buf()); - mappings - .insert(&mapping.key.clone(), mapping) - .context("Failed to insert a key")?; + let mapping_key = mapping.key.clone(); + mappings.insert(&mapping_key, mapping).with_context(|| { + format!( + "Failed to insert '{}' for path: '{}'\nMapTree is now: \n{}", + MapKey::display(&mapping_key), + directory.path().display(), + mappings, + ) + })?; } } todo!() diff --git a/sys/nixpkgs/pkgs/lf-make-map/src/generator/mod.rs.old b/sys/nixpkgs/pkgs/lf-make-map/src/generator/mod.rs.old deleted file mode 100644 index 406b1996..00000000 --- a/sys/nixpkgs/pkgs/lf-make-map/src/generator/mod.rs.old +++ /dev/null @@ -1,165 +0,0 @@ -use std::{ - collections::HashMap, - path::{Path, PathBuf}, -}; - -use anyhow::{bail, Context, Result}; -use futures::{Stream, StreamExt, TryStreamExt}; -use log::info; -use tokio::{ - fs::{self, DirEntry}, - io, - sync::mpsc::{self, Receiver, Sender}, - task::JoinHandle, -}; -use tokio_stream::wrappers::{ReadDirStream, ReceiverStream}; - -pub struct MappingGenerator { - current_mappings: HashMap<String, PathBuf>, - paths_to_process: Vec<PathBuf>, -} - -pub struct MappingGeneratorHelper { - tx: Sender<(PathBuf, oneshotSender<PathBuf>)>, - handle: JoinHandle<()>, - done: Vec<PathBuf>, -} - -impl MappingGeneratorHelper { - pub fn new() -> Self { - let (rx, tx) = mpsc::channel(100); - - let handle = tokio::spawn(async move { - while let Some(dir) = rx.recv().await { - info!("processing '{}'..", dir.display()); - get_dir(dir); - } - }); - - Self { tx, handle } - } - - pub async fn process(&self, dir: PathBuf) -> Result<()> { - let (tx, rx) = - self.tx.send(dir).await?; - Ok(()) - } -} - -impl MappingGenerator { - pub async fn new(directories_to_scan: Vec<PathBuf>, depth: usize) -> Result<Self> { - let cleaned_directories: Vec<PathBuf> = directories_to_scan - .into_iter() - .map(check_dir) - .collect::<Result<_>>()?; - - let helper = MappingGeneratorHelper::new(); - - cleaned_directories - .into_iter() - .for_each(|dir| helper.process(dir)); - - info!( - "Will process:\n {}", - all_directories - .iter() - .map(|pat| pat.display().to_string()) - .collect::<Vec<_>>() - .join("\n ") - ); - Ok(Self { - current_mappings: HashMap::new(), - paths_to_process: all_directories, - }) - } -} - -fn check_dir(dir: PathBuf) -> Result<PathBuf> { - match dir.metadata() { - Ok(_) => Ok(dir), - Err(e) => bail!( - "'{}' is not a valid path; Error was: '{}'", - dir.display(), - e - ), - } -} - -pub async fn get_dir(dir: PathBuf, current_depth: usize, max_depth: usize) -> Result<Vec<PathBuf>> { - let (tx, rx) = mpsc::channel(100); - - let handle = tokio::spawn(async move { get_dir_recursive(dir, current_depth, max_depth, tx) }); - - let out = ReceiverStream::new(rx).collect::<Vec<PathBuf>>().await; - handle.await?; - Ok(out) -} - -async fn get_dir_recursive( - dir: PathBuf, - current_depth: usize, - max_depth: usize, - tx: Sender<PathBuf>, -) -> Result<()> { - if dir.is_dir() && current_depth != max_depth { - tx.send(dir).await?; - - match fs::read_dir(&dir).await { - Ok(directories) => { - let mut handles: Vec<JoinHandle<Result<(), anyhow::Error>>> = vec![]; - while let Some(entry) = directories - .next_entry() - .await - .with_context(|| format!("Failed to read directory: '{}'", dir.display()))? - { - let tx_new = tx.clone(); - handles.push(tokio::spawn(async move { - get_dir_recursive(entry.path(), current_depth + 1, max_depth, tx_new) - .await - .with_context(|| { - format!("Failed to get child directories to '{}'", dir.display()) - })?; - - Ok(()) - })); - } - - let out: Vec<_> = tokio_stream::iter(handles) - .then(|handle| async move { handle.await }) - .collect() - .await; - - // I have no idea what happened here to the type system - for i in out { - i?? - } - - Ok(()) - } - - Err(e) => { - bail!( - "Unable to read directory {}, skipping; error: {}", - dir.display(), - e - ); - } - } - } else { - return Ok(()); - } -} - -#[cfg(test)] -mod test { - use std::path::PathBuf; - - use super::get_dir; - - #[test] - fn test_get_dir() { - let dirs = get_dir(PathBuf::from("~/repos")); - let expected_dirs = vec![PathBuf::from("~/repos/rust")]; - assert_eq!(dirs, expected_dirs); - } -} |