mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-13 21:44:16 +00:00
Some improvements to validate commands suggested from history
This commit is contained in:
parent
e995cc9329
commit
05c721bebb
3 changed files with 37 additions and 22 deletions
|
@ -33,6 +33,7 @@
|
|||
#include "output.h"
|
||||
#include "wildcard.h"
|
||||
#include "path.h"
|
||||
#include "history.h"
|
||||
|
||||
/**
|
||||
Number of elements in the highlight_var array
|
||||
|
@ -810,9 +811,8 @@ bool autosuggest_suggest_special(const wcstring &str, const wcstring &working_di
|
|||
return result;
|
||||
}
|
||||
|
||||
bool autosuggest_special_validate_from_history(const wcstring &str, const wcstring &working_directory, bool *outSuggestionOK) {
|
||||
bool autosuggest_validate_from_history(const history_item_t &item, file_detection_context_t &detector, const wcstring &working_directory, const env_vars &vars) {
|
||||
ASSERT_IS_BACKGROUND_THREAD();
|
||||
assert(outSuggestionOK != NULL);
|
||||
|
||||
bool handled = false, suggestionOK = false;
|
||||
|
||||
|
@ -820,7 +820,7 @@ bool autosuggest_special_validate_from_history(const wcstring &str, const wcstri
|
|||
wcstring parsed_command;
|
||||
wcstring_list_t parsed_arguments;
|
||||
int parsed_last_arg_pos = -1;
|
||||
if (! autosuggest_parse_command(str, &parsed_command, &parsed_arguments, &parsed_last_arg_pos))
|
||||
if (! autosuggest_parse_command(item.str(), &parsed_command, &parsed_arguments, &parsed_last_arg_pos))
|
||||
return false;
|
||||
|
||||
if (parsed_command == L"cd" && ! parsed_arguments.empty()) {
|
||||
|
@ -845,11 +845,34 @@ bool autosuggest_special_validate_from_history(const wcstring &str, const wcstri
|
|||
free(path);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
/* Either an error or some other command, so we don't handle it specially */
|
||||
}
|
||||
*outSuggestionOK = suggestionOK;
|
||||
return handled;
|
||||
|
||||
/* If not handled specially, handle it here */
|
||||
if (! handled) {
|
||||
bool cmd_ok = false;
|
||||
|
||||
wchar_t *full_path = path_get_path(parsed_command.c_str());
|
||||
if (full_path) {
|
||||
cmd_ok = true;
|
||||
free(full_path);
|
||||
}
|
||||
else if (builtin_exists(parsed_command) || function_exists_no_autoload(parsed_command, vars)) {
|
||||
cmd_ok = true;
|
||||
}
|
||||
|
||||
if (cmd_ok) {
|
||||
const path_list_t &paths = item.get_required_paths();
|
||||
if (paths.empty()) {
|
||||
suggestionOK= true;
|
||||
}
|
||||
else {
|
||||
detector.potential_paths = paths;
|
||||
suggestionOK = detector.paths_are_valid(paths);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return suggestionOK;
|
||||
}
|
||||
|
||||
// This function does I/O
|
||||
|
|
|
@ -70,6 +70,9 @@
|
|||
*/
|
||||
#define HIGHLIGHT_AUTOSUGGESTION 0x2000
|
||||
|
||||
class history_item_t;
|
||||
class file_detection_context_t;
|
||||
|
||||
/**
|
||||
Perform syntax highlighting for the shell commands in buff. The result is
|
||||
stored in the color array as a color_code from the HIGHLIGHT_ enum
|
||||
|
@ -109,7 +112,7 @@ rgb_color_t highlight_get_color( int highlight, bool is_background );
|
|||
/** Given a command 'str' from the history, try to determine whether we ought to suggest it by specially recognizing the command.
|
||||
Returns true if we validated the command. If so, returns by reference whether the suggestion is valid or not.
|
||||
*/
|
||||
bool autosuggest_special_validate_from_history(const wcstring &str, const wcstring &working_directory, bool *outSuggestionOK);
|
||||
bool autosuggest_validate_from_history(const history_item_t &item, file_detection_context_t &detector, const wcstring &working_directory, const env_vars &vars);
|
||||
|
||||
/** Given the command line contents 'str', return via reference a suggestion by specially recognizing the command. Returns true if we recognized the command (even if we couldn't think of a suggestion for it).
|
||||
*/
|
||||
|
|
15
reader.cpp
15
reader.cpp
|
@ -1255,23 +1255,12 @@ struct autosuggestion_context_t {
|
|||
if (item.str().find('\n') != wcstring::npos)
|
||||
continue;
|
||||
|
||||
bool item_ok = false;
|
||||
if (autosuggest_special_validate_from_history(item.str(), working_directory, &item_ok)) {
|
||||
if (autosuggest_validate_from_history(item, detector, working_directory, vars)) {
|
||||
/* The command autosuggestion was handled specially, so we're done */
|
||||
} else {
|
||||
/* See if the item has any required paths */
|
||||
const path_list_t &paths = item.get_required_paths();
|
||||
if (paths.empty()) {
|
||||
item_ok = true;
|
||||
} else {
|
||||
detector.potential_paths = paths;
|
||||
item_ok = detector.paths_are_valid(paths);
|
||||
}
|
||||
}
|
||||
if (item_ok) {
|
||||
this->autosuggestion = searcher.current_string();
|
||||
return 1;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/* Try handling a special command like cd */
|
||||
|
|
Loading…
Reference in a new issue