mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-27 20:25:12 +00:00
Correct some more memory management in env.cpp
This commit is contained in:
parent
efeb8e43a2
commit
d5d3712220
1 changed files with 4 additions and 4 deletions
|
@ -217,7 +217,7 @@ void var_stack_t::push(bool new_scope) {
|
||||||
// Only if we introduce a new shadowing scope; i.e. not if it's just `begin; end` or
|
// Only if we introduce a new shadowing scope; i.e. not if it's just `begin; end` or
|
||||||
// "--no-scope-shadowing".
|
// "--no-scope-shadowing".
|
||||||
if (new_scope && top_node != this->global_env) {
|
if (new_scope && top_node != this->global_env) {
|
||||||
for (auto &var : top_node->env) {
|
for (const auto &var : top_node->env) {
|
||||||
if (var.second.exportv) node->env.insert(var);
|
if (var.second.exportv) node->env.insert(var);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -547,14 +547,14 @@ static void init_path_vars() {
|
||||||
|
|
||||||
/// Initialize the curses subsystem.
|
/// Initialize the curses subsystem.
|
||||||
static void init_curses() {
|
static void init_curses() {
|
||||||
for (auto var_name : curses_variables) {
|
for (const auto &var_name : curses_variables) {
|
||||||
|
std::string name = wcs2string(var_name);
|
||||||
const auto var = env_get(var_name, ENV_EXPORT);
|
const auto var = env_get(var_name, ENV_EXPORT);
|
||||||
const std::string &name = wcs2string(var_name);
|
|
||||||
if (var.missing_or_empty()) {
|
if (var.missing_or_empty()) {
|
||||||
debug(2, L"curses var %s missing or empty", name.c_str());
|
debug(2, L"curses var %s missing or empty", name.c_str());
|
||||||
unsetenv(name.c_str());
|
unsetenv(name.c_str());
|
||||||
} else {
|
} else {
|
||||||
const std::string &value = wcs2string(var->as_string());
|
std::string value = wcs2string(var->as_string());
|
||||||
debug(2, L"curses var %s='%s'", name.c_str(), value.c_str());
|
debug(2, L"curses var %s='%s'", name.c_str(), value.c_str());
|
||||||
setenv(name.c_str(), value.c_str(), 1);
|
setenv(name.c_str(), value.c_str(), 1);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue