mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-15 22:44:01 +00:00
Remove unused functions, members (and a variable)
If we ever need any of these... they're in this commit: fish_wcswidth_visible() status_cmd_opts_t::feature_name completion_t::is_naturally_less_than() parser_t::set_empty_var_and_fire() parser_t::get_block_desc() parser_keywords_skip_arguments() parser_keywords_is_block() job_t::has_internal_proc() fish_wcswidth_visible()
This commit is contained in:
parent
63bd4eda55
commit
0118eafee1
12 changed files with 2 additions and 103 deletions
|
@ -100,7 +100,6 @@ namespace {
|
||||||
struct status_cmd_opts_t {
|
struct status_cmd_opts_t {
|
||||||
int level{1};
|
int level{1};
|
||||||
maybe_t<job_control_t> new_job_control_mode{};
|
maybe_t<job_control_t> new_job_control_mode{};
|
||||||
const wchar_t *feature_name{};
|
|
||||||
status_cmd_t status_cmd{STATUS_UNDEF};
|
status_cmd_t status_cmd{STATUS_UNDEF};
|
||||||
bool print_help{false};
|
bool print_help{false};
|
||||||
};
|
};
|
||||||
|
|
|
@ -241,10 +241,6 @@ __attribute__((always_inline)) static inline bool natural_compare_completions(
|
||||||
return wcsfilecmp(a.completion.c_str(), b.completion.c_str()) < 0;
|
return wcsfilecmp(a.completion.c_str(), b.completion.c_str()) < 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool completion_t::is_naturally_less_than(const completion_t &a, const completion_t &b) {
|
|
||||||
return natural_compare_completions(a, b);
|
|
||||||
}
|
|
||||||
|
|
||||||
void completion_t::prepend_token_prefix(const wcstring &prefix) {
|
void completion_t::prepend_token_prefix(const wcstring &prefix) {
|
||||||
if (this->flags & COMPLETE_REPLACES_TOKEN) {
|
if (this->flags & COMPLETE_REPLACES_TOKEN) {
|
||||||
this->completion.insert(0, prefix);
|
this->completion.insert(0, prefix);
|
||||||
|
@ -882,7 +878,7 @@ static void complete_load(const wcstring &name) {
|
||||||
bool completer_t::complete_param_for_command(const wcstring &cmd_orig, const wcstring &popt,
|
bool completer_t::complete_param_for_command(const wcstring &cmd_orig, const wcstring &popt,
|
||||||
const wcstring &str, bool use_switches,
|
const wcstring &str, bool use_switches,
|
||||||
bool *out_do_file) {
|
bool *out_do_file) {
|
||||||
bool use_common = true, use_files = true, has_force = false;
|
bool use_files = true, has_force = false;
|
||||||
|
|
||||||
wcstring cmd, path;
|
wcstring cmd, path;
|
||||||
parse_cmd_string(cmd_orig, &path, &cmd, ctx.vars);
|
parse_cmd_string(cmd_orig, &path, &cmd, ctx.vars);
|
||||||
|
@ -926,8 +922,7 @@ bool completer_t::complete_param_for_command(const wcstring &cmd_orig, const wcs
|
||||||
// the lock because callouts (like the condition) may add or remove completions. See issue 2.
|
// the lock because callouts (like the condition) may add or remove completions. See issue 2.
|
||||||
for (const option_list_t &options : all_options) {
|
for (const option_list_t &options : all_options) {
|
||||||
size_t short_opt_pos = short_option_pos(str, options);
|
size_t short_opt_pos = short_option_pos(str, options);
|
||||||
bool last_option_requires_param = false;
|
bool last_option_requires_param = false, use_common = true;
|
||||||
use_common = true;
|
|
||||||
if (use_switches) {
|
if (use_switches) {
|
||||||
if (str[0] == L'-') {
|
if (str[0] == L'-') {
|
||||||
// Check if we are entering a combined option and argument (like --color=auto or
|
// Check if we are entering a combined option and argument (like --color=auto or
|
||||||
|
|
|
@ -87,13 +87,6 @@ class completion_t {
|
||||||
completion_t(completion_t &&) noexcept;
|
completion_t(completion_t &&) noexcept;
|
||||||
completion_t &operator=(completion_t &&) noexcept;
|
completion_t &operator=(completion_t &&) noexcept;
|
||||||
|
|
||||||
// Compare two completions. No operating overlaoding to make this always explicit (there's
|
|
||||||
// potentially multiple ways to compare completions).
|
|
||||||
//
|
|
||||||
// "Naturally less than" means in a natural ordering, where digits are treated as numbers. For
|
|
||||||
// example, foo10 is naturally greater than foo2 (but alphabetically less than it).
|
|
||||||
static bool is_naturally_less_than(const completion_t &a, const completion_t &b);
|
|
||||||
|
|
||||||
/// \return the completion's match rank. Lower ranks are better completions.
|
/// \return the completion's match rank. Lower ranks are better completions.
|
||||||
uint32_t rank() const { return match.rank(); }
|
uint32_t rank() const { return match.rank(); }
|
||||||
|
|
||||||
|
|
|
@ -2874,8 +2874,6 @@ static void test_test_brackets() {
|
||||||
null_output_stream_t null{};
|
null_output_stream_t null{};
|
||||||
io_streams_t streams(null, null);
|
io_streams_t streams(null, null);
|
||||||
|
|
||||||
wcstring_list_t args;
|
|
||||||
|
|
||||||
const wchar_t *args1[] = {L"[", L"foo", nullptr};
|
const wchar_t *args1[] = {L"[", L"foo", nullptr};
|
||||||
do_test(builtin_test(parser, streams, args1) != 0);
|
do_test(builtin_test(parser, streams, args1) != 0);
|
||||||
|
|
||||||
|
|
|
@ -114,10 +114,6 @@ int parser_t::set_var_and_fire(const wcstring &key, env_mode_flags_t mode, wcstr
|
||||||
return set_var_and_fire(key, mode, std::move(vals));
|
return set_var_and_fire(key, mode, std::move(vals));
|
||||||
}
|
}
|
||||||
|
|
||||||
int parser_t::set_empty_var_and_fire(const wcstring &key, env_mode_flags_t mode) {
|
|
||||||
return set_var_and_fire(key, mode, wcstring_list_t{});
|
|
||||||
}
|
|
||||||
|
|
||||||
block_t *parser_t::push_block(block_t &&block) {
|
block_t *parser_t::push_block(block_t &&block) {
|
||||||
block.src_lineno = parser_t::get_lineno();
|
block.src_lineno = parser_t::get_lineno();
|
||||||
block.src_filename = parser_t::current_filename();
|
block.src_filename = parser_t::current_filename();
|
||||||
|
@ -140,39 +136,6 @@ void parser_t::pop_block(const block_t *expected) {
|
||||||
if (pop_env) vars().pop();
|
if (pop_env) vars().pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
const wchar_t *parser_t::get_block_desc(block_type_t block) {
|
|
||||||
switch (block) {
|
|
||||||
case block_type_t::while_block:
|
|
||||||
return WHILE_BLOCK;
|
|
||||||
case block_type_t::for_block:
|
|
||||||
return FOR_BLOCK;
|
|
||||||
case block_type_t::if_block:
|
|
||||||
return IF_BLOCK;
|
|
||||||
case block_type_t::function_call:
|
|
||||||
return FUNCTION_CALL_BLOCK;
|
|
||||||
|
|
||||||
case block_type_t::function_call_no_shadow:
|
|
||||||
return FUNCTION_CALL_NO_SHADOW_BLOCK;
|
|
||||||
case block_type_t::switch_block:
|
|
||||||
return SWITCH_BLOCK;
|
|
||||||
case block_type_t::subst:
|
|
||||||
return SUBST_BLOCK;
|
|
||||||
case block_type_t::top:
|
|
||||||
return TOP_BLOCK;
|
|
||||||
case block_type_t::begin:
|
|
||||||
return BEGIN_BLOCK;
|
|
||||||
case block_type_t::source:
|
|
||||||
return SOURCE_BLOCK;
|
|
||||||
case block_type_t::event:
|
|
||||||
return EVENT_BLOCK;
|
|
||||||
case block_type_t::breakpoint:
|
|
||||||
return BREAKPOINT_BLOCK;
|
|
||||||
case block_type_t::variable_assignment:
|
|
||||||
return VARIABLE_ASSIGNMENT_BLOCK;
|
|
||||||
}
|
|
||||||
return _(UNKNOWN_BLOCK);
|
|
||||||
}
|
|
||||||
|
|
||||||
const block_t *parser_t::block_at_index(size_t idx) const {
|
const block_t *parser_t::block_at_index(size_t idx) const {
|
||||||
return idx < block_list.size() ? &block_list[idx] : nullptr;
|
return idx < block_list.size() ? &block_list[idx] : nullptr;
|
||||||
}
|
}
|
||||||
|
|
|
@ -380,7 +380,6 @@ class parser_t : public std::enable_shared_from_this<parser_t> {
|
||||||
/// \return a value like ENV_OK.
|
/// \return a value like ENV_OK.
|
||||||
int set_var_and_fire(const wcstring &key, env_mode_flags_t mode, wcstring val);
|
int set_var_and_fire(const wcstring &key, env_mode_flags_t mode, wcstring val);
|
||||||
int set_var_and_fire(const wcstring &key, env_mode_flags_t mode, wcstring_list_t vals);
|
int set_var_and_fire(const wcstring &key, env_mode_flags_t mode, wcstring_list_t vals);
|
||||||
int set_empty_var_and_fire(const wcstring &key, env_mode_flags_t mode);
|
|
||||||
|
|
||||||
/// Pushes a new block. Returns a pointer to the block, stored in the parser. The pointer is
|
/// Pushes a new block. Returns a pointer to the block, stored in the parser. The pointer is
|
||||||
/// valid until the call to pop_block().
|
/// valid until the call to pop_block().
|
||||||
|
@ -389,9 +388,6 @@ class parser_t : public std::enable_shared_from_this<parser_t> {
|
||||||
/// Remove the outermost block, asserting it's the given one.
|
/// Remove the outermost block, asserting it's the given one.
|
||||||
void pop_block(const block_t *expected);
|
void pop_block(const block_t *expected);
|
||||||
|
|
||||||
/// Return a description of the given blocktype.
|
|
||||||
static const wchar_t *get_block_desc(block_type_t block);
|
|
||||||
|
|
||||||
/// Return the function name for the specified stack frame. Default is one (current frame).
|
/// Return the function name for the specified stack frame. Default is one (current frame).
|
||||||
maybe_t<wcstring> get_function_name(int level = 1);
|
maybe_t<wcstring> get_function_name(int level = 1);
|
||||||
|
|
||||||
|
|
|
@ -40,10 +40,6 @@ static size_t list_max_length(const string_set_t &list) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool parser_keywords_skip_arguments(const wcstring &cmd) {
|
|
||||||
return cmd == skip_keywords[0] || cmd == skip_keywords[1];
|
|
||||||
}
|
|
||||||
|
|
||||||
bool parser_keywords_is_subcommand(const wcstring &cmd) {
|
bool parser_keywords_is_subcommand(const wcstring &cmd) {
|
||||||
const static string_set_t search_list = ([] {
|
const static string_set_t search_list = ([] {
|
||||||
string_set_t results;
|
string_set_t results;
|
||||||
|
@ -59,14 +55,6 @@ bool parser_keywords_is_subcommand(const wcstring &cmd) {
|
||||||
return cmd.length() <= max_len && search_list.find(cmd) != not_found;
|
return cmd.length() <= max_len && search_list.find(cmd) != not_found;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool parser_keywords_is_block(const wcstring &word) {
|
|
||||||
const static auto max_len = list_max_length(block_keywords);
|
|
||||||
const static auto not_found = block_keywords.end();
|
|
||||||
|
|
||||||
// Everything above is executed only at startup, this is the actual optimized search routine:
|
|
||||||
return word.length() <= max_len && block_keywords.find(word) != not_found;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool parser_keywords_is_reserved(const wcstring &word) {
|
bool parser_keywords_is_reserved(const wcstring &word) {
|
||||||
const static string_set_t search_list = ([] {
|
const static string_set_t search_list = ([] {
|
||||||
string_set_t results;
|
string_set_t results;
|
||||||
|
|
|
@ -20,11 +20,4 @@ bool parser_keywords_is_subcommand(const wcstring &cmd);
|
||||||
/// \return 1 of the command parameter is a command, 0 otherwise
|
/// \return 1 of the command parameter is a command, 0 otherwise
|
||||||
bool parser_keywords_is_reserved(const wcstring &word);
|
bool parser_keywords_is_reserved(const wcstring &word);
|
||||||
|
|
||||||
/// Test if the specified string is command that opens a new block.
|
|
||||||
bool parser_keywords_is_block(const wcstring &word);
|
|
||||||
|
|
||||||
/// Check if the specified command is one of the builtins that cannot have arguments, any followin
|
|
||||||
/// argument is interpreted as a new command.
|
|
||||||
bool parser_keywords_skip_arguments(const wcstring &cmd);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -310,13 +310,6 @@ void job_t::mark_constructed() {
|
||||||
mut_flags().constructed = true;
|
mut_flags().constructed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool job_t::has_internal_proc() const {
|
|
||||||
for (const auto &p : processes) {
|
|
||||||
if (p->is_internal()) return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool job_t::has_external_proc() const {
|
bool job_t::has_external_proc() const {
|
||||||
for (const auto &p : processes) {
|
for (const auto &p : processes) {
|
||||||
if (!p->is_internal()) return true;
|
if (!p->is_internal()) return true;
|
||||||
|
|
|
@ -462,7 +462,6 @@ class job_t : noncopyable_t {
|
||||||
/// \return whether we have internal or external procs, respectively.
|
/// \return whether we have internal or external procs, respectively.
|
||||||
/// Internal procs are builtins, blocks, and functions.
|
/// Internal procs are builtins, blocks, and functions.
|
||||||
/// External procs include exec and external.
|
/// External procs include exec and external.
|
||||||
bool has_internal_proc() const;
|
|
||||||
bool has_external_proc() const;
|
bool has_external_proc() const;
|
||||||
|
|
||||||
/// \return whether this job, when run, will want a job ID.
|
/// \return whether this job, when run, will want a job ID.
|
||||||
|
|
|
@ -315,15 +315,3 @@ int fish_wcwidth_visible(wchar_t widechar) {
|
||||||
if (widechar == L'\b') return -1;
|
if (widechar == L'\b') return -1;
|
||||||
return std::max(0, fish_wcwidth(widechar));
|
return std::max(0, fish_wcwidth(widechar));
|
||||||
}
|
}
|
||||||
|
|
||||||
int fish_wcswidth_visible(const wcstring &str) {
|
|
||||||
int res = 0;
|
|
||||||
for (wchar_t ch : str) {
|
|
||||||
if (ch == L'\b') {
|
|
||||||
res += -1;
|
|
||||||
} else {
|
|
||||||
res += std::max(0, fish_wcwidth(ch));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
|
@ -297,10 +297,4 @@ class line_iterator_t {
|
||||||
/// Like fish_wcwidth, but returns 0 for characters with no real width instead of -1.
|
/// Like fish_wcwidth, but returns 0 for characters with no real width instead of -1.
|
||||||
int fish_wcwidth_visible(wchar_t widechar);
|
int fish_wcwidth_visible(wchar_t widechar);
|
||||||
|
|
||||||
/// The same, but for all chars. Note that this only makes sense if the string has an arbitrary long
|
|
||||||
/// prefix - backslashes can move the cursor *before* the string.
|
|
||||||
///
|
|
||||||
/// In typical usage, you probably want to wrap wcwidth_visible to accumulate the width, but never
|
|
||||||
/// go below 0.
|
|
||||||
int fish_wcswidth_visible(const wcstring &str);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue