Don't compute $history for variable completion description

Fixes #6288
This commit is contained in:
Johannes Altmanninger 2019-11-05 12:59:49 +01:00
parent 4f1fa9513c
commit 23eb6e9c09

View file

@ -1190,15 +1190,20 @@ bool completer_t::complete_variable(const wcstring &str, size_t start_offset) {
wcstring desc;
if (this->wants_descriptions()) {
if (this->type() != COMPLETE_AUTOSUGGEST) {
// $history can be huge, don't put it in the completion description; see #6288.
if (env_name == L"history") {
desc = format_string(L"Full history of interactive commands");
} else {
// Can't use this->vars here, it could be any variable.
auto var = vars.get(env_name);
if (!var) continue;
if (this->type() != COMPLETE_AUTOSUGGEST) {
wcstring value = expand_escape_variable(*var);
desc = format_string(COMPLETE_VAR_DESC_VAL, value.c_str());
}
}
}
// Append matching environment variables
append_completion(&this->completions, std::move(comp), desc, flags, match);