Add lots of new code comments.

darcs-hash:20080113164747-75c98-9d0cefd27be7aef7ba60772616d9da7e6bb52912.gz
This commit is contained in:
liljencrantz 2008-01-14 02:47:47 +10:00
parent ab3502fc8b
commit 87db9517e9
31 changed files with 399 additions and 94 deletions

View file

@ -407,6 +407,9 @@ static void builtin_missing_argument( const wchar_t *cmd, const wchar_t *opt )
#include "builtin_ulimit.c" #include "builtin_ulimit.c"
#include "builtin_jobs.c" #include "builtin_jobs.c"
/**
List all current key bindings
*/
static void builtin_bind_list() static void builtin_bind_list()
{ {
array_list_t lst; array_list_t lst;
@ -442,6 +445,13 @@ static void builtin_bind_list()
al_destroy( &lst ); al_destroy( &lst );
} }
/**
Print terminfo key binding names to string buffer used for standard output.
\param all if set, all terminfo key binding names will be
printed. If not set, only ones that are defined for this terminal
are printed.
*/
static void builtin_bind_key_names( int all ) static void builtin_bind_key_names( int all )
{ {
array_list_t lst; array_list_t lst;
@ -460,6 +470,10 @@ static void builtin_bind_key_names( int all )
al_destroy( &lst ); al_destroy( &lst );
} }
/**
Print all the special key binding functions to string buffer used for standard output.
*/
static void builtin_bind_function_names() static void builtin_bind_function_names()
{ {
array_list_t lst; array_list_t lst;
@ -478,6 +492,9 @@ static void builtin_bind_function_names()
al_destroy( &lst ); al_destroy( &lst );
} }
/**
Add specified key binding.
*/
static int builtin_bind_add( wchar_t *seq, wchar_t *cmd, int terminfo ) static int builtin_bind_add( wchar_t *seq, wchar_t *cmd, int terminfo )
{ {
@ -526,6 +543,12 @@ static int builtin_bind_add( wchar_t *seq, wchar_t *cmd, int terminfo )
} }
/**
Erase specified key bindings
\param seq an array of all key bindings to erase
\param all if specified, _all_ key bindings will be erased
*/
static void builtin_bind_erase( wchar_t **seq, int all ) static void builtin_bind_erase( wchar_t **seq, int all )
{ {
if( all ) if( all )
@ -983,7 +1006,9 @@ static int builtin_builtin( wchar_t **argv )
return STATUS_BUILTIN_OK; return STATUS_BUILTIN_OK;
} }
/**
Implementation of the builtin emit command, used to create events.
*/
static int builtin_emit( wchar_t **argv ) static int builtin_emit( wchar_t **argv )
{ {
int argc=builtin_count_args( argv ); int argc=builtin_count_args( argv );
@ -2660,7 +2685,10 @@ static int builtin_cd( wchar_t **argv )
return res; return res;
} }
/**
Implementation of the builtin count command, used to count the
number of arguments sent to it.
*/
static int builtin_count( wchar_t ** argv ) static int builtin_count( wchar_t ** argv )
{ {
int argc; int argc;
@ -2669,6 +2697,10 @@ static int builtin_count( wchar_t ** argv )
return !(argc-1); return !(argc-1);
} }
/**
Implementation of the builtin contains command, used to check if a
specified string is part of a list.
*/
static int builtin_contains( wchar_t ** argv ) static int builtin_contains( wchar_t ** argv )
{ {
int argc; int argc;
@ -3408,6 +3440,11 @@ static int builtin_break_continue( wchar_t **argv )
return STATUS_BUILTIN_OK; return STATUS_BUILTIN_OK;
} }
/**
Implementation of the builtin count command, used to launch the
interactive debugger.
*/
static int builtin_breakpoint( wchar_t **argv ) static int builtin_breakpoint( wchar_t **argv )
{ {
parser_push_block( BREAKPOINT ); parser_push_block( BREAKPOINT );

View file

@ -129,6 +129,7 @@ int builtin_exists( wchar_t *cmd );
of the builtin. The list is terminated by a of the builtin. The list is terminated by a
null pointer. This syntax resembles the syntax null pointer. This syntax resembles the syntax
for exec. for exec.
\param io the io redirections to perform on this builtin.
\return the exit status of the builtin command \return the exit status of the builtin command
*/ */

View file

@ -52,7 +52,15 @@ enum
} }
; ;
/**
Pointer to what the commandline builtin considers to be the current
contents of the command line buffer.
*/
static wchar_t *current_buffer=0; static wchar_t *current_buffer=0;
/**
What the commandline builtin considers to be the current cursor
position.
*/
static int current_cursor_pos = -1; static int current_cursor_pos = -1;
/** /**

View file

@ -702,6 +702,11 @@ void write_screen( const wchar_t *msg, string_buffer_t *buff )
sb_append_char( buff, L'\n' ); sb_append_char( buff, L'\n' );
} }
/**
Perform string escaping of a strinng by only quoting it. Assumes
the string has already been checked for characters that can not be
escaped this way.
*/
static wchar_t *escape_simple( const wchar_t *in ) static wchar_t *escape_simple( const wchar_t *in )
{ {
wchar_t *out; wchar_t *out;

View file

@ -40,11 +40,12 @@
*/ */
#define BYTE_MAX 0xffu #define BYTE_MAX 0xffu
/* /**
Escape special fish syntax characters liek the semicolon Escape special fish syntax characters like the semicolon
*/ */
#define UNESCAPE_SPECIAL 1 #define UNESCAPE_SPECIAL 1
/*
/**
Allow incomplete escape sequences Allow incomplete escape sequences
*/ */
#define UNESCAPE_INCOMPLETE 2 #define UNESCAPE_INCOMPLETE 2
@ -155,10 +156,16 @@ extern wchar_t *program_name;
*/ */
#define N_(wstr) wstr #define N_(wstr) wstr
/**
Check if the specified stringelement is a part of the specified string list
*/
#define contains( str,... ) contains_internal( str, __VA_ARGS__, (void *)0 ) #define contains( str,... ) contains_internal( str, __VA_ARGS__, (void *)0 )
/**
Concatenate all the specified strings into a single newly allocated one
*/
#define wcsdupcat( str,... ) wcsdupcat_internal( str, __VA_ARGS__, (void *)0 ) #define wcsdupcat( str,... ) wcsdupcat_internal( str, __VA_ARGS__, (void *)0 )
/* /**
Print a stack trace to stderr Print a stack trace to stderr
*/ */
void show_stackframe(); void show_stackframe();

View file

@ -163,7 +163,7 @@ typedef struct
\param comp A space separated list of completions which may contain subshells. \param comp A space separated list of completions which may contain subshells.
\param desc A description of the completion. \param desc A description of the completion.
\param condition a command to be run to check it this completion should be used. If \c condition is empty, the completion is always used. \param condition a command to be run to check it this completion should be used. If \c condition is empty, the completion is always used.
\param flags A set of completion flags
*/ */
void complete_add( const wchar_t *cmd, void complete_add( const wchar_t *cmd,
int cmd_type, int cmd_type,
@ -242,7 +242,7 @@ void complete_load( const wchar_t *cmd, int reload );
Create a new completion entry Create a new completion entry
\param context The halloc context to use for allocating new memory \param context The halloc context to use for allocating new memory
\pram comp The completion string \param comp The completion string
\param desc The description of the completion \param desc The description of the completion
\param flags completion flags \param flags completion flags
*/ */

6
env.c
View file

@ -480,6 +480,9 @@ static void setup_path()
al_destroy( &l ); al_destroy( &l );
} }
/**
Set up default values for various variables if not defined.
*/
static void env_set_defaults() static void env_set_defaults()
{ {
@ -1442,6 +1445,9 @@ static void export_func1( void *k, void *v, void *aux )
} }
/**
Get list of all exported variables
*/
static void get_exported( env_node_t *n, hash_table_t *h ) static void get_exported( env_node_t *n, hash_table_t *h )
{ {
if( !n ) if( !n )

View file

@ -176,8 +176,10 @@ static char *iconv_wide_names_2[]=
} }
; ;
/**
wchar_t *utf2wcs( const char *in ) Convert utf-8 string to wide string
*/
static wchar_t *utf2wcs( const char *in )
{ {
iconv_t cd=(iconv_t) -1; iconv_t cd=(iconv_t) -1;
int i,j; int i,j;
@ -287,7 +289,10 @@ wchar_t *utf2wcs( const char *in )
return out; return out;
} }
char *wcs2utf( const wchar_t *in ) /**
Convert wide string to utf-8
*/
static char *wcs2utf( const wchar_t *in )
{ {
iconv_t cd=(iconv_t) -1; iconv_t cd=(iconv_t) -1;
int i,j; int i,j;
@ -404,6 +409,9 @@ void env_universal_common_destroy()
hash_destroy( &env_universal_var ); hash_destroy( &env_universal_var );
} }
/**
Read one byte of date form the specified connection
*/
static int read_byte( connection_t *src ) static int read_byte( connection_t *src )
{ {
@ -740,6 +748,9 @@ void try_send_all( connection_t *c )
} }
} }
/**
Escape specified string
*/
static wchar_t *full_escape( const wchar_t *in ) static wchar_t *full_escape( const wchar_t *in )
{ {
string_buffer_t out; string_buffer_t out;

3
exec.c
View file

@ -830,6 +830,9 @@ static pid_t exec_fork()
} }
/**
Perform output from builtins
*/
static void do_builtin_io( wchar_t *out, wchar_t *err ) static void do_builtin_io( wchar_t *out, wchar_t *err )
{ {

View file

@ -764,7 +764,9 @@ void expand_variable_error( const wchar_t *token, int token_pos, int error_pos )
} }
} }
/**
Parse an array slicing specification
*/
static int parse_slice( wchar_t *in, wchar_t **end_ptr, array_list_t *idx ) static int parse_slice( wchar_t *in, wchar_t **end_ptr, array_list_t *idx )
{ {

View file

@ -54,9 +54,18 @@ typedef char tputs_arg_t;
#endif #endif
#ifndef HAVE_WINSIZE #ifndef HAVE_WINSIZE
/**
Structure used to get the size of a terminal window
*/
struct winsize struct winsize
{ {
/**
Number of rows
*/
unsigned short ws_row; unsigned short ws_row;
/**
Number of columns
*/
unsigned short ws_col; unsigned short ws_col;
} }
; ;
@ -400,17 +409,35 @@ extern int _nl_msg_cat_cntr;
#ifndef HAVE_KILLPG #ifndef HAVE_KILLPG
/**
Send specified signal to specified process group.
*/
int killpg( int pgr, int sig ); int killpg( int pgr, int sig );
#endif #endif
#ifndef HAVE_WORKING_GETOPT_LONG #ifndef HAVE_WORKING_GETOPT_LONG
/**
Struct describing a long getopt option
*/
struct option struct option
{ {
/**
Name of option
*/
const char *name; const char *name;
/**
Flag
*/
int has_arg; int has_arg;
/**
Flag
*/
int *flag; int *flag;
/**
Return value
*/
int val; int val;
} }
; ;

3
fish.c
View file

@ -106,10 +106,9 @@ static int read_init()
} }
/* /**
Parse the argument list, return the index of the first non-switch Parse the argument list, return the index of the first non-switch
arguments. arguments.
*/ */
static int fish_parse_opt( int argc, char **argv, char **cmd_ptr ) static int fish_parse_opt( int argc, char **argv, char **cmd_ptr )
{ {

View file

@ -16,7 +16,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/ */
/** \file main.c /** \file fish_indent.c
The fish_indent proegram. The fish_indent proegram.
*/ */
@ -48,7 +48,10 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/ */
#define GETOPT_STRING "hvi" #define GETOPT_STRING "hvi"
void read_file( FILE *f, string_buffer_t *b ) /**
Read the entire contents of a file into the specified string_Buffer_t
*/
static void read_file( FILE *f, string_buffer_t *b )
{ {
while( 1 ) while( 1 )
{ {
@ -62,6 +65,9 @@ void read_file( FILE *f, string_buffer_t *b )
} }
} }
/**
Insert the specified number of tabe into the output buffer
*/
static void insert_tabs( string_buffer_t *out, int indent ) static void insert_tabs( string_buffer_t *out, int indent )
{ {
int i; int i;
@ -73,6 +79,9 @@ static void insert_tabs( string_buffer_t *out, int indent )
} }
/**
Indent the specified input
*/
static int indent( string_buffer_t *out, wchar_t *in, int flags ) static int indent( string_buffer_t *out, wchar_t *in, int flags )
{ {
tokenizer tok; tokenizer tok;
@ -217,7 +226,12 @@ static int indent( string_buffer_t *out, wchar_t *in, int flags )
return res; return res;
} }
wchar_t *trim( wchar_t *in ) /**
Remove any prefix and suffix newlines from the specified
string. Does not allocete a new string, edits the string in place
and returns a pointer somewhere into the string.
*/
static wchar_t *trim( wchar_t *in )
{ {
wchar_t *end; wchar_t *end;
@ -245,7 +259,9 @@ wchar_t *trim( wchar_t *in )
} }
/**
The main mathod. Run the program.
*/
int main( int argc, char **argv ) int main( int argc, char **argv )
{ {
string_buffer_t sb_in; string_buffer_t sb_in;

View file

@ -750,6 +750,9 @@ static void test_expand()
} }
/**
Test path functions
*/
static void test_path() static void test_path()
{ {
say( L"Testing path functions" ); say( L"Testing path functions" );

View file

@ -41,9 +41,9 @@
typedef struct typedef struct
{ {
/** Function definition */ /** Function definition */
wchar_t *cmd; wchar_t *definition;
/** Function description */ /** Function description */
wchar_t *desc; wchar_t *description;
/** /**
File where this function was defined File where this function was defined
*/ */
@ -53,6 +53,9 @@ typedef struct
*/ */
int definition_offset; int definition_offset;
/**
List of all named arguments for this function
*/
array_list_t *named_arguments; array_list_t *named_arguments;
@ -61,6 +64,10 @@ typedef struct
*/ */
int is_autoload; int is_autoload;
/**
Set to non-zero if invoking this function shadows the variables
of the underlying function.
*/
int shadows; int shadows;
} }
function_internal_data_t; function_internal_data_t;
@ -155,6 +162,9 @@ void function_init()
&hash_wcs_cmp ); &hash_wcs_cmp );
} }
/**
Clear specified value, but not key
*/
static void clear_entry( void *key, void *value ) static void clear_entry( void *key, void *value )
{ {
halloc_free( value ); halloc_free( value );
@ -180,7 +190,7 @@ void function_add( function_data_t *data )
d = halloc( 0, sizeof( function_internal_data_t ) ); d = halloc( 0, sizeof( function_internal_data_t ) );
d->definition_offset = parse_util_lineno( parser_get_buffer(), current_block->tok_pos )-1; d->definition_offset = parse_util_lineno( parser_get_buffer(), current_block->tok_pos )-1;
d->cmd = halloc_wcsdup( d, data->definition ); d->definition = halloc_wcsdup( d, data->definition );
if( data->named_arguments ) if( data->named_arguments )
{ {
@ -192,9 +202,9 @@ void function_add( function_data_t *data )
} }
} }
cmd_end = d->cmd + wcslen(d->cmd)-1; cmd_end = d->definition + wcslen(d->definition)-1;
d->desc = data->description?halloc_wcsdup( d, data->description ):0; d->description = data->description?halloc_wcsdup( d, data->description ):0;
d->definition_file = intern(reader_current_filename()); d->definition_file = intern(reader_current_filename());
d->is_autoload = is_autoload; d->is_autoload = is_autoload;
d->shadows = data->shadows; d->shadows = data->shadows;
@ -266,7 +276,7 @@ const wchar_t *function_get_definition( const wchar_t *name )
data = (function_internal_data_t *)hash_get( &function, name ); data = (function_internal_data_t *)hash_get( &function, name );
if( data == 0 ) if( data == 0 )
return 0; return 0;
return data->cmd; return data->definition;
} }
array_list_t *function_get_named_arguments( const wchar_t *name ) array_list_t *function_get_named_arguments( const wchar_t *name )
@ -307,7 +317,7 @@ const wchar_t *function_get_desc( const wchar_t *name )
if( data == 0 ) if( data == 0 )
return 0; return 0;
return _(data->desc); return _(data->description);
} }
void function_set_desc( const wchar_t *name, const wchar_t *desc ) void function_set_desc( const wchar_t *name, const wchar_t *desc )
@ -322,7 +332,7 @@ void function_set_desc( const wchar_t *name, const wchar_t *desc )
if( data == 0 ) if( data == 0 )
return; return;
data->desc = halloc_wcsdup( data, desc ); data->description = halloc_wcsdup( data, desc );
} }
/** /**

View file

@ -19,11 +19,30 @@
*/ */
typedef struct function_data typedef struct function_data
{ {
/**
Name of function
*/
wchar_t *name; wchar_t *name;
/**
Description of function
*/
wchar_t *description; wchar_t *description;
/**
Function definition
*/
wchar_t *definition; wchar_t *definition;
/**
List of all event handlers for this function
*/
array_list_t *events; array_list_t *events;
/**
List of all named arguments for this function
*/
array_list_t *named_arguments; array_list_t *named_arguments;
/**
Set to non-zero if invoking this function shadows the variables
of the underlying function.
*/
int shadows; int shadows;
} }
function_data_t; function_data_t;

