mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-03 16:48:45 +00:00
0f7bba5f0e
This commit recognizes an existing pattern: many operations need some combination of a set of variables, a way to detect cancellation, and sometimes a parser. For example, tab completion needs a parser to execute custom completions, the variable set, should cancel on SIGINT. Background autosuggestions don't need a parser, but they do need the variables and should cancel if the user types something new. Etc. This introduces a new triple operation_context_t that wraps these concepts up. This simplifies many method signatures and argument passing.
131 lines
5.3 KiB
C++
131 lines
5.3 KiB
C++
// Prototypes for functions for syntax highlighting.
|
|
#ifndef FISH_HIGHLIGHT_H
|
|
#define FISH_HIGHLIGHT_H
|
|
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
|
|
#include <vector>
|
|
|
|
#include "color.h"
|
|
#include "common.h"
|
|
#include "env.h"
|
|
|
|
/// Describes the role of a span of text.
|
|
enum class highlight_role_t : uint8_t {
|
|
normal = 0, // normal text
|
|
error, // error
|
|
command, // command
|
|
statement_terminator, // process separator
|
|
param, // command parameter (argument)
|
|
comment, // comment
|
|
match, // matching parenthesis, etc.
|
|
search_match, // search match
|
|
operat, // operator
|
|
escape, // escape sequences
|
|
quote, // quoted string
|
|
redirection, // redirection
|
|
autosuggestion, // autosuggestion
|
|
selection,
|
|
|
|
// Pager support.
|
|
// NOTE: pager.cpp relies on these being in this order.
|
|
pager_progress,
|
|
pager_background,
|
|
pager_prefix,
|
|
pager_completion,
|
|
pager_description,
|
|
pager_secondary_background,
|
|
pager_secondary_prefix,
|
|
pager_secondary_completion,
|
|
pager_secondary_description,
|
|
pager_selected_background,
|
|
pager_selected_prefix,
|
|
pager_selected_completion,
|
|
pager_selected_description,
|
|
};
|
|
|
|
/// Simply value type describing how a character should be highlighted..
|
|
struct highlight_spec_t {
|
|
highlight_role_t foreground{highlight_role_t::normal};
|
|
highlight_role_t background{highlight_role_t::normal};
|
|
bool valid_path{false};
|
|
bool force_underline{false};
|
|
|
|
highlight_spec_t() = default;
|
|
|
|
/* implicit */ highlight_spec_t(highlight_role_t fg,
|
|
highlight_role_t bg = highlight_role_t::normal)
|
|
: foreground(fg), background(bg) {}
|
|
|
|
bool operator==(const highlight_spec_t &rhs) const {
|
|
return foreground == rhs.foreground && background == rhs.background &&
|
|
valid_path == rhs.valid_path && force_underline == rhs.force_underline;
|
|
}
|
|
|
|
bool operator!=(const highlight_spec_t &rhs) const { return !(*this == rhs); }
|
|
|
|
static highlight_spec_t make_background(highlight_role_t bg_role) {
|
|
return highlight_spec_t{highlight_role_t::normal, bg_role};
|
|
}
|
|
};
|
|
|
|
class history_item_t;
|
|
class operation_context_t;
|
|
|
|
std::string colorize(const wcstring &text, const std::vector<highlight_spec_t> &colors);
|
|
|
|
/// 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 for each character in buff.
|
|
///
|
|
/// \param buffstr The buffer on which to perform syntax highlighting
|
|
/// \param color The array in which to store the color codes. The first 8 bits are used for fg
|
|
/// color, the next 8 bits for bg color.
|
|
/// \param pos the cursor position. Used for quote matching, etc.
|
|
/// \param ctx The variables and cancellation check for this operation.
|
|
void highlight_shell(const wcstring &buffstr, std::vector<highlight_spec_t> &color, size_t pos,
|
|
const operation_context_t &ctx);
|
|
|
|
/// Perform a non-blocking shell highlighting. The function will not do any I/O that may block. As a
|
|
/// result, invalid commands may not be detected, etc.
|
|
void highlight_shell_no_io(const wcstring &buffstr, std::vector<highlight_spec_t> &color,
|
|
size_t pos, const operation_context_t &ctx);
|
|
|
|
/// Perform syntax highlighting for the text in buff. Matching quotes and parenthesis are
|
|
/// highlighted. The result is stored in the color array as a color_code from the HIGHLIGHT_ enum
|
|
/// for each character in buff.
|
|
///
|
|
/// \param buffstr The buffer on which to perform syntax highlighting
|
|
/// \param color The array in which to store the color codes. The first 8 bits are used for fg
|
|
/// color, the next 8 bits for bg color.
|
|
/// \param pos the cursor position. Used for quote matching, etc.
|
|
/// \param ctx The cancellation and other environment for this operation. This is unused.
|
|
void highlight_universal(const wcstring &buffstr, std::vector<highlight_spec_t> &color, size_t pos,
|
|
const operation_context_t &ctx);
|
|
|
|
/// \return an RGB color for a given highlight spec.
|
|
rgb_color_t highlight_get_color(const highlight_spec_t &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_validate_from_history(const history_item_t &item,
|
|
const wcstring &working_directory,
|
|
const operation_context_t &ctx);
|
|
|
|
// Tests whether the specified string cpath is the prefix of anything we could cd to. directories is
|
|
// a list of possible parent directories (typically either the working directory, or the cdpath).
|
|
// This does I/O!
|
|
//
|
|
// This is used only internally to this file, and is exposed only for testing.
|
|
enum {
|
|
// The path must be to a directory.
|
|
PATH_REQUIRE_DIR = 1 << 0,
|
|
// Expand any leading tilde in the path.
|
|
PATH_EXPAND_TILDE = 1 << 1
|
|
};
|
|
typedef unsigned int path_flags_t;
|
|
bool is_potential_path(const wcstring &potential_path_fragment, const wcstring_list_t &directories,
|
|
const environment_t &vars, path_flags_t flags);
|
|
|
|
#endif
|