From de0c252e27e4f3cb63bb30925d1dd8f48ca1d5d3 Mon Sep 17 00:00:00 2001 From: Sam Hedin Date: Thu, 4 Jun 2020 04:37:02 +0200 Subject: [PATCH] Removing vals not working, strangely --- crates/nu-cli/src/env/environment.rs | 21 +++++++++++++++++---- crates/nu-protocol/src/value/dict.rs | 4 ++++ 2 files changed, 21 insertions(+), 4 deletions(-) diff --git a/crates/nu-cli/src/env/environment.rs b/crates/nu-cli/src/env/environment.rs index bb8718230a..f24f38b0e0 100644 --- a/crates/nu-cli/src/env/environment.rs +++ b/crates/nu-cli/src/env/environment.rs @@ -1,11 +1,13 @@ use crate::data::config::Conf; use indexmap::{indexmap, IndexSet}; use nu_protocol::{UntaggedValue, Value}; -use std::collections::HashMap; +use std::collections::{HashMap}; +use indexmap::IndexMap; use std::ffi::OsString; use std::fmt::Debug; use std::fs::File; use std::io::prelude::*; +use std::io::Write; use std::path::PathBuf; pub trait Env: Debug + Send { @@ -68,8 +70,12 @@ impl Environment { //TODO: handle errors pub fn maintain_nurc_environment_vars(&mut self) { - self.clear_vars_from_unvisited_dirs(); - self.add_nurc(); + match self.clear_vars_from_unvisited_dirs() { + _ => {} + }; + match self.add_nurc() { + _ => {} + }; } pub fn add_nurc(&mut self) -> std::io::Result<()> { @@ -125,13 +131,20 @@ impl Environment { } // environment_vars: Option, + // pub fn remove_env(&mut self, key: &str) { if let Some(Value { value: UntaggedValue::Row(envs), tag: _, }) = &mut self.environment_vars { - envs.entries.remove(key); + + let mut file = File::create("env.txt").unwrap(); + write!(&mut file, "env: {:?}", envs.entries).unwrap(); + + let mut file = File::create("removenv.txt").unwrap(); + let removed = envs.remove_key(key); + write!(&mut file, "removed {:?}", (key, removed)).unwrap(); } } diff --git a/crates/nu-protocol/src/value/dict.rs b/crates/nu-protocol/src/value/dict.rs index b66307decf..70873f7983 100644 --- a/crates/nu-protocol/src/value/dict.rs +++ b/crates/nu-protocol/src/value/dict.rs @@ -159,6 +159,10 @@ impl Dictionary { self.entries.contains_key(key) } + pub fn remove_key(&mut self, key: &str) -> Option { + self.entries.remove(key) + } + /// Find the matching Value for a key, if possible pub fn get_data_by_key(&self, name: Spanned<&str>) -> Option { let result = self