View file

@ -78,6 +78,9 @@ typedef struct halloc
} }
halloc_t; halloc_t;
/**
Allign the specified pointer
*/
static char *align_ptr( char *in ) static char *align_ptr( char *in )
{ {
unsigned long step = maxi(sizeof(double),sizeof(void *)); unsigned long step = maxi(sizeof(double),sizeof(void *));
@ -87,6 +90,9 @@ static char *align_ptr( char *in )
return (char *)long_out; return (char *)long_out;
} }
/**
Allign specifies size_t
*/
static size_t align_sz( size_t in ) static size_t align_sz( size_t in )
{ {
size_t step = maxi(sizeof(double),sizeof(void *)); size_t step = maxi(sizeof(double),sizeof(void *));

View file

@ -252,6 +252,9 @@ static wchar_t *history_unescape_newlines( wchar_t *in )
return (wchar_t *)out->buff; return (wchar_t *)out->buff;
} }
/**
Check if the specified item is already loaded
*/
static int item_is_new( history_mode_t *m, void *d ) static int item_is_new( history_mode_t *m, void *d )
{ {
char *begin = (char *)d; char *begin = (char *)d;
@ -409,6 +412,9 @@ static void history_destroy_mode( history_mode_t *m )
} }
/**
Free all memory used by specified mistory mode
*/
static void history_destroy_mode_wrapper( void *n, history_mode_t *m ) static void history_destroy_mode_wrapper( void *n, history_mode_t *m )
{ {
halloc_free( m ); halloc_free( m );

25
input.c
View file

@ -232,6 +232,9 @@ static const wchar_t code_arr[] =
*/ */
static array_list_t mappings = {0,0,0}; static array_list_t mappings = {0,0,0};
/**
List of all terminfo mappings
*/
static array_list_t *terminfo_mappings = 0; static array_list_t *terminfo_mappings = 0;
@ -240,28 +243,18 @@ static array_list_t *terminfo_mappings = 0;
*/ */
static int is_init = 0; static int is_init = 0;
/**
Initialize terminfo.
*/
static void input_terminfo_init(); static void input_terminfo_init();
/**
Deallocate memory used by terminfo. Or at least try to. Terminfo leaks.
*/
static void input_terminfo_destroy(); static void input_terminfo_destroy();
/** /**
Returns the function description for the given function code. Returns the function description for the given function code.
*/ */
/*
static const wchar_t *input_get_desc( wchar_t c )
{
int i;
for( i = 0; i<(sizeof( code_arr )/sizeof(wchar_t)) ; i++ )
{
if( c == code_arr[i] )
{
return desc_arr[i];
}
}
return 0;
}
*/
void input_mapping_add( const wchar_t *sequence, void input_mapping_add( const wchar_t *sequence,
const wchar_t *command ) const wchar_t *command )

19
input.h
View file

@ -89,19 +89,26 @@ void input_unreadch( wint_t ch );
/** /**
Add a key mapping from the specified sequence Add a key mapping from the specified sequence to the specified command
\param mode the name of the mapping mode to add this mapping to \param sequence the sequence to bind
\param s the sequence \param command an input function that will be run whenever the key sequence occurs
\param d a description of the sequence
\param cmd an input function that will be run whenever the key sequence occurs
*/ */
void input_mapping_add( const wchar_t *sequence, const wchar_t *cmd ); void input_mapping_add( const wchar_t *sequence, const wchar_t *command );
/**
Insert all mapping names into the specified array_list_t
*/
void input_mapping_get_names( array_list_t *list ); void input_mapping_get_names( array_list_t *list );
/**
Erase binding for specified key sequence
*/
int input_mapping_erase( const wchar_t *sequence ); int input_mapping_erase( const wchar_t *sequence );
/**
Return the command bound to the specified key sequence
*/
const wchar_t *input_mapping_get( const wchar_t *sequence ); const wchar_t *input_mapping_get( const wchar_t *sequence );
/** /**

View file

@ -28,7 +28,7 @@ Implementation file for the low level input library
/** /**
Time in milliseconds to wait for another byte to be available for Time in milliseconds to wait for another byte to be available for
reading after \x1b is read before assuming that escape key was reading after \\x1b is read before assuming that escape key was
pressed, and not an escape sequence. pressed, and not an escape sequence.
*/ */
#define WAIT_ON_ESCAPE 10 #define WAIT_ON_ESCAPE 10

3
io.h
View file

@ -44,6 +44,9 @@ typedef struct io_data
} param2 } param2
; ;
/**
Set to true if this is an input io redirection
*/
int is_input; int is_input;
/** Pointer to the next IO redirection */ /** Pointer to the next IO redirection */

