mirror of https://github.com/MidnightCommander/mc
156 lines
5.2 KiB
C
156 lines
5.2 KiB
C
|
|
/** \file input.h
|
|
* \brief Header: WInput widget
|
|
*/
|
|
|
|
#ifndef MC__WIDGET_INPUT_H
|
|
#define MC__WIDGET_INPUT_H
|
|
|
|
#include <limits.h> /* MB_LEN_MAX */
|
|
|
|
/*** typedefs(not structures) and defined constants **********************************************/
|
|
|
|
#define INPUT(x) ((WInput *)(x))
|
|
|
|
/* For history load-save functions */
|
|
#define INPUT_LAST_TEXT ((char *) 2)
|
|
|
|
/*** enums ***************************************************************************************/
|
|
|
|
typedef enum
|
|
{
|
|
WINPUTC_MAIN, /* color used */
|
|
WINPUTC_MARK, /* color for marked text */
|
|
WINPUTC_UNCHANGED, /* color for inactive text (Is first keystroke) */
|
|
WINPUTC_HISTORY, /* color for history list */
|
|
WINPUTC_COUNT_COLORS /* count of used colors */
|
|
} input_colors_enum_t;
|
|
|
|
/* completion flags */
|
|
typedef enum
|
|
{
|
|
INPUT_COMPLETE_NONE = 0,
|
|
INPUT_COMPLETE_FILENAMES = 1 << 0,
|
|
INPUT_COMPLETE_HOSTNAMES = 1 << 1,
|
|
INPUT_COMPLETE_COMMANDS = 1 << 2,
|
|
INPUT_COMPLETE_VARIABLES = 1 << 3,
|
|
INPUT_COMPLETE_USERNAMES = 1 << 4,
|
|
INPUT_COMPLETE_CD = 1 << 5,
|
|
INPUT_COMPLETE_SHELL_ESC = 1 << 6,
|
|
} input_complete_t;
|
|
|
|
/*** structures declarations (and typedefs of structures)*****************************************/
|
|
|
|
typedef int input_colors_t[WINPUTC_COUNT_COLORS];
|
|
|
|
typedef struct
|
|
{
|
|
Widget widget;
|
|
|
|
GString *buffer;
|
|
const int *color;
|
|
int point; /* cursor position in the input line in characters */
|
|
int mark; /* the mark position in characters; negative value means no marked text */
|
|
int term_first_shown; /* column of the first shown character */
|
|
gboolean first; /* is first keystroke? */
|
|
int disable_update; /* do we want to skip updates? */
|
|
gboolean is_password; /* is this a password input line? */
|
|
gboolean init_from_history; /* init text will be get from history */
|
|
gboolean need_push; /* need to push the current Input on hist? */
|
|
gboolean strip_password; /* need to strip password before placing string to history */
|
|
GPtrArray *completions; /* possible completions array */
|
|
input_complete_t completion_flags;
|
|
char charbuf[MB_LEN_MAX]; /* buffer for multibytes characters */
|
|
size_t charpoint; /* point to end of mulibyte sequence in charbuf */
|
|
WLabel *label; /* label associated with this input line */
|
|
struct input_history_t
|
|
{
|
|
char *name; /* name of history for loading and saving */
|
|
GList *list; /* the history */
|
|
GList *current; /* current history item */
|
|
gboolean changed; /* the history has changed */
|
|
} history;
|
|
} WInput;
|
|
|
|
/*** global variables defined in .c file *********************************************************/
|
|
|
|
extern int quote;
|
|
|
|
extern const global_keymap_t *input_map;
|
|
|
|
/* Color styles for normal and command line input widgets */
|
|
extern input_colors_t input_colors;
|
|
|
|
/*** declarations of public functions ************************************************************/
|
|
|
|
WInput *input_new (int y, int x, const int *colors,
|
|
int len, const char *text, const char *histname,
|
|
input_complete_t completion_flags);
|
|
/* callback is public; needed for command line */
|
|
cb_ret_t input_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *data);
|
|
void input_set_default_colors (void);
|
|
cb_ret_t input_handle_char (WInput * in, int key);
|
|
void input_assign_text (WInput * in, const char *text);
|
|
void input_insert (WInput * in, const char *text, gboolean insert_extra_space);
|
|
void input_set_point (WInput * in, int pos);
|
|
void input_update (WInput * in, gboolean clear_first);
|
|
void input_enable_update (WInput * in);
|
|
void input_disable_update (WInput * in);
|
|
void input_clean (WInput * in);
|
|
|
|
/* input_complete.c */
|
|
void input_complete (WInput * in);
|
|
void input_complete_free (WInput * in);
|
|
|
|
/* --------------------------------------------------------------------------------------------- */
|
|
/*** inline functions ****************************************************************************/
|
|
/* --------------------------------------------------------------------------------------------- */
|
|
|
|
/**
|
|
* Get text of input line.
|
|
*
|
|
* @param in input line
|
|
*
|
|
* @return newly allocated string that contains a copy of @in's text.
|
|
*/
|
|
static inline char *
|
|
input_get_text (const WInput *in)
|
|
{
|
|
return g_strndup (in->buffer->str, in->buffer->len);
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------- */
|
|
|
|
/**
|
|
* Get pointer to input line buffer.
|
|
*
|
|
* @param in input line
|
|
*
|
|
* @return pointer to @in->buffer->str.
|
|
*/
|
|
static inline const char *
|
|
input_get_ctext (const WInput *in)
|
|
{
|
|
return in->buffer->str;
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------- */
|
|
|
|
/**
|
|
* Is input line empty or not.
|
|
*
|
|
* @param in input line
|
|
*
|
|
* @return TRUE if buffer of @in is empty, FALSE otherwise.
|
|
*/
|
|
static inline gboolean
|
|
input_is_empty (const WInput *in)
|
|
{
|
|
return (in->buffer->len == 0);
|
|
}
|
|
|
|
/* --------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
#endif /* MC__WIDGET_INPUT_H */
|