1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
#ifndef _IPXE_EDITBOX_H
#define _IPXE_EDITBOX_H
/** @file
*
* Editable text box widget
*
*/
FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
#include <curses.h>
#include <ipxe/editstring.h>
/** An editable text box widget */
struct edit_box {
/** Editable string */
struct edit_string string;
/** Containing window */
WINDOW *win;
/** Row */
unsigned int row;
/** Starting column */
unsigned int col;
/** Width */
unsigned int width;
/** First displayed character */
unsigned int first;
/** Flags */
unsigned int flags;
};
/** Editable text box widget flags */
enum edit_box_flags {
/** Show stars instead of contents (for password widgets) */
EDITBOX_STARS = 0x0001,
};
extern void init_editbox ( struct edit_box *box, char *buf, size_t len,
WINDOW *win, unsigned int row, unsigned int col,
unsigned int width, unsigned int flags )
__attribute__ (( nonnull (1, 2) ));
extern void draw_editbox ( struct edit_box *box ) __nonnull;
static inline int edit_editbox ( struct edit_box *box, int key ) __nonnull;
/**
* Edit text box widget
*
* @v box Editable text box widget
* @v key Key pressed by user
* @ret key Key returned to application, or zero
*
* You must call draw_editbox() to update the display after calling
* edit_editbox().
*
*/
static inline int edit_editbox ( struct edit_box *box, int key ) {
return edit_string ( &box->string, key );
}
#endif /* _IPXE_EDITBOX_H */
|