View file

@ -121,6 +121,9 @@ static char *writestr_buff = 0;
static int (*out)(char c) = &writeb_internal; static int (*out)(char c) = &writeb_internal;
/**
Name of terminal
*/
static wchar_t *current_term = 0; static wchar_t *current_term = 0;

View file

@ -73,7 +73,9 @@ enum
void set_color( int c, int c2 ); void set_color( int c, int c2 );
/**
Write specified multibyte string
*/
#define writembs( mbs ) \ #define writembs( mbs ) \
{ \ { \
char *tmp = mbs; \ char *tmp = mbs; \
@ -144,10 +146,18 @@ int writeb( tputs_arg_t b );
void output_set_writer( int (*writer)(char) ); void output_set_writer( int (*writer)(char) );
//typedef int (*func_ptr_t)(char); //typedef int (*func_ptr_t)(char);
/**
Return the current output writer
*/
int (*output_get_writer())(char) ; int (*output_get_writer())(char) ;
/**
Set the terminal name
*/
void output_set_term( wchar_t *term ); void output_set_term( wchar_t *term );
/**
Return the terminal name
*/
wchar_t *output_get_term(); wchar_t *output_get_term();
#endif #endif

10
path.h
View file

@ -9,6 +9,9 @@
#ifndef FISH_PATH_H #ifndef FISH_PATH_H
#define FISH_PATH_H #define FISH_PATH_H
/**
Return value for path_cdpath_get when locatied a rotten symlink
*/
#define EROTTEN 1 #define EROTTEN 1
/** /**
@ -48,6 +51,13 @@ wchar_t *path_get_path( void *context, const wchar_t *cmd );
*/ */
wchar_t *path_get_cdpath( void *context, wchar_t *in ); wchar_t *path_get_cdpath( void *context, wchar_t *in );
/**
Remove doulbe slashes and trailing slashes from a path,
e.g. transform foo//bar/ into foo/bar.
The returned string is allocated using the specified halloc
context.
*/
wchar_t *path_make_canonical( void *context, const wchar_t *path ); wchar_t *path_make_canonical( void *context, const wchar_t *path );

View file

@ -117,6 +117,9 @@ commence.
*/ */
#define DEFAULT_PROMPT L"echo \"$USER@\"; hostname|cut -d . -f 1; echo \" \"; pwd; printf '> ';" #define DEFAULT_PROMPT L"echo \"$USER@\"; hostname|cut -d . -f 1; echo \" \"; pwd; printf '> ';"
/**
The name of the function that prints the fish prompt
*/
#define PROMPT_FUNCTION_NAME L"fish_prompt" #define PROMPT_FUNCTION_NAME L"fish_prompt"
/** /**
@ -132,15 +135,40 @@ commence.
*/ */
#define READAHEAD_MAX 256 #define READAHEAD_MAX 256
/**
A mode for calling the reader_kill function. In this mode, the new
string is appended to the current contents of the kill buffer.
*/
#define KILL_APPEND 0 #define KILL_APPEND 0
/**
A mode for calling the reader_kill function. In this mode, the new
string is prepended to the current contents of the kill buffer.
*/
#define KILL_PREPEND 1 #define KILL_PREPEND 1
/**
History search mode. This value means that no search is currently
performed.
*/
#define NO_SEARCH 0 #define NO_SEARCH 0
/**
History search mode. This value means that we are perforing a line
history search.
*/
#define LINE_SEARCH 1 #define LINE_SEARCH 1
/**
History search mode. This value means that we are perforing a token
history search.
*/
#define TOKEN_SEARCH 2 #define TOKEN_SEARCH 2
/**
History search mode. This value means we are searching backwards.
*/
#define SEARCH_BACKWARD 0 #define SEARCH_BACKWARD 0
/**
History search mode. This value means we are searching forwards.
*/
#define SEARCH_FORWARD 1 #define SEARCH_FORWARD 1
/** /**
@ -155,6 +183,9 @@ typedef struct reader_data
*/ */
wchar_t *buff; wchar_t *buff;
/**
The representation of the current screen contents
*/
screen_t screen; screen_t screen;
/** /**
@ -252,6 +283,9 @@ typedef struct reader_data
*/ */
int prev_end_loop; int prev_end_loop;
/**
The current contents of the top item in the kill ring.
*/
string_buffer_t kill_item; string_buffer_t kill_item;
/** /**
@ -509,6 +543,9 @@ static int check_size()
} }
/**
Compare two completion entrys
*/
static int completion_cmp( const void *a, const void *b ) static int completion_cmp( const void *a, const void *b )
{ {
completion_t *c= *((completion_t **)a); completion_t *c= *((completion_t **)a);
@ -518,6 +555,9 @@ static int completion_cmp( const void *a, const void *b )
} }
/**
Sort an array_list_t containing compltion_t structs.
*/
static void sort_completion_list( array_list_t *comp ) static void sort_completion_list( array_list_t *comp )
{ {
qsort( comp->arr, qsort( comp->arr,
@ -949,9 +989,8 @@ static void get_param( wchar_t *cmd,
string. string.
\param val the string to insert \param val the string to insert
\param is_complete Whether this completion is the whole string or \param flags A union of all flags describing the completion to insert. See the completion_t struct for more information on possible values.
just the common prefix of several completions. If the former, end by
printing a space (and an end quote if the parameter is quoted).
*/ */
static void completion_insert( const wchar_t *val, int flags ) static void completion_insert( const wchar_t *val, int flags )
{ {
@ -1225,7 +1264,7 @@ static void run_pager( wchar_t *prefix, int is_quoted, array_list_t *comp )
io_buffer_destroy( in); io_buffer_destroy( in);
} }
/* /**
Flash the screen. This function only changed the color of the Flash the screen. This function only changed the color of the
current line, since the flash_screen sequnce is rather painful to current line, since the flash_screen sequnce is rather painful to
look at in most terminal emulators. look at in most terminal emulators.
@ -1801,7 +1840,7 @@ static void handle_token_history( int forward, int reset )
\param dir Direction to move/erase. 0 means move left, 1 means move right. \param dir Direction to move/erase. 0 means move left, 1 means move right.
\param erase Whether to erase the characters along the way or only move past them. \param erase Whether to erase the characters along the way or only move past them.
\param do_append if erase is true, this flag decides if the new kill item should be appended to the previous kill item. \param new if the new kill item should be appended to the previous kill item or not.
*/ */
static void move_word( int dir, int erase, int new ) static void move_word( int dir, int erase, int new )
{ {

View file

@ -86,6 +86,10 @@ static int try_sequence( char *seq, wchar_t *str )
return 0; return 0;
} }
/**
Returns the number of columns left until the next tab stop, given
the current cursor postion.
*/
static int next_tab_stop( int in ) static int next_tab_stop( int in )
{ {
/* /*
@ -759,6 +763,9 @@ static void s_update( screen_t *scr, wchar_t *prompt )
} }
/**
Returns non-zero if we are using a dumb terminal.
*/
static int is_dumb() static int is_dumb()
{ {
return ( !cursor_up || !cursor_down || !cursor_left || !cursor_right ); return ( !cursor_up || !cursor_down || !cursor_left || !cursor_right );

View file

@ -2,8 +2,12 @@
The screen library allows the interactive reader to write its The screen library allows the interactive reader to write its
output to screen efficiently by keeping an inetrnal representation output to screen efficiently by keeping an inetrnal representation
of the current screen contents and trying to find the most of the current screen contents and trying to find a reasonably
efficient way for transforming that to the desired screen content. efficient way for transforming that to the desired screen content.
The current implementation is less smart than ncurses allows
and can not for example move blocks of text around to handle text
insertion.
*/ */
#ifndef FISH_SCREEN_H #ifndef FISH_SCREEN_H
#define FISH_SCREEN_H #define FISH_SCREEN_H
@ -13,7 +17,7 @@
*/ */
typedef struct typedef struct
{ {
/* /**
The internal representation of the desired screen contents. The internal representation of the desired screen contents.
*/ */
array_list_t desired; array_list_t desired;
@ -35,7 +39,7 @@ typedef struct
*/ */
string_buffer_t actual_prompt; string_buffer_t actual_prompt;
/* /**
The actual width of the screen at the time of the last screen The actual width of the screen at the time of the last screen
write. write.
*/ */

27
util.c
View file

@ -50,6 +50,10 @@
*/ */
#define SB_MAX_SIZE 32767 #define SB_MAX_SIZE 32767
/**
Handle oom condition. Default action is to print a stack trace and
exit, but an alternative action can be specified.
*/
#define oom_handler( p ) \ #define oom_handler( p ) \
{ \ { \
if( oom_handler_internal == util_die_on_oom ) \ if( oom_handler_internal == util_die_on_oom ) \
@ -790,6 +794,10 @@ void al_destroy( array_list_t *l )
free( l->arr ); free( l->arr );
} }
/**
Real implementation of all al_push_* versions. Pushes arbitrary
element to end of list.
*/
static int al_push_generic( array_list_t *l, anything_t o ) static int al_push_generic( array_list_t *l, anything_t o )
{ {
if( l->pos >= l->size ) if( l->pos >= l->size )
@ -887,6 +895,10 @@ int al_insert( array_list_t *a, int pos, int count )
return 1; return 1;
} }
/**
Real implementation of all al_set_* versions. Sets arbitrary
element of list.
*/
static int al_set_generic( array_list_t *l, int pos, anything_t v ) static int al_set_generic( array_list_t *l, int pos, anything_t v )
{ {
@ -926,13 +938,16 @@ int al_set_long( array_list_t *l, int pos, long o )
return al_set_generic( l, pos, v ); return al_set_generic( l, pos, v );
} }
int al_set_func( array_list_t *l, int pos, func_ptr_t o ) int al_set_func( array_list_t *l, int pos, func_ptr_t f )
{ {
anything_t v; anything_t v;
v.func_val = o; v.func_val = f;
return al_set_generic( l, pos, v ); return al_set_generic( l, pos, v );
} }
/**
Real implementation of all al_get_* versions. Returns element from list.
*/
static anything_t al_get_generic( array_list_t *l, int pos ) static anything_t al_get_generic( array_list_t *l, int pos )
{ {
anything_t res; anything_t res;
@ -967,6 +982,10 @@ void al_truncate( array_list_t *l, int new_sz )
l->pos = new_sz; l->pos = new_sz;
} }
/**
Real implementation of all al_pop_* versions. Pops arbitrary
element from end of list.
*/
static anything_t al_pop_generic( array_list_t *l ) static anything_t al_pop_generic( array_list_t *l )
{ {
anything_t e; anything_t e;
@ -1014,6 +1033,10 @@ func_ptr_t al_pop_func( array_list_t *l )
return al_pop_generic(l).func_val; return al_pop_generic(l).func_val;
} }
/**
Real implementation of all al_peek_* versions. Peeks last element
of list.
*/
static anything_t al_peek_generic( array_list_t *l ) static anything_t al_peek_generic( array_list_t *l )
{ {
anything_t res; anything_t res;

42
util.h
View file

@ -15,12 +15,29 @@
#include <stdarg.h> #include <stdarg.h>
#include <unistd.h> #include <unistd.h>
/**
Typedef for a generic function pointer
*/
typedef void (*func_ptr_t)(); typedef void (*func_ptr_t)();
/**
A union of all types that can be stored in an array_list_t. This is
used to make sure that the pointer type can fit whatever we want to
insert.
*/
typedef union typedef union
{ {
/**
long value
*/
long long_val; long long_val;
/**
pointer value
*/
void *ptr_val; void *ptr_val;
/**
function pointer value
*/
func_ptr_t func_val; func_ptr_t func_val;
} }
anything_t; anything_t;
@ -163,7 +180,7 @@ buffer_t;
typedef buffer_t string_buffer_t; typedef buffer_t string_buffer_t;
/** /**
Set the out of memory handler callback function. If a memory Set the out-of-memory handler callback function. If a memory
allocation fails, this function will be called. allocation fails, this function will be called.
*/ */
void (*util_set_oom_handler( void (*h)(void *) ))(void *); void (*util_set_oom_handler( void (*h)(void *) ))(void *);
@ -175,7 +192,7 @@ void (*util_set_oom_handler( void (*h)(void *) ))(void *);
This is the default out of memory handler. This is the default out of memory handler.
*/ */
void util_die_on_oom( void * ); void util_die_on_oom( void *p );
/** /**
Returns the larger of two ints Returns the larger of two ints
@ -428,11 +445,10 @@ int al_push_long( array_list_t *l, long o );
Append element to list Append element to list
\param l The list \param l The list
\param o The element \param f The element
\return
\return 1 if succesfull, 0 otherwise \return 1 if succesfull, 0 otherwise
*/ */
int al_push_func( array_list_t *l, void (*f)() ); int al_push_func( array_list_t *l, func_ptr_t f );
/** /**
Append all elements of a list to another Append all elements of a list to another
@ -443,6 +459,9 @@ int al_push_func( array_list_t *l, void (*f)() );
*/ */
int al_push_all( array_list_t *a, array_list_t *b ); int al_push_all( array_list_t *a, array_list_t *b );
/**
Insert the specified number of new empty positions at the specified position in the list.
*/
int al_insert( array_list_t *a, int pos, int count ); int al_insert( array_list_t *a, int pos, int count );
/** /**
@ -458,7 +477,7 @@ int al_set( array_list_t *l, int pos, const void *o );
\param l The array_list_t \param l The array_list_t
\param pos The index \param pos The index
\param o The element \param v The element to set
*/ */
int al_set_long( array_list_t *l, int pos, long v ); int al_set_long( array_list_t *l, int pos, long v );
/** /**
@ -466,9 +485,9 @@ int al_set_long( array_list_t *l, int pos, long v );
\param l The array_list_t \param l The array_list_t
\param pos The index \param pos The index
\param o The element \param f The element to insert
*/ */
int al_set_func( array_list_t *l, int pos, void (*f)() ); int al_set_func( array_list_t *l, int pos, func_ptr_t f );
/** /**
Returns the element at the specified index Returns the element at the specified index
@ -599,15 +618,18 @@ void sb_init( string_buffer_t * );
string_buffer_t *sb_new(); string_buffer_t *sb_new();
/** /**
Append a part of a string to the buffer Append a part of a string to the buffer.
*/ */
void sb_append_substring( string_buffer_t *, const wchar_t *, size_t ); void sb_append_substring( string_buffer_t *, const wchar_t *, size_t );
/** /**
Append a character to the buffer Append a character to the buffer.
*/ */
void sb_append_char( string_buffer_t *, wchar_t ); void sb_append_char( string_buffer_t *, wchar_t );
/**
Append all specified items to buffer.
*/
#define sb_append( sb,... ) sb_append_internal( sb, __VA_ARGS__, (void *)0 ) #define sb_append( sb,... ) sb_append_internal( sb, __VA_ARGS__, (void *)0 )
/** /**

View file

@ -378,7 +378,11 @@ static wchar_t *make_path( const wchar_t *base_dir, const wchar_t *name )
return long_name; return long_name;
} }
/**
Return a description of a file based on its suffix. This function
does not perform any caching, it directly calls the mimedb command
to do a lookup.
*/
static wchar_t *complete_get_desc_suffix_internal( const wchar_t *suff_orig ) static wchar_t *complete_get_desc_suffix_internal( const wchar_t *suff_orig )
{ {
@ -425,12 +429,19 @@ static wchar_t *complete_get_desc_suffix_internal( const wchar_t *suff_orig )
return desc; return desc;
} }
/**
Free the suffix_hash hash table and all memory used by it.
*/
static void complete_get_desc_destroy_suffix_hash() static void complete_get_desc_destroy_suffix_hash()
{
if( suffix_hash )
{ {
hash_foreach( suffix_hash, &clear_hash_entry ); hash_foreach( suffix_hash, &clear_hash_entry );
hash_destroy( suffix_hash ); hash_destroy( suffix_hash );
free( suffix_hash ); free( suffix_hash );
} }
}
@ -759,7 +770,14 @@ static int test_flags( wchar_t *filename,
return 1; return 1;
} }
/**
The real implementation of wildcard expansion is in this
function. Other functions are just wrappers around this one.
This function traverses the relevant directory tree looking for
matches, and recurses when needed to handle wildcrards spanning
multiple components and recursive wildcards.
*/
static int wildcard_expand_internal( const wchar_t *wc, static int wildcard_expand_internal( const wchar_t *wc,
const wchar_t *base_dir, const wchar_t *base_dir,
int flags, int flags,