123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 |
- /*
- * shell.h - private interface to the shell class
- */
- #include "clish/shell.h"
- #include "clish/pargv.h"
- #include "clish/variable.h"
- #include "lub/bintree.h"
- #include "tinyrl/tinyrl.h"
- /*-------------------------------------
- * PRIVATE TYPES
- *------------------------------------- */
- /*-------------------------------------------------------- */
- /*
- * The context structure is used to simplify the cleanup of
- * a CLI session when a thread is cancelled.
- */
- struct clish_context_s {
- pthread_t pthread;
- const clish_shell_hooks_t *hooks;
- void *cookie;
- FILE *istream;
- FILE *ostream;
- clish_shell_t *shell;
- clish_pargv_t *pargv;
- char *prompt;
- };
- typedef enum {
- SHELL_STATE_INITIALISING,
- SHELL_STATE_READY,
- SHELL_STATE_HELPING,
- SHELL_STATE_SCRIPT_ERROR,
- SHELL_STATE_CLOSING
- } shell_state_t;
- /*
- * iterate around commands
- */
- typedef struct {
- const char *last_cmd;
- clish_nspace_visibility_t field;
- } clish_shell_iterator_t;
- /* this is used to maintain a stack of file handles */
- typedef struct clish_shell_file_s clish_shell_file_t;
- struct clish_shell_file_s {
- clish_shell_file_t *next;
- FILE *file;
- bool_t stop_on_error; /* stop on error for file input */
- };
- struct clish_shell_s {
- lub_bintree_t view_tree; /* Maintain a tree of views */
- lub_bintree_t ptype_tree; /* Maintain a tree of ptypes */
- const clish_shell_hooks_t *client_hooks; /* Client callback hooks */
- void *client_cookie; /* Client callback cookie */
- clish_view_t *global; /* Reference to the global view. */
- clish_view_t *view; /* Reference to the current view. */
- clish_command_t *startup; /* This is the startup command */
- clish_shell_iterator_t iter; /* used for iterating commands */
- shell_state_t state; /* The current state */
- char *overview; /* Overview text for this shell. */
- char *viewid; /* The current view ID string */
- tinyrl_t *tinyrl; /* Tiny readline instance */
- clish_shell_file_t *current_file; /* file currently in use for input */
- char **cfg_pwdv; /* Levels for the config file structure */
- unsigned cfg_pwdc;
- konf_client_t *client;
- clish_pargv_t *completion_pargv;
- unsigned completion_index;
- unsigned completion_pindex;
- };
- /**
- * Initialise a command iterator structure
- */
- void
- clish_shell_iterator_init(clish_shell_iterator_t * iter,
- clish_nspace_visibility_t field);
- /**
- * get the next command which is an extension of the specified line
- */
- const clish_command_t *clish_shell_find_next_completion(const clish_shell_t *
- instance,
- const char *line,
- clish_shell_iterator_t *
- iter);
- /**
- * Push the specified file handle on to the stack of file handles
- * for this shell. The specified file will become the source of
- * commands, until it is exhausted.
- *
- * \return
- * BOOL_TRUE - the file was successfully associated with the shell.
- * BOOL_FALSE - there was insufficient resource to associate this file.
- */
- bool_t
- clish_shell_push_file(clish_shell_t * instance,
- FILE * file, bool_t stop_on_error);
- /**
- * Pop the current file handle from the stack of file handles, shutting
- * the file down and freeing any associated memory. The next file handle
- * in the stack becomes associated with the input stream for this shell.
- *
- * \return
- * BOOL_TRUE - the current file handle has been replaced.
- * BOOL_FALSE - there is only one handle on the stack which cannot be replaced.
- */
- bool_t clish_shell_pop_file(clish_shell_t * instance);
- clish_view_t *clish_shell_find_view(clish_shell_t * instance, const char *name);
- void clish_shell_insert_view(clish_shell_t * instance, clish_view_t * view);
- clish_pargv_status_t
- clish_shell_parse(const clish_shell_t * instance,
- const char *line,
- const clish_command_t ** cmd, clish_pargv_t ** pargv);
- char *clish_shell_word_generator(clish_shell_t * instance,
- const char *line,
- unsigned offset, unsigned state);
- const clish_command_t *clish_shell_resolve_command(const clish_shell_t *
- instance, const char *line);
- const clish_command_t *clish_shell_resolve_prefix(const clish_shell_t *
- instance, const char *line);
- const clish_command_t *clish_shell_getfirst_command(clish_shell_t * instance,
- const char *line,
- clish_nspace_visibility_t
- field);
- const clish_command_t *clish_shell_getnext_command(clish_shell_t * instance,
- const char *line);
- void clish_shell_insert_ptype(clish_shell_t * instance, clish_ptype_t * ptype);
- void clish_shell_tinyrl_history(clish_shell_t * instance, unsigned int *limit);
- tinyrl_t *clish_shell_tinyrl_new(FILE * instream,
- FILE * outstream, unsigned stifle);
- void clish_shell_tinyrl_delete(tinyrl_t * instance);
|