aboutsummaryrefslogtreecommitdiff
path: root/src/include/ipxe/editstring.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/include/ipxe/editstring.h')
-rw-r--r--src/include/ipxe/editstring.h33
1 files changed, 21 insertions, 12 deletions
diff --git a/src/include/ipxe/editstring.h b/src/include/ipxe/editstring.h
index a00a8ad..7ad8fb3 100644
--- a/src/include/ipxe/editstring.h
+++ b/src/include/ipxe/editstring.h
@@ -11,10 +11,8 @@ FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
/** An editable string */
struct edit_string {
- /** Buffer for string */
- char *buf;
- /** Size of buffer (including terminating NUL) */
- size_t len;
+ /** Dynamically allocated string buffer */
+ char **buf;
/** Cursor position */
unsigned int cursor;
@@ -32,17 +30,28 @@ struct edit_string {
* Initialise editable string
*
* @v string Editable string
- * @v buf Buffer for string
- * @v len Length of buffer
+ * @v buf Dynamically allocated string buffer
+ *
+ * The @c buf parameter must be the address of a caller-provided
+ * pointer to a NUL-terminated string allocated using malloc() (or
+ * equivalent, such as strdup()). Any edits made to the string will
+ * realloc() the string buffer as needed.
+ *
+ * The caller may choose leave the initial string buffer pointer as @c
+ * NULL, in which case it will be allocated upon the first attempt to
+ * insert a character into the buffer. If the caller does this, then
+ * it must be prepared to find the pointer still @c NULL after
+ * editing, since the user may never attempt to insert any characters.
*/
-static inline void init_editstring ( struct edit_string *string, char *buf,
- size_t len ) {
+static inline __nonnull void init_editstring ( struct edit_string *string,
+ char **buf ) {
+
string->buf = buf;
- string->len = len;
}
-extern void replace_string ( struct edit_string *string,
- const char *replacement ) __nonnull;
-extern int edit_string ( struct edit_string *string, int key ) __nonnull;
+extern __attribute__ (( nonnull ( 1 ) )) int
+replace_string ( struct edit_string *string, const char *replacement );
+
+extern __nonnull int edit_string ( struct edit_string *string, int key );
#endif /* _IPXE_EDITSTRING_H */