2016-05-02 23:53:10 +00:00
|
|
|
// Various mostly unrelated utility functions related to parsing, loading and evaluating fish code.
|
2006-01-30 16:51:50 +00:00
|
|
|
#ifndef FISH_PARSE_UTIL_H
|
|
|
|
#define FISH_PARSE_UTIL_H
|
|
|
|
|
2015-07-25 15:14:25 +00:00
|
|
|
#include <stddef.h>
|
2017-02-14 04:37:27 +00:00
|
|
|
|
2015-07-25 15:14:25 +00:00
|
|
|
#include <vector>
|
2016-04-21 06:00:54 +00:00
|
|
|
|
2015-07-25 15:14:25 +00:00
|
|
|
#include "common.h"
|
2017-12-22 22:40:15 +00:00
|
|
|
#include "parse_tree.h"
|
2016-04-21 06:00:54 +00:00
|
|
|
#include "tokenizer.h"
|
2012-01-23 19:42:41 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Find the beginning and end of the first subshell in the specified string.
|
|
|
|
///
|
|
|
|
/// \param in the string to search for subshells
|
|
|
|
/// \param begin the starting paranthesis of the subshell
|
|
|
|
/// \param end the ending paranthesis of the subshell
|
|
|
|
/// \param accept_incomplete whether to permit missing closing parenthesis
|
|
|
|
/// \return -1 on syntax error, 0 if no subshells exist and 1 on success
|
|
|
|
int parse_util_locate_cmdsubst(const wchar_t *in, wchar_t **begin, wchar_t **end,
|
2013-07-17 08:35:30 +00:00
|
|
|
bool accept_incomplete);
|
2006-01-30 16:51:50 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Same as parse_util_locate_cmdsubst, but handles square brackets [ ].
|
|
|
|
int parse_util_locate_slice(const wchar_t *in, wchar_t **begin, wchar_t **end,
|
2014-02-03 22:13:42 +00:00
|
|
|
bool accept_incomplete);
|
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Alternative API. Iterate over command substitutions.
|
|
|
|
///
|
|
|
|
/// \param str the string to search for subshells
|
|
|
|
/// \param inout_cursor_offset On input, the location to begin the search. On output, either the end
|
|
|
|
/// of the string, or just after the closed-paren.
|
|
|
|
/// \param out_contents On output, the contents of the command substitution
|
|
|
|
/// \param out_start On output, the offset of the start of the command substitution (open paren)
|
|
|
|
/// \param out_end On output, the offset of the end of the command substitution (close paren), or
|
|
|
|
/// the end of the string if it was incomplete
|
|
|
|
/// \param accept_incomplete whether to permit missing closing parenthesis
|
|
|
|
/// \return -1 on syntax error, 0 if no subshells exist and 1 on success
|
|
|
|
int parse_util_locate_cmdsubst_range(const wcstring &str, size_t *inout_cursor_offset,
|
|
|
|
wcstring *out_contents, size_t *out_start, size_t *out_end,
|
2014-01-15 09:40:40 +00:00
|
|
|
bool accept_incomplete);
|
2013-10-09 01:41:35 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Find the beginning and end of the command substitution under the cursor. If no subshell is
|
|
|
|
/// found, the entire string is returned. If the current command substitution is not ended, i.e. the
|
|
|
|
/// closing parenthesis is missing, then the string from the beginning of the substitution to the
|
|
|
|
/// end of the string is returned.
|
|
|
|
///
|
|
|
|
/// \param buff the string to search for subshells
|
|
|
|
/// \param cursor_pos the position of the cursor
|
|
|
|
/// \param a the start of the searched string
|
|
|
|
/// \param b the end of the searched string
|
|
|
|
void parse_util_cmdsubst_extent(const wchar_t *buff, size_t cursor_pos, const wchar_t **a,
|
2012-11-19 00:30:30 +00:00
|
|
|
const wchar_t **b);
|
2006-01-30 16:51:50 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Find the beginning and end of the process definition under the cursor
|
|
|
|
///
|
|
|
|
/// \param buff the string to search for subshells
|
|
|
|
/// \param cursor_pos the position of the cursor
|
2019-10-29 12:32:26 +00:00
|
|
|
/// \param a the start of the process
|
|
|
|
/// \param b the end of the process
|
|
|
|
/// \param tokens the tokens in the process
|
2016-05-02 23:53:10 +00:00
|
|
|
void parse_util_process_extent(const wchar_t *buff, size_t cursor_pos, const wchar_t **a,
|
2019-10-29 12:32:26 +00:00
|
|
|
const wchar_t **b, std::vector<tok_t> *tokens);
|
2006-01-30 16:51:50 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Find the beginning and end of the job definition under the cursor
|
|
|
|
///
|
|
|
|
/// \param buff the string to search for subshells
|
|
|
|
/// \param cursor_pos the position of the cursor
|
|
|
|
/// \param a the start of the searched string
|
|
|
|
/// \param b the end of the searched string
|
|
|
|
void parse_util_job_extent(const wchar_t *buff, size_t cursor_pos, const wchar_t **a,
|
2012-11-19 00:30:30 +00:00
|
|
|
const wchar_t **b);
|
2006-01-30 16:51:50 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Find the beginning and end of the token under the cursor and the token before the current token.
|
|
|
|
/// Any combination of tok_begin, tok_end, prev_begin and prev_end may be null.
|
|
|
|
///
|
|
|
|
/// \param buff the string to search for subshells
|
|
|
|
/// \param cursor_pos the position of the cursor
|
|
|
|
/// \param tok_begin the start of the current token
|
|
|
|
/// \param tok_end the end of the current token
|
|
|
|
/// \param prev_begin the start o the token before the current token
|
|
|
|
/// \param prev_end the end of the token before the current token
|
|
|
|
void parse_util_token_extent(const wchar_t *buff, size_t cursor_pos, const wchar_t **tok_begin,
|
|
|
|
const wchar_t **tok_end, const wchar_t **prev_begin,
|
2012-11-19 00:30:30 +00:00
|
|
|
const wchar_t **prev_end);
|
2006-01-30 16:51:50 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Get the linenumber at the specified character offset.
|
2012-11-19 00:30:30 +00:00
|
|
|
int parse_util_lineno(const wchar_t *str, size_t len);
|
2006-02-05 13:10:35 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Calculate the line number of the specified cursor position.
|
2012-11-19 00:30:30 +00:00
|
|
|
int parse_util_get_line_from_offset(const wcstring &str, size_t pos);
|
2007-09-21 14:05:49 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Get the offset of the first character on the specified line.
|
2012-11-19 00:30:30 +00:00
|
|
|
size_t parse_util_get_offset_from_line(const wcstring &str, int line);
|
2007-09-21 14:05:49 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Return the total offset of the buffer for the cursor position nearest to the specified poition.
|
2012-11-19 00:30:30 +00:00
|
|
|
size_t parse_util_get_offset(const wcstring &str, int line, long line_offset);
|
2007-09-21 14:05:49 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Return the given string, unescaping wildcard characters but not performing any other character
|
|
|
|
/// transformation.
|
2015-08-19 18:35:24 +00:00
|
|
|
wcstring parse_util_unescape_wildcards(const wcstring &in);
|
2006-02-19 01:14:32 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Checks if the specified string is a help option.
|
2017-06-19 05:07:48 +00:00
|
|
|
bool parse_util_argument_is_help(const wchar_t *s);
|
2014-03-18 21:42:38 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Calculates information on the parameter at the specified index.
|
|
|
|
///
|
|
|
|
/// \param cmd The command to be analyzed
|
|
|
|
/// \param pos An index in the string which is inside the parameter
|
|
|
|
/// \param quote If not NULL, store the type of quote this parameter has, can be either ', " or \\0,
|
|
|
|
/// meaning the string is not quoted.
|
|
|
|
/// \param offset If not NULL, get_param will store the offset to the beginning of the parameter.
|
2016-06-06 01:46:04 +00:00
|
|
|
/// \param out_type If not NULL, get_param will store the token type.
|
2016-05-02 23:53:10 +00:00
|
|
|
void parse_util_get_parameter_info(const wcstring &cmd, const size_t pos, wchar_t *quote,
|
2019-10-13 23:06:16 +00:00
|
|
|
size_t *offset, token_type_t *out_type);
|
2016-05-02 23:53:10 +00:00
|
|
|
|
|
|
|
/// Attempts to escape the string 'cmd' using the given quote type, as determined by the quote
|
|
|
|
/// character. The quote can be a single quote or double quote, or L'\0' to indicate no quoting (and
|
2018-02-17 22:36:43 +00:00
|
|
|
/// thus escaping should be with backslashes). Optionally do not escape tildes.
|
|
|
|
wcstring parse_util_escape_string_with_quote(const wcstring &cmd, wchar_t quote,
|
|
|
|
bool no_tilde = false);
|
2007-04-22 09:50:26 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Given a string, parse it as fish code and then return the indents. The return value has the same
|
|
|
|
/// size as the string.
|
2013-12-08 21:41:12 +00:00
|
|
|
std::vector<int> parse_util_compute_indents(const wcstring &src);
|
2007-04-22 09:50:26 +00:00
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Given a string, detect parse errors in it. If allow_incomplete is set, then if the string is
|
|
|
|
/// incomplete (e.g. an unclosed quote), an error is not returned and the PARSER_TEST_INCOMPLETE bit
|
|
|
|
/// is set in the return value. If allow_incomplete is not set, then incomplete strings result in an
|
2017-12-22 22:40:15 +00:00
|
|
|
/// error. If out_pstree is not NULL, the resulting tree is returned by reference.
|
2016-02-28 08:44:20 +00:00
|
|
|
class parse_node_tree_t;
|
2016-05-02 23:53:10 +00:00
|
|
|
parser_test_error_bits_t parse_util_detect_errors(const wcstring &buff_src,
|
|
|
|
parse_error_list_t *out_errors = NULL,
|
|
|
|
bool allow_incomplete = true,
|
2017-12-22 22:40:15 +00:00
|
|
|
parsed_source_ref_t *out_pstree = NULL);
|
2016-05-02 23:53:10 +00:00
|
|
|
|
2019-08-04 21:49:56 +00:00
|
|
|
/// Detect errors in the specified string when parsed as an argument list. Returns the text of an
|
|
|
|
/// error, or none if no error occurred.
|
|
|
|
maybe_t<wcstring> parse_util_detect_errors_in_argument_list(const wcstring &arg_list_src,
|
|
|
|
const wcstring &prefix = {});
|
|
|
|
|
2016-05-02 23:53:10 +00:00
|
|
|
/// Test if this argument contains any errors. Detected errors include syntax errors in command
|
|
|
|
/// substitutions, improperly escaped characters and improper use of the variable expansion
|
|
|
|
/// operator. This does NOT currently detect unterminated quotes.
|
2015-07-25 15:14:25 +00:00
|
|
|
class parse_node_t;
|
2016-05-02 23:53:10 +00:00
|
|
|
parser_test_error_bits_t parse_util_detect_errors_in_argument(
|
2018-01-12 19:36:45 +00:00
|
|
|
tnode_t<grammar::argument> node, const wcstring &arg_src,
|
|
|
|
parse_error_list_t *out_errors = NULL);
|
2016-05-02 23:53:10 +00:00
|
|
|
|
|
|
|
/// Given a string containing a variable expansion error, append an appropriate error to the errors
|
|
|
|
/// list. The global_token_pos is the offset of the token in the larger source, and the dollar_pos
|
|
|
|
/// is the offset of the offending dollar sign within the token.
|
|
|
|
void parse_util_expand_variable_error(const wcstring &token, size_t global_token_pos,
|
|
|
|
size_t dollar_pos, parse_error_list_t *out_errors);
|
2015-04-29 23:53:02 +00:00
|
|
|
|
2006-01-30 16:51:50 +00:00
|
|
|
#endif
|