From 9f6c380f1c40a4eea97c4d67cb7c2920604e85e5 Mon Sep 17 00:00:00 2001 From: Cole Helbling Date: Tue, 17 Oct 2023 09:35:45 -0700 Subject: [PATCH] fh login: print manual instructions when writing to nix.conf fails --- src/cli/cmd/login/mod.rs | 31 ++++++++++++++++++++++++------- 1 file changed, 24 insertions(+), 7 deletions(-) diff --git a/src/cli/cmd/login/mod.rs b/src/cli/cmd/login/mod.rs index 273c6708..e6def215 100644 --- a/src/cli/cmd/login/mod.rs +++ b/src/cli/cmd/login/mod.rs @@ -93,20 +93,37 @@ impl LoginSubcommand { tokio::fs::write(netrc_path, &netrc_contents).await?; tokio::fs::write(token_path, token).await?; - if crate::cli::cmd::init::prompt::Prompt::bool(&format!( + let write_to_nix_conf = crate::cli::cmd::init::prompt::Prompt::bool(&format!( "May I add `{}` to {}?", nix_config_addition.trim(), nix_config_path.display() - )) { - let mut file = tokio::fs::OpenOptions::new() + )); + let write_success = if write_to_nix_conf { + match tokio::fs::OpenOptions::new() .create(true) .append(true) - .open(nix_config_path) - .await?; - file.write_all(nix_config_addition.as_bytes()).await?; + .open(&nix_config_path) + .await + { + Ok(mut file) => { + let write_status = file.write_all(nix_config_addition.as_bytes()).await; + write_status.is_ok() + } + Err(_) => false, + } } else { + false + }; + + if !write_to_nix_conf { + print!("No problem! "); + } + if !write_success { + print!("Writing to {} failed. ", nix_config_path.display()); + } + if !write_success || !write_to_nix_conf { println!( - "No problem! Please add the following contents to {}:\n{nix_config_addition}", + "Please add the following contents to {}:\n{nix_config_addition}", nix_config_path.display() ); println!(