From efc547719531d90b32867dda47da506441178d6e Mon Sep 17 00:00:00 2001 From: Henrique Alves Date: Wed, 19 Apr 2023 09:56:27 -0300 Subject: Add inquire to add command --- src/commands.rs | 913 +++++++++++++++++++++++++++++--------------------------- 1 file changed, 465 insertions(+), 448 deletions(-) (limited to 'src/commands.rs') diff --git a/src/commands.rs b/src/commands.rs index a863705..a796762 100644 --- a/src/commands.rs +++ b/src/commands.rs @@ -1,529 +1,546 @@ -use std::path::{Path, PathBuf}; +use inquire::Text; +use serde::{Deserialize, Serialize}; use std::fs; use std::fs::write; +use std::path::{Path, PathBuf}; use std::process::exit; -use serde::{Serialize, Deserialize}; -#[path = "utils.rs"] mod utils; -#[path = "content.rs"] mod content; +#[path = "content.rs"] +mod content; +#[path = "utils.rs"] +mod utils; #[derive(Serialize, Deserialize)] struct GlamObject { - packages: Vec + packages: Vec, } #[derive(Clone, Debug, Serialize, Deserialize)] struct GlamPackage { - name : String, - git_repo : String, - #[serde(default = "default_string")] - commit : String, - #[serde(default = "default_string")] - target_folder : String, - #[serde(default = "default_string")] - source_folder : String, + name: String, + git_repo: String, + #[serde(default = "default_string")] + commit: String, + #[serde(default = "default_string")] + target_folder: String, + #[serde(default = "default_string")] + source_folder: String, } fn default_string() -> String { - return "".to_string(); + return "".to_string(); } -pub fn initialize(root : &str) { - let git_ignore = &format!("{}/.gitignore", &root); - if !Path::new(git_ignore).exists() { - match write(git_ignore, content::create_gitignore_file()) { - Ok(_v) => (), - Err(_e) => { - utils::log_error("There was a problem creating the .gitignore file!"); - exit(1); - } - } - } +pub fn initialize(root: &str) { + let git_ignore = &format!("{}/.gitignore", &root); + if !Path::new(git_ignore).exists() { + match write(git_ignore, content::create_gitignore_file()) { + Ok(_v) => (), + Err(_e) => { + utils::log_error("There was a problem creating the .gitignore file!"); + exit(1); + } + } + } } -pub fn initialize_glam_files(root : &str) { - // Create glam.d/ folder if it doesn't exist - if !Path::new(&format!("{}/.glam.d/", root)).exists() { - let res = utils::run_shell_command( - "mkdir -p .glam.d", - &root, - false - ); - - utils::assert_res(&res, "Couldn't create .glam.d/ folder!"); - - let gd_ignore = &format!("{}/.glam.d/.gdignore", &root); - if !Path::new(gd_ignore).exists() { - match write(gd_ignore, content::create_gdignore_file()) { - Ok(_v) => (), - Err(_e) => { - utils::log_error("There was a problem creating the .gdignore file!"); - exit(1); - } - } - } - - utils::log_info("Created .glam.d/ folder"); - } - - // Create .glam file if it doesn't exist - if !Path::new(&format!("{}/.glam", root)).exists() { - fs::write(&format!("{}/.glam",root), - content::create_glam_file()) - .expect("Couldn't create .glam file!"); - utils::log_info("Created .glam file"); - } +pub fn initialize_glam_files(root: &str) { + // Create glam.d/ folder if it doesn't exist + if !Path::new(&format!("{}/.glam.d/", root)).exists() { + let res = utils::run_shell_command("mkdir -p .glam.d", &root, false); + + utils::assert_result(&res, "Couldn't create .glam.d/ folder!"); + + let gd_ignore = &format!("{}/.glam.d/.gdignore", &root); + if !Path::new(gd_ignore).exists() { + match write(gd_ignore, content::create_gdignore_file()) { + Ok(_v) => (), + Err(_e) => { + utils::log_error("There was a problem creating the .gdignore file!"); + exit(1); + } + } + } + + utils::log_info("Created .glam.d/ folder"); + } + + // Create .glam file if it doesn't exist + if !Path::new(&format!("{}/.glam", root)).exists() { + fs::write(&format!("{}/.glam", root), content::create_glam_file()) + .expect("Couldn't create .glam file!"); + utils::log_info("Created .glam file"); + } } -pub fn check_initialization(root : &str) -> bool { - let git_ignore = &format!("{}/.gitignore", &root); - if !Path::new(git_ignore).exists() { - utils::log_warning(".gitignore file does not exist!"); - } - - let mut ret = true; - let glam_file = &format!("{}/.glam", &root); - if !Path::new(glam_file).exists() { - utils::log_error(".glam file does not exist!"); - ret = false; - } - - let glam_folder = &format!("{}/.glam.d/", &root); - if !Path::new(glam_folder).exists() { - utils::log_error(".glam.d/ folder does not exist!"); - ret = false; - } - return ret; +pub fn check_initialization(root: &str) -> bool { + let git_ignore = &format!("{}/.gitignore", &root); + if !Path::new(git_ignore).exists() { + utils::log_warning(".gitignore file does not exist!"); + } + + let mut ret = true; + let glam_file = &format!("{}/.glam", &root); + if !Path::new(glam_file).exists() { + utils::log_error(".glam file does not exist!"); + ret = false; + } + + let glam_folder = &format!("{}/.glam.d/", &root); + if !Path::new(glam_folder).exists() { + utils::log_error(".glam.d/ folder does not exist!"); + ret = false; + } + return ret; } -pub fn install_all_packages(root : &str, verbose : bool, copy_files : bool) { - let glam_file_path = format!("{}/.glam", root); +pub fn install_repositories(root: &str, verbose: bool, copy_files: bool) { + let glam_file_path = format!("{}/.glam", root); - // Find glam object or create one with default configuration - let mut glam_object = read_glam_file(&glam_file_path); - let mut glam_packages = glam_object.packages; + // Find glam object or create one with default configuration + let mut glam_object = read_glam_file(&glam_file_path); + let mut glam_packages = glam_object.packages; - for package in glam_packages.iter_mut() { - utils::log_info(&format!("Installing {}...", package.name)); - clone_or_fetch_package(root, package, verbose); - let commit = package.commit.to_string(); - install_glam_package(root, &commit, package, false, copy_files, verbose); - } + for package in glam_packages.iter_mut() { + utils::log_info(&format!("Installing {}...", package.name)); + clone_or_fetch_package(root, package, verbose); + let commit = package.commit.to_string(); + install_glam_package(root, &commit, package, false, copy_files, verbose); + } - // Write .glam file - glam_object.packages = glam_packages; - write_glam_file(&glam_file_path, &glam_object); + // Write .glam file + glam_object.packages = glam_packages; + write_glam_file(&glam_file_path, &glam_object); } -pub fn install_package(root : &str, git_repo : &str, commit : &str, copy_files : bool, verbose : bool) { - let glam_file_path = format!("{}/.glam", root); +pub fn add_repository(root: &str, git_repo: &str, verbose: bool) { + // Create glam object with default configuration + let glam_file_path = format!("{}/.glam", root); + let mut glam_object = read_glam_file(&glam_file_path); + let mut glam_packages = glam_object.packages; - // Find glam object or create one with default configuration - let mut glam_object = read_glam_file(&glam_file_path); - let mut glam_packages = glam_object.packages; - - let name = utils::get_repo_name(git_repo); + if find_package_by_repository(&glam_packages, &git_repo).is_some() { + utils::log_error("Repository already exists!"); + exit(1); + } - let mut package_index = find_package(&glam_packages, &name); - match package_index { - None => { - glam_packages.push(GlamPackage { - name, - git_repo : git_repo.to_string(), - commit: "".to_string(), - target_folder: "".to_string(), - source_folder: "".to_string() - }); + let default_name: String = utils::get_repo_name(git_repo); + let inquire_name = "Name of the repository:"; + let name = Text::new(inquire_name).with_default(&default_name).with_placeholder(&default_name).prompt().unwrap(); - package_index = Some(glam_packages.len() - 1); - } + if find_package_by_name(&glam_packages, &name).is_some() { + utils::log_error("Repository name exists!"); + exit(1); + } - _ => {} - } + let default_commit = "latest"; + let inquire_commit = "Commit hash of the repository:"; + let commit = Text::new(inquire_commit).with_default(&default_commit).with_placeholder(&default_commit).prompt().unwrap(); - let package_index = package_index.unwrap(); - let target_package = &mut glam_packages[package_index]; + glam_packages.push(GlamPackage { + name: name.to_string(), + git_repo: git_repo.to_string(), + commit: commit.to_string(), + target_folder: "".to_string(), + source_folder: "".to_string(), + }); - clone_or_fetch_package(root, target_package, verbose); + let target_package = glam_packages.last_mut().unwrap(); - // Update package folder to commit hash - install_glam_package(root, commit, target_package, false, copy_files, verbose); + clone_or_fetch_package(root, target_package, verbose); + install_glam_package(root, &commit, target_package, false, true, verbose); - // Write .glam file - glam_object.packages = glam_packages; - write_glam_file(&glam_file_path, &glam_object); + // Write .glam file + glam_object.packages = glam_packages; + write_glam_file(&glam_file_path, &glam_object); } -pub fn update_all_packages(root : &str, verbose : bool, copy_files : bool) { - let glam_file_path = format!("{}/.glam", root); +pub fn update_repositories(root: &str, verbose: bool, copy_files: bool) { + let glam_file_path = format!("{}/.glam", root); - // Find glam object or create one with default configuration - let mut glam_object = read_glam_file(&glam_file_path); - let mut glam_packages = glam_object.packages; + // Find glam object or create one with default configuration + let mut glam_object = read_glam_file(&glam_file_path); + let mut glam_packages = glam_object.packages; - for package in glam_packages.iter_mut() { - utils::log_info(&format!("Updating {}...", package.name)); - clone_or_fetch_package(root, package, verbose); - install_glam_package(root, "", package, true, copy_files, verbose); - } + for package in glam_packages.iter_mut() { + utils::log_info(&format!("Updating {}...", package.name)); + clone_or_fetch_package(root, package, verbose); + install_glam_package(root, "", package, true, copy_files, verbose); + } - glam_object.packages = glam_packages; - write_glam_file(&glam_file_path, &glam_object); + glam_object.packages = glam_packages; + write_glam_file(&glam_file_path, &glam_object); } -pub fn update_package(root : &str, package_name : &str, verbose : bool, copy_files : bool) { - let glam_file_path = format!("{}/.glam", root); +pub fn update_package(root: &str, package_name: &str, verbose: bool, copy_files: bool) { + let glam_file_path = format!("{}/.glam", root); - // Find package to update + // Find package to update - let mut glam_object = read_glam_file(&glam_file_path); - let mut glam_packages = glam_object.packages; + let mut glam_object = read_glam_file(&glam_file_path); + let mut glam_packages = glam_object.packages; - let package_index = find_package(&glam_packages, package_name); + let package_index = find_package_by_name(&glam_packages, package_name); - if package_index.is_none() { - utils::log_error("Package not found!"); - exit(1); - } + if package_index.is_none() { + utils::log_error("Package not found!"); + exit(1); + } - let package_index = package_index.unwrap(); - let target_package = &mut glam_packages[package_index]; + let package_index = package_index.unwrap(); + let target_package = &mut glam_packages[package_index]; - clone_or_fetch_package(root, target_package, verbose); - install_glam_package(root, "", target_package, true, copy_files, verbose); + clone_or_fetch_package(root, target_package, verbose); + install_glam_package(root, "", target_package, true, copy_files, verbose); - // Write .glam file - glam_object.packages = glam_packages; - write_glam_file(&glam_file_path, &glam_object); + // Write .glam file + glam_object.packages = glam_packages; + write_glam_file(&glam_file_path, &glam_object); } -pub fn remove_package(root : &str, package_name : &str, verbose : bool) { - let glam_file_path = format!("{}/.glam", root); - - // Find package to update - - let mut glam_object = read_glam_file(&glam_file_path); - let mut glam_packages = glam_object.packages; - - let package_index = find_package(&glam_packages, package_name); - - if package_index.is_none() { - utils::log_error("Package not found!"); - exit(1); - } - - let package_index = package_index.unwrap(); - let target_package = &mut glam_packages[package_index]; +// TODO: just "apply" don't apply changes to all repositories +pub fn apply_changes(root: &str, package_name: &str, create_from_addon: &str, verbose: bool) { + let glam_file_path = format!("{}/.glam", root); + + // Find package to update + + let mut glam_object = read_glam_file(&glam_file_path); + let mut glam_packages = glam_object.packages; + + let mut package_index = find_package_by_name(&glam_packages, package_name); + + if package_index.is_none() && create_from_addon == "" { + utils::log_error("Package not found!"); + exit(1); + } else if package_index.is_some() && create_from_addon != "" { + utils::log_error("Package already exists!"); + exit(1); + } else if create_from_addon != "" { + create_new_package_from_addon( + root, + &mut glam_packages, + package_name, + create_from_addon, + verbose, + ); + package_index = Some(glam_packages.len() - 1); + } + + let package_index = package_index.unwrap(); + let target_package = &mut glam_packages[package_index]; + + apply_glam_package_files(root, target_package, verbose); + + // Save changes + if create_from_addon != "" { + glam_object.packages = glam_packages; + write_glam_file(&glam_file_path, &glam_object); + } +} - remove_glam_package_files(root, target_package, verbose); +fn find_package_by_name(packages: &Vec, name: &str) -> Option { + let mut package_index = 0; + let mut found_package = false; - glam_packages.remove(package_index); + for (i, package) in packages.iter().enumerate() { + if package.name == name { + package_index = i; + found_package = true; + } + } - // Write .glam file - glam_object.packages = glam_packages; - write_glam_file(&glam_file_path, &glam_object); -} + if found_package { + return Some(package_index); + } -// TODO: just "apply" don't apply changes to all repositories -pub fn apply_changes(root : &str, package_name : &str, create_from_addon : &str, verbose : bool) { - let glam_file_path = format!("{}/.glam", root); - - // Find package to update - - let mut glam_object = read_glam_file(&glam_file_path); - let mut glam_packages = glam_object.packages; - - let mut package_index = find_package(&glam_packages, package_name); - - if package_index.is_none() && create_from_addon == "" { - utils::log_error("Package not found!"); - exit(1); - } - else if package_index.is_some() && create_from_addon != "" { - utils::log_error("Package already exists!"); - exit(1); - } - else if create_from_addon != "" { - create_new_package_from_addon(root, &mut glam_packages, package_name, create_from_addon, verbose); - package_index = Some(glam_packages.len()-1); - } - - let package_index = package_index.unwrap(); - let target_package = &mut glam_packages[package_index]; - - apply_glam_package_files(root, target_package, verbose); - - // Save changes - if create_from_addon != "" { - glam_object.packages = glam_packages; - write_glam_file(&glam_file_path, &glam_object); - } + return None; } -fn find_package(packages : &Vec, name : &str) -> Option { - let mut package_index = 0; - let mut found_package = false; +fn find_package_by_repository(packages: &Vec, repo: &str) -> Option { + let mut package_index = 0; + let mut found_package = false; - for (i, package) in packages.iter().enumerate() { - if package.name == name { - package_index = i; - found_package = true; - } - } + for (i, package) in packages.iter().enumerate() { + if package.git_repo == repo { + package_index = i; + found_package = true; + } + } - if found_package { - return Some(package_index); - } + if found_package { + return Some(package_index); + } - return None; + return None; } -fn install_glam_package(root : &str, commit : &str, package : &mut GlamPackage, update_package : bool, copy_files : bool, verbose : bool) { - // Update package folder to commit hash - if update_package { - package.commit = "".to_string(); - } - - if commit != "" { - package.commit = commit.to_string(); - } - - // TODO Get all folders on addon - let res = utils::run_shell_command( - &format!("ls .glam.d/{}/addons", package.name), - &root, - verbose); - - if res.is_err() { - utils::log_error("Couldn't get addon name."); - exit(1); - } - - let addon_folder = res.unwrap().trim().to_string(); - - if package.source_folder == "" { - package.source_folder = format!("addons/{}", addon_folder); - } - - if package.target_folder == "" { - package.target_folder = format!("addons/{}", addon_folder); - } - - if package.commit == "" { - let res = utils::run_shell_command( - &format!("cd .glam.d/{} && git rev-parse HEAD", - package.name), - &root, - verbose).unwrap(); - package.commit = res.trim().to_string(); - } else { - utils::log_info("Git checkout to package commit"); - let res = utils::run_shell_command( - &format!("cd .glam.d/{} && git reset --hard {}", - package.name, - package.commit), - &root, - verbose); - - utils::assert_res(&res, "Couldn't checkout repository!"); - } - - if copy_files { - // If project addon folder doesn't exist, create it - let res = utils::run_shell_command( - &format!("mkdir -p {}", package.target_folder), - &root, - verbose - ); - - utils::assert_res(&res, "Couldn't create addons folder!"); - // TODO: Why this is throwing Err("cp: -t: No such file or directory\n") on mac? - println!("cp -rf .glam.d/{}/{}/* -t {}", package.name, package.source_folder, package.target_folder); - - // Copy addon repository content to target folder - let res = utils::run_shell_command( - &format!("cp -rf .glam.d/{}/{}/* -t {}", package.name, package.source_folder, package.target_folder), - &root, - verbose - ); - - utils::assert_res(&res, "Couldn't copy files to addons!"); - } +fn install_glam_package( + root: &str, + commit: &str, + package: &mut GlamPackage, + update_package: bool, + copy_files: bool, + verbose: bool, +) { + // Update package folder to commit hash + if update_package { + package.commit = "latest".to_string(); + } + + if commit != "latest" { + package.commit = commit.to_string(); + } + + // TODO Get all folders on addon + let res = utils::run_shell_command( + &format!("ls .glam.d/{}/addons", package.name), + &root, + verbose, + ); + + if res.is_err() { + utils::log_error("Couldn't get addon name."); + exit(1); + } + + let addon_folder = res.unwrap().trim().to_string(); + + if package.source_folder == "" { + package.source_folder = format!("addons/{}", addon_folder); + } + + if package.target_folder == "" { + package.target_folder = format!("addons/{}", addon_folder); + } + + if package.commit == "latest" { + let res = utils::run_shell_command( + &format!("cd .glam.d/{} && git rev-parse HEAD", package.name), + &root, + verbose, + ) + .unwrap(); + package.commit = res.trim().to_string(); + } else { + utils::log_info("Git checkout to package commit"); + let res = utils::run_shell_command( + &format!( + "cd .glam.d/{} && git reset --hard {}", + package.name, package.commit + ), + &root, + verbose, + ); + + utils::assert_result(&res, "Couldn't checkout repository!"); + } + + if copy_files { + // If project addon folder doesn't exist, create it + let res = utils::run_shell_command( + &format!("mkdir -p {}", package.target_folder), + &root, + verbose, + ); + + utils::assert_result(&res, "Couldn't create addons folder!"); + // TODO: Why this is throwing Err("cp: -t: No such file or directory\n") on mac? + // println!( + // "cp -rf .glam.d/{}/{}/* -t {}", + // package.name, package.source_folder, package.target_folder + // ); + + // Copy addon repository content to target folder + let res = utils::run_shell_command( + &format!( + "cp -rf .glam.d/{}/{}/* -t {}", + package.name, package.source_folder, package.target_folder + ), + &root, + verbose, + ); + + utils::assert_result(&res, "Couldn't copy files to addons!"); + } } -fn create_new_package_from_addon(root : &str, packages : &mut Vec, package_name : &str, create_from_addon : &str, verbose : bool) { - if !Path::new(&format!("addons/{}", create_from_addon)).exists() { - utils::log_error("Addon folder doesn't exist!"); - exit(1); - } - - packages.push(GlamPackage { - name: package_name.to_string(), - git_repo : "".to_string(), - commit: "".to_string(), - target_folder: format!("addons/{}",create_from_addon), - source_folder: format!("addons/{}",create_from_addon), - }); - - let package = &packages[packages.len()-1]; - - let res = utils::run_shell_command( - &format!("mkdir -p .glam.d/{}/{}", package.name, package.source_folder), - &root, - false - ); - - utils::assert_res(&res, "Couldn't create source folder!"); - - let res = utils::run_shell_command( - &format!("git init .glam.d/{}", package.name), - &root, - false - ); - - utils::assert_res(&res, "Couldn't create new repository!"); - - let git_ignore_path = Path::new(root).join(&format!(".glam.d/{}/.gitignore", package.name)); - let git_ignore = git_ignore_path.to_str().unwrap(); - - match write(git_ignore, content::create_gitignore_file()) { - Ok(_v) => (), - Err(_e) => { - utils::log_error("There was a problem creating the .gitignore file!"); - exit(1); - } - } - - apply_glam_package_files(root, &packages[packages.len()-1], verbose); +fn create_new_package_from_addon( + root: &str, + packages: &mut Vec, + package_name: &str, + create_from_addon: &str, + verbose: bool, +) { + if !Path::new(&format!("addons/{}", create_from_addon)).exists() { + utils::log_error("Addon folder doesn't exist!"); + exit(1); + } + + packages.push(GlamPackage { + name: package_name.to_string(), + git_repo: "".to_string(), + commit: "".to_string(), + target_folder: format!("addons/{}", create_from_addon), + source_folder: format!("addons/{}", create_from_addon), + }); + + let package = &packages[packages.len() - 1]; + + let res = utils::run_shell_command( + &format!( + "mkdir -p .glam.d/{}/{}", + package.name, package.source_folder + ), + &root, + false, + ); + + utils::assert_result(&res, "Couldn't create source folder!"); + + let res = utils::run_shell_command(&format!("git init .glam.d/{}", package.name), &root, false); + + utils::assert_result(&res, "Couldn't create new repository!"); + + let git_ignore_path = Path::new(root).join(&format!(".glam.d/{}/.gitignore", package.name)); + let git_ignore = git_ignore_path.to_str().unwrap(); + + match write(git_ignore, content::create_gitignore_file()) { + Ok(_v) => (), + Err(_e) => { + utils::log_error("There was a problem creating the .gitignore file!"); + exit(1); + } + } + + apply_glam_package_files(root, &packages[packages.len() - 1], verbose); } -fn apply_glam_package_files(root : &str, package : &GlamPackage, verbose : bool) { - - // Overwrite source folder with target folder - let res = utils::run_shell_command( - &format!("for f in $(ls .glam.d/{}/{}); do rm -rf .glam.d/{}/{}/$f; done", - package.name, - package.source_folder, - package.name, - package.source_folder), - &root, - verbose - ); - - utils::assert_res(&res, "Couldn't remove source folder files!"); - - // Copy addon repository content to target folder - let res = utils::run_shell_command( - &format!("for f in $(ls ./{}); do cp -rf ./{}/$f ./.glam.d/{}/{}/$f; done", - package.target_folder, - package.target_folder, - package.name, - package.source_folder), - &root, - verbose - ); - - utils::assert_res(&res, "Couldn't copy files to repository!"); +fn apply_glam_package_files(root: &str, package: &GlamPackage, verbose: bool) { + // Overwrite source folder with target folder + let res = utils::run_shell_command( + &format!( + "for f in $(ls .glam.d/{}/{}); do rm -rf .glam.d/{}/{}/$f; done", + package.name, package.source_folder, package.name, package.source_folder + ), + &root, + verbose, + ); + + utils::assert_result(&res, "Couldn't remove source folder files!"); + + // Copy addon repository content to target folder + let res = utils::run_shell_command( + &format!( + "for f in $(ls ./{}); do cp -rf ./{}/$f ./.glam.d/{}/{}/$f; done", + package.target_folder, package.target_folder, package.name, package.source_folder + ), + &root, + verbose, + ); + + utils::assert_result(&res, "Couldn't copy files to repository!"); } -fn remove_glam_package_files(root : &str, package : &GlamPackage, verbose : bool) { - // Copy addon repository content to target folder - let res = utils::run_shell_command( - &format!("rm -rf {}", package.target_folder), - &root, - verbose - ); +fn remove_glam_package_files(root: &str, package: &GlamPackage, verbose: bool) { + // Copy addon repository content to target folder + let res = + utils::run_shell_command(&format!("rm -rf {}", package.target_folder), &root, verbose); - utils::assert_res(&res, "Couldn't remove files from root addons!"); + utils::assert_result(&res, "Couldn't remove files from root addons!"); - let res = utils::run_shell_command( - &format!("rm -rf ./.glam.d/{}", package.name), - &root, - verbose - ); + let res = utils::run_shell_command( + &format!("rm -rf ./.glam.d/{}", package.name), + &root, + verbose, + ); - utils::assert_res(&res, "Couldn't copy files to addons!"); + utils::assert_result(&res, "Couldn't copy files to addons!"); } -fn clone_or_fetch_package(root : &str, package : &mut GlamPackage, verbose : bool) { - // If glam package folder doesn't exist, clone project - if !Path::new(&format!("{}/.glam.d/{}", root, package.name)).exists() { - let res = utils::run_shell_command( - &format!("cd .glam.d/ && git clone {} {} --progress", package.git_repo, package.name), - &root, - verbose - ); - - utils::assert_res(&res, "Couldn't clone repository!"); - - utils::log_check("Created package folder on .glam.d"); - } else { - if package.git_repo == "" { - let res = utils::run_shell_command( - &format!("cd .glam.d/{} && git remote get-url origin", - package.name), - &root, - verbose); - - if res.is_err() { - utils::log_error("GLAM Package has no origin yet!"); - exit(1); - } - - package.git_repo = res.unwrap().trim().to_string(); - } - - let res = utils::run_shell_command( - &format!("cd .glam.d/{} && git fetch origin && git pull", package.name), - &root, - verbose - ); - utils::assert_res(&res, "Couldn't fetch package repository updates!"); - - utils::log_info("Glam package folder already exists, fetched and pulled latest changes"); - } +fn clone_or_fetch_package(root: &str, package: &mut GlamPackage, verbose: bool) { + // If glam package folder doesn't exist, clone project + if !Path::new(&format!("{}/.glam.d/{}", root, package.name)).exists() { + let res = utils::run_shell_command( + &format!( + "cd .glam.d/ && git clone {} {} --progress", + package.git_repo, package.name + ), + &root, + verbose, + ); + + utils::assert_result(&res, "Couldn't clone repository!"); + + utils::log_check("Created package folder on .glam.d"); + } else { + if package.git_repo == "" { + let res = utils::run_shell_command( + &format!("cd .glam.d/{} && git remote get-url origin", package.name), + &root, + verbose, + ); + + if res.is_err() { + utils::log_error("GLAM Package has no origin yet!"); + exit(1); + } + + package.git_repo = res.unwrap().trim().to_string(); + } + + let res = utils::run_shell_command( + &format!( + "cd .glam.d/{} && git fetch origin && git pull", + package.name + ), + &root, + verbose, + ); + utils::assert_result(&res, "Couldn't fetch package repository updates!"); + + utils::log_info("Glam package folder already exists, fetched and pulled latest changes"); + } } -fn read_glam_file(file_path : &str) -> GlamObject { - if !Path::new(file_path).exists() { - fs::write(file_path, content::create_glam_file()).expect("Couldn't create .glam file!"); - } +fn read_glam_file(file_path: &str) -> GlamObject { + if !Path::new(file_path).exists() { + fs::write(file_path, content::create_glam_file()).expect("Couldn't create .glam file!"); + } - let glam_content = fs::read_to_string(file_path).expect("Couldn't read .glam file!"); - let glam_obj : GlamObject = serde_json::from_str(&glam_content).unwrap(); + let glam_content = fs::read_to_string(file_path).expect("Couldn't read .glam file!"); + let glam_obj: GlamObject = serde_json::from_str(&glam_content).unwrap(); - return glam_obj; + return glam_obj; } -fn write_glam_file(file_path : &str, glam_object : &GlamObject) { - let json_string = serde_json::to_string_pretty(glam_object).unwrap(); - fs::write(file_path, json_string).expect("Couldn't create .glam file!"); +fn write_glam_file(file_path: &str, glam_object: &GlamObject) { + let json_string = serde_json::to_string_pretty(glam_object).unwrap(); + fs::write(file_path, json_string).expect("Couldn't create .glam file!"); } -pub fn search_project_root() -> String{ - let path = PathBuf::from("./"); - let mut dir = path.canonicalize().unwrap(); - - loop { - let dir_path = dir.to_str().unwrap(); - let proj_path = format!("{}/project.godot", dir_path); - - let godot_project = Path::new(&proj_path); - - if godot_project.exists() { - break; - } - else { - let parent = dir.parent(); - if parent.is_none() { - utils::log_error("Godot project not found!"); - exit(1); - } - dir = dir.parent().unwrap().to_path_buf(); - } - } - - let root = dir.to_str().unwrap().to_string(); - utils::log_check(&format!("Found root project in: {}", root)); - return root; -} +pub fn search_project_root() -> String { + let path = PathBuf::from("./"); + let mut dir = path.canonicalize().unwrap(); + + loop { + let dir_path = dir.to_str().unwrap(); + let proj_path = format!("{}/project.godot", dir_path); + + let godot_project = Path::new(&proj_path); + + if godot_project.exists() { + break; + } else { + let parent = dir.parent(); + if parent.is_none() { + utils::log_error("Godot project not found!"); + exit(1); + } + dir = dir.parent().unwrap().to_path_buf(); + } + } + + let root = dir.to_str().unwrap().to_string(); + utils::log_check(&format!("Found root project in: {}", root)); + return root; +} \ No newline at end of file -- cgit v1.2.3