2016-05-01 12:31:25 +08:00
|
|
|
// Functions for reading a character of input from stdin, using the inputrc information for key
|
|
|
|
// bindings.
|
2005-10-04 23:11:39 +08:00
|
|
|
#ifndef FISH_INPUT_H
|
|
|
|
#define FISH_INPUT_H
|
|
|
|
|
2015-07-25 23:14:25 +08:00
|
|
|
#include <stddef.h>
|
2017-02-14 12:37:27 +08:00
|
|
|
|
2015-07-25 23:14:25 +08:00
|
|
|
#include <vector>
|
|
|
|
|
2017-06-13 08:19:13 +08:00
|
|
|
#include "builtin_bind.h"
|
2015-07-25 23:14:25 +08:00
|
|
|
#include "common.h"
|
2019-03-15 16:11:15 +08:00
|
|
|
#include "input_common.h"
|
2005-10-04 23:11:39 +08:00
|
|
|
|
2014-01-19 17:27:39 +08:00
|
|
|
#define FISH_BIND_MODE_VAR L"fish_bind_mode"
|
2013-12-31 08:52:41 +08:00
|
|
|
|
2018-09-14 15:36:26 +08:00
|
|
|
class environment_t;
|
|
|
|
|
2014-02-13 04:49:32 +08:00
|
|
|
wcstring describe_char(wint_t c);
|
2005-09-20 21:26:39 +08:00
|
|
|
|
2017-02-16 12:09:26 +08:00
|
|
|
/// Set up arrays used by readch to detect escape sequences for special keys and perform related
|
|
|
|
/// initializations for our input subsystem.
|
|
|
|
void init_input();
|
2005-09-20 21:26:39 +08:00
|
|
|
|
2019-06-03 06:41:23 +08:00
|
|
|
struct input_mapping_t;
|
|
|
|
class inputter_t {
|
|
|
|
input_event_queue_t event_queue_{};
|
|
|
|
std::vector<wchar_t> input_function_args_{};
|
|
|
|
bool function_status_{false};
|
|
|
|
|
|
|
|
void function_push_arg(wchar_t arg);
|
|
|
|
void function_push_args(readline_cmd_t code);
|
|
|
|
void mapping_execute(const input_mapping_t &m, bool allow_commands);
|
|
|
|
void mapping_execute_matching_or_generic(bool allow_commands);
|
|
|
|
bool mapping_is_match(const input_mapping_t &m);
|
|
|
|
const input_mapping_t *find_mapping();
|
|
|
|
char_event_t read_characters_no_readline();
|
|
|
|
|
|
|
|
public:
|
|
|
|
inputter_t() = default;
|
|
|
|
|
|
|
|
/// Read a character from fd 0. Try to convert some escape sequences into character constants,
|
|
|
|
/// but do not permanently block the escape character.
|
|
|
|
///
|
|
|
|
/// This is performed in the same way vim does it, i.e. if an escape character is read, wait for
|
|
|
|
/// more input for a short time (a few milliseconds). If more input is avaialable, it is assumed
|
|
|
|
/// to be an escape sequence for a special character (such as an arrow key), and readch attempts
|
|
|
|
/// to parse it. If no more input follows after the escape key, it is assumed to be an actual
|
|
|
|
/// escape key press, and is returned as such.
|
|
|
|
///
|
|
|
|
/// The argument determines whether fish commands are allowed to be run as bindings. If false,
|
|
|
|
/// when a character is encountered that would invoke a fish command, it is unread and
|
|
|
|
/// char_event_type_t::check_exit is returned.
|
|
|
|
char_event_t readch(bool allow_commands = true);
|
|
|
|
|
|
|
|
/// Enqueue a char event to the queue of unread characters that input_readch will return before
|
|
|
|
/// actually reading from fd 0.
|
|
|
|
void queue_ch(char_event_t ch);
|
|
|
|
|
|
|
|
/// Enqueue a char event to the front of the queue; this will be the next event returned.
|
|
|
|
void push_front(char_event_t ch);
|
|
|
|
|
|
|
|
/// Sets the return status of the most recently executed input function.
|
|
|
|
void function_set_status(bool status) { function_status_ = status; }
|
|
|
|
|
|
|
|
/// Pop an argument from the function argument stack.
|
|
|
|
wchar_t function_pop_arg();
|
|
|
|
};
|
2005-09-20 21:26:39 +08:00
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Add a key mapping from the specified sequence to the specified command.
|
|
|
|
///
|
|
|
|
/// \param sequence the sequence to bind
|
|
|
|
/// \param command an input function that will be run whenever the key sequence occurs
|
2013-12-31 08:52:41 +08:00
|
|
|
void input_mapping_add(const wchar_t *sequence, const wchar_t *command,
|
|
|
|
const wchar_t *mode = DEFAULT_BIND_MODE,
|
2018-09-18 17:52:25 +08:00
|
|
|
const wchar_t *new_mode = DEFAULT_BIND_MODE, bool user = true);
|
2007-09-26 00:14:47 +08:00
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
void input_mapping_add(const wchar_t *sequence, const wchar_t *const *commands, size_t commands_len,
|
|
|
|
const wchar_t *mode = DEFAULT_BIND_MODE,
|
2018-09-18 17:52:25 +08:00
|
|
|
const wchar_t *new_mode = DEFAULT_BIND_MODE, bool user = true);
|
2014-01-01 07:11:32 +08:00
|
|
|
|
2014-09-23 12:04:06 +08:00
|
|
|
struct input_mapping_name_t {
|
|
|
|
wcstring seq;
|
|
|
|
wcstring mode;
|
|
|
|
};
|
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Returns all mapping names and modes.
|
2018-09-18 17:52:25 +08:00
|
|
|
std::vector<input_mapping_name_t> input_mapping_get_names(bool user = true);
|
|
|
|
|
|
|
|
/// Erase all bindings
|
|
|
|
void input_mapping_clear(const wchar_t *mode = NULL, bool user = true);
|
2007-09-26 00:14:47 +08:00
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Erase binding for specified key sequence.
|
2019-05-05 18:09:25 +08:00
|
|
|
bool input_mapping_erase(const wcstring &sequence, const wcstring &mode = DEFAULT_BIND_MODE,
|
|
|
|
bool user = true);
|
2007-09-26 00:14:47 +08:00
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Gets the command bound to the specified key sequence in the specified mode. Returns true if it
|
|
|
|
/// exists, false if not.
|
2019-05-05 18:09:25 +08:00
|
|
|
bool input_mapping_get(const wcstring &sequence, const wcstring &mode, wcstring_list_t *out_cmds,
|
|
|
|
bool user, wcstring *out_new_mode);
|
2013-12-31 08:52:41 +08:00
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Return the current bind mode.
|
2018-09-14 15:36:26 +08:00
|
|
|
wcstring input_get_bind_mode(const environment_t &vars);
|
2013-12-31 08:52:41 +08:00
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Set the current bind mode.
|
2014-03-31 04:13:35 +08:00
|
|
|
void input_set_bind_mode(const wcstring &bind_mode);
|
2005-09-20 21:26:39 +08:00
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Sets the return status of the most recently executed input function.
|
2014-01-23 17:23:04 +08:00
|
|
|
void input_function_set_status(bool status);
|
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Return the sequence for the terminfo variable of the specified name.
|
|
|
|
///
|
|
|
|
/// If no terminfo variable of the specified name could be found, return false and set errno to
|
|
|
|
/// ENOENT. If the terminfo variable does not have a value, return false and set errno to EILSEQ.
|
2013-04-16 04:07:17 +08:00
|
|
|
bool input_terminfo_get_sequence(const wchar_t *name, wcstring *out_seq);
|
2005-09-20 21:26:39 +08:00
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Return the name of the terminfo variable with the specified sequence, in out_name. Returns true
|
|
|
|
/// if found, false if not found.
|
2014-07-08 01:45:26 +08:00
|
|
|
bool input_terminfo_get_name(const wcstring &seq, wcstring *out_name);
|
2005-09-20 21:26:39 +08:00
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Return a list of all known terminfo names.
|
2012-11-19 08:30:30 +08:00
|
|
|
wcstring_list_t input_terminfo_get_names(bool skip_null);
|
2007-09-26 00:14:47 +08:00
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Returns the input function code for the given input function name.
|
2019-03-17 08:56:35 +08:00
|
|
|
maybe_t<readline_cmd_t> input_function_get_code(const wcstring &name);
|
2007-09-26 00:14:47 +08:00
|
|
|
|
2016-05-01 12:31:25 +08:00
|
|
|
/// Returns a list of all existing input function names.
|
2012-11-19 08:30:30 +08:00
|
|
|
wcstring_list_t input_function_get_names(void);
|
2007-09-26 00:14:47 +08:00
|
|
|
|
2005-10-04 23:11:39 +08:00
|
|
|
#endif
|