diff --git a/exec.cpp b/exec.cpp index 384fa4e36..e49644e15 100644 --- a/exec.cpp +++ b/exec.cpp @@ -1740,7 +1740,7 @@ int exec_subshell( const wchar_t *cmd, CHECK( cmd, -1 ); - ifs = env_get_string(L"IFS").empty()?NULL:env_get_string(L"IFS"); + ifs = env_get_string(L"IFS").empty()?NULL:env_get_string(L"IFS").c_str(); if( ifs && ifs[0] ) { diff --git a/expand.cpp b/expand.cpp index 11bc43172..3dc94068a 100644 --- a/expand.cpp +++ b/expand.cpp @@ -176,11 +176,11 @@ int expand_is_clean( const wchar_t *in ) /** Return the environment variable value for the string starting at \c in. */ -static wchar_t *expand_var( wchar_t *in ) +static wcstring expand_var( wchar_t *in ) { if( !in ) return 0; - return env_get( in ); + return env_get_string( in ); } /** @@ -958,7 +958,8 @@ static int expand_variables( wchar_t *in, array_list_t *out, int last_idx ) int start_pos = i+1; int stop_pos; int var_len, new_len; - wchar_t * var_val; + const wchar_t * var_val; + wcstring var_val_wstr; wchar_t * new_in; int is_single = (c==VARIABLE_EXPAND_SINGLE); int var_name_stop_pos; @@ -991,7 +992,8 @@ static int expand_variables( wchar_t *in, array_list_t *out, int last_idx ) sb_append_substring( var_tmp, &in[start_pos], var_len ); - var_val = expand_var( (wchar_t *)var_tmp->buff ); + var_val_wstr = expand_var( (wchar_t *)var_tmp->buff ); + var_val = var_val_wstr.empty()?NULL:var_val_wstr.c_str(); if( var_val ) {