2006-01-31 00:51:50 +08:00
|
|
|
/** \file parse_util.h
|
|
|
|
|
2006-02-19 09:54:38 +08:00
|
|
|
Various mostly unrelated utility functions related to parsing,
|
|
|
|
loading and evaluating fish code.
|
2006-01-31 00:51:50 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef FISH_PARSE_UTIL_H
|
|
|
|
#define FISH_PARSE_UTIL_H
|
|
|
|
|
|
|
|
#include <wchar.h>
|
|
|
|
|
|
|
|
/**
|
2006-02-19 09:54:38 +08:00
|
|
|
Find the beginning and end of the first subshell in the specified string.
|
2006-01-31 00:51:50 +08:00
|
|
|
|
|
|
|
\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 flags set this variable to ACCEPT_INCOMPLETE if in tab_completion mode
|
|
|
|
\return -1 on syntax error, 0 if no subshells exist and 1 on sucess
|
|
|
|
*/
|
|
|
|
|
|
|
|
int parse_util_locate_cmdsubst( const wchar_t *in,
|
2006-06-14 21:22:40 +08:00
|
|
|
wchar_t **begin,
|
|
|
|
wchar_t **end,
|
2006-06-20 08:50:10 +08:00
|
|
|
int flags );
|
2006-01-31 00:51:50 +08:00
|
|
|
|
2006-02-09 02:47:37 +08:00
|
|
|
/**
|
2006-07-03 18:46:47 +08: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.
|
2006-02-19 09:54:38 +08:00
|
|
|
|
|
|
|
\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
|
2006-02-09 02:47:37 +08:00
|
|
|
*/
|
2006-01-31 00:51:50 +08:00
|
|
|
void parse_util_cmdsubst_extent( const wchar_t *buff,
|
|
|
|
int cursor_pos,
|
2006-06-14 21:22:40 +08:00
|
|
|
wchar_t **a,
|
|
|
|
wchar_t **b );
|
2006-01-31 00:51:50 +08:00
|
|
|
|
2006-02-09 02:47:37 +08:00
|
|
|
/**
|
|
|
|
Find the beginning and end of the process definition under the cursor
|
2006-02-19 09:54:38 +08:00
|
|
|
|
|
|
|
\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
|
2006-02-09 02:47:37 +08:00
|
|
|
*/
|
2006-01-31 00:51:50 +08:00
|
|
|
void parse_util_process_extent( const wchar_t *buff,
|
2006-02-19 09:54:38 +08:00
|
|
|
int cursor_pos,
|
2006-06-14 21:22:40 +08:00
|
|
|
wchar_t **a,
|
|
|
|
wchar_t **b );
|
2006-01-31 00:51:50 +08:00
|
|
|
|
|
|
|
|
2006-02-09 02:47:37 +08:00
|
|
|
/**
|
|
|
|
Find the beginning and end of the job definition under the cursor
|
2006-02-19 09:54:38 +08:00
|
|
|
|
|
|
|
\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
|
2006-02-09 02:47:37 +08:00
|
|
|
*/
|
2006-01-31 00:51:50 +08:00
|
|
|
void parse_util_job_extent( const wchar_t *buff,
|
2006-02-19 09:54:38 +08:00
|
|
|
int cursor_pos,
|
2006-06-14 21:22:40 +08:00
|
|
|
wchar_t **a,
|
|
|
|
wchar_t **b );
|
2006-01-31 00:51:50 +08:00
|
|
|
|
2006-02-09 02:47:37 +08:00
|
|
|
/**
|
2006-06-20 08:50:10 +08:00
|
|
|
Find the beginning and end of the token under the cursor and the
|
|
|
|
toekn before the current token. Any combination of tok_begin,
|
|
|
|
tok_end, prev_begin and prev_end may be null.
|
2006-02-19 09:54:38 +08:00
|
|
|
|
|
|
|
\param buff the string to search for subshells
|
|
|
|
\param cursor_pos the position of the cursor
|
2006-06-20 08:50:10 +08:00
|
|
|
\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
|
2006-02-09 02:47:37 +08:00
|
|
|
*/
|
2006-01-31 00:51:50 +08:00
|
|
|
void parse_util_token_extent( const wchar_t *buff,
|
|
|
|
int cursor_pos,
|
2006-06-14 21:22:40 +08:00
|
|
|
wchar_t **tok_begin,
|
|
|
|
wchar_t **tok_end,
|
|
|
|
wchar_t **prev_begin,
|
|
|
|
wchar_t **prev_end );
|
2006-01-31 00:51:50 +08:00
|
|
|
|
2006-02-09 02:47:37 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
Get the linenumber at the specified character offset
|
|
|
|
*/
|
2006-02-05 21:10:35 +08:00
|
|
|
int parse_util_lineno( const wchar_t *str, int len );
|
|
|
|
|
2007-09-21 22:05:49 +08:00
|
|
|
/**
|
|
|
|
Calculate the line number of the specified cursor position
|
|
|
|
*/
|
|
|
|
int parse_util_get_line_from_offset( wchar_t *buff, int pos );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Get the offset of the first character on the specified line
|
|
|
|
*/
|
|
|
|
int parse_util_get_offset_from_line( wchar_t *buff, int line );
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
Return the total offset of the buffer for the cursor position nearest to the specified poition
|
|
|
|
*/
|
|
|
|
int parse_util_get_offset( wchar_t *buff, int line, int line_offset );
|
|
|
|
|
|
|
|
|
2006-02-09 02:47:37 +08:00
|
|
|
/**
|
|
|
|
Autoload the specified file, if it exists in the specified path. Do
|
2006-07-12 22:22:42 +08:00
|
|
|
not load it multiple times unless it's timestamp changes or
|
|
|
|
parse_util_unload is called.
|
2006-02-09 02:47:37 +08:00
|
|
|
|
2006-10-11 06:45:46 +08:00
|
|
|
Autoloading one file may unload another.
|
|
|
|
|
2006-02-09 02:47:37 +08:00
|
|
|
\param cmd the filename to search for. The suffix '.fish' is always added to this name
|
2006-07-12 22:22:42 +08:00
|
|
|
\param path_var_name the environment variable giving the search path
|
2006-10-19 19:46:32 +08:00
|
|
|
\param on_unload a callback function to run if a suitable file is found, which has not already been run. unload will also be called for old files which are unloaded.
|
2006-02-09 02:47:37 +08:00
|
|
|
\param reload wheter to recheck file timestamps on already loaded files
|
|
|
|
*/
|
2006-02-08 17:20:05 +08:00
|
|
|
int parse_util_load( const wchar_t *cmd,
|
2006-02-20 01:01:16 +08:00
|
|
|
const wchar_t *path_var_name,
|
2006-10-19 19:46:32 +08:00
|
|
|
void (*on_unload)(const wchar_t *cmd),
|
2006-02-08 17:20:05 +08:00
|
|
|
int reload );
|
|
|
|
|
2006-02-19 09:54:38 +08:00
|
|
|
/**
|
2006-07-12 22:22:42 +08:00
|
|
|
Reset the loader for the specified path variable. This will cause
|
|
|
|
all information on loaded files in the specified directory to be
|
|
|
|
reset.
|
|
|
|
|
|
|
|
\param path_var_name the environment variable giving the search path
|
2006-10-19 19:46:32 +08:00
|
|
|
\param on_unload a callback function which will be called before (re)loading a file, may be used to unload the previous file.
|
2006-07-12 22:22:42 +08:00
|
|
|
*/
|
|
|
|
void parse_util_load_reset( const wchar_t *path_var_name,
|
2006-10-19 19:46:32 +08:00
|
|
|
void (*on_unload)(const wchar_t *cmd) );
|
2006-07-12 22:22:42 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
Tell the autoloader that the specified file, in the specified path,
|
|
|
|
is no longer loaded.
|
|
|
|
|
|
|
|
\param cmd the filename to search for. The suffix '.fish' is always added to this name
|
|
|
|
\param path_var_name the environment variable giving the search path
|
2006-10-19 19:46:32 +08:00
|
|
|
\param on_unload a callback function which will be called before (re)loading a file, may be used to unload the previous file.
|
2006-07-12 22:22:42 +08:00
|
|
|
\return non-zero if the file was removed, zero if the file had not yet been loaded
|
2006-02-19 09:54:38 +08:00
|
|
|
*/
|
2006-07-12 22:22:42 +08:00
|
|
|
int parse_util_unload( const wchar_t *cmd,
|
|
|
|
const wchar_t *path_var_name,
|
2006-10-19 19:46:32 +08:00
|
|
|
void (*on_unload)(const wchar_t *cmd) );
|
2006-02-15 10:46:44 +08:00
|
|
|
|
2006-02-15 10:24:15 +08:00
|
|
|
/**
|
|
|
|
Set the argv environment variable to the specified null-terminated
|
2006-02-19 09:54:38 +08:00
|
|
|
array of strings.
|
2006-02-15 10:24:15 +08:00
|
|
|
*/
|
2007-04-17 04:06:11 +08:00
|
|
|
void parse_util_set_argv( wchar_t **argv, array_list_t *named_arguments );
|
2006-02-15 10:24:15 +08:00
|
|
|
|
2006-02-19 09:14:32 +08:00
|
|
|
/**
|
2006-02-19 09:54:38 +08:00
|
|
|
Make a duplicate of the specified string, unescape wildcard
|
|
|
|
characters but not performing any other character transformation.
|
2006-02-19 09:14:32 +08:00
|
|
|
*/
|
|
|
|
wchar_t *parse_util_unescape_wildcards( const wchar_t *in );
|
|
|
|
|
2007-04-22 17:50:26 +08:00
|
|
|
|
|
|
|
|
2006-01-31 00:51:50 +08:00
|
|
|
#endif
|