]> git.r.bdr.sh - rbdr/page/blobdiff - src/file_handler/file_strategies/file.rs
Remove clang from page
[rbdr/page] / src / file_handler / file_strategies / file.rs
index b1de596f110e70060b89517f09a8969714b1d341..2346128494c796e79efe3501a1bda02e3758f832 100644 (file)
@@ -1,9 +1,20 @@
 pub struct Strategy {}
 
 use std::path::PathBuf;
 pub struct Strategy {}
 
 use std::path::PathBuf;
+use std::fs::{copy, create_dir_all};
 
 use crate::file_handler::{File, FileType, FileHandlerStrategy};
 
 
 use crate::file_handler::{File, FileType, FileHandlerStrategy};
 
+impl Strategy {
+    fn handle(&self, source: &PathBuf, destination: &PathBuf, file: &File) {
+        let relative_path = file.path.strip_prefix(&source).unwrap();
+        let complete_destination = destination.join(relative_path);
+        let destination_parent = complete_destination.parent().unwrap();
+        create_dir_all(destination_parent).unwrap();
+        copy(&file.path, &complete_destination).unwrap();
+    }
+}
+
 impl FileHandlerStrategy for Strategy {
     fn is(&self, path: &PathBuf) -> bool {
         !path.is_dir()
 impl FileHandlerStrategy for Strategy {
     fn is(&self, path: &PathBuf) -> bool {
         !path.is_dir()
@@ -20,7 +31,11 @@ impl FileHandlerStrategy for Strategy {
         }
     }
 
         }
     }
 
-    fn handle(&self, file: &File) {
-        println!("Should copy {}", file.path.display())
+    fn handle_html(&self, source: &PathBuf, destination: &PathBuf, file: &File, _l: &String) {
+        return self.handle(source, destination, file);
+    }
+
+    fn handle_gemini(&self, source: &PathBuf, destination: &PathBuf, file: &File) {
+        return self.handle(source, destination, file);
     }
 }
     }
 }