2005-09-15 09:58:31 -04:00
|
|
|
#ifndef EL__BFU_MSGBOX_H
|
|
|
|
#define EL__BFU_MSGBOX_H
|
|
|
|
|
2005-12-20 05:48:45 -05:00
|
|
|
#include "util/align.h"
|
2005-09-15 09:58:31 -04:00
|
|
|
#include "util/memlist.h"
|
|
|
|
|
2020-10-05 14:14:55 -04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2005-09-15 09:58:31 -04:00
|
|
|
struct terminal;
|
|
|
|
|
|
|
|
|
|
|
|
/* Bitmask specifying some @msg_box() function parameters attributes or
|
|
|
|
* altering function operation. See @msg_box() description for details about
|
|
|
|
* the flags effect. */
|
|
|
|
enum msgbox_flags {
|
|
|
|
/* {msg_box(.text)} is dynamically allocated */
|
|
|
|
MSGBOX_FREE_TEXT = 0x1,
|
|
|
|
/* The msg_box() string parameters should NOT be run through gettext
|
|
|
|
* and translated. */
|
|
|
|
MSGBOX_NO_INTL = 0x2,
|
|
|
|
/* Should the text be scrollable */
|
|
|
|
/* XXX: The text need to be allocated since it will be mangled */
|
|
|
|
MSGBOX_SCROLLABLE = 0x4,
|
|
|
|
/* i18nalize title and buttons but not the text. */
|
|
|
|
MSGBOX_NO_TEXT_INTL = 0x8,
|
|
|
|
};
|
|
|
|
|
2022-01-28 10:41:23 -05:00
|
|
|
typedef unsigned char msgbox_flags_T;
|
|
|
|
|
2005-09-15 09:58:31 -04:00
|
|
|
/* This is _the_ dialog function used in almost all parts of the code. It is
|
|
|
|
* used to easily format dialogs containing only text and few buttons below.
|
|
|
|
*
|
|
|
|
* @term The terminal where the message box should appear.
|
|
|
|
*
|
|
|
|
* @mem_list A list of pointers to allocated memory that should be
|
|
|
|
* free()'d when then dialog is closed. The list can be
|
|
|
|
* initialized using getml(args, NULL) using NULL as the end.
|
|
|
|
* This is useful especially when you pass stuff to @udata
|
|
|
|
* which you want to be free()d when not needed anymore.
|
|
|
|
*
|
|
|
|
* @flags If the MSGBOX_FREE_TEXT flag is passed, @text is free()d upon
|
|
|
|
* the dialog's death. This is equivalent to adding @text to the
|
|
|
|
* @mem_list. Also, when this parameter is passed, @text is not
|
|
|
|
* automagically localized and it is up to the user to do it.
|
|
|
|
*
|
|
|
|
* If the MSGBOX_NO_INTL flag is passed, @title, @text and button
|
|
|
|
* labels will not be localized automatically inside of msg_box()
|
|
|
|
* and it is up to the user to do the best job possible.
|
|
|
|
*
|
|
|
|
* @title The title of the message box. It is automatically localized
|
|
|
|
* inside (unless MSGBOX_NO_INTL is passed).
|
|
|
|
*
|
|
|
|
* @align Provides info about how @text should be aligned.
|
|
|
|
*
|
|
|
|
* @text The info text of the message box. If the text requires
|
|
|
|
* formatting use msg_text(format, args...). This will allocate
|
|
|
|
* a string so remember to @align |= MSGBOX_FREE_TEXT.
|
|
|
|
*
|
|
|
|
* If no formatting is needed just pass the string and don't
|
|
|
|
* @align |= MSGBOX_FREE_TEXT or you will get in trouble. ;)
|
|
|
|
*
|
|
|
|
* The @text is automatically localized inside of msg_box(),
|
|
|
|
* unless MSGBOX_NO_INTL or MSGBOX_FREE_TEXT is passed. That is
|
|
|
|
* because you do NOT want to localize output of msg_text(),
|
|
|
|
* but rather individually the format string and parameters to
|
|
|
|
* its string conversions.
|
|
|
|
*
|
|
|
|
* @udata Is a reference to any data that should be passed to
|
|
|
|
* the handlers associated with each button. NULL if none.
|
|
|
|
*
|
2007-03-10 16:50:56 -05:00
|
|
|
* @buttons Denotes the number of buttons given as variadic arguments.
|
2005-09-15 09:58:31 -04:00
|
|
|
* For each button 3 arguments are extracted:
|
|
|
|
* o First the label text. It is automatically localized
|
|
|
|
* unless MSGBOX_NO_INTL is passed. If NULL, this button
|
|
|
|
* is skipped.
|
|
|
|
* o Second pointer to the handler function (taking
|
|
|
|
* one (void *), which is incidentally the udata).
|
|
|
|
* o Third any flags.
|
2007-03-10 16:50:56 -05:00
|
|
|
* Each triple should be wrapped in the MSG_BOX_BUTTON
|
|
|
|
* macro, which converts the values to the correct types.
|
|
|
|
* (The compiler can't do that on its own for variadic
|
|
|
|
* arguments.)
|
2005-09-15 09:58:31 -04:00
|
|
|
*
|
|
|
|
* Note that you should ALWAYS format the msg_box() call like:
|
|
|
|
*
|
|
|
|
* msg_box(term, mem_list, flags,
|
|
|
|
* title, align,
|
|
|
|
* text,
|
|
|
|
* udata, M,
|
2007-03-10 16:50:56 -05:00
|
|
|
* MSG_BOX_BUTTON(label1, handler1, flags1),
|
2005-09-15 09:58:31 -04:00
|
|
|
* ...,
|
2007-03-10 16:50:56 -05:00
|
|
|
* MSG_BOX_BUTTON(labelM, handlerM, flagsM));
|
2005-09-15 09:58:31 -04:00
|
|
|
*
|
|
|
|
* ...no matter that it could fit on one line in case of a tiny message box. */
|
|
|
|
struct dialog_data *
|
|
|
|
msg_box(struct terminal *term, struct memory_list *mem_list,
|
2022-01-28 10:41:23 -05:00
|
|
|
msgbox_flags_T flags, char *title, format_align_T align,
|
2021-01-02 10:20:27 -05:00
|
|
|
char *text, void *udata, int buttons, ...);
|
2005-09-15 09:58:31 -04:00
|
|
|
|
2007-03-10 16:50:56 -05:00
|
|
|
/* Cast @value to @type and warn if the conversion is suspicious.
|
|
|
|
* If @value has side effects, this does them only once.
|
|
|
|
* The expression used here is intended to be standard C, but it is
|
|
|
|
* somewhat tricky. If it causes trouble on some compiler, you can
|
|
|
|
* #ifdef an alternative definition that skips the type check. */
|
|
|
|
#define MSG_BOX_CAST(type, value) \
|
|
|
|
(((void) sizeof(((int (*)(type)) 0)(value))), (type) (value))
|
|
|
|
|
|
|
|
/* A button in the variadic arguments of msg_box().
|
|
|
|
* This macro expands into three arguments. */
|
|
|
|
#define MSG_BOX_BUTTON(label, handler, flags) \
|
2021-01-02 10:20:27 -05:00
|
|
|
MSG_BOX_CAST(const char *, label), \
|
2007-03-10 16:50:56 -05:00
|
|
|
MSG_BOX_CAST(done_handler_T *, handler), \
|
|
|
|
MSG_BOX_CAST(int, flags)
|
|
|
|
|
2005-09-15 09:58:31 -04:00
|
|
|
|
|
|
|
/* msg_text() is basically an equivalent to asprintf(), specifically to be used
|
|
|
|
* inside of message boxes. Please always use msg_text() instead of asprintf()
|
|
|
|
* in msg_box() parameters (ie. own format conversions can be introduced later
|
|
|
|
* specifically crafted for message boxes, and so on).
|
|
|
|
* The returned string is allocated and may be NULL!
|
|
|
|
* This one automagically localizes the format string. The possible
|
|
|
|
* additional parameters still need to be localized manually at the user's
|
|
|
|
* side. */
|
2021-03-03 08:38:11 -05:00
|
|
|
char *msg_text(struct terminal *term, const char *format, ...);
|
2005-09-15 09:58:31 -04:00
|
|
|
|
|
|
|
/* A periodically refreshed message box with one OK button. The text in the
|
|
|
|
* message box is updated using the get_info() function. If get_info() returns
|
|
|
|
* NULL the message box is closed. */
|
|
|
|
void
|
2022-01-28 10:41:23 -05:00
|
|
|
refreshed_msg_box(struct terminal *term, msgbox_flags_T flags,
|
2022-01-28 10:05:35 -05:00
|
|
|
char *title, format_align_T align,
|
2021-01-02 10:20:27 -05:00
|
|
|
char *(get_info)(struct terminal *, void *),
|
2005-09-15 09:58:31 -04:00
|
|
|
void *data);
|
|
|
|
|
|
|
|
struct dialog_data *
|
2022-01-28 10:41:23 -05:00
|
|
|
info_box(struct terminal *term, msgbox_flags_T flags,
|
2022-01-28 10:05:35 -05:00
|
|
|
char *title, format_align_T align,
|
2021-01-02 10:20:27 -05:00
|
|
|
char *text);
|
2005-09-15 09:58:31 -04:00
|
|
|
|
2020-10-05 14:14:55 -04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2005-09-15 09:58:31 -04:00
|
|
|
|
|
|
|
#endif
|