2005-09-20 21:26:39 +08:00
|
|
|
/** \file common.h
|
|
|
|
Prototypes for various functions, mostly string utilities, that are used by most parts of fish.
|
|
|
|
*/
|
|
|
|
|
2005-10-04 23:11:39 +08:00
|
|
|
#ifndef FISH_COMMON_H
|
2005-10-24 23:26:25 +08:00
|
|
|
/**
|
|
|
|
Header guard
|
|
|
|
*/
|
2005-10-04 23:11:39 +08:00
|
|
|
#define FISH_COMMON_H
|
|
|
|
|
|
|
|
#include <wchar.h>
|
|
|
|
#include <termios.h>
|
|
|
|
|
|
|
|
#include "util.h"
|
2005-09-20 21:26:39 +08:00
|
|
|
|
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
Under curses, tputs expects an int (*func)(char) as its last
|
|
|
|
parameter, but in ncurses, tputs expects a int (*func)(int) as its
|
|
|
|
last parameter. tputs_arg_t is defined to always be what tputs
|
|
|
|
expects. Hopefully.
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef NCURSES_VERSION
|
|
|
|
typedef int tputs_arg_t;
|
|
|
|
#else
|
|
|
|
typedef char tputs_arg_t;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
Maximum number of bytes used by a single utf-8 character
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
|
|
|
#define MAX_UTF8_BYTES 6
|
|
|
|
|
|
|
|
/**
|
|
|
|
Color code for set_color. Does not update the color.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define FISH_COLOR_IGNORE -1
|
|
|
|
|
|
|
|
/**
|
|
|
|
Color code for set_color. Sets the default color.
|
|
|
|
*/
|
|
|
|
#define FISH_COLOR_RESET -2
|
|
|
|
|
2005-11-03 00:49:13 +08:00
|
|
|
/**
|
|
|
|
Save the shell mode on startup so we can restore them on exit
|
|
|
|
*/
|
2005-09-20 21:26:39 +08:00
|
|
|
extern struct termios shell_modes;
|
|
|
|
|
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
The character to use where the text has been truncated. Is an
|
|
|
|
ellipsis on unicode system and a $ on other systems.
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
|
|
|
extern wchar_t ellipsis_char;
|
|
|
|
|
|
|
|
/**
|
|
|
|
The maximum number of charset convertion errors to report
|
|
|
|
*/
|
|
|
|
extern int error_max;
|
|
|
|
|
2005-09-25 03:31:17 +08:00
|
|
|
/**
|
|
|
|
The verbosity of fish
|
|
|
|
*/
|
|
|
|
extern int debug_level;
|
|
|
|
|
2005-09-20 21:26:39 +08:00
|
|
|
/**
|
|
|
|
Profiling flag. True if commands should be profiled.
|
|
|
|
*/
|
|
|
|
extern char *profile;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Name of the current program. Should be set at startup. Used by the
|
|
|
|
debug function.
|
|
|
|
*/
|
|
|
|
extern wchar_t *program_name;
|
2005-10-25 17:39:45 +08:00
|
|
|
|
2005-09-20 21:26:39 +08:00
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
Take an array_list_t containing wide strings and converts them to a
|
|
|
|
single null-terminated wchar_t **.
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
|
|
|
wchar_t **list_to_char_arr( array_list_t *l );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Read a line from the stream f into the buffer buff of length len. If
|
|
|
|
buff is to small, it will be reallocated, and both buff and len will
|
|
|
|
be updated to reflect this. Returns the number of bytes read or -1
|
|
|
|
on failiure.
|
|
|
|
|
|
|
|
If the carriage return character is encountered, it is
|
|
|
|
ignored. fgetws() considers the line to end if reading the file
|
|
|
|
results in either a newline (L'\n') character, the null (L'\\0')
|
|
|
|
character or the end of file (WEOF) character.
|
|
|
|
*/
|
|
|
|
int fgetws2( wchar_t **buff, int *len, FILE *f );
|
|
|
|
|
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
Sorts a list of wide strings according to the wcsfilecmp-function
|
|
|
|
from the util library
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
|
|
|
void sort_list( array_list_t *comp );
|
|
|
|
|
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
Returns a newly allocated wide character string equivalent of the
|
|
|
|
specified multibyte character string
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
|
|
|
wchar_t *str2wcs( const char *in );
|
|
|
|
|
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
Returns a newly allocated multibyte character string equivalent of
|
|
|
|
the specified wide character string
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
|
|
|
char *wcs2str( const wchar_t *in );
|
|
|
|
|
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
Returns a newly allocated wide character string array equivalent of
|
|
|
|
the specified multibyte character string array
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
|
|
|
char **wcsv2strv( const wchar_t **in );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns a newly allocated multibyte character string array equivalent of the specified wide character string array
|
|
|
|
*/
|
|
|
|
wchar_t **strv2wcsv( const char **in );
|
|
|
|
|
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
Returns a newly allocated concatenation of the specified wide
|
|
|
|
character strings
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
|
|
|
wchar_t *wcsdupcat( const wchar_t *a, const wchar_t *b );
|
|
|
|
|
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
Returns a newly allocated concatenation of the specified wide
|
|
|
|
character strings. The last argument must be a null pointer.
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
|
|
|
wchar_t *wcsdupcat2( const wchar_t *a, ... );
|
|
|
|
|
|
|
|
|
2005-11-03 00:49:13 +08:00
|
|
|
/**
|
|
|
|
Appends src to string dst of size siz (unlike wcsncat, siz is the
|
|
|
|
full size of dst, not space left). At most siz-1 characters will be
|
|
|
|
copied. Always NUL terminates (unless siz <= wcslen(dst)). Returns
|
|
|
|
wcslen(src) + MIN(siz, wcslen(initial dst)). If retval >= siz,
|
|
|
|
truncation occurred.
|
2005-09-20 21:26:39 +08:00
|
|
|
|
2005-11-03 00:49:13 +08:00
|
|
|
This is the OpenBSD strlcat function, modified for wide characters,
|
|
|
|
and renamed to reflect this change.
|
|
|
|
|
|
|
|
*/
|
|
|
|
size_t wcslcat( wchar_t *dst, const wchar_t *src, size_t siz );
|
2005-09-20 21:26:39 +08:00
|
|
|
|
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
Copy src to string dst of size siz. At most siz-1 characters will
|
|
|
|
be copied. Always NUL terminates (unless siz == 0). Returns
|
|
|
|
wcslen(src); if retval >= siz, truncation occurred.
|
|
|
|
|
|
|
|
This is the OpenBSD strlcpy function, modified for wide characters,
|
|
|
|
and renamed to reflect this change.
|
|
|
|
*/
|
|
|
|
size_t wcslcpy( wchar_t *dst, const wchar_t *src, size_t siz );
|
|
|
|
|
2005-09-20 21:26:39 +08:00
|
|
|
/**
|
|
|
|
Test if the given string is a valid variable name
|
|
|
|
*/
|
|
|
|
|
|
|
|
int wcsvarname( wchar_t *str );
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
A wcswidth workalike. Fish uses this since the regular wcswidth seems flaky.
|
|
|
|
*/
|
|
|
|
int my_wcswidth( const wchar_t *c );
|
|
|
|
|
|
|
|
/**
|
2005-11-03 00:49:13 +08:00
|
|
|
This functions returns the end of the quoted substring beginning at
|
|
|
|
\c in. It can handle both single and double quotes. Returns 0 on
|
|
|
|
error.
|
|
|
|
|
|
|
|
\param in the position of the opening quote
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
|
|
|
wchar_t *quote_end( const wchar_t *in );
|
|
|
|
|
|
|
|
/**
|
|
|
|
A call to this function will reset the error counter. Some
|
|
|
|
functions print out non-critical error messages. These should check
|
|
|
|
the error_count before, and skip printing the message if
|
|
|
|
MAX_ERROR_COUNT messages have been printed. The error_reset()
|
|
|
|
should be called after each interactive command executes, to allow
|
|
|
|
new messages to be printed.
|
|
|
|
*/
|
|
|
|
void error_reset();
|
|
|
|
|
|
|
|
/**
|
2006-01-09 07:00:49 +08:00
|
|
|
This function behaves exactly like a wide character equivalent of
|
|
|
|
the C function setlocale, except that it will also try to detect if
|
|
|
|
the user is using a Unicode character set, and if so, use the
|
|
|
|
unicode ellipsis character as ellipsis, instead of '$'.
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
2006-01-09 07:00:49 +08:00
|
|
|
const wchar_t *wsetlocale( int category, const wchar_t *locale );
|
2005-09-20 21:26:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
Checks if \c needle is included in the list of strings specified
|
|
|
|
|
|
|
|
\param needle the string to search for in the list
|
|
|
|
*/
|
|
|
|
int contains_str( const wchar_t *needle, ... );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Call read while blocking the SIGCHLD signal. Should only be called
|
|
|
|
if you _know_ there is data available for reading.
|
|
|
|
*/
|
|
|
|
int read_blocked(int fd, void *buf, size_t count);
|
|
|
|
|
|
|
|
/**
|
|
|
|
This is for writing process notification messages. Has to write to
|
|
|
|
stdout, so clr_eol and such functions will work correctly. Not an
|
|
|
|
issue since this function is only used in interactive mode anyway.
|
|
|
|
*/
|
|
|
|
int writeb( tputs_arg_t b );
|
|
|
|
|
2005-10-24 23:26:25 +08:00
|
|
|
/**
|
|
|
|
Exit program at once, leaving an error message about running out of memory
|
|
|
|
*/
|
2005-09-20 21:26:39 +08:00
|
|
|
void die_mem();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Clean up
|
|
|
|
*/
|
|
|
|
void common_destroy();
|
|
|
|
|
|
|
|
/**
|
2005-10-14 19:40:33 +08:00
|
|
|
Issue a debug message with printf-style string formating and
|
|
|
|
automatic line breaking. The string will begin with the string \c
|
|
|
|
program_name, followed by a colon and a whitespace.
|
2005-09-20 21:26:39 +08:00
|
|
|
|
2005-10-14 19:40:33 +08:00
|
|
|
\param level the priority of the message. Lower number means higher priority. Messages with a priority_number higher than \c debug_level will be ignored..
|
2005-10-24 23:26:25 +08:00
|
|
|
\param msg the message format string.
|
2005-10-14 19:40:33 +08:00
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
<code>debug( 1, L"Pi = %.3f", M_PI );</code>
|
|
|
|
|
|
|
|
will print the string 'fish: Pi = 3.141', given that debug_level is 1 or higher, and that program_name is 'fish'.
|
2005-09-20 21:26:39 +08:00
|
|
|
*/
|
2006-01-04 20:51:02 +08:00
|
|
|
void debug( int level, const wchar_t *msg, ... );
|
2005-09-20 21:26:39 +08:00
|
|
|
|
|
|
|
/**
|
2005-10-14 19:40:33 +08:00
|
|
|
Replace special characters with backslash escape sequences. Newline is
|
2005-09-20 21:26:39 +08:00
|
|
|
replaced with \n, etc.
|
|
|
|
|
|
|
|
\param in The string to be escaped
|
|
|
|
\param escape_all Whether all characters wich hold special meaning in fish (Pipe, semicolon, etc,) should be escaped, or only unprintable characters
|
|
|
|
\return The escaped string, or 0 if there is not enough memory
|
|
|
|
*/
|
|
|
|
|
2005-10-07 18:36:51 +08:00
|
|
|
wchar_t *escape( const wchar_t *in,
|
2005-09-20 21:26:39 +08:00
|
|
|
int escape_all );
|
|
|
|
|
2005-10-24 23:26:25 +08:00
|
|
|
/**
|
|
|
|
Expand backslashed escapes and substitute them with their unescaped
|
|
|
|
counterparts. Also optionally change the wildcards, the tilde
|
|
|
|
character and a few more into constants which are defined in a
|
|
|
|
private use area of Unicode. This assumes wchar_t is a unicode
|
2005-10-25 19:03:52 +08:00
|
|
|
character set.
|
2005-10-24 23:26:25 +08:00
|
|
|
|
|
|
|
The result must be free()d. The original string is not modified. If
|
|
|
|
an invalid sequence is specified, 0 is returned.
|
|
|
|
|
|
|
|
*/
|
|
|
|
wchar_t *unescape( const wchar_t * in,
|
|
|
|
int escape_special );
|
2005-09-20 21:26:39 +08:00
|
|
|
|
2005-10-24 23:26:25 +08:00
|
|
|
/**
|
|
|
|
Block SIGCHLD. Calls to block/unblock may be nested, and only once the nest count reaches zero wiull the block be removed.
|
|
|
|
*/
|
2005-09-20 21:26:39 +08:00
|
|
|
void block();
|
2005-10-24 23:26:25 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
undo call to block().
|
|
|
|
*/
|
2005-09-20 21:26:39 +08:00
|
|
|
void unblock();
|
2005-09-28 09:43:09 +08:00
|
|
|
|
2005-10-24 23:26:25 +08:00
|
|
|
/**
|
|
|
|
Attempt to acquire a lock based on a lockfile, waiting LOCKPOLLINTERVAL
|
|
|
|
milliseconds between polls and timing out after timeout seconds,
|
|
|
|
thereafter forcibly attempting to obtain the lock if force is non-zero.
|
|
|
|
Returns 1 on success, 0 on failure.
|
|
|
|
To release the lock the lockfile must be unlinked.
|
|
|
|
A unique temporary file named by appending characters to the lockfile name
|
|
|
|
is used; any pre-existing file of the same name is subject to deletion.
|
|
|
|
*/
|
2005-10-14 19:40:33 +08:00
|
|
|
int acquire_lock_file( const char *lockfile, const int timeout, int force );
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the width of the terminal window, so that not all
|
|
|
|
functions that use these values continually have to keep track of
|
|
|
|
it.
|
|
|
|
|
|
|
|
Only works if common_handle_winch is registered to handle winch signals.
|
|
|
|
*/
|
|
|
|
int common_get_width();
|
|
|
|
/**
|
|
|
|
Returns the height of the terminal window, so that not all
|
|
|
|
functions that use these values continually have to keep track of
|
|
|
|
it.
|
|
|
|
|
|
|
|
Only works if common_handle_winch is registered to handle winch signals.
|
|
|
|
*/
|
|
|
|
int common_get_height();
|
|
|
|
|
2005-10-24 23:26:25 +08:00
|
|
|
/**
|
2005-10-14 19:40:33 +08:00
|
|
|
Handle a window change event by looking up the new window size and
|
|
|
|
saving it in an internal variable used by common_get_wisth and
|
|
|
|
common_get_height().
|
|
|
|
*/
|
|
|
|
void common_handle_winch( int signal );
|
|
|
|
|
2006-01-15 19:58:05 +08:00
|
|
|
/**
|
|
|
|
Write paragraph of output to screen. Ignore newlines in message and
|
|
|
|
perform internal line-breaking.
|
|
|
|
*/
|
|
|
|
void write_screen( const wchar_t *msg );
|
|
|
|
|
|
|
|
|
2005-10-04 23:11:39 +08:00
|
|
|
#endif
|
|
|
|
|